mirror of
https://github.com/BentoBoxWorld/Boxed.git
synced 2025-01-21 21:01:56 +01:00
Fixes enderpearl usage and flags
https://github.com/BentoBoxWorld/Boxed/issues/50
This commit is contained in:
parent
9d9b4ca3fb
commit
48284c92d7
@ -2,8 +2,10 @@ package world.bentobox.boxed.listeners;
|
|||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import org.bukkit.GameMode;
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.Sound;
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.World;
|
||||||
import org.bukkit.block.BlockFace;
|
import org.bukkit.block.BlockFace;
|
||||||
import org.bukkit.entity.EnderPearl;
|
import org.bukkit.entity.EnderPearl;
|
||||||
import org.bukkit.entity.EntityType;
|
import org.bukkit.entity.EntityType;
|
||||||
@ -12,8 +14,11 @@ import org.bukkit.event.EventHandler;
|
|||||||
import org.bukkit.event.EventPriority;
|
import org.bukkit.event.EventPriority;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.entity.ProjectileHitEvent;
|
import org.bukkit.event.entity.ProjectileHitEvent;
|
||||||
|
import org.bukkit.event.player.PlayerTeleportEvent;
|
||||||
|
|
||||||
import world.bentobox.bentobox.api.user.User;
|
import world.bentobox.bentobox.api.user.User;
|
||||||
|
import world.bentobox.bentobox.database.objects.Island;
|
||||||
|
import world.bentobox.bentobox.util.Util;
|
||||||
import world.bentobox.boxed.Boxed;
|
import world.bentobox.boxed.Boxed;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -32,34 +37,100 @@ public class EnderPearlListener implements Listener {
|
|||||||
this.addon = addon;
|
this.addon = addon;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)
|
||||||
|
public void onPlayerTeleport(PlayerTeleportEvent e) {
|
||||||
|
if (!addon.inWorld(e.getFrom()) || !e.getPlayer().getGameMode().equals(GameMode.SURVIVAL)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
User u = User.getInstance(e.getPlayer());
|
||||||
|
// If the to is outside the box, cancel it
|
||||||
|
if (e.getTo() != null) {
|
||||||
|
Island i = addon.getIslands().getIsland(e.getFrom().getWorld(), u);
|
||||||
|
if (i == null || !i.onIsland(e.getTo())) {
|
||||||
|
u.sendMessage("boxed.general.errors.no-teleport-outside");
|
||||||
|
e.setCancelled(true);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.NORMAL, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.NORMAL, ignoreCancelled = true)
|
||||||
public void onEnderPearlLand(ProjectileHitEvent e) {
|
public void onEnderPearlLand(ProjectileHitEvent e) {
|
||||||
if (!e.getEntityType().equals(EntityType.ENDER_PEARL)
|
if (!e.getEntityType().equals(EntityType.ENDER_PEARL)
|
||||||
|| e.getHitBlock() == null
|
|| e.getHitBlock() == null
|
||||||
|| !addon.inWorld(e.getHitBlock().getLocation())) {
|
|| !addon.inWorld(e.getHitBlock().getLocation())
|
||||||
|
|| !Boxed.ALLOW_MOVE_BOX.isSetForWorld(e.getHitBlock().getWorld())
|
||||||
|
) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
// Moving box is allowed
|
||||||
Location l = e.getHitBlock().getRelative(BlockFace.UP).getLocation();
|
Location l = e.getHitBlock().getRelative(BlockFace.UP).getLocation();
|
||||||
|
World w = e.getHitBlock().getWorld();
|
||||||
EnderPearl ep = (EnderPearl)e.getEntity();
|
EnderPearl ep = (EnderPearl)e.getEntity();
|
||||||
if (ep.getShooter() instanceof Player player) {
|
if (ep.getShooter() instanceof Player player) {
|
||||||
User u = User.getInstance(player);
|
User u = User.getInstance(player);
|
||||||
|
// Check if enderpearl is inside or outside the box
|
||||||
|
// Get user's box
|
||||||
|
Island is = addon.getIslands().getIsland(w, u);
|
||||||
|
if (is == null) {
|
||||||
|
return; // Nothing to do
|
||||||
|
}
|
||||||
|
// Get the box that the player is in
|
||||||
|
addon.getIslands().getIslandAt(u.getLocation()).ifPresent(fromIsland -> {
|
||||||
|
// Check that it is their box
|
||||||
|
if (!is.getUniqueId().equals(fromIsland.getUniqueId())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// Find where the pearl landed
|
||||||
|
addon.getIslands().getIslandAt(l).ifPresentOrElse(toIsland -> {
|
||||||
|
if (fromIsland.getUniqueId().equals(toIsland.getUniqueId())) {
|
||||||
|
if (!toIsland.onIsland(l)) {
|
||||||
|
// Moving is allowed
|
||||||
|
moveBox(u, fromIsland, l);
|
||||||
|
Util.teleportAsync(player, l);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// Different island. This is never allowed. Cancel the throw
|
||||||
|
e.setCancelled(true);
|
||||||
|
u.sendMessage("boxed.general.errors.no-teleport-outside");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}, () -> {
|
||||||
|
// No island. This is never allowed. Cancel the throw
|
||||||
|
e.setCancelled(true);
|
||||||
|
u.sendMessage("boxed.general.errors.no-teleport-outside");
|
||||||
|
return;
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
addon.getIslands().getIslandAt(l).ifPresent(i -> {
|
addon.getIslands().getIslandAt(l).ifPresent(i -> {
|
||||||
// Check flag
|
// Check flag
|
||||||
if (i.isAllowed(u, Boxed.MOVE_BOX) && addon.getIslands().isSafeLocation(l)) {
|
if (i.isAllowed(u, Boxed.MOVE_BOX) && addon.getIslands().isSafeLocation(l)) {
|
||||||
// Reset home locations
|
|
||||||
i.getMemberSet().forEach(uuid -> addon.getIslands().setHomeLocation(uuid, l));
|
|
||||||
try {
|
|
||||||
i.setProtectionCenter(l);
|
|
||||||
i.setSpawnPoint(l.getWorld().getEnvironment(), l);
|
|
||||||
u.getPlayer().playSound(l, Sound.ENTITY_GENERIC_EXPLODE, 2F, 2F);
|
|
||||||
} catch (IOException e1) {
|
|
||||||
addon.logError("Could not move box " + e1.getMessage());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
private void moveBox(User u, Island fromIsland, Location l) {
|
||||||
|
// Reset home locations
|
||||||
|
fromIsland.getMemberSet().forEach(uuid -> addon.getIslands().setHomeLocation(uuid, l));
|
||||||
|
try {
|
||||||
|
fromIsland.setProtectionCenter(l);
|
||||||
|
fromIsland.setSpawnPoint(l.getWorld().getEnvironment(), l);
|
||||||
|
u.getPlayer().playSound(l, Sound.ENTITY_GENERIC_EXPLODE, 2F, 2F);
|
||||||
|
} catch (IOException e1) {
|
||||||
|
addon.logError("Could not move box " + e1.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -15,6 +15,7 @@ boxed:
|
|||||||
already-have-island: '&c You already have a box!'
|
already-have-island: '&c You already have a box!'
|
||||||
no-safe-location: '&c No safe location found in box!'
|
no-safe-location: '&c No safe location found in box!'
|
||||||
not-owner: '&c You are not the owner of your team!'
|
not-owner: '&c You are not the owner of your team!'
|
||||||
|
no-teleport-outside: "&c You cannot teleport outside of your box"
|
||||||
commands:
|
commands:
|
||||||
boxed:
|
boxed:
|
||||||
help:
|
help:
|
||||||
@ -305,6 +306,12 @@ boxed:
|
|||||||
deleted-island: '&a Area at &e [xyz] &a has been successfully regenerated.'
|
deleted-island: '&a Area at &e [xyz] &a has been successfully regenerated.'
|
||||||
protection:
|
protection:
|
||||||
flags:
|
flags:
|
||||||
|
ALLOW_MOVE_BOX:
|
||||||
|
name: Box moving
|
||||||
|
description: |-
|
||||||
|
&a Allow players to move
|
||||||
|
&a their box by throwing
|
||||||
|
&a enderpearls
|
||||||
ELYTRA:
|
ELYTRA:
|
||||||
description: Toggle use
|
description: Toggle use
|
||||||
ENDERMAN_GRIEFING:
|
ENDERMAN_GRIEFING:
|
||||||
|
Loading…
Reference in New Issue
Block a user