2018-10-31 14:32:21 +01:00
|
|
|
package world.bentobox.warps;
|
2017-10-26 03:33:23 +02:00
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
|
2018-05-29 00:42:03 +02:00
|
|
|
import java.util.HashSet;
|
|
|
|
import java.util.Set;
|
2018-09-28 06:01:46 +02:00
|
|
|
import java.util.UUID;
|
2018-05-29 00:42:03 +02:00
|
|
|
|
2019-04-30 08:23:54 +02:00
|
|
|
import org.bukkit.World;
|
|
|
|
|
2019-01-16 21:46:39 +01:00
|
|
|
import world.bentobox.bentobox.api.addons.Addon;
|
2019-01-31 19:25:32 +01:00
|
|
|
import world.bentobox.bentobox.api.configuration.Config;
|
2019-01-16 21:46:39 +01:00
|
|
|
import world.bentobox.bentobox.util.Util;
|
2018-10-31 14:32:21 +01:00
|
|
|
import world.bentobox.level.Level;
|
|
|
|
import world.bentobox.warps.commands.WarpCommand;
|
|
|
|
import world.bentobox.warps.commands.WarpsCommand;
|
2019-01-31 19:25:32 +01:00
|
|
|
import world.bentobox.warps.config.Settings;
|
2017-10-26 03:33:23 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Addin to BSkyBlock that enables welcome warp signs
|
|
|
|
* @author tastybento
|
|
|
|
*
|
|
|
|
*/
|
2017-12-31 06:15:47 +01:00
|
|
|
public class Warp extends Addon {
|
2019-04-30 08:23:54 +02:00
|
|
|
// ---------------------------------------------------------------------
|
|
|
|
// Section: Variables
|
|
|
|
// ---------------------------------------------------------------------
|
2017-10-26 03:33:23 +02:00
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
/**
|
|
|
|
* This variable stores string for Level addon.
|
|
|
|
*/
|
2018-10-31 14:32:21 +01:00
|
|
|
private static final String LEVEL_ADDON_NAME = "Level";
|
2018-01-01 20:49:02 +01:00
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
/**
|
|
|
|
* Warp panel Manager
|
|
|
|
*/
|
2017-12-31 06:15:47 +01:00
|
|
|
private WarpPanelManager warpPanelManager;
|
2017-10-26 03:33:23 +02:00
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
/**
|
|
|
|
* Worlds Sign manager.
|
|
|
|
*/
|
2017-12-31 06:15:47 +01:00
|
|
|
private WarpSignsManager warpSignsManager;
|
2017-10-26 03:33:23 +02:00
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
/**
|
|
|
|
* This variable stores in which worlds this addon is working.
|
|
|
|
*/
|
2018-05-29 00:42:03 +02:00
|
|
|
private Set<World> registeredWorlds;
|
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
/**
|
|
|
|
* This variable stores if addon settings.
|
|
|
|
*/
|
|
|
|
private Settings settings;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This variable stores if addon is hooked or not.
|
|
|
|
*/
|
|
|
|
private boolean hooked;
|
|
|
|
|
2019-04-30 08:23:54 +02:00
|
|
|
// ---------------------------------------------------------------------
|
|
|
|
// Section: Methods
|
|
|
|
// ---------------------------------------------------------------------
|
2019-01-31 19:25:32 +01:00
|
|
|
|
2018-08-01 04:48:13 +02:00
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
/**
|
|
|
|
* Executes code when loading the addon. This is called before {@link #onEnable()}. This should preferably
|
|
|
|
* be used to setup configuration and worlds.
|
|
|
|
*/
|
2017-10-26 03:33:23 +02:00
|
|
|
@Override
|
2019-01-31 19:25:32 +01:00
|
|
|
public void onLoad()
|
|
|
|
{
|
|
|
|
super.onLoad();
|
|
|
|
// Save default config.yml
|
|
|
|
this.saveDefaultConfig();
|
2017-10-26 03:33:23 +02:00
|
|
|
// Load the plugin's config
|
2019-01-31 19:25:32 +01:00
|
|
|
this.loadSettings();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes code when reloading the addon.
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public void onReload()
|
|
|
|
{
|
|
|
|
super.onReload();
|
|
|
|
|
|
|
|
if (this.hooked) {
|
|
|
|
this.warpSignsManager.saveWarpList();
|
|
|
|
|
|
|
|
this.loadSettings();
|
|
|
|
this.getLogger().info("WelcomeWarp addon reloaded.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onEnable() {
|
2017-10-26 03:33:23 +02:00
|
|
|
// Check if it is enabled - it might be loaded, but not enabled.
|
2019-01-31 19:25:32 +01:00
|
|
|
if (!this.getPlugin().isEnabled()) {
|
2018-10-31 02:12:30 +01:00
|
|
|
this.setState(State.DISABLED);
|
2017-10-26 03:33:23 +02:00
|
|
|
return;
|
|
|
|
}
|
2019-01-31 19:25:32 +01:00
|
|
|
|
2018-08-18 06:58:56 +02:00
|
|
|
registeredWorlds = new HashSet<>();
|
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
// Register commands
|
|
|
|
this.getPlugin().getAddonsManager().getGameModeAddons().forEach(gameModeAddon -> {
|
|
|
|
if (!this.settings.getDisabledGameModes().contains(gameModeAddon.getDescription().getName()))
|
|
|
|
{
|
|
|
|
if (gameModeAddon.getPlayerCommand().isPresent())
|
|
|
|
{
|
|
|
|
this.registeredWorlds.add(gameModeAddon.getOverWorld());
|
|
|
|
|
|
|
|
new WarpCommand(this, gameModeAddon.getPlayerCommand().get());
|
|
|
|
new WarpsCommand(this, gameModeAddon.getPlayerCommand().get());
|
|
|
|
this.hooked = true;
|
|
|
|
}
|
|
|
|
}
|
2017-10-27 00:58:58 +02:00
|
|
|
});
|
2019-01-31 19:25:32 +01:00
|
|
|
|
|
|
|
if (hooked)
|
|
|
|
{
|
|
|
|
// Start warp signs
|
|
|
|
warpSignsManager = new WarpSignsManager(this, this.getPlugin());
|
|
|
|
warpPanelManager = new WarpPanelManager(this);
|
|
|
|
// Load the listener
|
|
|
|
getServer().getPluginManager().registerEvents(new WarpSignsListener(this), this.getPlugin());
|
|
|
|
}
|
2017-10-26 03:33:23 +02:00
|
|
|
}
|
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
|
2017-10-26 03:33:23 +02:00
|
|
|
@Override
|
|
|
|
public void onDisable(){
|
|
|
|
// Save the warps
|
2017-12-31 06:15:47 +01:00
|
|
|
if (warpSignsManager != null)
|
|
|
|
warpSignsManager.saveWarpList();
|
2017-10-26 03:33:23 +02:00
|
|
|
}
|
|
|
|
|
2019-01-31 19:25:32 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This method loads addon configuration settings in memory.
|
|
|
|
*/
|
|
|
|
private void loadSettings() {
|
|
|
|
this.settings = new Config<>(this, Settings.class).loadConfigObject();
|
|
|
|
|
|
|
|
if (this.settings == null) {
|
|
|
|
// Disable
|
|
|
|
this.logError("WelcomeWarp settings could not load! Addon disabled.");
|
|
|
|
this.setState(State.DISABLED);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-10-26 03:33:23 +02:00
|
|
|
/**
|
2017-12-31 06:15:47 +01:00
|
|
|
* Get warp panel manager
|
|
|
|
* @return
|
2017-10-26 03:33:23 +02:00
|
|
|
*/
|
2017-12-31 06:15:47 +01:00
|
|
|
public WarpPanelManager getWarpPanelManager() {
|
|
|
|
return warpPanelManager;
|
2017-10-26 03:33:23 +02:00
|
|
|
}
|
2018-01-01 20:49:02 +01:00
|
|
|
|
2017-12-31 06:15:47 +01:00
|
|
|
public WarpSignsManager getWarpSignsManager() {
|
|
|
|
return warpSignsManager;
|
2017-10-26 03:33:23 +02:00
|
|
|
}
|
|
|
|
|
2018-05-29 00:42:03 +02:00
|
|
|
public String getPermPrefix(World world) {
|
2018-09-01 21:55:55 +02:00
|
|
|
return this.getPlugin().getIWM().getPermissionPrefix(world);
|
2018-05-29 00:42:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if an event is in a registered world
|
|
|
|
* @param world - world to check
|
|
|
|
* @return true if it is
|
|
|
|
*/
|
|
|
|
public boolean inRegisteredWorld(World world) {
|
|
|
|
return registeredWorlds.contains(Util.getWorld(world));
|
|
|
|
}
|
|
|
|
|
2018-08-01 04:48:13 +02:00
|
|
|
/**
|
|
|
|
* @return the settings
|
|
|
|
*/
|
2019-01-31 19:25:32 +01:00
|
|
|
public Settings getSettings() {
|
2018-08-01 04:48:13 +02:00
|
|
|
return settings;
|
|
|
|
}
|
|
|
|
|
2018-09-28 06:01:46 +02:00
|
|
|
/**
|
|
|
|
* Get the island level
|
|
|
|
* @param world - world
|
|
|
|
* @param uniqueId - player's UUID
|
|
|
|
* @return island level or null if there is no level plugin
|
|
|
|
*/
|
|
|
|
public Long getLevel(World world, UUID uniqueId) {
|
2019-01-31 19:25:32 +01:00
|
|
|
return this.getPlugin().getAddonsManager().getAddonByName(LEVEL_ADDON_NAME).map(l -> ((Level) l).getIslandLevel(world, uniqueId)).orElse(null);
|
2018-09-28 06:01:46 +02:00
|
|
|
}
|
|
|
|
|
2017-10-26 03:33:23 +02:00
|
|
|
}
|