| | |
| | | package com.consum.base.service.impl; |
| | | |
| | | import com.consum.base.service.GoodsBaseServiceImpl; |
| | | import com.consum.base.service.LGoodsUserRecordServiceImpl; |
| | | import com.consum.base.service.LGoodsWhRecordServiceImpl; |
| | | import com.consum.base.service.LWarehouseFlowService; |
| | | import com.consum.base.service.LWhFormTransferService; |
| | | import com.consum.base.service.LWhGoodsRecordService; |
| | | import com.consum.base.service.LWhGoodsService; |
| | | import java.util.ArrayList; |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | |
| | | import com.consum.base.core.service.LWhWarningCoreServiceImpl; |
| | | import com.consum.base.core.utils.IdUtil; |
| | | import com.consum.base.core.utils.LockManage; |
| | | import com.consum.base.service.GoodsBaseServiceImpl; |
| | | import com.consum.base.service.LGoodsUserRecordServiceImpl; |
| | | import com.consum.base.service.LGoodsWhRecordServiceImpl; |
| | | import com.consum.base.service.LWarehouseFlowService; |
| | | import com.consum.base.service.LWhFormTransferService; |
| | | import com.consum.base.service.LWhGoodsRecordService; |
| | | import com.consum.base.service.LWhGoodsService; |
| | | import com.consum.model.po.LGoodsUserRecord; |
| | | import com.consum.model.po.LWarehouseFlow; |
| | | import com.consum.model.po.LWhFormTransfer; |
| | |
| | | Long userId = currentUser.getId(); |
| | | String nickName = currentUser.getNick_name(); |
| | | long dealTime = DateUtils.getDateTimeNumber(System.currentTimeMillis()); |
| | | //单据类型。0仓库调拨;1部门分发;2部门物品回退 |
| | | // 单据类型。0仓库调拨;1部门分发;2部门物品回退 |
| | | Integer businessType = lWhFormTransfer.getBusinessType(); |
| | | businessType = businessType == null ? 0 : businessType; |
| | | WhBusinessEnum businessEnum = WhBusinessEnum.DIAOBO; |
| | |
| | | try { |
| | | // 根据调拨单 生成 出库单 这样就能公用出库 |
| | | lWhFormTransfer.getBusinessType(); |
| | | outWarehouseFormId = lWhFormOutputCoreService.createOutFormByTransId(whFormTransferId, businessEnum, currentUser, dealTime); |
| | | outWarehouseFormId = |
| | | lWhFormOutputCoreService.createOutFormByTransId(whFormTransferId, businessEnum, currentUser, dealTime); |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage()); |
| | | return; |
| | | } |
| | | // 出库单 出库,返回 出库单流水Id |
| | | Long lWarehouseFlowId = lWhFormOutputCoreService.outFormByTransId(outWarehouseFormId, businessEnum, currentUser, dealTime, whFormTransferId); |
| | | Long lWarehouseFlowId = lWhFormOutputCoreService.outFormByTransId(outWarehouseFormId, businessEnum, currentUser, |
| | | dealTime, whFormTransferId); |
| | | |
| | | // 更新调拨单 |
| | | lWhFormTransfer = new LWhFormTransfer(whFormTransferId); |
| | |
| | | |
| | | // 流水记录总表ID |
| | | long inWarehouseFlowId = NumberGenerator.getLongSequenceNumber(); |
| | | //单据类型。0仓库调拨;1部门分发;2部门物品回退 |
| | | // 单据类型。0仓库调拨;1部门分发;2部门物品回退 |
| | | Integer businessType = lWhFormTransfer.getBusinessType(); |
| | | //状态(0=在途调拨;1=入库未分发;2=已下发;3=报废 4 零星出库) |
| | | // 状态(0=在途调拨;1=入库未分发;2=已下发;3=报废 4 零星出库) |
| | | Integer goodsStatus = 1; |
| | | //类型0分发使用1 反库 |
| | | // 类型0分发使用1 反库 |
| | | Integer recordType = null; |
| | | if (businessType == 1) { |
| | | goodsStatus = 2; |
| | |
| | | whGoodsRecord.setWarehouseType(inWarehouseType); |
| | | whGoodsRecord.setWarehouseId(inWarehouseId); |
| | | whGoodsRecord.setDealTime(dealTime); |
| | | //通过LockManage获得锁 |
| | | // 通过LockManage获得锁 |
| | | Object warehouseModelLockObj = LockManage.acquireLock(inWarehouseType, inWarehouseId, baseGoodsModelsId); |
| | | List<Long> outGoodsIds = null; |
| | | synchronized (warehouseModelLockObj) { |
| | |
| | | throw new RuntimeException("入库单失败,未查询到物品!"); |
| | | } |
| | | // 库存物品详情(L_WH_GOODS)中 状态设置为1 |
| | | lWhGoodsService.modGoodsTransfering(outGoodsIds, inWarehouseType, inWarehouseId, inWarehouseName, goodsStatus); |
| | | lWhGoodsService.modGoodsTransfering(outGoodsIds, inWarehouseType, inWarehouseId, inWarehouseName, |
| | | goodsStatus); |
| | | |
| | | // 通过物品id查询所有商品的总金额 |
| | | // long amount = lWhGoodsService.queryGoodsPriceById(outGoodsIds); |
| | | // LWhProcureModel lWhFormScrappedGoods = new LWhProcureModel(formScrappedGood.getId()); |
| | | // lWhFormScrappedGoods.setTotalAmount(amount); |
| | | // lWhFormTransferService.update(lWhFormScrappedGoods); |
| | | |
| | | // 获得锁后查询该型号的期初数量 |
| | | int goodsModelNum = lWhGoodsService.queryGoodsModelNum(inWarehouseType, inWarehouseId, baseGoodsModelsId, 1, null); |
| | | int goodsModelNum = |
| | | lWhGoodsService.queryGoodsModelNum(inWarehouseType, inWarehouseId, baseGoodsModelsId, 1, null); |
| | | whGoodsRecord.setInitialCount(goodsModelNum); |
| | | whGoodsRecord.setEndCount(goodsModelNum + whGoodsRecord.getThisCount()); |
| | | long totalAmount = lWhGoodsService.queryGoodsPriceById(outGoodsIds); |
| | | whGoodsRecord.setTotalPrice(totalAmount); |
| | | } |
| | | if (businessType == 1) { |
| | | // List<Map<String, Object>> modelInfo = baseGoodsModelsService.queryGoodsModelInfo(baseGoodsModelsId); |
| | | // List<Map<String, Object>> modelInfo = baseGoodsModelsService.queryGoodsModelInfo(baseGoodsModelsId); |
| | | // 1部门分发 此时要往 物品使用记录【L_GOODS_USER_RECORD】添加数据 |
| | | //查询部门分发使用人 |
| | | // 查询部门分发使用人 |
| | | LWhProcureModelUser lWhProcureModelUser = new LWhProcureModelUser(); |
| | | lWhProcureModelUser.setTransBusinessId(whFormTransferId); |
| | | lWhProcureModelUser.setBaseGoodsModelsId(baseGoodsModelsId); |
| | | List<LWhProcureModelUser> goodsUserInfo = goodsBaseService.select(lWhProcureModelUser); |
| | | //将物品型号以前的使用记录设置为非最新 |
| | | // 将物品型号以前的使用记录设置为非最新 |
| | | lGoodsUserRecordService.updSetNotLast(outGoodsIds); |
| | | if (!CollectionUtils.isEmpty(goodsUserInfo)) { |
| | | //认为是A类物品 |
| | | int totalGoodsNum = goodsUserInfo.stream().filter(item -> item.getGoodsNum() != null).mapToInt(LWhProcureModelUser::getGoodsNum).sum(); |
| | | // 认为是A类物品 |
| | | int totalGoodsNum = goodsUserInfo.stream().filter(item -> item.getGoodsNum() != null) |
| | | .mapToInt(LWhProcureModelUser::getGoodsNum).sum(); |
| | | if (totalGoodsNum != outGoodsIds.size()) { |
| | | TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); |
| | | throw new RuntimeException("入库单失败,使用人使用数量与物品数量不一致"); |
| | | // log.error("创建入库单失败"); |
| | | // log.error("创建入库单失败"); |
| | | } |
| | | |
| | | ArrayList<LGoodsUserRecord> goodsUserRecordList = new ArrayList<>(); |
| | |
| | | // 更新下标位置 |
| | | startIndex += goodsNum; |
| | | } |
| | | //批量插入使用人记录 |
| | | // 批量插入使用人记录 |
| | | lGoodsUserRecordService.insertBatch(goodsUserRecordList); |
| | | } |
| | | } |
| | | //将保管仓库信息更新到 物品仓库保管记录【L_GOODS_WH_RECORD】 |
| | | // 将保管仓库信息更新到 物品仓库保管记录【L_GOODS_WH_RECORD】 |
| | | lGoodsWhRecordService.insertNewRecord(outGoodsIds, inWarehouseFlowId, dealTime); |
| | | |
| | | LWhGoodsRecordDetails lWhGoodsRecordDetails = new LWhGoodsRecordDetails(); |
| | | lWhGoodsRecordDetails.setWhGoodsRecordId(oldRecordId); |
| | | List<LWhGoodsRecordDetails> goodsRecordDetailsList = lWhGoodsRecordDetailsService.select(lWhGoodsRecordDetails); |
| | | List<LWhGoodsRecordDetails> goodsRecordDetailsList = |
| | | lWhGoodsRecordDetailsService.select(lWhGoodsRecordDetails); |
| | | for (LWhGoodsRecordDetails whGoodsRecordDetails : goodsRecordDetailsList) { |
| | | whGoodsRecordDetails.setId(null); |
| | | whGoodsRecordDetails.setWhGoodsRecordId(whGoodsRecord.getId()); |
| | |
| | | lWhFormTransfer.setInTime(dealTime); |
| | | lWhFormTransferService.update(lWhFormTransfer); |
| | | |
| | | //当库存变动时调用该方法 |
| | | // 当库存变动时调用该方法 |
| | | if (inWarehouseType == 0) { |
| | | lWhWarningCoreService.updateKuCun(Convert.toShort(inWarehouseType, (short) 0), inWarehouseId, allChangModelList, null, dealTime); |
| | | lWhWarningCoreService.updateKuCun(Convert.toShort(inWarehouseType, (short)0), inWarehouseId, |
| | | allChangModelList, null, dealTime); |
| | | } |
| | | log.info("调拨单:{} 入库完成", whFormTransferId); |
| | | return; |
| | | } |
| | | |
| | | |
| | | private static String GET_GOODSID_BY_FLOWID = "SELECT goods.id FROM L_WH_GOODS_RECORD gr LEFT JOIN L_WH_GOODS_RECORD_DETAILS grd ON gr.id=grd.WH_GOODS_RECORD_ID LEFT JOIN L_WH_GOODS goods ON goods.id=grd.WH_GOODS_ID WHERE 1=1"; |
| | | private static String GET_GOODSID_BY_FLOWID = |
| | | "SELECT goods.id FROM L_WH_GOODS_RECORD gr LEFT JOIN L_WH_GOODS_RECORD_DETAILS grd ON gr.id=grd.WH_GOODS_RECORD_ID LEFT JOIN L_WH_GOODS goods ON goods.id=grd.WH_GOODS_ID WHERE 1=1"; |
| | | |
| | | /** |
| | | * 根据出库流水ID 查询 出库的物品ID |
| | |
| | | if (CollectionUtils.isEmpty(outGoods)) { |
| | | return null; |
| | | } |
| | | List<Long> whGoodsIds = outGoods.stream().map(map -> (Long) map.get("id")).collect(Collectors.toList()); |
| | | List<Long> whGoodsIds = outGoods.stream().map(map -> (Long)map.get("id")).collect(Collectors.toList()); |
| | | return whGoodsIds; |
| | | } |
| | | } |