Reformat and clean up event scripts
This commit is contained in:
@@ -21,7 +21,7 @@
|
||||
/**
|
||||
* @author: Ronan
|
||||
* @event: Pink Bean Battle
|
||||
*/
|
||||
*/
|
||||
|
||||
var isPq = true;
|
||||
var minPlayers = 6, maxPlayers = 30;
|
||||
@@ -39,7 +39,7 @@ var eventTime = 140; // 140 minutes
|
||||
const maxLobbies = 1;
|
||||
|
||||
function init() {
|
||||
setEventRequirements();
|
||||
setEventRequirements();
|
||||
}
|
||||
|
||||
function getMaxLobbies() {
|
||||
@@ -47,40 +47,46 @@ function getMaxLobbies() {
|
||||
}
|
||||
|
||||
function setEventRequirements() {
|
||||
var reqStr = "";
|
||||
|
||||
reqStr += "\r\n Number of players: ";
|
||||
if(maxPlayers - minPlayers >= 1) reqStr += minPlayers + " ~ " + maxPlayers;
|
||||
else reqStr += minPlayers;
|
||||
|
||||
reqStr += "\r\n Level range: ";
|
||||
if(maxLevel - minLevel >= 1) reqStr += minLevel + " ~ " + maxLevel;
|
||||
else reqStr += minLevel;
|
||||
|
||||
reqStr += "\r\n Time limit: ";
|
||||
reqStr += eventTime + " minutes";
|
||||
|
||||
em.setProperty("party", reqStr);
|
||||
var reqStr = "";
|
||||
|
||||
reqStr += "\r\n Number of players: ";
|
||||
if (maxPlayers - minPlayers >= 1) {
|
||||
reqStr += minPlayers + " ~ " + maxPlayers;
|
||||
} else {
|
||||
reqStr += minPlayers;
|
||||
}
|
||||
|
||||
reqStr += "\r\n Level range: ";
|
||||
if (maxLevel - minLevel >= 1) {
|
||||
reqStr += minLevel + " ~ " + maxLevel;
|
||||
} else {
|
||||
reqStr += minLevel;
|
||||
}
|
||||
|
||||
reqStr += "\r\n Time limit: ";
|
||||
reqStr += eventTime + " minutes";
|
||||
|
||||
em.setProperty("party", reqStr);
|
||||
}
|
||||
|
||||
function setEventExclusives(eim) {
|
||||
var itemSet = [];
|
||||
eim.setExclusiveItems(itemSet);
|
||||
var itemSet = [];
|
||||
eim.setExclusiveItems(itemSet);
|
||||
}
|
||||
|
||||
function setEventRewards(eim) {
|
||||
var itemSet, itemQty, evLevel, expStages, mesoStages;
|
||||
var itemSet, itemQty, evLevel, expStages, mesoStages;
|
||||
|
||||
evLevel = 1; //Rewards at clear PQ
|
||||
itemSet = [];
|
||||
itemQty = [];
|
||||
eim.setEventRewards(evLevel, itemSet, itemQty);
|
||||
|
||||
expStages = []; //bonus exp given on CLEAR stage signal
|
||||
eim.setEventClearStageExp(expStages);
|
||||
|
||||
mesoStages = []; //bonus meso given on CLEAR stage signal
|
||||
eim.setEventClearStageMeso(mesoStages);
|
||||
evLevel = 1; //Rewards at clear PQ
|
||||
itemSet = [];
|
||||
itemQty = [];
|
||||
eim.setEventRewards(evLevel, itemSet, itemQty);
|
||||
|
||||
expStages = []; //bonus exp given on CLEAR stage signal
|
||||
eim.setEventClearStageExp(expStages);
|
||||
|
||||
mesoStages = []; //bonus meso given on CLEAR stage signal
|
||||
eim.setEventClearStageMeso(mesoStages);
|
||||
}
|
||||
|
||||
function afterSetup(eim) {
|
||||
@@ -93,7 +99,7 @@ function setup(channel) {
|
||||
eim.setProperty("canJoin", 1);
|
||||
eim.setProperty("defeatedBoss", 0);
|
||||
eim.setProperty("fallenPlayers", 0);
|
||||
|
||||
|
||||
eim.setProperty("stage", 1);
|
||||
eim.setProperty("channel", channel);
|
||||
|
||||
@@ -107,11 +113,11 @@ function setup(channel) {
|
||||
var mob = LifeFactory.getMonster(8820000);
|
||||
mob.disableDrops();
|
||||
eim.getInstanceMap(270050100).spawnMonsterOnGroundBelow(mob, new Point(0, -42));
|
||||
|
||||
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
setEventRewards(eim);
|
||||
setEventExclusives(eim);
|
||||
|
||||
|
||||
return eim;
|
||||
}
|
||||
|
||||
@@ -127,12 +133,11 @@ function scheduledTimeout(eim) {
|
||||
|
||||
function changedMap(eim, player, mapid) {
|
||||
if (mapid < minMapId || mapid > maxMapId) {
|
||||
if (eim.isExpeditionTeamLackingNow(true, minPlayers, player)) {
|
||||
if (eim.isExpeditionTeamLackingNow(true, minPlayers, player)) {
|
||||
eim.unregisterPlayer(player);
|
||||
eim.dropMessage(5, "[Expedition] Either the leader has quit the expedition or there is no longer the minimum number of members required to continue it.");
|
||||
end(eim);
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
eim.dropMessage(5, "[Expedition] " + player.getName() + " has left the expedition.");
|
||||
eim.unregisterPlayer(player);
|
||||
}
|
||||
@@ -144,15 +149,15 @@ function changedLeader(eim, leader) {}
|
||||
function playerDead(eim, player) {
|
||||
var count = eim.getIntProperty("fallenPlayers");
|
||||
count = count + 1;
|
||||
|
||||
|
||||
eim.setIntProperty("fallenPlayers", count);
|
||||
|
||||
if(count == 5) {
|
||||
|
||||
if (count == 5) {
|
||||
eim.dropMessage(5, "[Expedition] Too many players have fallen, Pink Bean is now deemed undefeatable; the expedition is over.");
|
||||
end(eim);
|
||||
} else if(count == 4) {
|
||||
} else if (count == 4) {
|
||||
eim.dropMessage(5, "[Expedition] Pink Bean is growing stronger than ever, last stand mode everyone!");
|
||||
} else if(count == 3) {
|
||||
} else if (count == 3) {
|
||||
eim.dropMessage(5, "[Expedition] Casualty count is starting to get out of control. Battle with care.");
|
||||
}
|
||||
}
|
||||
@@ -162,9 +167,9 @@ function playerRevive(eim, player) {
|
||||
}
|
||||
|
||||
function monsterRevive(eim, mob) {
|
||||
if(isPinkBean(mob)) {
|
||||
mob.enableDrops();
|
||||
}
|
||||
if (isPinkBean(mob)) {
|
||||
mob.enableDrops();
|
||||
}
|
||||
}
|
||||
|
||||
function playerDisconnected(eim, player) {
|
||||
@@ -172,16 +177,15 @@ function playerDisconnected(eim, player) {
|
||||
eim.unregisterPlayer(player);
|
||||
eim.dropMessage(5, "[Expedition] Either the leader has quit the expedition or there is no longer the minimum number of members required to continue it.");
|
||||
end(eim);
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
eim.dropMessage(5, "[Expedition] " + player.getName() + " has left the expedition.");
|
||||
eim.unregisterPlayer(player);
|
||||
}
|
||||
}
|
||||
|
||||
function leftParty (eim, player) {}
|
||||
function leftParty(eim, player) {}
|
||||
|
||||
function disbandParty (eim) {}
|
||||
function disbandParty(eim) {}
|
||||
|
||||
function monsterValue(eim, mobId) {
|
||||
return 1;
|
||||
@@ -226,9 +230,9 @@ function noJrBossesLeft(map) {
|
||||
}
|
||||
|
||||
function spawnJrBoss(mobObj, gotKilled) {
|
||||
if(gotKilled) {
|
||||
if (gotKilled) {
|
||||
spawnid = mobObj.getId() + 17;
|
||||
|
||||
|
||||
} else {
|
||||
mobObj.getMap().killMonster(mobObj.getId());
|
||||
spawnid = mobObj.getId() - 17;
|
||||
@@ -240,19 +244,19 @@ function spawnJrBoss(mobObj, gotKilled) {
|
||||
}
|
||||
|
||||
function monsterKilled(mob, eim) {
|
||||
if(isPinkBean(mob)) {
|
||||
if (isPinkBean(mob)) {
|
||||
eim.setIntProperty("defeatedBoss", 1);
|
||||
eim.showClearEffect(mob.getMap().getId());
|
||||
mob.getMap().killAllMonsters();
|
||||
eim.clearPQ();
|
||||
|
||||
|
||||
var ch = eim.getIntProperty("channel");
|
||||
mob.getMap().broadcastPinkBeanVictory(ch);
|
||||
} else if(isJrBoss(mob)) {
|
||||
if(noJrBossesLeft(mob.getMap())) {
|
||||
} else if (isJrBoss(mob)) {
|
||||
if (noJrBossesLeft(mob.getMap())) {
|
||||
var stage = eim.getIntProperty("stage");
|
||||
|
||||
if(stage == 5) {
|
||||
|
||||
if (stage == 5) {
|
||||
var iid = 4001193;
|
||||
const Item = Java.type('client.inventory.Item');
|
||||
var itemObj = new Item(iid, 0, 1);
|
||||
@@ -266,19 +270,19 @@ function monsterKilled(mob, eim) {
|
||||
} else {
|
||||
stage++;
|
||||
eim.setIntProperty("stage", stage);
|
||||
|
||||
|
||||
eim.dropMessage(5, "The next wave will start within 15 seconds, prepare yourselves.");
|
||||
eim.schedule("startWave", 15 * 1000);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function startWave(eim) {
|
||||
var mapObj = eim.getMapInstance(270050100);
|
||||
var stage = eim.getProperty("stage");
|
||||
|
||||
for(var i = 1; i <= stage; i++) {
|
||||
|
||||
for (var i = 1; i <= stage; i++) {
|
||||
spawnJrBoss(mapObj.getMonsterById(8820019 + (i % 5)), false);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user