From f8c64c4e54cec545eb613d8450932096f15937ef Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期三, 26 三月 2025 09:20:35 +0800
Subject: [PATCH] #修改 物料新增动态字段不能保存问题修复
---
rsf-server/src/main/java/com/vincent/rsf/server/common/utils/FieldsUtils.java | 62 ++++++++++++++++++++++++++++++
1 files changed, 61 insertions(+), 1 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 abf6c8a..6182be3 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
@@ -50,6 +50,28 @@
return fieldsMap;
}
+
+ public static void mergeFields(Map<String, Object> fileds ,String uuid) {
+ FieldsService fieldsService = SpringUtils.getBean(FieldsService.class);
+ List<Fields> fields = fieldsService.list(new LambdaQueryWrapper<Fields>().eq(Fields::getFlagEnable, 1).eq(Fields::getStatus, 1));
+ if (fields.isEmpty()) {
+ return;
+ }
+ FieldsItemService fieldsItemService = SpringUtils.getBean(FieldsItemService.class);
+ List<FieldsItem> fieldsItems = fieldsItemService.list(new LambdaQueryWrapper<FieldsItem>().eq(FieldsItem::getUuid, uuid));
+ for (Fields field : fields ) {
+ if (fieldsItems.isEmpty()) {
+ fileds.put(field.getFields(), null);
+ continue;
+ }
+ fieldsItems.forEach(fieldsItem -> {
+ if (fieldsItem.getFieldsId().equals(field.getId())) {
+ fileds.put(field.getFields(), fieldsItem.getValue());
+ }
+ });
+ }
+
+ }
/**
* @param template
@@ -58,7 +80,7 @@
* @description 鍔ㄦ�佸瓧娈祐alue淇濆瓨
* @time 2025/3/18 15:00
*/
- public static void saveFields(Map<String, ?> template, String uuid) {
+ public static void saveFields(Map<String, ?> template, String uuid) throws Exception{
List<Fields> fields = getFieldsSta();
FieldsItemService fieldsItemService = SpringUtils.getBean(FieldsItemService.class);
if (fields.isEmpty()) {
@@ -87,4 +109,42 @@
FieldsService fieldsService = SpringUtils.getBean(FieldsService.class);
return fieldsService.list(new LambdaQueryWrapper<Fields>().eq(Fields::getStatus, 1).eq(Fields::getFlagEnable, 1));
}
+
+ 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)) {
+ String index = fieldsIndex.toString();
+ FieldsItemService fieldsItemService = SpringUtils.getBean(FieldsItemService.class);
+ for (Fields field : fields) {
+ Map<String, String> extendFields = (Map<String, String>) params.get("extendFields");
+ if (!Objects.isNull(extendFields)) {
+ if (!Objects.isNull(extendFields.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())
+ .setValue(extendFields.get(field.getFields()).toString());
+ if (!fieldsItemService.save(item)) {
+ throw new CoolException("鎵╁睍瀛楁淇敼澶辫触锛侊紒");
+ }
+ } else {
+ indexItem.setValue(extendFields.get(field.getFields()).toString());
+ if (!fieldsItemService.updateById(indexItem)) {
+ throw new CoolException("鎵╁睍瀛楁淇敼澶辫触锛侊紒");
+ }
+ }
+ }
+ }
+ }
+ } else {
+ String uuid16 = CommonUtil.randomUUID16();
+ saveFields(params, uuid16);
+ }
+ }
}
--
Gitblit v1.9.1