AgentNewServiceImpl.java 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. package com.fdkankan.manage.service.impl;
  2. import com.alibaba.excel.EasyExcel;
  3. import com.alibaba.excel.ExcelWriter;
  4. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  5. import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
  6. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  7. import com.fdkankan.manage.common.PageInfo;
  8. import com.fdkankan.manage.common.CacheUtil;
  9. import com.fdkankan.manage.common.ResultCode;
  10. import com.fdkankan.manage.entity.*;
  11. import com.fdkankan.manage.exception.BusinessException;
  12. import com.fdkankan.manage.mapper.IAgentNewMapper;
  13. import com.fdkankan.manage.service.*;
  14. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  15. import com.fdkankan.manage.vo.request.AgentAddIncrementParam;
  16. import com.fdkankan.manage.vo.request.AgentNewLogParam;
  17. import com.fdkankan.manage.vo.request.AgentParam;
  18. import com.fdkankan.manage.vo.request.OrderParam;
  19. import com.fdkankan.manage.vo.response.AgentNewLogVo;
  20. import com.fdkankan.manage.vo.response.AgentVo;
  21. import com.fdkankan.manage.vo.response.OrderVo;
  22. import org.apache.commons.lang3.StringUtils;
  23. import org.springframework.beans.BeanUtils;
  24. import org.springframework.beans.factory.annotation.Autowired;
  25. import org.springframework.stereotype.Service;
  26. import org.springframework.transaction.annotation.Transactional;
  27. import javax.servlet.http.HttpServletRequest;
  28. import javax.servlet.http.HttpServletResponse;
  29. import java.util.ArrayList;
  30. import java.util.HashMap;
  31. import java.util.List;
  32. import java.util.WeakHashMap;
  33. /**
  34. * <p>
  35. * 服务实现类
  36. * </p>
  37. *
  38. * @author
  39. * @since 2022-11-08
  40. */
  41. @Service
  42. public class AgentNewServiceImpl extends ServiceImpl<IAgentNewMapper, AgentNew> implements IAgentNewService {
  43. @Autowired
  44. ISysUserService sysUserService;
  45. @Autowired
  46. IIncrementTypeService incrementTypeService;
  47. @Autowired
  48. IAgentNewLogService agentNewLogService;
  49. @Autowired
  50. IExcelService excelService;
  51. @Override
  52. public Object pageList(AgentParam agentParam) {
  53. LambdaQueryWrapper<AgentNew> wrapper = new LambdaQueryWrapper<>();
  54. if(StringUtils.isNotBlank(agentParam.getName())){
  55. wrapper.like(AgentNew::getName,agentParam.getName());
  56. }
  57. wrapper.orderByDesc(AgentNew::getCreateTime);
  58. Page<AgentNew> page = this.page(new Page<>(agentParam.getPageNum(), agentParam.getPageSize()), wrapper);
  59. List<AgentVo> voList = new ArrayList<>();
  60. for (AgentNew record : page.getRecords()) {
  61. AgentVo vo = new AgentVo();
  62. BeanUtils.copyProperties(record,vo);
  63. SysUser sysUser = sysUserService.getById(vo.getSysUserId());
  64. if(sysUser != null){
  65. vo.setSysUserName(sysUser.getNickName());
  66. }
  67. voList.add(vo);
  68. }
  69. Page<AgentVo> voPage = new Page<>(agentParam.getPageNum(), agentParam.getPageSize());
  70. voPage.setTotal(page.getTotal());
  71. voPage.setRecords(voList);
  72. return PageInfo.PageInfo(voPage);
  73. }
  74. @Override
  75. public void addIncrementNum(AgentAddIncrementParam param) {
  76. if(param.getId() == null ){
  77. throw new BusinessException(ResultCode.MISSING_REQUIRED_PARAMETERS);
  78. }
  79. AgentNew agentNew = this.getById(param.getId());
  80. if(agentNew == null){
  81. throw new BusinessException(ResultCode.AGENT_NEW_EMPTY);
  82. }
  83. if(param.getDownAddNum() <=0 && param.getMajorAddNum() <=0 && param.getHighAddNum() <=0 ){
  84. return;
  85. }
  86. LambdaUpdateWrapper<AgentNew> wrapper = new LambdaUpdateWrapper<>();
  87. wrapper.eq(AgentNew::getId,param.getId());
  88. if( param.getDownAddNum() >0){
  89. wrapper.set(AgentNew::getDownTotalNum,agentNew.getDownTotalNum() + param.getDownAddNum());
  90. }
  91. if(param.getHighAddNum() >0){
  92. wrapper.set(AgentNew::getHighTotalNum,agentNew.getHighTotalNum() + param.getHighAddNum());
  93. }
  94. if( param.getMajorAddNum() >0){
  95. wrapper.set(AgentNew::getMajorTotalNum,agentNew.getMajorTotalNum() + param.getMajorAddNum());
  96. }
  97. this.update(wrapper);
  98. }
  99. @Override
  100. public AgentNew getByName(String agentName) {
  101. LambdaQueryWrapper<AgentNew> wrapper = new LambdaQueryWrapper<>();
  102. wrapper.eq(AgentNew::getName, agentName);
  103. List<AgentNew> list = this.list(wrapper);
  104. if(list == null || list.size() != 1) {
  105. return null;
  106. }
  107. return list.get(0);
  108. }
  109. @Override
  110. public Object logList(AgentNewLogParam param) {
  111. CacheUtil.agentParam = param;
  112. return agentNewLogService.getVoList(param);
  113. }
  114. @Override
  115. public void checkUserName(String userName) {
  116. LambdaQueryWrapper<AgentNew> wrapper = new LambdaQueryWrapper<>();
  117. wrapper.eq(AgentNew::getUserName,userName);
  118. List<AgentNew> list = this.list(wrapper);
  119. if(list !=null && list.size() >0){
  120. throw new BusinessException(ResultCode.AGENT_U_NOT_EMPTY);
  121. }
  122. }
  123. @Override
  124. public void export(HttpServletRequest req, HttpServletResponse resp) {
  125. AgentNewLogParam param = CacheUtil.agentParam;
  126. List<AgentNewLogVo> voList = agentNewLogService.getVoList(param);
  127. ExcelWriter excelWriter = null;
  128. try {
  129. excelWriter = EasyExcel.write(resp.getOutputStream(),AgentNewLogVo.class).build();
  130. excelService.commonExport(req,resp,"经销商结算统计",voList,excelWriter);
  131. }catch (Exception e){
  132. e.printStackTrace();
  133. }finally {
  134. if(excelWriter != null){
  135. excelWriter.finish();
  136. }
  137. }
  138. }
  139. }