From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Spyridon Pagkalos Date: Thu, 25 Mar 2021 20:25:47 +0200 Subject: [PATCH] Introduce beacon activation/deactivation events diff --git a/src/main/java/io/papermc/paper/event/block/BeaconActivatedEvent.java b/src/main/java/io/papermc/paper/event/block/BeaconActivatedEvent.java new file mode 100644 index 0000000000000000000000000000000000000000..7575ca7dd84dee89528ec2e5e5f99f97d8a10f58 --- /dev/null +++ b/src/main/java/io/papermc/paper/event/block/BeaconActivatedEvent.java @@ -0,0 +1,40 @@ +package io.papermc.paper.event.block; + +import org.bukkit.block.Beacon; +import org.bukkit.block.Block; +import org.bukkit.event.HandlerList; +import org.bukkit.event.block.BlockEvent; +import org.jetbrains.annotations.NotNull; + +/** + * Called when a beacon is activated. + * Activation occurs when the beacon beam becomes visible. + */ +public class BeaconActivatedEvent extends BlockEvent { + private static final HandlerList handlers = new HandlerList(); + + public BeaconActivatedEvent(@NotNull Block block) { + super(block); + } + + /** + * Returns the beacon that was activated. + * + * @return the beacon that was activated. + */ + @NotNull + public Beacon getBeacon() { + return (Beacon) block.getState(); + } + + @NotNull + @Override + public HandlerList getHandlers() { + return handlers; + } + + @NotNull + public static HandlerList getHandlerList() { + return handlers; + } +} diff --git a/src/main/java/io/papermc/paper/event/block/BeaconDeactivatedEvent.java b/src/main/java/io/papermc/paper/event/block/BeaconDeactivatedEvent.java new file mode 100644 index 0000000000000000000000000000000000000000..46fd5eac7b6b1eb73016fdc1dfd97aa752450496 --- /dev/null +++ b/src/main/java/io/papermc/paper/event/block/BeaconDeactivatedEvent.java @@ -0,0 +1,43 @@ +package io.papermc.paper.event.block; + +import org.bukkit.block.Beacon; +import org.bukkit.block.Block; +import org.bukkit.block.BlockType; +import org.bukkit.event.HandlerList; +import org.bukkit.event.block.BlockEvent; +import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; + +/** + * Called when a beacon is deactivated, either because its base block(s) or itself were destroyed. + */ +public class BeaconDeactivatedEvent extends BlockEvent { + private static final HandlerList HANDLER_LIST = new HandlerList(); + + public BeaconDeactivatedEvent(@NotNull Block block) { + super(block); + } + + /** + * Returns the beacon that was deactivated. + * This will return null if the beacon does not exist. + * (which can occur after the deactivation of a now broken beacon) + * + * @return The beacon that got deactivated, or null if it does not exist. + */ + @Nullable + public Beacon getBeacon() { + return this.block.getType() == BlockType.BEACON ? (Beacon) this.block.getState() : null; + } + + @NotNull + @Override + public HandlerList getHandlers() { + return HANDLER_LIST; + } + + @NotNull + public static HandlerList getHandlerList() { + return HANDLER_LIST; + } +}