mirror of
https://github.com/hyperdefined/ToolStats.git
synced 2026-04-23 03:21:22 +00:00
add logs stripped
This commit is contained in:
@@ -306,6 +306,35 @@ public class ItemChecker {
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the player's axe.
|
||||
*
|
||||
* @param inventory Their inventory.
|
||||
* @return Their axe, either main or offhand.
|
||||
*/
|
||||
public @Nullable ItemStack getAxe(PlayerInventory inventory) {
|
||||
ItemStack main = inventory.getItemInMainHand();
|
||||
ItemStack offHand = inventory.getItemInOffHand();
|
||||
|
||||
boolean isMain = main.getType().toString().endsWith("_AXE");
|
||||
boolean isOffHand = offHand.getType().toString().endsWith("_AXE");
|
||||
|
||||
// if the player is holding an axe in their main hand, use that one
|
||||
// if the axe is in their offhand instead, use that one after checking main hand
|
||||
// Minecraft prioritizes main hand if the player holds in both hands
|
||||
if (isMain && isOffHand) {
|
||||
return main;
|
||||
}
|
||||
if (isMain) {
|
||||
return main;
|
||||
}
|
||||
if (isOffHand) {
|
||||
return offHand;
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks the keys of the item and returns the tokens we should add.
|
||||
* If the server swaps token systems this should allow compatability.
|
||||
@@ -363,6 +392,9 @@ public class ItemChecker {
|
||||
if (container.has(toolStats.toolStatsKeys.getTridentThrows())) {
|
||||
tokens.add("trident-throws");
|
||||
}
|
||||
if (container.has(toolStats.toolStatsKeys.getLogsStripped())) {
|
||||
tokens.add("logs-stripped");
|
||||
}
|
||||
if (tokens.isEmpty()) {
|
||||
return null;
|
||||
}
|
||||
|
||||
@@ -1299,7 +1299,7 @@ public class ItemLore {
|
||||
|
||||
if (criticalStrikes == null) {
|
||||
criticalStrikes = 0;
|
||||
toolStats.logger.warn("{} does not have valid fish-caught set! Resting to zero. This should NEVER happen.", clone);
|
||||
toolStats.logger.warn("{} does not have valid critical-strikes set! Resting to zero. This should NEVER happen.", clone);
|
||||
}
|
||||
|
||||
container.set(toolStats.toolStatsKeys.getCriticalStrikes(), PersistentDataType.INTEGER, criticalStrikes + add);
|
||||
@@ -1397,7 +1397,7 @@ public class ItemLore {
|
||||
|
||||
if (tridentThrows == null) {
|
||||
tridentThrows = 0;
|
||||
toolStats.logger.warn("{} does not have valid fish-caught set! Resting to zero. This should NEVER happen.", clone);
|
||||
toolStats.logger.warn("{} does not have valid trident-throws set! Resting to zero. This should NEVER happen.", clone);
|
||||
}
|
||||
|
||||
container.set(toolStats.toolStatsKeys.getTridentThrows(), PersistentDataType.INTEGER, tridentThrows + add);
|
||||
@@ -1413,6 +1413,104 @@ public class ItemLore {
|
||||
return meta;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add x to logs stripped.
|
||||
*
|
||||
* @param axe The axe used.
|
||||
*/
|
||||
public ItemMeta updateLogsStripped(ItemStack axe, int add) {
|
||||
ItemStack clone = axe.clone();
|
||||
ItemMeta meta = clone.getItemMeta();
|
||||
if (meta == null) {
|
||||
toolStats.logger.warn("{} does NOT have any meta! Unable to update stats.", clone);
|
||||
return null;
|
||||
}
|
||||
|
||||
PersistentDataContainer container = meta.getPersistentDataContainer();
|
||||
|
||||
// if it's disabled, don't update the stats
|
||||
// check to see if the item has the stats, remove them if it does
|
||||
if (!toolStats.config.getBoolean("enabled.logs-stripped")) {
|
||||
if (container.has(toolStats.toolStatsKeys.getLogsStripped())) {
|
||||
Integer logsStripped = container.get(toolStats.toolStatsKeys.getLogsStripped(), PersistentDataType.INTEGER);
|
||||
if (logsStripped == null) {
|
||||
return null;
|
||||
}
|
||||
container.remove(toolStats.toolStatsKeys.getLogsStripped());
|
||||
// remove the applied token if this stat is disabled
|
||||
if (container.has(toolStats.toolStatsKeys.getTokenApplied())) {
|
||||
String appliedTokens = container.get(toolStats.toolStatsKeys.getTokenApplied(), PersistentDataType.STRING);
|
||||
if (appliedTokens != null) {
|
||||
// remove the token from the list
|
||||
// if the list is empty, remove the PDC
|
||||
// otherwise set the PDC back with the new list
|
||||
List<String> newTokens = toolStats.itemChecker.removeToken(appliedTokens, "logs-stripped");
|
||||
if (!newTokens.isEmpty()) {
|
||||
container.set(toolStats.toolStatsKeys.getTokenApplied(), PersistentDataType.STRING, String.join(",", newTokens));
|
||||
} else {
|
||||
container.remove(toolStats.toolStatsKeys.getTokenApplied());
|
||||
}
|
||||
}
|
||||
}
|
||||
if (meta.hasLore()) {
|
||||
String oldLogsStripped = toolStats.numberFormat.formatInt(logsStripped);
|
||||
Component lineToRemove = toolStats.configTools.formatLore("logs-stripped", "{logs}", oldLogsStripped);
|
||||
List<Component> newLore = removeLore(meta.lore(), lineToRemove);
|
||||
meta.lore(newLore);
|
||||
}
|
||||
return meta;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
// check for tokens
|
||||
boolean validToken = toolStats.itemChecker.checkTokens(container, "logs-stripped");
|
||||
// check for tokens
|
||||
if (toolStats.config.getBoolean("tokens.enabled")) {
|
||||
// if the item has stats but no token, add the token
|
||||
if (container.has(toolStats.toolStatsKeys.getLogsStripped()) && !validToken) {
|
||||
String newTokens = toolStats.itemChecker.addTokensToExisting(clone);
|
||||
if (newTokens != null) {
|
||||
container.set(toolStats.toolStatsKeys.getTokenApplied(), PersistentDataType.STRING, newTokens);
|
||||
}
|
||||
}
|
||||
|
||||
// the item does not have a valid token
|
||||
if (!validToken) {
|
||||
return null;
|
||||
}
|
||||
} else {
|
||||
if (!validToken) {
|
||||
String newTokens = toolStats.itemChecker.addTokensToExisting(clone);
|
||||
if (newTokens != null) {
|
||||
container.set(toolStats.toolStatsKeys.getTokenApplied(), PersistentDataType.STRING, newTokens);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Integer logsStripped = 0;
|
||||
if (container.has(toolStats.toolStatsKeys.getLogsStripped(), PersistentDataType.INTEGER)) {
|
||||
logsStripped = container.get(toolStats.toolStatsKeys.getLogsStripped(), PersistentDataType.INTEGER);
|
||||
}
|
||||
|
||||
if (logsStripped == null) {
|
||||
logsStripped = 0;
|
||||
toolStats.logger.warn("{} does not have valid logs-stripped set! Resting to zero. This should NEVER happen.", clone);
|
||||
}
|
||||
|
||||
container.set(toolStats.toolStatsKeys.getLogsStripped(), PersistentDataType.INTEGER, logsStripped + add);
|
||||
String oldLogsStrippedFormatted = toolStats.numberFormat.formatInt(logsStripped);
|
||||
String newLogsStrippedFormatted = toolStats.numberFormat.formatInt(logsStripped + add);
|
||||
Component oldLine = toolStats.configTools.formatLore("logs-stripped", "{logs}", oldLogsStrippedFormatted);
|
||||
Component newLine = toolStats.configTools.formatLore("logs-stripped", "{logs}", newLogsStrippedFormatted);
|
||||
if (oldLine == null || newLine == null) {
|
||||
return null;
|
||||
}
|
||||
List<Component> newLore = updateItemLore(meta, oldLine, newLine);
|
||||
meta.lore(newLore);
|
||||
return meta;
|
||||
}
|
||||
|
||||
/**
|
||||
* Format the item owner lore.
|
||||
*
|
||||
@@ -1667,6 +1765,26 @@ public class ItemLore {
|
||||
finalItem.setItemMeta(meta);
|
||||
}
|
||||
}
|
||||
if (container.has(toolStats.toolStatsKeys.getTridentThrows())) {
|
||||
Integer tridentThrows = container.get(toolStats.toolStatsKeys.getTridentThrows(), PersistentDataType.INTEGER);
|
||||
if (tridentThrows != null) {
|
||||
container.remove(toolStats.toolStatsKeys.getTridentThrows());
|
||||
String tridentThrowsFormatted = toolStats.numberFormat.formatInt(tridentThrows);
|
||||
Component lineToRemove = toolStats.configTools.formatLore("trident-throws", "{times}", tridentThrowsFormatted);
|
||||
meta.lore(removeLore(meta.lore(), lineToRemove));
|
||||
finalItem.setItemMeta(meta);
|
||||
}
|
||||
}
|
||||
if (container.has(toolStats.toolStatsKeys.getLogsStripped())) {
|
||||
Integer logsStripped = container.get(toolStats.toolStatsKeys.getLogsStripped(), PersistentDataType.INTEGER);
|
||||
if (logsStripped != null) {
|
||||
container.remove(toolStats.toolStatsKeys.getLogsStripped());
|
||||
String logsStrippedFormatted = toolStats.numberFormat.formatInt(logsStripped);
|
||||
Component lineToRemove = toolStats.configTools.formatLore("logs-stripped", "{logs}", logsStrippedFormatted);
|
||||
meta.lore(removeLore(meta.lore(), lineToRemove));
|
||||
finalItem.setItemMeta(meta);
|
||||
}
|
||||
}
|
||||
if (removeMeta) {
|
||||
Integer origin = null;
|
||||
if (container.has(toolStats.toolStatsKeys.getOriginType())) {
|
||||
|
||||
@@ -153,6 +153,13 @@ public class TokenData {
|
||||
tridentThrowsRecipe.setIngredient('S', Material.PRISMARINE_SHARD);
|
||||
recipes.add(tridentThrowsRecipe);
|
||||
|
||||
NamespacedKey logsStrippedKey = new NamespacedKey(toolStats, "logs-stripped-token");
|
||||
ShapedRecipe logsStrippedRecipe = new ShapedRecipe(logsStrippedKey, createToken("logs-stripped"));
|
||||
logsStrippedRecipe.shape(" P ", "PSP", " P ");
|
||||
logsStrippedRecipe.setIngredient('P', Material.PAPER);
|
||||
logsStrippedRecipe.setIngredient('S', Material.WOODEN_AXE);
|
||||
recipes.add(logsStrippedRecipe);
|
||||
|
||||
tokenTypes.add("crops-mined");
|
||||
tokenTypes.add("blocks-mined");
|
||||
tokenTypes.add("damage-taken");
|
||||
@@ -169,6 +176,7 @@ public class TokenData {
|
||||
tokenTypes.add("enderdragon-kills");
|
||||
tokenTypes.add("critical-strikes");
|
||||
tokenTypes.add("trident-throws");
|
||||
tokenTypes.add("logs-stripped");
|
||||
}
|
||||
|
||||
public Set<ShapedRecipe> getRecipes() {
|
||||
|
||||
@@ -37,6 +37,7 @@ public class ToolStatsKeys {
|
||||
private NamespacedKey criticalStrikes;
|
||||
private NamespacedKey tridentThrows;
|
||||
private NamespacedKey originType;
|
||||
private NamespacedKey logsStripped;
|
||||
|
||||
public void make() {
|
||||
itemOwner = new NamespacedKey(toolStats, "owner");
|
||||
@@ -61,6 +62,7 @@ public class ToolStatsKeys {
|
||||
criticalStrikes = new NamespacedKey(toolStats, "critical-strikes");
|
||||
tridentThrows = new NamespacedKey(toolStats, "trident-throws");
|
||||
originType = new NamespacedKey(toolStats, "origin");
|
||||
logsStripped = new NamespacedKey(toolStats, "logs-stripped");
|
||||
|
||||
// save which stat can be used by a reset token
|
||||
tokenKeys.add(blocksMined);
|
||||
@@ -76,6 +78,7 @@ public class ToolStatsKeys {
|
||||
tokenKeys.add(enderDragonKills);
|
||||
tokenKeys.add(criticalStrikes);
|
||||
tokenKeys.add(tridentThrows);
|
||||
tokenKeys.add(logsStripped);
|
||||
}
|
||||
|
||||
public NamespacedKey getItemOwner() {
|
||||
@@ -162,6 +165,10 @@ public class ToolStatsKeys {
|
||||
return tridentThrows;
|
||||
}
|
||||
|
||||
public NamespacedKey getLogsStripped() {
|
||||
return logsStripped;
|
||||
}
|
||||
|
||||
/**
|
||||
* Stores how an item was created.
|
||||
* 0 = crafted.
|
||||
|
||||
Reference in New Issue
Block a user