PurchaseService.java 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506
  1. package com.dk.mdm.service.pur;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
  4. import com.dk.common.exception.BaseBusinessException;
  5. import com.dk.common.infrastructure.annotaiton.Pagination;
  6. import com.dk.common.infrastructure.constant.Constant;
  7. import com.dk.common.infrastructure.enums.ErrorCodeEnum;
  8. import com.dk.common.model.pojo.PageList;
  9. import com.dk.common.response.ResponseCodeEnum;
  10. import com.dk.common.response.ResponseResultUtil;
  11. import com.dk.common.response.ResponseResultVO;
  12. import com.dk.mdm.infrastructure.convert.ivt.InboundConvert;
  13. import com.dk.mdm.infrastructure.convert.ivt.InboundItemConvert;
  14. import com.dk.mdm.infrastructure.convert.pur.PurChaseConvert;
  15. import com.dk.mdm.infrastructure.convert.pur.PurChaseItemConvert;
  16. import com.dk.mdm.mapper.common.CommonMapper;
  17. import com.dk.mdm.mapper.mst.GoodsSkuMapper;
  18. import com.dk.mdm.mapper.pur.PurchaseItemMapper;
  19. import com.dk.mdm.model.pojo.mst.GoodsSku;
  20. import com.dk.mdm.model.pojo.pur.Purchase;
  21. import com.dk.mdm.mapper.pur.PurchaseMapper;
  22. import com.dk.common.service.BaseService;
  23. import com.dk.common.mapper.BaseMapper;
  24. import com.dk.mdm.model.pojo.pur.PurchaseItem;
  25. import com.dk.mdm.model.pojo.sale.Order;
  26. import com.dk.mdm.model.query.pur.PurchaseItemQuery;
  27. import com.dk.mdm.model.query.pur.PurchaseQuery;
  28. import com.dk.mdm.model.response.mst.GoodsSkuResponse;
  29. import com.dk.mdm.model.response.pur.PurchaseItemResponse;
  30. import com.dk.mdm.model.response.pur.PurchaseResponse;
  31. import com.dk.mdm.model.vo.ivt.InboundItemVO;
  32. import com.dk.mdm.model.vo.ivt.InboundVO;
  33. import com.dk.mdm.model.vo.pur.PurchaseItemVO;
  34. import com.dk.mdm.model.vo.pur.PurchaseVO;
  35. import com.dk.mdm.service.common.CommonService;
  36. import com.dk.mdm.service.ivt.inbound.InboundItemService;
  37. import com.dk.mdm.service.ivt.inbound.InboundPurchaseService;
  38. import com.dk.mdm.service.ivt.inbound.InboundService;
  39. import org.springframework.stereotype.Service;
  40. import org.springframework.beans.factory.annotation.Autowired;
  41. import org.springframework.transaction.annotation.Transactional;
  42. import java.math.BigDecimal;
  43. import java.math.RoundingMode;
  44. import java.time.LocalDate;
  45. import java.time.LocalDateTime;
  46. import java.util.ArrayList;
  47. import java.util.List;
  48. import java.util.Map;
  49. import java.util.UUID;
  50. import java.util.stream.Collectors;
  51. @Service
  52. @Transactional
  53. public class PurchaseService extends BaseService<Purchase> {
  54. @Override
  55. public BaseMapper<Purchase> getRepository() {
  56. return purchaseMapper;
  57. }
  58. @Autowired
  59. private PurchaseMapper purchaseMapper;
  60. @Autowired
  61. private PurChaseConvert purChaseConvert;
  62. @Autowired
  63. private PurChaseItemConvert purchaseItemConvert;
  64. @Autowired
  65. private PurchaseItemMapper purchaseItemMapper;
  66. @Autowired
  67. private CommonMapper commonMapper;
  68. @Autowired
  69. private CommonService commonService;
  70. @Autowired
  71. private PurchaseItemService purchaseItemService;
  72. @Autowired
  73. private InboundService inboundService;
  74. @Autowired
  75. private InboundItemService inboundItemService;
  76. @Autowired
  77. private InboundItemConvert inboundItemConvert;
  78. @Autowired
  79. private InboundConvert inboundConvert;
  80. @Autowired
  81. private GoodsSkuMapper goodsSkuMapper;
  82. @Autowired
  83. private InboundPurchaseService inboundPurchaseService;
  84. /**
  85. * @desc : 条件查询
  86. * @author : 常皓宁
  87. * @date : 2024/2/28 9:47
  88. */
  89. @Pagination
  90. public ResponseResultVO<PageList<PurchaseResponse>> selectByCond(PurchaseQuery purchaseQuery) {
  91. return super.mergeListWithCount(purchaseQuery, purchaseMapper.selectByCond(purchaseQuery), purchaseMapper.countByCond(purchaseQuery));
  92. }
  93. /**
  94. * @desc : 条件查询 带明细(采购入库 查询采购订单 过滤已入库数据)
  95. * @author : 王英杰
  96. * @date : 2024/2/28 9:47
  97. */
  98. @Pagination
  99. public ResponseResultVO<PageList<Map<String, Object>>> selectByCondItem(PurchaseQuery purchaseQuery) {
  100. return super.mergeListWithCount(purchaseQuery, purchaseMapper.selectPurOrderAndDeatil(purchaseQuery), purchaseMapper.countByCond(purchaseQuery));
  101. }
  102. /**
  103. * @desc : 采购订单 待入库查询
  104. * @author : 王英杰
  105. * @date : 2024/2/28 9:46
  106. */
  107. @Pagination
  108. public ResponseResultVO<PageList<PurchaseResponse>> noStoredSelectByCond(PurchaseQuery purchaseQuery) {
  109. return super.mergeListWithCount(purchaseQuery, purchaseMapper.noStoredSelectByCond(purchaseQuery), purchaseMapper.noStoredCountByCond(purchaseQuery));
  110. }
  111. /**
  112. * @desc : 新建
  113. * @author : 常皓宁
  114. * @date : 2024/2/28 9:42
  115. */
  116. @Transactional(rollbackFor = {Exception.class})
  117. public ResponseResultVO<Boolean> insert(PurchaseVO purchasevo) {
  118. //region 组织结构不能为空
  119. if (purchasevo.getOrgId() == null) {
  120. throw new BaseBusinessException(ResponseCodeEnum.OPERATE_FAIL.getCode(), ErrorCodeEnum.ORGANIZATION_CANNOT_BE_EMPTY.getMessage());
  121. }
  122. //endregion
  123. //region 员工不能为空
  124. if (purchasevo.getStaffId() == null) {
  125. throw new BaseBusinessException(ResponseCodeEnum.OPERATE_FAIL.getCode(), ErrorCodeEnum.STAFF_CANNOT_BE_EMPTY.getMessage());
  126. }
  127. //endregion
  128. //region 供应商不能为空
  129. if (purchasevo.getSupId() == null) {
  130. throw new BaseBusinessException(ResponseCodeEnum.OPERATE_FAIL.getCode(), ErrorCodeEnum.SUPLIER_CANNOT_BE_EMPTY.getMessage());
  131. }
  132. //endregion
  133. //region 设置采购订单总单信息并新建
  134. // 制单时间
  135. purchasevo.setMakeTime(LocalDateTime.now());
  136. // 单据类型
  137. purchasevo.setPurType(Constant.DocumentType.PUR_CHASE.getName());
  138. // 入库状态
  139. purchasevo.setIntoStatus(Constant.IntoStatus.DAIRUKU.getName());
  140. // 订单状态
  141. purchasevo.setPurStatus(Constant.OrderStatus.STATUS_DEAL.getName());
  142. // 获取单号
  143. Map<String, Object> codeMap = commonService.getUniqueNoteCode(Constant.docNameConstant.PURCHASE.getName(), false);
  144. purchasevo.setPurId(codeMap.get("outId").toString());
  145. purchasevo.setPurNo(codeMap.get("outNote").toString());
  146. Purchase purchase = purChaseConvert.convertToPo(purchasevo);
  147. super.insert(purchase);
  148. //endregion
  149. //region 设置采购订单明细信息并新建
  150. // List<PurchaseItemVO> purchaseItemVOList = purchasevo.getPurchaseItemVOList().stream().filter(it -> it.getItemId() == null).collect(Collectors.toList());
  151. List<PurchaseItemVO> purchaseItemVOList = purchasevo.getPurchaseItemVOList();
  152. // 商品顺序
  153. for (PurchaseItemVO purchaseItemVO : purchaseItemVOList) {
  154. PurchaseItem purchaseItem = purchaseItemConvert.convertToPo(purchaseItemVO);
  155. purchaseItem.setPurId(purchase.getPurId());
  156. purchaseItem.setItemIndex(purchaseItemVO.getItemIndex());
  157. purchaseItem.setIntoStatus(Constant.IntoStatus.DAIRUKU.getName());
  158. purchaseItem.setCpId(purchase.getCpId());
  159. purchaseItem.setItemId(null);
  160. purchaseItem.setPriceDiscount(purchaseItemVO.getPriceDiscount());
  161. purchaseItemMapper.insert(purchaseItem);
  162. }
  163. //endregion
  164. /****************************************判断是否生成采购入库单****************************************/
  165. //region 判断是否生成采购入库单
  166. if(purchasevo.getInboundProcessingFlag()!=null && purchasevo.getInboundProcessingFlag()){
  167. List<InboundItemVO> inboundItemVOList = new ArrayList<>();
  168. //region 明细
  169. for (PurchaseItemVO purchaseItemVO : purchasevo.getPurchaseItemVOList()) {
  170. //region 采购订单明细转换采购入库明细
  171. InboundItemVO inboundItemVO = inboundItemConvert.convertPurchaseItemVOToInboundItemVO(purchaseItemVO);
  172. //endregion
  173. //region 赋值 采购订单明细和入库单明细不一致的字段要单独set
  174. //来源id
  175. inboundItemVO.setFromId(purchasevo.getPurId());
  176. //来源明细id
  177. inboundItemVO.setFromItemId(purchaseItemVO.getItemId());
  178. //入库价
  179. inboundItemVO.setPriceInto(purchaseItemVO.getPricePur());
  180. //入库中数量
  181. inboundItemVO.setIntoingQty(purchaseItemVO.getItemQty());
  182. //已入库数量
  183. inboundItemVO.setIntoingAmt(purchaseItemVO.getItemAmt());
  184. //endregion
  185. //region 根据sku查询商品信息
  186. if (inboundItemVO.getSkuId() != null) {
  187. GoodsSkuResponse goodsSku = goodsSkuMapper.selectById(inboundItemVO.getSkuId());
  188. //商品名称
  189. inboundItemVO.setSkuName(goodsSku.getSkuName());
  190. //商品型号
  191. inboundItemVO.setSkuModel(goodsSku.getSkuModel());
  192. }
  193. //endregion
  194. //region 箱片计算
  195. //入库中 或者待入库
  196. if (Constant.IntoStatus.RUKUZHONG.getName().equals(inboundItemVO.getIntoStatus()) ||
  197. Constant.IntoStatus.DAIRUKU.getName().equals(inboundItemVO.getIntoStatus())) {
  198. //箱
  199. inboundItemVO.setIntoingBox(Integer.valueOf(inboundItemVO.getIntoingQty().divide(inboundItemVO.getPackBox(), 0, RoundingMode.DOWN).toString()));
  200. //片
  201. inboundItemVO.setIntoingPiece(inboundItemVO.getIntoingQty().remainder(inboundItemVO.getPackBox()));
  202. }
  203. //已入库
  204. else {
  205. //箱
  206. inboundItemVO.setIntoBox(Integer.valueOf(inboundItemVO.getIntoingQty().divide(inboundItemVO.getPackBox(), 0, RoundingMode.DOWN).toString()));
  207. //片
  208. inboundItemVO.setIntoPiece(inboundItemVO.getIntoingQty().remainder(inboundItemVO.getPackBox()));
  209. }
  210. //endregion
  211. //region 入库明细list添加
  212. inboundItemVOList.add(inboundItemVO);
  213. //endregion
  214. }
  215. //endregion
  216. //region 总单
  217. InboundVO inboundVO = inboundConvert.convertPurchaseVOToInboundVO(purchasevo);
  218. inboundVO.setItemList(inboundItemVOList);
  219. //endregion
  220. //新建采购入库单
  221. inboundPurchaseService.purchaseInboundInsert(inboundVO);
  222. }
  223. //endregion
  224. /****************************************判断是否生成采购入库单****************************************/
  225. return ResponseResultUtil.success();
  226. }
  227. /**
  228. * @desc : 新建
  229. * @author : 常皓宁
  230. * @date : 2024/2/28 9:42
  231. */
  232. @Transactional(rollbackFor = {Exception.class})
  233. public ResponseResultVO<Boolean> soldAndPurchasedInsert(PurchaseVO purchasevo) {
  234. this.insert(purchasevo);
  235. return ResponseResultUtil.success();
  236. }
  237. /**
  238. * @desc : 根据总单id查询
  239. * @author : 常皓宁
  240. * @date : 2024/2/29 9:56
  241. */
  242. public ResponseResultVO selectById(String purId) {
  243. //根据id查询
  244. PurchaseResponse purchaseResponse = purchaseMapper.selectById(purId);
  245. //不存在
  246. if (purchaseResponse == null) {
  247. return ResponseResultUtil.error(ErrorCodeEnum.PURCHASE_CANNOT_BE_EMPTY.getCode(),
  248. ErrorCodeEnum.PURCHASE_CANNOT_BE_EMPTY.getMessage());
  249. }
  250. //查询明细
  251. List<PurchaseItemResponse> purchaseItemResponses = purchaseItemMapper.selectByCond(new PurchaseItemQuery().setPurId(purId));
  252. for (PurchaseItemResponse item : purchaseItemResponses) {
  253. item.setPurNo(purchaseResponse.getPurNo());
  254. }
  255. purchaseResponse.setPurchaseItemResponseList(purchaseItemResponses);
  256. return ResponseResultUtil.success(purchaseResponse);
  257. }
  258. /**
  259. * @desc : 转入库 查询采购订单 总单带明细(过滤明细已入库数据)
  260. * @author : 王英杰
  261. * @date : 2024/2/28 14:56
  262. */
  263. public ResponseResultVO purSelectById(String purId) {
  264. //根据id查询
  265. PurchaseResponse purchaseResponse = purchaseMapper.selectById(purId);
  266. //不存在
  267. if (purchaseResponse == null) {
  268. return ResponseResultUtil.error(ErrorCodeEnum.PURCHASE_CANNOT_BE_EMPTY.getCode(),
  269. ErrorCodeEnum.PURCHASE_CANNOT_BE_EMPTY.getMessage());
  270. }
  271. //查询明细 (过滤掉已入库数据)
  272. List<PurchaseItemResponse> purchaseItemResponses = purchaseItemMapper.purSelectByCond(new PurchaseItemQuery().setPurId(purId));
  273. for (PurchaseItemResponse item : purchaseItemResponses) {
  274. item.setPurNo(purchaseResponse.getPurNo());
  275. }
  276. purchaseResponse.setPurchaseItemResponseList(purchaseItemResponses);
  277. return ResponseResultUtil.success(purchaseResponse);
  278. }
  279. /**
  280. * @desc : 编辑方法
  281. * @author : 常皓宁
  282. * @date : 2024/2/28 10:57
  283. */
  284. @Transactional(
  285. rollbackFor = {Exception.class}
  286. )
  287. public ResponseResultVO<Boolean> update(PurchaseVO purchasevo) {
  288. // 转化实体
  289. Purchase purchase = purChaseConvert.convertToPo(purchasevo);
  290. //删除的
  291. List<PurchaseItemVO> deletePurchaseItemVOList = purchasevo.getDeletePurchaseItemList().stream().filter(it -> it.getItemId() != null).collect(Collectors.toList());
  292. if (deletePurchaseItemVOList.size() > 0) {
  293. for (PurchaseItemVO purchaseItemVO : deletePurchaseItemVOList) {
  294. // 非待入库单据不能删除
  295. if (!Constant.IntoStatus.DAIRUKU.getName().equals(purchaseItemVO.getIntoStatus())) {
  296. throw new BaseBusinessException(ResponseCodeEnum.OPERATE_FAIL.getCode(), ErrorCodeEnum.NO_WAIT_INTO.getMessage());
  297. } else {
  298. purchaseItemMapper.deleteById(purchaseItemVO.getItemId());
  299. }
  300. }
  301. }
  302. // 编辑的(包括新增的)
  303. // 新增的
  304. List<PurchaseItemVO> insertPurchaseItemVOList = purchasevo.getEditPurchaseItemList().stream().filter(it -> it.getItemId() == null).collect(Collectors.toList());
  305. for (PurchaseItemVO purchaseItemVO : insertPurchaseItemVOList) {
  306. PurchaseItem purchaseItem = purchaseItemConvert.convertToPo(purchaseItemVO);
  307. purchaseItem.setPurId(purchase.getPurId());
  308. purchaseItem.setItemIndex(purchaseItemVO.getItemIndex());
  309. purchaseItem.setIntoStatus(Constant.IntoStatus.DAIRUKU.getName());
  310. purchaseItem.setCpId(purchase.getCpId());
  311. purchaseItem.setFromId(purchaseItemVO.getFromId());
  312. purchaseItem.setFromItemId(purchaseItemVO.getFromItemId());
  313. purchaseItem.setPriceDiscount(purchaseItemVO.getPriceDiscount());
  314. purchaseItemMapper.insert(purchaseItem);
  315. }
  316. // 编辑的
  317. List<PurchaseItemVO> editPurchaseItemVOList = purchasevo.getEditPurchaseItemList().stream().filter(it -> it.getItemId() != null).collect(Collectors.toList());
  318. for (PurchaseItemVO purchaseItemVO : editPurchaseItemVOList) {
  319. // 商品数量不能小于可转入库数量数量(入库中+已入库)
  320. if (purchaseItemVO.getItemQty().compareTo(purchaseItemVO.getIntoQty().add(purchaseItemVO.getIntoingQty())) == -1) {
  321. throw new BaseBusinessException(ResponseCodeEnum.OPERATE_FAIL.getCode(), ErrorCodeEnum.ITEMQTY_NO_LESS_INTOQTY.getMessage());
  322. } else {
  323. PurchaseItem purchaseItem = purchaseItemConvert.convertToPo(purchaseItemVO);
  324. purchaseItemService.updataById(purchaseItem);
  325. }
  326. }
  327. return ResponseResultUtil.success(super.update(purchase, new UpdateWrapper<Purchase>().lambda().eq(Purchase::getPurId,
  328. UUID.fromString(purchase.getPurId ()))));
  329. }
  330. /**
  331. * @desc : 作废
  332. * @author : 常皓宁
  333. * @date : 2024-03-08 16:38
  334. */
  335. public ResponseResultVO<?> invalid(String id) {
  336. Purchase purForUpdate = purchaseMapper.selectByIdForUpdate(id);
  337. // 并发校验
  338. if (!purForUpdate.getFlgValid()) {
  339. throw new BaseBusinessException(ResponseCodeEnum.OPERATE_FAIL.getCode(), ErrorCodeEnum.ISFLGVALID_FALSE.getMessage());
  340. }
  341. // 如果入库中数量或已入库数量不是0,不能作废
  342. if (purForUpdate.getIntoQty().compareTo(BigDecimal.ZERO) != 0 || purForUpdate.getIntoingQty().compareTo(BigDecimal.ZERO) != 0) {
  343. throw new BaseBusinessException(ResponseCodeEnum.OPERATE_FAIL.getCode(), ErrorCodeEnum.ISEXISTS_AFTER_OPERATE.getMessage());
  344. }
  345. // 作废
  346. Purchase purUpdate = new Purchase();
  347. purUpdate.setFlgValid(false).setPurId(id);
  348. super.update(purUpdate, new UpdateWrapper<Purchase>().lambda().eq(Purchase::getPurId,
  349. UUID.fromString(purUpdate.getPurId ())));
  350. return ResponseResultUtil.success();
  351. }
  352. /**
  353. * @desc : 采购订单 转 采购入库 (目前废弃)
  354. * @author : 王英杰
  355. * @date : 2024年3月11日
  356. */
  357. @Transactional(
  358. rollbackFor = {Exception.class}
  359. )
  360. public ResponseResultVO<Boolean> insertInbound(PurchaseVO purchasevo) {
  361. ResponseResultVO<Boolean> result = new ResponseResultVO<>();
  362. // todo 给 inboundVO 实体放入数据
  363. InboundVO inboundVO = convertEntity(purchasevo); //转换实体
  364. inboundService.insert(inboundVO); //新建入库单
  365. //TODO 反更 采购订单 状态为已入库
  366. // PurchaseService.update(purchasevo);
  367. // 检查入库单是否成功插入
  368. if (inboundVO.getIntoId() != null) { //插入入库单成功
  369. List<InboundItemVO> itemList = new ArrayList<>();
  370. itemList = inboundVO.getItemList();
  371. for (InboundItemVO objitem : itemList) {
  372. inboundItemService.insert(objitem); //插入入库单明细
  373. //todo 插入一个 已入库明细 就要插入一个 库存明细
  374. }
  375. result.setData(true);
  376. } else {
  377. // 如果入库单插入失败,可以进行相应的处理,比如回滚事务或者返回错误信息
  378. result.setData(false);
  379. result.setMessage("插入入库单失败");
  380. }
  381. return result;
  382. }
  383. /**
  384. * @desc : 采购订单实体数据 转 入库单数据 (目前废弃)
  385. * @author : 王英杰
  386. * @date : 2024年3月11日
  387. */
  388. private InboundVO convertEntity (PurchaseVO purchaseVO){
  389. InboundVO inboundVO = new InboundVO();
  390. inboundVO.setItemList(convertEntityDetail(purchaseVO.getPurchaseItemVOList()));//转明细实体
  391. inboundVO.setIntoType("入库类型-采购入库");
  392. inboundVO.setFromId(purchaseVO.getPurId());
  393. inboundVO.setFromNo(purchaseVO.getPurNo());
  394. inboundVO.setOrgId(purchaseVO.getOrgId());
  395. inboundVO.setStaffId(purchaseVO.getStaffId());
  396. inboundVO.setCusId("");
  397. inboundVO.setSupId(purchaseVO.getSupId());
  398. inboundVO.setIntoStatus("入库状态-已入库");
  399. // inboundVO.setIntoingQty(); todo 合计 商品入库中数量
  400. // inboundVO.setIntoingAmt(); todo 合计 商品入库中金额
  401. inboundVO.setWhId(purchaseVO.getWhId());
  402. inboundVO.setIntoDate(LocalDate.now()); //入库时间为当前时间
  403. inboundVO.setRemarks(purchaseVO.getRemarks());
  404. // inboundVO.getAnnexPaths(purchaseVO.getAnnexPaths()); todo 附件
  405. inboundVO.setMakeStaff(purchaseVO.getMakeStaff());
  406. inboundVO.setMakeTime(purchaseVO.getMakeTime());
  407. inboundVO.setCpId(purchaseVO.getCpId());
  408. return inboundVO;
  409. }
  410. /**
  411. * @desc : 采购订单明细实体数据 转 入库单明细数据 (目前废弃)
  412. * @author : 王英杰
  413. * @date : 2024年3月11日
  414. */
  415. private List<InboundItemVO> convertEntityDetail( List <PurchaseItemVO> PurchaseItemVOList){
  416. List<InboundItemVO> InboundItemVOList = new ArrayList<>();
  417. for (int i=0 ; i<PurchaseItemVOList.size() ; i++){
  418. InboundItemVO inboundItemVO = new InboundItemVO();
  419. PurchaseItemVO purchaseItemVO = PurchaseItemVOList.get(i);
  420. inboundItemVO.setIntoId(purchaseItemVO.getPurId());
  421. inboundItemVO.setIntoType("入库类型-采购入库");
  422. inboundItemVO.setFromId(purchaseItemVO.getPurId());
  423. inboundItemVO.setFromItemId(purchaseItemVO.getItemId());
  424. inboundItemVO.setItemIndex(purchaseItemVO.getItemIndex());
  425. inboundItemVO.setSkuId(purchaseItemVO.getSkuId());
  426. inboundItemVO.setPriceInto(purchaseItemVO.getPricePur());
  427. // inboundItemVO.setNonStdCode(); todo 非标号
  428. inboundItemVO.setIntoStatus("入库状态-已入库");
  429. inboundItemVO.setIntoingQty(purchaseItemVO.getItemQty());
  430. inboundItemVO.setIntoingAmt(purchaseItemVO.getItemAmt());
  431. inboundItemVO.setRemarks(purchaseItemVO.getRemarks());
  432. // inboundItemVO.setInvId( ); todo 需要先生成 库存明细 在生成入库明细
  433. InboundItemVOList.add(inboundItemVO);
  434. }
  435. return InboundItemVOList;
  436. }
  437. /**
  438. * @desc : 采购跟踪
  439. * @author : 常皓宁
  440. * @date : 2024/4/22 10:19
  441. */
  442. public ResponseResultVO<PageList> selectTrackReport(Map<String, Object> param) {
  443. // 获取组合商品
  444. Map<String, Object> map = purchaseMapper.selectTrackReport(param);
  445. JSONObject sku = JSONObject.parseObject(map.get("f_query_pur_for_track").toString());
  446. // 定义返回值
  447. PageList data = new PageList<>();
  448. List dataList = sku.get("data") != null ? JSONObject.parseArray(sku.get("data").toString()).toJavaList(Map.class) : new ArrayList();
  449. // 组装返回值
  450. data.setList(dataList);
  451. return ResponseResultUtil.success(data);
  452. }
  453. }