From b7d3b5954bc0f811c85b0c4efb9c2095ddef9a99 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期二, 26 八月 2025 11:10:10 +0800
Subject: [PATCH] 单据同步功能优化 单据修改接口优化

---
 rsf-server/src/main/java/com/vincent/rsf/server/common/utils/FieldsUtils.java |  177 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 168 insertions(+), 9 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/common/utils/FieldsUtils.java b/rsf-server/src/main/java/com/vincent/rsf/server/common/utils/FieldsUtils.java
index 2496618..44601b4 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/common/utils/FieldsUtils.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/common/utils/FieldsUtils.java
@@ -1,15 +1,23 @@
 package com.vincent.rsf.server.common.utils;
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.TableInfo;
+import com.baomidou.mybatisplus.core.metadata.TableInfoHelper;
+import com.vincent.rsf.framework.common.Cools;
 import com.vincent.rsf.framework.common.SpringUtils;
+import com.vincent.rsf.framework.exception.CoolException;
+import com.vincent.rsf.server.common.domain.BaseParam;
+import com.vincent.rsf.server.common.domain.PageParam;
 import com.vincent.rsf.server.system.entity.Fields;
 import com.vincent.rsf.server.system.entity.FieldsItem;
 import com.vincent.rsf.server.system.service.FieldsItemService;
 import com.vincent.rsf.server.system.service.FieldsService;
+import lombok.Synchronized;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.transaction.annotation.Transactional;
 
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 /**
  * @author Ryan
@@ -22,10 +30,10 @@
 public class FieldsUtils {
 
     /**
-     * @author Ryan
-     * @description 閫氳繃瀛楁鍞竴鏍囪瘑鑾峰彇鍔ㄦ�佸瓧娈礛ap
      * @param
-     * @return
+     * @return 鎵╁睍瀛楁瀵硅薄
+     * @author Ryan
+     * @description 閫氳繃瀛楁鍞竴鏍囪瘑鑾峰彇鍔ㄦ�佸瓧娈靛璞ey-value
      * @time 2025/3/12 12:50
      */
     public static Map<String, String> getFields(String uuid) {
@@ -37,7 +45,7 @@
         }
         FieldsItemService fieldsItemService = SpringUtils.getBean(FieldsItemService.class);
         List<FieldsItem> fieldsItems = fieldsItemService.list(new LambdaQueryWrapper<FieldsItem>().eq(FieldsItem::getUuid, uuid));
-        for (Fields field : fields ) {
+        for (Fields field : fields) {
             if (fieldsItems.isEmpty()) {
                 fieldsMap.put(field.getFields(), null);
                 continue;
@@ -49,7 +57,158 @@
             });
         }
 
-        return  fieldsMap;
+        return fieldsMap;
     }
 
