活动:每日充值

This commit is contained in:
luying
2022-03-03 19:17:54 +08:00
parent 17b5071d66
commit 8649cb82b7
8 changed files with 171 additions and 131 deletions

View File

@@ -1,11 +1,12 @@
import { Application, BackendSession, HandlerService, } from 'pinus';
import { resResult } from '../../../pubUtils/util';
import { ITEM_CHANGE_REASON, STATUS } from '../../../consts';
import { getPlayerRechargeMoneyData } from '../../../services/activity/rechargeMoneyService';
import { RechargeMoneyItem } from '../../../domain/activityField/rechargeMoneyField';
import { getPlayerRechargeMoneyData, getPlayerRechargeMoneyDataShow } from '../../../services/activity/rechargeMoneyService';
import { RechargeMoneyPool } from '../../../domain/activityField/rechargeMoneyField';
import { addReward, stringToRewardParam } from '../../../services/activity/giftPackageService';
import { RewardParam } from '../../../domain/activityField/rewardField';
import { ActivityRechargeMoneyModel } from '../../../db/ActivityRechargeMoney';
import { addItems } from '../../../services/rewardService';
export default function (app: Application) {
@@ -29,9 +30,8 @@ export class RechargeMoneyHandler {
const roleId = session.get('roleId');
const serverId = session.get('serverId');
let playerData = await getPlayerRechargeMoneyData(activityId, serverId, roleId);
let playerData = await getPlayerRechargeMoneyDataShow(activityId, serverId, roleId);
if (!playerData) return resResult(STATUS.ACTIVITY_MISSING);
delete playerData.recordArray;
return resResult(STATUS.SUCCESS, playerData);
}
@@ -41,7 +41,7 @@ export class RechargeMoneyHandler {
* @param {BackendSession} session
* @memberof RechargeMoneyHandler
*/
async getRechargeMoneyReward(msg: { activityId: number }, session: BackendSession) {
async pull(msg: { activityId: number }, session: BackendSession) {
const { activityId } = msg;
const roleId = session.get('roleId');
const serverId = session.get('serverId');
@@ -52,30 +52,26 @@ export class RechargeMoneyHandler {
let playerData = await getPlayerRechargeMoneyData(activityId, serverId, roleId);
if (!playerData) return resResult(STATUS.ACTIVITY_MISSING);
if (playerData.totalCount <= playerData.receiveCount) {
return resResult(STATUS.ACTIVITY_RECHARGE_MONEY_NO_REWARD);
if (playerData.ticketCnt <= 0) {
return resResult(STATUS.ACTIVITY_RECHARGE_TICKET_NOT_ENOUGH);
}
let item: RechargeMoneyItem = playerData.randomReward();
let item = playerData.pull();
if (!item) {
return resResult(STATUS.ACTIVITY_RECHARGE_MONEY_ERROR);
return resResult(STATUS.ACTIVITY_RECHARGE_TICKET_NOT_ENOUGH);
}
let recordArray = playerData.recordArray.filter(obj => { return obj && !obj.rewardTime })
let rechargeItem = recordArray[0];
// console.log('recordArray', JSON.stringify(recordArray));
await ActivityRechargeMoneyModel.addRecord(rechargeItem._id, item.id, item.reward)
let rewardParamArr: Array<RewardParam> = stringToRewardParam(item.reward);
let result = await addReward(roleId, roleName, sid, serverId, rewardParamArr, ITEM_CHANGE_REASON.RECHARGE_REWARD)
if (playerData.isLast()) {
let _ids = playerData.recordArray.map(a => a._id)
await ActivityRechargeMoneyModel.setEndState(serverId, roleId, _ids);
}
let notGetRecord = playerData.recordArr[0];
console.log('notGetRecord', JSON.stringify(notGetRecord));
await ActivityRechargeMoneyModel.addRecord(notGetRecord._id, item.id, `${item.gid}&${item.count}`);
let goods = await addItems(roleId, roleName, sid, [{ id: item.gid, count: item.count }], ITEM_CHANGE_REASON.RECHARGE_REWARD)
item.rewardTime = new Date();
return resResult(STATUS.SUCCESS, Object.assign(result, {
item.setHasGet(true);
return resResult(STATUS.SUCCESS, {
goods,
param: { activityId },
item: item
}));
});
}
}