TWarehouseAgreementServiceImpl.java 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491
  1. package com.ruoyi.warehouseBusiness.service.impl;
  2. import cn.hutool.core.collection.CollUtil;
  3. import com.alibaba.fastjson.JSONArray;
  4. import com.alibaba.fastjson.JSONObject;
  5. import com.ruoyi.approvalFlow.domain.AuditItems;
  6. import com.ruoyi.approvalFlow.service.impl.AuditItemsServiceImpl;
  7. import com.ruoyi.basicData.domain.TCorps;
  8. import com.ruoyi.basicData.domain.TFees;
  9. import com.ruoyi.basicData.domain.TGoods;
  10. import com.ruoyi.basicData.mapper.TCorpsMapper;
  11. import com.ruoyi.basicData.mapper.TFeesMapper;
  12. import com.ruoyi.basicData.mapper.TGoodsMapper;
  13. import com.ruoyi.common.core.domain.AjaxResult;
  14. import com.ruoyi.common.core.domain.entity.SysUser;
  15. import com.ruoyi.common.core.domain.model.LoginUser;
  16. import com.ruoyi.common.utils.DateUtils;
  17. import com.ruoyi.common.utils.StringUtils;
  18. import com.ruoyi.system.domain.SysConfig;
  19. import com.ruoyi.system.mapper.SysConfigMapper;
  20. import com.ruoyi.system.mapper.SysDeptMapper;
  21. import com.ruoyi.warehouseBusiness.domain.BillnoDel;
  22. import com.ruoyi.warehouseBusiness.domain.TWarehouseAgreement;
  23. import com.ruoyi.warehouseBusiness.domain.TWarehouseAgreementitems;
  24. import com.ruoyi.warehouseBusiness.mapper.BillnoDelMapper;
  25. import com.ruoyi.warehouseBusiness.mapper.TWarehouseAgreementMapper;
  26. import com.ruoyi.warehouseBusiness.mapper.TWarehouseAgreementitemsMapper;
  27. import com.ruoyi.warehouseBusiness.service.ITWarehouseAgreementService;
  28. import org.springframework.beans.factory.annotation.Autowired;
  29. import org.springframework.stereotype.Service;
  30. import org.springframework.transaction.annotation.Transactional;
  31. import org.springframework.transaction.interceptor.TransactionAspectSupport;
  32. import java.math.BigDecimal;
  33. import java.util.*;
  34. /**
  35. * 仓储费Service业务层处理
  36. *
  37. * @author ruoyi
  38. * @date 2020-12-11
  39. */
  40. @Service
  41. public class TWarehouseAgreementServiceImpl implements ITWarehouseAgreementService {
  42. @Autowired
  43. private TWarehouseAgreementMapper tWarehouseAgreementMapper;
  44. @Autowired
  45. private TWarehouseAgreementitemsMapper tWarehouseAgreementitemsMapper;
  46. @Autowired
  47. private BillnoSerialServiceImpl billnoSerialServiceImpl;
  48. @Autowired
  49. private BillnoDelMapper billnoDelMapper;
  50. @Autowired
  51. private TCorpsMapper tCorpsMapper;
  52. @Autowired
  53. private TGoodsMapper tGoodsMapper;
  54. @Autowired
  55. private TFeesMapper tFeesMapper;
  56. @Autowired
  57. private SysDeptMapper sysDeptMapper;
  58. @Autowired
  59. private SysConfigMapper sysConfigMapper;
  60. @Autowired
  61. private AuditItemsServiceImpl auditItemsService;
  62. /**
  63. * 查询仓储费
  64. *
  65. * @param fId 仓储费ID
  66. * @return 仓储费
  67. */
  68. @Override
  69. public TWarehouseAgreement selectTWarehouseAgreementById(Long fId) {
  70. return tWarehouseAgreementMapper.selectTWarehouseAgreementById(fId);
  71. }
  72. @Override
  73. public Map<String, Object> selectTWarehouseAgreementById1(Long fId) {
  74. Map<String, Object> map = new HashMap<>();
  75. // 查询协议主表数据
  76. TWarehouseAgreement tWarehouseAgreement = tWarehouseAgreementMapper.selectTWarehouseAgreementById(fId);
  77. // 客户表
  78. List<Long> corpsId = new ArrayList<>();
  79. // 用户表
  80. List<SysUser> sysUserList = new ArrayList<>();
  81. // 商品
  82. List<Long> goodsId = new ArrayList<>();
  83. // 费用
  84. List<Long> feesId = new ArrayList<>();
  85. if (!StringUtils.isNull(tWarehouseAgreement)) {
  86. corpsId.add(tWarehouseAgreement.getfCorpid());
  87. goodsId.add(tWarehouseAgreement.getfGoodsid());
  88. map.put("tWarehouseAgreement", tWarehouseAgreement);
  89. }
  90. // 协议从表
  91. TWarehouseAgreementitems tWarehouseAgreementitems = new TWarehouseAgreementitems();
  92. tWarehouseAgreementitems.setfPid(fId);
  93. List<TWarehouseAgreementitems> tWarehouseAgreementitemss = tWarehouseAgreementitemsMapper.selectTWarehouseAgreementitemsList(tWarehouseAgreementitems);
  94. if (StringUtils.isNotEmpty(tWarehouseAgreementitemss)) {
  95. for (TWarehouseAgreementitems fees : tWarehouseAgreementitemss) {
  96. feesId.add(fees.getfFeeid());
  97. }
  98. }
  99. List<TCorps> corpsList = new ArrayList<>();
  100. List<Long> corpsIdList = StringUtils.integerDeduplication(corpsId);
  101. for (Long corpId : corpsIdList) {
  102. TCorps corps = tCorpsMapper.selectTCorpsById(corpId);
  103. if (StringUtils.isNotNull(corps)) {
  104. corpsList.add(corps);
  105. }
  106. }
  107. List<TGoods> goodsList = new ArrayList<>();
  108. List<Long> goodsIdList = StringUtils.integerDeduplication(goodsId);
  109. for (Long goods : goodsIdList) {
  110. TGoods tGoods = tGoodsMapper.selectTGoodsById(goods);
  111. if (StringUtils.isNotNull(tGoods)) {
  112. goodsList.add(tGoods);
  113. }
  114. }
  115. List<TFees> feesList = new ArrayList<>();
  116. List<Long> longList = StringUtils.integerDeduplication(feesId);
  117. for (Long fees : longList) {
  118. TFees tFees = tFeesMapper.selectTFeesById(fees);
  119. if (StringUtils.isNotNull(tFees)) {
  120. feesList.add(tFees);
  121. }
  122. }
  123. map.put("corps", corpsList);
  124. map.put("goodsList", goodsList);
  125. map.put("feesList", feesList);
  126. map.put("tWarehouseAgreementitems", tWarehouseAgreementitemss);
  127. map.put("dept", sysDeptMapper.selectDeptById(tWarehouseAgreement.getfDeptid()));
  128. return map;
  129. }
  130. /**
  131. * 查询仓储费列表
  132. *
  133. * @param tWarehouseAgreement 仓储费
  134. * @return 仓储费
  135. */
  136. @Override
  137. public List<Map<String, Object>> selectTWarehouseAgreementList1(TWarehouseAgreement tWarehouseAgreement) {
  138. return tWarehouseAgreementMapper.selectTWarehouseAgreementList1(tWarehouseAgreement);
  139. }
  140. /**
  141. * 查询仓储费列表
  142. *
  143. * @param tWarehouseAgreement 仓储费
  144. * @return 仓储费
  145. */
  146. @Override
  147. public List<TWarehouseAgreement> selectTWarehouseAgreementList(TWarehouseAgreement tWarehouseAgreement) {
  148. return tWarehouseAgreementMapper.selectTWarehouseAgreementList(tWarehouseAgreement);
  149. }
  150. /**
  151. * 新增
  152. * @param agreement
  153. * @param agreementitems
  154. * @param loginUser
  155. * @return
  156. */
  157. @Override
  158. public AjaxResult insertTWarehouseAgreement(String agreement, String agreementitems, LoginUser loginUser,int fFeetypeid) {
  159. Long fPid = null;
  160. TWarehouseAgreement tWarehouseAgreement = JSONArray.parseObject(agreement, TWarehouseAgreement.class);
  161. if(StringUtils.isNull(tWarehouseAgreement.getfId())){
  162. // 如果是新数据
  163. tWarehouseAgreement.setCreateBy(loginUser.getUser().getUserName());
  164. // 业务编码
  165. String billNo = billnoSerialServiceImpl.getBillNo("WA", new Date());
  166. tWarehouseAgreement.setfBillno(billNo);
  167. tWarehouseAgreement.setCreateBy(loginUser.getUser().getUserName());
  168. tWarehouseAgreement.setfDeptid(loginUser.getUser().getDeptId());
  169. tWarehouseAgreement.setfFeetypeid((long) fFeetypeid);
  170. tWarehouseAgreementMapper.insertTWarehouseAgreement(tWarehouseAgreement);
  171. fPid = tWarehouseAgreement.getfId();
  172. }else{
  173. fPid = tWarehouseAgreement.getfId();
  174. tWarehouseAgreement.setUpdateBy(loginUser.getUser().getUserName());
  175. tWarehouseAgreement.setUpdateTime(new Date());
  176. tWarehouseAgreementMapper.updateTWarehouseAgreement(tWarehouseAgreement);
  177. tWarehouseAgreementitemsMapper.deleteByFPid(fPid);
  178. }
  179. // 从表添加
  180. if (StringUtils.isNotNull(agreementitems) && !"[]".equals(agreementitems)) {
  181. JSONArray jsonDrArray = JSONArray.parseArray(agreementitems);
  182. List<TWarehouseAgreementitems> tWarehouseAgreementitemsList = JSONObject.parseArray(jsonDrArray.toJSONString(), TWarehouseAgreementitems.class);
  183. for (TWarehouseAgreementitems tWarehouseAgreementitems : tWarehouseAgreementitemsList) {
  184. tWarehouseAgreementitems.setfPid(fPid);
  185. tWarehouseAgreementitems.setCreateBy(loginUser.getUser().getUserName());
  186. tWarehouseAgreementitems.setCreateTime(new Date());
  187. tWarehouseAgreementitemsMapper.insertTWarehouseAgreementitems(tWarehouseAgreementitems);
  188. }
  189. }
  190. return AjaxResult.success();
  191. }
  192. /**
  193. * 仓储费请核
  194. * @param agreement
  195. * @param agreementitems
  196. * @param loginUser
  197. * @param fFeetypeid
  198. * @return
  199. */
  200. @Override
  201. @Transactional
  202. public AjaxResult tWarehouseAgreementSubmit(String agreement, String agreementitems, LoginUser loginUser, int fFeetypeid) {
  203. Long fPid = null;
  204. TWarehouseAgreement tWarehouseAgreement = JSONArray.parseObject(agreement, TWarehouseAgreement.class);
  205. if(StringUtils.isNull(tWarehouseAgreement.getfId())){
  206. // 如果是新数据
  207. tWarehouseAgreement.setCreateBy(loginUser.getUser().getUserName());
  208. // 业务编码
  209. String billNo = billnoSerialServiceImpl.getBillNo("WA", new Date());
  210. tWarehouseAgreement.setfBillno(billNo);
  211. tWarehouseAgreement.setCreateBy(loginUser.getUser().getUserName());
  212. tWarehouseAgreement.setfDeptid(loginUser.getUser().getDeptId());
  213. tWarehouseAgreement.setfFeetypeid((long) fFeetypeid);
  214. tWarehouseAgreementMapper.insertTWarehouseAgreement(tWarehouseAgreement);
  215. fPid = tWarehouseAgreement.getfId();
  216. }else{
  217. fPid = tWarehouseAgreement.getfId();
  218. tWarehouseAgreement.setUpdateBy(loginUser.getUser().getUserName());
  219. tWarehouseAgreement.setUpdateTime(new Date());
  220. tWarehouseAgreementMapper.updateTWarehouseAgreement(tWarehouseAgreement);
  221. tWarehouseAgreementitemsMapper.deleteByFPid(fPid);
  222. }
  223. // 从表添加
  224. if (StringUtils.isNotNull(agreementitems) && !"[]".equals(agreementitems)) {
  225. JSONArray jsonDrArray = JSONArray.parseArray(agreementitems);
  226. List<TWarehouseAgreementitems> tWarehouseAgreementitemsList = JSONObject.parseArray(jsonDrArray.toJSONString(), TWarehouseAgreementitems.class);
  227. for (TWarehouseAgreementitems tWarehouseAgreementitems : tWarehouseAgreementitemsList) {
  228. tWarehouseAgreementitems.setfPid(fPid);
  229. tWarehouseAgreementitems.setCreateBy(loginUser.getUser().getUserName());
  230. tWarehouseAgreementitems.setCreateTime(new Date());
  231. tWarehouseAgreementitemsMapper.insertTWarehouseAgreementitems(tWarehouseAgreementitems);
  232. }
  233. }
  234. // 这里加个判断取系统参数来确定是否需要启用审批流
  235. String key = "";
  236. boolean isApprove = false;
  237. long actId = 0L;
  238. if (fFeetypeid==0) {
  239. actId = 310L;
  240. key = "warehouse.storage.ApprovalFlow";
  241. } else if (fFeetypeid==1) {
  242. actId = 320L;
  243. key = "warehouse.task.ApprovalFlow";
  244. }
  245. SysConfig sysConfig = sysConfigMapper.checkConfigKeyUnique(key);
  246. if (StringUtils.isNull(sysConfig)) {
  247. TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
  248. return AjaxResult.error("系统参数异常,未找到开启审批流参数");
  249. }
  250. if ("0".equals(sysConfig.getConfigValue())) {
  251. isApprove = true;
  252. }
  253. if (isApprove) {
  254. AuditItems auditItems = new AuditItems();
  255. auditItems.setLevelId(0L);
  256. auditItems.setBillId(fPid);
  257. auditItems.setActId(actId);
  258. auditItems.setIffinalItem("F");
  259. auditItems.setBillNo(tWarehouseAgreement.getfBillno());
  260. auditItems.setRefno1(String.valueOf(tWarehouseAgreement.getfCorpid()));
  261. if(tWarehouseAgreement.getfFeetypeid()==0){
  262. auditItems.setRefno2("CCF");// 存储业务类型(业务类型)
  263. }else{
  264. auditItems.setRefno2("ZYF");// 存储业务类型(业务类型)
  265. }
  266. auditItems.setSendUserId(loginUser.getUser().getUserId());
  267. auditItems.setSendName(loginUser.getUsername());
  268. auditItems.setSendTime(new Date());
  269. auditItems.setAuditUserId(loginUser.getUser().getUserId());
  270. auditItems.setAuditItem(new Date());
  271. auditItems.setAuditMsg("提交");
  272. auditItems.setAuditStatus("O");
  273. AjaxResult approvalFlow = auditItemsService.createApprovalFlow(auditItems);
  274. Long code = Long.valueOf(String.valueOf(approvalFlow.get("code"))).longValue();
  275. if (code.equals(500L)) {
  276. TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
  277. }
  278. return approvalFlow;
  279. }else {
  280. AjaxResult ajaxResult = agreementFollow(fPid, 6L);
  281. Long code = Long.valueOf(String.valueOf(ajaxResult.get("code"))).longValue();
  282. return ajaxResult;
  283. }
  284. }
  285. /**
  286. * 根据协议主表id 更新对应明细表状态
  287. *
  288. * @param fPid 协议主表id
  289. * @return 结果
  290. */
  291. @Transactional
  292. public AjaxResult agreementFollow(Long fPid, long fettle) {
  293. if (StringUtils.isNull(fPid)) {
  294. return AjaxResult.error("协议更新状态未找到主表信息,请与管理员联系");
  295. }
  296. TWarehouseAgreement tWarehouseAgreement = new TWarehouseAgreement();
  297. tWarehouseAgreement.setfId(fPid);
  298. tWarehouseAgreement.setfBillstatus(String.valueOf(fettle));
  299. int tFeeUpdateResult = tWarehouseAgreementMapper.updateTWarehouseAgreement(tWarehouseAgreement);
  300. if (tFeeUpdateResult <= 0) {
  301. TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
  302. return AjaxResult.error("更新协议明细状态失败,请联系管理员");
  303. }
  304. int itemUpdateResult = tWarehouseAgreementitemsMapper.agreementitemsFollowUpdate(fPid,fettle);
  305. if (itemUpdateResult <= 0) {
  306. TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
  307. return AjaxResult.error("更新协议明细状态失败,请联系管理员");
  308. }
  309. return AjaxResult.success();
  310. }
  311. /**
  312. * 修改仓储费
  313. *
  314. * @param tWarehouseAgreement 仓储费
  315. * @return 结果
  316. */
  317. @Override
  318. public int updateTWarehouseAgreement(TWarehouseAgreement tWarehouseAgreement) {
  319. tWarehouseAgreement.setUpdateTime(DateUtils.getNowDate());
  320. return tWarehouseAgreementMapper.updateTWarehouseAgreement(tWarehouseAgreement);
  321. }
  322. /**
  323. * 批量删除仓储费
  324. *
  325. * @param fIds 需要删除的仓储费ID
  326. * @return 结果
  327. */
  328. @Override
  329. public int deleteTWarehouseAgreementByIds(Long[] fIds) {
  330. // 取出业务编号、 放入 billno_del
  331. for(Long id:fIds){
  332. // 1、查询主表信息
  333. TWarehouseAgreement tWarehouseAgreement = tWarehouseAgreementMapper.selectTWarehouseAgreementById(id);
  334. // 2、业务编号、客存编号 放入 billno_del
  335. BillnoDel billnoDel =new BillnoDel();
  336. billnoDel.setBillType("WA");
  337. billnoDel.setBillNo(tWarehouseAgreement.getfBillno());
  338. billnoDelMapper.insertBillnoDel(billnoDel);
  339. }
  340. return tWarehouseAgreementMapper.deleteTWarehouseAgreementByIds(fIds);
  341. }
  342. /**
  343. * 删除仓储费信息
  344. *
  345. * @param fId 仓储费ID
  346. * @return 结果
  347. */
  348. @Override
  349. public int deleteTWarehouseAgreementById(Long fId) {
  350. return tWarehouseAgreementMapper.deleteTWarehouseAgreementById(fId);
  351. }
  352. @Override
  353. public AjaxResult queryRemove(Long fId) {
  354. // 查询协议主表数据
  355. TWarehouseAgreement tWarehouseAgreement = tWarehouseAgreementMapper.selectTWarehouseAgreementById(fId);
  356. TWarehouseAgreementitems tWarehouseAgreementitems = new TWarehouseAgreementitems();
  357. tWarehouseAgreementitems.setfPid(tWarehouseAgreement.getfId());
  358. List<TWarehouseAgreementitems> tWarehouseAgreementitemss = tWarehouseAgreementitemsMapper.selectTWarehouseAgreementitemsList(tWarehouseAgreementitems);
  359. if( StringUtils.isNull(tWarehouseAgreement)){
  360. return AjaxResult.success("0");
  361. } else if(StringUtils.isNotNull(tWarehouseAgreement) && StringUtils.isEmpty(tWarehouseAgreementitemss) ){
  362. return AjaxResult.success("1");
  363. } else {
  364. return AjaxResult.success("2");
  365. }
  366. }
  367. /**
  368. * 计算存储费用
  369. * @author shanxin
  370. * @param fCorpid 出库客户Id
  371. * @param fGoodsid 物资类型Id
  372. * @param days 时长天数(需要计算仓储费的时长)
  373. * @param feeUnitid 计价单位
  374. * @param itemNums 数量
  375. * @param earlySumDays 已经计算过仓储费的天数(假设传参80,则阶梯计价时按照80往后的计算) 21.01.14 曹志刚要求新增
  376. * @return
  377. */
  378. public Map<String, Object> getCarryingCost(Long fCorpid,
  379. Long fGoodsid,
  380. Long days,
  381. Long feeUnitid,
  382. BigDecimal itemNums,
  383. Long earlySumDays) {
  384. Map<String, Object> map = new HashMap<>();
  385. if (null == fCorpid ||
  386. null == fGoodsid ||
  387. null == days ||
  388. null == feeUnitid ||
  389. null == itemNums ||
  390. null == earlySumDays) {
  391. return null;
  392. }
  393. List<TWarehouseAgreementitems> itemList =
  394. this.tWarehouseAgreementitemsMapper.getItemsBytWarehouseAgreementMsg(fCorpid,fGoodsid,feeUnitid);
  395. if (CollUtil.isEmpty(itemList)) {
  396. return null;
  397. }
  398. BigDecimal money = new BigDecimal(0);
  399. Long dayLength = 0L;
  400. Long feeId = 0L;
  401. for (TWarehouseAgreementitems tWarehouseAgreementitems : itemList) {
  402. if (days < 1) break;
  403. if (earlySumDays >= tWarehouseAgreementitems.getfEndays()) continue; //将已算账的天数 与 计费规则的 最后一天作比较如果 已算10天 > 规则结束 不算帐
  404. dayLength = tWarehouseAgreementitems.getfEndays() - tWarehouseAgreementitems.getfFromdays() + 1L; //阶梯中的结束-开始日期
  405. if (days >= dayLength) {
  406. feeId = tWarehouseAgreementitems.getfFeeid();
  407. money = money.add(this.getCalculate(itemNums,tWarehouseAgreementitems.getfPrice(),dayLength));
  408. days = days - dayLength;
  409. } else {
  410. feeId = tWarehouseAgreementitems.getfFeeid();
  411. money = money.add(this.getCalculate(itemNums,tWarehouseAgreementitems.getfPrice(),days));
  412. }
  413. }
  414. map.put("amt", money);
  415. map.put("feeId", feeId);
  416. return map;
  417. }
  418. /**
  419. * 数量 * 单价 * 天数
  420. * @param itemNumsBig 数量
  421. * @param unitPrice 单价
  422. * @param dateLength 天数
  423. * @return
  424. */
  425. public BigDecimal getCalculate (BigDecimal itemNumsBig,BigDecimal unitPrice,Long dateLength) {
  426. BigDecimal money = new BigDecimal(0);
  427. BigDecimal bigDaysBig = new BigDecimal(dateLength);
  428. money = itemNumsBig.multiply(unitPrice).multiply(bigDaysBig);
  429. return money;
  430. }
  431. }