Improved and fixed share progress level 2

This commit is contained in:
AlessioDP 2019-09-11 19:43:00 +02:00
parent 0d0cd1e27c
commit 550fbc4b4a
No known key found for this signature in database
GPG Key ID: B92B813840FFCC9F
2 changed files with 167 additions and 264 deletions

View File

@ -221,16 +221,11 @@ public abstract class CustomObjective implements Listener {
quester.finishObjective(quest, "customObj", null, null, null, null, null, null, null, null, null, obj); quester.finishObjective(quest, "customObj", null, null, null, null, null, null, null, null, null, obj);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { quester.dispatchMultiplayerEventShareObjective(quest, quester.getCurrentStage(quest), (Quester q) -> {
List<Quester> mq = quester.getMultiplayerQuestersByQuest(quest); q.getQuestData(quest).customObjectiveCounts.put(obj.getName(), quester.getQuestData(quest).customObjectiveCounts.get(obj.getName()));
if (mq != null) { q.finishObjective(quest, "customObj", null, null, null, null, null, null, null, null, null, obj);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "customObj", null, null, null, null, null, null, null, null, null, obj);
}
}
}
}
} }
} }
} }

View File

@ -27,6 +27,7 @@ import java.util.Set;
import java.util.UUID; import java.util.UUID;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
import java.util.function.BiFunction; import java.util.function.BiFunction;
import java.util.function.Function;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.ChatColor; import org.bukkit.ChatColor;
@ -1069,7 +1070,7 @@ public class Quester {
} }
} }
if (broken.getAmount() < toBreak.getAmount()) { if (broken.getAmount() < toBreak.getAmount()) {
ItemStack newBroken = broken; final ItemStack newBroken = broken;
newBroken.setAmount(broken.getAmount() + 1); newBroken.setAmount(broken.getAmount() + 1);
if (getQuestData(quest).blocksBroken.contains(broken)) { if (getQuestData(quest).blocksBroken.contains(broken)) {
getQuestData(quest).blocksBroken.set(getQuestData(quest).blocksBroken.indexOf(broken), newBroken); getQuestData(quest).blocksBroken.set(getQuestData(quest).blocksBroken.indexOf(broken), newBroken);
@ -1077,16 +1078,13 @@ public class Quester {
finishObjective(quest, "breakBlock", m, toBreak, null, null, null, null, null, null, null, null); finishObjective(quest, "breakBlock", m, toBreak, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final ItemStack finalBroken = broken;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); final ItemStack finalToBreak = toBreak;
if (mq != null) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
for (Quester q : mq) { q.getQuestData(quest).blocksBroken.set(getQuestData(quest).blocksBroken.indexOf(finalBroken), newBroken);
if (q.getCurrentQuests().containsKey(quest)) { q.finishObjective(quest, "breakBlock", m, finalToBreak, null, null, null, null, null, null, null, null);
q.finishObjective(quest, "breakBlock", m, toBreak, null, null, null, null, null, null, null, null); return null;
} });
}
}
}
} }
} }
} }
@ -1137,7 +1135,7 @@ public class Quester {
} }
} }
if (damaged.getAmount() < toDamage.getAmount()) { if (damaged.getAmount() < toDamage.getAmount()) {
ItemStack newDamaged = damaged; final ItemStack newDamaged = damaged;
newDamaged.setAmount(damaged.getAmount() + 1); newDamaged.setAmount(damaged.getAmount() + 1);
if (getQuestData(quest).blocksDamaged.contains(damaged)) { if (getQuestData(quest).blocksDamaged.contains(damaged)) {
getQuestData(quest).blocksDamaged.set(getQuestData(quest).blocksDamaged.indexOf(damaged), newDamaged); getQuestData(quest).blocksDamaged.set(getQuestData(quest).blocksDamaged.indexOf(damaged), newDamaged);
@ -1145,16 +1143,13 @@ public class Quester {
finishObjective(quest, "damageBlock", m, toDamage, null, null, null, null, null, null, null, null); finishObjective(quest, "damageBlock", m, toDamage, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final ItemStack finalDamaged = damaged;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); final ItemStack finalToDamage = toDamage;
if (mq != null) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
for (Quester q : mq) { q.getQuestData(quest).blocksDamaged.set(getQuestData(quest).blocksDamaged.indexOf(finalDamaged), newDamaged);
if (q.getCurrentQuests().containsKey(quest)) { q.finishObjective(quest, "damageBlock", m, finalToDamage, null, null, null, null, null, null, null, null);
q.finishObjective(quest, "damageBlock", m, toDamage, null, null, null, null, null, null, null, null); return null;
} });
}
}
}
} }
} }
} }
@ -1205,7 +1200,7 @@ public class Quester {
} }
} }
if (placed.getAmount() < toPlace.getAmount()) { if (placed.getAmount() < toPlace.getAmount()) {
ItemStack newplaced = placed; final ItemStack newplaced = placed;
newplaced.setAmount(placed.getAmount() + 1); newplaced.setAmount(placed.getAmount() + 1);
if (getQuestData(quest).blocksPlaced.contains(placed)) { if (getQuestData(quest).blocksPlaced.contains(placed)) {
getQuestData(quest).blocksPlaced.set(getQuestData(quest).blocksPlaced.indexOf(placed), newplaced); getQuestData(quest).blocksPlaced.set(getQuestData(quest).blocksPlaced.indexOf(placed), newplaced);
@ -1213,16 +1208,13 @@ public class Quester {
finishObjective(quest, "placeBlock", m, toPlace, null, null, null, null, null, null, null, null); finishObjective(quest, "placeBlock", m, toPlace, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final ItemStack finalPlaced = placed;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); final ItemStack finalToPlace = toPlace;
if (mq != null) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
for (Quester q : mq) { q.getQuestData(quest).blocksPlaced.set(getQuestData(quest).blocksPlaced.indexOf(finalPlaced), newplaced);
if (q.getCurrentQuests().containsKey(quest)) { q.finishObjective(quest, "damageBlock", m, finalToPlace, null, null, null, null, null, null, null, null);
q.finishObjective(quest, "placeBlock", m, toPlace, null, null, null, null, null, null, null, null); return null;
} });
}
}
}
} }
} }
} }
@ -1273,7 +1265,7 @@ public class Quester {
} }
} }
if (used.getAmount() < toUse.getAmount()) { if (used.getAmount() < toUse.getAmount()) {
ItemStack newUsed = used; final ItemStack newUsed = used;
newUsed.setAmount(used.getAmount() + 1); newUsed.setAmount(used.getAmount() + 1);
if (getQuestData(quest).blocksUsed.contains(used)) { if (getQuestData(quest).blocksUsed.contains(used)) {
getQuestData(quest).blocksUsed.set(getQuestData(quest).blocksUsed.indexOf(used), newUsed); getQuestData(quest).blocksUsed.set(getQuestData(quest).blocksUsed.indexOf(used), newUsed);
@ -1281,16 +1273,13 @@ public class Quester {
finishObjective(quest, "useBlock", m, toUse, null, null, null, null, null, null, null, null); finishObjective(quest, "useBlock", m, toUse, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final ItemStack finalUsed = used;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); final ItemStack finalToUse = toUse;
if (mq != null) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
for (Quester q : mq) { q.getQuestData(quest).blocksUsed.set(getQuestData(quest).blocksUsed.indexOf(finalUsed), newUsed);
if (q.getCurrentQuests().containsKey(quest)) { q.finishObjective(quest, "useBlock", m, finalToUse, null, null, null, null, null, null, null, null);
q.finishObjective(quest, "useBlock", m, toUse, null, null, null, null, null, null, null, null); return null;
} });
}
}
}
} }
} }
} }
@ -1341,7 +1330,7 @@ public class Quester {
} }
} }
if (cut.getAmount() < toCut.getAmount()) { if (cut.getAmount() < toCut.getAmount()) {
ItemStack newCut = cut; final ItemStack newCut = cut;
newCut.setAmount(cut.getAmount() + 1); newCut.setAmount(cut.getAmount() + 1);
if (getQuestData(quest).blocksCut.contains(cut)) { if (getQuestData(quest).blocksCut.contains(cut)) {
getQuestData(quest).blocksCut.set(getQuestData(quest).blocksCut.indexOf(cut), newCut); getQuestData(quest).blocksCut.set(getQuestData(quest).blocksCut.indexOf(cut), newCut);
@ -1349,16 +1338,13 @@ public class Quester {
finishObjective(quest, "cutBlock", m, toCut, null, null, null, null, null, null, null, null); finishObjective(quest, "cutBlock", m, toCut, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final ItemStack finalCut = cut;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); final ItemStack finalToCut = toCut;
if (mq != null) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
for (Quester q : mq) { q.getQuestData(quest).blocksCut.set(getQuestData(quest).blocksCut.indexOf(finalCut), newCut);
if (q.getCurrentQuests().containsKey(quest)) { q.finishObjective(quest, "cutBlock", m, finalToCut, null, null, null, null, null, null, null, null);
q.finishObjective(quest, "cutBlock", m, toCut, null, null, null, null, null, null, null, null); return null;
} });
}
}
}
} }
} }
} }
@ -1396,16 +1382,12 @@ public class Quester {
finishObjective(quest, "craftItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null); finishObjective(quest, "craftItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final ItemStack finalFound = found;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
if (mq != null) { q.getQuestData(quest).itemsCrafted.put(finalFound, req);
for (Quester q : mq) { q.finishObjective(quest, "craftItem", new ItemStack(m, 1), finalFound, null, null, null, null, null, null, null, null);
if (q.getCurrentQuests().containsKey(quest)) { return null;
q.finishObjective(quest, "craftItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null); });
}
}
}
}
} else { } else {
getQuestData(quest).itemsCrafted.put(found, (amount + i.getAmount())); getQuestData(quest).itemsCrafted.put(found, (amount + i.getAmount()));
} }
@ -1445,16 +1427,12 @@ public class Quester {
finishObjective(quest, "smeltItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null); finishObjective(quest, "smeltItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final ItemStack finalFound = found;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
if (mq != null) { q.getQuestData(quest).itemsSmelted.put(finalFound, req);
for (Quester q : mq) { q.finishObjective(quest, "smeltItem", new ItemStack(m, 1), finalFound, null, null, null, null, null, null, null, null);
if (q.getCurrentQuests().containsKey(quest)) { return null;
q.finishObjective(quest, "smeltItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null); });
}
}
}
}
} else { } else {
getQuestData(quest).itemsSmelted.put(found, (amount + i.getAmount())); getQuestData(quest).itemsSmelted.put(found, (amount + i.getAmount()));
} }
@ -1481,16 +1459,11 @@ public class Quester {
finishObjective(quest, "enchantItem", new ItemStack(m, 1), null, e, null, null, null, null, null, null, null); finishObjective(quest, "enchantItem", new ItemStack(m, 1), null, e, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
List<Quester> mq = getMultiplayerQuestersByQuest(quest); q.getQuestData(quest).itemsEnchanted.put(entry.getKey(), num);
if (mq != null) { q.finishObjective(quest, "enchantItem", new ItemStack(m, 1), null, null, null, null, null, null, null, null, null);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "enchantItem", new ItemStack(m, 1), null, e, null, null, null, null, null, null, null);
}
}
}
}
} }
} }
break; break;
@ -1533,16 +1506,12 @@ public class Quester {
finishObjective(quest, "brewItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null); finishObjective(quest, "brewItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final ItemStack finalFound = found;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
if (mq != null) { q.getQuestData(quest).itemsBrewed.put(finalFound, req);
for (Quester q : mq) { q.finishObjective(quest, "brewItem", new ItemStack(m, 1), finalFound, null, null, null, null, null, null, null, null);
if (q.getCurrentQuests().containsKey(quest)) { return null;
q.finishObjective(quest, "brewItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null); });
}
}
}
}
} else { } else {
getQuestData(quest).itemsBrewed.put(found, (amount + i.getAmount())); getQuestData(quest).itemsBrewed.put(found, (amount + i.getAmount()));
} }
@ -1562,16 +1531,11 @@ public class Quester {
finishObjective(quest, "catchFish", null, null, null, null, null, null, null, null, null, null); finishObjective(quest, "catchFish", null, null, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
List<Quester> mq = getMultiplayerQuestersByQuest(quest); q.getQuestData(quest).setFishCaught(getQuestData(quest).getFishCaught());
if (mq != null) { q.finishObjective(quest, "catchFish", null, null, null, null, null, null, null, null, null, null);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "catchFish", null, null, null, null, null, null, null, null, null, null);
}
}
}
}
} }
} }
} }
@ -1620,16 +1584,11 @@ public class Quester {
finishObjective(quest, "killMob", null, null, null, e, null, null, null, null, null, null); finishObjective(quest, "killMob", null, null, null, e, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { dispatchMultiplayerEventShareObjective(quest, currentStage, (Quester q) -> {
List<Quester> mq = getMultiplayerQuestersByQuest(quest); q.finishObjective(quest, "killMob", null, null, null, e, null, null, null, null, null, null);
if (mq != null) { q.getQuestData(quest).mobNumKilled.set(indexOfMobKilled, newNumberOfSpecificMobKilled);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "killMob", null, null, null, e, null, null, null, null, null, null);
}
}
}
}
} }
} }
} }
@ -1647,16 +1606,11 @@ public class Quester {
finishObjective(quest, "killPlayer", null, null, null, null, null, null, null, null, null, null); finishObjective(quest, "killPlayer", null, null, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
List<Quester> mq = getMultiplayerQuestersByQuest(quest); q.getQuestData(quest).setPlayersKilled(getQuestData(quest).getPlayersKilled());
if (mq != null) { q.finishObjective(quest, "killPlayer", null, null, null, null, null, null, null, null, null, null);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "killPlayer", null, null, null, null, null, null, null, null, null, null);
}
}
}
}
} }
} }
} }
@ -1698,41 +1652,23 @@ public class Quester {
+ " when delivering for quest " + quest.getName()); + " when delivering for quest " + quest.getName());
return; return;
} }
if ((i.getAmount() + amount) > req) { if ((i.getAmount() + amount) >= req) {
getQuestData(quest).itemsDelivered.put(found, req); getQuestData(quest).itemsDelivered.put(found, req);
i.setAmount(i.getAmount() - (req - amount)); // Take away the remaining amount needed to be delivered if ((i.getAmount() + amount) >= req) {
player.getInventory().setItem(index, i); i.setAmount(i.getAmount() - (req - amount)); // Take away the remaining amount needed to be delivered
player.getInventory().setItem(index, i);
} else {
player.getInventory().setItem(index, null);
}
player.updateInventory(); player.updateInventory();
finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null); finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
List<Quester> mq = getMultiplayerQuestersByQuest(quest); q.getQuestData(quest).itemsDelivered.put(found, req);
if (mq != null) { q.finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
}
}
}
}
} else if ((i.getAmount() + amount) == req) {
getQuestData(quest).itemsDelivered.put(found, req);
player.getInventory().setItem(index, null);
player.updateInventory();
finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
// Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) {
List<Quester> mq = getMultiplayerQuestersByQuest(quest);
if (mq != null) {
for (Quester q : mq) {
if (q.getCurrentQuests().containsKey(quest)) {
q.finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
}
}
}
}
} else { } else {
getQuestData(quest).itemsDelivered.put(found, (amount + i.getAmount())); getQuestData(quest).itemsDelivered.put(found, (amount + i.getAmount()));
player.getInventory().setItem(index, null); player.getInventory().setItem(index, null);
@ -1777,40 +1713,23 @@ public class Quester {
if (amount < req) { if (amount < req) {
if ((i.getAmount() + amount) > req) { if ((i.getAmount() + amount) > req) {
getQuestData(quest).itemsDelivered.put(found, req); getQuestData(quest).itemsDelivered.put(found, req);
int index = player.getInventory().first(i); if ((i.getAmount() + amount) > req) {
i.setAmount(i.getAmount() - (req - amount)); // Take away the remaining amount needed to be delivered int index = player.getInventory().first(i);
player.getInventory().setItem(index, i); i.setAmount(i.getAmount() - (req - amount)); // Take away the remaining amount needed to be delivered
player.getInventory().setItem(index, i);
} else {
player.getInventory().setItem(player.getInventory().first(i), null);
}
player.updateInventory(); player.updateInventory();
finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null); finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final ItemStack finalFound = found;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
if (mq != null) { q.getQuestData(quest).itemsDelivered.put(finalFound, req);
for (Quester q : mq) { q.finishObjective(quest, "deliverItem", new ItemStack(m, 1), finalFound, null, null, null, null, null, null, null, null);
if (q.getCurrentQuests().containsKey(quest)) { return null;
q.finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null); });
}
}
}
}
} else if ((i.getAmount() + amount) == req) {
getQuestData(quest).itemsDelivered.put(found, req);
player.getInventory().setItem(player.getInventory().first(i), null);
player.updateInventory();
finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
// Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) {
List<Quester> mq = getMultiplayerQuestersByQuest(quest);
if (mq != null) {
for (Quester q : mq) {
if (q.getCurrentQuests().containsKey(quest)) {
q.finishObjective(quest, "deliverItem", new ItemStack(m, 1), found, null, null, null, null, null, null, null, null);
}
}
}
}
} else { } else {
getQuestData(quest).itemsDelivered.put(found, (amount + i.getAmount())); getQuestData(quest).itemsDelivered.put(found, (amount + i.getAmount()));
player.getInventory().setItem(player.getInventory().first(i), null); player.getInventory().setItem(player.getInventory().first(i), null);
@ -1838,16 +1757,11 @@ public class Quester {
finishObjective(quest, "talkToNPC", null, null, null, null, null, n, null, null, null, null); finishObjective(quest, "talkToNPC", null, null, null, null, null, n, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
List<Quester> mq = getMultiplayerQuestersByQuest(quest); q.getQuestData(quest).citizensInteracted.put(n.getId(), true);
if (mq != null) { q.finishObjective(quest, "talkToNPC", null, null, null, null, null, n, null, null, null, null);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "talkToNPC", null, null, null, null, null, n, null, null, null, null);
}
}
}
}
} }
} }
} }
@ -1867,16 +1781,11 @@ public class Quester {
finishObjective(quest, "killNPC", null, null, null, null, null, n, null, null, null, null); finishObjective(quest, "killNPC", null, null, null, null, null, n, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
List<Quester> mq = getMultiplayerQuestersByQuest(quest); q.getQuestData(quest).citizenNumKilled.set(index, getQuestData(quest).citizenNumKilled.get(index));
if (mq != null) { q.finishObjective(quest, "killNPC", null, null, null, null, null, n, null, null, null, null);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "killNPC", null, null, null, null, null, n, null, null, null, null);
}
}
}
}
} }
} }
} }
@ -1916,16 +1825,16 @@ public class Quester {
finishObjective(quest, "reachLocation", null, null, null, null, null, null, location, null, null, null); finishObjective(quest, "reachLocation", null, null, null, null, null, null, location, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { final int finalIndex = index;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
if (mq != null) { if (finalIndex >= getQuestData(quest).hasReached.size()) {
for (Quester q : mq) { q.getQuestData(quest).hasReached.add(true);
if (q.getCurrentQuests().containsKey(quest)) { } else {
q.finishObjective(quest, "reachLocation", null, null, null, null, null, null, location, null, null, null); q.getQuestData(quest).hasReached.set(finalIndex, true);
}
}
} }
} q.finishObjective(quest, "reachLocation", null, null, null, null, null, null, location, null, null, null);
return null;
});
} }
} }
} }
@ -1956,16 +1865,11 @@ public class Quester {
finishObjective(quest, "tameMob", null, null, null, entity, null, null, null, null, null, null); finishObjective(quest, "tameMob", null, null, null, entity, null, null, null, null, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
List<Quester> mq = getMultiplayerQuestersByQuest(quest); q.getQuestData(quest).mobsTamed.put(entity, getQuestData(quest).mobsTamed.get(entity));
if (mq != null) { q.finishObjective(quest, "tameMob", null, null, null, entity, null, null, null, null, null, null);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "tameMob", null, null, null, entity, null, null, null, null, null, null);
}
}
}
}
} }
} }
} }
@ -1983,16 +1887,11 @@ public class Quester {
finishObjective(quest, "shearSheep", null, null, null, null, null, null, null, color, null, null); finishObjective(quest, "shearSheep", null, null, null, null, null, null, null, color, null, null);
// Multiplayer // Multiplayer
if (quest.getOptions().getShareProgressLevel() == 2) { dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
List<Quester> mq = getMultiplayerQuestersByQuest(quest); q.getQuestData(quest).sheepSheared.put(color, getQuestData(quest).mobsTamed.get(color));
if (mq != null) { q.finishObjective(quest, "shearSheep", null, null, null, null, null, null, null, color, null, null);
for (Quester q : mq) { return null;
if (q.getCurrentQuests().containsKey(quest)) { });
q.finishObjective(quest, "shearSheep", null, null, null, null, null, null, null, color, null, null);
}
}
}
}
} }
} }
} }
@ -2013,24 +1912,15 @@ public class Quester {
String display = getCurrentStage(quest).passwordDisplays.get(getCurrentStage(quest).passwordPhrases.indexOf(passes)); String display = getCurrentStage(quest).passwordDisplays.get(getCurrentStage(quest).passwordPhrases.indexOf(passes));
getQuestData(quest).passwordsSaid.put(display, true); getQuestData(quest).passwordsSaid.put(display, true);
done = true; done = true;
plugin.getServer().getScheduler().runTask(plugin, new Runnable() { plugin.getServer().getScheduler().runTask(plugin, () -> {
finishObjective(quest, "password", null, null, null, null, null, null, null, null, display, null);
@Override
public void run() { // Multiplayer
finishObjective(quest, "password", null, null, null, null, null, null, null, null, display, null); dispatchMultiplayerEventShareObjective(quest, getCurrentStage(quest), (Quester q) -> {
q.getQuestData(quest).passwordsSaid.put(display, true);
// Multiplayer q.finishObjective(quest, "password", null, null, null, null, null, null, null, null, display, null);
if (quest.getOptions().getShareProgressLevel() == 2) { return null;
List<Quester> mq = getMultiplayerQuestersByQuest(quest); });
if (mq != null) {
for (Quester q : mq) {
if (q.getCurrentQuests().containsKey(quest)) {
q.finishObjective(quest, "password", null, null, null, null, null, null, null, null, display, null);
}
}
}
}
}
}); });
break; break;
} }
@ -3368,8 +3258,8 @@ public class Quester {
/** /**
* Dispatch any event to the right quest if multiplayer enabled * Dispatch any event to the right quest if multiplayer enabled
* *
* @param eventName The event name * @param eventName the event name
* @param fun The function to execute, the event call * @param fun the function to execute, the event call
*/ */
public void dispatchMultiplayerEvent(String eventName, BiFunction<Quester, Quest, Void> fun) { public void dispatchMultiplayerEvent(String eventName, BiFunction<Quester, Quest, Void> fun) {
Map<Quester, MultiplayerType> mq = getMultiplayerQuesters(); Map<Quester, MultiplayerType> mq = getMultiplayerQuesters();
@ -3385,6 +3275,24 @@ public class Quester {
} }
} }
/**
* Dispatch a finish objective multiplayer event
*
* @param quest the current quest
* @param currentStage the current stage of the quest
* @param fun the function to execute, the event call
*/
public void dispatchMultiplayerEventShareObjective(Quest quest, Stage currentStage, Function<Quester, Void> fun) {
if (quest.getOptions().getShareProgressLevel() == 2) {
List<Quester> mq = getMultiplayerQuestersByQuest(quest);
for (Quester q : mq) {
if (q.getCurrentQuests().containsKey(quest) && currentStage.equals(q.getCurrentStage(quest))) {
fun.apply(q);
}
}
}
}
/** /**
* Get a map of fellow Questers in a party or group * Get a map of fellow Questers in a party or group
* *