Interface ItemMeta
- All Superinterfaces:
- Cloneable,- ConfigurationSerializable,- PersistentDataHolder,- PersistentDataViewHolder
- All Known Subinterfaces:
- ArmorMeta,- ArmorStandMeta,- AxolotlBucketMeta,- BannerMeta,- BlockDataMeta,- BlockStateMeta,- BookMeta,- BundleMeta,- ColorableArmorMeta,- CompassMeta,- CrossbowMeta,- Damageable,- EnchantmentStorageMeta,- FireworkEffectMeta,- FireworkMeta,- KnowledgeBookMeta,- LeatherArmorMeta,- MapMeta,- MusicInstrumentMeta,- OminousBottleMeta,- PotionMeta,- Repairable,- ShieldMeta,- SkullMeta,- SpawnEggMeta,- SuspiciousStewMeta,- TropicalFishBucketMeta,- WritableBookMeta
An implementation will handle the creation and application for ItemMeta. This class should not be implemented by a plugin in a live environment.
- 
Method SummaryModifier and TypeMethodDescriptionbooleanaddAttributeModifier(@NotNull Attribute attribute, @NotNull AttributeModifier modifier) Add an Attribute and it's Modifier.booleanaddEnchant(@NotNull Enchantment enchant, int level, boolean ignoreLevelRestriction) Adds the specified enchantment to this item meta.voidaddItemFlags(@NotNull ItemFlag... itemFlags) Set itemflags which should be ignored when rendering a ItemStack in the Client.clone()Gets the custom name.voidcustomName(@Nullable Component customName) Sets the custom name.Gets the display name.default voiddisplayName(@Nullable Component displayName) Sets the display name.Get this ItemMeta as a component-compliant string.Get this ItemMeta as an NBT string.Return an immutable copy of all Attributes and their modifiers in this ItemMeta.
 Returns null if none exist.getAttributeModifiers(@NotNull Attribute attribute) Return an immutable copy of allAttributeModifiers for a givenAttributeReturn an immutable copy of allAttributes and theirAttributeModifiers for a givenEquipmentSlot.
 AnyAttributeModifierthat does have a givenEquipmentSlotwill be returned.Deprecated, for removal: This API element is subject to removal in a future version.Deprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI.intDeprecated.more complex custom model data can be specified withgetCustomModelDataComponent().Gets the custom model data set on this item, or creates an empty custom model data instance.Deprecated.this API part has been replaced by thePersistentDataHolderAPI.Gets the type of damage this item will be resistant to when in entity form.Deprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI.Deprecated.in favour ofdisplayName()net.md_5.bungee.api.chat.BaseComponent[]Deprecated.usedisplayName()intGets the enchantable component.intgetEnchantLevel(@NotNull Enchantment enchant) Checks for the level of the specified enchantment.Sets the enchantment_glint_override.Returns a copy the enchantments in this ItemMeta.Gets the equippable set on this item, or creates an empty equippable instance.getFood()Gets the food set on this item, or creates an empty food instance.Get current set itemFlags.Gets the custom item model.Deprecated.in favour ofitemName()Gets the jukebox playable component set on this item.Deprecated, for removal: This API element is subject to removal in a future version.UsedisplayName()and cast it to aTranslatableComponent.getLore()Deprecated.in favour oflore()Deprecated.uselore()intGets the max_stack_size.Deprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI.Gets the item rarity.getTool()Gets the tool set on this item, or creates an empty tool instance.Gets the custom tooltip style.Gets the use cooldown set on this item, or creates an empty cooldown instance.Gets the item which this item will convert to when used.booleanChecks for the existence of any AttributeModifiers.booleanhasConflictingEnchant(@NotNull Enchantment enchant) Checks if the specified enchantment conflicts with any enchantments in this ItemMeta.booleanDeprecated.more complex custom model data can be specified withhasCustomModelDataComponent().booleanChecks if the custom model data component is set.booleanChecks for existence of a custom name.booleanGets if this item is resistant to certain types of damage.booleanDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI.default booleanChecks for existence of a display name.booleanhasEnchant(@NotNull Enchantment enchant) Checks for existence of the specified enchantment.booleanGets if the enchantable component is set.booleanGets if an enchantment_glint_override is set.booleanChecks for the existence of any enchantments.booleanChecks if the equippable is set.booleanhasFood()Checks if the food is set.booleanhasItemFlag(@NotNull ItemFlag flag) Check if the specified flag is present on this item.booleanGets if this item has a custom item model.booleanChecks for existence of an item name.booleanChecks if the jukebox playable is set.booleanDeprecated, for removal: This API element is subject to removal in a future version.UsedisplayName()and check if it is instanceof aTranslatableComponent.booleanhasLore()Checks for existence of lore.booleanGets if the max_stack_size is set.booleanDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI.booleanGets if the rarity is set.booleanhasTool()Checks if the tool is set.booleanGets if this item has a custom tooltip style.booleanChecks if the use cooldown is set.booleanChecks if the use remainder is set.booleanDeprecated.booleanisGlider()Checks if this item is a glider.booleanGets if this item has hide_tooltip set.booleanReturn if the unbreakable tag is true.itemName()Gets the item name component that is set.voidSets the item name.lore()Gets the lore.voidSets the lore.booleanremoveAttributeModifier(@NotNull Attribute attribute) Remove allAttributeModifiers associated with the givenAttribute.booleanremoveAttributeModifier(@NotNull Attribute attribute, @NotNull AttributeModifier modifier) Remove a specificAttributeandAttributeModifier.booleanRemove allAttributes andAttributeModifiers for a givenEquipmentSlot.
 If the givenEquipmentSlotis null, this will remove allAttributeModifiers that do not have an EquipmentSlot set.booleanremoveEnchant(@NotNull Enchantment enchant) Removes the specified enchantment from this item meta.voidRemoves all enchantments from this item meta.voidremoveItemFlags(@NotNull ItemFlag... itemFlags) Remove specific set of itemFlags.voidsetAttributeModifiers(@Nullable Multimap<Attribute, AttributeModifier> attributeModifiers) Set allAttributes and theirAttributeModifiers.voidsetCanDestroy(Set<Material> canDestroy) Deprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI.voidsetCanPlaceOn(Set<Material> canPlaceOn) Deprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI.voidDeprecated.more complex custom model data can be specified withsetCustomModelDataComponent(org.bukkit.inventory.meta.components.CustomModelDataComponent).voidsetCustomModelDataComponent(@Nullable CustomModelDataComponent customModelData) Sets the custom model data component.voidSets the type of damage this item will be resistant to when in entity form.voidsetDestroyableKeys(@NotNull Collection<Namespaced> canDestroy) Deprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI.voidsetDisplayName(@Nullable String name) Deprecated.in favour ofdisplayName(net.kyori.adventure.text.Component)voidsetDisplayNameComponent(net.md_5.bungee.api.chat.BaseComponent[] component) Deprecated.voidsetEnchantable(@Nullable Integer enchantable) Sets the enchantable.voidsetEnchantmentGlintOverride(@Nullable Boolean override) Sets the enchantment_glint_override.voidsetEquippable(@Nullable EquippableComponent equippable) Sets the equippable tool.voidsetFireResistant(boolean fireResistant) Deprecated.voidsetFood(@Nullable FoodComponent food) Sets the item food.voidsetGlider(boolean glider) Sets if this item is a glider.voidsetHideTooltip(boolean hideTooltip) Sets if this item has hide_tooltip set.voidsetItemModel(@Nullable NamespacedKey itemModel) Sets the custom item model.voidsetItemName(@Nullable String name) Deprecated.in favour ofitemName(Component)voidsetJukeboxPlayable(@Nullable JukeboxPlayableComponent jukeboxPlayable) Sets the jukebox playable component.voidsetLocalizedName(@Nullable String name) Deprecated, for removal: This API element is subject to removal in a future version.UsedisplayName(Component)with aTranslatableComponent.voidDeprecated.in favour oflore(List)voidsetLoreComponents(@Nullable List<net.md_5.bungee.api.chat.BaseComponent[]> lore) Deprecated.uselore(List)voidSets the max_stack_size.voidsetPlaceableKeys(@NotNull Collection<Namespaced> canPlaceOn) Deprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI.voidsetRarity(@Nullable ItemRarity rarity) Sets the item rarity.voidsetTool(@Nullable ToolComponent tool) Sets the item tool.voidsetTooltipStyle(@Nullable NamespacedKey tooltipStyle) Sets the custom tooltip style.voidsetUnbreakable(boolean unbreakable) Sets the unbreakable tag.voidsetUseCooldown(@Nullable UseCooldownComponent cooldown) Sets the item use cooldown.voidsetUseRemainder(@Nullable ItemStack remainder) Sets the item which this item will convert to when used.voidsetVersion(int version) Internal use only! Do not use under any circumstances!Methods inherited from interface org.bukkit.configuration.serialization.ConfigurationSerializableserializeMethods inherited from interface org.bukkit.persistence.PersistentDataHoldergetPersistentDataContainer
