SteamWar/BauSystem
Archiviert
13
0

Fix /dt clear on not Detonator items #259

Manuell gemergt
YoyoNow hat 1 Commits von fix_dt_clear nach master 2021-05-15 17:51:06 +02:00 zusammengeführt
2 geänderte Dateien mit 13 neuen und 3 gelöschten Zeilen

Datei anzeigen

@ -89,19 +89,19 @@ public class CommandDetonator extends SWCommand {
@Register("clear")
public void clearCommand(Player p) {
if (!permissionCheck(p)) return;
p.getInventory().setItemInMainHand(Detonator.clearDetonator(p.getInventory().getItemInMainHand()));
Detonator.clear(p);
}
@Register("delete")
public void deleteCommand(Player p) {
if (!permissionCheck(p)) return;
p.getInventory().setItemInMainHand(Detonator.clearDetonator(p.getInventory().getItemInMainHand()));
Detonator.clear(p);
}
@Register("reset")
public void resetCommand(Player p) {
if (!permissionCheck(p)) return;
p.getInventory().setItemInMainHand(Detonator.clearDetonator(p.getInventory().getItemInMainHand()));
Detonator.clear(p);
}
private boolean permissionCheck(Player player) {

Datei anzeigen

@ -239,6 +239,16 @@ public class Detonator implements Listener {
return item;
}
public static void clear(Player player) {
VersionedRunnable.call(new VersionedRunnable(() -> PLAYER_LOCS.computeIfAbsent(player, player1 -> new HashSet<>()).clear(), 12), new VersionedRunnable(() -> {
if (player.getInventory().getItemInMainHand().getItemMeta().getPersistentDataContainer().has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE)) {
player.sendMessage(BauSystem.PREFIX + "§cDu hast keinen Detonator im Inventar");
return;
}
player.getInventory().setItemInMainHand(clearDetonator(player.getInventory().getItemInMainHand()));
}, 15));
}
public static ItemStack clearDetonator(ItemStack item) {
ItemMeta meta = item.getItemMeta();
PersistentDataContainer container = meta.getPersistentDataContainer();