This commit is contained in:
nulli0n 2022-07-31 16:26:23 +05:00
parent e2cb12ddd5
commit 10249cb318
109 changed files with 608 additions and 372 deletions

View File

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>ExcellentEnchants</artifactId> <artifactId>ExcellentEnchants</artifactId>
<groupId>su.nightexpress.excellentenchants</groupId> <groupId>su.nightexpress.excellentenchants</groupId>
<version>3.2.3</version> <version>3.2.4</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
@ -27,27 +27,27 @@
<dependency> <dependency>
<groupId>org.spigotmc</groupId> <groupId>org.spigotmc</groupId>
<artifactId>spigot-api</artifactId> <artifactId>spigot-api</artifactId>
<version>1.19-R0.1-SNAPSHOT</version> <version>1.19.1-R0.1-SNAPSHOT</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>su.nightexpress.excellentenchants</groupId> <groupId>su.nightexpress.excellentenchants</groupId>
<artifactId>NMS</artifactId> <artifactId>NMS</artifactId>
<version>3.2.3</version> <version>3.2.4</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>su.nightexpress.excellentenchants</groupId> <groupId>su.nightexpress.excellentenchants</groupId>
<artifactId>V1_17_R1</artifactId> <artifactId>V1_17_R1</artifactId>
<version>3.2.3</version> <version>3.2.4</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>su.nightexpress.excellentenchants</groupId> <groupId>su.nightexpress.excellentenchants</groupId>
<artifactId>V1_18_R2</artifactId> <artifactId>V1_18_R2</artifactId>
<version>3.2.3</version> <version>3.2.4</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>su.nightexpress.excellentenchants</groupId> <groupId>su.nightexpress.excellentenchants</groupId>
<artifactId>V1_19_R1</artifactId> <artifactId>V1_19_R1</artifactId>
<version>3.2.3</version> <version>3.2.4</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>fr.neatmonster</groupId> <groupId>fr.neatmonster</groupId>

View File