- 
Method Details- 
hasCustomNameboolean hasCustomName()Checks for existence of a custom name.- Returns:
- true if this has a custom name
 
- 
customNameGets the custom name.Plugins should check that hasCustomName()returnstruebefore calling this method.- Returns:
- the custom name
 
- 
customNameSets the custom name.- Parameters:
- customName- the custom name to set
 
- 
hasDisplayNameChecks for existence of a display name.- Returns:
- true if this has a display name
- API Note:
- This method is obsolete, use hasCustomName()instead.
 
- 
displayNameGets the display name.Plugins should check that hasDisplayName()returnstruebefore calling this method.- Returns:
- the display name
- API Note:
- This method is obsolete, use customName()instead.
 
- 
displayNameSets the display name.- Parameters:
- displayName- the display name to set
- API Note:
- This method is obsolete, use customName(Component)instead.
 
- 
getDisplayNameDeprecated.in favour ofdisplayName()Gets the display name that is set.Plugins should check that hasDisplayName() returns truebefore calling this method.- Returns:
- the display name that is set
 
- 
getDisplayNameComponentDeprecated.usedisplayName()Gets the display name that is set.Plugins should check that hasDisplayName() returns truebefore calling this method.- Returns:
- the display name that is set
 
- 
setDisplayNameDeprecated.in favour ofdisplayName(net.kyori.adventure.text.Component)Sets the display name.- Parameters:
- name- the name to set
 
