疯狂的狮子li
2023-01-16 f3aff3460203eef795e9b5a5b3dd41368cc5ec39
ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysDictDataServiceImpl.java
@@ -1,14 +1,18 @@
package com.ruoyi.system.service.impl;
import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ruoyi.common.core.domain.entity.SysDictData;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.common.constant.CacheNames;
import com.ruoyi.common.core.domain.PageQuery;
import com.ruoyi.system.domain.SysDictData;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.utils.DictUtils;
import com.ruoyi.common.utils.PageUtils;
import com.ruoyi.common.exception.ServiceException;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.common.utils.redis.CacheUtils;
import com.ruoyi.system.mapper.SysDictDataMapper;
import com.ruoyi.system.service.ISysDictDataService;
import lombok.RequiredArgsConstructor;
import org.springframework.cache.annotation.CachePut;
import org.springframework.stereotype.Service;
import java.util.List;
@@ -16,108 +20,111 @@
/**
 * 字典 业务层处理
 *
 * @author ruoyi
 * @author Lion Li
 */
@RequiredArgsConstructor
@Service
public class SysDictDataServiceImpl extends ServiceImpl<SysDictDataMapper, SysDictData> implements ISysDictDataService {
public class SysDictDataServiceImpl implements ISysDictDataService {
   @Override
   public TableDataInfo<SysDictData> selectPageDictDataList(SysDictData dictData) {
      LambdaQueryWrapper<SysDictData> lqw = new LambdaQueryWrapper<SysDictData>()
         .eq(StrUtil.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType())
         .like(StrUtil.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel())
         .eq(StrUtil.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus())
         .orderByAsc(SysDictData::getDictSort);
      return PageUtils.buildDataInfo(page(PageUtils.buildPage(), lqw));
   }
    private final SysDictDataMapper baseMapper;
   /**
    * 根据条件分页查询字典数据
    *
    * @param dictData 字典数据信息
    * @return 字典数据集合信息
    */
   @Override
   public List<SysDictData> selectDictDataList(SysDictData dictData) {
      return list(new LambdaQueryWrapper<SysDictData>()
         .eq(StrUtil.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType())
         .like(StrUtil.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel())
         .eq(StrUtil.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus())
         .orderByAsc(SysDictData::getDictSort));
   }
    @Override
    public TableDataInfo<SysDictData> selectPageDictDataList(SysDictData dictData, PageQuery pageQuery) {
        LambdaQueryWrapper<SysDictData> lqw = new LambdaQueryWrapper<SysDictData>()
            .eq(StringUtils.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType())
            .like(StringUtils.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel())
            .eq(StringUtils.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus())
            .orderByAsc(SysDictData::getDictSort);
        Page<SysDictData> page = baseMapper.selectPage(pageQuery.build(), lqw);
        return TableDataInfo.build(page);
    }
   /**
    * 根据字典类型和字典键值查询字典数据信息
    *
    * @param dictType  字典类型
    * @param dictValue 字典键值
    * @return 字典标签
    */
   @Override
   public String selectDictLabel(String dictType, String dictValue) {
      return getOne(new LambdaQueryWrapper<SysDictData>()
         .select(SysDictData::getDictLabel)
         .eq(SysDictData::getDictType, dictType)
         .eq(SysDictData::getDictValue, dictValue))
         .getDictLabel();
   }
    /**
     * 根据条件分页查询字典数据
     *
     * @param dictData 字典数据信息
     * @return 字典数据集合信息
     */
    @Override
    public List<SysDictData> selectDictDataList(SysDictData dictData) {
        return baseMapper.selectList(new LambdaQueryWrapper<SysDictData>()
            .eq(StringUtils.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType())
            .like(StringUtils.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel())
            .eq(StringUtils.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus())
            .orderByAsc(SysDictData::getDictSort));
    }
   /**
    * 根据字典数据ID查询信息
    *
    * @param dictCode 字典数据ID
    * @return 字典数据
    */
   @Override
   public SysDictData selectDictDataById(Long dictCode) {
      return getById(dictCode);
   }
    /**
     * 根据字典类型和字典键值查询字典数据信息
     *
     * @param dictType  字典类型
     * @param dictValue 字典键值
     * @return 字典标签
     */
    @Override
    public String selectDictLabel(String dictType, String dictValue) {
        return baseMapper.selectOne(new LambdaQueryWrapper<SysDictData>()
                .select(SysDictData::getDictLabel)
                .eq(SysDictData::getDictType, dictType)
                .eq(SysDictData::getDictValue, dictValue))
            .getDictLabel();
    }
   /**
    * 批量删除字典数据信息
    *
    * @param dictCodes 需要删除的字典数据ID
    * @return 结果
    */
   @Override
   public void deleteDictDataByIds(Long[] dictCodes) {
      for (Long dictCode : dictCodes) {
         SysDictData data = selectDictDataById(dictCode);
            removeById(dictCode);
         List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType());
         DictUtils.setDictCache(data.getDictType(), dictDatas);
      }
   }
    /**
     * 根据字典数据ID查询信息
     *
     * @param dictCode 字典数据ID
     * @return 字典数据
     */
    @Override
    public SysDictData selectDictDataById(Long dictCode) {
        return baseMapper.selectById(dictCode);
    }
   /**
    * 新增保存字典数据信息
    *
    * @param data 字典数据信息
    * @return 结果
    */
   @Override
   public int insertDictData(SysDictData data) {
      int row = baseMapper.insert(data);
      if (row > 0) {
         List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType());
         DictUtils.setDictCache(data.getDictType(), dictDatas);
      }
      return row;
   }
    /**
     * 批量删除字典数据信息
     *
     * @param dictCodes 需要删除的字典数据ID
     */
    @Override
    public void deleteDictDataByIds(Long[] dictCodes) {
        for (Long dictCode : dictCodes) {
            SysDictData data = selectDictDataById(dictCode);
            baseMapper.deleteById(dictCode);
            CacheUtils.evict(CacheNames.SYS_DICT, data.getDictType());
        }
    }
   /**
    * 修改保存字典数据信息
    *
    * @param data 字典数据信息
    * @return 结果
    */
   @Override
   public int updateDictData(SysDictData data) {
      int row = baseMapper.updateById(data);
      if (row > 0) {
         List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType());
         DictUtils.setDictCache(data.getDictType(), dictDatas);
      }
      return row;
   }
    /**
     * 新增保存字典数据信息
     *
     * @param data 字典数据信息
     * @return 结果
     */
    @CachePut(cacheNames = CacheNames.SYS_DICT, key = "#data.dictType")
    @Override
    public List<SysDictData> insertDictData(SysDictData data) {
        int row = baseMapper.insert(data);
        if (row > 0) {
            return baseMapper.selectDictDataByType(data.getDictType());
        }
        throw new ServiceException("操作失败");
    }
    /**
     * 修改保存字典数据信息
     *
     * @param data 字典数据信息
     * @return 结果
     */
    @CachePut(cacheNames = CacheNames.SYS_DICT, key = "#data.dictType")
    @Override
    public List<SysDictData> updateDictData(SysDictData data) {
        int row = baseMapper.updateById(data);
        if (row > 0) {
            return baseMapper.selectDictDataByType(data.getDictType());
        }
        throw new ServiceException("操作失败");
    }
}