mirror of
https://github.com/Auxilor/EcoEnchants.git
synced 2024-11-29 16:15:17 +01:00
Fixed lore getter
This commit is contained in:
parent
1d127c5f0f
commit
5f26c992ab
@ -5,6 +5,7 @@ import com.willfp.ecoenchants.display.EnchantDisplay;
|
|||||||
import com.willfp.ecoenchants.enchantments.EcoEnchant;
|
import com.willfp.ecoenchants.enchantments.EcoEnchant;
|
||||||
import com.willfp.ecoenchants.enchantments.EcoEnchants;
|
import com.willfp.ecoenchants.enchantments.EcoEnchants;
|
||||||
import org.bukkit.ChatColor;
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.enchantments.Enchantment;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
import org.bukkit.event.player.PlayerItemHeldEvent;
|
import org.bukkit.event.player.PlayerItemHeldEvent;
|
||||||
@ -14,7 +15,9 @@ import org.bukkit.inventory.meta.ItemMeta;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
public class HoldItemListener implements Listener {
|
public class HoldItemListener implements Listener {
|
||||||
|
|
||||||
@ -38,58 +41,63 @@ public class HoldItemListener implements Listener {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (EnchantDisplay.OPTIONS.isUseLoreGetter()) {
|
Map<Enchantment, Integer> toAdd = new HashMap<>();
|
||||||
List<String> lore = meta.getLore();
|
|
||||||
|
|
||||||
if (lore == null) {
|
if (!EnchantDisplay.OPTIONS.isUseLoreGetter()) {
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
|
|
||||||
for (String line : new ArrayList<>(lore)) {
|
|
||||||
String rawLine = line;
|
|
||||||
line = ChatColor.stripColor(line);
|
|
||||||
|
|
||||||
EcoEnchant enchant;
|
|
||||||
int level;
|
|
||||||
String[] lineSplit = line.split(" ");
|
|
||||||
if (lineSplit.length == 1) {
|
|
||||||
enchant = EcoEnchants.getByName(lineSplit[0]);
|
|
||||||
level = 1;
|
|
||||||
} else {
|
|
||||||
String levelString = lineSplit[lineSplit.length - 1];
|
|
||||||
levelString = levelString.replace(" ", "");
|
|
||||||
|
|
||||||
try {
|
|
||||||
level = NumberUtils.fromNumeral(levelString);
|
|
||||||
} catch (IllegalArgumentException e) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
StringBuilder nameBuilder = new StringBuilder();
|
|
||||||
|
|
||||||
for (int i = 0; i < lineSplit.length - 1; i++) {
|
|
||||||
nameBuilder.append(lineSplit[i]);
|
|
||||||
if (i != lineSplit.length - 2) {
|
|
||||||
nameBuilder.append(" ");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
enchant = EcoEnchants.getByName(nameBuilder.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (enchant != null) {
|
|
||||||
if (meta instanceof EnchantmentStorageMeta) {
|
|
||||||
((EnchantmentStorageMeta) meta).addStoredEnchant(enchant, level, true);
|
|
||||||
lore.clear();
|
|
||||||
} else {
|
|
||||||
meta.addEnchant(enchant, level, true);
|
|
||||||
lore.remove(rawLine);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
meta.setLore(lore);
|
|
||||||
itemStack.setItemMeta(meta);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
List<String> lore = meta.getLore();
|
||||||
|
|
||||||
|
if (lore == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (String line : new ArrayList<>(lore)) {
|
||||||
|
String rawLine = line;
|
||||||
|
line = ChatColor.stripColor(line);
|
||||||
|
|
||||||
|
EcoEnchant enchant;
|
||||||
|
int level;
|
||||||
|
String[] lineSplit = line.split(" ");
|
||||||
|
if (lineSplit.length == 1) {
|
||||||
|
enchant = EcoEnchants.getByName(lineSplit[0]);
|
||||||
|
level = 1;
|
||||||
|
} else {
|
||||||
|
String levelString = lineSplit[lineSplit.length - 1];
|
||||||
|
levelString = levelString.replace(" ", "");
|
||||||
|
|
||||||
|
try {
|
||||||
|
level = NumberUtils.fromNumeral(levelString);
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
StringBuilder nameBuilder = new StringBuilder();
|
||||||
|
|
||||||
|
for (int i = 0; i < lineSplit.length - 1; i++) {
|
||||||
|
nameBuilder.append(lineSplit[i]);
|
||||||
|
if (i != lineSplit.length - 2) {
|
||||||
|
nameBuilder.append(" ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
enchant = EcoEnchants.getByName(nameBuilder.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (enchant != null) {
|
||||||
|
lore.remove(rawLine);
|
||||||
|
toAdd.put(enchant, level);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (meta instanceof EnchantmentStorageMeta) {
|
||||||
|
lore.clear();
|
||||||
|
toAdd.forEach((enchantment, integer) -> ((EnchantmentStorageMeta) meta).addStoredEnchant(enchantment, integer, true));
|
||||||
|
} else {
|
||||||
|
toAdd.forEach((enchantment, integer) -> meta.addEnchant(enchantment, integer, true));
|
||||||
|
}
|
||||||
|
meta.setLore(lore);
|
||||||
|
itemStack.setItemMeta(meta);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user