Working on project
This commit is contained in:
@@ -5,11 +5,11 @@ import org.bukkit.Material;
|
|||||||
import org.bukkit.entity.Item;
|
import org.bukkit.entity.Item;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
import org.bukkit.potion.PotionEffect;
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.ArrayList;
|
||||||
import java.util.Objects;
|
import java.util.Collections;
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
public class ClassWrapper {
|
public class ClassWrapper {
|
||||||
|
|
||||||
@@ -84,33 +84,48 @@ public class ClassWrapper {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void enchantItem(Player player, Item item) {
|
public static void enchantItem(Player player, ItemStack itemStack) {
|
||||||
if (AppliedStatus.getInstance().isDwarf(player.getName())) {
|
if (AppliedStatus.getInstance().isDwarf(player.getName())) {
|
||||||
DwarfClass.enchantItem(item.getItemStack());
|
setUnbreakableAndSoulbound(itemStack);
|
||||||
|
DwarfClass.enchantItem(itemStack);
|
||||||
}
|
}
|
||||||
if (AppliedStatus.getInstance().isElf(player.getName())) {
|
if (AppliedStatus.getInstance().isElf(player.getName())) {
|
||||||
ElfClass.enchantItem(item.getItemStack());
|
setUnbreakableAndSoulbound(itemStack);
|
||||||
|
ElfClass.enchantItem(itemStack);
|
||||||
}
|
}
|
||||||
if (AppliedStatus.getInstance().isFireDwarf(player.getName())) {
|
if (AppliedStatus.getInstance().isFireDwarf(player.getName())) {
|
||||||
FireDwarfClass.enchantItem(item.getItemStack());
|
setUnbreakableAndSoulbound(itemStack);
|
||||||
|
FireDwarfClass.enchantItem(itemStack);
|
||||||
}
|
}
|
||||||
if (AppliedStatus.getInstance().isNaga(player.getName())) {
|
if (AppliedStatus.getInstance().isNaga(player.getName())) {
|
||||||
NagaClass.enchantItem(item.getItemStack());
|
setUnbreakableAndSoulbound(itemStack);
|
||||||
|
NagaClass.enchantItem(itemStack);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void givePlayerClassItem(Player player) {
|
public static void removeAllEnchantments(ItemStack itemStack) {
|
||||||
if (AppliedStatus.getInstance().isDwarf(player.getName())) {
|
itemStack
|
||||||
DwarfClass.giveClassItem(player);
|
.getEnchantments()
|
||||||
|
.keySet()
|
||||||
|
.forEach(itemStack::removeEnchantment);
|
||||||
|
removeUnbreakableAndSoulbound(itemStack);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setUnbreakableAndSoulbound(ItemStack itemStack) {
|
||||||
|
if (itemStack.getItemMeta() != null) {
|
||||||
|
ItemMeta itemMeta = itemStack.getItemMeta();
|
||||||
|
itemMeta.setUnbreakable(true);
|
||||||
|
itemMeta.setLore(Collections.singletonList("Soulbound"));
|
||||||
|
itemStack.setItemMeta(itemMeta);
|
||||||
}
|
}
|
||||||
if (AppliedStatus.getInstance().isElf(player.getName())) {
|
}
|
||||||
ElfClass.giveClassItem(player);
|
|
||||||
}
|
public static void removeUnbreakableAndSoulbound(ItemStack itemStack) {
|
||||||
if (AppliedStatus.getInstance().isFireDwarf(player.getName())) {
|
if (itemStack.getItemMeta() != null) {
|
||||||
FireDwarfClass.giveClassItem(player);
|
ItemMeta itemMeta = itemStack.getItemMeta();
|
||||||
}
|
itemMeta.setUnbreakable(false);
|
||||||
if (AppliedStatus.getInstance().isNaga(player.getName())) {
|
itemMeta.setLore(new ArrayList<>());
|
||||||
NagaClass.giveClassItem(player);
|
itemStack.setItemMeta(itemMeta);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -120,15 +135,4 @@ public class ClassWrapper {
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void removePlayerClassItem(Player player) {
|
|
||||||
for (ItemStack content :
|
|
||||||
Arrays.stream(player.getInventory().getContents())
|
|
||||||
.filter(Objects::nonNull)
|
|
||||||
.collect(Collectors.toList())) {
|
|
||||||
if (isSoulBound(content)) {
|
|
||||||
player.getInventory().remove(content);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -102,12 +102,6 @@ public class DwarfClass {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static void enchantItem(ItemStack itemStack) {
|
public static void enchantItem(ItemStack itemStack) {
|
||||||
if (itemStack.getItemMeta() != null) {
|
|
||||||
ItemMeta itemMeta = itemStack.getItemMeta();
|
|
||||||
itemMeta.setUnbreakable(true);
|
|
||||||
itemMeta.setLore(Collections.singletonList("Soulbound"));
|
|
||||||
itemStack.setItemMeta(itemMeta);
|
|
||||||
}
|
|
||||||
classEnchantments
|
classEnchantments
|
||||||
.getOrDefault(itemStack.getType(), new ArrayList<>())
|
.getOrDefault(itemStack.getType(), new ArrayList<>())
|
||||||
.forEach(
|
.forEach(
|
||||||
@@ -115,20 +109,4 @@ public class DwarfClass {
|
|||||||
itemStack.addUnsafeEnchantment(
|
itemStack.addUnsafeEnchantment(
|
||||||
enchantmentIntegerPair.getFirst(), enchantmentIntegerPair.getSecond()));
|
enchantmentIntegerPair.getFirst(), enchantmentIntegerPair.getSecond()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void giveClassItem(Player player) {
|
|
||||||
List<Boolean> itemStackList =
|
|
||||||
Arrays.stream(player.getInventory().getContents())
|
|
||||||
.filter(Objects::nonNull)
|
|
||||||
.map(ClassWrapper::isSoulBound)
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
if (itemStackList.contains(true)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (Material material : classEnchantments.keySet()) {
|
|
||||||
ItemStack itemStack = new ItemStack(material);
|
|
||||||
enchantItem(itemStack);
|
|
||||||
player.getInventory().addItem(itemStack);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -80,17 +80,7 @@ public class ElfClass {
|
|||||||
return classEnchantments.containsKey(type);
|
return classEnchantments.containsKey(type);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void makeSoulbound(ItemStack itemStack) {
|
|
||||||
if (itemStack.getItemMeta() != null) {
|
|
||||||
ItemMeta itemMeta = itemStack.getItemMeta();
|
|
||||||
itemMeta.setUnbreakable(true);
|
|
||||||
itemMeta.setLore(Collections.singletonList("Soulbound"));
|
|
||||||
itemStack.setItemMeta(itemMeta);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void enchantItem(ItemStack itemStack) {
|
public static void enchantItem(ItemStack itemStack) {
|
||||||
makeSoulbound(itemStack);
|
|
||||||
classEnchantments
|
classEnchantments
|
||||||
.getOrDefault(itemStack.getType(), new ArrayList<>())
|
.getOrDefault(itemStack.getType(), new ArrayList<>())
|
||||||
.forEach(
|
.forEach(
|
||||||
@@ -99,25 +89,4 @@ public class ElfClass {
|
|||||||
.addUnsafeEnchantment(
|
.addUnsafeEnchantment(
|
||||||
enchantmentIntegerPair.getFirst(), enchantmentIntegerPair.getSecond()));
|
enchantmentIntegerPair.getFirst(), enchantmentIntegerPair.getSecond()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void giveClassItem(Player player) {
|
|
||||||
List<Boolean> itemStackList =
|
|
||||||
Arrays.stream(player.getInventory().getContents())
|
|
||||||
.filter(Objects::nonNull)
|
|
||||||
.map(ClassWrapper::isSoulBound)
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
if (itemStackList.contains(true)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (Material material : classEnchantments.keySet()) {
|
|
||||||
if (material.equals(Material.BOW)) {
|
|
||||||
ItemStack itemStack = new ItemStack(Material.ARROW);
|
|
||||||
makeSoulbound(itemStack);
|
|
||||||
player.getInventory().addItem(itemStack);
|
|
||||||
}
|
|
||||||
ItemStack itemStack = new ItemStack(material);
|
|
||||||
enchantItem(itemStack);
|
|
||||||
player.getInventory().addItem(itemStack);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -119,12 +119,6 @@ public class FireDwarfClass {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static void enchantItem(ItemStack itemStack) {
|
public static void enchantItem(ItemStack itemStack) {
|
||||||
if (itemStack.getItemMeta() != null) {
|
|
||||||
ItemMeta itemMeta = itemStack.getItemMeta();
|
|
||||||
itemMeta.setUnbreakable(true);
|
|
||||||
itemMeta.setLore(Collections.singletonList("Soulbound"));
|
|
||||||
itemStack.setItemMeta(itemMeta);
|
|
||||||
}
|
|
||||||
classEnchantments
|
classEnchantments
|
||||||
.getOrDefault(itemStack.getType(), new ArrayList<>())
|
.getOrDefault(itemStack.getType(), new ArrayList<>())
|
||||||
.forEach(
|
.forEach(
|
||||||
@@ -133,20 +127,4 @@ public class FireDwarfClass {
|
|||||||
.addUnsafeEnchantment(
|
.addUnsafeEnchantment(
|
||||||
enchantmentIntegerPair.getFirst(), enchantmentIntegerPair.getSecond()));
|
enchantmentIntegerPair.getFirst(), enchantmentIntegerPair.getSecond()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void giveClassItem(Player player) {
|
|
||||||
List<Boolean> itemStackList =
|
|
||||||
Arrays.stream(player.getInventory().getContents())
|
|
||||||
.filter(Objects::nonNull)
|
|
||||||
.map(ClassWrapper::isSoulBound)
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
if (itemStackList.contains(true)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (Material material : classEnchantments.keySet()) {
|
|
||||||
ItemStack itemStack = new ItemStack(material);
|
|
||||||
enchantItem(itemStack);
|
|
||||||
player.getInventory().addItem(itemStack);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -100,12 +100,6 @@ public class NagaClass {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static void enchantItem(ItemStack itemStack) {
|
public static void enchantItem(ItemStack itemStack) {
|
||||||
if (itemStack.getItemMeta() != null) {
|
|
||||||
ItemMeta itemMeta = itemStack.getItemMeta();
|
|
||||||
itemMeta.setUnbreakable(true);
|
|
||||||
itemMeta.setLore(Collections.singletonList("Soulbound"));
|
|
||||||
itemStack.setItemMeta(itemMeta);
|
|
||||||
}
|
|
||||||
classEnchantments
|
classEnchantments
|
||||||
.getOrDefault(itemStack.getType(), new ArrayList<>())
|
.getOrDefault(itemStack.getType(), new ArrayList<>())
|
||||||
.forEach(
|
.forEach(
|
||||||
@@ -114,20 +108,4 @@ public class NagaClass {
|
|||||||
.addUnsafeEnchantment(
|
.addUnsafeEnchantment(
|
||||||
enchantmentIntegerPair.getFirst(), enchantmentIntegerPair.getSecond()));
|
enchantmentIntegerPair.getFirst(), enchantmentIntegerPair.getSecond()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void giveClassItem(Player player) {
|
|
||||||
List<Boolean> itemStackList =
|
|
||||||
Arrays.stream(player.getInventory().getContents())
|
|
||||||
.filter(Objects::nonNull)
|
|
||||||
.map(ClassWrapper::isSoulBound)
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
if (itemStackList.contains(true)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (Material material : classEnchantments.keySet()) {
|
|
||||||
ItemStack itemStack = new ItemStack(material);
|
|
||||||
enchantItem(itemStack);
|
|
||||||
player.getInventory().addItem(itemStack);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,7 +23,6 @@ public class CommandClass implements CommandExecutor {
|
|||||||
AppliedStatus.getInstance().setDwarf(player.getName(), true);
|
AppliedStatus.getInstance().setDwarf(player.getName(), true);
|
||||||
ClassWrapper.clearAllClassEffects(player);
|
ClassWrapper.clearAllClassEffects(player);
|
||||||
DwarfClass.reapplyEffects(player);
|
DwarfClass.reapplyEffects(player);
|
||||||
DwarfClass.giveClassItem(player);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (args[0].equals("elf")) {
|
if (args[0].equals("elf")) {
|
||||||
@@ -33,7 +32,6 @@ public class CommandClass implements CommandExecutor {
|
|||||||
AppliedStatus.getInstance().setElf(player.getName(), true);
|
AppliedStatus.getInstance().setElf(player.getName(), true);
|
||||||
ClassWrapper.clearAllClassEffects(player);
|
ClassWrapper.clearAllClassEffects(player);
|
||||||
ElfClass.reapplyEffects(player);
|
ElfClass.reapplyEffects(player);
|
||||||
ElfClass.giveClassItem(player);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (args[0].equals("fire_dwarf")) {
|
if (args[0].equals("fire_dwarf")) {
|
||||||
@@ -43,7 +41,6 @@ public class CommandClass implements CommandExecutor {
|
|||||||
AppliedStatus.getInstance().setFireDwarf(player.getName(), true);
|
AppliedStatus.getInstance().setFireDwarf(player.getName(), true);
|
||||||
ClassWrapper.clearAllClassEffects(player);
|
ClassWrapper.clearAllClassEffects(player);
|
||||||
FireDwarfClass.reapplyEffects(player);
|
FireDwarfClass.reapplyEffects(player);
|
||||||
FireDwarfClass.giveClassItem(player);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (args[0].equals("naga")) {
|
if (args[0].equals("naga")) {
|
||||||
@@ -53,7 +50,6 @@ public class CommandClass implements CommandExecutor {
|
|||||||
AppliedStatus.getInstance().setNaga(player.getName(), true);
|
AppliedStatus.getInstance().setNaga(player.getName(), true);
|
||||||
ClassWrapper.clearAllClassEffects(player);
|
ClassWrapper.clearAllClassEffects(player);
|
||||||
NagaClass.reapplyEffects(player);
|
NagaClass.reapplyEffects(player);
|
||||||
NagaClass.giveClassItem(player);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (args[0].equals("clear")) {
|
if (args[0].equals("clear")) {
|
||||||
@@ -62,7 +58,6 @@ public class CommandClass implements CommandExecutor {
|
|||||||
AppliedStatus.getInstance().setFireDwarf(player.getName(), false);
|
AppliedStatus.getInstance().setFireDwarf(player.getName(), false);
|
||||||
AppliedStatus.getInstance().setNaga(player.getName(), false);
|
AppliedStatus.getInstance().setNaga(player.getName(), false);
|
||||||
ClassWrapper.clearAllClassEffects(player);
|
ClassWrapper.clearAllClassEffects(player);
|
||||||
ClassWrapper.removePlayerClassItem(player);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (args[0].equals("whoami")) {
|
if (args[0].equals("whoami")) {
|
||||||
|
|||||||
@@ -0,0 +1,43 @@
|
|||||||
|
package net.babamod.mineclass.utils;
|
||||||
|
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class ClassItemPossessed {
|
||||||
|
/** Instance unique pré-initialisée */
|
||||||
|
private static ClassItemPossessed INSTANCE;
|
||||||
|
|
||||||
|
private final HashMap<String, List<ItemStack>> itemsPossessed;
|
||||||
|
|
||||||
|
/** Constructeur privé */
|
||||||
|
private ClassItemPossessed() {
|
||||||
|
itemsPossessed = new HashMap<>();
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Point d'accès pour l'instance unique du singleton */
|
||||||
|
public static synchronized ClassItemPossessed getInstance() {
|
||||||
|
if (INSTANCE == null) {
|
||||||
|
INSTANCE = new ClassItemPossessed();
|
||||||
|
}
|
||||||
|
|
||||||
|
return INSTANCE;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addItems(String playerName, List<ItemStack> itemStacks) {
|
||||||
|
List<ItemStack> itemStackList = itemsPossessed.getOrDefault(playerName, new ArrayList<>());
|
||||||
|
itemStackList.addAll(itemStacks);
|
||||||
|
itemsPossessed.put(playerName, itemStackList);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearItems(String playerName) {
|
||||||
|
itemsPossessed.put(playerName, new ArrayList<>());
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<ItemStack> getItems(String playerName) {
|
||||||
|
return itemsPossessed.get(playerName);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -3,22 +3,21 @@ package net.babamod.mineclass.utils;
|
|||||||
import net.babamod.mineclass.Mineclass;
|
import net.babamod.mineclass.Mineclass;
|
||||||
import net.babamod.mineclass.classes.ClassWrapper;
|
import net.babamod.mineclass.classes.ClassWrapper;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.entity.Entity;
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.entity.EntityDeathEvent;
|
|
||||||
import org.bukkit.event.entity.EntityPickupItemEvent;
|
import org.bukkit.event.entity.EntityPickupItemEvent;
|
||||||
import org.bukkit.event.entity.PlayerDeathEvent;
|
import org.bukkit.event.entity.PlayerDeathEvent;
|
||||||
import org.bukkit.event.inventory.*;
|
import org.bukkit.event.inventory.InventoryAction;
|
||||||
|
import org.bukkit.event.inventory.InventoryClickEvent;
|
||||||
import org.bukkit.event.player.PlayerDropItemEvent;
|
import org.bukkit.event.player.PlayerDropItemEvent;
|
||||||
import org.bukkit.event.player.PlayerItemConsumeEvent;
|
import org.bukkit.event.player.PlayerItemConsumeEvent;
|
||||||
import org.bukkit.event.player.PlayerJoinEvent;
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
import org.bukkit.event.player.PlayerRespawnEvent;
|
import org.bukkit.event.player.PlayerRespawnEvent;
|
||||||
|
import org.bukkit.inventory.CraftingInventory;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.inventory.PlayerInventory;
|
import org.bukkit.inventory.PlayerInventory;
|
||||||
|
|
||||||
import javax.swing.*;
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
@@ -60,7 +59,7 @@ public class MineClassListeners implements Listener {
|
|||||||
ClassWrapper.isItemEnchantable(player, event.getItem().getItemStack().getType())));
|
ClassWrapper.isItemEnchantable(player, event.getItem().getItemStack().getType())));
|
||||||
if (ClassWrapper.isItemEnchantable(player, event.getItem().getItemStack().getType())) {
|
if (ClassWrapper.isItemEnchantable(player, event.getItem().getItemStack().getType())) {
|
||||||
player.sendMessage("Enchantable item !");
|
player.sendMessage("Enchantable item !");
|
||||||
ClassWrapper.enchantItem(player, event.getItem());
|
ClassWrapper.enchantItem(player, event.getItem().getItemStack());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -70,19 +69,22 @@ public class MineClassListeners implements Listener {
|
|||||||
List<ItemStack> itemStackList =
|
List<ItemStack> itemStackList =
|
||||||
event.getDrops().stream().filter(ClassWrapper::isSoulBound).collect(Collectors.toList());
|
event.getDrops().stream().filter(ClassWrapper::isSoulBound).collect(Collectors.toList());
|
||||||
event.getDrops().removeAll(itemStackList);
|
event.getDrops().removeAll(itemStackList);
|
||||||
ClassWrapper.removePlayerClassItem(event.getEntity());
|
ClassItemPossessed.getInstance().addItems(event.getEntity().getName(), itemStackList);
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void on(PlayerRespawnEvent event) {
|
public void on(PlayerRespawnEvent event) {
|
||||||
ClassWrapper.givePlayerClassItem(event.getPlayer());
|
|
||||||
new ApplyClassStatusTask(this.plugin, event.getPlayer()).runTaskLater(this.plugin, 10);
|
new ApplyClassStatusTask(this.plugin, event.getPlayer()).runTaskLater(this.plugin, 10);
|
||||||
|
ClassItemPossessed.getInstance()
|
||||||
|
.getItems(event.getPlayer().getName())
|
||||||
|
.forEach(itemStack -> event.getPlayer().getInventory().addItem(itemStack));
|
||||||
|
ClassItemPossessed.getInstance().clearItems(event.getPlayer().getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void on(PlayerDropItemEvent event) {
|
public void on(PlayerDropItemEvent event) {
|
||||||
if (ClassWrapper.isSoulBound(event.getItemDrop().getItemStack())) {
|
if (ClassWrapper.isSoulBound(event.getItemDrop().getItemStack())) {
|
||||||
event.setCancelled(true);
|
ClassWrapper.removeAllEnchantments(event.getItemDrop().getItemStack());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -100,17 +102,43 @@ public class MineClassListeners implements Listener {
|
|||||||
System.out.println(event.getHotbarButton());
|
System.out.println(event.getHotbarButton());
|
||||||
System.out.println(event.getRawSlot());
|
System.out.println(event.getRawSlot());
|
||||||
System.out.println(event.getSlot());
|
System.out.println(event.getSlot());
|
||||||
System.out.println("-----------------------------------");
|
|
||||||
|
|
||||||
if (event.getAction().equals(InventoryAction.MOVE_TO_OTHER_INVENTORY)) {
|
if (event.getAction().equals(InventoryAction.MOVE_TO_OTHER_INVENTORY)
|
||||||
if (event.getCurrentItem() != null && ClassWrapper.isSoulBound(event.getCurrentItem())) {
|
&& event.getClickedInventory() instanceof CraftingInventory) {
|
||||||
event.setCancelled(true);
|
System.out.println("We are in a crafting inventory.");
|
||||||
return;
|
CraftingInventory playerInventory = (CraftingInventory) event.getClickedInventory();
|
||||||
|
if (event.getCurrentItem() != null
|
||||||
|
&& playerInventory.getHolder() != null
|
||||||
|
&& !ClassWrapper.isSoulBound(event.getCurrentItem())) {
|
||||||
|
System.out.println("Enchanting item !");
|
||||||
|
ClassWrapper.enchantItem((Player) playerInventory.getHolder(), event.getCurrentItem());
|
||||||
}
|
}
|
||||||
if (event.getCursor() != null && ClassWrapper.isSoulBound(event.getCursor())) {
|
if (event.getCursor() != null
|
||||||
event.setCancelled(true);
|
&& playerInventory.getHolder() != null
|
||||||
|
&& !ClassWrapper.isSoulBound(event.getCursor())) {
|
||||||
|
System.out.println("Enchanting item !");
|
||||||
|
ClassWrapper.enchantItem((Player) playerInventory.getHolder(), event.getCursor());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (event.getAction().equals(InventoryAction.PLACE_ALL)
|
||||||
|
&& event.getClickedInventory() instanceof PlayerInventory) {
|
||||||
|
System.out.println("We are in a player inventory.");
|
||||||
|
PlayerInventory playerInventory = (PlayerInventory) event.getClickedInventory();
|
||||||
|
if (event.getCurrentItem() != null
|
||||||
|
&& playerInventory.getHolder() != null
|
||||||
|
&& !ClassWrapper.isSoulBound(event.getCurrentItem())) {
|
||||||
|
System.out.println("Enchanting item !");
|
||||||
|
ClassWrapper.enchantItem((Player) playerInventory.getHolder(), event.getCurrentItem());
|
||||||
|
}
|
||||||
|
if (event.getCursor() != null
|
||||||
|
&& playerInventory.getHolder() != null
|
||||||
|
&& !ClassWrapper.isSoulBound(event.getCursor())) {
|
||||||
|
System.out.println("Enchanting item !");
|
||||||
|
ClassWrapper.enchantItem((Player) playerInventory.getHolder(), event.getCursor());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
System.out.println("-----------------------------------");
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|||||||
Reference in New Issue
Block a user