diff --git a/paper-api/src/main/java/com/destroystokyo/paper/event/player/PlayerRecipeBookClickEvent.java b/paper-api/src/main/java/com/destroystokyo/paper/event/player/PlayerRecipeBookClickEvent.java new file mode 100644 index 0000000000..a7becccb2c --- /dev/null +++ b/paper-api/src/main/java/com/destroystokyo/paper/event/player/PlayerRecipeBookClickEvent.java @@ -0,0 +1,87 @@ +package com.destroystokyo.paper.event.player; + +import org.bukkit.NamespacedKey; +import org.bukkit.entity.Player; +import org.bukkit.event.Cancellable; +import org.bukkit.event.HandlerList; +import org.bukkit.event.player.PlayerEvent; +import org.jetbrains.annotations.ApiStatus; +import org.jspecify.annotations.NullMarked; + +/** + * Called when a player clicks a recipe in the recipe book + */ +@NullMarked +public class PlayerRecipeBookClickEvent extends PlayerEvent implements Cancellable { + + private static final HandlerList HANDLER_LIST = new HandlerList(); + + private NamespacedKey recipe; + private boolean makeAll; + + private boolean cancelled; + + @ApiStatus.Internal + public PlayerRecipeBookClickEvent(final Player player, final NamespacedKey recipe, final boolean makeAll) { + super(player); + this.recipe = recipe; + this.makeAll = makeAll; + } + + /** + * Gets the namespaced key of the recipe that was clicked by the player + * + * @return The namespaced key of the recipe + */ + public NamespacedKey getRecipe() { + return this.recipe; + } + + /** + * Changes what recipe is requested. This sets the requested recipe to the recipe with the given key + * + * @param recipe The key of the recipe that should be requested + */ + public void setRecipe(final NamespacedKey recipe) { + this.recipe = recipe; + } + + /** + * Gets a boolean which indicates whether the player requested to make the maximum amount of results. This is + * {@code true} if shift is pressed while the recipe is clicked in the recipe book + * + * @return {@code true} if shift is pressed while the recipe is clicked + */ + public boolean isMakeAll() { + return this.makeAll; + } + + /** + * Sets whether the maximum amount of results should be made. If this is {@code true}, the request is handled as if + * the player had pressed shift while clicking on the recipe + * + * @param makeAll {@code true} if the request should attempt to make the maximum amount of results + */ + public void setMakeAll(final boolean makeAll) { + this.makeAll = makeAll; + } + + @Override + public boolean isCancelled() { + return this.cancelled; + } + + @Override + public void setCancelled(final boolean cancel) { + this.cancelled = cancel; + } + + @Override + public HandlerList getHandlers() { + return HANDLER_LIST; + } + + public static HandlerList getHandlerList() { + return HANDLER_LIST; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/player/PlayerRecipeBookClickEvent.java b/paper-api/src/main/java/org/bukkit/event/player/PlayerRecipeBookClickEvent.java index eb8623184f..a843f73473 100644 --- a/paper-api/src/main/java/org/bukkit/event/player/PlayerRecipeBookClickEvent.java +++ b/paper-api/src/main/java/org/bukkit/event/player/PlayerRecipeBookClickEvent.java @@ -9,7 +9,10 @@ import org.jetbrains.annotations.NotNull; /** * Called when a player clicks a recipe in the recipe book. + * @deprecated use {@link com.destroystokyo.paper.event.player.PlayerRecipeBookClickEvent} */ +@Deprecated(forRemoval = true) // Paper +@org.bukkit.Warning(false) // Paper public class PlayerRecipeBookClickEvent extends PlayerEvent { private static final HandlerList handlers = new HandlerList();