From a3878a7adb5c76e3f8cab0ca4c7b9d943f14006f Mon Sep 17 00:00:00 2001 From: TheCreeperCow Date: Mon, 7 Jan 2019 15:12:15 +0100 Subject: [PATCH] Added explosion listener and melon and pumpkin seed warning --- .../epicfarming/listeners/BlockListeners.java | 41 ++++++++++++++++--- .../src/main/resources/en_US.lang | 3 +- 2 files changed, 38 insertions(+), 6 deletions(-) diff --git a/EpicFarming-Plugin/src/main/java/com/songoda/epicfarming/listeners/BlockListeners.java b/EpicFarming-Plugin/src/main/java/com/songoda/epicfarming/listeners/BlockListeners.java index bc70f2c..1890637 100644 --- a/EpicFarming-Plugin/src/main/java/com/songoda/epicfarming/listeners/BlockListeners.java +++ b/EpicFarming-Plugin/src/main/java/com/songoda/epicfarming/listeners/BlockListeners.java @@ -18,10 +18,7 @@ import org.bukkit.entity.Player; import org.bukkit.event.EventHandler; import org.bukkit.event.EventPriority; import org.bukkit.event.Listener; -import org.bukkit.event.block.BlockBreakEvent; -import org.bukkit.event.block.BlockFadeEvent; -import org.bukkit.event.block.BlockGrowEvent; -import org.bukkit.event.block.BlockPlaceEvent; +import org.bukkit.event.block.*; import org.bukkit.event.entity.ItemSpawnEvent; import org.bukkit.event.entity.SheepRegrowWoolEvent; import org.bukkit.inventory.ItemStack; @@ -32,6 +29,7 @@ import java.util.Collection; /** * Created by songoda on 3/14/2017. */ +@SuppressWarnings("Duplicates") public class BlockListeners implements Listener { private EpicFarmingPlugin instance; @@ -102,7 +100,11 @@ public class BlockListeners implements Listener { } Location location = e.getBlock().getLocation(); - + if (e.getBlockPlaced().getType().equals(Material.MELON_SEEDS)||e.getBlockPlaced().getType().equals(Material.PUMPKIN_SEEDS)){ + if (checkForFarm(location)){ + e.getPlayer().sendMessage(instance.getLocale().getMessage("event.warning.noauto")); + } + } Bukkit.getScheduler().runTaskLater(instance, () -> { int level = 1; if (instance.getLevelFromItem(e.getItemInHand()) != 0) { @@ -209,4 +211,33 @@ public class BlockListeners implements Listener { } } } + + @EventHandler(ignoreCancelled = true) + public void onBlockExplode(BlockExplodeEvent event) { + try { + if (event.getBlock().getType() != Material.valueOf(instance.getConfig().getString("Main.Farm Block Material"))) + return; + + Farm farm = instance.getFarmManager().removeFarm(event.getBlock().getLocation()); + + if (farm == null) return; + instance.getFarmTask().getCrops(farm, false); + + event.setCancelled(true); + + ItemStack item = instance.makeFarmItem(farm.getLevel()); + + Block block = event.getBlock(); + + block.setType(Material.AIR); + block.getLocation().getWorld().dropItemNaturally(block.getLocation().add(.5, .5, .5), item); + + for (ItemStack itemStack : ((EFarm) farm).dumpInventory()) { + if (itemStack == null) continue; + farm.getLocation().getWorld().dropItemNaturally(farm.getLocation().add(.5, .5, .5), itemStack); + } + } catch (Exception ex) { + Debugger.runReport(ex); + } + } } \ No newline at end of file diff --git a/EpicFarming-Plugin/src/main/resources/en_US.lang b/EpicFarming-Plugin/src/main/resources/en_US.lang index b4749ab..035f8cd 100644 --- a/EpicFarming-Plugin/src/main/resources/en_US.lang +++ b/EpicFarming-Plugin/src/main/resources/en_US.lang @@ -30,4 +30,5 @@ event.upgrade.cannotafford = "&cYou cannot afford this upgrade." event.upgrade.success = "&7You successfully upgraded this farm to &6level %level%&7!" event.upgrade.maxed = "&6This farm is maxed out." event.upgrade.successmaxed = "&7You maxed out this farm at &6%level%x&7." -event.limit.hit = "&7You can only have &6%limit% &7farms at a single time." \ No newline at end of file +event.limit.hit = "&7You can only have &6%limit% &7farms at a single time." +event.warning.noauto = "&6Warning: &cThis item does not get farmed automatically" \ No newline at end of file