Add workbench command

This commit is contained in:
gomeow
2013-04-08 11:25:26 -07:00
parent a0b2cd209a
commit c2bde3a272
3 changed files with 25 additions and 9 deletions
@@ -56,6 +56,7 @@ public class Main extends JavaPlugin {
commands = new Commands(); commands = new Commands();
getCommand("pv").setExecutor(commands); getCommand("pv").setExecutor(commands);
getCommand("pvdel").setExecutor(commands); getCommand("pvdel").setExecutor(commands);
getCommand("workbench").setExecutor(commands);
setupEconomy(); setupEconomy();
if(getConfig().getBoolean("drop-on-death.enabled")) { if(getConfig().getBoolean("drop-on-death.enabled")) {
@@ -2,15 +2,17 @@ package com.drtshock.playervaults.commands;
import java.util.HashMap; import java.util.HashMap;
import org.bukkit.Bukkit;
import org.bukkit.ChatColor; import org.bukkit.ChatColor;
import org.bukkit.command.Command; import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.event.inventory.InventoryType;
import org.bukkit.inventory.Inventory;
import com.drtshock.playervaults.util.Lang; import com.drtshock.playervaults.util.Lang;
public class Commands implements CommandExecutor { public class Commands implements CommandExecutor {
public static HashMap<String, VaultViewInfo> inVault = new HashMap<String, VaultViewInfo>(); public static HashMap<String, VaultViewInfo> inVault = new HashMap<String, VaultViewInfo>();
@@ -34,17 +36,16 @@ public class Commands implements CommandExecutor {
} }
} }
else sender.sendMessage(Lang.TITLE.toString() + ChatColor.RED + Lang.PLAYER_ONLY); else sender.sendMessage(Lang.TITLE.toString() + ChatColor.RED + Lang.PLAYER_ONLY);
} } else if(cmd.getName().equalsIgnoreCase("pvdel")) {
else if(cmd.getName().equalsIgnoreCase("pvdel")) {
switch (args.length) { switch (args.length) {
case 1: case 1:
if(sender instanceof Player) { if(sender instanceof Player) {
Player p = (Player) sender; Player p = (Player) sender;
VaultOperations.deleteOwnVault(p, args[0]); VaultOperations.deleteOwnVault(p, args[0]);
} }
else else {
sender.sendMessage(Lang.TITLE.toString() + ChatColor.RED + Lang.PLAYER_ONLY); sender.sendMessage(Lang.TITLE.toString() + ChatColor.RED + Lang.PLAYER_ONLY);
}
break; break;
case 2: case 2:
VaultOperations.deleteOtherVault(sender, args[0], args[1]); VaultOperations.deleteOtherVault(sender, args[0], args[1]);
@@ -52,6 +53,18 @@ public class Commands implements CommandExecutor {
default: default:
Feedback.showHelp(sender, Feedback.Type.DELETE); Feedback.showHelp(sender, Feedback.Type.DELETE);
} }
} else if(cmd.getName().equalsIgnoreCase("workbench")) {
if(sender.hasPermission("playervaults.workbench")) {
if(sender instanceof Player) {
Inventory workbench = Bukkit.createInventory(null, InventoryType.WORKBENCH);
((Player)sender).openInventory(workbench);
sender.sendMessage(Lang.TITLE.toString() + Lang.OPEN_WORKBENCH);
} else {
sender.sendMessage(Lang.TITLE.toString() + Lang.PLAYER_ONLY);
}
} else {
sender.sendMessage(Lang.TITLE.toString() + Lang.NO_PERMS);
}
} }
return true; return true;
} }
+2
View File
@@ -11,3 +11,5 @@ commands:
pvdel: pvdel:
description: Delete a vault. description: Delete a vault.
aliases: [vaultdel] aliases: [vaultdel]
workbench:
description: Opens a workbench.