Improve forbidden items management

This commit is contained in:
Barazok
2020-10-25 01:17:59 +02:00
parent c572b97fc7
commit 6d3f811283
6 changed files with 33 additions and 26 deletions

View File

@@ -30,4 +30,6 @@ public interface MineClass {
void giveItems(Player player); void giveItems(Player player);
String getCode(); String getCode();
void dropForbiddenItems(Player player);
} }

View File

@@ -62,7 +62,8 @@ public class MineClassFactory {
public synchronized Optional<MineClass> getRightClass(Player player) { public synchronized Optional<MineClass> getRightClass(Player player) {
for (Map.Entry<String, MineClass> stringMineClassEntry : availableClasses.entrySet()) { for (Map.Entry<String, MineClass> stringMineClassEntry : availableClasses.entrySet()) {
if (AppliedStatus.getInstance().getStatus(player).equals(stringMineClassEntry.getKey()) if (AppliedStatus.getInstance().getStatus(player) != null
&& AppliedStatus.getInstance().getStatus(player).equals(stringMineClassEntry.getKey())
|| stringMineClassEntry.getValue().is(player)) { || stringMineClassEntry.getValue().is(player)) {
return Optional.of(stringMineClassEntry.getValue()); return Optional.of(stringMineClassEntry.getValue());
} }
@@ -77,4 +78,8 @@ public class MineClassFactory {
public void giveItemsForClassByCode(String code, Player player) { public void giveItemsForClassByCode(String code, Player player) {
availableClasses.get(code).giveItems(player); availableClasses.get(code).giveItems(player);
} }
public void dropForbiddenItemsForClassByCode(String code, Player player) {
availableClasses.get(code).dropForbiddenItems(player);
}
} }

View File

@@ -51,4 +51,14 @@ public abstract class MineClassImpl implements MineClass {
MineClassFactory.setUnbreakableAndSoulbound(itemStack); MineClassFactory.setUnbreakableAndSoulbound(itemStack);
} }
} }
@Override
public void dropForbiddenItems(Player player) {
for (ItemStack content : player.getInventory().getContents()) {
if (content != null && getForbiddenItems().contains(content.getType())) {
player.getInventory().remove(content);
player.getWorld().dropItemNaturally(player.getLocation(), content);
}
}
}
} }

View File

