Support components in ItemMeta (#3513)
This commit is contained in:
parent
ea8823ef57
commit
1eeb8ad14b
2 changed files with 172 additions and 0 deletions
77
Spigot-API-Patches/0214-Support-components-in-ItemMeta.patch
Normal file
77
Spigot-API-Patches/0214-Support-components-in-ItemMeta.patch
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: MiniDigger <admin@minidigger.me>
|
||||||
|
Date: Sat, 6 Jun 2020 18:13:16 +0200
|
||||||
|
Subject: [PATCH] Support components in ItemMeta
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/inventory/meta/ItemMeta.java b/src/main/java/org/bukkit/inventory/meta/ItemMeta.java
|
||||||
|
index 7e0b1d363829031075b6822d7b35ccde9fc05da9..5db838cab09888c3b3537e122e0e381a78e1dbb7 100644
|
||||||
|
--- a/src/main/java/org/bukkit/inventory/meta/ItemMeta.java
|
||||||
|
+++ b/src/main/java/org/bukkit/inventory/meta/ItemMeta.java
|
||||||
|
@@ -42,6 +42,18 @@ public interface ItemMeta extends Cloneable, ConfigurationSerializable, Persiste
|
||||||
|
@NotNull
|
||||||
|
String getDisplayName();
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
+ /**
|
||||||
|
+ * Gets the display name that is set.
|
||||||
|
+ * <p>
|
||||||
|
+ * Plugins should check that hasDisplayName() returns <code>true</code>
|
||||||
|
+ * before calling this method.
|
||||||
|
+ *
|
||||||
|
+ * @return the display name that is set
|
||||||
|
+ */
|
||||||
|
+ @NotNull
|
||||||
|
+ net.md_5.bungee.api.chat.BaseComponent[] getDisplayNameComponent();
|
||||||
|
+ // Paper end
|
||||||
|
/**
|
||||||
|
* Sets the display name.
|
||||||
|
*
|
||||||
|
@@ -49,6 +61,14 @@ public interface ItemMeta extends Cloneable, ConfigurationSerializable, Persiste
|
||||||
|
*/
|
||||||
|
void setDisplayName(@Nullable String name);
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
+ /**
|
||||||
|
+ * Sets the display name.
|
||||||
|
+ *
|
||||||
|
+ * @param component the name component to set
|
||||||
|
+ */
|
||||||
|
+ void setDisplayNameComponent(@Nullable net.md_5.bungee.api.chat.BaseComponent[] component);
|
||||||
|
+ // Paper end
|
||||||
|
/**
|
||||||
|
* Checks for existence of a localized name.
|
||||||
|
*
|
||||||
|
@@ -92,6 +112,17 @@ public interface ItemMeta extends Cloneable, ConfigurationSerializable, Persiste
|
||||||
|
@Nullable
|
||||||
|
List<String> getLore();
|
||||||
|
|
||||||
|
+ /**
|
||||||
|
+ * Gets the lore that is set.
|
||||||
|
+ * <p>
|
||||||
|
+ * Plugins should check if hasLore() returns <code>true</code> before
|
||||||
|
+ * calling this method.
|
||||||
|
+ *
|
||||||
|
+ * @return a list of lore that is set
|
||||||
|
+ */
|
||||||
|
+ @Nullable
|
||||||
|
+ List<net.md_5.bungee.api.chat.BaseComponent[]> getLoreComponents();
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
* Sets the lore for this item.
|
||||||
|
* Removes lore when given null.
|
||||||
|
@@ -100,6 +131,14 @@ public interface ItemMeta extends Cloneable, ConfigurationSerializable, Persiste
|
||||||
|
*/
|
||||||
|
void setLore(@Nullable List<String> lore);
|
||||||
|
|
||||||
|
+ /**
|
||||||
|
+ * Sets the lore for this item.
|
||||||
|
+ * Removes lore when given null.
|
||||||
|
+ *
|
||||||
|
+ * @param lore the lore that will be set
|
||||||
|
+ */
|
||||||
|
+ void setLoreComponents(@Nullable List<net.md_5.bungee.api.chat.BaseComponent[]> lore);
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
* Checks for existence of custom model data.
|
||||||
|
* <p>
|
|
@ -0,0 +1,95 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: MiniDigger <admin@minidigger.me>
|
||||||
|
Date: Sat, 6 Jun 2020 18:13:42 +0200
|
||||||
|
Subject: [PATCH] Support components in ItemMeta
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/IChatBaseComponent.java b/src/main/java/net/minecraft/server/IChatBaseComponent.java
|
||||||
|
index fd3e6cda6a0e7154c50608ba9a4b70f3c43c8f2a..94a6d0ad76b10b8790ffb2019bf6972472b04c3d 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/IChatBaseComponent.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/IChatBaseComponent.java
|
||||||
|
@@ -344,6 +344,7 @@ public interface IChatBaseComponent extends Message, IChatFormatted, Iterable<IC
|
||||||
|
return jsonobject;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ public static String componentToJson(IChatBaseComponent ichatbasecomponent) { return a(ichatbasecomponent);} // Paper - OBFHELPER
|
||||||
|
public static String a(IChatBaseComponent ichatbasecomponent) {
|
||||||
|
return IChatBaseComponent.ChatSerializer.a.toJson(ichatbasecomponent);
|
||||||
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
|
index 8f48b58c98ba40d5d7deb6775957e2c6b4d334c6..fc09a30b9792cff4717d0767f7fcef50f6f4ff90 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
||||||
|
@@ -873,11 +873,23 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
return CraftChatMessage.fromComponent(displayName);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
+ @Override
|
||||||
|
+ public net.md_5.bungee.api.chat.BaseComponent[] getDisplayNameComponent() {
|
||||||
|
+ return net.md_5.bungee.chat.ComponentSerializer.parse(IChatBaseComponent.ChatSerializer.componentToJson(displayName));
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
@Override
|
||||||
|
public final void setDisplayName(String name) {
|
||||||
|
this.displayName = CraftChatMessage.fromStringOrNull(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
+ @Override
|
||||||
|
+ public void setDisplayNameComponent(net.md_5.bungee.api.chat.BaseComponent[] component) {
|
||||||
|
+ this.displayName = IChatBaseComponent.ChatSerializer.jsonToComponent(net.md_5.bungee.chat.ComponentSerializer.toString(component));
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
@Override
|
||||||
|
public boolean hasDisplayName() {
|
||||||
|
return displayName != null;
|
||||||
|
@@ -1008,6 +1020,14 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
return this.lore == null ? null : new ArrayList<String>(Lists.transform(this.lore, CraftChatMessage::fromComponent));
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
+ @Override
|
||||||
|
+ public List<net.md_5.bungee.api.chat.BaseComponent[]> getLoreComponents() {
|
||||||
|
+ return this.lore == null ? null : new ArrayList<>(this.lore.stream().map(entry ->
|
||||||
|
+ net.md_5.bungee.chat.ComponentSerializer.parse(IChatBaseComponent.ChatSerializer.componentToJson(entry)
|
||||||
|
+ )).collect(java.util.stream.Collectors.toList()));
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
@Override
|
||||||
|
public void setLore(List<String> lore) { // too tired to think if .clone is better
|
||||||
|
if (lore == null) {
|
||||||
|
@@ -1022,6 +1042,21 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
+ @Override
|
||||||
|
+ public void setLoreComponents(List<net.md_5.bungee.api.chat.BaseComponent[]> lore) {
|
||||||
|
+ if (lore == null) {
|
||||||
|
+ this.lore = null;
|
||||||
|
+ } else {
|
||||||
|
+ if (this.lore == null) {
|
||||||
|
+ safelyAdd(lore, this.lore = new ArrayList<>(lore.size()), Integer.MAX_VALUE);
|
||||||
|
+ } else {
|
||||||
|
+ this.lore.clear();
|
||||||
|
+ safelyAdd(lore, this.lore, Integer.MAX_VALUE);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
@Override
|
||||||
|
public boolean hasCustomModelData() {
|
||||||
|
return customModelData != null;
|
||||||
|
@@ -1483,6 +1518,11 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
||||||
|
}
|
||||||
|
|
||||||
|
for (Object object : addFrom) {
|
||||||
|
+ // Paper start - support components
|
||||||
|
+ if(object instanceof net.md_5.bungee.api.chat.BaseComponent[]) {
|
||||||
|
+ addTo.add(IChatBaseComponent.ChatSerializer.jsonToComponent(net.md_5.bungee.chat.ComponentSerializer.toString((net.md_5.bungee.api.chat.BaseComponent[]) object)));
|
||||||
|
+ } else
|
||||||
|
+ // Paper end
|
||||||
|
if (!(object instanceof String)) {
|
||||||
|
if (object != null) {
|
||||||
|
throw new IllegalArgumentException(addFrom + " cannot contain non-string " + object.getClass().getName());
|
Loading…
Reference in a new issue