diff --git a/src/main/java/net/brennholz/challenges/BlockCreateListener.java b/src/main/java/net/brennholz/challenges/BlockCreateListener.java new file mode 100644 index 0000000..2e56440 --- /dev/null +++ b/src/main/java/net/brennholz/challenges/BlockCreateListener.java @@ -0,0 +1,27 @@ +package net.brennholz.challenges; + + + +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.block.BlockPlaceEvent; +import org.bukkit.event.player.PlayerBucketEmptyEvent; + +public class BlockCreateListener implements Listener { + + private Challenges chl = Challenges.getplugin(); + + @EventHandler + public void onBlockPlace(BlockPlaceEvent e) { + if (this.chl.getConfig().getBoolean("timer.enabled") == false) { + e.setCancelled(true); + } + } + + @EventHandler + public void onBucketPlace(PlayerBucketEmptyEvent e) { + if (this.chl.getConfig().getBoolean("timer.enabled") == false) { + e.setCancelled(true); + } + } +} diff --git a/src/main/java/net/brennholz/challenges/BlockDestroyListener.java b/src/main/java/net/brennholz/challenges/BlockDestroyListener.java new file mode 100644 index 0000000..e764cba --- /dev/null +++ b/src/main/java/net/brennholz/challenges/BlockDestroyListener.java @@ -0,0 +1,57 @@ +package net.brennholz.challenges; + + + +import org.bukkit.Material; +import org.bukkit.Sound; +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.block.BlockBreakEvent; +import org.bukkit.event.block.BlockExplodeEvent; +import org.bukkit.event.entity.EntityExplodeEvent; +import org.bukkit.inventory.ItemStack; + +public class BlockDestroyListener implements Listener { + + private Challenges chl = Challenges.getplugin(); + + @EventHandler + public void onBlockBreak(BlockBreakEvent e) { + if (this.chl.getConfig().getBoolean("rnddrops") == true && this.chl.getConfig().getBoolean("timer.enabled") == true) { + e.setDropItems(false); + e.getBlock().getWorld().dropItem(e.getBlock().getLocation().add(0.5D, 0.5D, 0.5D), new ItemStack(this.chl.getRandomDropsManager().getMaterialFromBlock(e.getBlock()))); + } + if (this.chl.getConfig().getBoolean("timer.enabled") == false) { + e.setCancelled(true); + } + } + + @EventHandler + public void onBlockExplode(BlockExplodeEvent e) { + if (this.chl.getConfig().getBoolean("rnddrops") == true) { + e.setCancelled(true); + e.getBlock().getWorld().playSound(e.getBlock().getLocation(), Sound.ENTITY_GENERIC_EXPLODE, (float) 0.1, 1); + e.blockList().forEach(block -> { + if(!block.getType().isAir()){ + block.getWorld().dropItem(block.getLocation().add(0.5D, 0.5D, 0.5D),new ItemStack(this.chl.getRandomDropsManager().getMaterialFromBlock(block))); + block.setType(Material.AIR); + } + }); + } + } + + @EventHandler + public void onEntityExplode(EntityExplodeEvent e) { + if (this.chl.getConfig().getBoolean("rnddrops") == true) { + e.setCancelled(true); + e.getEntity().getWorld().playSound(e.getEntity().getLocation(), Sound.ENTITY_GENERIC_EXPLODE, (float) 0.1, 1); + e.blockList().forEach(block -> { + if(!block.getType().isAir()){ + block.getWorld().dropItem(block.getLocation().add(0.5D, 0.5D, 0.5D),new ItemStack(this.chl.getRandomDropsManager().getMaterialFromBlock(block))); + block.setType(Material.AIR); + } + }); + } + } +} + diff --git a/src/main/java/net/brennholz/challenges/Challenges.java b/src/main/java/net/brennholz/challenges/Challenges.java index 6c5b4e4..26019d5 100644 --- a/src/main/java/net/brennholz/challenges/Challenges.java +++ b/src/main/java/net/brennholz/challenges/Challenges.java @@ -58,7 +58,15 @@ getCommand("challenges").setExecutor(new Challenges_Command()); getCommand("backpack").setExecutor(new Backpack()); getCommand("reset").setExecutor(new Reset_Command()); - Bukkit.getPluginManager().registerEvents(new EventListener(), (Plugin)this); + + Bukkit.getPluginManager().registerEvents(new InventoryClickListener(), (Plugin)this); + Bukkit.getPluginManager().registerEvents(new QuitJoinListener(), (Plugin)this); + Bukkit.getPluginManager().registerEvents(new BlockDestroyListener(), (Plugin)this); + Bukkit.getPluginManager().registerEvents(new BlockCreateListener(), (Plugin)this); + Bukkit.getPluginManager().registerEvents(new InteractListener(), (Plugin)this); + Bukkit.getPluginManager().registerEvents(new DamageListener(), (Plugin)this); + Bukkit.getPluginManager().registerEvents(new DeathListener(), (Plugin)this); + saveDefaultConfig(); reloadConfig(); createRndDropsConfig(); diff --git a/src/main/java/net/brennholz/challenges/DamageListener.java b/src/main/java/net/brennholz/challenges/DamageListener.java new file mode 100644 index 0000000..0b2577c --- /dev/null +++ b/src/main/java/net/brennholz/challenges/DamageListener.java @@ -0,0 +1,89 @@ +package net.brennholz.challenges; + + + +import java.text.DecimalFormat; +import org.bukkit.Bukkit; +import org.bukkit.Sound; +import org.bukkit.entity.Player; +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.entity.EntityDamageByEntityEvent; +import org.bukkit.event.entity.EntityDamageEvent; +import org.bukkit.event.entity.EntityDamageEvent.DamageCause; +import org.bukkit.event.player.PlayerToggleSneakEvent; + +public class DamageListener implements Listener { + + private Challenges chl = Challenges.getplugin(); + + @EventHandler + public void onDamage(EntityDamageEvent e) { + if (e.getEntity() instanceof Player) { + Player p = (Player) e.getEntity(); + String dmg = new DecimalFormat("#.##").format(e.getFinalDamage()); + if (e.getFinalDamage() > 0) { + if (e.getCause() == DamageCause.FALL) { + if (chl.getConfig().getBoolean("deathonfall") == true) { + if (chl.getConfig().getBoolean("dmginchat") == true) { + Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + p.getHealth() + " §cHP Schaden genommen durch §4" + e.getCause()); + } + Bukkit.getScheduler().scheduleSyncDelayedTask(chl, new Runnable() { + @Override + public void run() { + p.setHealth(0); + } + }, 1); + } else if (chl.getConfig().getBoolean("dmginchat") == true) { + Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + dmg + " §cHP Schaden genommen durch §4" + e.getCause()); + } + } else if (e.getCause() == DamageCause.CUSTOM) { + if (!p.isSneaking() && (chl.getConfig().getBoolean("dmginchat") == true)) { + Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + chl.getConfig().getDouble("sneakdmg") + " §cHP Schaden genommen durch §4SNEAKING"); + } + } else if (e.getCause() == DamageCause.ENTITY_ATTACK || e.getCause() == DamageCause.ENTITY_EXPLOSION) { + + } else if (chl.getConfig().getBoolean("dmginchat") == true) { + Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + dmg + " §cHP Schaden genommen durch §4" + e.getCause()); + } + if (chl.getConfig().getBoolean("sharedmg") == true) { + for (Player pp : Bukkit.getOnlinePlayers()) { + if (pp != p) { + double health = pp.getHealth() - e.getFinalDamage(); + if(health < 0) { + pp.setHealth(0); + }else { + pp.setHealth(health); + pp.getWorld().playSound(pp.getLocation(), Sound.ENTITY_PLAYER_HURT, (float) 1, 1); + } + + } + } + } + } + } + } + + @EventHandler + public void onEntityDamage(EntityDamageByEntityEvent e) { + if ((e.getEntity() instanceof Player) && (e.getFinalDamage() > 0)) { + Player p = (Player) e.getEntity(); + String dmg = new DecimalFormat("#.##").format(e.getFinalDamage()); + if ((e.getCause() == DamageCause.ENTITY_ATTACK || e.getCause() == DamageCause.ENTITY_EXPLOSION) + && chl.getConfig().getBoolean("dmginchat") == true) { + Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + dmg + " §cHP Schaden genommen durch §4" + e.getDamager().getName()); + } + } + } + + @EventHandler + public void PlayerSneak(PlayerToggleSneakEvent e) { + Player p = (Player) e.getPlayer(); + if (!p.isSneaking()) { + if (chl.getConfig().getBoolean("damageonsneak") == true) { + p.damage(chl.getConfig().getDouble("sneakdmg")); + } + } + } +} + diff --git a/src/main/java/net/brennholz/challenges/DeathListener.java b/src/main/java/net/brennholz/challenges/DeathListener.java new file mode 100644 index 0000000..d82f479 --- /dev/null +++ b/src/main/java/net/brennholz/challenges/DeathListener.java @@ -0,0 +1,67 @@ +package net.brennholz.challenges; + + + +import org.bukkit.Bukkit; +import org.bukkit.GameMode; +import org.bukkit.entity.EnderDragon; +import org.bukkit.entity.Player; +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.entity.EntityDeathEvent; +import org.bukkit.event.entity.PlayerDeathEvent; +import org.bukkit.event.player.PlayerRespawnEvent; + +public class DeathListener implements Listener { + + private Challenges chl = Challenges.getplugin(); + + @EventHandler + public void onPlayerDeath(PlayerDeathEvent e) { + if (chl.getConfig().getBoolean("onelife") == true) { + chl.getConfig().set("timer.enabled", false); + chl.saveConfig(); + for (Player p : Bukkit.getOnlinePlayers()) { + p.setGameMode(GameMode.SPECTATOR); + } + chl.getServer().broadcastMessage(""); + chl.getServer().broadcastMessage(""); + e.setDeathMessage("§6" + e.getEntity().getName() + " §cist gestorben!"); + chl.getServer().broadcastMessage("§cDie Challenge wurde nach §6" + chl.getConfig().getInt("timer.hrs") + ":" + chl.getConfig().getString("timer.min") + ":" + chl.getConfig().getString("timer.sek") + " §cabgebrochen!"); + chl.getServer().broadcastMessage("§aSeed: §b" + Bukkit.getWorlds().get(0).getSeed()); + chl.getServer().broadcastMessage("§6Um alle wiederzubeleben benutze §c/revive ALL"); + } else { + e.setDeathMessage("§6" + e.getEntity().getName() + " §cist gestorben! §6(" + e.getEntity().getWorld().getName() + " " + e.getEntity().getLocation().getBlockX() + " " + e.getEntity().getLocation().getBlockY() + " " + e.getEntity().getLocation().getBlockZ() + "§c)"); + if (chl.getConfig().getBoolean("respawn") == false) { + Bukkit.getServer().broadcastMessage("§6Benutze §c/revive " + e.getEntity().getName() + " [world] [x] [y] [z] §6um ihn wiederzubeleben!"); + } + } + } + + @EventHandler + public void onPlayerRespawn(PlayerRespawnEvent e) { + if (chl.getConfig().getBoolean("respawn") == false) { + e.getPlayer().sendTitle("§cDu bist gestorben!", "§4Du bist nun Zuschauer", 10, 80, 10); + Bukkit.getScheduler().scheduleSyncDelayedTask(chl, new Runnable() { + @Override + public void run() { + e.getPlayer().setGameMode(GameMode.SPECTATOR); + } + }, 1); + } + } + + @EventHandler + public void DragonDeath(EntityDeathEvent e) { + if (e.getEntity() instanceof EnderDragon) { + chl.getConfig().set("timer.enabled", false); + chl.getServer().broadcastMessage("§6§kLIpwjwdjmpwdjmimjPiwjdÜOaiwjdüoJwoüdMdJM"); + chl.getServer().broadcastMessage(""); + chl.getServer().broadcastMessage("§aGRATULATION! IHR HABT DIE CHALLENGE ERFOLGREICH ABGESCHLOSSEN!"); + chl.getServer().broadcastMessage("§aBenötigte Zeit: §b" + chl.getConfig().getInt("timer.hrs") + ":"+ chl.getConfig().getString("timer.min") + ":" + chl.getConfig().getString("timer.sek")); + chl.getServer().broadcastMessage("§cSeed: §b" + Bukkit.getWorlds().get(0).getSeed()); + chl.getServer().broadcastMessage(""); + chl.getServer().broadcastMessage("§6§kLIpwjwdjmpwdjmimjPiwjdÜOaiwjdüoJwoüdMdJM"); + } + } +} diff --git a/src/main/java/net/brennholz/challenges/EventListener.java b/src/main/java/net/brennholz/challenges/EventListener.java deleted file mode 100644 index 1f69b96..0000000 --- a/src/main/java/net/brennholz/challenges/EventListener.java +++ /dev/null @@ -1,329 +0,0 @@ -package net.brennholz.challenges; - - - -import java.text.DecimalFormat; -import java.util.Random; - -import org.bukkit.Bukkit; -import org.bukkit.GameMode; -import org.bukkit.Material; -import org.bukkit.Sound; -import org.bukkit.World; -import org.bukkit.entity.EnderDragon; -import org.bukkit.entity.EntityType; -import org.bukkit.entity.Player; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.block.Action; -import org.bukkit.event.block.BlockBreakEvent; -import org.bukkit.event.block.BlockExplodeEvent; -import org.bukkit.event.entity.EntityDamageByEntityEvent; -import org.bukkit.event.entity.EntityDamageEvent; -import org.bukkit.event.entity.EntityDamageEvent.DamageCause; -import org.bukkit.event.inventory.InventoryClickEvent; -import org.bukkit.event.entity.EntityDeathEvent; -import org.bukkit.event.entity.EntityExplodeEvent; -import org.bukkit.event.entity.PlayerDeathEvent; -import org.bukkit.event.player.PlayerInteractEntityEvent; -import org.bukkit.event.player.PlayerInteractEvent; -import org.bukkit.event.player.PlayerJoinEvent; -import org.bukkit.event.player.PlayerQuitEvent; -import org.bukkit.event.player.PlayerRespawnEvent; -import org.bukkit.event.player.PlayerToggleSneakEvent; -import org.bukkit.inventory.ItemStack; - -public class EventListener implements Listener { - - private Challenges chl = Challenges.getplugin(); - - Challenges chall; - Coords_Command coco; - - @EventHandler - public void onBlockBreak(BlockBreakEvent e) { - if (this.chl.getConfig().getBoolean("rnddrops") == true) { - e.setDropItems(false); - e.getBlock().getWorld().dropItem(e.getBlock().getLocation().add(0.5D, 0.5D, 0.5D), new ItemStack(this.chl.getRandomDropsManager().getMaterialFromBlock(e.getBlock()))); - } - } - - @EventHandler - public void onBlockExplode(BlockExplodeEvent e) { - if (this.chl.getConfig().getBoolean("rnddrops") == true) { - e.setCancelled(true); - e.getBlock().getWorld().playSound(e.getBlock().getLocation(), Sound.ENTITY_GENERIC_EXPLODE, (float) 0.1, 1); - e.blockList().forEach(block -> { - if(!block.getType().isAir()){ - block.getWorld().dropItem(block.getLocation().add(0.5D, 0.5D, 0.5D),new ItemStack(this.chl.getRandomDropsManager().getMaterialFromBlock(block))); - block.setType(Material.AIR); - } - }); - } - } - - @EventHandler - public void onEntityExplode(EntityExplodeEvent e) { - if (this.chl.getConfig().getBoolean("rnddrops") == true) { - e.setCancelled(true); - e.getEntity().getWorld().playSound(e.getEntity().getLocation(), Sound.ENTITY_GENERIC_EXPLODE, (float) 0.1, 1); - e.blockList().forEach(block -> { - if(!block.getType().isAir()){ - block.getWorld().dropItem(block.getLocation().add(0.5D, 0.5D, 0.5D),new ItemStack(this.chl.getRandomDropsManager().getMaterialFromBlock(block))); - block.setType(Material.AIR); - } - }); - } - } - - @EventHandler - public void PlayerJoinEvent(PlayerJoinEvent e) { - Player p = e.getPlayer(); - e.setJoinMessage("§6" + p.getName() + " §chat den Server betreten!"); - if (chl.getConfig().getBoolean("sharedmg") == true) { - int rnd = new Random().nextInt(Bukkit.getOnlinePlayers().size()); - Player rp = (Player) Bukkit.getServer().getOnlinePlayers().toArray()[rnd]; - p.setHealth(rp.getHealth()); - } - if (this.chl.getConfig().getBoolean("tabhp") == true) { - this.chl.getSBManager().createScoreboard(p); - } - } - - @EventHandler - public void PlayerQuitEvent(PlayerQuitEvent e) { - Player p = e.getPlayer(); - e.setQuitMessage("§6" + p.getName() + " §chat den Server verlassen!"); - } - - @EventHandler - public void onBlockClick(PlayerInteractEvent e) { - if (e.getAction() == Action.RIGHT_CLICK_BLOCK) { - if (e.getClickedBlock().getType() == Material.CRAFTING_TABLE) { - if (chl.getConfig().getBoolean("craftingtable") == false) { - e.setCancelled(true); - } - } - } - } - - @EventHandler - public void onEntityClick(PlayerInteractEntityEvent e) { - if (e.getRightClicked().getType() == EntityType.VILLAGER) { - if (chl.getConfig().getBoolean("allowtrading") == false) { - e.setCancelled(true); - } - } - } - - @EventHandler - public void onPlayerDeath(PlayerDeathEvent e) { - if (chl.getConfig().getBoolean("onelife") == true) { - chl.getConfig().set("timer.enabled", false); - chl.saveConfig(); - for (Player p : Bukkit.getOnlinePlayers()) { - p.setGameMode(GameMode.SPECTATOR); - } - chl.getServer().broadcastMessage(""); - chl.getServer().broadcastMessage(""); - e.setDeathMessage("§6" + e.getEntity().getName() + " §cist gestorben!"); - chl.getServer().broadcastMessage("§cDie Challenge wurde nach §6" + chl.getConfig().getInt("timer.hrs") + ":" + chl.getConfig().getString("timer.min") + ":" + chl.getConfig().getString("timer.sek") + " §cabgebrochen!"); - chl.getServer().broadcastMessage("§aSeed: §b" + Bukkit.getWorlds().get(0).getSeed()); - chl.getServer().broadcastMessage("§6Um alle wiederzubeleben benutze §c/revive ALL"); - } else { - e.setDeathMessage("§6" + e.getEntity().getName() + " §cist gestorben! §6(" + e.getEntity().getWorld().getName() + " " + e.getEntity().getLocation().getBlockX() + " " + e.getEntity().getLocation().getBlockY() + " " + e.getEntity().getLocation().getBlockZ() + "§c)"); - if (chl.getConfig().getBoolean("respawn") == false) { - Bukkit.getServer().broadcastMessage("§6Benutze §c/revive " + e.getEntity().getName() + " [world] [x] [y] [z] §6um ihn wiederzubeleben!"); - } - } - } - - @EventHandler - public void onPlayerRespawn(PlayerRespawnEvent e) { - if (chl.getConfig().getBoolean("respawn") == false) { - e.getPlayer().sendTitle("§cDu bist gestorben!", "§4Du bist nun Zuschauer", 10, 80, 10); - Bukkit.getScheduler().scheduleSyncDelayedTask(chl, new Runnable() { - @Override - public void run() { - e.getPlayer().setGameMode(GameMode.SPECTATOR); - } - }, 1); - } - } - - @EventHandler - public void PlayerSneak(PlayerToggleSneakEvent e) { - Player p = (Player) e.getPlayer(); - if (!p.isSneaking()) { - if (chl.getConfig().getBoolean("damageonsneak") == true) { - p.damage(chl.getConfig().getDouble("sneakdmg")); - } - } - } - - @EventHandler - public void onDamage(EntityDamageEvent e) { - if (e.getEntity() instanceof Player) { - Player p = (Player) e.getEntity(); - String dmg = new DecimalFormat("#.##").format(e.getFinalDamage()); - if (e.getFinalDamage() > 0) { - if (e.getCause() == DamageCause.FALL) { - if (chl.getConfig().getBoolean("deathonfall") == true) { - if (chl.getConfig().getBoolean("dmginchat") == true) { - Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + p.getHealth() + " §cHP Schaden genommen durch §4" + e.getCause()); - } - Bukkit.getScheduler().scheduleSyncDelayedTask(chl, new Runnable() { - @Override - public void run() { - p.setHealth(0); - } - }, 1); - } else if (chl.getConfig().getBoolean("dmginchat") == true) { - Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + dmg + " §cHP Schaden genommen durch §4" + e.getCause()); - } - } else if (e.getCause() == DamageCause.CUSTOM) { - if (!p.isSneaking() && (chl.getConfig().getBoolean("dmginchat") == true)) { - Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + chl.getConfig().getDouble("sneakdmg") + " §cHP Schaden genommen durch §4SNEAKING"); - } - } else if (e.getCause() == DamageCause.ENTITY_ATTACK || e.getCause() == DamageCause.ENTITY_EXPLOSION) { - - } else if (chl.getConfig().getBoolean("dmginchat") == true) { - Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + dmg + " §cHP Schaden genommen durch §4" + e.getCause()); - } - if (chl.getConfig().getBoolean("sharedmg") == true) { - for (Player pp : Bukkit.getOnlinePlayers()) { - if (pp != p) { - double health = pp.getHealth() - e.getFinalDamage(); - if(health < 0) { - pp.setHealth(0); - }else { - pp.setHealth(health); - pp.getWorld().playSound(pp.getLocation(), Sound.ENTITY_PLAYER_HURT, (float) 1, 1); - } - - } - } - } - } - } - } - - @EventHandler - public void onEntityDamage(EntityDamageByEntityEvent e) { - if ((e.getEntity() instanceof Player) && (e.getFinalDamage() > 0)) { - Player p = (Player) e.getEntity(); - String dmg = new DecimalFormat("#.##").format(e.getFinalDamage()); - if ((e.getCause() == DamageCause.ENTITY_ATTACK || e.getCause() == DamageCause.ENTITY_EXPLOSION) - && chl.getConfig().getBoolean("dmginchat") == true) { - Bukkit.broadcastMessage("§6" + p.getName() + " §chat §4" + dmg + " §cHP Schaden genommen durch §4" + e.getDamager().getName()); - } - } - } - - @EventHandler - public void DragonDeath(EntityDeathEvent e) { - if (e.getEntity() instanceof EnderDragon) { - chl.getConfig().set("timer.enabled", false); - chl.getServer().broadcastMessage("§6§kLIpwjwdjmpwdjmimjPiwjdÜOaiwjdüoJwoüdMdJM"); - chl.getServer().broadcastMessage(""); - chl.getServer().broadcastMessage("§aGRATULATION! IHR HABT DIE CHALLENGE ERFOLGREICH ABGESCHLOSSEN!"); - chl.getServer().broadcastMessage("§aBenötigte Zeit: §b" + chl.getConfig().getInt("timer.hrs") + ": "+ chl.getConfig().getString("timer.min") + ":" + chl.getConfig().getString("timer.sek")); - chl.getServer().broadcastMessage("§cSeed: §b" + Bukkit.getWorlds().get(0).getSeed()); - chl.getServer().broadcastMessage(""); - chl.getServer().broadcastMessage("§6§kLIpwjwdjmpwdjmimjPiwjdÜOaiwjdüoJwoüdMdJM"); - } - } - - - @SuppressWarnings({ "deprecation", "static-access" }) - @EventHandler - public void InvClick(InventoryClickEvent e) { - World wld = Bukkit.getWorlds().get(0); - World nth = Bukkit.getWorlds().get(1); - World end = Bukkit.getWorlds().get(2); - String invname = e.getView().getTitle(); - Player p = (Player) e.getWhoClicked(); - int slot = e.getRawSlot(); - if (invname.equals(chall.GUIName)) { - e.setCancelled(true); - if (p.hasPermission("challenges.settings.modify")) { - switch (slot) { - case 18: - chl.getConfig().set("craftingtable", !(chl.getConfig().getBoolean("craftingtable"))); - break; - case 19: - chl.getConfig().set("allowtrading", !(chl.getConfig().getBoolean("allowtrading"))); - break; - case 20: - chl.getConfig().set("deathonfall", !(chl.getConfig().getBoolean("deathonfall"))); - break; - case 21: - chl.getConfig().set("damageonsneak", !(chl.getConfig().getBoolean("damageonsneak"))); - break; - case 22: - chl.getConfig().set("rnddrops", !(chl.getConfig().getBoolean("rnddrops"))); - break; - case 23: - chl.getConfig().set("sharedmg", !(chl.getConfig().getBoolean("sharedmg"))); - break; - case 24: - chl.getConfig().set("respawn", !(chl.getConfig().getBoolean("respawn"))); - break; - case 25: - chl.getConfig().set("onelife", !(chl.getConfig().getBoolean("onelife"))); - break; - case 26: - chl.getConfig().set("dmginchat", !(chl.getConfig().getBoolean("dmginchat"))); - break; - case 37: - if (wld.getGameRuleValue("keepInventory").equals("true")) { - wld.setGameRuleValue("keepInventory", "false"); - nth.setGameRuleValue("keepInventory", "false"); - end.setGameRuleValue("keepInventory", "false"); - } else if (wld.getGameRuleValue("keepInventory").equals("false")) { - wld.setGameRuleValue("keepInventory", "true"); - nth.setGameRuleValue("keepInventory", "true"); - end.setGameRuleValue("keepInventory", "true"); - } - break; - case 43: - if (wld.getGameRuleValue("naturalRegeneration").equals("true")) { - wld.setGameRuleValue("naturalRegeneration", "false"); - nth.setGameRuleValue("naturalRegeneration", "false"); - end.setGameRuleValue("naturalRegeneration", "false"); - } else if (wld.getGameRuleValue("naturalRegeneration").equals("false")) { - wld.setGameRuleValue("naturalRegeneration", "true"); - nth.setGameRuleValue("naturalRegeneration", "true"); - end.setGameRuleValue("naturalRegeneration", "true"); - } - break; - default: - break; - } - chl.saveConfig(); - p.performCommand("settings"); - } - } - if (invname.equals(coco.CGUIN)) { - e.setCancelled(true); - if (slot >= 0 && slot <= 44) { - if (coco.CoordsGUI.getItem(slot) != null && p.hasPermission("challenges.coords.delete")) { - p.performCommand("coords delete " + e.getCurrentItem().getItemMeta().getDisplayName()); - } - } - } - if (invname.equals(coco.CDGUIN)) { - e.setCancelled(true); - if (slot == 0) { - String cname = coco.CoordsDeleteGUI.getItem(4).getItemMeta().getDisplayName(); - chl.getConfig().set("Saved_Locations." + cname, null); - chl.saveConfig(); - p.sendMessage("§cPosition §6" + cname + " §cwurde gelöscht!"); - p.closeInventory(); - } - if (slot == 8) { - p.performCommand("coords"); - } - } - } -} diff --git a/src/main/java/net/brennholz/challenges/InteractListener.java b/src/main/java/net/brennholz/challenges/InteractListener.java new file mode 100644 index 0000000..eb697f4 --- /dev/null +++ b/src/main/java/net/brennholz/challenges/InteractListener.java @@ -0,0 +1,43 @@ +package net.brennholz.challenges; + + + +import org.bukkit.Material; +import org.bukkit.entity.EntityType; +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.block.Action; +import org.bukkit.event.player.PlayerInteractEntityEvent; +import org.bukkit.event.player.PlayerInteractEvent; + +public class InteractListener implements Listener { + + private Challenges chl = Challenges.getplugin(); + + @EventHandler + public void onBlockClick(PlayerInteractEvent e) { + if (e.getAction() == Action.RIGHT_CLICK_BLOCK) { + if (e.getClickedBlock().getType() == Material.CRAFTING_TABLE) { + if (chl.getConfig().getBoolean("craftingtable") == false) { + e.setCancelled(true); + } + } + if (this.chl.getConfig().getBoolean("timer.enabled") == false) { + e.setCancelled(true); + } + } + } + + @EventHandler + public void onEntityClick(PlayerInteractEntityEvent e) { + if (e.getRightClicked().getType() == EntityType.VILLAGER) { + if (chl.getConfig().getBoolean("allowtrading") == false) { + e.setCancelled(true); + } + } + if (this.chl.getConfig().getBoolean("timer.enabled") == false) { + e.setCancelled(true); + } + } +} + diff --git a/src/main/java/net/brennholz/challenges/InventoryClickListener.java b/src/main/java/net/brennholz/challenges/InventoryClickListener.java new file mode 100644 index 0000000..7a730c4 --- /dev/null +++ b/src/main/java/net/brennholz/challenges/InventoryClickListener.java @@ -0,0 +1,111 @@ +package net.brennholz.challenges; + + + +import org.bukkit.Bukkit; +import org.bukkit.World; +import org.bukkit.entity.Player; +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.inventory.InventoryClickEvent; + +public class InventoryClickListener implements Listener { + + private Challenges chl = Challenges.getplugin(); + + Challenges chall; + Coords_Command coco; + + @SuppressWarnings({ "deprecation", "static-access" }) + @EventHandler + public void InvClick(InventoryClickEvent e) { + World wld = Bukkit.getWorlds().get(0); + World nth = Bukkit.getWorlds().get(1); + World end = Bukkit.getWorlds().get(2); + String invname = e.getView().getTitle(); + Player p = (Player) e.getWhoClicked(); + int slot = e.getRawSlot(); + if (invname.equals(chall.GUIName)) { + e.setCancelled(true); + if (p.hasPermission("challenges.settings.modify")) { + switch (slot) { + case 18: + chl.getConfig().set("craftingtable", !(chl.getConfig().getBoolean("craftingtable"))); + break; + case 19: + chl.getConfig().set("allowtrading", !(chl.getConfig().getBoolean("allowtrading"))); + break; + case 20: + chl.getConfig().set("deathonfall", !(chl.getConfig().getBoolean("deathonfall"))); + break; + case 21: + chl.getConfig().set("damageonsneak", !(chl.getConfig().getBoolean("damageonsneak"))); + break; + case 22: + chl.getConfig().set("rnddrops", !(chl.getConfig().getBoolean("rnddrops"))); + break; + case 23: + chl.getConfig().set("sharedmg", !(chl.getConfig().getBoolean("sharedmg"))); + break; + case 24: + chl.getConfig().set("respawn", !(chl.getConfig().getBoolean("respawn"))); + break; + case 25: + chl.getConfig().set("onelife", !(chl.getConfig().getBoolean("onelife"))); + break; + case 26: + chl.getConfig().set("dmginchat", !(chl.getConfig().getBoolean("dmginchat"))); + break; + case 37: + if (wld.getGameRuleValue("keepInventory").equals("true")) { + wld.setGameRuleValue("keepInventory", "false"); + nth.setGameRuleValue("keepInventory", "false"); + end.setGameRuleValue("keepInventory", "false"); + } else if (wld.getGameRuleValue("keepInventory").equals("false")) { + wld.setGameRuleValue("keepInventory", "true"); + nth.setGameRuleValue("keepInventory", "true"); + end.setGameRuleValue("keepInventory", "true"); + } + break; + case 43: + if (wld.getGameRuleValue("naturalRegeneration").equals("true")) { + wld.setGameRuleValue("naturalRegeneration", "false"); + nth.setGameRuleValue("naturalRegeneration", "false"); + end.setGameRuleValue("naturalRegeneration", "false"); + } else if (wld.getGameRuleValue("naturalRegeneration").equals("false")) { + wld.setGameRuleValue("naturalRegeneration", "true"); + nth.setGameRuleValue("naturalRegeneration", "true"); + end.setGameRuleValue("naturalRegeneration", "true"); + } + break; + default: + break; + } + chl.saveConfig(); + p.performCommand("settings"); + } + } + if (invname.equals(coco.CGUIN)) { + e.setCancelled(true); + if (slot >= 0 && slot <= 44) { + if (coco.CoordsGUI.getItem(slot) != null && p.hasPermission("challenges.coords.delete")) { + p.performCommand("coords delete " + e.getCurrentItem().getItemMeta().getDisplayName()); + } + } + } + if (invname.equals(coco.CDGUIN)) { + e.setCancelled(true); + if (slot == 0) { + String cname = coco.CoordsDeleteGUI.getItem(4).getItemMeta().getDisplayName(); + chl.getConfig().set("Saved_Locations." + cname, null); + chl.saveConfig(); + p.sendMessage("§cPosition §6" + cname + " §cwurde gelöscht!"); + p.closeInventory(); + } + if (slot == 8) { + p.performCommand("coords"); + } + } + } +} + diff --git a/src/main/java/net/brennholz/challenges/QuitJoinListener.java b/src/main/java/net/brennholz/challenges/QuitJoinListener.java new file mode 100644 index 0000000..dd64531 --- /dev/null +++ b/src/main/java/net/brennholz/challenges/QuitJoinListener.java @@ -0,0 +1,37 @@ +package net.brennholz.challenges; + + + +import java.util.Random; + +import org.bukkit.Bukkit; +import org.bukkit.entity.Player; +import org.bukkit.event.EventHandler; +import org.bukkit.event.Listener; +import org.bukkit.event.player.PlayerJoinEvent; +import org.bukkit.event.player.PlayerQuitEvent; + +public class QuitJoinListener implements Listener { + + private Challenges chl = Challenges.getplugin(); + + @EventHandler + public void PlayerJoinEvent(PlayerJoinEvent e) { + Player p = e.getPlayer(); + e.setJoinMessage("§6" + p.getName() + " §chat den Server betreten!"); + if (chl.getConfig().getBoolean("sharedmg") == true) { + int rnd = new Random().nextInt(Bukkit.getOnlinePlayers().size()); + Player rp = (Player) Bukkit.getServer().getOnlinePlayers().toArray()[rnd]; + p.setHealth(rp.getHealth()); + } + if (this.chl.getConfig().getBoolean("tabhp") == true) { + this.chl.getSBManager().createScoreboard(p); + } + } + + @EventHandler + public void PlayerQuitEvent(PlayerQuitEvent e) { + Player p = e.getPlayer(); + e.setQuitMessage("§6" + p.getName() + " §chat den Server verlassen!"); + } +}