From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: BillyGalbreath Date: Sat, 21 Jul 2018 01:59:53 -0500 Subject: [PATCH] PlayerElytraBoostEvent diff --git a/src/main/java/com/destroystokyo/paper/event/player/PlayerElytraBoostEvent.java b/src/main/java/com/destroystokyo/paper/event/player/PlayerElytraBoostEvent.java new file mode 100644 index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 --- /dev/null +++ b/src/main/java/com/destroystokyo/paper/event/player/PlayerElytraBoostEvent.java @@ -0,0 +0,0 @@ +package com.destroystokyo.paper.event.player; + +import org.bukkit.entity.Firework; +import org.bukkit.entity.Player; +import org.bukkit.event.Cancellable; +import org.bukkit.event.HandlerList; +import org.bukkit.event.player.PlayerEvent; +import org.bukkit.inventory.EquipmentSlot; +import org.bukkit.inventory.ItemStack; +import org.jetbrains.annotations.ApiStatus; +import org.jetbrains.annotations.NotNull; + +/** + * Fired when a player boosts elytra flight with a firework + */ +public class PlayerElytraBoostEvent extends PlayerEvent implements Cancellable { + + private static final HandlerList HANDLER_LIST = new HandlerList(); + + @NotNull private final ItemStack itemStack; + @NotNull private final Firework firework; + private boolean consume = true; + @NotNull + private final EquipmentSlot hand; + + private boolean cancelled; + + @ApiStatus.Internal + public PlayerElytraBoostEvent(@NotNull Player player, @NotNull ItemStack itemStack, @NotNull Firework firework, @NotNull EquipmentSlot hand) { + super(player); + this.itemStack = itemStack; + this.firework = firework; + this.hand = hand; + } + + /** + * Get the firework itemstack used + * + * @return ItemStack of firework + */ + @NotNull + public ItemStack getItemStack() { + return this.itemStack; + } + + /** + * Get the firework entity that was spawned + * + * @return Firework entity + */ + @NotNull + public Firework getFirework() { + return this.firework; + } + + /** + * Get whether to consume the firework or not + * + * @return {@code true} to consume + */ + public boolean shouldConsume() { + return this.consume; + } + + /** + * Set whether to consume the firework or not + * + * @param consume {@code true} to consume + */ + public void setShouldConsume(boolean consume) { + this.consume = consume; + } + + /** + * Gets the hand holding the firework used for boosting this player. + * + * @return interaction hand + */ + @NotNull + public EquipmentSlot getHand() { + return this.hand; + } + + @Override + public boolean isCancelled() { + return this.cancelled; + } + + @Override + public void setCancelled(boolean cancel) { + this.cancelled = cancel; + } + + @NotNull + @Override + public HandlerList getHandlers() { + return HANDLER_LIST; + } + + @NotNull + public static HandlerList getHandlerList() { + return HANDLER_LIST; + } +}