- 
setDisplayNameComponent@Deprecated void setDisplayNameComponent(@Nullable net.md_5.bungee.api.chat.BaseComponent[] component) Deprecated.Sets the display name.- Parameters:
- component- the name component to set
 
- 
hasItemNameboolean hasItemName()Checks for existence of an item name.
 Item name differs from display name in that it is cannot be edited by an anvil, is not styled with italics, and does not show labels.- Returns:
- true if this has an item name
 
- 
itemNameGets the item name component that is set.
 Item name differs from display name in that it is cannot be edited by an anvil, is not styled with italics, and does not show labels.Plugins should check that hasItemName()returnstruebefore calling this method.- Returns:
- the item name that is set
- See Also:
 
- 
itemNameSets the item name.
 Item name differs from display name in that it is cannot be edited by an anvil, is not styled with italics, and does not show labels.- Parameters:
- name- the name to set, null to remove it
 
- 
getItemNameDeprecated.in favour ofitemName()Gets the item name that is set.
 Item name differs from display name in that it is cannot be edited by an anvil, is not styled with italics, and does not show labels.Plugins should check that hasItemName() returns truebefore calling this method.- Returns:
- the item name that is set
 
- 
setItemNameDeprecated.in favour ofitemName(Component)Sets the item name.
 Item name differs from display name in that it is cannot be edited by an anvil, is not styled with italics, and does not show labels.- Parameters:
- name- the name to set
 
- 
hasLocalizedNameDeprecated, for removal: This API element is subject to removal in a future version.UsedisplayName()and check if it is instanceof aTranslatableComponent.Checks for existence of a localized name.- Returns:
- true if this has a localized name
 
- 
getLocalizedNameDeprecated, for removal: This API element is subject to removal in a future version.UsedisplayName()and cast it to aTranslatableComponent. No longer used by the client.Gets the localized display name that is set.Plugins should check that hasLocalizedName() returns truebefore calling this method.- Returns:
- the localized name that is set
 
- 
setLocalizedNameDeprecated, for removal: This API element is subject to removal in a future version.UsedisplayName(Component)with aTranslatableComponent. No longer used by the client.Sets the localized name.- Parameters:
- name- the name to set
 
- 
hasLoreboolean hasLore()Checks for existence of lore.- Returns:
- true if this has lore
 
- 
loreGets the lore.Plugins should check that hasLore()returnstruebefore calling this method.- Returns:
- the lore
 
