arena menu
This commit is contained in:
parent
0ff26a8724
commit
d0cddac3b5
@ -5,6 +5,7 @@ import org.bukkit.command.CommandExecutor;
|
|||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import rip.tilly.bedwars.BedWars;
|
import rip.tilly.bedwars.BedWars;
|
||||||
|
import rip.tilly.bedwars.menus.arena.ArenaManagerMenu;
|
||||||
import rip.tilly.bedwars.utils.CC;
|
import rip.tilly.bedwars.utils.CC;
|
||||||
|
|
||||||
public class ArenaCommand implements CommandExecutor {
|
public class ArenaCommand implements CommandExecutor {
|
||||||
@ -40,7 +41,9 @@ public class ArenaCommand implements CommandExecutor {
|
|||||||
player.sendMessage(CC.translate(" &c/arena buildmax <arena>"));
|
player.sendMessage(CC.translate(" &c/arena buildmax <arena>"));
|
||||||
} else {
|
} else {
|
||||||
switch (args[0].toLowerCase()) {
|
switch (args[0].toLowerCase()) {
|
||||||
|
case "manage":
|
||||||
|
new ArenaManagerMenu().openMenu(player);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,9 +77,10 @@ public class InteractListener implements Listener {
|
|||||||
case SPAWN:
|
case SPAWN:
|
||||||
switch (hotbarItem.getActionType()) {
|
switch (hotbarItem.getActionType()) {
|
||||||
case QUEUE_MENU:
|
case QUEUE_MENU:
|
||||||
for (GameType gameType : GameType.values()) {
|
new QueueMenu().openMenu(player);
|
||||||
new PlayAGameMenu(this.plugin.getPlayerMenuUtil(player), gameType).open();
|
// for (GameType gameType : GameType.values()) {
|
||||||
}
|
// new PlayAGameMenu(this.plugin.getPlayerMenuUtil(player), gameType).open();
|
||||||
|
// }
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case SETTINGS_MENU:
|
case SETTINGS_MENU:
|
||||||
|
@ -0,0 +1,38 @@
|
|||||||
|
package rip.tilly.bedwars.menus.arena;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import rip.tilly.bedwars.BedWars;
|
||||||
|
import rip.tilly.bedwars.game.arena.Arena;
|
||||||
|
import rip.tilly.bedwars.game.arena.CopiedArena;
|
||||||
|
import rip.tilly.bedwars.menus.arena.buttons.ArenaCopyButton;
|
||||||
|
import rip.tilly.bedwars.utils.CC;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Menu;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class ArenaCopyMenu extends Menu {
|
||||||
|
|
||||||
|
private final Arena arena;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getTitle(Player player) {
|
||||||
|
return CC.translate("&eArena Copies");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<Integer, Button> getButtons(Player player) {
|
||||||
|
Map<Integer, Button> buttons = new HashMap<>();
|
||||||
|
|
||||||
|
int i = 0;
|
||||||
|
for (CopiedArena arenaCopy : BedWars.getInstance().getArenaManager().getArena(arena.getName()).getCopiedArenas()) {
|
||||||
|
buttons.put(buttons.size(), new ArenaCopyButton(i, arena, arenaCopy));
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return buttons;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,37 @@
|
|||||||
|
package rip.tilly.bedwars.menus.arena;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import rip.tilly.bedwars.game.arena.Arena;
|
||||||
|
import rip.tilly.bedwars.menus.arena.buttons.ArenaGenerateButton;
|
||||||
|
import rip.tilly.bedwars.utils.CC;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Menu;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class ArenaGenerationMenu extends Menu {
|
||||||
|
|
||||||
|
private final Arena arena;
|
||||||
|
|
||||||
|
@Getter private final int[] clonableAmounts = {1, 2, 3, 4, 5, 10, 15};
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getTitle(Player player) {
|
||||||
|
return CC.translate("&eArena Copies Generation");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<Integer, Button> getButtons(Player player) {
|
||||||
|
Map<Integer, Button> buttons = new HashMap<>();
|
||||||
|
|
||||||
|
for (int curr : clonableAmounts) {
|
||||||
|
buttons.put(1 + buttons.size(), new ArenaGenerateButton(arena, curr));
|
||||||
|
}
|
||||||
|
|
||||||
|
return buttons;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,53 @@
|
|||||||
|
package rip.tilly.bedwars.menus.arena;
|
||||||
|
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import rip.tilly.bedwars.BedWars;
|
||||||
|
import rip.tilly.bedwars.menus.arena.buttons.ArenaButton;
|
||||||
|
import rip.tilly.bedwars.utils.ItemBuilder;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
import rip.tilly.bedwars.utils.menu.pagination.PageButton;
|
||||||
|
import rip.tilly.bedwars.utils.menu.pagination.PaginatedMenu;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class ArenaManagerMenu extends PaginatedMenu {
|
||||||
|
|
||||||
|
private final BedWars plugin = BedWars.getInstance();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getPrePaginatedTitle(Player player) {
|
||||||
|
return "Arena Management";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<Integer, Button> getAllPagesButtons(Player player) {
|
||||||
|
Map<Integer, Button> buttons = new HashMap<>();
|
||||||
|
this.plugin.getArenaManager().getArenas().forEach((s, arena) -> buttons.put(buttons.size(), new ArenaButton(arena)));
|
||||||
|
|
||||||
|
return buttons;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<Integer, Button> getGlobalButtons(Player player) {
|
||||||
|
Map<Integer, Button> buttons = new HashMap<>();
|
||||||
|
|
||||||
|
buttons.put(0, new PageButton(-1, this));
|
||||||
|
buttons.put(8, new PageButton(1, this));
|
||||||
|
|
||||||
|
bottomTopButtons(false, buttons, new ItemBuilder(Material.STAINED_GLASS_PANE).name(" ").durability(7).build());
|
||||||
|
|
||||||
|
return buttons;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getSize() {
|
||||||
|
return 9 * 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMaxItemsPerPage(Player player) {
|
||||||
|
return 9 * 3;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,66 @@
|
|||||||
|
package rip.tilly.bedwars.menus.arena.buttons;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.inventory.ClickType;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import rip.tilly.bedwars.BedWars;
|
||||||
|
import rip.tilly.bedwars.game.arena.Arena;
|
||||||
|
import rip.tilly.bedwars.menus.arena.ArenaCopyMenu;
|
||||||
|
import rip.tilly.bedwars.menus.arena.ArenaGenerationMenu;
|
||||||
|
import rip.tilly.bedwars.utils.CC;
|
||||||
|
import rip.tilly.bedwars.utils.ItemBuilder;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class ArenaButton extends Button {
|
||||||
|
|
||||||
|
private final Arena arena;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getButtonItem(Player player) {
|
||||||
|
return new ItemBuilder(Material.valueOf(arena.getIcon()))
|
||||||
|
.durability(arena.getIconData())
|
||||||
|
.name("&b" + arena.getName())
|
||||||
|
.lore(CC.translate(
|
||||||
|
Arrays.asList(
|
||||||
|
" ",
|
||||||
|
"&bArena Information&7:",
|
||||||
|
" &9&l▸ &fState: " + (arena.isEnabled() ? "&aEnabled" : "&cDisabled"),
|
||||||
|
" &9&l▸ &fType: &b" + (arena.getAvailableArenas().size() == 0 ? "Shared" : "Standalone"),
|
||||||
|
" &9&l▸ &fCopies: &b" + (arena.getCopiedArenas().size() == 0 ? "Not Required!" : arena.getCopiedArenas().size()),
|
||||||
|
" &9&l▸ &fAvailable: &b" + (arena.getAvailableArenas().size() == 0 ? +1 : arena.getAvailableArenas().size()),
|
||||||
|
" ",
|
||||||
|
(arena.getCopiedArenas().size() == 0 ? "&4&l&mMIDDLE-CLICK &4&mto see arena copies" : "&6&lMIDDLE-CLICK &6to see arena copies"),
|
||||||
|
"&a&lLEFT-CLICK &ato teleport to arena",
|
||||||
|
"&b&lRIGHT CLICK &bto generate standalone arenas")
|
||||||
|
)
|
||||||
|
)
|
||||||
|
.hideFlags()
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clicked(Player player, int slot, ClickType clickType, int hotbarButton) {
|
||||||
|
playSuccess(player);
|
||||||
|
switch (clickType) {
|
||||||
|
case LEFT:
|
||||||
|
player.teleport(arena.getA().toBukkitLocation());
|
||||||
|
break;
|
||||||
|
case RIGHT:
|
||||||
|
Bukkit.getScheduler().runTaskLaterAsynchronously(BedWars.getInstance(), () -> new ArenaGenerationMenu(arena).openMenu(player), 1L);
|
||||||
|
break;
|
||||||
|
case MIDDLE:
|
||||||
|
if (arena.getCopiedArenas().size() >= 1) {
|
||||||
|
Bukkit.getScheduler().runTaskLaterAsynchronously(BedWars.getInstance(), () -> new ArenaCopyMenu(arena).openMenu(player), 1L);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
player.closeInventory();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,60 @@
|
|||||||
|
package rip.tilly.bedwars.menus.arena.buttons;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.inventory.ClickType;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import rip.tilly.bedwars.BedWars;
|
||||||
|
import rip.tilly.bedwars.game.arena.Arena;
|
||||||
|
import rip.tilly.bedwars.game.arena.CopiedArena;
|
||||||
|
import rip.tilly.bedwars.runnables.ArenaCopyRemovalRunnable;
|
||||||
|
import rip.tilly.bedwars.utils.CC;
|
||||||
|
import rip.tilly.bedwars.utils.ItemBuilder;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class ArenaCopyButton extends Button {
|
||||||
|
|
||||||
|
private final BedWars plugin = BedWars.getInstance();
|
||||||
|
|
||||||
|
private final int number;
|
||||||
|
private final Arena arena;
|
||||||
|
private final CopiedArena arenaCopy;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getButtonItem(Player player) {
|
||||||
|
return new ItemBuilder(Material.PAPER)
|
||||||
|
.name("&8" + number)
|
||||||
|
.lore(CC.translate(
|
||||||
|
Arrays.asList(
|
||||||
|
"&bCopy Information&7:",
|
||||||
|
" &9&l▸ &fParent Arena: &b" + arena.getName() + " &7(&f#" + number + "&7)",
|
||||||
|
" &9&l▸ &f1st Spawn: &b" + Math.round(arenaCopy.getA().getX()) + "&7, &b" + Math.round(arenaCopy.getA().getY()) + "&7, &b" + Math.round(arenaCopy.getA().getZ()),
|
||||||
|
" &9&l▸ &f2nd Spawn: &b" + Math.round(arenaCopy.getB().getX()) + "&7, &b" + Math.round(arenaCopy.getB().getY()) + "&7, &b" + Math.round(arenaCopy.getB().getZ()),
|
||||||
|
" &9&l▸ &fMin Location: &b" + Math.round(arenaCopy.getMin().getX()) + "&7, &b" + Math.round(arenaCopy.getMin().getY()) + "&7, &b" + Math.round(arenaCopy.getMin().getZ()),
|
||||||
|
" &9&l▸ &fMax Location: &b" + Math.round(arenaCopy.getMax().getX()) + "&7, &b" + Math.round(arenaCopy.getMax().getY()) + "&7, &b" + Math.round(arenaCopy.getMax().getZ()),
|
||||||
|
" ",
|
||||||
|
"&a&lLEFT-CLICK &ato teleport to this copy!",
|
||||||
|
"&c&lRIGHT-CLICK &cto delete this copy!"
|
||||||
|
))
|
||||||
|
)
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clicked(Player player, int slot, ClickType clickType, int hotbarButton) {
|
||||||
|
switch (clickType) {
|
||||||
|
case LEFT:
|
||||||
|
player.teleport(arenaCopy.getA().toBukkitLocation());
|
||||||
|
break;
|
||||||
|
case RIGHT:
|
||||||
|
new ArenaCopyRemovalRunnable(number, arena, arenaCopy).runTask(this.plugin);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
player.closeInventory();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,53 @@
|
|||||||
|
package rip.tilly.bedwars.menus.arena.buttons;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.inventory.ClickType;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import rip.tilly.bedwars.game.arena.Arena;
|
||||||
|
import rip.tilly.bedwars.utils.CC;
|
||||||
|
import rip.tilly.bedwars.utils.ItemBuilder;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class ArenaGenerateButton extends Button {
|
||||||
|
|
||||||
|
private final Arena arena;
|
||||||
|
private final int currentCopyAmount;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getButtonItem(Player player) {
|
||||||
|
return new ItemBuilder(Material.PAPER)
|
||||||
|
.name("&aCreate " + currentCopyAmount + " Arena Copies")
|
||||||
|
.lore(CC.translate(
|
||||||
|
Arrays.asList(
|
||||||
|
" ",
|
||||||
|
"&7Clicking here will generate &b&l" + currentCopyAmount,
|
||||||
|
"&7arenas for the map &b" + arena.getName() + "&7!",
|
||||||
|
" ",
|
||||||
|
"&a&lLEFT-CLICK &ato generate arenas")
|
||||||
|
))
|
||||||
|
.amount(currentCopyAmount)
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clicked(Player player, int slot, ClickType clickType, int hotbarButton) {
|
||||||
|
player.performCommand("arena generate " + arena.getName() + " " + currentCopyAmount);
|
||||||
|
|
||||||
|
player.sendMessage(CC.chatBar);
|
||||||
|
player.sendMessage(CC.translate("&b&lGENERATING ARENAS&b..."));
|
||||||
|
player.sendMessage(CC.translate(" "));
|
||||||
|
player.sendMessage(CC.translate("&fFrost is currently generating copies for:"));
|
||||||
|
player.sendMessage(CC.translate(" &9&l▸ &fArena: &b" + arena.getName()));
|
||||||
|
player.sendMessage(CC.translate(" &9&l▸ &fCopies: &b" + currentCopyAmount));
|
||||||
|
player.sendMessage(CC.translate(" "));
|
||||||
|
player.sendMessage(CC.translate("&7&oYou can check the progress in console."));
|
||||||
|
player.sendMessage(CC.chatBar);
|
||||||
|
|
||||||
|
player.closeInventory();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,35 @@
|
|||||||
|
package rip.tilly.bedwars.utils.menu.buttons;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.inventory.ClickType;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Menu;
|
||||||
|
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BackButton extends Button {
|
||||||
|
|
||||||
|
private Menu back;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getButtonItem(Player player) {
|
||||||
|
ItemStack itemStack = new ItemStack(Material.BED);
|
||||||
|
ItemMeta itemMeta = itemStack.getItemMeta();
|
||||||
|
|
||||||
|
itemMeta.setDisplayName(ChatColor.RED + "Go back");
|
||||||
|
itemStack.setItemMeta(itemMeta);
|
||||||
|
|
||||||
|
return itemStack;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clicked(Player player, int i, ClickType clickType, int hb) {
|
||||||
|
Button.playNeutral(player);
|
||||||
|
|
||||||
|
this.back.openMenu(player);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,31 @@
|
|||||||
|
package rip.tilly.bedwars.utils.menu.buttons;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.inventory.ClickType;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
|
||||||
|
@AllArgsConstructor @Getter @Setter
|
||||||
|
public class DisplayButton extends Button {
|
||||||
|
|
||||||
|
private ItemStack itemStack;
|
||||||
|
private boolean cancel;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getButtonItem(Player player) {
|
||||||
|
if (this.itemStack == null) {
|
||||||
|
return new ItemStack(Material.AIR);
|
||||||
|
} else {
|
||||||
|
return this.itemStack;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean shouldCancel(Player player, int slot, ClickType clickType) {
|
||||||
|
return this.cancel;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,45 @@
|
|||||||
|
package rip.tilly.bedwars.utils.menu.pagination;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.inventory.ClickType;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class JumpToPageButton extends Button {
|
||||||
|
|
||||||
|
private int page;
|
||||||
|
private PaginatedMenu menu;
|
||||||
|
private boolean current;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getButtonItem(Player player) {
|
||||||
|
ItemStack itemStack = new ItemStack(this.current ? Material.ENCHANTED_BOOK : Material.BOOK, this.page);
|
||||||
|
ItemMeta itemMeta = itemStack.getItemMeta();
|
||||||
|
|
||||||
|
itemMeta.setDisplayName(ChatColor.GREEN + "Page " + this.page);
|
||||||
|
|
||||||
|
if (this.current) {
|
||||||
|
itemMeta.setLore(Arrays.asList(
|
||||||
|
"",
|
||||||
|
ChatColor.GREEN + "Current page"
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
itemStack.setItemMeta(itemMeta);
|
||||||
|
|
||||||
|
return itemStack;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clicked(Player player, int i, ClickType clickType, int hb) {
|
||||||
|
this.menu.modPage(player, this.page - this.menu.getPage());
|
||||||
|
Button.playNeutral(player);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,61 @@
|
|||||||
|
package rip.tilly.bedwars.utils.menu.pagination;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.inventory.ClickType;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class PageButton extends Button {
|
||||||
|
|
||||||
|
private int mod;
|
||||||
|
private PaginatedMenu menu;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getButtonItem(Player player) {
|
||||||
|
ItemStack itemStack = new ItemStack(Material.CARPET);
|
||||||
|
ItemMeta itemMeta = itemStack.getItemMeta();
|
||||||
|
|
||||||
|
if (this.hasNext(player)) {
|
||||||
|
itemMeta.setDisplayName(this.mod > 0 ? ChatColor.GREEN + "Next page" : ChatColor.RED + "Previous page");
|
||||||
|
} else {
|
||||||
|
itemMeta.setDisplayName(ChatColor.GRAY + (this.mod > 0 ? "Last page" : "First page"));
|
||||||
|
}
|
||||||
|
|
||||||
|
itemMeta.setLore(Arrays.asList(
|
||||||
|
"",
|
||||||
|
ChatColor.GREEN + "Right click to",
|
||||||
|
ChatColor.GREEN + "jump to a page"
|
||||||
|
));
|
||||||
|
|
||||||
|
itemStack.setItemMeta(itemMeta);
|
||||||
|
|
||||||
|
return itemStack;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clicked(Player player, int i, ClickType clickType, int hb) {
|
||||||
|
if (clickType == ClickType.RIGHT) {
|
||||||
|
new ViewAllPagesMenu(this.menu).openMenu(player);
|
||||||
|
playNeutral(player);
|
||||||
|
} else {
|
||||||
|
if (hasNext(player)) {
|
||||||
|
this.menu.modPage(player, this.mod);
|
||||||
|
Button.playNeutral(player);
|
||||||
|
} else {
|
||||||
|
Button.playFail(player);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean hasNext(Player player) {
|
||||||
|
int pg = this.menu.getPage() + this.mod;
|
||||||
|
return pg > 0 && this.menu.getPages(player) >= pg;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,118 @@
|
|||||||
|
package rip.tilly.bedwars.utils.menu.pagination;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Menu;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.stream.IntStream;
|
||||||
|
|
||||||
|
public abstract class PaginatedMenu extends Menu {
|
||||||
|
|
||||||
|
@Getter private int page = 1;
|
||||||
|
|
||||||
|
{
|
||||||
|
setUpdateAfterClick(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getTitle(Player player) {
|
||||||
|
return getPrePaginatedTitle(player) + " - " + page + "/" + getPages(player);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Changes the page number
|
||||||
|
*
|
||||||
|
* @param player player viewing the inventory
|
||||||
|
* @param mod delta to modify the page number by
|
||||||
|
*/
|
||||||
|
public final void modPage(Player player, int mod) {
|
||||||
|
page += mod;
|
||||||
|
getButtons().clear();
|
||||||
|
openMenu(player);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param player player viewing the inventory
|
||||||
|
*/
|
||||||
|
public final int getPages(Player player) {
|
||||||
|
int buttonAmount = getAllPagesButtons(player).size();
|
||||||
|
|
||||||
|
if (buttonAmount == 0) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (int) Math.ceil(buttonAmount / (double) getMaxItemsPerPage(player));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public final Map<Integer, Button> getButtons(Player player) {
|
||||||
|
int minIndex = (int) ((double) (page - 1) * getMaxItemsPerPage(player));
|
||||||
|
int maxIndex = (int) ((double) (page) * getMaxItemsPerPage(player));
|
||||||
|
|
||||||
|
HashMap<Integer, Button> buttons = new HashMap<>();
|
||||||
|
|
||||||
|
buttons.put(0, new PageButton(-1, this));
|
||||||
|
buttons.put(8, new PageButton(1, this));
|
||||||
|
|
||||||
|
for (Map.Entry<Integer, Button> entry : getAllPagesButtons(player).entrySet()) {
|
||||||
|
int ind = entry.getKey();
|
||||||
|
if (ind >= minIndex && ind < maxIndex) {
|
||||||
|
ind -= (int) ((double) (getMaxItemsPerPage(player)) * (page - 1)) - 9;
|
||||||
|
buttons.put(ind, entry.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<Integer, Button> global = getGlobalButtons(player);
|
||||||
|
if (global != null) {
|
||||||
|
for (Map.Entry<Integer, Button> gent : global.entrySet()) {
|
||||||
|
buttons.put(gent.getKey(), gent.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return buttons;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getMaxItemsPerPage(Player player) {
|
||||||
|
return 18;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param player player viewing the inventory
|
||||||
|
*
|
||||||
|
* @return a Map of buttons that returns items which will be present on all pages
|
||||||
|
*/
|
||||||
|
public Map<Integer, Button> getGlobalButtons(Player player) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void bottomTopButtons(boolean full, Map buttons, ItemStack itemStack) {
|
||||||
|
IntStream.range(0, getSize()).filter(slot -> buttons.get(slot) == null).forEach(slot -> {
|
||||||
|
if (slot < 9 || slot > getSize() - 10 || full && (slot % 9 == 0 || (slot + 1) % 9 == 0)) {
|
||||||
|
buttons.put(slot, new Button() {
|
||||||
|
@Override
|
||||||
|
public ItemStack getButtonItem(Player player) {
|
||||||
|
return itemStack;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param player player viewing the inventory
|
||||||
|
*
|
||||||
|
* @return title of the inventory before the page number is added
|
||||||
|
*/
|
||||||
|
public abstract String getPrePaginatedTitle(Player player);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param player player viewing the inventory
|
||||||
|
*
|
||||||
|
* @return a map of buttons that will be paginated and spread across pages
|
||||||
|
*/
|
||||||
|
public abstract Map<Integer, Button> getAllPagesButtons(Player player);
|
||||||
|
}
|
@ -0,0 +1,47 @@
|
|||||||
|
package rip.tilly.bedwars.utils.menu.pagination;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.NonNull;
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import rip.tilly.bedwars.utils.CC;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Button;
|
||||||
|
import rip.tilly.bedwars.utils.menu.Menu;
|
||||||
|
import rip.tilly.bedwars.utils.menu.buttons.BackButton;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
@RequiredArgsConstructor
|
||||||
|
public class ViewAllPagesMenu extends Menu {
|
||||||
|
|
||||||
|
@NonNull @Getter PaginatedMenu menu;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getTitle(Player player) {
|
||||||
|
return CC.translate("&eJump to page");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<Integer, Button> getButtons(Player player) {
|
||||||
|
HashMap<Integer, Button> buttons = new HashMap<>();
|
||||||
|
|
||||||
|
buttons.put(0, new BackButton(menu));
|
||||||
|
|
||||||
|
int index = 10;
|
||||||
|
for (int i = 1; i <= menu.getPages(player); i++) {
|
||||||
|
buttons.put(index++, new JumpToPageButton(i, menu, menu.getPage() == i));
|
||||||
|
|
||||||
|
if ((index - 8) % 9 == 0) {
|
||||||
|
index += 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return buttons;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isAutoUpdate() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user