From 9eccc25e5f8e764b18a84ad2d08171dd6fabb452 Mon Sep 17 00:00:00 2001 From: Junjie <xjj@123> Date: 星期三, 27 三月 2024 12:43:32 +0800 Subject: [PATCH] # --- zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/service/MapService.java | 89 +++++++++++++++++++++++++++++++++++++++----- 1 files changed, 79 insertions(+), 10 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 4ec28c1..03965db 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,13 +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.system.entity.User; +import com.zy.asrs.wcs.core.map.controller.param.MapQueryParam; +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 @@ -17,21 +24,83 @@ @Autowired private UserService userService; + @Autowired + private DictService dictService; - public MapDataParam getMapData(Long userId) { - User user = userService.getById(userId); - if (Cools.isEmpty(user.getMemo())) { - return new MapDataParam(); + public String getMapFloorList(Long userId) { + String floorKey = "map-floor-list"; + Dict dict = dictService.getOne(new LambdaQueryWrapper<Dict>().eq(Dict::getFlag, floorKey)); + if (null == dict) { + dict = new Dict(); + dict.setName(floorKey); + dict.setFlag(floorKey); + dict.setType(DictType.JSON.flag); + dict.setValue("[\n" + + " {\n" + + " label: '1F',\n" + + " value: 1\n" + + " },\n" + + " {\n" + + " label: '2F',\n" + + " value: 2\n" + + " },\n" + + " {\n" + + " label: '3F',\n" + + " value: 3\n" + + " },\n" + + " {\n" + + " label: '4F',\n" + + " value: 4\n" + + " },\n" + + " {\n" + + " label: '5F',\n" + + " value: 5\n" + + " },\n" + + "]"); + dict.setCreateBy(userId); + dict.setUpdateBy(userId); + if (!dictService.save(dict)) { + throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇�"); + } } - return JSON.parseObject(user.getMemo(), MapDataParam.class); + 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