From 18d1f4bc4f4f77c8883702a00896dd99469db648 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期五, 25 八月 2023 16:06:37 +0800
Subject: [PATCH] Merge branch 'master' of http://git.homecommunity.cn/supervip/MicroCommunity

---
 service-store/src/main/java/com/java110/store/api/CollectionApi.java |  241 ++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 224 insertions(+), 17 deletions(-)

diff --git a/service-store/src/main/java/com/java110/store/api/CollectionApi.java b/service-store/src/main/java/com/java110/store/api/CollectionApi.java
old mode 100644
new mode 100755
index f8cdff4..3435452
--- a/service-store/src/main/java/com/java110/store/api/CollectionApi.java
+++ b/service-store/src/main/java/com/java110/store/api/CollectionApi.java
@@ -3,19 +3,34 @@
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.java110.core.factory.GenerateCodeFactory;
-import com.java110.dto.purchaseApply.PurchaseApplyDto;
-import com.java110.entity.audit.AuditUser;
+import com.java110.dto.purchase.PurchaseApplyDto;
+import com.java110.dto.resource.ResourceStoreDto;
+import com.java110.dto.resource.ResourceStoreTimesDto;
+import com.java110.dto.user.UserDto;
+import com.java110.dto.user.UserStorehouseDto;
+import com.java110.dto.audit.AuditUser;
+import com.java110.intf.store.IResourceStoreInnerServiceSMO;
+import com.java110.intf.store.IResourceStoreTimesV1InnerServiceSMO;
+import com.java110.intf.store.IUserStorehouseInnerServiceSMO;
+import com.java110.intf.user.IUserV1InnerServiceSMO;
 import com.java110.po.purchase.PurchaseApplyDetailPo;
 import com.java110.po.purchase.PurchaseApplyPo;
+import com.java110.po.purchase.ResourceStorePo;
+import com.java110.po.resource.ResourceStoreTimesPo;
+import com.java110.po.user.UserStorehousePo;
 import com.java110.store.bmo.collection.IGetCollectionAuditOrderBMO;
 import com.java110.store.bmo.collection.IGoodsCollectionBMO;
 import com.java110.store.bmo.collection.IResourceOutBMO;
+import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.DateUtil;
+import com.java110.utils.util.StringUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.http.ResponseEntity;
 import org.springframework.web.bind.annotation.*;
 
+import java.math.BigDecimal;
 import java.util.ArrayList;
 import java.util.List;
 
@@ -36,12 +51,24 @@
     @Autowired
     private IResourceOutBMO resourceOutBMOImpl;
 
