mirror of
https://github.com/TotalFreedomMC/TF-EssentialsX.git
synced 2024-12-31 20:42:17 +00:00
Add UserTeleportSpawnEvent (#4328)
Co-authored-by: Josh Roy <10731363+JRoy@users.noreply.github.com>
This commit is contained in:
parent
2858bd3784
commit
3787b80286
2 changed files with 83 additions and 1 deletions
|
@ -7,6 +7,7 @@ import com.earth2me.essentials.User;
|
||||||
import com.earth2me.essentials.commands.EssentialsCommand;
|
import com.earth2me.essentials.commands.EssentialsCommand;
|
||||||
import com.earth2me.essentials.commands.NoChargeException;
|
import com.earth2me.essentials.commands.NoChargeException;
|
||||||
import com.earth2me.essentials.commands.NotEnoughArgumentsException;
|
import com.earth2me.essentials.commands.NotEnoughArgumentsException;
|
||||||
|
import net.essentialsx.api.v2.events.UserTeleportSpawnEvent;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.Server;
|
import org.bukkit.Server;
|
||||||
import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause;
|
import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause;
|
||||||
|
@ -38,7 +39,7 @@ public class Commandspawn extends EssentialsCommand {
|
||||||
});
|
});
|
||||||
respawn(user.getSource(), user, otherUser, charge, commandLabel, future);
|
respawn(user.getSource(), user, otherUser, charge, commandLabel, future);
|
||||||
} else {
|
} else {
|
||||||
respawn(user.getSource(), user, user, charge, commandLabel, new CompletableFuture<>());
|
respawn(user.getSource(), null, user, charge, commandLabel, new CompletableFuture<>());
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new NoChargeException();
|
throw new NoChargeException();
|
||||||
|
@ -77,6 +78,11 @@ public class Commandspawn extends EssentialsCommand {
|
||||||
showError(sender.getSender(), e, commandLabel);
|
showError(sender.getSender(), e, commandLabel);
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
|
final UserTeleportSpawnEvent spawnEvent = new UserTeleportSpawnEvent(teleportee, teleportOwner, teleportee.getGroup(), spawn);
|
||||||
|
ess.getServer().getPluginManager().callEvent(spawnEvent);
|
||||||
|
if (spawnEvent.isCancelled()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (teleportOwner == null) {
|
if (teleportOwner == null) {
|
||||||
teleportee.getAsyncTeleport().now(spawn, false, TeleportCause.COMMAND, future);
|
teleportee.getAsyncTeleport().now(spawn, false, TeleportCause.COMMAND, future);
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -0,0 +1,76 @@
|
||||||
|
package net.essentialsx.api.v2.events;
|
||||||
|
|
||||||
|
import net.ess3.api.IUser;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.event.Cancellable;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called before a user is teleported to spawn via the /spawn command.
|
||||||
|
*/
|
||||||
|
public class UserTeleportSpawnEvent extends Event implements Cancellable {
|
||||||
|
private static final HandlerList handlers = new HandlerList();
|
||||||
|
|
||||||
|
private final IUser user;
|
||||||
|
private final IUser controller;
|
||||||
|
private final String spawnGroup;
|
||||||
|
private final Location target;
|
||||||
|
private boolean cancelled = false;
|
||||||
|
|
||||||
|
public UserTeleportSpawnEvent(final IUser user, final IUser controller, final String spawnGroup, final Location target) {
|
||||||
|
this.user = user;
|
||||||
|
this.controller = controller;
|
||||||
|
this.spawnGroup = spawnGroup;
|
||||||
|
this.target = target;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return The user who is being teleported to spawn.
|
||||||
|
*/
|
||||||
|
public IUser getUser() {
|
||||||
|
return user;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return The user who caused teleport to spawn or null if there is none
|
||||||
|
*/
|
||||||
|
public IUser getController() {
|
||||||
|
return controller;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The {@link #getUser() user's} group used to determine their spawn location.
|
||||||
|
* @return The user's group.
|
||||||
|
*/
|
||||||
|
public String getSpawnGroup() {
|
||||||
|
return spawnGroup;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The spawn location of the {@link #getUser() user's} {@link #getSpawnGroup() group}.
|
||||||
|
* @return The spawn location of the user's group.
|
||||||
|
*/
|
||||||
|
public Location getSpawnLocation() {
|
||||||
|
return target;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isCancelled() {
|
||||||
|
return cancelled;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setCancelled(final boolean cancelled) {
|
||||||
|
this.cancelled = cancelled;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlers;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static HandlerList getHandlerList() {
|
||||||
|
return handlers;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue