From 33118389d7c18e736e0661385a4a60e46e9ddc96 Mon Sep 17 00:00:00 2001 From: FrozenEarth Date: Wed, 5 Jun 2024 13:01:31 -0500 Subject: [PATCH] add display item in mob entry inventory and get description item command --- .../libraryofsouls/SoulEntry.java | 4 ++- .../bestiary/BestiaryCommand.java | 25 +++++++++++++---- .../bestiary/BestiarySoulInventory.java | 28 +++++++++++++++++++ 3 files changed, 51 insertions(+), 6 deletions(-) diff --git a/src/main/java/com/playmonumenta/libraryofsouls/SoulEntry.java b/src/main/java/com/playmonumenta/libraryofsouls/SoulEntry.java index fff06e1..de1de01 100644 --- a/src/main/java/com/playmonumenta/libraryofsouls/SoulEntry.java +++ b/src/main/java/com/playmonumenta/libraryofsouls/SoulEntry.java @@ -268,7 +268,9 @@ public ItemStack getBestiaryItem(Player player) { lore.add(Component.text(BestiarySoulInventory.formatWell(getId().getKey()), NamedTextColor.GRAY).decoration(TextDecoration.ITALIC, false)); lore.add(Component.text("Kills: " + BestiaryManager.getKillsForMob(player, this), NamedTextColor.DARK_RED).decoration(TextDecoration.ITALIC, false)); if (!mDescription.isEmpty()) { - lore.addAll(getDescription()); + for (Component line : mDescription) { + lore.add(line.color(NamedTextColor.DARK_GRAY)); + } } if (info.allowsAccessTo(InfoTier.STATS)) { lore.add(Component.text("Click for more info!", NamedTextColor.LIGHT_PURPLE).decoration(TextDecoration.ITALIC, false)); diff --git a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryCommand.java b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryCommand.java index e9ed944..b73b81f 100644 --- a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryCommand.java +++ b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryCommand.java @@ -1,7 +1,6 @@ package com.playmonumenta.libraryofsouls.bestiary; import com.playmonumenta.libraryofsouls.LibraryOfSouls; -import com.playmonumenta.libraryofsouls.Soul; import com.playmonumenta.libraryofsouls.SoulEntry; import com.playmonumenta.libraryofsouls.SoulsDatabase; import com.playmonumenta.libraryofsouls.commands.LibraryOfSoulsCommand; @@ -10,17 +9,13 @@ import dev.jorel.commandapi.CommandPermission; import dev.jorel.commandapi.arguments.EntitySelectorArgument; import dev.jorel.commandapi.arguments.IntegerArgument; -import dev.jorel.commandapi.arguments.StringArgument; import dev.jorel.commandapi.arguments.TextArgument; -import java.text.MessageFormat; import java.util.ArrayList; import java.util.List; import net.kyori.adventure.text.Component; import net.kyori.adventure.text.format.NamedTextColor; import net.kyori.adventure.text.format.TextDecoration; -import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer; import org.bukkit.Bukkit; -import org.bukkit.ChatColor; import org.bukkit.Location; import org.bukkit.Material; import org.bukkit.entity.Item; @@ -142,6 +137,26 @@ public static void register() { } } }))) + .withSubcommand(new CommandAPICommand("description") + .withSubcommand(new CommandAPICommand("get") + .withPermission(CommandPermission.fromString("los.bestiary.description")) + .withArguments(LibraryOfSoulsCommand.mobLabelArg) + .executesPlayer((sender, args) -> { + String name = args.getByArgument(LibraryOfSoulsCommand.mobLabelArg); + SoulEntry soul = SoulsDatabase.getInstance().getSoul(name); + if (soul == null) { + throw CommandAPI.failWithString("Mob '" + name + "' not found"); + } else { + ItemStack item = new ItemStack(Material.BLAZE_POWDER); + item.lore(soul.getDescription()); + Location location = sender.getLocation(); + if (!sender.getInventory().addItem(item).isEmpty()) { + Item droppedItem = location.getWorld().dropItem(location, item); + droppedItem.setPickupDelay(0); + droppedItem.setCanMobPickup(false); + } + } + }))) .register(); } diff --git a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiarySoulInventory.java b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiarySoulInventory.java index 750a6de..d2b370b 100644 --- a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiarySoulInventory.java +++ b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiarySoulInventory.java @@ -468,6 +468,7 @@ public BestiarySoulInventory(Player player, SoulEntry soul, BestiaryArea parent, effectItem = getEffectItem(effectItem); ItemStack speedItem = getSpeedItem(entityNBT, speed, speedScalar, speedPercent); + ItemStack descriptionItem = getDescriptionItem(soul); ItemStack loreItem = getLoreItem(soul); ItemStack equipmentPageItem = new ItemStack(Material.LIME_STAINED_GLASS_PANE); ItemMeta meta = equipmentPageItem.getItemMeta(); @@ -477,6 +478,9 @@ public BestiarySoulInventory(Player player, SoulEntry soul, BestiaryArea parent, _inventory.setItem(11, healthItem); _inventory.setItem(13, armorItem); _inventory.setItem(15, damageItem); + if (!soul.getDescription().isEmpty()) { + _inventory.setItem(16, descriptionItem); + } _inventory.setItem(22, equipmentPageItem); if (!soul.getLore().isEmpty()) { _inventory.setItem(29, speedItem); @@ -758,6 +762,30 @@ public ItemStack getLoreItem(SoulEntry soul) { return loreItem; } + public ItemStack getDescriptionItem(SoulEntry soul) { + List description = soul.getDescription(); + ItemStack descriptionItem = new ItemStack(Material.BLAZE_POWDER); + ItemMeta meta = descriptionItem.getItemMeta(); + meta.displayName(Component.text("Description", NamedTextColor.WHITE, TextDecoration.BOLD).decoration(TextDecoration.ITALIC, false)); + + if (description == null || description.isEmpty()) { + List itemDescription = new ArrayList<>(); + itemDescription.add(Component.text("This is a bug. Or at the very least, should be.", NamedTextColor.WHITE).decoration(TextDecoration.ITALIC, true)); + meta.lore(itemDescription); + descriptionItem.setItemMeta(meta); + return descriptionItem; + } + + List itemDescription = new ArrayList<>(); + for (Component comp : description) { + itemDescription.add(comp.color(NamedTextColor.GRAY)); + } + + meta.lore(itemDescription); + descriptionItem.setItemMeta(meta); + return descriptionItem; + } + //Legacy function, will be edited once the new boss tags system is implemented public static List formatTags(String tag) { List ret = new ArrayList<>();