12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- package com.gmail.nossr50.commands.skills;
- import com.gmail.nossr50.datatypes.skills.PrimarySkillType;
- import com.gmail.nossr50.datatypes.skills.SubSkillType;
- import com.gmail.nossr50.locale.LocaleLoader;
- import com.gmail.nossr50.skills.smelting.Smelting;
- import com.gmail.nossr50.util.Permissions;
- import com.gmail.nossr50.util.TextComponentFactory;
- import com.gmail.nossr50.util.player.UserManager;
- import com.gmail.nossr50.util.skills.RankUtils;
- import net.md_5.bungee.api.chat.TextComponent;
- import org.bukkit.entity.Player;
- import java.util.ArrayList;
- import java.util.List;
- public class SmeltingCommand extends SkillCommand {
- private String burnTimeModifier;
- private String secondSmeltChance;
- private String secondSmeltChanceLucky;
- private String fluxMiningChance;
- private String fluxMiningChanceLucky;
- private boolean canFuelEfficiency;
- private boolean canSecondSmelt;
- private boolean canFluxMine;
- private boolean canVanillaXPBoost;
- public SmeltingCommand() {
- super(PrimarySkillType.SMELTING);
- }
- @Override
- protected void dataCalculations(Player player, float skillValue, boolean isLucky) {
- // FUEL EFFICIENCY
- if (canFuelEfficiency) {
- burnTimeModifier = decimal.format(1 + ((skillValue / Smelting.burnModifierMaxLevel) * Smelting.burnTimeMultiplier));
- }
- // SECOND SMELT
- if (canSecondSmelt) {
- String[] secondSmeltStrings = calculateAbilityDisplayValues(skillValue, SubSkillType.SMELTING_SECOND_SMELT, isLucky);
- secondSmeltChance = secondSmeltStrings[0];
- secondSmeltChanceLucky = secondSmeltStrings[1];
- }
- // FLUX MINING
- if (canFluxMine) {
- String[] fluxMiningStrings = calculateAbilityDisplayValues(Smelting.fluxMiningChance, isLucky);
- fluxMiningChance = fluxMiningStrings[0];
- fluxMiningChanceLucky = fluxMiningStrings[1];
- }
- }
- @Override
- protected void permissionsCheck(Player player) {
- canFuelEfficiency = canUseSubskill(player, SubSkillType.SMELTING_FUEL_EFFICIENCY);
- canSecondSmelt = canUseSubskill(player, SubSkillType.SMELTING_SECOND_SMELT);
- canFluxMine = canUseSubskill(player, SubSkillType.SMELTING_FLUX_MINING);
- canVanillaXPBoost = Permissions.vanillaXpBoost(player, skill) && RankUtils.hasUnlockedSubskill(player, SubSkillType.SMELTING_UNDERSTANDING_THE_ART);
- }
- @Override
- protected List<String> statsDisplay(Player player, float skillValue, boolean hasEndurance, boolean isLucky) {
- List<String> messages = new ArrayList<String>();
- if (canFuelEfficiency) {
- messages.add(LocaleLoader.getString("Smelting.Ability.FuelEfficiency", burnTimeModifier));
- }
- if (canSecondSmelt) {
- messages.add(LocaleLoader.getString("Smelting.Ability.SecondSmelt", secondSmeltChance) + (isLucky ? LocaleLoader.getString("Perks.Lucky.Bonus", secondSmeltChanceLucky) : ""));
- }
- if (canVanillaXPBoost) {
- messages.add(LocaleLoader.getString("Smelting.Ability.VanillaXPBoost", UserManager.getPlayer(player).getSmeltingManager().getVanillaXpMultiplier()));
- }
- if (canFluxMine) {
- messages.add(LocaleLoader.getString("Smelting.Ability.FluxMining", fluxMiningChance) + (isLucky ? LocaleLoader.getString("Perks.Lucky.Bonus", fluxMiningChanceLucky) : ""));
- }
- return messages;
- }
- @Override
- protected List<TextComponent> getTextComponents(Player player) {
- List<TextComponent> textComponents = new ArrayList<>();
- TextComponentFactory.getSubSkillTextComponents(player, textComponents, PrimarySkillType.SMELTING);
- return textComponents;
- }
- }
|