@ -74,6 +74,13 @@ public abstract class ExcellentEnchant extends Enchantment implements IListener
this.updateConfig(); this.updateConfig();
this.cfg.saveChanges(); this.cfg.saveChanges();
this.priority = priority; this.priority = priority;
this.conflicts = new HashSet<>();
this.loadConfig();
}
public void loadConfig() {
this.cfg.reload();
this.displayName = StringUtil.color(cfg.getString("Name", this.getId())); this.displayName = StringUtil.color(cfg.getString("Name", this.getId()));
this.tier = EnchantManager.getTierById(cfg.getString("Tier", Placeholders.DEFAULT)); this.tier = EnchantManager.getTierById(cfg.getString("Tier", Placeholders.DEFAULT));
@ -83,7 +90,6 @@ public abstract class ExcellentEnchant extends Enchantment implements IListener
this.tier.getEnchants().add(this); this.tier.getEnchants().add(this);
this.description = StringUtil.color(cfg.getStringList("Description")); this.description = StringUtil.color(cfg.getStringList("Description"));
this.conflicts = new HashSet<>();
this.isTreasure = cfg.getBoolean("Is_Treasure"); this.isTreasure = cfg.getBoolean("Is_Treasure");
this.levelMin = cfg.getInt("Level.Min"); this.levelMin = cfg.getInt("Level.Min");
this.levelMax = cfg.getInt("Level.Max"); this.levelMax = cfg.getInt("Level.Max");
@ -102,6 +108,7 @@ public abstract class ExcellentEnchant extends Enchantment implements IListener
protected void updateConfig() { protected void updateConfig() {
cfg.addMissing("Is_Treasure", false); cfg.addMissing("Is_Treasure", false);
cfg.addMissing("Conflicts", new ArrayList<String>());
cfg.addMissing("Settings.Cost.Enabled", false); cfg.addMissing("Settings.Cost.Enabled", false);
cfg.addMissing("Settings.Cost.Item.Material", Material.AIR.name()); cfg.addMissing("Settings.Cost.Item.Material", Material.AIR.name());
cfg.addMissing("Settings.Cost.Item.Amount", 1); cfg.addMissing("Settings.Cost.Item.Amount", 1);
@ -201,12 +208,11 @@ public abstract class ExcellentEnchant extends Enchantment implements IListener
return itemType == null ? new FitItemType[0] : new FitItemType[]{itemType}; return itemType == null ? new FitItemType[0] : new FitItemType[]{itemType};
} }
protected void addConflicts() { private void addConflicts() {
this.conflicts.addAll(this.getConfig().getStringSet("Conflicts").stream()
} .map(enchId -> Enchantment.getByKey(NamespacedKey.minecraft(enchId.toLowerCase())))
.filter(Objects::nonNull)
protected void addConflict(@NotNull Enchantment enchantment) { .toList());
this.conflicts.add(enchantment);
} }
public boolean hasCostItem() { public boolean hasCostItem() {
@ -326,26 +332,6 @@ public abstract class ExcellentEnchant extends Enchantment implements IListener
return Stream.of(this.getFitItemTypes()).anyMatch(fitItemType -> fitItemType.isIncluded(item)); return Stream.of(this.getFitItemTypes()).anyMatch(fitItemType -> fitItemType.isIncluded(item));
} }
/*protected boolean isFitItemType(@NotNull ItemStack item) {
EnchantmentTarget target = this.getItemTarget();
return switch (target) {
case ARMOR -> ItemUtil.isArmor(item);
case ARMOR_FEET -> ItemUtil.isBoots(item);
case ARMOR_LEGS -> ItemUtil.isLeggings(item);
case ARMOR_TORSO -> ItemUtil.isChestplate(item) || (Config.ENCHANTMENTS_ITEM_ELYTRA_AS_CHESTPLATE && item.getType() == Material.ELYTRA);
case ARMOR_HEAD -> ItemUtil.isHelmet(item);
case WEAPON -> ItemUtil.isSword(item) || (Config.ENCHANTMENTS_ITEM_AXES_AS_SWORDS && ItemUtil.isAxe(item));
case TOOL -> ItemUtil.isTool(item);
case BOW -> item.getType() == Material.BOW || (Config.ENCHANTMENTS_ITEM_CROSSBOWS_AS_BOWS && ItemUtil.isBow(item));
case FISHING_ROD -> item.getType() == Material.FISHING_ROD;
case BREAKABLE -> true;
case WEARABLE -> EnchantManager.isEnchantable(item);
case TRIDENT -> ItemUtil.isTrident(item);
case CROSSBOW -> item.getType() == Material.CROSSBOW;
default -> false;
};
}*/
@Override @Override
public boolean isCursed() { public boolean isCursed() {
return false; return false;

View File

@ -16,13 +16,18 @@ import su.nightexpress.excellentenchants.manager.tasks.ArrowTrailsTask;
public abstract class IEnchantBowTemplate extends IEnchantChanceTemplate implements BowEnchant { public abstract class IEnchantBowTemplate extends IEnchantChanceTemplate implements BowEnchant {
protected final String arrowTrailName; protected String arrowTrailName;
protected final String arrowTrailData; protected String arrowTrailData;
protected final String arrowMeta; protected final String arrowMeta;
public IEnchantBowTemplate(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg, @NotNull EnchantPriority priority) { public IEnchantBowTemplate(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg, @NotNull EnchantPriority priority) {
super(plugin, cfg, priority); super(plugin, cfg, priority);
this.arrowMeta = this.getId() + "_arrow"; this.arrowMeta = this.getId() + "_arrow";
}
@Override
public void loadConfig() {
super.loadConfig();
this.arrowTrailName = cfg.getString("Settings.Arrow.Trail.Name", ""); this.arrowTrailName = cfg.getString("Settings.Arrow.Trail.Name", "");
this.arrowTrailData = cfg.getString("Settings.Arrow.Trail.Data", ""); this.arrowTrailData = cfg.getString("Settings.Arrow.Trail.Data", "");
} }

View File

@ -18,7 +18,11 @@ public abstract class IEnchantChanceTemplate extends ExcellentEnchant {
public IEnchantChanceTemplate(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg, @NotNull EnchantPriority priority) { public IEnchantChanceTemplate(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg, @NotNull EnchantPriority priority) {
super(plugin, cfg, priority); super(plugin, cfg, priority);
}
@Override
public void loadConfig() {
super.loadConfig();
this.triggerChance = new EnchantScaler(this, "Settings.Trigger_Chance"); this.triggerChance = new EnchantScaler(this, "Settings.Trigger_Chance");
} }

View File

@ -20,7 +20,11 @@ public abstract class IEnchantCombatPotionTemplate extends IEnchantPotionTemplat
@NotNull EnchantPriority priority, @NotNull EnchantPriority priority,
@NotNull PotionEffectType effectType) { @NotNull PotionEffectType effectType) {
super(plugin, cfg, priority, effectType); super(plugin, cfg, priority, effectType);
}
@Override
public void loadConfig() {
super.loadConfig();
this.particleName = cfg.getString("Settings.Particle.Name", ""); this.particleName = cfg.getString("Settings.Particle.Name", "");
this.particleData = cfg.getString("Settings.Particle.Data", ""); this.particleData = cfg.getString("Settings.Particle.Data", "");
} }

View File

@ -22,18 +22,23 @@ public abstract class IEnchantPotionTemplate extends IEnchantChanceTemplate {
public static final String PLACEHOLDER_POTION_TYPE = "%enchantment_potion_type%"; public static final String PLACEHOLDER_POTION_TYPE = "%enchantment_potion_type%";
protected PotionEffectType potionEffectType; protected PotionEffectType potionEffectType;
protected final boolean potionParticles;
protected Scaler potionDuration; protected Scaler potionDuration;
protected Scaler potionLevel; protected Scaler potionLevel;
protected final boolean potionParticles;
public IEnchantPotionTemplate(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg, public IEnchantPotionTemplate(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg,
@NotNull EnchantPriority priority, @NotNull EnchantPriority priority,
@NotNull PotionEffectType potionEffectType) { @NotNull PotionEffectType potionEffectType) {
super(plugin, cfg, priority); super(plugin, cfg, priority);
this.potionEffectType = potionEffectType; this.potionEffectType = potionEffectType;
this.potionParticles = !(this instanceof PassiveEnchant);
}
@Override
public void loadConfig() {
super.loadConfig();
this.potionDuration = new EnchantScaler(this, "Settings.Potion_Effect.Duration"); this.potionDuration = new EnchantScaler(this, "Settings.Potion_Effect.Duration");
this.potionLevel = new EnchantScaler(this, "Settings.Potion_Effect.Level"); this.potionLevel = new EnchantScaler(this, "Settings.Potion_Effect.Level");
this.potionParticles = !(this instanceof PassiveEnchant);
} }
@Override @Override

View File

@ -159,7 +159,11 @@ public class EnchantRegister {
} }
public static void setup() { public static void setup() {
if (ExcellentEnchants.isLoaded) return; // Prevent to register enchantments during the runtime. // Prevent to register enchantments during the runtime.
if (ExcellentEnchants.isLoaded) {
ENCHANT_LIST.forEach(ExcellentEnchant::loadConfig);
return;
}
//ENCHANT_LIST.clear(); //ENCHANT_LIST.clear();
Reflex.setFieldValue(Enchantment.class, "acceptingNew", true); Reflex.setFieldValue(Enchantment.class, "acceptingNew", true);

View File

@ -5,7 +5,6 @@ import org.bukkit.Material;
import org.bukkit.Particle; import org.bukkit.Particle;
import org.bukkit.block.Block; import org.bukkit.block.Block;
import org.bukkit.block.BlockFace; import org.bukkit.block.BlockFace;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.enchantments.EnchantmentTarget; import org.bukkit.enchantments.EnchantmentTarget;
import org.bukkit.entity.LivingEntity; import org.bukkit.entity.LivingEntity;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@ -40,18 +39,22 @@ public class EnchantFlameWalker extends IEnchantChanceTemplate implements MoveEn
private static final BlockFace[] FACES = {BlockFace.SOUTH, BlockFace.NORTH, BlockFace.EAST, BlockFace.WEST}; private static final BlockFace[] FACES = {BlockFace.SOUTH, BlockFace.NORTH, BlockFace.EAST, BlockFace.WEST};
private static final Map<Block, Long> BLOCKS_TO_DESTROY = new HashMap<>(); private static final Map<Block, Long> BLOCKS_TO_DESTROY = new HashMap<>();
private final Scaler blockDecayTime; private Scaler blockDecayTime;
private BlockTickTask blockTickTask; private BlockTickTask blockTickTask;
public EnchantFlameWalker(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantFlameWalker(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
this.blockDecayTime = new EnchantScaler(this, "Settings.Block_Decay");
this.blockTickTask = new BlockTickTask(plugin); this.blockTickTask = new BlockTickTask(plugin);
this.blockTickTask.start(); this.blockTickTask.start();
} }
@Override
public void loadConfig() {
super.loadConfig();
this.blockDecayTime = new EnchantScaler(this, "Settings.Block_Decay");
}
@Override @Override
protected void updateConfig() { protected void updateConfig() {
super.updateConfig(); super.updateConfig();
@ -73,12 +76,6 @@ public class EnchantFlameWalker extends IEnchantChanceTemplate implements MoveEn
BLOCKS_TO_DESTROY.put(block, (long) (System.currentTimeMillis() + seconds * 1000L)); BLOCKS_TO_DESTROY.put(block, (long) (System.currentTimeMillis() + seconds * 1000L));
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(Enchantment.FROST_WALKER);
}
@Override @Override
@NotNull @NotNull
public EnchantmentTarget getItemTarget() { public EnchantmentTarget getItemTarget() {

View File

@ -26,10 +26,10 @@ public class EnchantRegrowth extends IEnchantChanceTemplate implements PassiveEn
public static final String ID = "regrowth"; public static final String ID = "regrowth";
private final String particleName; private String particleName;
private final String particleData; private String particleData;
private final long healthInterval; private long healthInterval;
private final Scaler healthAmount; private Scaler healthAmount;
private Task healthTask; private Task healthTask;
private static final String PLACEHOLDER_HEALTH_AMOUNT = "%enchantment_health_amount%"; private static final String PLACEHOLDER_HEALTH_AMOUNT = "%enchantment_health_amount%";
@ -37,12 +37,18 @@ public class EnchantRegrowth extends IEnchantChanceTemplate implements PassiveEn
public EnchantRegrowth(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantRegrowth(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
this.healthTask = new Task(plugin);
this.healthTask.start();
}
@Override
public void loadConfig() {
super.loadConfig();
this.particleName = cfg.getString("Settings.Particle.Name", Particle.HEART.name()); this.particleName = cfg.getString("Settings.Particle.Name", Particle.HEART.name());
this.particleData = cfg.getString("Settings.Particle.Data", ""); this.particleData = cfg.getString("Settings.Particle.Data", "");
this.healthInterval = cfg.getLong("Settings.Health.Interval", 100); this.healthInterval = cfg.getLong("Settings.Health.Interval", 100);
this.healthAmount = new EnchantScaler(this, "Settings.Health.Amount"); this.healthAmount = new EnchantScaler(this, "Settings.Health.Amount");
this.healthTask = new Task(plugin);
this.healthTask.start();
} }
@Override @Override

View File

@ -21,8 +21,8 @@ import java.util.function.UnaryOperator;
public class EnchantSaturation extends IEnchantChanceTemplate implements PassiveEnchant, ICleanable { public class EnchantSaturation extends IEnchantChanceTemplate implements PassiveEnchant, ICleanable {
private final long saturationInterval; private long saturationInterval;
private final Scaler saturationAmount; private Scaler saturationAmount;
private Task saturationTask; private Task saturationTask;
public static final String ID = "saturation"; public static final String ID = "saturation";
@ -33,12 +33,17 @@ public class EnchantSaturation extends IEnchantChanceTemplate implements Passive
public EnchantSaturation(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantSaturation(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
this.saturationInterval = cfg.getLong("Settings.Saturation.Interval", 100);
this.saturationAmount = new EnchantScaler(this, "Settings.Saturation.Amount");
this.saturationTask = new Task(plugin); this.saturationTask = new Task(plugin);
this.saturationTask.start(); this.saturationTask.start();
} }
@Override
public void loadConfig() {
super.loadConfig();
this.saturationInterval = cfg.getLong("Settings.Saturation.Interval", 100);
this.saturationAmount = new EnchantScaler(this, "Settings.Saturation.Amount");
}
@Override @Override
protected void updateConfig() { protected void updateConfig() {
super.updateConfig(); super.updateConfig();

View File

@ -22,15 +22,19 @@ import java.util.function.UnaryOperator;
public class EnchantSelfDestruction extends IEnchantChanceTemplate implements DeathEnchant { public class EnchantSelfDestruction extends IEnchantChanceTemplate implements DeathEnchant {
private final Scaler explosionSize; private Scaler explosionSize;
public static final String ID = "self_destruction"; public static final String ID = "self_destruction";
private static final String META_EXPLOSION_SOURCE = ID + "_explosion_source"; private static final String META_EXPLOSION_SOURCE = ID + "_explosion_source";
private static final String PLACEHOLDER_EXPLOSION_POWER = "%enchantment_explosion_power%"; private static final String PLACEHOLDER_EXPLOSION_POWER = "%enchantment_explosion_power%";
public EnchantSelfDestruction(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantSelfDestruction(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.explosionSize = new EnchantScaler(this, "Settings.Explosion.Size"); this.explosionSize = new EnchantScaler(this, "Settings.Explosion.Size");
} }

View File

@ -1,6 +1,5 @@
package su.nightexpress.excellentenchants.manager.enchants.bow; package su.nightexpress.excellentenchants.manager.enchants.bow;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.enchantments.EnchantmentTarget; import org.bukkit.enchantments.EnchantmentTarget;
import org.bukkit.entity.LivingEntity; import org.bukkit.entity.LivingEntity;
import org.bukkit.entity.Projectile; import org.bukkit.entity.Projectile;
@ -17,14 +16,13 @@ import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate;
import su.nightexpress.excellentenchants.api.enchantment.type.BowEnchant; import su.nightexpress.excellentenchants.api.enchantment.type.BowEnchant;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
import su.nightexpress.excellentenchants.manager.object.EnchantScaler; import su.nightexpress.excellentenchants.manager.object.EnchantScaler;
import java.util.function.UnaryOperator; import java.util.function.UnaryOperator;
public class EnchantBomber extends IEnchantChanceTemplate implements BowEnchant { public class EnchantBomber extends IEnchantChanceTemplate implements BowEnchant {
private final Scaler fuseTicks; private Scaler fuseTicks;
public static final String ID = "bomber"; public static final String ID = "bomber";
@ -32,7 +30,11 @@ public class EnchantBomber extends IEnchantChanceTemplate implements BowEnchant
public EnchantBomber(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantBomber(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.HIGHEST); super(plugin, cfg, EnchantPriority.HIGHEST);
}
@Override
public void loadConfig() {
super.loadConfig();
this.fuseTicks = new EnchantScaler(this, "Settings.Fuse_Ticks"); this.fuseTicks = new EnchantScaler(this, "Settings.Fuse_Ticks");
} }
@ -54,22 +56,6 @@ public class EnchantBomber extends IEnchantChanceTemplate implements BowEnchant
return (int) this.fuseTicks.getValue(level); return (int) this.fuseTicks.getValue(level);
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.ENDER_BOW);
this.addConflict(EnchantRegister.GHAST);
this.addConflict(EnchantRegister.EXPLOSIVE_ARROWS);
this.addConflict(EnchantRegister.WITHERED_ARROWS);
this.addConflict(EnchantRegister.POISONED_ARROWS);
this.addConflict(EnchantRegister.DRAGONFIRE_ARROWS);
this.addConflict(EnchantRegister.ELECTRIFIED_ARROWS);
this.addConflict(EnchantRegister.CONFUSING_ARROWS);
this.addConflict(Enchantment.ARROW_FIRE);
this.addConflict(Enchantment.ARROW_DAMAGE);
this.addConflict(Enchantment.ARROW_KNOCKBACK);
}
@Override @Override
@NotNull @NotNull
public EnchantmentTarget getItemTarget() { public EnchantmentTarget getItemTarget() {

View File

@ -14,7 +14,6 @@ import su.nexmedia.engine.utils.NumberUtil;
import su.nightexpress.excellentenchants.ExcellentEnchants; import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowTemplate;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
import su.nightexpress.excellentenchants.manager.object.EnchantScaler; import su.nightexpress.excellentenchants.manager.object.EnchantScaler;
import java.util.function.UnaryOperator; import java.util.function.UnaryOperator;
@ -26,24 +25,18 @@ public class EnchantDragonfireArrows extends IEnchantBowTemplate {
public static final String PLACEHOLDER_FIRE_RADIUS = "%enchantment_fire_radius%"; public static final String PLACEHOLDER_FIRE_RADIUS = "%enchantment_fire_radius%";
public static final String PLACEHOLDER_FIRE_DURATION = "%enchantment_fire_duration%"; public static final String PLACEHOLDER_FIRE_DURATION = "%enchantment_fire_duration%";
private final EnchantScaler fireDuration; private EnchantScaler fireDuration;
private final EnchantScaler fireRadius; private EnchantScaler fireRadius;
public EnchantDragonfireArrows(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantDragonfireArrows(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
this.fireDuration = new EnchantScaler(this, "Settings.Fire.Duration");
this.fireRadius = new EnchantScaler(this, "Settings.Fire.Radius");
} }
@Override @Override
protected void addConflicts() { public void loadConfig() {
super.addConflicts(); super.loadConfig();
this.addConflict(EnchantRegister.CONFUSING_ARROWS); this.fireDuration = new EnchantScaler(this, "Settings.Fire.Duration");
this.addConflict(EnchantRegister.POISONED_ARROWS); this.fireRadius = new EnchantScaler(this, "Settings.Fire.Radius");
this.addConflict(EnchantRegister.EXPLOSIVE_ARROWS);
this.addConflict(EnchantRegister.WITHERED_ARROWS);
this.addConflict(EnchantRegister.ELECTRIFIED_ARROWS);
} }
@Override @Override

View File

@ -14,7 +14,6 @@ import su.nexmedia.engine.utils.LocationUtil;
import su.nightexpress.excellentenchants.ExcellentEnchants; import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowTemplate;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
public class EnchantElectrifiedArrows extends IEnchantBowTemplate { public class EnchantElectrifiedArrows extends IEnchantBowTemplate {
@ -24,16 +23,6 @@ public class EnchantElectrifiedArrows extends IEnchantBowTemplate {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.CONFUSING_ARROWS);
this.addConflict(EnchantRegister.POISONED_ARROWS);
this.addConflict(EnchantRegister.EXPLOSIVE_ARROWS);
this.addConflict(EnchantRegister.WITHERED_ARROWS);
this.addConflict(EnchantRegister.DRAGONFIRE_ARROWS);
}
@Override @Override
public boolean use(@NotNull ProjectileHitEvent e, @NotNull Projectile projectile, @NotNull ItemStack bow, int level) { public boolean use(@NotNull ProjectileHitEvent e, @NotNull Projectile projectile, @NotNull ItemStack bow, int level) {
if (!super.use(e, projectile, bow, level)) return false; if (!super.use(e, projectile, bow, level)) return false;

View File

@ -1,6 +1,5 @@
package su.nightexpress.excellentenchants.manager.enchants.bow; package su.nightexpress.excellentenchants.manager.enchants.bow;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.enchantments.EnchantmentTarget; import org.bukkit.enchantments.EnchantmentTarget;
import org.bukkit.entity.EnderPearl; import org.bukkit.entity.EnderPearl;
import org.bukkit.entity.LivingEntity; import org.bukkit.entity.LivingEntity;
@ -15,7 +14,6 @@ import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate;
import su.nightexpress.excellentenchants.api.enchantment.type.BowEnchant; import su.nightexpress.excellentenchants.api.enchantment.type.BowEnchant;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
public class EnchantEnderBow extends IEnchantChanceTemplate implements BowEnchant { public class EnchantEnderBow extends IEnchantChanceTemplate implements BowEnchant {
@ -25,22 +23,6 @@ public class EnchantEnderBow extends IEnchantChanceTemplate implements BowEnchan
super(plugin, cfg, EnchantPriority.HIGHEST); super(plugin, cfg, EnchantPriority.HIGHEST);
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.BOMBER);
this.addConflict(EnchantRegister.GHAST);
this.addConflict(EnchantRegister.EXPLOSIVE_ARROWS);
this.addConflict(EnchantRegister.WITHERED_ARROWS);
this.addConflict(EnchantRegister.POISONED_ARROWS);
this.addConflict(EnchantRegister.DRAGONFIRE_ARROWS);
this.addConflict(EnchantRegister.ELECTRIFIED_ARROWS);
this.addConflict(EnchantRegister.CONFUSING_ARROWS);
this.addConflict(Enchantment.ARROW_FIRE);
this.addConflict(Enchantment.ARROW_DAMAGE);
this.addConflict(Enchantment.ARROW_KNOCKBACK);
}
@Override @Override
@NotNull @NotNull
public EnchantmentTarget getItemTarget() { public EnchantmentTarget getItemTarget() {

View File

@ -18,17 +18,16 @@ import su.nexmedia.engine.utils.NumberUtil;
import su.nightexpress.excellentenchants.ExcellentEnchants; import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowTemplate;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
import su.nightexpress.excellentenchants.manager.object.EnchantScaler; import su.nightexpress.excellentenchants.manager.object.EnchantScaler;
import java.util.function.UnaryOperator; import java.util.function.UnaryOperator;
public class EnchantExplosiveArrows extends IEnchantBowTemplate { public class EnchantExplosiveArrows extends IEnchantBowTemplate {
private final boolean explosionFireSpread; private boolean explosionFireSpread;
private final boolean explosionDamageItems; private boolean explosionDamageItems;
private final boolean explosionDamageBlocks; private boolean explosionDamageBlocks;
private final Scaler explosionSize; private Scaler explosionSize;
public static final String ID = "explosive_arrows"; public static final String ID = "explosive_arrows";
public static final String PLACEHOLDER_EXPLOSION_POWER = "%enchantment_explosion_power%"; public static final String PLACEHOLDER_EXPLOSION_POWER = "%enchantment_explosion_power%";
@ -37,6 +36,11 @@ public class EnchantExplosiveArrows extends IEnchantBowTemplate {
public EnchantExplosiveArrows(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantExplosiveArrows(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.explosionFireSpread = cfg.getBoolean("Settings.Explosion.Fire_Spread"); this.explosionFireSpread = cfg.getBoolean("Settings.Explosion.Fire_Spread");
this.explosionDamageItems = cfg.getBoolean("Settings.Explosion.Damage_Items"); this.explosionDamageItems = cfg.getBoolean("Settings.Explosion.Damage_Items");
this.explosionDamageBlocks = cfg.getBoolean("Settings.Explosion.Damage_Blocks"); this.explosionDamageBlocks = cfg.getBoolean("Settings.Explosion.Damage_Blocks");
@ -52,16 +56,6 @@ public class EnchantExplosiveArrows extends IEnchantBowTemplate {
this.cfg.addMissing("Settings.Explosion.Damage_Blocks", false); this.cfg.addMissing("Settings.Explosion.Damage_Blocks", false);
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.CONFUSING_ARROWS);
this.addConflict(EnchantRegister.POISONED_ARROWS);
this.addConflict(EnchantRegister.ELECTRIFIED_ARROWS);
this.addConflict(EnchantRegister.WITHERED_ARROWS);
this.addConflict(EnchantRegister.DRAGONFIRE_ARROWS);
}
@Override @Override
@NotNull @NotNull
public UnaryOperator<String> replacePlaceholders(int level) { public UnaryOperator<String> replacePlaceholders(int level) {

View File

@ -17,19 +17,22 @@ import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate;
import su.nightexpress.excellentenchants.api.enchantment.type.BowEnchant; import su.nightexpress.excellentenchants.api.enchantment.type.BowEnchant;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
import su.nightexpress.excellentenchants.manager.object.EnchantScaler; import su.nightexpress.excellentenchants.manager.object.EnchantScaler;
public class EnchantGhast extends IEnchantChanceTemplate implements BowEnchant { public class EnchantGhast extends IEnchantChanceTemplate implements BowEnchant {
private final boolean fireSpread; private boolean fireSpread;
private final Scaler yield; private Scaler yield;
public static final String ID = "ghast"; public static final String ID = "ghast";
public EnchantGhast(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantGhast(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.HIGHEST); super(plugin, cfg, EnchantPriority.HIGHEST);
}
@Override
public void loadConfig() {
super.loadConfig();
this.fireSpread = cfg.getBoolean("Settings.Fire_Spread"); this.fireSpread = cfg.getBoolean("Settings.Fire_Spread");
this.yield = new EnchantScaler(this, "Settings.Yield"); this.yield = new EnchantScaler(this, "Settings.Yield");
} }
@ -42,21 +45,6 @@ public class EnchantGhast extends IEnchantChanceTemplate implements BowEnchant {
cfg.addMissing("Settings.Yield", "1.0 * " + PLACEHOLDER_LEVEL); cfg.addMissing("Settings.Yield", "1.0 * " + PLACEHOLDER_LEVEL);
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.BOMBER);
this.addConflict(EnchantRegister.ENDER_BOW);
this.addConflict(EnchantRegister.EXPLOSIVE_ARROWS);
this.addConflict(EnchantRegister.WITHERED_ARROWS);
this.addConflict(EnchantRegister.POISONED_ARROWS);
this.addConflict(EnchantRegister.DRAGONFIRE_ARROWS);
this.addConflict(EnchantRegister.ELECTRIFIED_ARROWS);
this.addConflict(EnchantRegister.CONFUSING_ARROWS);
this.addConflict(Enchantment.ARROW_FIRE);
this.addConflict(Enchantment.ARROW_KNOCKBACK);
}
public boolean isFireSpread() { public boolean isFireSpread() {
return fireSpread; return fireSpread;
} }

View File

@ -6,7 +6,6 @@ import su.nexmedia.engine.api.config.JYML;
import su.nightexpress.excellentenchants.ExcellentEnchants; import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowPotionTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowPotionTemplate;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
public class EnchantPoisonedArrows extends IEnchantBowPotionTemplate { public class EnchantPoisonedArrows extends IEnchantBowPotionTemplate {
@ -15,14 +14,4 @@ public class EnchantPoisonedArrows extends IEnchantBowPotionTemplate {
public EnchantPoisonedArrows(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantPoisonedArrows(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM, PotionEffectType.POISON); super(plugin, cfg, EnchantPriority.MEDIUM, PotionEffectType.POISON);
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.CONFUSING_ARROWS);
this.addConflict(EnchantRegister.ELECTRIFIED_ARROWS);
this.addConflict(EnchantRegister.EXPLOSIVE_ARROWS);
this.addConflict(EnchantRegister.WITHERED_ARROWS);
this.addConflict(EnchantRegister.DRAGONFIRE_ARROWS);
}
} }

View File

@ -6,7 +6,6 @@ import su.nexmedia.engine.api.config.JYML;
import su.nightexpress.excellentenchants.ExcellentEnchants; import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowPotionTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantBowPotionTemplate;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
public class EnchantWitheredArrows extends IEnchantBowPotionTemplate { public class EnchantWitheredArrows extends IEnchantBowPotionTemplate {
@ -15,14 +14,4 @@ public class EnchantWitheredArrows extends IEnchantBowPotionTemplate {
public EnchantWitheredArrows(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantWitheredArrows(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM, PotionEffectType.WITHER); super(plugin, cfg, EnchantPriority.MEDIUM, PotionEffectType.WITHER);
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.CONFUSING_ARROWS);
this.addConflict(EnchantRegister.POISONED_ARROWS);
this.addConflict(EnchantRegister.EXPLOSIVE_ARROWS);
this.addConflict(EnchantRegister.ELECTRIFIED_ARROWS);
this.addConflict(EnchantRegister.DRAGONFIRE_ARROWS);
}
} }

View File

@ -30,8 +30,8 @@ import java.util.function.UnaryOperator;
public class EnchantBlastMining extends IEnchantChanceTemplate implements BlockBreakEnchant { public class EnchantBlastMining extends IEnchantChanceTemplate implements BlockBreakEnchant {
private final Scaler explosionPower; private Scaler explosionPower;
private final Scaler minBlockStrength; private Scaler minBlockStrength;
public static final String ID = "blast_mining"; public static final String ID = "blast_mining";
public static final String PLACEHOLDER_EXPLOSION_POWER = "%enchantment_explosion_power%"; public static final String PLACEHOLDER_EXPLOSION_POWER = "%enchantment_explosion_power%";
@ -41,7 +41,11 @@ public class EnchantBlastMining extends IEnchantChanceTemplate implements BlockB
public EnchantBlastMining(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantBlastMining(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.explosionPower = new EnchantScaler(this, "Settings.Explosion.Power"); this.explosionPower = new EnchantScaler(this, "Settings.Explosion.Power");
this.minBlockStrength = new EnchantScaler(this, "Settings.Min_Block_Strength"); this.minBlockStrength = new EnchantScaler(this, "Settings.Min_Block_Strength");
} }
@ -66,13 +70,6 @@ public class EnchantBlastMining extends IEnchantChanceTemplate implements BlockB
cfg.addMissing("Settings.Min_Block_Strength", "1.5 - " + PLACEHOLDER_LEVEL + " / 10.0"); cfg.addMissing("Settings.Min_Block_Strength", "1.5 - " + PLACEHOLDER_LEVEL + " / 10.0");
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.TUNNEL);
this.addConflict(EnchantRegister.VEINMINER);
}
@Override @Override
@NotNull @NotNull
public UnaryOperator<String> replacePlaceholders(int level) { public UnaryOperator<String> replacePlaceholders(int level) {
@ -81,11 +78,6 @@ public class EnchantBlastMining extends IEnchantChanceTemplate implements BlockB
); );
} }
/*@Override
public boolean isFitItemType(@NotNull ItemStack item) {
return ItemUtil.isPickaxe(item);
}*/
@Override @Override
@NotNull @NotNull
public FitItemType[] getFitItemTypes() { public FitItemType[] getFitItemTypes() {

View File

@ -1,6 +1,5 @@
package su.nightexpress.excellentenchants.manager.enchants.tool; package su.nightexpress.excellentenchants.manager.enchants.tool;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.enchantments.EnchantmentTarget; import org.bukkit.enchantments.EnchantmentTarget;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
@ -20,14 +19,18 @@ import java.util.function.UnaryOperator;
public class EnchantCurseOfBreaking extends IEnchantChanceTemplate { public class EnchantCurseOfBreaking extends IEnchantChanceTemplate {
private final Scaler durabilityAmount; private Scaler durabilityAmount;
public static final String ID = "curse_of_breaking"; public static final String ID = "curse_of_breaking";
public static final String PLACEHOLDER_DURABILITY_AMOUNT = "%enchantment_durability_amount%"; public static final String PLACEHOLDER_DURABILITY_AMOUNT = "%enchantment_durability_amount%";
public EnchantCurseOfBreaking(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantCurseOfBreaking(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.durabilityAmount = new EnchantScaler(this, "Settings.Durability_Amount"); this.durabilityAmount = new EnchantScaler(this, "Settings.Durability_Amount");
} }
@ -40,12 +43,6 @@ public class EnchantCurseOfBreaking extends IEnchantChanceTemplate {
return (int) this.durabilityAmount.getValue(level); return (int) this.durabilityAmount.getValue(level);
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(Enchantment.DURABILITY);
}
@Override @Override
@NotNull @NotNull
public UnaryOperator<String> replacePlaceholders(int level) { public UnaryOperator<String> replacePlaceholders(int level) {

View File

@ -17,13 +17,17 @@ import su.nightexpress.excellentenchants.manager.type.FitItemType;
public class EnchantCurseOfMisfortune extends IEnchantChanceTemplate implements BlockBreakEnchant, DeathEnchant { public class EnchantCurseOfMisfortune extends IEnchantChanceTemplate implements BlockBreakEnchant, DeathEnchant {
private final boolean dropExp; private boolean dropExp;
public static final String ID = "curse_of_misfortune"; public static final String ID = "curse_of_misfortune";
public EnchantCurseOfMisfortune(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantCurseOfMisfortune(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.LOWEST); super(plugin, cfg, EnchantPriority.LOWEST);
}
@Override
public void loadConfig() {
super.loadConfig();
this.dropExp = cfg.getBoolean("Settings.Drop_Exp"); this.dropExp = cfg.getBoolean("Settings.Drop_Exp");
} }
@ -31,13 +35,6 @@ public class EnchantCurseOfMisfortune extends IEnchantChanceTemplate implements
return dropExp; return dropExp;
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(LOOT_BONUS_BLOCKS);
this.addConflict(LOOT_BONUS_MOBS);
}
@Override @Override
@NotNull @NotNull
public FitItemType[] getFitItemTypes() { public FitItemType[] getFitItemTypes() {

View File

@ -27,7 +27,6 @@ import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate;
import su.nightexpress.excellentenchants.api.enchantment.type.BlockBreakEnchant; import su.nightexpress.excellentenchants.api.enchantment.type.BlockBreakEnchant;
import su.nightexpress.excellentenchants.api.enchantment.type.CustomDropEnchant; import su.nightexpress.excellentenchants.api.enchantment.type.CustomDropEnchant;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
import su.nightexpress.excellentenchants.manager.type.FitItemType; import su.nightexpress.excellentenchants.manager.type.FitItemType;
public class EnchantDivineTouch extends IEnchantChanceTemplate implements BlockBreakEnchant, CustomDropEnchant { public class EnchantDivineTouch extends IEnchantChanceTemplate implements BlockBreakEnchant, CustomDropEnchant {
@ -35,13 +34,17 @@ public class EnchantDivineTouch extends IEnchantChanceTemplate implements BlockB
public static final String ID = "divine_touch"; public static final String ID = "divine_touch";
private static final String META_HANDLE = ID + "_handle"; private static final String META_HANDLE = ID + "_handle";
private final String particleName; private String particleName;
private final String particleData; private String particleData;
private final String spawnerName; private String spawnerName;
public EnchantDivineTouch(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantDivineTouch(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.particleName = cfg.getString("Settings.Particle.Name", Particle.VILLAGER_HAPPY.name()); this.particleName = cfg.getString("Settings.Particle.Name", Particle.VILLAGER_HAPPY.name());
this.particleData = cfg.getString("Settings.Particle.Data", ""); this.particleData = cfg.getString("Settings.Particle.Data", "");
this.spawnerName = StringUtil.color(cfg.getString("Settings.Spawner_Item.Name", "&aMob Spawner &7(%type%)")); this.spawnerName = StringUtil.color(cfg.getString("Settings.Spawner_Item.Name", "&aMob Spawner &7(%type%)"));
@ -62,12 +65,6 @@ public class EnchantDivineTouch extends IEnchantChanceTemplate implements BlockB
return new FitItemType[]{FitItemType.PICKAXE}; return new FitItemType[]{FitItemType.PICKAXE};
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.SMELTER);
}
@Override @Override
@NotNull @NotNull
public EnchantmentTarget getItemTarget() { public EnchantmentTarget getItemTarget() {

View File

@ -19,7 +19,7 @@ import java.util.function.UnaryOperator;
public class EnchantLuckyMiner extends IEnchantChanceTemplate implements BlockBreakEnchant { public class EnchantLuckyMiner extends IEnchantChanceTemplate implements BlockBreakEnchant {
private final Scaler expModifier; private Scaler expModifier;
public static final String ID = "lucky_miner"; public static final String ID = "lucky_miner";
@ -27,6 +27,11 @@ public class EnchantLuckyMiner extends IEnchantChanceTemplate implements BlockBr
public EnchantLuckyMiner(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantLuckyMiner(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.expModifier = new EnchantScaler(this, "Settings.Exp_Modifier"); this.expModifier = new EnchantScaler(this, "Settings.Exp_Modifier");
} }

View File

@ -28,8 +28,8 @@ import java.util.Set;
public class EnchantReplanter extends IEnchantChanceTemplate implements InteractEnchant, BlockBreakEnchant { public class EnchantReplanter extends IEnchantChanceTemplate implements InteractEnchant, BlockBreakEnchant {
private final boolean replantOnRightClick; private boolean replantOnRightClick;
private final boolean replantOnPlantBreak; private boolean replantOnPlantBreak;
public static final String ID = "replanter"; public static final String ID = "replanter";
@ -39,7 +39,11 @@ public class EnchantReplanter extends IEnchantChanceTemplate implements Interact
public EnchantReplanter(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantReplanter(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.HIGH); super(plugin, cfg, EnchantPriority.HIGH);
}
@Override
public void loadConfig() {
super.loadConfig();
this.replantOnRightClick = cfg.getBoolean("Settings.Replant.On_Right_Click"); this.replantOnRightClick = cfg.getBoolean("Settings.Replant.On_Right_Click");
this.replantOnPlantBreak = cfg.getBoolean("Settings.Replant.On_Plant_Break"); this.replantOnPlantBreak = cfg.getBoolean("Settings.Replant.On_Plant_Break");
} }

View File

@ -36,20 +36,26 @@ import java.util.TreeMap;
public class EnchantSilkChest extends IEnchantChanceTemplate implements CustomDropEnchant { public class EnchantSilkChest extends IEnchantChanceTemplate implements CustomDropEnchant {
private final Map<Integer, NamespacedKey> keyItems; private final Map<Integer, NamespacedKey> keyItems;
private final String chestName;
private String chestName;
public static final String ID = "silk_chest"; public static final String ID = "silk_chest";
public EnchantSilkChest(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantSilkChest(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.HIGH); super(plugin, cfg, EnchantPriority.HIGH);
this.keyItems = new TreeMap<>(); this.keyItems = new TreeMap<>();
this.chestName = StringUtil.color(cfg.getString("Settings.Chest_Item.Name", "%name% &7(%items% items)"));
for (int pos = 0; pos < 27; pos++) { for (int pos = 0; pos < 27; pos++) {
this.getItemKey(pos); this.getItemKey(pos);
} }
} }
@Override
public void loadConfig() {
super.loadConfig();
this.chestName = StringUtil.color(cfg.getString("Settings.Chest_Item.Name", "%name% &7(%items% items)"));
}
@Override @Override
protected void updateConfig() { protected void updateConfig() {
super.updateConfig(); super.updateConfig();
@ -139,6 +145,9 @@ public class EnchantSilkChest extends IEnchantChanceTemplate implements CustomDr
BlockState state = block.getState(); BlockState state = block.getState();
if (!(state instanceof Chest chest)) return; if (!(state instanceof Chest chest)) return;
chest.setCustomName(null);
chest.update(true);
Inventory inventory = chest.getBlockInventory(); Inventory inventory = chest.getBlockInventory();
for (int pos = 0; pos < inventory.getSize(); pos++) { for (int pos = 0; pos < inventory.getSize(); pos++) {
String data = PDCUtil.getStringData(item, this.getItemKey(pos)); String data = PDCUtil.getStringData(item, this.getItemKey(pos));

View File

@ -1,8 +1,10 @@
package su.nightexpress.excellentenchants.manager.enchants.tool; package su.nightexpress.excellentenchants.manager.enchants.tool;
import org.bukkit.*; import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.Particle;
import org.bukkit.Sound;
import org.bukkit.block.Block; import org.bukkit.block.Block;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.enchantments.EnchantmentTarget; import org.bukkit.enchantments.EnchantmentTarget;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.event.block.BlockDropItemEvent; import org.bukkit.event.block.BlockDropItemEvent;
@ -16,7 +18,6 @@ import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate;
import su.nightexpress.excellentenchants.api.enchantment.type.BlockDropEnchant; import su.nightexpress.excellentenchants.api.enchantment.type.BlockDropEnchant;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
import su.nightexpress.excellentenchants.manager.type.FitItemType; import su.nightexpress.excellentenchants.manager.type.FitItemType;
import java.util.HashMap; import java.util.HashMap;
@ -26,14 +27,18 @@ public class EnchantSmelter extends IEnchantChanceTemplate implements BlockDropE
public static final String ID = "smelter"; public static final String ID = "smelter";
private final Sound sound; private Sound sound;
private final String particleName; private String particleName;
private final String particleData; private String particleData;
private final Map<Material, Material> smeltingTable; private Map<Material, Material> smeltingTable;
public EnchantSmelter(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantSmelter(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.sound = cfg.getEnum("Settings.Sound", Sound.class); this.sound = cfg.getEnum("Settings.Sound", Sound.class);
this.particleName = cfg.getString("Settings.Particle.Name", Particle.FLAME.name()); this.particleName = cfg.getString("Settings.Particle.Name", Particle.FLAME.name());
this.particleData = cfg.getString("Settings.Particle.Data", ""); this.particleData = cfg.getString("Settings.Particle.Data", "");
@ -70,12 +75,12 @@ public class EnchantSmelter extends IEnchantChanceTemplate implements BlockDropE
return new FitItemType[]{FitItemType.PICKAXE, FitItemType.AXE, FitItemType.SHOVEL}; return new FitItemType[]{FitItemType.PICKAXE, FitItemType.AXE, FitItemType.SHOVEL};
} }
@Override /*@Override
protected void addConflicts() { protected void addConflicts() {
super.addConflicts(); super.addConflicts();
this.addConflict(Enchantment.SILK_TOUCH); this.addConflict(Enchantment.SILK_TOUCH);
this.addConflict(EnchantRegister.DIVINE_TOUCH); this.addConflict(EnchantRegister.DIVINE_TOUCH);
} }*/
@Override @Override
@NotNull @NotNull

View File

@ -26,15 +26,19 @@ import java.util.function.UnaryOperator;
public class EnchantTelekinesis extends IEnchantChanceTemplate implements CustomDropEnchant { public class EnchantTelekinesis extends IEnchantChanceTemplate implements CustomDropEnchant {
private final LangMessage messageDropReceived; private LangMessage messageDropReceived;
private final String messageItemName; private String messageItemName;
private final String messageItemSeparator; private String messageItemSeparator;
public static final String ID = "telekinesis"; public static final String ID = "telekinesis";
public EnchantTelekinesis(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantTelekinesis(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.LOWEST); super(plugin, cfg, EnchantPriority.LOWEST);
}
@Override
public void loadConfig() {
super.loadConfig();
this.messageDropReceived = new LangMessage(plugin, cfg.getString("Settings.Message.Drop_Received", "")); this.messageDropReceived = new LangMessage(plugin, cfg.getString("Settings.Message.Drop_Received", ""));
this.messageItemName = StringUtil.color(cfg.getString("Settings.Message.Item_Name", "&7x%item_amount% &f%item_name%")); this.messageItemName = StringUtil.color(cfg.getString("Settings.Message.Item_Name", "&7x%item_amount% &f%item_name%"));
this.messageItemSeparator = StringUtil.color(cfg.getString("Settings.Message.Item_Separator", "&7, ")); this.messageItemSeparator = StringUtil.color(cfg.getString("Settings.Message.Item_Separator", "&7, "));

View File

@ -31,10 +31,10 @@ import java.util.function.Predicate;
public class EnchantTreasures extends IEnchantChanceTemplate implements CustomDropEnchant, ICleanable { public class EnchantTreasures extends IEnchantChanceTemplate implements CustomDropEnchant, ICleanable {
private final String particleName; private String particleName;
private final String particleData; private String particleData;
private final Sound sound; private Sound sound;
private final Map<Material, Map<Material, Double>> treasures; private Map<Material, Map<Material, Double>> treasures;
private final Predicate<Block> blockTracker; private final Predicate<Block> blockTracker;
public static final String ID = "treasures"; public static final String ID = "treasures";
@ -42,6 +42,15 @@ public class EnchantTreasures extends IEnchantChanceTemplate implements CustomDr
public EnchantTreasures(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantTreasures(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
PlayerBlockTracker.initialize();
PlayerBlockTracker.BLOCK_FILTERS.add(this.blockTracker = (block) -> {
return this.getTreasure(block.getType()) != null;
});
}
@Override
public void loadConfig() {
super.loadConfig();
this.particleName = cfg.getString("Settings.Particle.Name", Particle.REDSTONE.name()); this.particleName = cfg.getString("Settings.Particle.Name", Particle.REDSTONE.name());
this.particleData = cfg.getString("Settings.Particle.Data", "200,180,0"); this.particleData = cfg.getString("Settings.Particle.Data", "200,180,0");
this.sound = cfg.getEnum("Settings.Sound", Sound.class, Sound.BLOCK_NOTE_BLOCK_BELL); this.sound = cfg.getEnum("Settings.Sound", Sound.class, Sound.BLOCK_NOTE_BLOCK_BELL);
@ -68,11 +77,6 @@ public class EnchantTreasures extends IEnchantChanceTemplate implements CustomDr
this.treasures.put(mFrom, treasuresList); this.treasures.put(mFrom, treasuresList);
} }
} }
PlayerBlockTracker.initialize();
PlayerBlockTracker.BLOCK_FILTERS.add(this.blockTracker = (block) -> {
return this.getTreasure(block.getType()) != null;
});
} }
@Override @Override

View File

@ -26,7 +26,7 @@ import java.util.Set;
public class EnchantTunnel extends IEnchantChanceTemplate implements BlockBreakEnchant { public class EnchantTunnel extends IEnchantChanceTemplate implements BlockBreakEnchant {
private final boolean disableOnSneak; private boolean disableOnSneak;
public static final String ID = "tunnel"; public static final String ID = "tunnel";
private static final String META_BLOCK_TUNNEL = ID + "_block_tunneled"; private static final String META_BLOCK_TUNNEL = ID + "_block_tunneled";
@ -41,6 +41,11 @@ public class EnchantTunnel extends IEnchantChanceTemplate implements BlockBreakE
public EnchantTunnel(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantTunnel(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.HIGH); super(plugin, cfg, EnchantPriority.HIGH);
}
@Override
public void loadConfig() {
super.loadConfig();
this.disableOnSneak = cfg.getBoolean("Settings.Ignore_When_Sneaking"); this.disableOnSneak = cfg.getBoolean("Settings.Ignore_When_Sneaking");
} }
@ -49,14 +54,6 @@ public class EnchantTunnel extends IEnchantChanceTemplate implements BlockBreakE
super.updateConfig(); super.updateConfig();
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.VEINMINER);
this.addConflict(EnchantRegister.BLAST_MINING);
}
@Override @Override
@NotNull @NotNull
public FitItemType[] getFitItemTypes() { public FitItemType[] getFitItemTypes() {

View File

@ -32,8 +32,8 @@ import java.util.stream.Stream;
public class EnchantVeinminer extends IEnchantChanceTemplate implements BlockBreakEnchant { public class EnchantVeinminer extends IEnchantChanceTemplate implements BlockBreakEnchant {
private final Scaler blocksLimit; private Scaler blocksLimit;
private final Set<Material> blocksAffected; private Set<Material> blocksAffected;
public static final String ID = "veinminer"; public static final String ID = "veinminer";
@ -43,17 +43,14 @@ public class EnchantVeinminer extends IEnchantChanceTemplate implements BlockBre
public EnchantVeinminer(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantVeinminer(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.HIGH); super(plugin, cfg, EnchantPriority.HIGH);
this.blocksLimit = new EnchantScaler(this, "Settings.Blocks.Max_At_Once");
this.blocksAffected = cfg.getStringSet("Settings.Blocks.Affected").stream()
.map(type -> Material.getMaterial(type.toUpperCase())).filter(Objects::nonNull).collect(Collectors.toSet());
} }
@Override @Override
protected void addConflicts() { public void loadConfig() {
super.addConflicts(); super.loadConfig();
this.addConflict(EnchantRegister.TUNNEL); this.blocksLimit = new EnchantScaler(this, "Settings.Blocks.Max_At_Once");
this.addConflict(EnchantRegister.BLAST_MINING); this.blocksAffected = cfg.getStringSet("Settings.Blocks.Affected").stream()
.map(type -> Material.getMaterial(type.toUpperCase())).filter(Objects::nonNull).collect(Collectors.toSet());
} }
@NotNull @NotNull

View File

@ -2,7 +2,6 @@ package su.nightexpress.excellentenchants.manager.enchants.weapon;
import com.google.common.collect.Sets; import com.google.common.collect.Sets;
import org.bukkit.Particle; import org.bukkit.Particle;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.enchantments.EnchantmentTarget; import org.bukkit.enchantments.EnchantmentTarget;
import org.bukkit.entity.EntityType; import org.bukkit.entity.EntityType;
import org.bukkit.entity.LivingEntity; import org.bukkit.entity.LivingEntity;
@ -17,7 +16,6 @@ import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate;
import su.nightexpress.excellentenchants.api.enchantment.type.CombatEnchant; import su.nightexpress.excellentenchants.api.enchantment.type.CombatEnchant;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
import su.nightexpress.excellentenchants.manager.object.EnchantScaler; import su.nightexpress.excellentenchants.manager.object.EnchantScaler;
import java.util.Set; import java.util.Set;
@ -25,10 +23,10 @@ import java.util.function.UnaryOperator;
public class EnchantBaneOfNetherspawn extends IEnchantChanceTemplate implements CombatEnchant { public class EnchantBaneOfNetherspawn extends IEnchantChanceTemplate implements CombatEnchant {
private final String particleName; private String particleName;
private final String particleData; private String particleData;
private final boolean damageModifier; private boolean damageModifier;
private final Scaler damageFormula; private Scaler damageFormula;
private final Set<EntityType> entityTypes; private final Set<EntityType> entityTypes;
public static final String ID = "bane_of_netherspawn"; public static final String ID = "bane_of_netherspawn";
@ -38,11 +36,6 @@ public class EnchantBaneOfNetherspawn extends IEnchantChanceTemplate implements
public EnchantBaneOfNetherspawn(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantBaneOfNetherspawn(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
this.particleName = cfg.getString("Settings.Particle.Name", "");
this.particleData = cfg.getString("Settings.Particle.Data", "");
this.damageModifier = cfg.getBoolean("Settings.Damage.As_Modifier");
this.damageFormula = new EnchantScaler(this, "Settings.Damage.Formula");
this.entityTypes = Sets.newHashSet(EntityType.BLAZE, EntityType.MAGMA_CUBE, this.entityTypes = Sets.newHashSet(EntityType.BLAZE, EntityType.MAGMA_CUBE,
EntityType.WITHER_SKELETON, EntityType.GHAST, EntityType.WITHER); EntityType.WITHER_SKELETON, EntityType.GHAST, EntityType.WITHER);
@ -54,6 +47,15 @@ public class EnchantBaneOfNetherspawn extends IEnchantChanceTemplate implements
this.entityTypes.add(EntityType.ZOMBIFIED_PIGLIN); this.entityTypes.add(EntityType.ZOMBIFIED_PIGLIN);
} }
@Override
public void loadConfig() {
super.loadConfig();
this.particleName = cfg.getString("Settings.Particle.Name", "");
this.particleData = cfg.getString("Settings.Particle.Data", "");
this.damageModifier = cfg.getBoolean("Settings.Damage.As_Modifier");
this.damageFormula = new EnchantScaler(this, "Settings.Damage.Formula");
}
public double getDamageModifier(int level) { public double getDamageModifier(int level) {
return this.damageFormula.getValue(level); return this.damageFormula.getValue(level);
} }
@ -67,15 +69,6 @@ public class EnchantBaneOfNetherspawn extends IEnchantChanceTemplate implements
cfg.addMissing("Settings.Particle.Data", ""); cfg.addMissing("Settings.Particle.Data", "");
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.VILLAGE_DEFENDER);
this.addConflict(Enchantment.DAMAGE_ARTHROPODS);
this.addConflict(Enchantment.DAMAGE_UNDEAD);
this.addConflict(Enchantment.DAMAGE_ALL);
}
@Override @Override
@NotNull @NotNull
public UnaryOperator<String> replacePlaceholders(int level) { public UnaryOperator<String> replacePlaceholders(int level) {

View File

@ -20,9 +20,9 @@ import java.util.Set;
public class EnchantCure extends IEnchantChanceTemplate implements CombatEnchant { public class EnchantCure extends IEnchantChanceTemplate implements CombatEnchant {
private final Sound sound; private Sound sound;
private final String particleName; private String particleName;
private final String particleData; private String particleData;
public static final String ID = "cure"; public static final String ID = "cure";
@ -30,7 +30,11 @@ public class EnchantCure extends IEnchantChanceTemplate implements CombatEnchant
public EnchantCure(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantCure(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.sound = cfg.getEnum("Settings.Sound", Sound.class); this.sound = cfg.getEnum("Settings.Sound", Sound.class);
this.particleName = cfg.getString("Settings.Particle.Name", Particle.CLOUD.name()); this.particleName = cfg.getString("Settings.Particle.Name", Particle.CLOUD.name());
this.particleData = cfg.getString("Settings.Particle.Data", ""); this.particleData = cfg.getString("Settings.Particle.Data", "");
@ -61,19 +65,15 @@ public class EnchantCure extends IEnchantChanceTemplate implements CombatEnchant
e.setCancelled(true); e.setCancelled(true);
EffectUtil.playEffect(victim.getLocation(), this.particleName, this.particleData, 0.25, 0.25, 0.25, 0.1f, 20); EffectUtil.playEffect(victim.getLocation(), this.particleName, this.particleData, 0.25, 0.25, 0.25, 0.1f, 20);
if (this.sound != null) MessageUtil.sound(victim.getLocation(), this.sound); MessageUtil.sound(victim.getLocation(), this.sound);
if (victim instanceof PigZombie pigZombie) { if (victim instanceof PigZombie pigZombie) {
victim.getWorld().spawn(victim.getLocation(), Piglin.class); victim.getWorld().spawn(victim.getLocation(), Piglin.class);
victim.remove();
} }
else if (victim instanceof ZombieVillager zombieVillager) { else if (victim instanceof ZombieVillager zombieVillager) {
Villager.Profession profession = zombieVillager.getVillagerProfession(); zombieVillager.setConversionTime(1);
Villager villager = victim.getWorld().spawn(victim.getLocation(), Villager.class);
if (profession != null) {
villager.setProfession(profession);
} }
}
victim.remove();
return true; return true;
} }
} }

View File

@ -36,6 +36,11 @@ public class EnchantCutter extends IEnchantChanceTemplate implements CombatEncha
public EnchantCutter(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantCutter(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.LOWEST); super(plugin, cfg, EnchantPriority.LOWEST);
}
@Override
public void loadConfig() {
super.loadConfig();
this.durabilityReduction = new EnchantScaler(this, "Settings.Item.Durability_Reduction"); this.durabilityReduction = new EnchantScaler(this, "Settings.Item.Durability_Reduction");
this.sound = cfg.getEnum("Settings.Item.Sound", Sound.class); this.sound = cfg.getEnum("Settings.Item.Sound", Sound.class);
} }

View File

@ -26,17 +26,21 @@ import java.util.stream.Collectors;
public class EnchantDecapitator extends IEnchantChanceTemplate implements DeathEnchant { public class EnchantDecapitator extends IEnchantChanceTemplate implements DeathEnchant {
private final String particleName; private String particleName;
private final String particleData; private String particleData;
private final Set<String> ignoredEntityTypes; private Set<String> ignoredEntityTypes;
private final String headName; private String headName;
private final Map<String, String> headTextures; private Map<String, String> headTextures;
public static final String ID = "decapitator"; public static final String ID = "decapitator";
public EnchantDecapitator(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantDecapitator(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.particleName = cfg.getString("Settings.Particle.Name", Particle.BLOCK_CRACK.name()); this.particleName = cfg.getString("Settings.Particle.Name", Particle.BLOCK_CRACK.name());
this.particleData = cfg.getString("Settings.Particle.Data", Material.REDSTONE_BLOCK.name()); this.particleData = cfg.getString("Settings.Particle.Data", Material.REDSTONE_BLOCK.name());
this.ignoredEntityTypes = cfg.getStringSet("Settings.Ignored_Entity_Types").stream().map(String::toUpperCase).collect(Collectors.toSet()); this.ignoredEntityTypes = cfg.getStringSet("Settings.Ignored_Entity_Types").stream().map(String::toUpperCase).collect(Collectors.toSet());

View File

@ -17,15 +17,19 @@ import su.nightexpress.excellentenchants.api.enchantment.type.CombatEnchant;
public class EnchantDoubleStrike extends IEnchantChanceTemplate implements CombatEnchant { public class EnchantDoubleStrike extends IEnchantChanceTemplate implements CombatEnchant {
private final String particleName; private String particleName;
private final String particleData; private String particleData;
private final Sound sound; private Sound sound;
public static final String ID = "double_strike"; public static final String ID = "double_strike";
public EnchantDoubleStrike(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantDoubleStrike(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.LOW); super(plugin, cfg, EnchantPriority.LOW);
}
@Override
public void loadConfig() {
super.loadConfig();
this.particleName = cfg.getString("Settings.Particle.Name", Particle.EXPLOSION_NORMAL.name()); this.particleName = cfg.getString("Settings.Particle.Name", Particle.EXPLOSION_NORMAL.name());
this.particleData = cfg.getString("Settings.Particle.Data", ""); this.particleData = cfg.getString("Settings.Particle.Data", "");
this.sound = cfg.getEnum("Settings.Sound", Sound.class); this.sound = cfg.getEnum("Settings.Sound", Sound.class);

View File

@ -18,13 +18,18 @@ import java.util.function.UnaryOperator;
public class EnchantExpHunter extends IEnchantChanceTemplate implements DeathEnchant { public class EnchantExpHunter extends IEnchantChanceTemplate implements DeathEnchant {
private final Scaler expModifier; private Scaler expModifier;
public static final String ID = "exp_hunter"; public static final String ID = "exp_hunter";
public static final String PLACEHOLDER_EXP_MODIFIER = "%enchantment_exp_modifier%"; public static final String PLACEHOLDER_EXP_MODIFIER = "%enchantment_exp_modifier%";
public EnchantExpHunter(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantExpHunter(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.expModifier = new EnchantScaler(this, "Settings.Exp_Modifier"); this.expModifier = new EnchantScaler(this, "Settings.Exp_Modifier");
} }

View File

@ -22,14 +22,18 @@ import java.util.function.UnaryOperator;
public class EnchantInfernus extends IEnchantChanceTemplate { public class EnchantInfernus extends IEnchantChanceTemplate {
private final Scaler fireTicks; private Scaler fireTicks;
public static final String ID = "infernus"; public static final String ID = "infernus";
public static final String PLACEHOLDER_FIRE_DURATION = "%enchantment_fire_duration%"; public static final String PLACEHOLDER_FIRE_DURATION = "%enchantment_fire_duration%";
public EnchantInfernus(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantInfernus(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.fireTicks = new EnchantScaler(this, "Settings.Fire_Ticks"); this.fireTicks = new EnchantScaler(this, "Settings.Fire_Ticks");
} }

View File

@ -20,12 +20,17 @@ import su.nightexpress.excellentenchants.manager.object.EnchantScaler;
public class EnchantRocket extends IEnchantChanceTemplate implements CombatEnchant { public class EnchantRocket extends IEnchantChanceTemplate implements CombatEnchant {
private final Scaler fireworkPower; private Scaler fireworkPower;
public static final String ID = "rocket"; public static final String ID = "rocket";
public EnchantRocket(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantRocket(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.fireworkPower = new EnchantScaler(this, "Settings.Firework_Power"); this.fireworkPower = new EnchantScaler(this, "Settings.Firework_Power");
} }

View File

@ -23,12 +23,17 @@ import java.util.Map;
public class EnchantScavenger extends IEnchantChanceTemplate implements DeathEnchant { public class EnchantScavenger extends IEnchantChanceTemplate implements DeathEnchant {
private final Map<EntityType, Map<Material, Map.Entry<int[], Double>>> loot; private Map<EntityType, Map<Material, Map.Entry<int[], Double>>> loot;
public static final String ID = "scavenger"; public static final String ID = "scavenger";
public EnchantScavenger(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantScavenger(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.loot = new HashMap<>(); this.loot = new HashMap<>();
for (String eId : cfg.getSection("Settings.Treasures")) { for (String eId : cfg.getSection("Settings.Treasures")) {

View File

@ -24,13 +24,17 @@ public class EnchantTemper extends IEnchantChanceTemplate implements CombatEncha
public static final String PLACEHOLDER_DAMAGE_CAPACITY = "%enchantment_damage_capacity%"; public static final String PLACEHOLDER_DAMAGE_CAPACITY = "%enchantment_damage_capacity%";
public static final String PLACEHOLDER_HEALTH_POINT = "%enchantment_health_point%"; public static final String PLACEHOLDER_HEALTH_POINT = "%enchantment_health_point%";
private final EnchantScaler damageAmount; private EnchantScaler damageAmount;
private final EnchantScaler damageCapacity; private EnchantScaler damageCapacity;
private final EnchantScaler healthPoint; private EnchantScaler healthPoint;
public EnchantTemper(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantTemper(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.damageAmount = new EnchantScaler(this, "Settings.Damage.Amount"); this.damageAmount = new EnchantScaler(this, "Settings.Damage.Amount");
this.damageCapacity = new EnchantScaler(this, "Settings.Damage.Capacity"); this.damageCapacity = new EnchantScaler(this, "Settings.Damage.Capacity");
this.healthPoint = new EnchantScaler(this, "Settings.Health.Point"); this.healthPoint = new EnchantScaler(this, "Settings.Health.Point");
@ -82,7 +86,7 @@ public class EnchantTemper extends IEnchantChanceTemplate implements CombatEncha
double damageAmount = this.getDamageAmount(level); double damageAmount = this.getDamageAmount(level);
double damageCap = this.getDamageCapacity(level); double damageCap = this.getDamageCapacity(level);
double damageFinal = Math.min(damageCap, damageAmount * pointAmount); double damageFinal = Math.min(damageCap, 1D + damageAmount * pointAmount);
e.setDamage(e.getDamage() * damageFinal); e.setDamage(e.getDamage() * damageFinal);
return true; return true;

View File

@ -24,8 +24,8 @@ import java.util.stream.Collectors;
public class EnchantThrifty extends IEnchantChanceTemplate implements DeathEnchant { public class EnchantThrifty extends IEnchantChanceTemplate implements DeathEnchant {
private final Set<String> ignoredEntityTypes; private Set<String> ignoredEntityTypes;
private final Set<String> ignoredSpawnReasons; private Set<String> ignoredSpawnReasons;
private final NamespacedKey keyEntityIgnored; private final NamespacedKey keyEntityIgnored;
public static final String ID = "thrifty"; public static final String ID = "thrifty";
@ -33,7 +33,11 @@ public class EnchantThrifty extends IEnchantChanceTemplate implements DeathEncha
public EnchantThrifty(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantThrifty(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
this.keyEntityIgnored = new NamespacedKey(plugin, ID + "_ignored"); this.keyEntityIgnored = new NamespacedKey(plugin, ID + "_ignored");
}
@Override
public void loadConfig() {
super.loadConfig();
this.ignoredEntityTypes = cfg.getStringSet("Settings.Ignored_Entity_Types").stream().map(String::toUpperCase).collect(Collectors.toSet()); this.ignoredEntityTypes = cfg.getStringSet("Settings.Ignored_Entity_Types").stream().map(String::toUpperCase).collect(Collectors.toSet());
this.ignoredSpawnReasons = cfg.getStringSet("Settings.Ignored_Spawn_Reasons").stream().map(String::toUpperCase).collect(Collectors.toSet()); this.ignoredSpawnReasons = cfg.getStringSet("Settings.Ignored_Spawn_Reasons").stream().map(String::toUpperCase).collect(Collectors.toSet());
} }

View File

@ -13,13 +13,17 @@ import su.nightexpress.excellentenchants.api.enchantment.type.CombatEnchant;
public class EnchantThunder extends IEnchantChanceTemplate implements CombatEnchant { public class EnchantThunder extends IEnchantChanceTemplate implements CombatEnchant {
private final boolean inThunderstormOnly; private boolean inThunderstormOnly;
public static final String ID = "thunder"; public static final String ID = "thunder";
public EnchantThunder(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantThunder(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.inThunderstormOnly = cfg.getBoolean("Settings.During_Thunderstorm_Only"); this.inThunderstormOnly = cfg.getBoolean("Settings.During_Thunderstorm_Only");
} }

View File

@ -23,17 +23,21 @@ import java.util.function.UnaryOperator;
public class EnchantVampire extends IEnchantChanceTemplate implements CombatEnchant { public class EnchantVampire extends IEnchantChanceTemplate implements CombatEnchant {
private final String particleName; private String particleName;
private final String particleData; private String particleData;
private final Scaler healAmount; private Scaler healAmount;
private final boolean healMultiplier; private boolean healMultiplier;
public static final String ID = "vampire"; public static final String ID = "vampire";
public static final String PLACEHOLDER_HEAL_AMOUNT = "%enchantment_heal_amount%"; public static final String PLACEHOLDER_HEAL_AMOUNT = "%enchantment_heal_amount%";
public EnchantVampire(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantVampire(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.LOWEST); super(plugin, cfg, EnchantPriority.LOWEST);
}
@Override
public void loadConfig() {
super.loadConfig();
this.particleName = cfg.getString("Settings.Particle.Name", Particle.HEART.name()); this.particleName = cfg.getString("Settings.Particle.Name", Particle.HEART.name());
this.particleData = cfg.getString("Settings.Particle.Data", ""); this.particleData = cfg.getString("Settings.Particle.Data", "");
this.healAmount = new EnchantScaler(this, "Settings.Heal.Amount"); this.healAmount = new EnchantScaler(this, "Settings.Heal.Amount");

View File

@ -1,7 +1,6 @@
package su.nightexpress.excellentenchants.manager.enchants.weapon; package su.nightexpress.excellentenchants.manager.enchants.weapon;
import org.bukkit.Particle; import org.bukkit.Particle;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.enchantments.EnchantmentTarget; import org.bukkit.enchantments.EnchantmentTarget;
import org.bukkit.entity.Illager; import org.bukkit.entity.Illager;
import org.bukkit.entity.LivingEntity; import org.bukkit.entity.LivingEntity;
@ -16,24 +15,27 @@ import su.nightexpress.excellentenchants.ExcellentEnchants;
import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority; import su.nightexpress.excellentenchants.api.enchantment.EnchantPriority;
import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate; import su.nightexpress.excellentenchants.api.enchantment.IEnchantChanceTemplate;
import su.nightexpress.excellentenchants.api.enchantment.type.CombatEnchant; import su.nightexpress.excellentenchants.api.enchantment.type.CombatEnchant;
import su.nightexpress.excellentenchants.manager.EnchantRegister;
import su.nightexpress.excellentenchants.manager.object.EnchantScaler; import su.nightexpress.excellentenchants.manager.object.EnchantScaler;
import java.util.function.UnaryOperator; import java.util.function.UnaryOperator;
public class EnchantVillageDefender extends IEnchantChanceTemplate implements CombatEnchant { public class EnchantVillageDefender extends IEnchantChanceTemplate implements CombatEnchant {
private final boolean damageMultiplier; private boolean damageMultiplier;
private final Scaler damageAmount; private Scaler damageAmount;
private final String particleName; private String particleName;
private final String particleData; private String particleData;
public static final String ID = "village_defender"; public static final String ID = "village_defender";
public static final String PLACEHOLDER_DAMAGE_AMOUNT = "%enchantment_damage_amount%"; public static final String PLACEHOLDER_DAMAGE_AMOUNT = "%enchantment_damage_amount%";
public EnchantVillageDefender(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) { public EnchantVillageDefender(@NotNull ExcellentEnchants plugin, @NotNull JYML cfg) {
super(plugin, cfg, EnchantPriority.MEDIUM); super(plugin, cfg, EnchantPriority.MEDIUM);
}
@Override
public void loadConfig() {
super.loadConfig();
this.damageAmount = new EnchantScaler(this, "Settings.Damage.Formula"); this.damageAmount = new EnchantScaler(this, "Settings.Damage.Formula");
this.damageMultiplier = cfg.getBoolean("Settings.Damage.As_Modifier"); this.damageMultiplier = cfg.getBoolean("Settings.Damage.As_Modifier");
this.particleName = cfg.getString("Settings.Particle.Name", Particle.VILLAGER_ANGRY.name()); this.particleName = cfg.getString("Settings.Particle.Name", Particle.VILLAGER_ANGRY.name());
@ -65,15 +67,6 @@ public class EnchantVillageDefender extends IEnchantChanceTemplate implements Co
cfg.addMissing("Settings.Particle.Data", ""); cfg.addMissing("Settings.Particle.Data", "");
} }
@Override
protected void addConflicts() {
super.addConflicts();
this.addConflict(EnchantRegister.BANE_OF_NETHERSPAWN);
this.addConflict(Enchantment.DAMAGE_ARTHROPODS);
this.addConflict(Enchantment.DAMAGE_UNDEAD);
this.addConflict(Enchantment.DAMAGE_ALL);
}
@Override @Override
@NotNull @NotNull
public EnchantmentTarget getItemTarget() { public EnchantmentTarget getItemTarget() {

View File

@ -12,11 +12,13 @@ Tier: exotic
# You can use multiple lines here. # You can use multiple lines here.
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- Grants %enchantment_potion_type% %enchantment_potion_level% effect that costs x1 - 'Grants %enchantment_potion_type% %enchantment_potion_level% effect that costs x1 %enchantment_cost_item%.'
%enchantment_cost_item%.
# Defines if this enchantment is a treasure enchantment. # Defines if this enchantment is a treasure enchantment.
# Treasure enchantments can only be received via looting, trading, or fishing. # Treasure enchantments can only be received via looting, trading, or fishing.
Is_Treasure: false Is_Treasure: false
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,13 @@ Description:
# Defines if this enchantment is a treasure enchantment. # Defines if this enchantment is a treasure enchantment.
# Treasure enchantments can only be received via looting, trading, or fishing. # Treasure enchantments can only be received via looting, trading, or fishing.
Is_Treasure: false Is_Treasure: false
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- village_defender
- sharpness
- smite
- bane_of_arthropods
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,11 @@ Tier: legendary
Description: Description:
- '%enchantment_trigger_chance%% chance to mine blocks by x%enchantment_explosion_power% - '%enchantment_trigger_chance%% chance to mine blocks by x%enchantment_explosion_power%
power explosion.' power explosion.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- tunnel
- veinminer
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level% - '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level%
for %enchantment_potion_duration%s. on hit.' for %enchantment_potion_duration%s. on hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -14,6 +14,20 @@ Tier: exotic
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to launch TNT that explodes in %enchantment_fuse_ticks%s.' - '%enchantment_trigger_chance%% chance to launch TNT that explodes in %enchantment_fuse_ticks%s.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- ender_bow
- ghast
- explosive_arrows
- withered_arrows
- poisoned_arrows
- dragonfire_arrows
- electrified_arrows
- confusing_arrows
- flame
- power
- punch
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -16,6 +16,9 @@ Tier: common
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- Grants permanent %enchantment_potion_type% %enchantment_potion_level%. - Grants permanent %enchantment_potion_type% %enchantment_potion_level%.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: rare
Description: Description:
- '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level% - '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level%
for %enchantment_potion_duration%s. to attacker.' for %enchantment_potion_duration%s. to attacker.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to launch an arrow with %enchantment_potion_type% - '%enchantment_trigger_chance%% chance to launch an arrow with %enchantment_potion_type%
%enchantment_potion_level% (%enchantment_potion_duration%s.)' %enchantment_potion_level% (%enchantment_potion_duration%s.)'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level% - '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level%
for %enchantment_potion_duration%s. on hit.' for %enchantment_potion_duration%s. on hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: exotic
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to cure Zombified Piglins and Zombie Villagers.' - '%enchantment_trigger_chance%% chance to cure Zombified Piglins and Zombie Villagers.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,10 @@ Tier: cursed
Description: Description:
- '%enchantment_trigger_chance%% chance the item will consume extra %enchantment_durability_amount% - '%enchantment_trigger_chance%% chance the item will consume extra %enchantment_durability_amount%
durability points.' durability points.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- durability
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,11 @@ Tier: cursed
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to have no drops from blocks or mobs.' - '%enchantment_trigger_chance%% chance to have no drops from blocks or mobs.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- fortune
- looting
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,9 @@ Tier: exotic
Description: Description:
- '%enchantment_trigger_chance%% chance to throw away enemy''s armor and damage it - '%enchantment_trigger_chance%% chance to throw away enemy''s armor and damage it
for %enchantment_durability_damage%%.' for %enchantment_durability_damage%%.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: exotic
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to obtain player''s or mob''s head.' - '%enchantment_trigger_chance%% chance to obtain player''s or mob''s head.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,10 @@ Tier: legendary
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to obtain &fMob Spawner&8.' - '%enchantment_trigger_chance%% chance to obtain &fMob Spawner&8.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- smelter
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: legendary
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to inflict double damage.' - '%enchantment_trigger_chance%% chance to inflict double damage.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -16,6 +16,14 @@ Tier: exotic
Description: Description:
- '%enchantment_trigger_chance%% chance to launch an dragonfire arrow (R=%enchantment_fire_radius%, - '%enchantment_trigger_chance%% chance to launch an dragonfire arrow (R=%enchantment_fire_radius%,
%enchantment_fire_duration%s).' %enchantment_fire_duration%s).'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- confusing_arrows
- poisoned_arrows
- explosive_arrows
- withered_arrows
- electrified_arrows
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,14 @@ Tier: rare
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to launch an electrified arrow.' - '%enchantment_trigger_chance%% chance to launch an electrified arrow.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- confusing_arrows
- poisoned_arrows
- explosive_arrows
- withered_arrows
- dragonfire_arrows
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,20 @@ Tier: legendary
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to shoot Ender Pearl instead of arrows.' - '%enchantment_trigger_chance%% chance to shoot Ender Pearl instead of arrows.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- bomber
- ghast
- explosive_arrows
- withered_arrows
- poisoned_arrows
- dragonfire_arrows
- electrified_arrows
- confusing_arrows
- flame
- power
- punch
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level% - '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level%
for %enchantment_potion_duration%s. on hit.' for %enchantment_potion_duration%s. on hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,9 @@ Tier: rare
Description: Description:
- '%enchantment_trigger_chance%% chance to obtain +%enchantment_exp_modifier%% more - '%enchantment_trigger_chance%% chance to obtain +%enchantment_exp_modifier%% more
exp from mobs.' exp from mobs.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,14 @@ Tier: exotic
Description: Description:
- '%enchantment_trigger_chance%% chance to launch an explosive arrow with x%enchantment_explosion_power% - '%enchantment_trigger_chance%% chance to launch an explosive arrow with x%enchantment_explosion_power%
power.' power.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- confusing_arrows
- poisoned_arrows
- dragonfire_arrows
- withered_arrows
- electrified_arrows
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,10 @@ Tier: exotic
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- Ability to walk on lava and on magma blocks without getting damage. - Ability to walk on lava and on magma blocks without getting damage.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- frost_walker
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,19 @@ Tier: rare
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to launch a fireball instead of arrow.' - '%enchantment_trigger_chance%% chance to launch a fireball instead of arrow.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- ender_bow
- bomber
- explosive_arrows
- withered_arrows
- poisoned_arrows
- dragonfire_arrows
- electrified_arrows
- confusing_arrows
- flame
- punch
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: rare
Description: Description:
- '%enchantment_trigger_chance%% chance to obtain %enchantment_potion_type% %enchantment_potion_level% - '%enchantment_trigger_chance%% chance to obtain %enchantment_potion_type% %enchantment_potion_level%
for %enchantment_potion_duration%s. when damaged.' for %enchantment_potion_duration%s. when damaged.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -16,6 +16,9 @@ Tier: rare
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- Grants %enchantment_potion_type% %enchantment_potion_level% effect. - Grants %enchantment_potion_type% %enchantment_potion_level% effect.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to launch an arrow with %enchantment_potion_type% - '%enchantment_trigger_chance%% chance to launch an arrow with %enchantment_potion_type%
%enchantment_potion_level% (%enchantment_potion_duration%s.)' %enchantment_potion_level% (%enchantment_potion_duration%s.)'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to freeze and apply %enchantment_potion_type% - '%enchantment_trigger_chance%% chance to freeze and apply %enchantment_potion_type%
%enchantment_potion_level% for %enchantment_potion_duration%s. on hit.' %enchantment_potion_level% for %enchantment_potion_duration%s. on hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,9 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to launch flaming Trident that ignites the - '%enchantment_trigger_chance%% chance to launch flaming Trident that ignites the
enemy for %enchantment_fire_duration%s.' enemy for %enchantment_fire_duration%s.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,9 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to obtain +%enchantment_exp_modifier%% more - '%enchantment_trigger_chance%% chance to obtain +%enchantment_exp_modifier%% more
exp from ores.' exp from ores.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: rare
Description: Description:
- Grants %enchantment_potion_type% %enchantment_potion_level% effect that costs x1 - Grants %enchantment_potion_type% %enchantment_potion_level% effect that costs x1
%enchantment_cost_item%. %enchantment_cost_item%.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -20,6 +20,9 @@ Level:
# Maximal (final) enchantment level. # Maximal (final) enchantment level.
# Keep in mind that while you can enchant items with bypass max. enchantment level, all enchantment 'Scalable' option values will not exceed the max. enchantment level. # Keep in mind that while you can enchant items with bypass max. enchantment level, all enchantment 'Scalable' option values will not exceed the max. enchantment level.
Max: 1 Max: 1
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment settings for Anvil. # Enchantment settings for Anvil.
Anvil: Anvil:
# Defines the exp cost to merge this enchantment on other items on anvil. # Defines the exp cost to merge this enchantment on other items on anvil.

View File

@ -17,6 +17,9 @@ Tier: rare
Description: Description:
- '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level% - '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level%
for %enchantment_potion_duration%s. on hit.' for %enchantment_potion_duration%s. on hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,14 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to launch an arrow with %enchantment_potion_type% - '%enchantment_trigger_chance%% chance to launch an arrow with %enchantment_potion_type%
%enchantment_potion_level% (%enchantment_potion_duration%s.)' %enchantment_potion_level% (%enchantment_potion_duration%s.)'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- confusing_arrows
- dragonfire_arrows
- explosive_arrows
- withered_arrows
- electrified_arrows
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: rare
Description: Description:
- '%enchantment_trigger_chance%% chance to get %enchantment_potion_type% %enchantment_potion_level% - '%enchantment_trigger_chance%% chance to get %enchantment_potion_type% %enchantment_potion_level%
effect for %enchantment_potion_duration%s. on hit.' effect for %enchantment_potion_duration%s. on hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -16,6 +16,9 @@ Tier: exotic
Description: Description:
- Restores %enchantment_health_amount% hearts every %enchantment_health_interval%s. - Restores %enchantment_health_amount% hearts every %enchantment_health_interval%s.
with %enchantment_trigger_chance%% chance. with %enchantment_trigger_chance%% chance.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -20,6 +20,9 @@ Level:
# Maximal (final) enchantment level. # Maximal (final) enchantment level.
# Keep in mind that while you can enchant items with bypass max. enchantment level, all enchantment 'Scalable' option values will not exceed the max. enchantment level. # Keep in mind that while you can enchant items with bypass max. enchantment level, all enchantment 'Scalable' option values will not exceed the max. enchantment level.
Max: 1 Max: 1
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment settings for Anvil. # Enchantment settings for Anvil.
Anvil: Anvil:
# Defines the exp cost to merge this enchantment on other items on anvil. # Defines the exp cost to merge this enchantment on other items on anvil.

View File

@ -20,6 +20,9 @@ Level:
# Maximal (final) enchantment level. # Maximal (final) enchantment level.
# Keep in mind that while you can enchant items with bypass max. enchantment level, all enchantment 'Scalable' option values will not exceed the max. enchantment level. # Keep in mind that while you can enchant items with bypass max. enchantment level, all enchantment 'Scalable' option values will not exceed the max. enchantment level.
Max: 3 Max: 3
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment settings for Anvil. # Enchantment settings for Anvil.
Anvil: Anvil:
# Defines the exp cost to merge this enchantment on other items on anvil. # Defines the exp cost to merge this enchantment on other items on anvil.

View File

@ -16,6 +16,9 @@ Tier: rare
Description: Description:
- Restores %enchantment_saturation_amount% food points every %enchantment_saturation_interval%s. - Restores %enchantment_saturation_amount% food points every %enchantment_saturation_interval%s.
with %enchantment_trigger_chance%% chance. with %enchantment_trigger_chance%% chance.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: common
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to obtain additional loot from mobs.' - '%enchantment_trigger_chance%% chance to obtain additional loot from mobs.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,9 @@ Tier: exotic
Description: Description:
- '%enchantment_trigger_chance%% chance to create an x%enchantment_explosion_power% - '%enchantment_trigger_chance%% chance to create an x%enchantment_explosion_power%
power explosion on death.' power explosion on death.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: rare
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- Drop chests and saves all its content. - Drop chests and saves all its content.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: rare
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to smelt ore or a block on mining.' - '%enchantment_trigger_chance%% chance to smelt ore or a block on mining.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -16,6 +16,9 @@ Tier: rare
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- Grants %enchantment_potion_type% %enchantment_potion_level% effect. - Grants %enchantment_potion_type% %enchantment_potion_level% effect.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: exotic
Description: Description:
- '%enchantment_trigger_chance%% chance to apply random potion effect to enemy on - '%enchantment_trigger_chance%% chance to apply random potion effect to enemy on
hit.' hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: exotic
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- Moves all blocks loot directly to your inventory. - Moves all blocks loot directly to your inventory.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -18,6 +18,9 @@ Description:
- '%enchantment_trigger_chance%% chance to inflict %enchantment_damage_amount%% (max. - '%enchantment_trigger_chance%% chance to inflict %enchantment_damage_amount%% (max.
%enchantment_damage_capacity%%) more damage for each %enchantment_health_point% %enchantment_damage_capacity%%) more damage for each %enchantment_health_point%
hearts missing.' hearts missing.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: exotic
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to obtain mob Spawn Egg on kill.' - '%enchantment_trigger_chance%% chance to obtain mob Spawn Egg on kill.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: rare
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to summon lightning to enemy on hit.' - '%enchantment_trigger_chance%% chance to summon lightning to enemy on hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,9 @@ Tier: common
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- '%enchantment_trigger_chance%% chance to attempt to find a treasure in mined block.' - '%enchantment_trigger_chance%% chance to attempt to find a treasure in mined block.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -13,6 +13,11 @@ Tier: legendary
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- Allows you to mine multiple blocks at once in a shape. - Allows you to mine multiple blocks at once in a shape.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- veinminer
- blast_mining
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,9 @@ Tier: exotic
Description: Description:
- '%enchantment_trigger_chance%% chance to heal yourself for %enchantment_heal_amount% - '%enchantment_trigger_chance%% chance to heal yourself for %enchantment_heal_amount%
heart(s) on hit.' heart(s) on hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -14,6 +14,11 @@ Tier: rare
# You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders # You can use 'Enchantment' placeholders: http://77.222.60.131:8080/plugin/excellentenchants/utils/placeholders
Description: Description:
- Mines up to %enchantment_block_limit% blocks of the ore vein at once. - Mines up to %enchantment_block_limit% blocks of the ore vein at once.
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- blast_mining
- tunnel
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -17,6 +17,9 @@ Tier: rare
Description: Description:
- '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level% - '%enchantment_trigger_chance%% chance to apply %enchantment_potion_type% %enchantment_potion_level%
for %enchantment_potion_duration%s. on hit.' for %enchantment_potion_duration%s. on hit.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts: []
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

View File

@ -15,6 +15,13 @@ Tier: common
Description: Description:
- '%enchantment_trigger_chance%% chance to inflict %enchantment_damage_amount% more - '%enchantment_trigger_chance%% chance to inflict %enchantment_damage_amount% more
damage on Pillagers.' damage on Pillagers.'
# List of the conflicting enchantments.
# Conflicted enchantments can not be applied together on the same item.
Conflicts:
- bane_of_netherspawn
- sharpness
- smite
- bane_of_arthropods
# Enchantment level settings. # Enchantment level settings.
Level: Level:
# Minimal (start) enchantment level. Can not be smaller then 1. # Minimal (start) enchantment level. Can not be smaller then 1.

Some files were not shown because too many files have changed in this diff Show More