Brewery/src/com/dre/brewery/listeners/InventoryListener.java

113 lines
3.1 KiB
Java
Raw Normal View History

2013-05-09 21:47:58 +02:00
package com.dre.brewery.listeners;
import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener;
import org.bukkit.event.inventory.BrewEvent;
import org.bukkit.event.inventory.InventoryClickEvent;
2014-04-09 00:35:08 +02:00
import org.bukkit.event.inventory.InventoryCloseEvent;
import org.bukkit.event.inventory.InventoryPickupItemEvent;
import org.bukkit.event.inventory.InventoryType;
2013-05-09 21:47:58 +02:00
import org.bukkit.inventory.BrewerInventory;
import org.bukkit.inventory.meta.PotionMeta;
2013-05-09 21:47:58 +02:00
import org.bukkit.inventory.ItemStack;
import org.bukkit.Material;
2015-01-10 00:15:13 +01:00
import com.dre.brewery.Barrel;
2013-05-09 21:47:58 +02:00
import com.dre.brewery.Brew;
import com.dre.brewery.P;
2014-04-09 00:35:08 +02:00
import com.dre.brewery.integration.LogBlockBarrel;
2013-05-09 21:47:58 +02:00
public class InventoryListener implements Listener {
@EventHandler(priority = EventPriority.HIGH, ignoreCancelled = false)
2013-05-09 21:47:58 +02:00
public void onBrew(BrewEvent event) {
if (event.isCancelled()) {
P.p.log("Got Cancelled Brew Event");
} else {
P.p.log("Got Brew Event");
}
2013-05-09 21:47:58 +02:00
int slot = 0;
BrewerInventory inv = event.getContents();
ItemStack item;
boolean custom = false;
2013-07-03 18:06:13 +02:00
Boolean[] contents = new Boolean[3];
2013-05-09 21:47:58 +02:00
while (slot < 3) {
item = inv.getItem(slot);
2013-07-03 18:06:13 +02:00
contents[slot] = false;
2013-05-09 21:47:58 +02:00
if (item != null) {
if (item.getType() == Material.POTION) {
if (item.hasItemMeta()) {
2013-07-03 18:06:13 +02:00
int uid = Brew.getUID(item);
if (Brew.potions.containsKey(uid)) {
2013-05-09 21:47:58 +02:00
// has custom potion in "slot"
2013-07-03 18:06:13 +02:00
if (Brew.get(uid).canDistill()) {
// is further distillable
contents[slot] = true;
custom = true;
}
2013-05-09 21:47:58 +02:00
}
}
}
}
slot++;
}
if (custom) {
event.setCancelled(true);
Brew.distillAll(inv, contents);
}
}
// convert to non colored Lore when taking out of Barrel/Brewer
2014-04-09 00:35:08 +02:00
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
public void onInventoryClick(InventoryClickEvent event) {
if (event.getInventory().getType() == InventoryType.BREWING) {
if (event.getSlot() > 2) {
return;
}
2015-01-10 00:15:13 +01:00
} else if (!(event.getInventory().getHolder() instanceof Barrel)) {
2013-08-30 21:19:49 +02:00
return;
}
ItemStack item = event.getCurrentItem();
if (item != null) {
2014-05-19 15:17:55 +02:00
if (item.getType() == Material.POTION) {
if (item.hasItemMeta()) {
PotionMeta meta = (PotionMeta) item.getItemMeta();
Brew brew = Brew.get(meta);
if (brew != null) {
2013-08-30 21:19:49 +02:00
if (Brew.hasColorLore(meta)) {
brew.convertLore(meta, false);
item.setItemMeta(meta);
}
}
}
}
}
}
// block the pickup of items where getPickupDelay is > 1000 (puke)
2014-02-16 17:11:02 +01:00
@EventHandler(ignoreCancelled = true)
public void onInventoryPickupItem(InventoryPickupItemEvent event){
if (event.getItem().getPickupDelay() > 1000) {
event.setCancelled(true);
}
}
2014-04-09 00:35:08 +02:00
@EventHandler
public void onInventoryClose(InventoryCloseEvent event) {
if (P.p.useLB) {
2015-01-10 00:15:13 +01:00
if (event.getInventory().getHolder() instanceof Barrel) {
try {
LogBlockBarrel.closeBarrel(event.getPlayer(), event.getInventory());
} catch (Exception e) {
P.p.errorLog("Failed to Log Barrel to LogBlock!");
P.p.errorLog("Brewery was tested with version 1.80 of LogBlock!");
e.printStackTrace();
2014-04-09 00:35:08 +02:00
}
}
}
}
2013-05-09 21:47:58 +02:00
}