123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- package com.gmail.nossr50.commands.skills;
- import com.gmail.nossr50.datatypes.skills.MaterialType;
- import com.gmail.nossr50.datatypes.skills.SubSkillType;
- import com.gmail.nossr50.locale.LocaleLoader;
- import com.gmail.nossr50.mcMMO;
- import com.gmail.nossr50.skills.repair.ArcaneForging;
- import com.gmail.nossr50.skills.repair.Repair;
- import com.gmail.nossr50.skills.repair.RepairManager;
- import com.gmail.nossr50.skills.repair.repairables.Repairable;
- import com.gmail.nossr50.util.Permissions;
- import com.gmail.nossr50.util.skills.RankUtils;
- import com.gmail.nossr50.util.skills.SkillActivationType;
- import com.gmail.nossr50.util.text.TextComponentFactory;
- import com.neetgames.mcmmo.player.OnlineMMOPlayer;
- import net.kyori.adventure.text.Component;
- import org.bukkit.Material;
- import org.jetbrains.annotations.NotNull;
- import java.util.ArrayList;
- import java.util.List;
- public class RepairCommand extends SkillCommand {
- private String repairMasteryBonus;
- private String superRepairChance;
- private String superRepairChanceLucky;
- private boolean canSuperRepair;
- private boolean canMasterRepair;
- private boolean canArcaneForge;
- private boolean canRepairStone;
- private boolean canRepairIron;
- private boolean canRepairGold;
- private boolean canRepairDiamond;
- private boolean canRepairString;
- private boolean canRepairLeather;
- private boolean canRepairWood;
- private boolean arcaneBypass;
- private int diamondLevel;
- private int goldLevel;
- private int ironLevel;
- private int stoneLevel;
- public RepairCommand() {
- super(PrimarySkillType.REPAIR);
- }
- @Override
- protected void dataCalculations(@NotNull OnlineMMOPlayer mmoPlayer, float skillValue) {
- // We're using pickaxes here, not the best but it works
- Repairable diamondRepairable = mcMMO.getRepairableManager().getRepairable(Material.DIAMOND_PICKAXE);
- Repairable goldRepairable = mcMMO.getRepairableManager().getRepairable(Material.GOLDEN_PICKAXE);
- Repairable ironRepairable = mcMMO.getRepairableManager().getRepairable(Material.IRON_PICKAXE);
- Repairable stoneRepairable = mcMMO.getRepairableManager().getRepairable(Material.STONE_PICKAXE);
- // TODO: This isn't really accurate - if they don't have pickaxes loaded it doesn't always mean the repair level is 0
- diamondLevel = (diamondRepairable == null) ? 0 : diamondRepairable.getMinimumLevel();
- goldLevel = (goldRepairable == null) ? 0 : goldRepairable.getMinimumLevel();
- ironLevel = (ironRepairable == null) ? 0 : ironRepairable.getMinimumLevel();
- stoneLevel = (stoneRepairable == null) ? 0 : stoneRepairable.getMinimumLevel();
- // REPAIR MASTERY
- if (canMasterRepair) {
- repairMasteryBonus = percent.format(Math.min(((Repair.repairMasteryMaxBonus / Repair.repairMasteryMaxBonusLevel) * skillValue), Repair.repairMasteryMaxBonus) / 100D);
- }
- // SUPER REPAIR
- if (canSuperRepair) {
- String[] superRepairStrings = getAbilityDisplayValues(SkillActivationType.RANDOM_LINEAR_100_SCALE_WITH_CAP, mmoPlayer, SubSkillType.REPAIR_SUPER_REPAIR);
- superRepairChance = superRepairStrings[0];
- superRepairChanceLucky = superRepairStrings[1];
- }
- }
- @Override
- protected void permissionsCheck(@NotNull OnlineMMOPlayer mmoPlayer) {
- canSuperRepair = canUseSubskill(mmoPlayer, SubSkillType.REPAIR_SUPER_REPAIR);
- canMasterRepair = canUseSubskill(mmoPlayer, SubSkillType.REPAIR_REPAIR_MASTERY);
- canArcaneForge = canUseSubskill(mmoPlayer, SubSkillType.REPAIR_ARCANE_FORGING);
- canRepairDiamond = Permissions.repairMaterialType(Misc.adaptPlayer(mmoPlayer), MaterialType.DIAMOND);
- canRepairGold = Permissions.repairMaterialType(Misc.adaptPlayer(mmoPlayer), MaterialType.GOLD);
- canRepairIron = Permissions.repairMaterialType(Misc.adaptPlayer(mmoPlayer), MaterialType.IRON);
- canRepairStone = Permissions.repairMaterialType(Misc.adaptPlayer(mmoPlayer), MaterialType.STONE);
- canRepairString = Permissions.repairMaterialType(Misc.adaptPlayer(mmoPlayer), MaterialType.STRING);
- canRepairLeather = Permissions.repairMaterialType(Misc.adaptPlayer(mmoPlayer), MaterialType.LEATHER);
- canRepairWood = Permissions.repairMaterialType(Misc.adaptPlayer(mmoPlayer), MaterialType.WOOD);
- arcaneBypass = (Permissions.arcaneBypass(mmoPlayer.getPlayer()) || Permissions.hasRepairEnchantBypassPerk(mmoPlayer.getPlayer()));
- }
- @Override
- protected @NotNull List<String> statsDisplay(@NotNull OnlineMMOPlayer mmoPlayer, float skillValue, boolean hasEndurance, boolean isLucky) {
- List<String> messages = new ArrayList<>();
- if (canArcaneForge) {
- RepairManager repairManager = ((McMMOPlayer) (mmoPlayer)).getRepairManager();
- messages.add(getStatMessage(false, true,
- SubSkillType.REPAIR_ARCANE_FORGING,
- String.valueOf(RankUtils.getRank(mmoPlayer, SubSkillType.REPAIR_ARCANE_FORGING)),
- RankUtils.getHighestRankStr(SubSkillType.REPAIR_ARCANE_FORGING)));
- if (ArcaneForging.arcaneForgingEnchantLoss || ArcaneForging.arcaneForgingDowngrades) {
- messages.add(getStatMessage(true, true, SubSkillType.REPAIR_ARCANE_FORGING,
- String.valueOf(arcaneBypass ? 100 : repairManager.getKeepEnchantChance()),
- String.valueOf(arcaneBypass ? 0 : repairManager.getDowngradeEnchantChance()))); //Jesus those parentheses
- }
- }
-
- if (canMasterRepair) {
- messages.add(getStatMessage(false, true, SubSkillType.REPAIR_REPAIR_MASTERY, repairMasteryBonus));
- }
- if (canSuperRepair) {
- messages.add(getStatMessage(SubSkillType.REPAIR_SUPER_REPAIR, superRepairChance)
- + (isLucky ? LocaleLoader.getString("Perks.Lucky.Bonus", superRepairChanceLucky) : ""));
- }
- return messages;
- }
- @Override
- protected @NotNull List<Component> getTextComponents(@NotNull OnlineMMOPlayer mmoPlayer) {
- List<Component> textComponents = new ArrayList<>();
- TextComponentFactory.getSubSkillTextComponents(mmoPlayer, textComponents, PrimarySkillType.REPAIR);
- return textComponents;
- }
- }
|