diff --git a/src/main/java/com/gamingmesh/jobs/PlayerManager.java b/src/main/java/com/gamingmesh/jobs/PlayerManager.java index f57c230c..190d378c 100644 --- a/src/main/java/com/gamingmesh/jobs/PlayerManager.java +++ b/src/main/java/com/gamingmesh/jobs/PlayerManager.java @@ -65,6 +65,7 @@ import com.gamingmesh.jobs.stuff.Util; import net.Zrips.CMILib.ActionBar.CMIActionBar; import net.Zrips.CMILib.Items.CMIItemStack; import net.Zrips.CMILib.Items.CMIMaterial; +import net.Zrips.CMILib.Logs.CMIDebug; import net.Zrips.CMILib.Messages.CMIMessages; import net.Zrips.CMILib.NBT.CMINBT; import net.Zrips.CMILib.Version.Version; @@ -487,6 +488,9 @@ public class PlayerManager { job.updateTotalPlayers(); jPlayer.maxJobsEquation = getMaxJobs(jPlayer); + + // Removing from cached item boost for recalculation + cache.remove(jPlayer.getUniqueId()); } private static void performCommandsOnLeave(JobsPlayer jPlayer, Job job) { @@ -528,6 +532,10 @@ public class PlayerManager { Jobs.getSignUtil().updateAllSign(job); job.updateTotalPlayers(); + + // Removing from cached item boost for recalculation + cache.remove(jPlayer.getUniqueId()); + return true; } @@ -1055,6 +1063,8 @@ public class PlayerManager { continue; } } + + CMIDebug.d("get bonus item"); jitems.add(getJobsItemByNbt(item)); } } diff --git a/src/main/java/com/gamingmesh/jobs/config/ShopManager.java b/src/main/java/com/gamingmesh/jobs/config/ShopManager.java index 75530ae5..d60a04c4 100644 --- a/src/main/java/com/gamingmesh/jobs/config/ShopManager.java +++ b/src/main/java/com/gamingmesh/jobs/config/ShopManager.java @@ -113,11 +113,14 @@ public class ShopManager { List lore = new ArrayList<>(); CMIMaterial mat = CMIMaterial.get(item.getIconMaterial()); + boolean hiddenLore = false; + if (item.isHideWithoutPerm()) { for (String onePerm : item.getRequiredPerm()) { if (!player.hasPermission(onePerm)) { mat = CMIMaterial.STONE_BUTTON; lore.add(Jobs.getLanguage().getMessage("command.shop.info.NoPermToBuy")); + hiddenLore = true; break; } } @@ -127,6 +130,7 @@ public class ShopManager { jPlayer.getTotalLevels() < item.getRequiredTotalLevels()) { mat = CMIMaterial.STONE_BUTTON; lore.add(Jobs.getLanguage().getMessage("command.shop.info.NoPoints")); + hiddenLore = true; } if (mat == CMIMaterial.NONE) @@ -142,48 +146,50 @@ public class ShopManager { if (item.getIconName() != null) meta.setDisplayName(item.getIconName()); - lore.addAll(item.getIconLore()); + if (!hiddenLore) { + lore.addAll(item.getIconLore()); - if (item.getPointPrice() > 0) { - String color = item.getPointPrice() >= points ? "" : Jobs.getLanguage().getMessage("command.shop.info.haveColor"); - lore.add(Jobs.getLanguage().getMessage("command.shop.info.pointsPrice", "%currentpoints%", color + points, "%price%", item.getPointPrice())); - } - - if (item.getVaultPrice() > 0) { - String color = item.getVaultPrice() >= balance ? "" : Jobs.getLanguage().getMessage("command.shop.info.haveColor"); - lore.add(Jobs.getLanguage().getMessage("command.shop.info.moneyPrice", "%currentbalance%", color + Jobs.getEconomy().getEconomy().format(balance), "%price%", item.getVaultPrice())); - } - - if (!item.getRequiredJobs().isEmpty()) { - lore.add(Jobs.getLanguage().getMessage("command.shop.info.reqJobs")); - - for (Entry one : item.getRequiredJobs().entrySet()) { - Job job = Jobs.getJob(one.getKey()); - if (job == null) { - continue; - } - - String jobColor = ""; - String levelColor = ""; - - JobProgression prog = jPlayer.getJobProgression(job); - if (prog == null) { - jobColor = Jobs.getLanguage().getMessage("command.shop.info.reqJobsColor"); - levelColor = Jobs.getLanguage().getMessage("command.shop.info.reqJobsLevelColor"); - } - - if (prog != null && prog.getLevel() < one.getValue()) - levelColor = Jobs.getLanguage().getMessage("command.shop.info.reqJobsLevelColor"); - - lore.add(Jobs.getLanguage().getMessage("command.shop.info.reqJobsList", "%jobsname%", - jobColor + one.getKey(), "%level%", levelColor + one.getValue())); + if (item.getPointPrice() > 0) { + String color = item.getPointPrice() >= points ? "" : Jobs.getLanguage().getMessage("command.shop.info.haveColor"); + lore.add(Jobs.getLanguage().getMessage("command.shop.info.pointsPrice", "%currentpoints%", color + points, "%price%", item.getPointPrice())); } - } - if (item.getRequiredTotalLevels() != -1) { - lore.add(Jobs.getLanguage().getMessage("command.shop.info.reqTotalLevel", - "%totalLevel%", (jPlayer.getTotalLevels() < item.getRequiredTotalLevels() - ? Jobs.getLanguage().getMessage("command.shop.info.reqTotalLevelColor") : "") + item.getRequiredTotalLevels())); + if (item.getVaultPrice() > 0) { + String color = item.getVaultPrice() >= balance ? "" : Jobs.getLanguage().getMessage("command.shop.info.haveColor"); + lore.add(Jobs.getLanguage().getMessage("command.shop.info.moneyPrice", "%currentbalance%", color + Jobs.getEconomy().getEconomy().format(balance), "%price%", item.getVaultPrice())); + } + + if (!item.getRequiredJobs().isEmpty()) { + lore.add(Jobs.getLanguage().getMessage("command.shop.info.reqJobs")); + + for (Entry one : item.getRequiredJobs().entrySet()) { + Job job = Jobs.getJob(one.getKey()); + if (job == null) { + continue; + } + + String jobColor = ""; + String levelColor = ""; + + JobProgression prog = jPlayer.getJobProgression(job); + if (prog == null) { + jobColor = Jobs.getLanguage().getMessage("command.shop.info.reqJobsColor"); + levelColor = Jobs.getLanguage().getMessage("command.shop.info.reqJobsLevelColor"); + } + + if (prog != null && prog.getLevel() < one.getValue()) + levelColor = Jobs.getLanguage().getMessage("command.shop.info.reqJobsLevelColor"); + + lore.add(Jobs.getLanguage().getMessage("command.shop.info.reqJobsList", "%jobsname%", + jobColor + one.getKey(), "%level%", levelColor + one.getValue())); + } + } + + if (item.getRequiredTotalLevels() != -1) { + lore.add(Jobs.getLanguage().getMessage("command.shop.info.reqTotalLevel", + "%totalLevel%", (jPlayer.getTotalLevels() < item.getRequiredTotalLevels() + ? Jobs.getLanguage().getMessage("command.shop.info.reqTotalLevelColor") : "") + item.getRequiredTotalLevels())); + } } meta.setLore(lore); diff --git a/src/main/java/com/gamingmesh/jobs/container/Job.java b/src/main/java/com/gamingmesh/jobs/container/Job.java index 937ed75b..de82f577 100644 --- a/src/main/java/com/gamingmesh/jobs/container/Job.java +++ b/src/main/java/com/gamingmesh/jobs/container/Job.java @@ -101,41 +101,41 @@ public class Job { @Deprecated public Job(String jobName, String jobDisplayName, String fullName, String jobShortName, String description, CMIChatColor jobColour, Parser maxExpEquation, DisplayMethod displayMethod, int maxLevel, - int vipmaxLevel, Integer maxSlots, List jobPermissions, List jobCommands, List jobConditions, Map jobItems, - Map jobLimitedItems, List cmdOnJoin, List cmdOnLeave, ItemStack guiItem, int guiSlot, String bossbar, Long rejoinCD, List worldBlacklist) { - this(jobName, jobDisplayName, fullName, jobShortName, jobColour, maxExpEquation, displayMethod, maxLevel, - vipmaxLevel, maxSlots, jobPermissions, jobCommands, jobConditions, - jobLimitedItems, cmdOnJoin, cmdOnLeave, guiItem, guiSlot, worldBlacklist); + int vipmaxLevel, Integer maxSlots, List jobPermissions, List jobCommands, List jobConditions, Map jobItems, + Map jobLimitedItems, List cmdOnJoin, List cmdOnLeave, ItemStack guiItem, int guiSlot, String bossbar, Long rejoinCD, List worldBlacklist) { + this(jobName, jobDisplayName, fullName, jobShortName, jobColour, maxExpEquation, displayMethod, maxLevel, + vipmaxLevel, maxSlots, jobPermissions, jobCommands, jobConditions, + jobLimitedItems, cmdOnJoin, cmdOnLeave, guiItem, guiSlot, worldBlacklist); - this.jobItems = jobItems; - this.description = description; + this.jobItems = jobItems; + this.description = description; } public Job(String jobName, String jobDisplayName, String fullName, String jobShortName, CMIChatColor jobColour, Parser maxExpEquation, DisplayMethod displayMethod, int maxLevel, - int vipmaxLevel, Integer maxSlots, List jobPermissions, List jobCommands, List jobConditions, - Map jobLimitedItems, List cmdOnJoin, List cmdOnLeave, ItemStack guiItem, int guiSlot, List worldBlacklist) { - this.jobName = jobName == null ? "" : jobName; - this.fullName = fullName == null ? "" : fullName; - this.jobShortName = jobShortName; - this.jobColour = jobColour; - this.maxExpEquation = maxExpEquation; - this.displayMethod = displayMethod; - this.maxLevel = maxLevel; - this.vipmaxLevel = vipmaxLevel; - this.maxSlots = maxSlots; - this.jobPermissions = jobPermissions; - this.jobCommands = jobCommands; - this.jobConditions = jobConditions; - this.jobLimitedItems = jobLimitedItems; - this.cmdOnJoin = cmdOnJoin; - this.cmdOnLeave = cmdOnLeave; - this.guiItem = guiItem; - this.guiSlot = guiSlot; - this.jobDisplayName = CMIChatColor.translate(jobDisplayName); + int vipmaxLevel, Integer maxSlots, List jobPermissions, List jobCommands, List jobConditions, + Map jobLimitedItems, List cmdOnJoin, List cmdOnLeave, ItemStack guiItem, int guiSlot, List worldBlacklist) { + this.jobName = jobName == null ? "" : jobName; + this.fullName = fullName == null ? "" : fullName; + this.jobShortName = jobShortName; + this.jobColour = jobColour; + this.maxExpEquation = maxExpEquation; + this.displayMethod = displayMethod; + this.maxLevel = maxLevel; + this.vipmaxLevel = vipmaxLevel; + this.maxSlots = maxSlots; + this.jobPermissions = jobPermissions; + this.jobCommands = jobCommands; + this.jobConditions = jobConditions; + this.jobLimitedItems = jobLimitedItems; + this.cmdOnJoin = cmdOnJoin; + this.cmdOnLeave = cmdOnLeave; + this.guiItem = guiItem; + this.guiSlot = guiSlot; + this.jobDisplayName = CMIChatColor.translate(jobDisplayName); - if (worldBlacklist != null) { - this.worldBlacklist = worldBlacklist; - } + if (worldBlacklist != null) { + this.worldBlacklist = worldBlacklist; + } } /** @@ -146,7 +146,7 @@ public class Job { * @param point the amount of boost to add */ public void addBoost(CurrencyType type, double point) { - boost.add(type, point); + boost.add(type, point); } /** @@ -163,20 +163,20 @@ public class Job { */ public void addBoost(CurrencyType type, double point, long duration) { - if (duration <= 0) { - addBoost(type, point); - return; - } + if (duration <= 0) { + addBoost(type, point); + return; + } - boost.add(type, point, System.currentTimeMillis() + (duration * 1000L)); + boost.add(type, point, System.currentTimeMillis() + (duration * 1000L)); } public void setBoost(BoostMultiplier boost) { - this.boost = boost; + this.boost = boost; } public BoostMultiplier getBoost() { - return boost; + return boost; } /** @@ -186,8 +186,8 @@ public class Job { * @return true if same */ public boolean isSame(Job job) { - return job != null && (id == job.getId() || jobName.equalsIgnoreCase(job.getName()) - || fullName.equalsIgnoreCase(job.getJobFullName()) || fullName.equalsIgnoreCase(job.getName())); + return job != null && (id == job.getId() || jobName.equalsIgnoreCase(job.getName()) + || fullName.equalsIgnoreCase(job.getJobFullName()) || fullName.equalsIgnoreCase(job.getName())); } /** @@ -196,67 +196,74 @@ public class Job { * @return the amount of total players in this job */ public int getTotalPlayers() { - if (totalPlayers == -1) { - updateTotalPlayers(); - } + if (totalPlayers == -1) { + updateTotalPlayers(); + } - return totalPlayers; + return totalPlayers; } /** * Updates the total players property from database synchronously. */ public void updateTotalPlayers() { - totalPlayers = Jobs.getJobsDAO().getTotalPlayerAmountByJobName(jobName); + totalPlayers = Jobs.getJobsDAO().getTotalPlayerAmountByJobName(jobName); - if (totalPlayers <= 0) { - totalPlayers = Jobs.getJobsDAO().getTotalPlayerAmountByJobName(fullName); - } + if (totalPlayers <= 0) { + totalPlayers = Jobs.getJobsDAO().getTotalPlayerAmountByJobName(fullName); + } - updateBonus(); + updateBonus(); } public void updateBonus() { - if (!Jobs.getGCManager().useDynamicPayment) - return; + if (!Jobs.getGCManager().useDynamicPayment) + return; - Parser eq = Jobs.getGCManager().DynamicPaymentEquation; - eq.setVariable("totalworkers", Jobs.getJobsDAO().getTotalPlayers()); - eq.setVariable("totaljobs", Jobs.getJobs().size()); - eq.setVariable("jobstotalplayers", getTotalPlayers()); + Parser eq = Jobs.getGCManager().DynamicPaymentEquation; + eq.setVariable("totalworkers", Jobs.getJobsDAO().getTotalPlayers()); + eq.setVariable("totaljobs", Jobs.getJobs().size()); + eq.setVariable("jobstotalplayers", getTotalPlayers()); - double now = eq.getValue(); - CMIDebug.d("Now",now); - if (now > Jobs.getGCManager().DynamicPaymentMaxBonus) - now = Jobs.getGCManager().DynamicPaymentMaxBonus; + double now = 0D; + try { + now = eq.getValue(); + } catch (Throwable e) { + e.printStackTrace(); + } - if (now < Jobs.getGCManager().DynamicPaymentMaxPenalty) - now = Jobs.getGCManager().DynamicPaymentMaxPenalty; + CMIDebug.d("Now", now, this.getName(), getTotalPlayers(), now == Double.POSITIVE_INFINITY); - this.bonus = now; + if (now > Jobs.getGCManager().DynamicPaymentMaxBonus) + now = Jobs.getGCManager().DynamicPaymentMaxBonus; + + if (now < Jobs.getGCManager().DynamicPaymentMaxPenalty) + now = Jobs.getGCManager().DynamicPaymentMaxPenalty; + + this.bonus = now; } public double getBonus() { - if (bonus == null) - updateBonus(); + if (bonus == null) + updateBonus(); - return bonus == null ? 0D : bonus; + return bonus == null ? 0D : bonus; } public List getCmdOnJoin() { - return cmdOnJoin; + return cmdOnJoin; } public List getCmdOnLeave() { - return cmdOnLeave; + return cmdOnLeave; } public ItemStack getGuiItem() { - return guiItem; + return guiItem; } public int getGuiSlot() { - return guiSlot; + return guiSlot; } /** @@ -265,7 +272,7 @@ public class Job { * @param info - the job info */ public void setJobInfo(ActionType type, List info) { - jobInfo.put(type, info); + jobInfo.put(type, info); } /** @@ -274,7 +281,7 @@ public class Job { * @return Job info list */ public List getJobInfo(ActionType type) { - return jobInfo.get(type); + return jobInfo.get(type); } /** @@ -282,41 +289,41 @@ public class Job { * @return Job info list */ public Map> getJobInfoList() { - return jobInfo; + return jobInfo; } public JobInfo getJobInfo(ActionInfo action, int level) { - BiPredicate condition = (jobInfo, actionInfo) -> { - if (actionInfo instanceof PotionItemActionInfo) { - String subName = ((PotionItemActionInfo) action).getNameWithSub(); - return jobInfo.getName().equalsIgnoreCase(subName) || (jobInfo.getName() + ":" + jobInfo.getMeta()).equalsIgnoreCase(subName); - } + BiPredicate condition = (jobInfo, actionInfo) -> { + if (actionInfo instanceof PotionItemActionInfo) { + String subName = ((PotionItemActionInfo) action).getNameWithSub(); + return jobInfo.getName().equalsIgnoreCase(subName) || (jobInfo.getName() + ":" + jobInfo.getMeta()).equalsIgnoreCase(subName); + } - if (actionInfo instanceof EnchantActionInfo) { - return Util.enchantMatchesActionInfo(jobInfo.getName(), (EnchantActionInfo) actionInfo); - } + if (actionInfo instanceof EnchantActionInfo) { + return Util.enchantMatchesActionInfo(jobInfo.getName(), (EnchantActionInfo) actionInfo); + } - return jobInfo.getName().equalsIgnoreCase(action.getNameWithSub()) || - (jobInfo.getName() + ":" + jobInfo.getMeta()).equalsIgnoreCase(action.getNameWithSub()) || - jobInfo.getName().equalsIgnoreCase(action.getName()); - }; + return jobInfo.getName().equalsIgnoreCase(action.getNameWithSub()) || + (jobInfo.getName() + ":" + jobInfo.getMeta()).equalsIgnoreCase(action.getNameWithSub()) || + jobInfo.getName().equalsIgnoreCase(action.getName()); + }; - String shortActionName = CMIMaterial.getGeneralMaterialName(action.getName()); - for (JobInfo info : getJobInfo(action.getType())) { - if (condition.test(info, action)) { - if (!info.isInLevelRange(level)) { - break; - } + String shortActionName = CMIMaterial.getGeneralMaterialName(action.getName()); + for (JobInfo info : getJobInfo(action.getType())) { + if (condition.test(info, action)) { + if (!info.isInLevelRange(level)) { + break; + } - return info; - } + return info; + } - if ((shortActionName + ":ALL").equalsIgnoreCase(info.getName())) { - return info; - } - } + if ((shortActionName + ":ALL").equalsIgnoreCase(info.getName())) { + return info; + } + } - return null; + return null; } /** @@ -325,20 +332,20 @@ public class Job { * @return the name of this job */ public String getName() { - return jobName; + return jobName; } public String getJobFullName() { - return fullName; + return fullName; } @Deprecated public String getJobDisplayName() { - return getDisplayName(); + return getDisplayName(); } public String getDisplayName() { - return jobDisplayName == null ? jobColour + fullName : jobDisplayName; + return jobDisplayName == null ? jobColour + fullName : jobDisplayName; } /** @@ -349,7 +356,7 @@ public class Job { */ @Deprecated public String getNameWithColor() { - return jobColour + fullName; + return jobColour + fullName; } /** @@ -358,7 +365,7 @@ public class Job { * @return the shortened version of the jobName */ public String getShortName() { - return jobShortName; + return jobShortName; } /** @@ -370,7 +377,7 @@ public class Job { */ @Deprecated public String getDescription() { - return description; + return description; } /** @@ -378,7 +385,7 @@ public class Job { * @return the Color of the job for chat */ public CMIChatColor getChatColor() { - return jobColour; + return jobColour; } /** @@ -386,7 +393,7 @@ public class Job { * @return the MaxExpEquation of the job */ public Parser getMaxExpEquation() { - return maxExpEquation; + return maxExpEquation; } /** @@ -395,10 +402,10 @@ public class Job { * @return the correct max exp for this level */ public double getMaxExp(Map level) { - for (Map.Entry temp : level.entrySet()) { - maxExpEquation.setVariable(temp.getKey(), temp.getValue()); - } - return maxExpEquation.getValue(); + for (Map.Entry temp : level.entrySet()) { + maxExpEquation.setVariable(temp.getKey(), temp.getValue()); + } + return maxExpEquation.getValue(); } /** @@ -406,7 +413,7 @@ public class Job { * @return the display method */ public DisplayMethod getDisplayMethod() { - return displayMethod; + return displayMethod; } /** @@ -415,7 +422,7 @@ public class Job { * @return the max level */ public int getMaxLevel() { - return maxLevel; + return maxLevel; } /** @@ -425,20 +432,20 @@ public class Job { * @return the max level of player */ public int getMaxLevel(JobsPlayer player) { - return player == null ? maxLevel : player.getMaxJobLevelAllowed(this); + return player == null ? maxLevel : player.getMaxJobLevelAllowed(this); } public int getMaxLevel(CommandSender sender) { - if (sender == null) - return maxLevel; + if (sender == null) + return maxLevel; - if (sender instanceof Player) { - JobsPlayer player = Jobs.getPlayerManager().getJobsPlayer((Player) sender); - if (player != null) - return player.getMaxJobLevelAllowed(this); - } + if (sender instanceof Player) { + JobsPlayer player = Jobs.getPlayerManager().getJobsPlayer((Player) sender); + if (player != null) + return player.getMaxJobLevelAllowed(this); + } - return maxLevel > vipmaxLevel ? maxLevel : vipmaxLevel; + return maxLevel > vipmaxLevel ? maxLevel : vipmaxLevel; } /** @@ -447,7 +454,7 @@ public class Job { * @return null - no max level */ public int getVipMaxLevel() { - return vipmaxLevel; + return vipmaxLevel; } /** @@ -456,7 +463,7 @@ public class Job { * @return null - no max slots */ public Integer getMaxSlots() { - return maxSlots; + return maxSlots; } /** @@ -464,7 +471,7 @@ public class Job { * @return Permissions for this job */ public List getPermissions() { - return Collections.unmodifiableList(jobPermissions); + return Collections.unmodifiableList(jobPermissions); } /** @@ -472,7 +479,7 @@ public class Job { * @return Commands for this job */ public List getCommands() { - return Collections.unmodifiableList(jobCommands); + return Collections.unmodifiableList(jobCommands); } /** @@ -480,7 +487,7 @@ public class Job { * @return Conditions for this job */ public List getConditions() { - return Collections.unmodifiableList(jobConditions); + return Collections.unmodifiableList(jobConditions); } /** @@ -489,14 +496,14 @@ public class Job { */ @Deprecated public Map getItemBonus() { - if (jobItems == null) - jobItems = new HashMap(); - return jobItems; + if (jobItems == null) + jobItems = new HashMap(); + return jobItems; } @Deprecated public JobItems getItemBonus(String key) { - return jobItems.get(key.toLowerCase()); + return jobItems.get(key.toLowerCase()); } /** @@ -504,192 +511,192 @@ public class Job { * @return Limited items for this job */ public Map getLimitedItems() { - return jobLimitedItems; + return jobLimitedItems; } public JobLimitedItems getLimitedItems(String key) { - return jobLimitedItems.get(key.toLowerCase()); + return jobLimitedItems.get(key.toLowerCase()); } public String getBossbar() { - return bossbar; + return bossbar; } public void setBossbar(String bossbar) { - this.bossbar = bossbar; + this.bossbar = bossbar; } public Parser getMoneyEquation() { - return moneyEquation; + return moneyEquation; } public void setMoneyEquation(Parser moneyEquation) { - this.moneyEquation = moneyEquation; + this.moneyEquation = moneyEquation; } public Parser getXpEquation() { - return xpEquation; + return xpEquation; } public void setXpEquation(Parser xpEquation) { - this.xpEquation = xpEquation; + this.xpEquation = xpEquation; } public Parser getPointsEquation() { - return pointsEquation; + return pointsEquation; } public void setPointsEquation(Parser pointsEquation) { - this.pointsEquation = pointsEquation; + this.pointsEquation = pointsEquation; } public Long getRejoinCd() { - return rejoinCd; + return rejoinCd; } public void setRejoinCd(Long rejoinCd) { - this.rejoinCd = rejoinCd; + this.rejoinCd = rejoinCd; } public List getFullDescription() { - return fDescription; + return fDescription; } public void setFullDescription(List fDescription) { - this.fDescription.clear(); + this.fDescription.clear(); - if (fDescription != null) { - this.fDescription.addAll(fDescription); - this.description = String.join("\n", this.fDescription); - } + if (fDescription != null) { + this.fDescription.addAll(fDescription); + this.description = String.join("\n", this.fDescription); + } } public void setMaxLevelCommands(List commands) { - maxLevelCommands.clear(); + maxLevelCommands.clear(); - if (commands != null) { - maxLevelCommands.addAll(commands); - } + if (commands != null) { + maxLevelCommands.addAll(commands); + } } public List getMaxLevelCommands() { - return maxLevelCommands; + return maxLevelCommands; } public List getQuests() { - return quests; + return quests; } public Quest getQuest(String name) { - if (name == null || name.trim().isEmpty()) { - return null; - } + if (name == null || name.trim().isEmpty()) { + return null; + } - for (Quest one : quests) { - if (one.getConfigName().equalsIgnoreCase(name)) - return one; - } + for (Quest one : quests) { + if (one.getConfigName().equalsIgnoreCase(name)) + return one; + } - return null; + return null; } public void setQuests(List quests) { - this.quests.clear(); + this.quests.clear(); - if (quests != null) { - this.quests.addAll(quests); - } + if (quests != null) { + this.quests.addAll(quests); + } } public Quest getNextQuest(List excludeQuests, Integer level) { - List ls = new ArrayList<>(quests); - Collections.shuffle(ls); + List ls = new ArrayList<>(quests); + Collections.shuffle(ls); - int i = 0; - while (true) { - i++; + int i = 0; + while (true) { + i++; - int target = new Random(System.nanoTime()).nextInt(100); - for (Quest one : ls) { - if (one.isEnabled() && one.getChance() >= target && (excludeQuests == null || !excludeQuests.contains(one.getConfigName().toLowerCase())) - && one.isInLevelRange(level)) { - return one; - } - } + int target = new Random(System.nanoTime()).nextInt(100); + for (Quest one : ls) { + if (one.isEnabled() && one.getChance() >= target && (excludeQuests == null || !excludeQuests.contains(one.getConfigName().toLowerCase())) + && one.isInLevelRange(level)) { + return one; + } + } - if (i > 20) - return null; - } + if (i > 20) + return null; + } } public int getMaxDailyQuests() { - return maxDailyQuests; + return maxDailyQuests; } public void setMaxDailyQuests(int maxDailyQuests) { - this.maxDailyQuests = maxDailyQuests; + this.maxDailyQuests = maxDailyQuests; } public int getId() { - return id; + return id; } public void setId(int id) { - this.id = id; + this.id = id; } public List getWorldBlacklist() { - return worldBlacklist; + return worldBlacklist; } public boolean isWorldBlackListed(Entity ent) { - return isWorldBlackListed(null, ent); + return isWorldBlackListed(null, ent); } public boolean isWorldBlackListed(Block block) { - return isWorldBlackListed(block, null); + return isWorldBlackListed(block, null); } public boolean isWorldBlackListed(Block block, Entity ent) { - if (worldBlacklist.isEmpty()) - return reversedWorldBlacklist; + if (worldBlacklist.isEmpty()) + return reversedWorldBlacklist; - if (block != null) - return worldBlacklist.contains(block.getWorld().getName()) != reversedWorldBlacklist; + if (block != null) + return worldBlacklist.contains(block.getWorld().getName()) != reversedWorldBlacklist; - return ent != null && worldBlacklist.contains(ent.getWorld().getName()) != reversedWorldBlacklist; + return ent != null && worldBlacklist.contains(ent.getWorld().getName()) != reversedWorldBlacklist; } public boolean isReversedWorldBlacklist() { - return reversedWorldBlacklist; + return reversedWorldBlacklist; } public void setReversedWorldBlacklist(boolean reversedWorldBlacklist) { - this.reversedWorldBlacklist = reversedWorldBlacklist; + this.reversedWorldBlacklist = reversedWorldBlacklist; } public boolean isIgnoreMaxJobs() { - return ignoreMaxJobs; + return ignoreMaxJobs; } public void setIgnoreMaxJobs(boolean ignoreMaxJobs) { - this.ignoreMaxJobs = ignoreMaxJobs; + this.ignoreMaxJobs = ignoreMaxJobs; } @Override public boolean equals(Object obj) { - return obj instanceof Job && isSame((Job) obj); + return obj instanceof Job && isSame((Job) obj); } public void setJobDisplayName(String jobDisplayName) { - this.jobDisplayName = jobDisplayName; + this.jobDisplayName = jobDisplayName; } public int getLegacyId() { - return legacyId; + return legacyId; } public void setLegacyId(int legacyId) { - this.legacyId = legacyId; + this.legacyId = legacyId; } }