活动:刷新任务活动添加兑换点数接口

This commit is contained in:
qiaoxin
2021-06-21 15:18:06 +08:00
parent 3c68d50d46
commit 482760086f
4 changed files with 117 additions and 3 deletions

View File

@@ -2,6 +2,7 @@ import moment = require('moment');
import { REFRESH_TIME, TASK_TYPE } from '../../consts';
import { ActivityModelType } from '../../db/Activity';
import { ActivityRefreshTaskModelType } from '../../db/ActivityRefreshTask';
import { ActivityRefreshTaskPointModelType } from '../../db/ActivityRefreshTaskPoint';
import { ActivityBase } from './activityField';
@@ -15,6 +16,7 @@ export class RefreshTaskItem {
condition: number; //任务数据条件 dic_zyz_taskType.jsonT
reward: string; // 任务奖励,格式:1&3&1(类型&id&数量) 类型定义:1.英雄2.物品
skip: number; //跳转客户端用
point: number; //奖励的点数
totalCount: number = 0; //完成任务累计次数
receiveRewardCount: number = 0; //领取奖励次数
@@ -28,6 +30,7 @@ export class RefreshTaskItem {
this.condition = data.condition;
this.reward = data.reward;
this.skip = data.skip;
this.point = data.point;
this.totalCount = 0;
this.receiveRewardCount = 0;
}
@@ -57,6 +60,12 @@ export class RefreshTaskData extends ActivityBase {
nextRefreshTime: number;//下次刷新时间
roundIndex: number = 1;//周期数从1开始
consumePoint: number = 0;//消耗点数兑换奖品
reward: string = ''//消耗点数的奖品内容
totalPoint: number = 0;//获得的总点数
exchangePoint: number = 0;//兑换了点数奖品
public findItem(pageIndex: number, id: number, type: TASK_TYPE) {
let index = this.list.findIndex(obj => { return obj && obj.pageIndex === pageIndex });
if (index != -1) {
@@ -78,16 +87,24 @@ export class RefreshTaskData extends ActivityBase {
}
//解析玩家领取记录
public setPlayerRecords(data: ActivityRefreshTaskModelType[]) {
public setPlayerRecords(data: ActivityRefreshTaskModelType[], pointRecordData: ActivityRefreshTaskPointModelType) {
for (let pageData of this.list) {
for (let item of pageData.items) {
let index = data.findIndex(record => { return item.id == record.id && item.pageIndex == record.pageIndex && item.taskType == record.type })
if (index != -1) {
item.totalCount = data[index].totalCount ? data[index].totalCount : 0;
item.receiveRewardCount = data[index].receiveRewardCount ? data[index].receiveRewardCount : 0;
if (item.receiveRewardCount) {
this.totalPoint += item.point;
}
}
}
}
let pointRecords = pointRecordData && pointRecordData.records ? pointRecordData.records : [];
for (let record of pointRecords) {
this.exchangePoint += record.point;
}
}
public initData(data: string) {
@@ -95,6 +112,10 @@ export class RefreshTaskData extends ActivityBase {
let dataObj = JSON.parse(data);
this.name = dataObj.name;
this.interval = dataObj.interval;
this.totalPoint = 0;
this.isReceive = false;
this.consumePoint = dataObj.consumePoint;
this.reward = dataObj.reward;
this.beginTime = moment(this.beginTime).startOf('d').add(REFRESH_TIME, 'hour').valueOf();
if (this.interval > 0) {