From 13909c99e368788a94a48753dc9f76e40a992cd6 Mon Sep 17 00:00:00 2001
From: Junjie <540245094@qq.com>
Date: 星期一, 29 七月 2024 15:21:06 +0800
Subject: [PATCH] #

---
 zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java |   36 ++++++++++++++++++++++++++++++------
 1 files changed, 30 insertions(+), 6 deletions(-)

diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java
index 26147cd..8f84135 100644
--- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java
+++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/asrs/controller/LocDetlController.java
@@ -1,7 +1,7 @@
 package com.zy.asrs.wms.asrs.controller;
 
 import com.alibaba.fastjson.JSON;
-import com.alibaba.fastjson.JSONObject;
+import com.alibaba.fastjson.parser.Feature;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.zy.asrs.framework.common.Cools;
@@ -21,10 +21,7 @@
 import org.springframework.web.bind.annotation.*;
 
 import javax.servlet.http.HttpServletResponse;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 @RestController
 @RequestMapping("/api")
@@ -104,7 +101,11 @@
     @PreAuthorize("hasAuthority('asrs:locDetl:update')")
     @OperationLog("淇敼搴撳瓨鏄庣粏")
     @PostMapping("/locDetl/update")
-    public R update(@RequestBody LocDetl locDetl) {
+    public R update(@RequestBody HashMap<String,Object> param) {
+        LocDetl locDetl = JSON.parseObject(JSON.toJSONString(param), LocDetl.class, Feature.DisableCircularReferenceDetect);
+        //璁剧疆鎵╁睍瀛楁
+        setLocDetlField(param, locDetl);
+
         if (!locDetlService.updateById(locDetl)) {
             return R.error("淇敼澶辫触");
         }
@@ -141,4 +142,27 @@
         ExcelUtil.build(ExcelUtil.create(locDetlService.list(), LocDetl.class), response);
     }
 
+    private void setLocDetlField(HashMap<String, Object> param, LocDetl locDetl) {
+        //鑾峰彇鎵╁睍瀛楁
+        List<MatField> matFields = matFieldService.list(new LambdaQueryWrapper<MatField>().eq(MatField::getFieldType, 1));
+        for (MatField matField : matFields) {
+            if (param.containsKey(matField.getName())) {
+                LocDetlField fieldValue = locDetlFieldService.getOne(new LambdaQueryWrapper<LocDetlField>()
+                        .eq(LocDetlField::getDetlId, locDetl.getId())
+                        .eq(LocDetlField::getFieldId, matField.getId()));
+                if (fieldValue == null) {
+                    fieldValue = new LocDetlField();
+                    fieldValue.setDetlId(locDetl.getId());
+                    fieldValue.setFieldId(matField.getId());
+                    fieldValue.setName(matField.getName());
+                    fieldValue.setValue(param.get(matField.getName()).toString());
+                    locDetlFieldService.save(fieldValue);
+                }else {
+                    fieldValue.setValue(param.get(matField.getName()).toString());
+                    locDetlFieldService.updateById(fieldValue);
+                }
+            }
+        }
+    }
+
 }

--
Gitblit v1.9.1