Working on project

This commit is contained in:
Barazok
2020-10-10 18:07:02 +02:00
parent 896106222d
commit fc3d2298fa
8 changed files with 120 additions and 147 deletions

View File

@@ -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);
}
}
}
} }

View File

@@ -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);
}
}
} }

View File

@@ -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);
}
}
} }

View File

@@ -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);
}
}
} }

View File

@@ -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);
}
}
} }

View File

@@ -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")) {

View File

@@ -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);
}
}

View File

@@ -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("-----------------------------------");
} }
/* /*