Refactor code and remove naga class

This commit is contained in:
Barazok
2020-10-24 14:30:39 +02:00
parent 4db1014b2d
commit 8db992a3be
15 changed files with 297 additions and 506 deletions

View File

@@ -0,0 +1,54 @@
package net.babamod.mineclass.classes;
import org.bukkit.Material;
import org.bukkit.entity.Player;
import org.bukkit.inventory.ItemStack;
import org.bukkit.potion.PotionEffect;
import java.util.ArrayList;
import java.util.stream.Collectors;
public abstract class MineClassImpl implements MineClass {
@Override
public boolean is(Player player) {
return player.getActivePotionEffects().stream()
.map(PotionEffect::getType)
.collect(Collectors.toList())
.containsAll(getPotionEffects().keySet());
}
@Override
public void reapplyEffects(Player player) {
getPotionEffects()
.forEach(
(key, value) -> {
if (player.hasPotionEffect(key)) {
player.removePotionEffect(key);
}
player.addPotionEffect(
new PotionEffect(key, Integer.MAX_VALUE, value - 1, false, false));
});
}
@Override
public boolean isItemForbidden(Material type) {
return getForbiddenItems().contains(type);
}
@Override
public boolean isItemEnchantable(Material type) {
return getClassEnchantments().containsKey(type);
}
@Override
public void enchantItem(ItemStack itemStack) {
getClassEnchantments()
.getOrDefault(itemStack.getType(), new ArrayList<>())
.forEach(
enchantmentIntegerPair ->
itemStack.addUnsafeEnchantment(
enchantmentIntegerPair.getFirst(), enchantmentIntegerPair.getSecond()));
MineClassFactory.setUnbreakableAndSoulbound(itemStack);
}
}