-}
+    /**
+     * @param
+     * @return 鍖呭惈鎵╁睍瀛楁鐨勯泦鍚堝璞�
+     * @author Ryan
+     * @description 鑾峰彇闆嗗悎鎵╁睍瀛楁key-value鍊�
+     * @time 2025/3/15 15:05
+     */
+    public static List<Map<String, Object>> getExtendFields(List<Map<String, Object>> params) {
+        FieldsService fieldsService = SpringUtils.getBean(FieldsService.class);
+        List<Fields> fields = fieldsService.list(new LambdaQueryWrapper<Fields>()
+                .eq(Fields::getStatus, 1)
+                .eq(Fields::getFlagEnable, 1));
+        FieldsItemService fieldsItemService = SpringUtils.getBean(FieldsItemService.class);
+        List<Map<String, Object>> result = new ArrayList<>();
+        for (Map<String, Object> param : params) {
+            result.add(param);
+            if (Objects.isNull(param.get("fieldsIndex"))) {
+                continue;
+            }
+            List<FieldsItem> itemList = fieldsItemService
+                    .list(new LambdaQueryWrapper<FieldsItem>()
+                            .eq(FieldsItem::getUuid, param.get("fieldsIndex")));
+            if (itemList.isEmpty()) {
+                continue;
+            }
+            fields.forEach(fds -> {
+                for (FieldsItem fieldsItem : itemList) {
+                    if (!Objects.isNull(fieldsItem.getFieldsId()) && fieldsItem.getFieldsId().equals(fds.getId())) {
+                        param.put(fds.getFields(), fieldsItem.getValue());
+                    }
+                }
+            });
+        }
+        return result;
+    }
+
+    /**
+     * @param template
+     * @return
+     * @author Ryan
+     * @description 鍔ㄦ�佸瓧娈祐alue淇濆瓨
+     * @time 2025/3/18 15:00
+     */
+    @Transactional(rollbackFor = Exception.class)
+    public static boolean saveFields(Map<String, ?> template, String uuid) {
+        List<Fields> fields = getFieldsSta();
+        FieldsItemService fieldsItemService = SpringUtils.getBean(FieldsItemService.class);
+        List<FieldsItem> fieldsItems = new ArrayList<>();
+        if (!fields.isEmpty()) {
+            for (Fields obj : fields) {
+                if (!Objects.isNull(template.get(obj.getFields())) && StringUtils.isNotBlank(template.get(obj.getFields()).toString())) {
+                    FieldsItem item = new FieldsItem();
+                    item.setUuid(uuid)
+                            .setValue(template.get(obj.getFields()).toString())
+                            .setMatnrId(!Objects.isNull(template.get("matnrId")) ? Long.parseLong(template.get("matnrId").toString()) : null)
+                            .setFieldsId(obj.getId());
+                    fieldsItems.add(item);
+                }
+            }
+            if (fieldsItems.isEmpty()) {
+                return false;
+            }
+            if (!fieldsItemService.saveBatch(fieldsItems)) {
+                throw new CoolException("鎵╁睍瀛楁淇濆瓨澶辫触锛侊紒");
+            }
+            return true;
+        }
+        return false;
+    }
+
+    /**
+     * 鑾峰彇鎵�鏈夊紑鍚姩鎬佹墿灞曞瓧娈�
+     *
+     * @return
+     */
+    public static List<Fields> getFieldsSta() {
+        FieldsService fieldsService = SpringUtils.getBean(FieldsService.class);
+        return fieldsService.list(new LambdaQueryWrapper<Fields>().eq(Fields::getStatus, 1).eq(Fields::getFlagEnable, 1));
+    }
+
+    /**
+     * @param
+     * @return
+     * @author Ryan
+     * @description 鍔ㄦ�佸瓧娈典慨鏀�
+     * @time 2025/4/7 15:28
+     */
+    @Synchronized
+    @Transactional(rollbackFor = Exception.class)
+    public static void updateFieldsValue(Map<String, Object> params) throws Exception {
+        List<Fields> fields = getFieldsSta();
+        if (fields.isEmpty()) {
+            return;
+        }
+        Object fieldsIndex = params.get("fieldsIndex");
+        if (!Objects.isNull(fieldsIndex) && StringUtils.isNotBlank(fieldsIndex.toString())) {
+            String index = fieldsIndex.toString();
+            FieldsItemService fieldsItemService = SpringUtils.getBean(FieldsItemService.class);
+            for (Fields field : fields) {
+                if (!Objects.isNull(params.get(field.getFields()))) {
+                    FieldsItem indexItem = fieldsItemService.getOne(new LambdaQueryWrapper<FieldsItem>()
+                            .eq(FieldsItem::getUuid, index)
+                            .eq(FieldsItem::getFieldsId, field.getId()));
+                    //濡傛灉瀛愯〃涓虹┖锛屾墽琛屾彃鍏ユ搷浣滐紝鍚﹀垯灏辨墽琛屼慨鏀规搷浣�
+                    if (Objects.isNull(indexItem)) {
+                        FieldsItem item = new FieldsItem();
+                        item.setUuid(index)
+                                .setFieldsId(field.getId())
+                                .setMatnrId(!Objects.isNull(params.get("matnrId")) ? Long.parseLong(params.get("matnrId").toString()) : null)
+                                .setValue(params.get(field.getFields()).toString());
+                        if (!fieldsItemService.save(item)) {
+                            throw new CoolException("鎵╁睍瀛楁淇敼澶辫触锛侊紒");
+                        }
+                    } else {
+                        indexItem.setValue(params.get(field.getFields()).toString());
+                        if (!fieldsItemService.updateById(indexItem)) {
+                            throw new CoolException("鎵╁睍瀛楁淇敼澶辫触锛侊紒");
+                        }
+                    }
+                }
+            }
+        } else {
+            saveFields(params, params.get("index").toString());
+        }
+    }
+
+    public static <T> QueryWrapper<T> setFieldsFilters(QueryWrapper<T> queryWrapper, PageParam<T, BaseParam> pageParam, Class<T> entityClass) {
+        // 鍔ㄦ�佽幏鍙栬〃鍚�
+        TableInfo tableInfo = TableInfoHelper.getTableInfo(entityClass);
+        String tableName = tableInfo.getTableName();
+
+        FieldsService fieldsService = SpringUtils.getBean(FieldsService.class);
+        Map<String, Object> map = pageParam.getWhere().getFields();
+
+        for (String key : map.keySet()) {
+            Object val = map.get(key);
+            Fields fields = fieldsService.getOne(new LambdaQueryWrapper<Fields>().eq(Fields::getFields, key));
+            if (!Cools.isEmpty(fields)) {
+                String applySql = String.format(
+                        "EXISTS (SELECT 1 FROM sys_fields_item fie " +
+                                "WHERE %s.fields_index IS NOT NULL " +
+                                "AND fie.uuid = %s.fields_index " +
+                                "AND fie.fields_id = '%s' " +
+                                "AND fie.value = '%s')",
+                        tableName, tableName, fields.getId(), val
+                );
+                queryWrapper.apply(applySql);
+            }
+        }
+        return queryWrapper;
+    }
+}
\ No newline at end of file

--
Gitblit v1.9.1