From efcb04d7539c01d84217be92d28fe0072c5a71d2 Mon Sep 17 00:00:00 2001
From: Owen1212055 <23108066+Owen1212055@users.noreply.github.com>
Date: Fri, 19 Mar 2021 23:39:21 -0400
Subject: [PATCH] Add ElderGuardianAppearanceEvent

---
 .../entity/ElderGuardianAppearanceEvent.java  | 65 +++++++++++++++++++
 1 file changed, 65 insertions(+)
 create mode 100644 paper-api/src/main/java/io/papermc/paper/event/entity/ElderGuardianAppearanceEvent.java

diff --git a/paper-api/src/main/java/io/papermc/paper/event/entity/ElderGuardianAppearanceEvent.java b/paper-api/src/main/java/io/papermc/paper/event/entity/ElderGuardianAppearanceEvent.java
new file mode 100644
index 0000000000..027e70a108
--- /dev/null
+++ b/paper-api/src/main/java/io/papermc/paper/event/entity/ElderGuardianAppearanceEvent.java
@@ -0,0 +1,65 @@
+package io.papermc.paper.event.entity;
+
+import org.bukkit.entity.ElderGuardian;
+import org.bukkit.entity.Player;
+import org.bukkit.event.Cancellable;
+import org.bukkit.event.HandlerList;
+import org.bukkit.event.entity.EntityEvent;
+import org.jetbrains.annotations.ApiStatus;
+import org.jspecify.annotations.NullMarked;
+
+/**
+ * Is called when an {@link ElderGuardian} appears in front of a {@link Player}.
+ */
+@NullMarked
+public class ElderGuardianAppearanceEvent extends EntityEvent implements Cancellable {
+
+    private static final HandlerList HANDLER_LIST = new HandlerList();
+
+    private final Player affectedPlayer;
+    private boolean cancelled;
+
+    @ApiStatus.Internal
+    public ElderGuardianAppearanceEvent(final ElderGuardian guardian, final Player affectedPlayer) {
+        super(guardian);
+        this.affectedPlayer = affectedPlayer;
+    }
+
+    /**
+     * Get the player affected by the guardian appearance.
+     *
+     * @return Player affected by the appearance
+     */
+    public Player getAffectedPlayer() {
+        return this.affectedPlayer;
+    }
+
+    /**
+     * The elder guardian playing the effect.
+     *
+     * @return The elder guardian
+     */
+    @Override
+    public ElderGuardian getEntity() {
+        return (ElderGuardian) super.getEntity();
+    }
+
+    @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;
+    }
+}