活动:成长活动、今日挑战奖励接口返回数据添加字段
This commit is contained in:
@@ -2,17 +2,6 @@ import BaseModel from './BaseModel';
|
||||
import { index, getModelForClass, prop, DocumentType } from '@typegoose/typegoose';
|
||||
|
||||
|
||||
/**
|
||||
* 购买记录
|
||||
*/
|
||||
|
||||
export class BuyRecord {
|
||||
@prop({ required: true })
|
||||
id: number; //物品id标识
|
||||
@prop({ required: true })
|
||||
time: Date; //购买时间
|
||||
}
|
||||
|
||||
/**
|
||||
* 活动系统 - 弹出商店
|
||||
*/
|
||||
@@ -30,18 +19,18 @@ export default class ActivityPopUpShop extends BaseModel {
|
||||
@prop({ required: true })
|
||||
endTime: Date; // 结束时间
|
||||
@prop({ required: true })
|
||||
taskId: number; // 任务id
|
||||
id: number; // 任务id
|
||||
@prop({ required: true })
|
||||
records: BuyRecord[]; // 购买记录
|
||||
isBuy: boolean; // 是否购买
|
||||
|
||||
//购买奖励的记录
|
||||
public static async addRecord(serverId: number, activityId: number, roleId: string, taskId: number, id: number) {
|
||||
public static async addRecord(serverId: number, activityId: number, roleId: string, id: number) {
|
||||
let nowDate = new Date();
|
||||
let result: ActivityPopUpShopModelType = await ActivityPopUpShopModel.findOneAndUpdate({
|
||||
serverId, roleId, activityId, taskId,
|
||||
serverId, roleId, activityId, id,
|
||||
beginTime: { $lt: nowDate }, endTime: { $gt: nowDate }
|
||||
},
|
||||
{ $push: { records: { id, time: new Date() } } }, { upsert: true, new: true }).lean(true);
|
||||
{ $set: { isBuy: true } }, { upsert: true, new: true }).lean(true);
|
||||
return result;
|
||||
}
|
||||
|
||||
@@ -56,20 +45,20 @@ export default class ActivityPopUpShop extends BaseModel {
|
||||
}
|
||||
|
||||
//根据活动taskId查询现在正在进行的活动数据
|
||||
public static async findOpenDataByTaskId(serverId: number, activityId: number, roleId: string, taskId: number) {
|
||||
public static async findOpenDataByTaskId(serverId: number, activityId: number, roleId: string, id: number) {
|
||||
let nowDate = new Date();
|
||||
let result: ActivityPopUpShopModelType = await ActivityPopUpShopModel.findOne({
|
||||
serverId, roleId, activityId, taskId,
|
||||
serverId, roleId, activityId, id,
|
||||
beginTime: { $lt: nowDate }, endTime: { $gt: nowDate }
|
||||
}).lean(true);
|
||||
return result;
|
||||
}
|
||||
|
||||
//删除活动领取记录
|
||||
public static async deleteActivity(serverId: number, activityId: number, roleId: string, taskId: number) {
|
||||
public static async deleteActivity(serverId: number, activityId: number, roleId: string, id: number) {
|
||||
let nowDate = new Date();
|
||||
await ActivityPopUpShopModel.deleteMany({
|
||||
roleId, activityId, taskId,
|
||||
roleId, activityId, id,
|
||||
beginTime: { $lt: nowDate }, endTime: { $gt: nowDate }
|
||||
});
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user