diff --git a/pom.xml b/pom.xml
index a8c00da..bc39acc 100644
--- a/pom.xml
+++ b/pom.xml
@@ -40,6 +40,7 @@
1.17.3
2.6.3
1.7
+ 1.0.0
${build.version}-SNAPSHOT
@@ -136,7 +137,7 @@
org.spigotmc
plugin-annotations
1.2.3-SNAPSHOT
- compile
+ provided
@@ -158,11 +159,19 @@
${level.version}
provided
+
+
+ lv.id.bonne
+ panelutils
+ ${panelutils.version}
+ compile
+
org.jetbrains
annotations
- 21.0.1
+ 22.0.0
+ provided
@@ -190,7 +199,6 @@
1.5.21
provided
-
@@ -236,6 +244,8 @@
maven-compiler-plugin
3.7.0
+
+ ${java.version}
${java.version}
@@ -350,6 +360,38 @@
+
+ org.apache.maven.plugins
+ maven-shade-plugin
+ 3.3.1-SNAPSHOT
+
+ true
+
+
+ lv.id.bonne:panelutils:*
+
+
+
+
+
+ MANIFEST.MF
+
+
+
+ META-INF/MANIFEST.MF
+ src/main/resources/META-INF/MANIFEST.MF
+
+
+
+
+
+ package
+
+ shade
+
+
+
+
diff --git a/src/main/java/world/bentobox/challenges/database/object/requirements/IslandRequirements.java b/src/main/java/world/bentobox/challenges/database/object/requirements/IslandRequirements.java
index 1de6737..5e27445 100644
--- a/src/main/java/world/bentobox/challenges/database/object/requirements/IslandRequirements.java
+++ b/src/main/java/world/bentobox/challenges/database/object/requirements/IslandRequirements.java
@@ -39,7 +39,7 @@ public class IslandRequirements extends Requirements
/**
* Method IslandRequirements#getRequiredBlocks returns the requiredBlocks of this object.
*
- * @return the requiredBlocks (type Map) of this object.
+ * @return the requiredBlocks (type {@code Map}) of this object.
*/
public Map getRequiredBlocks()
{
@@ -83,7 +83,7 @@ public class IslandRequirements extends Requirements
/**
* Method IslandRequirements#getRequiredEntities returns the requiredEntities of this object.
*
- * @return the requiredEntities (type Map) of this object.
+ * @return the requiredEntities (type {@code Map}) of this object.
*/
public Map getRequiredEntities()
{
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/AdminPanel.java b/src/main/java/world/bentobox/challenges/panel/admin/AdminPanel.java
index 7dce90a..f919626 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/AdminPanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/AdminPanel.java
@@ -11,6 +11,7 @@ import org.bukkit.Material;
import org.bukkit.World;
import org.bukkit.inventory.ItemStack;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
@@ -20,7 +21,6 @@ import world.bentobox.challenges.panel.CommonPanel;
import world.bentobox.challenges.panel.ConversationUtils;
import world.bentobox.challenges.panel.util.ChallengeTypeSelector;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
import world.bentobox.challenges.web.WebManager;
@@ -84,7 +84,7 @@ public class AdminPanel extends CommonPanel
PanelBuilder panelBuilder = new PanelBuilder().user(this.user).name(
this.user.getTranslation(Constants.TITLE + "admin-gui"));
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
panelBuilder.item(10, this.createButton(Button.COMPLETE_USER_CHALLENGES));
panelBuilder.item(19, this.createButton(Button.RESET_USER_CHALLENGES));
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/EditChallengePanel.java b/src/main/java/world/bentobox/challenges/panel/admin/EditChallengePanel.java
index 0781e9c..52e8ede 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/EditChallengePanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/EditChallengePanel.java
@@ -12,6 +12,7 @@ import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.event.inventory.InventoryCloseEvent;
import org.bukkit.inventory.ItemStack;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.PanelListener;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
@@ -28,7 +29,6 @@ import world.bentobox.challenges.panel.CommonPanel;
import world.bentobox.challenges.panel.ConversationUtils;
import world.bentobox.challenges.panel.util.*;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -125,7 +125,7 @@ public class EditChallengePanel extends CommonPanel
this.user.getTranslation(Constants.TITLE + "edit-challenge",
"[challenge]", this.challenge.getFriendlyName()));
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
panelBuilder.item(2, this.createMenuButton(MenuType.PROPERTIES));
panelBuilder.item(4, this.createMenuButton(MenuType.REQUIREMENTS));
@@ -1330,7 +1330,7 @@ public class EditChallengePanel extends CommonPanel
icon = requirements.getEntity() == null ?
new ItemStack(Material.BARRIER) :
- new ItemStack(GuiUtils.getEntityEgg(requirements.getEntity()));
+ new ItemStack(PanelUtils.getEntityEgg(requirements.getEntity()));
clickHandler = (panel, user, clickType, slot) -> {
SingleEntitySelector.open(this.user,
true,
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/EditLevelPanel.java b/src/main/java/world/bentobox/challenges/panel/admin/EditLevelPanel.java
index 5460405..665ca8e 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/EditLevelPanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/EditLevelPanel.java
@@ -11,6 +11,7 @@ import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.event.inventory.InventoryCloseEvent;
import org.bukkit.inventory.ItemStack;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.PanelListener;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
@@ -27,7 +28,6 @@ import world.bentobox.challenges.panel.ConversationUtils;
import world.bentobox.challenges.panel.util.ItemSelector;
import world.bentobox.challenges.panel.util.ChallengeSelector;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -131,7 +131,7 @@ public class EditLevelPanel extends CommonPagedPanel
this.user.getTranslation(Constants.TITLE + "edit-level",
"[level]", this.challengeLevel.getFriendlyName()));
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
panelBuilder.item(2, this.createMenuButton(MenuType.PROPERTIES));
panelBuilder.item(4, this.createMenuButton(MenuType.REWARDS));
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/EditSettingsPanel.java b/src/main/java/world/bentobox/challenges/panel/admin/EditSettingsPanel.java
index 1a02de3..3d0eed9 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/EditSettingsPanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/EditSettingsPanel.java
@@ -11,6 +11,7 @@ import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.event.inventory.InventoryCloseEvent;
import org.bukkit.inventory.ItemStack;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.PanelListener;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
@@ -23,7 +24,6 @@ import world.bentobox.challenges.config.SettingsUtils.VisibilityMode;
import world.bentobox.challenges.panel.CommonPanel;
import world.bentobox.challenges.panel.ConversationUtils;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -105,7 +105,7 @@ public class EditSettingsPanel extends CommonPanel
PanelBuilder panelBuilder = new PanelBuilder().user(this.user).name(
this.user.getTranslation(Constants.TITLE + "settings"));
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
panelBuilder.item(10, this.getSettingsButton(Button.SHOW_TITLE));
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/LibraryPanel.java b/src/main/java/world/bentobox/challenges/panel/admin/LibraryPanel.java
index 1194666..cfa10d3 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/LibraryPanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/LibraryPanel.java
@@ -15,6 +15,7 @@ import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.event.inventory.InventoryCloseEvent;
import org.bukkit.scheduler.BukkitTask;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.PanelListener;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
@@ -24,7 +25,6 @@ import world.bentobox.challenges.panel.CommonPagedPanel;
import world.bentobox.challenges.panel.CommonPanel;
import world.bentobox.challenges.panel.ConversationUtils;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
import world.bentobox.challenges.web.object.LibraryEntry;
@@ -182,7 +182,7 @@ public class LibraryPanel extends CommonPagedPanel
PanelBuilder panelBuilder = new PanelBuilder().user(this.user).name(
this.user.getTranslation(Constants.TITLE + "library"));
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
this.populateElements(panelBuilder, this.filterElements);
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/ListChallengesPanel.java b/src/main/java/world/bentobox/challenges/panel/admin/ListChallengesPanel.java
index f7f009e..3e047a7 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/ListChallengesPanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/ListChallengesPanel.java
@@ -8,6 +8,7 @@ import java.util.stream.Collectors;
import org.bukkit.Material;
import org.bukkit.World;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
@@ -19,7 +20,6 @@ import world.bentobox.challenges.panel.CommonPagedPanel;
import world.bentobox.challenges.panel.CommonPanel;
import world.bentobox.challenges.panel.ConversationUtils;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -119,11 +119,11 @@ public class ListChallengesPanel extends CommonPagedPanel
if (this.currentMode.equals(Mode.DELETE))
{
- GuiUtils.fillBorder(panelBuilder, Material.RED_STAINED_GLASS_PANE);
+ PanelUtils.fillBorder(panelBuilder, Material.RED_STAINED_GLASS_PANE);
}
else
{
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
}
List challengeList = this.addon.getChallengesManager().getAllChallenges(this.world).
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/ListLevelsPanel.java b/src/main/java/world/bentobox/challenges/panel/admin/ListLevelsPanel.java
index ac19cab..9b344f5 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/ListLevelsPanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/ListLevelsPanel.java
@@ -8,19 +8,18 @@ import java.util.List;
import java.util.function.Consumer;
import java.util.stream.Collectors;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
import world.bentobox.bentobox.api.user.User;
import world.bentobox.bentobox.util.Util;
import world.bentobox.challenges.ChallengesAddon;
-import world.bentobox.challenges.database.object.Challenge;
import world.bentobox.challenges.database.object.ChallengeLevel;
import world.bentobox.challenges.panel.CommonPagedPanel;
import world.bentobox.challenges.panel.CommonPanel;
import world.bentobox.challenges.panel.ConversationUtils;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -120,11 +119,11 @@ public class ListLevelsPanel extends CommonPagedPanel
if (this.currentMode.equals(Mode.DELETE))
{
- GuiUtils.fillBorder(panelBuilder, Material.RED_STAINED_GLASS_PANE);
+ PanelUtils.fillBorder(panelBuilder, Material.RED_STAINED_GLASS_PANE);
}
else
{
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
}
List levelList = this.addon.getChallengesManager().getLevels(this.world).
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/ListUsersPanel.java b/src/main/java/world/bentobox/challenges/panel/admin/ListUsersPanel.java
index a7216dc..2a6aab3 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/ListUsersPanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/ListUsersPanel.java
@@ -12,6 +12,7 @@ import org.bukkit.Material;
import org.bukkit.World;
import org.bukkit.entity.Player;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
@@ -24,7 +25,6 @@ import world.bentobox.challenges.panel.CommonPagedPanel;
import world.bentobox.challenges.panel.CommonPanel;
import world.bentobox.challenges.panel.util.ChallengeSelector;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -135,7 +135,7 @@ public class ListUsersPanel extends CommonPagedPanel
PanelBuilder panelBuilder = new PanelBuilder().user(this.user).name(
this.user.getTranslation(Constants.TITLE + "choose-player"));
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
this.populateElements(panelBuilder, this.filterElements);
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/ManageBlocksPanel.java b/src/main/java/world/bentobox/challenges/panel/admin/ManageBlocksPanel.java
index b288dc0..fd81740 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/ManageBlocksPanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/ManageBlocksPanel.java
@@ -13,6 +13,7 @@ import java.util.stream.Collectors;
import org.bukkit.Material;
import org.bukkit.inventory.ItemStack;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
@@ -21,7 +22,6 @@ import world.bentobox.challenges.panel.CommonPanel;
import world.bentobox.challenges.panel.ConversationUtils;
import world.bentobox.challenges.panel.util.MultiBlockSelector;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -93,7 +93,7 @@ public class ManageBlocksPanel extends CommonPagedPanel
name(this.user.getTranslation(Constants.TITLE + "manage-blocks"));
// Create nice border.
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
panelBuilder.item(3, this.createButton(Button.ADD_BLOCK));
panelBuilder.item(5, this.createButton(Button.REMOVE_BLOCK));
@@ -233,7 +233,7 @@ public class ManageBlocksPanel extends CommonPagedPanel
return new PanelItemBuilder().
name(this.user.getTranslation(reference + "name", "[material]",
Utils.prettifyObject(material, this.user))).
- icon(GuiUtils.getMaterialItem(material, this.materialMap.get(material))).
+ icon(PanelUtils.getMaterialItem(material, this.materialMap.get(material))).
description(description).
clickHandler((panel, user1, clickType, slot) -> {
// On right click change which entities are selected for deletion.
diff --git a/src/main/java/world/bentobox/challenges/panel/admin/ManageEntitiesPanel.java b/src/main/java/world/bentobox/challenges/panel/admin/ManageEntitiesPanel.java
index 1e4ff5d..db0267d 100644
--- a/src/main/java/world/bentobox/challenges/panel/admin/ManageEntitiesPanel.java
+++ b/src/main/java/world/bentobox/challenges/panel/admin/ManageEntitiesPanel.java
@@ -14,6 +14,7 @@ import org.bukkit.Material;
import org.bukkit.entity.EntityType;
import org.bukkit.inventory.ItemStack;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
@@ -22,7 +23,6 @@ import world.bentobox.challenges.panel.CommonPanel;
import world.bentobox.challenges.panel.ConversationUtils;
import world.bentobox.challenges.panel.util.MultiEntitySelector;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -91,7 +91,7 @@ public class ManageEntitiesPanel extends CommonPagedPanel
name(this.user.getTranslation(Constants.TITLE + "manage-entities"));
// create border
- GuiUtils.fillBorder(panelBuilder);
+ PanelUtils.fillBorder(panelBuilder);
panelBuilder.item(3, this.createButton(Button.ADD_ENTITY));
panelBuilder.item(5, this.createButton(Button.REMOVE_ENTITY));
@@ -244,8 +244,8 @@ public class ManageEntitiesPanel extends CommonPagedPanel
name(this.user.getTranslation(reference + "name", "[entity]",
Utils.prettifyObject(entity, this.user))).
icon(this.asEggs ?
- GuiUtils.getEntityEgg(entity, this.requiredEntities.get(entity)) :
- GuiUtils.getEntityHead(entity, this.requiredEntities.get(entity))).
+ PanelUtils.getEntityEgg(entity, this.requiredEntities.get(entity)) :
+ PanelUtils.getEntityHead(entity, this.requiredEntities.get(entity))).
description(description).
clickHandler((panel, user1, clickType, slot) -> {
// On right click change which entities are selected for deletion.
diff --git a/src/main/java/world/bentobox/challenges/panel/util/ChallengeSelector.java b/src/main/java/world/bentobox/challenges/panel/util/ChallengeSelector.java
index c582e76..a75306a 100644
--- a/src/main/java/world/bentobox/challenges/panel/util/ChallengeSelector.java
+++ b/src/main/java/world/bentobox/challenges/panel/util/ChallengeSelector.java
@@ -12,6 +12,7 @@ import java.util.stream.Collectors;
import org.bukkit.Material;
import org.bukkit.inventory.ItemStack;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
@@ -19,7 +20,6 @@ import world.bentobox.bentobox.api.user.User;
import world.bentobox.bentobox.util.Util;
import world.bentobox.challenges.database.object.Challenge;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
/**
@@ -61,7 +61,7 @@ public class ChallengeSelector extends PagedSelector
PanelBuilder panelBuilder = new PanelBuilder().user(this.user);
panelBuilder.name(this.user.getTranslation(Constants.TITLE + "challenge-selector"));
- GuiUtils.fillBorder(panelBuilder, this.border);
+ PanelUtils.fillBorder(panelBuilder, this.border);
this.populateElements(panelBuilder, this.filterElements);
diff --git a/src/main/java/world/bentobox/challenges/panel/util/MultiBlockSelector.java b/src/main/java/world/bentobox/challenges/panel/util/MultiBlockSelector.java
index d945f6e..ba20b5d 100644
--- a/src/main/java/world/bentobox/challenges/panel/util/MultiBlockSelector.java
+++ b/src/main/java/world/bentobox/challenges/panel/util/MultiBlockSelector.java
@@ -8,12 +8,12 @@ import java.util.stream.Collectors;
import org.bukkit.Material;
import org.bukkit.inventory.ItemStack;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
import world.bentobox.bentobox.api.user.User;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -104,7 +104,7 @@ public class MultiBlockSelector extends PagedSelector
PanelBuilder panelBuilder = new PanelBuilder().user(this.user);
panelBuilder.name(this.user.getTranslation(Constants.TITLE + "block-selector"));
- GuiUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
+ PanelUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
this.populateElements(panelBuilder, this.filterElements);
@@ -233,7 +233,7 @@ public class MultiBlockSelector extends PagedSelector
return new PanelItemBuilder().
name(this.user.getTranslation(reference + "name", "[material]",
Utils.prettifyObject(material, this.user))).
- icon(GuiUtils.getMaterialItem(material)).
+ icon(PanelUtils.getMaterialItem(material)).
description(description).
clickHandler((panel, user1, clickType, slot) -> {
// On right click change which entities are selected for deletion.
diff --git a/src/main/java/world/bentobox/challenges/panel/util/MultiEntitySelector.java b/src/main/java/world/bentobox/challenges/panel/util/MultiEntitySelector.java
index affd355..74ada01 100644
--- a/src/main/java/world/bentobox/challenges/panel/util/MultiEntitySelector.java
+++ b/src/main/java/world/bentobox/challenges/panel/util/MultiEntitySelector.java
@@ -8,12 +8,12 @@ import java.util.*;
import java.util.function.BiConsumer;
import java.util.stream.Collectors;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
import world.bentobox.bentobox.api.user.User;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -88,7 +88,7 @@ public class MultiEntitySelector extends PagedSelector
PanelBuilder panelBuilder = new PanelBuilder().user(this.user);
panelBuilder.name(this.user.getTranslation(Constants.TITLE + "entity-selector"));
- GuiUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
+ PanelUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
this.populateElements(panelBuilder, this.filterElements);
@@ -217,7 +217,7 @@ public class MultiEntitySelector extends PagedSelector
return new PanelItemBuilder().
name(this.user.getTranslation(reference + "name", "[entity]",
Utils.prettifyObject(entity, this.user))).
- icon(this.asEgg ? GuiUtils.getEntityEgg(entity) : GuiUtils.getEntityHead(entity)).
+ icon(this.asEgg ? PanelUtils.getEntityEgg(entity) : PanelUtils.getEntityHead(entity)).
description(description).
clickHandler((panel, user1, clickType, slot) -> {
// On right click change which entities are selected for deletion.
diff --git a/src/main/java/world/bentobox/challenges/panel/util/SingleBlockSelector.java b/src/main/java/world/bentobox/challenges/panel/util/SingleBlockSelector.java
index 2400722..d9fae37 100644
--- a/src/main/java/world/bentobox/challenges/panel/util/SingleBlockSelector.java
+++ b/src/main/java/world/bentobox/challenges/panel/util/SingleBlockSelector.java
@@ -7,12 +7,12 @@ import java.util.*;
import java.util.function.BiConsumer;
import java.util.stream.Collectors;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
import world.bentobox.bentobox.api.user.User;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -114,7 +114,7 @@ public class SingleBlockSelector extends PagedSelector
PanelBuilder panelBuilder = new PanelBuilder().user(this.user);
panelBuilder.name(this.user.getTranslation(Constants.TITLE + "block-selector"));
- GuiUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
+ PanelUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
this.populateElements(panelBuilder, this.filterElements);
@@ -197,7 +197,7 @@ public class SingleBlockSelector extends PagedSelector
return new PanelItemBuilder().
name(this.user.getTranslation(reference + "name", "[material]",
Utils.prettifyObject(material, this.user))).
- icon(GuiUtils.getMaterialItem(material)).
+ icon(PanelUtils.getMaterialItem(material)).
description(description).
clickHandler((panel, user1, clickType, slot) -> {
this.consumer.accept(true, material);
diff --git a/src/main/java/world/bentobox/challenges/panel/util/SingleEntitySelector.java b/src/main/java/world/bentobox/challenges/panel/util/SingleEntitySelector.java
index 06c2667..b0219aa 100644
--- a/src/main/java/world/bentobox/challenges/panel/util/SingleEntitySelector.java
+++ b/src/main/java/world/bentobox/challenges/panel/util/SingleEntitySelector.java
@@ -9,12 +9,12 @@ import org.bukkit.Material;
import org.bukkit.entity.EntityType;
import org.bukkit.inventory.ItemStack;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
import world.bentobox.bentobox.api.user.User;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -107,7 +107,7 @@ public class SingleEntitySelector extends PagedSelector
PanelBuilder panelBuilder = new PanelBuilder().user(this.user);
panelBuilder.name(this.user.getTranslation(Constants.TITLE + "entity-selector"));
- GuiUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
+ PanelUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
this.populateElements(panelBuilder, this.filterElements);
@@ -159,7 +159,7 @@ public class SingleEntitySelector extends PagedSelector
return new PanelItemBuilder().
name(this.user.getTranslation(reference + "name", "[entity]",
Utils.prettifyObject(entity, this.user))).
- icon(this.asEggs ? GuiUtils.getEntityEgg(entity) : GuiUtils.getEntityHead(entity)).
+ icon(this.asEggs ? PanelUtils.getEntityEgg(entity) : PanelUtils.getEntityHead(entity)).
description(description).
clickHandler((panel, user1, clickType, slot) -> {
this.consumer.accept(true, entity);
diff --git a/src/main/java/world/bentobox/challenges/panel/util/StatisticSelector.java b/src/main/java/world/bentobox/challenges/panel/util/StatisticSelector.java
index afabe65..f6d2aed 100644
--- a/src/main/java/world/bentobox/challenges/panel/util/StatisticSelector.java
+++ b/src/main/java/world/bentobox/challenges/panel/util/StatisticSelector.java
@@ -3,19 +3,17 @@ package world.bentobox.challenges.panel.util;
import org.bukkit.Material;
import org.bukkit.Statistic;
-import org.bukkit.entity.EntityType;
import org.bukkit.inventory.ItemStack;
import java.util.*;
import java.util.function.BiConsumer;
-import java.util.function.Consumer;
import java.util.stream.Collectors;
+import lv.id.bonne.panelutils.PanelUtils;
import world.bentobox.bentobox.api.panels.PanelItem;
import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
import world.bentobox.bentobox.api.user.User;
import world.bentobox.challenges.utils.Constants;
-import world.bentobox.challenges.utils.GuiUtils;
import world.bentobox.challenges.utils.Utils;
@@ -70,7 +68,7 @@ public class StatisticSelector extends PagedSelector
PanelBuilder panelBuilder = new PanelBuilder().user(this.user);
panelBuilder.name(this.user.getTranslation(Constants.TITLE + "statistic-selector"));
- GuiUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
+ PanelUtils.fillBorder(panelBuilder, Material.BLUE_STAINED_GLASS_PANE);
this.populateElements(panelBuilder, this.filterElements);
diff --git a/src/main/java/world/bentobox/challenges/utils/GuiUtils.java b/src/main/java/world/bentobox/challenges/utils/GuiUtils.java
deleted file mode 100644
index 129bc21..0000000
--- a/src/main/java/world/bentobox/challenges/utils/GuiUtils.java
+++ /dev/null
@@ -1,414 +0,0 @@
-package world.bentobox.challenges.utils;
-
-
-import java.util.*;
-
-import org.bukkit.Material;
-import org.bukkit.entity.EntityType;
-import org.bukkit.inventory.ItemStack;
-
-import world.bentobox.bentobox.api.panels.PanelItem;
-import world.bentobox.bentobox.api.panels.builders.PanelBuilder;
-import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
-
-
-/**
- * This class contains static methods that is used through multiple GUIs.
- */
-public class GuiUtils
-{
-// ---------------------------------------------------------------------
-// Section: Border around GUIs
-// ---------------------------------------------------------------------
-
-
- /**
- * This method creates border of black panes around given panel with 5 rows.
- * @param panelBuilder PanelBuilder which must be filled with border blocks.
- */
- public static void fillBorder(PanelBuilder panelBuilder)
- {
- GuiUtils.fillBorder(panelBuilder, 5, Material.BLACK_STAINED_GLASS_PANE);
- }
-
-
- /**
- * This method sets black stained glass pane around Panel with given row count.
- * @param panelBuilder object that builds Panel.
- * @param rowCount in Panel.
- */
- public static void fillBorder(PanelBuilder panelBuilder, int rowCount)
- {
- GuiUtils.fillBorder(panelBuilder, rowCount, Material.BLACK_STAINED_GLASS_PANE);
- }
-
-
- /**
- * This method sets blocks with given Material around Panel with 5 rows.
- * @param panelBuilder object that builds Panel.
- * @param material that will be around Panel.
- */
- public static void fillBorder(PanelBuilder panelBuilder, Material material)
- {
- GuiUtils.fillBorder(panelBuilder, 5, material);
- }
-
-
- /**
- * This method sets blocks with given Material around Panel with given row count.
- * @param panelBuilder object that builds Panel.
- * @param rowCount in Panel.
- * @param material that will be around Panel.
- */
- public static void fillBorder(PanelBuilder panelBuilder, int rowCount, Material material)
- {
- // Only for useful filling.
- if (rowCount < 3)
- {
- return;
- }
-
- for (int i = 0; i < 9 * rowCount; i++)
- {
- // First (i < 9) and last (i > 35) rows must be filled
- // First column (i % 9 == 0) and last column (i % 9 == 8) also must be filled.
-
- if (i < 9 || i > 9 * (rowCount - 1) || i % 9 == 0 || i % 9 == 8)
- {
- panelBuilder.item(i, BorderBlock.getPanelBorder(material));
- }
- }
- }
-
-
-// ---------------------------------------------------------------------
-// Section: ItemStack transformations
-// ---------------------------------------------------------------------
-
- /**
- * This method transforms entity into egg or block that corresponds given entity.
- * If entity egg is not found, then it is replaced by block that represents entity or
- * barrier block.
- * @param entity Entity which egg must be returned.
- * @return ItemStack that may be egg for given entity.
- */
- public static ItemStack getEntityEgg(EntityType entity)
- {
- return GuiUtils.getEntityEgg(entity, 1);
- }
-
-
- /**
- * This method transforms entity into egg or block that corresponds given entity.
- * If entity egg is not found, then it is replaced by block that represents entity or
- * barrier block.
- * @param entity Entity which egg must be returned.
- * @param amount Amount of ItemStack elements.
- * @return ItemStack that may be egg for given entity.
- */
- public static ItemStack getEntityEgg(EntityType entity, int amount)
- {
- ItemStack itemStack;
-
- switch (entity)
- {
- case ENDER_DRAGON:
- itemStack = new ItemStack(Material.DRAGON_EGG);
- break;
- case WITHER:
- itemStack = new ItemStack(Material.SOUL_SAND);
- break;
- case PLAYER:
- itemStack = new ItemStack(Material.PLAYER_HEAD);
- break;
- case MUSHROOM_COW:
- itemStack = new ItemStack(Material.MOOSHROOM_SPAWN_EGG);
- break;
- case SNOWMAN:
- itemStack = new ItemStack(Material.CARVED_PUMPKIN);
- break;
- case IRON_GOLEM:
- itemStack = new ItemStack(Material.IRON_BLOCK);
- break;
- case ARMOR_STAND:
- itemStack = new ItemStack(Material.ARMOR_STAND);
- break;
- default:
- Material material = Material.getMaterial(entity.name() + "_SPAWN_EGG");
-
- if (material == null)
- {
- itemStack = new ItemStack(Material.BARRIER);
- }
- else
- {
- itemStack = new ItemStack(material);
- }
-
- break;
- }
-
- if (entity.name().equals("PIG_ZOMBIE"))
- {
- // If pig zombie exist, then pigman spawn egg exists too.
- itemStack = new ItemStack(Material.getMaterial("ZOMBIE_PIGMAN_SPAWN_EGG"));
- }
-
- itemStack.setAmount(amount);
-
- return itemStack;
- }
-
-
- /**
- * This method transforms entity into player head with skin that corresponds given
- * entity. If entity head is not found, then it is replaced by barrier block.
- * @param entity Entity which head must be returned.
- * @return ItemStack that may be head for given entity.
- */
- public static ItemStack getEntityHead(EntityType entity)
- {
- return GuiUtils.getEntityHead(entity, 1);
- }
-
-
- /**
- * This method transforms entity into player head with skin that corresponds given
- * entity. If entity head is not found, then it is replaced by barrier block.
- * @param entity Entity which head must be returned.
- * @param amount Amount of ItemStack elements.
- * @return ItemStack that may be head for given entity.
- */
- public static ItemStack getEntityHead(EntityType entity, int amount)
- {
- ItemStack itemStack;
-
- switch (entity)
- {
- case PLAYER:
- itemStack = new ItemStack(Material.PLAYER_HEAD);
- break;
- case WITHER_SKELETON:
- itemStack = new ItemStack(Material.WITHER_SKELETON_SKULL);
- break;
- case ARMOR_STAND:
- itemStack = new ItemStack(Material.ARMOR_STAND);
- break;
- case SKELETON:
- itemStack = new ItemStack(Material.SKELETON_SKULL);
- break;
- case GIANT:
- case ZOMBIE:
- itemStack = new ItemStack(Material.ZOMBIE_HEAD);
- break;
- case CREEPER:
- itemStack = new ItemStack(Material.CREEPER_HEAD);
- break;
- case ENDER_DRAGON:
- itemStack = new ItemStack(Material.DRAGON_HEAD);
- break;
- default:
- HeadLib head = HeadLib.getHead(entity.name());
-
- if (head == null)
- {
- itemStack = new ItemStack(Material.BARRIER);
- }
- else
- {
- itemStack = head.toItemStack();
- }
- break;
- }
-
- itemStack.setAmount(amount);
-
- return itemStack;
- }
-
-
- /**
- * This method transforms material into item stack that can be displayed in users
- * inventory.
- * @param material Material which item stack must be returned.
- * @return ItemStack that represents given material.
- */
- public static ItemStack getMaterialItem(Material material)
- {
- return GuiUtils.getMaterialItem(material, 1);
- }
-
-
- /**
- * This method transforms material into item stack that can be displayed in users
- * inventory.
- * @param material Material which item stack must be returned.
- * @param amount Amount of ItemStack elements.
- * @return ItemStack that represents given material.
- */
- public static ItemStack getMaterialItem(Material material, int amount)
- {
- ItemStack itemStack;
-
- // Process items that cannot be item-stacks.
- if (material.name().contains("WALL_"))
- {
- // Materials that is attached to wall cannot be showed in GUI. But they should be in list.
-
- Material newMaterial = Material.getMaterial(material.name().replace("WALL_", ""));
- itemStack = new ItemStack(Objects.requireNonNullElse(newMaterial, material));
- }
- else if (material.equals(Material.POTTED_AZALEA_BUSH))
- {
- return new ItemStack(Material.AZALEA);
- }
- else if (material.equals(Material.POTTED_FLOWERING_AZALEA_BUSH))
- {
- return new ItemStack(Material.FLOWERING_AZALEA);
- }
- else if (material.name().startsWith("POTTED_"))
- {
- // Materials Potted elements cannot be in inventory.
- Material newMaterial = Material.getMaterial(material.name().replace("POTTED_", ""));
- itemStack = new ItemStack(Objects.requireNonNullElse(newMaterial, material));
- }
- else if (material.name().endsWith("CAULDRON"))
- {
- itemStack = new ItemStack(Material.CAULDRON);
- }
- else if (material.equals(Material.MELON_STEM) || material.equals(Material.ATTACHED_MELON_STEM))
- {
- itemStack = new ItemStack(Material.MELON_SEEDS);
- }
- else if (material.equals(Material.PUMPKIN_STEM) || material.equals(Material.ATTACHED_PUMPKIN_STEM))
- {
- itemStack = new ItemStack(Material.PUMPKIN_SEEDS);
- }
- else if (material.equals(Material.TALL_SEAGRASS))
- {
- itemStack = new ItemStack(Material.SEAGRASS);
- }
- else if (material.equals(Material.CARROTS))
- {
- itemStack = new ItemStack(Material.CARROT);
- }
- else if (material.equals(Material.BEETROOTS))
- {
- itemStack = new ItemStack(Material.BEETROOT);
- }
- else if (material.equals(Material.POTATOES))
- {
- itemStack = new ItemStack(Material.POTATO);
- }
- else if (material.equals(Material.COCOA))
- {
- itemStack = new ItemStack(Material.COCOA_BEANS);
- }
- else if (material.equals(Material.CAVE_VINES) || material.equals(Material.CAVE_VINES_PLANT))
- {
- // Process cave vines as they are glow berries
- itemStack = new ItemStack(Material.GLOW_BERRIES);
- }
- else if (material.name().endsWith("_PLANT"))
- {
- // Plants cannot be displayed in GUI's.
- Material newMaterial = Material.getMaterial(material.name().replace("_PLANT", ""));
- itemStack = new ItemStack(Objects.requireNonNullElse(newMaterial, material));
- }
- else if (material.equals(Material.REDSTONE_WIRE))
- {
- itemStack = new ItemStack(Material.REDSTONE);
- }
- else if (material.equals(Material.TRIPWIRE))
- {
- itemStack = new ItemStack(Material.STRING);
- }
- else if (material.equals(Material.FROSTED_ICE))
- {
- itemStack = new ItemStack(Material.ICE);
- }
- else if (material.equals(Material.END_PORTAL) || material.equals(Material.END_GATEWAY) || material.equals(Material.NETHER_PORTAL))
- {
- itemStack = new ItemStack(Material.PAPER);
- }
- else if (material.equals(Material.BUBBLE_COLUMN) || material.equals(Material.WATER))
- {
- itemStack = new ItemStack(Material.WATER_BUCKET);
- }
- else if (material.equals(Material.LAVA))
- {
- itemStack = new ItemStack(Material.LAVA_BUCKET);
- }
- else if (material.equals(Material.FIRE))
- {
- itemStack = new ItemStack(Material.FIRE_CHARGE);
- }
- else if (material.equals(Material.AIR) || material.equals(Material.CAVE_AIR) || material.equals(Material.VOID_AIR))
- {
- itemStack = new ItemStack(Material.GLASS_BOTTLE);
- }
- else if (material.equals(Material.PISTON_HEAD) || material.equals(Material.MOVING_PISTON))
- {
- itemStack = new ItemStack(Material.PISTON);
- }
- else if (material.equals(Material.BAMBOO_SAPLING))
- {
- itemStack = new ItemStack(Material.BAMBOO);
- }
- else if (material.equals(Material.SWEET_BERRY_BUSH))
- {
- itemStack = new ItemStack(Material.SWEET_BERRIES);
- }
- else if (material.name().contains("CANDLE_CAKE"))
- {
- itemStack = new ItemStack(Material.CAKE);
- }
- else if (material.equals(Material.POWDER_SNOW))
- {
- itemStack = new ItemStack(Material.POWDER_SNOW_BUCKET);
- }
- else if (material.equals(Material.BIG_DRIPLEAF_STEM))
- {
- itemStack = new ItemStack(Material.BIG_DRIPLEAF);
- }
- else
- {
- itemStack = new ItemStack(material);
- }
-
- itemStack.setAmount(amount);
-
- return itemStack;
- }
-
-
- /**
- * This BorderBlock is simple PanelItem but without item meta data.
- */
- private static class BorderBlock extends PanelItem
- {
- private BorderBlock(ItemStack icon)
- {
- super(new PanelItemBuilder().
- icon(icon.clone()).
- name(" ").
- description(Collections.emptyList()).
- glow(false).
- clickHandler(null));
- }
-
-
- /**
- * This method retunrs BorderBlock with requested item stack.
- * @param material of which broder must be created.
- * @return PanelItem that acts like border.
- */
- private static BorderBlock getPanelBorder(Material material)
- {
- ItemStack itemStack = new ItemStack(material);
- itemStack.getItemMeta().setDisplayName("&r&8");
-
- return new BorderBlock(itemStack);
- }
- }
-}
\ No newline at end of file
diff --git a/src/main/java/world/bentobox/challenges/utils/HeadLib.java b/src/main/java/world/bentobox/challenges/utils/HeadLib.java
deleted file mode 100644
index afd442d..0000000
--- a/src/main/java/world/bentobox/challenges/utils/HeadLib.java
+++ /dev/null
@@ -1,289 +0,0 @@
-/*
- * Written in 2018 by Daniel Saukel
- *
- * To the extent possible under law, the author(s) have dedicated all
- * copyright and related and neighboring rights to this software
- * to the public domain worldwide.
- *
- * This software is distributed without any warranty.
- *
- * You should have received a copy of the CC0 Public Domain Dedication
- * along with this software. If not, see .
- *
- * @url https://github.com/DRE2N/HeadLib
- */
-package world.bentobox.challenges.utils;
-
-
-import java.lang.reflect.Field;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.UUID;
-
-import org.bukkit.ChatColor;
-import org.bukkit.Material;
-import org.bukkit.inventory.ItemStack;
-import org.bukkit.inventory.meta.ItemMeta;
-
-import com.mojang.authlib.GameProfile;
-import com.mojang.authlib.properties.Property;
-
-import world.bentobox.bentobox.BentoBox;
-
-
-/**
- * @author Daniel Saukel
- *
- * BONNe modified it for BentoBox by leaving only mob heads and removing unused code.
- */
-public enum HeadLib
-{
-// ---------------------------------------------------------------------
-// Section: Library of All Mob heads
-// ---------------------------------------------------------------------
-
- /**
- * All enum values.
- */
- SPIDER("8bdb71d0-4724-48b2-9344-e79480424798", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvY2Q1NDE1NDFkYWFmZjUwODk2Y2QyNThiZGJkZDRjZjgwYzNiYTgxNjczNTcyNjA3OGJmZTM5MzkyN2U1N2YxIn19fQ=="),
- CAVE_SPIDER("39173a7a-c957-4ec1-ac1a-43e5a64983df", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNDE2NDVkZmQ3N2QwOTkyMzEwN2IzNDk2ZTk0ZWViNWMzMDMyOWY5N2VmYzk2ZWQ3NmUyMjZlOTgyMjQifX19"),
- ENDERMAN("0de98464-1274-4dd6-bba8-370efa5d41a8", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvN2E1OWJiMGE3YTMyOTY1YjNkOTBkOGVhZmE4OTlkMTgzNWY0MjQ1MDllYWRkNGU2YjcwOWFkYTUwYjljZiJ9fX0="),
- SLIME("7f0b0873-df6a-4a19-9bcd-f6c90ef804c7", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvODk1YWVlYzZiODQyYWRhODY2OWY4NDZkNjViYzQ5NzYyNTk3ODI0YWI5NDRmMjJmNDViZjNiYmI5NDFhYmU2YyJ9fX0="),
- GUARDIAN("f3898fe0-04fb-4f9c-8f8b-146a1d894007", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYzI1YWY5NjZhMzI2ZjlkOTg0NjZhN2JmODU4MmNhNGRhNjQ1M2RlMjcxYjNiYzllNTlmNTdhOTliNjM1MTFjNiJ9fX0="),
- GHAST("807f287f-6499-4e93-a887-0a298ab3091f", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvOGI2YTcyMTM4ZDY5ZmJiZDJmZWEzZmEyNTFjYWJkODcxNTJlNGYxYzk3ZTVmOTg2YmY2ODU1NzFkYjNjYzAifX19"),
- BLAZE("7ceb88b2-7f5f-4399-abb9-7068251baa9d", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYjc4ZWYyZTRjZjJjNDFhMmQxNGJmZGU5Y2FmZjEwMjE5ZjViMWJmNWIzNWE0OWViNTFjNjQ2Nzg4MmNiNWYwIn19fQ=="),
- MAGMA_CUBE("96aced64-5b85-4b99-b825-53cd7a9f9726", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMzg5NTdkNTAyM2M5MzdjNGM0MWFhMjQxMmQ0MzQxMGJkYTIzY2Y3OWE5ZjZhYjM2Yjc2ZmVmMmQ3YzQyOSJ9fX0="),
- WITHER("119c371b-ea16-47c9-ad7f-23b3d894520a", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvY2RmNzRlMzIzZWQ0MTQzNjk2NWY1YzU3ZGRmMjgxNWQ1MzMyZmU5OTllNjhmYmI5ZDZjZjVjOGJkNDEzOWYifX19"),
- ENDER_DRAGON("433562fa-9e23-443e-93b0-d67228435e77", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNzRlY2MwNDA3ODVlNTQ2NjNlODU1ZWYwNDg2ZGE3MjE1NGQ2OWJiNGI3NDI0YjczODFjY2Y5NWIwOTVhIn19fQ=="),
- SHULKER("d700b0b9-be74-4630-8cb5-62c979828ef6", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYjFkMzUzNGQyMWZlODQ5OTI2MmRlODdhZmZiZWFjNGQyNWZmZGUzNWM4YmRjYTA2OWU2MWUxNzg3ZmYyZiJ9fX0="),
- CREEPER("eed2d903-ca32-4cc7-b33b-ca3bdbe18da4", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvZjQyNTQ4MzhjMzNlYTIyN2ZmY2EyMjNkZGRhYWJmZTBiMDIxNWY3MGRhNjQ5ZTk0NDQ3N2Y0NDM3MGNhNjk1MiJ9fX0="),
- ZOMBIE("9959dd98-efb3-4ee9-a8fb-2fda0218cda0", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNTZmYzg1NGJiODRjZjRiNzY5NzI5Nzk3M2UwMmI3OWJjMTA2OTg0NjBiNTFhNjM5YzYwZTVlNDE3NzM0ZTExIn19fQ=="),
- ZOMBIE_VILLAGER("bcaf2b85-d421-47cc-a40a-455e77bfb60b", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMzdlODM4Y2NjMjY3NzZhMjE3YzY3ODM4NmY2YTY1NzkxZmU4Y2RhYjhjZTljYTRhYzZiMjgzOTdhNGQ4MWMyMiJ9fX0="),
- ZOMBIE_PIGMAN("6540c046-d6ea-4aff-9766-32a54ebe6958", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNzRlOWM2ZTk4NTgyZmZkOGZmOGZlYjMzMjJjZDE4NDljNDNmYjE2YjE1OGFiYjExY2E3YjQyZWRhNzc0M2ViIn19fQ=="),
- DOG("9655594c-5b1c-48a5-8e12-ffd7e0c735f2", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNDk1MTgzY2E0Y2RkMjk2MjhmZTZjNzIyZjc3OTA4N2I4M2MyMWJhOTdmNDIyNWU0YWQ5YjNlNjE4ZWNjZDMwIn19fQ=="),
- HORSE("c6abc94e-a5ff-45fe-a0d7-4e479f290a6f", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNDJlYjk2N2FiOTRmZGQ0MWE2MzI1ZjEyNzdkNmRjMDE5MjI2ZTVjZjM0OTc3ZWVlNjk1OTdmYWZjZjVlIn19fQ=="),
- TURTLE("ef56c7a3-a5e7-4a7f-9786-a4b6273a591d", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMTJlNTQ4NDA4YWI3NWQ3ZGY4ZTZkNWQyNDQ2ZDkwYjZlYzYyYWE0ZjdmZWI3OTMwZDFlZTcxZWVmZGRmNjE4OSJ9fX0="),
- OCELOT("664dd492-3fcd-443b-9e61-4c7ebd9e4e10", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNTY1N2NkNWMyOTg5ZmY5NzU3MGZlYzRkZGNkYzY5MjZhNjhhMzM5MzI1MGMxYmUxZjBiMTE0YTFkYjEifX19"),
- SHEEP("fa234925-9dbe-4b8f-a544-7c70fb6b6ac5", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvZjMxZjljY2M2YjNlMzJlY2YxM2I4YTExYWMyOWNkMzNkMThjOTVmYzczZGI4YTY2YzVkNjU3Y2NiOGJlNzAifX19"),
- COW("97ddf3b3-9dbe-4a3b-8a0f-1b19ddeac0bd", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNWQ2YzZlZGE5NDJmN2Y1ZjcxYzMxNjFjNzMwNmY0YWVkMzA3ZDgyODk1ZjlkMmIwN2FiNDUyNTcxOGVkYzUifX19"),
- CHICKEN("7d3a8ace-e045-4eba-ab71-71dbf525daf1", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMTYzODQ2OWE1OTljZWVmNzIwNzUzNzYwMzI0OGE5YWIxMWZmNTkxZmQzNzhiZWE0NzM1YjM0NmE3ZmFlODkzIn19fQ=="),
- PIG("e1e1c2e4-1ed2-473d-bde2-3ec718535399", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNjIxNjY4ZWY3Y2I3OWRkOWMyMmNlM2QxZjNmNGNiNmUyNTU5ODkzYjZkZjRhNDY5NTE0ZTY2N2MxNmFhNCJ9fX0="),
- SQUID("f95d9504-ea2b-4b89-b2d0-d400654a7010", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMDE0MzNiZTI0MjM2NmFmMTI2ZGE0MzRiODczNWRmMWViNWIzY2IyY2VkZTM5MTQ1OTc0ZTljNDgzNjA3YmFjIn19fQ=="),
- MUSHROOM_COW("e206ac29-ae69-475b-909a-fb523d894336", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvZDBiYzYxYjk3NTdhN2I4M2UwM2NkMjUwN2EyMTU3OTEzYzJjZjAxNmU3YzA5NmE0ZDZjZjFmZTFiOGRiIn19fQ=="),
- ELDER_GUARDIAN("f2e933a7-614f-44e0-bf18-289b102104ab", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMWM3OTc0ODJhMTRiZmNiODc3MjU3Y2IyY2ZmMWI2ZTZhOGI4NDEzMzM2ZmZiNGMyOWE2MTM5Mjc4YjQzNmIifX19"),
- STRAY("644c9bad-958b-43ce-9d2f-199d85be607c", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNzhkZGY3NmU1NTVkZDVjNGFhOGEwYTVmYzU4NDUyMGNkNjNkNDg5YzI1M2RlOTY5ZjdmMjJmODVhOWEyZDU2In19fQ=="),
- HUSK("2e387bc6-774b-4fda-ba22-eb54a26dfd9e", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNzc3MDY4MWQxYTI1NWZiNGY3NTQ3OTNhYTA1NWIyMjA0NDFjZGFiOWUxMTQxZGZhNTIzN2I0OTkzMWQ5YjkxYyJ9fX0="),
- SKELETON_HORSE("bcbce5bf-86c4-4e62-9fc5-0cc90de94b6d", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNDdlZmZjZTM1MTMyYzg2ZmY3MmJjYWU3N2RmYmIxZDIyNTg3ZTk0ZGYzY2JjMjU3MGVkMTdjZjg5NzNhIn19fQ=="),
- ZOMBIE_HORSE("506ced1a-dac8-4d84-b341-645fbb297335", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvY2Q2YjllZjhkZDEwYmE2NDE0MjJiNDQ5ZWQxNWFkYzI5MmQ3M2Y1NzI5ODRkNDdlMjhhMjI2YWE2ZWRkODcifX19"),
- DONKEY("3da7917b-cb95-40b3-a516-9befa4f4d71d", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYjEyNTJjMjI1MGM0NjhkOWZkZTUzODY3Nzg1NWJjOWYyODQzM2RmNjkyNDdkNzEzODY4NzgxYjgyZDE0YjU1In19fQ=="),
- MULE("fac6815e-02d5-4776-a5d6-f6d6535b7831", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNzY5Y2E0YzI5NTZhNTY3Yzk2ZWUwNGM1MzE0OWYxODY0NjIxODM5M2JjN2IyMWVkNDVmZGFhMTNiZWJjZGFkIn19fQ=="),
- EVOKER("36ee7e5b-c092-48ad-9673-2a73b0a44b4f", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYTAwZDNmZmYxNmMyZGNhNTliOWM1OGYwOTY1MjVjODY5NzExNjZkYmFlMTMzYjFiMDUwZTVlZTcxNjQ0MyJ9fX0="),
- VEX("f83bcfc1-0213-4957-888e-d3e2fae71203", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNWU3MzMwYzdkNWNkOGEwYTU1YWI5ZTk1MzIxNTM1YWM3YWUzMGZlODM3YzM3ZWE5ZTUzYmVhN2JhMmRlODZiIn19fQ=="),
- VINDICATOR("5f958e1c-91ea-42d3-9d26-09e5925f2d9c", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvN2RhNTg1ZWJkZGNjNDhmMzA3YmU2YTgzOTE2Zjg3OGVkNGEwMTRlYzNkNGYyODZhMmNmZDk1MzI4MTk2OSJ9fX0="),
- ILLUSIONER("ccb79aa9-1764-4e5b-8ff3-e7be661ac7e2", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNjYxNWUxMjQ1ZDBkODJkODFkZmEzNzUzMDYzZDhhYWQwZmE2NjU3NTk5ODcxY2Y0YzY5YmFiNzNjNjk5MDU1In19fQ=="),
- PIG_ZOMBIE("6540c046-d6ea-4aff-9766-32a54ebe6958", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNzRlOWM2ZTk4NTgyZmZkOGZmOGZlYjMzMjJjZDE4NDljNDNmYjE2YjE1OGFiYjExY2E3YjQyZWRhNzc0M2ViIn19fQ=="),
- SILVERFISH("30a4cd5c-5754-4db8-8960-18022a74627d", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvZGE5MWRhYjgzOTFhZjVmZGE1NGFjZDJjMGIxOGZiZDgxOWI4NjVlMWE4ZjFkNjIzODEzZmE3NjFlOTI0NTQwIn19fQ=="),
- BAT("cfdaf903-18cf-4a92-acf2-efa8626cf0b2", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvOWU5OWRlZWY5MTlkYjY2YWMyYmQyOGQ2MzAyNzU2Y2NkNTdjN2Y4YjEyYjlkY2E4ZjQxYzNlMGEwNGFjMWNjIn19fQ=="),
- WITCH("7f92b3d6-5ee0-4ab6-afae-2206b9514a63", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMjBlMTNkMTg0NzRmYzk0ZWQ1NWFlYjcwNjk1NjZlNDY4N2Q3NzNkYWMxNmY0YzNmODcyMmZjOTViZjlmMmRmYSJ9fX0="),
- ENDERMITE("33c425bb-a294-4e01-9b5b-a8ad652bb5cf", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvODRhYWZmYTRjMDllMmVhZmI4NWQzNTIyMTIyZGIwYWE0NTg3NGJlYTRlM2Y1ZTc1NjZiNGQxNjZjN2RmOCJ9fX0="),
- WOLF("4aabc2be-340a-46ad-a42b-0c348344750a", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvZDdhZGU0OWY1MDEzMTExNTExZGM1MWJhYjc2OWMxYWQ2OTUzMTlhNWQzNTViMzZhZTkyMzRlYTlkMWZmOGUifX19"),
- SNOWMAN("d71e165b-b49d-4180-9ccf-8ad3084df1dc", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMTdlOTgzMWRhZjY4MWY4YzRjNDc3NWNiNDY1M2MzNGJlMjg5OGY4N2VmZDNiNTk4ZDU1NTUxOGYyZmFjNiJ9fX0="),
- IRON_GOLEM("7cb6e9a5-994f-40d5-9bfc-4ba5d796d21e", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvODkwOTFkNzllYTBmNTllZjdlZjk0ZDdiYmE2ZTVmMTdmMmY3ZDQ1NzJjNDRmOTBmNzZjNDgxOWE3MTQifX19"),
- RABBIT("2186bdc6-55b1-4b44-8a46-3c8a11d40f3d", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvN2QxMTY5YjI2OTRhNmFiYTgyNjM2MDk5MjM2NWJjZGE1YTEwYzg5YTNhYTJiNDhjNDM4NTMxZGQ4Njg1YzNhNyJ9fX0="),
- POLAR_BEAR("87324464-1700-468f-8333-e7779ec8c21e", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvZDQ2ZDIzZjA0ODQ2MzY5ZmEyYTM3MDJjMTBmNzU5MTAxYWY3YmZlODQxOTk2NjQyOTUzM2NkODFhMTFkMmIifX19"),
- LLAMA("75fb08e5-2419-46fa-bf09-57362138f234", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYzJiMWVjZmY3N2ZmZTNiNTAzYzMwYTU0OGViMjNhMWEwOGZhMjZmZDY3Y2RmZjM4OTg1NWQ3NDkyMTM2OCJ9fX0="),
- PARROT("da0cac14-3763-45df-b884-c99a567882ac", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNTZkZTFlYjllMzI1ZTYyZjI4ZjJjMTgzZDM5YTY4MzExMzY0NDYzNjU3MjY0Njc1YThiNDYxY2QyOGM5In19fQ=="),
- VILLAGER("b3ed4a1b-dfff-464c-87c0-c8029e1de47b", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYzZhYjYxYWNlMTM2MDE3YTg3YjFiODFiMTQ1ZWJjNjNlMmU2ZGE5ZDM2NGM4MTE5NGIzM2VlODY2ZmU0ZCJ9fX0="),
- PHANTOM("9290add8-c291-4a5a-8f8a-594f165406a3", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvN2U5NTE1M2VjMjMyODRiMjgzZjAwZDE5ZDI5NzU2ZjI0NDMxM2EwNjFiNzBhYzAzYjk3ZDIzNmVlNTdiZDk4MiJ9fX0="),
- COD("d6d4c744-06b4-4a8a-bc7a-bdb0770bb1cf", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNzg5MmQ3ZGQ2YWFkZjM1Zjg2ZGEyN2ZiNjNkYTRlZGRhMjExZGY5NmQyODI5ZjY5MTQ2MmE0ZmIxY2FiMCJ9fX0="),
- SALMON("0354c430-3979-4b6e-8e65-a99eb3ea8818", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvOGFlYjIxYTI1ZTQ2ODA2Y2U4NTM3ZmJkNjY2ODI4MWNmMTc2Y2VhZmU5NWFmOTBlOTRhNWZkODQ5MjQ4NzgifX19"),
- PUFFERFISH("258e3114-368c-48a1-85fd-be580912f0df", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMTcxNTI4NzZiYzNhOTZkZDJhMjI5OTI0NWVkYjNiZWVmNjQ3YzhhNTZhYzg4NTNhNjg3YzNlN2I1ZDhiYiJ9fX0="),
- TROPICAL_FISH("d93c1bf6-616f-401a-af6e-f9b9803a0024", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMTc5ZTQ4ZDgxNGFhM2JjOTg0ZThhNmZkNGZiMTcwYmEwYmI0ODkzZjRiYmViZGU1ZmRmM2Y4Zjg3MWNiMjkyZiJ9fX0="),
- DROWNED("2f169660-61be-46bd-acb5-1abef9fe5731", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYzNmN2NjZjYxZGJjM2Y5ZmU5YTYzMzNjZGUwYzBlMTQzOTllYjJlZWE3MWQzNGNmMjIzYjNhY2UyMjA1MSJ9fX0="),
- DOLPHIN("8b7ccd6d-36de-47e0-8d5a-6f6799c6feb8", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvOGU5Njg4Yjk1MGQ4ODBiNTViN2FhMmNmY2Q3NmU1YTBmYTk0YWFjNmQxNmY3OGU4MzNmNzQ0M2VhMjlmZWQzIn19fQ=="),
- // Since 1.14
- CAT("f0aaa05b-0283-4663-9b57-52dbf2ca2750", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYTBkYjQxMzc2Y2E1N2RmMTBmY2IxNTM5ZTg2NjU0ZWVjZmQzNmQzZmU3NWU4MTc2ODg1ZTkzMTg1ZGYyODBhNSJ9fX0="),
- FOX("237a2651-7da8-457a-aaea-3714bcc196a2", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvZDg5NTRhNDJlNjllMDg4MWFlNmQyNGQ0MjgxNDU5YzE0NGEwZDVhOTY4YWVkMzVkNmQzZDczYTNjNjVkMjZhIn19fQ=="),
- PANDA("bf7435c9-b7eb-49e9-8887-60697f8081b9", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvZGNhMDk2ZWVhNTA2MzAxYmVhNmQ0YjE3ZWUxNjA1NjI1YTZmNTA4MmM3MWY3NGE2MzljYzk0MDQzOWY0NzE2NiJ9fX0="),
- PILLAGER("1ac9d5aa-46ef-4d71-b077-4564382c0a43", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNGFlZTZiYjM3Y2JmYzkyYjBkODZkYjVhZGE0NzkwYzY0ZmY0NDY4ZDY4Yjg0OTQyZmRlMDQ0MDVlOGVmNTMzMyJ9fX0="),
- RAVAGER("def81bd7-85e5-4644-b1b2-e7521e53bba8", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMWNiOWYxMzlmOTQ4OWQ4NmU0MTBhMDZkOGNiYzY3MGM4MDI4MTM3NTA4ZTNlNGJlZjYxMmZlMzJlZGQ2MDE5MyJ9fX0="),
- TRADER_LLAMA("47dbdab5-105f-42bc-9580-c61cee9231f3", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNzA4N2E1NTZkNGZmYTk1ZWNkMjg0NGYzNTBkYzQzZTI1NGU1ZDUzNWZhNTk2ZjU0MGQ3ZTc3ZmE2N2RmNDY5NiJ9fX0="),
- WANDERING_TRADER("943947ea-3e1a-4fdc-85e5-f538379f05e9", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNWYxMzc5YTgyMjkwZDdhYmUxZWZhYWJiYzcwNzEwZmYyZWMwMmRkMzRhZGUzODZiYzAwYzkzMGM0NjFjZjkzMiJ9fX0="),
- // Since 1.15
- BEE("77342662-8870-445a-869f-f0aef1406b3d", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNTlhYzE2ZjI5NmI0NjFkMDVlYTA3ODVkNDc3MDMzZTUyNzM1OGI0ZjMwYzI2NmFhMDJmMDIwMTU3ZmZjYTczNiJ9fX0="),
- // Since 1.16
- PIGLIN("7b3f9b15-325b-4d6e-a184-0455e233a1cc", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvY2NlZDlkODAxYWE2ZjgzZjhlNDlmOTBkOWE4Yjg1YjdmOGZkYTU4M2Q4NWY3MmNmZmI2OTg2NzI1Nzg5ZjYzNiJ9fX0="),
- ZOMBIFIED_PIGLIN("4f013cfb-84f8-4d80-8529-25127f6c70ee", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvN2VhYmFlY2M1ZmFlNWE4YTQ5Yzg4NjNmZjQ4MzFhYWEyODQxOThmMWEyMzk4ODkwYzc2NWUwYThkZTE4ZGE4YyJ9fX0="),
- STRIDER("d1c2fba9-6633-4625-9cda-8528fae6fe09", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvMThhOWFkZjc4MGVjN2RkNDYyNWM5YzA3NzkwNTJlNmExNWE0NTE4NjY2MjM1MTFlNGM4MmU5NjU1NzE0YjNjMSJ9fX0="),
- HOGLIN("8196c240-e96a-4434-b630-6b191ceeb480", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvOWJiOWJjMGYwMWRiZDc2MmEwOGQ5ZTc3YzA4MDY5ZWQ3Yzk1MzY0YWEzMGNhMTA3MjIwODU2MWI3MzBlOGQ3NSJ9fX0="),
- ZOGLIN("d6f4e7ce-dc71-4c81-97dc-df0d15d39a68", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNWZhMGFkYTM0MTFmYmE4Yjg4NTgzZDg2NGIyNTI2MDZlOTNkZmRmNjQ3NjkwZDNjZjRjMDE3YjYzYmFiMTJiMCJ9fX0="),
- PIGLIN_BRUTE("bf47747e-757d-3212-9848-880f64274787", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNjQ4ODc5OWM4M2VjYjI5NDUyY2ViYTg5YzNjMDA5OTIxOTI3NGNlNWIyYmZiOGFkMGIzZWE0YzY1ZmFjNDYzMCJ9fX0="),
- // Since 1.17
- AXOLOTL("b9e1cfe8-792a-3971-855a-7e453c0c22e1", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNjY3ZTE1ZWFiNzMwNjRiNjY4MGQxZGI5OGJhNDQ1ZWQwOTE0YmEzNWE3OTk5OTdjMGRhMmIwM2ZmYzNhODgyNiJ9fX0="),
- GLOW_SQUID("40a2f93f-2954-3bea-91ca-85e48e63fe21", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvNGIyZTliNjU4MWZlZDQ4YTk5ZTAzMjMwOTFhZDVjM2MzMjZjZGEyMDA3M2UyOGE5MDJhMDM3M2Y3MzgyYjU5ZiJ9fX0="),
- GOAT("acbab1c5-e323-3a61-ac37-58d0b2a546d1", "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvODc0NzNlMDU1ZGY2ZTdmZDk4NjY0ZTlmZGI2MzY3NWYwODgxMDYzMDVkNzQ0MDI0YTQxYmIzNTg5MThhMTQyYiJ9fX0=");
-
-// ---------------------------------------------------------------------
-// Section: Variables
-// ---------------------------------------------------------------------
-
- /**
- * User UUID that has given skin.
- */
- private String uuid;
-
- /**
- * Base64 Encoded link to Minecraft texture.
- */
- private String textureValue;
-
- /**
- * Skull owner.
- */
- private Object skullOwner;
-
- /**
- * This map allows to access all enum values via their string.
- */
- private final static Map BY_NAME = new HashMap<>();
-
-
-// ---------------------------------------------------------------------
-// Section: Constructor
-// ---------------------------------------------------------------------
-
-
- /**
- * This inits new enum value by given UUID and textureValue that is encoded in Base64.
- * @param uuid User UUID String which skin must be loaded.
- * @param textureValue Texture link encoded in Base64.
- */
- HeadLib(String uuid, String textureValue)
- {
- this.uuid = uuid;
- this.textureValue = textureValue;
- }
-
-
-// ---------------------------------------------------------------------
-// Section: Methods that returns ItemStacks
-// ---------------------------------------------------------------------
-
- /**
- * Returns an ItemStack of the size 1 of the custom head.
- *
- * @return an ItemStack of the custom head.
- */
- public ItemStack toItemStack()
- {
- return this.toItemStack(1);
- }
-
-
- /**
- * Returns an ItemStack of the custom head.
- *
- * @param amount the amount of items in the stack
- * @return an ItemStack of the custom head.
- */
- public ItemStack toItemStack(int amount)
- {
- return this.toItemStack(amount, null);
- }
-
-
- /**
- * Returns an ItemStack of the size 1 of the custom head.
- *
- * @param displayName the name to display. Supports "&" color codes
- * @param loreLines optional lore lines. Supports "&" color codes
- * @return an ItemStack of the custom head.
- */
- public ItemStack toItemStack(String displayName, String... loreLines)
- {
- return this.toItemStack(1, displayName, loreLines);
- }
-
-
- /**
- * Returns an ItemStack of the custom head.
- *
- * @param amount the amount of items in the stack
- * @param displayName the name to display. Supports "&" color codes
- * @param loreLines optional lore lines. Supports "&" color codes
- * @return an ItemStack of the custom head.
- */
- public ItemStack toItemStack(int amount, String displayName, String... loreLines)
- {
- ItemStack item = new ItemStack(Material.PLAYER_HEAD, amount);
- ItemMeta meta = item.getItemMeta();
-
- // Set Lora and DisplayName
- if (meta != null && displayName != null)
- {
- meta.setDisplayName(ChatColor.translateAlternateColorCodes('&', displayName));
-
- if (loreLines.length != 0)
- {
- List loreCC = new ArrayList<>();
- Arrays.stream(loreLines).forEach(l -> loreCC.add(ChatColor.translateAlternateColorCodes('&', l)));
- meta.setLore(loreCC);
- }
-
- item.setItemMeta(meta);
- }
-
- // Set correct Skull texture
- if (meta != null && this.textureValue != null && !this.textureValue.isEmpty())
- {
- GameProfile profile = new GameProfile(UUID.fromString(this.uuid), null);
- profile.getProperties().put("textures", new Property("textures", this.textureValue));
-
- try
- {
- Field profileField = meta.getClass().getDeclaredField("profile");
- profileField.setAccessible(true);
- profileField.set(meta, profile);
- item.setItemMeta(meta);
- }
- catch (NoSuchFieldException | IllegalArgumentException | IllegalAccessException e)
- {
- BentoBox.getInstance().log("Error while creating Skull Icon");
- }
- }
-
- return item;
- }
-
-
-// ---------------------------------------------------------------------
-// Section: Other methods
-// ---------------------------------------------------------------------
-
-
- /**
- * This method returns HeadLib enum object with given name. If enum value with given name does not exist,
- * then return null.
- * @param name Name of object that must be returned.
- * @return HeadLib with given name or null.
- */
- public static HeadLib getHead(String name)
- {
- return BY_NAME.get(name.toUpperCase());
- }
-
-
- //
- // This static call populates all existing enum values into static map.
- //
- static
- {
- for (HeadLib head : values())
- {
- BY_NAME.put(head.name(), head);
- }
- }
-}
\ No newline at end of file