ContractUpdateFlow.java 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465
  1. package com.fjhx.sale.flow;
  2. import cn.hutool.core.util.ObjectUtil;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
  5. import com.baomidou.mybatisplus.core.toolkit.IdWorker;
  6. import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
  7. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  8. import com.fjhx.account.entity.account.po.AccountRunningWater;
  9. import com.fjhx.account.service.account.AccountRunningWaterService;
  10. import com.fjhx.area.utils.CustomizeAreaUtil;
  11. import com.fjhx.common.enums.FlowStatusEnum1;
  12. import com.fjhx.common.utils.Assert;
  13. import com.fjhx.file.utils.ObsFileUtil;
  14. import com.fjhx.flow.core.FlowDelegate;
  15. import com.fjhx.flow.enums.FlowStatusEnum;
  16. import com.fjhx.sale.entity.claim.po.Claim;
  17. import com.fjhx.sale.entity.claim.po.ClaimContract;
  18. import com.fjhx.sale.entity.contract.dto.ContractDto;
  19. import com.fjhx.sale.entity.contract.po.Contract;
  20. import com.fjhx.sale.entity.contract.po.ContractProduct;
  21. import com.fjhx.sale.entity.contract.po.ContractProject;
  22. import com.fjhx.sale.entity.contract.po.ContractShipment;
  23. import com.fjhx.sale.service.claim.ClaimContractService;
  24. import com.fjhx.sale.service.claim.ClaimService;
  25. import com.fjhx.sale.service.contract.ContractProductService;
  26. import com.fjhx.sale.service.contract.ContractProjectService;
  27. import com.fjhx.sale.service.contract.ContractService;
  28. import com.fjhx.sale.service.contract.ContractShipmentService;
  29. import com.ruoyi.common.core.domain.BaseIdPo;
  30. import com.ruoyi.common.core.domain.BasePo;
  31. import com.ruoyi.common.core.domain.entity.SysUser;
  32. import com.ruoyi.common.exception.ServiceException;
  33. import com.ruoyi.common.utils.SecurityUtils;
  34. import org.springframework.beans.factory.annotation.Autowired;
  35. import org.springframework.stereotype.Component;
  36. import java.math.BigDecimal;
  37. import java.util.Arrays;
  38. import java.util.Date;
  39. import java.util.List;
  40. import java.util.Map;
  41. import java.util.function.Function;
  42. import java.util.regex.Matcher;
  43. import java.util.regex.Pattern;
  44. import java.util.stream.Collectors;
  45. /**
  46. * 合同变更流程
  47. */
  48. @Component
  49. public class ContractUpdateFlow extends FlowDelegate {
  50. @Autowired
  51. private ContractFlow contractFlow;
  52. @Autowired
  53. private ContractService contractService;
  54. @Autowired
  55. private ContractProductService contractProductService;
  56. @Autowired
  57. private ClaimContractService claimContractService;
  58. @Autowired
  59. private AccountRunningWaterService accountRunningWaterService;
  60. @Autowired
  61. private ClaimService claimService;
  62. @Autowired
  63. private ContractProjectService contractProjectService;
  64. @Autowired
  65. private ContractShipmentService contractShipmentService;
  66. @Override
  67. public String getFlowKey() {
  68. return "contract_update_flow";
  69. }
  70. /**
  71. * 发起流程
  72. *
  73. * @param flowId 流程ID
  74. * @param submitData 采购付款数据
  75. * @return
  76. */
  77. @Override
  78. public Long start(Long flowId, JSONObject submitData) {
  79. ContractDto contract = submitData.toJavaObject(ContractDto.class);
  80. contract.setIssue("1");//默认直接下发到交接单
  81. contract.setFlowId(flowId);//赋值新合同流程ID
  82. // 原合同id不能为空
  83. Long oldContractId = contract.getOldContractId();
  84. if (oldContractId == null) {
  85. throw new ServiceException("原合同id不能为空");
  86. }
  87. //查询原合同
  88. Contract oldContract = contractService.getById(contract.getOldContractId());
  89. if (ObjectUtil.isEmpty(oldContract)) {
  90. throw new ServiceException("查询不到原合同信息");
  91. }
  92. //更新原样品单状态为变更中
  93. oldContract.setStatus(FlowStatusEnum1.UPDATE_LOADING.getKey());
  94. contractService.updateById(oldContract);
  95. //查询旧合同的订单产品
  96. List<ContractProduct> oldContractProductList = contractProductService.list(q -> q.eq(ContractProduct::getContractId, oldContractId));
  97. if (CollectionUtils.isEmpty(oldContractProductList)) {
  98. throw new ServiceException("原合同没有产品");
  99. }
  100. Map<Long, List<ContractProduct>> oldContractProductMap = oldContractProductList.stream().collect(Collectors.groupingBy(ContractProduct::getId));
  101. List<ContractProduct> newContractProductList = contract.getContractProductList();
  102. if (CollectionUtils.isEmpty(newContractProductList)) {
  103. throw new ServiceException("变更合同产品不能为空");
  104. }
  105. /**
  106. * 赋值新的变更合同号
  107. */
  108. String code = oldContract.getCode();
  109. Matcher matcher = Pattern.compile(".*\\((.*?)\\)$").matcher(code);
  110. int index = 2;
  111. if (matcher.find()) {
  112. index = (Integer.parseInt(matcher.group(1)) + 1);
  113. code = code.substring(0, code.lastIndexOf("("));
  114. }
  115. contract.setCode(code + "(" + index + ")");
  116. contract.setIsShow(1);//隐藏当前数据
  117. /**
  118. * 计算新合同的剩余数量
  119. */
  120. for (ContractProduct newCp : newContractProductList) {
  121. newCp.setExpendQuantity(newCp.getQuantity());
  122. if (ObjectUtil.isNotEmpty(newCp.getId())) {//如果新合同产品ID不为空
  123. //取出旧合同
  124. ContractProduct oldContractProduct = oldContractProductMap.getOrDefault(newCp.getId(), null).get(0);
  125. // //取出旧合同包装方式
  126. // JSONObject oldJson = JSONObject.parseObject(oldContractProduct.getEhsdJson());
  127. // String oldPackMethod = oldJson.getOrDefault("packMethod",null)==null?null:oldJson.getOrDefault("packMethod",null).toString();
  128. // //取出新合同包装方式
  129. // JSONObject newJson = JSONObject.parseObject(newCp.getEhsdJson());
  130. // String newPackMethod = newJson.getOrDefault("packMethod",null)==null?null:oldJson.getOrDefault("packMethod",null).toString();
  131. /**
  132. * 商品英文名、尺寸、包装方式、数量 没有变更---取原本的剩余数量
  133. */
  134. if (oldContractProduct.getQuantity().compareTo(newCp.getQuantity()) == 0) {//如果数量没有变动
  135. //取出旧的剩余数量
  136. newCp.setExpendQuantity(oldContractProduct.getExpendQuantity());
  137. } else {//变动了
  138. BigDecimal quantity = newCp.getQuantity().subtract(oldContractProduct.getQuantity()).subtract(oldContractProduct.getExpendQuantity());//剩余数量
  139. newCp.setExpendQuantity(quantity);
  140. }
  141. }
  142. }
  143. return update(contract);
  144. }
  145. /**
  146. * 变更
  147. *
  148. * @param contract
  149. * @return
  150. */
  151. public Long update(ContractDto contract) {
  152. // 赋值城市省份信息
  153. CustomizeAreaUtil.setAreaId(contract);
  154. SysUser loginUser = SecurityUtils.getLoginUser().getUser();
  155. contract.setUserName(loginUser.getNickName());
  156. contract.setBuyCityId(contract.getCityId());
  157. contract.setBuyCountryId(contract.getCountryId());
  158. contract.setBuyProvinceId(contract.getProvinceId());
  159. contract.setStatus(FlowStatusEnum1.UNDER_REVIEW.getKey());
  160. // contract.setRate(ExchangeRateUtil.getCnyToCodeRate(contract.getCurrency()));
  161. contractService.save(contract);
  162. // 保存合同产品
  163. List<ContractProduct> contractProductList = contract.getContractProductList();
  164. if (CollectionUtils.isNotEmpty(contractProductList)) {
  165. for (ContractProduct c : contractProductList) {
  166. c.setId(IdWorker.getId());
  167. c.setContractId(contract.getId());
  168. // ObsFileUtil.saveFile(c.getFileList(), c.getId());
  169. }
  170. contractProductService.saveBatch(contractProductList);
  171. }
  172. // 保存收费项目
  173. List<ContractProject> contractProjectList = contract.getContractProjectList();
  174. if (CollectionUtils.isNotEmpty(contractProjectList)) {
  175. for (ContractProject c : contractProjectList) {
  176. c.setId(IdWorker.getId());
  177. c.setContractId(contract.getId());
  178. }
  179. contractProjectService.saveBatch(contractProjectList);
  180. }
  181. // 保存自定义出货
  182. List<ContractShipment> contractShipmentList = contract.getContractShipmentList();
  183. if (CollectionUtils.isNotEmpty(contractShipmentList)) {
  184. for (ContractShipment c : contractShipmentList) {
  185. c.setId(IdWorker.getId());
  186. c.setContractId(contract.getId());
  187. }
  188. contractShipmentService.saveBatch(contractShipmentList);
  189. }
  190. // 交接单附件列表
  191. ObsFileUtil.copyFileAndSave(contract.getFileList(), contract.getId(), 1);
  192. // 包装指示附件列表
  193. ObsFileUtil.copyFileAndSave(contract.getPackageFileList(), contract.getId(), 2);
  194. return contract.getId();
  195. }
  196. /**
  197. * 结束流程
  198. *
  199. * @param flowId 流程ID
  200. * @param businessId 业务ID
  201. * @param submitData 数据
  202. */
  203. @Override
  204. public void end(Long flowId, Long businessId, JSONObject submitData) {
  205. // 通过业务ID查询合同数据
  206. Contract newContract = contractService.getById(businessId);
  207. if (ObjectUtils.isEmpty(newContract)) {
  208. throw new ServiceException("合同不存在");
  209. }
  210. long oldContractId = newContract.getOldContractId();//取出旧的合同ID
  211. Contract oldContract = contractService.getById(oldContractId);
  212. if (oldContract == null) {
  213. throw new ServiceException("原合同不存在");
  214. }
  215. //替换新数据ID为临时ID
  216. long temNewId = IdWorker.getId();
  217. Contract temNewUpContract = new Contract();
  218. temNewUpContract.setId(temNewId);
  219. temNewUpContract.setUpId(businessId);
  220. contractService.updateContract(temNewUpContract);
  221. long temOldId = IdWorker.getId();
  222. Contract temOldUpContract = new Contract();
  223. temOldUpContract.setId(temOldId);
  224. temOldUpContract.setUpId(oldContractId);
  225. contractService.updateContract(temOldUpContract);
  226. //查询新数据产品、收费、出货
  227. List<Long> newContractProductIds = contractProductService.list(Wrappers.<ContractProduct>query().lambda().select(ContractProduct::getId).eq(ContractProduct::getContractId, businessId)).stream().map(ContractProduct::getId).collect(Collectors.toList());
  228. List<Long> newContractProjectIds = contractProjectService.list(Wrappers.<ContractProject>query().lambda().select(ContractProject::getId).eq(ContractProject::getContractId, businessId)).stream().map(ContractProject::getId).collect(Collectors.toList());
  229. List<Long> newContractShipmentIds = contractShipmentService.list(Wrappers.<ContractShipment>query().lambda().select(ContractShipment::getId).eq(ContractShipment::getContractId, businessId)).stream().map(ContractShipment::getId).collect(Collectors.toList());
  230. //查询旧数据产品、收费、出货
  231. List<Long> oldContractProductIds = contractProductService.list(Wrappers.<ContractProduct>query().lambda().select(ContractProduct::getId).eq(ContractProduct::getContractId, oldContractId)).stream().map(ContractProduct::getId).collect(Collectors.toList());
  232. List<Long> oldContractProjectIds = contractProjectService.list(Wrappers.<ContractProject>query().lambda().select(ContractProject::getId).eq(ContractProject::getContractId, oldContractId)).stream().map(ContractProject::getId).collect(Collectors.toList());
  233. List<Long> oldContractShipmentIds = contractShipmentService.list(Wrappers.<ContractShipment>query().lambda().select(ContractShipment::getId).eq(ContractShipment::getContractId, oldContractId)).stream().map(ContractShipment::getId).collect(Collectors.toList());
  234. /**
  235. * 处理新合同---
  236. */
  237. newContract.setId(oldContractId);//id赋值为旧合同的id
  238. newContract.setStatus(FlowStatusEnum1.PASS.getKey());
  239. newContract.setApprovedDate(new Date());
  240. newContract.setUpId(temNewId);
  241. newContract.setOldContractId(businessId);
  242. newContract.setIsShow(0);//显示新合同
  243. contractService.updateContract(newContract);
  244. //修改合同产品相关数据
  245. if (CollectionUtils.isNotEmpty(newContractProductIds)) {
  246. contractProductService.update(Wrappers.<ContractProduct>update().lambda().set(ContractProduct::getContractId, oldContractId).in(ContractProduct::getId, newContractProductIds));
  247. }
  248. //修改合同收费相关数据
  249. if (CollectionUtils.isNotEmpty(newContractProjectIds)) {
  250. contractProjectService.update(Wrappers.<ContractProject>update().lambda().set(ContractProject::getContractId, oldContractId).in(ContractProject::getId, newContractProjectIds));
  251. }
  252. //修改合同出货相关数据
  253. if (CollectionUtils.isNotEmpty(newContractShipmentIds)) {
  254. contractShipmentService.update(Wrappers.<ContractShipment>update().lambda().set(ContractShipment::getContractId, oldContractId).in(ContractShipment::getId, newContractShipmentIds));
  255. }
  256. /**
  257. * 处理旧的合同---
  258. */
  259. oldContract.setId(businessId);
  260. oldContract.setStatus(FlowStatusEnum1.UPDATE.getKey());
  261. oldContract.setIsChange("1");
  262. contractService.updateById(oldContract);
  263. List<ClaimContract> claimContractList = claimContractService.list(Wrappers.<ClaimContract>query().lambda().eq(ClaimContract::getContractId, oldContractId));
  264. if (ObjectUtil.isNotEmpty(claimContractList)) {
  265. List<Long> claimIds = claimContractList.stream().map(ClaimContract::getClaimId).collect(Collectors.toList());
  266. List<Long> claimContractIds = claimContractList.stream().map(ClaimContract::getId).collect(Collectors.toList());
  267. //取出到账认领数据
  268. List<Claim> claims = claimService.list(q -> q.in(Claim::getId, CollectionUtils.isEmpty(claimIds) ? Arrays.asList("0000") : claimIds));
  269. for (Claim c : claims) {
  270. //查询流水数据
  271. AccountRunningWater accountRunningWater = accountRunningWaterService.getById(c.getBusinessId());
  272. BigDecimal sumClaimMoney = accountRunningWater.getClaimAmount().subtract(c.getAmount());
  273. //更新流水数据为认领状态---已认领金额还原
  274. AccountRunningWater water = new AccountRunningWater();
  275. if (sumClaimMoney.compareTo(BigDecimal.ZERO) > 0) {
  276. water.setIsClaim(2);//部分认领
  277. } else {
  278. water.setIsClaim(0);//未认领
  279. }
  280. water.setId(c.getBusinessId());
  281. water.setClaimAmount(sumClaimMoney);
  282. accountRunningWaterService.updateById(water);
  283. }
  284. //删除到账认领数据
  285. claimContractService.remove(q -> q.in(ClaimContract::getId, claimContractIds));
  286. //删除到账认领数据
  287. claimService.remove(q -> q.in(Claim::getId, claimIds));
  288. }
  289. oldContract.setUpId(temOldId);
  290. oldContract.setIsShow(1);//隐藏旧合同
  291. contractService.updateContract(oldContract);
  292. //修改合同产品相关数据
  293. if (CollectionUtils.isNotEmpty(oldContractProductIds)) {
  294. contractProductService.update(Wrappers.<ContractProduct>update().lambda().set(ContractProduct::getContractId, businessId).in(ContractProduct::getId, oldContractProductIds));
  295. }
  296. //修改合同出货相关数据
  297. if (CollectionUtils.isNotEmpty(oldContractProjectIds)) {
  298. //修改合同收费相关数据
  299. contractProjectService.update(Wrappers.<ContractProject>update().lambda().set(ContractProject::getContractId, businessId).in(ContractProject::getId, oldContractProjectIds));
  300. }
  301. //修改合同出货相关数据
  302. if (CollectionUtils.isNotEmpty(oldContractShipmentIds)) {
  303. //修改合同出货相关数据
  304. contractShipmentService.update(Wrappers.<ContractShipment>update().lambda().set(ContractShipment::getContractId, businessId).in(ContractShipment::getId, oldContractShipmentIds));
  305. }
  306. ObsFileUtil.exchangeBusinessId(oldContractId, businessId);
  307. }
  308. /**
  309. * 重新发起
  310. *
  311. * @param flowId
  312. * @param businessId
  313. * @param flowStatus
  314. * @param submitData
  315. */
  316. @Override
  317. public void relaunch(Long flowId, Long businessId, FlowStatusEnum flowStatus, JSONObject submitData) {
  318. super.relaunch(flowId, businessId, flowStatus, submitData);
  319. reStart(submitData);
  320. }
  321. /**
  322. * 驳回
  323. *
  324. * @param flowId
  325. * @param businessId
  326. * @param flowStatus
  327. */
  328. @Override
  329. public void reject(Long flowId, Long businessId, FlowStatusEnum flowStatus) {
  330. super.reject(flowId, businessId, flowStatus);
  331. reject(businessId);
  332. }
  333. /**
  334. * 作废
  335. *
  336. * @param flowId 流程id
  337. * @param businessId 业务id
  338. * @param flowStatus 流程状态枚举
  339. */
  340. @Override
  341. public void cancellation(Long flowId, Long businessId, FlowStatusEnum flowStatus) {
  342. super.cancellation(flowId, businessId, flowStatus);
  343. contractService.update(q -> q
  344. .eq(Contract::getId, businessId)
  345. .set(Contract::getStatus, FlowStatusEnum1.CANCELLATION.getKey())
  346. .set(BasePo::getUpdateTime, new Date())
  347. .set(BasePo::getUpdateUser, SecurityUtils.getUserId())
  348. );
  349. //合同变更作废需要还原旧合同状态 为审批通过
  350. Contract contract = contractService.getById(businessId);
  351. contractService.update(q -> q
  352. .eq(Contract::getId, contract.getOldContractId())
  353. .set(Contract::getStatus, FlowStatusEnum1.PASS.getKey())
  354. .set(BasePo::getUpdateTime, new Date())
  355. .set(BasePo::getUpdateUser, SecurityUtils.getUserId())
  356. );
  357. }
  358. /**
  359. * 变更合同时执行的数据操作公共代码
  360. */
  361. private ContractDto opDate(ContractDto contract) {
  362. // 原合同id不能为空
  363. Long oldContractId = contract.getOldContractId();
  364. if (oldContractId == null) {
  365. throw new ServiceException("原合同id不能为空");
  366. }
  367. List<ContractProduct> list = contractProductService.list(q -> q.eq(ContractProduct::getContractId, oldContractId));
  368. // 赋值待处理数量
  369. if (CollectionUtils.isNotEmpty(list)) {
  370. List<ContractProduct> contractProductList = contract.getContractProductList();
  371. if (ObjectUtil.isEmpty(contractProductList)) {
  372. throw new ServiceException("没有合同产品");
  373. }
  374. Map<Long, ContractProduct> contractProductMap = contractProductList
  375. .stream()
  376. .filter(item -> ObjectUtil.isNotEmpty(item.getId()))
  377. .collect(Collectors.toMap(BaseIdPo::getId, Function.identity()));
  378. for (ContractProduct item : list) {
  379. ContractProduct contractProduct = contractProductMap.get(item.getId());
  380. if (ObjectUtil.isNotEmpty(contractProduct)) {
  381. BigDecimal expendQuantity = item.getExpendQuantity().subtract(item.getQuantity().subtract(contractProduct.getQuantity()));
  382. contractProduct.setExpendQuantity(expendQuantity);
  383. }
  384. }
  385. }
  386. return contract;
  387. }
  388. /**
  389. * 重新发起
  390. */
  391. private void reStart(JSONObject submitData) {
  392. ContractDto contract = submitData.toJavaObject(ContractDto.class);
  393. Assert.notEmpty(contract.getId(), "合同id不能为空");
  394. //变更合同需要提前操作数据
  395. contract = opDate(contract);
  396. contractFlow.reStart1(contract);
  397. }
  398. /**
  399. * 驳回
  400. */
  401. private void reject(Long businessId) {
  402. contractService.update(q -> q
  403. .eq(Contract::getId, businessId)
  404. .set(Contract::getStatus, FlowStatusEnum1.REJECT.getKey())//20为驳回
  405. .set(BasePo::getUpdateTime, new Date())
  406. .set(BasePo::getUpdateUser, SecurityUtils.getUserId())
  407. );
  408. }
  409. }