use meta here instead

This commit is contained in:
hyperdefined
2025-01-26 14:36:45 -05:00
parent eada8cc448
commit 4dda215805
9 changed files with 79 additions and 77 deletions

View File

@@ -178,42 +178,43 @@ public class AnvilEvent implements Listener {
ItemStack newItem = toolStats.itemChecker.addToken(firstSlotItem, targetToken);
switch (targetToken) {
case "crops-mined": {
event.setResult(toolStats.itemLore.updateCropsMined(newItem, 0));
newItem.setItemMeta(toolStats.itemLore.updateCropsMined(newItem, 0));
break;
}
case "blocks-mined": {
event.setResult(toolStats.itemLore.updateBlocksMined(newItem, 0));
newItem.setItemMeta(toolStats.itemLore.updateBlocksMined(newItem, 0));
break;
}
case "damage-taken": {
event.setResult(toolStats.itemLore.updateDamage(newItem, 0.0));
newItem.setItemMeta(toolStats.itemLore.updateDamage(newItem, 0.0));
break;
}
case "mob-kills": {
event.setResult(toolStats.itemLore.updateMobKills(newItem, 0));
newItem.setItemMeta(toolStats.itemLore.updateMobKills(newItem, 0));
break;
}
case "player-kills": {
event.setResult(toolStats.itemLore.updatePlayerKills(newItem, 0));
newItem.setItemMeta(toolStats.itemLore.updatePlayerKills(newItem, 0));
break;
}
case "arrows-shot": {
event.setResult(toolStats.itemLore.updateArrowsShot(newItem, 0));
newItem.setItemMeta(toolStats.itemLore.updateArrowsShot(newItem, 0));
break;
}
case "sheep-sheared": {
event.setResult(toolStats.itemLore.updateSheepSheared(newItem, 0));
newItem.setItemMeta(toolStats.itemLore.updateSheepSheared(newItem, 0));
break;
}
case "flight-time": {
event.setResult(toolStats.itemLore.updateFlightTime(newItem, 0));
newItem.setItemMeta(toolStats.itemLore.updateFlightTime(newItem, 0));
break;
}
case "fish-caught": {
event.setResult(toolStats.itemLore.updateFishCaught(newItem, 0));
newItem.setItemMeta(toolStats.itemLore.updateFishCaught(newItem, 0));
break;
}
}
event.setResult(newItem);
event.getView().setRepairCost(toolStats.itemChecker.getCost(targetToken));
}
}

View File

@@ -30,6 +30,7 @@ import org.bukkit.event.Listener;
import org.bukkit.event.block.BlockBreakEvent;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.PlayerInventory;
import org.bukkit.inventory.meta.ItemMeta;
import java.util.Locale;
@@ -72,19 +73,19 @@ public class BlocksMined implements Listener {
if (ageable.getAge() != ageable.getMaximumAge()) {
return;
}
ItemStack newItem = toolStats.itemLore.updateCropsMined(heldItem, 1);
if (newItem != null) {
ItemMeta newMeta = toolStats.itemLore.updateCropsMined(heldItem, 1);
if (newMeta != null) {
// replace item in main hand
inventory.setItemInMainHand(newItem);
heldItem.setItemMeta(newMeta);
}
}
} else {
// item is not a hoe
// update the blocks mined
ItemStack newItem = toolStats.itemLore.updateBlocksMined(heldItem, 1);
if (newItem != null) {
ItemMeta newMeta = toolStats.itemLore.updateBlocksMined(heldItem, 1);
if (newMeta != null) {
// replace item in main hand
inventory.setItemInMainHand(newItem);
heldItem.setItemMeta(newMeta);
}
}
}

View File

