From 94103b342d3f526a38dfd75cf57aabf3b3318e10 Mon Sep 17 00:00:00 2001 From: luying Date: Tue, 26 Apr 2022 22:01:56 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BB=BB=E5=8A=A1=EF=BC=9A=E4=BF=AE=E5=A4=8D?= =?UTF-8?q?=E7=BB=93=E7=AE=97=E6=9C=AA=E6=88=90=E5=8A=9F=E4=B9=9F=E8=BE=BE?= =?UTF-8?q?=E6=88=90=E7=9A=84=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../battle/handler/normalBattleHandler.ts | 2 +- game-server/app/services/task/taskService.ts | 34 ++++++++++--------- 2 files changed, 19 insertions(+), 17 deletions(-) diff --git a/game-server/app/servers/battle/handler/normalBattleHandler.ts b/game-server/app/servers/battle/handler/normalBattleHandler.ts index ae34687c0..c048b6710 100644 --- a/game-server/app/servers/battle/handler/normalBattleHandler.ts +++ b/game-server/app/servers/battle/handler/normalBattleHandler.ts @@ -275,7 +275,7 @@ export class NormalBattleHandler { let actordata = await roleLevelup(KING_EXP_RATIO_TYPE.BATTLE, roleId, isSuccess ? warInfo.kingExp : 0, session);// 主公升级经验 - await checkTaskInBattleEnd(serverId, roleId, sid, battleId, dbHeroes, newStar); + await checkTaskInBattleEnd(serverId, roleId, sid, battleId, dbHeroes, newStar, isSuccess); // 返回值: // towerStatus: false-本层未通过, true-本层已通过 return resResult(STATUS.SUCCESS, { diff --git a/game-server/app/services/task/taskService.ts b/game-server/app/services/task/taskService.ts index 322d36c66..4246bcd8a 100644 --- a/game-server/app/services/task/taskService.ts +++ b/game-server/app/services/task/taskService.ts @@ -110,22 +110,24 @@ export async function checkTaskInGuildTrain(serverId: number, roleId: string, si /** * battle.normalBattleHandler.battleEnd 中会触发的任务,因为有点多提出来了 */ - export async function checkTaskInBattleEnd(serverId: number, roleId: string, sid: string, warId: number, battleHeroes: number[], battleStar: number) { - let task = new CheckTask(serverId, roleId); - task.setParam(TASK_TYPE.BATTLE_WITH_HERO, { warId, battleHeroes }); - task.setParam(TASK_TYPE.BATTLE_MAIN, { warId, count: 1 }); - task.setParam(TASK_TYPE.BATTLE_DAILY_STAR, { warId, battleStar }); - task.setParam(TASK_TYPE.BATTLE_DAILY, { warId, count: 1 }); - task.setParam(TASK_TYPE.BATTLE_DUNGEON, { warId, count: 1 }); - task.setParam(TASK_TYPE.BATTLE_DUNGEON_WAR, { warId, count: 1 }); - task.setParam(TASK_TYPE.BATTLE_TOWER, { warId, count: 1 }); - task.setParam(TASK_TYPE.BATTLE_VESTIGE, { warId, count: 1 }); - task.setParam(TASK_TYPE.BATTLE_EXPEDITION, { warId, count: 1 }); - task.setParam(TASK_TYPE.BATTLE_MAIN_ELITE, { warId, count: 1 }); - await task.saveAndPush(sid); - let dicWar = gameData.war.get(warId); - if(dicWar && dicWar.warType == WAR_TYPE.NORMAL) { - checkPopUpCondition(serverId, roleId, POP_UP_SHOP_CONDITION_TYPE.MAIN_BATTLE, { warId }, sid); + export async function checkTaskInBattleEnd(serverId: number, roleId: string, sid: string, warId: number, battleHeroes: number[], battleStar: number, isSuccess: boolean) { + if(isSuccess) { + let task = new CheckTask(serverId, roleId); + task.setParam(TASK_TYPE.BATTLE_WITH_HERO, { warId, battleHeroes }); + task.setParam(TASK_TYPE.BATTLE_MAIN, { warId, count: 1 }); + task.setParam(TASK_TYPE.BATTLE_DAILY_STAR, { warId, battleStar }); + task.setParam(TASK_TYPE.BATTLE_DAILY, { warId, count: 1 }); + task.setParam(TASK_TYPE.BATTLE_DUNGEON, { warId, count: 1 }); + task.setParam(TASK_TYPE.BATTLE_DUNGEON_WAR, { warId, count: 1 }); + task.setParam(TASK_TYPE.BATTLE_TOWER, { warId, count: 1 }); + task.setParam(TASK_TYPE.BATTLE_VESTIGE, { warId, count: 1 }); + task.setParam(TASK_TYPE.BATTLE_EXPEDITION, { warId, count: 1 }); + task.setParam(TASK_TYPE.BATTLE_MAIN_ELITE, { warId, count: 1 }); + await task.saveAndPush(sid); + let dicWar = gameData.war.get(warId); + if(dicWar && dicWar.warType == WAR_TYPE.NORMAL) { + checkPopUpCondition(serverId, roleId, POP_UP_SHOP_CONDITION_TYPE.MAIN_BATTLE, { warId }, sid); + } } }