From 1c53b54fd9c7d428bf0437b2912cee672e6a3b11 Mon Sep 17 00:00:00 2001 From: Badbird5907 <50347938+Badbird5907@users.noreply.github.com> Date: Mon, 4 Mar 2024 22:18:33 -0500 Subject: [PATCH] Add BlockBreakProgressUpdateEvent --- .../block/BlockBreakProgressUpdateEvent.java | 57 +++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 paper-api/src/main/java/io/papermc/paper/event/block/BlockBreakProgressUpdateEvent.java diff --git a/paper-api/src/main/java/io/papermc/paper/event/block/BlockBreakProgressUpdateEvent.java b/paper-api/src/main/java/io/papermc/paper/event/block/BlockBreakProgressUpdateEvent.java new file mode 100644 index 0000000000..1820e9b121 --- /dev/null +++ b/paper-api/src/main/java/io/papermc/paper/event/block/BlockBreakProgressUpdateEvent.java @@ -0,0 +1,57 @@ +package io.papermc.paper.event.block; + +import org.bukkit.block.Block; +import org.bukkit.entity.Entity; +import org.bukkit.event.HandlerList; +import org.bukkit.event.block.BlockEvent; +import org.jetbrains.annotations.ApiStatus; +import org.jspecify.annotations.NullMarked; + +/** + * Called when the progress of a block break is updated. + */ +@NullMarked +public class BlockBreakProgressUpdateEvent extends BlockEvent { + + private static final HandlerList HANDLER_LIST = new HandlerList(); + + private final float progress; + private final Entity entity; + + @ApiStatus.Internal + public BlockBreakProgressUpdateEvent(final Block block, final float progress, final Entity entity) { + super(block); + this.progress = progress; + this.entity = entity; + } + + /** + * The progress of the block break + *
+ * The progress ranges from 0.0 - 1.0, where 0 is no damage and + * 1.0 is the most damaged + * + * @return The progress of the block break + */ + public float getProgress() { + return this.progress; + } + + /** + * The entity breaking the block. + * + * @return The entity breaking the block + */ + public Entity getEntity() { + return this.entity; + } + + @Override + public HandlerList getHandlers() { + return HANDLER_LIST; + } + + public static HandlerList getHandlerList() { + return HANDLER_LIST; + } +}