@@ -31,6 +31,7 @@ import org.bukkit.event.entity.EntityDamageByEntityEvent;
import org.bukkit.event.entity.EntityDamageEvent;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.PlayerInventory;
import org.bukkit.inventory.meta.ItemMeta;
import java.util.*;
@@ -75,31 +76,33 @@ public class EntityDamage implements Listener {
}
// a player is killing another player
if (mobBeingAttacked instanceof Player) {
ItemStack newItem = toolStats.itemLore.updatePlayerKills(heldItem, 1);
ItemMeta newItem = toolStats.itemLore.updatePlayerKills(heldItem, 1);
if (newItem != null) {
attackingPlayerInventory.setItemInMainHand(newItem);
attackingPlayerInventory.getItemInMainHand().setItemMeta(newItem);
}
return;
}
// player is killing regular mob
ItemStack newItem = toolStats.itemLore.updateMobKills(heldItem, 1);
ItemMeta newItem = toolStats.itemLore.updateMobKills(heldItem, 1);
if (newItem != null) {
attackingPlayerInventory.setItemInMainHand(newItem);
attackingPlayerInventory.getItemInMainHand().setItemMeta(newItem);
}
trackedMobs.add(mobBeingAttacked.getUniqueId());
}
// trident is being thrown at something
if (event.getDamager() instanceof Trident trident) {
ItemStack newTrident;
ItemStack newTrident = trident.getItemStack();
ItemMeta newMeta = null;
// trident is killing player
if (mobBeingAttacked instanceof Player) {
newTrident = toolStats.itemLore.updatePlayerKills(trident.getItemStack(), 1);
newMeta = toolStats.itemLore.updatePlayerKills(trident.getItemStack(), 1);
} else {
// trident is killing a mob
newTrident = toolStats.itemLore.updateMobKills(trident.getItemStack(), 1);
newMeta = toolStats.itemLore.updateMobKills(trident.getItemStack(), 1);
trackedMobs.add(mobBeingAttacked.getUniqueId());
}
if (newTrident != null) {
if (newMeta != null) {
newTrident.setItemMeta(newMeta);
trident.setItemStack(newTrident);
}
}
@@ -118,15 +121,15 @@ public class EntityDamage implements Listener {
// player is shooting another player
if (mobBeingAttacked instanceof Player) {
ItemStack newItem = toolStats.itemLore.updatePlayerKills(heldBow, 1);
ItemMeta newItem = toolStats.itemLore.updatePlayerKills(heldBow, 1);
if (newItem != null) {
shootingPlayerInventory.setItemInMainHand(newItem);
shootingPlayerInventory.getItemInMainHand().setItemMeta(newItem);
}
} else {
// player is shooting a mob
ItemStack newItem = toolStats.itemLore.updateMobKills(heldBow, 1);
ItemMeta newItem = toolStats.itemLore.updateMobKills(heldBow, 1);
if (newItem != null) {
shootingPlayerInventory.setItemInMainHand(newItem);
shootingPlayerInventory.getItemInMainHand().setItemMeta(newItem);
}
trackedMobs.add(mobBeingAttacked.getUniqueId());
}
@@ -140,13 +143,12 @@ public class EntityDamage implements Listener {
}
PlayerInventory playerInventory = playerTakingDamage.getInventory();
ItemStack[] armorContents = playerInventory.getArmorContents();
for (int i = 0; i < armorContents.length; i++) {
ItemStack armorPiece = armorContents[i];
for (ItemStack armorPiece : armorContents) {
if (armorPiece != null) {
if (toolStats.itemChecker.isArmor(armorPiece.getType())) {
ItemStack newItem = toolStats.itemLore.updateDamage(armorPiece, event.getFinalDamage());
ItemMeta newItem = toolStats.itemLore.updateDamage(armorPiece, event.getFinalDamage());
if (newItem != null) {
armorContents[i] = newItem;
armorPiece.setItemMeta(newItem);
}
}
}
@@ -176,13 +178,12 @@ public class EntityDamage implements Listener {
}
PlayerInventory playerInventory = playerTakingDamage.getInventory();
ItemStack[] armorContents = playerInventory.getArmorContents();
for (int i = 0; i < armorContents.length; i++) {
ItemStack armorPiece = armorContents[i];
for (ItemStack armorPiece : armorContents) {
if (armorPiece != null) {
if (toolStats.itemChecker.isArmor(armorPiece.getType())) {
ItemStack newItem = toolStats.itemLore.updateDamage(armorPiece, event.getFinalDamage());
ItemMeta newItem = toolStats.itemLore.updateDamage(armorPiece, event.getFinalDamage());
if (newItem != null) {
armorContents[i] = newItem;
armorPiece.setItemMeta(newItem);
}
}
}
@@ -212,13 +213,12 @@ public class EntityDamage implements Listener {
}
PlayerInventory playerInventory = playerTakingDamage.getInventory();
ItemStack[] armorContents = playerInventory.getArmorContents();
for (int i = 0; i < armorContents.length; i++) {
ItemStack armorPiece = armorContents[i];
for (ItemStack armorPiece : armorContents) {
if (armorPiece != null) {
if (toolStats.itemChecker.isArmor(armorPiece.getType())) {
ItemStack newItem = toolStats.itemLore.updateDamage(armorPiece, event.getFinalDamage());
ItemMeta newItem = toolStats.itemLore.updateDamage(armorPiece, event.getFinalDamage());
if (newItem != null) {
armorContents[i] = newItem;
armorPiece.setItemMeta(newItem);
}
}
}

View File

@@ -67,16 +67,16 @@ public class PlayerFish implements Listener {
}
// update the fishing rod!
ItemStack newFishingRod = toolStats.itemLore.updateFishCaught(fishingRod, 1);
ItemMeta newFishingRod = toolStats.itemLore.updateFishCaught(fishingRod, 1);
if (newFishingRod != null) {
PlayerInventory inventory = player.getInventory();
boolean isMain = inventory.getItemInMainHand().getType() == Material.FISHING_ROD;
boolean isOffHand = inventory.getItemInOffHand().getType() == Material.FISHING_ROD;
if (isMain) {
inventory.setItemInMainHand(newFishingRod);
inventory.getItemInMainHand().setItemMeta(newFishingRod);
}
if (isOffHand) {
inventory.setItemInOffHand(newFishingRod);
inventory.getItemInOffHand().setItemMeta(newFishingRod);
}
}

View File

@@ -26,6 +26,7 @@ import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerMoveEvent;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.PlayerInventory;
import org.bukkit.inventory.meta.ItemMeta;
import java.util.HashMap;
import java.util.Map;
@@ -56,9 +57,9 @@ public class PlayerMove implements Listener {
// make sure the player is wearing an elytra
if (chest != null && chest.getType() == Material.ELYTRA) {
long duration = (System.currentTimeMillis() - playerStartFlight.get(player));
ItemStack newItem = toolStats.itemLore.updateFlightTime(chest, duration);
ItemMeta newItem = toolStats.itemLore.updateFlightTime(chest, duration);
if (newItem != null) {
inventory.setChestplate(newItem);
inventory.getChestplate().setItemMeta(newItem);
}
}
playerStartFlight.remove(player);

View File

@@ -29,6 +29,7 @@ import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerInteractEntityEvent;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.PlayerInventory;
import org.bukkit.inventory.meta.ItemMeta;
public class SheepShear implements Listener {
@@ -64,16 +65,16 @@ public class SheepShear implements Listener {
}
// update the stats
ItemStack newItem = toolStats.itemLore.updateSheepSheared(heldShears, 1);
ItemMeta newItem = toolStats.itemLore.updateSheepSheared(heldShears, 1);
if (newItem != null) {
PlayerInventory inventory = player.getInventory();
boolean isMain = inventory.getItemInMainHand().getType() == Material.SHEARS;
boolean isOffHand = inventory.getItemInOffHand().getType() == Material.SHEARS;
if (isMain) {
inventory.setItemInMainHand(newItem);
inventory.getItemInMainHand().setItemMeta(newItem);
}
if (isOffHand) {
inventory.setItemInOffHand(newItem);
inventory.getItemInOffHand().setItemMeta(newItem);
}
}
}

View File

@@ -28,6 +28,7 @@ import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityShootBowEvent;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.PlayerInventory;
import org.bukkit.inventory.meta.ItemMeta;
import org.jetbrains.annotations.Nullable;
public class ShootBow implements Listener {
@@ -56,16 +57,16 @@ public class ShootBow implements Listener {
return;
}
ItemStack newItem = toolStats.itemLore.updateArrowsShot(heldBow, 1);
ItemMeta newItem = toolStats.itemLore.updateArrowsShot(heldBow, 1);
if (newItem != null) {
PlayerInventory inventory = player.getInventory();
boolean isMain = inventory.getItemInMainHand().getType() == Material.BOW || inventory.getItemInMainHand().getType() == Material.CROSSBOW;
boolean isOffHand = inventory.getItemInOffHand().getType() == Material.BOW || inventory.getItemInOffHand().getType() == Material.CROSSBOW;
if (isMain) {
inventory.setItemInMainHand(newItem);
inventory.getItemInMainHand().setItemMeta(newItem);
}
if (isOffHand) {
inventory.setItemInOffHand(newItem);
inventory.getItemInOffHand().setItemMeta(newItem);
}
}
}