diff --git a/README.md b/README.md index 8abbd29..331ff1d 100644 --- a/README.md +++ b/README.md @@ -10,8 +10,10 @@ The HUD lets you see what Slimefun item a block is without breaking or opening i ## PlaceholderAPI -- `%slimehud_toggle%` -Returns the current player's toggle state. Possible values are `true` or `false`. +- `%slimehud_toggle%` Returns the current player's toggle state. Possible values are `true` or `false`. +- `%slimehud_hud%` Standard hud, including block display name and additional information. +- `%slimehud_hud_block%` Only block display names. +- `%slimehud_hud_block_info%` Only additional information. ## Limitations diff --git a/pom.xml b/pom.xml index 7c6c664..a0fd7e1 100644 --- a/pom.xml +++ b/pom.xml @@ -3,7 +3,7 @@ 4.0.0 io.github.schntgaispock.slimehud SlimeHUD - 1.2.7 + 1.3.0 17 diff --git a/src/main/java/io/github/schntgaispock/slimehud/placeholder/PlaceholderHook.java b/src/main/java/io/github/schntgaispock/slimehud/placeholder/PlaceholderHook.java index 7009c86..c70b503 100644 --- a/src/main/java/io/github/schntgaispock/slimehud/placeholder/PlaceholderHook.java +++ b/src/main/java/io/github/schntgaispock/slimehud/placeholder/PlaceholderHook.java @@ -1,6 +1,8 @@ package io.github.schntgaispock.slimehud.placeholder; import io.github.schntgaispock.slimehud.SlimeHUD; +import io.github.schntgaispock.slimehud.waila.PlayerWAILA; +import io.github.schntgaispock.slimehud.waila.WAILAManager; import me.clip.placeholderapi.expansion.PlaceholderExpansion; import org.bukkit.entity.Player; @@ -8,6 +10,8 @@ import javax.annotation.Nullable; public class PlaceholderHook extends PlaceholderExpansion { + private final WAILAManager wailaManager = WAILAManager.getInstance(); + @Override public @Nonnull String getIdentifier() { return "slimehud"; @@ -32,8 +36,22 @@ public boolean persist() { public @Nullable String onPlaceholderRequest(Player player, @Nonnull String params) { if (params.equalsIgnoreCase("toggle")) { return SlimeHUD.getInstance().getPlayerData().getString(player.getUniqueId() + ".waila", "true"); - } else { - return null; + } else if (params.startsWith("hud")) { + String[] split = params.split("_"); + PlayerWAILA playerWAILA = wailaManager.getWailas().get(player.getUniqueId()); + switch (split.length) { + case 1 -> { + return playerWAILA.getFacing(); + } + case 2 -> { + return playerWAILA.getFacingBlock(); + } + case 3 -> { + return playerWAILA.getFacingBlockInfo(); + } + } } + + return null; } } diff --git a/src/main/java/io/github/schntgaispock/slimehud/util/HudBuilder.java b/src/main/java/io/github/schntgaispock/slimehud/util/HudBuilder.java index 8d89ae4..7b26848 100644 --- a/src/main/java/io/github/schntgaispock/slimehud/util/HudBuilder.java +++ b/src/main/java/io/github/schntgaispock/slimehud/util/HudBuilder.java @@ -22,7 +22,7 @@ public class HudBuilder { */ @Nonnull public static String formatEnergyStored(int energy) { - return "&7| " + HudBuilder.getAbbreviatedNumber(energy) + " J Stored"; + return HudBuilder.getAbbreviatedNumber(energy) + " J Stored"; } /** @@ -33,7 +33,7 @@ public static String formatEnergyStored(int energy) { */ @Nonnull public static String formatEnergyStored(int energy, int totalEnergy) { - return "&7| " + HudBuilder.getAbbreviatedNumber(energy) + "/" + HudBuilder.getAbbreviatedNumber(totalEnergy) + " J"; + return HudBuilder.getAbbreviatedNumber(energy) + "/" + HudBuilder.getAbbreviatedNumber(totalEnergy) + " J"; } /** @@ -44,7 +44,7 @@ public static String formatEnergyStored(int energy, int totalEnergy) { */ @Nonnull public static String formatEnergyGenerated(int energy) { - return "&7| &e⚡&7 " + HudBuilder.getAbbreviatedNumber(energy) + " J/t"; + return "&e⚡&7 " + HudBuilder.getAbbreviatedNumber(energy) + " J/t"; } /** @@ -128,7 +128,7 @@ public static String formatProgressBar(int progress, int total) { */ @Nonnull public static String formatProgressBar(int percentCompleted) { - return "&7| " + HudBuilder.getProgressBar(percentCompleted) + " - " + percentCompleted + "%"; + return HudBuilder.getProgressBar(percentCompleted) + " - " + percentCompleted + "%"; } /** diff --git a/src/main/java/io/github/schntgaispock/slimehud/waila/HudController.java b/src/main/java/io/github/schntgaispock/slimehud/waila/HudController.java index 3f2fa8d..c3b5f40 100644 --- a/src/main/java/io/github/schntgaispock/slimehud/waila/HudController.java +++ b/src/main/java/io/github/schntgaispock/slimehud/waila/HudController.java @@ -65,7 +65,7 @@ private String processEnergyNode(@Nonnull HudRequest request) { Network en = EnergyNet.getNetworkFromLocation(request.getLocation()); int size = getNetworkSize(en); - return size < 0 ? "" : "&7| Network Size: " + HudBuilder.getCommaNumber(size); + return size < 0 ? "" : "Network Size: " + HudBuilder.getCommaNumber(size); } @Nonnull @@ -99,7 +99,7 @@ private String processMachine(@Nonnull HudRequest request) { MachineOperation operation = machine.getMachineProcessor().getOperation(request.getLocation()); if (operation == null) { - hudText.append("&7| Idle"); + hudText.append("Idle"); if (request.getSlimefunItem() instanceof EnergyNetComponent) { hudText.append(" ").append(processCapacitor(request)); } @@ -131,7 +131,7 @@ private String processGenerator(@Nonnull HudRequest request) { if (generation > 0) { hudText.append(HudBuilder.formatEnergyGenerated(generation)); } else { - hudText.append("&7| Not generating"); + hudText.append("Not generating"); } if (gen instanceof EnergyNetComponent) { @@ -155,7 +155,7 @@ private String processSolarGenerator(@Nonnull HudRequest request) { if (generation > 0) { hudText.append(HudBuilder.formatEnergyGenerated(generation)); } else { - hudText.append("&7| Not generating"); + hudText.append("Not generating"); } if (gen instanceof EnergyNetComponent) { @@ -172,7 +172,7 @@ private String processCargoNode(@Nonnull HudRequest request) { } CargoNode cn = (CargoNode) request.getSlimefunItem(); int channel = cn.getSelectedChannel(request.getLocation().getBlock()) + 1; - return "&7| Channel: " + Util.getColorFromCargoChannel(channel).toString() + channel; + return "Channel: " + Util.getColorFromCargoChannel(channel).toString() + channel; } @Nonnull @@ -183,7 +183,7 @@ private String processCargoManagerConnector(@Nonnull HudRequest request) { Network cn = CargoNet.getNetworkFromLocation(request.getLocation()); int size = getNetworkSize(cn); - return size < 0 ? "" : "&7| Network Size: " + HudBuilder.getCommaNumber(size); + return size < 0 ? "" : "Network Size: " + HudBuilder.getCommaNumber(size); } private int getNetworkSize(Network network) { diff --git a/src/main/java/io/github/schntgaispock/slimehud/waila/PlayerWAILA.java b/src/main/java/io/github/schntgaispock/slimehud/waila/PlayerWAILA.java index 064a17b..0f7f347 100644 --- a/src/main/java/io/github/schntgaispock/slimehud/waila/PlayerWAILA.java +++ b/src/main/java/io/github/schntgaispock/slimehud/waila/PlayerWAILA.java @@ -21,13 +21,24 @@ public class PlayerWAILA extends BukkitRunnable { - final private @Nonnull @Getter Player player; + final private @Nonnull + @Getter Player player; final private @Getter BossBar WAILABar; // Bossbar final private String WAILALocation; final private boolean useAutoBossBarColor; final private boolean keepTextColors; - + /** + * Returns an empty string if not a Slimefun item. Otherwise returns the + * formatted item name + */ + @Getter + private String facing = ""; + @Getter + private String facingBlock = ""; + @Getter + private String facingBlockInfo = ""; private String previousFacing = ""; + private @Getter boolean paused; public PlayerWAILA(@Nonnull Player player) { @@ -44,39 +55,13 @@ public PlayerWAILA(@Nonnull Player player) { this.keepTextColors = SlimeHUD.getInstance().getConfig().getBoolean("waila.use-original-colors"); } - /** - * Returns an empty string if not a Slimefun item. Otherwise returns the - * formatted item name - * - * @return Formatted item name or empty string - */ - public String getFacing() { - Block targetBlock = player.getTargetBlockExact(5); - if (targetBlock == null) - return ""; - - Location target = targetBlock.getLocation(); - if (target == null) - return ""; - - SlimefunItem item = BlockStorage.check(targetBlock); - if (item == null) - return ""; - - HudRequest request = new HudRequest(item, target, player); - StringBuilder text = new StringBuilder(SlimeHUD.getTranslationManager().getItemName(player, item)) - .append(" ") - .append(ChatColor.translateAlternateColorCodes('&', - SlimeHUD.getHudController().processRequest(request))); - - return text.toString(); - } - /** * Called every waila.tick-rate ticks */ @Override public void run() { + updateFacing(); + if (isPaused()) { return; } @@ -113,6 +98,32 @@ public void run() { } + private void updateFacing() { + Block targetBlock = player.getTargetBlockExact(5); + if (targetBlock == null) { + clearFacing(); + return; + } + + SlimefunItem item = BlockStorage.check(targetBlock); + if (item == null) { + clearFacing(); + return; + } + + Location target = targetBlock.getLocation(); + HudRequest request = new HudRequest(item, target, player); + facingBlock = SlimeHUD.getTranslationManager().getItemName(player, item); + facingBlockInfo = SlimeHUD.getHudController().processRequest(request); + facing = ChatColor.translateAlternateColorCodes('&', facingBlock + (facingBlockInfo.isEmpty() ? "" : " &7| " + facingBlockInfo)); + } + + private void clearFacing() { + facingBlock = ""; + facingBlockInfo = ""; + facing = ""; + } + public void setPaused(boolean paused) { setVisible(!previousFacing.equals("") && !paused); this.paused = paused;