diff --git a/paper-api/src/main/java/io/papermc/paper/event/player/PlayerStopUsingItemEvent.java b/paper-api/src/main/java/io/papermc/paper/event/player/PlayerStopUsingItemEvent.java new file mode 100644 index 0000000000..d79b995292 --- /dev/null +++ b/paper-api/src/main/java/io/papermc/paper/event/player/PlayerStopUsingItemEvent.java @@ -0,0 +1,53 @@ +package io.papermc.paper.event.player; + +import org.bukkit.entity.Player; +import org.bukkit.event.HandlerList; +import org.bukkit.event.player.PlayerEvent; +import org.bukkit.inventory.ItemStack; +import org.jspecify.annotations.NullMarked; + +/** + * Called when the server detects a player stopping using an item. + * Examples of this are letting go of the interact button when holding a bow, an edible item, or a spyglass. + */ +@NullMarked +public class PlayerStopUsingItemEvent extends PlayerEvent { + + private static final HandlerList HANDLER_LIST = new HandlerList(); + + private final ItemStack item; + private final int ticksHeldFor; + + public PlayerStopUsingItemEvent(final Player player, final ItemStack item, final int ticksHeldFor) { + super(player); + this.item = item; + this.ticksHeldFor = ticksHeldFor; + } + + /** + * Gets the exact item the player is releasing + * + * @return ItemStack the exact item the player released + */ + public ItemStack getItem() { + return this.item; + } + + /** + * Gets the number of ticks the item was held for + * + * @return int the number of ticks the item was held for + */ + public int getTicksHeldFor() { + return this.ticksHeldFor; + } + + @Override + public HandlerList getHandlers() { + return HANDLER_LIST; + } + + public static HandlerList getHandlerList() { + return HANDLER_LIST; + } +}