每日优惠礼包(RMB购买)
This commit is contained in:
84
game-server/app/services/dailyRMBGiftsService.ts
Normal file
84
game-server/app/services/dailyRMBGiftsService.ts
Normal file
@@ -0,0 +1,84 @@
|
||||
import { ACTIVITY_TYPE, TASK_TYPE } from '../consts';
|
||||
import { ActivityModel, ActivityModelType } from '../db/Activity';
|
||||
import { ActivityDailyRMBGiftsModel, ActivityDailyRMBGiftsModelType } from '../db/ActivityDailyRMBGifts';
|
||||
import { DailyRMBGiftsData, DailyRMBGiftsItem } from '../domain/activityField/dailyRMBGiftsField';
|
||||
import { RoleModel } from '../db/Role';
|
||||
import moment = require('moment');
|
||||
import { UserOrderModel, UserOrderModelType } from '../db/UserOrder';
|
||||
import { RewardParam } from '../domain/activityField/rewardField';
|
||||
import { addReward, stringToRewardParam } from './giftPackageService';
|
||||
|
||||
/**
|
||||
* 获取活动数据
|
||||
*
|
||||
* @param {number} serverId 区Id
|
||||
* @param {number} type 活动类型 ACTIVITY_TYPE
|
||||
* @param {string} roleId 角色Id
|
||||
*
|
||||
*/
|
||||
|
||||
export async function thirtyDaysActivity(type: number, serverId: number, roleId: string) {
|
||||
let activityArray: ActivityModelType[] = await ActivityModel.findActivityByType(type, true)
|
||||
activityArray = activityArray.sort((a, b) => {
|
||||
return a.activityId - b.activityId
|
||||
});
|
||||
let allPlayerActivity = [];
|
||||
for (let i = 0; i < activityArray.length; i++) {
|
||||
let activityData = activityArray[i];
|
||||
let playerData = await getPlayerDailyGiftsData(activityData.activityId, serverId, roleId);
|
||||
allPlayerActivity.push(playerData)
|
||||
}
|
||||
|
||||
return allPlayerActivity
|
||||
}
|
||||
|
||||
/**
|
||||
* 玩家活动数据
|
||||
*
|
||||
* @param {number} serverId 区Id
|
||||
* @param {number} activityId 活动Id
|
||||
* @param {string} roleId 角色Id
|
||||
*
|
||||
*/
|
||||
export async function getPlayerDailyGiftsData(activityId: number, serverId: number, roleId: string) {
|
||||
let activityData: ActivityModelType = await ActivityModel.findActivity(activityId, true);
|
||||
|
||||
let playerData = new DailyRMBGiftsData(activityData);
|
||||
let productID = playerData.productID;
|
||||
|
||||
let playerOrders: UserOrderModelType[] = await UserOrderModel.findPlayerOrder(productID, roleId, activityId, 1);
|
||||
let buyTime = moment(new Date()).startOf('d').toDate()
|
||||
let endTime = moment(new Date()).endOf('d').toDate()
|
||||
if (playerOrders.length > 0) {
|
||||
buyTime = playerOrders[0].createdAt;//购买时候的日期
|
||||
endTime = moment(buyTime).add(7, 'd').endOf('d').toDate()
|
||||
}
|
||||
let playerRecords: ActivityDailyRMBGiftsModelType[] = await ActivityDailyRMBGiftsModel.findRecord(serverId, activityId, roleId, buyTime);
|
||||
|
||||
playerData.setPlayerRecords(playerRecords, endTime);
|
||||
return playerData;
|
||||
}
|
||||
|
||||
/**
|
||||
* 结算购买礼包的奖励
|
||||
*
|
||||
* @param {number} serverId 区Id
|
||||
* @param {number} activityId 活动Id
|
||||
* @param {string} roleId 角色Id
|
||||
* @param {string} productID 商品ID
|
||||
*
|
||||
*/
|
||||
export async function makeDailyRMBGiftsReward(roleId: string, roleName: string, sid: string, serverId: number, funcs: number[],
|
||||
activityId: number, productID: string) {
|
||||
let activityData: ActivityModelType = await ActivityModel.findActivity(activityId, true);
|
||||
let playerData = new DailyRMBGiftsData(activityData);
|
||||
let bigGiftProductID = playerData.productID;
|
||||
if (bigGiftProductID == productID) {//一次性购买7天礼包
|
||||
return { goods: [], addHeros: [] }
|
||||
} else {
|
||||
let item = playerData.findProduct(productID);
|
||||
let rewardParamArr: Array<RewardParam> = stringToRewardParam(item.reward);
|
||||
let result = await addReward(roleId, roleName, sid, serverId, funcs, rewardParamArr)
|
||||
return result
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user