✨ feat(活动): 辜月集会 fa97e8d45
This commit is contained in:
79
shared/db/ActivityNovemberRec.ts
Normal file
79
shared/db/ActivityNovemberRec.ts
Normal file
@@ -0,0 +1,79 @@
|
||||
import { getModelForClass, index, prop, DocumentType } from "@typegoose/typegoose";
|
||||
import BaseModel from "./BaseModel";
|
||||
|
||||
@index({ roleId: 1, activityId: 1, serverId: 1, roundIndex: 1 })
|
||||
|
||||
|
||||
export class NovemberRecord {
|
||||
@prop({ required: true })
|
||||
todayIndex: number; // 今天index
|
||||
@prop({ required: true })
|
||||
gameCode: string; // 唯一挑战id
|
||||
@prop({ required: true })
|
||||
time: Date; // 时间
|
||||
@prop({ required: true })
|
||||
rewards: string; // 奖励
|
||||
@prop({ required: true })
|
||||
isSuccess: boolean; // 是否制作成功
|
||||
@prop({ required: true })
|
||||
isSkip: boolean // 是否纯净召唤
|
||||
@prop({ required: true })
|
||||
menuId: number //菜单id
|
||||
@prop({ required: true })
|
||||
isPass: boolean // gameEnd后置为true
|
||||
}
|
||||
|
||||
export class NovemberBuyRec {
|
||||
@prop({ required: true })
|
||||
menuId: number //菜单id
|
||||
|
||||
@prop({ required: true })
|
||||
buyCnt: number //购买次数
|
||||
}
|
||||
export default class Activity_November_Rec extends BaseModel {
|
||||
@prop({ required: true })
|
||||
serverId: number; // 服Id
|
||||
|
||||
@prop({ required: true })
|
||||
activityId: number; // 活动Id
|
||||
|
||||
@prop({ required: true })
|
||||
roundIndex: number; // 第几轮
|
||||
|
||||
@prop({ required: true })
|
||||
roleId: string; // 用户Id
|
||||
|
||||
@prop({ required: true, type: NovemberBuyRec, default: [], _id: false })
|
||||
buyRec: NovemberBuyRec[] // 购买
|
||||
|
||||
@prop({ required: true, type: NovemberRecord, _id: false })
|
||||
records: NovemberRecord[]; // 记录
|
||||
|
||||
public static async findData(serverId: number, activityId: number, roundIndex: number, roleId: string) {
|
||||
let result: ActivityNovemberRecModelType = await ActivityNovemberRecModel.findOne({ serverId, roleId, activityId, roundIndex }).lean();
|
||||
return result;
|
||||
}
|
||||
|
||||
public static async records(serverId: number, activityId: number, roundIndex: number, roleId: string, records: NovemberRecord[]) {
|
||||
let result: ActivityNovemberRecModelType = await ActivityNovemberRecModel.findOneAndUpdate({ serverId, roleId, activityId, roundIndex }, { $push: { records: { $each: records } }, $setOnInsert: { buyRec: [] } }, { new: true, upsert: true }).lean();
|
||||
return result;
|
||||
}
|
||||
|
||||
public static async gameEnd(serverId: number, activityId: number, roundIndex: number, roleId: string, gameCode: string, isSuccess: boolean, time: Date, rewards: string, isPass: boolean) {
|
||||
let result: ActivityNovemberRecModelType = await ActivityNovemberRecModel.findOneAndUpdate({ serverId, roleId, activityId, roundIndex, 'records.gameCode': gameCode },
|
||||
{ $set: { 'records.$.time': time, 'records.$.isSuccess': isSuccess, 'records.$.rewards': rewards, 'records.$.isPass': isPass } }, { new: true }).lean();
|
||||
return result;
|
||||
}
|
||||
|
||||
public static async buyCnt(serverId: number, activityId: number, roundIndex: number, roleId: string, buyRec: NovemberBuyRec, isPushBuyRec: boolean) {
|
||||
let result: ActivityNovemberRecModelType;
|
||||
if (isPushBuyRec) result = await ActivityNovemberRecModel.findOneAndUpdate({ serverId, roleId, activityId, roundIndex }, { $push: { buyRec } }, { new: true, upsert: true }).lean();
|
||||
else result = await ActivityNovemberRecModel.findOneAndUpdate({ serverId, roleId, activityId, roundIndex, 'buyRec.menuId': buyRec.menuId }, { $inc: { 'buyRec.buyCnt': buyRec.buyCnt }, $setOnInsert: { records: [] } }, { new: true, upsert: true }).lean();
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
export const ActivityNovemberRecModel = getModelForClass(Activity_November_Rec);
|
||||
|
||||
export interface ActivityNovemberRecModelType extends Pick<DocumentType<Activity_November_Rec>, keyof Activity_November_Rec> { }
|
||||
export type ActivityNovemberRecModelTypeParam = Partial<ActivityNovemberRecModelType>; // 将所有字段变成可选项
|
||||
Reference in New Issue
Block a user