summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java104
1 files changed, 101 insertions, 3 deletions
diff --git a/Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java b/Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java
index ae480f16b..494b298ba 100644
--- a/Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java
+++ b/Essentials/src/com/earth2me/essentials/EssentialsBlockListener.java
@@ -6,6 +6,7 @@ import net.minecraft.server.InventoryPlayer;
import org.bukkit.*;
import org.bukkit.block.*;
import org.bukkit.craftbukkit.block.CraftSign;
+import org.bukkit.craftbukkit.inventory.CraftInventory;
import org.bukkit.craftbukkit.inventory.CraftInventoryPlayer;
import org.bukkit.entity.Player;
import org.bukkit.event.block.*;
@@ -81,10 +82,18 @@ public class EssentialsBlockListener extends BlockListener
}
if (event.getLine(0).equalsIgnoreCase("[Heal]"))
{
- if (user.isAuthorized("essentials.signs.heal.create"))
+ event.setLine(0, "§4[Heal]");
+ if (user.isAuthorized("essentials.signs.heal.create")) {
+ if (!event.getLine(1).isEmpty()) {
+ String[] l1 = event.getLine(1).split("[ :-]+");
+ boolean m1 = l1[0].matches("\\$[0-9]+");
+ int q1 = Integer.parseInt(m1 ? l1[0].substring(1) : l1[0]);
+ if (q1 < 1) throw new Exception("Quantities must be greater than 0.");
+ if (!m1) ItemDb.get(l1[1]);
+ event.setLine(1, (m1 ? "$" + q1 : q1 + " " + l1[1]));
+ }
event.setLine(0, "§1[Heal]");
- else
- event.setLine(0, "§4[Heal]");
+ }
return;
}
if (event.getLine(0).equalsIgnoreCase("[Free]"))
@@ -104,6 +113,95 @@ public class EssentialsBlockListener extends BlockListener
event.setLine(0, "§4[Mail]");
return;
}
+ if (event.getLine(0).equalsIgnoreCase("[Balance]"))
+ {
+ if (user.isAuthorized("essentials.signs.balance.create"))
+
+ event.setLine(0, "§1[Balance]");
+ else
+ event.setLine(0, "§4[Balance]");
+ return;
+ }
+ }
+ catch (Throwable ex)
+ {
+ user.sendMessage("§cError: " + ex.getMessage());
+ }
+ }
+
+ @Override
+ public void onBlockRightClick(BlockRightClickEvent event)
+ {
+ User user = User.get(event.getPlayer());
+ if (user.isJailed()) return;
+ if (Essentials.getSettings().areSignsDisabled()) return;
+ if (event.getBlock().getType() != Material.WALL_SIGN && event.getBlock().getType() != Material.SIGN_POST)
+ return;
+ Sign sign = new CraftSign(event.getBlock());
+
+ try
+ {
+ if (sign.getLine(0).equals("§1[Free]") && user.isAuthorized("essentials.signs.free.use"))
+ {
+ ItemStack item = ItemDb.get(sign.getLine(1));
+ CraftInventoryPlayer inv = new CraftInventoryPlayer(new InventoryPlayer(user.getHandle()));
+ inv.clear();
+ item.setAmount(9 * 4 * 64);
+ inv.addItem(item);
+ user.showInventory(inv);
+ return;
+ }
+ if (sign.getLine(0).equals("§1[Disposal]") && user.isAuthorized("essentials.signs.disposal.use"))
+ {
+ CraftInventoryPlayer inv = new CraftInventoryPlayer(new InventoryPlayer(user.getHandle()));
+ inv.clear();
+ user.showInventory(inv);
+ return;
+ }
+ if (sign.getLine(0).equals("§1[Heal]") && user.isAuthorized("essentials.signs.heal.use"))
+ {
+ if (!sign.getLine(1).isEmpty()) {
+ String[] l1 = sign.getLine(1).split("[ :-]+");
+ boolean m1 = l1[0].matches("\\$[0-9]+");
+ int q1 = Integer.parseInt(m1 ? l1[0].substring(1) : l1[0]);
+ if (q1 < 1) throw new Exception("Quantities must be greater than 0.");
+ if (m1)
+ {
+ if (user.getMoney() < q1) throw
+ new Exception("You do not have sufficient funds.");
+ user.takeMoney(q1);
+ user.sendMessage("$" + q1 + " taken from your bank account.");
+ }
+ else
+ {
+ ItemStack i = ItemDb.get(l1[1], q1);
+ if (!InventoryWorkaround.containsItem((CraftInventory)user.getInventory(), true, i))
+ throw new Exception("You do not have " + q1 + "x " + l1[1] + ".");
+ InventoryWorkaround.removeItem((CraftInventory)user.getInventory(), true, i);
+ user.updateInventory();
+ }
+ }
+ user.setHealth(20);
+ user.sendMessage("§7You have been healed.");
+ return;
+ }
+ if (sign.getLine(0).equals("§1[Mail]") && user.isAuthorized("essentials.signs.mail.use") && user.isAuthorized("essentials.mail"))
+ {
+ List<String> mail = Essentials.readMail(user);
+ if (mail.isEmpty())
+ {
+ user.sendMessage("§cYou do not have any mail!");
+ return;
+ }
+ for (String s : mail) user.sendMessage(s);
+ user.sendMessage("§cTo mark your mail as read, type §c/mail clear");
+ return;
+ }
+ if (sign.getLine(0).equals("§1[Balance]") && user.isAuthorized("essentials.signs.balance.use"))
+ {
+ user.sendMessage("§7Balance: $" + user.getMoney());
+ return;
+ }
}
catch (Throwable ex)
{