mirror of
https://github.com/Artillex-Studios/AxTrade.git
synced 2025-01-04 18:47:51 +01:00
1.8.0
This commit is contained in:
parent
fc88f0e88d
commit
3d945b12c7
2
LICENSE
2
LICENSE
@ -1,6 +1,6 @@
|
|||||||
MIT License
|
MIT License
|
||||||
|
|
||||||
Copyright (c) 2023 Artillex-Studios
|
Copyright (c) 2024 Artillex-Studios
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
4
pom.xml
4
pom.xml
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
<groupId>com.artillexstudios</groupId>
|
<groupId>com.artillexstudios</groupId>
|
||||||
<artifactId>AxTrade</artifactId>
|
<artifactId>AxTrade</artifactId>
|
||||||
<version>1.7.1</version>
|
<version>1.8.0</version>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
<name>AxTrade</name>
|
<name>AxTrade</name>
|
||||||
@ -112,7 +112,7 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.artillexstudios.axapi</groupId>
|
<groupId>com.artillexstudios.axapi</groupId>
|
||||||
<artifactId>axapi</artifactId>
|
<artifactId>axapi</artifactId>
|
||||||
<version>1.4.329</version>
|
<version>1.4.332</version>
|
||||||
<scope>compile</scope>
|
<scope>compile</scope>
|
||||||
<classifier>all</classifier>
|
<classifier>all</classifier>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
@ -136,6 +136,12 @@ public class Commands implements OrphanCommand {
|
|||||||
Trades.addTrade(sender, other);
|
Trades.addTrade(sender, other);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// @Subcommand("test")
|
||||||
|
// @CommandPermission(value = "axtrade.admin")
|
||||||
|
// public void test(@NotNull Player sender) {
|
||||||
|
// Trades.addTrade(sender, sender);
|
||||||
|
// }
|
||||||
|
|
||||||
private static BukkitCommandHandler handler = null;
|
private static BukkitCommandHandler handler = null;
|
||||||
public static void registerCommand() {
|
public static void registerCommand() {
|
||||||
if (handler == null) {
|
if (handler == null) {
|
||||||
|
@ -6,11 +6,13 @@ import org.bukkit.Bukkit;
|
|||||||
import org.bukkit.OfflinePlayer;
|
import org.bukkit.OfflinePlayer;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.text.DecimalFormat;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
public class PlaceholderCurrencyHook implements CurrencyHook {
|
public class PlaceholderCurrencyHook implements CurrencyHook {
|
||||||
private final String name;
|
private final String name;
|
||||||
private final Section section;
|
private final Section section;
|
||||||
|
private DecimalFormat df;
|
||||||
|
|
||||||
public PlaceholderCurrencyHook(String name, Section section) {
|
public PlaceholderCurrencyHook(String name, Section section) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
@ -19,6 +21,7 @@ public class PlaceholderCurrencyHook implements CurrencyHook {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setup() {
|
public void setup() {
|
||||||
|
df = new DecimalFormat("#");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -74,6 +77,6 @@ public class PlaceholderCurrencyHook implements CurrencyHook {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private String parseNumber(double amount) {
|
private String parseNumber(double amount) {
|
||||||
return usesDouble() ? "" + amount : "" + Math.round(amount);
|
return df.format(usesDouble() ? amount : Math.round(amount));
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -7,6 +7,7 @@ import com.artillexstudios.axtrade.trade.Trades;
|
|||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.EntityPickupItemEvent;
|
||||||
import org.bukkit.event.player.PlayerCommandPreprocessEvent;
|
import org.bukkit.event.player.PlayerCommandPreprocessEvent;
|
||||||
import org.bukkit.event.player.PlayerDropItemEvent;
|
import org.bukkit.event.player.PlayerDropItemEvent;
|
||||||
import org.bukkit.event.player.PlayerInteractEvent;
|
import org.bukkit.event.player.PlayerInteractEvent;
|
||||||
@ -58,12 +59,21 @@ public class TradeListeners implements Listener {
|
|||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPickup(@NotNull EntityPickupItemEvent event) {
|
||||||
|
if (!(event.getEntity() instanceof Player player)) return;
|
||||||
|
final Trade trade = Trades.getTrade(player);
|
||||||
|
if (trade == null) return;
|
||||||
|
event.setCancelled(true);
|
||||||
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onMove(@NotNull PlayerMoveEvent event) {
|
public void onMove(@NotNull PlayerMoveEvent event) {
|
||||||
|
if (event.getTo() == null) return;
|
||||||
final Player player = event.getPlayer();
|
final Player player = event.getPlayer();
|
||||||
final Trade trade = Trades.getTrade(player);
|
final Trade trade = Trades.getTrade(player);
|
||||||
if (trade == null) return;
|
if (trade == null) return;
|
||||||
if (System.currentTimeMillis() - trade.getPrepTime() < 1_000L) return;
|
if (event.getFrom().distanceSquared(event.getTo()) == 0) return;
|
||||||
trade.abort();
|
trade.abort();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
package com.artillexstudios.axtrade.trade;
|
package com.artillexstudios.axtrade.trade;
|
||||||
|
|
||||||
import com.artillexstudios.axapi.config.Config;
|
import com.artillexstudios.axapi.config.Config;
|
||||||
|
import com.artillexstudios.axapi.nms.NMSHandlers;
|
||||||
import com.artillexstudios.axapi.utils.NumberUtils;
|
import com.artillexstudios.axapi.utils.NumberUtils;
|
||||||
|
import com.artillexstudios.axapi.utils.Pair;
|
||||||
import com.artillexstudios.axtrade.utils.ItemBuilderUtil;
|
import com.artillexstudios.axtrade.utils.ItemBuilderUtil;
|
||||||
import dev.triumphteam.gui.components.GuiAction;
|
import dev.triumphteam.gui.components.GuiAction;
|
||||||
import dev.triumphteam.gui.guis.BaseGui;
|
import dev.triumphteam.gui.guis.BaseGui;
|
||||||
@ -14,6 +16,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
@ -23,10 +26,12 @@ public class GuiFrame {
|
|||||||
protected BaseGui gui;
|
protected BaseGui gui;
|
||||||
protected Player player;
|
protected Player player;
|
||||||
protected boolean opened = false;
|
protected boolean opened = false;
|
||||||
|
protected final Trade trade;
|
||||||
|
|
||||||
public GuiFrame(Config file, Player player) {
|
public GuiFrame(Config file, Player player, Trade trade) {
|
||||||
this.file = file;
|
this.file = file;
|
||||||
this.player = player;
|
this.player = player;
|
||||||
|
this.trade = trade;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setGui(BaseGui gui) {
|
public void setGui(BaseGui gui) {
|
||||||
@ -46,7 +51,18 @@ public class GuiFrame {
|
|||||||
|
|
||||||
protected ItemStack buildItem(@NotNull String key, Map<String, String> replacements) {
|
protected ItemStack buildItem(@NotNull String key, Map<String, String> replacements) {
|
||||||
if (file.getSection(key) == null) return air;
|
if (file.getSection(key) == null) return air;
|
||||||
return ItemBuilderUtil.newBuilder(file.getSection(key), replacements, player).get();
|
|
||||||
|
final Pair<String, String> selfTextures = NMSHandlers.getNmsHandler().textures(player.getPlayer());
|
||||||
|
final Pair<String, String> otherTextures = NMSHandlers.getNmsHandler().textures(trade.getOtherPlayer(player.getPlayer()));
|
||||||
|
|
||||||
|
final HashMap<String, String> map = new HashMap<>(Map.of(
|
||||||
|
"%own-head%", selfTextures == null ? "" : selfTextures.getFirst(),
|
||||||
|
"%partner-head%", otherTextures == null ? "" : otherTextures.getFirst()
|
||||||
|
));
|
||||||
|
|
||||||
|
map.putAll(replacements);
|
||||||
|
|
||||||
|
return ItemBuilderUtil.newBuilder(file.getSection(key), map, player).get();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void createItem(@NotNull String route) {
|
protected void createItem(@NotNull String route) {
|
||||||
|
@ -13,6 +13,7 @@ import java.util.ArrayList;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static com.artillexstudios.axtrade.AxTrade.CONFIG;
|
||||||
import static com.artillexstudios.axtrade.AxTrade.LANG;
|
import static com.artillexstudios.axtrade.AxTrade.LANG;
|
||||||
import static com.artillexstudios.axtrade.AxTrade.MESSAGEUTILS;
|
import static com.artillexstudios.axtrade.AxTrade.MESSAGEUTILS;
|
||||||
|
|
||||||
@ -91,8 +92,10 @@ public class Trade {
|
|||||||
String currencyName = Utils.getFormattedCurrency(entry.getKey());
|
String currencyName = Utils.getFormattedCurrency(entry.getKey());
|
||||||
String currencyAm = NumberUtils.formatNumber(entry.getValue());
|
String currencyAm = NumberUtils.formatNumber(entry.getValue());
|
||||||
player1Currencies.add(currencyName + ": " + currencyAm);
|
player1Currencies.add(currencyName + ": " + currencyAm);
|
||||||
MESSAGEUTILS.sendFormatted(player1.getPlayer(), LANG.getString("summary.give.currency"), Map.of("%amount%", currencyAm, "%currency%", currencyName));
|
if (CONFIG.getBoolean("enable-trade-summaries")) {
|
||||||
MESSAGEUTILS.sendFormatted(player2.getPlayer(), LANG.getString("summary.get.currency"), Map.of("%amount%", currencyAm, "%currency%", currencyName));
|
MESSAGEUTILS.sendFormatted(player2.getPlayer(), LANG.getString("summary.get.currency"), Map.of("%amount%", currencyAm, "%currency%", currencyName));
|
||||||
|
MESSAGEUTILS.sendFormatted(player1.getPlayer(), LANG.getString("summary.give.currency"), Map.of("%amount%", currencyAm, "%currency%", currencyName));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
List<String> player2Currencies = new ArrayList<>();
|
List<String> player2Currencies = new ArrayList<>();
|
||||||
@ -102,8 +105,10 @@ public class Trade {
|
|||||||
String currencyName = Utils.getFormattedCurrency(entry.getKey());
|
String currencyName = Utils.getFormattedCurrency(entry.getKey());
|
||||||
String currencyAm = NumberUtils.formatNumber(entry.getValue());
|
String currencyAm = NumberUtils.formatNumber(entry.getValue());
|
||||||
player2Currencies.add(currencyName + ": " + currencyAm);
|
player2Currencies.add(currencyName + ": " + currencyAm);
|
||||||
MESSAGEUTILS.sendFormatted(player2.getPlayer(), LANG.getString("summary.give.currency"), Map.of("%amount%", currencyAm, "%currency%", currencyName));
|
if (CONFIG.getBoolean("enable-trade-summaries")) {
|
||||||
MESSAGEUTILS.sendFormatted(player1.getPlayer(), LANG.getString("summary.get.currency"), Map.of("%amount%", currencyAm, "%currency%", currencyName));
|
MESSAGEUTILS.sendFormatted(player2.getPlayer(), LANG.getString("summary.give.currency"), Map.of("%amount%", currencyAm, "%currency%", currencyName));
|
||||||
|
MESSAGEUTILS.sendFormatted(player1.getPlayer(), LANG.getString("summary.get.currency"), Map.of("%amount%", currencyAm, "%currency%", currencyName));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
List<String> player1Items = new ArrayList<>();
|
List<String> player1Items = new ArrayList<>();
|
||||||
@ -115,8 +120,10 @@ public class Trade {
|
|||||||
final String itemName = Utils.getFormattedItemName(itemStack);
|
final String itemName = Utils.getFormattedItemName(itemStack);
|
||||||
int itemAm = itemStack.getAmount();
|
int itemAm = itemStack.getAmount();
|
||||||
player1Items.add(itemAm + "x " + itemName);
|
player1Items.add(itemAm + "x " + itemName);
|
||||||
MESSAGEUTILS.sendFormatted(player1.getPlayer(), LANG.getString("summary.give.item"), Map.of("%amount%", "" + itemAm, "%item%", itemName));
|
if (CONFIG.getBoolean("enable-trade-summaries")) {
|
||||||
MESSAGEUTILS.sendFormatted(player2.getPlayer(), LANG.getString("summary.get.item"), Map.of("%amount%", "" + itemAm, "%item%", itemName));
|
MESSAGEUTILS.sendFormatted(player1.getPlayer(), LANG.getString("summary.give.item"), Map.of("%amount%", "" + itemAm, "%item%", itemName));
|
||||||
|
MESSAGEUTILS.sendFormatted(player2.getPlayer(), LANG.getString("summary.get.item"), Map.of("%amount%", "" + itemAm, "%item%", itemName));
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
List<String> player2Items = new ArrayList<>();
|
List<String> player2Items = new ArrayList<>();
|
||||||
@ -128,8 +135,10 @@ public class Trade {
|
|||||||
final String itemName = Utils.getFormattedItemName(itemStack);
|
final String itemName = Utils.getFormattedItemName(itemStack);
|
||||||
int itemAm = itemStack.getAmount();
|
int itemAm = itemStack.getAmount();
|
||||||
player2Items.add(itemAm + "x " + itemName);
|
player2Items.add(itemAm + "x " + itemName);
|
||||||
MESSAGEUTILS.sendFormatted(player2.getPlayer(), LANG.getString("summary.give.item"), Map.of("%amount%", "" + itemAm, "%item%", itemName));
|
if (CONFIG.getBoolean("enable-trade-summaries")) {
|
||||||
MESSAGEUTILS.sendFormatted(player1.getPlayer(), LANG.getString("summary.get.item"), Map.of("%amount%", "" + itemAm, "%item%", itemName));
|
MESSAGEUTILS.sendFormatted(player2.getPlayer(), LANG.getString("summary.give.item"), Map.of("%amount%", "" + itemAm, "%item%", itemName));
|
||||||
|
MESSAGEUTILS.sendFormatted(player1.getPlayer(), LANG.getString("summary.get.item"), Map.of("%amount%", "" + itemAm, "%item%", itemName));
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
HistoryUtils.writeToHistory(
|
HistoryUtils.writeToHistory(
|
||||||
|
@ -42,7 +42,7 @@ public class TradeGui extends GuiFrame {
|
|||||||
// private final ItemStack fullSlot;
|
// private final ItemStack fullSlot;
|
||||||
|
|
||||||
public TradeGui(@NotNull Trade trade, @NotNull TradePlayer player) {
|
public TradeGui(@NotNull Trade trade, @NotNull TradePlayer player) {
|
||||||
super(GUIS, player.getPlayer());
|
super(GUIS, player.getPlayer(), trade);
|
||||||
this.trade = trade;
|
this.trade = trade;
|
||||||
this.player = player;
|
this.player = player;
|
||||||
this.gui = Gui.storage()
|
this.gui = Gui.storage()
|
||||||
@ -160,34 +160,27 @@ public class TradeGui extends GuiFrame {
|
|||||||
// private final HashSet<Integer> lockedSlot = new HashSet<>();
|
// private final HashSet<Integer> lockedSlot = new HashSet<>();
|
||||||
|
|
||||||
public void update() {
|
public void update() {
|
||||||
final Pair<String, String> selfTextures = NMSHandlers.getNmsHandler().textures(player.getPlayer());
|
|
||||||
final Pair<String, String> otherTextures = NMSHandlers.getNmsHandler().textures(trade.getOtherPlayer(player.getPlayer()));
|
|
||||||
|
|
||||||
final Map<String, String> replacements = Map.of(
|
|
||||||
"%own-head%", selfTextures == null ? "" : selfTextures.getFirst(),
|
|
||||||
"%partner-head%", otherTextures == null ? "" : otherTextures.getFirst()
|
|
||||||
);
|
|
||||||
if (player.hasConfirmed()) {
|
if (player.hasConfirmed()) {
|
||||||
super.createItem("own.confirm-item.slot", "own.confirm-item.cancel", event -> {
|
super.createItem("own.confirm-item.slot", "own.confirm-item.cancel", event -> {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
player.cancel();
|
player.cancel();
|
||||||
trade.update();
|
trade.update();
|
||||||
}, replacements, player.getConfirmed());
|
}, Map.of(), player.getConfirmed());
|
||||||
} else {
|
} else {
|
||||||
super.createItem("own.confirm-item.slot", "own.confirm-item.accept", event -> {
|
super.createItem("own.confirm-item.slot", "own.confirm-item.accept", event -> {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
player.confirm();
|
player.confirm();
|
||||||
}, replacements);
|
}, Map.of());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (player.getOtherPlayer().hasConfirmed()) {
|
if (player.getOtherPlayer().hasConfirmed()) {
|
||||||
super.createItem("partner.confirm-item.slot", "partner.confirm-item.cancel", event -> {
|
super.createItem("partner.confirm-item.slot", "partner.confirm-item.cancel", event -> {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
}, replacements, player.getOtherPlayer().getConfirmed());
|
}, Map.of(), player.getOtherPlayer().getConfirmed());
|
||||||
} else {
|
} else {
|
||||||
super.createItem("partner.confirm-item.slot", "partner.confirm-item.accept", event -> {
|
super.createItem("partner.confirm-item.slot", "partner.confirm-item.accept", event -> {
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
}, replacements);
|
}, Map.of());
|
||||||
}
|
}
|
||||||
|
|
||||||
for (String currencyItem : GUIS.getSection("own").getRoutesAsStrings(false)) {
|
for (String currencyItem : GUIS.getSection("own").getRoutesAsStrings(false)) {
|
||||||
|
@ -1,126 +0,0 @@
|
|||||||
package com.artillexstudios.axtrade.utils;
|
|
||||||
|
|
||||||
import com.artillexstudios.axapi.items.WrappedItemStack;
|
|
||||||
import com.artillexstudios.axapi.items.component.DataComponents;
|
|
||||||
import org.bukkit.inventory.ItemStack;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
import org.jetbrains.annotations.Nullable;
|
|
||||||
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
public class NBTUtils {
|
|
||||||
|
|
||||||
public static void writeToNBT(@NotNull ItemStack item, @NotNull String namespace, @NotNull String content) {
|
|
||||||
WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
var customData = wrappedItemStack.get(DataComponents.customData());
|
|
||||||
customData.putString(namespace, content);
|
|
||||||
wrappedItemStack.set(DataComponents.customData(), customData);
|
|
||||||
return wrappedItemStack;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void writeToNBT(@NotNull ItemStack item, @NotNull String namespace, int content) {
|
|
||||||
WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
var customData = wrappedItemStack.get(DataComponents.customData());
|
|
||||||
customData.putInt(namespace, content);
|
|
||||||
wrappedItemStack.set(DataComponents.customData(), customData);
|
|
||||||
return wrappedItemStack;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void writeToNBT(@NotNull ItemStack item, @NotNull String namespace, boolean content) {
|
|
||||||
WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
var customData = wrappedItemStack.get(DataComponents.customData());
|
|
||||||
customData.putBoolean(namespace, content);
|
|
||||||
wrappedItemStack.set(DataComponents.customData(), customData);
|
|
||||||
return wrappedItemStack;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void writeToNBT(@NotNull ItemStack item, @NotNull String namespace, double content) {
|
|
||||||
WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
var customData = wrappedItemStack.get(DataComponents.customData());
|
|
||||||
customData.putDouble(namespace, content);
|
|
||||||
wrappedItemStack.set(DataComponents.customData(), customData);
|
|
||||||
return wrappedItemStack;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void writeToNBT(@NotNull ItemStack item, @NotNull String namespace, long content) {
|
|
||||||
WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
var customData = wrappedItemStack.get(DataComponents.customData());
|
|
||||||
customData.putLong(namespace, content);
|
|
||||||
wrappedItemStack.set(DataComponents.customData(), customData);
|
|
||||||
return wrappedItemStack;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void writeToNBT(@NotNull ItemStack item, @NotNull String namespace, float content) {
|
|
||||||
WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
var customData = wrappedItemStack.get(DataComponents.customData());
|
|
||||||
customData.putFloat(namespace, content);
|
|
||||||
wrappedItemStack.set(DataComponents.customData(), customData);
|
|
||||||
return wrappedItemStack;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void writeToNBT(@NotNull ItemStack item, @NotNull String namespace, UUID content) {
|
|
||||||
WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
var customData = wrappedItemStack.get(DataComponents.customData());
|
|
||||||
customData.putUUID(namespace, content);
|
|
||||||
wrappedItemStack.set(DataComponents.customData(), customData);
|
|
||||||
return wrappedItemStack;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static boolean containsNBT(@NotNull ItemStack item, @NotNull String namespace) {
|
|
||||||
return WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
return wrappedItemStack.get(DataComponents.customData()).contains(namespace);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
@Nullable
|
|
||||||
public static String readStringFromNBT(@NotNull ItemStack item, @NotNull String namespace) {
|
|
||||||
return WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
final String str = wrappedItemStack.get(DataComponents.customData()).getString(namespace);
|
|
||||||
return str.isEmpty() ? null : str;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static int readIntegerFromNBT(@NotNull ItemStack item, @NotNull String namespace) {
|
|
||||||
return WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
return wrappedItemStack.get(DataComponents.customData()).getInt(namespace);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static float readFloatFromNBT(@NotNull ItemStack item, @NotNull String namespace) {
|
|
||||||
return WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
return wrappedItemStack.get(DataComponents.customData()).getFloat(namespace);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static long readLongFromNBT(@NotNull ItemStack item, @NotNull String namespace) {
|
|
||||||
return WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
return wrappedItemStack.get(DataComponents.customData()).getLong(namespace);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static double readDoubleFromNBT(@NotNull ItemStack item, @NotNull String namespace) {
|
|
||||||
return WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
return wrappedItemStack.get(DataComponents.customData()).getDouble(namespace);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
@Nullable
|
|
||||||
public static UUID readUUIDFromNBT(@NotNull ItemStack item, @NotNull String namespace) {
|
|
||||||
return WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
return wrappedItemStack.get(DataComponents.customData()).getUUID(namespace);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static boolean readBooleanFromNBT(@NotNull ItemStack item, @NotNull String namespace) {
|
|
||||||
return WrappedItemStack.edit(item, wrappedItemStack -> {
|
|
||||||
return wrappedItemStack.get(DataComponents.customData()).getBoolean(namespace);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
@ -25,6 +25,9 @@ trade-max-distance: 10
|
|||||||
# should shift + right clicking on another player send them a trade request?
|
# should shift + right clicking on another player send them a trade request?
|
||||||
shift-click-send-request: true
|
shift-click-send-request: true
|
||||||
|
|
||||||
|
# the trade summaries will not be sent after trades end to players if disabled
|
||||||
|
enable-trade-summaries: true
|
||||||
|
|
||||||
number-formatting:
|
number-formatting:
|
||||||
# modes:
|
# modes:
|
||||||
# 0 - formatted (customizable, look at the formatted part)
|
# 0 - formatted (customizable, look at the formatted part)
|
||||||
@ -60,4 +63,4 @@ update-notifier:
|
|||||||
on-join: true
|
on-join: true
|
||||||
|
|
||||||
# do not change this
|
# do not change this
|
||||||
version: 3
|
version: 4
|
Loading…
Reference in New Issue
Block a user