From 190589f5b186e338f707804527985db623c1084f Mon Sep 17 00:00:00 2001
From: 廖井涛 <2265517004@qq.com>
Date: 星期一, 28 七月 2025 17:08:45 +0800
Subject: [PATCH] Merge branch 'master' of http://bore.pub:10439/r/ERP_override

---
 north-glass-erp/src/main/java/com/example/erp/service/sd/ProductService.java |  117 +++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 102 insertions(+), 15 deletions(-)

diff --git a/north-glass-erp/src/main/java/com/example/erp/service/sd/ProductService.java b/north-glass-erp/src/main/java/com/example/erp/service/sd/ProductService.java
index b048dae..915a2cf 100644
--- a/north-glass-erp/src/main/java/com/example/erp/service/sd/ProductService.java
+++ b/north-glass-erp/src/main/java/com/example/erp/service/sd/ProductService.java
@@ -1,21 +1,24 @@
 package com.example.erp.service.sd;
 
-import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
+import com.alibaba.fastjson.parser.Feature;
 import com.baomidou.dynamic.datasource.annotation.DS;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
+import com.example.erp.common.Constants;
 import com.example.erp.entity.sd.Product;
 import com.example.erp.entity.sd.ProductDetail;
+import com.example.erp.entity.userInfo.Log;
+import com.example.erp.exception.ServiceException;
 import com.example.erp.mapper.sd.ProductDetailMapper;
 import com.example.erp.mapper.sd.ProductMapper;
+import com.example.erp.service.userInfo.LogService;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import java.text.DecimalFormat;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.Objects;
+import java.util.*;
 
 @Service
 @DS("sd")
@@ -26,11 +29,14 @@
     private final
     ProductDetailMapper productDetailMapper;
 
