七天乐-每日特惠礼包
This commit is contained in:
@@ -1,12 +1,15 @@
|
||||
import { Application, BackendSession } from 'pinus';
|
||||
import { resResult } from '../../../pubUtils/util';
|
||||
import { STATUS, } from '../../../consts';
|
||||
import { STATUS, ACTIVITY_RESOURCES_TYPE } from '../../../consts';
|
||||
import { getPlayerGrowthData } from '../../../services/growthService';
|
||||
import { getPlayerDailyChallengesData } from '../../../services/dailyChallengesService';
|
||||
import { GrowthItem } from '../../../domain/activityField/growthField';
|
||||
import { addItems, createHeroes } from '../../../services/rewardService';
|
||||
import { addItems, createHeroes, handleCost } from '../../../services/rewardService';
|
||||
import { ActivityGrowthModel } from '../../../db/ActivityGrowth';
|
||||
import { DailyItem } from '../../../domain/activityField/dailyChallengesField';
|
||||
import { getPlayerDailyGiftsData } from '../../../services/dailyGiftsService';
|
||||
import { DailyGiftItem } from '../../../domain/activityField/DailyGiftsField';
|
||||
import { ActivityDailyGiftsModel } from '../../../db/ActivityDailyGifts';
|
||||
|
||||
|
||||
export default function (app: Application) {
|
||||
@@ -17,6 +20,8 @@ export class SevenDaysHandler {
|
||||
constructor(private app: Application) {
|
||||
}
|
||||
|
||||
/************************成长任务****************************/
|
||||
|
||||
/**
|
||||
* @description 获取七天乐活动数据
|
||||
* @param {{ activityId: number}} msg
|
||||
@@ -184,4 +189,79 @@ export class SevenDaysHandler {
|
||||
|
||||
return resResult(STATUS.SUCCESS, { goods, addHeros });
|
||||
}
|
||||
|
||||
|
||||
/************************每日特惠礼包****************************/
|
||||
|
||||
/**
|
||||
* @description 获取每日特惠礼包活动数据
|
||||
* @param {{ activityId: number}} msg
|
||||
* @param {BackendSession} session
|
||||
* @memberof SevenDaysHandler
|
||||
*/
|
||||
async getSevenDayDailyGiftsActivity(msg: { activityId: number }, session: BackendSession) {
|
||||
const { activityId } = msg;
|
||||
const roleId = session.get('roleId');
|
||||
const serverId = session.get('serverId');
|
||||
|
||||
let playerData = await getPlayerDailyGiftsData(activityId, serverId, roleId)
|
||||
|
||||
if (!playerData) return resResult(STATUS.ACTIVITY_MISSING);
|
||||
|
||||
return resResult(STATUS.SUCCESS, playerData);
|
||||
}
|
||||
|
||||
/**
|
||||
* @description 购买每日特惠礼包
|
||||
* @param {{ activityId: number, dayIndex: number, cellIndex: number}} msg
|
||||
* @param {BackendSession} session
|
||||
* @memberof SevenDaysHandler
|
||||
*/
|
||||
async buyDailyGiftsCell(msg: { activityId: number, dayIndex: number, cellIndex: number }, session: BackendSession) {
|
||||
const { activityId, dayIndex, cellIndex } = msg;
|
||||
const roleId = session.get('roleId');
|
||||
const serverId = session.get('serverId');
|
||||
const sid = session.get('sid');
|
||||
const roleName = session.get('roleName');
|
||||
const funcs = session.get('funcs');
|
||||
|
||||
let playerData = await getPlayerDailyGiftsData(activityId, serverId, roleId)
|
||||
if (!playerData) return resResult(STATUS.ACTIVITY_MISSING);
|
||||
|
||||
let dailyItemData: DailyGiftItem = playerData.findDailyGiftsItem(dayIndex, cellIndex);
|
||||
if (!dailyItemData) {
|
||||
return resResult(STATUS.ACTIVITY_DATA_ERROR);
|
||||
}
|
||||
if (!dailyItemData.canBuy()) {//最大次数
|
||||
return resResult(STATUS.ACTIVITY_MAX_COUNT);
|
||||
}
|
||||
if (dayIndex > playerData.today()) {//还未开启
|
||||
return resResult(STATUS.ACTIVITY_UNOPENED);
|
||||
}
|
||||
|
||||
//货币是否足够
|
||||
let consumeData = dailyItemData.consumeRes();
|
||||
let consumeType = consumeData.type;//购买类型
|
||||
|
||||
if (consumeType == ACTIVITY_RESOURCES_TYPE.GOODS) {//物品表,元宝、金币、体力
|
||||
let result = await handleCost(roleId, sid, [{ id: consumeData.id, count: consumeData.count }]);
|
||||
if (!result) return resResult(STATUS.ACTIVITY_RES_NOT_ENOUGH);
|
||||
} else if (consumeType == ACTIVITY_RESOURCES_TYPE.RMB) {//RMB购买
|
||||
|
||||
}
|
||||
|
||||
await ActivityDailyGiftsModel.buyRecord(activityId, roleId, dayIndex, cellIndex, 1);
|
||||
let reward = dailyItemData.goodReward();
|
||||
let goods = await addItems(roleId, roleName, sid, reward);
|
||||
let heroReward = dailyItemData.heroReward();
|
||||
let addHeros = [];
|
||||
if (heroReward.length > 0) {
|
||||
let heroResult = await createHeroes(roleId, roleName, sid, serverId, funcs, heroReward);
|
||||
goods = goods.concat(heroResult.goods)
|
||||
addHeros = addHeros.concat(heroResult.heroes);
|
||||
}
|
||||
|
||||
return resResult(STATUS.SUCCESS, { goods, addHeros });
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user