- 
loreSets the lore.- Parameters:
- lore- the lore to set
 
- 
getLoreDeprecated.in favour oflore()Gets the lore that is set.Plugins should check if hasLore() returns truebefore calling this method.- Returns:
- a list of lore that is set
 
- 
getLoreComponentsDeprecated.uselore()Gets the lore that is set.Plugins should check if hasLore() returns truebefore calling this method.- Returns:
- a list of lore that is set
 
- 
setLoreDeprecated.in favour oflore(List)Sets the lore for this item. Removes lore when given null.- Parameters:
- lore- the lore that will be set
 
- 
setLoreComponents@Deprecated void setLoreComponents(@Nullable @Nullable List<net.md_5.bungee.api.chat.BaseComponent[]> lore) Deprecated.uselore(List)Sets the lore for this item. Removes lore when given null.- Parameters:
- lore- the lore that will be set
 
- 
hasCustomModelDataDeprecated.more complex custom model data can be specified withhasCustomModelDataComponent(). Integers from the old custom model data are equivalent to a single float in theCustomModelDataComponent.getFloats()list.Checks for existence of custom model data.CustomModelData is an integer that may be associated client side with a custom item model. - Returns:
- true if this has custom model data
 
- 
getCustomModelDataDeprecated.more complex custom model data can be specified withgetCustomModelDataComponent(). Integers from the old custom model data are equivalent to a single float in theCustomModelDataComponent.getFloats()list.Gets the custom model data that is set.CustomModelData is an integer that may be associated client side with a custom item model. Plugins should check that hasCustomModelData() returns truebefore calling this method.- Returns:
- the custom model data that is set
 
- 
getCustomModelDataComponentGets the custom model data set on this item, or creates an empty custom model data instance.The returned component is a snapshot of its current state and does not reflect a live view of what is on an item. After changing any value on this component, it must be set with setCustomModelDataComponent(CustomModelDataComponent)to apply the changes.- Returns:
- component
 
- 
setCustomModelDataDeprecated.more complex custom model data can be specified withsetCustomModelDataComponent(org.bukkit.inventory.meta.components.CustomModelDataComponent). Integers from the old custom model data are equivalent to a single float in theCustomModelDataComponent.setFloats(java.util.List)list.Sets the custom model data.CustomModelData is an integer that may be associated client side with a custom item model. - Parameters:
- data- the data to set, or null to clear
 
- 
hasCustomModelDataComponentboolean hasCustomModelDataComponent()Checks if the custom model data component is set.- Returns:
- if a custom model data component is set
 
- 
setCustomModelDataComponentSets the custom model data component.- Parameters:
- customModelData- new component
 
- 
hasEnchantableboolean hasEnchantable()Gets if the enchantable component is set.- Returns:
- if an enchantable is set.
 
- 
getEnchantableint getEnchantable()Gets the enchantable component. Higher values allow higher enchantments.- Returns:
- the enchantable value
 
- 
setEnchantableSets the enchantable. Higher values allow higher enchantments.- Parameters:
- enchantable- enchantable value, must be positive
 
- 
hasEnchantsboolean hasEnchants()Checks for the existence of any enchantments.- Returns:
- true if an enchantment exists on this meta
 
- 
hasEnchantChecks for existence of the specified enchantment.- Parameters:
- enchant- enchantment to check
- Returns:
- true if this enchantment exists for this meta
 
- 
getEnchantLevelChecks for the level of the specified enchantment.- Parameters:
- enchant- enchantment to check
- Returns:
- The level that the specified enchantment has, or 0 if none
 
- 
getEnchantsReturns a copy the enchantments in this ItemMeta.
 Returns an empty map if none.- Returns:
- An immutable copy of the enchantments
 
- 
addEnchantboolean addEnchant(@NotNull @NotNull Enchantment enchant, int level, boolean ignoreLevelRestriction) Adds the specified enchantment to this item meta.- Parameters:
- enchant- Enchantment to add
- level- Level for the enchantment
- ignoreLevelRestriction- this indicates the enchantment should be applied, ignoring the level limit
- Returns:
- true if the item meta changed as a result of this call, false otherwise
 
- 
removeEnchantRemoves the specified enchantment from this item meta.- Parameters:
- enchant- Enchantment to remove
- Returns:
- true if the item meta changed as a result of this call, false otherwise
 
