123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- package com.gmail.nossr50.commands.skills;
- import com.gmail.nossr50.config.AdvancedConfig;
- import com.gmail.nossr50.datatypes.skills.SkillType;
- import com.gmail.nossr50.locale.LocaleLoader;
- import com.gmail.nossr50.skills.smelting.Smelting;
- import com.gmail.nossr50.util.Permissions;
- 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(SkillType.SMELTING);
- }
- @Override
- protected void dataCalculations() {
- // FUEL EFFICIENCY
- if (canFuelEfficiency) {
- burnTimeModifier = decimal.format(1 + ((skillValue / Smelting.burnModifierMaxLevel) * Smelting.burnTimeMultiplier));
- }
- // SECOND SMELT
- if (canSecondSmelt) {
- String[] secondSmeltStrings = calculateAbilityDisplayValues(Smelting.secondSmeltMaxLevel, Smelting.secondSmeltMaxChance);
- secondSmeltChance = secondSmeltStrings[0];
- secondSmeltChanceLucky = secondSmeltStrings[1];
- }
- // FLUX MINING
- if (canFluxMine) {
- String[] fluxMiningStrings = calculateAbilityDisplayValues(Smelting.fluxMiningChance);
- fluxMiningChance = fluxMiningStrings[0];
- fluxMiningChanceLucky = fluxMiningStrings[1];
- }
- }
- @Override
- protected void permissionsCheck() {
- canFuelEfficiency = Permissions.fuelEfficiency(player);
- canSecondSmelt = Permissions.doubleDrops(player, skill);
- canFluxMine = Permissions.fluxMining(player);
- canVanillaXPBoost = Permissions.vanillaXpBoost(player, skill);
- }
- @Override
- protected boolean effectsHeaderPermissions() {
- return canFluxMine || canFuelEfficiency || canSecondSmelt || canVanillaXPBoost;
- }
- @Override
- protected void effectsDisplay() {
- luckyEffectsDisplay();
- if (canFuelEfficiency) {
- player.sendMessage(LocaleLoader.getString("Effects.Template", LocaleLoader.getString("Smelting.Effect.0"), LocaleLoader.getString("Smelting.Effect.1")));
- }
- if (canSecondSmelt) {
- player.sendMessage(LocaleLoader.getString("Effects.Template", LocaleLoader.getString("Smelting.Effect.2"), LocaleLoader.getString("Smelting.Effect.3")));
- }
- if (canVanillaXPBoost) {
- player.sendMessage(LocaleLoader.getString("Effects.Template", LocaleLoader.getString("Smelting.Effect.4"), LocaleLoader.getString("Smelting.Effect.5")));
- }
- if (canFluxMine) {
- player.sendMessage(LocaleLoader.getString("Effects.Template", LocaleLoader.getString("Smelting.Effect.6"), LocaleLoader.getString("Smelting.Effect.7")));
- }
- }
- @Override
- protected boolean statsHeaderPermissions() {
- return canFluxMine || canFuelEfficiency || canSecondSmelt || canVanillaXPBoost;
- }
- @Override
- protected void statsDisplay() {
- if (canFuelEfficiency) {
- player.sendMessage(LocaleLoader.getString("Smelting.Ability.FuelEfficiency", burnTimeModifier));
- }
- if (canSecondSmelt) {
- player.sendMessage(LocaleLoader.getString("Smelting.Ability.SecondSmelt", secondSmeltChance) + (isLucky ? LocaleLoader.getString("Perks.lucky.bonus", secondSmeltChanceLucky) : ""));
- }
- if (canVanillaXPBoost) {
- int unlockLevel = AdvancedConfig.getInstance().getSmeltingVanillaXPBoostRank1Level();
- if (skillValue < unlockLevel) {
- player.sendMessage(LocaleLoader.getString("Ability.Generic.Template.Lock", LocaleLoader.getString("Smelting.Ability.Locked.0", unlockLevel)));
- }
- else {
- player.sendMessage(LocaleLoader.getString("Smelting.Ability.VanillaXPBoost", mcMMOPlayer.getSmeltingManager().getVanillaXpMultiplier()));
- }
- }
- if (canFluxMine) {
- if (skillValue < Smelting.fluxMiningUnlockLevel) {
- player.sendMessage(LocaleLoader.getString("Ability.Generic.Template.Lock", LocaleLoader.getString("Smelting.Ability.Locked.1", Smelting.fluxMiningUnlockLevel)));
- }
- else {
- player.sendMessage(LocaleLoader.getString("Smelting.Ability.FluxMining", fluxMiningChance) + (isLucky ? LocaleLoader.getString("Perks.lucky.bonus", fluxMiningChanceLucky) : ""));
- }
- }
- }
- }
|