+    @Autowired
+    private IResourceStoreInnerServiceSMO resourceStoreInnerServiceSMOImpl;
+
+    @Autowired
+    private IUserStorehouseInnerServiceSMO userStorehouseInnerServiceSMOImpl;
+
+    @Autowired
+    private IUserV1InnerServiceSMO userV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IResourceStoreTimesV1InnerServiceSMO resourceStoreTimesV1InnerServiceSMOImpl;
+
+
     /**
      * 鐗╁搧棰嗙敤 鎺ュ彛绫�
      *
      * @param reqJson
      * @param userId
-     * @param userName
      * @param storeId
      * @return {"resourceStores":[{"resId":"852020070239060001","resName":"姘存�х瑪","resCode":"002","price":"2.00","stock":"2",
      * "description":"榛戣壊","quantity":"1"}],"description":"123123","endUserName":"1","endUserTel":"17797173942","file":"",
@@ -50,12 +77,19 @@
     @RequestMapping(value = "/goodsCollection", method = RequestMethod.POST)
     public ResponseEntity<String> goodsCollection(@RequestBody JSONObject reqJson,
                                                   @RequestHeader(value = "user-id") String userId,
-                                                  @RequestHeader(value = "user-name") String userName,
                                                   @RequestHeader(value = "store-id") String storeId) {
+
+        UserDto userDto = new UserDto();
+        userDto.setUserId(userId);
+        List<UserDto> userDtos = userV1InnerServiceSMOImpl.queryUsers(userDto);
+
+        Assert.listOnlyOne(userDtos,"鏈寘鍚敤鎴�");
+
+
+        String userName  = userDtos.get(0).getName();
 
         Assert.hasKeyAndValue(reqJson, "resourceStores", "蹇呭~锛岃濉啓鐗╁搧棰嗙敤鐨勭墿璧�");
         Assert.hasKeyAndValue(reqJson, "description", "蹇呭~锛岃濉啓閲囪喘鐢宠璇存槑");
-
         PurchaseApplyPo purchaseApplyPo = new PurchaseApplyPo();
         purchaseApplyPo.setApplyOrderId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_applyOrderId));
         purchaseApplyPo.setDescription(reqJson.getString("description"));
@@ -65,25 +99,28 @@
         purchaseApplyPo.setEndUserTel(reqJson.getString("endUserTel"));
         purchaseApplyPo.setStoreId(storeId);
         purchaseApplyPo.setResOrderType(PurchaseApplyDto.RES_ORDER_TYPE_OUT);
-        purchaseApplyPo.setState(PurchaseApplyDto.STATE_DEALING);
-
+        purchaseApplyPo.setState(PurchaseApplyDto.STATE_WAIT_DEAL);
+        purchaseApplyPo.setCreateTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
+        purchaseApplyPo.setCreateUserId(userId);
+        purchaseApplyPo.setCreateUserName(userName);
+        purchaseApplyPo.setWarehousingWay(PurchaseApplyDto.WAREHOUSING_TYPE_APPLY);
+        purchaseApplyPo.setCommunityId(reqJson.getString("communityId"));
         JSONArray resourceStores = reqJson.getJSONArray("resourceStores");
-
         List<PurchaseApplyDetailPo> purchaseApplyDetailPos = new ArrayList<>();
-
         for (int resourceStoreIndex = 0; resourceStoreIndex < resourceStores.size(); resourceStoreIndex++) {
             JSONObject resourceStore = resourceStores.getJSONObject(resourceStoreIndex);
+            resourceStore.put("originalStock", resourceStore.get("stock"));
             PurchaseApplyDetailPo purchaseApplyDetailPo = BeanConvertUtil.covertBean(resourceStore, PurchaseApplyDetailPo.class);
             purchaseApplyDetailPo.setId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_applyOrderId));
             purchaseApplyDetailPos.add(purchaseApplyDetailPo);
         }
         purchaseApplyPo.setPurchaseApplyDetailPos(purchaseApplyDetailPos);
-
-        return goodsCollectionBMOImpl.collection(purchaseApplyPo);
+        return goodsCollectionBMOImpl.collection(purchaseApplyPo,reqJson);
     }
 
     /**
      * 鏌ヨ瀹℃牳鍗�
+     *
      * @param page
      * @param row
      * @param userId
@@ -93,18 +130,20 @@
     @RequestMapping(value = "/getCollectionAuditOrder", method = RequestMethod.GET)
     public ResponseEntity<String> getCollectionAuditOrder(@RequestParam(value = "page") int page,
                                                           @RequestParam(value = "row") int row,
+                                                          @RequestParam(value = "communityId") String communityId,
                                                           @RequestHeader(value = "user-id") String userId,
-                                                          @RequestHeader(value = "store-id") String storeId){
-
+                                                          @RequestHeader(value = "store-id") String storeId) {
         AuditUser auditUser = new AuditUser();
         auditUser.setUserId(userId);
         auditUser.setPage(page);
         auditUser.setRow(row);
         auditUser.setStoreId(storeId);
+        auditUser.setCommunityId(communityId);
         return getCollectionAuditOrderBMOImpl.auditOrder(auditUser);
     }
 
     /**
+     * 鐗╁搧鍙戞斁(鐗╁搧鍙戞斁涔嬪悗鐩存帴鍒颁釜浜烘墜涓�)
      * {"resourceOuts":[],"applyOrderId":"152020071665420001","taskId":"237506","resOrderType":"20000",
      * "purchaseApplyDetailVo":[{"applyOrderId":"152020071665420001","id":"152020071690120002","price":"","quantity":"1",
      * "resCode":"002","resId":"852020070239060001","resName":"姘存�х瑪","stock":"2","purchaseQuantity":"2","purchaseRemark":""}]}
@@ -113,9 +152,7 @@
     @RequestMapping(value = "/resourceOut", method = RequestMethod.POST)
     public ResponseEntity<String> resourceOut(@RequestBody JSONObject reqJson) {
         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);
@@ -123,12 +160,182 @@
             Assert.hasKeyAndValue(purchaseApplyDetail, "id", "鏄庣粏ID涓虹┖");
             PurchaseApplyDetailPo purchaseApplyDetailPo = BeanConvertUtil.covertBean(purchaseApplyDetail, PurchaseApplyDetailPo.class);
             purchaseApplyDetailPos.add(purchaseApplyDetailPo);
-
         }
-
         PurchaseApplyPo purchaseApplyPo = new PurchaseApplyPo();
         purchaseApplyPo.setApplyOrderId(reqJson.getString("applyOrderId"));
         purchaseApplyPo.setPurchaseApplyDetailPos(purchaseApplyDetailPos);
         return resourceOutBMOImpl.out(purchaseApplyPo);
     }
+
+    /**
+     * 鐗╁搧棰嗙敤-鐗╁搧鐩存帴鍑哄簱
+     */
+    @RequestMapping(value = "/goodsDelivery", method = RequestMethod.POST)
+    public ResponseEntity<String> goodsDelivery(@RequestBody JSONObject reqJson,
+                                                @RequestHeader(value = "user-id") String userId,
+                                                @RequestHeader(value = "store-id") String storeId) {
+        Assert.hasKeyAndValue(reqJson, "resourceStores", "蹇呭~锛岃濉啓鐗╁搧棰嗙敤鐨勭墿璧�");
+        Assert.hasKeyAndValue(reqJson, "description", "蹇呭~锛岃濉啓閲囪喘鐢宠璇存槑");
+
+        UserDto userDto = new UserDto();
+        userDto.setUserId(userId);
+        List<UserDto> userDtos = userV1InnerServiceSMOImpl.queryUsers(userDto);
+
+        Assert.listOnlyOne(userDtos,"鏈寘鍚敤鎴�");
+
+
+        String userName  = userDtos.get(0).getName();
+
+        PurchaseApplyPo purchaseApplyPo = new PurchaseApplyPo();
+        purchaseApplyPo.setApplyOrderId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_applyOrderId));
+        purchaseApplyPo.setDescription(reqJson.getString("description"));
+        purchaseApplyPo.setUserId(reqJson.getString("receiverUserId"));
+        purchaseApplyPo.setUserName(reqJson.getString("receiverUserName"));
+        purchaseApplyPo.setEndUserName(reqJson.getString("endUserName"));
+        purchaseApplyPo.setEndUserTel(reqJson.getString("endUserTel"));
+        purchaseApplyPo.setStoreId(storeId);
+        purchaseApplyPo.setResOrderType(PurchaseApplyDto.RES_ORDER_TYPE_OUT);
+        purchaseApplyPo.setState(PurchaseApplyDto.STATE_END);
+        purchaseApplyPo.setCreateTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
+        purchaseApplyPo.setCreateUserId(userId);
+        purchaseApplyPo.setCreateUserName(userName);
+        purchaseApplyPo.setWarehousingWay(PurchaseApplyDto.WAREHOUSING_TYPE_DIRECT);
+        purchaseApplyPo.setDescription("鐩存帴鍑哄簱鎿嶄綔");
+        purchaseApplyPo.setCommunityId(reqJson.getString("communityId"));
+        JSONArray resourceStores = reqJson.getJSONArray("resourceStores");
+        List<PurchaseApplyDetailPo> purchaseApplyDetailPos = new ArrayList<>();
+        for (int resourceStoreIndex = 0; resourceStoreIndex < resourceStores.size(); resourceStoreIndex++) {
+            JSONObject resourceStore = resourceStores.getJSONObject(resourceStoreIndex);
+            PurchaseApplyDetailPo purchaseApplyDetailPo = BeanConvertUtil.covertBean(resourceStore, PurchaseApplyDetailPo.class);
+            purchaseApplyDetailPo.setPrice(resourceStore.getString("contrastPrice"));
+            purchaseApplyDetailPo.setId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_applyOrderId));
+            purchaseApplyDetailPo.setQuantity(purchaseApplyDetailPo.getPurchaseQuantity());
+            purchaseApplyDetailPo.setRemark("鐩存帴鍑哄簱");
+            purchaseApplyDetailPo.setOriginalStock(resourceStore.getString("stock"));
+            purchaseApplyDetailPos.add(purchaseApplyDetailPo);
+            //璋冩暣鎬诲簱瀛�
+            ResourceStorePo resourceStorePo = new ResourceStorePo();
+            resourceStorePo.setResId(purchaseApplyDetailPo.getResId());
+            resourceStorePo.setStock("-" + purchaseApplyDetailPo.getPurchaseQuantity());
+            resourceStorePo.setResOrderType(PurchaseApplyDto.RES_ORDER_TYPE_OUT);
+            //璁$畻鍑哄簱鍚庣殑鏈�灏忚閲忔�绘暟
+            BigDecimal oldMiniStock = new BigDecimal(resourceStore.getString("miniStock")); //鑾峰彇鍘熷厛鐨勬渶灏忚閲忔�绘暟
+            BigDecimal oldMiniUnitStock = new BigDecimal(resourceStore.getString("miniUnitStock")); //鑾峰彇鏈�灏忚閲忓崟浣嶆暟閲�
+            BigDecimal nowQuantity = new BigDecimal(purchaseApplyDetailPo.getPurchaseQuantity()); //鑾峰彇鍑哄簱鏁伴噺
+            BigDecimal nowMiniStock = nowQuantity.multiply(oldMiniUnitStock); //璁$畻褰撳墠鍑哄簱鐨勬渶灏忚閲忔�绘暟
+            BigDecimal surplusMiniStock = oldMiniStock.subtract(nowMiniStock);
+            if (surplusMiniStock.compareTo(BigDecimal.ZERO) == -1) {
+                throw new IllegalArgumentException("鐗╁搧搴撳瓨宸茬粡涓嶈冻锛岃纭鐗╁搧搴撳瓨锛�");
+            }
+            resourceStorePo.setMiniStock(String.valueOf(surplusMiniStock));
+            resourceStoreInnerServiceSMOImpl.updateResourceStore(resourceStorePo);
+
+            //鍔犲叆 浠庡簱瀛樹腑鎵e噺
+            subResourceStoreTimesStock(resourceStore.getString("resCode"), purchaseApplyDetailPo);
+
+            //鏌ヨ璧勬簮
+            ResourceStoreDto resourceStoreDto = new ResourceStoreDto();
+            resourceStoreDto.setResId(purchaseApplyDetailPo.getResId());
+            List<ResourceStoreDto> resourceStoreDtos = resourceStoreInnerServiceSMOImpl.queryResourceStores(resourceStoreDto);
+            if (resourceStoreDtos == null || resourceStoreDtos.size() < 1) {
+                throw new IllegalArgumentException("鏈煡璇㈠埌鐗╁搧璧勬簮淇℃伅锛�");
+            }
+            //鑾峰彇鐗╁搧鍗曚綅
+            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.setResName(resourceStoreDtos.get(0).getResName());
+            userStorehousePo.setStoreId(resourceStoreDtos.get(0).getStoreId());
+            userStorehousePo.setUserId(purchaseApplyPo.getUserId());
+            userStorehousePo.setTimesId(purchaseApplyDetailPo.getTimesId());
+
+            //鏌ヨ涓汉鐗╁搧浠撳簱涓� 鏄惁宸茬粡瀛樺湪鍟嗗搧
+            UserStorehouseDto userStorehouseDto = new UserStorehouseDto();
+            userStorehouseDto.setResCode(resourceStoreDtos.get(0).getResCode());
+            userStorehouseDto.setUserId(purchaseApplyPo.getUserId());
+            userStorehouseDto.setStoreId(resourceStoreDtos.get(0).getStoreId());
+            List<UserStorehouseDto> userStorehouseDtos = userStorehouseInnerServiceSMOImpl.queryUserStorehouses(userStorehouseDto);
+            userStorehousePo.setResCode(resourceStoreDtos.get(0).getResCode());
+            if (userStorehouseDtos == null || userStorehouseDtos.size() < 1) {
+                userStorehousePo.setStock(purchaseApplyDetailPo.getPurchaseQuantity());
+                if (!StringUtil.isEmpty(unitCode) && !StringUtil.isEmpty(miniUnitCode) && !StringUtil.isEmpty(miniUnitStock) && !unitCode.equals(miniUnitCode)) {
+                    //鑾峰彇棰嗗彇鏁伴噺
+                    BigDecimal purchaseQuantity = new BigDecimal(purchaseApplyDetailPo.getPurchaseQuantity());
+                    //璁$畻涓汉鐗╁搧鏈�灏忚閲忔�绘暟
+                    BigDecimal miniUnitStock1 = new BigDecimal(miniUnitStock);
+                    BigDecimal quantity = purchaseQuantity.multiply(miniUnitStock1);
+                    userStorehousePo.setMiniStock(String.valueOf(quantity));
+                } else {
+                    userStorehousePo.setMiniStock(purchaseApplyDetailPo.getPurchaseQuantity());
+                }
+                userStorehouseInnerServiceSMOImpl.saveUserStorehouses(userStorehousePo);
+            } else {
+                //鑾峰彇涓汉鐗╁搧棰嗙敤鍚庣殑搴撳瓨
+                BigDecimal purchaseQuantity = new BigDecimal(purchaseApplyDetailPo.getPurchaseQuantity());
+                BigDecimal stock1 = new BigDecimal(userStorehouseDtos.get(0).getStock());
+                BigDecimal total = purchaseQuantity.add(stock1);
+                userStorehousePo.setStock(total + "");
+                userStorehousePo.setUsId(userStorehouseDtos.get(0).getUsId());
+                if (!StringUtil.isEmpty(unitCode) && !StringUtil.isEmpty(miniUnitCode) && !StringUtil.isEmpty(miniUnitStock) && !unitCode.equals(miniUnitCode)) {
+                    //鑾峰彇鏈棰嗗彇鏁伴噺
+                    BigDecimal miniUnitStock1 = new BigDecimal(miniUnitStock);
+                    //璁$畻鏈棰嗗彇鐨勪釜浜虹墿鍝佹渶灏忚閲忔�绘暟
+                    BigDecimal quantity = purchaseQuantity.multiply(miniUnitStock1);
+                    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);
+            }
+        }
+        purchaseApplyPo.setPurchaseApplyDetailPos(purchaseApplyDetailPos);
+        return goodsCollectionBMOImpl.collection(purchaseApplyPo,reqJson);
+    }
+
+    /**
+     * 浠巘imes涓墸鍑�
+     *
+     * @param resCode
+     * @param purchaseApplyDetailPo
+     */
+    private void subResourceStoreTimesStock(String resCode, PurchaseApplyDetailPo purchaseApplyDetailPo) {
+        String applyQuantity = purchaseApplyDetailPo.getPurchaseQuantity();
+        ResourceStoreTimesDto resourceStoreTimesDto = new ResourceStoreTimesDto();
+        resourceStoreTimesDto.setResCode(resCode);
+        resourceStoreTimesDto.setTimesId(purchaseApplyDetailPo.getTimesId());
+        List<ResourceStoreTimesDto> resourceStoreTimesDtos = resourceStoreTimesV1InnerServiceSMOImpl.queryResourceStoreTimess(resourceStoreTimesDto);
+
+        if (resourceStoreTimesDtos == null || resourceStoreTimesDtos.size() < 1) {
+            return;
+        }
+        int stock = 0;
+        int quantity = Integer.parseInt(applyQuantity);
+        ResourceStoreTimesPo resourceStoreTimesPo = null;
+
+        stock = Integer.parseInt(resourceStoreTimesDtos.get(0).getStock());
+        if (stock < quantity) {
+            throw new CmdException(resourceStoreTimesDtos.get(0).getResCode() + "浠锋牸涓猴細" + resourceStoreTimesDtos.get(0).getPrice() + "鐨勫簱瀛�" + resourceStoreTimesDtos.get(0).getStock() + ",搴撳瓨涓嶈冻");
+        }
+
+        stock = stock - quantity;
+        resourceStoreTimesPo = new ResourceStoreTimesPo();
+        resourceStoreTimesPo.setTimesId(resourceStoreTimesDtos.get(0).getTimesId());
+        resourceStoreTimesPo.setStock(stock + "");
+        resourceStoreTimesV1InnerServiceSMOImpl.updateResourceStoreTimes(resourceStoreTimesPo);
+    }
 }

--
Gitblit v1.8.0