mirror of
https://github.com/PurpurMC/Purpur.git
synced 2026-02-19 17:37:42 +01:00
Update anvil colors patch to use adventure
This commit is contained in:
@@ -5,30 +5,25 @@ Subject: [PATCH] Allow anvil colors
|
|||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/ContainerAnvil.java b/src/main/java/net/minecraft/server/ContainerAnvil.java
|
diff --git a/src/main/java/net/minecraft/server/ContainerAnvil.java b/src/main/java/net/minecraft/server/ContainerAnvil.java
|
||||||
index 4aa6b035a6a8ea39401c6566cd286de39f60e942..5e4e59e5c8478b76078fdda14e5ced76304d489c 100644
|
index 4aa6b035a6a8ea39401c6566cd286de39f60e942..bbe66247a2f1e07e58dc8039a8210492606343e8 100644
|
||||||
--- a/src/main/java/net/minecraft/server/ContainerAnvil.java
|
--- a/src/main/java/net/minecraft/server/ContainerAnvil.java
|
||||||
+++ b/src/main/java/net/minecraft/server/ContainerAnvil.java
|
+++ b/src/main/java/net/minecraft/server/ContainerAnvil.java
|
||||||
@@ -251,6 +251,25 @@ public class ContainerAnvil extends ContainerAnvilAbstract {
|
@@ -2,6 +2,7 @@ package net.minecraft.server;
|
||||||
|
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.Map;
|
||||||
|
+import io.papermc.paper.adventure.PaperAdventure; // Purpur
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
@@ -251,6 +252,12 @@ public class ContainerAnvil extends ContainerAnvilAbstract {
|
||||||
} else if (!this.renameText.equals(itemstack.getName().getString())) {
|
} else if (!this.renameText.equals(itemstack.getName().getString())) {
|
||||||
b1 = 1;
|
b1 = 1;
|
||||||
i += b1;
|
i += b1;
|
||||||
+ // Purpur start
|
+ // Purpur start
|
||||||
+ if (player != null && player.world.purpurConfig.anvilAllowColors && player.getBukkitEntity().hasPermission("purpur.anvil.color")) {
|
+ if (player != null && player.world.purpurConfig.anvilAllowColors && player.getBukkitEntity().hasPermission("purpur.anvil.color")) {
|
||||||
+ String json = "";
|
+ final net.kyori.adventure.text.Component renameTextComponent = net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer.legacyAmpersand().deserialize(renameText);
|
||||||
+ try {
|
+ itemstack1.a(PaperAdventure.asVanilla(renameTextComponent));
|
||||||
+ String coloredText = net.md_5.bungee.api.ChatColor.translateAlternateColorCodes('&', this.renameText);
|
|
||||||
+ net.md_5.bungee.api.chat.BaseComponent[] bungeeComp = net.md_5.bungee.api.chat.TextComponent.fromLegacyText(coloredText);
|
|
||||||
+ json = net.md_5.bungee.chat.ComponentSerializer.toString(bungeeComp);
|
|
||||||
+ IChatBaseComponent nmsComp = IChatBaseComponent.ChatSerializer.jsonToComponent(json);
|
|
||||||
+ itemstack1.a(nmsComp);
|
|
||||||
+ } catch (Exception e) {
|
|
||||||
+ MinecraftServer.LOGGER.warn("There was a problem processing item name json component on anvil!");
|
|
||||||
+ MinecraftServer.LOGGER.warn("We have fallen back to legacy colorless item name to prevent real errors");
|
|
||||||
+ MinecraftServer.LOGGER.warn("Please report this to Purpur!");
|
|
||||||
+ MinecraftServer.LOGGER.warn("JSON: " + json);
|
|
||||||
+ MinecraftServer.LOGGER.warn("The following error describes what went wrong:");
|
|
||||||
+ e.printStackTrace();
|
|
||||||
+ }
|
|
||||||
+ } else
|
+ } else
|
||||||
+ // Purpur end
|
+ // Purpur end
|
||||||
itemstack1.a((IChatBaseComponent) (new ChatComponentText(this.renameText)));
|
itemstack1.a((IChatBaseComponent) (new ChatComponentText(this.renameText)));
|
||||||
|
|||||||
Reference in New Issue
Block a user