活动:月卡权限
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
import { ACTIVITY_TYPE, ITEM_CHANGE_REASON, MAIL_TYPE, STATUS } from '../../consts';
|
||||
import { ACTIVITY_TYPE, HANG_UP_CONSTS, ITEM_CHANGE_REASON, MAIL_TYPE, STATUS } from '../../consts';
|
||||
import { ActivityModel, ActivityModelType } from '../../db/Activity';
|
||||
import { ActivityMonthlyTicketModel, ActivityMonthlyTicketModelType } from '../../db/ActivityMonthlyTicket';
|
||||
import { RewardParam } from '../../domain/activityField/rewardField';
|
||||
@@ -7,8 +7,12 @@ import { addReward, stringToRewardInter, stringToRewardParam } from './giftPacka
|
||||
import moment = require('moment');
|
||||
import { ServerlistModel } from '../../db/Serverlist';
|
||||
import { sendMailByContent } from './../mailService';
|
||||
import { RoleModel } from '../../db/Role';
|
||||
import { RoleModel, RoleType } from '../../db/Role';
|
||||
import { getActivityById } from './activityService';
|
||||
import { RewardInter } from '../../pubUtils/interface';
|
||||
import { getGoldId } from '../../pubUtils/itemUtils';
|
||||
import { DUNGEON_CONST, PVP, VIP } from '../../pubUtils/dicParam';
|
||||
import { cal } from '../../pubUtils/util';
|
||||
|
||||
/**
|
||||
* 获取活动数据
|
||||
@@ -115,10 +119,10 @@ export async function makeMonthlyTicketReward(roleId: string, roleName: string,
|
||||
let { createTime } = await RoleModel.findByRoleId(roleId);
|
||||
let playerData = new MonthlyTicketData(activityData, createTime);
|
||||
|
||||
let endTime = moment(new Date()).startOf('d').add(playerData.days, 'day').toDate();
|
||||
let endTime = playerData.isForever? moment(new Date()).startOf('d').add(playerData.days, 'day').toDate(): null;
|
||||
console.log('endTime', moment(new Date()).startOf('d'), endTime, playerData.days)
|
||||
await ActivityMonthlyTicketModel.buyMonthlyTicket(serverId, roleId, activityId, activityData.type, endTime)
|
||||
|
||||
await ActivityMonthlyTicketModel.buyMonthlyTicket(serverId, roleId, activityId, activityData.type, endTime, playerData.isForever)
|
||||
await RoleModel.buyForeverTicket(roleId);
|
||||
let firstReward = playerData.firstReward;
|
||||
let rewardParamArr: Array<RewardParam> = stringToRewardParam(firstReward);
|
||||
let result = await addReward(roleId, roleName, sid, serverId, rewardParamArr, ITEM_CHANGE_REASON.MONTHLY_TICKET_FIRST)
|
||||
@@ -127,3 +131,75 @@ export async function makeMonthlyTicketReward(roleId: string, roleName: string,
|
||||
data: Object.assign(result, { item: { isOpen: true, todayIndex: 1 }, activityId: activityData.activityId })
|
||||
}
|
||||
}
|
||||
|
||||
// 月卡权限
|
||||
|
||||
// 军团捐献消耗
|
||||
export function getVipDonateConsume(originConsume: RewardInter, vipStartTime: number) {
|
||||
if(vipStartTime > 0) {
|
||||
if(originConsume.id == getGoldId()) {
|
||||
return [{ id: originConsume.id, count: Math.floor(originConsume.count * VIP.VIP_GUILD_DONATE_COST_GOLD_RATIO) }];
|
||||
} else {
|
||||
return [originConsume];
|
||||
}
|
||||
} else {
|
||||
return [originConsume];
|
||||
}
|
||||
}
|
||||
|
||||
export function getVipHungupReward(startTime: number, endTime: number, baseReward: RewardInter[], notReceivedGoods: {gid: number, count: number}[], vipStartTime: number) {
|
||||
let multi = Math.floor((endTime - startTime) / HANG_UP_CONSTS.UNIT_TIME);
|
||||
if(vipStartTime > 0) {
|
||||
if(vipStartTime > startTime) { // 开始挂机之后买的月卡
|
||||
let isNotVipNum = Math.floor((vipStartTime - startTime) / HANG_UP_CONSTS.UNIT_TIME); // 不是vip的时间段数
|
||||
let isVipNum = multi - isNotVipNum; // 是vip的时间段数
|
||||
multi = cal.add(isNotVipNum, cal.mul(isVipNum, VIP.VIP_TOWER_HUNG_UP_RATIO));
|
||||
} else {
|
||||
multi = cal.mul(multi, VIP.VIP_TOWER_HUNG_UP_RATIO);
|
||||
}
|
||||
}
|
||||
|
||||
let needReceiveGoods: {gid: number, count: number}[] = [];// 由于小数,未能领取的奖励
|
||||
let timeReward: {id: number, count: number}[] = []; // 本次奖励
|
||||
for (let { id, count } of baseReward) {
|
||||
let newCount = cal.mul(count, multi);
|
||||
let oldGoods = notReceivedGoods.find(cur => cur.gid == id);
|
||||
if (oldGoods) newCount = cal.add(newCount, oldGoods.count);
|
||||
let roundCount = Math.floor(newCount);
|
||||
if (newCount > roundCount) {
|
||||
needReceiveGoods.push({ gid: id, count: cal.sub(newCount, roundCount) });
|
||||
}
|
||||
if (roundCount > 0) {
|
||||
timeReward.push({ id, count: roundCount })
|
||||
}
|
||||
}
|
||||
return { needReceiveGoods, timeReward }
|
||||
}
|
||||
|
||||
export async function getVipPvpChallengeMaxCnt(roleId: string, vipStartTime?: number) {
|
||||
if(vipStartTime == undefined) {
|
||||
let role = await RoleModel.findByRoleId(roleId, 'vipStartTime');
|
||||
vipStartTime = role.vipStartTime;
|
||||
}
|
||||
let count = PVP.PVP_CHALLENGE_COUNTS;
|
||||
if(vipStartTime > 0) {
|
||||
count += VIP.VIP_PVP_CHALLENGE_COUNTS_ADD;
|
||||
}
|
||||
return count;
|
||||
}
|
||||
|
||||
export function getVipDailyCnt(timesPerDay: number, role: RoleType) {
|
||||
let vipStartTime = role.vipStartTime;
|
||||
if(vipStartTime > 0) {
|
||||
timesPerDay += VIP.VIP_DAILY_TIMERS_PER_DAY_ADD;
|
||||
}
|
||||
return timesPerDay
|
||||
}
|
||||
|
||||
export function getVipDungeonCnt(vipStartTime: number) {
|
||||
let count = DUNGEON_CONST.DUNGEON_CONST_FREE;
|
||||
if(vipStartTime > 0) {
|
||||
count += VIP.VIP_DUNGEON_CONST_FREE_ADD;
|
||||
}
|
||||
return count
|
||||
}
|
||||
Reference in New Issue
Block a user