package org.jeecg.modules.system.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import lombok.extern.slf4j.Slf4j; import org.jeecg.common.constant.CacheConstant; import org.jeecg.common.constant.CommonConstant; import org.jeecg.common.system.vo.DictModel; import org.jeecg.common.system.vo.DictQuery; import org.jeecg.common.util.oConvertUtils; import org.jeecg.modules.system.entity.SysDict; import org.jeecg.modules.system.entity.SysDictItem; import org.jeecg.modules.system.mapper.SysDictItemMapper; import org.jeecg.modules.system.mapper.SysDictMapper; import org.jeecg.modules.system.model.TreeSelectModel; import org.jeecg.modules.system.service.ISysDictService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.cache.annotation.Cacheable; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.stream.Collectors; /** *

* 字典表 服务实现类 *

* * @Author zhangweijian * @since 2018-12-28 */ @Service @Slf4j public class SysDictServiceImpl extends ServiceImpl implements ISysDictService { @Autowired private SysDictMapper sysDictMapper; @Autowired private SysDictItemMapper sysDictItemMapper; /** * 通过查询指定code 获取字典 * @param code * @return */ @Override @Cacheable(value = CacheConstant.SYS_DICT_CACHE,key = "#code") public List queryDictItemsByCode(String code) { log.info("无缓存dictCache的时候调用这里!"); return sysDictMapper.queryDictItemsByCode(code); } @Override public Map> queryAllDictItems() { Map> res = new HashMap>(); List ls = sysDictMapper.selectList(null); LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper(); queryWrapper.eq(SysDictItem::getStatus, 1); queryWrapper.orderByAsc(SysDictItem::getSortOrder); List sysDictItemList = sysDictItemMapper.selectList(queryWrapper); for (SysDict d : ls) { List dictModelList = sysDictItemList.stream().filter(s -> d.getId().equals(s.getDictId())).map(item -> { DictModel dictModel = new DictModel(); dictModel.setText(item.getItemText()); dictModel.setValue(item.getItemValue()); return dictModel; }).collect(Collectors.toList()); res.put(d.getDictCode(), dictModelList); } log.info("-------登录加载系统字典-----" + res.toString()); return res; } /** * 通过查询指定code 获取字典值text * @param code * @param key * @return */ @Override @Cacheable(value = CacheConstant.SYS_DICT_CACHE,key = "#code+':'+#key") public String queryDictTextByKey(String code, String key) { log.info("无缓存dictText的时候调用这里!"); return sysDictMapper.queryDictTextByKey(code, key); } /** * 通过查询指定table的 text code 获取字典 * dictTableCache采用redis缓存有效期10分钟 * @param table * @param text * @param code * @return */ @Override //@Cacheable(value = CacheConstant.SYS_DICT_TABLE_CACHE) public List queryTableDictItemsByCode(String table, String text, String code) { log.info("无缓存dictTableList的时候调用这里!"); return sysDictMapper.queryTableDictItemsByCode(table,text,code); } @Override public List queryTableDictItemsByCodeAndFilter(String table, String text, String code, String filterSql) { log.info("无缓存dictTableList的时候调用这里!"); return sysDictMapper.queryTableDictItemsByCodeAndFilter(table,text,code,filterSql); } /** * 通过查询指定table的 text code 获取字典值text * dictTableCache采用redis缓存有效期10分钟 * @param table * @param text * @param code * @param key * @return */ @Override @Cacheable(value = CacheConstant.SYS_DICT_TABLE_CACHE) public String queryTableDictTextByKey(String table,String text,String code, String key) { log.info("无缓存dictTable的时候调用这里!"); return sysDictMapper.queryTableDictTextByKey(table,text,code,key); } /** * 通过查询指定table的 text code 获取字典,包含text和value * dictTableCache采用redis缓存有效期10分钟 * @param table * @param text * @param code * @param keys (逗号分隔) * @return */ @Override @Cacheable(value = CacheConstant.SYS_DICT_TABLE_CACHE) public List queryTableDictByKeys(String table, String text, String code, String keys) { if(oConvertUtils.isEmpty(keys)){ return null; } String[] keyArray = keys.split(","); List dicts = sysDictMapper.queryTableDictByKeys(table, text, code, keyArray); List texts = new ArrayList<>(dicts.size()); // 查询出来的顺序可能是乱的,需要排个序 for (String key : keyArray) { for (DictModel dict : dicts) { if (key.equals(dict.getValue())) { texts.add(dict.getText()); break; } } } return texts; } /** * 根据字典类型id删除关联表中其对应的数据 */ @Override public boolean deleteByDictId(SysDict sysDict) { sysDict.setDelFlag(CommonConstant.DEL_FLAG_1); return this.updateById(sysDict); } @Override @Transactional public Integer saveMain(SysDict sysDict, List sysDictItemList) { int insert=0; try{ insert = sysDictMapper.insert(sysDict); if (sysDictItemList != null) { for (SysDictItem entity : sysDictItemList) { entity.setDictId(sysDict.getId()); entity.setStatus(1); sysDictItemMapper.insert(entity); } } }catch(Exception e){ return insert; } return insert; } @Override public List queryAllDepartBackDictModel() { return baseMapper.queryAllDepartBackDictModel(); } @Override public List queryAllUserBackDictModel() { return baseMapper.queryAllUserBackDictModel(); } @Override public List queryTableDictItems(String table, String text, String code, String keyword) { return baseMapper.queryTableDictItems(table, text, code, "%"+keyword+"%"); } @Override public List queryTreeList(Map query,String table, String text, String code, String pidField,String pid,String hasChildField) { return baseMapper.queryTreeList(query,table, text, code, pidField, pid,hasChildField); } @Override public void deleteOneDictPhysically(String id) { this.baseMapper.deleteOneById(id); this.sysDictItemMapper.delete(new LambdaQueryWrapper().eq(SysDictItem::getDictId,id)); } @Override public void updateDictDelFlag(int delFlag, String id) { baseMapper.updateDictDelFlag(delFlag,id); } @Override public List queryDeleteList() { return baseMapper.queryDeleteList(); } @Override public List queryDictTablePageList(DictQuery query, int pageSize, int pageNo) { Page page = new Page(pageNo,pageSize,false); Page pageList = baseMapper.queryDictTablePageList(page, query); return pageList.getRecords(); } }