活动:新手签到活动
This commit is contained in:
@@ -1,7 +1,8 @@
|
||||
import moment = require('moment');
|
||||
import { ACTIVITY_TYPE, SERVER_OPEN_TIME, SIGNIN_VIP_OPEN_LIMIT, STATUS } from '../consts';
|
||||
import { ACTIVITY_TYPE, NEW_PLAYER_SIGIN_DAYS, SERVER_OPEN_TIME, SIGNIN_VIP_OPEN_LIMIT, STATUS } from '../consts';
|
||||
import { ActivityModel, ActivityModelType } from '../db/Activity';
|
||||
import { ActivitySignInModel, ActivitySignInModelType } from '../db/ActivitySignIn';
|
||||
import { RoleModel } from '../db/Role';
|
||||
import { ServerlistModel } from '../db/Serverlist';
|
||||
import { SignInData, SignInItem } from '../domain/activityField/signInField';
|
||||
|
||||
@@ -22,8 +23,8 @@ export async function signInActivity(serverId: number, roleId: string) {
|
||||
}
|
||||
let activityData = activityArray[0];
|
||||
let playerData = new SignInData(activityData);
|
||||
let todayIndex = moment(new Date()).date();
|
||||
if (todayIndex < playerData.startDate || todayIndex > playerData.endDate) {//未开启
|
||||
let curDate = moment(new Date()).valueOf();
|
||||
if (curDate < playerData.beginTime || curDate > playerData.beginTime) {//未开启
|
||||
return null;
|
||||
}
|
||||
let playerRecords: ActivitySignInModelType = await ActivitySignInModel.findData(activityData.activityId, roleId, playerData.roundIndex);
|
||||
@@ -49,8 +50,8 @@ export async function signInVIPActivity(serverId: number, roleId: string) {
|
||||
let activityData = activityArray[0];
|
||||
let playerData = new SignInData(activityData);
|
||||
|
||||
let todayIndex = moment(new Date()).date();
|
||||
if (todayIndex < playerData.startDate || todayIndex > playerData.endDate) {//未开启
|
||||
let curDate = moment(new Date()).valueOf();
|
||||
if (curDate < playerData.beginTime || curDate > playerData.beginTime) {//未开启
|
||||
return null;
|
||||
}
|
||||
|
||||
@@ -59,6 +60,41 @@ export async function signInVIPActivity(serverId: number, roleId: string) {
|
||||
return playerData;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取活动数据
|
||||
*
|
||||
* @param {number} type 新手签到
|
||||
* @param {number} serverId 区Id
|
||||
* @param {number} activityId 活动Id
|
||||
* @param {string} roleId 角色Id
|
||||
*
|
||||
*/
|
||||
export async function newPlayerSignInActivity(serverId: number, roleId: string) {
|
||||
let { createTime } = await RoleModel.findByRoleId(roleId);
|
||||
let betinTime = moment(createTime).startOf('d').toDate();
|
||||
let endTime = moment(betinTime).add(NEW_PLAYER_SIGIN_DAYS - 1, 'd').endOf('d').toDate()
|
||||
let curDate = new Date()
|
||||
if (curDate > endTime) {
|
||||
return null;
|
||||
}
|
||||
|
||||
let { activityGroupId } = await ServerlistModel.findByServerId(serverId);
|
||||
let activityArray: ActivityModelType[] = await ActivityModel.findOpenActivityByType(activityGroupId, ACTIVITY_TYPE.NEW_PLAYER_SIGN_IN, new Date());
|
||||
if (activityArray.length == 0) {
|
||||
return null;
|
||||
}
|
||||
let activityData = activityArray[0];
|
||||
let playerData = new SignInData(activityData);
|
||||
playerData.setNewPlayerDate(betinTime, endTime);
|
||||
let curDateStamp = moment(new Date()).valueOf();
|
||||
if (curDateStamp < playerData.beginTime || curDateStamp > playerData.beginTime) {//未开启
|
||||
return null;
|
||||
}
|
||||
let playerRecords: ActivitySignInModelType = await ActivitySignInModel.findData(activityData.activityId, roleId, playerData.roundIndex);
|
||||
playerData.setPlayerRecords(playerRecords);
|
||||
return playerData;
|
||||
}
|
||||
|
||||
/**
|
||||
* 玩家活动数据
|
||||
*
|
||||
@@ -69,14 +105,19 @@ export async function signInVIPActivity(serverId: number, roleId: string) {
|
||||
*/
|
||||
export async function getPlayerSignInData(activityId: number, serverId: number, roleId: string) {
|
||||
let activityData: ActivityModelType = await ActivityModel.findActivity(activityId);
|
||||
if (activityData.type !== ACTIVITY_TYPE.SIGN_IN_VIP && activityData.type !== ACTIVITY_TYPE.SIGN_IN) {
|
||||
if (activityData.type !== ACTIVITY_TYPE.SIGN_IN_VIP && activityData.type !== ACTIVITY_TYPE.SIGN_IN && activityData.type !== ACTIVITY_TYPE.NEW_PLAYER_SIGN_IN) {
|
||||
return null;
|
||||
}
|
||||
let playerData = new SignInData(activityData);
|
||||
let playerRecords: ActivitySignInModelType = await ActivitySignInModel.findData(activityId, roleId, playerData.roundIndex);
|
||||
|
||||
playerData.setPlayerRecords(playerRecords);
|
||||
|
||||
if (playerData.type === ACTIVITY_TYPE.NEW_PLAYER_SIGN_IN) {
|
||||
let { createTime } = await RoleModel.findByRoleId(roleId);
|
||||
let betinTime = moment(createTime * 1000).startOf('d').toDate();
|
||||
let endTime = moment(betinTime).add(NEW_PLAYER_SIGIN_DAYS - 1, 'd').endOf('d').toDate()
|
||||
playerData.setNewPlayerDate(betinTime, endTime)
|
||||
}
|
||||
return playerData;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user