|
|
@@ -0,0 +1,269 @@
|
|
|
+package com.java110.store.cmd.collection;
|
|
|
+
|
|
|
+import com.alibaba.fastjson.JSONArray;
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
+import com.java110.core.annotation.Java110Cmd;
|
|
|
+import com.java110.core.context.ICmdDataFlowContext;
|
|
|
+import com.java110.core.event.cmd.Cmd;
|
|
|
+import com.java110.core.event.cmd.CmdEvent;
|
|
|
+import com.java110.core.factory.GenerateCodeFactory;
|
|
|
+import com.java110.doc.annotation.*;
|
|
|
+import com.java110.dto.purchaseApply.PurchaseApplyDto;
|
|
|
+import com.java110.dto.resourceStore.ResourceStoreDto;
|
|
|
+import com.java110.dto.resourceStoreTimes.ResourceStoreTimesDto;
|
|
|
+import com.java110.dto.userStorehouse.UserStorehouseDto;
|
|
|
+import com.java110.intf.store.*;
|
|
|
+import com.java110.po.purchase.PurchaseApplyDetailPo;
|
|
|
+import com.java110.po.purchase.PurchaseApplyPo;
|
|
|
+import com.java110.po.purchase.ResourceStorePo;
|
|
|
+import com.java110.po.resourceStoreTimes.ResourceStoreTimesPo;
|
|
|
+import com.java110.po.userStorehouse.UserStorehousePo;
|
|
|
+import com.java110.utils.exception.CmdException;
|
|
|
+import com.java110.utils.util.Assert;
|
|
|
+import com.java110.utils.util.BeanConvertUtil;
|
|
|
+import com.java110.utils.util.StringUtil;
|
|
|
+import com.java110.vo.ResultVo;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+
|
|
|
+import java.math.BigDecimal;
|
|
|
+import java.text.ParseException;
|
|
|
+import java.util.ArrayList;
|
|
|
+import java.util.List;
|
|
|
+
|
|
|
+
|
|
|
+/**
|
|
|
+ * 采购人员入库 功能
|
|
|
+ * 请求地址为/app/purchase/resourceEnter
|
|
|
+ */
|
|
|
+
|
|
|
+@Java110CmdDoc(title = "仓库管理员 领用出库",
|
|
|
+ description = "主要用于 仓库管理员领用出库",
|
|
|
+ httpMethod = "post",
|
|
|
+ url = "http://{ip}:{port}/app/collection/resourceOut",
|
|
|
+ resource = "storeDoc",
|
|
|
+ author = "吴学文",
|
|
|
+ serviceCode = "collection.resourceOut"
|
|
|
+)
|
|
|
+
|
|
|
+@Java110ParamsDoc(params = {
|
|
|
+ @Java110ParamDoc(name = "applyOrderId", length = 30, remark = "采购申请单订单ID"),
|
|
|
+ @Java110ParamDoc(name = "purchaseApplyDetailVo", type = "Array",length = 30, remark = "采购物品信息"),
|
|
|
+ @Java110ParamDoc(parentNodeName = "-", name = "purchaseQuantity", type = "Int",length = 30, remark = "数量"),
|
|
|
+ @Java110ParamDoc(parentNodeName = "-", name = "id", type = "String",length = 30, remark = "采购明细ID"),
|
|
|
+ @Java110ParamDoc(parentNodeName = "-", name = "resId", type = "String",length = 30, remark = "物品ID"),
|
|
|
+})
|
|
|
+
|
|
|
+@Java110ResponseDoc(
|
|
|
+ params = {
|
|
|
+ @Java110ParamDoc(name = "code", type = "int", length = 11, defaultValue = "0", remark = "返回编号,0 成功 其他失败"),
|
|
|
+ @Java110ParamDoc(name = "msg", type = "String", length = 250, defaultValue = "成功", remark = "描述"),
|
|
|
+ }
|
|
|
+)
|
|
|
+
|
|
|
+@Java110ExampleDoc(
|
|
|
+ reqBody="{'applyOrderId':'123123','purchaseApplyDetailVo':[{'purchaseQuantity':'10','id':'123123','resId':'343434'}]}",
|
|
|
+ resBody="{'code':0,'msg':'成功'}"
|
|
|
+)
|
|
|
+
|
|
|
+/**
|
|
|
+ * 物品领用
|
|
|
+ */
|
|
|
+@Java110Cmd(serviceCode = "/collection/resourceOut")
|
|
|
+public class ResourceOutCmd extends Cmd {
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IPurchaseApplyInnerServiceSMO purchaseApplyInnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IPurchaseApplyDetailInnerServiceSMO purchaseApplyDetailInnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IResourceStoreInnerServiceSMO resourceStoreInnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IUserStorehouseInnerServiceSMO userStorehouseInnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IResourceStoreTimesV1InnerServiceSMO resourceStoreTimesV1InnerServiceSMOImpl;
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
|
|
|
+ Assert.hasKeyAndValue(reqJson, "applyOrderId", "订单ID为空");
|
|
|
+ JSONArray purchaseApplyDetails = reqJson.getJSONArray("purchaseApplyDetailVo");
|
|
|
+ List<PurchaseApplyDetailPo> purchaseApplyDetailPos = new ArrayList<>();
|
|
|
+ for (int detailIndex = 0; detailIndex < purchaseApplyDetails.size(); detailIndex++) {
|
|
|
+ JSONObject purchaseApplyDetail = purchaseApplyDetails.getJSONObject(detailIndex);
|
|
|
+ Assert.hasKeyAndValue(purchaseApplyDetail, "purchaseQuantity", "采购数量未填写");
|
|
|
+ Assert.hasKeyAndValue(purchaseApplyDetail, "id", "明细ID为空");
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
|
|
|
+
|
|
|
+ JSONArray purchaseApplyDetails = reqJson.getJSONArray("purchaseApplyDetailVo");
|
|
|
+ List<PurchaseApplyDetailPo> purchaseApplyDetailPos = new ArrayList<>();
|
|
|
+ for (int detailIndex = 0; detailIndex < purchaseApplyDetails.size(); detailIndex++) {
|
|
|
+ JSONObject purchaseApplyDetail = purchaseApplyDetails.getJSONObject(detailIndex);
|
|
|
+ PurchaseApplyDetailPo purchaseApplyDetailPo = BeanConvertUtil.covertBean(purchaseApplyDetail, PurchaseApplyDetailPo.class);
|
|
|
+ purchaseApplyDetailPos.add(purchaseApplyDetailPo);
|
|
|
+ }
|
|
|
+ PurchaseApplyPo purchaseApplyPo = new PurchaseApplyPo();
|
|
|
+ purchaseApplyPo.setApplyOrderId(reqJson.getString("applyOrderId"));
|
|
|
+ purchaseApplyPo.setPurchaseApplyDetailPos(purchaseApplyDetailPos);
|
|
|
+
|
|
|
+ PurchaseApplyDto purchaseApplyDto = new PurchaseApplyDto();
|
|
|
+ purchaseApplyDto.setApplyOrderId(purchaseApplyPo.getApplyOrderId());
|
|
|
+ List<PurchaseApplyDto> purchaseApplyDtos = purchaseApplyInnerServiceSMOImpl.queryPurchaseApplys(purchaseApplyDto);
|
|
|
+ Assert.listOnlyOne(purchaseApplyDtos, "出库单不存在");
|
|
|
+ purchaseApplyDetailPos = purchaseApplyPo.getPurchaseApplyDetailPos();
|
|
|
+ for (PurchaseApplyDetailPo purchaseApplyDetailPo : purchaseApplyDetailPos) {
|
|
|
+ purchaseApplyDetailInnerServiceSMOImpl.updatePurchaseApplyDetail(purchaseApplyDetailPo);
|
|
|
+ //查询物品资源信息
|
|
|
+ ResourceStoreDto resourceStore = new ResourceStoreDto();
|
|
|
+ resourceStore.setResId(purchaseApplyDetailPo.getResId());
|
|
|
+ List<ResourceStoreDto> resourceStores = resourceStoreInnerServiceSMOImpl.queryResourceStores(resourceStore);
|
|
|
+ Assert.listOnlyOne(resourceStores, "查询物品资源信息错误!");
|
|
|
+ ResourceStorePo resourceStorePo = new ResourceStorePo();
|
|
|
+ resourceStorePo.setResId(purchaseApplyDetailPo.getResId());
|
|
|
+ resourceStorePo.setStock("-" + purchaseApplyDetailPo.getPurchaseQuantity());
|
|
|
+ resourceStorePo.setResOrderType(PurchaseApplyDto.RES_ORDER_TYPE_OUT);
|
|
|
+ //获取原物品最小计量总数
|
|
|
+ if (StringUtil.isEmpty(resourceStores.get(0).getMiniStock())) {
|
|
|
+ throw new IllegalArgumentException("最小计量总数不能为空!");
|
|
|
+ }
|
|
|
+ BigDecimal miniStock1 = new BigDecimal(resourceStores.get(0).getMiniStock());
|
|
|
+ BigDecimal purchaseQuantity = new BigDecimal(purchaseApplyDetailPo.getPurchaseQuantity());
|
|
|
+ if (StringUtil.isEmpty(resourceStores.get(0).getMiniUnitStock())) {
|
|
|
+ throw new IllegalArgumentException("最小计量单位数量不能为空!");
|
|
|
+ }
|
|
|
+ //获取物品最小计量单位数量
|
|
|
+ BigDecimal miniUnitStock1 = new BigDecimal(resourceStores.get(0).getMiniUnitStock());
|
|
|
+ //计算领用物品的最小计量总数
|
|
|
+ BigDecimal applyQuantity = purchaseQuantity.multiply(miniUnitStock1);
|
|
|
+ //计算物品领用后剩余的最小计量总数
|
|
|
+ BigDecimal newMiniStock = miniStock1.subtract(applyQuantity);
|
|
|
+ if (newMiniStock.compareTo(BigDecimal.ZERO) == -1) {
|
|
|
+ throw new IllegalArgumentException("物品库存已经不足,请确认物品库存!");
|
|
|
+ }
|
|
|
+ resourceStorePo.setMiniStock(String.valueOf(newMiniStock));
|
|
|
+ resourceStoreInnerServiceSMOImpl.updateResourceStore(resourceStorePo);
|
|
|
+
|
|
|
+ //加入 从库存中扣减
|
|
|
+ subResourceStoreTimesStock(purchaseApplyDetailPo.getResId(), purchaseApplyDetailPo.getPurchaseQuantity());
|
|
|
+
|
|
|
+ ResourceStoreDto resourceStoreDto = new ResourceStoreDto();
|
|
|
+ resourceStoreDto.setResId(purchaseApplyDetailPo.getResId());
|
|
|
+ //查询物品资源
|
|
|
+ List<ResourceStoreDto> resourceStoreDtos = resourceStoreInnerServiceSMOImpl.queryResourceStores(resourceStoreDto);
|
|
|
+ if (resourceStoreDtos == null || resourceStoreDtos.size() < 1) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ //获取物品单位
|
|
|
+ String unitCode = resourceStoreDtos.get(0).getUnitCode();
|
|
|
+ //获取物品最小计量单位
|
|
|
+ String miniUnitCode = resourceStoreDtos.get(0).getMiniUnitCode();
|
|
|
+ //获取物品最小计量单位数量
|
|
|
+ String miniUnitStock = resourceStoreDtos.get(0).getMiniUnitStock();
|
|
|
+ //入库到个人仓库中
|
|
|
+ UserStorehousePo userStorehousePo = new UserStorehousePo();
|
|
|
+ userStorehousePo.setUsId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_usId));
|
|
|
+ userStorehousePo.setResId(resourceStoreDtos.get(0).getResId());
|
|
|
+ userStorehousePo.setResCode(resourceStoreDtos.get(0).getResCode());
|
|
|
+ userStorehousePo.setResName(resourceStoreDtos.get(0).getResName());
|
|
|
+ userStorehousePo.setStoreId(resourceStoreDtos.get(0).getStoreId());
|
|
|
+ userStorehousePo.setUserId(purchaseApplyDtos.get(0).getUserId());
|
|
|
+ //查询物品 是否已经存在
|
|
|
+ UserStorehouseDto userStorehouseDto = new UserStorehouseDto();
|
|
|
+ userStorehouseDto.setResCode(resourceStoreDtos.get(0).getResCode());
|
|
|
+ userStorehouseDto.setUserId(purchaseApplyDtos.get(0).getUserId());
|
|
|
+ userStorehouseDto.setStoreId(resourceStoreDtos.get(0).getStoreId());
|
|
|
+ List<UserStorehouseDto> userStorehouseDtos = userStorehouseInnerServiceSMOImpl.queryUserStorehouses(userStorehouseDto);
|
|
|
+ if (userStorehouseDtos == null || userStorehouseDtos.size() < 1) {
|
|
|
+ userStorehousePo.setStock(purchaseApplyDetailPo.getPurchaseQuantity());
|
|
|
+ if (!StringUtil.isEmpty(unitCode) && !StringUtil.isEmpty(miniUnitCode) && !StringUtil.isEmpty(miniUnitStock) && !unitCode.equals(miniUnitCode)) {
|
|
|
+ //获取领取数量
|
|
|
+ BigDecimal purchaseQuantity2 = new BigDecimal(purchaseApplyDetailPo.getPurchaseQuantity());
|
|
|
+ BigDecimal miniUnitStock2 = new BigDecimal(miniUnitStock);
|
|
|
+ //计算个人物品最小计量总数
|
|
|
+ BigDecimal quantity = purchaseQuantity2.multiply(miniUnitStock2);
|
|
|
+ userStorehousePo.setMiniStock(String.valueOf(quantity));
|
|
|
+ } else {
|
|
|
+ userStorehousePo.setMiniStock(purchaseApplyDetailPo.getPurchaseQuantity());
|
|
|
+ }
|
|
|
+ userStorehouseInnerServiceSMOImpl.saveUserStorehouses(userStorehousePo);
|
|
|
+ } else {
|
|
|
+ //获取个人物品领用后的库存
|
|
|
+ BigDecimal purchaseQuantity3 = new BigDecimal(purchaseApplyDetailPo.getPurchaseQuantity());
|
|
|
+ BigDecimal stock3 = new BigDecimal(userStorehouseDtos.get(0).getStock());
|
|
|
+ BigDecimal total = purchaseQuantity3.add(stock3);
|
|
|
+ userStorehousePo.setStock(total.toString());
|
|
|
+ userStorehousePo.setUsId(userStorehouseDtos.get(0).getUsId());
|
|
|
+ if (!StringUtil.isEmpty(unitCode) && !StringUtil.isEmpty(miniUnitCode) && !StringUtil.isEmpty(miniUnitStock) && !unitCode.equals(miniUnitCode)) {
|
|
|
+ //获取本次领取数量
|
|
|
+ BigDecimal miniUnitStock3 = new BigDecimal(miniUnitStock);
|
|
|
+ //计算本次领取的个人物品最小计量总数
|
|
|
+ BigDecimal quantity = purchaseQuantity3.multiply(miniUnitStock3);
|
|
|
+ BigDecimal miniStock = new BigDecimal(0);
|
|
|
+ //获取个人物品原先的最小计量总数
|
|
|
+ if (StringUtil.isEmpty(userStorehouseDtos.get(0).getMiniStock())) {
|
|
|
+ throw new IllegalArgumentException("信息错误,个人物品最小计量总数不能为空!");
|
|
|
+ } else {
|
|
|
+ miniStock = new BigDecimal(userStorehouseDtos.get(0).getMiniStock());
|
|
|
+ }
|
|
|
+ //计算领用后个人物品总的最小计量总数
|
|
|
+ BigDecimal miniQuantity = quantity.add(miniStock);
|
|
|
+ userStorehousePo.setMiniStock(String.valueOf(miniQuantity));
|
|
|
+ } else {
|
|
|
+ userStorehousePo.setMiniStock(String.valueOf(total));
|
|
|
+ }
|
|
|
+ userStorehouseInnerServiceSMOImpl.updateUserStorehouses(userStorehousePo);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //获取订单号
|
|
|
+ String applyOrderId = purchaseApplyPo.getApplyOrderId();
|
|
|
+ PurchaseApplyPo purchaseApply = new PurchaseApplyPo();
|
|
|
+ purchaseApply.setApplyOrderId(applyOrderId);
|
|
|
+ purchaseApply.setState(PurchaseApplyDto.STATE_AUDITED);
|
|
|
+ purchaseApply.setStatusCd("0");
|
|
|
+ purchaseApplyInnerServiceSMOImpl.updatePurchaseApply(purchaseApply);
|
|
|
+ context.setResponseEntity(ResultVo.createResponseEntity(ResultVo.CODE_OK, "出库成功"));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 从times中扣减
|
|
|
+ * @param resId
|
|
|
+ * @param applyQuantity
|
|
|
+ */
|
|
|
+ private void subResourceStoreTimesStock(String resId, String applyQuantity) {
|
|
|
+
|
|
|
+ ResourceStoreTimesDto resourceStoreTimesDto = new ResourceStoreTimesDto();
|
|
|
+ resourceStoreTimesDto.setResId(resId);
|
|
|
+ resourceStoreTimesDto.setHasStock("Y");
|
|
|
+ List<ResourceStoreTimesDto> resourceStoreTimesDtos = resourceStoreTimesV1InnerServiceSMOImpl.queryResourceStoreTimess(resourceStoreTimesDto);
|
|
|
+
|
|
|
+ if (resourceStoreTimesDtos == null || resourceStoreTimesDtos.size() < 1) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ int stock = 0;
|
|
|
+ int quantity = Integer.parseInt(applyQuantity);
|
|
|
+ ResourceStoreTimesPo resourceStoreTimesPo = null;
|
|
|
+ for (ResourceStoreTimesDto resourceStoreTimesDto1 : resourceStoreTimesDtos) {
|
|
|
+ stock = Integer.parseInt(resourceStoreTimesDto1.getStock());
|
|
|
+ if (stock > quantity) {
|
|
|
+ stock = stock - quantity;
|
|
|
+ resourceStoreTimesPo = new ResourceStoreTimesPo();
|
|
|
+ resourceStoreTimesPo.setTimesId(resourceStoreTimesDto1.getTimesId());
|
|
|
+ resourceStoreTimesPo.setStock(stock + "");
|
|
|
+ resourceStoreTimesV1InnerServiceSMOImpl.updateResourceStoreTimes(resourceStoreTimesPo);
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ quantity = quantity - stock;
|
|
|
+ resourceStoreTimesPo = new ResourceStoreTimesPo();
|
|
|
+ resourceStoreTimesPo.setTimesId(resourceStoreTimesDto1.getTimesId());
|
|
|
+ resourceStoreTimesPo.setStock("0");
|
|
|
+ resourceStoreTimesV1InnerServiceSMOImpl.updateResourceStoreTimes(resourceStoreTimesPo);
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|