-    public ProductService(ProductMapper productMapper, ProductDetailMapper productDetailMapper) {
+    private final LogService logService;
+
+    public ProductService(ProductMapper productMapper, ProductDetailMapper productDetailMapper, LogService logService) {
         this.productMapper = productMapper;
         this.productDetailMapper = productDetailMapper;
+        this.logService = logService;
     }
-//浜у搧鏌ヨ鏂规硶
+    //浜у搧鏌ヨ鏂规硶
     public Map<String,Object> defaultDateProduct(Integer pageNum, Integer pageSize, List<String> glassType, Product product) {
         Integer offset = (pageNum-1)*pageSize;
         String glassTypeId = null;
@@ -43,29 +49,74 @@
         return map;
     }
 
-//浜у搧淇濆瓨鏂规硶
-    public boolean saveProduct(Map<String,Object>  productObject) {
+    //浜у搧淇濆瓨鏂规硶
+    public boolean saveProduct(Map<String,Object>  productObject, String operator) {
         //鎶婁紶鍏ヤ富闄勮〃鐨刼bject绫诲瀷杞崲鎴愬疄浣撶被绫诲瀷
         JSONObject productJson = new JSONObject(productObject);
         Product product = JSONObject.parseObject(JSONObject.toJSONString(productJson.get("title")), Product.class);
         List<ProductDetail> productDetails = JSONArray.parseArray(JSONObject.toJSONString(productJson.get("detail")), ProductDetail.class);
-
         //瀹屽杽涓婚檮琛ㄤ俊鎭苟杩斿洖
         Map<String,Object> getProductJson = updateProduct(productDetails,product);
         Product getProduct = JSONObject.parseObject(JSONObject.toJSONString(getProductJson.get("title")), Product.class);
         List<ProductDetail> getProductDetails = JSONArray.parseArray(JSONObject.toJSONString(getProductJson.get("detail")), ProductDetail.class);
 
+        if(getProduct.getId()==null ){
+            insertProduct(getProduct,getProductDetails);
+        }else{
+            updateProductData(getProductDetails,getProduct,operator);
+        }
+        return true;
+
+    }
+
+    public Map<String,Object> selectProduct(String productName,Map<String,Object>  productObject) {
+        Map<String,Object> map = new HashMap<>();
+        //鎶婁紶鍏ヤ富闄勮〃鐨刼bject绫诲瀷杞崲鎴愬疄浣撶被绫诲瀷
+        JSONObject productJson = new JSONObject(productObject);
+        Product product = JSONObject.parseObject(JSONObject.toJSONString(productJson.get("title")), Product.class);
+        List<ProductDetail> productDetails = JSONArray.parseArray(JSONObject.toJSONString(productJson.get("detail")), ProductDetail.class);
+        //瀹屽杽涓婚檮琛ㄤ俊鎭苟杩斿洖
+        Map<String,Object> getProductJson = updateProduct(productDetails,product);
+        Product getProduct = JSONObject.parseObject(JSONObject.toJSONString(getProductJson.get("title")), Product.class);
+        List<ProductDetail> getProductDetails = JSONArray.parseArray(JSONObject.toJSONString(getProductJson.get("detail")), ProductDetail.class);
+        if(getProduct.getId()!=null){
+            map.put("data",productMapper.selectProductId(productName,getProduct.getProductAbbreviation(), getProduct.getId()));
+        }else{
+            map.put("data",productMapper.selectProduct(productName,getProduct.getProductAbbreviation()));
+        }
+
+        return map;
+
+    }
+
+    private void updateProductData(List<ProductDetail> getProductDetails, Product getProduct, String operator) {
+        productMapper.update(getProduct,new UpdateWrapper<Product>().eq("id",getProduct.getId()));
+        productDetailMapper.delete(new QueryWrapper<ProductDetail>().eq("prod_id",getProduct.getId()));
+        for (ProductDetail getProductDetail : getProductDetails) {
+            getProductDetail.setProdId(getProduct.getId());
+        }
+        productDetailMapper.insertList(getProductDetails);
+        Log log = new Log();
+        log.setOperator(operator);
+        log.setContent(getProductDetails.toString()+getProduct.toString());
+        log.setFunction("浜у搧淇敼:saveProduct"+getProduct.getId());
+        logService.saveLog(log);
+    }
+
+    private void insertProduct(Product getProduct, List<ProductDetail> getProductDetails) {
         //鎻掑叆涓昏〃鏁版嵁
         productMapper.insert(getProduct);
         //缁欏壇琛ㄦ坊鍔犱骇鍝乮d
         for (ProductDetail getProductDetail : getProductDetails) {
             getProductDetail.setProdId(getProduct.getId());
         }
+
         //鎻掑叆鍓〃
         productDetailMapper.insertList(getProductDetails);
-
-        return false;
-
+        Log log = new Log();
+        log.setOperator(getProduct.getCreator());
+        log.setFunction("浜у搧鍒涘缓:saveProduct"+getProduct.getId());
+        logService.saveLog(log);
     }
 
     private Map<String,Object> updateProduct(List<ProductDetail> productDetailList,Product product) {
@@ -87,8 +138,7 @@
         for (ProductDetail productDetail : productDetailList) {
             sortNum+=1;
             productDetail.setSortNum(sortNum);
-
-            JSONObject separation = JSONObject.parseObject( productDetail.getSeparation());
+            JSONObject separation = JSONObject.parseObject(productDetail.getSeparation(), Feature.OrderedField);
             String  getThickness = (String) separation.get("thickness");
             double thicknessDetail = Double.parseDouble(getThickness.replace("mm",""));
             totalThickness += thicknessDetail;
@@ -115,4 +165,41 @@
         map.put("detail",productDetailList);
         return map;
     }
+
+    public boolean deleteProductById(Integer id, String operator) {
+        Product product = productMapper.selectById(id);
+        if(product.getState()==1){
+            throw new ServiceException(Constants.Code_600,"浜у搧宸插鏍�,鏃犳硶鍒犻櫎");
+        }
+        productMapper.deleteById(id);
+        Log log = new Log();
+        log.setOperator(operator);
+        log.setFunction("浜у搧鍒犻櫎:deleteProductById"+id);
+        logService.saveLog(log);
+        return true;
+    }
+
+    public boolean updateProductStateById(Integer id, Integer state, String operator) {
+        Log log = new Log();
+        log.setOperator(operator);
+        log.setContent(state+state==0?"鍙嶅":"瀹℃牳");
+        log.setFunction("浜у搧瀹℃牳鍙嶅:updateProductStateById"+id);
+        logService.saveLog(log);
+       return productMapper.updateProductStateById(id,state);
+    }
+
+    public Map<String,Object> selectProductById(Integer id) {
+        Product product = productMapper.selectById(id);
+        List<ProductDetail> productDetailList = productDetailMapper.selectList(
+                new QueryWrapper<ProductDetail>().eq("prod_id", id));
+        Map<String,Object> map = new HashMap<>();
+        map.put("title",product);
+        map.put("detail",productDetailList);
+        return map;
+    }
+
+    public List<Product> otherSysGetProduct() {
+        return productMapper.selectList(new QueryWrapper<Product>().eq("state",1)
+                .orderByDesc("id"));
+    }
 }

--
Gitblit v1.8.0