mirror of
https://github.com/songoda/EpicHeads.git
synced 2025-02-13 01:51:19 +01:00
Added give command.
This commit is contained in:
parent
f0e03909a8
commit
19adc5c07e
@ -32,6 +32,7 @@ public class CommandManager implements CommandExecutor {
|
||||
addCommand(new CommandReload(commandEpicHeads));
|
||||
addCommand(new CommandUrl(commandEpicHeads));
|
||||
addCommand(new CommandBase64(commandEpicHeads));
|
||||
addCommand(new CommandGive(commandEpicHeads));
|
||||
|
||||
for (AbstractCommand abstractCommand : commands) {
|
||||
if (abstractCommand.getParent() != null) continue;
|
||||
|
@ -0,0 +1,88 @@
|
||||
package com.songoda.epicheads.command.commands;
|
||||
|
||||
import com.songoda.epicheads.EpicHeads;
|
||||
import com.songoda.epicheads.command.AbstractCommand;
|
||||
import com.songoda.epicheads.head.Head;
|
||||
import com.songoda.epicheads.utils.Methods;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.inventory.ItemStack;
|
||||
import org.bukkit.inventory.meta.ItemMeta;
|
||||
import org.bukkit.inventory.meta.SkullMeta;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Optional;
|
||||
|
||||
public class CommandGive extends AbstractCommand {
|
||||
|
||||
public CommandGive(AbstractCommand parent) {
|
||||
super(parent, false, "give");
|
||||
}
|
||||
|
||||
@Override
|
||||
protected ReturnType runCommand(EpicHeads instance, CommandSender sender, String... args) {
|
||||
|
||||
if (args.length != 4) return ReturnType.SYNTAX_ERROR;
|
||||
|
||||
Player player = Bukkit.getPlayer(args[1]);
|
||||
String archive = args[2];
|
||||
int headId = Integer.parseInt(args[3]);
|
||||
|
||||
if (player == null) {
|
||||
sender.sendMessage(instance.getReferences().getPrefix() + instance.getLocale().getMessage("command.give.notonline", args[1]));
|
||||
return ReturnType.FAILURE;
|
||||
}
|
||||
|
||||
List<Head> heads;
|
||||
|
||||
if (archive.equalsIgnoreCase("global"))
|
||||
heads = instance.getHeadManager().getGlobalHeads();
|
||||
else if (archive.equalsIgnoreCase("local"))
|
||||
heads = instance.getHeadManager().getLocalHeads();
|
||||
else {
|
||||
return ReturnType.SYNTAX_ERROR;
|
||||
}
|
||||
|
||||
Optional<Head> head = heads.stream().filter(h -> h.getId() == headId).findFirst();
|
||||
|
||||
if (head.isPresent()) {
|
||||
ItemStack item = head.get().asItemStack();
|
||||
|
||||
ItemMeta meta = item.getItemMeta();
|
||||
meta.setLore(new ArrayList<>());
|
||||
item.setItemMeta(meta);
|
||||
|
||||
player.getInventory().addItem(item);
|
||||
} else {
|
||||
sender.sendMessage(instance.getReferences().getPrefix() + instance.getLocale().getMessage("command.give.notfound", head.get().getName()));
|
||||
return ReturnType.FAILURE;
|
||||
}
|
||||
|
||||
sender.sendMessage(instance.getReferences().getPrefix() + instance.getLocale().getMessage("command.give.success", player.getName(), head.get().getName()));
|
||||
player.sendMessage(instance.getReferences().getPrefix() + instance.getLocale().getMessage("command.give.receive", head.get().getName()));
|
||||
|
||||
return ReturnType.SUCCESS;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected List<String> onTab(EpicHeads instance, CommandSender sender, String... args) {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getPermissionNode() {
|
||||
return "epicheads.give";
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getSyntax() {
|
||||
return "/heads give <player> <global/local> <head_id>";
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getDescription() {
|
||||
return "Gives the specified player the specified amount of heads.";
|
||||
}
|
||||
}
|
@ -72,6 +72,10 @@ public class HeadManager {
|
||||
return Collections.unmodifiableList(localRegisteredHeads);
|
||||
}
|
||||
|
||||
public List<Head> getGlobalHeads() {
|
||||
return new ArrayList<>(registeredHeads);
|
||||
}
|
||||
|
||||
public void removeLocalHead(Head head) {
|
||||
localRegisteredHeads.remove(head);
|
||||
}
|
||||
|
@ -28,3 +28,8 @@ gui.overview.discordlore = "&8Add or request new heads|&8in our discord server."
|
||||
|
||||
event.general.nopermission = "&cYou do not have permission to use that command."
|
||||
event.buyhead.cannotafford = "&cYou cannot afford this head."
|
||||
|
||||
command.give.notonline = "&cThe player &4%name% &ccould not be found."
|
||||
command.give.notfound = "&cThe head &4%name%&c could not be found."
|
||||
command.give.success = "&7You have been given &6%player% &7a head named &6%name%&7."
|
||||
command.give.receive = "&7You have been given a head named &6%name%&7."
|
Loading…
Reference in New Issue
Block a user