Merge branch 'develop' of https://github.com/BentoBoxWorld/Level.git
into develop
This commit is contained in:
commit
a95f0b790e
11
pom.xml
11
pom.xml
|
@ -408,20 +408,25 @@
|
||||||
</configuration>
|
</configuration>
|
||||||
<executions>
|
<executions>
|
||||||
<execution>
|
<execution>
|
||||||
<id>pre-unit-test</id>
|
<id>prepare-agent</id>
|
||||||
<goals>
|
<goals>
|
||||||
<goal>prepare-agent</goal>
|
<goal>prepare-agent</goal>
|
||||||
</goals>
|
</goals>
|
||||||
</execution>
|
</execution>
|
||||||
<execution>
|
<execution>
|
||||||
<id>post-unit-test</id>
|
<id>report</id>
|
||||||
<goals>
|
<goals>
|
||||||
<goal>report</goal>
|
<goal>report</goal>
|
||||||
</goals>
|
</goals>
|
||||||
|
<configuration>
|
||||||
|
<formats>
|
||||||
|
<format>XML</format>
|
||||||
|
</formats>
|
||||||
|
</configuration>
|
||||||
</execution>
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
|
|
|
@ -170,20 +170,14 @@ public class Level extends Addon {
|
||||||
{
|
{
|
||||||
this.visitHook = (VisitAddon) addon;
|
this.visitHook = (VisitAddon) addon;
|
||||||
this.log("Level Addon hooked into Visit addon.");
|
this.log("Level Addon hooked into Visit addon.");
|
||||||
}, () ->
|
}, () -> this.visitHook = null);
|
||||||
{
|
|
||||||
this.visitHook = null;
|
|
||||||
});
|
|
||||||
|
|
||||||
// Try to find Warps addon and if it does not exist, display a warning
|
// Try to find Warps addon and if it does not exist, display a warning
|
||||||
this.getAddonByName("Warps").ifPresentOrElse(addon ->
|
this.getAddonByName("Warps").ifPresentOrElse(addon ->
|
||||||
{
|
{
|
||||||
this.warpHook = (Warp) addon;
|
this.warpHook = (Warp) addon;
|
||||||
this.log("Level Addon hooked into Warps addon.");
|
this.log("Level Addon hooked into Warps addon.");
|
||||||
}, () ->
|
}, () -> this.warpHook = null);
|
||||||
{
|
|
||||||
this.warpHook = null;
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -212,9 +206,6 @@ public class Level extends Addon {
|
||||||
return comparisonResult;
|
return comparisonResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private void registerCommands(GameModeAddon gm) {
|
private void registerCommands(GameModeAddon gm) {
|
||||||
gm.getAdminCommand().ifPresent(adminCommand -> {
|
gm.getAdminCommand().ifPresent(adminCommand -> {
|
||||||
new AdminLevelCommand(this, adminCommand);
|
new AdminLevelCommand(this, adminCommand);
|
||||||
|
@ -351,7 +342,7 @@ public class Level extends Addon {
|
||||||
* @param playerUUID - the target island member's UUID
|
* @param playerUUID - the target island member's UUID
|
||||||
* @deprecated Do not use this anymore. Use getManager().calculateLevel(playerUUID, island)
|
* @deprecated Do not use this anymore. Use getManager().calculateLevel(playerUUID, island)
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated(since="2.3.0", forRemoval=true)
|
||||||
public void calculateIslandLevel(World world, @Nullable User user, @NonNull UUID playerUUID) {
|
public void calculateIslandLevel(World world, @Nullable User user, @NonNull UUID playerUUID) {
|
||||||
Island island = getIslands().getIsland(world, playerUUID);
|
Island island = getIslands().getIsland(world, playerUUID);
|
||||||
if (island != null) getManager().calculateLevel(playerUUID, island);
|
if (island != null) getManager().calculateLevel(playerUUID, island);
|
||||||
|
@ -363,7 +354,7 @@ public class Level extends Addon {
|
||||||
* @return LevelsData object or null if not found. Only island levels are set!
|
* @return LevelsData object or null if not found. Only island levels are set!
|
||||||
* @deprecated Do not use this anymore. Use {@link #getIslandLevel(World, UUID)}
|
* @deprecated Do not use this anymore. Use {@link #getIslandLevel(World, UUID)}
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated(since="2.3.0", forRemoval=true)
|
||||||
public LevelsData getLevelsData(UUID targetPlayer) {
|
public LevelsData getLevelsData(UUID targetPlayer) {
|
||||||
LevelsData ld = new LevelsData(targetPlayer);
|
LevelsData ld = new LevelsData(targetPlayer);
|
||||||
getPlugin().getAddonsManager().getGameModeAddons().stream()
|
getPlugin().getAddonsManager().getGameModeAddons().stream()
|
||||||
|
|
|
@ -152,8 +152,6 @@ public class LevelsManager {
|
||||||
addon.getPipeliner().addIsland(island).thenAccept(r -> {
|
addon.getPipeliner().addIsland(island).thenAccept(r -> {
|
||||||
// Results are irrelevant because the island is unowned or deleted, or IslandLevelCalcEvent is cancelled
|
// Results are irrelevant because the island is unowned or deleted, or IslandLevelCalcEvent is cancelled
|
||||||
if (r == null || fireIslandLevelCalcEvent(targetPlayer, island, r)) {
|
if (r == null || fireIslandLevelCalcEvent(targetPlayer, island, r)) {
|
||||||
System.out.println("results are null or event canceled");
|
|
||||||
|
|
||||||
result.complete(null);
|
result.complete(null);
|
||||||
}
|
}
|
||||||
// Save result
|
// Save result
|
||||||
|
@ -337,7 +335,7 @@ public class LevelsManager {
|
||||||
.filter(e -> addon.getIslands().isOwner(world, e.getKey()))
|
.filter(e -> addon.getIslands().isOwner(world, e.getKey()))
|
||||||
.filter(l -> l.getValue() > 0)
|
.filter(l -> l.getValue() > 0)
|
||||||
.sorted(Collections.reverseOrder(Map.Entry.comparingByValue()));
|
.sorted(Collections.reverseOrder(Map.Entry.comparingByValue()));
|
||||||
return stream.takeWhile(x -> !x.getKey().equals(uuid)).map(Map.Entry::getKey).collect(Collectors.toList()).size() + 1;
|
return (int) (stream.takeWhile(x -> !x.getKey().equals(uuid)).map(Map.Entry::getKey).count() + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -363,10 +361,7 @@ public class LevelsManager {
|
||||||
addon.getIslands().getIslandById(il.getUniqueId()).ifPresent(i -> this.addToTopTen(i, il.getLevel()));
|
addon.getIslands().getIslandById(il.getUniqueId()).ifPresent(i -> this.addToTopTen(i, il.getLevel()));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
topTenLists.keySet().forEach(w -> {
|
topTenLists.keySet().forEach(w -> addon.log("Generated rankings for " + w.getName()));
|
||||||
addon.log("Generated rankings for " + w.getName());
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,11 @@
|
||||||
package world.bentobox.level.calculators;
|
package world.bentobox.level.calculators;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.EnumMap;
|
import java.util.EnumMap;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -24,13 +24,11 @@ import org.bukkit.Material;
|
||||||
import org.bukkit.Tag;
|
import org.bukkit.Tag;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.World.Environment;
|
import org.bukkit.World.Environment;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.*;
|
||||||
import org.bukkit.block.BlockState;
|
|
||||||
import org.bukkit.block.Container;
|
|
||||||
import org.bukkit.block.CreatureSpawner;
|
|
||||||
import org.bukkit.block.data.BlockData;
|
import org.bukkit.block.data.BlockData;
|
||||||
import org.bukkit.block.data.type.Slab;
|
import org.bukkit.block.data.type.Slab;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.BlockStateMeta;
|
||||||
import org.bukkit.scheduler.BukkitTask;
|
import org.bukkit.scheduler.BukkitTask;
|
||||||
|
|
||||||
import com.bgsoftware.wildstacker.api.WildStackerAPI;
|
import com.bgsoftware.wildstacker.api.WildStackerAPI;
|
||||||
|
@ -67,9 +65,10 @@ public class IslandLevelCalculator {
|
||||||
* @param str - equation to evaluate
|
* @param str - equation to evaluate
|
||||||
* @return value of equation
|
* @return value of equation
|
||||||
*/
|
*/
|
||||||
private static double eval(final String str) {
|
private static double eval(final String str) throws IOException {
|
||||||
return new Object() {
|
return new Object() {
|
||||||
int pos = -1, ch;
|
int pos = -1;
|
||||||
|
int ch;
|
||||||
|
|
||||||
boolean eat(int charToEat) {
|
boolean eat(int charToEat) {
|
||||||
while (ch == ' ') nextChar();
|
while (ch == ' ') nextChar();
|
||||||
|
@ -84,10 +83,10 @@ public class IslandLevelCalculator {
|
||||||
ch = (++pos < str.length()) ? str.charAt(pos) : -1;
|
ch = (++pos < str.length()) ? str.charAt(pos) : -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
double parse() {
|
double parse() throws IOException {
|
||||||
nextChar();
|
nextChar();
|
||||||
double x = parseExpression();
|
double x = parseExpression();
|
||||||
if (pos < str.length()) throw new RuntimeException("Unexpected: " + (char)ch);
|
if (pos < str.length()) throw new IOException("Unexpected: " + (char)ch);
|
||||||
return x;
|
return x;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -97,7 +96,7 @@ public class IslandLevelCalculator {
|
||||||
// factor = `+` factor | `-` factor | `(` expression `)`
|
// factor = `+` factor | `-` factor | `(` expression `)`
|
||||||
// | number | functionName factor | factor `^` factor
|
// | number | functionName factor | factor `^` factor
|
||||||
|
|
||||||
double parseExpression() {
|
double parseExpression() throws IOException {
|
||||||
double x = parseTerm();
|
double x = parseTerm();
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (eat('+')) x += parseTerm(); // addition
|
if (eat('+')) x += parseTerm(); // addition
|
||||||
|
@ -106,7 +105,7 @@ public class IslandLevelCalculator {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
double parseFactor() {
|
double parseFactor() throws IOException {
|
||||||
if (eat('+')) return parseFactor(); // unary plus
|
if (eat('+')) return parseFactor(); // unary plus
|
||||||
if (eat('-')) return -parseFactor(); // unary minus
|
if (eat('-')) return -parseFactor(); // unary minus
|
||||||
|
|
||||||
|
@ -139,10 +138,10 @@ public class IslandLevelCalculator {
|
||||||
x = Math.log(x);
|
x = Math.log(x);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new RuntimeException("Unknown function: " + func);
|
throw new IOException("Unknown function: " + func);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
throw new RuntimeException("Unexpected: " + (char)ch);
|
throw new IOException("Unexpected: " + (char)ch);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (eat('^')) x = Math.pow(x, parseFactor()); // exponentiation
|
if (eat('^')) x = Math.pow(x, parseFactor()); // exponentiation
|
||||||
|
@ -150,7 +149,7 @@ public class IslandLevelCalculator {
|
||||||
return x;
|
return x;
|
||||||
}
|
}
|
||||||
|
|
||||||
double parseTerm() {
|
double parseTerm() throws IOException {
|
||||||
double x = parseFactor();
|
double x = parseFactor();
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (eat('*')) x *= parseFactor(); // multiplication
|
if (eat('*')) x *= parseFactor(); // multiplication
|
||||||
|
@ -163,7 +162,7 @@ public class IslandLevelCalculator {
|
||||||
private final Level addon;
|
private final Level addon;
|
||||||
private final Queue<Pair<Integer, Integer>> chunksToCheck;
|
private final Queue<Pair<Integer, Integer>> chunksToCheck;
|
||||||
private final Island island;
|
private final Island island;
|
||||||
private final HashMap<Material, Integer> limitCount;
|
private final Map<Material, Integer> limitCount;
|
||||||
private final CompletableFuture<Results> r;
|
private final CompletableFuture<Results> r;
|
||||||
|
|
||||||
|
|
||||||
|
@ -192,7 +191,7 @@ public class IslandLevelCalculator {
|
||||||
results = new Results();
|
results = new Results();
|
||||||
duration = System.currentTimeMillis();
|
duration = System.currentTimeMillis();
|
||||||
chunksToCheck = getChunksToScan(island);
|
chunksToCheck = getChunksToScan(island);
|
||||||
this.limitCount = new HashMap<>(addon.getBlockConfig().getBlockLimits());
|
this.limitCount = new EnumMap<>(addon.getBlockConfig().getBlockLimits());
|
||||||
// Get the initial island level
|
// Get the initial island level
|
||||||
results.initialLevel.set(addon.getInitialIslandLevel(island));
|
results.initialLevel.set(addon.getInitialIslandLevel(island));
|
||||||
// Set up the worlds
|
// Set up the worlds
|
||||||
|
@ -223,7 +222,15 @@ public class IslandLevelCalculator {
|
||||||
private long calculateLevel(long blockAndDeathPoints) {
|
private long calculateLevel(long blockAndDeathPoints) {
|
||||||
String calcString = addon.getSettings().getLevelCalc();
|
String calcString = addon.getSettings().getLevelCalc();
|
||||||
String withValues = calcString.replace("blocks", String.valueOf(blockAndDeathPoints)).replace("level_cost", String.valueOf(this.addon.getSettings().getLevelCost()));
|
String withValues = calcString.replace("blocks", String.valueOf(blockAndDeathPoints)).replace("level_cost", String.valueOf(this.addon.getSettings().getLevelCost()));
|
||||||
return (long)eval(withValues) - (addon.getSettings().isZeroNewIslandLevels() ? results.initialLevel.get() : 0);
|
long evalWithValues;
|
||||||
|
try {
|
||||||
|
evalWithValues = (long)eval(withValues);
|
||||||
|
return evalWithValues - (addon.getSettings().isZeroNewIslandLevels() ? results.initialLevel.get() : 0);
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
addon.getPlugin().logStacktrace(e);
|
||||||
|
return 0L;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -426,7 +433,7 @@ public class IslandLevelCalculator {
|
||||||
private void scanChests(Chunk chunk) {
|
private void scanChests(Chunk chunk) {
|
||||||
// Count blocks in chests
|
// Count blocks in chests
|
||||||
for (BlockState bs : chunk.getTileEntities()) {
|
for (BlockState bs : chunk.getTileEntities()) {
|
||||||
if (bs instanceof Container) {
|
if (bs instanceof Container container) {
|
||||||
if (addon.isAdvChestEnabled()) {
|
if (addon.isAdvChestEnabled()) {
|
||||||
AdvancedChest<?,?> aChest = AdvancedChestsAPI.getChestManager().getAdvancedChest(bs.getLocation());
|
AdvancedChest<?,?> aChest = AdvancedChestsAPI.getChestManager().getAdvancedChest(bs.getLocation());
|
||||||
if (aChest != null && aChest.getChestType().getName().equals("NORMAL")) {
|
if (aChest != null && aChest.getChestType().getName().equals("NORMAL")) {
|
||||||
|
@ -439,16 +446,22 @@ public class IslandLevelCalculator {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Regular chest
|
// Regular chest
|
||||||
((Container)bs).getSnapshotInventory().forEach(this::countItemStack);
|
container.getSnapshotInventory().forEach(this::countItemStack);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void countItemStack(ItemStack i) {
|
private void countItemStack(ItemStack i) {
|
||||||
if (i != null && i.getType().isBlock()) {
|
if (i == null || !i.getType().isBlock()) return;
|
||||||
for (int c = 0; c < i.getAmount(); c++) {
|
|
||||||
checkBlock(i.getType(), false);
|
for (int c = 0; c < i.getAmount(); c++) {
|
||||||
|
if (addon.getSettings().isIncludeShulkersInChest()
|
||||||
|
&& i.getItemMeta() instanceof BlockStateMeta blockStateMeta
|
||||||
|
&& blockStateMeta.getBlockState() instanceof ShulkerBox shulkerBox) {
|
||||||
|
shulkerBox.getSnapshotInventory().forEach(this::countItemStack);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
checkBlock(i.getType(), false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -509,7 +522,7 @@ public class IslandLevelCalculator {
|
||||||
}
|
}
|
||||||
// Hook for Wild Stackers (Blocks and Spawners Only) - this has to use the real chunk
|
// Hook for Wild Stackers (Blocks and Spawners Only) - this has to use the real chunk
|
||||||
if (addon.isStackersEnabled() && (blockData.getMaterial().equals(Material.CAULDRON) || blockData.getMaterial().equals(Material.SPAWNER))) {
|
if (addon.isStackersEnabled() && (blockData.getMaterial().equals(Material.CAULDRON) || blockData.getMaterial().equals(Material.SPAWNER))) {
|
||||||
stackedBlocks.add(new Location(cp.world, x + cp.chunkSnapshot.getX() * 16,y,z + cp.chunkSnapshot.getZ() * 16));
|
stackedBlocks.add(new Location(cp.world, (double)x + cp.chunkSnapshot.getX() * 16, y, (double)z + cp.chunkSnapshot.getZ() * 16));
|
||||||
}
|
}
|
||||||
// Scan chests
|
// Scan chests
|
||||||
if (addon.getSettings().isIncludeChests() && CHESTS.contains(blockData.getMaterial())) {
|
if (addon.getSettings().isIncludeChests() && CHESTS.contains(blockData.getMaterial())) {
|
||||||
|
@ -560,21 +573,21 @@ public class IslandLevelCalculator {
|
||||||
}
|
}
|
||||||
|
|
||||||
private Collection<String> sortedReport(int total, Multiset<Material> materialCount) {
|
private Collection<String> sortedReport(int total, Multiset<Material> materialCount) {
|
||||||
Collection<String> r = new ArrayList<>();
|
Collection<String> result = new ArrayList<>();
|
||||||
Iterable<Multiset.Entry<Material>> entriesSortedByCount = Multisets.copyHighestCountFirst(materialCount).entrySet();
|
Iterable<Multiset.Entry<Material>> entriesSortedByCount = Multisets.copyHighestCountFirst(materialCount).entrySet();
|
||||||
for (Entry<Material> en : entriesSortedByCount) {
|
for (Entry<Material> en : entriesSortedByCount) {
|
||||||
Material type = en.getElement();
|
Material type = en.getElement();
|
||||||
|
|
||||||
int value = getValue(type);
|
int value = getValue(type);
|
||||||
|
|
||||||
r.add(type.toString() + ":"
|
result.add(type.toString() + ":"
|
||||||
+ String.format("%,d", en.getCount()) + " blocks x " + value + " = " + (value * en.getCount()));
|
+ String.format("%,d", en.getCount()) + " blocks x " + value + " = " + (value * en.getCount()));
|
||||||
total += (value * en.getCount());
|
total += (value * en.getCount());
|
||||||
|
|
||||||
}
|
}
|
||||||
r.add("Subtotal = " + total);
|
result.add("Subtotal = " + total);
|
||||||
r.add(LINE_BREAK);
|
result.add(LINE_BREAK);
|
||||||
return r;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -634,7 +647,7 @@ public class IslandLevelCalculator {
|
||||||
|
|
||||||
public void scanIsland(Pipeliner pipeliner) {
|
public void scanIsland(Pipeliner pipeliner) {
|
||||||
// Scan the next chunk
|
// Scan the next chunk
|
||||||
scanNextChunk().thenAccept(r -> {
|
scanNextChunk().thenAccept(result -> {
|
||||||
if (!Bukkit.isPrimaryThread()) {
|
if (!Bukkit.isPrimaryThread()) {
|
||||||
addon.getPlugin().logError("scanChunk not on Primary Thread!");
|
addon.getPlugin().logError("scanChunk not on Primary Thread!");
|
||||||
}
|
}
|
||||||
|
@ -649,7 +662,7 @@ public class IslandLevelCalculator {
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (Boolean.TRUE.equals(r) && !pipeliner.getTask().isCancelled()) {
|
if (Boolean.TRUE.equals(result) && !pipeliner.getTask().isCancelled()) {
|
||||||
// scanNextChunk returns true if there are more chunks to scan
|
// scanNextChunk returns true if there are more chunks to scan
|
||||||
scanIsland(pipeliner);
|
scanIsland(pipeliner);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -2,7 +2,6 @@ package world.bentobox.level.commands;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
import world.bentobox.bentobox.api.commands.CompositeCommand;
|
import world.bentobox.bentobox.api.commands.CompositeCommand;
|
||||||
import world.bentobox.bentobox.api.localization.TextVariables;
|
import world.bentobox.bentobox.api.localization.TextVariables;
|
||||||
|
@ -60,6 +59,6 @@ public class AdminTopRemoveCommand extends CompositeCommand {
|
||||||
@Override
|
@Override
|
||||||
public Optional<List<String>> tabComplete(User user, String alias, List<String> args) {
|
public Optional<List<String>> tabComplete(User user, String alias, List<String> args) {
|
||||||
return Optional.of(addon.getManager().getTopTen(getWorld(), Level.TEN).keySet().stream().map(addon.getPlayers()::getName)
|
return Optional.of(addon.getManager().getTopTen(getWorld(), Level.TEN).keySet().stream().map(addon.getPlayers()::getName)
|
||||||
.filter(n -> !n.isEmpty()).collect(Collectors.toList()));
|
.filter(n -> !n.isEmpty()).toList());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@ import world.bentobox.level.util.Utils;
|
||||||
|
|
||||||
public class IslandValueCommand extends CompositeCommand
|
public class IslandValueCommand extends CompositeCommand
|
||||||
{
|
{
|
||||||
|
private static final String MATERIAL = "[material]";
|
||||||
private final Level addon;
|
private final Level addon;
|
||||||
|
|
||||||
|
|
||||||
|
@ -45,7 +46,7 @@ public class IslandValueCommand extends CompositeCommand
|
||||||
if (args.size() > 1)
|
if (args.size() > 1)
|
||||||
{
|
{
|
||||||
this.showHelp(this, user);
|
this.showHelp(this, user);
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args.isEmpty())
|
if (args.isEmpty())
|
||||||
|
@ -73,8 +74,8 @@ public class IslandValueCommand extends CompositeCommand
|
||||||
if (material == null)
|
if (material == null)
|
||||||
{
|
{
|
||||||
Utils.sendMessage(user,
|
Utils.sendMessage(user,
|
||||||
user.getTranslation(this.getWorld(), "level.conversations.unknown-item",
|
user.getTranslation(this.getWorld(), "level.conversations.unknown-item",
|
||||||
"[material]", args.get(0)));
|
MATERIAL, args.get(0)));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -98,24 +99,24 @@ public class IslandValueCommand extends CompositeCommand
|
||||||
if (value != null)
|
if (value != null)
|
||||||
{
|
{
|
||||||
Utils.sendMessage(user,
|
Utils.sendMessage(user,
|
||||||
user.getTranslation(this.getWorld(), "level.conversations.value",
|
user.getTranslation(this.getWorld(), "level.conversations.value",
|
||||||
"[value]", String.valueOf(value),
|
"[value]", String.valueOf(value),
|
||||||
"[material]", Utils.prettifyObject(material, user)));
|
MATERIAL, Utils.prettifyObject(material, user)));
|
||||||
|
|
||||||
double underWater = this.addon.getSettings().getUnderWaterMultiplier();
|
double underWater = this.addon.getSettings().getUnderWaterMultiplier();
|
||||||
|
|
||||||
if (underWater > 1.0)
|
if (underWater > 1.0)
|
||||||
{
|
{
|
||||||
Utils.sendMessage(user,
|
Utils.sendMessage(user,
|
||||||
user.getTranslation(this.getWorld(),"level.conversations.success-underwater",
|
user.getTranslation(this.getWorld(),"level.conversations.success-underwater",
|
||||||
"[value]", (underWater * value) + ""),
|
"[value]", (underWater * value) + ""),
|
||||||
"[material]", Utils.prettifyObject(material, user));
|
MATERIAL, Utils.prettifyObject(material, user));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Utils.sendMessage(user,
|
Utils.sendMessage(user,
|
||||||
user.getTranslation(this.getWorld(),"level.conversations.no-value"));
|
user.getTranslation(this.getWorld(),"level.conversations.no-value"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -132,8 +133,8 @@ public class IslandValueCommand extends CompositeCommand
|
||||||
}
|
}
|
||||||
|
|
||||||
List<String> options = new ArrayList<>(Arrays.stream(Material.values()).
|
List<String> options = new ArrayList<>(Arrays.stream(Material.values()).
|
||||||
filter(Material::isBlock).
|
filter(Material::isBlock).
|
||||||
map(Material::name).toList());
|
map(Material::name).toList());
|
||||||
|
|
||||||
options.add("HAND");
|
options.add("HAND");
|
||||||
|
|
||||||
|
|
|
@ -119,6 +119,12 @@ public class ConfigSettings implements ConfigObject {
|
||||||
@ConfigComment("Shows large level values rounded down, e.g., 10,345 -> 10k")
|
@ConfigComment("Shows large level values rounded down, e.g., 10,345 -> 10k")
|
||||||
@ConfigEntry(path = "shorthand")
|
@ConfigEntry(path = "shorthand")
|
||||||
private boolean shorthand = false;
|
private boolean shorthand = false;
|
||||||
|
@ConfigComment("")
|
||||||
|
@ConfigComment("Include Shulker Box content in chests in level calculations.")
|
||||||
|
@ConfigComment("Will count blocks in Shulker Boxes inside of chests.")
|
||||||
|
@ConfigComment("NOTE: include-chests needs to be enabled for this to work!.")
|
||||||
|
@ConfigEntry(path = "include-shulkers-in-chest")
|
||||||
|
private boolean includeShulkersInChest = false;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -385,4 +391,17 @@ public class ConfigSettings implements ConfigObject {
|
||||||
this.logReportToConsole = logReportToConsole;
|
this.logReportToConsole = logReportToConsole;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return includeShulkersInChest
|
||||||
|
*/
|
||||||
|
public boolean isIncludeShulkersInChest() {
|
||||||
|
return includeShulkersInChest;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param includeShulkersInChest the includeChests to set
|
||||||
|
*/
|
||||||
|
public void setIncludeShulkersInChest(boolean includeShulkersInChest) {
|
||||||
|
this.includeShulkersInChest = includeShulkersInChest;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@ import org.bukkit.inventory.ItemStack;
|
||||||
import com.google.common.base.Enums;
|
import com.google.common.base.Enums;
|
||||||
|
|
||||||
import lv.id.bonne.panelutils.PanelUtils;
|
import lv.id.bonne.panelutils.PanelUtils;
|
||||||
|
import world.bentobox.bentobox.api.localization.TextVariables;
|
||||||
import world.bentobox.bentobox.api.panels.PanelItem;
|
import world.bentobox.bentobox.api.panels.PanelItem;
|
||||||
import world.bentobox.bentobox.api.panels.TemplatedPanel;
|
import world.bentobox.bentobox.api.panels.TemplatedPanel;
|
||||||
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
|
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
|
||||||
|
@ -48,8 +49,8 @@ public class DetailsPanel
|
||||||
* @param user User who opens panel
|
* @param user User who opens panel
|
||||||
*/
|
*/
|
||||||
private DetailsPanel(Level addon,
|
private DetailsPanel(Level addon,
|
||||||
World world,
|
World world,
|
||||||
User user)
|
User user)
|
||||||
{
|
{
|
||||||
this.addon = addon;
|
this.addon = addon;
|
||||||
this.world = world;
|
this.world = world;
|
||||||
|
@ -126,99 +127,93 @@ public class DetailsPanel
|
||||||
|
|
||||||
switch (this.activeTab)
|
switch (this.activeTab)
|
||||||
{
|
{
|
||||||
case ALL_BLOCKS -> {
|
case ALL_BLOCKS -> {
|
||||||
Map<Material, Integer> materialCountMap = new EnumMap<>(Material.class);
|
Map<Material, Integer> materialCountMap = new EnumMap<>(Material.class);
|
||||||
|
|
||||||
materialCountMap.putAll(this.levelsData.getMdCount());
|
materialCountMap.putAll(this.levelsData.getMdCount());
|
||||||
|
|
||||||
// Add underwater blocks.
|
// Add underwater blocks.
|
||||||
this.levelsData.getUwCount().forEach((material, count) -> {
|
this.levelsData.getUwCount().forEach((material, count) -> materialCountMap.put(material,
|
||||||
materialCountMap.put(material,
|
materialCountMap.computeIfAbsent(material, key -> 0) + count));
|
||||||
materialCountMap.computeIfAbsent(material, key -> 0) + count);
|
|
||||||
});
|
|
||||||
|
|
||||||
materialCountMap.entrySet().stream().sorted((Map.Entry.comparingByKey())).
|
materialCountMap.entrySet().stream().sorted((Map.Entry.comparingByKey())).
|
||||||
forEachOrdered(entry ->
|
forEachOrdered(entry ->
|
||||||
this.materialCountList.add(new Pair<>(entry.getKey(), entry.getValue())));
|
this.materialCountList.add(new Pair<>(entry.getKey(), entry.getValue())));
|
||||||
}
|
}
|
||||||
case ABOVE_SEA_LEVEL -> {
|
case ABOVE_SEA_LEVEL -> this.levelsData.getMdCount().entrySet().stream().sorted((Map.Entry.comparingByKey()))
|
||||||
this.levelsData.getMdCount().entrySet().stream().sorted((Map.Entry.comparingByKey())).
|
.forEachOrdered(entry -> this.materialCountList.add(new Pair<>(entry.getKey(), entry.getValue())));
|
||||||
forEachOrdered(entry ->
|
|
||||||
this.materialCountList.add(new Pair<>(entry.getKey(), entry.getValue())));
|
|
||||||
}
|
|
||||||
case UNDERWATER -> {
|
|
||||||
this.levelsData.getUwCount().entrySet().stream().sorted((Map.Entry.comparingByKey())).
|
|
||||||
forEachOrdered(entry ->
|
|
||||||
this.materialCountList.add(new Pair<>(entry.getKey(), entry.getValue())));
|
|
||||||
}
|
|
||||||
case SPAWNER -> {
|
|
||||||
int aboveWater = this.levelsData.getMdCount().getOrDefault(Material.SPAWNER, 0);
|
|
||||||
int underWater = this.levelsData.getUwCount().getOrDefault(Material.SPAWNER, 0);
|
|
||||||
|
|
||||||
// TODO: spawners need some touch...
|
case UNDERWATER -> this.levelsData.getUwCount().entrySet().stream().sorted((Map.Entry.comparingByKey()))
|
||||||
this.materialCountList.add(new Pair<>(Material.SPAWNER, underWater + aboveWater));
|
.forEachOrdered(entry -> this.materialCountList.add(new Pair<>(entry.getKey(), entry.getValue())));
|
||||||
}
|
|
||||||
|
case SPAWNER -> {
|
||||||
|
int aboveWater = this.levelsData.getMdCount().getOrDefault(Material.SPAWNER, 0);
|
||||||
|
int underWater = this.levelsData.getUwCount().getOrDefault(Material.SPAWNER, 0);
|
||||||
|
|
||||||
|
// TODO: spawners need some touch...
|
||||||
|
this.materialCountList.add(new Pair<>(Material.SPAWNER, underWater + aboveWater));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Comparator<Pair<Material, Integer>> sorter;
|
Comparator<Pair<Material, Integer>> sorter;
|
||||||
|
|
||||||
switch (this.activeFilter)
|
switch (this.activeFilter)
|
||||||
{
|
{
|
||||||
case COUNT ->
|
case COUNT ->
|
||||||
|
{
|
||||||
|
sorter = (o1, o2) ->
|
||||||
{
|
{
|
||||||
sorter = (o1, o2) ->
|
if (o1.getValue().equals(o2.getValue()))
|
||||||
{
|
|
||||||
if (o1.getValue().equals(o2.getValue()))
|
|
||||||
{
|
|
||||||
String o1Name = Utils.prettifyObject(o1.getKey(), this.user);
|
|
||||||
String o2Name = Utils.prettifyObject(o2.getKey(), this.user);
|
|
||||||
|
|
||||||
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return Integer.compare(o2.getValue(), o1.getValue());
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
case VALUE ->
|
|
||||||
{
|
|
||||||
sorter = (o1, o2) ->
|
|
||||||
{
|
|
||||||
int blockLimit = this.addon.getBlockConfig().getBlockLimits().getOrDefault(o1.getKey(), 0);
|
|
||||||
int o1Count = blockLimit > 0 ? Math.min(o1.getValue(), blockLimit) : o1.getValue();
|
|
||||||
|
|
||||||
blockLimit = this.addon.getBlockConfig().getBlockLimits().getOrDefault(o2.getKey(), 0);
|
|
||||||
int o2Count = blockLimit > 0 ? Math.min(o2.getValue(), blockLimit) : o2.getValue();
|
|
||||||
|
|
||||||
long o1Value = (long) o1Count *
|
|
||||||
this.addon.getBlockConfig().getBlockValues().getOrDefault(o1.getKey(), 0);
|
|
||||||
long o2Value = (long) o2Count *
|
|
||||||
this.addon.getBlockConfig().getBlockValues().getOrDefault(o2.getKey(), 0);
|
|
||||||
|
|
||||||
if (o1Value == o2Value)
|
|
||||||
{
|
|
||||||
String o1Name = Utils.prettifyObject(o1.getKey(), this.user);
|
|
||||||
String o2Name = Utils.prettifyObject(o2.getKey(), this.user);
|
|
||||||
|
|
||||||
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return Long.compare(o2Value, o1Value);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
default ->
|
|
||||||
{
|
|
||||||
sorter = (o1, o2) ->
|
|
||||||
{
|
{
|
||||||
String o1Name = Utils.prettifyObject(o1.getKey(), this.user);
|
String o1Name = Utils.prettifyObject(o1.getKey(), this.user);
|
||||||
String o2Name = Utils.prettifyObject(o2.getKey(), this.user);
|
String o2Name = Utils.prettifyObject(o2.getKey(), this.user);
|
||||||
|
|
||||||
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
||||||
};
|
}
|
||||||
}
|
else
|
||||||
|
{
|
||||||
|
return Integer.compare(o2.getValue(), o1.getValue());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
case VALUE ->
|
||||||
|
{
|
||||||
|
sorter = (o1, o2) ->
|
||||||
|
{
|
||||||
|
int blockLimit = this.addon.getBlockConfig().getBlockLimits().getOrDefault(o1.getKey(), 0);
|
||||||
|
int o1Count = blockLimit > 0 ? Math.min(o1.getValue(), blockLimit) : o1.getValue();
|
||||||
|
|
||||||
|
blockLimit = this.addon.getBlockConfig().getBlockLimits().getOrDefault(o2.getKey(), 0);
|
||||||
|
int o2Count = blockLimit > 0 ? Math.min(o2.getValue(), blockLimit) : o2.getValue();
|
||||||
|
|
||||||
|
long o1Value = (long) o1Count *
|
||||||
|
this.addon.getBlockConfig().getBlockValues().getOrDefault(o1.getKey(), 0);
|
||||||
|
long o2Value = (long) o2Count *
|
||||||
|
this.addon.getBlockConfig().getBlockValues().getOrDefault(o2.getKey(), 0);
|
||||||
|
|
||||||
|
if (o1Value == o2Value)
|
||||||
|
{
|
||||||
|
String o1Name = Utils.prettifyObject(o1.getKey(), this.user);
|
||||||
|
String o2Name = Utils.prettifyObject(o2.getKey(), this.user);
|
||||||
|
|
||||||
|
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return Long.compare(o2Value, o1Value);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
default ->
|
||||||
|
{
|
||||||
|
sorter = (o1, o2) ->
|
||||||
|
{
|
||||||
|
String o1Name = Utils.prettifyObject(o1.getKey(), this.user);
|
||||||
|
String o2Name = Utils.prettifyObject(o2.getKey(), this.user);
|
||||||
|
|
||||||
|
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
||||||
|
};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.materialCountList.sort(sorter);
|
this.materialCountList.sort(sorter);
|
||||||
|
@ -227,9 +222,9 @@ public class DetailsPanel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Tab Button Type
|
// Section: Tab Button Type
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -267,23 +262,21 @@ public class DetailsPanel
|
||||||
List<ItemTemplateRecord.ActionRecords> activeActions = new ArrayList<>(template.actions());
|
List<ItemTemplateRecord.ActionRecords> activeActions = new ArrayList<>(template.actions());
|
||||||
|
|
||||||
activeActions.removeIf(action ->
|
activeActions.removeIf(action ->
|
||||||
"VIEW".equalsIgnoreCase(action.actionType()) && this.activeTab == tab);
|
"VIEW".equalsIgnoreCase(action.actionType()) && this.activeTab == tab);
|
||||||
|
|
||||||
// Add Click handler
|
// Add Click handler
|
||||||
builder.clickHandler((panel, user, clickType, i) ->
|
builder.clickHandler((panel, user, clickType, i) ->
|
||||||
{
|
{
|
||||||
for (ItemTemplateRecord.ActionRecords action : activeActions)
|
for (ItemTemplateRecord.ActionRecords action : activeActions)
|
||||||
{
|
{
|
||||||
if (clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType()))
|
if ((clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType()))
|
||||||
|
&& "VIEW".equalsIgnoreCase(action.actionType()))
|
||||||
{
|
{
|
||||||
if ("VIEW".equalsIgnoreCase(action.actionType()))
|
this.activeTab = tab;
|
||||||
{
|
|
||||||
this.activeTab = tab;
|
|
||||||
|
|
||||||
// Update filters.
|
// Update filters.
|
||||||
this.updateFilters();
|
this.updateFilters();
|
||||||
this.build();
|
this.build();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -292,10 +285,10 @@ public class DetailsPanel
|
||||||
|
|
||||||
// Collect tooltips.
|
// Collect tooltips.
|
||||||
List<String> tooltips = activeActions.stream().
|
List<String> tooltips = activeActions.stream().
|
||||||
filter(action -> action.tooltip() != null).
|
filter(action -> action.tooltip() != null).
|
||||||
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
||||||
filter(text -> !text.isBlank()).
|
filter(text -> !text.isBlank()).
|
||||||
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
||||||
|
|
||||||
// Add tooltips.
|
// Add tooltips.
|
||||||
if (!tooltips.isEmpty())
|
if (!tooltips.isEmpty())
|
||||||
|
@ -403,10 +396,10 @@ public class DetailsPanel
|
||||||
|
|
||||||
// Collect tooltips.
|
// Collect tooltips.
|
||||||
List<String> tooltips = activeActions.stream().
|
List<String> tooltips = activeActions.stream().
|
||||||
filter(action -> action.tooltip() != null).
|
filter(action -> action.tooltip() != null).
|
||||||
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
||||||
filter(text -> !text.isBlank()).
|
filter(text -> !text.isBlank()).
|
||||||
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
||||||
|
|
||||||
// Add tooltips.
|
// Add tooltips.
|
||||||
if (!tooltips.isEmpty())
|
if (!tooltips.isEmpty())
|
||||||
|
@ -422,9 +415,9 @@ public class DetailsPanel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Create common buttons
|
// Section: Create common buttons
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -439,7 +432,7 @@ public class DetailsPanel
|
||||||
long size = this.materialCountList.size();
|
long size = this.materialCountList.size();
|
||||||
|
|
||||||
if (size <= slot.amountMap().getOrDefault("BLOCK", 1) ||
|
if (size <= slot.amountMap().getOrDefault("BLOCK", 1) ||
|
||||||
1.0 * size / slot.amountMap().getOrDefault("BLOCK", 1) <= this.pageIndex + 1)
|
1.0 * size / slot.amountMap().getOrDefault("BLOCK", 1) <= this.pageIndex + 1)
|
||||||
{
|
{
|
||||||
// There are no next elements
|
// There are no next elements
|
||||||
return null;
|
return null;
|
||||||
|
@ -453,7 +446,7 @@ public class DetailsPanel
|
||||||
{
|
{
|
||||||
ItemStack clone = template.icon().clone();
|
ItemStack clone = template.icon().clone();
|
||||||
|
|
||||||
if ((Boolean) template.dataMap().getOrDefault("indexing", false))
|
if (Boolean.TRUE.equals(template.dataMap().getOrDefault("indexing", false)))
|
||||||
{
|
{
|
||||||
clone.setAmount(nextPageIndex);
|
clone.setAmount(nextPageIndex);
|
||||||
}
|
}
|
||||||
|
@ -469,7 +462,7 @@ public class DetailsPanel
|
||||||
if (template.description() != null)
|
if (template.description() != null)
|
||||||
{
|
{
|
||||||
builder.description(this.user.getTranslation(this.world, template.description(),
|
builder.description(this.user.getTranslation(this.world, template.description(),
|
||||||
"[number]", String.valueOf(nextPageIndex)));
|
TextVariables.NUMBER, String.valueOf(nextPageIndex)));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add ClickHandler
|
// Add ClickHandler
|
||||||
|
@ -477,13 +470,11 @@ public class DetailsPanel
|
||||||
{
|
{
|
||||||
for (ItemTemplateRecord.ActionRecords action : template.actions())
|
for (ItemTemplateRecord.ActionRecords action : template.actions())
|
||||||
{
|
{
|
||||||
if (clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType()))
|
if ((clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType())) &&
|
||||||
|
"NEXT".equalsIgnoreCase(action.actionType()))
|
||||||
{
|
{
|
||||||
if ("NEXT".equalsIgnoreCase(action.actionType()))
|
this.pageIndex++;
|
||||||
{
|
this.build();
|
||||||
this.pageIndex++;
|
|
||||||
this.build();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -493,10 +484,10 @@ public class DetailsPanel
|
||||||
|
|
||||||
// Collect tooltips.
|
// Collect tooltips.
|
||||||
List<String> tooltips = template.actions().stream().
|
List<String> tooltips = template.actions().stream().
|
||||||
filter(action -> action.tooltip() != null).
|
filter(action -> action.tooltip() != null).
|
||||||
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
||||||
filter(text -> !text.isBlank()).
|
filter(text -> !text.isBlank()).
|
||||||
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
||||||
|
|
||||||
// Add tooltips.
|
// Add tooltips.
|
||||||
if (!tooltips.isEmpty())
|
if (!tooltips.isEmpty())
|
||||||
|
@ -533,7 +524,7 @@ public class DetailsPanel
|
||||||
{
|
{
|
||||||
ItemStack clone = template.icon().clone();
|
ItemStack clone = template.icon().clone();
|
||||||
|
|
||||||
if ((Boolean) template.dataMap().getOrDefault("indexing", false))
|
if (Boolean.TRUE.equals(template.dataMap().getOrDefault("indexing", false)))
|
||||||
{
|
{
|
||||||
clone.setAmount(previousPageIndex);
|
clone.setAmount(previousPageIndex);
|
||||||
}
|
}
|
||||||
|
@ -549,7 +540,7 @@ public class DetailsPanel
|
||||||
if (template.description() != null)
|
if (template.description() != null)
|
||||||
{
|
{
|
||||||
builder.description(this.user.getTranslation(this.world, template.description(),
|
builder.description(this.user.getTranslation(this.world, template.description(),
|
||||||
"[number]", String.valueOf(previousPageIndex)));
|
TextVariables.NUMBER, String.valueOf(previousPageIndex)));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add ClickHandler
|
// Add ClickHandler
|
||||||
|
@ -557,13 +548,11 @@ public class DetailsPanel
|
||||||
{
|
{
|
||||||
for (ItemTemplateRecord.ActionRecords action : template.actions())
|
for (ItemTemplateRecord.ActionRecords action : template.actions())
|
||||||
{
|
{
|
||||||
if (clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType()))
|
if ((clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType()))
|
||||||
|
&& "PREVIOUS".equalsIgnoreCase(action.actionType()))
|
||||||
{
|
{
|
||||||
if ("PREVIOUS".equalsIgnoreCase(action.actionType()))
|
this.pageIndex--;
|
||||||
{
|
this.build();
|
||||||
this.pageIndex--;
|
|
||||||
this.build();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -573,10 +562,10 @@ public class DetailsPanel
|
||||||
|
|
||||||
// Collect tooltips.
|
// Collect tooltips.
|
||||||
List<String> tooltips = template.actions().stream().
|
List<String> tooltips = template.actions().stream().
|
||||||
filter(action -> action.tooltip() != null).
|
filter(action -> action.tooltip() != null).
|
||||||
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
||||||
filter(text -> !text.isBlank()).
|
filter(text -> !text.isBlank()).
|
||||||
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
||||||
|
|
||||||
// Add tooltips.
|
// Add tooltips.
|
||||||
if (!tooltips.isEmpty())
|
if (!tooltips.isEmpty())
|
||||||
|
@ -590,9 +579,9 @@ public class DetailsPanel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Create Material Button
|
// Section: Create Material Button
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -630,7 +619,7 @@ public class DetailsPanel
|
||||||
* @return PanelItem for generator tier.
|
* @return PanelItem for generator tier.
|
||||||
*/
|
*/
|
||||||
private PanelItem createMaterialButton(ItemTemplateRecord template,
|
private PanelItem createMaterialButton(ItemTemplateRecord template,
|
||||||
Pair<Material, Integer> materialCount)
|
Pair<Material, Integer> materialCount)
|
||||||
{
|
{
|
||||||
PanelItemBuilder builder = new PanelItemBuilder();
|
PanelItemBuilder builder = new PanelItemBuilder();
|
||||||
|
|
||||||
|
@ -651,30 +640,30 @@ public class DetailsPanel
|
||||||
if (template.title() != null)
|
if (template.title() != null)
|
||||||
{
|
{
|
||||||
builder.name(this.user.getTranslation(this.world, template.title(),
|
builder.name(this.user.getTranslation(this.world, template.title(),
|
||||||
"[number]", String.valueOf(materialCount.getValue()),
|
TextVariables.NUMBER, String.valueOf(materialCount.getValue()),
|
||||||
"[material]", Utils.prettifyObject(materialCount.getKey(), this.user)));
|
"[material]", Utils.prettifyObject(materialCount.getKey(), this.user)));
|
||||||
}
|
}
|
||||||
|
|
||||||
String description = Utils.prettifyDescription(materialCount.getKey(), this.user);
|
String description = Utils.prettifyDescription(materialCount.getKey(), this.user);
|
||||||
|
|
||||||
final String reference = "level.gui.buttons.material.";
|
final String reference = "level.gui.buttons.material.";
|
||||||
String blockId = this.user.getTranslationOrNothing(reference + "id",
|
String blockId = this.user.getTranslationOrNothing(reference + "id",
|
||||||
"[id]", materialCount.getKey().name());
|
"[id]", materialCount.getKey().name());
|
||||||
|
|
||||||
int blockValue = this.addon.getBlockConfig().getBlockValues().getOrDefault(materialCount.getKey(), 0);
|
int blockValue = this.addon.getBlockConfig().getBlockValues().getOrDefault(materialCount.getKey(), 0);
|
||||||
String value = blockValue > 0 ? this.user.getTranslationOrNothing(reference + "value",
|
String value = blockValue > 0 ? this.user.getTranslationOrNothing(reference + "value",
|
||||||
"[number]", String.valueOf(blockValue)) : "";
|
TextVariables.NUMBER, String.valueOf(blockValue)) : "";
|
||||||
|
|
||||||
int blockLimit = this.addon.getBlockConfig().getBlockLimits().getOrDefault(materialCount.getKey(), 0);
|
int blockLimit = this.addon.getBlockConfig().getBlockLimits().getOrDefault(materialCount.getKey(), 0);
|
||||||
String limit = blockLimit > 0 ? this.user.getTranslationOrNothing(reference + "limit",
|
String limit = blockLimit > 0 ? this.user.getTranslationOrNothing(reference + "limit",
|
||||||
"[number]", String.valueOf(blockLimit)) : "";
|
TextVariables.NUMBER, String.valueOf(blockLimit)) : "";
|
||||||
|
|
||||||
String count = this.user.getTranslationOrNothing(reference + "count",
|
String count = this.user.getTranslationOrNothing(reference + "count",
|
||||||
"[number]", String.valueOf(materialCount.getValue()));
|
TextVariables.NUMBER, String.valueOf(materialCount.getValue()));
|
||||||
|
|
||||||
long calculatedValue = (long) Math.min(blockLimit > 0 ? blockLimit : Integer.MAX_VALUE, materialCount.getValue()) * blockValue;
|
long calculatedValue = (long) Math.min(blockLimit > 0 ? blockLimit : Integer.MAX_VALUE, materialCount.getValue()) * blockValue;
|
||||||
String valueText = calculatedValue > 0 ? this.user.getTranslationOrNothing(reference + "calculated",
|
String valueText = calculatedValue > 0 ? this.user.getTranslationOrNothing(reference + "calculated",
|
||||||
"[number]", String.valueOf(calculatedValue)) : "";
|
TextVariables.NUMBER, String.valueOf(calculatedValue)) : "";
|
||||||
|
|
||||||
if (template.description() != null)
|
if (template.description() != null)
|
||||||
{
|
{
|
||||||
|
@ -685,18 +674,18 @@ public class DetailsPanel
|
||||||
"[calculated]", valueText,
|
"[calculated]", valueText,
|
||||||
"[limit]", limit,
|
"[limit]", limit,
|
||||||
"[count]", count).
|
"[count]", count).
|
||||||
replaceAll("(?m)^[ \\t]*\\r?\\n", "").
|
replaceAll("(?m)^[ \\t]*\\r?\\n", "").
|
||||||
replaceAll("(?<!\\\\)\\|", "\n").
|
replaceAll("(?<!\\\\)\\|", "\n").
|
||||||
replaceAll("\\\\\\|", "|"));
|
replace("\\\\\\|", "|"));
|
||||||
}
|
}
|
||||||
|
|
||||||
return builder.build();
|
return builder.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Other Methods
|
// Section: Other Methods
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -708,16 +697,16 @@ public class DetailsPanel
|
||||||
* @param user User who opens panel
|
* @param user User who opens panel
|
||||||
*/
|
*/
|
||||||
public static void openPanel(Level addon,
|
public static void openPanel(Level addon,
|
||||||
World world,
|
World world,
|
||||||
User user)
|
User user)
|
||||||
{
|
{
|
||||||
new DetailsPanel(addon, world, user).build();
|
new DetailsPanel(addon, world, user).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Enums
|
// Section: Enums
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -764,9 +753,9 @@ public class DetailsPanel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Variables
|
// Section: Variables
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This variable holds targeted island.
|
* This variable holds targeted island.
|
||||||
|
|
|
@ -6,14 +6,18 @@
|
||||||
package world.bentobox.level.panels;
|
package world.bentobox.level.panels;
|
||||||
|
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.event.inventory.ClickType;
|
import org.bukkit.event.inventory.ClickType;
|
||||||
import java.io.File;
|
|
||||||
import java.util.*;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
import world.bentobox.bentobox.api.addons.GameModeAddon;
|
import world.bentobox.bentobox.api.addons.GameModeAddon;
|
||||||
|
import world.bentobox.bentobox.api.localization.TextVariables;
|
||||||
import world.bentobox.bentobox.api.panels.PanelItem;
|
import world.bentobox.bentobox.api.panels.PanelItem;
|
||||||
import world.bentobox.bentobox.api.panels.TemplatedPanel;
|
import world.bentobox.bentobox.api.panels.TemplatedPanel;
|
||||||
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
|
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
|
||||||
|
@ -31,9 +35,11 @@ import world.bentobox.level.util.Utils;
|
||||||
*/
|
*/
|
||||||
public class TopLevelPanel
|
public class TopLevelPanel
|
||||||
{
|
{
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
// Section: Internal Constructor
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
// Section: Internal Constructor
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -53,11 +59,11 @@ public class TopLevelPanel
|
||||||
this.iconPermission = permissionPrefix + "level.icon";
|
this.iconPermission = permissionPrefix + "level.icon";
|
||||||
|
|
||||||
this.topIslands = this.addon.getManager().getTopTen(this.world, 10).entrySet().stream().
|
this.topIslands = this.addon.getManager().getTopTen(this.world, 10).entrySet().stream().
|
||||||
map(entry -> {
|
map(entry -> {
|
||||||
Island island = this.addon.getIslandsManager().getIsland(this.world, entry.getKey());
|
Island island = this.addon.getIslandsManager().getIsland(this.world, entry.getKey());
|
||||||
return new IslandTopRecord(island, entry.getValue());
|
return new IslandTopRecord(island, entry.getValue());
|
||||||
}).
|
}).
|
||||||
collect(Collectors.toList());
|
collect(Collectors.toList());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -82,9 +88,9 @@ public class TopLevelPanel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Methods
|
// Section: Methods
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -100,8 +106,6 @@ public class TopLevelPanel
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
final String reference = "level.gui.buttons.island.";
|
|
||||||
|
|
||||||
PanelItemBuilder builder = new PanelItemBuilder();
|
PanelItemBuilder builder = new PanelItemBuilder();
|
||||||
|
|
||||||
if (template.icon() != null)
|
if (template.icon() != null)
|
||||||
|
@ -112,18 +116,18 @@ public class TopLevelPanel
|
||||||
if (template.title() != null)
|
if (template.title() != null)
|
||||||
{
|
{
|
||||||
builder.name(this.user.getTranslation(this.world, template.title(),
|
builder.name(this.user.getTranslation(this.world, template.title(),
|
||||||
"[name]", String.valueOf(index)));
|
TextVariables.NAME, String.valueOf(index)));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
builder.name(this.user.getTranslation(this.world, reference,
|
builder.name(this.user.getTranslation(this.world, REFERENCE,
|
||||||
"[name]", String.valueOf(index)));
|
TextVariables.NAME, String.valueOf(index)));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (template.description() != null)
|
if (template.description() != null)
|
||||||
{
|
{
|
||||||
builder.description(this.user.getTranslation(this.world, template.description(),
|
builder.description(this.user.getTranslation(this.world, template.description(),
|
||||||
"[number]", String.valueOf(index)));
|
TextVariables.NUMBER, String.valueOf(index)));
|
||||||
}
|
}
|
||||||
|
|
||||||
builder.amount(index != 0 ? (int) index : 1);
|
builder.amount(index != 0 ? (int) index : 1);
|
||||||
|
@ -189,23 +193,23 @@ public class TopLevelPanel
|
||||||
{
|
{
|
||||||
switch (action.actionType().toUpperCase())
|
switch (action.actionType().toUpperCase())
|
||||||
{
|
{
|
||||||
case "WARP" -> {
|
case "WARP" -> {
|
||||||
return island.getOwner() == null ||
|
return island.getOwner() == null ||
|
||||||
this.addon.getWarpHook() == null ||
|
this.addon.getWarpHook() == null ||
|
||||||
!this.addon.getWarpHook().getWarpSignsManager().hasWarp(this.world, island.getOwner());
|
!this.addon.getWarpHook().getWarpSignsManager().hasWarp(this.world, island.getOwner());
|
||||||
}
|
}
|
||||||
case "VISIT" -> {
|
case "VISIT" -> {
|
||||||
return island.getOwner() == null ||
|
return island.getOwner() == null ||
|
||||||
this.addon.getVisitHook() == null ||
|
this.addon.getVisitHook() == null ||
|
||||||
!this.addon.getVisitHook().getAddonManager().preprocessTeleportation(this.user, island);
|
!this.addon.getVisitHook().getAddonManager().preprocessTeleportation(this.user, island);
|
||||||
}
|
}
|
||||||
case "VIEW" -> {
|
case "VIEW" -> {
|
||||||
return island.getOwner() == null ||
|
return island.getOwner() == null ||
|
||||||
!island.getMemberSet(RanksManager.MEMBER_RANK).contains(this.user.getUniqueId());
|
!island.getMemberSet(RanksManager.MEMBER_RANK).contains(this.user.getUniqueId());
|
||||||
}
|
}
|
||||||
default -> {
|
default -> {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -218,33 +222,38 @@ public class TopLevelPanel
|
||||||
{
|
{
|
||||||
switch (action.actionType().toUpperCase())
|
switch (action.actionType().toUpperCase())
|
||||||
{
|
{
|
||||||
case "WARP" -> {
|
case "WARP" -> {
|
||||||
this.user.closeInventory();
|
this.user.closeInventory();
|
||||||
this.addon.getWarpHook().getWarpSignsManager().warpPlayer(this.world, this.user, island.getOwner());
|
this.addon.getWarpHook().getWarpSignsManager().warpPlayer(this.world, this.user, island.getOwner());
|
||||||
}
|
}
|
||||||
case "VISIT" -> {
|
case "VISIT" ->
|
||||||
// The command call implementation solves necessity to check for all visits options,
|
// The command call implementation solves necessity to check for all visits options,
|
||||||
// like cool down, confirmation and preprocess in single go. Would it be better to write
|
// like cool down, confirmation and preprocess in single go. Would it be better to write
|
||||||
// all logic here?
|
// all logic here?
|
||||||
|
|
||||||
this.addon.getPlugin().getIWM().getAddon(this.world).
|
this.addon.getPlugin().getIWM().getAddon(this.world).
|
||||||
flatMap(GameModeAddon::getPlayerCommand).ifPresent(command ->
|
flatMap(GameModeAddon::getPlayerCommand).ifPresent(command ->
|
||||||
{
|
{
|
||||||
String mainCommand =
|
String mainCommand =
|
||||||
this.addon.getVisitHook().getSettings().getPlayerMainCommand();
|
this.addon.getVisitHook().getSettings().getPlayerMainCommand();
|
||||||
|
|
||||||
if (!mainCommand.isBlank())
|
if (!mainCommand.isBlank())
|
||||||
{
|
{
|
||||||
this.user.closeInventory();
|
|
||||||
this.user.performCommand(command.getTopLabel() + " " + mainCommand + " " + island.getOwner());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
case "VIEW" -> {
|
|
||||||
this.user.closeInventory();
|
this.user.closeInventory();
|
||||||
// Open Detailed GUI.
|
this.user.performCommand(command.getTopLabel() + " " + mainCommand + " " + island.getOwner());
|
||||||
DetailsPanel.openPanel(this.addon, this.world, this.user);
|
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
case "VIEW" -> {
|
||||||
|
this.user.closeInventory();
|
||||||
|
// Open Detailed GUI.
|
||||||
|
DetailsPanel.openPanel(this.addon, this.world, this.user);
|
||||||
|
}
|
||||||
|
// Catch default
|
||||||
|
default -> {
|
||||||
|
this.user.closeInventory();
|
||||||
|
addon.logError("Unknown action type " + action.actionType().toUpperCase());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -254,10 +263,10 @@ public class TopLevelPanel
|
||||||
|
|
||||||
// Collect tooltips.
|
// Collect tooltips.
|
||||||
List<String> tooltips = activeActions.stream().
|
List<String> tooltips = activeActions.stream().
|
||||||
filter(action -> action.tooltip() != null).
|
filter(action -> action.tooltip() != null).
|
||||||
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
||||||
filter(text -> !text.isBlank()).
|
filter(text -> !text.isBlank()).
|
||||||
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
||||||
|
|
||||||
// Add tooltips.
|
// Add tooltips.
|
||||||
if (!tooltips.isEmpty())
|
if (!tooltips.isEmpty())
|
||||||
|
@ -278,22 +287,21 @@ public class TopLevelPanel
|
||||||
* @param template the template
|
* @param template the template
|
||||||
* @param island the island
|
* @param island the island
|
||||||
*/
|
*/
|
||||||
private void populateIslandTitle(PanelItemBuilder builder,
|
private void populateIslandTitle(PanelItemBuilder builder,
|
||||||
ItemTemplateRecord template,
|
ItemTemplateRecord template,
|
||||||
Island island)
|
Island island)
|
||||||
{
|
{
|
||||||
final String reference = "level.gui.buttons.island.";
|
|
||||||
|
|
||||||
// Get Island Name
|
// Get Island Name
|
||||||
String nameText;
|
String nameText;
|
||||||
|
|
||||||
if (island.getName() == null || island.getName().isEmpty())
|
if (island.getName() == null || island.getName().isEmpty())
|
||||||
{
|
{
|
||||||
nameText = this.user.getTranslation(reference + "owners-island",
|
nameText = this.user.getTranslation(REFERENCE + "owners-island",
|
||||||
"[player]",
|
PLAYER,
|
||||||
island.getOwner() == null ?
|
island.getOwner() == null ?
|
||||||
this.user.getTranslation(reference + "unknown") :
|
this.user.getTranslation(REFERENCE + "unknown") :
|
||||||
this.addon.getPlayers().getName(island.getOwner()));
|
this.addon.getPlayers().getName(island.getOwner()));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -304,11 +312,11 @@ public class TopLevelPanel
|
||||||
if (template.title() != null && !template.title().isBlank())
|
if (template.title() != null && !template.title().isBlank())
|
||||||
{
|
{
|
||||||
builder.name(this.user.getTranslation(this.world, template.title(),
|
builder.name(this.user.getTranslation(this.world, template.title(),
|
||||||
"[name]", nameText));
|
TextVariables.NAME, nameText));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
builder.name(this.user.getTranslation(reference + "name", "[name]", nameText));
|
builder.name(this.user.getTranslation(REFERENCE + "name", TextVariables.NAME, nameText));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -321,11 +329,11 @@ public class TopLevelPanel
|
||||||
* @param island the island
|
* @param island the island
|
||||||
*/
|
*/
|
||||||
private void populateIslandIcon(PanelItemBuilder builder,
|
private void populateIslandIcon(PanelItemBuilder builder,
|
||||||
ItemTemplateRecord template,
|
ItemTemplateRecord template,
|
||||||
Island island)
|
Island island)
|
||||||
{
|
{
|
||||||
User owner = island.getOwner() == null ? null : User.getInstance(island.getOwner());
|
User owner = island.getOwner() == null ? null : User.getInstance(island.getOwner());
|
||||||
|
|
||||||
// Get permission or island icon
|
// Get permission or island icon
|
||||||
String permissionIcon = owner == null ? null :
|
String permissionIcon = owner == null ? null :
|
||||||
Utils.getPermissionValue(owner, this.iconPermission, null);
|
Utils.getPermissionValue(owner, this.iconPermission, null);
|
||||||
|
@ -376,20 +384,18 @@ public class TopLevelPanel
|
||||||
* @param islandTopRecord the top record object
|
* @param islandTopRecord the top record object
|
||||||
* @param index place index.
|
* @param index place index.
|
||||||
*/
|
*/
|
||||||
private void populateIslandDescription(PanelItemBuilder builder,
|
private void populateIslandDescription(PanelItemBuilder builder,
|
||||||
ItemTemplateRecord template,
|
ItemTemplateRecord template,
|
||||||
Island island,
|
Island island,
|
||||||
IslandTopRecord islandTopRecord,
|
IslandTopRecord islandTopRecord,
|
||||||
int index)
|
int index)
|
||||||
{
|
{
|
||||||
final String reference = "level.gui.buttons.island.";
|
|
||||||
|
|
||||||
// Get Owner Name
|
// Get Owner Name
|
||||||
String ownerText = this.user.getTranslation(reference + "owner",
|
String ownerText = this.user.getTranslation(REFERENCE + "owner",
|
||||||
"[player]",
|
PLAYER,
|
||||||
island.getOwner() == null ?
|
island.getOwner() == null ?
|
||||||
this.user.getTranslation(reference + "unknown") :
|
this.user.getTranslation(REFERENCE + "unknown") :
|
||||||
this.addon.getPlayers().getName(island.getOwner()));
|
this.addon.getPlayers().getName(island.getOwner()));
|
||||||
|
|
||||||
// Get Members Text
|
// Get Members Text
|
||||||
String memberText;
|
String memberText;
|
||||||
|
@ -397,11 +403,11 @@ public class TopLevelPanel
|
||||||
if (island.getMemberSet().size() > 1)
|
if (island.getMemberSet().size() > 1)
|
||||||
{
|
{
|
||||||
StringBuilder memberBuilder = new StringBuilder(
|
StringBuilder memberBuilder = new StringBuilder(
|
||||||
this.user.getTranslationOrNothing(reference + "members-title"));
|
this.user.getTranslationOrNothing(REFERENCE + "members-title"));
|
||||||
|
|
||||||
for (UUID uuid : island.getMemberSet())
|
for (UUID uuid : island.getMemberSet())
|
||||||
{
|
{
|
||||||
User user = User.getInstance(uuid);
|
User member = User.getInstance(uuid);
|
||||||
|
|
||||||
if (memberBuilder.length() > 0)
|
if (memberBuilder.length() > 0)
|
||||||
{
|
{
|
||||||
|
@ -409,8 +415,8 @@ public class TopLevelPanel
|
||||||
}
|
}
|
||||||
|
|
||||||
memberBuilder.append(
|
memberBuilder.append(
|
||||||
this.user.getTranslationOrNothing(reference + "member",
|
this.user.getTranslationOrNothing(REFERENCE + "member",
|
||||||
"[player]", user.getName()));
|
PLAYER, member.getName()));
|
||||||
}
|
}
|
||||||
|
|
||||||
memberText = memberBuilder.toString();
|
memberText = memberBuilder.toString();
|
||||||
|
@ -420,11 +426,11 @@ public class TopLevelPanel
|
||||||
memberText = "";
|
memberText = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
String placeText = this.user.getTranslation(reference + "place",
|
String placeText = this.user.getTranslation(REFERENCE + "place",
|
||||||
"[number]", String.valueOf(index));
|
TextVariables.NUMBER, String.valueOf(index));
|
||||||
|
|
||||||
String levelText = this.user.getTranslation(reference + "level",
|
String levelText = this.user.getTranslation(REFERENCE + "level",
|
||||||
"[number]", this.addon.getManager().formatLevel(islandTopRecord.level()));
|
TextVariables.NUMBER, this.addon.getManager().formatLevel(islandTopRecord.level()));
|
||||||
|
|
||||||
// Template specific description is always more important than custom one.
|
// Template specific description is always more important than custom one.
|
||||||
if (template.description() != null && !template.description().isBlank())
|
if (template.description() != null && !template.description().isBlank())
|
||||||
|
@ -434,26 +440,26 @@ public class TopLevelPanel
|
||||||
"[members]", memberText,
|
"[members]", memberText,
|
||||||
"[level]", levelText,
|
"[level]", levelText,
|
||||||
"[place]", placeText).
|
"[place]", placeText).
|
||||||
replaceAll("(?m)^[ \\t]*\\r?\\n", "").
|
replaceAll("(?m)^[ \\t]*\\r?\\n", "").
|
||||||
replaceAll("(?<!\\\\)\\|", "\n").
|
replaceAll("(?<!\\\\)\\|", "\n").
|
||||||
replaceAll("\\\\\\|", "|"));
|
replace("\\\\\\|", "|")); // Not a regex - replace is more efficient
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Now combine everything.
|
// Now combine everything.
|
||||||
String descriptionText = this.user.getTranslation(reference + "description",
|
String descriptionText = this.user.getTranslation(REFERENCE + "description",
|
||||||
"[owner]", ownerText,
|
"[owner]", ownerText,
|
||||||
"[members]", memberText,
|
"[members]", memberText,
|
||||||
"[level]", levelText,
|
"[level]", levelText,
|
||||||
"[place]", placeText);
|
"[place]", placeText);
|
||||||
|
|
||||||
builder.description(descriptionText.
|
builder.description(descriptionText.
|
||||||
replaceAll("(?m)^[ \\t]*\\r?\\n", "").
|
replaceAll("(?m)^[ \\t]*\\r?\\n", "").
|
||||||
replaceAll("(?<!\\\\)\\|", "\n").
|
replaceAll("(?<!\\\\)\\|", "\n").
|
||||||
replaceAll("\\\\\\|", "|"));
|
replace("\\\\\\|", "|")); // Not a regex - replace is more efficient
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create viewer button panel item.
|
* Create viewer button panel item.
|
||||||
|
@ -473,11 +479,11 @@ public class TopLevelPanel
|
||||||
int place = this.addon.getManager().getRank(this.world, this.user.getUniqueId());
|
int place = this.addon.getManager().getRank(this.world, this.user.getUniqueId());
|
||||||
long level = this.addon.getIslandLevel(this.world, island.getOwner());
|
long level = this.addon.getIslandLevel(this.world, island.getOwner());
|
||||||
|
|
||||||
IslandTopRecord record = new IslandTopRecord(island, level);
|
IslandTopRecord topRecord = new IslandTopRecord(island, level);
|
||||||
|
|
||||||
return this.createIslandIcon(template, record, place);
|
return this.createIslandIcon(template, topRecord, place);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method is used to open UserPanel outside this class. It will be much easier to open panel with single method
|
* This method is used to open UserPanel outside this class. It will be much easier to open panel with single method
|
||||||
|
@ -493,11 +499,16 @@ public class TopLevelPanel
|
||||||
new TopLevelPanel(addon, user, world, permissionPrefix).build();
|
new TopLevelPanel(addon, user, world, permissionPrefix).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
// Section: Constants
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
private static final String REFERENCE = "level.gui.buttons.island.";
|
||||||
// Section: Record
|
private static final String PLAYER = "[player]";
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
|
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
// Section: Record
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This record is used internally. It converts user -> level to island -> level.
|
* This record is used internally. It converts user -> level to island -> level.
|
||||||
|
@ -505,9 +516,9 @@ public class TopLevelPanel
|
||||||
private record IslandTopRecord(Island island, Long level) {}
|
private record IslandTopRecord(Island island, Long level) {}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Variables
|
// Section: Variables
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This variable allows to access addon object.
|
* This variable allows to access addon object.
|
||||||
|
|
|
@ -17,6 +17,7 @@ import org.bukkit.inventory.ItemStack;
|
||||||
import com.google.common.base.Enums;
|
import com.google.common.base.Enums;
|
||||||
|
|
||||||
import lv.id.bonne.panelutils.PanelUtils;
|
import lv.id.bonne.panelutils.PanelUtils;
|
||||||
|
import world.bentobox.bentobox.api.localization.TextVariables;
|
||||||
import world.bentobox.bentobox.api.panels.PanelItem;
|
import world.bentobox.bentobox.api.panels.PanelItem;
|
||||||
import world.bentobox.bentobox.api.panels.TemplatedPanel;
|
import world.bentobox.bentobox.api.panels.TemplatedPanel;
|
||||||
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
|
import world.bentobox.bentobox.api.panels.builders.PanelItemBuilder;
|
||||||
|
@ -33,6 +34,7 @@ import world.bentobox.level.util.Utils;
|
||||||
*/
|
*/
|
||||||
public class ValuePanel
|
public class ValuePanel
|
||||||
{
|
{
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Internal Constructor
|
// Section: Internal Constructor
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
@ -46,8 +48,8 @@ public class ValuePanel
|
||||||
* @param user User who opens panel
|
* @param user User who opens panel
|
||||||
*/
|
*/
|
||||||
private ValuePanel(Level addon,
|
private ValuePanel(Level addon,
|
||||||
World world,
|
World world,
|
||||||
User user)
|
User user)
|
||||||
{
|
{
|
||||||
this.addon = addon;
|
this.addon = addon;
|
||||||
this.world = world;
|
this.world = world;
|
||||||
|
@ -55,18 +57,18 @@ public class ValuePanel
|
||||||
|
|
||||||
this.activeFilter = Filter.NAME_ASC;
|
this.activeFilter = Filter.NAME_ASC;
|
||||||
this.materialRecordList = Arrays.stream(Material.values()).
|
this.materialRecordList = Arrays.stream(Material.values()).
|
||||||
filter(Material::isBlock).
|
filter(Material::isBlock).
|
||||||
filter(m -> !m.name().startsWith("LEGACY_")).
|
filter(m -> !m.name().startsWith("LEGACY_")).
|
||||||
map(material ->
|
map(material ->
|
||||||
{
|
{
|
||||||
Integer value = this.addon.getBlockConfig().getValue(this.world, material);
|
Integer value = this.addon.getBlockConfig().getValue(this.world, material);
|
||||||
Integer limit = this.addon.getBlockConfig().getBlockLimits().get(material);
|
Integer limit = this.addon.getBlockConfig().getBlockLimits().get(material);
|
||||||
|
|
||||||
return new MaterialRecord(material,
|
return new MaterialRecord(material,
|
||||||
value != null ? value : 0,
|
value != null ? value : 0,
|
||||||
limit != null ? limit : 0);
|
limit != null ? limit : 0);
|
||||||
}).
|
}).
|
||||||
collect(Collectors.toList());
|
collect(Collectors.toList());
|
||||||
|
|
||||||
this.elementList = new ArrayList<>(Material.values().length);
|
this.elementList = new ArrayList<>(Material.values().length);
|
||||||
this.searchText = "";
|
this.searchText = "";
|
||||||
|
@ -89,7 +91,7 @@ public class ValuePanel
|
||||||
|
|
||||||
panelBuilder.registerTypeBuilder("NEXT", this::createNextButton);
|
panelBuilder.registerTypeBuilder("NEXT", this::createNextButton);
|
||||||
panelBuilder.registerTypeBuilder("PREVIOUS", this::createPreviousButton);
|
panelBuilder.registerTypeBuilder("PREVIOUS", this::createPreviousButton);
|
||||||
panelBuilder.registerTypeBuilder("BLOCK", this::createMaterialButton);
|
panelBuilder.registerTypeBuilder(BLOCK, this::createMaterialButton);
|
||||||
|
|
||||||
panelBuilder.registerTypeBuilder("FILTER", this::createFilterButton);
|
panelBuilder.registerTypeBuilder("FILTER", this::createFilterButton);
|
||||||
panelBuilder.registerTypeBuilder("SEARCH", this::createSearchButton);
|
panelBuilder.registerTypeBuilder("SEARCH", this::createSearchButton);
|
||||||
|
@ -108,60 +110,60 @@ public class ValuePanel
|
||||||
|
|
||||||
switch (this.activeFilter)
|
switch (this.activeFilter)
|
||||||
{
|
{
|
||||||
case VALUE_ASC ->
|
case VALUE_ASC ->
|
||||||
{
|
|
||||||
sorter = (o1, o2) ->
|
|
||||||
{
|
|
||||||
if (o1.value().equals(o2.value()))
|
|
||||||
{
|
|
||||||
String o1Name = Utils.prettifyObject(o1.material(), this.user);
|
|
||||||
String o2Name = Utils.prettifyObject(o2.material(), this.user);
|
|
||||||
|
|
||||||
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
sorter = (o1, o2) ->
|
||||||
}
|
{
|
||||||
else
|
if (o1.value().equals(o2.value()))
|
||||||
{
|
|
||||||
return Integer.compare(o1.value(), o2.value());
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
case VALUE_DESC ->
|
|
||||||
{
|
{
|
||||||
sorter = (o1, o2) ->
|
String o1Name = Utils.prettifyObject(o1.material(), this.user);
|
||||||
{
|
String o2Name = Utils.prettifyObject(o2.material(), this.user);
|
||||||
if (o1.value().equals(o2.value()))
|
|
||||||
{
|
|
||||||
String o1Name = Utils.prettifyObject(o1.material(), this.user);
|
|
||||||
String o2Name = Utils.prettifyObject(o2.material(), this.user);
|
|
||||||
|
|
||||||
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return Integer.compare(o2.value(), o1.value());
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
case NAME_DESC ->
|
else
|
||||||
{
|
{
|
||||||
sorter = (o1, o2) ->
|
return Integer.compare(o1.value(), o2.value());
|
||||||
{
|
|
||||||
String o1Name = Utils.prettifyObject(o1.material(), this.user);
|
|
||||||
String o2Name = Utils.prettifyObject(o2.material(), this.user);
|
|
||||||
|
|
||||||
return String.CASE_INSENSITIVE_ORDER.compare(o2Name, o1Name);
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
default ->
|
};
|
||||||
|
|
||||||
|
case VALUE_DESC ->
|
||||||
|
|
||||||
|
sorter = (o1, o2) ->
|
||||||
|
{
|
||||||
|
if (o1.value().equals(o2.value()))
|
||||||
{
|
{
|
||||||
sorter = (o1, o2) ->
|
String o1Name = Utils.prettifyObject(o1.material(), this.user);
|
||||||
{
|
String o2Name = Utils.prettifyObject(o2.material(), this.user);
|
||||||
String o1Name = Utils.prettifyObject(o1.material(), this.user);
|
|
||||||
String o2Name = Utils.prettifyObject(o2.material(), this.user);
|
|
||||||
|
|
||||||
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return Integer.compare(o2.value(), o1.value());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
case NAME_DESC ->
|
||||||
|
|
||||||
|
sorter = (o1, o2) ->
|
||||||
|
{
|
||||||
|
String o1Name = Utils.prettifyObject(o1.material(), this.user);
|
||||||
|
String o2Name = Utils.prettifyObject(o2.material(), this.user);
|
||||||
|
|
||||||
|
return String.CASE_INSENSITIVE_ORDER.compare(o2Name, o1Name);
|
||||||
|
};
|
||||||
|
|
||||||
|
default ->
|
||||||
|
|
||||||
|
sorter = (o1, o2) ->
|
||||||
|
{
|
||||||
|
String o1Name = Utils.prettifyObject(o1.material(), this.user);
|
||||||
|
String o2Name = Utils.prettifyObject(o2.material(), this.user);
|
||||||
|
|
||||||
|
return String.CASE_INSENSITIVE_ORDER.compare(o1Name, o2Name);
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this.materialRecordList.sort(sorter);
|
this.materialRecordList.sort(sorter);
|
||||||
|
@ -171,12 +173,12 @@ public class ValuePanel
|
||||||
this.elementList = new ArrayList<>(this.materialRecordList.size());
|
this.elementList = new ArrayList<>(this.materialRecordList.size());
|
||||||
final String text = this.searchText.toLowerCase();
|
final String text = this.searchText.toLowerCase();
|
||||||
|
|
||||||
this.materialRecordList.forEach(record ->
|
this.materialRecordList.forEach(rec ->
|
||||||
{
|
{
|
||||||
if (record.material.name().toLowerCase().contains(text) ||
|
if (rec.material.name().toLowerCase().contains(text) ||
|
||||||
Utils.prettifyObject(record.material(), this.user).toLowerCase().contains(text))
|
Utils.prettifyObject(rec.material(), this.user).toLowerCase().contains(text))
|
||||||
{
|
{
|
||||||
this.elementList.add(record);
|
this.elementList.add(rec);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -189,9 +191,9 @@ public class ValuePanel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Tab Button Type
|
// Section: Tab Button Type
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -227,7 +229,7 @@ public class ValuePanel
|
||||||
List<ItemTemplateRecord.ActionRecords> activeActions = new ArrayList<>(template.actions());
|
List<ItemTemplateRecord.ActionRecords> activeActions = new ArrayList<>(template.actions());
|
||||||
|
|
||||||
activeActions.removeIf(action ->
|
activeActions.removeIf(action ->
|
||||||
"CLEAR".equalsIgnoreCase(action.actionType()) && this.searchText.isBlank());
|
"CLEAR".equalsIgnoreCase(action.actionType()) && this.searchText.isBlank());
|
||||||
|
|
||||||
// Add Click handler
|
// Add Click handler
|
||||||
builder.clickHandler((panel, user, clickType, i) ->
|
builder.clickHandler((panel, user, clickType, i) ->
|
||||||
|
@ -260,9 +262,9 @@ public class ValuePanel
|
||||||
|
|
||||||
// start conversation
|
// start conversation
|
||||||
ConversationUtils.createStringInput(consumer,
|
ConversationUtils.createStringInput(consumer,
|
||||||
user,
|
user,
|
||||||
user.getTranslation("level.conversations.write-search"),
|
user.getTranslation("level.conversations.write-search"),
|
||||||
user.getTranslation("level.conversations.search-updated"));
|
user.getTranslation("level.conversations.search-updated"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -272,10 +274,10 @@ public class ValuePanel
|
||||||
|
|
||||||
// Collect tooltips.
|
// Collect tooltips.
|
||||||
List<String> tooltips = activeActions.stream().
|
List<String> tooltips = activeActions.stream().
|
||||||
filter(action -> action.tooltip() != null).
|
filter(action -> action.tooltip() != null).
|
||||||
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
||||||
filter(text -> !text.isBlank()).
|
filter(text -> !text.isBlank()).
|
||||||
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
||||||
|
|
||||||
// Add tooltips.
|
// Add tooltips.
|
||||||
if (!tooltips.isEmpty())
|
if (!tooltips.isEmpty())
|
||||||
|
@ -339,7 +341,7 @@ public class ValuePanel
|
||||||
if (this.activeFilter.name().startsWith(filterName))
|
if (this.activeFilter.name().startsWith(filterName))
|
||||||
{
|
{
|
||||||
return this.activeFilter.name().endsWith("ASC") && "ASC".equalsIgnoreCase(action.actionType()) ||
|
return this.activeFilter.name().endsWith("ASC") && "ASC".equalsIgnoreCase(action.actionType()) ||
|
||||||
this.activeFilter.name().endsWith("DESC") && "DESC".equalsIgnoreCase(action.actionType());
|
this.activeFilter.name().endsWith("DESC") && "DESC".equalsIgnoreCase(action.actionType());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -378,10 +380,10 @@ public class ValuePanel
|
||||||
|
|
||||||
// Collect tooltips.
|
// Collect tooltips.
|
||||||
List<String> tooltips = activeActions.stream().
|
List<String> tooltips = activeActions.stream().
|
||||||
filter(action -> action.tooltip() != null).
|
filter(action -> action.tooltip() != null).
|
||||||
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
||||||
filter(text -> !text.isBlank()).
|
filter(text -> !text.isBlank()).
|
||||||
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
||||||
|
|
||||||
// Add tooltips.
|
// Add tooltips.
|
||||||
if (!tooltips.isEmpty())
|
if (!tooltips.isEmpty())
|
||||||
|
@ -397,9 +399,9 @@ public class ValuePanel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Create common buttons
|
// Section: Create common buttons
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -413,8 +415,8 @@ public class ValuePanel
|
||||||
{
|
{
|
||||||
long size = this.elementList.size();
|
long size = this.elementList.size();
|
||||||
|
|
||||||
if (size <= slot.amountMap().getOrDefault("BLOCK", 1) ||
|
if (size <= slot.amountMap().getOrDefault(BLOCK, 1) ||
|
||||||
1.0 * size / slot.amountMap().getOrDefault("BLOCK", 1) <= this.pageIndex + 1)
|
1.0 * size / slot.amountMap().getOrDefault(BLOCK, 1) <= this.pageIndex + 1)
|
||||||
{
|
{
|
||||||
// There are no next elements
|
// There are no next elements
|
||||||
return null;
|
return null;
|
||||||
|
@ -428,7 +430,7 @@ public class ValuePanel
|
||||||
{
|
{
|
||||||
ItemStack clone = template.icon().clone();
|
ItemStack clone = template.icon().clone();
|
||||||
|
|
||||||
if ((Boolean) template.dataMap().getOrDefault("indexing", false))
|
if (Boolean.TRUE.equals(template.dataMap().getOrDefault("indexing", false)))
|
||||||
{
|
{
|
||||||
clone.setAmount(nextPageIndex);
|
clone.setAmount(nextPageIndex);
|
||||||
}
|
}
|
||||||
|
@ -444,7 +446,7 @@ public class ValuePanel
|
||||||
if (template.description() != null)
|
if (template.description() != null)
|
||||||
{
|
{
|
||||||
builder.description(this.user.getTranslation(this.world, template.description(),
|
builder.description(this.user.getTranslation(this.world, template.description(),
|
||||||
"[number]", String.valueOf(nextPageIndex)));
|
TextVariables.NUMBER, String.valueOf(nextPageIndex)));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add ClickHandler
|
// Add ClickHandler
|
||||||
|
@ -452,13 +454,11 @@ public class ValuePanel
|
||||||
{
|
{
|
||||||
for (ItemTemplateRecord.ActionRecords action : template.actions())
|
for (ItemTemplateRecord.ActionRecords action : template.actions())
|
||||||
{
|
{
|
||||||
if (clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType()))
|
if ((clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType()))
|
||||||
|
&& "NEXT".equalsIgnoreCase(action.actionType()))
|
||||||
{
|
{
|
||||||
if ("NEXT".equalsIgnoreCase(action.actionType()))
|
this.pageIndex++;
|
||||||
{
|
this.build();
|
||||||
this.pageIndex++;
|
|
||||||
this.build();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -468,10 +468,10 @@ public class ValuePanel
|
||||||
|
|
||||||
// Collect tooltips.
|
// Collect tooltips.
|
||||||
List<String> tooltips = template.actions().stream().
|
List<String> tooltips = template.actions().stream().
|
||||||
filter(action -> action.tooltip() != null).
|
filter(action -> action.tooltip() != null).
|
||||||
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
||||||
filter(text -> !text.isBlank()).
|
filter(text -> !text.isBlank()).
|
||||||
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
||||||
|
|
||||||
// Add tooltips.
|
// Add tooltips.
|
||||||
if (!tooltips.isEmpty())
|
if (!tooltips.isEmpty())
|
||||||
|
@ -508,7 +508,7 @@ public class ValuePanel
|
||||||
{
|
{
|
||||||
ItemStack clone = template.icon().clone();
|
ItemStack clone = template.icon().clone();
|
||||||
|
|
||||||
if ((Boolean) template.dataMap().getOrDefault("indexing", false))
|
if (Boolean.TRUE.equals(template.dataMap().getOrDefault("indexing", false)))
|
||||||
{
|
{
|
||||||
clone.setAmount(previousPageIndex);
|
clone.setAmount(previousPageIndex);
|
||||||
}
|
}
|
||||||
|
@ -524,7 +524,7 @@ public class ValuePanel
|
||||||
if (template.description() != null)
|
if (template.description() != null)
|
||||||
{
|
{
|
||||||
builder.description(this.user.getTranslation(this.world, template.description(),
|
builder.description(this.user.getTranslation(this.world, template.description(),
|
||||||
"[number]", String.valueOf(previousPageIndex)));
|
TextVariables.NUMBER, String.valueOf(previousPageIndex)));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add ClickHandler
|
// Add ClickHandler
|
||||||
|
@ -532,13 +532,11 @@ public class ValuePanel
|
||||||
{
|
{
|
||||||
for (ItemTemplateRecord.ActionRecords action : template.actions())
|
for (ItemTemplateRecord.ActionRecords action : template.actions())
|
||||||
{
|
{
|
||||||
if (clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType()))
|
if ((clickType == action.clickType() || ClickType.UNKNOWN.equals(action.clickType()))
|
||||||
|
&& "PREVIOUS".equalsIgnoreCase(action.actionType()))
|
||||||
{
|
{
|
||||||
if ("PREVIOUS".equalsIgnoreCase(action.actionType()))
|
this.pageIndex--;
|
||||||
{
|
this.build();
|
||||||
this.pageIndex--;
|
|
||||||
this.build();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -548,10 +546,10 @@ public class ValuePanel
|
||||||
|
|
||||||
// Collect tooltips.
|
// Collect tooltips.
|
||||||
List<String> tooltips = template.actions().stream().
|
List<String> tooltips = template.actions().stream().
|
||||||
filter(action -> action.tooltip() != null).
|
filter(action -> action.tooltip() != null).
|
||||||
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
map(action -> this.user.getTranslation(this.world, action.tooltip())).
|
||||||
filter(text -> !text.isBlank()).
|
filter(text -> !text.isBlank()).
|
||||||
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
collect(Collectors.toCollection(() -> new ArrayList<>(template.actions().size())));
|
||||||
|
|
||||||
// Add tooltips.
|
// Add tooltips.
|
||||||
if (!tooltips.isEmpty())
|
if (!tooltips.isEmpty())
|
||||||
|
@ -565,9 +563,9 @@ public class ValuePanel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Create Material Button
|
// Section: Create Material Button
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -585,7 +583,7 @@ public class ValuePanel
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
int index = this.pageIndex * slot.amountMap().getOrDefault("BLOCK", 1) + slot.slot();
|
int index = this.pageIndex * slot.amountMap().getOrDefault(BLOCK, 1) + slot.slot();
|
||||||
|
|
||||||
if (index >= this.elementList.size())
|
if (index >= this.elementList.size())
|
||||||
{
|
{
|
||||||
|
@ -605,7 +603,7 @@ public class ValuePanel
|
||||||
* @return PanelItem for generator tier.
|
* @return PanelItem for generator tier.
|
||||||
*/
|
*/
|
||||||
private PanelItem createMaterialButton(ItemTemplateRecord template,
|
private PanelItem createMaterialButton(ItemTemplateRecord template,
|
||||||
MaterialRecord materialRecord)
|
MaterialRecord materialRecord)
|
||||||
{
|
{
|
||||||
PanelItemBuilder builder = new PanelItemBuilder();
|
PanelItemBuilder builder = new PanelItemBuilder();
|
||||||
|
|
||||||
|
@ -626,24 +624,24 @@ public class ValuePanel
|
||||||
if (template.title() != null)
|
if (template.title() != null)
|
||||||
{
|
{
|
||||||
builder.name(this.user.getTranslation(this.world, template.title(),
|
builder.name(this.user.getTranslation(this.world, template.title(),
|
||||||
"[material]", Utils.prettifyObject(materialRecord.material(), this.user)));
|
"[material]", Utils.prettifyObject(materialRecord.material(), this.user)));
|
||||||
}
|
}
|
||||||
|
|
||||||
String description = Utils.prettifyDescription(materialRecord.material(), this.user);
|
String description = Utils.prettifyDescription(materialRecord.material(), this.user);
|
||||||
|
|
||||||
final String reference = "level.gui.buttons.material.";
|
final String reference = "level.gui.buttons.material.";
|
||||||
String blockId = this.user.getTranslationOrNothing(reference + "id",
|
String blockId = this.user.getTranslationOrNothing(reference + "id",
|
||||||
"[id]", materialRecord.material().name());
|
"[id]", materialRecord.material().name());
|
||||||
|
|
||||||
String value = this.user.getTranslationOrNothing(reference + "value",
|
String value = this.user.getTranslationOrNothing(reference + "value",
|
||||||
"[number]", String.valueOf(materialRecord.value()));
|
TextVariables.NUMBER, String.valueOf(materialRecord.value()));
|
||||||
|
|
||||||
String underWater;
|
String underWater;
|
||||||
|
|
||||||
if (this.addon.getSettings().getUnderWaterMultiplier() > 1.0)
|
if (this.addon.getSettings().getUnderWaterMultiplier() > 1.0)
|
||||||
{
|
{
|
||||||
underWater = this.user.getTranslationOrNothing(reference + "underwater",
|
underWater = this.user.getTranslationOrNothing(reference + "underwater",
|
||||||
"[number]", String.valueOf(materialRecord.value() * this.addon.getSettings().getUnderWaterMultiplier()));
|
TextVariables.NUMBER, String.valueOf(materialRecord.value() * this.addon.getSettings().getUnderWaterMultiplier()));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -651,7 +649,7 @@ public class ValuePanel
|
||||||
}
|
}
|
||||||
|
|
||||||
String limit = materialRecord.limit() > 0 ? this.user.getTranslationOrNothing(reference + "limit",
|
String limit = materialRecord.limit() > 0 ? this.user.getTranslationOrNothing(reference + "limit",
|
||||||
"[number]", String.valueOf(materialRecord.limit())) : "";
|
TextVariables.NUMBER, String.valueOf(materialRecord.limit())) : "";
|
||||||
|
|
||||||
if (template.description() != null)
|
if (template.description() != null)
|
||||||
{
|
{
|
||||||
|
@ -661,13 +659,13 @@ public class ValuePanel
|
||||||
"[value]", value,
|
"[value]", value,
|
||||||
"[underwater]", underWater,
|
"[underwater]", underWater,
|
||||||
"[limit]", limit).
|
"[limit]", limit).
|
||||||
replaceAll("(?m)^[ \\t]*\\r?\\n", "").
|
replaceAll("(?m)^[ \\t]*\\r?\\n", "").
|
||||||
replaceAll("(?<!\\\\)\\|", "\n").
|
replaceAll("(?<!\\\\)\\|", "\n").
|
||||||
replaceAll("\\\\\\|", "|"));
|
replace("\\\\\\|", "|")); // Non regex
|
||||||
}
|
}
|
||||||
|
|
||||||
builder.clickHandler((panel, user1, clickType, i) -> {
|
builder.clickHandler((panel, user1, clickType, i) -> {
|
||||||
System.out.println("Material: " + materialRecord.material());
|
addon.log("Material: " + materialRecord.material());
|
||||||
return true;
|
return true;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -675,9 +673,9 @@ public class ValuePanel
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Other Methods
|
// Section: Other Methods
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -689,16 +687,16 @@ public class ValuePanel
|
||||||
* @param user User who opens panel
|
* @param user User who opens panel
|
||||||
*/
|
*/
|
||||||
public static void openPanel(Level addon,
|
public static void openPanel(Level addon,
|
||||||
World world,
|
World world,
|
||||||
User user)
|
User user)
|
||||||
{
|
{
|
||||||
new ValuePanel(addon, world, user).build();
|
new ValuePanel(addon, world, user).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Enums
|
// Section: Enums
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -729,10 +727,15 @@ public class ValuePanel
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
// Section: Constants
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
// ---------------------------------------------------------------------
|
private static final String BLOCK = "BLOCK";
|
||||||
// Section: Variables
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
// Section: Variables
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This variable allows to access addon object.
|
* This variable allows to access addon object.
|
||||||
|
|
|
@ -7,10 +7,16 @@
|
||||||
package world.bentobox.level.util;
|
package world.bentobox.level.util;
|
||||||
|
|
||||||
|
|
||||||
import org.bukkit.conversations.*;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
|
import org.bukkit.conversations.ConversationAbandonedListener;
|
||||||
|
import org.bukkit.conversations.ConversationContext;
|
||||||
|
import org.bukkit.conversations.ConversationFactory;
|
||||||
|
import org.bukkit.conversations.MessagePrompt;
|
||||||
|
import org.bukkit.conversations.Prompt;
|
||||||
|
import org.bukkit.conversations.StringPrompt;
|
||||||
import org.eclipse.jdt.annotation.NonNull;
|
import org.eclipse.jdt.annotation.NonNull;
|
||||||
import org.eclipse.jdt.annotation.Nullable;
|
import org.eclipse.jdt.annotation.Nullable;
|
||||||
import java.util.function.Consumer;
|
|
||||||
|
|
||||||
import world.bentobox.bentobox.BentoBox;
|
import world.bentobox.bentobox.BentoBox;
|
||||||
import world.bentobox.bentobox.api.user.User;
|
import world.bentobox.bentobox.api.user.User;
|
||||||
|
@ -18,10 +24,11 @@ import world.bentobox.bentobox.api.user.User;
|
||||||
|
|
||||||
public class ConversationUtils
|
public class ConversationUtils
|
||||||
{
|
{
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
// Section: Conversation API implementation
|
// Section: Conversation API implementation
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
|
|
||||||
|
private ConversationUtils() {} // Private constructor as this is a utility class only with static methods
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method will close opened gui and writes question in chat. After players answers on question in chat, message
|
* This method will close opened gui and writes question in chat. After players answers on question in chat, message
|
||||||
|
@ -32,9 +39,9 @@ public class ConversationUtils
|
||||||
* @param user User who is targeted with current confirmation.
|
* @param user User who is targeted with current confirmation.
|
||||||
*/
|
*/
|
||||||
public static void createStringInput(Consumer<String> consumer,
|
public static void createStringInput(Consumer<String> consumer,
|
||||||
User user,
|
User user,
|
||||||
@NonNull String question,
|
@NonNull String question,
|
||||||
@Nullable String successMessage)
|
@Nullable String successMessage)
|
||||||
{
|
{
|
||||||
// Text input message.
|
// Text input message.
|
||||||
StringPrompt stringPrompt = new StringPrompt()
|
StringPrompt stringPrompt = new StringPrompt()
|
||||||
|
@ -56,16 +63,16 @@ public class ConversationUtils
|
||||||
};
|
};
|
||||||
|
|
||||||
new ConversationFactory(BentoBox.getInstance()).
|
new ConversationFactory(BentoBox.getInstance()).
|
||||||
withPrefix(context -> user.getTranslation("level.conversations.prefix")).
|
withPrefix(context -> user.getTranslation("level.conversations.prefix")).
|
||||||
withFirstPrompt(stringPrompt).
|
withFirstPrompt(stringPrompt).
|
||||||
// On cancel conversation will be closed.
|
// On cancel conversation will be closed.
|
||||||
withLocalEcho(false).
|
withLocalEcho(false).
|
||||||
withTimeout(90).
|
withTimeout(90).
|
||||||
withEscapeSequence(user.getTranslation("level.conversations.cancel-string")).
|
withEscapeSequence(user.getTranslation("level.conversations.cancel-string")).
|
||||||
// Use null value in consumer to detect if user has abandoned conversation.
|
// Use null value in consumer to detect if user has abandoned conversation.
|
||||||
addConversationAbandonedListener(ConversationUtils.getAbandonListener(consumer, user)).
|
addConversationAbandonedListener(ConversationUtils.getAbandonListener(consumer, user)).
|
||||||
buildConversation(user.getPlayer()).
|
buildConversation(user.getPlayer()).
|
||||||
begin();
|
begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -111,7 +118,7 @@ public class ConversationUtils
|
||||||
consumer.accept(null);
|
consumer.accept(null);
|
||||||
// send cancell message
|
// send cancell message
|
||||||
abandonedEvent.getContext().getForWhom().sendRawMessage(
|
abandonedEvent.getContext().getForWhom().sendRawMessage(
|
||||||
user.getTranslation("level.conversations.prefix") +
|
user.getTranslation("level.conversations.prefix") +
|
||||||
user.getTranslation("level.conversations.cancelled"));
|
user.getTranslation("level.conversations.cancelled"));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -7,10 +7,10 @@
|
||||||
package world.bentobox.level.util;
|
package world.bentobox.level.util;
|
||||||
|
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.permissions.PermissionAttachmentInfo;
|
import org.bukkit.permissions.PermissionAttachmentInfo;
|
||||||
import java.util.List;
|
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
import world.bentobox.bentobox.api.user.User;
|
import world.bentobox.bentobox.api.user.User;
|
||||||
import world.bentobox.bentobox.hooks.LangUtilsHook;
|
import world.bentobox.bentobox.hooks.LangUtilsHook;
|
||||||
|
@ -18,6 +18,10 @@ import world.bentobox.bentobox.hooks.LangUtilsHook;
|
||||||
|
|
||||||
public class Utils
|
public class Utils
|
||||||
{
|
{
|
||||||
|
private static final String LEVEL_MATERIALS = "level.materials.";
|
||||||
|
|
||||||
|
private Utils() {} // Private constructor as this is a utility class only with static methods
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method sends a message to the user with appended "prefix" text before message.
|
* This method sends a message to the user with appended "prefix" text before message.
|
||||||
* @param user User who receives message.
|
* @param user User who receives message.
|
||||||
|
@ -27,7 +31,7 @@ public class Utils
|
||||||
public static void sendMessage(User user, String translationText, String... parameters)
|
public static void sendMessage(User user, String translationText, String... parameters)
|
||||||
{
|
{
|
||||||
user.sendMessage(user.getTranslation( "level.conversations.prefix") +
|
user.sendMessage(user.getTranslation( "level.conversations.prefix") +
|
||||||
user.getTranslation( translationText, parameters));
|
user.getTranslation( translationText, parameters));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -52,9 +56,9 @@ public class Utils
|
||||||
String permPrefix = permissionPrefix + ".";
|
String permPrefix = permissionPrefix + ".";
|
||||||
|
|
||||||
List<String> permissions = user.getEffectivePermissions().stream().
|
List<String> permissions = user.getEffectivePermissions().stream().
|
||||||
map(PermissionAttachmentInfo::getPermission).
|
map(PermissionAttachmentInfo::getPermission).
|
||||||
filter(permission -> permission.startsWith(permPrefix)).
|
filter(permission -> permission.startsWith(permPrefix)).
|
||||||
collect(Collectors.toList());
|
toList();
|
||||||
|
|
||||||
for (String permission : permissions)
|
for (String permission : permissions)
|
||||||
{
|
{
|
||||||
|
@ -154,7 +158,7 @@ public class Utils
|
||||||
// materials:
|
// materials:
|
||||||
// [material]:
|
// [material]:
|
||||||
// name: [name]
|
// name: [name]
|
||||||
String translation = user.getTranslationOrNothing("level.materials." + object.name().toLowerCase() + ".name");
|
String translation = user.getTranslationOrNothing(LEVEL_MATERIALS + object.name().toLowerCase() + ".name");
|
||||||
|
|
||||||
if (!translation.isEmpty())
|
if (!translation.isEmpty())
|
||||||
{
|
{
|
||||||
|
@ -167,7 +171,7 @@ public class Utils
|
||||||
// materials:
|
// materials:
|
||||||
// [material]: [name]
|
// [material]: [name]
|
||||||
|
|
||||||
translation = user.getTranslationOrNothing("level.materials." + object.name().toLowerCase());
|
translation = user.getTranslationOrNothing(LEVEL_MATERIALS + object.name().toLowerCase());
|
||||||
|
|
||||||
if (!translation.isEmpty())
|
if (!translation.isEmpty())
|
||||||
{
|
{
|
||||||
|
@ -211,7 +215,7 @@ public class Utils
|
||||||
// materials:
|
// materials:
|
||||||
// [material]:
|
// [material]:
|
||||||
// description: [text]
|
// description: [text]
|
||||||
String translation = user.getTranslationOrNothing("level.materials." + object.name().toLowerCase() + ".description");
|
String translation = user.getTranslationOrNothing(LEVEL_MATERIALS + object.name().toLowerCase() + ".description");
|
||||||
|
|
||||||
if (!translation.isEmpty())
|
if (!translation.isEmpty())
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1,165 @@
|
||||||
|
---
|
||||||
|
admin:
|
||||||
|
level:
|
||||||
|
parameters: "<speler>"
|
||||||
|
description: bereken het eiland level voor een speler
|
||||||
|
sethandicap:
|
||||||
|
parameters: "<speler> <handicap>"
|
||||||
|
description: stel handicap in voor het eiland, normaal gesproken het level van
|
||||||
|
het starter eiland.
|
||||||
|
changed: "&a Initiële handicap is veranderd van [number] naar [new_number]."
|
||||||
|
invalid-level: "&c Ongeldige handicap. Gebruik een getal."
|
||||||
|
levelstatus:
|
||||||
|
description: laat zien hoeveel eilanden er in de wachtrij staan voor het scannen
|
||||||
|
islands-in-queue: "&a Aantal eilanden in de wachtrij: [number]"
|
||||||
|
top:
|
||||||
|
description: Laat de top tien zien
|
||||||
|
unknown-world: "&c Ongeldige wereld!"
|
||||||
|
display: "&f[rank]. &a[name] &7- &b[level]"
|
||||||
|
remove:
|
||||||
|
description: verwijder speler van de top tien
|
||||||
|
parameters: "<speler>"
|
||||||
|
island:
|
||||||
|
level:
|
||||||
|
parameters: "[speler]"
|
||||||
|
description: bereken het eiland level voor [player]
|
||||||
|
calculating: "&a Level aan het berekenen..."
|
||||||
|
estimated-wait: "&a Verwachtte wachttijd: [number] seconde"
|
||||||
|
in-queue: "&a Jij staat op plek [number] in de wachtrij"
|
||||||
|
island-level-is: "&a Eiland level is &b[level]"
|
||||||
|
required-points-to-next-level: "&a [points] punten nodig voor het volgende level"
|
||||||
|
deaths: "&c([number] doodgegaan)"
|
||||||
|
cooldown: "&c Je moet nog &b[time] &c seconden wachten tot je dit weer kan doen."
|
||||||
|
in-progress: "&6 Eiland level wordt berekend..."
|
||||||
|
time-out: "&c De level berekening duurde te lang. Probeer het later opnieuw."
|
||||||
|
top:
|
||||||
|
description: Toon de Top tien
|
||||||
|
gui-title: "&a Top tien"
|
||||||
|
gui-heading: "&6[name]: &B[rank]"
|
||||||
|
island-level: "&b Level [level]"
|
||||||
|
warp-to: "&A Teleporteren naar [name]'s eiland"
|
||||||
|
level-details:
|
||||||
|
above-sea-level-blocks: 'Blokken boven zeeniveau '
|
||||||
|
spawners: Monsterkooien
|
||||||
|
underwater-blocks: Blokken onder zeeniveau
|
||||||
|
all-blocks: Alle blokken
|
||||||
|
no-island: "&c Geen eiland!"
|
||||||
|
names-island: "[name]'s eiland"
|
||||||
|
syntax: "[name] x [number]"
|
||||||
|
hint: "&c Gebruik level om het blokkenrapport te zien"
|
||||||
|
level:
|
||||||
|
commands:
|
||||||
|
value:
|
||||||
|
parameters: "[hand|<type>]"
|
||||||
|
description: toont de waarde van blokken. Voeg 'hand' toe aan het einde om de
|
||||||
|
waarde te laten zien van het item in je hand.
|
||||||
|
gui:
|
||||||
|
titles:
|
||||||
|
top: "&0&l Top eilanden"
|
||||||
|
detail-panel: "&0&l [name]'s eiland"
|
||||||
|
value-panel: "&0&l Blok waardes"
|
||||||
|
buttons:
|
||||||
|
island:
|
||||||
|
empty: "&f&l [name]. plaats"
|
||||||
|
name: "&f&l [name]"
|
||||||
|
description: |-
|
||||||
|
[owner]
|
||||||
|
[members]
|
||||||
|
[place]
|
||||||
|
[level]
|
||||||
|
owners-island: "[player]'s Eiland"
|
||||||
|
owner: "&7&l Eigenaar: &r&b [player]"
|
||||||
|
members-title: "&7&l Leden:"
|
||||||
|
member: "&b - [player]"
|
||||||
|
unknown: onbekend
|
||||||
|
place: "&7&o [number]. &r&7 plaats"
|
||||||
|
level: "&7 Level: &o [number]"
|
||||||
|
material:
|
||||||
|
name: "&f&l [number] x [material]"
|
||||||
|
description: |-
|
||||||
|
[description]
|
||||||
|
[count]
|
||||||
|
[value]
|
||||||
|
[calculated]
|
||||||
|
[limit]
|
||||||
|
[id]
|
||||||
|
id: "&7 Blok id: &e [id]"
|
||||||
|
value: "&7 Block waarde: &e [number]"
|
||||||
|
limit: "&7 Block limiet: &e [number]"
|
||||||
|
count: "&7 Aantal blokken: &e [number]"
|
||||||
|
calculated: "&7 Berekende waarde: &e [number]"
|
||||||
|
all_blocks:
|
||||||
|
name: "&f&l Alle Blokken"
|
||||||
|
description: "&7 Toon alle blokken \n&7 op het eiland."
|
||||||
|
above_sea_level:
|
||||||
|
name: "&f&l Blokken boven zeeniveau"
|
||||||
|
description: |-
|
||||||
|
&7 Toon alleen blokken
|
||||||
|
&7 die boven zeeniveau zijn
|
||||||
|
underwater:
|
||||||
|
name: "&f&l Blokken onder zeeniveau"
|
||||||
|
description: |-
|
||||||
|
&7 Toon alleen blokken
|
||||||
|
&7 die onder zeeniveau zijn
|
||||||
|
spawner:
|
||||||
|
name: "&f&l Monsterkooien"
|
||||||
|
description: "&7 Toon alleen monsterkooien."
|
||||||
|
filters:
|
||||||
|
name:
|
||||||
|
name: "&f&l Sorteer aan de hand van naam"
|
||||||
|
description: "&7 Sorteer alle blokken aan de hand van naam."
|
||||||
|
value:
|
||||||
|
name: "&f&l Sorteer aan de hand van waarde"
|
||||||
|
description: "&7 Sorteer alle blokken aan de hand van waarde."
|
||||||
|
count:
|
||||||
|
name: "&f&l Sorteer aan de hand van aantal"
|
||||||
|
description: "&7 Sorteer alle blokken aan de hand van aantal."
|
||||||
|
value:
|
||||||
|
name: "&f&l [material]"
|
||||||
|
description: |-
|
||||||
|
[description]
|
||||||
|
[value]
|
||||||
|
[underwater]
|
||||||
|
[limit]
|
||||||
|
[id]
|
||||||
|
id: "&7 Blok id: &e [id]"
|
||||||
|
value: "&7 Block waarrde: &e [number]"
|
||||||
|
underwater: "&7 Onder zeeniveau: &e [number]"
|
||||||
|
limit: "&7 Blok limiet: &e [number]"
|
||||||
|
previous:
|
||||||
|
name: "&f&l Vorige pagina"
|
||||||
|
description: "&7 Ga naar pagina [number]"
|
||||||
|
next:
|
||||||
|
name: "&f&l Volgende pagina"
|
||||||
|
description: "&7 Ga naar pagina [number]"
|
||||||
|
search:
|
||||||
|
name: "&f&l Zoek"
|
||||||
|
description: "&7 Zoek voor een \n&7 specifieke waarde."
|
||||||
|
search: "&b Waarde: [value]"
|
||||||
|
tips:
|
||||||
|
click-to-view: "&e Klik &7 om te zien."
|
||||||
|
click-to-previous: "&e Klik &7 om de vorige pagina te zien."
|
||||||
|
click-to-next: "&e Klik &7 om de volgende pagina te zien."
|
||||||
|
click-to-select: "&e Klik &7 om te selecteren."
|
||||||
|
left-click-to-cycle-up: "&e Linker Klik &7 om door te lopen."
|
||||||
|
right-click-to-cycle-down: "&e Rechter Klik &7 om terug door te lopen."
|
||||||
|
left-click-to-change: "&e Linker Klik &7 om bij te werken."
|
||||||
|
right-click-to-clear: "&e Linker Klik &7 om te verwijderen."
|
||||||
|
click-to-asc: "&e Klik &7 om te toenemend te sorteren."
|
||||||
|
click-to-desc: "&e Klik &7 om te afnemenend te sorteren."
|
||||||
|
click-to-warp: "&e Klik &7 om te teleporteren."
|
||||||
|
click-to-visit: "&e Klik &7 om te bezoeken."
|
||||||
|
right-click-to-visit: "&e Rechter Klik &7 om te bezoeken."
|
||||||
|
conversations:
|
||||||
|
prefix: "&l&6 [BentoBox]: &r"
|
||||||
|
no-data: "&c Gebruik level om het blokkenrapport te zien."
|
||||||
|
cancel-string: stop
|
||||||
|
exit-string: stop
|
||||||
|
write-search: "&e Schrijf een zoekopdracht. (Schrijf 'stop' om te zoeken)"
|
||||||
|
search-updated: "&a Zoekopdracht bijgewerkt."
|
||||||
|
cancelled: "&c Conversatie gestopt!"
|
||||||
|
no-value: "&c Dit item heeft geen waarde."
|
||||||
|
unknown-item: "&c '[material]' bestaat niet in het spel."
|
||||||
|
value: "&7 De waarde van '[material]' is: &e[value]"
|
||||||
|
value-underwater: "&7 The waarde van '[material]' onder zeeniveau: &e[value]"
|
||||||
|
empty-hand: "&c Je hebt geen blok vast"
|
|
@ -2,53 +2,162 @@
|
||||||
admin:
|
admin:
|
||||||
level:
|
level:
|
||||||
parameters: "<player>"
|
parameters: "<player>"
|
||||||
description: 计算某玩家的岛屿等级
|
description: 计算指定玩家的岛屿等级
|
||||||
sethandicap:
|
sethandicap:
|
||||||
parameters: "<玩家> <让分>"
|
parameters: "<player> <handicap>"
|
||||||
description: 设置孤岛障碍,通常是首发岛的水平
|
description: 设置偏差值,通常用于调整新建的初始岛屿等级为零。实际岛屿等级 - <handicap> = 计算的岛屿等级
|
||||||
changed: "&a初始离岛差由[number]更改为[new_number]。"
|
changed: "&a 岛屿的偏差值从 [number] 更改为 [new_number]"
|
||||||
invalid-level: "&c差点。使用整数。"
|
invalid-level: "&c 偏差值无效,请使用整数"
|
||||||
levelstatus:
|
levelstatus:
|
||||||
description: 显示要扫描的队列中有多少岛
|
description: 显示等级计算队列中的岛屿
|
||||||
islands-in-queue: "&a列队中的列队:[人数]"
|
islands-in-queue: "&a 列队中的岛屿:[number]"
|
||||||
top:
|
top:
|
||||||
description: 显示前十名
|
description: 显示前十名
|
||||||
unknown-world: "&c未知世界!"
|
unknown-world: "&c 未知的世界!"
|
||||||
display: "&f[rank]. &a[name] &7- &b[level]"
|
display: "&f[rank]. &a[name] &7- &b[level]"
|
||||||
remove:
|
remove:
|
||||||
description: 将玩家移出前十
|
description: 将玩家移出前十名
|
||||||
parameters: "<player>"
|
parameters: "<player>"
|
||||||
island:
|
island:
|
||||||
level:
|
level:
|
||||||
parameters: "[player]"
|
parameters: "[player]"
|
||||||
description: 计算你或玩家 [player] 的岛屿等级
|
description: 计算你或指定玩家 [player] 的岛屿等级
|
||||||
calculating: "&a计算等级中..."
|
calculating: "&a 等级计算中..."
|
||||||
estimated-wait: "&a 预计等待时间: [number] 秒"
|
estimated-wait: "&a 预计等待时间:[number] 秒"
|
||||||
in-queue: "&a您是队列中的数字[number]"
|
in-queue: "&a 你处于队列中第 [number] 个"
|
||||||
island-level-is: "&a岛屿等级为 &b[level]"
|
island-level-is: "&a 岛屿等级为 &b[level]"
|
||||||
required-points-to-next-level: "&a还需 [points] 才能升到下一级"
|
required-points-to-next-level: "&a 还需 [points] 点数才能到达下一级"
|
||||||
deaths: "&c([number] 次死亡)"
|
deaths: "&c([number] 次死亡)"
|
||||||
cooldown: "&c再等 &b[time] &c秒才能再次使用"
|
cooldown: "&c 还需等待 &b[time] &c秒才能再次使用该指令"
|
||||||
in-progress: "&6岛级计算正在进行中..."
|
in-progress: "&6 岛级等级正在计算中..."
|
||||||
time-out: "&c等级计算花了太长时间。请稍后再试。"
|
time-out: "&c 等级计算超时。请稍后再试"
|
||||||
top:
|
top:
|
||||||
description: 显示前十名
|
description: 显示前十名
|
||||||
gui-title: "&a前十"
|
gui-title: "&a 前十"
|
||||||
gui-heading: "&6[name]: &B[rank]"
|
gui-heading: "&6[name]: &B[rank]"
|
||||||
island-level: "&B等级 [level]"
|
island-level: "&b 等级 [level]"
|
||||||
warp-to: "&A正传送到 [name] 的岛屿"
|
warp-to: "&a 正在传送到 [name] 的岛屿"
|
||||||
level-details:
|
level-details:
|
||||||
above-sea-level-blocks: 海拔以上的街区
|
above-sea-level-blocks: 海平面以上的方块
|
||||||
spawners: 产卵者
|
spawners: 刷怪笼
|
||||||
underwater-blocks: 水下积木
|
underwater-blocks: 水下的方块
|
||||||
all-blocks: 所有块
|
all-blocks: 所有方块
|
||||||
no-island: "&c没有岛!"
|
no-island: "&c 没有岛屿!"
|
||||||
names-island: "[名字]的小岛"
|
names-island: "[name] 的岛屿"
|
||||||
syntax: "[名称] x [数字]"
|
syntax: "[name] x [number]"
|
||||||
hint: "&c运行级别以查看阻止报告"
|
hint: "&c 运行level指令查看方块报告"
|
||||||
value:
|
level:
|
||||||
description: 查看某方块的价值
|
commands:
|
||||||
success: "&7本方块的价值: &e[value]"
|
value:
|
||||||
success-underwater: "&7本方块的水下价值: &e[value]"
|
parameters: "[hand|<material>]"
|
||||||
empty-hand: "&c你手里没有方块"
|
description: 显示方块的价值。在末尾添加 'hand' 可显示手中方块的价值
|
||||||
no-value: "&c这个东西一文不值."
|
gui:
|
||||||
|
titles:
|
||||||
|
top: "&0&l 岛屿排行榜"
|
||||||
|
detail-panel: "&0&l [name] 的岛屿"
|
||||||
|
value-panel: "&0&l 方块价值"
|
||||||
|
buttons:
|
||||||
|
island:
|
||||||
|
empty: "&f&l 第 [name] 名"
|
||||||
|
name: "&f&l [name]"
|
||||||
|
description: |-
|
||||||
|
[owner]
|
||||||
|
[members]
|
||||||
|
[place]
|
||||||
|
[level]
|
||||||
|
owners-island: "[player] 的岛屿"
|
||||||
|
owner: "&7&l 岛主:&r&b [player]"
|
||||||
|
members-title: "&7&l 成员:"
|
||||||
|
member: "&b - [player]"
|
||||||
|
unknown: 未知
|
||||||
|
place: "&7第 &7&o[number] &r&7名"
|
||||||
|
level: "&7 等级: &o [number]"
|
||||||
|
material:
|
||||||
|
name: "&f&l [number] x [material]"
|
||||||
|
description: |-
|
||||||
|
[description]
|
||||||
|
[count]
|
||||||
|
[value]
|
||||||
|
[calculated]
|
||||||
|
[limit]
|
||||||
|
[id]
|
||||||
|
id: "&7 方块ID:&e [id]"
|
||||||
|
value: "&7 方块价值:&e [number]"
|
||||||
|
limit: "&7 方块限制:&e [number]"
|
||||||
|
count: "&7 方块数量:&e [number]"
|
||||||
|
calculated: "&7 计算值:&e [number]"
|
||||||
|
all_blocks:
|
||||||
|
name: "&f&l 所有方块"
|
||||||
|
description: "&7 显示岛屿上所有的方块"
|
||||||
|
above_sea_level:
|
||||||
|
name: "&f&l 方块在海平面以上的价值"
|
||||||
|
description: |-
|
||||||
|
&7 只显示所有
|
||||||
|
&7 海平面以上的方块
|
||||||
|
underwater:
|
||||||
|
name: "&f&l 海平面以下的方块"
|
||||||
|
description: |-
|
||||||
|
&7 只显示所有
|
||||||
|
&7 海平面以下的方块
|
||||||
|
spawner:
|
||||||
|
name: "&f&l 刷怪笼"
|
||||||
|
description: "&7 只显示刷怪笼"
|
||||||
|
filters:
|
||||||
|
name:
|
||||||
|
name: "&f&l 按名称排序"
|
||||||
|
description: "&7 通过名称排序所有的方块"
|
||||||
|
value:
|
||||||
|
name: "&f&l 按价值排序"
|
||||||
|
description: "&7 通过价值排序所有的方块"
|
||||||
|
count:
|
||||||
|
name: "&f&l 按数量排序"
|
||||||
|
description: "&7 通过数量排序所有方块"
|
||||||
|
value:
|
||||||
|
name: "&f&l [material]"
|
||||||
|
description: |-
|
||||||
|
[description]
|
||||||
|
[value]
|
||||||
|
[underwater]
|
||||||
|
[limit]
|
||||||
|
[id]
|
||||||
|
id: "&7 方块ID:&e [id]"
|
||||||
|
value: "&7 方块价值:&e [number]"
|
||||||
|
underwater: "&7 方块海平面下价值:&e [number]"
|
||||||
|
limit: "&7 方块限制:&e [number]"
|
||||||
|
previous:
|
||||||
|
name: "&f&l 上一页"
|
||||||
|
description: "&7 切换到第 [number] 页"
|
||||||
|
next:
|
||||||
|
name: "&f&l 下一页"
|
||||||
|
description: "&7 切换到第 [number] 页"
|
||||||
|
search:
|
||||||
|
name: "&f&l 搜索"
|
||||||
|
description: "&7 搜索特定的内容"
|
||||||
|
search: "&b 搜索值:[value]"
|
||||||
|
tips:
|
||||||
|
click-to-view: "&e 点击 &7 查看"
|
||||||
|
click-to-previous: "&e 点击 &7 查看上一页"
|
||||||
|
click-to-next: "&e 点击 &7 查看下一页"
|
||||||
|
click-to-select: "&e 点击 &7 选择"
|
||||||
|
left-click-to-cycle-up: "&e 左键点击 &7 向上循环"
|
||||||
|
right-click-to-cycle-down: "&e 右键点击 &7 向下循环"
|
||||||
|
left-click-to-change: "&e 左键点击 &7 编辑"
|
||||||
|
right-click-to-clear: "&e 右键点击 &7 清除"
|
||||||
|
click-to-asc: "&e 点击 &7 以升序排序"
|
||||||
|
click-to-desc: "&e 点击 &7 以降序排序"
|
||||||
|
click-to-warp: "&e 点击 &7 去岛屿传送点"
|
||||||
|
click-to-visit: "&e 点击 &7 参观"
|
||||||
|
right-click-to-visit: "&e 右键点击 &7 查看"
|
||||||
|
conversations:
|
||||||
|
prefix: "&l&6 [BentoBox]: &r"
|
||||||
|
no-data: "&c 运行level指令查看方块报告"
|
||||||
|
cancel-string: cancel
|
||||||
|
exit-string: cancel, exit, quit
|
||||||
|
write-search: "&e 请输入要搜索的值. (输入 'cancel' 退出)"
|
||||||
|
search-updated: "&a 搜索值已更新"
|
||||||
|
cancelled: "&c 对话已取消!"
|
||||||
|
no-value: "&c 这件物品一文不值"
|
||||||
|
unknown-item: "&c 物品 '[material]' 在游戏中不存在"
|
||||||
|
value: "&7 物品 '[material]' 的价值:&e[value]"
|
||||||
|
value-underwater: "&7 物品 '[material]' 在海平面以下的价值:&e[value]"
|
||||||
|
empty-hand: "&c 你的手中没有拿着方块"
|
||||||
|
|
|
@ -166,7 +166,7 @@ public class LevelsManagerTest {
|
||||||
// Default to uuid's being island owners
|
// Default to uuid's being island owners
|
||||||
when(im.isOwner(eq(world), any())).thenReturn(true);
|
when(im.isOwner(eq(world), any())).thenReturn(true);
|
||||||
when(im.getOwner(any(), any(UUID.class))).thenAnswer(in -> in.getArgument(1, UUID.class));
|
when(im.getOwner(any(), any(UUID.class))).thenAnswer(in -> in.getArgument(1, UUID.class));
|
||||||
when(im.getIsland(eq(world), eq(uuid))).thenReturn(island);
|
when(im.getIsland(world, uuid)).thenReturn(island);
|
||||||
when(im.getIslandById(anyString())).thenReturn(Optional.of(island));
|
when(im.getIslandById(anyString())).thenReturn(Optional.of(island));
|
||||||
|
|
||||||
// Player
|
// Player
|
||||||
|
@ -392,8 +392,8 @@ public class LevelsManagerTest {
|
||||||
Bukkit.getScheduler();
|
Bukkit.getScheduler();
|
||||||
verify(scheduler).runTaskAsynchronously(eq(plugin), task.capture());
|
verify(scheduler).runTaskAsynchronously(eq(plugin), task.capture());
|
||||||
task.getValue().run();
|
task.getValue().run();
|
||||||
verify(addon).log(eq("Generating rankings"));
|
verify(addon).log("Generating rankings");
|
||||||
verify(addon).log(eq("Generated rankings for bskyblock-world"));
|
verify(addon).log("Generated rankings for bskyblock-world");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -164,7 +164,7 @@ public class AdminTopRemoveCommandTest {
|
||||||
@Test
|
@Test
|
||||||
public void testCanExecuteWrongArgs() {
|
public void testCanExecuteWrongArgs() {
|
||||||
assertFalse(atrc.canExecute(user, "delete", Collections.emptyList()));
|
assertFalse(atrc.canExecute(user, "delete", Collections.emptyList()));
|
||||||
verify(user).sendMessage(eq("commands.help.header"), eq(TextVariables.LABEL), eq("BSkyBlock"));
|
verify(user).sendMessage("commands.help.header", TextVariables.LABEL, "BSkyBlock");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -174,7 +174,7 @@ public class AdminTopRemoveCommandTest {
|
||||||
public void testCanExecuteUnknown() {
|
public void testCanExecuteUnknown() {
|
||||||
when(pm.getUser(anyString())).thenReturn(null);
|
when(pm.getUser(anyString())).thenReturn(null);
|
||||||
assertFalse(atrc.canExecute(user, "delete", Collections.singletonList("tastybento")));
|
assertFalse(atrc.canExecute(user, "delete", Collections.singletonList("tastybento")));
|
||||||
verify(user).sendMessage(eq("general.errors.unknown-player"), eq(TextVariables.NAME), eq("tastybento"));
|
verify(user).sendMessage("general.errors.unknown-player", TextVariables.NAME, "tastybento");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -193,7 +193,7 @@ public class AdminTopRemoveCommandTest {
|
||||||
testCanExecuteKnown();
|
testCanExecuteKnown();
|
||||||
assertTrue(atrc.execute(user, "delete", Collections.singletonList("tastybento")));
|
assertTrue(atrc.execute(user, "delete", Collections.singletonList("tastybento")));
|
||||||
verify(manager).removeEntry(any(World.class), eq(uuid));
|
verify(manager).removeEntry(any(World.class), eq(uuid));
|
||||||
verify(user).sendMessage(eq("general.success"));
|
verify(user).sendMessage("general.success");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue