diff --git a/paper-api/src/main/java/io/papermc/paper/event/packet/PlayerChunkLoadEvent.java b/paper-api/src/main/java/io/papermc/paper/event/packet/PlayerChunkLoadEvent.java new file mode 100644 index 0000000000..2815c5802e --- /dev/null +++ b/paper-api/src/main/java/io/papermc/paper/event/packet/PlayerChunkLoadEvent.java @@ -0,0 +1,43 @@ +package io.papermc.paper.event.packet; + +import org.bukkit.Chunk; +import org.bukkit.entity.Player; +import org.bukkit.event.HandlerList; +import org.bukkit.event.world.ChunkEvent; +import org.jetbrains.annotations.ApiStatus; +import org.jspecify.annotations.NullMarked; + +/** + * Is called when a {@link Player} receives a {@link Chunk} + *

+ * Can for example be used for spawning a fake entity when the player receives a chunk. + *

+ * Should only be used for packet/clientside related stuff. + * Not intended for modifying server side state. + */ +@NullMarked +public class PlayerChunkLoadEvent extends ChunkEvent { + + private static final HandlerList HANDLER_LIST = new HandlerList(); + + private final Player player; + + @ApiStatus.Internal + public PlayerChunkLoadEvent(final Chunk chunk, final Player player) { + super(chunk); + this.player = player; + } + + public Player getPlayer() { + return this.player; + } + + @Override + public HandlerList getHandlers() { + return HANDLER_LIST; + } + + public static HandlerList getHandlerList() { + return HANDLER_LIST; + } +} diff --git a/paper-api/src/main/java/io/papermc/paper/event/packet/PlayerChunkUnloadEvent.java b/paper-api/src/main/java/io/papermc/paper/event/packet/PlayerChunkUnloadEvent.java new file mode 100644 index 0000000000..3ebb35b680 --- /dev/null +++ b/paper-api/src/main/java/io/papermc/paper/event/packet/PlayerChunkUnloadEvent.java @@ -0,0 +1,41 @@ +package io.papermc.paper.event.packet; + +import org.bukkit.Chunk; +import org.bukkit.entity.Player; +import org.bukkit.event.HandlerList; +import org.bukkit.event.world.ChunkEvent; +import org.jetbrains.annotations.ApiStatus; +import org.jspecify.annotations.NullMarked; + +/** + * Is called when a {@link Player} receives a chunk unload packet. + *

+ * Should only be used for packet/clientside related stuff. + * Not intended for modifying server side. + */ +@NullMarked +public class PlayerChunkUnloadEvent extends ChunkEvent { + + private static final HandlerList HANDLER_LIST = new HandlerList(); + + private final Player player; + + @ApiStatus.Internal + public PlayerChunkUnloadEvent(final Chunk chunk, final Player player) { + super(chunk); + this.player = player; + } + + public Player getPlayer() { + return this.player; + } + + @Override + public HandlerList getHandlers() { + return HANDLER_LIST; + } + + public static HandlerList getHandlerList() { + return HANDLER_LIST; + } +}