@@ -22,6 +22,7 @@ public class CommandClass implements CommandExecutor {
MineClassFactory.clearAllClassEffects(player); MineClassFactory.clearAllClassEffects(player);
MineClassFactory.getInstance().reapplyEffectsByCode(args[0], player); MineClassFactory.getInstance().reapplyEffectsByCode(args[0], player);
MineClassFactory.getInstance().giveItemsForClassByCode(args[0], player); MineClassFactory.getInstance().giveItemsForClassByCode(args[0], player);
MineClassFactory.getInstance().dropForbiddenItemsForClassByCode(args[0], player);
return true; return true;
} }
if (args[0].equals("clear")) { if (args[0].equals("clear")) {

View File

@@ -14,7 +14,6 @@ import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.block.BlockDropItemEvent; import org.bukkit.event.block.BlockDropItemEvent;
import org.bukkit.event.entity.*; import org.bukkit.event.entity.*;
import org.bukkit.event.inventory.InventoryAction;
import org.bukkit.event.inventory.InventoryClickEvent; import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.event.player.PlayerChangedWorldEvent; import org.bukkit.event.player.PlayerChangedWorldEvent;
import org.bukkit.event.player.PlayerItemConsumeEvent; import org.bukkit.event.player.PlayerItemConsumeEvent;
@@ -92,20 +91,7 @@ public class MineClassListeners implements Listener {
@EventHandler @EventHandler
public void on(InventoryClickEvent event) { public void on(InventoryClickEvent event) {
if ((event.getAction().equals(InventoryAction.PICKUP_ALL) if (event.getWhoClicked() instanceof Player) {
|| event.getAction().equals(InventoryAction.PICKUP_HALF)
|| event.getAction().equals(InventoryAction.PICKUP_ONE)
|| event.getAction().equals(InventoryAction.PICKUP_SOME))
&& event.getWhoClicked() instanceof Player) {
if (isForbiddenItem(event)) {
event.setCancelled(true);
return;
}
enchantItem(event);
}
if ((event.getAction().equals(InventoryAction.MOVE_TO_OTHER_INVENTORY))
&& event.getWhoClicked() instanceof Player) {
if (isForbiddenItem(event)) { if (isForbiddenItem(event)) {
event.setCancelled(true); event.setCancelled(true);
return; return;
@@ -144,7 +130,8 @@ public class MineClassListeners implements Listener {
@EventHandler @EventHandler
public void on(BlockDropItemEvent event) { public void on(BlockDropItemEvent event) {
Player player = event.getPlayer(); Player player = event.getPlayer();
if (AppliedStatus.getInstance().getStatus(player).equals("fire_dwarf")) { if (AppliedStatus.getInstance().getStatus(player) != null
&& AppliedStatus.getInstance().getStatus(player).equals("fire_dwarf")) {
event event
.getItems() .getItems()
.forEach( .forEach(
@@ -166,7 +153,8 @@ public class MineClassListeners implements Listener {
((AbstractArrow) event.getProjectile()) ((AbstractArrow) event.getProjectile())
.setPickupStatus(AbstractArrow.PickupStatus.DISALLOWED); .setPickupStatus(AbstractArrow.PickupStatus.DISALLOWED);
} }
if (AppliedStatus.getInstance().getStatus(player).equals("fire_dwarf")) { if (AppliedStatus.getInstance().getStatus(player) != null
&& AppliedStatus.getInstance().getStatus(player).equals("fire_dwarf")) {
event.getProjectile().setFireTicks(10000); event.getProjectile().setFireTicks(10000);
} }
} }
@@ -178,6 +166,7 @@ public class MineClassListeners implements Listener {
if (event.getEntity() instanceof Player) { if (event.getEntity() instanceof Player) {
Player player = (Player) event.getEntity(); Player player = (Player) event.getEntity();
if (event.getCause().equals(EntityDamageEvent.DamageCause.FALL) if (event.getCause().equals(EntityDamageEvent.DamageCause.FALL)
&& AppliedStatus.getInstance().getStatus(player) != null
&& (AppliedStatus.getInstance().getStatus(player).equals("elf") && (AppliedStatus.getInstance().getStatus(player).equals("elf")
|| AppliedStatus.getInstance().getStatus(player).equals("ender_elf"))) { || AppliedStatus.getInstance().getStatus(player).equals("ender_elf"))) {
event.setCancelled(true); event.setCancelled(true);
@@ -189,10 +178,12 @@ public class MineClassListeners implements Listener {
public void on(FoodLevelChangeEvent event) { public void on(FoodLevelChangeEvent event) {
if (event.getEntity() instanceof Player) { if (event.getEntity() instanceof Player) {
Player player = (Player) event.getEntity(); Player player = (Player) event.getEntity();
if (AppliedStatus.getInstance().getStatus(player).equals("elf")) { if (AppliedStatus.getInstance().getStatus(player) != null
&& AppliedStatus.getInstance().getStatus(player).equals("elf")) {
event.setCancelled(true); event.setCancelled(true);
} }
if (AppliedStatus.getInstance().getStatus(player).equals("ender_elf")) { if (AppliedStatus.getInstance().getStatus(player) != null
&& AppliedStatus.getInstance().getStatus(player).equals("ender_elf")) {
int difference = player.getFoodLevel() - event.getFoodLevel(); int difference = player.getFoodLevel() - event.getFoodLevel();
if (difference > 0) { if (difference > 0) {
event.setFoodLevel(player.getFoodLevel() - (difference * 2)); event.setFoodLevel(player.getFoodLevel() - (difference * 2));
@@ -205,7 +196,8 @@ public class MineClassListeners implements Listener {
public void on(EntityDamageByEntityEvent event) { public void on(EntityDamageByEntityEvent event) {
if (event.getDamager() instanceof Player) { if (event.getDamager() instanceof Player) {
Player player = (Player) event.getDamager(); Player player = (Player) event.getDamager();
if (AppliedStatus.getInstance().getStatus(player).equals("ender_elf") if (AppliedStatus.getInstance().getStatus(player) != null
&& AppliedStatus.getInstance().getStatus(player).equals("ender_elf")
&& player.getInventory().getItemInMainHand().getType().equals(Material.ENDER_PEARL)) { && player.getInventory().getItemInMainHand().getType().equals(Material.ENDER_PEARL)) {
PlayerHitCounter.getInstance().increaseHitCount(player); PlayerHitCounter.getInstance().increaseHitCount(player);
if (player.getAttackCooldown() == 1) { if (player.getAttackCooldown() == 1) {
@@ -242,7 +234,8 @@ public class MineClassListeners implements Listener {
if (player.getGameMode().equals(GameMode.CREATIVE)) { if (player.getGameMode().equals(GameMode.CREATIVE)) {
return; return;
} }
if (AppliedStatus.getInstance().getStatus(player).equals("ender_elf") if (AppliedStatus.getInstance().getStatus(player) != null
&& AppliedStatus.getInstance().getStatus(player).equals("ender_elf")
&& event.getEntity() instanceof EnderPearl) { && event.getEntity() instanceof EnderPearl) {
ItemStack itemStack = new ItemStack(Material.ENDER_PEARL, 1); ItemStack itemStack = new ItemStack(Material.ENDER_PEARL, 1);
MineClassFactory.setUnbreakableAndSoulbound(itemStack); MineClassFactory.setUnbreakableAndSoulbound(itemStack);

View File

@@ -34,10 +34,6 @@ public class AppliedStatus implements Serializable {
return appliedStatus.getOrDefault(player.getName(), "none"); return appliedStatus.getOrDefault(player.getName(), "none");
} }
public synchronized boolean hasClass(Player player) {
return appliedStatus.get(player.getName()) != null;
}
@Override @Override
public boolean equals(Object o) { public boolean equals(Object o) {
if (this == o) return true; if (this == o) return true;