ranks gui
This commit is contained in:
+2
-2
@@ -4,7 +4,7 @@ plugins {
|
||||
}
|
||||
|
||||
group 'sh.okx'
|
||||
version '3.9'
|
||||
version '3.10-alpha'
|
||||
|
||||
repositories {
|
||||
mavenCentral()
|
||||
@@ -28,7 +28,7 @@ dependencies {
|
||||
testImplementation 'com.github.seeseemelk:MockBukkit-v1.15:0.3.0'
|
||||
|
||||
compileOnly 'org.jetbrains:annotations:16.0.2'
|
||||
implementation 'org.spigotmc:spigot-api:1.16.1-R0.1-SNAPSHOT'
|
||||
implementation 'org.spigotmc:spigot-api:1.16.2-R0.1-SNAPSHOT'
|
||||
implementation('com.github.Realizedd:TokenManager:3.2.4') {
|
||||
transitive = false
|
||||
}
|
||||
|
||||
@@ -1,5 +1,11 @@
|
||||
package sh.okx.rankup;
|
||||
|
||||
import java.io.File;
|
||||
import java.text.DecimalFormat;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.function.Supplier;
|
||||
import lombok.Getter;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.ChatColor;
|
||||
@@ -14,7 +20,12 @@ import org.bukkit.plugin.PluginDescriptionFile;
|
||||
import org.bukkit.plugin.PluginManager;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
import org.bukkit.plugin.java.JavaPluginLoader;
|
||||
import sh.okx.rankup.commands.*;
|
||||
import sh.okx.rankup.commands.InfoCommand;
|
||||
import sh.okx.rankup.commands.MaxRankupCommand;
|
||||
import sh.okx.rankup.commands.PrestigeCommand;
|
||||
import sh.okx.rankup.commands.PrestigesCommand;
|
||||
import sh.okx.rankup.commands.RanksCommand;
|
||||
import sh.okx.rankup.commands.RankupCommand;
|
||||
import sh.okx.rankup.economy.Economy;
|
||||
import sh.okx.rankup.economy.EconomyProvider;
|
||||
import sh.okx.rankup.economy.VaultEconomyProvider;
|
||||
@@ -33,31 +44,46 @@ import sh.okx.rankup.prestige.Prestiges;
|
||||
import sh.okx.rankup.ranks.Rank;
|
||||
import sh.okx.rankup.ranks.RankList;
|
||||
import sh.okx.rankup.ranks.Rankups;
|
||||
import sh.okx.rankup.ranksgui.RanksGuiManager;
|
||||
import sh.okx.rankup.ranksgui.RanksGuiCommand;
|
||||
import sh.okx.rankup.ranksgui.RanksGuiListener;
|
||||
import sh.okx.rankup.requirements.Requirement;
|
||||
import sh.okx.rankup.requirements.RequirementRegistry;
|
||||
import sh.okx.rankup.requirements.requirement.AdvancementRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.BlockBreakRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.CraftItemRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.GroupRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.ItemDeductibleRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.ItemRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.MobKillsRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.MoneyDeductibleRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.MoneyRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.PermissionRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.PlaceholderRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.PlayerKillsRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.PlaytimeMinutesRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.TotalMobKillsRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.UseItemRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.WorldRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.XpLevelDeductibleRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.*;
|
||||
import sh.okx.rankup.requirements.requirement.XpLevelRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.advancedachievements.AdvancedAchievementsAchievementRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.advancedachievements.AdvancedAchievementsTotalRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.mcmmo.McMMOPowerLevelRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.mcmmo.McMMOSkillRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.tokenmanager.TokensDeductibleRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.tokenmanager.TokensRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.towny.*;
|
||||
import sh.okx.rankup.requirements.requirement.towny.TownyKingNumberResidentsRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.towny.TownyKingNumberTownsRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.towny.TownyKingRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.towny.TownyMayorNumberResidentsRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.towny.TownyMayorRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.towny.TownyResidentRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.votingplugin.VotingPluginPointsDeductibleRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.votingplugin.VotingPluginPointsRequirement;
|
||||
import sh.okx.rankup.requirements.requirement.votingplugin.VotingPluginVotesRequirement;
|
||||
import sh.okx.rankup.util.UpdateNotifier;
|
||||
import sh.okx.rankup.util.VersionChecker;
|
||||
|
||||
import java.io.File;
|
||||
import java.text.DecimalFormat;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.function.Supplier;
|
||||
|
||||
public class RankupPlugin extends JavaPlugin {
|
||||
|
||||
public static final int CONFIG_VERSION = 8;
|
||||
@@ -88,8 +114,6 @@ public class RankupPlugin extends JavaPlugin {
|
||||
private PermissionManager permissionManager = new VaultPermissionManager(this);
|
||||
private EconomyProvider economyProvider = new VaultEconomyProvider();
|
||||
|
||||
private RanksGuiManager ranksGuiManager = new RanksGuiManager(this);
|
||||
|
||||
public RankupPlugin() {
|
||||
super();
|
||||
}
|
||||
@@ -139,8 +163,11 @@ public class RankupPlugin extends JavaPlugin {
|
||||
getCommand("maxrankup").setExecutor(new MaxRankupCommand(this));
|
||||
}
|
||||
|
||||
RanksGuiListener listener = new RanksGuiListener();
|
||||
getCommand("ranksgui").setExecutor(new RanksGuiCommand(this, listener));
|
||||
getCommand("rankup").setExecutor(new RankupCommand(this));
|
||||
getCommand("rankup3").setExecutor(new InfoCommand(this, notifier));
|
||||
getServer().getPluginManager().registerEvents(listener, this);
|
||||
getServer().getPluginManager().registerEvents(new GuiListener(this), this);
|
||||
getServer().getPluginManager().registerEvents(
|
||||
new JoinUpdateNotifier(notifier, () -> getConfig().getBoolean("notify-update"), "rankup.notify"), this);
|
||||
@@ -417,7 +444,7 @@ public class RankupPlugin extends JavaPlugin {
|
||||
|
||||
public MessageBuilder replaceMoneyRequirements(MessageBuilder builder, CommandSender sender,
|
||||
Rank rank) {
|
||||
if (builder instanceof NullMessageBuilder) {
|
||||
if (builder instanceof NullMessageBuilder || rank == null) {
|
||||
return builder;
|
||||
}
|
||||
|
||||
|
||||
@@ -63,7 +63,7 @@ public class PrestigeCommand implements CommandExecutor {
|
||||
.send(player);
|
||||
break;
|
||||
case "gui":
|
||||
Gui gui = Gui.of(player, prestige, rankElement.getNext().getRank(), plugin);
|
||||
Gui gui = Gui.of(player, prestige, rankElement.getNext().getRank(), plugin, false);
|
||||
if (gui == null) {
|
||||
player.sendMessage(ChatColor.RED + "GUI is not available. Check console for more informatiopn.");
|
||||
return true;
|
||||
|
||||
@@ -62,7 +62,7 @@ public class RankupCommand implements CommandExecutor {
|
||||
.send(player);
|
||||
break;
|
||||
case "gui":
|
||||
Gui gui = Gui.of(player, rankElement.getRank(), rankElement.getNext().getRank(), plugin);
|
||||
Gui gui = Gui.of(player, rankElement.getRank(), rankElement.getNext().getRank(), plugin, args.length > 0 && args[0].equalsIgnoreCase("gui"));
|
||||
if (gui == null) {
|
||||
player.sendMessage(ChatColor.RED + "GUI is not available. Check console for more informatiopn.");
|
||||
return true;
|
||||
|
||||
@@ -1,8 +1,11 @@
|
||||
package sh.okx.rankup.gui;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.Objects;
|
||||
import java.util.stream.Collectors;
|
||||
import lombok.AccessLevel;
|
||||
import lombok.Getter;
|
||||
import lombok.NoArgsConstructor;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.ChatColor;
|
||||
import org.bukkit.Material;
|
||||
@@ -17,14 +20,13 @@ import sh.okx.rankup.messages.Message;
|
||||
import sh.okx.rankup.messages.MessageBuilder;
|
||||
import sh.okx.rankup.prestige.Prestige;
|
||||
import sh.okx.rankup.ranks.Rank;
|
||||
import sh.okx.rankup.ranks.RankElement;
|
||||
import sh.okx.rankup.util.ItemUtil;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.Objects;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
@NoArgsConstructor(access = AccessLevel.PRIVATE)
|
||||
@RequiredArgsConstructor(access = AccessLevel.PRIVATE)
|
||||
public class Gui implements InventoryHolder {
|
||||
@Getter
|
||||
private final boolean returnToRanksGui;
|
||||
@Getter
|
||||
private Inventory inventory;
|
||||
@Getter
|
||||
@@ -34,8 +36,8 @@ public class Gui implements InventoryHolder {
|
||||
@Getter
|
||||
private boolean prestige;
|
||||
|
||||
public static Gui of(Player player, Rank oldRank, Rank rank, RankupPlugin plugin) {
|
||||
Gui gui = new Gui();
|
||||
public static Gui of(Player player, Rank oldRank, Rank rank, RankupPlugin plugin, boolean returnToRanksGui) {
|
||||
Gui gui = new Gui(returnToRanksGui);
|
||||
gui.prestige = oldRank instanceof Prestige;
|
||||
|
||||
String type = gui.prestige ? "prestige" : "rankup";
|
||||
@@ -60,17 +62,28 @@ public class Gui implements InventoryHolder {
|
||||
gui.cancel = cancel;
|
||||
|
||||
Inventory inventory = Bukkit.createInventory(gui, items.length,
|
||||
plugin.replaceMoneyRequirements(
|
||||
ChatColor.stripColor(ChatColor.translateAlternateColorCodes('&', plugin.replaceMoneyRequirements(
|
||||
plugin.getMessage(oldRank, gui.prestige ? Message.PRESTIGE_TITLE : Message.TITLE)
|
||||
.replaceRanks(player, oldRank, rank)
|
||||
.replaceFromTo(oldRank), player, oldRank).toString());
|
||||
.replaceFromTo(oldRank), player, oldRank).toString())));
|
||||
inventory.setContents(items);
|
||||
gui.inventory = inventory;
|
||||
return gui;
|
||||
}
|
||||
|
||||
public static ItemStack getItem(RankupPlugin plugin, ConfigurationSection section, Player player, RankElement<Rank> element) {
|
||||
if (element == null) {
|
||||
return getItem(plugin, section, player, null, null);
|
||||
} else {
|
||||
return getItem(plugin, section, player, element.getRank(), element.getNext().getRank());
|
||||
}
|
||||
}
|
||||
|
||||
@SuppressWarnings("deprecation")
|
||||
private static ItemStack getItem(RankupPlugin plugin, ConfigurationSection section, Player player, Rank oldRank, Rank rank) {
|
||||
public static ItemStack getItem(RankupPlugin plugin, ConfigurationSection section, Player player, Rank oldRank, Rank rank) {
|
||||
if (section == null) {
|
||||
return null;
|
||||
}
|
||||
String materialName = section.getString("material").toUpperCase();
|
||||
|
||||
ItemStack item;
|
||||
@@ -108,9 +121,11 @@ public class Gui implements InventoryHolder {
|
||||
}
|
||||
|
||||
private static String format(RankupPlugin plugin, String message, Player player, Rank oldRank, Rank rank) {
|
||||
return plugin.replaceMoneyRequirements(new MessageBuilder(ChatColor.translateAlternateColorCodes('&', message))
|
||||
.replaceRanks(player, oldRank, rank), player, oldRank)
|
||||
.toString();
|
||||
MessageBuilder builder = new MessageBuilder(message);
|
||||
if (oldRank != null && rank != null) {
|
||||
builder = builder.replaceRanks(player, oldRank, rank);
|
||||
}
|
||||
return ChatColor.translateAlternateColorCodes('&', plugin.replaceMoneyRequirements(builder, player, oldRank).toString());
|
||||
}
|
||||
|
||||
private static void addItem(ItemStack[] items, ConfigurationSection section, ItemStack item) {
|
||||
|
||||
@@ -34,7 +34,12 @@ public class GuiListener implements Listener {
|
||||
plugin.getHelper().rankup(player);
|
||||
}
|
||||
} else if (gui.getCancel().isSimilar(e.getCurrentItem())) {
|
||||
Bukkit.getScheduler().runTask(plugin, player::closeInventory);
|
||||
Bukkit.getScheduler().runTask(plugin, () -> {
|
||||
player.closeInventory();
|
||||
if (gui.isReturnToRanksGui()) {
|
||||
Bukkit.dispatchCommand(player, "ranksgui");
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -52,7 +52,7 @@ public class PrestigeListRankRequirements implements RankRequirements {
|
||||
|
||||
for (Prestige prestige : prestiges.getTree()) {
|
||||
String next = prestige.getNext();
|
||||
if(plugin.getPermissions().inGroup(player.getUniqueId(), next)) {
|
||||
if(next != null && plugin.getPermissions().inGroup(player.getUniqueId(), next)) {
|
||||
RankRequirements rankRequirements = this.requirements.get(next.toLowerCase());
|
||||
if (rankRequirements != null) {
|
||||
return rankRequirements;
|
||||
|
||||
@@ -1,9 +1,122 @@
|
||||
package sh.okx.rankup.ranksgui;
|
||||
|
||||
import java.util.function.BiFunction;
|
||||
import lombok.Getter;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.configuration.ConfigurationSection;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.inventory.InventoryClickEvent;
|
||||
import org.bukkit.inventory.Inventory;
|
||||
import org.bukkit.inventory.ItemStack;
|
||||
import sh.okx.rankup.RankupPlugin;
|
||||
import sh.okx.rankup.gui.Gui;
|
||||
import sh.okx.rankup.ranks.Rank;
|
||||
import sh.okx.rankup.ranks.RankElement;
|
||||
|
||||
public class RanksGui {
|
||||
public Inventory getInventory() {
|
||||
private final RankupPlugin plugin;
|
||||
@Getter
|
||||
private final Player player;
|
||||
|
||||
private int rankupSlot;
|
||||
|
||||
@Getter
|
||||
private Inventory inventory;
|
||||
|
||||
public RanksGui(RankupPlugin plugin, Player player) {
|
||||
this.plugin = plugin;
|
||||
this.player = player;
|
||||
}
|
||||
|
||||
public void open() {
|
||||
RankElement<Rank> playerRankElement = plugin.getRankups().getByPlayer(player);
|
||||
ConfigurationSection playerPath = playerRankElement == null ? null : plugin.getSection(playerRankElement.getRank(), "rankup.ranksgui");
|
||||
ConfigurationSection basePath = plugin.getMessages().getConfigurationSection("rankup.ranksgui");
|
||||
|
||||
String title = get(ConfigurationSection::getString, "title", playerPath, basePath, "Ranks");
|
||||
int rows = get(ConfigurationSection::getInt, "rows", playerPath, basePath, 3);
|
||||
int offset = get(ConfigurationSection::getInt, "offset", playerPath, basePath, 10);
|
||||
int width = get(ConfigurationSection::getInt, "width", playerPath, basePath, 7);
|
||||
|
||||
inventory = Bukkit.createInventory(null, rows * 9, title);
|
||||
|
||||
ItemStack fill = get((section, path) -> Gui.getItem(plugin, section.getConfigurationSection(path), player, playerRankElement), "fill", playerPath, basePath, null);
|
||||
|
||||
int index = offset;
|
||||
int rowIndex = offset + width;
|
||||
RankElement<Rank> rankElement = plugin.getRankups().getTree().getFirst();
|
||||
boolean complete = playerRankElement != null;
|
||||
while(rankElement.hasNext()) {
|
||||
ConfigurationSection rankPath = plugin.getSection(rankElement.getRank(), "rankup.ranksgui");
|
||||
|
||||
String path;
|
||||
if (rankElement == playerRankElement) {
|
||||
path = "current";
|
||||
complete = false;
|
||||
rankupSlot = index;
|
||||
} else if (complete) {
|
||||
path = "complete";
|
||||
} else {
|
||||
path = "incomplete";
|
||||
}
|
||||
|
||||
RankElement<Rank> rankElement0 = rankElement;
|
||||
ItemStack item = get((section, path0) -> Gui.getItem(plugin, section.getConfigurationSection(path0), player, rankElement0), path, rankPath, basePath, null);
|
||||
|
||||
inventory.setItem(index++, item);
|
||||
if (index == rowIndex) {
|
||||
rowIndex += 9;
|
||||
index += 9 - width;
|
||||
}
|
||||
if (index >= rows * 9) {
|
||||
throw new IllegalArgumentException("Ranks GUI is too small for the number of ranks. Increase the number of rows on the ranks GUI.");
|
||||
}
|
||||
rankElement = rankElement.getNext();
|
||||
}
|
||||
|
||||
if (fill != null) {
|
||||
for (int i = 0; i < rows * 9; i++) {
|
||||
ItemStack item = inventory.getItem(i);
|
||||
if (item == null) {
|
||||
inventory.setItem(i, fill);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
player.openInventory(inventory);
|
||||
}
|
||||
|
||||
private <T> T get(BiFunction<ConfigurationSection, String, T> fun, String path, ConfigurationSection primary, ConfigurationSection secondary, T def) {
|
||||
T get = null;
|
||||
if (primary != null) {
|
||||
get = fun.apply(primary, path);
|
||||
}
|
||||
if (get != null) {
|
||||
return get;
|
||||
}
|
||||
if (secondary != null) {
|
||||
get = fun.apply(secondary, path);
|
||||
}
|
||||
if (get != null) {
|
||||
return get;
|
||||
}
|
||||
return def;
|
||||
}
|
||||
|
||||
public void click(InventoryClickEvent event) {
|
||||
if (event.getClickedInventory() != event.getInventory()) {
|
||||
return;
|
||||
}
|
||||
int slot = event.getRawSlot();
|
||||
if (slot == rankupSlot) {
|
||||
Bukkit.getScheduler().runTask(plugin, () -> {
|
||||
player.closeInventory();
|
||||
Bukkit.dispatchCommand(player, "rankup gui");
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
public void close() {
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,13 +1,18 @@
|
||||
package sh.okx.rankup.ranksgui;
|
||||
|
||||
import org.bukkit.Bukkit;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.bukkit.command.Command;
|
||||
import org.bukkit.command.CommandExecutor;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
import sh.okx.rankup.RankupPlugin;
|
||||
|
||||
@RequiredArgsConstructor
|
||||
public class RanksGuiCommand implements CommandExecutor {
|
||||
private final RankupPlugin plugin;
|
||||
private final RanksGuiListener listener;
|
||||
|
||||
@Override
|
||||
public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String label, @NotNull String[] args) {
|
||||
if (!(sender instanceof Player)) {
|
||||
@@ -15,8 +20,7 @@ public class RanksGuiCommand implements CommandExecutor {
|
||||
}
|
||||
Player player = (Player) sender;
|
||||
|
||||
player.openInventory(Bukkit.createInventory())
|
||||
|
||||
listener.open(new RanksGui(plugin, player));
|
||||
return true;
|
||||
}
|
||||
}
|
||||
@@ -1,28 +0,0 @@
|
||||
package sh.okx.rankup.ranksgui;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.inventory.InventoryCloseEvent;
|
||||
|
||||
public class RanksGuiHolder implements Listener {
|
||||
private final Map<Player, RanksGui> guiMap = new HashMap<>();
|
||||
|
||||
|
||||
@EventHandler
|
||||
public void on(InventoryCloseEvent event) {
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
return;
|
||||
}
|
||||
Player player = (Player) event.getPlayer();
|
||||
if (guiMap.containsKey(player)) {
|
||||
RanksGui ranksGui = guiMap.get(player);
|
||||
if (ranksGui.getInventory() == event.getInventory()) {
|
||||
guiMap.remove(player);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -0,0 +1,48 @@
|
||||
package sh.okx.rankup.ranksgui;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.inventory.InventoryClickEvent;
|
||||
import org.bukkit.event.inventory.InventoryCloseEvent;
|
||||
|
||||
public class RanksGuiListener implements Listener {
|
||||
|
||||
private final Map<Player, RanksGui> guiMap = new HashMap<>();
|
||||
|
||||
@EventHandler
|
||||
public void on(InventoryCloseEvent event) {
|
||||
if (!(event.getPlayer() instanceof Player)) {
|
||||
return;
|
||||
}
|
||||
Player player = (Player) event.getPlayer();
|
||||
if (guiMap.containsKey(player)) {
|
||||
RanksGui ranksGui = guiMap.get(player);
|
||||
if (ranksGui.getInventory() != null
|
||||
&& ranksGui.getInventory() == event.getInventory()) {
|
||||
guiMap.remove(player);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@EventHandler
|
||||
public void on(InventoryClickEvent event) {
|
||||
if (!(event.getWhoClicked() instanceof Player)) {
|
||||
return;
|
||||
}
|
||||
Player player = (Player) event.getWhoClicked();
|
||||
RanksGui ranksGui = guiMap.get(player);
|
||||
if (ranksGui != null && event.getInventory() == ranksGui.getInventory()) {
|
||||
ranksGui.click(event);
|
||||
event.setCancelled(true);
|
||||
}
|
||||
}
|
||||
|
||||
public void open(RanksGui gui) {
|
||||
guiMap.put(gui.getPlayer(), gui);
|
||||
gui.open();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,15 +0,0 @@
|
||||
package sh.okx.rankup.ranksgui;
|
||||
|
||||
import sh.okx.rankup.RankupPlugin;
|
||||
|
||||
public class RanksGuiManager {
|
||||
private final RankupPlugin plugin;
|
||||
|
||||
public RanksGuiManager(RankupPlugin plugin) {
|
||||
this.plugin = plugin;
|
||||
}
|
||||
|
||||
public void enable() {
|
||||
|
||||
}
|
||||
}
|
||||
@@ -1,5 +1,5 @@
|
||||
# this is used for letting you know that you need to update/change your config file
|
||||
version: 8
|
||||
version: 9
|
||||
|
||||
# the locale to use for messages
|
||||
# all messages can be customised but this allows you to
|
||||
|
||||
@@ -38,6 +38,26 @@ rankup:
|
||||
# this works for both the rankup and cancel blocks as well
|
||||
material: BLACK_STAINED_GLASS_PANE
|
||||
|
||||
ranksgui:
|
||||
title: "Ranks"
|
||||
rows: 3
|
||||
offset: 10
|
||||
width: 7
|
||||
rankup:
|
||||
complete:
|
||||
material: GREEN_STAINED_GLASS_PANE
|
||||
name: "&aRank &7{RANK} &a(completed)"
|
||||
current:
|
||||
material: ORANGE_STAINED_GLASS_PANE
|
||||
name: "&dRankup to &7{RANK}"
|
||||
incomplete:
|
||||
material: RED_STAINED_GLASS_PANE
|
||||
name: "&cRank &7{RANK} &c(requires rankup)"
|
||||
fill:
|
||||
material: BLACK_STAINED_GLASS_PANE
|
||||
name: ' '
|
||||
|
||||
|
||||
# you can (and probably should) you override these in rankups.yml
|
||||
# to show the specific requirements for each rank.
|
||||
# however if you are just using money or don't need to change the message per rank, you can use any combination of:
|
||||
|
||||
@@ -26,6 +26,8 @@ commands:
|
||||
maxrankup:
|
||||
permission: rankup.maxrankup
|
||||
description: Rankup as much as possible.
|
||||
ranksgui:
|
||||
description: Show the ranks GUI
|
||||
permissions:
|
||||
rankup.*:
|
||||
children:
|
||||
|
||||
Reference in New Issue
Block a user