mirror of
https://github.com/PikaMug/Quests.git
synced 2025-01-01 14:08:28 +01:00
Improved and fixed share progress level 2
This commit is contained in:
parent
0d0cd1e27c
commit
550fbc4b4a
@ -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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user