MoneyOverdueServiceImpl.java 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. package vip.xiaonuo.money.service.impl;
  2. import cn.hutool.core.date.DateUtil;
  3. import cn.hutool.core.util.ObjectUtil;
  4. import com.alibaba.fastjson.JSONArray;
  5. import com.alibaba.fastjson.JSONException;
  6. import com.alibaba.fastjson.JSONObject;
  7. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  8. import com.baomidou.mybatisplus.core.toolkit.StringUtils;
  9. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  10. import org.springframework.beans.factory.annotation.Autowired;
  11. import vip.xiaonuo.money.entity.MoneyOverdue;
  12. import vip.xiaonuo.money.entity.MoneyWriteOverdue;
  13. import vip.xiaonuo.money.entity.vo.MoneyBorrowUserVo;
  14. import vip.xiaonuo.money.mapper.MoneyOverdueMapper;
  15. import vip.xiaonuo.money.mapper.MoneyWriteOverdueMapper;
  16. import vip.xiaonuo.money.param.MoneyOverdueDetailPageParam;
  17. import vip.xiaonuo.money.param.MoneyOverduePageParam;
  18. import vip.xiaonuo.money.param.MoneyOverdueParam;
  19. import vip.xiaonuo.money.service.IMoneyOverdueService;
  20. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  21. import org.springframework.stereotype.Service;
  22. import java.math.BigDecimal;
  23. import java.math.RoundingMode;
  24. import java.text.DecimalFormat;
  25. import java.text.SimpleDateFormat;
  26. import java.util.*;
  27. /**
  28. * <p>
  29. * 财务应收逾期表 服务实现类
  30. * </p>
  31. *
  32. * @author author
  33. * @since 2024-11-21
  34. */
  35. @Service
  36. public class MoneyOverdueServiceImpl extends ServiceImpl<MoneyOverdueMapper, MoneyOverdue> implements IMoneyOverdueService {
  37. @Autowired
  38. private MoneyOverdueMapper overdueMapper;
  39. @Autowired
  40. private MoneyWriteOverdueMapper writeOverdueMapper;
  41. @Override
  42. public JSONObject getOverdueCount(MoneyOverdueParam overdueParam) {
  43. String orgId = overdueParam.getOrgId();
  44. QueryWrapper<MoneyWriteOverdue> queryWrapper = new QueryWrapper<>();
  45. queryWrapper.eq(StringUtils.isNotBlank(orgId), "org_id", orgId);
  46. Date date = new Date();
  47. Calendar calendar = Calendar.getInstance();
  48. calendar.setTime(date);
  49. calendar.add(Calendar.MONTH, -1);
  50. queryWrapper.ge("end_time", calendar.getTime());
  51. queryWrapper.select("convert(IFNULL(sum(money),'0'),decimal(10,2)) money");
  52. MoneyWriteOverdue writeOverdue = writeOverdueMapper.selectOne(queryWrapper);
  53. JSONObject jsonObject = new JSONObject();
  54. jsonObject.put("money", writeOverdue.getMoney());
  55. return jsonObject;
  56. }
  57. @Override
  58. public JSONObject overdueRank(MoneyOverdueParam overdueParam) {
  59. String orgId = overdueParam.getOrgId();
  60. QueryWrapper<MoneyWriteOverdue> queryWrapper = new QueryWrapper<>();
  61. queryWrapper.eq(StringUtils.isNotBlank(orgId), "org_id", orgId);
  62. queryWrapper.select("sum(money) money,end_time endTime");
  63. List<MoneyWriteOverdue> writeOverdues = writeOverdueMapper.selectList(queryWrapper);
  64. double count = 0.00;
  65. double isOverdue = 0.00;
  66. double disOverdue = 0.00;
  67. JSONObject jsonObject = new JSONObject();
  68. DecimalFormat def = new DecimalFormat("0.00");
  69. if (ObjectUtil.isNotEmpty(writeOverdues)) {
  70. for (MoneyWriteOverdue overdue : writeOverdues) {
  71. if (overdue.getEndTime().before(new Date())) {
  72. isOverdue = isOverdue + Double.valueOf(overdue.getMoney());
  73. }else {
  74. disOverdue = disOverdue + Double.valueOf(overdue.getMoney());
  75. }
  76. count = isOverdue + disOverdue;
  77. }
  78. if (count == 0) {
  79. jsonObject.put("isOverdue", "0");
  80. jsonObject.put("disOverdue", "100");
  81. } else {
  82. jsonObject.put("isOverdue", def.format(isOverdue / count));
  83. jsonObject.put("disOverdue", def.format(disOverdue / count));
  84. }
  85. } else {
  86. jsonObject.put("isOverdue", "0");
  87. jsonObject.put("disOverdue", "100");
  88. }
  89. return jsonObject;
  90. }
  91. @Override
  92. public List<MoneyBorrowUserVo> userRank(MoneyOverdueParam overdueParam) {
  93. String orgId = overdueParam.getOrgId();
  94. String time = overdueParam.getTime();
  95. List<MoneyBorrowUserVo> userRank = overdueMapper.getUserRank(time + "-01 00:00:00", time + "-31 23:59:59",orgId);
  96. BigDecimal math = new BigDecimal("10000");
  97. List<MoneyBorrowUserVo> list = new ArrayList<>();
  98. if (userRank.size() != 0) {
  99. Double collect = 0.00;
  100. Double overdue = 0.00;
  101. for (int i = 0; i < userRank.size(); i++) {
  102. if (i < 15) {
  103. BigDecimal bg = new BigDecimal(userRank.get(i).getCollectPrice());
  104. bg = bg.divide(math, 2, RoundingMode.HALF_UP);
  105. BigDecimal bg1 = new BigDecimal(userRank.get(i).getOverduePrice());
  106. bg1 = bg1.divide(math, 2, RoundingMode.HALF_UP);
  107. userRank.get(i).setCollectPrice(bg.toString());
  108. userRank.get(i).setOverduePrice(bg1.toString());
  109. list.add(userRank.get(i));
  110. } else {
  111. collect = collect + Double.valueOf(userRank.get(i).getCollectPrice());
  112. overdue = overdue + Double.valueOf(userRank.get(i).getOverduePrice());
  113. }
  114. }
  115. MoneyBorrowUserVo vo = new MoneyBorrowUserVo();
  116. vo.setUserName("others");
  117. BigDecimal c1 = new BigDecimal(collect);
  118. c1 = c1.divide(math, 2, RoundingMode.HALF_UP);
  119. BigDecimal c2 = new BigDecimal(overdue);
  120. c2 = c2.divide(math, 2, RoundingMode.HALF_UP);
  121. vo.setCollectPrice(c1.toString());
  122. vo.setOverduePrice(c2.toString());
  123. list.add(vo);
  124. }
  125. return list;
  126. }
  127. @Override
  128. public Page<MoneyWriteOverdue> overdueDetail(MoneyOverdueDetailPageParam overduePageParam) {
  129. String orgId = overduePageParam.getOrgId();
  130. Integer pageNum = overduePageParam.getPageNum();
  131. Integer pageSize = overduePageParam.getPageSize();
  132. Integer type = overduePageParam.getType();
  133. String userName = overduePageParam.getUserName();
  134. QueryWrapper<MoneyWriteOverdue> queryWrapper = new QueryWrapper<>();
  135. queryWrapper.eq(StringUtils.isNotBlank(orgId), "org_id", orgId).orderByDesc("create_time");
  136. queryWrapper.eq(StringUtils.isNotBlank(userName), "user_name", userName);
  137. Calendar calendar = Calendar.getInstance();
  138. calendar.add(Calendar.DAY_OF_MONTH, 15);
  139. if (0 == type) {
  140. queryWrapper.ge("end_time", calendar.getTime());
  141. } else if (1 == type) {
  142. queryWrapper.le("end_time",DateUtil.beginOfDay(new Date()));
  143. } else if (2 == type) {
  144. queryWrapper.between("end_time", DateUtil.beginOfDay(new Date()), calendar.getTime());
  145. }
  146. Page<MoneyWriteOverdue> page = new Page<>(pageNum, pageSize);
  147. Page<MoneyWriteOverdue> selectPage = writeOverdueMapper.selectPage(page, queryWrapper);
  148. return selectPage;
  149. }
  150. @Override
  151. public List<MoneyOverdue> listUserName(Map<String, String> paramsMap) {
  152. String orgId = paramsMap.get("orgId");
  153. QueryWrapper<MoneyOverdue> queryWrapper = new QueryWrapper<>();
  154. queryWrapper.eq(StringUtils.isNotBlank(orgId), "org_id", orgId);
  155. queryWrapper.groupBy("user_name");
  156. return overdueMapper.selectList(queryWrapper);
  157. }
  158. @Override
  159. public List<MoneyOverdue> keHu(MoneyOverdue moneyOverdue) {
  160. String orgId = moneyOverdue.getOrgId();
  161. List<MoneyOverdue> moneyOverdues = overdueMapper.selectList(new QueryWrapper<MoneyOverdue>().select("user_name").eq(StringUtils.isNotBlank(orgId), "org_id", orgId).groupBy("user_name"));
  162. return moneyOverdues;
  163. }
  164. /*数组排序*/
  165. public static JSONArray jsonArraySort(JSONArray jsonArr, String sortKey, boolean is_desc) {
  166. //存放排序结果json数组
  167. JSONArray sortedJsonArray = new JSONArray();
  168. //用于排序的list
  169. List<JSONObject> jsonValues = new ArrayList<JSONObject>();
  170. //将参数json数组每一项取出,放入list
  171. for (int i = 0; i < jsonArr.size(); i++) {
  172. jsonValues.add(jsonArr.getJSONObject(i));
  173. }
  174. //快速排序,重写compare方法,完成按指定字段比较,完成排序
  175. Collections.sort(jsonValues, new Comparator<JSONObject>() {
  176. //排序字段
  177. private final String KEY_NAME = sortKey;
  178. //重写compare方法
  179. @Override
  180. public int compare(JSONObject a, JSONObject b) {
  181. //如果用String接会导致一位数和两位数混合比对的时候不能准确比出来,要用int类型接
  182. //String valA = new String();
  183. //String valB = new String();
  184. Float valA = 0.00f;
  185. Float valB = 0.00f;
  186. try {
  187. valA = Float.parseFloat(a.getString(KEY_NAME));
  188. valB = Float.parseFloat(b.getString(KEY_NAME));
  189. } catch (JSONException e) {
  190. e.printStackTrace();
  191. }
  192. //是升序还是降序
  193. if (is_desc) {
  194. return -valA.compareTo(valB);
  195. } else {
  196. return -valB.compareTo(valA);
  197. }
  198. }
  199. });
  200. //将排序后结果放入结果jsonArray
  201. for (int i = 0; i < jsonArr.size(); i++) {
  202. sortedJsonArray.add(jsonValues.get(i));
  203. }
  204. return sortedJsonArray;
  205. }
  206. }