diff --git a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryAreaInventory.java b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryAreaInventory.java index 1cd3894..329bd28 100644 --- a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryAreaInventory.java +++ b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryAreaInventory.java @@ -88,8 +88,11 @@ public BestiaryAreaInventory(Player player, BestiaryArea area, int offset) { String secondBars = "|".repeat(20 - bars); progressBar = progressBar.append(Component.text(secondBars, NamedTextColor.RED).decoration(TextDecoration.ITALIC, false)); + //No way for discovered mobs to possibly be a non-integer, but safety first + int discInt = (int)Math.floor(discovered); + int totalInt = (int)Math.floor(total); progressBar = progressBar.append(Component.text("]", NamedTextColor.GRAY).decoration(TextDecoration.ITALIC, false)); - progressBar = progressBar.append(Component.text(" " + discovered + "/" + total, NamedTextColor.BLUE).decoration(TextDecoration.ITALIC, false)); + progressBar = progressBar.append(Component.text(" " + discInt + "/" + totalInt, NamedTextColor.BLUE).decoration(TextDecoration.ITALIC, false)); ItemMeta meta = item.getItemMeta(); List lore = meta.hasLore() ? meta.lore() : new ArrayList<>(); if (!lore.contains(progressBar)) { diff --git a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryCommand.java b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryCommand.java index 7381dd3..c956fad 100644 --- a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryCommand.java +++ b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryCommand.java @@ -149,6 +149,13 @@ public static void register() { } soul.setLore("", sender); }))) + .withSubcommand(new CommandAPICommand("deleteall") + .withPermission(CommandPermission.fromString("los.bestiary.deleteall")) + .withArguments(new EntitySelectorArgument.OnePlayer("player")) + .executes((sender, args) -> { + Player player = (Player)args[0]; + BestiaryManager.deleteAll(player); + })) .register(); } diff --git a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryManager.java b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryManager.java index 1f09102..6e3b084 100644 --- a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryManager.java +++ b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiaryManager.java @@ -9,6 +9,7 @@ import java.util.Collection; import java.util.HashSet; import java.util.LinkedHashMap; +import java.util.List; import java.util.Map; import java.util.Objects; import java.util.Set; @@ -104,6 +105,13 @@ public static int addKillsToMob(Player player, SoulEntry soul, int amount) { return INSTANCE.mStorage.addKillsForMob(player, soul, amount); } + public static void deleteAll(Player player) { + List souls = SoulsDatabase.getInstance().getSouls(); + for (SoulEntry soul : souls) { + BestiaryManager.setKillsForMob(player, soul, 0); + } + } + @EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true) public void entityDamageByEntityEvent(EntityDamageByEntityEvent event) { Entity entity = event.getEntity(); diff --git a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiarySoulInventory.java b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiarySoulInventory.java index ddf2146..5e8d388 100644 --- a/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiarySoulInventory.java +++ b/src/main/java/com/playmonumenta/libraryofsouls/bestiary/BestiarySoulInventory.java @@ -538,7 +538,7 @@ public static double getAttributeNumber(ItemStack item, Attribute attribute, Att } } } - return attributeNum; + return Math.round(attributeNum * 1000) / 1000.0; } private static ItemStack getHealthItem(double health) { @@ -710,6 +710,7 @@ private static ItemStack getSpeedItem(EntityNBT entityNBT, double speed, double speed *= speedPercent; } + speed = Math.round(speed * 1000) / 1000.0; lore.add(Component.text(speed + " Speed", NamedTextColor.GREEN).decoration(TextDecoration.ITALIC, false)); speedMeta.lore(lore); speedMeta.displayName(Component.text("Speed", NamedTextColor.WHITE).decoration(TextDecoration.ITALIC, false));