分销:Review代码修改

This commit is contained in:
owen 2023-09-24 20:28:44 +08:00
parent 421bb7d154
commit e9fd377772
20 changed files with 131 additions and 102 deletions

View File

@ -1,5 +1,6 @@
package cn.iocoder.yudao.framework.common.util.number; package cn.iocoder.yudao.framework.common.util.number;
import cn.hutool.core.math.Money;
import cn.hutool.core.util.NumberUtil; import cn.hutool.core.util.NumberUtil;
import java.math.BigDecimal; import java.math.BigDecimal;
@ -16,7 +17,7 @@ public class MoneyUtils {
* 计算百分比金额四舍五入 * 计算百分比金额四舍五入
* *
* @param price 金额 * @param price 金额
* @param rate 百分比例如说 56.77% 则传入 56.77 * @param rate 百分比例如说 56.77% 则传入 56.77
* @return 百分比金额 * @return 百分比金额
*/ */
public static Integer calculateRatePrice(Integer price, Double rate) { public static Integer calculateRatePrice(Integer price, Double rate) {
@ -27,24 +28,43 @@ public class MoneyUtils {
* 计算百分比金额向下传入 * 计算百分比金额向下传入
* *
* @param price 金额 * @param price 金额
* @param rate 百分比例如说 56.77% 则传入 56.77 * @param rate 百分比例如说 56.77% 则传入 56.77
* @return 百分比金额 * @return 百分比金额
*/ */
public static Integer calculateRatePriceFloor(Integer price, Double rate) { public static Integer calculateRatePriceFloor(Integer price, Double rate) {
return calculateRatePrice(price, rate, 0, RoundingMode.FLOOR).intValue(); return calculateRatePrice(price, rate, 0, RoundingMode.FLOOR).intValue();
} }
/** /**
* 计算百分比金额 * 计算百分比金额
* *
* @param price 金额 * @param price 金额
* @param rate 百分比例如说 56.77% 则传入 56.77 * @param rate 百分比例如说 56.77% 则传入 56.77
* @param scale 保留小数位数 * @param scale 保留小数位数
* @param roundingMode 舍入模式 * @param roundingMode 舍入模式
*/ */
public static BigDecimal calculateRatePrice(Number price, Number rate, int scale, RoundingMode roundingMode) { public static BigDecimal calculateRatePrice(Number price, Number rate, int scale, RoundingMode roundingMode) {
return NumberUtil.toBigDecimal(price).multiply(NumberUtil.toBigDecimal(rate)) // 乘以 return NumberUtil.toBigDecimal(price).multiply(NumberUtil.toBigDecimal(rate)) // 乘以
.divide(BigDecimal.valueOf(100), scale, roundingMode); // 除以 100 .divide(BigDecimal.valueOf(100), scale, roundingMode); // 除以 100
} }
/**
* 分转元
*
* @param fen
* @return
*/
public static BigDecimal fenToYuan(int fen) {
return new Money(0, fen).getAmount();
}
/**
* 分转元字符串
*
* @param fen
* @return
*/
public static String fenToYuanStr(int fen) {
return new Money(0, fen).toString();
}
} }

View File

@ -0,0 +1,11 @@
package cn.iocoder.yudao.module.trade.enums;
/**
* Trade 字典类型的枚举类
*
* @author owen
*/
public interface DictTypeConstants {
String BROKERAGE_WITHDRAW_STATUS = "brokerage_withdraw_status"; // 佣金提现状态
}

View File

@ -22,9 +22,6 @@ public enum BrokerageWithdrawStatusEnum implements IntArrayValuable {
WITHDRAW_FAIL(21, "提现失败"), WITHDRAW_FAIL(21, "提现失败"),
; ;
// TODO @疯狂字典现在枚举在每个模块的 DictTypeConstants 里哈可以创建一个出来主要是想治理每个模块到底有多少个枚举
public static final String DICT_TYPE = "BROKERAGE_WITHDRAW_STATUS";
public static final int[] ARRAYS = Arrays.stream(values()).mapToInt(BrokerageWithdrawStatusEnum::getStatus).toArray(); public static final int[] ARRAYS = Arrays.stream(values()).mapToInt(BrokerageWithdrawStatusEnum::getStatus).toArray();
/** /**

View File

@ -67,8 +67,8 @@ public class AppBrokerageUserController {
@Operation(summary = "绑定推广员") @Operation(summary = "绑定推广员")
@PreAuthenticated @PreAuthenticated
public CommonResult<Boolean> bindBrokerageUser(@Valid @RequestBody AppBrokerageUserBindReqVO reqVO) { public CommonResult<Boolean> bindBrokerageUser(@Valid @RequestBody AppBrokerageUserBindReqVO reqVO) {
// TODO @疯狂是不是 isNewUser 不用传递哈交给 service 自己计算出来 MemberUserRespDTO user = memberUserApi.getUser(getLoginUserId());
return success(brokerageUserService.bindBrokerageUser(getLoginUserId(), reqVO.getBindUserId(), false)); return success(brokerageUserService.bindBrokerageUser(user.getId(), reqVO.getBindUserId(), user.getCreateTime()));
} }
@GetMapping("/get-summary") @GetMapping("/get-summary")

View File

@ -9,7 +9,6 @@ import cn.iocoder.yudao.module.trade.controller.app.brokerage.vo.withdraw.AppBro
import cn.iocoder.yudao.module.trade.controller.app.brokerage.vo.withdraw.AppBrokerageWithdrawRespVO; import cn.iocoder.yudao.module.trade.controller.app.brokerage.vo.withdraw.AppBrokerageWithdrawRespVO;
import cn.iocoder.yudao.module.trade.convert.brokerage.BrokerageWithdrawConvert; import cn.iocoder.yudao.module.trade.convert.brokerage.BrokerageWithdrawConvert;
import cn.iocoder.yudao.module.trade.dal.dataobject.brokerage.BrokerageWithdrawDO; import cn.iocoder.yudao.module.trade.dal.dataobject.brokerage.BrokerageWithdrawDO;
import cn.iocoder.yudao.module.trade.enums.brokerage.BrokerageWithdrawStatusEnum;
import cn.iocoder.yudao.module.trade.service.brokerage.BrokerageWithdrawService; import cn.iocoder.yudao.module.trade.service.brokerage.BrokerageWithdrawService;
import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.tags.Tag;
@ -19,7 +18,6 @@ import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource; import javax.annotation.Resource;
import javax.validation.Valid; import javax.validation.Valid;
import java.util.Map;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
import static cn.iocoder.yudao.framework.web.core.util.WebFrameworkUtils.getLoginUserId; import static cn.iocoder.yudao.framework.web.core.util.WebFrameworkUtils.getLoginUserId;
@ -44,10 +42,7 @@ public class AppBrokerageWithdrawController {
// 分页查询 // 分页查询
PageResult<BrokerageWithdrawDO> pageResult = brokerageWithdrawService.getBrokerageWithdrawPage( PageResult<BrokerageWithdrawDO> pageResult = brokerageWithdrawService.getBrokerageWithdrawPage(
BrokerageWithdrawConvert.INSTANCE.convert(pageReqVO, getLoginUserId())); BrokerageWithdrawConvert.INSTANCE.convert(pageReqVO, getLoginUserId()));
// 拼接信息 return success(BrokerageWithdrawConvert.INSTANCE.convertPage03(pageResult));
// TODO @疯狂后端可以直接用 DictFrameworkUtils.getDictDataLabel() 去渲染哈这样就不用 getDictDataLabelMap 方法了
Map<String, String> statusNameMap = dictDataApi.getDictDataLabelMap(BrokerageWithdrawStatusEnum.DICT_TYPE);
return success(BrokerageWithdrawConvert.INSTANCE.convertPage02(pageResult, statusNameMap));
} }
@PostMapping("/create") @PostMapping("/create")

View File

@ -3,6 +3,7 @@ package cn.iocoder.yudao.module.trade.controller.app.config;
import cn.hutool.core.util.ObjUtil; import cn.hutool.core.util.ObjUtil;
import cn.iocoder.yudao.framework.common.pojo.CommonResult; import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.module.trade.controller.app.config.vo.AppTradeConfigRespVO; import cn.iocoder.yudao.module.trade.controller.app.config.vo.AppTradeConfigRespVO;
import cn.iocoder.yudao.module.trade.convert.config.TradeConfigConvert;
import cn.iocoder.yudao.module.trade.dal.dataobject.config.TradeConfigDO; import cn.iocoder.yudao.module.trade.dal.dataobject.config.TradeConfigDO;
import cn.iocoder.yudao.module.trade.service.config.TradeConfigService; import cn.iocoder.yudao.module.trade.service.config.TradeConfigService;
import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Operation;
@ -33,13 +34,7 @@ public class AppTradeConfigController {
@Operation(summary = "获得交易配置") @Operation(summary = "获得交易配置")
public CommonResult<AppTradeConfigRespVO> getTradeConfig() { public CommonResult<AppTradeConfigRespVO> getTradeConfig() {
TradeConfigDO tradeConfig = ObjUtil.defaultIfNull(tradeConfigService.getTradeConfig(), new TradeConfigDO()); TradeConfigDO tradeConfig = ObjUtil.defaultIfNull(tradeConfigService.getTradeConfig(), new TradeConfigDO());
// TODO @疯狂是不是直接 convert 就好啦 return success(TradeConfigConvert.INSTANCE.convert02(tradeConfig));
AppTradeConfigRespVO respVO = new AppTradeConfigRespVO()
.setBrokeragePosterUrls(tradeConfig.getBrokeragePostUrls())
.setBrokerageFrozenDays(tradeConfig.getBrokerageFrozenDays())
.setBrokerageWithdrawMinPrice(tradeConfig.getBrokerageWithdrawMinPrice())
.setBrokerageWithdrawType(tradeConfig.getBrokerageWithdrawType());
return success(respVO);
} }
} }

View File

@ -4,6 +4,7 @@ import cn.hutool.core.math.Money;
import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil; import cn.hutool.core.util.StrUtil;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.number.MoneyUtils;
import cn.iocoder.yudao.module.member.api.user.dto.MemberUserRespDTO; import cn.iocoder.yudao.module.member.api.user.dto.MemberUserRespDTO;
import cn.iocoder.yudao.module.trade.controller.admin.brokerage.vo.record.BrokerageRecordPageReqVO; import cn.iocoder.yudao.module.trade.controller.admin.brokerage.vo.record.BrokerageRecordPageReqVO;
import cn.iocoder.yudao.module.trade.controller.admin.brokerage.vo.record.BrokerageRecordRespVO; import cn.iocoder.yudao.module.trade.controller.admin.brokerage.vo.record.BrokerageRecordRespVO;
@ -51,7 +52,7 @@ public interface BrokerageRecordConvert {
.setBizType(bizType.getType()).setBizId(bizId) .setBizType(bizType.getType()).setBizId(bizId)
.setPrice(brokeragePrice).setTotalPrice(user.getBrokeragePrice()) .setPrice(brokeragePrice).setTotalPrice(user.getBrokeragePrice())
.setTitle(title) .setTitle(title)
.setDescription(StrUtil.format(bizType.getDescription(), new Money(0, Math.abs(brokeragePrice)))) .setDescription(StrUtil.format(bizType.getDescription(), MoneyUtils.fenToYuanStr(Math.abs(brokeragePrice))))
.setStatus(status).setFrozenDays(brokerageFrozenDays).setUnfreezeTime(unfreezeTime) .setStatus(status).setFrozenDays(brokerageFrozenDays).setUnfreezeTime(unfreezeTime)
.setSourceUserLevel(sourceUserLevel).setSourceUserId(sourceUserId); .setSourceUserLevel(sourceUserLevel).setSourceUserId(sourceUserId);
} }

View File

@ -1,7 +1,7 @@
package cn.iocoder.yudao.module.trade.convert.brokerage; package cn.iocoder.yudao.module.trade.convert.brokerage;
import cn.hutool.core.map.MapUtil;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.dict.core.util.DictFrameworkUtils;
import cn.iocoder.yudao.module.member.api.user.dto.MemberUserRespDTO; import cn.iocoder.yudao.module.member.api.user.dto.MemberUserRespDTO;
import cn.iocoder.yudao.module.trade.controller.admin.brokerage.vo.withdraw.BrokerageWithdrawPageReqVO; import cn.iocoder.yudao.module.trade.controller.admin.brokerage.vo.withdraw.BrokerageWithdrawPageReqVO;
import cn.iocoder.yudao.module.trade.controller.admin.brokerage.vo.withdraw.BrokerageWithdrawRespVO; import cn.iocoder.yudao.module.trade.controller.admin.brokerage.vo.withdraw.BrokerageWithdrawRespVO;
@ -9,6 +9,7 @@ import cn.iocoder.yudao.module.trade.controller.app.brokerage.vo.withdraw.AppBro
import cn.iocoder.yudao.module.trade.controller.app.brokerage.vo.withdraw.AppBrokerageWithdrawPageReqVO; import cn.iocoder.yudao.module.trade.controller.app.brokerage.vo.withdraw.AppBrokerageWithdrawPageReqVO;
import cn.iocoder.yudao.module.trade.controller.app.brokerage.vo.withdraw.AppBrokerageWithdrawRespVO; import cn.iocoder.yudao.module.trade.controller.app.brokerage.vo.withdraw.AppBrokerageWithdrawRespVO;
import cn.iocoder.yudao.module.trade.dal.dataobject.brokerage.BrokerageWithdrawDO; import cn.iocoder.yudao.module.trade.dal.dataobject.brokerage.BrokerageWithdrawDO;
import cn.iocoder.yudao.module.trade.enums.DictTypeConstants;
import org.mapstruct.Mapper; import org.mapstruct.Mapper;
import org.mapstruct.factory.Mappers; import org.mapstruct.factory.Mappers;
@ -44,10 +45,10 @@ public interface BrokerageWithdrawConvert {
PageResult<AppBrokerageWithdrawRespVO> convertPage02(PageResult<BrokerageWithdrawDO> pageResult); PageResult<AppBrokerageWithdrawRespVO> convertPage02(PageResult<BrokerageWithdrawDO> pageResult);
default PageResult<AppBrokerageWithdrawRespVO> convertPage02(PageResult<BrokerageWithdrawDO> pageResult, Map<String, String> statusNameMap) { default PageResult<AppBrokerageWithdrawRespVO> convertPage03(PageResult<BrokerageWithdrawDO> pageResult) {
PageResult<AppBrokerageWithdrawRespVO> result = convertPage02(pageResult); PageResult<AppBrokerageWithdrawRespVO> result = convertPage02(pageResult);
for (AppBrokerageWithdrawRespVO vo : result.getList()) { for (AppBrokerageWithdrawRespVO vo : result.getList()) {
vo.setStatusName(MapUtil.getStr(statusNameMap, String.valueOf(vo.getStatus()), "")); vo.setStatusName(DictFrameworkUtils.getDictDataLabel(DictTypeConstants.BROKERAGE_WITHDRAW_STATUS, vo.getStatus()));
} }
return result; return result;
} }

View File

@ -2,6 +2,7 @@ package cn.iocoder.yudao.module.trade.convert.config;
import cn.iocoder.yudao.module.trade.controller.admin.config.vo.TradeConfigRespVO; import cn.iocoder.yudao.module.trade.controller.admin.config.vo.TradeConfigRespVO;
import cn.iocoder.yudao.module.trade.controller.admin.config.vo.TradeConfigSaveReqVO; import cn.iocoder.yudao.module.trade.controller.admin.config.vo.TradeConfigSaveReqVO;
import cn.iocoder.yudao.module.trade.controller.app.config.vo.AppTradeConfigRespVO;
import cn.iocoder.yudao.module.trade.dal.dataobject.config.TradeConfigDO; import cn.iocoder.yudao.module.trade.dal.dataobject.config.TradeConfigDO;
import org.mapstruct.Mapper; import org.mapstruct.Mapper;
import org.mapstruct.factory.Mappers; import org.mapstruct.factory.Mappers;
@ -20,4 +21,5 @@ public interface TradeConfigConvert {
TradeConfigRespVO convert(TradeConfigDO bean); TradeConfigRespVO convert(TradeConfigDO bean);
AppTradeConfigRespVO convert02(TradeConfigDO tradeConfig);
} }

View File

@ -1,7 +1,6 @@
package cn.iocoder.yudao.module.trade.service.brokerage; package cn.iocoder.yudao.module.trade.service.brokerage;
import cn.hutool.core.collection.CollUtil; import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.math.Money;
import cn.hutool.core.util.ArrayUtil; import cn.hutool.core.util.ArrayUtil;
import cn.hutool.core.util.BooleanUtil; import cn.hutool.core.util.BooleanUtil;
import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.ObjectUtil;
@ -240,7 +239,6 @@ public class BrokerageRecordServiceImpl implements BrokerageRecordService {
return new PageResult<>(pageResult.getRecords(), pageResult.getTotal()); return new PageResult<>(pageResult.getRecords(), pageResult.getTotal());
} }
// TODO @疯狂这个求出来应该是不准的例如说超过 100+ 名后
@Override @Override
public Integer getUserRankByPrice(Long userId, LocalDateTime[] times) { public Integer getUserRankByPrice(Long userId, LocalDateTime[] times) {
AppBrokerageUserRankPageReqVO pageParam = new AppBrokerageUserRankPageReqVO().setTimes(times); AppBrokerageUserRankPageReqVO pageParam = new AppBrokerageUserRankPageReqVO().setTimes(times);
@ -261,15 +259,14 @@ public class BrokerageRecordServiceImpl implements BrokerageRecordService {
int balance = Optional.of(user) int balance = Optional.of(user)
.map(BrokerageUserDO::getBrokeragePrice).orElse(0); .map(BrokerageUserDO::getBrokeragePrice).orElse(0);
if (balance + brokeragePrice < 0) { if (balance + brokeragePrice < 0) {
// TODO @疯狂要不 MoneyUtils 统一搞个 format 金额的方法然后把分到元的字符串统一收口掉 throw exception(BROKERAGE_WITHDRAW_USER_BALANCE_NOT_ENOUGH, MoneyUtils.fenToYuanStr(balance));
throw exception(BROKERAGE_WITHDRAW_USER_BALANCE_NOT_ENOUGH, new Money(0, balance));
} }
// 2. 更新佣金余额 // 2. 更新佣金余额
boolean success = brokerageUserService.updateUserPrice(userId, brokeragePrice); boolean success = brokerageUserService.updateUserPrice(userId, brokeragePrice);
if (!success) { if (!success) {
// 失败时则抛出异常只会出现扣减佣金时余额不足的情况 // 失败时则抛出异常只会出现扣减佣金时余额不足的情况
throw exception(BROKERAGE_WITHDRAW_USER_BALANCE_NOT_ENOUGH, new Money(0, balance)); throw exception(BROKERAGE_WITHDRAW_USER_BALANCE_NOT_ENOUGH, MoneyUtils.fenToYuanStr(balance));
} }
// 3. 新增记录 // 3. 新增记录

View File

@ -187,7 +187,7 @@ public class BrokerageUserServiceImpl implements BrokerageUserService {
/** /**
* 补全绑定用户的字段 * 补全绑定用户的字段
* *
* @param bindUserId 绑定的用户编号 * @param bindUserId 绑定的用户编号
* @param brokerageUser update 对象 * @param brokerageUser update 对象
* @return 补全后的 update 对象 * @return 补全后的 update 对象
*/ */
@ -261,12 +261,15 @@ public class BrokerageUserServiceImpl implements BrokerageUserService {
} }
// 下级不能绑定自己的上级 // 下级不能绑定自己的上级
// TODO @疯狂这里是不是查询不到的时候应该有个 break 结束循环哈
for (int i = 0; i <= Short.MAX_VALUE; i++) { for (int i = 0; i <= Short.MAX_VALUE; i++) {
if (Objects.equals(bindUser.getBindUserId(), user.getId())) { if (Objects.equals(bindUser.getBindUserId(), user.getId())) {
throw exception(BROKERAGE_BIND_LOOP); throw exception(BROKERAGE_BIND_LOOP);
} }
bindUser = getBrokerageUser(bindUser.getBindUserId()); bindUser = getBrokerageUser(bindUser.getBindUserId());
// 找到根节点结束循环
if (bindUser == null || bindUser.getBindUserId() == null) {
break;
}
} }
} }
@ -274,8 +277,8 @@ public class BrokerageUserServiceImpl implements BrokerageUserService {
* 根据绑定用户编号获得绑定用户编号列表 * 根据绑定用户编号获得绑定用户编号列表
* *
* @param bindUserId 绑定用户编号 * @param bindUserId 绑定用户编号
* @param level 绑定用户的层级 * @param level 绑定用户的层级
* 如果 level 为空则查询 1+2 两个层级 * 如果 level 为空则查询 1+2 两个层级
* @return 绑定用户编号列表 * @return 绑定用户编号列表
*/ */
private List<Long> buildBindUserIdsByLevel(Long bindUserId, Integer level) { private List<Long> buildBindUserIdsByLevel(Long bindUserId, Integer level) {

View File

@ -93,7 +93,7 @@ public class BrokerageWithdrawServiceImpl implements BrokerageWithdrawService {
// 4. 通知用户 // 4. 通知用户
Map<String, Object> templateParams = MapUtil.<String, Object>builder() Map<String, Object> templateParams = MapUtil.<String, Object>builder()
.put("createTime", LocalDateTimeUtil.formatNormal(withdraw.getCreateTime())) .put("createTime", LocalDateTimeUtil.formatNormal(withdraw.getCreateTime()))
.put("price", new Money(0, withdraw.getPrice()).toString()) .put("price", MoneyUtils.fenToYuanStr(withdraw.getPrice()))
.put("reason", withdraw.getAuditReason()) .put("reason", withdraw.getAuditReason())
.build(); .build();
NotifySendSingleToUserReqDTO reqDTO = new NotifySendSingleToUserReqDTO() NotifySendSingleToUserReqDTO reqDTO = new NotifySendSingleToUserReqDTO()
@ -170,7 +170,7 @@ public class BrokerageWithdrawServiceImpl implements BrokerageWithdrawService {
TradeConfigDO validateWithdrawPrice(Integer withdrawPrice) { TradeConfigDO validateWithdrawPrice(Integer withdrawPrice) {
TradeConfigDO tradeConfig = tradeConfigService.getTradeConfig(); TradeConfigDO tradeConfig = tradeConfigService.getTradeConfig();
if (tradeConfig.getBrokerageWithdrawMinPrice() != null && withdrawPrice < tradeConfig.getBrokerageWithdrawMinPrice()) { if (tradeConfig.getBrokerageWithdrawMinPrice() != null && withdrawPrice < tradeConfig.getBrokerageWithdrawMinPrice()) {
throw exception(BROKERAGE_WITHDRAW_MIN_PRICE, new Money(0, tradeConfig.getBrokerageWithdrawMinPrice())); throw exception(BROKERAGE_WITHDRAW_MIN_PRICE, MoneyUtils.fenToYuanStr(tradeConfig.getBrokerageWithdrawMinPrice()));
} }
return tradeConfig; return tradeConfig;
} }

View File

@ -3,6 +3,8 @@ package cn.iocoder.yudao.module.member.api.user.dto;
import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum; import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
import lombok.Data; import lombok.Data;
import java.time.LocalDateTime;
/** /**
* 用户信息 Response DTO * 用户信息 Response DTO
* *
@ -33,6 +35,10 @@ public class MemberUserRespDTO {
* 手机 * 手机
*/ */
private String mobile; private String mobile;
/**
* 创建时间
*/
private LocalDateTime createTime;
// ========== 其它信息 ========== // ========== 其它信息 ==========

View File

@ -3,8 +3,6 @@ package cn.iocoder.yudao.module.system.api.dict;
import cn.iocoder.yudao.module.system.api.dict.dto.DictDataRespDTO; import cn.iocoder.yudao.module.system.api.dict.dto.DictDataRespDTO;
import java.util.Collection; import java.util.Collection;
import java.util.List;
import java.util.Map;
/** /**
* 字典数据 API 接口 * 字典数据 API 接口
@ -19,40 +17,23 @@ public interface DictDataApi {
* 2. 字典数据被禁用 * 2. 字典数据被禁用
* *
* @param dictType 字典类型 * @param dictType 字典类型
* @param values 字典数据值的数组 * @param values 字典数据值的数组
*/ */
void validateDictDataList(String dictType, Collection<String> values); void validateDictDataList(String dictType, Collection<String> values);
/** /**
* 获得指定的字典数据从缓存中 * 获得指定的字典数据从缓存中
* *
* @param type 字典类型 * @param type 字典类型
* @param value 字典数据值 * @param value 字典数据值
* @return 字典数据 * @return 字典数据
*/ */
DictDataRespDTO getDictData(String type, String value); DictDataRespDTO getDictData(String type, String value);
/**
* 获得指定类型的字典数据从缓存中
*
* @param type 字典类型
* @return 字典数据
*/
List<DictDataRespDTO> getDictDataList(String type);
/**
* 获得指定类型的字典数据 标签字典从缓存中
* keyvalue, value: label
*
* @param type 字典类型
* @return 字典数据
*/
Map<String, String> getDictDataLabelMap(String type);
/** /**
* 解析获得指定的字典数据从缓存中 * 解析获得指定的字典数据从缓存中
* *
* @param type 字典类型 * @param type 字典类型
* @param label 字典数据标签 * @param label 字典数据标签
* @return 字典数据 * @return 字典数据
*/ */

View File

@ -1,7 +1,6 @@
package cn.iocoder.yudao.module.system.api.dict; package cn.iocoder.yudao.module.system.api.dict;
import cn.iocoder.yudao.module.system.api.dict.dto.DictDataRespDTO; import cn.iocoder.yudao.module.system.api.dict.dto.DictDataRespDTO;
import cn.iocoder.yudao.module.system.controller.admin.dict.vo.data.DictDataExportReqVO;
import cn.iocoder.yudao.module.system.convert.dict.DictDataConvert; import cn.iocoder.yudao.module.system.convert.dict.DictDataConvert;
import cn.iocoder.yudao.module.system.dal.dataobject.dict.DictDataDO; import cn.iocoder.yudao.module.system.dal.dataobject.dict.DictDataDO;
import cn.iocoder.yudao.module.system.service.dict.DictDataService; import cn.iocoder.yudao.module.system.service.dict.DictDataService;
@ -9,10 +8,6 @@ import org.springframework.stereotype.Service;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.util.Collection; import java.util.Collection;
import java.util.List;
import java.util.Map;
import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertMap;
/** /**
* 字典数据 API 实现类 * 字典数据 API 实现类
@ -36,19 +31,6 @@ public class DictDataApiImpl implements DictDataApi {
return DictDataConvert.INSTANCE.convert02(dictData); return DictDataConvert.INSTANCE.convert02(dictData);
} }
@Override
public List<DictDataRespDTO> getDictDataList(String type) {
// TODO @疯狂不用 DictDataExportReqVO 可以考虑直接加个允许传递 type 传递的
List<DictDataDO> list = dictDataService.getDictDataList(new DictDataExportReqVO().setDictType(type));
return DictDataConvert.INSTANCE.convertList04(list);
}
@Override
public Map<String, String> getDictDataLabelMap(String type) {
List<DictDataDO> list = dictDataService.getDictDataList(new DictDataExportReqVO().setDictType(type));
return convertMap(list, DictDataDO::getValue, DictDataDO::getLabel);
}
@Override @Override
public DictDataRespDTO parseDictData(String dictType, String label) { public DictDataRespDTO parseDictData(String dictType, String label) {
DictDataDO dictData = dictDataService.parseDictData(dictType, label); DictDataDO dictData = dictDataService.parseDictData(dictType, label);

View File

@ -1,17 +1,17 @@
package cn.iocoder.yudao.module.system.controller.app.dict; package cn.iocoder.yudao.module.system.controller.app.dict;
import cn.iocoder.yudao.framework.common.pojo.CommonResult; import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.module.system.controller.admin.dict.vo.data.DictDataExportReqVO;
import cn.iocoder.yudao.module.system.controller.app.dict.vo.AppDictDataRespVO; import cn.iocoder.yudao.module.system.controller.app.dict.vo.AppDictDataRespVO;
import cn.iocoder.yudao.module.system.convert.dict.DictDataConvert; import cn.iocoder.yudao.module.system.convert.dict.DictDataConvert;
import cn.iocoder.yudao.module.system.dal.dataobject.dict.DictDataDO; import cn.iocoder.yudao.module.system.dal.dataobject.dict.DictDataDO;
import cn.iocoder.yudao.module.system.service.dict.DictDataService; import cn.iocoder.yudao.module.system.service.dict.DictDataService;
import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.validation.annotation.Validated; import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController; import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource; import javax.annotation.Resource;
@ -28,11 +28,11 @@ public class AppDictDataController {
@Resource @Resource
private DictDataService dictDataService; private DictDataService dictDataService;
// TODO @疯狂暂时不用 path 参数哈主要考虑一些中间件支持的一般例如说链路追踪之类的还是作为一个参数噶 @GetMapping("/type")
@GetMapping("/type/{dictType}")
@Operation(summary = "根据字典类型查询字典数据信息") @Operation(summary = "根据字典类型查询字典数据信息")
public CommonResult<List<AppDictDataRespVO>> getDictDataList(@PathVariable String dictType) { @Parameter(name = "type", description = "字典类型", required = true, example = "common_status")
List<DictDataDO> list = dictDataService.getDictDataList(new DictDataExportReqVO().setDictType(dictType)); public CommonResult<List<AppDictDataRespVO>> getDictDataListByType(@RequestParam String type) {
List<DictDataDO> list = dictDataService.getEnabledDictDataListByType(type);
return success(DictDataConvert.INSTANCE.convertList03(list)); return success(DictDataConvert.INSTANCE.convertList03(list));
} }

View File

@ -1,22 +1,41 @@
package cn.iocoder.yudao.module.system.controller.app.dict.vo; package cn.iocoder.yudao.module.system.controller.app.dict.vo;
import cn.iocoder.yudao.module.system.controller.admin.dict.vo.data.DictDataBaseVO;
import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.media.Schema;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.Data; import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;
@Schema(description = "用户 App - 字典数据信息 Response VO") @Schema(description = "用户 App - 字典数据信息 Response VO")
@Data @Data
@NoArgsConstructor @NoArgsConstructor
@AllArgsConstructor @AllArgsConstructor
@EqualsAndHashCode(callSuper = true) public class AppDictDataRespVO {
public class AppDictDataRespVO extends DictDataBaseVO {
// TODO @疯狂app 的接口不集成 admin 接口的 vo 看看是不是只返回必要的字段类似 remarksort 不好返回的哈
@Schema(description = "字典数据编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024") @Schema(description = "字典数据编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024")
private Long id; private Long id;
@Schema(description = "字典标签", requiredMode = Schema.RequiredMode.REQUIRED, example = "芋道")
@NotBlank(message = "字典标签不能为空")
@Size(max = 100, message = "字典标签长度不能超过100个字符")
private String label;
@Schema(description = "字典值", requiredMode = Schema.RequiredMode.REQUIRED, example = "iocoder")
@NotBlank(message = "字典键值不能为空")
@Size(max = 100, message = "字典键值长度不能超过100个字符")
private String value;
@Schema(description = "字典类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "sys_common_sex")
@NotBlank(message = "字典类型不能为空")
@Size(max = 100, message = "字典类型长度不能超过100个字符")
private String dictType;
@Schema(description = "颜色类型,default、primary、success、info、warning、danger", example = "default")
private String colorType;
@Schema(description = "css 样式", example = "btn-visible")
private String cssClass;
} }

View File

@ -48,4 +48,8 @@ public interface DictDataMapper extends BaseMapperX<DictDataDO> {
.eqIfPresent(DictDataDO::getStatus, reqVO.getStatus())); .eqIfPresent(DictDataDO::getStatus, reqVO.getStatus()));
} }
default List<DictDataDO> selectListByTypeAndStatus(String dictType, Integer status) {
return selectList(new LambdaQueryWrapper<DictDataDO>()
.eq(DictDataDO::getDictType, dictType).eq(DictDataDO::getStatus, status));
}
} }

View File

@ -62,6 +62,14 @@ public interface DictDataService {
*/ */
List<DictDataDO> getDictDataList(DictDataExportReqVO reqVO); List<DictDataDO> getDictDataList(DictDataExportReqVO reqVO);
/**
* 获得字典数据列表
*
* @param dictType 字典类型
* @return 字典数据列表
*/
List<DictDataDO> getEnabledDictDataListByType(String dictType);
/** /**
* 获得字典数据详情 * 获得字典数据详情
* *
@ -84,7 +92,7 @@ public interface DictDataService {
* 2. 字典数据被禁用 * 2. 字典数据被禁用
* *
* @param dictType 字典类型 * @param dictType 字典类型
* @param values 字典数据值的数组 * @param values 字典数据值的数组
*/ */
void validateDictDataList(String dictType, Collection<String> values); void validateDictDataList(String dictType, Collection<String> values);
@ -92,7 +100,7 @@ public interface DictDataService {
* 获得指定的字典数据 * 获得指定的字典数据
* *
* @param dictType 字典类型 * @param dictType 字典类型
* @param value 字典数据值 * @param value 字典数据值
* @return 字典数据 * @return 字典数据
*/ */
DictDataDO getDictData(String dictType, String value); DictDataDO getDictData(String dictType, String value);
@ -101,7 +109,7 @@ public interface DictDataService {
* 解析获得指定的字典数据从缓存中 * 解析获得指定的字典数据从缓存中
* *
* @param dictType 字典类型 * @param dictType 字典类型
* @param label 字典数据标签 * @param label 字典数据标签
* @return 字典数据 * @return 字典数据
*/ */
DictDataDO parseDictData(String dictType, String label); DictDataDO parseDictData(String dictType, String label);

View File

@ -66,6 +66,13 @@ public class DictDataServiceImpl implements DictDataService {
return list; return list;
} }
@Override
public List<DictDataDO> getEnabledDictDataListByType(String dictType) {
List<DictDataDO> list = dictDataMapper.selectListByTypeAndStatus(dictType, CommonStatusEnum.ENABLE.getStatus());
list.sort(COMPARATOR_TYPE_AND_SORT);
return list;
}
@Override @Override
public DictDataDO getDictData(Long id) { public DictDataDO getDictData(Long id) {
return dictDataMapper.selectById(id); return dictDataMapper.selectById(id);