活动:刷新任务活动添加兑换点数接口
This commit is contained in:
@@ -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) {
|
||||
|
||||
Reference in New Issue
Block a user