- 
removeEnchantmentsvoid removeEnchantments()Removes all enchantments from this item meta.
- 
hasConflictingEnchantChecks if the specified enchantment conflicts with any enchantments in this ItemMeta.- Parameters:
- enchant- enchantment to test
- Returns:
- true if the enchantment conflicts, false otherwise
 
- 
addItemFlagsSet itemflags which should be ignored when rendering a ItemStack in the Client. This Method does silently ignore double set itemFlags.- Parameters:
- itemFlags- The hideflags which shouldn't be rendered
 
- 
removeItemFlagsRemove specific set of itemFlags. This tells the Client it should render it again. This Method does silently ignore double removed itemFlags.- Parameters:
- itemFlags- Hideflags which should be removed
 
- 
getItemFlagsGet current set itemFlags. The collection returned is unmodifiable.- Returns:
- A set of all itemFlags set
 
- 
hasItemFlagCheck if the specified flag is present on this item.- Parameters:
- flag- the flag to check
- Returns:
- if it is present
 
- 
isHideTooltipboolean isHideTooltip()Gets if this item has hide_tooltip set. An item with this set will not show any tooltip whatsoever.- Returns:
- hide_tooltip
 
- 
setHideTooltipvoid setHideTooltip(boolean hideTooltip) Sets if this item has hide_tooltip set. An item with this set will not show any tooltip whatsoever.- Parameters:
- hideTooltip- new hide_tooltip
 
- 
hasTooltipStyleboolean hasTooltipStyle()Gets if this item has a custom tooltip style.- Returns:
- if a tooltip_style is set
 
- 
getTooltipStyleGets the custom tooltip style.- Returns:
- the tooltip style
 
- 
setTooltipStyleSets the custom tooltip style.- Parameters:
- tooltipStyle- the new style
 
- 
hasItemModelboolean hasItemModel()Gets if this item has a custom item model.- Returns:
- if a item_model is set
 
- 
getItemModelGets the custom item model.- Returns:
- the item model
 
- 
setItemModelSets the custom item model.- Parameters:
- itemModel- the new model
 
- 
isUnbreakableboolean isUnbreakable()Return if the unbreakable tag is true. An unbreakable item will not lose durability.- Returns:
- true if the unbreakable tag is true
 
- 
setUnbreakablevoid setUnbreakable(boolean unbreakable) Sets the unbreakable tag. An unbreakable item will not lose durability.- Parameters:
- unbreakable- true if set unbreakable
 
- 
hasEnchantmentGlintOverrideboolean hasEnchantmentGlintOverride()Gets if an enchantment_glint_override is set.- Returns:
- if an enchantment_glint_override is set
 
- 
getEnchantmentGlintOverrideSets the enchantment_glint_override. If true, the item will glint, even without enchantments; if false, the item will not glint, even with enchantments. Plugins should checkhasEnchantmentGlintOverride()before calling this method.- Returns:
- enchantment_glint_override
 
- 
setEnchantmentGlintOverrideSets the enchantment_glint_override. If true, the item will glint, even without enchantments; if false, the item will not glint, even with enchantments. If null, the override will be cleared.- Parameters:
- override- new enchantment_glint_override
 
- 
isGliderboolean isGlider()Checks if this item is a glider. If true, this item will allow players to glide when it is equipped.- Returns:
- glider
 
- 
setGlidervoid setGlider(boolean glider) Sets if this item is a glider. If true, this item will allow players to glide when it is equipped.- Parameters:
- glider- glider
 
- 
isFireResistantDeprecated.Checks if this item is fire_resistant. If true, it will not burn in fire or lava.- Returns:
- fire_resistant
 
- 
setFireResistantDeprecated.Sets if this item is fire_resistant. If true, it will not burn in fire or lava.- Parameters:
- fireResistant- fire_resistant
 
- 
hasDamageResistantboolean hasDamageResistant()Gets if this item is resistant to certain types of damage.- Returns:
- true if a resistance is set
 
- 
getDamageResistantGets the type of damage this item will be resistant to when in entity form. Plugins should checkhasDamageResistant()before calling this method.- Returns:
- damage type
 
- 
setDamageResistantSets the type of damage this item will be resistant to when in entity form.- Parameters:
- tag- the tag, or null to clear
 
- 
hasMaxStackSizeboolean hasMaxStackSize()Gets if the max_stack_size is set.- Returns:
- if a max_stack_size is set.
 
