活动:特惠礼包
This commit is contained in:
@@ -6,6 +6,7 @@ import { RewardParam } from '../../../domain/activityField/rewardField';
|
|||||||
import { addReward, stringToRewardParam } from '../../../services/activity/giftPackageService';
|
import { addReward, stringToRewardParam } from '../../../services/activity/giftPackageService';
|
||||||
import { ActivityDailyRMBGiftsModel } from '../../../db/ActivityDailyRMBGifts';
|
import { ActivityDailyRMBGiftsModel } from '../../../db/ActivityDailyRMBGifts';
|
||||||
import moment = require('moment');
|
import moment = require('moment');
|
||||||
|
import { DailyRMBGiftsItem } from '../../../domain/activityField/dailyRMBGiftsField';
|
||||||
|
|
||||||
export default function (app: Application) {
|
export default function (app: Application) {
|
||||||
new HandlerService(app, {});
|
new HandlerService(app, {});
|
||||||
@@ -49,11 +50,11 @@ export class DailyRMBGiftsHandler {
|
|||||||
const sid = session.get('sid');
|
const sid = session.get('sid');
|
||||||
const roleName = session.get('roleName');
|
const roleName = session.get('roleName');
|
||||||
|
|
||||||
|
|
||||||
let playerData = await getPlayerDailyRMBGiftsData(activityId, serverId, roleId)
|
let playerData = await getPlayerDailyRMBGiftsData(activityId, serverId, roleId)
|
||||||
if (!playerData) return resResult(STATUS.ACTIVITY_MISSING);
|
if (!playerData) return resResult(STATUS.ACTIVITY_MISSING);
|
||||||
|
|
||||||
if (id > 0) {//领取单个--免费奖励
|
let items: DailyRMBGiftsItem[] = [];
|
||||||
|
if(id > 0) {
|
||||||
let item = playerData.findItem(id);
|
let item = playerData.findItem(id);
|
||||||
if (!item) {
|
if (!item) {
|
||||||
return resResult(STATUS.ACTIVITY_DATA_ERROR);
|
return resResult(STATUS.ACTIVITY_DATA_ERROR);
|
||||||
@@ -64,37 +65,31 @@ export class DailyRMBGiftsHandler {
|
|||||||
if (!playerData.isBuy && item.price > 0) {
|
if (!playerData.isBuy && item.price > 0) {
|
||||||
return resResult(STATUS.ACTIVITY_NEED_PAY);
|
return resResult(STATUS.ACTIVITY_NEED_PAY);
|
||||||
}
|
}
|
||||||
let rewardParamArr: Array<RewardParam> = stringToRewardParam(item.reward);
|
items.push(item);
|
||||||
let result = await addReward(roleId, roleName, sid, serverId, rewardParamArr, ITEM_CHANGE_REASON.DAILY_RMB_GIFT)
|
} else {
|
||||||
await ActivityDailyRMBGiftsModel.receiveRecord(serverId, activityId, roleId, moment(playerData.beginTime).toDate(), playerData.todayIndex, [item.id]);
|
|
||||||
item.isReceive = true;
|
|
||||||
return resResult(STATUS.SUCCESS, Object.assign(result, {
|
|
||||||
param: { activityId, id },
|
|
||||||
items: [item]
|
|
||||||
}));
|
|
||||||
} else {//一键领取全天的奖励
|
|
||||||
if (!playerData.isBuy) {
|
if (!playerData.isBuy) {
|
||||||
return resResult(STATUS.ACTIVITY_UNOPENED);
|
return resResult(STATUS.ACTIVITY_UNOPENED);
|
||||||
}
|
}
|
||||||
let items = playerData.unReceiveItem();
|
items.push(...playerData.unReceiveItem());
|
||||||
if (items.length == 0) {
|
|
||||||
return resResult(STATUS.ACTIVITY_REWARDED);
|
|
||||||
}
|
|
||||||
let rewardArray = [];
|
|
||||||
let ids = []
|
|
||||||
for (let item of items) {
|
|
||||||
ids.push(item.id)
|
|
||||||
let rewardParamArr: Array<RewardParam> = stringToRewardParam(item.reward);
|
|
||||||
rewardArray = rewardArray.concat(rewardParamArr);
|
|
||||||
item.isReceive = true;
|
|
||||||
}
|
|
||||||
let result = await addReward(roleId, roleName, sid, serverId, rewardArray, ITEM_CHANGE_REASON.DAILY_RMB_GIFT)
|
|
||||||
await ActivityDailyRMBGiftsModel.receiveRecord(serverId, activityId, roleId, moment(playerData.beginTime).toDate(), playerData.todayIndex, ids);
|
|
||||||
return resResult(STATUS.SUCCESS, Object.assign(result, {
|
|
||||||
param: { activityId },
|
|
||||||
items: items
|
|
||||||
}));
|
|
||||||
}
|
}
|
||||||
|
if (items.length == 0) {
|
||||||
|
return resResult(STATUS.ACTIVITY_REWARDED);
|
||||||
|
}
|
||||||
|
|
||||||
|
let rewardArray: RewardParam[] = [];
|
||||||
|
let ids: number[] = []
|
||||||
|
for (let item of items) {
|
||||||
|
ids.push(item.id);
|
||||||
|
rewardArray.push(...stringToRewardParam(item.reward));
|
||||||
|
}
|
||||||
|
let resultItems = playerData.receiveItems(ids);
|
||||||
|
let result = await addReward(roleId, roleName, sid, serverId, rewardArray, ITEM_CHANGE_REASON.DAILY_RMB_GIFT)
|
||||||
|
await ActivityDailyRMBGiftsModel.receiveRecord(serverId, activityId, roleId, moment(playerData.beginTime).toDate(), playerData.todayIndex, ids);
|
||||||
|
|
||||||
|
return resResult(STATUS.SUCCESS, Object.assign(result, {
|
||||||
|
param: { activityId, unReceiveCount: playerData.unReceiveCount, buttonStatus: playerData.buttonStatus },
|
||||||
|
items: resultItems
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ import { DailyRMBGiftsData } from '../../domain/activityField/dailyRMBGiftsField
|
|||||||
import moment = require('moment');
|
import moment = require('moment');
|
||||||
import { RewardParam } from '../../domain/activityField/rewardField';
|
import { RewardParam } from '../../domain/activityField/rewardField';
|
||||||
import { addReward, stringToRewardParam } from './giftPackageService';
|
import { addReward, stringToRewardParam } from './giftPackageService';
|
||||||
import { ServerlistModel } from '../../db/Serverlist';
|
|
||||||
import { RoleModel } from '../../db/Role';
|
|
||||||
import { getActivitiesByType, getActivityById } from './activityService';
|
import { getActivitiesByType, getActivityById } from './activityService';
|
||||||
import { getRoleCreateTime, getServerCreateTime } from '../redisService';
|
import { getRoleCreateTime, getServerCreateTime } from '../redisService';
|
||||||
|
|
||||||
@@ -42,18 +40,9 @@ export async function getPlayerDailyRMBGiftsData(activityId: number, serverId: n
|
|||||||
let createTime = await getRoleCreateTime(roleId);
|
let createTime = await getRoleCreateTime(roleId);
|
||||||
let serverTime = await getServerCreateTime(serverId);
|
let serverTime = await getServerCreateTime(serverId);
|
||||||
let playerData = new DailyRMBGiftsData(activityData, createTime, serverTime);
|
let playerData = new DailyRMBGiftsData(activityData, createTime, serverTime);
|
||||||
// let productID = playerData.productID;
|
let playerRecords: ActivityDailyRMBGiftsModelType[] = await ActivityDailyRMBGiftsModel.findBuyRecord(serverId, activityId, roleId, moment(playerData.beginTime).toDate(), playerData.todayIndex);
|
||||||
// let playerOrders: UserOrderModelType[] = await UserOrderModel.findPlayerOrder(productID, roleId, activityId, 1);
|
|
||||||
// let buyTime = moment(new Date()).startOf('d').toDate()
|
|
||||||
// let endTime = null;
|
|
||||||
// if (playerOrders.length > 0) {
|
|
||||||
// buyTime = playerOrders[0].createdAt;//购买时候的日期
|
|
||||||
// endTime = moment(buyTime).add(7, 'd').endOf('d').toDate()
|
|
||||||
// }
|
|
||||||
let playerRecord: ActivityDailyRMBGiftsModelType = await ActivityDailyRMBGiftsModel.findRecord(serverId, activityId, roleId, moment(playerData.beginTime).toDate(), playerData.todayIndex);
|
|
||||||
let unReceiveRecord: ActivityDailyRMBGiftsModelType[] = await ActivityDailyRMBGiftsModel.findBuyRecord(serverId, activityId, roleId, moment(playerData.beginTime).toDate(), playerData.todayIndex);
|
|
||||||
|
|
||||||
playerData.setPlayerRecords(playerRecord, unReceiveRecord.length);
|
playerData.setPlayerRecords(playerRecords);
|
||||||
return playerData;
|
return playerData;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -80,7 +69,8 @@ export async function makeDailyRMBGiftsReward(roleId: string, roleName: string,
|
|||||||
let bigGiftProductID = playerData.productID;
|
let bigGiftProductID = playerData.productID;
|
||||||
if (bigGiftProductID == productID) {//一次性购买7天礼包
|
if (bigGiftProductID == productID) {//一次性购买7天礼包
|
||||||
let playerRecord: ActivityDailyRMBGiftsModelType = await ActivityDailyRMBGiftsModel.findRecord(serverId, activityId, roleId, moment(playerData.beginTime).toDate(), playerData.todayIndex);
|
let playerRecord: ActivityDailyRMBGiftsModelType = await ActivityDailyRMBGiftsModel.findRecord(serverId, activityId, roleId, moment(playerData.beginTime).toDate(), playerData.todayIndex);
|
||||||
if (playerRecord && playerRecord.records && playerRecord.records.length > 0) {//今天已经购买过其他奖励
|
playerData.setPlayerRecords(playerRecord?[playerRecord]: []);
|
||||||
|
if (playerData.shouldbuyNextDay()) {//今天已经购买过其他奖励
|
||||||
playerData.todayIndex ++;
|
playerData.todayIndex ++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -166,6 +166,14 @@ export const SIGNIN_VIP_OPEN_LIMIT = 15;
|
|||||||
//每日特惠礼包RMB购买4挡,一次性支付购买7天,每天只能领取当天的礼包奖励
|
//每日特惠礼包RMB购买4挡,一次性支付购买7天,每天只能领取当天的礼包奖励
|
||||||
export const DAILYRMBGIFTS_DAYS = 7;//一次性购买*天
|
export const DAILYRMBGIFTS_DAYS = 7;//一次性购买*天
|
||||||
|
|
||||||
|
export enum DAILY_RMB_GIFT_STATUS {
|
||||||
|
CAN_BUY = 0, // 可以购买
|
||||||
|
CAN_NOT_BUY = 1, // 不可购买
|
||||||
|
CAN_RECEIVE = 2, // 可以一键领取
|
||||||
|
HAS_RECEIVED = 3, // 已一键领取
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
//签到活动开启时间
|
//签到活动开启时间
|
||||||
export const SIGNIN_OPEN = 1;//*号0点开启
|
export const SIGNIN_OPEN = 1;//*号0点开启
|
||||||
export const SIGNIN_CLOSE = 31;//*号晚上24点结束
|
export const SIGNIN_CLOSE = 31;//*号晚上24点结束
|
||||||
|
|||||||
@@ -69,7 +69,7 @@ export default class Activity_Daily_RMB_Gifts extends BaseModel {
|
|||||||
//获取已经购买还没有领取的数据
|
//获取已经购买还没有领取的数据
|
||||||
public static async findBuyRecord(serverId: number, activityId: number, roleId: string, beginTime: Date, todayIndex: number) {
|
public static async findBuyRecord(serverId: number, activityId: number, roleId: string, beginTime: Date, todayIndex: number) {
|
||||||
let result: ActivityDailyRMBGiftsModelType[] = await ActivityDailyRMBGiftsModel.find(
|
let result: ActivityDailyRMBGiftsModelType[] = await ActivityDailyRMBGiftsModel.find(
|
||||||
{ serverId, roleId, activityId, beginTime, todayIndex: { $gt: todayIndex } }).lean(true);
|
{ serverId, roleId, activityId, beginTime, todayIndex: { $gte: todayIndex } }).lean(true);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
import { DAILYRMBGIFTS_DAYS } from '../../consts';
|
import { DAILYRMBGIFTS_DAYS, DAILY_RMB_GIFT_STATUS } from '../../consts';
|
||||||
import { ActivityModelType } from '../../db/Activity';
|
import { ActivityModelType } from '../../db/Activity';
|
||||||
import { ActivityDailyRMBGiftsModelType } from '../../db/ActivityDailyRMBGifts';
|
import { ActivityDailyRMBGiftsModelType } from '../../db/ActivityDailyRMBGifts';
|
||||||
import { ActivityBase } from './activityField';
|
import { ActivityBase } from './activityField';
|
||||||
@@ -32,13 +32,14 @@ export class DailyRMBGiftsData extends ActivityBase {
|
|||||||
list: Array<DailyRMBGiftsItem> = [];//每件商品信息
|
list: Array<DailyRMBGiftsItem> = [];//每件商品信息
|
||||||
isBuy: boolean = false;//是否一次性购买过
|
isBuy: boolean = false;//是否一次性购买过
|
||||||
|
|
||||||
|
unReceived: number[] = [];
|
||||||
unReceiveCount: number = 0;//剩余领取次数(一次性购买)
|
unReceiveCount: number = 0;//剩余领取次数(一次性购买)
|
||||||
|
buttonStatus: number = DAILY_RMB_GIFT_STATUS.CAN_BUY;
|
||||||
|
|
||||||
public unReceiveItem() {
|
public unReceiveItem() {
|
||||||
return this.list.filter(obj => { return !obj.isReceive });
|
return this.list.filter(obj => { return !obj.isReceive });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public findItem(id: number) {
|
public findItem(id: number) {
|
||||||
let index = this.list.findIndex(obj => { return obj.id == id });
|
let index = this.list.findIndex(obj => { return obj.id == id });
|
||||||
return (index != -1) ? this.list[index] : null
|
return (index != -1) ? this.list[index] : null
|
||||||
@@ -50,29 +51,61 @@ export class DailyRMBGiftsData extends ActivityBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//解析玩家领取记录
|
//解析玩家领取记录
|
||||||
public setPlayerRecords(data: ActivityDailyRMBGiftsModelType, unReceiveCount: number) {
|
public setPlayerRecords(playerRecords: ActivityDailyRMBGiftsModelType[]) {
|
||||||
this.isBuy = false;
|
for(let playerRecord of playerRecords) {
|
||||||
this.unReceiveCount = 0;
|
if(playerRecord.todayIndex == this.todayIndex) {
|
||||||
if (!data) {
|
this.isBuy = !!playerRecord.isBuy;
|
||||||
return;
|
let records = playerRecord.records ? playerRecord.records : [];
|
||||||
}
|
for(let {id} of records) {
|
||||||
let records = data.records ? data.records : [];
|
let item = this.findItem(id);
|
||||||
let isOver = true;
|
if(item) item.isReceive = true;
|
||||||
for (let item of this.list) {
|
}
|
||||||
let index = records.findIndex(obj => { return obj.id === item.id })
|
} else {
|
||||||
if (index != -1) {
|
this.unReceived.push(playerRecord.todayIndex);
|
||||||
item.isReceive = true;
|
|
||||||
}
|
|
||||||
if (!item.isReceive) {
|
|
||||||
isOver = false;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.isBuy = data.isBuy ? data.isBuy : false;
|
this.calTodayReceiveStatus();
|
||||||
this.unReceiveCount = unReceiveCount;
|
this.calButtonStatus();
|
||||||
if (this.isBuy && !isOver) {
|
}
|
||||||
this.unReceiveCount += 1;
|
|
||||||
|
public calTodayReceiveStatus() {
|
||||||
|
if(this.isBuy) {
|
||||||
|
let hasAllReceived = !this.list.find(item => !item.isReceive);
|
||||||
|
console.log('##### calTodayReceiveStatus', this.unReceived, this.todayIndex, hasAllReceived)
|
||||||
|
if(!hasAllReceived && this.unReceived.indexOf(this.todayIndex) == -1) {
|
||||||
|
this.unReceived.push(this.todayIndex);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
this.unReceiveCount = this.unReceived.length;
|
||||||
|
}
|
||||||
|
|
||||||
|
public calButtonStatus() {
|
||||||
|
if(this.isBuy) { // 已购买
|
||||||
|
let hasAllReceived = !this.list.find(item => !item.isReceive);
|
||||||
|
if(hasAllReceived) { // 买了且全都领完
|
||||||
|
this.buttonStatus = DAILY_RMB_GIFT_STATUS.HAS_RECEIVED;
|
||||||
|
} else {
|
||||||
|
this.buttonStatus = DAILY_RMB_GIFT_STATUS.CAN_RECEIVE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public shouldbuyNextDay() {
|
||||||
|
return this.list.filter(item => item.isReceive && item.price != 0).length != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public receiveItems(ids: number[]) {
|
||||||
|
let items: DailyRMBGiftsItem[] = [];
|
||||||
|
for(let item of this.list) {
|
||||||
|
if(ids.indexOf(item.id) != -1) {
|
||||||
|
item.isReceive = true;
|
||||||
|
items.push(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.calButtonStatus();
|
||||||
|
this.calTodayReceiveStatus();
|
||||||
|
return items;
|
||||||
}
|
}
|
||||||
|
|
||||||
public initData(data: string) {
|
public initData(data: string) {
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
{
|
{
|
||||||
"id": 5,
|
"id": 5,
|
||||||
"score": 2500,
|
"score": 2500,
|
||||||
"reward": "40005&500"
|
"reward": "60004&1"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"id": 6,
|
"id": 6,
|
||||||
|
|||||||
Reference in New Issue
Block a user