Code Coupons + Worldmap update + Mini-games + Player Interaction wrap
Fixed several cases on the Cash Shop that would freeze some player actions when triggered, requiring exit Cash Shop to unstuck. Implemented Code Coupons, supporting several items bundled on the same code, and also devised a way to automate code generation. Added a current status on-demand option on the Buyback command. Info such as "current fee" or "time remaining" are available now. Reviewed several cases where non-owned items would get stacked with owner-tagged items. Added Door support for Happyville, Crimsonwood Keep. Added worldmap tooltip support for some maps in Masteria's C. Keep and H. House. Added Masteria region to the world map. C. Keep interiors no longer relocates players to entrance after actions such as logout. Overhauled minigame mechanics: from player boxes tooltip and in-match improvements to deploy different minigame types, accordingly with item description or player choice. Fixed Amoria outskirts not relocating players to city after getting KO'ed. Fixed issues with pets, rings and cash items being assigned the same cash unique ids leading to some quirks on the cash shop inventory. Fixed an issue with the recently added HP/MP ratio update, arbitrarily taking off 1 point in certain cases. Answer positions on the explorer's 3rd job quiz are now randomed. Fixed several issues that showed up when the bcrypt system is disabled. DOT from maps such as El Nath and Aqua Road now procs at a 5sec interval, GMS-like. Improved performance of Whodrops and Search commands. Concurrently protected player interaction handlers, thus mitigating several exploits on these lines. Adjusted several expedition timers, such as Horntail, now having a more sane deadline. Concurrently protected chair modules. Fixed "seduce" debuff not working on chairs.
This commit is contained in:
@@ -47,7 +47,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 0);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -47,7 +47,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 0);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -62,7 +62,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 0);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -47,7 +47,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 0);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -47,7 +47,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 0);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -47,7 +47,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 0);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -58,7 +58,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(map, map.getPortal(0));
|
||||
|
||||
//TODO: hold time across map changes
|
||||
//player.getClient().getSession().write(tools.MaplePacketCreator.getClock(1800));
|
||||
//player.getClient().announce(tools.MaplePacketCreator.getClock(1800));
|
||||
}
|
||||
|
||||
function playerDead(eim, player) {
|
||||
|
||||
@@ -53,7 +53,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 2);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -54,7 +54,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 1);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -29,7 +29,7 @@ var exitMap = 105100100;
|
||||
var minMapId = 910520000;
|
||||
var maxMapId = 910520000;
|
||||
|
||||
var eventTime = 10; //10 minutes
|
||||
var eventTime = 10; //10 minutes
|
||||
|
||||
var lobbyRange = [0, 0];
|
||||
|
||||
@@ -56,7 +56,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 1);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -26,7 +26,7 @@ importPackage(Packages.tools);
|
||||
|
||||
var entryMap = 922000010;
|
||||
var exitMap = 221024400;
|
||||
var eventTime = 10; //10 minutes
|
||||
var eventTime = 10; //10 minutes
|
||||
|
||||
function init() {
|
||||
em.setProperty("noEntry","false");
|
||||
@@ -39,7 +39,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(entryMap, 0);
|
||||
em.setProperty("noEntry","true");
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -237,7 +237,7 @@ function changedMap(eim, player, mapid) {
|
||||
function afterChangedMap(eim, player, mapid) {
|
||||
if (mapid == 990000100) {
|
||||
var texttt = "So, here is the brief. You guys should be warned that, once out on the fortress outskirts, anyone that would not be equipping the #b#t1032033##k will die instantly due to the deteriorated state of the air around there. That being said, once your team moves out, make sure to #bhit the glowing rocks#k in that region and #bequip the dropped item#k before advancing stages. That will protect you thoroughly from the air sickness. Good luck!";
|
||||
player.getClient().getSession().write(Packages.tools.MaplePacketCreator.getNPCTalk(9040000, /*(byte)*/ 0, texttt, "00 00", /*(byte)*/ 0));
|
||||
player.getClient().announce(Packages.tools.MaplePacketCreator.getNPCTalk(9040000, /*(byte)*/ 0, texttt, "00 00", /*(byte)*/ 0));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -34,7 +34,7 @@ function playerEntry(eim, player) {
|
||||
onRide = eim.getMapFactory().getMap(birdRide[myRide]);
|
||||
player.changeMap(onRide, onRide.getPortal(0));
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(rideTime / 1000));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(rideTime / 1000));
|
||||
eim.schedule("timeOut", rideTime);
|
||||
}
|
||||
|
||||
|
||||
@@ -36,7 +36,7 @@ var clearMap = 240050600;
|
||||
var minMapId = 240060000;
|
||||
var maxMapId = 240060200;
|
||||
|
||||
var eventTime = 15; // 15 minutes
|
||||
var eventTime = 120; // 120 minutes
|
||||
|
||||
var lobbyRange = [0, 0];
|
||||
|
||||
|
||||
@@ -35,8 +35,8 @@ function playerEntry(eim, player) {
|
||||
onRide = eim.getMapFactory().getMap(trainRide[myRide]);
|
||||
player.changeMap(onRide, onRide.getPortal(0));
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(rideTime / 1000));
|
||||
player.getClient().getSession().write(MaplePacketCreator.earnTitleMessage("The next stop is at Kerning " + (myRide == 0 ? "Square" : "Subway") + " Station. The exit is to your left."));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(rideTime / 1000));
|
||||
player.getClient().announce(MaplePacketCreator.earnTitleMessage("The next stop is at Kerning " + (myRide == 0 ? "Square" : "Subway") + " Station. The exit is to your left."));
|
||||
eim.schedule("timeOut", rideTime);
|
||||
}
|
||||
|
||||
|
||||
@@ -2,7 +2,7 @@ importPackage(Packages.tools);
|
||||
importPackage(Packages.server.life);
|
||||
|
||||
var minPlayers = 1;
|
||||
var eventTime = 10;
|
||||
var eventTime = 10; // 10 minutes
|
||||
var entryMap = 106021402;
|
||||
var exitMap = 106021600;
|
||||
|
||||
@@ -36,7 +36,7 @@ function playerEntry(eim, player){
|
||||
var pm = MapleLifeFactory.getMonster(3300008);
|
||||
weddinghall.spawnMonsterOnGroundBelow(pm, new Packages.java.awt.Point(472, 27));
|
||||
|
||||
player.getClient().getSession().write(MaplePacketCreator.getClock(eventTime * 60));
|
||||
player.getClient().announce(MaplePacketCreator.getClock(eventTime * 60));
|
||||
eim.startEventTimer(eventTime * 60000);
|
||||
}
|
||||
|
||||
|
||||
@@ -180,7 +180,7 @@ function playerEntry(eim, player) {
|
||||
player.changeMap(map, map.getPortal(0));
|
||||
|
||||
var texttt = "Hi, my name is Eak, the Chamberlain of the Goddess. Don't be alarmed; you won't be able to see me right now. Back when the Goddess turned into a block of stone, I simultaneously lost my own power. If you gather up the power of the Magic Cloud of Orbis, however, then I'll be able to recover my body and re-transform back to my original self. Please collect #b20#k Magic Clouds and bring them back to me. Right now, you'll only see me as a tiny, flickering light.";
|
||||
player.getClient().getSession().write(Packages.tools.MaplePacketCreator.getNPCTalk(2013001, /*(byte)*/ 0, texttt, "00 00", /*(byte)*/ 0));
|
||||
player.getClient().announce(Packages.tools.MaplePacketCreator.getNPCTalk(2013001, /*(byte)*/ 0, texttt, "00 00", /*(byte)*/ 0));
|
||||
}
|
||||
|
||||
function scheduledTimeout(eim) {
|
||||
|
||||
@@ -37,7 +37,7 @@ var clearMap = 270050300;
|
||||
var minMapId = 270050100;
|
||||
var maxMapId = 270050300;
|
||||
|
||||
var eventTime = 100; // 100 minutes
|
||||
var eventTime = 140; // 140 minutes
|
||||
|
||||
var lobbyRange = [0, 0];
|
||||
|
||||
|
||||
@@ -22,7 +22,7 @@
|
||||
importPackage(Packages.tools);
|
||||
|
||||
var exitMap;
|
||||
var startMap;
|
||||
var entryMap;
|
||||
var otherMap;
|
||||
var minPlayers = 1;
|
||||
var fightTime = 60;
|
||||
@@ -30,7 +30,7 @@ var timer = 1000 * 60 * fightTime;
|
||||
|
||||
function init() {
|
||||
exitMap = em.getChannelServer().getMapFactory().getMap(103040400);
|
||||
startMap = em.getChannelServer().getMapFactory().getMap(103040410);
|
||||
entryMap = em.getChannelServer().getMapFactory().getMap(103040410);
|
||||
otherMap = em.getChannelServer().getMapFactory().getMap(103040420);
|
||||
}
|
||||
|
||||
@@ -44,7 +44,7 @@ function setup() {
|
||||
function afterSetup(eim) {}
|
||||
|
||||
function respawn(eim) {
|
||||
var map = eim.getMapInstance(startMap.getId());
|
||||
var map = eim.getMapInstance(entryMap.getId());
|
||||
var map2 = eim.getMapInstance(otherMap.getId());
|
||||
map.allowSummonState(true);
|
||||
map2.allowSummonState(true);
|
||||
@@ -55,7 +55,7 @@ function respawn(eim) {
|
||||
|
||||
|
||||
function playerEntry(eim, player) {
|
||||
var amplifierMap = eim.getMapInstance(startMap.getId());
|
||||
var amplifierMap = eim.getMapInstance(entryMap.getId());
|
||||
player.changeMap(amplifierMap);
|
||||
eim.schedule("timeOut", timer);
|
||||
}
|
||||
@@ -107,7 +107,7 @@ function playerExit(eim, player) {
|
||||
function moveMap(eim, player) {
|
||||
if (player.getMap().getId() == exitMap.getId()) {
|
||||
removePlayer(eim, player);
|
||||
player.getClient().getSession().write(MaplePacketCreator.removeClock());
|
||||
player.getClient().announce(MaplePacketCreator.removeClock());
|
||||
eim.dispose();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -22,7 +22,7 @@
|
||||
importPackage(Packages.tools);
|
||||
|
||||
var exitMap;
|
||||
var startMap;
|
||||
var entryMap;
|
||||
var otherMap;
|
||||
var minPlayers = 1;
|
||||
var fightTime = 30;
|
||||
@@ -30,7 +30,7 @@ var timer = 1000 * 60 * fightTime;
|
||||
|
||||
function init() {
|
||||
exitMap = em.getChannelServer().getMapFactory().getMap(103040400);
|
||||
startMap = em.getChannelServer().getMapFactory().getMap(103040440);
|
||||
entryMap = em.getChannelServer().getMapFactory().getMap(103040440);
|
||||
otherMap = em.getChannelServer().getMapFactory().getMap(103040450);
|
||||
}
|
||||
|
||||
@@ -44,7 +44,7 @@ function setup() {
|
||||
function afterSetup(eim) {}
|
||||
|
||||
function respawn(eim) {
|
||||
var map = eim.getMapInstance(startMap.getId());
|
||||
var map = eim.getMapInstance(entryMap.getId());
|
||||
var map2 = eim.getMapInstance(otherMap.getId());
|
||||
map.allowSummonState(true);
|
||||
map2.allowSummonState(true);
|
||||
@@ -55,7 +55,7 @@ function respawn(eim) {
|
||||
|
||||
|
||||
function playerEntry(eim, player) {
|
||||
var amplifierMap = eim.getMapInstance(startMap.getId());
|
||||
var amplifierMap = eim.getMapInstance(entryMap.getId());
|
||||
player.changeMap(amplifierMap);
|
||||
eim.schedule("timeOut", timer);
|
||||
}
|
||||
@@ -107,7 +107,7 @@ function playerExit(eim, player) {
|
||||
function moveMap(eim, player) {
|
||||
if (player.getMap().getId() == exitMap.getId()) {
|
||||
removePlayer(eim, player);
|
||||
player.getClient().getSession().write(MaplePacketCreator.removeClock());
|
||||
player.getClient().announce(MaplePacketCreator.removeClock());
|
||||
eim.dispose();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -36,7 +36,7 @@ var clearMap = 211042400;
|
||||
var minMapId = 280030000;
|
||||
var maxMapId = 280030000;
|
||||
|
||||
var eventTime = 60; // 60 minutes
|
||||
var eventTime = 120; // 120 minutes
|
||||
|
||||
var lobbyRange = [0, 0];
|
||||
|
||||
|
||||
@@ -3,7 +3,7 @@
|
||||
function start(ms) {
|
||||
//var pq = ms.getPyramid();
|
||||
//ms.getPlayer().resetEnteredScript();
|
||||
//ms.getClient().getSession().write(MaplePacketCreator.getClock(pq.timer()));
|
||||
//ms.getClient().announce(MaplePacketCreator.getClock(pq.timer()));
|
||||
}
|
||||
/*
|
||||
killing/first/stage
|
||||
|
||||
@@ -29,11 +29,11 @@ var player;
|
||||
function start(ms) {
|
||||
player = ms.getPlayer();
|
||||
player.resetEnteredScript();
|
||||
ms.getClient().getSession().write(MaplePacketCreator.showEffect("event/space/start"));
|
||||
ms.getClient().announce(MaplePacketCreator.showEffect("event/space/start"));
|
||||
player.startMapEffect("Please rescue Gaga within the time limit.", 5120027);
|
||||
var map = player.getMap();
|
||||
if (map.getTimeLeft() > 0) {
|
||||
ms.getClient().getSession().write(MaplePacketCreator.getClock(map.getTimeLeft()));
|
||||
ms.getClient().announce(MaplePacketCreator.getClock(map.getTimeLeft()));
|
||||
} else {
|
||||
map.addMapTimer(180);
|
||||
}
|
||||
|
||||
@@ -21,13 +21,14 @@ function action(mode, type, selection) {
|
||||
if(status == 0){
|
||||
cm.sendYesNo("Would you like to leave?");
|
||||
}else if(status == 1){
|
||||
var mapid = cm.getMapId();
|
||||
if(mapid == 108010101) cm.getPlayer().changeMap(105040305);
|
||||
else if(mapid == 108010201) cm.getPlayer().changeMap(100040106);
|
||||
else if(mapid == 108010301) cm.getPlayer().changeMap(105070001);
|
||||
else if(mapid == 108010401) cm.getPlayer().changeMap(107000402);
|
||||
else if(mapid == 108010501) cm.getPlayer().changeMap(105070200);
|
||||
var mapid = cm.getMapId(), exitid = mapid;
|
||||
if(mapid == 108010101) exitid = 105040305;
|
||||
else if(mapid == 108010201) exitid = 100040106;
|
||||
else if(mapid == 108010301) exitid = 105070001;
|
||||
else if(mapid == 108010401) exitid = 107000402;
|
||||
else if(mapid == 108010501) exitid = 105070200;
|
||||
|
||||
if (mapid != exitid) cm.getPlayer().changeMap(exitid);
|
||||
cm.dispose();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -92,7 +92,7 @@ function action(mode, type, selection){
|
||||
else if (status == 2) {
|
||||
if (cm.getPlayer().getRemainingSp() > 0)
|
||||
if (cm.getPlayer().getRemainingSp() > (cm.getLevel() - 70) * 3) {
|
||||
cm.sendNext("Please, use all your SP before contining.");
|
||||
cm.sendNext("Please, use all your SP before continuing.");
|
||||
cm.dispose();
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -64,7 +64,7 @@ function action(mode, type, selection){
|
||||
else if (status == 2) {
|
||||
if (cm.getPlayer().getRemainingSp() > 0)
|
||||
if (cm.getPlayer().getRemainingSp() > (cm.getLevel() - 70) * 3) {
|
||||
cm.sendNext("Please, use all your SP before contining.");
|
||||
cm.sendNext("Please, use all your SP before continuing.");
|
||||
cm.dispose();
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -66,7 +66,7 @@ function action(mode, type, selection){
|
||||
else if (status == 2) {
|
||||
if (cm.getPlayer().getRemainingSp() > 0)
|
||||
if (cm.getPlayer().getRemainingSp() > (cm.getLevel() - 70) * 3) {
|
||||
cm.sendNext("Please, use all your SP before contining.");
|
||||
cm.sendNext("Please, use all your SP before continuing.");
|
||||
cm.dispose();
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -64,7 +64,7 @@ function action(mode, type, selection){
|
||||
else if (status == 2) {
|
||||
if (cm.getPlayer().getRemainingSp() > 0)
|
||||
if (cm.getPlayer().getRemainingSp() > (cm.getLevel() - 70) * 3) {
|
||||
cm.sendNext("Please, use all your SP before contining.");
|
||||
cm.sendNext("Please, use all your SP before continuing.");
|
||||
cm.dispose();
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -64,7 +64,7 @@ function action(mode, type, selection){
|
||||
else if (status == 2) {
|
||||
if (cm.getPlayer().getRemainingSp() > 0)
|
||||
if (cm.getPlayer().getRemainingSp() > (cm.getLevel() - 70) * 3) {
|
||||
cm.sendNext("Please, use all your SP before contining.");
|
||||
cm.sendNext("Please, use all your SP before continuing.");
|
||||
cm.dispose();
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -39,7 +39,7 @@ var questionTree = [
|
||||
//Questions Related to MONSTERS
|
||||
["Green Mushroom, Tree Stump, Bubbling, Axe Stump, Octopus, which is highest level of all?", ["Tree Stump", "Bubbling", "Axe Stump", "Octopus", "Green Mushroom"], 2],
|
||||
["Which monster will be seen during the ship trip to Orbis/Ellinia?", ["Werewolf", "Slime", "Crimson Balrog", "Zakum", "Star Pixie"], 2],
|
||||
["Maple Island doesn't have which following monsters?", ["Shroom", "Blue Snail", "Orange Mushroom", "Red Snail", "Pig"], 4],
|
||||
["Maple Island doesn't have which following monsters?", ["Green Mushroom", "Blue Snail", "Orange Mushroom", "Red Snail", "Pig"], 0],
|
||||
["Which monster is not at Victoria Island and Sleepywood?", ["Evil Eye", "Sentinel", "Jr. Balrog", "Ghost Stump", "Snail"], 1],
|
||||
["El Nath doesn't have which following monsters?", ["Dark Yeti", "Dark Ligator", "Yeti & Pepe", "Bain", "Coolie Zombie"], 1],
|
||||
["Which of following monsters can fly?", ["Malady", "Ligator", "Cold Eye", "Meerkat", "Alishar"], 0],
|
||||
@@ -80,6 +80,8 @@ var question;
|
||||
var questionPool;
|
||||
var questionPoolCursor;
|
||||
|
||||
var questionAnswer;
|
||||
|
||||
function start() {
|
||||
status = -1;
|
||||
action(1, 0, 0);
|
||||
@@ -121,7 +123,10 @@ function action(mode, type, selection) {
|
||||
question = fetchNextQuestion();
|
||||
var questionHead = generateQuestionHeading();
|
||||
var questionEntry = questionTree[question][0];
|
||||
var questionOptions = generateSelectionMenu(questionTree[question][1]);
|
||||
|
||||
var questionData = generateSelectionMenu(questionTree[question][1], questionTree[question][2]);
|
||||
var questionOptions = questionData[0];
|
||||
questionAnswer = questionData[1];
|
||||
|
||||
cm.sendSimple(questionHead + questionEntry + "\r\n\r\n#b" + questionOptions + "#k");
|
||||
} else if(status >= 2 && status <= 5) {
|
||||
@@ -134,7 +139,10 @@ function action(mode, type, selection) {
|
||||
question = fetchNextQuestion();
|
||||
var questionHead = generateQuestionHeading();
|
||||
var questionEntry = questionTree[question][0];
|
||||
var questionOptions = generateSelectionMenu(questionTree[question][1]);
|
||||
|
||||
var questionData = generateSelectionMenu(questionTree[question][1], questionTree[question][2]);
|
||||
var questionOptions = questionData[0];
|
||||
questionAnswer = questionData[1];
|
||||
|
||||
cm.sendSimple(questionHead + questionEntry + "\r\n\r\n#b" + questionOptions + "#k");
|
||||
} else if(status == 6) {
|
||||
@@ -155,7 +163,7 @@ function action(mode, type, selection) {
|
||||
}
|
||||
|
||||
function evaluateAnswer(selection) {
|
||||
return selection == questionTree[question][2];
|
||||
return selection == questionAnswer;
|
||||
}
|
||||
|
||||
function generateQuestionHeading() {
|
||||
@@ -189,10 +197,36 @@ function fetchNextQuestion() {
|
||||
return next;
|
||||
}
|
||||
|
||||
function generateSelectionMenu(array) {
|
||||
function shuffle(array) {
|
||||
var currentIndex = array.length, temporaryValue, randomIndex;
|
||||
|
||||
// While there remain elements to shuffle...
|
||||
while (0 !== currentIndex) {
|
||||
|
||||
// Pick a remaining element...
|
||||
randomIndex = Math.floor(Math.random() * currentIndex);
|
||||
currentIndex -= 1;
|
||||
|
||||
// And swap it with the current element.
|
||||
temporaryValue = array[currentIndex];
|
||||
array[currentIndex] = array[randomIndex];
|
||||
array[randomIndex] = temporaryValue;
|
||||
}
|
||||
|
||||
return array;
|
||||
}
|
||||
|
||||
function generateSelectionMenu(array, answer) {
|
||||
var answerStr = array[answer], answerPos = -1;
|
||||
|
||||
shuffle(array);
|
||||
|
||||
var menu = "";
|
||||
for (var i = 0; i < array.length; i++) {
|
||||
menu += "#L" + i + "#" + array[i] + "#l\r\n";
|
||||
if (answerStr == array[i]) {
|
||||
answerPos = i;
|
||||
}
|
||||
}
|
||||
return menu;
|
||||
return [menu, answerPos];
|
||||
}
|
||||
@@ -107,14 +107,14 @@ function action(mode, type, selection) {
|
||||
} else {
|
||||
if(cm.haveItem(4031061) && cm.haveItem(4031062)) {
|
||||
if(!cm.haveItem(4000082, 30)) {
|
||||
cm.sendOk("You have completed the trials, however there's still the need of #b30 #t4000082##k to forge the #t4001017#.");
|
||||
cm.sendOk("You have completed the trials, however there's still the need of #b30 #t4000082##k to forge 5 #t4001017#.");
|
||||
} else {
|
||||
cm.completeQuest(100201);
|
||||
cm.gainItem(4031061, -1);
|
||||
cm.gainItem(4031062, -1);
|
||||
cm.gainItem(4000082, -30);
|
||||
|
||||
cm.gainItem(4001017, 1);
|
||||
cm.gainItem(4001017, 5);
|
||||
cm.sendNext("You #rhave completed the trials#k, from now on having my approval to challenge Zakum.");
|
||||
}
|
||||
|
||||
|
||||
@@ -21,7 +21,7 @@
|
||||
*/
|
||||
var status = 0;
|
||||
|
||||
function start() {
|
||||
function start() {
|
||||
if(cm.getMapId() != 680000401) cm.sendSimple("Hello, where would you like to go?\r\n#b" + ((cm.getMapId() != 680000400) ? "#L0#Untamed Hearts Hunting Ground#l\r\n" : "") + ((cm.getMapId() == 680000400) ? "#L1#I have 7 keys. Bring me to smash boxes#l\r\n" : "") + "#L2#Please warp me out.#l#k");
|
||||
else cm.sendSimple("Hello, do you want to go back now? Returning here again will cost you #rother 7 keys#k.\r\n#b#L2#Please warp me back to the training grounds.#l#k");
|
||||
}
|
||||
|
||||
@@ -82,19 +82,22 @@ function writeFeatureTab_PlayerSocialNetwork() {
|
||||
addFeature("Automated support for Player NPCs and Hall of Fame.");
|
||||
addFeature("Engagement & Wedding system.");
|
||||
addFeature("Equipments displays to everyone it's level & EXP info.");
|
||||
addFeature("Further improved the existent minigame mechanics.");
|
||||
}
|
||||
|
||||
function writeFeatureTab_CashItems() {
|
||||
addFeature("EXP/DROP/Cosmetic Coupons.");
|
||||
addFeature("EXP/DROP Coupon as buff effect during active time.");
|
||||
addFeature("Great deal of cash items functional.");
|
||||
addFeature("Code coupons functional, with multi-items support.");
|
||||
addFeature("Merged unique ids for pets, rings and cash items.");
|
||||
addFeature("MapleTV mechanics stabilized and split by world.");
|
||||
addFeature("GMS-esque omok/match card drop chances.");
|
||||
addFeature("New town scroll: antibanish. Counters boss banishes.");
|
||||
addFeature("Inventory system checks for free slot & stack space.");
|
||||
addFeature("Storage with 'Arrange Items' feature functional.");
|
||||
addFeature("Close-quarters evaluation mode for items.");
|
||||
addFeature("Further improved Karma scissors.");
|
||||
addFeature("Reviewed Karma scissors & Untradeable items.");
|
||||
addFeature("Scroll for Spikes on Shoes.");
|
||||
addFeature("Scroll for Cold Protection.");
|
||||
addFeature("Vega's spell.");
|
||||
@@ -133,6 +136,8 @@ function writeFeatureTab_MonstersMapsReactors() {
|
||||
addFeature("Updated scripted portals, now with proper portal SFX.");
|
||||
addFeature("Reviewed Masteria, W. Tour, N. Desert and Neo City.");
|
||||
addFeature("Added world maps for M. Castle, W. Tour & Ellin areas.");
|
||||
addFeature("Added W. Tour & Masteria continents in the world map.");
|
||||
addFeature("Reviewed several issues with W. Map tooltips & links.");
|
||||
addFeature("Giant Cake boss drops s. bags and Maple items.");
|
||||
}
|
||||
|
||||
@@ -197,6 +202,7 @@ function writeFeatureTab_Commands() {
|
||||
addFeature("Rank command highlighting users by world or overall.");
|
||||
addFeature("Server commands layered by GM levels.");
|
||||
addFeature("Revamped command files layout - thanks Arthur L!");
|
||||
addFeature("Improved 'Search' performance & added map search.");
|
||||
}
|
||||
|
||||
function writeFeatureTab_CustomNPCs() {
|
||||
@@ -274,9 +280,9 @@ function action(mode, type, selection) {
|
||||
status++;
|
||||
else
|
||||
status--;
|
||||
|
||||
|
||||
if (status == 0) {
|
||||
var sendStr = "HeavenMS was developed on the timespan of 3 years, based on where Solaxia left. On the meantime many nice features emerged, development aimed to get back the old GMS experience. Now many of these so-long missing features are gracefully presented to you in the shape of this server. Long live MapleStory!!\r\n\r\nThese are the features from #bHeavenMS#k:\r\n\r\n";
|
||||
var sendStr = "HeavenMS was developed on the timespan of 3 years, based on where Solaxia left. I'm glad to say the development itself had continuously been agraciated by dozens of contributors and cheerers (truly thanks for the trusting vow, guys & gals!).\r\n\r\nTalking about results: many nice features emerged, development aimed to get back the old GMS experience. Now many of these so-long missing features are gracefully presented to you in the shape of this server. Long live MapleStory!!\r\n\r\nThese are the features from #bHeavenMS#k:\r\n\r\n";
|
||||
for(var i = 0; i < tabs.length; i++) {
|
||||
sendStr += "#L" + i + "##b" + tabs[i] + "#k#l\r\n";
|
||||
}
|
||||
|
||||
@@ -37,6 +37,7 @@ function writeServerStaff_HeavenMS() {
|
||||
addPerson("Ronan", "Developer");
|
||||
addPerson("Vcoc", "Freelance Developer");
|
||||
addPerson("Thora", "Contributor");
|
||||
addPerson("GabrielSin", "Contributor");
|
||||
|
||||
setHistory(2015, 2018);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user