- 
getMaxStackSizeint getMaxStackSize()Gets the max_stack_size. This is the maximum amount which an item will stack.- Returns:
- max_stack_size
 
- 
setMaxStackSizeSets the max_stack_size. This is the maximum amount which an item will stack.- Parameters:
- max- max_stack_size, between 1 and 99 (inclusive)
 
- 
hasRarityboolean hasRarity()Gets if the rarity is set.- Returns:
- rarity
 
- 
getRarityGets the item rarity. Plugins should checkhasRarity()before calling this method.- Returns:
- rarity
 
- 
setRaritySets the item rarity.- Parameters:
- rarity- new rarity
 
- 
hasUseRemainderboolean hasUseRemainder()Checks if the use remainder is set.- Returns:
- if a use remainder item is set
 
- 
getUseRemainderGets the item which this item will convert to when used.- Returns:
- remainder
 
- 
setUseRemainderSets the item which this item will convert to when used.- Parameters:
- remainder- new item
 
- 
hasUseCooldownboolean hasUseCooldown()Checks if the use cooldown is set.- Returns:
- if a use cooldown is set
 
- 
getUseCooldownGets the use cooldown set on this item, or creates an empty cooldown instance.The returned component is a snapshot of its current state and does not reflect a live view of what is on an item. After changing any value on this component, it must be set with setUseCooldown(UseCooldownComponent)to apply the changes.- Returns:
- cooldown
 
- 
setUseCooldownSets the item use cooldown.- Parameters:
- cooldown- new cooldown
 
- 
hasFoodboolean hasFood()Checks if the food is set.- Returns:
- if a food is set
 
- 
getFoodGets the food set on this item, or creates an empty food instance.The returned component is a snapshot of its current state and does not reflect a live view of what is on an item. After changing any value on this component, it must be set with setFood(FoodComponent)to apply the changes.- Returns:
- food
 
- 
setFoodSets the item food.- Parameters:
- food- new food
 
- 
hasToolboolean hasTool()Checks if the tool is set.- Returns:
- if a tool is set
 
- 
getToolGets the tool set on this item, or creates an empty tool instance.The returned component is a snapshot of its current state and does not reflect a live view of what is on an item. After changing any value on this component, it must be set with setTool(ToolComponent)to apply the changes.- Returns:
- tool
 
- 
setToolSets the item tool.- Parameters:
- tool- new tool
 
- 
hasEquippableboolean hasEquippable()Checks if the equippable is set.- Returns:
- if a equippable is set
 
- 
getEquippableGets the equippable set on this item, or creates an empty equippable instance.The returned component is a snapshot of its current state and does not reflect a live view of what is on an item. After changing any value on this component, it must be set with setEquippable(EquippableComponent)to apply the changes.- Returns:
- equippable
 
- 
setEquippableSets the equippable tool.- Parameters:
- equippable- new equippable
 
- 
hasJukeboxPlayableboolean hasJukeboxPlayable()Checks if the jukebox playable is set.- Returns:
- if a jukebox playable is set
 
- 
getJukeboxPlayableGets the jukebox playable component set on this item.The returned component is a snapshot of its current state and does not reflect a live view of what is on an item. After changing any value on this component, it must be set with setJukeboxPlayable(org.bukkit.inventory.meta.components.JukeboxPlayableComponent)to apply the changes.- Returns:
- component
 
- 
setJukeboxPlayableSets the jukebox playable component.- Parameters:
- jukeboxPlayable- new component
 
- 
hasAttributeModifiersboolean hasAttributeModifiers()Checks for the existence of any AttributeModifiers.- Returns:
- true if any AttributeModifiers exist
 
- 
getAttributeModifiersReturn an immutable copy of all Attributes and their modifiers in this ItemMeta.
 Returns null if none exist.- Returns:
- an immutable Multimapof Attributes and their AttributeModifiers, or null if none exist
 
- 
getAttributeModifiers@NotNull @NotNull Multimap<Attribute,AttributeModifier> getAttributeModifiers(@NotNull @NotNull EquipmentSlot slot) Return an immutable copy of allAttributes and theirAttributeModifiers for a givenEquipmentSlot.
 AnyAttributeModifierthat does have a givenEquipmentSlotwill be returned. This is because AttributeModifiers without a slot are active in any slot.
 If there are no attributes set for the given slot, an empty map will be returned.- Parameters:
