refactor: 字典模块重构

This commit is contained in:
Ray.Hao
2025-03-24 07:24:32 +08:00
parent b080d11853
commit 60f94fdf7f
24 changed files with 264 additions and 277 deletions

View File

@@ -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", "用户指纹识别失败"),

View File

@@ -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();
}
} }

View File

@@ -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);
}
}

View File

@@ -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

View File

@@ -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);
} }

View File

@@ -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);
} }

View File

@@ -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);
}

View File

@@ -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);
}

View File

@@ -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();
} }

View File

@@ -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);

View File

@@ -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 {
/** /**
* 字典编码 * 字典编码

View File

@@ -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;
} }

View File

@@ -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="字典编码")

View File

@@ -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;
} }

View File

@@ -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;
}

View File

@@ -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;

View File

@@ -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);
/** /**
* 获取字典数据列表 * 获取字典数据列表

View File

@@ -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);
} }

View File

@@ -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();
} }

View File

@@ -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();
}
} }

View File

@@ -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 -> {

View File

@@ -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

View File

@@ -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>

View File

@@ -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