refactor: 字典模块重构
This commit is contained in:
@@ -9,6 +9,10 @@ import java.io.Serializable;
|
|||||||
* 响应码枚举
|
* 响应码枚举
|
||||||
* <p>
|
* <p>
|
||||||
* 参考阿里巴巴开发手册响应码规范
|
* 参考阿里巴巴开发手册响应码规范
|
||||||
|
* 00000 正常
|
||||||
|
* A**** 用户端错误
|
||||||
|
* B**** 系统执行出错
|
||||||
|
* C**** 调用第三方服务出错
|
||||||
*
|
*
|
||||||
* @author Ray.Hao
|
* @author Ray.Hao
|
||||||
* @since 2020/6/23
|
* @since 2020/6/23
|
||||||
@@ -57,6 +61,7 @@ public enum ResultCode implements IResultCode, Serializable {
|
|||||||
|
|
||||||
USER_PASSWORD_ERROR("A0210", "用户名或密码错误"),
|
USER_PASSWORD_ERROR("A0210", "用户名或密码错误"),
|
||||||
USER_INPUT_PASSWORD_ERROR_LIMIT_EXCEEDED("A0211", "用户输入密码错误次数超限"),
|
USER_INPUT_PASSWORD_ERROR_LIMIT_EXCEEDED("A0211", "用户输入密码错误次数超限"),
|
||||||
|
USER_NOT_EXIST("A0212", "用户不存在"),
|
||||||
|
|
||||||
USER_IDENTITY_VERIFICATION_FAILED("A0220", "用户身份校验失败"),
|
USER_IDENTITY_VERIFICATION_FAILED("A0220", "用户身份校验失败"),
|
||||||
USER_FINGERPRINT_RECOGNITION_FAILED("A0221", "用户指纹识别失败"),
|
USER_FINGERPRINT_RECOGNITION_FAILED("A0221", "用户指纹识别失败"),
|
||||||
|
|||||||
@@ -4,12 +4,16 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|||||||
import com.youlai.boot.common.result.PageResult;
|
import com.youlai.boot.common.result.PageResult;
|
||||||
import com.youlai.boot.common.result.Result;
|
import com.youlai.boot.common.result.Result;
|
||||||
import com.youlai.boot.common.enums.LogModuleEnum;
|
import com.youlai.boot.common.enums.LogModuleEnum;
|
||||||
|
import com.youlai.boot.system.model.form.DictItemForm;
|
||||||
|
import com.youlai.boot.system.model.query.DictItemPageQuery;
|
||||||
import com.youlai.boot.system.model.query.DictPageQuery;
|
import com.youlai.boot.system.model.query.DictPageQuery;
|
||||||
|
import com.youlai.boot.system.model.vo.DictItemOptionVO;
|
||||||
|
import com.youlai.boot.system.model.vo.DictItemPageVO;
|
||||||
import com.youlai.boot.system.model.vo.DictPageVO;
|
import com.youlai.boot.system.model.vo.DictPageVO;
|
||||||
import com.youlai.boot.common.annotation.RepeatSubmit;
|
import com.youlai.boot.common.annotation.RepeatSubmit;
|
||||||
import com.youlai.boot.system.model.form.DictForm;
|
import com.youlai.boot.system.model.form.DictForm;
|
||||||
import com.youlai.boot.common.annotation.Log;
|
import com.youlai.boot.common.annotation.Log;
|
||||||
import com.youlai.boot.system.model.vo.DictVO;
|
import com.youlai.boot.system.service.DictItemService;
|
||||||
import com.youlai.boot.system.service.DictService;
|
import com.youlai.boot.system.service.DictService;
|
||||||
import io.swagger.v3.oas.annotations.Parameter;
|
import io.swagger.v3.oas.annotations.Parameter;
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
@@ -25,17 +29,23 @@ import java.util.List;
|
|||||||
/**
|
/**
|
||||||
* 字典控制层
|
* 字典控制层
|
||||||
*
|
*
|
||||||
* @author Ray
|
* @author Ray.Hao
|
||||||
* @since 2.9.0
|
* @since 2.9.0
|
||||||
*/
|
*/
|
||||||
@Tag(name = "06.字典接口")
|
@Tag(name = "06.字典接口")
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping("/api/v1/dict")
|
@SuppressWarnings("SpellCheckingInspection")
|
||||||
|
@RequestMapping("/api/v1/dicts")
|
||||||
@RequiredArgsConstructor
|
@RequiredArgsConstructor
|
||||||
public class DictController {
|
public class DictController {
|
||||||
|
|
||||||
private final DictService dictService;
|
private final DictService dictService;
|
||||||
|
private final DictItemService dictItemService;
|
||||||
|
|
||||||
|
|
||||||
|
//---------------------------------------------------
|
||||||
|
// 字典相关接口
|
||||||
|
//---------------------------------------------------
|
||||||
@Operation(summary = "字典分页列表")
|
@Operation(summary = "字典分页列表")
|
||||||
@GetMapping("/page")
|
@GetMapping("/page")
|
||||||
@Log( value = "字典分页列表",module = LogModuleEnum.DICT)
|
@Log( value = "字典分页列表",module = LogModuleEnum.DICT)
|
||||||
@@ -46,14 +56,7 @@ public class DictController {
|
|||||||
return PageResult.success(result);
|
return PageResult.success(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(summary = "所有字典列表")
|
@Operation(summary = "字典表单数据")
|
||||||
@GetMapping("/list")
|
|
||||||
public Result<List<DictVO>> getAllDictWithData() {
|
|
||||||
List<DictVO> list = dictService.getAllDictWithData();
|
|
||||||
return Result.success(list);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(summary = "字典表单")
|
|
||||||
@GetMapping("/{id}/form")
|
@GetMapping("/{id}/form")
|
||||||
public Result<DictForm> getDictForm(
|
public Result<DictForm> getDictForm(
|
||||||
@Parameter(description = "字典ID") @PathVariable Long id
|
@Parameter(description = "字典ID") @PathVariable Long id
|
||||||
@@ -92,4 +95,76 @@ public class DictController {
|
|||||||
return Result.success();
|
return Result.success();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//---------------------------------------------------
|
||||||
|
// 字典项相关接口
|
||||||
|
//---------------------------------------------------
|
||||||
|
@Operation(summary = "字典项分页")
|
||||||
|
@GetMapping("/{dictCode}/items/page")
|
||||||
|
public PageResult<DictItemPageVO> getDictItemPage(
|
||||||
|
@PathVariable String dictCode,
|
||||||
|
DictItemPageQuery queryParams
|
||||||
|
) {
|
||||||
|
queryParams.setDictCode(dictCode);
|
||||||
|
Page<DictItemPageVO> result = dictItemService.getDictItemPage(queryParams);
|
||||||
|
return PageResult.success(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "字典项列表")
|
||||||
|
@GetMapping("/{dictCode}/items")
|
||||||
|
public Result<List<DictItemOptionVO>> getDictItems(
|
||||||
|
@Parameter(description = "字典编码") @PathVariable String dictCode
|
||||||
|
) {
|
||||||
|
List<DictItemOptionVO> list = dictService.getDictItems(dictCode);
|
||||||
|
return Result.success(list);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "新增字典项")
|
||||||
|
@PostMapping("/{dictCode}/items")
|
||||||
|
@PreAuthorize("@ss.hasPerm('sys:dict-item:add')")
|
||||||
|
@RepeatSubmit
|
||||||
|
public Result<Void> saveDictItem(
|
||||||
|
@PathVariable String dictCode,
|
||||||
|
@Valid @RequestBody DictItemForm formData
|
||||||
|
) {
|
||||||
|
formData.setDictCode(dictCode);
|
||||||
|
boolean result = dictItemService.saveDictItem(formData);
|
||||||
|
return Result.judge(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "字典项表单数据")
|
||||||
|
@GetMapping("/{dictCode}/items/{itemId}/form")
|
||||||
|
public Result<DictItemForm> getDictItemForm(
|
||||||
|
@PathVariable String dictCode,
|
||||||
|
@Parameter(description = "字典项ID") @PathVariable Long itemId
|
||||||
|
) {
|
||||||
|
DictItemForm formData = dictItemService.getDictItemForm(dictCode,itemId);
|
||||||
|
return Result.success(formData);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "修改字典项")
|
||||||
|
@PutMapping("/{dictCode}/items/{itemId}")
|
||||||
|
@PreAuthorize("@ss.hasPerm('sys:dict-item:edit')")
|
||||||
|
@RepeatSubmit
|
||||||
|
public Result<?> updateDictItem(
|
||||||
|
@PathVariable String dictCode,
|
||||||
|
@PathVariable Long itemId,
|
||||||
|
@RequestBody DictItemForm formData
|
||||||
|
) {
|
||||||
|
formData.setId(itemId);
|
||||||
|
formData.setDictCode(dictCode);
|
||||||
|
boolean status = dictItemService.updateDictItem(formData);
|
||||||
|
return Result.judge(status);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "删除字典项")
|
||||||
|
@DeleteMapping("/{dictCode}/items/{itemIds}")
|
||||||
|
@PreAuthorize("@ss.hasPerm('sys:dict-item:delete')")
|
||||||
|
public Result<Void> deleteDictItems(
|
||||||
|
@Parameter(description = "字典ID,多个以英文逗号(,)拼接") @PathVariable String ids
|
||||||
|
) {
|
||||||
|
dictItemService.deleteDictItemByIds(ids);
|
||||||
|
return Result.success();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,96 +0,0 @@
|
|||||||
package com.youlai.boot.system.controller;
|
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
||||||
import com.youlai.boot.common.annotation.Log;
|
|
||||||
import com.youlai.boot.common.annotation.RepeatSubmit;
|
|
||||||
import com.youlai.boot.common.enums.LogModuleEnum;
|
|
||||||
import com.youlai.boot.common.model.Option;
|
|
||||||
import com.youlai.boot.common.result.PageResult;
|
|
||||||
import com.youlai.boot.common.result.Result;
|
|
||||||
import com.youlai.boot.system.model.form.DictDataForm;
|
|
||||||
import com.youlai.boot.system.model.query.DictDataPageQuery;
|
|
||||||
import com.youlai.boot.system.model.vo.DictDataPageVO;
|
|
||||||
import com.youlai.boot.system.service.DictDataService;
|
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
|
||||||
import io.swagger.v3.oas.annotations.Parameter;
|
|
||||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
||||||
import jakarta.validation.Valid;
|
|
||||||
import lombok.RequiredArgsConstructor;
|
|
||||||
import org.springframework.security.access.prepost.PreAuthorize;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 字典数据控制层
|
|
||||||
*
|
|
||||||
* @author Ray
|
|
||||||
* @since 2.9.0
|
|
||||||
*/
|
|
||||||
@Tag(name = "07.字典数据接口")
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("/api/v1/dict-data")
|
|
||||||
@RequiredArgsConstructor
|
|
||||||
public class DictDataController {
|
|
||||||
|
|
||||||
private final DictDataService dictDataService;
|
|
||||||
|
|
||||||
@Operation(summary = "字典数据分页列表")
|
|
||||||
@GetMapping("/page")
|
|
||||||
@Log( value = "字典数据分页列表",module = LogModuleEnum.DICT)
|
|
||||||
public PageResult<DictDataPageVO> getDictDataPage(
|
|
||||||
DictDataPageQuery queryParams
|
|
||||||
) {
|
|
||||||
Page<DictDataPageVO> result = dictDataService.getDictDataPage(queryParams);
|
|
||||||
return PageResult.success(result);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(summary = "获取字典数据表单")
|
|
||||||
@GetMapping("/{id}/form")
|
|
||||||
public Result<DictDataForm> getDictDataForm(
|
|
||||||
@Parameter(description = "字典数据ID") @PathVariable Long id
|
|
||||||
) {
|
|
||||||
DictDataForm formData = dictDataService.getDictDataForm(id);
|
|
||||||
return Result.success(formData);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(summary = "新增字典数据")
|
|
||||||
@PostMapping
|
|
||||||
@PreAuthorize("@ss.hasPerm('sys:dict-data:add')")
|
|
||||||
@RepeatSubmit
|
|
||||||
public Result<Void> saveDictData(@Valid @RequestBody DictDataForm formData) {
|
|
||||||
boolean result = dictDataService.saveDictData(formData);
|
|
||||||
return Result.judge(result);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(summary = "修改字典数据")
|
|
||||||
@PutMapping("/{id}")
|
|
||||||
@PreAuthorize("@ss.hasPerm('sys:dict-data:edit')")
|
|
||||||
public Result<?> updateDictData(
|
|
||||||
@PathVariable Long id,
|
|
||||||
@RequestBody DictDataForm formData
|
|
||||||
) {
|
|
||||||
boolean status = dictDataService.updateDictData(formData);
|
|
||||||
return Result.judge(status);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(summary = "删除字典数据")
|
|
||||||
@DeleteMapping("/{ids}")
|
|
||||||
@PreAuthorize("@ss.hasPerm('sys:dict-data:delete')")
|
|
||||||
public Result<Void> deleteDictionaries(
|
|
||||||
@Parameter(description = "字典ID,多个以英文逗号(,)拼接") @PathVariable String ids
|
|
||||||
) {
|
|
||||||
dictDataService.deleteDictDataByIds(ids);
|
|
||||||
return Result.success();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(summary = "字典数据列表")
|
|
||||||
@GetMapping("/{dictCode}/options")
|
|
||||||
public Result<List<Option<String>>> getDictDataList(
|
|
||||||
@Parameter(description = "字典编码") @PathVariable String dictCode
|
|
||||||
) {
|
|
||||||
List<Option<String>> options = dictDataService.getDictDataList(dictCode);
|
|
||||||
return Result.success(options);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -191,7 +191,7 @@ public class UserController {
|
|||||||
|
|
||||||
@Operation(summary = "重置用户密码")
|
@Operation(summary = "重置用户密码")
|
||||||
@PutMapping(value = "/{userId}/password/reset")
|
@PutMapping(value = "/{userId}/password/reset")
|
||||||
@PreAuthorize("@ss.hasPerm('sys:user:password:reset')")
|
@PreAuthorize("@ss.hasPerm('sys:user:reset-password')")
|
||||||
public Result<?> resetPassword(
|
public Result<?> resetPassword(
|
||||||
@Parameter(description = "用户ID") @PathVariable Long userId,
|
@Parameter(description = "用户ID") @PathVariable Long userId,
|
||||||
@RequestParam String password
|
@RequestParam String password
|
||||||
|
|||||||
@@ -1,11 +1,10 @@
|
|||||||
package com.youlai.boot.system.converter;
|
package com.youlai.boot.system.converter;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.youlai.boot.system.model.entity.DictData;
|
import com.youlai.boot.system.model.entity.DictItem;
|
||||||
import com.youlai.boot.system.model.form.DictDataForm;
|
import com.youlai.boot.system.model.form.DictItemForm;
|
||||||
import com.youlai.boot.system.model.vo.DictPageVO;
|
import com.youlai.boot.system.model.vo.DictPageVO;
|
||||||
import com.youlai.boot.common.model.Option;
|
import com.youlai.boot.common.model.Option;
|
||||||
import com.youlai.boot.system.model.form.DictForm;
|
|
||||||
import org.mapstruct.Mapper;
|
import org.mapstruct.Mapper;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -19,12 +18,12 @@ import java.util.List;
|
|||||||
@Mapper(componentModel = "spring")
|
@Mapper(componentModel = "spring")
|
||||||
public interface DictDataConverter {
|
public interface DictDataConverter {
|
||||||
|
|
||||||
Page<DictPageVO> toPageVo(Page<DictData> page);
|
Page<DictPageVO> toPageVo(Page<DictItem> page);
|
||||||
|
|
||||||
DictDataForm toForm(DictData entity);
|
DictItemForm toForm(DictItem entity);
|
||||||
|
|
||||||
DictData toEntity(DictDataForm formFata);
|
DictItem toEntity(DictItemForm formFata);
|
||||||
|
|
||||||
Option<Long> toOption(DictData dictData);
|
Option<Long> toOption(DictItem dictItem);
|
||||||
List<Option<Long>> toOption(List<DictData> dictData);
|
List<Option<Long>> toOption(List<DictItem> dictData);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ public class UserImportListener extends AnalysisEventListener<UserImportDTO> {
|
|||||||
|
|
||||||
private final List<Role> roleList;
|
private final List<Role> roleList;
|
||||||
private final List<Dept> deptList;
|
private final List<Dept> deptList;
|
||||||
private final List<DictData> genderList;
|
private final List<DictItem> genderList;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 当前行
|
* 当前行
|
||||||
@@ -71,8 +71,8 @@ public class UserImportListener extends AnalysisEventListener<UserImportDTO> {
|
|||||||
.select(Role::getId, Role::getCode));
|
.select(Role::getId, Role::getCode));
|
||||||
this.deptList = SpringUtil.getBean(DeptService.class)
|
this.deptList = SpringUtil.getBean(DeptService.class)
|
||||||
.list(new LambdaQueryWrapper<Dept>().select(Dept::getId, Dept::getCode));
|
.list(new LambdaQueryWrapper<Dept>().select(Dept::getId, Dept::getCode));
|
||||||
this.genderList = SpringUtil.getBean(DictDataService.class)
|
this.genderList = SpringUtil.getBean(DictItemService.class)
|
||||||
.list(new LambdaQueryWrapper<DictData>().eq(DictData::getDictCode, DictCodeEnum.GENDER.getValue()));
|
.list(new LambdaQueryWrapper<DictItem>().eq(DictItem::getDictCode, DictCodeEnum.GENDER.getValue()));
|
||||||
this.excelResult = new ExcelResult();
|
this.excelResult = new ExcelResult();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -202,7 +202,7 @@ public class UserImportListener extends AnalysisEventListener<UserImportDTO> {
|
|||||||
return this.genderList.stream()
|
return this.genderList.stream()
|
||||||
.filter(r -> r.getLabel().equals(genderLabel))
|
.filter(r -> r.getLabel().equals(genderLabel))
|
||||||
.findFirst()
|
.findFirst()
|
||||||
.map(DictData::getValue)
|
.map(DictItem::getValue)
|
||||||
.map(Convert::toInt)
|
.map(Convert::toInt)
|
||||||
.orElse(null);
|
.orElse(null);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,28 +0,0 @@
|
|||||||
package com.youlai.boot.system.mapper;
|
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
||||||
import com.youlai.boot.common.model.Option;
|
|
||||||
import com.youlai.boot.system.model.entity.DictData;
|
|
||||||
import com.youlai.boot.system.model.query.DictDataPageQuery;
|
|
||||||
import com.youlai.boot.system.model.vo.DictDataPageVO;
|
|
||||||
import org.apache.ibatis.annotations.Mapper;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 字典数据映射层
|
|
||||||
*
|
|
||||||
* @author Ray Hao
|
|
||||||
* @since 2.9.0
|
|
||||||
*/
|
|
||||||
@Mapper
|
|
||||||
public interface DictDataMapper extends BaseMapper<DictData> {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 字典数据分页列表
|
|
||||||
*/
|
|
||||||
Page<DictDataPageVO> getDictDataPage(Page<DictDataPageVO> page, DictDataPageQuery queryParams);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -0,0 +1,27 @@
|
|||||||
|
package com.youlai.boot.system.mapper;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
|
import com.youlai.boot.system.model.entity.DictItem;
|
||||||
|
import com.youlai.boot.system.model.query.DictItemPageQuery;
|
||||||
|
import com.youlai.boot.system.model.vo.DictItemPageVO;
|
||||||
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典数据映射层
|
||||||
|
*
|
||||||
|
* @author Ray Hao
|
||||||
|
* @since 2.9.0
|
||||||
|
*/
|
||||||
|
@Mapper
|
||||||
|
public interface DictItemMapper extends BaseMapper<DictItem> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典数据分页列表
|
||||||
|
*/
|
||||||
|
Page<DictItemPageVO> getDictItemPage(Page<DictItemPageVO> page, DictItemPageQuery queryParams);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -29,13 +29,6 @@ public interface DictMapper extends BaseMapper<Dict> {
|
|||||||
*/
|
*/
|
||||||
Page<DictPageVO> getDictPage(Page<DictPageVO> page, DictPageQuery queryParams);
|
Page<DictPageVO> getDictPage(Page<DictPageVO> page, DictPageQuery queryParams);
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取字典列表(包含字典数据)
|
|
||||||
*
|
|
||||||
* @return 字典列表
|
|
||||||
*/
|
|
||||||
List<DictVO> getAllDictWithData();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -6,14 +6,19 @@ import org.apache.ibatis.annotations.Mapper;
|
|||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 角色持久层接口
|
||||||
|
*
|
||||||
|
* @author Ray.Hao
|
||||||
|
* @since 2022/1/14
|
||||||
|
*/
|
||||||
@Mapper
|
@Mapper
|
||||||
public interface RoleMapper extends BaseMapper<Role> {
|
public interface RoleMapper extends BaseMapper<Role> {
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取最大范围的数据权限
|
* 获取最大范围的数据权限
|
||||||
*
|
*
|
||||||
* @param roles
|
* @param roles 角色编码集合
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
Integer getMaximumDataScope(Set<String> roles);
|
Integer getMaximumDataScope(Set<String> roles);
|
||||||
|
|||||||
@@ -1,23 +1,20 @@
|
|||||||
package com.youlai.boot.system.model.entity;
|
package com.youlai.boot.system.model.entity;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.IdType;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableId;
|
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableName;
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
import com.youlai.boot.common.base.BaseEntity;
|
import com.youlai.boot.common.base.BaseEntity;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典数据实体对象
|
* 字典项实体对象
|
||||||
*
|
*
|
||||||
* @author haoxr
|
* @author Ray.Hao
|
||||||
* @since 2022/12/17
|
* @since 2022/12/17
|
||||||
*/
|
*/
|
||||||
@EqualsAndHashCode(callSuper = false)
|
@EqualsAndHashCode(callSuper = false)
|
||||||
@TableName("sys_dict_data")
|
@TableName("sys_dict_item")
|
||||||
@Data
|
@Data
|
||||||
public class DictData extends BaseEntity {
|
public class DictItem extends BaseEntity {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典编码
|
* 字典编码
|
||||||
@@ -3,41 +3,36 @@ package com.youlai.boot.system.model.form;
|
|||||||
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.Getter;
|
|
||||||
import lombok.Setter;
|
|
||||||
import org.hibernate.validator.constraints.Range;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典数据表单对象
|
* 字典项表单对象
|
||||||
*
|
*
|
||||||
* @author Ray Hao
|
* @author Ray Hao
|
||||||
* @since 2.9.0
|
* @since 2.9.0
|
||||||
*/
|
*/
|
||||||
@Schema(description = "字典数据表单")
|
@Schema(description = "字典项表单")
|
||||||
@Data
|
@Data
|
||||||
public class DictDataForm {
|
public class DictItemForm {
|
||||||
|
|
||||||
@Schema(description = "字典ID")
|
@Schema(description = "字典项ID")
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
@Schema(description = "字典编码")
|
@Schema(description = "字典编码")
|
||||||
private String dictCode;
|
private String dictCode;
|
||||||
|
|
||||||
@Schema(description = "字典值")
|
@Schema(description = "字典项值")
|
||||||
private String value;
|
private String value;
|
||||||
|
|
||||||
@Schema(description = "字典标签")
|
@Schema(description = "字典项标签")
|
||||||
private String label;
|
private String label;
|
||||||
|
|
||||||
@Schema(description = "排序")
|
@Schema(description = "排序")
|
||||||
private Integer sort;
|
private Integer sort;
|
||||||
|
|
||||||
@Schema(description = "状态(1-启用,0-禁用)")
|
@Schema(description = "状态(0:禁用,1:启用)")
|
||||||
private Integer status;
|
private Integer status;
|
||||||
|
|
||||||
@Schema(description = "字典类型")
|
@Schema(description = "字典类型(用于显示样式)")
|
||||||
private String tagType;
|
private String tagType;
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -8,10 +8,10 @@ import lombok.EqualsAndHashCode;
|
|||||||
|
|
||||||
@Data
|
@Data
|
||||||
@EqualsAndHashCode(callSuper = false)
|
@EqualsAndHashCode(callSuper = false)
|
||||||
@Schema(description ="字典数据分页查询对象")
|
@Schema(description ="字典项分页查询对象")
|
||||||
public class DictDataPageQuery extends BasePageQuery {
|
public class DictItemPageQuery extends BasePageQuery {
|
||||||
|
|
||||||
@Schema(description="关键字(字典数据标签/值)")
|
@Schema(description="关键字(字典项值/字典项名称)")
|
||||||
private String keywords;
|
private String keywords;
|
||||||
|
|
||||||
@Schema(description="字典编码")
|
@Schema(description="字典编码")
|
||||||
@@ -1,6 +1,5 @@
|
|||||||
package com.youlai.boot.system.model.query;
|
package com.youlai.boot.system.model.query;
|
||||||
|
|
||||||
|
|
||||||
import com.youlai.boot.common.base.BasePageQuery;
|
import com.youlai.boot.common.base.BasePageQuery;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
@@ -8,13 +7,10 @@ import lombok.EqualsAndHashCode;
|
|||||||
|
|
||||||
@Data
|
@Data
|
||||||
@EqualsAndHashCode(callSuper = false)
|
@EqualsAndHashCode(callSuper = false)
|
||||||
@Schema(description ="字典数据项分页查询对象")
|
@Schema(description ="字典分页查询对象")
|
||||||
public class DictPageQuery extends BasePageQuery {
|
public class DictPageQuery extends BasePageQuery {
|
||||||
|
|
||||||
@Schema(description="关键字(字典名称)")
|
@Schema(description="关键字(字典名称)")
|
||||||
private String keywords;
|
private String keywords;
|
||||||
|
|
||||||
@Schema(description="字典编码")
|
|
||||||
private String typeCode;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,27 @@
|
|||||||
|
package com.youlai.boot.system.model.vo;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 字典数据项
|
||||||
|
*
|
||||||
|
* @author Ray
|
||||||
|
* @since 0.0.1
|
||||||
|
*/
|
||||||
|
@Schema(description = "字典数据项")
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
public class DictItemOptionVO {
|
||||||
|
|
||||||
|
@Schema(description = "字典数据值")
|
||||||
|
private String value;
|
||||||
|
|
||||||
|
@Schema(description = "字典数据标签")
|
||||||
|
private String label;
|
||||||
|
|
||||||
|
@Schema(description = "标签类型")
|
||||||
|
private String tagType;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -7,7 +7,7 @@ import lombok.Setter;
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典数据项分页VO
|
* 字典项分页VO
|
||||||
*
|
*
|
||||||
* @author Ray
|
* @author Ray
|
||||||
* @since 0.0.1
|
* @since 0.0.1
|
||||||
@@ -15,7 +15,7 @@ import lombok.Setter;
|
|||||||
@Schema(description = "字典数据分页对象")
|
@Schema(description = "字典数据分页对象")
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
public class DictDataPageVO {
|
public class DictItemPageVO {
|
||||||
|
|
||||||
@Schema(description = "字典数据ID")
|
@Schema(description = "字典数据ID")
|
||||||
private Long id;
|
private Long id;
|
||||||
@@ -3,22 +3,20 @@ package com.youlai.boot.system.service;
|
|||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.baomidou.mybatisplus.extension.service.IService;
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
import com.youlai.boot.common.model.Option;
|
import com.youlai.boot.common.model.Option;
|
||||||
import com.youlai.boot.system.model.entity.DictData;
|
import com.youlai.boot.system.model.entity.DictItem;
|
||||||
import com.youlai.boot.system.model.form.DictDataForm;
|
import com.youlai.boot.system.model.form.DictItemForm;
|
||||||
import com.youlai.boot.system.model.form.DictForm;
|
import com.youlai.boot.system.model.query.DictItemPageQuery;
|
||||||
import com.youlai.boot.system.model.query.DictDataPageQuery;
|
import com.youlai.boot.system.model.vo.DictItemPageVO;
|
||||||
import com.youlai.boot.system.model.query.DictPageQuery;
|
|
||||||
import com.youlai.boot.system.model.vo.DictDataPageVO;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典数据接口
|
* 字典项接口
|
||||||
*
|
*
|
||||||
* @author Ray Hao
|
* @author Ray Hao
|
||||||
* @since 2023/3/4
|
* @since 2023/3/4
|
||||||
*/
|
*/
|
||||||
public interface DictDataService extends IService<DictData> {
|
public interface DictItemService extends IService<DictItem> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典数据分页列表
|
* 字典数据分页列表
|
||||||
@@ -26,23 +24,24 @@ public interface DictDataService extends IService<DictData> {
|
|||||||
* @param queryParams
|
* @param queryParams
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
Page<DictDataPageVO> getDictDataPage(DictDataPageQuery queryParams);
|
Page<DictItemPageVO> getDictItemPage(DictItemPageQuery queryParams);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取字典数据表单
|
* 获取字典数据表单
|
||||||
*
|
*
|
||||||
* @param id 字典数据ID
|
* @param dictCode 字典编码
|
||||||
|
* @param itemId 字典数据ID
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
DictDataForm getDictDataForm(Long id);
|
DictItemForm getDictItemForm(String dictCode,Long itemId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 保存字典数据
|
* 保存字典项
|
||||||
*
|
*
|
||||||
* @param formData
|
* @param formData
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
boolean saveDictData(DictDataForm formData);
|
boolean saveDictItem(DictItemForm formData);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 更新字典数据
|
* 更新字典数据
|
||||||
@@ -50,14 +49,14 @@ public interface DictDataService extends IService<DictData> {
|
|||||||
* @param formData 字典数据表单
|
* @param formData 字典数据表单
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
boolean updateDictData(DictDataForm formData);
|
boolean updateDictItem(DictItemForm formData);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 删除字典数据
|
* 删除字典数据
|
||||||
*
|
*
|
||||||
* @param ids 字典数据ID,多个逗号分隔
|
* @param ids 字典数据ID,多个逗号分隔
|
||||||
*/
|
*/
|
||||||
void deleteDictDataByIds(String ids);
|
void deleteDictItemByIds(String ids);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取字典数据列表
|
* 获取字典数据列表
|
||||||
@@ -2,10 +2,10 @@ package com.youlai.boot.system.service;
|
|||||||
|
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.baomidou.mybatisplus.extension.service.IService;
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
import com.youlai.boot.common.model.Option;
|
|
||||||
import com.youlai.boot.system.model.entity.Dict;
|
import com.youlai.boot.system.model.entity.Dict;
|
||||||
import com.youlai.boot.system.model.form.DictForm;
|
import com.youlai.boot.system.model.form.DictForm;
|
||||||
import com.youlai.boot.system.model.query.DictPageQuery;
|
import com.youlai.boot.system.model.query.DictPageQuery;
|
||||||
|
import com.youlai.boot.system.model.vo.DictItemOptionVO;
|
||||||
import com.youlai.boot.system.model.vo.DictPageVO;
|
import com.youlai.boot.system.model.vo.DictPageVO;
|
||||||
import com.youlai.boot.system.model.vo.DictVO;
|
import com.youlai.boot.system.model.vo.DictVO;
|
||||||
|
|
||||||
@@ -59,11 +59,11 @@ public interface DictService extends IService<Dict> {
|
|||||||
*/
|
*/
|
||||||
void deleteDictByIds(List<String> ids);
|
void deleteDictByIds(List<String> ids);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取字典列表(包含字典数据)
|
* 获取字典项列表
|
||||||
*
|
*
|
||||||
* @return 字典列表
|
* @param dictCode 字典编码
|
||||||
|
* @return 字典项列表
|
||||||
*/
|
*/
|
||||||
List<DictVO> getAllDictWithData();
|
List<DictItemOptionVO> getDictItems(String dictCode);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,13 +5,12 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|||||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
import com.youlai.boot.common.model.Option;
|
import com.youlai.boot.common.model.Option;
|
||||||
import com.youlai.boot.system.converter.DictDataConverter;
|
import com.youlai.boot.system.converter.DictDataConverter;
|
||||||
import com.youlai.boot.system.mapper.DictDataMapper;
|
import com.youlai.boot.system.mapper.DictItemMapper;
|
||||||
import com.youlai.boot.system.model.entity.DictData;
|
import com.youlai.boot.system.model.entity.DictItem;
|
||||||
import com.youlai.boot.system.model.form.DictDataForm;
|
import com.youlai.boot.system.model.form.DictItemForm;
|
||||||
import com.youlai.boot.system.model.query.DictDataPageQuery;
|
import com.youlai.boot.system.model.query.DictItemPageQuery;
|
||||||
import com.youlai.boot.system.model.query.DictPageQuery;
|
import com.youlai.boot.system.model.vo.DictItemPageVO;
|
||||||
import com.youlai.boot.system.model.vo.DictDataPageVO;
|
import com.youlai.boot.system.service.DictItemService;
|
||||||
import com.youlai.boot.system.service.DictDataService;
|
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
@@ -26,7 +25,7 @@ import java.util.List;
|
|||||||
*/
|
*/
|
||||||
@Service
|
@Service
|
||||||
@RequiredArgsConstructor
|
@RequiredArgsConstructor
|
||||||
public class DictDataServiceImpl extends ServiceImpl<DictDataMapper, DictData> implements DictDataService {
|
public class DictItemServiceImpl extends ServiceImpl<DictItemMapper, DictItem> implements DictItemService {
|
||||||
|
|
||||||
private final DictDataConverter dictDataConverter;
|
private final DictDataConverter dictDataConverter;
|
||||||
|
|
||||||
@@ -37,23 +36,24 @@ public class DictDataServiceImpl extends ServiceImpl<DictDataMapper, DictData> i
|
|||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public Page<DictDataPageVO> getDictDataPage(DictDataPageQuery queryParams) {
|
public Page<DictItemPageVO> getDictItemPage(DictItemPageQuery queryParams) {
|
||||||
int pageNum = queryParams.getPageNum();
|
int pageNum = queryParams.getPageNum();
|
||||||
int pageSize = queryParams.getPageSize();
|
int pageSize = queryParams.getPageSize();
|
||||||
Page<DictDataPageVO> page = new Page<>(pageNum, pageSize);
|
Page<DictItemPageVO> page = new Page<>(pageNum, pageSize);
|
||||||
|
|
||||||
return this.baseMapper.getDictDataPage(page, queryParams);
|
return this.baseMapper.getDictItemPage(page, queryParams);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取字典数据表单
|
* 获取字典项表单
|
||||||
*
|
*
|
||||||
* @param id 字典数据ID
|
* @param dictCode 字典编码
|
||||||
|
* @param itemId 字典数据ID
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public DictDataForm getDictDataForm(Long id) {
|
public DictItemForm getDictItemForm(String dictCode,Long itemId) {
|
||||||
DictData entity = this.getById(id);
|
DictItem entity = this.getById(itemId);
|
||||||
return dictDataConverter.toForm(entity);
|
return dictDataConverter.toForm(entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -64,8 +64,8 @@ public class DictDataServiceImpl extends ServiceImpl<DictDataMapper, DictData> i
|
|||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean saveDictData(DictDataForm formData) {
|
public boolean saveDictItem(DictItemForm formData) {
|
||||||
DictData entity = dictDataConverter.toEntity(formData);
|
DictItem entity = dictDataConverter.toEntity(formData);
|
||||||
return this.save(entity);
|
return this.save(entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -76,8 +76,8 @@ public class DictDataServiceImpl extends ServiceImpl<DictDataMapper, DictData> i
|
|||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean updateDictData(DictDataForm formData) {
|
public boolean updateDictItem(DictItemForm formData) {
|
||||||
DictData entity = dictDataConverter.toEntity(formData);
|
DictItem entity = dictDataConverter.toEntity(formData);
|
||||||
return this.updateById(entity);
|
return this.updateById(entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -87,7 +87,7 @@ public class DictDataServiceImpl extends ServiceImpl<DictDataMapper, DictData> i
|
|||||||
* @param ids 字典数据ID集合
|
* @param ids 字典数据ID集合
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void deleteDictDataByIds(String ids) {
|
public void deleteDictItemByIds(String ids) {
|
||||||
List<Long> idList = Arrays.stream(ids.split(",")).map(Long::parseLong).toList();
|
List<Long> idList = Arrays.stream(ids.split(",")).map(Long::parseLong).toList();
|
||||||
this.removeByIds(idList);
|
this.removeByIds(idList);
|
||||||
}
|
}
|
||||||
@@ -100,9 +100,9 @@ public class DictDataServiceImpl extends ServiceImpl<DictDataMapper, DictData> i
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public List<Option<String>> getDictDataList(String dictCode) {
|
public List<Option<String>> getDictDataList(String dictCode) {
|
||||||
return this.list(new LambdaQueryWrapper<DictData>()
|
return this.list(new LambdaQueryWrapper<DictItem>()
|
||||||
.eq(DictData::getDictCode, dictCode)
|
.eq(DictItem::getDictCode, dictCode)
|
||||||
.eq(DictData::getStatus, 1)
|
.eq(DictItem::getStatus, 1)
|
||||||
).stream().map(item -> new Option<>(item.getValue(), item.getLabel(),item.getTagType()))
|
).stream().map(item -> new Option<>(item.getValue(), item.getLabel(),item.getTagType()))
|
||||||
.toList();
|
.toList();
|
||||||
}
|
}
|
||||||
@@ -6,15 +6,14 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|||||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
import com.youlai.boot.common.exception.BusinessException;
|
import com.youlai.boot.common.exception.BusinessException;
|
||||||
import com.youlai.boot.system.converter.DictConverter;
|
import com.youlai.boot.system.converter.DictConverter;
|
||||||
import com.youlai.boot.system.converter.DictDataConverter;
|
|
||||||
import com.youlai.boot.system.mapper.DictMapper;
|
import com.youlai.boot.system.mapper.DictMapper;
|
||||||
import com.youlai.boot.system.model.entity.Dict;
|
import com.youlai.boot.system.model.entity.Dict;
|
||||||
import com.youlai.boot.system.model.entity.DictData;
|
import com.youlai.boot.system.model.entity.DictItem;
|
||||||
import com.youlai.boot.system.model.form.DictForm;
|
import com.youlai.boot.system.model.form.DictForm;
|
||||||
import com.youlai.boot.system.model.query.DictPageQuery;
|
import com.youlai.boot.system.model.query.DictPageQuery;
|
||||||
|
import com.youlai.boot.system.model.vo.DictItemOptionVO;
|
||||||
import com.youlai.boot.system.model.vo.DictPageVO;
|
import com.youlai.boot.system.model.vo.DictPageVO;
|
||||||
import com.youlai.boot.system.model.vo.DictVO;
|
import com.youlai.boot.system.service.DictItemService;
|
||||||
import com.youlai.boot.system.service.DictDataService;
|
|
||||||
import com.youlai.boot.system.service.DictService;
|
import com.youlai.boot.system.service.DictService;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
@@ -32,9 +31,8 @@ import java.util.List;
|
|||||||
@RequiredArgsConstructor
|
@RequiredArgsConstructor
|
||||||
public class DictServiceImpl extends ServiceImpl<DictMapper, Dict> implements DictService {
|
public class DictServiceImpl extends ServiceImpl<DictMapper, Dict> implements DictService {
|
||||||
|
|
||||||
private final DictDataService dictDataService;
|
private final DictItemService dictItemService;
|
||||||
private final DictConverter dictConverter;
|
private final DictConverter dictConverter;
|
||||||
private final DictDataConverter dictDataConverter;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字典分页列表
|
* 字典分页列表
|
||||||
@@ -65,7 +63,7 @@ public class DictServiceImpl extends ServiceImpl<DictMapper, Dict> implements Di
|
|||||||
String dictCode = entity.getDictCode();
|
String dictCode = entity.getDictCode();
|
||||||
|
|
||||||
long count = this.count(new LambdaQueryWrapper<Dict>()
|
long count = this.count(new LambdaQueryWrapper<Dict>()
|
||||||
.eq(Dict::getDictCode, dictCode)
|
.eq(Dict::getDictCode, dictCode)
|
||||||
);
|
);
|
||||||
|
|
||||||
Assert.isTrue(count == 0, "字典编码已存在");
|
Assert.isTrue(count == 0, "字典编码已存在");
|
||||||
@@ -127,9 +125,9 @@ public class DictServiceImpl extends ServiceImpl<DictMapper, Dict> implements Di
|
|||||||
boolean removeResult = this.removeById(id);
|
boolean removeResult = this.removeById(id);
|
||||||
// 删除字典下的字典项
|
// 删除字典下的字典项
|
||||||
if (removeResult) {
|
if (removeResult) {
|
||||||
dictDataService.remove(
|
dictItemService.remove(
|
||||||
new LambdaQueryWrapper<DictData>()
|
new LambdaQueryWrapper<DictItem>()
|
||||||
.eq(DictData::getDictCode, dict.getDictCode())
|
.eq(DictItem::getDictCode, dict.getDictCode())
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -137,13 +135,28 @@ public class DictServiceImpl extends ServiceImpl<DictMapper, Dict> implements Di
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取字典列表(包含字典数据)
|
/**
|
||||||
*/
|
* 获取字典项列表
|
||||||
@Override
|
*
|
||||||
public List<DictVO> getAllDictWithData() {
|
* @param dictCode 字典编码
|
||||||
return this.baseMapper.getAllDictWithData();
|
*/
|
||||||
}
|
@Override
|
||||||
|
public List<DictItemOptionVO> getDictItems(String dictCode) {
|
||||||
|
return dictItemService.list(
|
||||||
|
new LambdaQueryWrapper<DictItem>()
|
||||||
|
.eq(DictItem::getDictCode, dictCode)
|
||||||
|
.eq(DictItem::getStatus, 1)
|
||||||
|
.orderByAsc(DictItem::getSort)
|
||||||
|
).stream()
|
||||||
|
.map(item -> {
|
||||||
|
DictItemOptionVO dictItemOptionVO = new DictItemOptionVO();
|
||||||
|
dictItemOptionVO.setLabel(item.getLabel());
|
||||||
|
dictItemOptionVO.setValue(item.getValue());
|
||||||
|
dictItemOptionVO.setTagType(item.getTagType());
|
||||||
|
return dictItemOptionVO;
|
||||||
|
}).toList();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ import com.youlai.boot.system.mapper.UserMapper;
|
|||||||
import com.youlai.boot.system.model.bo.UserBO;
|
import com.youlai.boot.system.model.bo.UserBO;
|
||||||
import com.youlai.boot.system.model.dto.UserAuthInfo;
|
import com.youlai.boot.system.model.dto.UserAuthInfo;
|
||||||
import com.youlai.boot.system.model.dto.UserExportDTO;
|
import com.youlai.boot.system.model.dto.UserExportDTO;
|
||||||
import com.youlai.boot.system.model.entity.DictData;
|
import com.youlai.boot.system.model.entity.DictItem;
|
||||||
import com.youlai.boot.system.model.entity.User;
|
import com.youlai.boot.system.model.entity.User;
|
||||||
import com.youlai.boot.system.model.entity.UserRole;
|
import com.youlai.boot.system.model.entity.UserRole;
|
||||||
import com.youlai.boot.system.model.form.*;
|
import com.youlai.boot.system.model.form.*;
|
||||||
@@ -69,7 +69,7 @@ public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements Us
|
|||||||
|
|
||||||
private final TokenManager tokenManager;
|
private final TokenManager tokenManager;
|
||||||
|
|
||||||
private final DictDataService dictDataService;
|
private final DictItemService dictItemService;
|
||||||
|
|
||||||
private final UserConverter userConverter;
|
private final UserConverter userConverter;
|
||||||
|
|
||||||
@@ -287,11 +287,11 @@ public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements Us
|
|||||||
List<UserExportDTO> exportUsers = this.baseMapper.listExportUsers(queryParams);
|
List<UserExportDTO> exportUsers = this.baseMapper.listExportUsers(queryParams);
|
||||||
if (CollectionUtil.isNotEmpty(exportUsers)) {
|
if (CollectionUtil.isNotEmpty(exportUsers)) {
|
||||||
//获取角色的字典数据
|
//获取角色的字典数据
|
||||||
Map<String, String> genderMap = dictDataService.list(
|
Map<String, String> genderMap = dictItemService.list(
|
||||||
new LambdaQueryWrapper<DictData>().eq(DictData::getDictCode,
|
new LambdaQueryWrapper<DictItem>().eq(DictItem::getDictCode,
|
||||||
DictCodeEnum.GENDER.getValue())
|
DictCodeEnum.GENDER.getValue())
|
||||||
).stream()
|
).stream()
|
||||||
.collect(Collectors.toMap(DictData::getValue, DictData::getLabel)
|
.collect(Collectors.toMap(DictItem::getValue, DictItem::getLabel)
|
||||||
);
|
);
|
||||||
|
|
||||||
exportUsers.forEach(item -> {
|
exportUsers.forEach(item -> {
|
||||||
|
|||||||
@@ -2,10 +2,10 @@
|
|||||||
<!DOCTYPE mapper
|
<!DOCTYPE mapper
|
||||||
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="com.youlai.boot.system.mapper.DictDataMapper">
|
<mapper namespace="com.youlai.boot.system.mapper.DictItemMapper">
|
||||||
|
|
||||||
<!-- 获取字典数据分页列表 -->
|
<!-- 获取字典数据分页列表 -->
|
||||||
<select id="getDictDataPage" resultType="com.youlai.boot.system.model.vo.DictDataPageVO">
|
<select id="getDictItemPage" resultType="com.youlai.boot.system.model.vo.DictItemPageVO">
|
||||||
SELECT
|
SELECT
|
||||||
id,
|
id,
|
||||||
dict_code,
|
dict_code,
|
||||||
@@ -14,7 +14,7 @@
|
|||||||
sort,
|
sort,
|
||||||
status
|
status
|
||||||
FROM
|
FROM
|
||||||
sys_dict_data
|
sys_dict_item
|
||||||
<where>
|
<where>
|
||||||
<if test="queryParams.keywords!=null and queryParams.keywords.trim() neq ''">
|
<if test="queryParams.keywords!=null and queryParams.keywords.trim() neq ''">
|
||||||
AND (
|
AND (
|
||||||
@@ -36,7 +36,7 @@
|
|||||||
label,
|
label,
|
||||||
tag_type
|
tag_type
|
||||||
FROM
|
FROM
|
||||||
sys_dict_data
|
sys_dict_item
|
||||||
WHERE
|
WHERE
|
||||||
status = 1 AND dict_code = #{dictCode}
|
status = 1 AND dict_code = #{dictCode}
|
||||||
ORDER BY
|
ORDER BY
|
||||||
@@ -26,25 +26,4 @@
|
|||||||
t1.create_time DESC
|
t1.create_time DESC
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<resultMap id="DictWithDataMap" type="com.youlai.boot.system.model.vo.DictVO">
|
|
||||||
<result column="name" property="name"/>
|
|
||||||
<result column="dict_code" property="dictCode"/>
|
|
||||||
<collection property="dictDataList"
|
|
||||||
column="{dictCode=dict_code}"
|
|
||||||
select="com.youlai.boot.system.mapper.DictDataMapper.getDictDataList">
|
|
||||||
</collection>
|
|
||||||
</resultMap>
|
|
||||||
|
|
||||||
<!-- 获取字典列表(包含字典数据) -->
|
|
||||||
<select id="getAllDictWithData" resultMap="DictWithDataMap">
|
|
||||||
SELECT
|
|
||||||
t1.name,
|
|
||||||
t1.dict_code
|
|
||||||
FROM
|
|
||||||
sys_dict t1
|
|
||||||
WHERE
|
|
||||||
t1.is_deleted = 0 AND t1.status = 1
|
|
||||||
ORDER BY
|
|
||||||
t1.create_time DESC
|
|
||||||
</select>
|
|
||||||
</mapper>
|
</mapper>
|
||||||
|
|||||||
@@ -25,6 +25,7 @@
|
|||||||
LEFT JOIN sys_role r ON sur.role_id = r.id
|
LEFT JOIN sys_role r ON sur.role_id = r.id
|
||||||
<where>
|
<where>
|
||||||
u.is_deleted = 0
|
u.is_deleted = 0
|
||||||
|
<!-- 非超级管理员用户限制查看超级管理员 -->
|
||||||
<if test="!queryParams.isRoot">
|
<if test="!queryParams.isRoot">
|
||||||
AND NOT EXISTS (
|
AND NOT EXISTS (
|
||||||
SELECT
|
SELECT
|
||||||
|
|||||||
Reference in New Issue
Block a user