CommissionCashServiceImpl.java 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. package com.fuint.common.service.impl;
  2. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  3. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  4. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  5. import com.fuint.common.dto.OrderUserDto;
  6. import com.fuint.common.enums.*;
  7. import com.fuint.common.service.*;
  8. import com.fuint.common.util.CommonUtil;
  9. import com.fuint.framework.annoation.OperationServiceLog;
  10. import com.fuint.framework.exception.BusinessCheckException;
  11. import com.fuint.framework.pagination.PaginationRequest;
  12. import com.fuint.framework.pagination.PaginationResponse;
  13. import com.fuint.module.backendApi.request.CommissionCashRequest;
  14. import com.fuint.module.backendApi.request.CommissionLogRequest;
  15. import com.fuint.module.backendApi.request.CommissionSettleConfirmRequest;
  16. import com.fuint.module.backendApi.request.CommissionSettleRequest;
  17. import com.fuint.repository.mapper.MtCommissionCashMapper;
  18. import com.fuint.common.dto.CommissionCashDto;
  19. import com.fuint.repository.mapper.MtCommissionLogMapper;
  20. import com.fuint.repository.model.*;
  21. import com.fuint.utils.StringUtil;
  22. import com.github.pagehelper.PageHelper;
  23. import lombok.AllArgsConstructor;
  24. import org.apache.commons.lang.StringUtils;
  25. import org.slf4j.Logger;
  26. import org.slf4j.LoggerFactory;
  27. import com.github.pagehelper.Page;
  28. import org.springframework.beans.BeanUtils;
  29. import org.springframework.data.domain.PageImpl;
  30. import org.springframework.data.domain.PageRequest;
  31. import org.springframework.stereotype.Service;
  32. import org.springframework.transaction.annotation.Transactional;
  33. import java.math.BigDecimal;
  34. import java.util.*;
  35. /**
  36. * 分销提成提现服务接口
  37. *
  38. * Created by FSQ
  39. * CopyRight https://www.fuint.cn
  40. */
  41. @Service
  42. @AllArgsConstructor
  43. public class CommissionCashServiceImpl extends ServiceImpl<MtCommissionCashMapper, MtCommissionCash> implements CommissionCashService {
  44. private static final Logger logger = LoggerFactory.getLogger(CommissionCashServiceImpl.class);
  45. private MtCommissionCashMapper mtCommissionCashMapper;
  46. private MtCommissionLogMapper mtCommissionLogMapper;
  47. /**
  48. * 店铺服务接口
  49. * */
  50. private StoreService storeService;
  51. /**
  52. * 员工服务接口
  53. * */
  54. private StaffService staffService;
  55. /**
  56. * 会员服务接口
  57. * */
  58. private MemberService memberService;
  59. /**
  60. * 分销提成记录业务接口
  61. */
  62. private CommissionLogService commissionLogService;
  63. /**
  64. * 分页查询提现列表
  65. *
  66. * @param paginationRequest
  67. * @return
  68. */
  69. @Override
  70. public PaginationResponse<CommissionCashDto> queryCommissionCashByPagination(PaginationRequest paginationRequest) throws BusinessCheckException {
  71. Page<MtCommissionCash> pageHelper = PageHelper.startPage(paginationRequest.getCurrentPage(), paginationRequest.getPageSize());
  72. LambdaQueryWrapper<MtCommissionCash> lambdaQueryWrapper = Wrappers.lambdaQuery();
  73. String status = paginationRequest.getSearchParams().get("status") == null ? "" : paginationRequest.getSearchParams().get("status").toString();
  74. if (StringUtils.isNotBlank(status)) {
  75. lambdaQueryWrapper.eq(MtCommissionCash::getStatus, status);
  76. }
  77. String merchantId = paginationRequest.getSearchParams().get("merchantId") == null ? "" : paginationRequest.getSearchParams().get("merchantId").toString();
  78. if (StringUtils.isNotBlank(merchantId)) {
  79. lambdaQueryWrapper.eq(MtCommissionCash::getMerchantId, merchantId);
  80. }
  81. String storeId = paginationRequest.getSearchParams().get("storeId") == null ? "" : paginationRequest.getSearchParams().get("storeId").toString();
  82. if (StringUtils.isNotBlank(storeId)) {
  83. lambdaQueryWrapper.eq(MtCommissionCash::getStoreId, storeId);
  84. }
  85. String realName = paginationRequest.getSearchParams().get("realName") == null ? "" : paginationRequest.getSearchParams().get("realName").toString();
  86. if (StringUtils.isNotEmpty(realName)) {
  87. Map<String, Object> params = new HashMap<>();
  88. params.put("REAL_NAME", realName);
  89. params.put("AUDITED_STATUS", StatusEnum.ENABLED.getKey());
  90. List<MtStaff> staffList = staffService.queryStaffByParams(params);
  91. if (staffList != null && staffList.size() > 0) {
  92. lambdaQueryWrapper.eq(MtCommissionCash::getStaffId, staffList.get(0).getId());
  93. } else {
  94. lambdaQueryWrapper.eq(MtCommissionCash::getStaffId, -1);
  95. }
  96. }
  97. String mobile = paginationRequest.getSearchParams().get("mobile") == null ? "" : paginationRequest.getSearchParams().get("mobile").toString();
  98. if (StringUtils.isNotEmpty(mobile)) {
  99. MtStaff mtStaff = staffService.queryStaffByMobile(mobile);
  100. if (mtStaff != null) {
  101. lambdaQueryWrapper.eq(MtCommissionCash::getStaffId, mtStaff.getId());
  102. } else {
  103. lambdaQueryWrapper.eq(MtCommissionCash::getStaffId, -1);
  104. }
  105. }
  106. String uuid = paginationRequest.getSearchParams().get("uuid") == null ? "" : paginationRequest.getSearchParams().get("uuid").toString();
  107. if (StringUtils.isNotBlank(uuid)) {
  108. lambdaQueryWrapper.eq(MtCommissionCash::getUuid, uuid);
  109. }
  110. // 开始时间、结束时间
  111. String startTime = paginationRequest.getSearchParams().get("startTime") == null ? "" : paginationRequest.getSearchParams().get("startTime").toString();
  112. String endTime = paginationRequest.getSearchParams().get("endTime") == null ? "" : paginationRequest.getSearchParams().get("endTime").toString();
  113. if (StringUtil.isNotEmpty(startTime)) {
  114. lambdaQueryWrapper.ge(MtCommissionCash::getCreateTime, startTime);
  115. }
  116. if (StringUtil.isNotEmpty(endTime)) {
  117. lambdaQueryWrapper.le(MtCommissionCash::getCreateTime, endTime);
  118. }
  119. lambdaQueryWrapper.orderByDesc(MtCommissionCash::getId);
  120. List<MtCommissionCash> commissionCashList = mtCommissionCashMapper.selectList(lambdaQueryWrapper);
  121. List<CommissionCashDto> dataList = new ArrayList<>();
  122. if (commissionCashList != null && commissionCashList.size() > 0) {
  123. for (MtCommissionCash mtCommissionCash : commissionCashList) {
  124. CommissionCashDto commissionCashDto = new CommissionCashDto();
  125. BeanUtils.copyProperties(mtCommissionCash, commissionCashDto);
  126. MtStore mtStore = storeService.getById(mtCommissionCash.getStoreId());
  127. commissionCashDto.setStoreInfo(mtStore);
  128. MtStaff mtStaff = staffService.getById(mtCommissionCash.getStaffId());
  129. if (mtCommissionCash.getUserId() != null && mtCommissionCash.getUserId() > 0) {
  130. MtUser userInfo = memberService.queryMemberById(mtCommissionCash.getUserId());
  131. if (userInfo != null) {
  132. OrderUserDto userDto = new OrderUserDto();
  133. userDto.setNo(userInfo.getUserNo());
  134. userDto.setId(userInfo.getId());
  135. userDto.setName(userInfo.getName());
  136. userDto.setCardNo(userInfo.getIdcard());
  137. userDto.setAddress(userInfo.getAddress());
  138. userDto.setMobile(userInfo.getMobile());
  139. commissionCashDto.setUserInfo(userDto);
  140. }
  141. }
  142. commissionCashDto.setStaffInfo(mtStaff);
  143. dataList.add(commissionCashDto);
  144. }
  145. }
  146. PageRequest pageRequest = PageRequest.of(paginationRequest.getCurrentPage(), paginationRequest.getPageSize());
  147. PageImpl pageImpl = new PageImpl(dataList, pageRequest, pageHelper.getTotal());
  148. PaginationResponse<CommissionCashDto> paginationResponse = new PaginationResponse(pageImpl, CommissionCashDto.class);
  149. paginationResponse.setTotalPages(pageHelper.getPages());
  150. paginationResponse.setTotalElements(pageHelper.getTotal());
  151. paginationResponse.setContent(dataList);
  152. return paginationResponse;
  153. }
  154. /**
  155. * 分销提成结算
  156. *
  157. * @param commissionSettleRequest 结算参数
  158. * @return
  159. */
  160. @Override
  161. @Transactional
  162. public String settleCommission(CommissionSettleRequest commissionSettleRequest) throws BusinessCheckException {
  163. LambdaQueryWrapper<MtCommissionLog> lambdaQueryWrapper = Wrappers.lambdaQuery();
  164. lambdaQueryWrapper.eq(MtCommissionLog::getStatus, CommissionStatusEnum.NORMAL.getKey());
  165. if (commissionSettleRequest.getMerchantId() != null && StringUtils.isNotBlank(commissionSettleRequest.getMerchantId().toString())) {
  166. lambdaQueryWrapper.eq(MtCommissionLog::getMerchantId, commissionSettleRequest.getMerchantId());
  167. }
  168. if (commissionSettleRequest.getStoreId() != null && StringUtils.isNotBlank(commissionSettleRequest.getStoreId().toString())) {
  169. lambdaQueryWrapper.eq(MtCommissionLog::getStoreId, commissionSettleRequest.getStoreId());
  170. }
  171. String realName = commissionSettleRequest.getRealName();
  172. if (StringUtils.isNotBlank(realName)) {
  173. Map<String, Object> params = new HashMap<>();
  174. params.put("REAL_NAME", realName);
  175. params.put("AUDITED_STATUS", StatusEnum.ENABLED.getKey());
  176. List<MtStaff> staffList = staffService.queryStaffByParams(params);
  177. if (staffList != null && staffList.size() > 0) {
  178. lambdaQueryWrapper.eq(MtCommissionLog::getStaffId, staffList.get(0).getId());
  179. }
  180. }
  181. String mobile = commissionSettleRequest.getMobile();
  182. if (StringUtils.isNotBlank(mobile)) {
  183. MtStaff mtStaff = staffService.queryStaffByMobile(mobile);
  184. if (mtStaff != null) {
  185. lambdaQueryWrapper.eq(MtCommissionLog::getStaffId, mtStaff.getId());
  186. }
  187. }
  188. lambdaQueryWrapper.orderByDesc(MtCommissionLog::getId);
  189. List<MtCommissionLog> commissionLogList = mtCommissionLogMapper.selectList(lambdaQueryWrapper);
  190. List<String> staffIds = new ArrayList<>();
  191. List<String> userIds = new ArrayList<>();
  192. String uuid = UUID.randomUUID().toString().replaceAll("-", "");
  193. if (commissionLogList != null && commissionLogList.size() > 0) {
  194. for (MtCommissionLog mtCommissionLog : commissionLogList) {
  195. if (mtCommissionLog.getStaffId() != null && mtCommissionLog.getStaffId() > 0 && !staffIds.contains(CommissionTargetEnum.STAFF.getKey() + mtCommissionLog.getStaffId())) {
  196. staffIds.add(CommissionTargetEnum.STAFF.getKey() + mtCommissionLog.getStaffId());
  197. } else if (mtCommissionLog.getUserId() != null && mtCommissionLog.getUserId() > 0 && !userIds.contains(CommissionTargetEnum.MEMBER.getKey() + mtCommissionLog.getUserId())){
  198. userIds.add(CommissionTargetEnum.MEMBER.getKey() + mtCommissionLog.getUserId());
  199. }
  200. }
  201. }
  202. staffIds.addAll(userIds);
  203. // 生成结算数据
  204. if (staffIds.size() > 0) {
  205. for (String staffId : staffIds) {
  206. BigDecimal totalAmount = new BigDecimal("0");
  207. Integer cashMerchantId = 0;
  208. Integer cashStoreId = 0;
  209. String settleNo = CommonUtil.createSettlementNo();
  210. Integer targetId;
  211. if (staffId.indexOf(CommissionTargetEnum.STAFF.getKey()) >= 0) {
  212. targetId = Integer.parseInt(staffId.replaceAll(CommissionTargetEnum.STAFF.getKey(), ""));
  213. } else {
  214. targetId = Integer.parseInt(staffId.replaceAll(CommissionTargetEnum.MEMBER.getKey(), ""));
  215. }
  216. for (MtCommissionLog mtCommissionLog : commissionLogList) {
  217. if (mtCommissionLog.getStaffId().equals(targetId) || mtCommissionLog.getUserId().equals(targetId)) {
  218. if (mtCommissionLog.getType().equals(CommissionTargetEnum.STAFF.getKey()) && staffId.indexOf(CommissionTargetEnum.STAFF.getKey()) < 0) {
  219. continue;
  220. }
  221. if (mtCommissionLog.getType().equals(CommissionTargetEnum.MEMBER.getKey()) && staffId.indexOf(CommissionTargetEnum.MEMBER.getKey()) < 0) {
  222. continue;
  223. }
  224. totalAmount = totalAmount.add(mtCommissionLog.getAmount());
  225. if (mtCommissionLog.getMerchantId() != null && mtCommissionLog.getMerchantId() > 0) {
  226. cashMerchantId = mtCommissionLog.getMerchantId();
  227. }
  228. if (mtCommissionLog.getStoreId() != null && mtCommissionLog.getStoreId() > 0) {
  229. cashStoreId = mtCommissionLog.getStoreId();
  230. }
  231. CommissionLogRequest commissionLogRequest = new CommissionLogRequest();
  232. commissionLogRequest.setId(mtCommissionLog.getId());
  233. commissionLogRequest.setSettleUuid(uuid);
  234. commissionLogRequest.setOperator(commissionSettleRequest.getOperator());
  235. commissionLogRequest.setStatus(CommissionStatusEnum.SETTLED.getKey());
  236. commissionLogService.updateCommissionLog(commissionLogRequest);
  237. }
  238. }
  239. MtCommissionCash mtCommissionCash = new MtCommissionCash();
  240. mtCommissionCash.setSettleNo(settleNo);
  241. mtCommissionCash.setUuid(uuid);
  242. if (staffId.indexOf(CommissionTargetEnum.STAFF.getKey()) >= 0) {
  243. mtCommissionCash.setStaffId(targetId);
  244. mtCommissionCash.setUserId(0);
  245. } else {
  246. mtCommissionCash.setUserId(targetId);
  247. mtCommissionCash.setStaffId(0);
  248. }
  249. if (cashStoreId > 0) {
  250. mtCommissionCash.setStoreId(cashStoreId);
  251. }
  252. if (cashMerchantId > 0) {
  253. mtCommissionCash.setMerchantId(cashMerchantId);
  254. }
  255. mtCommissionCash.setAmount(totalAmount);
  256. Date time = new Date();
  257. mtCommissionCash.setCreateTime(time);
  258. mtCommissionCash.setUpdateTime(time);
  259. mtCommissionCash.setOperator(commissionSettleRequest.getOperator());
  260. mtCommissionCash.setStatus(CommissionCashStatusEnum.WAIT.getKey());
  261. this.save(mtCommissionCash);
  262. }
  263. }
  264. return uuid;
  265. }
  266. /**
  267. * 根据ID获取记录信息
  268. *
  269. * @param id 分佣提成提现ID
  270. * @return
  271. */
  272. @Override
  273. public CommissionCashDto queryCommissionCashById(Integer id) {
  274. MtCommissionCash mtCommissionCash = mtCommissionCashMapper.selectById(id);
  275. CommissionCashDto commissionCashDto = null;
  276. if (mtCommissionCash != null) {
  277. BeanUtils.copyProperties(mtCommissionCash, commissionCashDto);
  278. }
  279. return commissionCashDto;
  280. }
  281. /**
  282. * 更新分销提成提现
  283. *
  284. * @param requestParam 请求参数
  285. * @return
  286. */
  287. @Override
  288. @Transactional
  289. @OperationServiceLog(description = "更新分销提成提现")
  290. public void updateCommissionCash(CommissionCashRequest requestParam) throws BusinessCheckException {
  291. MtCommissionCash mtCommissionCash = mtCommissionCashMapper.selectById(requestParam.getId());
  292. if (mtCommissionCash == null) {
  293. logger.error("更新分销提成提现失败...");
  294. throw new BusinessCheckException("更新分销提成提现失败,数据不存在");
  295. }
  296. mtCommissionCash.setUpdateTime(new Date());
  297. if (requestParam.getAmount() != null) {
  298. mtCommissionCash.setAmount(new BigDecimal(requestParam.getAmount()));
  299. }
  300. if (requestParam.getDescription() != null) {
  301. mtCommissionCash.setDescription(requestParam.getDescription());
  302. }
  303. if (requestParam.getStatus() != null) {
  304. mtCommissionCash.setStatus(requestParam.getStatus());
  305. }
  306. mtCommissionCash.setOperator(requestParam.getOperator());
  307. mtCommissionCashMapper.updateById(mtCommissionCash);
  308. }
  309. /**
  310. * 结算确认
  311. *
  312. * @param requestParam 确认参数
  313. * @throws BusinessCheckException
  314. * @return
  315. */
  316. @Override
  317. @Transactional
  318. @OperationServiceLog(description = "结算确认")
  319. public void confirmCommissionCash(CommissionSettleConfirmRequest requestParam) throws BusinessCheckException {
  320. if (StringUtil.isEmpty(requestParam.getUuid())) {
  321. throw new BusinessCheckException("请求有误.");
  322. }
  323. boolean flag = mtCommissionCashMapper.confirmCommissionCash(requestParam.getMerchantId(), requestParam.getUuid(), requestParam.getOperator());
  324. if (flag) {
  325. mtCommissionLogMapper.confirmCommissionLog(requestParam.getMerchantId(), requestParam.getUuid(), requestParam.getOperator());
  326. }
  327. }
  328. /**
  329. * 结算确认
  330. *
  331. * @param requestParam 取消参数
  332. * @throws BusinessCheckException
  333. * @return
  334. */
  335. @Override
  336. @Transactional
  337. @OperationServiceLog(description = "取消结算")
  338. public void cancelCommissionCash(CommissionSettleConfirmRequest requestParam) throws BusinessCheckException {
  339. if (StringUtil.isEmpty(requestParam.getUuid())) {
  340. throw new BusinessCheckException("请求有误.");
  341. }
  342. boolean flag = mtCommissionCashMapper.cancelCommissionCash(requestParam.getMerchantId(), requestParam.getUuid(), requestParam.getOperator());
  343. if (flag) {
  344. mtCommissionLogMapper.cancelCommissionLog(requestParam.getMerchantId(), requestParam.getUuid(), requestParam.getOperator());
  345. }
  346. }
  347. }