guoyujie
2025-06-18 873494885861271331bf7e51b679f537961f8def
north-glass-erp/src/main/java/com/example/erp/service/sd/ProductService.java
@@ -9,9 +9,11 @@
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;
@@ -27,9 +29,12 @@
    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) {
@@ -45,7 +50,7 @@
    }
    //产品保存方法
    public boolean saveProduct(Map<String,Object>  productObject) {
    public boolean saveProduct(Map<String,Object>  productObject, String operator) {
        //把传入主附表的object类型转换成实体类类型
        JSONObject productJson = new JSONObject(productObject);
        Product product = JSONObject.parseObject(JSONObject.toJSONString(productJson.get("title")), Product.class);
@@ -58,7 +63,7 @@
        if(getProduct.getId()==null ){
            insertProduct(getProduct,getProductDetails);
        }else{
            updateProductData(getProductDetails,getProduct);
            updateProductData(getProductDetails,getProduct,operator);
        }
        return true;
@@ -84,13 +89,18 @@
    }
    private void updateProductData(List<ProductDetail> getProductDetails, Product getProduct) {
    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) {
@@ -100,8 +110,13 @@
        for (ProductDetail getProductDetail : getProductDetails) {
            getProductDetail.setProdId(getProduct.getId());
        }
        //插入副表
        productDetailMapper.insertList(getProductDetails);
        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) {
@@ -151,16 +166,25 @@
        return map;
    }
    public boolean deleteProductById(Integer id) {
    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) {
    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);
    }