From 4e134e61ede1f8574189af45c810ca365c7c7f9a Mon Sep 17 00:00:00 2001
From: wuxw <928255095@qq.com>
Date: 星期四, 12 五月 2022 18:33:14 +0800
Subject: [PATCH] 优化代码

---
 service-store/src/main/java/com/java110/store/smo/impl/ResourceStoreInnerServiceSMOImpl.java |   65 +++++++++++++++++++++++---------
 1 files changed, 47 insertions(+), 18 deletions(-)

diff --git a/service-store/src/main/java/com/java110/store/smo/impl/ResourceStoreInnerServiceSMOImpl.java b/service-store/src/main/java/com/java110/store/smo/impl/ResourceStoreInnerServiceSMOImpl.java
index 08cc993..473a4b9 100755
--- a/service-store/src/main/java/com/java110/store/smo/impl/ResourceStoreInnerServiceSMOImpl.java
+++ b/service-store/src/main/java/com/java110/store/smo/impl/ResourceStoreInnerServiceSMOImpl.java
@@ -3,6 +3,7 @@
 import com.java110.core.base.smo.BaseServiceSMO;
 import com.java110.dto.PageDto;
 import com.java110.dto.file.FileRelDto;
+import com.java110.dto.purchaseApply.PurchaseApplyDto;
 import com.java110.dto.resourceStore.ResourceStoreDto;
 import com.java110.intf.common.IFileRelInnerServiceSMO;
 import com.java110.intf.store.IResourceStoreInnerServiceSMO;
@@ -91,32 +92,49 @@
             info.put("storeId", resourceStorePo.getStoreId());
             List<Map> stores = resourceResourceStoreServiceDaoImpl.getResourceStoreInfo(info);
             Assert.listOnlyOne(stores, "涓嶅瓨鍦ㄨ鐗╁搧");
-            Double stock = Double.parseDouble(stores.get(0).get("stock").toString());
-            Double newStock = Double.parseDouble(resourceStorePo.getStock());
-            Double totalStock = stock + newStock;
-            if (totalStock < 0) {
+            BigDecimal stock = new BigDecimal(stores.get(0).get("stock").toString());
+            BigDecimal newStock = new BigDecimal(resourceStorePo.getStock().toString());
+            BigDecimal totalStock = stock.add(newStock);
+            BigDecimal zeroStock = new BigDecimal (0);
+            if (totalStock.compareTo(zeroStock)== -1) {
                 throw new IllegalArgumentException("搴撳瓨涓嶈冻锛屽弬鏁版湁璇�");
             }
-            //鑾峰彇鍘熷潎浠�
-            Object averageOldPrice = stores.get(0).get("averagePrice");
-            Double price = 0.0;
-            if (averageOldPrice != null) {
-                price = Double.parseDouble(averageOldPrice.toString());
+            //鍏ュ簱鎿嶄綔 瀵圭墿鍝佽繘琛屽姞鏉冨钩鍧�
+            if (resourceStorePo.getResOrderType().equals(PurchaseApplyDto.RES_ORDER_TYPE_ENTER)
+                    || (resourceStorePo.getResOrderType().equals(PurchaseApplyDto.WAREHOUSING_TYPE_URGENT) && resourceStorePo.getOperationType().equals(PurchaseApplyDto.WEIGHTED_MEAN_TRUE))) {
+                //鑾峰彇鍘熷潎浠�
+                Object averageOldPrice = stores.get(0).get("averagePrice");
+                BigDecimal price = new BigDecimal(0);
+                if (averageOldPrice != null) {
+                    price = new BigDecimal(averageOldPrice.toString());
+                }
+                //鑾峰彇鐜板湪閲囪喘鐨勪环鏍�
+                BigDecimal newPrice = new BigDecimal(resourceStorePo.getPurchasePrice());
+                //鑾峰彇鍧囦环
+                BigDecimal averagePriceTotal = ((newPrice.multiply(newStock)).add(price.multiply(stock)));
+                BigDecimal averagePrice=averagePriceTotal.divide(totalStock,2,BigDecimal.ROUND_HALF_UP);
+                resourceStorePo.setAveragePrice(averagePrice.toString());
             }
-            //鑾峰彇鐜板湪閲囪喘鐨勪环鏍�
-            Double newPrice = Double.parseDouble(resourceStorePo.getPurchasePrice());
-            //鑾峰彇鍧囦环
-            double averagePrice = ((newPrice * newStock) + (price * stock)) / totalStock;
-            BigDecimal b0 = new BigDecimal(averagePrice);
-            //鍥涜垗浜斿叆淇濈暀涓や綅
-            double f0 = b0.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
-            resourceStorePo.setAveragePrice(String.valueOf(f0));
-            resourceStorePo.setStock(totalStock + "");
+            if (resourceStorePo.getResOrderType().equals(PurchaseApplyDto.WAREHOUSING_TYPE_URGENT) && resourceStorePo.getOperationType().equals(PurchaseApplyDto.WEIGHTED_MEAN_TRUE)) {
+                resourceStorePo.setStock(stock + "");
+            } else {
+                resourceStorePo.setStock(totalStock + "");
+            }
             resourceStorePo.setStatusCd("0");
             return resourceResourceStoreServiceDaoImpl.updateResourceStoreInfoInstance(BeanConvertUtil.beanCovertMap(resourceStorePo));
         } finally {
             DistributedLock.releaseDistributedLock(requestId, key);
         }
+    }
+
+    /**
+     * 鏂板鐗╁搧
+     *
+     * @param resourceStoreDto
+     */
+    @Override
+    public void saveResourceStore(@RequestBody ResourceStoreDto resourceStoreDto) {
+        resourceResourceStoreServiceDaoImpl.saveResourceStoreInfo(BeanConvertUtil.beanCovertMap(resourceStoreDto));
     }
 
     public IResourceStoreServiceDao getResourceStoreServiceDaoImpl() {
@@ -127,6 +145,17 @@
         this.resourceResourceStoreServiceDaoImpl = resourceResourceStoreServiceDaoImpl;
     }
 
+    @Override
+    public String queryResourceStoresTotalPrice(@RequestBody ResourceStoreDto resourceResourceStoreDto) {
+        //鏍¢獙鏄惁浼犱簡 鍒嗛〉淇℃伅
+        int page = resourceResourceStoreDto.getPage();
+        if (page != PageDto.DEFAULT_PAGE) {
+            resourceResourceStoreDto.setPage((page - 1) * resourceResourceStoreDto.getRow());
+        }
+        return resourceResourceStoreServiceDaoImpl.queryResourceStoresTotalPrice(BeanConvertUtil.beanCovertMap(resourceResourceStoreDto));
+
+    }
+
     public IUserInnerServiceSMO getUserInnerServiceSMOImpl() {
         return userInnerServiceSMOImpl;
     }

--
Gitblit v1.8.0