SysDictDataServiceImpl.java 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. package com.ruoyi.system.service.impl;
  2. import cn.hutool.core.util.StrUtil;
  3. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  4. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  5. import com.ruoyi.common.core.domain.entity.SysDictData;
  6. import com.ruoyi.common.core.page.TableDataInfo;
  7. import com.ruoyi.common.utils.DictUtils;
  8. import com.ruoyi.common.utils.PageUtils;
  9. import com.ruoyi.system.mapper.SysDictDataMapper;
  10. import com.ruoyi.system.service.ISysDictDataService;
  11. import org.springframework.stereotype.Service;
  12. import java.util.List;
  13. /**
  14. * 字典 业务层处理
  15. *
  16. * @author ruoyi
  17. */
  18. @Service
  19. public class SysDictDataServiceImpl extends ServiceImpl<SysDictDataMapper, SysDictData> implements ISysDictDataService {
  20. @Override
  21. public TableDataInfo<SysDictData> selectPageDictDataList(SysDictData dictData) {
  22. LambdaQueryWrapper<SysDictData> lqw = new LambdaQueryWrapper<SysDictData>()
  23. .eq(StrUtil.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType())
  24. .like(StrUtil.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel())
  25. .eq(StrUtil.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus())
  26. .orderByAsc(SysDictData::getDictSort);
  27. return PageUtils.buildDataInfo(page(PageUtils.buildPage(), lqw));
  28. }
  29. /**
  30. * 根据条件分页查询字典数据
  31. *
  32. * @param dictData 字典数据信息
  33. * @return 字典数据集合信息
  34. */
  35. @Override
  36. public List<SysDictData> selectDictDataList(SysDictData dictData) {
  37. return list(new LambdaQueryWrapper<SysDictData>()
  38. .eq(StrUtil.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType())
  39. .like(StrUtil.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel())
  40. .eq(StrUtil.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus())
  41. .orderByAsc(SysDictData::getDictSort));
  42. }
  43. /**
  44. * 根据字典类型和字典键值查询字典数据信息
  45. *
  46. * @param dictType 字典类型
  47. * @param dictValue 字典键值
  48. * @return 字典标签
  49. */
  50. @Override
  51. public String selectDictLabel(String dictType, String dictValue) {
  52. return getOne(new LambdaQueryWrapper<SysDictData>()
  53. .select(SysDictData::getDictLabel)
  54. .eq(SysDictData::getDictType, dictType)
  55. .eq(SysDictData::getDictValue, dictValue))
  56. .getDictLabel();
  57. }
  58. /**
  59. * 根据字典数据ID查询信息
  60. *
  61. * @param dictCode 字典数据ID
  62. * @return 字典数据
  63. */
  64. @Override
  65. public SysDictData selectDictDataById(Long dictCode) {
  66. return getById(dictCode);
  67. }
  68. /**
  69. * 批量删除字典数据信息
  70. *
  71. * @param dictCodes 需要删除的字典数据ID
  72. * @return 结果
  73. */
  74. @Override
  75. public void deleteDictDataByIds(Long[] dictCodes) {
  76. for (Long dictCode : dictCodes) {
  77. SysDictData data = selectDictDataById(dictCode);
  78. removeById(dictCode);
  79. List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType());
  80. DictUtils.setDictCache(data.getDictType(), dictDatas);
  81. }
  82. }
  83. /**
  84. * 新增保存字典数据信息
  85. *
  86. * @param data 字典数据信息
  87. * @return 结果
  88. */
  89. @Override
  90. public int insertDictData(SysDictData data) {
  91. int row = baseMapper.insert(data);
  92. if (row > 0) {
  93. List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType());
  94. DictUtils.setDictCache(data.getDictType(), dictDatas);
  95. }
  96. return row;
  97. }
  98. /**
  99. * 修改保存字典数据信息
  100. *
  101. * @param data 字典数据信息
  102. * @return 结果
  103. */
  104. @Override
  105. public int updateDictData(SysDictData data) {
  106. int row = baseMapper.updateById(data);
  107. if (row > 0) {
  108. List<SysDictData> dictDatas = baseMapper.selectDictDataByType(data.getDictType());
  109. DictUtils.setDictCache(data.getDictType(), dictDatas);
  110. }
  111. return row;
  112. }
  113. }