|
@@ -6,9 +6,8 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
-import org.dromara.common.core.constant.CacheConstants;
|
|
|
+import lombok.RequiredArgsConstructor;
|
|
|
import org.dromara.common.core.constant.CacheNames;
|
|
|
-import org.dromara.common.core.context.ThreadLocalHolder;
|
|
|
import org.dromara.common.core.exception.ServiceException;
|
|
|
import org.dromara.common.core.service.DictService;
|
|
|
import org.dromara.common.core.utils.MapstructUtils;
|
|
@@ -26,7 +25,6 @@ import org.dromara.system.domain.vo.SysDictTypeVo;
|
|
|
import org.dromara.system.mapper.SysDictDataMapper;
|
|
|
import org.dromara.system.mapper.SysDictTypeMapper;
|
|
|
import org.dromara.system.service.ISysDictTypeService;
|
|
|
-import lombok.RequiredArgsConstructor;
|
|
|
import org.springframework.cache.annotation.CachePut;
|
|
|
import org.springframework.cache.annotation.Cacheable;
|
|
|
import org.springframework.stereotype.Service;
|
|
@@ -217,16 +215,9 @@ public class SysDictTypeServiceImpl implements ISysDictTypeService, DictService
|
|
|
* @param separator 分隔符
|
|
|
* @return 字典标签
|
|
|
*/
|
|
|
- @SuppressWarnings("unchecked cast")
|
|
|
@Override
|
|
|
public String getDictLabel(String dictType, String dictValue, String separator) {
|
|
|
- // 优先从本地缓存获取
|
|
|
- List<SysDictDataVo> datas = ThreadLocalHolder.get(CacheConstants.SYS_DICT_KEY + dictType);
|
|
|
- if (ObjectUtil.isNull(datas)) {
|
|
|
- datas = SpringUtils.getAopProxy(this).selectDictDataByType(dictType);
|
|
|
- ThreadLocalHolder.set(CacheConstants.SYS_DICT_KEY + dictType, datas);
|
|
|
- }
|
|
|
-
|
|
|
+ List<SysDictDataVo> datas = SpringUtils.getAopProxy(this).selectDictDataByType(dictType);
|
|
|
Map<String, String> map = StreamUtils.toMap(datas, SysDictDataVo::getDictValue, SysDictDataVo::getDictLabel);
|
|
|
if (StringUtils.containsAny(dictValue, separator)) {
|
|
|
return Arrays.stream(dictValue.split(separator))
|
|
@@ -245,16 +236,9 @@ public class SysDictTypeServiceImpl implements ISysDictTypeService, DictService
|
|
|
* @param separator 分隔符
|
|
|
* @return 字典值
|
|
|
*/
|
|
|
- @SuppressWarnings("unchecked cast")
|
|
|
@Override
|
|
|
public String getDictValue(String dictType, String dictLabel, String separator) {
|
|
|
- // 优先从本地缓存获取
|
|
|
- List<SysDictDataVo> datas = ThreadLocalHolder.get(CacheConstants.SYS_DICT_KEY + dictType);
|
|
|
- if (ObjectUtil.isNull(datas)) {
|
|
|
- datas = SpringUtils.getAopProxy(this).selectDictDataByType(dictType);
|
|
|
- ThreadLocalHolder.set(CacheConstants.SYS_DICT_KEY + dictType, datas);
|
|
|
- }
|
|
|
-
|
|
|
+ List<SysDictDataVo> datas = SpringUtils.getAopProxy(this).selectDictDataByType(dictType);
|
|
|
Map<String, String> map = StreamUtils.toMap(datas, SysDictDataVo::getDictLabel, SysDictDataVo::getDictValue);
|
|
|
if (StringUtils.containsAny(dictLabel, separator)) {
|
|
|
return Arrays.stream(dictLabel.split(separator))
|