Compare commits

...

2 Commits

Author SHA1 Message Date
5a5af706e5 feat: 优化 2026-03-07 15:52:56 +08:00
09b7862971 feat: 优化 2026-03-07 15:49:46 +08:00
24 changed files with 311 additions and 226 deletions

View File

@@ -49,4 +49,7 @@ public interface ErrorCodeConstants {
ErrorCode POINTS_PENDING_NOT_FOUND = new ErrorCode(1_030_003_004, "预扣记录不存在");
ErrorCode POINTS_PENDING_ALREADY_CONFIRMED = new ErrorCode(1_030_003_005, "预扣记录已确认或已取消");
// ========== TikToken相关错误码 1-030-004-000 ==========
ErrorCode TIK_TOKEN_NOT_EXISTS = new ErrorCode(1_030_004_001, "TikToken不存在");
}

View File

@@ -1,7 +1,6 @@
package cn.iocoder.yudao.module.tik.muye.aimodelconfig.dal;
import lombok.*;
import java.math.BigDecimal;
import com.baomidou.mybatisplus.annotation.*;
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
@@ -45,18 +44,6 @@ public class AiModelConfigDO extends BaseDO {
* 状态(0-禁用 1-启用)
*/
private Integer status;
/**
* 温度参数
*/
private BigDecimal temperature;
/**
* 回复数Token数
*/
private Integer maxTokens;
/**
* 每日请求次数
*/
private Integer dailyLimit;
/**
* 模型类型(image-图像 text-文本 video-视频 audio-音频)
*/
@@ -65,22 +52,6 @@ public class AiModelConfigDO extends BaseDO {
* 消耗积分
*/
private Integer consumePoints;
/**
* 最大文本数量
*/
private Integer maxTextLength;
/**
* 图片最大像素
*/
private String maxImageSize;
/**
* 视频最大时长(秒)
*/
private Integer maxVideoDuration;
/**
* 视频最大质量
*/
private String maxVideoQuality;
/**
* 备注
*/

View File

@@ -25,15 +25,8 @@ public interface AiModelConfigMapper extends BaseMapperX<AiModelConfigDO> {
.eqIfPresent(AiModelConfigDO::getPlatform, reqVO.getPlatform())
.eqIfPresent(AiModelConfigDO::getApiKey, reqVO.getApiKey())
.eqIfPresent(AiModelConfigDO::getStatus, reqVO.getStatus())
.eqIfPresent(AiModelConfigDO::getTemperature, reqVO.getTemperature())
.eqIfPresent(AiModelConfigDO::getMaxTokens, reqVO.getMaxTokens())
.eqIfPresent(AiModelConfigDO::getDailyLimit, reqVO.getDailyLimit())
.eqIfPresent(AiModelConfigDO::getModelType, reqVO.getModelType())
.eqIfPresent(AiModelConfigDO::getConsumePoints, reqVO.getConsumePoints())
.eqIfPresent(AiModelConfigDO::getMaxTextLength, reqVO.getMaxTextLength())
.eqIfPresent(AiModelConfigDO::getMaxImageSize, reqVO.getMaxImageSize())
.eqIfPresent(AiModelConfigDO::getMaxVideoDuration, reqVO.getMaxVideoDuration())
.eqIfPresent(AiModelConfigDO::getMaxVideoQuality, reqVO.getMaxVideoQuality())
.eqIfPresent(AiModelConfigDO::getRemark, reqVO.getRemark())
.betweenIfPresent(AiModelConfigDO::getCreateTime, reqVO.getCreateTime())
.orderByDesc(AiModelConfigDO::getId));

View File

@@ -1,10 +1,8 @@
package cn.iocoder.yudao.module.tik.muye.aimodelconfig.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import cn.iocoder.yudao.framework.common.pojo.PageParam;
import java.math.BigDecimal;
import cn.iocoder.yudao.framework.common.pojo.SortablePageParam;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
@@ -12,7 +10,8 @@ import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_
@Schema(description = "管理后台 - AI模型配置分页 Request VO")
@Data
public class AiModelConfigPageReqVO extends PageParam {
@EqualsAndHashCode(callSuper = true)
public class AiModelConfigPageReqVO extends SortablePageParam {
@Schema(description = "模型名称", example = "李四")
private String modelName;
@@ -29,33 +28,12 @@ public class AiModelConfigPageReqVO extends PageParam {
@Schema(description = "状态(0-禁用 1-启用)", example = "2")
private Integer status;
@Schema(description = "温度参数")
private BigDecimal temperature;
@Schema(description = "回复数Token数")
private Integer maxTokens;
@Schema(description = "每日请求次数")
private Integer dailyLimit;
@Schema(description = "模型类型(image-图像 text-文本 video-视频 audio-音频)", example = "2")
private String modelType;
@Schema(description = "消耗积分")
private Integer consumePoints;
@Schema(description = "最大文本数量")
private Integer maxTextLength;
@Schema(description = "图片最大像素")
private String maxImageSize;
@Schema(description = "视频最大时长(秒)")
private Integer maxVideoDuration;
@Schema(description = "视频最大质量")
private String maxVideoQuality;
@Schema(description = "备注", example = "随便")
private String remark;

View File

@@ -2,9 +2,6 @@ package cn.iocoder.yudao.module.tik.muye.aimodelconfig.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import java.math.BigDecimal;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import cn.idev.excel.annotation.*;
@@ -37,18 +34,6 @@ public class AiModelConfigRespVO {
@ExcelProperty("状态(0-禁用 1-启用)")
private Integer status;
@Schema(description = "温度参数", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("温度参数")
private BigDecimal temperature;
@Schema(description = "回复数Token数", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("回复数Token数")
private Integer maxTokens;
@Schema(description = "每日请求次数", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("每日请求次数")
private Integer dailyLimit;
@Schema(description = "模型类型(image-图像 text-文本 video-视频 audio-音频)", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@ExcelProperty("模型类型(image-图像 text-文本 video-视频 audio-音频)")
private String modelType;
@@ -57,22 +42,6 @@ public class AiModelConfigRespVO {
@ExcelProperty("消耗积分")
private Integer consumePoints;
@Schema(description = "最大文本数量", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("最大文本数量")
private Integer maxTextLength;
@Schema(description = "图片最大像素", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("图片最大像素")
private String maxImageSize;
@Schema(description = "视频最大时长(秒)", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("视频最大时长(秒)")
private Integer maxVideoDuration;
@Schema(description = "视频最大质量", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty("视频最大质量")
private String maxVideoQuality;
@Schema(description = "备注", requiredMode = Schema.RequiredMode.REQUIRED, example = "随便")
@ExcelProperty("备注")
private String remark;

View File

@@ -2,9 +2,7 @@ package cn.iocoder.yudao.module.tik.muye.aimodelconfig.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import jakarta.validation.constraints.*;
import java.math.BigDecimal;
@Schema(description = "管理后台 - AI模型配置新增/修改 Request VO")
@Data
@@ -29,43 +27,18 @@ public class AiModelConfigSaveReqVO {
private String apiKey;
@Schema(description = "状态(0-禁用 1-启用)", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@NotNull(message = "状态(0-禁用 1-启用)不能为空")
@NotNull(message = "状态不能为空")
private Integer status;
@Schema(description = "温度参数", requiredMode = Schema.RequiredMode.REQUIRED)
@NotNull(message = "温度参数不能为空")
private BigDecimal temperature;
@Schema(description = "回复数Token数", requiredMode = Schema.RequiredMode.REQUIRED)
@NotNull(message = "回复数Token数不能为空")
private Integer maxTokens;
@Schema(description = "每日请求次数", requiredMode = Schema.RequiredMode.REQUIRED)
@NotNull(message = "每日请求次数不能为空")
private Integer dailyLimit;
@Schema(description = "模型类型(image-图像 text-文本 video-视频 audio-音频)", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@NotEmpty(message = "模型类型(image-图像 text-文本 video-视频 audio-音频)不能为空")
@NotEmpty(message = "模型类型不能为空")
private String modelType;
@Schema(description = "消耗积分", requiredMode = Schema.RequiredMode.REQUIRED)
@NotNull(message = "消耗积分不能为空")
private Integer consumePoints;
@Schema(description = "最大文本数量")
private Integer maxTextLength;
@Schema(description = "图片最大像素")
private String maxImageSize;
@Schema(description = "视频最大时长(秒)")
private Integer maxVideoDuration;
@Schema(description = "视频最大质量")
private String maxVideoQuality;
@Schema(description = "备注", requiredMode = Schema.RequiredMode.REQUIRED, example = "随便")
@NotEmpty(message = "备注不能为空")
@Schema(description = "备注", example = "随便")
private String remark;
}

View File

@@ -1,5 +1,7 @@
package cn.iocoder.yudao.module.tik.muye.points.service;
import cn.iocoder.yudao.module.member.dal.dataobject.user.MemberUserDO;
import cn.iocoder.yudao.module.member.service.user.MemberUserService;
import cn.iocoder.yudao.module.tik.muye.aimodelconfig.dal.AiModelConfigDO;
import cn.iocoder.yudao.module.tik.muye.aimodelconfig.mapper.AiModelConfigMapper;
import cn.iocoder.yudao.module.tik.muye.memberuserprofile.dal.MemberUserProfileDO;
@@ -43,6 +45,9 @@ public class PointsServiceImpl implements PointsService {
@Resource
private PointRecordMapper pointRecordMapper;
@Resource
private MemberUserService memberUserService;
@Override
public AiModelConfigDO getConfig(String platform, String modelCode) {
AiModelConfigDO config = aiModelConfigMapper.selectByPlatformAndModelCode(platform, modelCode);
@@ -72,9 +77,14 @@ public class PointsServiceImpl implements PointsService {
// 2. 查询扣减后余额
MemberUserProfileDO profile = memberUserProfileMapper.selectByUserId(userId);
// 2.1 获取用户手机号
MemberUserDO user = memberUserService.getUser(Long.parseLong(userId));
String mobile = user != null ? user.getMobile() : "";
// 3. 创建积分记录(已确认状态)
PointRecordDO record = PointRecordDO.builder()
.userId(Long.parseLong(userId))
.mobile(mobile)
.type("decrease")
.pointAmount(-points)
.balance(profile.getRemainingPoints())
@@ -98,9 +108,14 @@ public class PointsServiceImpl implements PointsService {
// 2. 查询当前余额
MemberUserProfileDO profile = memberUserProfileMapper.selectByUserId(userId);
// 2.1 获取用户手机号
MemberUserDO user = memberUserService.getUser(Long.parseLong(userId));
String mobile = user != null ? user.getMobile() : "";
// 3. 创建预扣记录(待确认状态)
PointRecordDO record = PointRecordDO.builder()
.userId(Long.parseLong(userId))
.mobile(mobile)
.type("decrease")
.pointAmount(-points)
.balance(profile.getRemainingPoints())

View File

@@ -0,0 +1,68 @@
package cn.iocoder.yudao.module.tik.tikhup.controller;
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.tik.tikhup.service.TikTokenService;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenPageReqVO;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenSaveReqVO;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenVO;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
import jakarta.annotation.Resource;
import jakarta.validation.Valid;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
@Tag(name = "管理后台 - TikToken 管理")
@RestController
@RequestMapping("/admin-api/tik/token")
@Validated
public class TikTokenAdminController {
@Resource
private TikTokenService tikTokenService;
@PostMapping("/create")
@Operation(summary = "创建TikToken")
@PreAuthorize("@ss.hasPermission('tik:token:create')")
public CommonResult<Long> create(@Valid @RequestBody TikTokenSaveReqVO reqVO) {
return success(tikTokenService.create(reqVO));
}
@PutMapping("/update")
@Operation(summary = "更新TikToken")
@PreAuthorize("@ss.hasPermission('tik:token:update')")
public CommonResult<Boolean> update(@Valid @RequestBody TikTokenSaveReqVO reqVO) {
tikTokenService.update(reqVO);
return success(true);
}
@DeleteMapping("/delete")
@Operation(summary = "删除TikToken")
@Parameter(name = "id", description = "编号", required = true)
@PreAuthorize("@ss.hasPermission('tik:token:delete')")
public CommonResult<Boolean> delete(@RequestParam("id") Long id) {
tikTokenService.delete(id);
return success(true);
}
@GetMapping("/get")
@Operation(summary = "获取TikToken详情")
@Parameter(name = "id", description = "编号", required = true)
@PreAuthorize("@ss.hasPermission('tik:token:query')")
public CommonResult<TikTokenVO> get(@RequestParam("id") Long id) {
return success(tikTokenService.get(id));
}
@GetMapping("/page")
@Operation(summary = "分页查询TikToken列表")
@PreAuthorize("@ss.hasPermission('tik:token:query')")
public CommonResult<PageResult<TikTokenVO>> getPage(@Valid TikTokenPageReqVO reqVO) {
return success(tikTokenService.getPage(reqVO));
}
}

View File

@@ -1,6 +1,9 @@
package cn.iocoder.yudao.module.tik.tikhup.mapper;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenPageReqVO;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenVO;
import org.apache.ibatis.annotations.Mapper;
@@ -15,4 +18,12 @@ public interface TikTokenMapper extends BaseMapperX<TikTokenVO> {
return selectOne("interface_type",interfaceType);
}
default PageResult<TikTokenVO> selectPage(TikTokenPageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<TikTokenVO>()
.likeIfPresent(TikTokenVO::getPlatformUrl, reqVO.getPlatformUrl())
.eqIfPresent(TikTokenVO::getInterfaceType, reqVO.getInterfaceType())
.likeIfPresent(TikTokenVO::getInterfaceDesc, reqVO.getInterfaceDesc())
.orderByDesc(TikTokenVO::getId));
}
}

View File

@@ -0,0 +1,39 @@
package cn.iocoder.yudao.module.tik.tikhup.service;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenPageReqVO;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenSaveReqVO;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenVO;
import jakarta.validation.Valid;
/**
* TikToken 管理Service接口
*/
public interface TikTokenService {
/**
* 分页查询TikToken列表
*/
PageResult<TikTokenVO> getPage(TikTokenPageReqVO reqVO);
/**
* 创建TikToken
*/
Long create(@Valid TikTokenSaveReqVO reqVO);
/**
* 更新TikToken
*/
void update(@Valid TikTokenSaveReqVO reqVO);
/**
* 删除TikToken
*/
void delete(Long id);
/**
* 获取TikToken详情
*/
TikTokenVO get(Long id);
}

View File

@@ -0,0 +1,62 @@
package cn.iocoder.yudao.module.tik.tikhup.service;
import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
import cn.iocoder.yudao.module.tik.tikhup.mapper.TikTokenMapper;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenPageReqVO;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenSaveReqVO;
import cn.iocoder.yudao.module.tik.tikhup.vo.TikTokenVO;
import jakarta.annotation.Resource;
import org.springframework.stereotype.Service;
import org.springframework.validation.annotation.Validated;
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.iocoder.yudao.module.tik.enums.ErrorCodeConstants.TIK_TOKEN_NOT_EXISTS;
/**
* TikToken 管理Service实现类
*/
@Service
@Validated
public class TikTokenServiceImpl implements TikTokenService {
@Resource
private TikTokenMapper tikTokenMapper;
@Override
public PageResult<TikTokenVO> getPage(TikTokenPageReqVO reqVO) {
return tikTokenMapper.selectPage(reqVO);
}
@Override
public Long create(TikTokenSaveReqVO reqVO) {
TikTokenVO token = BeanUtils.toBean(reqVO, TikTokenVO.class);
tikTokenMapper.insert(token);
return token.getId();
}
@Override
public void update(TikTokenSaveReqVO reqVO) {
validateExists(reqVO.getId());
TikTokenVO token = BeanUtils.toBean(reqVO, TikTokenVO.class);
tikTokenMapper.updateById(token);
}
@Override
public void delete(Long id) {
validateExists(id);
tikTokenMapper.deleteById(id);
}
@Override
public TikTokenVO get(Long id) {
return tikTokenMapper.selectById(id);
}
private void validateExists(Long id) {
if (tikTokenMapper.selectById(id) == null) {
throw exception(TIK_TOKEN_NOT_EXISTS);
}
}
}

View File

@@ -0,0 +1,22 @@
package cn.iocoder.yudao.module.tik.tikhup.vo;
import cn.iocoder.yudao.framework.common.pojo.SortablePageParam;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import lombok.EqualsAndHashCode;
@Schema(description = "管理后台 - TikToken 分页 Request VO")
@Data
@EqualsAndHashCode(callSuper = true)
public class TikTokenPageReqVO extends SortablePageParam {
@Schema(description = "平台URL", example = "https://api.tikhub.io")
private String platformUrl;
@Schema(description = "接口类型", example = "crawler")
private String interfaceType;
@Schema(description = "接口描述", example = "抖音视频爬虫接口")
private String interfaceDesc;
}

View File

@@ -0,0 +1,25 @@
package cn.iocoder.yudao.module.tik.tikhup.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.constraints.NotEmpty;
import lombok.Data;
@Schema(description = "管理后台 - TikToken 创建/更新 Request VO")
@Data
public class TikTokenSaveReqVO {
@Schema(description = "编号", example = "1")
private Long id;
@Schema(description = "平台URL", requiredMode = Schema.RequiredMode.REQUIRED, example = "https://api.tikhub.io")
@NotEmpty(message = "平台URL不能为空")
private String platformUrl;
@Schema(description = "接口类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "crawler")
@NotEmpty(message = "接口类型不能为空")
private String interfaceType;
@Schema(description = "接口描述", example = "抖音视频爬虫接口")
private String interfaceDesc;
}

View File

@@ -17,10 +17,10 @@ public class TikTokenVO extends TenantBaseDO {
@TableField(value = "platform_url")
private String platformUrl;
@TableField(value = "platform_token")
private String platformToken;
@TableField(value = "interface_type")
private String interfaceType;
@TableField(value = "interface_desc")
private String interfaceDesc;
}

View File

@@ -1,25 +1,17 @@
import request from '@/config/axios'
import type { Dayjs } from 'dayjs';
/** AI模型配置信息 */
export interface AiModelConfig {
id: number; // 主键
modelName?: string; // 模型名称
modelCode?: string; // 模型标识/编码
platform?: string; // 所属平台
apiKey?: string; // API秘钥
status?: number; // 状态(0-禁用 1-启用)
temperature?: number; // 温度参数
maxTokens?: number; // 回复数Token数
dailyLimit?: number; // 每日请求次数
modelType?: string; // 模型类型(image-图像 text-文本 video-视频 audio-音频)
consumePoints?: number; // 消耗积分
maxTextLength?: number; // 最大文本数量
maxImageSize?: string; // 图片最大像素
maxVideoDuration?: number; // 视频最大时长(秒)
maxVideoQuality?: string; // 视频最大质量
remark?: string; // 备注
}
id: number // 主键
modelName?: string // 模型名称
modelCode?: string // 模型标识/编码
platform?: string // 所属平台
apiKey?: string // API秘钥
status?: number // 状态(0-禁用 1-启用)
modelType?: string // 模型类型(image-图像 text-文本 video-视频 audio-音频)
consumePoints?: number // 消耗积分
remark?: string // 备注
}
// AI模型配置 API
export const AiModelConfigApi = {

View File

@@ -1,12 +1,12 @@
import request from '@/config/axios'
import type { Dayjs } from 'dayjs';
/** tikhup管理信息 */
export interface Token {
platformUrl?: string; // 平台URL
platformToken?: string; // 平台Token
id: number; // 主键ID
}
platformUrl?: string; // 平台URL
interfaceType?: string; // 接口类型
interfaceDesc?: string; // 接口描述
id: number; // 主键ID
}
// tikhup管理 API
export const TokenApi = {

View File

@@ -25,15 +25,6 @@
<el-radio value="0">禁用</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="温度参数" prop="temperature">
<el-input v-model="formData.temperature" placeholder="请输入温度参数" />
</el-form-item>
<el-form-item label="回复数Token数" prop="maxTokens">
<el-input v-model="formData.maxTokens" placeholder="请输入回复数Token数" />
</el-form-item>
<el-form-item label="每日请求次数" prop="dailyLimit">
<el-input v-model="formData.dailyLimit" placeholder="请输入每日请求次数" />
</el-form-item>
<el-form-item label="模型类型" prop="modelType">
<el-radio-group v-model="formData.modelType">
<el-radio value="image">图像</el-radio>
@@ -46,18 +37,6 @@
<el-form-item label="消耗积分" prop="consumePoints">
<el-input v-model="formData.consumePoints" placeholder="请输入消耗积分" />
</el-form-item>
<el-form-item label="最大文本数量" prop="maxTextLength">
<el-input v-model="formData.maxTextLength" placeholder="请输入最大文本数量" />
</el-form-item>
<el-form-item label="图片最大像素" prop="maxImageSize">
<el-input v-model="formData.maxImageSize" placeholder="请输入图片最大像素" />
</el-form-item>
<el-form-item label="视频最大时长(秒)" prop="maxVideoDuration">
<el-input v-model="formData.maxVideoDuration" placeholder="请输入视频最大时长(秒)" />
</el-form-item>
<el-form-item label="视频最大质量" prop="maxVideoQuality">
<el-input v-model="formData.maxVideoQuality" placeholder="请输入视频最大质量" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="formData.remark" placeholder="请输入备注" />
</el-form-item>
@@ -88,15 +67,8 @@ const formData = ref({
platform: undefined,
apiKey: undefined,
status: undefined,
temperature: undefined,
maxTokens: undefined,
dailyLimit: undefined,
modelType: undefined,
consumePoints: undefined,
maxTextLength: undefined,
maxImageSize: undefined,
maxVideoDuration: undefined,
maxVideoQuality: undefined,
remark: undefined,
})
const formRules = reactive({
@@ -104,9 +76,6 @@ const formRules = reactive({
modelCode: [{ required: true, message: '模型标识/编码不能为空', trigger: 'blur' }],
platform: [{ required: true, message: '所属平台不能为空', trigger: 'blur' }],
status: [{ required: true, message: '状态不能为空', trigger: 'blur' }],
temperature: [{ required: true, message: '温度参数不能为空', trigger: 'blur' }],
maxTokens: [{ required: true, message: '回复数Token数不能为空', trigger: 'blur' }],
dailyLimit: [{ required: true, message: '每日请求次数不能为空', trigger: 'blur' }],
modelType: [{ required: true, message: '模型类型不能为空', trigger: 'change' }],
consumePoints: [{ required: true, message: '消耗积分不能为空', trigger: 'blur' }],
remark: [{ required: true, message: '备注不能为空', trigger: 'blur' }],
@@ -164,15 +133,8 @@ const resetForm = () => {
platform: undefined,
apiKey: undefined,
status: undefined,
temperature: undefined,
maxTokens: undefined,
dailyLimit: undefined,
modelType: undefined,
consumePoints: undefined,
maxTextLength: undefined,
maxImageSize: undefined,
maxVideoDuration: undefined,
maxVideoQuality: undefined,
remark: undefined,
}
formRef.value?.resetFields()

View File

@@ -118,15 +118,8 @@
</el-tag>
</template>
</el-table-column>
<el-table-column label="温度参数" align="center" prop="temperature" />
<el-table-column label="回复数Token数" align="center" prop="maxTokens" />
<el-table-column label="每日请求次数" align="center" prop="dailyLimit" />
<el-table-column label="模型类型" align="center" prop="modelType" />
<el-table-column label="消耗积分" align="center" prop="consumePoints" />
<el-table-column label="最大文本数量" align="center" prop="maxTextLength" />
<el-table-column label="图片最大像素" align="center" prop="maxImageSize" />
<el-table-column label="视频最大时长(秒)" align="center" prop="maxVideoDuration" />
<el-table-column label="视频最大质量" align="center" prop="maxVideoQuality" />
<el-table-column label="备注" align="center" prop="remark" />
<el-table-column label="操作" align="center" min-width="120px">
<template #default="scope">

View File

@@ -13,14 +13,14 @@
<el-form-item label="手机号" prop="mobile">
<el-input v-model="formData.mobile" placeholder="请输入手机号" />
</el-form-item>
<el-form-item label="变动类型(increase-增加 decrease-减少)" prop="type">
<el-form-item label="变动类型" prop="type">
<el-radio-group v-model="formData.type">
<el-radio value="increase">增加</el-radio>
<el-radio value="decrease">减少</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="变动积分数量(正数为增加,负数为减少)" prop="pointAmount">
<el-input v-model="formData.pointAmount" placeholder="请输入变动积分数量(正数为增加,负数为减少)" />
<el-form-item label="变动积分数量" prop="pointAmount">
<el-input v-model="formData.pointAmount" placeholder="正数为增加,负数为减少" />
</el-form-item>
<el-form-item label="变动后余额" prop="balance">
<el-input v-model="formData.balance" placeholder="请输入变动后余额" />
@@ -28,7 +28,7 @@
<el-form-item label="变动原因" prop="reason">
<el-input v-model="formData.reason" placeholder="请输入变动原因" />
</el-form-item>
<el-form-item label="业务类型(signin-签到 recharge-充值 exchange-兑换 admin-后台调整 gift-礼包赠送)" prop="bizType">
<el-form-item label="业务类型" prop="bizType">
<el-radio-group v-model="formData.bizType">
<el-radio value="signin">签到</el-radio>
<el-radio value="recharge">充值</el-radio>
@@ -78,11 +78,11 @@ const formData = ref({
const formRules = reactive({
userId: [{ required: true, message: '用户编号不能为空', trigger: 'blur' }],
mobile: [{ required: true, message: '手机号不能为空', trigger: 'blur' }],
type: [{ required: true, message: '变动类型(increase-增加 decrease-减少)不能为空', trigger: 'change' }],
pointAmount: [{ required: true, message: '变动积分数量(正数为增加,负数为减少)不能为空', trigger: 'blur' }],
type: [{ required: true, message: '变动类型不能为空', trigger: 'change' }],
pointAmount: [{ required: true, message: '变动积分数量不能为空', trigger: 'blur' }],
balance: [{ required: true, message: '变动后余额不能为空', trigger: 'blur' }],
reason: [{ required: true, message: '变动原因不能为空', trigger: 'blur' }],
bizType: [{ required: true, message: '业务类型(signin-签到 recharge-充值 exchange-兑换 admin-后台调整 gift-礼包赠送)不能为空', trigger: 'change' }],
bizType: [{ required: true, message: '业务类型不能为空', trigger: 'change' }],
bizId: [{ required: true, message: '业务关联ID不能为空', trigger: 'blur' }],
remark: [{ required: true, message: '备注不能为空', trigger: 'blur' }],
})

View File

@@ -106,11 +106,12 @@
<el-table-column type="selection" width="55" />
<el-table-column label="用户编号" align="center" prop="userId" />
<el-table-column label="手机号" align="center" prop="mobile" />
<el-table-column label="变动类型(increase-增加 decrease-减少)" align="center" prop="type" />
<el-table-column label="变动积分数量(正数为增加,负数为减少)" align="center" prop="pointAmount" />
<el-table-column label="变动类型" align="center" prop="type" />
<el-table-column label="变动积分数量" align="center" prop="pointAmount" />
<el-table-column label="变动后余额" align="center" prop="balance" />
<el-table-column label="变动原因" align="center" prop="reason" />
<el-table-column label="业务类型(signin-签到 recharge-充值 exchange-兑换 admin-后台调整 gift-礼包赠送)" align="center" prop="bizType" />
<!-- (signin-签到 recharge-充值 exchange-兑换 admin-后台调整 gift-礼包赠送) -->
<el-table-column label="业务类型" align="center" prop="bizType" />
<el-table-column label="业务关联ID" align="center" prop="bizId" />
<el-table-column label="备注" align="center" prop="remark" />
<el-table-column label="操作" align="center" min-width="120px">

View File

@@ -16,8 +16,8 @@
<el-form-item label="连续签到奖励积分" prop="bonusPoints">
<el-input v-model="formData.bonusPoints" placeholder="请输入连续签到奖励积分" />
</el-form-item>
<el-form-item label="重置签到天数(0表示不重置)" prop="resetDays">
<el-input v-model="formData.resetDays" placeholder="请输入重置签到天数(0表示不重置)" />
<el-form-item label="重置签到天数" prop="resetDays">
<el-input v-model="formData.resetDays" placeholder="请输入重置签到天数" />
</el-form-item>
<el-form-item label="调整原因" prop="adjustReason">
<el-input v-model="formData.adjustReason" placeholder="请输入调整原因" />
@@ -28,7 +28,7 @@
<el-form-item label="操作人账号" prop="operatorName">
<el-input v-model="formData.operatorName" placeholder="请输入操作人账号" />
</el-form-item>
<el-form-item label="状态(0-禁用 1-启用)" prop="status">
<el-form-item label="状态" prop="status">
<el-radio-group v-model="formData.status">
<el-radio value="0">禁用</el-radio>
<el-radio value="1">启用</el-radio>
@@ -73,11 +73,11 @@ const formRules = reactive({
dailyPoints: [{ required: true, message: '每日签到赠送积分不能为空', trigger: 'blur' }],
continuousDays: [{ required: true, message: '连续签到天数不能为空', trigger: 'blur' }],
bonusPoints: [{ required: true, message: '连续签到奖励积分不能为空', trigger: 'blur' }],
resetDays: [{ required: true, message: '重置签到天数(0表示不重置)不能为空', trigger: 'blur' }],
resetDays: [{ required: true, message: '重置签到天数不能为空', trigger: 'blur' }],
adjustReason: [{ required: true, message: '调整原因不能为空', trigger: 'blur' }],
operatorId: [{ required: true, message: '操作人用户编号不能为空', trigger: 'blur' }],
operatorName: [{ required: true, message: '操作人账号不能为空', trigger: 'blur' }],
status: [{ required: true, message: '状态(0-禁用 1-启用)不能为空', trigger: 'blur' }],
status: [{ required: true, message: '状态不能为空', trigger: 'change' }],
remark: [{ required: true, message: '备注不能为空', trigger: 'blur' }],
})
const formRef = ref() // 表单 Ref

View File

@@ -35,10 +35,10 @@
class="!w-240px"
/>
</el-form-item>
<el-form-item label="重置签到天数(0表示不重置)" prop="resetDays">
<el-form-item label="重置签到天数" prop="resetDays">
<el-input
v-model="queryParams.resetDays"
placeholder="请输入重置签到天数(0表示不重置)"
placeholder="请输入重置签到天数"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
@@ -106,11 +106,14 @@
<el-table-column label="每日签到赠送积分" align="center" prop="dailyPoints" />
<el-table-column label="连续签到天数" align="center" prop="continuousDays" />
<el-table-column label="连续签到奖励积分" align="center" prop="bonusPoints" />
<el-table-column label="重置签到天数(0表示不重置)" align="center" prop="resetDays" />
<el-table-column label="重置天数" align="center" prop="resetDays">
<template #default="scope">{{ scope.row.resetDays || '不重置' }}</template>
</el-table-column>
<el-table-column label="调整原因" align="center" prop="adjustReason" />
<el-table-column label="操作人用户编号" align="center" prop="operatorId" />
<el-table-column label="操作人账号" align="center" prop="operatorName" />
<el-table-column label="状态(0-禁用 1-启用)" align="center" prop="status" />
<el-table-column label="操作人" align="center" prop="operatorName" />
<el-table-column label="状态" align="center" prop="status">
<template #default="scope">{{ scope.row.status === '1' ? '启用' : '禁用' }}</template>
</el-table-column>
<el-table-column label="备注" align="center" prop="remark" />
<el-table-column label="操作" align="center" min-width="120px">
<template #default="scope">

View File

@@ -10,8 +10,11 @@
<el-form-item label="平台URL" prop="platformUrl">
<el-input v-model="formData.platformUrl" placeholder="请输入平台URL" />
</el-form-item>
<el-form-item label="平台Token" prop="platformToken">
<el-input v-model="formData.platformToken" placeholder="请输入平台Token" />
<el-form-item label="接口类型" prop="interfaceType">
<el-input v-model="formData.interfaceType" placeholder="请输入接口类型" />
</el-form-item>
<el-form-item label="接口描述" prop="interfaceDesc">
<el-input v-model="formData.interfaceDesc" placeholder="请输入接口描述" />
</el-form-item>
</el-form>
<template #footer>
@@ -35,12 +38,13 @@ const formLoading = ref(false) // 表单的加载中1修改时的数据加
const formType = ref('') // 表单的类型create - 新增update - 修改
const formData = ref({
platformUrl: undefined,
platformToken: undefined,
interfaceType: undefined,
interfaceDesc: undefined,
id: undefined,
})
const formRules = reactive({
platformUrl: [{ required: true, message: '平台URL不能为空', trigger: 'blur' }],
platformToken: [{ required: true, message: '平台Token不能为空', trigger: 'blur' }],
interfaceType: [{ required: true, message: '接口类型不能为空', trigger: 'blur' }],
})
const formRef = ref() // 表单 Ref
@@ -90,7 +94,8 @@ const submitForm = async () => {
const resetForm = () => {
formData.value = {
platformUrl: undefined,
platformToken: undefined,
interfaceType: undefined,
interfaceDesc: undefined,
id: undefined,
}
formRef.value?.resetFields()

View File

@@ -17,10 +17,10 @@
class="!w-240px"
/>
</el-form-item>
<el-form-item label="平台Token" prop="platformToken">
<el-form-item label="接口类型" prop="interfaceType">
<el-input
v-model="queryParams.platformToken"
placeholder="请输入平台Token"
v-model="queryParams.interfaceType"
placeholder="请输入接口类型"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
@@ -82,8 +82,8 @@
>
<el-table-column type="selection" width="55" />
<el-table-column label="平台URL" align="center" prop="platformUrl" />
<el-table-column label="平台Token" align="center" prop="platformToken" />
<el-table-column label="主键ID" align="center" prop="id" />
<el-table-column label="接口类型" align="center" prop="interfaceType" />
<el-table-column label="接口描述" align="center" prop="interfaceDesc" />
<el-table-column
label="创建时间"
align="center"
@@ -145,7 +145,8 @@ const queryParams = reactive({
pageNo: 1,
pageSize: 10,
platformUrl: undefined,
platformToken: undefined,
interfaceType: undefined,
interfaceDesc: undefined,
createTime: [],
})
const queryFormRef = ref() // 搜索的表单
@@ -189,7 +190,6 @@ const handleDelete = async (id: number) => {
// 发起删除
await TokenApi.deleteToken(id)
message.success(t('common.delSuccess'))
currentRow.value = {}
// 刷新列表
await getList()
} catch {}