ItemAttributeModifierEvent

This event is fired when the attributes for an ItemStack are being calculated. Attributes are calculated on the server when equipping and un-equipping an item to add and remove attributes respectively, both must be consistent. Attributes are calculated on the client when rendering an item’s tooltip to show relevant attributes.

The event is not cancelable.

The event does not have a result.

Importing the class

It might be required for you to import the package if you encounter any issues (like casting an Array), so better be safe than sorry and add the import at the very top of the file.

script.zs
import crafttweaker.api.event.ItemAttributeModifierEvent;

Extending Event

ItemAttributeModifierEvent extends Event. That means all methods available in Event are also available in ItemAttributeModifierEvent

Methods

Adds a new AttributeModifier to the ItemStack.

Returns: True if the modifier was added. False otherwise.
Return Type: boolean

script.zs
// ItemAttributeModifierEvent.addModifier(attribute as Attribute, name as string, value as double, operation as AttributeOperation) as boolean
myItemAttributeModifierEvent.addModifier(<attribute:minecraft:generic.attack_damage>, "Extra Power", 10, AttributeOperation.ADDITION);
ParameterTypeDescription
Parameter
attribute
Type
Attribute
Description
The Attribute to add.
Parameter
name
Type
string
Description
The name of the modifier to add
Parameter
value
Type
double
Description
The value of the modifier.
Parameter
operation
Type
AttributeOperation
Description
The operation of the modifier.

Adds a new AttributeModifier to the ItemStack.

Returns: True if the modifier was added. False otherwise.
Return Type: boolean

script.zs
// ItemAttributeModifierEvent.addModifier(attribute as Attribute, uuid as string, name as string, value as double, operation as AttributeOperation) as boolean
myItemAttributeModifierEvent.addModifier(<attribute:minecraft:generic.attack_damage>, "8c1b5535-9f79-448b-87ae-52d81480aaa3", "Extra Power", 10, AttributeOperation.ADDITION);
ParameterTypeDescription
Parameter
attribute
Type
Attribute
Description
The Attribute to add.
Parameter
uuid
Type
string
Description
The UUID of the modifier.
Parameter
name
Type
string
Description
The name of the modifier.
Parameter
value
Type
double
Description
The value of the modifier.
Parameter
operation
Type
AttributeOperation
Description
The operation of the modifier.

Clears all AttributeModifiers from the ItemStack.

script.zs
// ItemAttributeModifierEvent.clearModifiers()
myItemAttributeModifierEvent.clearModifiers();

Gets the ItemStack that this event is being ran for.

Returns: The ItemStack this event is being ran for.
Return Type: IItemStack

script.zs
// ItemAttributeModifierEvent.getItemStack() as IItemStack
myItemAttributeModifierEvent.getItemStack();

Gets the modifiers on the ItemStack

Returns: A Map of Attribute to a List of AttributeModifier.
Return Type: stdlib.List<AttributeModifier>[Attribute]

script.zs
// ItemAttributeModifierEvent.getModifiers() as stdlib.List<AttributeModifier>[Attribute]
myItemAttributeModifierEvent.getModifiers();

Gets the original modifiers on the ItemStack before being changed by any other event listener.

Returns: A Map of Attribute to a List of AttributeModifier.
Return Type: stdlib.List<AttributeModifier>[Attribute]

script.zs
// ItemAttributeModifierEvent.getOriginalModifiers() as stdlib.List<AttributeModifier>[Attribute]
myItemAttributeModifierEvent.getOriginalModifiers();

Gets the EquipmentSlotType that this event is being ran for.

If you only want to add / remove a modifier from a specific slot, you can use this to filter based on the slot.

Returns: The EquipmentSlotType of this event.
Return Type: EquipmentSlot

script.zs
// ItemAttributeModifierEvent.getSlotType() as EquipmentSlot
myItemAttributeModifierEvent.getSlotType();

Removes an Attribute from the ItemStack.

Returns: A List of the AttributeModifiers for the removed Attribute.
Return Type: stdlib.List<AttributeModifier>

script.zs
// ItemAttributeModifierEvent.removeAttribute(attribute as Attribute) as stdlib.List<AttributeModifier>
myItemAttributeModifierEvent.removeAttribute(<attribute:minecraft:generic.attack_damage>);
ParameterTypeDescription
Parameter
attribute
Type
Attribute
Description
The Attribute to remove.

Removes an AttributeModifier from the ItemStack.

Returns: True if the modifier was remove. False otherwise.
Return Type: boolean

script.zs
// ItemAttributeModifierEvent.removeModifier(attribute as Attribute, modifier as AttributeModifier) as boolean
myItemAttributeModifierEvent.removeModifier(<attribute:minecraft:generic.attack_damage>, modifier);
ParameterTypeDescription
Parameter
attribute
Type
Attribute
Description
The Attribute to remove.
Parameter
modifier
Type
AttributeModifier
Description
The modifier to remove.

Removes an AttributeModifier from the ItemStack based on the modifier’s UUID.

Returns: True if the modifier was remove. False otherwise.
Return Type: boolean

script.zs
// ItemAttributeModifierEvent.removeModifier(attribute as Attribute, uuid as string) as boolean
myItemAttributeModifierEvent.removeModifier(<attribute:minecraft:generic.attack_damage>, "8c1b5535-9f79-448b-87ae-52d81480aaa3");
ParameterTypeDescription
Parameter
attribute
Type
Attribute
Description
The Attribute to remove.
Parameter
uuid
Type
string
Description
The UUID of the modifier.

Properties

NameTypeHas GetterHas SetterDescription
Name
itemstack
Type
IItemStack
Has Getter
true
Has Setter
false
Description
Gets the ItemStack that this event is being ran for.
Name
modifiers
Type
stdlib.List<AttributeModifier>[Attribute]
Has Getter
true
Has Setter
false
Description
Gets the modifiers on the ItemStack
Name
originalModifiers
Type
stdlib.List<AttributeModifier>[Attribute]
Has Getter
true
Has Setter
false
Description
Gets the original modifiers on the ItemStack before being changed by any other event listener.
Name
slotType
Type
EquipmentSlot
Has Getter
true
Has Setter
false
Description
Gets the EquipmentSlotType that this event is being ran for.

If you only want to add / remove a modifier from a specific slot, you can use this to filter based on the slot.