- slot- the- EquipmentSlotto check
- Returns:
- the immutable Multimapwith the respective Attributes and modifiers, or an empty map if no attributes are set.
 
- 
getAttributeModifiers@Nullable @Nullable Collection<AttributeModifier> getAttributeModifiers(@NotNull @NotNull Attribute attribute) Return an immutable copy of allAttributeModifiers for a givenAttribute- Parameters:
- attribute- the- Attribute
- Returns:
- an immutable collection of AttributeModifiers or null if no AttributeModifiers exist for the Attribute.
- Throws:
- NullPointerException- if Attribute is null
 
- 
addAttributeModifierboolean addAttributeModifier(@NotNull @NotNull Attribute attribute, @NotNull @NotNull AttributeModifier modifier) Add an Attribute and it's Modifier. AttributeModifiers can now supportEquipmentSlots. If not set, theAttributeModifierwill be active in ALL slots.
 TwoAttributeModifiers that have the sameUUIDcannot exist on the same Attribute.- Parameters:
- attribute- the- Attributeto modify
- modifier- the- AttributeModifierspecifying the modification
- Returns:
- true if the Attribute and AttributeModifier were successfully added
- Throws:
- NullPointerException- if Attribute is null
- NullPointerException- if AttributeModifier is null
- IllegalArgumentException- if AttributeModifier already exists
 
- 
setAttributeModifiersvoid setAttributeModifiers(@Nullable @Nullable Multimap<Attribute, AttributeModifier> attributeModifiers) Set allAttributes and theirAttributeModifiers. To clear all custom attribute modifiers, usenull. To set no modifiers (which will override the default modifiers), use an empty map. If not null nor empty, this will filter all entries that are not-null and add them to the ItemStack.- Parameters:
- attributeModifiers- the new Multimap containing the Attributes and their AttributeModifiers
 
- 
removeAttributeModifierRemove allAttributeModifiers associated with the givenAttribute. This will return false if nothing was removed.- Parameters:
- attribute- attribute to remove
- Returns:
- true if all modifiers were removed from a given Attribute. Returns false if no attributes were removed.
- Throws:
- NullPointerException- if Attribute is null
 
- 
removeAttributeModifierRemove allAttributes andAttributeModifiers for a givenEquipmentSlot.
 If the givenEquipmentSlotis null, this will remove allAttributeModifiers that do not have an EquipmentSlot set.- Parameters:
- slot- the- EquipmentSlotto clear all Attributes and their modifiers for
- Returns:
- true if all modifiers were removed that match the given EquipmentSlot.
 
- 
removeAttributeModifierboolean removeAttributeModifier(@NotNull @NotNull Attribute attribute, @NotNull @NotNull AttributeModifier modifier) Remove a specificAttributeandAttributeModifier. AttributeModifiers are matched according to theirUUID.- Parameters:
- attribute- the- Attributeto remove
- modifier- the- AttributeModifierto remove
- Returns:
- if any attribute modifiers were remove
- Throws:
- NullPointerException- if the Attribute is null
- NullPointerException- if the AttributeModifier is null
- See Also:
 
- 
getAsStringGet this ItemMeta as an NBT string. If this ItemMeta does not have any NBT, then"{}"will be returned.This string should NEVER be relied upon as a serializable value. If serialization is desired, the ConfigurationSerializableAPI should be used instead.- Returns:
- the NBT string
 
- 
getAsComponentStringGet this ItemMeta as a component-compliant string. If this ItemMeta does not contain any components, then"[]"will be returned.The result of this method should yield a string representing the components altered by this ItemMeta instance. When passed to ItemFactory.createItemStack(String)with a prepended item type, it will create an ItemStack that has an ItemMeta matching this ItemMeta instance exactly. Note that this method returns ONLY the components and cannot be passed to createItemStack() alone. An example may look something like this:ItemStack itemStack = // ... an item stack obtained from somewhere ItemMeta itemMeta = itemStack.getItemMeta(); String components = itemMeta.getAsComponentString(); // example: "[minecraft:damage=53]" String itemTypeKey = itemStack.getType().getKey().toString(); // example: "minecraft:diamond_sword" String itemAsString = itemTypeKey + components; // results in: "minecraft:diamond_sword[minecraft:damage=53]" ItemStack recreatedItemStack = Bukkit.getItemFactory().createItemStack(itemAsString); assert itemStack.isSimilar(recreatedItemStack); // Should be true* *Components not represented or explicitly overridden by this ItemMeta instance will not be included in the resulting string and therefore may result in ItemStacks that do not match exactly. For example, if setDisplayName(String)is not set, then the custom name component will not be included. Or if this ItemMeta is a PotionMeta, it will not include any components related to lodestone compasses, banners, or books, etc., only components modifiable by a PotionMeta instance.This string should NEVER be relied upon as a serializable value. If serialization is desired, the ConfigurationSerializableAPI should be used instead.- Returns:
- the component-compliant string
 
