mirror of
https://github.com/songoda/EpicEnchants.git
synced 2025-01-05 16:08:35 +01:00
Ye
This commit is contained in:
parent
eac363e23f
commit
12114a55f2
@ -3,10 +3,8 @@ package com.songoda.epicenchants;
|
|||||||
import co.aikar.commands.BukkitCommandManager;
|
import co.aikar.commands.BukkitCommandManager;
|
||||||
import co.aikar.commands.InvalidCommandArgument;
|
import co.aikar.commands.InvalidCommandArgument;
|
||||||
import com.songoda.epicenchants.commands.EnchantCommand;
|
import com.songoda.epicenchants.commands.EnchantCommand;
|
||||||
import com.songoda.epicenchants.listeners.ArmorListener;
|
import com.songoda.epicenchants.enums.GiveType;
|
||||||
import com.songoda.epicenchants.listeners.BookListener;
|
import com.songoda.epicenchants.listeners.*;
|
||||||
import com.songoda.epicenchants.listeners.EntityListener;
|
|
||||||
import com.songoda.epicenchants.listeners.PlayerListener;
|
|
||||||
import com.songoda.epicenchants.managers.EnchantManager;
|
import com.songoda.epicenchants.managers.EnchantManager;
|
||||||
import com.songoda.epicenchants.managers.FileManager;
|
import com.songoda.epicenchants.managers.FileManager;
|
||||||
import com.songoda.epicenchants.managers.GroupManager;
|
import com.songoda.epicenchants.managers.GroupManager;
|
||||||
@ -14,6 +12,7 @@ import com.songoda.epicenchants.managers.InfoManager;
|
|||||||
import com.songoda.epicenchants.objects.Enchant;
|
import com.songoda.epicenchants.objects.Enchant;
|
||||||
import com.songoda.epicenchants.utils.EnchantUtils;
|
import com.songoda.epicenchants.utils.EnchantUtils;
|
||||||
import com.songoda.epicenchants.utils.FastInv;
|
import com.songoda.epicenchants.utils.FastInv;
|
||||||
|
import com.songoda.epicenchants.utils.SpecialItems;
|
||||||
import com.songoda.epicenchants.utils.VersionDependent;
|
import com.songoda.epicenchants.utils.VersionDependent;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import net.milkbowl.vault.economy.Economy;
|
import net.milkbowl.vault.economy.Economy;
|
||||||
@ -22,6 +21,7 @@ import org.bukkit.event.Listener;
|
|||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
@ -39,6 +39,7 @@ public class EpicEnchants extends JavaPlugin {
|
|||||||
private GroupManager groupManager;
|
private GroupManager groupManager;
|
||||||
private EnchantUtils enchantUtils;
|
private EnchantUtils enchantUtils;
|
||||||
private FileManager fileManager;
|
private FileManager fileManager;
|
||||||
|
private SpecialItems specialItems;
|
||||||
private Locale locale;
|
private Locale locale;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -56,6 +57,7 @@ public class EpicEnchants extends JavaPlugin {
|
|||||||
this.enchantManager = new EnchantManager(this);
|
this.enchantManager = new EnchantManager(this);
|
||||||
this.enchantUtils = new EnchantUtils(this);
|
this.enchantUtils = new EnchantUtils(this);
|
||||||
this.infoManager = new InfoManager(this);
|
this.infoManager = new InfoManager(this);
|
||||||
|
this.specialItems = new SpecialItems(this);
|
||||||
this.economy = getServer().getServicesManager().getRegistration(Economy.class).getProvider();
|
this.economy = getServer().getServicesManager().getRegistration(Economy.class).getProvider();
|
||||||
|
|
||||||
fileManager.createFiles();
|
fileManager.createFiles();
|
||||||
@ -89,10 +91,16 @@ public class EpicEnchants extends JavaPlugin {
|
|||||||
|
|
||||||
commandManager.getCommandCompletions().registerCompletion("enchants", c -> enchantManager.getEnchants().stream().map(Enchant::getIdentifier).collect(Collectors.toList()));
|
commandManager.getCommandCompletions().registerCompletion("enchants", c -> enchantManager.getEnchants().stream().map(Enchant::getIdentifier).collect(Collectors.toList()));
|
||||||
commandManager.getCommandCompletions().registerCompletion("enchantFiles", c -> fileManager.getYmlFiles("enchants").orElse(Collections.emptyList()).stream().map(File::getName).collect(Collectors.toList()));
|
commandManager.getCommandCompletions().registerCompletion("enchantFiles", c -> fileManager.getYmlFiles("enchants").orElse(Collections.emptyList()).stream().map(File::getName).collect(Collectors.toList()));
|
||||||
|
commandManager.getCommandCompletions().registerCompletion("giveType", c -> Arrays.stream(GiveType.values()).map(s -> s.toString().replace("_", "").toLowerCase()).collect(Collectors.toList()));
|
||||||
|
|
||||||
commandManager.getCommandContexts().registerContext(Enchant.class, c -> enchantManager.getEnchant(c.popFirstArg()).orElseThrow(() -> new InvalidCommandArgument("No enchant exists by that name")));
|
commandManager.getCommandContexts().registerContext(Enchant.class, c -> enchantManager.getEnchant(c.popFirstArg()).orElseThrow(() -> new InvalidCommandArgument("No enchant exists by that name")));
|
||||||
commandManager.getCommandContexts().registerContext(File.class, c -> enchantManager.getEnchantFile(c.popFirstArg()).orElseThrow(() -> new InvalidCommandArgument("No EnchantFile exists by that name")));
|
commandManager.getCommandContexts().registerContext(File.class, c -> enchantManager.getEnchantFile(c.popFirstArg()).orElseThrow(() -> new InvalidCommandArgument("No EnchantFile exists by that name")));
|
||||||
|
|
||||||
|
commandManager.getCommandContexts().registerContext(GiveType.class, c -> Arrays.stream(GiveType.values())
|
||||||
|
.filter(s -> s.toString().toLowerCase().replace("_", "").equalsIgnoreCase(c.popFirstArg()))
|
||||||
|
.findFirst()
|
||||||
|
.orElseThrow(() -> new InvalidCommandArgument("No item by that type.")));
|
||||||
|
|
||||||
commandManager.registerCommand(new EnchantCommand());
|
commandManager.registerCommand(new EnchantCommand());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -103,6 +111,7 @@ public class EpicEnchants extends JavaPlugin {
|
|||||||
add(new ArmorListener());
|
add(new ArmorListener());
|
||||||
add(new PlayerListener(instance));
|
add(new PlayerListener(instance));
|
||||||
add(new EntityListener(instance));
|
add(new EntityListener(instance));
|
||||||
|
add(new WhiteScrollListener(instance));
|
||||||
}}.forEach(listener -> Bukkit.getPluginManager().registerEvents(listener, this));
|
}}.forEach(listener -> Bukkit.getPluginManager().registerEvents(listener, this));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,17 +31,43 @@ public class EnchantCommand extends BaseCommand {
|
|||||||
new EnchanterMenu(instance, instance.getFileManager().getConfiguration("menus/enchanter-menu"), player).open(player);
|
new EnchanterMenu(instance, instance.getFileManager().getConfiguration("menus/enchanter-menu"), player).open(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
//ee give {player} {enchant} {group}
|
//ee give book {player} {enchant} {group}
|
||||||
@Subcommand("give")
|
@Subcommand("give book")
|
||||||
@CommandCompletion("@players @enchants @nothing @nothing @nothing")
|
@CommandCompletion("@giveType @players @enchants @nothing @nothing @nothing")
|
||||||
@Description("Give enchant books to players")
|
@Description("Give enchant books to players")
|
||||||
@CommandPermission("epicenchants.give")
|
@CommandPermission("epicenchants.give")
|
||||||
public void onGiveBook(CommandSender sender, @Flags("other") Player target, Enchant enchant, @Optional Integer level, @Optional Integer successRate, @Optional Integer destroyRate) {
|
public void onGive(CommandSender sender, @Flags("other") Player target, Enchant enchant, @Optional Integer level, @Optional Integer successRate, @Optional Integer destroyRate) {
|
||||||
target.getInventory().addItem(enchant.getBookItem().get(enchant, level, successRate, destroyRate));
|
target.getInventory().addItem(enchant.getBookItem().get(enchant, level, successRate, destroyRate));
|
||||||
target.sendMessage(instance.getLocale().getMessageWithPrefix("command.book.received", of("enchant", enchant.getIdentifier())));
|
target.sendMessage(instance.getLocale().getMessageWithPrefix("command.book.received", of("enchant", enchant.getIdentifier())));
|
||||||
sender.sendMessage(instance.getLocale().getMessageWithPrefix("command.book.gave", of("player", target.getName()), of("enchant", enchant.getIdentifier())));
|
sender.sendMessage(instance.getLocale().getMessageWithPrefix("command.book.gave", of("player", target.getName()), of("enchant", enchant.getIdentifier())));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//ee give item {player} {giveType} {group}
|
||||||
|
@Subcommand("give item")
|
||||||
|
@CommandCompletion("@giveType @players @enchants @nothing @nothing @nothing")
|
||||||
|
@Description("Give enchant books to players")
|
||||||
|
@CommandPermission("epicenchants.give")
|
||||||
|
public void onGive(CommandSender sender, @Flags("other") Player target, String giveType, @Optional Integer amount, @Optional Integer successRate) {
|
||||||
|
String messageKey;
|
||||||
|
|
||||||
|
switch (giveType.toLowerCase()) {
|
||||||
|
case "whitescroll":
|
||||||
|
target.getInventory().addItem(instance.getSpecialItems().getWhiteScroll(amount));
|
||||||
|
messageKey = "whitescroll";
|
||||||
|
break;
|
||||||
|
case "blackscroll":
|
||||||
|
messageKey = "blackscroll";
|
||||||
|
target.getInventory().addItem(instance.getSpecialItems().getBlackScroll(amount, successRate));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
target.sendMessage(instance.getLocale().getMessageWithPrefix("command." + messageKey + ".received"));
|
||||||
|
sender.sendMessage(instance.getLocale().getMessageWithPrefix("command." + messageKey + ".gave", of("player", target.getName())));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//ee apply {enchant} {group}
|
//ee apply {enchant} {group}
|
||||||
@Subcommand("apply")
|
@Subcommand("apply")
|
||||||
@CommandCompletion("@enchants @nothing")
|
@CommandCompletion("@enchants @nothing")
|
||||||
|
@ -0,0 +1,5 @@
|
|||||||
|
package com.songoda.epicenchants.enums;
|
||||||
|
|
||||||
|
public enum GiveType {
|
||||||
|
WHITE_SCROLL, BLACK_SCROLL
|
||||||
|
}
|
@ -0,0 +1,40 @@
|
|||||||
|
package com.songoda.epicenchants.listeners;
|
||||||
|
|
||||||
|
import com.songoda.epicenchants.EpicEnchants;
|
||||||
|
import de.tr7zw.itemnbtapi.NBTItem;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.EventPriority;
|
||||||
|
import org.bukkit.event.inventory.InventoryAction;
|
||||||
|
import org.bukkit.event.inventory.InventoryClickEvent;
|
||||||
|
import org.bukkit.event.inventory.InventoryType;
|
||||||
|
|
||||||
|
public class BlackScrollListener {
|
||||||
|
private final EpicEnchants instance;
|
||||||
|
|
||||||
|
public BlackScrollListener(EpicEnchants instance) {
|
||||||
|
this.instance = instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGHEST)
|
||||||
|
public void onInventoryClick(InventoryClickEvent event) {
|
||||||
|
if (event.getCursor() == null || event.getCurrentItem() == null || event.getAction() != InventoryAction.SWAP_WITH_CURSOR || event.getClickedInventory().getType() == InventoryType.CREATIVE) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
NBTItem nbtItem = new NBTItem(event.getCursor());
|
||||||
|
NBTItem toApplyTo = new NBTItem(event.getCurrentItem());
|
||||||
|
|
||||||
|
if (!nbtItem.getBoolean("black-scroll")) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (toApplyTo.getCompound("enchants") == null || toApplyTo.getCompound("enchants").getKeys().isEmpty()) {
|
||||||
|
event.getWhoClicked().sendMessage(instance.getLocale().getMessageWithPrefix("blackscroll.noenchants"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//TODO: Blackscroll
|
||||||
|
|
||||||
|
event.getWhoClicked().sendMessage(instance.getLocale().getMessageWithPrefix("blackscroll.success"));
|
||||||
|
}
|
||||||
|
}
|
@ -65,7 +65,6 @@ public class BookListener implements Listener {
|
|||||||
|
|
||||||
if (result.getRight() == BROKEN_FAILURE) {
|
if (result.getRight() == BROKEN_FAILURE) {
|
||||||
event.getClickedInventory().clear(event.getSlot());
|
event.getClickedInventory().clear(event.getSlot());
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result.getRight() != CONFLICT && result.getRight() != MAXED_OUT) {
|
if (result.getRight() != CONFLICT && result.getRight() != MAXED_OUT) {
|
||||||
@ -81,5 +80,4 @@ public class BookListener implements Listener {
|
|||||||
event.getClickedInventory().setItem(event.getSlot(), result.getLeft());
|
event.getClickedInventory().setItem(event.getSlot(), result.getLeft());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,45 @@
|
|||||||
|
package com.songoda.epicenchants.listeners;
|
||||||
|
|
||||||
|
import com.songoda.epicenchants.EpicEnchants;
|
||||||
|
import de.tr7zw.itemnbtapi.NBTItem;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.EventPriority;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.inventory.InventoryAction;
|
||||||
|
import org.bukkit.event.inventory.InventoryClickEvent;
|
||||||
|
import org.bukkit.event.inventory.InventoryType;
|
||||||
|
|
||||||
|
public class WhiteScrollListener implements Listener {
|
||||||
|
private final EpicEnchants instance;
|
||||||
|
|
||||||
|
public WhiteScrollListener(EpicEnchants instance) {
|
||||||
|
this.instance = instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGHEST)
|
||||||
|
public void onInventoryClick(InventoryClickEvent event) {
|
||||||
|
if (event.getCursor() == null || event.getCurrentItem() == null || event.getAction() != InventoryAction.SWAP_WITH_CURSOR || event.getClickedInventory().getType() == InventoryType.CREATIVE) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
NBTItem nbtItem = new NBTItem(event.getCursor());
|
||||||
|
NBTItem toApplyTo = new NBTItem(event.getCurrentItem());
|
||||||
|
|
||||||
|
if (!nbtItem.getBoolean("white-scroll")) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (toApplyTo.hasKey("protected")) {
|
||||||
|
event.getWhoClicked().sendMessage(instance.getLocale().getMessageWithPrefix("whitescroll.alreadyapplied"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
toApplyTo.setBoolean("protected", true);
|
||||||
|
event.getWhoClicked().sendMessage(instance.getLocale().getMessageWithPrefix("whitescroll.applied"));
|
||||||
|
|
||||||
|
//TODO: add lore
|
||||||
|
|
||||||
|
event.getWhoClicked().setItemOnCursor(null);
|
||||||
|
event.getClickedInventory().setItem(event.getSlot(), toApplyTo.getItem());
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,45 @@
|
|||||||
|
package com.songoda.epicenchants.utils;
|
||||||
|
|
||||||
|
import com.songoda.epicenchants.EpicEnchants;
|
||||||
|
import de.tr7zw.itemnbtapi.NBTItem;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
|
import java.util.concurrent.ThreadLocalRandom;
|
||||||
|
|
||||||
|
import static com.songoda.epicenchants.objects.Placeholder.of;
|
||||||
|
|
||||||
|
public class SpecialItems {
|
||||||
|
private final EpicEnchants instance;
|
||||||
|
|
||||||
|
public SpecialItems(EpicEnchants instance) {
|
||||||
|
this.instance = instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ItemStack getWhiteScroll(Integer amount) {
|
||||||
|
NBTItem nbtItem = new ItemBuilder(instance.getFileManager().getConfiguration("special-items").getConfigurationSection("white-scroll")).nbt();
|
||||||
|
nbtItem.setBoolean("white-scroll", true);
|
||||||
|
ItemStack itemStack = nbtItem.getItem();
|
||||||
|
|
||||||
|
if (amount != null) {
|
||||||
|
itemStack.setAmount(amount);
|
||||||
|
}
|
||||||
|
|
||||||
|
return itemStack;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ItemStack getBlackScroll(Integer amount, Integer chance) {
|
||||||
|
int percentage = chance == null ? ThreadLocalRandom.current().nextInt(instance.getConfig().getInt("rates.black-scroll-min"), instance.getConfig().getInt("rates.black-scroll-max") + 1) : chance;
|
||||||
|
NBTItem nbtItem = new ItemBuilder(instance.getFileManager().getConfiguration("special-items").getConfigurationSection("black-scroll"), of("percentage", percentage)).nbt();
|
||||||
|
|
||||||
|
nbtItem.setBoolean("black-scroll", true);
|
||||||
|
nbtItem.setInteger("percentage", percentage);
|
||||||
|
|
||||||
|
ItemStack itemStack = nbtItem.getItem();
|
||||||
|
|
||||||
|
if (amount != null) {
|
||||||
|
itemStack.setAmount(amount);
|
||||||
|
}
|
||||||
|
|
||||||
|
return itemStack;
|
||||||
|
}
|
||||||
|
}
|
@ -6,6 +6,13 @@ general.nametag.prefix= "&8[&6EpicEnchants&8]"
|
|||||||
|
|
||||||
command.book.received= "&7You have been given a &6{enchant} &7book."
|
command.book.received= "&7You have been given a &6{enchant} &7book."
|
||||||
command.book.gave= "&7You gave {player} a &6{enchant} &7book."
|
command.book.gave= "&7You gave {player} a &6{enchant} &7book."
|
||||||
|
|
||||||
|
command.whitescroll;.received= "&7You have been given a whitescroll."
|
||||||
|
command.whitescroll.gave= "&7You gave {player} a whitescroll."
|
||||||
|
|
||||||
|
command.blackscroll.received= "&7You have been given a blackscroll."
|
||||||
|
command.blackscroll.gave= "&7You gave {player} a blackscroll."
|
||||||
|
|
||||||
command.reload= "&6Configuration files reload"
|
command.reload= "&6Configuration files reload"
|
||||||
command.filereload.success= "&6{file-name} has been successfully reloaded."
|
command.filereload.success= "&6{file-name} has been successfully reloaded."
|
||||||
command.filereload.failed= "&c{file-name} failed to be reloaded. &7Please check console for errors."
|
command.filereload.failed= "&c{file-name} failed to be reloaded. &7Please check console for errors."
|
||||||
@ -25,3 +32,9 @@ enchant.success= "&aYou have success fully applied &6{enchant}."
|
|||||||
enchant.conflict= "&cYou cannot apply this enchant as it conflicts with another enchant."
|
enchant.conflict= "&cYou cannot apply this enchant as it conflicts with another enchant."
|
||||||
enchant.maxedout= "&cYou already have that enchant maxed on this item."
|
enchant.maxedout= "&cYou already have that enchant maxed on this item."
|
||||||
enchant.alreadyapplied= "&cYou already have that enchant with that level applied on this item."
|
enchant.alreadyapplied= "&cYou already have that enchant with that level applied on this item."
|
||||||
|
|
||||||
|
#Item Messages
|
||||||
|
whitescroll.applied="&aThis item is now protected."
|
||||||
|
whitescroll.alreadyapplied= "&cThis item is already protected."
|
||||||
|
blackscroll.success= "&aYou have successfully extracted an enchant from this item."
|
||||||
|
blackscroll.noenchants= "&cThis item has no enchants to extract"
|
||||||
|
@ -4,4 +4,3 @@ main: com.songoda.epicenchants.EpicEnchants
|
|||||||
authors: [GB6]
|
authors: [GB6]
|
||||||
website: https://songoda.com/
|
website: https://songoda.com/
|
||||||
depend: [Vault]
|
depend: [Vault]
|
||||||
api-version: 1.13
|
|
16
core/src/main/resources/special-items.yml
Normal file
16
core/src/main/resources/special-items.yml
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
white-scroll:
|
||||||
|
material: EMPTY_MAP
|
||||||
|
display-name: "&e&lWhite Scroll"
|
||||||
|
lore:
|
||||||
|
- "&7Prevents an item from being destroyed"
|
||||||
|
- "&7due to a failed Enchantment Book."
|
||||||
|
- "&ePlace scroll on item to apply."
|
||||||
|
|
||||||
|
black-scroll:
|
||||||
|
material: INK_SAC
|
||||||
|
display-name: "&f&lBlack Scroll"
|
||||||
|
lore:
|
||||||
|
- "&7Removes a random enchantment"
|
||||||
|
- "&7from an item and converts"
|
||||||
|
- "&7it into a {percentage} success book."
|
||||||
|
- "&fPlace scroll on item to extract."
|
2
pom.xml
2
pom.xml
@ -31,7 +31,6 @@
|
|||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
|
|
||||||
<resources>
|
<resources>
|
||||||
<resource>
|
<resource>
|
||||||
<directory>src/main/resources</directory>
|
<directory>src/main/resources</directory>
|
||||||
@ -39,5 +38,4 @@
|
|||||||
</resource>
|
</resource>
|
||||||
</resources>
|
</resources>
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
</project>
|
</project>
|
Loading…
Reference in New Issue
Block a user