mirror of
https://github.com/songoda/EpicEnchants.git
synced 2025-01-25 01:01:23 +01:00
Fixed dusts and lores.
This commit is contained in:
parent
79ed22a755
commit
49bfa0ef90
@ -37,7 +37,6 @@ public class DustListener extends ItemListener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
successRate = successRate + cursor.getInteger("percentage") > 100 ? 100 : successRate + cursor.getInteger("percentage");
|
successRate = successRate + cursor.getInteger("percentage") > 100 ? 100 : successRate + cursor.getInteger("percentage");
|
||||||
|
|
||||||
event.setCurrentItem(enchant.getBook().get(enchant, current.getInteger("level"), successRate, current.getInteger("destroy-rate")));
|
event.setCurrentItem(enchant.getBook().get(enchant, current.getInteger("level"), successRate, current.getInteger("destroy-rate")));
|
||||||
|
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
package com.songoda.epicenchants.objects;
|
package com.songoda.epicenchants.objects;
|
||||||
|
|
||||||
import co.aikar.commands.annotation.Optional;
|
|
||||||
import com.songoda.epicenchants.EpicEnchants;
|
import com.songoda.epicenchants.EpicEnchants;
|
||||||
import com.songoda.epicenchants.utils.objects.ItemBuilder;
|
import com.songoda.epicenchants.utils.objects.ItemBuilder;
|
||||||
import com.songoda.epicenchants.utils.single.GeneralUtils;
|
import com.songoda.epicenchants.utils.single.GeneralUtils;
|
||||||
@ -10,7 +9,9 @@ import de.tr7zw.itemnbtapi.NBTItem;
|
|||||||
import lombok.Builder;
|
import lombok.Builder;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@ -34,7 +35,7 @@ public class BookItem {
|
|||||||
current().nextInt(enchant.getGroup().getDestroyRateMin(), enchant.getGroup().getDestroyRateMax()));
|
current().nextInt(enchant.getGroup().getDestroyRateMin(), enchant.getGroup().getDestroyRateMax()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public ItemStack get(Enchant enchant, @Optional Integer level, @Optional Integer successRate, @Optional Integer destroyRate) {
|
public ItemStack get(Enchant enchant, @Nullable Integer level, @Nullable Integer successRate, @Nullable Integer destroyRate) {
|
||||||
successRate = successRate == null ? current().nextInt(101) : successRate;
|
successRate = successRate == null ? current().nextInt(101) : successRate;
|
||||||
destroyRate = destroyRate == null ? current().nextInt(101) : destroyRate;
|
destroyRate = destroyRate == null ? current().nextInt(101) : destroyRate;
|
||||||
level = level == null ? current().nextInt(1, enchant.getMaxLevel() + 1) : level;
|
level = level == null ? current().nextInt(1, enchant.getMaxLevel() + 1) : level;
|
||||||
@ -42,14 +43,14 @@ public class BookItem {
|
|||||||
int finalSuccessRate = successRate;
|
int finalSuccessRate = successRate;
|
||||||
int finalDestroyRate = destroyRate;
|
int finalDestroyRate = destroyRate;
|
||||||
|
|
||||||
List<String> toSet = lore;
|
List<String> toSet = new ArrayList<>(lore);
|
||||||
|
|
||||||
for (int i = lore.size() - 1; i >= 0; i--) {
|
for (int i = toSet.size() - 1; i >= 0; i--) {
|
||||||
String string = toSet.get(i);
|
String string = toSet.get(i);
|
||||||
|
|
||||||
if (string.contains("{description}")) {
|
if (string.contains("{description}")) {
|
||||||
lore.remove(i);
|
toSet.remove(i);
|
||||||
lore.addAll(i, enchant.getDescription().stream().map(GeneralUtils::color).collect(Collectors.toList()));
|
toSet.addAll(i, enchant.getDescription().stream().map(GeneralUtils::color).collect(Collectors.toList()));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -58,7 +59,7 @@ public class BookItem {
|
|||||||
.replace("{success_rate}", "" + finalSuccessRate)
|
.replace("{success_rate}", "" + finalSuccessRate)
|
||||||
.replace("{destroy_rate}", "" + finalDestroyRate);
|
.replace("{destroy_rate}", "" + finalDestroyRate);
|
||||||
|
|
||||||
lore.set(i, string);
|
toSet.set(i, string);
|
||||||
}
|
}
|
||||||
|
|
||||||
ItemBuilder itemBuilder = new ItemBuilder(material)
|
ItemBuilder itemBuilder = new ItemBuilder(material)
|
||||||
|
@ -24,7 +24,7 @@ public class ConfigParser {
|
|||||||
.identifier(config.getString("identifier"))
|
.identifier(config.getString("identifier"))
|
||||||
.group(instance.getGroupManager().getValue(config.getString("group").toUpperCase()).orElseThrow(() -> new IllegalArgumentException("Invalid group: " + config.getString("group"))))
|
.group(instance.getGroupManager().getValue(config.getString("group").toUpperCase()).orElseThrow(() -> new IllegalArgumentException("Invalid group: " + config.getString("group"))))
|
||||||
.maxLevel(config.getInt("max-level"))
|
.maxLevel(config.getInt("max-level"))
|
||||||
.format(config.isSet("appliead-format") ? color(config.getString("applied-format")) : "")
|
.format(config.isSet("applied-format") ? color(config.getString("applied-format")) : "")
|
||||||
.bookItem(parseBookItem(instance, config.getConfigurationSection("book-item")))
|
.bookItem(parseBookItem(instance, config.getConfigurationSection("book-item")))
|
||||||
.itemWhitelist((config.isList("item-whitelist") ? config.getStringList("item-whitelist").stream().map(instance.getItemGroup()::get).flatMap(Collection::stream).collect(Collectors.toSet()) : Collections.emptySet()))
|
.itemWhitelist((config.isList("item-whitelist") ? config.getStringList("item-whitelist").stream().map(instance.getItemGroup()::get).flatMap(Collection::stream).collect(Collectors.toSet()) : Collections.emptySet()))
|
||||||
.conflict(config.isList("conflicting-enchants") ? new HashSet<>(config.getStringList("conflicting-enchants")) : Collections.emptySet())
|
.conflict(config.isList("conflicting-enchants") ? new HashSet<>(config.getStringList("conflicting-enchants")) : Collections.emptySet())
|
||||||
|
Loading…
Reference in New Issue
Block a user