活动:每日充值
This commit is contained in:
@@ -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
|
||||
}));
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user