From 2e95a2b66132930106816be0217169680fd55282 Mon Sep 17 00:00:00 2001
From: Junjie <xjj@123>
Date: 星期二, 26 三月 2024 13:53:47 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/Four-Way-Rack' into Four-Way-Rack
---
zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java | 57 ++++++++++++++++++++++++++++++++++++++++++++++-----------
1 files changed, 46 insertions(+), 11 deletions(-)
diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java
index 8a4dd70..0da5f5a 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java
@@ -1,14 +1,20 @@
package com.zy.asrs.wcs.core.map.service;
import com.alibaba.fastjson.JSON;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.zy.asrs.framework.common.Cools;
import com.zy.asrs.framework.exception.CoolException;
+import com.zy.asrs.wcs.common.domain.enums.DictType;
import com.zy.asrs.wcs.core.map.controller.param.MapDataParam;
import com.zy.asrs.wcs.core.map.controller.param.MapQueryParam;
-import com.zy.asrs.wcs.system.entity.User;
+import com.zy.asrs.wcs.system.entity.Dict;
+import com.zy.asrs.wcs.system.service.DictService;
import com.zy.asrs.wcs.system.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
+
+import java.util.Date;
+import java.util.Optional;
/**
* Created by vincent on 3/15/2024
@@ -18,21 +24,50 @@
@Autowired
private UserService userService;
+ @Autowired
+ private DictService dictService;
- public MapDataParam getMapData(MapQueryParam param, Long userId) {
- User user = userService.getById(userId);
- if (Cools.isEmpty(user.getMemo())) {
- return new MapDataParam();
- }
- return JSON.parseObject(user.getMemo(), MapDataParam.class);
+ public String getMapFloorList(Long userId) {
+ String floorKey = "map-floor-list";
+ Dict dict = dictService.getOne(new LambdaQueryWrapper<Dict>().eq(Dict::getFlag, floorKey));
+ return Optional.ofNullable(dict).map(Dict::getValue).orElse(null);
+ }
+
+ public String getMapData(MapQueryParam param, Long userId) {
+ String mapKey = getMapKey(param.getFloor());
+ Dict dict = dictService.getOne(new LambdaQueryWrapper<Dict>().eq(Dict::getFlag, mapKey));
+ return Optional.ofNullable(dict).map(Dict::getValue).orElse(null);
}
public void saveMapData(MapDataParam param, Long userId) {
- User user = userService.getById(userId);
- user.setMemo(JSON.toJSONString(param));
- if (!userService.updateById(user)) {
- throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇�");
+ String mapKey = getMapKey(param.getFloor());
+ Dict dict = dictService.getOne(new LambdaQueryWrapper<Dict>().eq(Dict::getFlag, mapKey));
+ if (Cools.isEmpty(dict)) {
+ dict = new Dict();
+ dict.setName(mapKey);
+ dict.setFlag(mapKey);
+ dict.setType(DictType.JSON.flag);
+ dict.setValue(JSON.toJSONString(param.getItemList()));
+ dict.setCreateBy(userId);
+ dict.setUpdateBy(userId);
+ if (!dictService.save(dict)) {
+ throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇�");
+ }
+ } else {
+ dict.setValue(JSON.toJSONString(param.getItemList()));
+ dict.setUpdateTime(new Date());
+ dict.setUpdateBy(userId);
+ if (!dictService.updateById(dict)) {
+ throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇�");
+ }
}
}
+ private String getMapKey(Integer floor) {
+ if (null != floor) {
+ return "map-" + floor;
+ }
+ return "map";
+ }
+
}
--
Gitblit v1.9.1