mirror of
https://github.com/YouHaveTrouble/Enchantio.git
synced 2026-05-11 21:56:55 +00:00
add ability to configure active slots for the enchant
This commit is contained in:
@@ -11,7 +11,9 @@ import net.kyori.adventure.key.Key;
|
||||
import org.bukkit.configuration.ConfigurationSection;
|
||||
import org.bukkit.configuration.file.FileConfiguration;
|
||||
import org.bukkit.configuration.file.YamlConfiguration;
|
||||
import org.bukkit.inventory.EquipmentSlotGroup;
|
||||
import org.bukkit.inventory.ItemType;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
@@ -98,6 +100,13 @@ public class EnchantioConfig {
|
||||
List.of(
|
||||
"#minecraft:enchantable/mining"
|
||||
)
|
||||
)),
|
||||
getEquipmentSlotGroups(getStringList(
|
||||
telepathySection,
|
||||
"activeSlots",
|
||||
List.of(
|
||||
"MAINHAND"
|
||||
)
|
||||
))
|
||||
);
|
||||
|
||||
@@ -159,6 +168,13 @@ public class EnchantioConfig {
|
||||
"#minecraft:enchantable/weapon"
|
||||
)
|
||||
)),
|
||||
getEquipmentSlotGroups(getStringList(
|
||||
executionerSection,
|
||||
"activeSlots",
|
||||
List.of(
|
||||
"MAINHAND"
|
||||
)
|
||||
)),
|
||||
getInt(executionerSection, "maxLevel", 5),
|
||||
getDouble(executionerSection, "damageMultiplierPerLevel", 0.05),
|
||||
getDouble(executionerSection, "maxDamageHpThreshold", 0.25)
|
||||
@@ -192,6 +208,13 @@ public class EnchantioConfig {
|
||||
"#minecraft:axes"
|
||||
)
|
||||
)),
|
||||
getEquipmentSlotGroups(getStringList(
|
||||
beheadingSection,
|
||||
"activeSlots",
|
||||
List.of(
|
||||
"MAINHAND"
|
||||
)
|
||||
)),
|
||||
getInt(beheadingSection, "maxLevel", 5),
|
||||
getDouble(beheadingSection, "chanceToDropHeadPerLevel", 0.02)
|
||||
);
|
||||
@@ -254,6 +277,13 @@ public class EnchantioConfig {
|
||||
"minecraft:elytra"
|
||||
)
|
||||
)),
|
||||
getEquipmentSlotGroups(getStringList(
|
||||
airbagSection,
|
||||
"activeSlots",
|
||||
List.of(
|
||||
"CHEST"
|
||||
)
|
||||
)),
|
||||
getInt(airbagSection, "maxLevel", 4),
|
||||
getDouble(airbagSection, "damageReductionPerLevel", 0.2)
|
||||
);
|
||||
@@ -291,6 +321,13 @@ public class EnchantioConfig {
|
||||
"#minecraft:enchantable/armor"
|
||||
)
|
||||
)),
|
||||
getEquipmentSlotGroups(getStringList(
|
||||
panicSection,
|
||||
"activeSlots",
|
||||
List.of(
|
||||
"ARMOR"
|
||||
)
|
||||
)),
|
||||
getInt(panicSection, "maxLevel", 1),
|
||||
getDouble(panicSection, "panicChancePerLevel", 0.025)
|
||||
);
|
||||
@@ -338,7 +375,20 @@ public class EnchantioConfig {
|
||||
return true;
|
||||
}
|
||||
|
||||
private Set<TagEntry<ItemType>> getTagsFromList(List<String> tags) {
|
||||
private Set<EquipmentSlotGroup> getEquipmentSlotGroups(@NotNull List<String> slots) {
|
||||
Set<EquipmentSlotGroup> equipmentSlotGroups = new HashSet<>();
|
||||
for (String slot : slots) {
|
||||
try {
|
||||
EquipmentSlotGroup equipmentSlotGroup = EquipmentSlotGroup.getByName(slot.toUpperCase(Locale.ENGLISH));
|
||||
equipmentSlotGroups.add(equipmentSlotGroup);
|
||||
} catch (IllegalArgumentException e) {
|
||||
logger.warning(slot + " is not a valid equipment slot group");
|
||||
}
|
||||
}
|
||||
return equipmentSlotGroups;
|
||||
}
|
||||
|
||||
private Set<TagEntry<ItemType>> getTagsFromList(@NotNull List<String> tags) {
|
||||
Set<TagEntry<ItemType>> supportedItemTags = new HashSet<>();
|
||||
for (String itemTag : tags) {
|
||||
if (itemTag == null) continue;
|
||||
|
||||
Reference in New Issue
Block a user