From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Alvinn8 <42838560+Alvinn8@users.noreply.github.com> Date: Fri, 8 Jan 2021 20:29:58 +0100 Subject: [PATCH] Add Adventure message to PlayerAdvancementDoneEvent diff --git a/src/main/java/org/bukkit/event/player/PlayerAdvancementDoneEvent.java b/src/main/java/org/bukkit/event/player/PlayerAdvancementDoneEvent.java index 21ff095afb434d15babcdbe85fa0b94cbb7e75a7..6f618bb140a901c5c1cd08210978a6a651677ba4 100644 --- a/src/main/java/org/bukkit/event/player/PlayerAdvancementDoneEvent.java +++ b/src/main/java/org/bukkit/event/player/PlayerAdvancementDoneEvent.java @@ -4,6 +4,10 @@ import org.bukkit.advancement.Advancement; import org.bukkit.entity.Player; import org.bukkit.event.HandlerList; import org.jetbrains.annotations.NotNull; +// Paper start +import org.jetbrains.annotations.Nullable; +import net.kyori.adventure.text.Component; +// Paper end /** * Called when a player has completed all criteria in an advancement. @@ -13,10 +17,17 @@ public class PlayerAdvancementDoneEvent extends PlayerEvent { private static final HandlerList handlers = new HandlerList(); // private final Advancement advancement; + private Component message; // Paper - Add Adventure message public PlayerAdvancementDoneEvent(@NotNull Player who, @NotNull Advancement advancement) { + // Paper start - Add Adventure message + this(who, advancement, null); + } + public PlayerAdvancementDoneEvent(@NotNull Player who, @NotNull Advancement advancement, @Nullable Component message) { + // Paper end super(who); this.advancement = advancement; + this.message = message; // Paper - Add Adventure message } /** @@ -29,6 +40,31 @@ public class PlayerAdvancementDoneEvent extends PlayerEvent { return advancement; } + // Paper start - Add Adventure message + /** + * Gets the message to send to all online players. + * <p> + * Will be null if the advancement does not announce to chat, for example if + * it is a recipe unlock or a root advancement. + * + * @return The announcement message, or null + */ + @Nullable + public Component message() { + return this.message; + } + + /** + * Sets the message to send to all online players. + * <p> + * If set to null the message will not be sent. + * + * @param message The new message + */ + public void message(@Nullable Component message) { + this.message = message; + } + // Paper end @NotNull @Override public HandlerList getHandlers() {