- 
getCustomTagContainerDeprecated.this API part has been replaced by thePersistentDataHolderAPI. Please usePersistentDataHolder.getPersistentDataContainer()instead of this.Returns a public custom tag container capable of storing tags on the item. Those tags will be sent to the client with all of their content, so the client is capable of reading them. This will result in the player seeing a NBT Tag notification on the item. These tags can also be modified by the client once in creative mode- Returns:
- the custom tag container
 
- 
setVersionInternal use only! Do not use under any circumstances!- Parameters:
- version- version
- API Note:
- internal use only
 
- 
clone
- 
getCanDestroyDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.getData(DataComponentType.Valued)withDataComponentTypes.CAN_BREAKinstead of this.Gets set of materials what given item can destroy inGameMode.ADVENTURE- Returns:
- Set of materials
 
- 
setCanDestroyDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.setData(DataComponentType.Valued, Object)withDataComponentTypes.CAN_BREAKinstead of this.Sets set of materials what given item can destroy inGameMode.ADVENTURE- Parameters:
- canDestroy- Set of materials
 
- 
getCanPlaceOnDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.getData(DataComponentType.Valued)withDataComponentTypes.CAN_PLACE_ONinstead of this.Gets set of materials where given item can be placed on inGameMode.ADVENTURE- Returns:
- Set of materials
 
- 
setCanPlaceOnDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.setData(DataComponentType.Valued, Object)withDataComponentTypes.CAN_PLACE_ONinstead of this.Sets set of materials where given item can be placed on inGameMode.ADVENTURE- Parameters:
- canPlaceOn- Set of materials
 
- 
getDestroyableKeysDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.getData(DataComponentType.Valued)withDataComponentTypes.CAN_BREAKinstead of this.Gets the collection of namespaced keys that the item can destroy inGameMode.ADVENTURE- Returns:
- Set of Namespaced
 
- 
setDestroyableKeys@Deprecated(forRemoval=true, since="1.20.6") void setDestroyableKeys(@NotNull @NotNull Collection<Namespaced> canDestroy) Deprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.setData(DataComponentType.Valued, Object)withDataComponentTypes.CAN_BREAKinstead of this.Sets the collection of namespaced keys that the item can destroy inGameMode.ADVENTURE- Parameters:
- canDestroy- Collection of- Namespaced
 
- 
getPlaceableKeysDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.getData(DataComponentType.Valued)withDataComponentTypes.CAN_PLACE_ONinstead of this.Gets the collection of namespaced keys that the item can be placed on inGameMode.ADVENTURE- Returns:
- Set of Namespaced
 
- 
setPlaceableKeys@Deprecated(forRemoval=true, since="1.20.6") void setPlaceableKeys(@NotNull @NotNull Collection<Namespaced> canPlaceOn) Deprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.setData(DataComponentType.Valued, Object)withDataComponentTypes.CAN_PLACE_ONinstead of this.Sets the set of namespaced keys that the item can be placed on inGameMode.ADVENTURE- Parameters:
- canPlaceOn- Collection of- Namespaced
 
- 
hasPlaceableKeysDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.hasData(DataComponentType)withDataComponentTypes.CAN_PLACE_ONinstead of this.Checks for the existence of any keys that the item can be placed on- Returns:
- true if this item has placeable keys
 
- 
hasDestroyableKeysDeprecated, for removal: This API element is subject to removal in a future version.this API part has been replaced by theItemAdventurePredicateAPI. Please useItemStack.hasData(DataComponentType)withDataComponentTypes.CAN_BREAKinstead of this.Checks for the existence of any keys that the item can destroy- Returns:
- true if this item has destroyable keys
 
 
- 
ItemAdventurePredicateAPI.