Compare commits

...

2 Commits

Author SHA1 Message Date
Emo
3efe937410 Merge branch '2009Scape' 2025-07-01 16:39:01 -04:00
Emo
bf94901522 bumped 2009Scape branch to April release 2025-07-01 16:38:42 -04:00
18 changed files with 177 additions and 154 deletions

View File

@ -15,6 +15,11 @@ fun kidnapPlayer(player: Player, loc: Location, type: TeleportType) {
} }
fun returnPlayer(player: Player) { fun returnPlayer(player: Player) {
// Prevent returning more than once and sending the player back to HOME_LOCATION
if (getAttribute<Location?>(player, "kidnapped-by-random", null) == null) {
return
}
player.locks.unlockTeleport() player.locks.unlockTeleport()
val destination = getAttribute(player, "/save:original-loc", ServerConstants.HOME_LOCATION ?: Location.create(3222, 3218, 0)) val destination = getAttribute(player, "/save:original-loc", ServerConstants.HOME_LOCATION ?: Location.create(3222, 3218, 0))
teleport(player, destination) teleport(player, destination)

View File

@ -90,7 +90,7 @@ public class PortalChamberPlugin extends OptionHandler {
for (Locations l : Locations.values()) { for (Locations l : Locations.values()) {
if (l.name().contains(identifier)) { if (l.name().contains(identifier)) {
if (l == Locations.ARDOUGNE){ if (l == Locations.ARDOUGNE){
if (player.getAttribute(ARDOUGNE_TELE_ATTRIBUTE, false)){ if (!player.getAttribute(ARDOUGNE_TELE_ATTRIBUTE, false)) {
player.sendMessage("You do not have the requirements to direct the portal there"); player.sendMessage("You do not have the requirements to direct the portal there");
return; return;
} }
@ -138,12 +138,6 @@ public class PortalChamberPlugin extends OptionHandler {
case "enter": case "enter":
String objectName = object.getName(); String objectName = object.getName();
for (Locations l : Locations.values()) { for (Locations l : Locations.values()) {
if (l == Locations.ARDOUGNE){
if (player.getAttribute(ARDOUGNE_TELE_ATTRIBUTE, false)){
player.sendMessage("You do not have the requirements to enter this portal.");
return false;
}
}
if (objectName.toLowerCase().contains(l.name().toLowerCase())) { if (objectName.toLowerCase().contains(l.name().toLowerCase())) {
player.teleport(l.location); player.teleport(l.location);
if (player.getHouseManager().isInHouse(player) && node.getId() == 13635) { if (player.getHouseManager().isInHouse(player) && node.getId() == 13635) {

View File

@ -44,29 +44,30 @@ public final class CookingRecipePlugin extends UseWithHandler {
@Override @Override
public boolean handle(NodeUsageEvent event) { public boolean handle(NodeUsageEvent event) {
Recipe recipe = null; Recipe recipe = null;
Item part = null;
// TODO: Transitioning to a Listener would save an O(n) pass through the recipes list on every use-with // TODO: Transitioning to a Listener would save an O(n) pass through the recipes list on every use-with
recipeloop:
for (Recipe temp : Recipe.RECIPES) { for (Recipe temp : Recipe.RECIPES) {
if (temp.isSingular()) { if (temp.isSingular()) {
if (temp.getBase().getId() == event.getUsedItem().getId() || temp.getBase().getId() == event.getBaseItem().getId()) { if (temp.getBase().getId() == event.getUsedItem().getId() || temp.getBase().getId() == event.getBaseItem().getId()) {
for (Item ingredient : temp.getIngredients()) { for (Item ingredient : temp.getIngredients()) {
if (ingredient.getId() == event.getBaseItem().getId() || ingredient.getId() == event.getUsedItem().getId()) { if (ingredient.getId() == event.getBaseItem().getId() || ingredient.getId() == event.getUsedItem().getId()) {
recipe = temp; recipe = temp;
break; break recipeloop;
} }
} }
} }
} else { } else {
Item part = null;
Item ingredient = null;
for (int k = 0; k < temp.getParts().length; k++) { for (int k = 0; k < temp.getParts().length; k++) {
for (int i = 0; i < temp.getIngredients().length; i++) { for (int i = 0; i < temp.getIngredients().length; i++) {
part = temp.getParts()[k]; Item tempPart = temp.getParts()[k];
ingredient = temp.getIngredients()[i]; Item ingredient = temp.getIngredients()[i];
if (part.getId() == event.getUsedItem().getId() && ingredient.getId() == event.getBaseItem().getId() || part.getId() == event.getBaseItem().getId() && ingredient.getId() == event.getUsedItem().getId()) { if (tempPart.getId() == event.getUsedItem().getId() && ingredient.getId() == event.getBaseItem().getId() || tempPart.getId() == event.getBaseItem().getId() && ingredient.getId() == event.getUsedItem().getId()) {
if (k == i) {// represents that this ingredient can if (k == i) {// represents that this ingredient can
// mix with the other. // mix with the other.
recipe = temp; recipe = temp;
break; part = tempPart;
break recipeloop;
} }
} }
} }
@ -76,6 +77,7 @@ public final class CookingRecipePlugin extends UseWithHandler {
if (recipe != null) { if (recipe != null) {
final Player player = event.getPlayer(); final Player player = event.getPlayer();
final Recipe recipe_ = recipe; final Recipe recipe_ = recipe;
final Item part_ = part;
SkillDialogueHandler handler = new SkillDialogueHandler(player, SkillDialogue.ONE_OPTION, recipe.getProduct()) { SkillDialogueHandler handler = new SkillDialogueHandler(player, SkillDialogue.ONE_OPTION, recipe.getProduct()) {
@Override @Override
public void create(final int amount, int index) { public void create(final int amount, int index) {
@ -91,7 +93,7 @@ public final class CookingRecipePlugin extends UseWithHandler {
@Override @Override
public int getAll(int index) { public int getAll(int index) {
return player.getInventory().getAmount(recipe_.getBase()); return player.getInventory().getAmount(part_ != null ? part_ : recipe_.getBase());
} }
}; };
if (player.getInventory().getAmount(recipe.getBase()) == 1) { if (player.getInventory().getAmount(recipe.getBase()) == 1) {

View File

@ -119,6 +119,9 @@ public abstract class Recipe {
} }
} }
if (index != -1) { if (index != -1) {
if (!player.getInventory().containItems(event.getBaseItem().getId(), event.getUsedItem().getId())) {
return;
}
if (player.getInventory().remove(event.getBaseItem()) && player.getInventory().remove(event.getUsedItem())) { if (player.getInventory().remove(event.getBaseItem()) && player.getInventory().remove(event.getUsedItem())) {
player.getInventory().add(getParts()[index + 1]); player.getInventory().add(getParts()[index + 1]);
String message = getMixMessage(event); String message = getMixMessage(event);

View File

@ -80,7 +80,7 @@ public final class PCLanderZone extends MapZone {
for (PestControlActivityPlugin a : activities) { for (PestControlActivityPlugin a : activities) {
if (a.getWaitingPlayers().remove(e)) { if (a.getWaitingPlayers().remove(e)) {
if (logout) { if (logout) {
e.getProperties().setTeleportLocation(a.getLeaveLocation()); e.setLocation(a.getLeaveLocation());
} }
break; break;
} }

View File

@ -109,15 +109,9 @@ class HaroldDialogueFile : DialogueFile() {
21 -> playerl(FacialExpression.ASKING, "What?").also { stage++ } 21 -> playerl(FacialExpression.ASKING, "What?").also { stage++ }
22 -> npcl(FacialExpression.FRIENDLY, "I really fancy one of those Blurberry Specials. I never get over to the Gnome Stronghold so I haven't had one for ages!").also { stage++ } 22 -> npcl(FacialExpression.FRIENDLY, "I really fancy one of those Blurberry Specials. I never get over to the Gnome Stronghold so I haven't had one for ages!").also { stage++ }
23 -> { 23 -> {
if (removeItem(player!!, Items.BLURBERRY_SPECIAL_2064)) { if (removeItem(player!!, Items.BLURBERRY_SPECIAL_2064) || removeItem(player!!, Items.PREMADE_BLURB_SP_2028)) {
sendMessage(player!!, "You give Harold a Blurberry Special.") sendMessage(player!!, "You give Harold a Blurberry Special.")
sendItemDialogue(player!!, Items.BLURBERRY_SPECIAL_2064, "You give Harold a Blurberry Special.").also { stage++ } sendItemDialogue(player!!, Items.BLURBERRY_SPECIAL_2064, "You give Harold a Blurberry Special.").also { stage++ }
} else if (removeItem(player!!, Items.BLURBERRY_SPECIAL_9520)) { // This should not be here since 9520 is used by the gnome restaurant minigame.
sendMessage(player!!, "You give Harold a Blurberry Special.")
sendItemDialogue(player!!, Items.BLURBERRY_SPECIAL_2064, "You give Harold a Blurberry Special.").also { stage++ }
} else if (removeItem(player!!, Items.PREMADE_BLURB_SP_2028)) {
sendMessage(player!!, "You give Harold a Blurberry Special.")
sendItemDialogue(player!!, Items.PREMADE_BLURB_SP_2028, "You give Harold a Blurberry Special.").also { stage++ }
} else { } else {
player(FacialExpression.FRIENDLY, "I'll go and get you one.").also { stage = END_DIALOGUE } player(FacialExpression.FRIENDLY, "I'll go and get you one.").also { stage = END_DIALOGUE }
} }

View File

@ -4,6 +4,7 @@ import content.data.Quests
import core.api.* import core.api.*
import org.rs09.consts.Items import org.rs09.consts.Items
import core.game.dialogue.DialogueFile import core.game.dialogue.DialogueFile
import core.game.dialogue.FacialExpression
import core.tools.END_DIALOGUE import core.tools.END_DIALOGUE
class CommanderMontaiDialogue : DialogueFile(){ class CommanderMontaiDialogue : DialogueFile(){
@ -12,19 +13,19 @@ class CommanderMontaiDialogue : DialogueFile(){
if (questStage == 10) { if (questStage == 10) {
when(stage) { when(stage) {
0 -> playerl("Hello.").also { stage++ } 0 -> playerl("Hello.").also { stage++ }
1 -> npcl("Hello traveller, are you here to help or just to watch?").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Hello traveller, are you here to help or just to watch?").also { stage++ }
2 -> playerl("I've been sent by King Bolren to retrieve the orb of protection.").also { stage++ } 2 -> playerl("I've been sent by King Bolren to retrieve the orb of protection.").also { stage++ }
3 -> npcl("Excellent we need all the help we can get.").also { stage++ } 3 -> npcl(FacialExpression.OLD_NORMAL, "Excellent we need all the help we can get.").also { stage++ }
4 -> npcl("I'm Commander Montai. The orb is in the Khazard stronghold to the north, but until we weaken their defences we can't get close.").also { stage++ } 4 -> npcl(FacialExpression.OLD_NORMAL, "I'm Commander Montai. The orb is in the Khazard stronghold to the north, but until we weaken their defences we can't get close.").also { stage++ }
5 -> playerl("What can I do?").also { stage++ } 5 -> playerl("What can I do?").also { stage++ }
6 -> npcl("Firstly we need to strengthen our own defences. We desperately need wood to make more battlements, once the battlements are gone it's all over. Six loads of normal logs should do it.").also { stage++ } 6 -> npcl(FacialExpression.OLD_NORMAL, "Firstly we need to strengthen our own defences. We desperately need wood to make more battlements, once the battlements are gone it's all over. Six loads of normal logs should do it.").also { stage++ }
7 -> options("Ok, I'll gather some wood.", "Sorry, I no longer want to be involved.").also { stage++ } 7 -> options("Ok, I'll gather some wood.", "Sorry, I no longer want to be involved.").also { stage++ }
8 -> when (buttonID) { 8 -> when (buttonID) {
1 -> playerl("Ok, I'll gather some wood.").also { stage = 10 } 1 -> playerl("Ok, I'll gather some wood.").also { stage = 10 }
2 -> playerl("Sorry, I no longer want to be involved.").also { stage = 9 } 2 -> playerl("Sorry, I no longer want to be involved.").also { stage = 9 }
} }
9 -> npcl("That's a shame, we could have done with your help.").also { stage = END_DIALOGUE } 9 -> npcl(FacialExpression.OLD_NORMAL, "That's a shame, we could have done with your help.").also { stage = END_DIALOGUE }
10 -> npcl("Please be as quick as you can, I don't know how much longer we can hold out.").also { 10 -> npcl(FacialExpression.OLD_NORMAL, "Please be as quick as you can, I don't know how much longer we can hold out.").also {
setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 20) setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 20)
stage = END_DIALOGUE stage = END_DIALOGUE
} }
@ -33,43 +34,43 @@ class CommanderMontaiDialogue : DialogueFile(){
if(inInventory(player!!, Items.LOGS_1511,6)){ if(inInventory(player!!, Items.LOGS_1511,6)){
when(stage) { when(stage) {
0 -> playerl("Hello.").also { stage++ } 0 -> playerl("Hello.").also { stage++ }
1 -> npcl("Hello again, we're still desperate for wood soldier.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Hello again, we're still desperate for wood soldier.").also { stage++ }
2 -> playerl("I have some here. (You give six loads of logs to the commander.)").also{ stage++ } 2 -> playerl("I have some here. (You give six loads of logs to the commander.)").also{ stage++ }
3 -> { 3 -> {
// Remove the 6 normal logs // Remove the 6 normal logs
for(i in 1..6) { removeItem(player!!,Items.LOGS_1511) } for(i in 1..6) { removeItem(player!!,Items.LOGS_1511) }
setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 25) setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 25)
npcl("That's excellent, now we can make more defensive battlements. Give me a moment to organize the troops and then come speak to me. I'll inform you of our next phase of attack.") npcl(FacialExpression.OLD_NORMAL, "That's excellent, now we can make more defensive battlements. Give me a moment to organize the troops and then come speak to me. I'll inform you of our next phase of attack.")
stage = END_DIALOGUE stage = END_DIALOGUE
} }
} }
} else { } else {
when(stage) { when(stage) {
0 -> playerl("Hello.").also { stage++ } 0 -> playerl("Hello.").also { stage++ }
1 -> npcl("Hello again, we're still desperate for wood soldier. We need six loads of normal logs.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Hello again, we're still desperate for wood soldier. We need six loads of normal logs.").also { stage++ }
2 -> playerl("I'll see what I can do.").also { stage++ } 2 -> playerl("I'll see what I can do.").also { stage++ }
3 -> npcl("Thank you.").also { stage = END_DIALOGUE } 3 -> npcl(FacialExpression.OLD_NORMAL, "Thank you.").also { stage = END_DIALOGUE }
} }
} }
} else if (questStage == 25) { } else if (questStage == 25) {
when(stage) { when(stage) {
0 -> playerl("How are you doing Montai?").also { stage++ } 0 -> playerl("How are you doing Montai?").also { stage++ }
1 -> npcl("We're hanging in there soldier. For the next phase of our attack we need to breach their stronghold.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "We're hanging in there soldier. For the next phase of our attack we need to breach their stronghold.").also { stage++ }
2 -> npcl("The ballista can break through the stronghold wall, and then we can advance and seize back the orb.").also { stage++ } 2 -> npcl(FacialExpression.OLD_NORMAL, "The ballista can break through the stronghold wall, and then we can advance and seize back the orb.").also { stage++ }
3 -> playerl("So what's the problem?").also { stage++ } 3 -> playerl("So what's the problem?").also { stage++ }
4 -> npcl("From this distance we can't get an accurate enough shot. We need the correct coordinates of the stronghold for a direct hit. I've sent out three tracker gnomes to gather them.").also { stage++ } 4 -> npcl(FacialExpression.OLD_NORMAL, "From this distance we can't get an accurate enough shot. We need the correct coordinates of the stronghold for a direct hit. I've sent out three tracker gnomes to gather them.").also { stage++ }
5 -> playerl("Have they returned?").also { stage++ } 5 -> playerl("Have they returned?").also { stage++ }
6 -> npcl("I'm afraid not, and we're running out of time. I need you to go into the heart of the battlefield, find the trackers, and bring back the coordinates.").also { stage++ } 6 -> npcl(FacialExpression.OLD_NORMAL, "I'm afraid not, and we're running out of time. I need you to go into the heart of the battlefield, find the trackers, and bring back the coordinates.").also { stage++ }
7 -> npcl("Do you think you can do it?").also { stage++ } 7 -> npcl(FacialExpression.OLD_NORMAL, "Do you think you can do it?").also { stage++ }
8 -> options("No, I've had enough of your battle.", "I'll try my best.").also { stage++ } 8 -> options("No, I've had enough of your battle.", "I'll try my best.").also { stage++ }
9 -> when(buttonID) { 9 -> when(buttonID) {
1 -> playerl("No, I've had enough of your battle.").also { stage = 10 } 1 -> playerl("No, I've had enough of your battle.").also { stage = 10 }
2 -> playerl("I'll try my best.").also { stage = 11 } 2 -> playerl("I'll try my best.").also { stage = 11 }
} }
10 -> npcl("I understand, this isn't your fight.").also { stage = END_DIALOGUE } 10 -> npcl(FacialExpression.OLD_NORMAL, "I understand, this isn't your fight.").also { stage = END_DIALOGUE }
11 -> npcl("Thank you, you're braver than most.").also { stage++ } 11 -> npcl(FacialExpression.OLD_NORMAL, "Thank you, you're braver than most.").also { stage++ }
12 -> npcl("I don't know how long I will be able to hold out. Once you have the coordinates come back and fire the ballista right into those monsters.").also { stage++ } 12 -> npcl(FacialExpression.OLD_NORMAL, "I don't know how long I will be able to hold out. Once you have the coordinates come back and fire the ballista right into those monsters.").also { stage++ }
13 -> npcl("If you can retrieve the orb and bring safety back to my people, none of the blood spilled on this field will be in vain.").also { 13 -> npcl(FacialExpression.OLD_NORMAL, "If you can retrieve the orb and bring safety back to my people, none of the blood spilled on this field will be in vain.").also {
setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 30) setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 30)
stage = END_DIALOGUE stage = END_DIALOGUE
} }
@ -77,29 +78,29 @@ class CommanderMontaiDialogue : DialogueFile(){
} else if (questStage == 30) { } else if (questStage == 30) {
when(stage) { when(stage) {
0 -> playerl("Hello.").also { stage++ } 0 -> playerl("Hello.").also { stage++ }
1 -> npcl("Hello warrior. We need the coordinates for a direct hit from the ballista.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Hello warrior. We need the coordinates for a direct hit from the ballista.").also { stage++ }
2 -> npcl("Once you have a direct hit you will be able to enter the stronghold and retrieve the orb.").also { stage = END_DIALOGUE } 2 -> npcl(FacialExpression.OLD_NORMAL, "Once you have a direct hit you will be able to enter the stronghold and retrieve the orb.").also { stage = END_DIALOGUE }
} }
} else if (questStage == 31) { } else if (questStage == 31) {
if(inInventory(player!!,Items.ORB_OF_PROTECTION_587)){ if(inInventory(player!!,Items.ORB_OF_PROTECTION_587)){
when(stage) { when(stage) {
0 -> playerl("I have the orb of protection.").also { stage++ } 0 -> playerl("I have the orb of protection.").also { stage++ }
1 -> npcl("Incredible, for a human you really are something.").also { stage++ } 1 -> npcl(FacialExpression.OLD_HAPPY, "Incredible, for a human you really are something.").also { stage++ }
2 -> playerl("Thanks... I think!").also { stage++ } 2 -> playerl("Thanks... I think!").also { stage++ }
3 -> npcl("I'll stay here with my troops and try and hold Khazard's men back. You return the orb to the gnome village. Go as quick as you can, the village is still unprotected.").also { stage = END_DIALOGUE } 3 -> npcl(FacialExpression.OLD_NORMAL, "I'll stay here with my troops and try and hold Khazard's men back. You return the orb to the gnome village. Go as quick as you can, the village is still unprotected.").also { stage = END_DIALOGUE }
} }
} else { } else {
when(stage) { when(stage) {
0 -> playerl("I've breached the stronghold.").also { stage++ } 0 -> playerl("I've breached the stronghold.").also { stage++ }
1 -> npcl("I saw, that was a beautiful sight. The Khazard troops didn't know what hit them.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "I saw, that was a beautiful sight. The Khazard troops didn't know what hit them.").also { stage++ }
2 -> npcl("Now is the time to retrieve the orb. It's all in your hands. I'll be praying for you.").also { stage = END_DIALOGUE } 2 -> npcl(FacialExpression.OLD_NORMAL, "Now is the time to retrieve the orb. It's all in your hands. I'll be praying for you.").also { stage = END_DIALOGUE }
} }
} }
} else if (questStage != 0){ } else if (questStage != 0){
when(stage) { when(stage) {
0 -> playerl("Hello Montai, how are you?").also { stage++ } 0 -> playerl("Hello Montai, how are you?").also { stage++ }
1 -> npcl("I'm ok, this battle is going to take longer to win than I expected. The Khazard troops won't give up even without the orb.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "I'm ok, this battle is going to take longer to win than I expected. The Khazard troops won't give up even without the orb.").also { stage++ }
2 -> playerl("Hang in there.").also { stage = END_DIALOGUE } 2 -> playerl("Hang in there.").also { stage = END_DIALOGUE }
} }
} }

View File

@ -11,6 +11,7 @@ import org.rs09.consts.Items
import core.game.dialogue.DialogueFile import core.game.dialogue.DialogueFile
import content.region.kandarin.quest.tree.TreeGnomeVillage.Companion.mazeEntrance import content.region.kandarin.quest.tree.TreeGnomeVillage.Companion.mazeEntrance
import content.region.kandarin.quest.tree.TreeGnomeVillage.Companion.mazeVillage import content.region.kandarin.quest.tree.TreeGnomeVillage.Companion.mazeVillage
import core.game.dialogue.FacialExpression
import core.game.world.GameWorld.Pulser import core.game.world.GameWorld.Pulser
import core.tools.END_DIALOGUE import core.tools.END_DIALOGUE
@ -45,30 +46,30 @@ class ElkoyDialogue : DialogueFile(){
inInventory(player!!, Items.ORBS_OF_PROTECTION_588) && followLocation == "exit" -> { inInventory(player!!, Items.ORBS_OF_PROTECTION_588) && followLocation == "exit" -> {
when(stage) { when(stage) {
0 -> playerl("Hello Elkoy. I have the orb.").also { stage++ } 0 -> playerl("Hello Elkoy. I have the orb.").also { stage++ }
1 -> npcl("Take it to King Bolren, I'm sure he'll be pleased to see you.").also { stage++ } 1 -> npcl(FacialExpression.OLD_HAPPY, "Take it to King Bolren, I'm sure he'll be pleased to see you.").also { stage++ }
2 -> options("Alright, I'll do that.", "Can you guide me out of the maze now?").also { stage++ } 2 -> options("Alright, I'll do that.", "Can you guide me out of the maze now?").also { stage++ }
3 -> when(buttonID) { 3 -> when(buttonID) {
1 -> playerl("Alright, I'll do that.").also { stage = END_DIALOGUE } 1 -> playerl("Alright, I'll do that.").also { stage = END_DIALOGUE }
2 -> playerl("Can you guide me out of the maze now?").also { stage = 4 } 2 -> playerl("Can you guide me out of the maze now?").also { stage = 4 }
} }
4 -> npcl("If you like, but please take the orb to King Bolren soon.").also { stage++ } 4 -> npcl(FacialExpression.OLD_NORMAL, "If you like, but please take the orb to King Bolren soon.").also { stage++ }
5 -> { 5 -> {
travelCutscene(player!!, mazeEntrance) travelCutscene(player!!, mazeEntrance)
stage++ stage++
} }
6 -> npcl("Here we are. Please don't lose the orb!").also { stage = END_DIALOGUE } 6 -> npcl(FacialExpression.OLD_NORMAL, "Here we are. Please don't lose the orb!").also { stage = END_DIALOGUE }
} }
} }
inInventory(player!!, Items.ORB_OF_PROTECTION_587) -> { inInventory(player!!, Items.ORB_OF_PROTECTION_587) -> {
when(stage) { when(stage) {
0 -> playerl("Hello Elkoy.").also { stage++ } 0 -> playerl("Hello Elkoy.").also { stage++ }
1 -> npcl("You're back! And the orb?").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "You're back! And the orb?").also { stage++ }
2 -> playerl("I have it here.").also { stage++ } 2 -> playerl("I have it here.").also { stage++ }
3 -> { 3 -> {
if(locY > 3161){ if(locY > 3161){
npcl("You're our saviour. Please return it to the village and we are all saved. Would you like me to show you the way to the village?").also { stage++ } npcl(FacialExpression.OLD_NORMAL, "You're our saviour. Please return it to the village and we are all saved. Would you like me to show you the way to the village?").also { stage++ }
} else { } else {
npcl("Take the orb to King Bolren, I'm sure he'll be pleased to see you.").also { stage = END_DIALOGUE } npcl(FacialExpression.OLD_NORMAL, "Take the orb to King Bolren, I'm sure he'll be pleased to see you.").also { stage = END_DIALOGUE }
} }
} }
4 -> options("Yes please.", "No thanks Elkoy.").also { stage++ } 4 -> options("Yes please.", "No thanks Elkoy.").also { stage++ }
@ -76,24 +77,24 @@ class ElkoyDialogue : DialogueFile(){
1 -> playerl("Yes please.").also { stage = 7 } 1 -> playerl("Yes please.").also { stage = 7 }
2 -> playerl("No thanks Elkoy.").also { stage = 6 } 2 -> playerl("No thanks Elkoy.").also { stage = 6 }
} }
6 -> npcl("Ok then, take care.").also { stage = END_DIALOGUE } 6 -> npcl(FacialExpression.OLD_NORMAL, "Ok then, take care.").also { stage = END_DIALOGUE }
7 -> travelCutscene(player!!, mazeVillage).also { stage++ } 7 -> travelCutscene(player!!, mazeVillage).also { stage++ }
8 -> npcl("Here we are. Take the orb to King Bolren, I'm sure he'll be pleased to see you.").also { stage = END_DIALOGUE } 8 -> npcl(FacialExpression.OLD_NORMAL, "Here we are. Take the orb to King Bolren, I'm sure he'll be pleased to see you.").also { stage = END_DIALOGUE }
} }
} }
inInventory(player!!, Items.ORBS_OF_PROTECTION_588) || questStage == 100 -> { inInventory(player!!, Items.ORBS_OF_PROTECTION_588) || questStage == 100 -> {
when(stage) { when(stage) {
0 -> playerl("Hello Elkoy.").also { stage++ } 0 -> playerl("Hello Elkoy.").also { stage++ }
1 -> npcl("You truly are a hero.").also { stage++ } 1 -> npcl(FacialExpression.OLD_HAPPY, "You truly are a hero.").also { stage++ }
2 -> playerl("Thanks.").also { stage++ } 2 -> playerl("Thanks.").also { stage++ }
3 -> npcl("You saved us by defeating the warlord. I'm humbled and wish you well.").also { stage++ } 3 -> npcl(FacialExpression.OLD_NORMAL, "You saved us by defeating the warlord. I'm humbled and wish you well.").also { stage++ }
4 -> npcl("Would you like me to show you the way to the ${followLocation}?").also { stage++ } 4 -> npcl(FacialExpression.OLD_NORMAL, "Would you like me to show you the way to the ${followLocation}?").also { stage++ }
5 -> options("Yes please.", "No thanks Elkoy.").also { stage++ } 5 -> options("Yes please.", "No thanks Elkoy.").also { stage++ }
6 -> when(buttonID) { 6 -> when(buttonID) {
1 -> playerl("Yes please.").also { stage = 8 } 1 -> playerl("Yes please.").also { stage = 8 }
2 -> playerl("No thanks Elkoy.").also { stage = 7 } 2 -> playerl("No thanks Elkoy.").also { stage = 7 }
} }
7 -> npcl("Ok then, take care.").also { stage = END_DIALOGUE } 7 -> npcl(FacialExpression.OLD_NORMAL, "Ok then, take care.").also { stage = END_DIALOGUE }
8 -> { 8 -> {
if(followLocation == "village") { if(followLocation == "village") {
travelCutscene(player!!, mazeVillage) travelCutscene(player!!, mazeVillage)
@ -104,33 +105,33 @@ class ElkoyDialogue : DialogueFile(){
stage++ stage++
} }
} }
9 -> npcl("Here we are. Have a safe journey.").also { stage = END_DIALOGUE } 9 -> npcl(FacialExpression.OLD_NORMAL, "Here we are. Have a safe journey.").also { stage = END_DIALOGUE }
10 -> npcl("Here we are. Feel free to have a look around.").also { stage = END_DIALOGUE } 10 -> npcl(FacialExpression.OLD_NORMAL, "Here we are. Feel free to have a look around.").also { stage = END_DIALOGUE }
} }
} }
questStage == 0 -> { questStage == 0 -> {
when(stage) { when(stage) {
0 -> playerl("Hello there.").also { stage++ } 0 -> playerl("Hello there.").also { stage++ }
1 -> npcl("Hello, welcome to our maze. I'm Elkoy the tree gnome.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Hello, welcome to our maze. I'm Elkoy the tree gnome.").also { stage++ }
2 -> playerl("I haven't heard of your sort.").also { stage++ } 2 -> playerl("I haven't heard of your sort.").also { stage++ }
3 -> npcl("There's not many of us left. Once you could find tree gnomes anywhere in the world, now we hide in small groups to avoid capture.").also { stage++ } 3 -> npcl(FacialExpression.OLD_SAD, "There's not many of us left. Once you could find tree gnomes anywhere in the world, now we hide in small groups to avoid capture.").also { stage++ }
4 -> playerl("Capture from whom?").also { stage++ } 4 -> playerl("Capture from whom?").also { stage++ }
5 -> npcl("Tree gnomes have been hunted for so called 'fun' since as long as I can remember.").also { stage++ } 5 -> npcl(FacialExpression.OLD_NORMAL, "Tree gnomes have been hunted for so called 'fun' since as long as I can remember.").also { stage++ }
6 -> npcl("Our main threat nowadays are General Khazard's troops. They know no mercy, but are also very dense. They'll never find their way through our maze.").also { stage++ } 6 -> npcl(FacialExpression.OLD_NORMAL, "Our main threat nowadays are General Khazard's troops. They know no mercy, but are also very dense. They'll never find their way through our maze.").also { stage++ }
7 -> npcl("Have fun.").also { stage = END_DIALOGUE } 7 -> npcl(FacialExpression.OLD_NORMAL, "Have fun.").also { stage = END_DIALOGUE }
} }
} }
questStage in 1..39 -> { questStage in 1..39 -> {
when (stage) { when (stage) {
0 -> npcl("Oh my! The orb, they have the orb. We're doomed.").also { stage++ } 0 -> npcl(FacialExpression.OLD_DISTRESSED, "Oh my! The orb, they have the orb. We're doomed.").also { stage++ }
1 -> playerl("Perhaps I'll be able to get it back for you.").also { stage++ } 1 -> playerl("Perhaps I'll be able to get it back for you.").also { stage++ }
2 -> npcl("Would you like me to show you the way to the ${followLocation}?").also { stage++ } 2 -> npcl(FacialExpression.OLD_NORMAL, "Would you like me to show you the way to the ${followLocation}?").also { stage++ }
3 -> options("Yes please.", "No thanks Elkoy.").also { stage++ } 3 -> options("Yes please.", "No thanks Elkoy.").also { stage++ }
4 -> when (buttonID) { 4 -> when (buttonID) {
1 -> playerl("Yes please.").also { stage = 6 } 1 -> playerl("Yes please.").also { stage = 6 }
2 -> playerl("No thanks Elkoy.").also { stage = 5 } 2 -> playerl("No thanks Elkoy.").also { stage = 5 }
} }
5 -> npcl("Ok then, take care.").also { stage = END_DIALOGUE } 5 -> npcl(FacialExpression.OLD_NORMAL, "Ok then, take care.").also { stage = END_DIALOGUE }
6 -> { 6 -> {
if(followLocation == "village") if(followLocation == "village")
travelCutscene(player!!, mazeVillage) travelCutscene(player!!, mazeVillage)
@ -138,20 +139,20 @@ class ElkoyDialogue : DialogueFile(){
travelCutscene(player!!, mazeEntrance) travelCutscene(player!!, mazeEntrance)
stage++ stage++
} }
7 -> npcl("Here we are. I hope you get the orb back soon.").also { stage = END_DIALOGUE } 7 -> npcl(FacialExpression.OLD_NORMAL, "Here we are. I hope you get the orb back soon.").also { stage = END_DIALOGUE }
} }
} }
questStage == 40 -> { questStage == 40 -> {
when(stage) { when(stage) {
0 -> playerl("Hello Elkoy.").also { stage++ } 0 -> playerl("Hello Elkoy.").also { stage++ }
1 -> npcl("Did you hear? Khazard's men have pillaged the village! They slaughtered many, and took the other orbs in an attempt to lead us out of the maze. When will the misery end?").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Did you hear? Khazard's men have pillaged the village! They slaughtered many, and took the other orbs in an attempt to lead us out of the maze. When will the misery end?").also { stage++ }
2 -> npcl("Would you like me to show you the way to the ${followLocation}?").also { stage++ } 2 -> npcl(FacialExpression.OLD_NORMAL, "Would you like me to show you the way to the ${followLocation}?").also { stage++ }
3 -> options("Yes please.", "No thanks Elkoy.").also { stage++ } 3 -> options("Yes please.", "No thanks Elkoy.").also { stage++ }
4 -> when(buttonID) { 4 -> when(buttonID) {
1 -> playerl("Yes please.").also { stage = 6 } 1 -> playerl("Yes please.").also { stage = 6 }
2 -> playerl("No thanks Elkoy.").also { stage = 5 } 2 -> playerl("No thanks Elkoy.").also { stage = 5 }
} }
5 -> npcl("Ok then, take care.").also { stage = END_DIALOGUE } 5 -> npcl(FacialExpression.OLD_NORMAL, "Ok then, take care.").also { stage = END_DIALOGUE }
6 -> { 6 -> {
if(followLocation == "village") { if(followLocation == "village") {
travelCutscene(player!!, mazeVillage) travelCutscene(player!!, mazeVillage)
@ -161,8 +162,8 @@ class ElkoyDialogue : DialogueFile(){
stage++ stage++
} }
} }
7 -> npcl("Please try to get our orbs back for us, otherwise the village is doomed!").also { stage = END_DIALOGUE } 7 -> npcl(FacialExpression.OLD_NORMAL, "Please try to get our orbs back for us, otherwise the village is doomed!").also { stage = END_DIALOGUE }
8 -> npcl("Here we are. Despite what has happened here, I hope you feel welcome.").also { stage = END_DIALOGUE } 8 -> npcl(FacialExpression.OLD_NORMAL, "Here we are. Despite what has happened here, I hope you feel welcome.").also { stage = END_DIALOGUE }
} }
} }
} }

View File

@ -10,6 +10,7 @@ import org.rs09.consts.Items
import org.rs09.consts.NPCs import org.rs09.consts.NPCs
import core.game.dialogue.DialogueFile import core.game.dialogue.DialogueFile
import content.region.kandarin.quest.tree.TreeGnomeVillage.Companion.mazeEntrance import content.region.kandarin.quest.tree.TreeGnomeVillage.Companion.mazeEntrance
import core.game.dialogue.FacialExpression
import core.game.world.GameWorld import core.game.world.GameWorld
import core.tools.END_DIALOGUE import core.tools.END_DIALOGUE
@ -20,37 +21,37 @@ class KingBolrenDialogue : DialogueFile() {
questStage < 10 -> { questStage < 10 -> {
when (stage) { when (stage) {
0 -> playerl("Hello.").also { stage++ } 0 -> playerl("Hello.").also { stage++ }
1 -> npcl("Well hello stranger. My name's Bolren, I'm the king of the tree gnomes.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Well hello stranger. My name's Bolren, I'm the king of the tree gnomes.").also { stage++ }
2 -> npcl("I'm surprised you made it in, maybe I made the maze too easy.").also { stage++ } 2 -> npcl(FacialExpression.OLD_NORMAL, "I'm surprised you made it in, maybe I made the maze too easy.").also { stage++ }
3 -> playerl("Maybe.").also { stage++ } 3 -> playerl("Maybe.").also { stage++ }
4 -> npcl("I'm afraid I have more serious concerns at the moment. Very serious.").also { stage++ } 4 -> npcl(FacialExpression.OLD_NORMAL, "I'm afraid I have more serious concerns at the moment. Very serious.").also { stage++ }
5 -> options("I'll leave you to it then.", "Can I help at all?").also { stage++ } 5 -> options("I'll leave you to it then.", "Can I help at all?").also { stage++ }
6 -> when (buttonID) { 6 -> when (buttonID) {
1 -> playerl("I'll leave you to it then.").also { stage = 7 } 1 -> playerl("I'll leave you to it then.").also { stage = 7 }
2 -> playerl("Can I help at all?").also { stage = 8 } 2 -> playerl("Can I help at all?").also { stage = 8 }
} }
7 -> npcl("Ok, take care.").also { stage = END_DIALOGUE } 7 -> npcl(FacialExpression.OLD_NORMAL, "Ok, take care.").also { stage = END_DIALOGUE }
8 -> npcl("I'm glad you asked.").also { stage++ } 8 -> npcl(FacialExpression.OLD_NORMAL, "I'm glad you asked.").also { stage++ }
9 -> npcl("The truth is my people are in grave danger. We have always been protected by the Spirit Tree. No creature of dark can harm us while its three orbs are in place.").also { stage++ } 9 -> npcl(FacialExpression.OLD_SAD, "The truth is my people are in grave danger. We have always been protected by the Spirit Tree. No creature of dark can harm us while its three orbs are in place.").also { stage++ }
10 -> npcl("We are not a violent race, but we fight when we must. Many gnomes have fallen battling the dark forces of Khazard to the North.").also { stage++ } 10 -> npcl(FacialExpression.OLD_SAD, "We are not a violent race, but we fight when we must. Many gnomes have fallen battling the dark forces of Khazard to the North.").also { stage++ }
11 -> npcl("We became desperate, so we took one orb of protection to the battlefield. It was a foolish move.").also { stage++ } 11 -> npcl(FacialExpression.OLD_SAD, "We became desperate, so we took one orb of protection to the battlefield. It was a foolish move.").also { stage++ }
12 -> npcl("Khazard troops seized the orb. Now we are completely defenceless.").also { stage++ } 12 -> npcl(FacialExpression.OLD_NORMAL, "Khazard troops seized the orb. Now we are completely defenceless.").also { stage++ }
13 -> playerl("How can I help?").also { stage++ } 13 -> playerl("How can I help?").also { stage++ }
14 -> npcl("You would be a huge benefit on the battlefield. If you would go there and try to retrieve the orb, my people and I will be forever grateful.").also { stage++ } 14 -> npcl(FacialExpression.OLD_NORMAL,"You would be a huge benefit on the battlefield. If you would go there and try to retrieve the orb, my people and I will be forever grateful.").also { stage++ }
15 -> options("I would be glad to help.", "I'm sorry but I won't be involved.").also { stage++ } 15 -> options("I would be glad to help.", "I'm sorry but I won't be involved.").also { stage++ }
16 -> when (buttonID) { 16 -> when (buttonID) {
1 -> playerl("I would be glad to help.").also { stage = 18 } 1 -> playerl("I would be glad to help.").also { stage = 18 }
2 -> playerl("I'm sorry but I won't be involved.").also { stage = 17 } 2 -> playerl("I'm sorry but I won't be involved.").also { stage = 17 }
} }
17 -> npcl("Ok then, travel safe.").also { stage = END_DIALOGUE } 17 -> npcl(FacialExpression.OLD_NORMAL, "Ok then, travel safe.").also { stage = END_DIALOGUE }
18 -> npcl("Thank you. The battlefield is to the north of the maze. Commander Montai will inform you of their current situation.").also { stage++ } 18 -> npcl(FacialExpression.OLD_NORMAL, "Thank you. The battlefield is to the north of the maze. Commander Montai will inform you of their current situation.").also { stage++ }
19 -> npcl("That is if he's still alive.").also { stage++ } 19 -> npcl(FacialExpression.OLD_NORMAL, "That is if he's still alive.").also { stage++ }
20 -> npcl("My assistant shall guide you out. Good luck friend, try your best to return the orb.").also { 20 -> npcl(FacialExpression.OLD_NORMAL, "My assistant shall guide you out. Good luck friend, try your best to return the orb.").also {
stage++ stage++
} }
21 -> { 21 -> {
teleport(player!!, mazeEntrance) teleport(player!!, mazeEntrance)
sendNPCDialogue(player!!, NPCs.ELKOY_5179, "We're out of the maze now. Please hurry, we must have the orb if we are to survive.") sendNPCDialogue(player!!, NPCs.ELKOY_5179, "We're out of the maze now. Please hurry, we must have the orb if we are to survive.", FacialExpression.OLD_NORMAL)
setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 10) setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 10)
stage = END_DIALOGUE stage = END_DIALOGUE
} }
@ -59,7 +60,7 @@ class KingBolrenDialogue : DialogueFile() {
questStage < 31 -> { questStage < 31 -> {
when (stage) { when (stage) {
0 -> playerl("Hello Bolren.").also { stage++ } 0 -> playerl("Hello Bolren.").also { stage++ }
1 -> npcl("Hello traveller, we must retrieve the orb. It's being held by Khazard troops north of here.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Hello traveller, we must retrieve the orb. It's being held by Khazard troops north of here.").also { stage++ }
2 -> playerl("Ok, I'll try my best.").also { stage = END_DIALOGUE } 2 -> playerl("Ok, I'll try my best.").also { stage = END_DIALOGUE }
} }
} }
@ -67,32 +68,32 @@ class KingBolrenDialogue : DialogueFile() {
if(inInventory(player!!,Items.ORB_OF_PROTECTION_587)){ if(inInventory(player!!,Items.ORB_OF_PROTECTION_587)){
when(stage) { when(stage) {
0 -> playerl("I have the orb.").also { stage++ } 0 -> playerl("I have the orb.").also { stage++ }
1 -> npcl("Oh my... The misery, the horror!").also { stage++ } 1 -> npcl(FacialExpression.OLD_DISTRESSED, "Oh my... The misery, the horror!").also { stage++ }
2 -> playerl("King Bolren, are you OK?").also { stage++ } 2 -> playerl("King Bolren, are you OK?").also { stage++ }
3 -> npcl("Thank you traveller, but it's too late. We're all doomed.").also { stage++ } 3 -> npcl(FacialExpression.OLD_DISTRESSED, "Thank you traveller, but it's too late. We're all doomed.").also { stage++ }
4 -> playerl("What happened?").also { stage++ } 4 -> playerl("What happened?").also { stage++ }
5 -> npcl("They came in the night. I don't know how many, but enough.").also { stage++ } 5 -> npcl(FacialExpression.OLD_DISTRESSED, "They came in the night. I don't know how many, but enough.").also { stage++ }
6 -> playerl("Who?").also { stage++ } 6 -> playerl("Who?").also { stage++ }
7 -> npcl("Khazard troops. They slaughtered anyone who got in their way. Women, children, my wife.").also { stage++ } 7 -> npcl(FacialExpression.OLD_DISTRESSED, "Khazard troops. They slaughtered anyone who got in their way. Women, children, my wife.").also { stage++ }
8 -> playerl("I'm sorry.").also { stage++ } 8 -> playerl("I'm sorry.").also { stage++ }
9 -> npcl("They took the other orbs, now we are defenceless.").also { stage++ } 9 -> npcl(FacialExpression.OLD_BOWS_HEAD_SAD, "They took the other orbs, now we are defenceless.").also { stage++ }
10 -> playerl("Where did they take them?").also { stage++ } 10 -> playerl("Where did they take them?").also { stage++ }
11 -> npcl("They headed north of the stronghold. A warlord carries the orbs.").also { stage++ } 11 -> npcl(FacialExpression.OLD_NORMAL, "They headed north of the stronghold. A warlord carries the orbs.").also { stage++ }
12 -> options("I will find the warlord and bring back the orbs.", "I'm sorry but I can't help.").also { stage++ } 12 -> options("I will find the warlord and bring back the orbs.", "I'm sorry but I can't help.").also { stage++ }
13 -> when(buttonID) { 13 -> when(buttonID) {
1 -> playerl("I will find the warlord and bring back the orbs.").also { stage = 15 } 1 -> playerl("I will find the warlord and bring back the orbs.").also { stage = 15 }
2 -> playerl("I'm sorry but I can't help.").also { stage = 14 } 2 -> playerl("I'm sorry but I can't help.").also { stage = 14 }
} }
14 -> npcl("I understand, this isn't your battle.").also { stage = END_DIALOGUE } 14 -> npcl(FacialExpression.OLD_NORMAL, "I understand, this isn't your battle.").also { stage = END_DIALOGUE }
15 -> npcl("You are brave, but this task will be tough even for you. I wish you the best of luck. Once again you are our only hope.").also { stage++ } 15 -> npcl(FacialExpression.OLD_NORMAL, "You are brave, but this task will be tough even for you. I wish you the best of luck. Once again you are our only hope.").also { stage++ }
16 -> npcl("I will safeguard this orb and pray for your safe return. My assistant will guide you out.").also { 16 -> npcl(FacialExpression.OLD_NORMAL, "I will safeguard this orb and pray for your safe return. My assistant will guide you out.").also {
stage++ stage++
} }
17 -> { 17 -> {
if(removeItem(player!!,Items.ORB_OF_PROTECTION_587)){ if(removeItem(player!!,Items.ORB_OF_PROTECTION_587)){
teleport(player!!,mazeEntrance) teleport(player!!,mazeEntrance)
setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 40) setQuestStage(player!!, Quests.TREE_GNOME_VILLAGE, 40)
sendNPCDialogue(player!!, NPCs.ELKOY_5179, "Good luck friend.") sendNPCDialogue(player!!, NPCs.ELKOY_5179, "Good luck friend.", FacialExpression.OLD_NORMAL)
} }
stage = END_DIALOGUE stage = END_DIALOGUE
} }
@ -100,9 +101,9 @@ class KingBolrenDialogue : DialogueFile() {
} else { } else {
when(stage) { when(stage) {
0 -> playerl("Hello Bolren.").also { stage++ } 0 -> playerl("Hello Bolren.").also { stage++ }
1 -> npcl("Do you have the orb?").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Do you have the orb?").also { stage++ }
2 -> playerl("No, I'm afraid not.").also { stage++ } 2 -> playerl("No, I'm afraid not.").also { stage++ }
3 -> npcl("Please, we must have the orb if we are to survive.").also { stage = END_DIALOGUE } 3 -> npcl(FacialExpression.OLD_NORMAL, "Please, we must have the orb if we are to survive.").also { stage = END_DIALOGUE }
} }
} }
} }
@ -110,12 +111,12 @@ class KingBolrenDialogue : DialogueFile() {
if(inInventory(player!!,Items.ORBS_OF_PROTECTION_588)){ if(inInventory(player!!,Items.ORBS_OF_PROTECTION_588)){
when(stage) { when(stage) {
0 -> playerl("Bolren, I have returned.").also { stage++ } 0 -> playerl("Bolren, I have returned.").also { stage++ }
1 -> npcl("You made it back! Do you have the orbs?").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "You made it back! Do you have the orbs?").also { stage++ }
2 -> playerl("I have them here.").also { stage++ } 2 -> playerl("I have them here.").also { stage++ }
3 -> npcl("Hooray, you're amazing. I didn't think it was possible but you've saved us.").also { stage++ } 3 -> npcl(FacialExpression.OLD_HAPPY, "Hooray, you're amazing. I didn't think it was possible but you've saved us.").also { stage++ }
4 -> npcl("Once the orbs are replaced we will be safe once more. We must begin the ceremony immediately.").also { stage++ } 4 -> npcl(FacialExpression.OLD_NORMAL, "Once the orbs are replaced we will be safe once more. We must begin the ceremony immediately.").also { stage++ }
5 -> playerl("What does the ceremony involve?").also { stage++ } 5 -> playerl("What does the ceremony involve?").also { stage++ }
6 -> npcl("The spirit tree has looked over us for centuries. Now we must pay our respects.").also { stage++ } 6 -> npcl(FacialExpression.OLD_NORMAL, "The spirit tree has looked over us for centuries. Now we must pay our respects.").also { stage++ }
7 -> sendDialogue(player!!,"The gnomes begin to chant. Meanwhile, King Bolren holds the orbs of protection out in front of him.").also { stage++ } 7 -> sendDialogue(player!!,"The gnomes begin to chant. Meanwhile, King Bolren holds the orbs of protection out in front of him.").also { stage++ }
8 -> { 8 -> {
// Orbs fly up, gnomes chant, spirit tree animates // Orbs fly up, gnomes chant, spirit tree animates
@ -166,20 +167,20 @@ class KingBolrenDialogue : DialogueFile() {
} else { } else {
when(stage) { when(stage) {
0 -> playerl("Bolren, I have returned.").also { stage++ } 0 -> playerl("Bolren, I have returned.").also { stage++ }
1 -> npcl("You made it back! Do you have the orbs?").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "You made it back! Do you have the orbs?").also { stage++ }
2 -> playerl("No, I'm afraid not.").also { stage++ } 2 -> playerl("No, I'm afraid not.").also { stage++ }
3 -> npcl("Please, we must have the orb if we are to survive.").also { stage = END_DIALOGUE } 3 -> npcl(FacialExpression.OLD_NORMAL, "Please, we must have the orb if we are to survive.").also { stage = END_DIALOGUE }
} }
} }
} }
questStage == 99 -> { questStage == 99 -> {
when(stage){ when(stage){
0 -> npcl("Now at last my people are safe once more. We can live in peace again.").also { stage++ } 0 -> npcl(FacialExpression.OLD_NORMAL, "Now at last my people are safe once more. We can live in peace again.").also { stage++ }
1 -> playerl("I'm pleased I could help.").also { stage++ } 1 -> playerl("I'm pleased I could help.").also { stage++ }
2 -> npcl("You are modest brave traveller.").also { stage++ } 2 -> npcl(FacialExpression.OLD_NORMAL, "You are modest brave traveller.").also { stage++ }
3 -> npcl("Please, for your efforts take this amulet. It's made from the same sacred stone as the orbs of protection. It will help keep you safe on your journeys.").also { stage++ } 3 -> npcl(FacialExpression.OLD_NORMAL, "Please, for your efforts take this amulet. It's made from the same sacred stone as the orbs of protection. It will help keep you safe on your journeys.").also { stage++ }
4 -> playerl("Thank you King Bolren.").also { stage++ } 4 -> playerl("Thank you King Bolren.").also { stage++ }
5 -> npcl("The tree has many other powers, some of which I cannot reveal. As a friend of the gnome people, I can now allow you to use the tree's magic to teleport to other trees grown from related seeds.").also { 5 -> npcl(FacialExpression.OLD_NORMAL, "The tree has many other powers, some of which I cannot reveal. As a friend of the gnome people, I can now allow you to use the tree's magic to teleport to other trees grown from related seeds.").also {
finishQuest(player!!, Quests.TREE_GNOME_VILLAGE) finishQuest(player!!, Quests.TREE_GNOME_VILLAGE)
stage = END_DIALOGUE stage = END_DIALOGUE
} }
@ -188,9 +189,9 @@ class KingBolrenDialogue : DialogueFile() {
isQuestComplete(player!!, Quests.TREE_GNOME_VILLAGE) -> { isQuestComplete(player!!, Quests.TREE_GNOME_VILLAGE) -> {
when(stage) { when(stage) {
0 -> playerl("Hello again Bolren.").also { stage++ } 0 -> playerl("Hello again Bolren.").also { stage++ }
1 -> npcl("Well hello, it's good to see you again.").also { stage = if (hasAnItem(player!!, Items.GNOME_AMULET_589).container != null) END_DIALOGUE else 2 } 1 -> npcl(FacialExpression.OLD_NORMAL, "Well hello, it's good to see you again.").also { stage = if (hasAnItem(player!!, Items.GNOME_AMULET_589).container != null) END_DIALOGUE else 2 }
2 -> playerl("I've lost my amulet.").also { stage++ } 2 -> playerl("I've lost my amulet.").also { stage++ }
3 -> npcl("Oh dear. Here, take another. We are truly indebted to you.").also { 3 -> npcl(FacialExpression.OLD_NORMAL, "Oh dear. Here, take another. We are truly indebted to you.").also {
addItemOrDrop(player!!, Items.GNOME_AMULET_589) addItemOrDrop(player!!, Items.GNOME_AMULET_589)
stage = END_DIALOGUE stage = END_DIALOGUE
} }

View File

@ -1,17 +1,18 @@
package content.region.kandarin.quest.tree package content.region.kandarin.quest.tree
import core.game.dialogue.DialogueFile import core.game.dialogue.DialogueFile
import core.game.dialogue.FacialExpression
import core.tools.END_DIALOGUE import core.tools.END_DIALOGUE
class LieutenantSchepburDialogue : DialogueFile(){ class LieutenantSchepburDialogue : DialogueFile(){
override fun handle(componentID: Int, buttonID: Int) { override fun handle(componentID: Int, buttonID: Int) {
when(stage) { when(stage) {
0 -> npcl("Move into position lads! eh? Who are you and what do you want?").also { stage++ } 0 -> npcl(FacialExpression.OLD_NORMAL, "Move into position lads! eh? Who are you and what do you want?").also { stage++ }
1 -> playerl("Who are you then?").also { stage++ } 1 -> playerl("Who are you then?").also { stage++ }
2 -> npcl("Lieutenant Schepbur, commanding officer of the new Armoured Tortoise Regiment.").also { stage++ } 2 -> npcl(FacialExpression.OLD_NORMAL, "Lieutenant Schepbur, commanding officer of the new Armoured Tortoise Regiment.").also { stage++ }
3 -> playerl("There's only two tortoises here, that's hardly a regiment.").also { stage++ } 3 -> playerl("There's only two tortoises here, that's hardly a regiment.").also { stage++ }
4 -> npcl("This is just the beginning! Gnome breeders and trainers are already working to expand the number of units. Soon we'll have hundreds of these beauties, nay thousands! And they will not only carry mages and").also { stage++ } 4 -> npcl(FacialExpression.OLD_NORMAL, "This is just the beginning! Gnome breeders and trainers are already working to expand the number of units. Soon we'll have hundreds of these beauties, nay thousands! And they will not only carry mages and").also { stage++ }
5 -> npcl("archers but other fiendish weapons of destruction of gnome devising. An army of giant tortoises will march upon this battlefield and rain the fire of our wrath upon all our enemies! Nothing will be able to stop us!").also { stage++ } 5 -> npcl(FacialExpression.OLD_NORMAL, "archers but other fiendish weapons of destruction of gnome devising. An army of giant tortoises will march upon this battlefield and rain the fire of our wrath upon all our enemies! Nothing will be able to stop us!").also { stage++ }
6 -> playerl("Oooookayy...... I'll leave you to it then....").also { stage = END_DIALOGUE } 6 -> playerl("Oooookayy...... I'll leave you to it then....").also { stage = END_DIALOGUE }
} }
} }

View File

@ -1,13 +1,14 @@
package content.region.kandarin.quest.tree package content.region.kandarin.quest.tree
import core.game.dialogue.DialogueFile import core.game.dialogue.DialogueFile
import core.game.dialogue.FacialExpression
import core.tools.END_DIALOGUE import core.tools.END_DIALOGUE
class LocalGnomeDialogue : DialogueFile() { class LocalGnomeDialogue : DialogueFile() {
override fun handle(componentID: Int, buttonID: Int) { override fun handle(componentID: Int, buttonID: Int) {
when (stage) { when (stage) {
0 -> playerl("Hello little man.").also { stage++ } 0 -> playerl("Hello little man.").also { stage++ }
1 -> npcl("Little man stronger than big man. Hee hee, lardi dee, lardi da.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_LAUGH1, "Little man stronger than big man. Hee hee, lardi dee, lardi da.").also { stage = END_DIALOGUE }
} }
} }
} }

View File

@ -5,6 +5,7 @@ import core.api.inInventory
import core.api.getQuestStage import core.api.getQuestStage
import org.rs09.consts.Items import org.rs09.consts.Items
import core.game.dialogue.DialogueFile import core.game.dialogue.DialogueFile
import core.game.dialogue.FacialExpression
import core.tools.END_DIALOGUE import core.tools.END_DIALOGUE
class RemsaiDialogue : DialogueFile(){ class RemsaiDialogue : DialogueFile(){
@ -14,35 +15,35 @@ class RemsaiDialogue : DialogueFile(){
inInventory(player!!,Items.ORBS_OF_PROTECTION_588) -> { inInventory(player!!,Items.ORBS_OF_PROTECTION_588) -> {
when(stage) { when(stage) {
0 -> playerl("I've returned.").also { stage++ } 0 -> playerl("I've returned.").also { stage++ }
1 -> npcl("You're back, well done brave adventurer. Now the orbs are safe we can perform the ritual for the spirit tree. We can live in peace once again.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_NORMAL, "You're back, well done brave adventurer. Now the orbs are safe we can perform the ritual for the spirit tree. We can live in peace once again.").also { stage = END_DIALOGUE }
} }
} }
inInventory(player!!, Items.ORB_OF_PROTECTION_587) -> { inInventory(player!!, Items.ORB_OF_PROTECTION_587) -> {
when(stage) { when(stage) {
0 -> playerl("Hello Remsai.").also { stage++ } 0 -> playerl("Hello Remsai.").also { stage++ }
1 -> npcl("Hello, did you find the orb?").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Hello, did you find the orb?").also { stage++ }
2 -> playerl("I have it here.").also { stage++ } 2 -> playerl("I have it here.").also { stage++ }
3 -> npcl("You're our saviour.").also { stage = END_DIALOGUE } 3 -> npcl(FacialExpression.OLD_HAPPY, "You're our saviour.").also { stage = END_DIALOGUE }
} }
} }
questStage < 40 -> { questStage < 40 -> {
when(stage) { when(stage) {
0 -> playerl("Hello Remsai.").also { stage++ } 0 -> playerl("Hello Remsai.").also { stage++ }
1 -> npcl("Hello, did you find the orb?").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "Hello, did you find the orb?").also { stage++ }
2 -> playerl("No, I'm afraid not.").also { stage++ } 2 -> playerl("No, I'm afraid not.").also { stage++ }
3 -> npcl("Please, we must have the orb if we are to survive.").also { stage = END_DIALOGUE } 3 -> npcl(FacialExpression.OLD_NORMAL, "Please, we must have the orb if we are to survive.").also { stage = END_DIALOGUE }
} }
} }
questStage == 40 -> { questStage == 40 -> {
when(stage) { when(stage) {
0 -> playerl("Are you ok?").also { stage++ } 0 -> playerl("Are you ok?").also { stage++ }
1 -> npcl("Khazard's men came. Without the orb we were defenceless. They killed many and then took our last hope, the other orbs. Now surely we're all doomed. Without them the spirit tree is useless.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_DISTRESSED, "Khazard's men came. Without the orb we were defenceless. They killed many and then took our last hope, the other orbs. Now surely we're all doomed. Without them the spirit tree is useless.").also { stage = END_DIALOGUE }
} }
} }
questStage > 40 -> { questStage > 40 -> {
when(stage) { when(stage) {
0 -> playerl("I've returned.").also { stage++ } 0 -> playerl("I've returned.").also { stage++ }
1 -> npcl("You're back, well done brave adventurer. Now the orbs are safe we can perform the ritual for the spirit tree. We can live in peace once again.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_NORMAL, "You're back, well done brave adventurer. Now the orbs are safe we can perform the ritual for the spirit tree. We can live in peace once again.").also { stage = END_DIALOGUE }
} }
} }
} }

View File

@ -4,6 +4,7 @@ import content.data.Quests
import core.api.* import core.api.*
import org.rs09.consts.Items import org.rs09.consts.Items
import core.game.dialogue.DialogueFile import core.game.dialogue.DialogueFile
import core.game.dialogue.FacialExpression
import core.tools.END_DIALOGUE import core.tools.END_DIALOGUE
class TrackerGnomeOneDialogue : DialogueFile(){ class TrackerGnomeOneDialogue : DialogueFile(){
@ -13,32 +14,32 @@ class TrackerGnomeOneDialogue : DialogueFile(){
questStage >= 40 -> { questStage >= 40 -> {
when (stage) { when (stage) {
0 -> playerl("Hello").also { stage++ } 0 -> playerl("Hello").also { stage++ }
1 -> npcl("When will this battle end? I feel like I've been fighting forever.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_BOWS_HEAD_SAD, "When will this battle end? I feel like I've been fighting forever.").also { stage = END_DIALOGUE }
} }
} }
questStage > 30 -> { questStage > 30 -> {
if(inInventory(player!!, Items.ORB_OF_PROTECTION_587)){ if(inInventory(player!!, Items.ORB_OF_PROTECTION_587)){
when(stage) { when(stage) {
0 -> playerl("How are you tracker?").also { stage++ } 0 -> playerl("How are you tracker?").also { stage++ }
1 -> npcl("Now we have the orb I'm much better. They won't stand a chance without it.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_NORMAL, "Now we have the orb I'm much better. They won't stand a chance without it.").also { stage = END_DIALOGUE }
} }
} else { } else {
when(stage) { when(stage) {
0 -> playerl("Hello again.").also { stage++ } 0 -> playerl("Hello again.").also { stage++ }
1 -> npcl("Well done, you've broken down their defences. This battle must be ours.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_NORMAL, "Well done, you've broken down their defences. This battle must be ours.").also { stage = END_DIALOGUE }
} }
} }
} }
questStage == 30 -> { questStage == 30 -> {
when (stage) { when (stage) {
0 -> playerl("Do you know the coordinates of the Khazard stronghold?").also { stage++ } 0 -> playerl("Do you know the coordinates of the Khazard stronghold?").also { stage++ }
1 -> npcl("I managed to get one, although it wasn't easy.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "I managed to get one, although it wasn't easy.").also { stage++ }
2 -> sendDialogue(player!!, "The gnome tells you the height coordinate.").also { 2 -> sendDialogue(player!!, "The gnome tells you the height coordinate.").also {
setAttribute(player!!, "/save:treegnome:tracker1", true) setAttribute(player!!, "/save:treegnome:tracker1", true)
stage++ stage++
} }
3 -> playerl("Well done.").also { stage++ } 3 -> playerl("Well done.").also { stage++ }
4 -> npcl("The other two tracker gnomes should have the other coordinates if they're still alive.").also { stage++ } 4 -> npcl(FacialExpression.OLD_NORMAL, "The other two tracker gnomes should have the other coordinates if they're still alive.").also { stage++ }
5 -> playerl("OK, take care.").also { stage = END_DIALOGUE } 5 -> playerl("OK, take care.").also { stage = END_DIALOGUE }
} }
} }

View File

@ -3,6 +3,7 @@ package content.region.kandarin.quest.tree
import content.data.Quests import content.data.Quests
import core.api.* import core.api.*
import core.game.dialogue.DialogueFile import core.game.dialogue.DialogueFile
import core.game.dialogue.FacialExpression
import core.tools.END_DIALOGUE import core.tools.END_DIALOGUE
class TrackerGnomeThreeDialogue : DialogueFile(){ class TrackerGnomeThreeDialogue : DialogueFile(){
@ -19,31 +20,31 @@ class TrackerGnomeThreeDialogue : DialogueFile(){
questStage == 30 -> { questStage == 30 -> {
when(stage) { when(stage) {
0 -> playerl("Are you OK?").also { stage++ } 0 -> playerl("Are you OK?").also { stage++ }
1 -> npcl("OK? Who's OK? Not me! Hee hee!").also { stage++ } 1 -> npcl(FacialExpression.OLD_LAUGH1, "OK? Who's OK? Not me! Hee hee!").also { stage++ }
2 -> playerl("What's wrong?").also { stage++ } 2 -> playerl("What's wrong?").also { stage++ }
3 -> npcl("You can't see me, no one can. Monsters, demons, they're all around me!").also { stage++ } 3 -> npcl(FacialExpression.OLD_LAUGH1, "You can't see me, no one can. Monsters, demons, they're all around me!").also { stage++ }
4 -> playerl("What do you mean?").also { stage++ } 4 -> playerl("What do you mean?").also { stage++ }
5 -> npcl("They're dancing, all of them, hee hee.").also { stage++ } 5 -> npcl(FacialExpression.OLD_LAUGH1, "They're dancing, all of them, hee hee.").also { stage++ }
6 -> sendDialogue(player!!,"He's clearly lost the plot.").also { stage++ } 6 -> sendDialogue(player!!,"He's clearly lost the plot.").also { stage++ }
7 -> playerl("Do you have the coordinate for the Khazard stronghold?").also { stage++ } 7 -> playerl("Do you have the coordinate for the Khazard stronghold?").also { stage++ }
8 -> npcl("Who holds the stronghold?").also { stage++ } 8 -> npcl(FacialExpression.OLD_NORMAL, "Who holds the stronghold?").also { stage++ }
9 -> playerl("What?").also { stage++ } 9 -> playerl("What?").also { stage++ }
10 -> { 10 -> {
// Generate the x coordinate answer // Generate the x coordinate answer
if(getAttribute(player!!,"treegnome:xcoord",0) == 0){ if(getAttribute(player!!,"treegnome:xcoord",0) == 0){
val answer = (1..4).random() val answer = (1..4).random()
npcl(xcoordMap[answer]) npcl(FacialExpression.OLD_NORMAL, xcoordMap[answer])
setAttribute(player!!,"/save:treegnome:xcoord",answer) setAttribute(player!!,"/save:treegnome:xcoord",answer)
} else { } else {
npcl(xcoordMap[getAttribute(player!!,"treegnome:xcoord",1)]) npcl(FacialExpression.OLD_NORMAL, xcoordMap[getAttribute(player!!,"treegnome:xcoord",1)])
} }
stage++ stage++
} }
11 -> playerl("You're mad").also { stage++ } 11 -> playerl("You're mad").also { stage++ }
12 -> npcl("Dance with me, and Khazard's men are beat.").also { stage++ } 12 -> npcl(FacialExpression.OLD_LAUGH1, "Dance with me, and Khazard's men are beat.").also { stage++ }
13 -> sendDialogue(player!!,"The toll of war has affected his mind.").also { stage++ } 13 -> sendDialogue(player!!,"The toll of war has affected his mind.").also { stage++ }
14 -> playerl("I'll pray for you little man.").also { stage++ } 14 -> playerl("I'll pray for you little man.").also { stage++ }
15 -> npcl("All day we pray in the hay, hee hee.").also { 15 -> npcl(FacialExpression.OLD_LAUGH1, "All day we pray in the hay, hee hee.").also {
setAttribute(player!!, "/save:treegnome:tracker3", true) setAttribute(player!!, "/save:treegnome:tracker3", true)
stage = END_DIALOGUE stage = END_DIALOGUE
} }
@ -52,13 +53,13 @@ class TrackerGnomeThreeDialogue : DialogueFile(){
questStage == 31 -> { questStage == 31 -> {
when(stage) { when(stage) {
0 -> playerl("Hello again.").also { stage++ } 0 -> playerl("Hello again.").also { stage++ }
1 -> npcl("Don't talk to me, you can't see me. No one can, just the demons.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_BOWS_HEAD_SAD, "Don't talk to me, you can't see me. No one can, just the demons.").also { stage = END_DIALOGUE }
} }
} }
questStage > 31 -> { questStage > 31 -> {
when(stage) { when(stage) {
0 -> playerl("Hello").also { stage++ } 0 -> playerl("Hello").also { stage++ }
1 -> npcl("I feel dizzy, where am I? Oh dear, oh dear I need some rest.").also { stage++ } 1 -> npcl(FacialExpression.OLD_NORMAL, "I feel dizzy, where am I? Oh dear, oh dear I need some rest.").also { stage++ }
2 -> playerl("I think you do.").also { stage = END_DIALOGUE } 2 -> playerl("I think you do.").also { stage = END_DIALOGUE }
} }
} }

View File

@ -4,6 +4,7 @@ import content.data.Quests
import core.api.* import core.api.*
import org.rs09.consts.Items import org.rs09.consts.Items
import core.game.dialogue.DialogueFile import core.game.dialogue.DialogueFile
import core.game.dialogue.FacialExpression
import core.tools.END_DIALOGUE import core.tools.END_DIALOGUE
class TrackerGnomeTwoDialogue : DialogueFile(){ class TrackerGnomeTwoDialogue : DialogueFile(){
@ -13,36 +14,36 @@ class TrackerGnomeTwoDialogue : DialogueFile(){
questStage == 30 -> { questStage == 30 -> {
when (stage) { when (stage) {
0 -> playerl("Are you OK?").also { stage++ } 0 -> playerl("Are you OK?").also { stage++ }
1 -> npcl("They caught me spying on the stronghold. They beat and tortured me.").also { stage++ } 1 -> npcl(FacialExpression.OLD_DISTRESSED, "They caught me spying on the stronghold. They beat and tortured me.").also { stage++ }
2 -> npcl("But I didn't crack. I told them nothing. They can't break me!").also { stage++ } 2 -> npcl(FacialExpression.OLD_LAUGH1, "But I didn't crack. I told them nothing. They can't break me!").also { stage++ }
3 -> playerl("I'm sorry little man.").also { stage++ } 3 -> playerl("I'm sorry little man.").also { stage++ }
4 -> npcl("Don't be. I have the position of the stronghold!").also { stage++ } 4 -> npcl(FacialExpression.OLD_LAUGH1, "Don't be. I have the position of the stronghold!").also { stage++ }
5 -> sendDialogue(player!!, "The gnome tells you the y coordinate.").also { 5 -> sendDialogue(player!!, "The gnome tells you the y coordinate.").also {
setAttribute(player!!, "/save:treegnome:tracker2", true) setAttribute(player!!, "/save:treegnome:tracker2", true)
stage++ stage++
} }
6 -> playerl("Well done.").also { stage++ } 6 -> playerl("Well done.").also { stage++ }
7 -> npcl("Now leave before they find you and all is lost.").also { stage++ } 7 -> npcl(FacialExpression.OLD_NORMAL, "Now leave before they find you and all is lost.").also { stage++ }
8 -> playerl("Hang in there.").also { stage++ } 8 -> playerl("Hang in there.").also { stage++ }
9 -> npcl("Go!").also { stage = END_DIALOGUE } 9 -> npcl(FacialExpression.OLD_NORMAL, "Go!").also { stage = END_DIALOGUE }
} }
} }
questStage >= 40 -> { questStage >= 40 -> {
when(stage) { when(stage) {
0 -> playerl("Hello").also { stage++ } 0 -> playerl("Hello").also { stage++ }
1 -> npcl("When will this battle end? I feel like I've been locked up my whole life.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_DISTRESSED, "When will this battle end? I feel like I've been locked up my whole life.").also { stage = END_DIALOGUE }
} }
} }
questStage > 30 -> { questStage > 30 -> {
if(inInventory(player!!,Items.ORB_OF_PROTECTION_587)){ if(inInventory(player!!,Items.ORB_OF_PROTECTION_587)){
when(stage) { when(stage) {
0 -> playerl("How are you tracker?").also { stage++ } 0 -> playerl("How are you tracker?").also { stage++ }
1 -> npcl("Now we have the orb I'm much better. Soon my comrades will come and free me.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_NORMAL, "Now we have the orb I'm much better. Soon my comrades will come and free me.").also { stage = END_DIALOGUE }
} }
} else { } else {
when(stage) { when(stage) {
0 -> playerl("Hello again.").also { stage++ } 0 -> playerl("Hello again.").also { stage++ }
1 -> npcl("Well done, you've broken down their defences. This battle must be ours.").also { stage = END_DIALOGUE } 1 -> npcl(FacialExpression.OLD_NORMAL, "Well done, you've broken down their defences. This battle must be ours.").also { stage = END_DIALOGUE }
} }
} }
} }

View File

@ -18,7 +18,7 @@ class ServerConstants {
var NOAUTH_DEFAULT_ADMIN: Boolean = true var NOAUTH_DEFAULT_ADMIN: Boolean = true
@JvmField @JvmField
var CURRENT_SAVEFILE_VERSION = 3 var CURRENT_SAVEFILE_VERSION = 4
@JvmField @JvmField
var DAILY_ACCOUNT_LIMIT = 3 var DAILY_ACCOUNT_LIMIT = 3

View File

@ -130,8 +130,8 @@ public final class BankContainer extends Container {
}); });
player.getInterfaceManager().openSingleTab(new Component(763)); player.getInterfaceManager().openSingleTab(new Component(763));
super.refresh(); super.refresh();
player.getInventory().getListeners().add(listener);
player.getInventory().refresh(); player.getInventory().refresh();
player.getInventory().getListeners().add(listener);
setVarp(player, 1249, lastAmountX); setVarp(player, 1249, lastAmountX);
int settings = new IfaceSettingsBuilder().enableOptions(new IntRange(0, 5)).enableExamine().enableSlotSwitch().build(); int settings = new IfaceSettingsBuilder().enableOptions(new IntRange(0, 5)).enableExamine().enableSlotSwitch().build();
player.getPacketDispatch().sendIfaceSettings(settings, 0, 763, 0, 27); player.getPacketDispatch().sendIfaceSettings(settings, 0, 763, 0, 27);

View File

@ -81,6 +81,22 @@ class SaveVersionHooks : LoginListener {
} }
} }
if (player.version < 4) { //GL !2065
replaceAllItems(player, Items.BLURBERRY_SPECIAL_9520, Items.BLURBERRY_SPECIAL_2064)
replaceAllItems(player, Items.BLURBERRY_SPECIAL_9521, Items.BLURBERRY_SPECIAL_2065)
replaceAllItems(player, Items.LAMP_6796, Items.LAMP_2528)
replaceAllItems(player, Items.RUNE_SHIELDH1_10667, Items.RUNE_SHIELDH1_7336)
replaceAllItems(player, Items.RUNE_SHIELDH2_10670, Items.RUNE_SHIELDH2_7342)
replaceAllItems(player, Items.RUNE_SHIELDH3_10673, Items.RUNE_SHIELDH3_7348)
replaceAllItems(player, Items.RUNE_SHIELDH4_10676, Items.RUNE_SHIELDH4_7354)
replaceAllItems(player, Items.RUNE_SHIELDH5_10679, Items.RUNE_SHIELDH5_7360)
replaceAllItems(player, Items.ADAMANT_SHIELDH1_10666, Items.ADAMANT_SHIELDH1_7334)
replaceAllItems(player, Items.ADAMANT_SHIELDH2_10669, Items.ADAMANT_SHIELDH2_7340)
replaceAllItems(player, Items.ADAMANT_SHIELDH3_10672, Items.ADAMANT_SHIELDH3_7346)
replaceAllItems(player, Items.ADAMANT_SHIELDH4_10675, Items.ADAMANT_SHIELDH4_7352)
replaceAllItems(player, Items.ADAMANT_SHIELDH5_10678, Items.ADAMANT_SHIELDH5_7358)
}
// Finish up // Finish up
player.version = ServerConstants.CURRENT_SAVEFILE_VERSION player.version = ServerConstants.CURRENT_SAVEFILE_VERSION
} }