Stamer Alle Gegen Einen src rauf

This commit is contained in:
Softi 2022-08-12 19:09:54 +02:00
parent b628516f80
commit f2bd15a9ac
30 changed files with 1090 additions and 0 deletions

113
.gitignore vendored Normal file
View File

@ -0,0 +1,113 @@
# User-specific stuff
.idea/
*.iml
*.ipr
*.iws
# IntelliJ
out/
# Compiled class file
*.class
# Log file
*.log
# BlueJ files
*.ctxt
# Package Files #
*.jar
*.war
*.nar
*.ear
*.zip
*.tar.gz
*.rar
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
hs_err_pid*
*~
# temporary files which can be created if a process still has a handle open of a deleted file
.fuse_hidden*
# KDE directory preferences
.directory
# Linux trash folder which might appear on any partition or disk
.Trash-*
# .nfs files are created when an open file is removed but is still being accessed
.nfs*
# General
.DS_Store
.AppleDouble
.LSOverride
# Icon must end with two \r
Icon
# Thumbnails
._*
# Files that might appear in the root of a volume
.DocumentRevisions-V100
.fseventsd
.Spotlight-V100
.TemporaryItems
.Trashes
.VolumeIcon.icns
.com.apple.timemachine.donotpresent
# Directories potentially created on remote AFP share
.AppleDB
.AppleDesktop
Network Trash Folder
Temporary Items
.apdisk
# Windows thumbnail cache files
Thumbs.db
Thumbs.db:encryptable
ehthumbs.db
ehthumbs_vista.db
# Dump file
*.stackdump
# Folder config file
[Dd]esktop.ini
# Recycle Bin used on file shares
$RECYCLE.BIN/
# Windows Installer files
*.cab
*.msi
*.msix
*.msm
*.msp
# Windows shortcuts
*.lnk
target/
pom.xml.tag
pom.xml.releaseBackup
pom.xml.versionsBackup
pom.xml.next
release.properties
dependency-reduced-pom.xml
buildNumber.properties
.mvn/timing.properties
.mvn/wrapper/maven-wrapper.jar
.flattened-pom.xml
# Common working directory
run/

74
pom.xml Normal file
View File

@ -0,0 +1,74 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>xyz.inlineyt</groupId>
<artifactId>stamper</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>
<name>Alle gegen Stamer</name>
<properties>
<java.version>18</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>17</source>
<target>17</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>3.2.4</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<createDependencyReducedPom>false</createDependencyReducedPom>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
</build>
<repositories>
<repository>
<id>spigotmc-repo</id>
<url>https://hub.spigotmc.org/nexus/content/repositories/snapshots/</url>
</repository>
<repository>
<id>sonatype</id>
<url>https://oss.sonatype.org/content/groups/public/</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>org.spigotmc</groupId>
<artifactId>spigot-api</artifactId>
<version>1.18.2-R0.1-SNAPSHOT</version>
<scope>provided</scope>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,40 @@
package xyz.inlineyt.stamper;
import org.bukkit.Bukkit;
import org.bukkit.plugin.PluginManager;
import org.bukkit.plugin.java.JavaPlugin;
import xyz.inlineyt.stamper.commands.*;
import xyz.inlineyt.stamper.gameState.StateManager;
import xyz.inlineyt.stamper.listener.*;
public final class Main extends JavaPlugin {
@Override
public void onEnable() {
// Plugin startup logic
// StateManager.setState("Lobby");
PluginManager manager = Bukkit.getPluginManager();
manager.registerEvents(new ChatListener(), this);
manager.registerEvents(new JoinListener(), this);
manager.registerEvents(new QuitListener(), this);
manager.registerEvents(new EntityHitListener(), this);
manager.registerEvents(new DeathListener(), this);
manager.registerEvents(new InvClickListener(), this);
getCommand("StartGame").setExecutor(new StartGame());
getCommand("Compass").setExecutor(new Compass());
getCommand("Rank").setExecutor(new rank());
//getCommand("Compass").setExecutor(new Compass());
getCommand("Kits").setExecutor(new Kits());
getCommand("Teleport").setExecutor(new Teleport());
getCommand("giveKit").setExecutor(new GiveKit());
xyz.inlineyt.stamper.kits.Kits.getKits().add("Tank-Test");
xyz.inlineyt.stamper.kits.Kits.getKits().add("Test-OP");
xyz.inlineyt.stamper.kits.Kits.getKits().add("Test-Normal");
}
@Override
public void onDisable() {
// Plugin shutdown logic
}
}

View File

@ -0,0 +1,67 @@
package xyz.inlineyt.stamper.builder;
import org.bukkit.Material;
import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.inventory.ItemFlag;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.ItemMeta;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.function.Consumer;
public class ItemBuilder {
private Map<Integer, Consumer<InventoryClickEvent>> clickActions;
private ItemMeta itemMeta;
private ItemStack itemStack;
public ItemBuilder(Material mat){
itemStack = new ItemStack(mat);
itemMeta = itemStack.getItemMeta();
this.clickActions = new HashMap<>();
}
public ItemBuilder setDisplayname(String s){
itemMeta.setDisplayName(s);
return this;
}
public ItemBuilder setLocalizedName(String s){
itemMeta.setLocalizedName(s);
return this;
}
public ItemBuilder setLore(String... s){
itemMeta.setLore(Arrays.asList(s));
return this;
}
public ItemBuilder setUnbreakable(boolean s){
itemMeta.setUnbreakable(s);
return this;
}
public ItemBuilder addItemFlags(ItemFlag... s){
itemMeta.addItemFlags(s);
return this;
}
@Override
public String toString() {
return "ItemBuilder{" +
"itemMeta=" + itemMeta +
", itemStack=" + itemStack +
'}';
}
public ItemStack build(){
itemStack.setItemMeta(itemMeta);
return itemStack;
}
}

View File

@ -0,0 +1,38 @@
package xyz.inlineyt.stamper.commands;
import xyz.inlineyt.stamper.builder.ItemBuilder;
import org.bukkit.Bukkit;
import org.bukkit.Material;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.inventory.PlayerInventory;
import xyz.inlineyt.stamper.player.OP;
public class Compass implements CommandExecutor {
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
Player player = (Player) sender;
PlayerInventory inventory = player.getInventory();
if (player.hasPermission("event.rank.op")) {
inventory.addItem(new ItemBuilder(Material.COMPASS).setDisplayname("Target: Spieler").build());
for (Player targetPlayer : Bukkit.getOnlinePlayers()) {
player.setCompassTarget(targetPlayer.getLocation());
}
player.setCompassTarget(OP.getOPPlayers().get(1).getLocation());
inventory.addItem(new ItemBuilder(Material.COMPASS).setDisplayname("Target: " + OP.getOPPlayers().get(1).getName()).build());
}
return false;
}
}

View File

@ -0,0 +1,38 @@
package xyz.inlineyt.stamper.commands;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import xyz.inlineyt.stamper.kits.Kits;
import xyz.inlineyt.stamper.kits.TestKit;
import xyz.inlineyt.stamper.kits.TestKitOP;
import xyz.inlineyt.stamper.kits.TestKitOPTank;
public class GiveKit implements CommandExecutor {
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
Player player = Bukkit.getPlayer(args[0]);
switch (args[1]){
case "testkit":
TestKit.Kit(player);
break;
case "tank":
TestKitOPTank.kit(player);
break;
case "op":
TestKitOP.kit(player);
break;
}
return false;
}
}

View File

@ -0,0 +1,37 @@
package xyz.inlineyt.stamper.commands;
import org.bukkit.Bukkit;
import org.bukkit.Material;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.inventory.Inventory;
import xyz.inlineyt.stamper.builder.ItemBuilder;
public class Kits implements CommandExecutor {
int slot ;
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
Player player = (Player) sender;
Inventory inventory = Bukkit.createInventory(null , 3*9 , "Kit Art Auswählen" );
//rework KitGUI
xyz.inlineyt.stamper.kits.Kits.getKits().forEach( (n) -> inventory.setItem( slot++ , new ItemBuilder(Material.NETHERITE_CHESTPLATE).setDisplayname(n).setLocalizedName(n).build()) );
// inventory.setItem( 11, new ItemBuilder(Material.NETHERITE_CHESTPLATE).setDisplayname("OP Kits").setLocalizedName("KitKat_OP").build());
// inventory.setItem( 13, new ItemBuilder(Material.NETHERITE_CHESTPLATE).setDisplayname("OP Kits").setLocalizedName("KitKat_Player").build());
player.openInventory(inventory);
return false;
}
}

View File

@ -0,0 +1,19 @@
package xyz.inlineyt.stamper.commands;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.inventory.Inventory;
import xyz.inlineyt.stamper.gameState.StateManager;
public class StartGame implements CommandExecutor {
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
StateManager.setState("inGame");
return false;
}
}

View File

@ -0,0 +1,56 @@
package xyz.inlineyt.stamper.commands;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
public class Teleport implements CommandExecutor {
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
Player playerSender = (Player) sender;
Player player = Bukkit.getPlayer(args[1]);
switch (args[0]){
case "here":
player.sendTitle("" , "",7 , 10, 7);
player.teleport( playerSender);
break;
case "to" :
if (args[2] == null) {
player.sendTitle("" , "",7 , 10, 7);
sender.sendMessage("bitte Spieler angeben");
}
player.sendTitle("" , "",7 , 10, 7);
Player target = Bukkit.getPlayer(args[2]);
player.teleport(target);
break;
case "all":
for (Player allPlayers : Bukkit.getOnlinePlayers()){
allPlayers.sendTitle("" , "",7 , 10, 7);
allPlayers.teleport(playerSender);
}
break;
}
return false;
}
}

View File

@ -0,0 +1,74 @@
package xyz.inlineyt.stamper.commands;
import org.bukkit.Bukkit;
import org.bukkit.ChatColor;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import xyz.inlineyt.stamper.player.Helpers;
import xyz.inlineyt.stamper.player.OP;
public class rank implements CommandExecutor {
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
Player target = Bukkit.getPlayer(args[0]) ;
if (args[1].equalsIgnoreCase("OP")) {
if (Helpers.getHelpers().contains(target)){
Helpers.getHelpers().remove(target);
}
OP.getOPPlayers().add(target);
for (Player Onlineplayers : Bukkit.getOnlinePlayers()) {
Onlineplayers.sendTitle(target.getName() + " wurde nun zum 眨" , "" ,0 , 10 ,0 );
}
target.setPlayerListName( "" + ChatColor.GRAY + target.getName());
} else if (args[1].equalsIgnoreCase("Helper")) {
if (OP.getOPPlayers().contains(target)){
OP.getOPPlayers().remove(target);
}
for (Player Onlineplayers : Bukkit.getOnlinePlayers()) {
Onlineplayers.sendTitle(target.getName() + " wurde nun zum 眩" , "" ,0 , 10 ,0 );
}
target.setPlayerListName( "" + target.getName());
Helpers.getHelpers().add(target);
} else if (args[1].equalsIgnoreCase("Player")) {
if (OP.getOPPlayers().contains(target)) {
OP.getOPPlayers().remove(target);
}
for (Player Onlineplayers : Bukkit.getOnlinePlayers()) {
Onlineplayers.sendTitle(target.getName() + " wurde nun zum 眪" , "" ,0 , 10 ,0 );
target.setPlayerListName( ""+ ChatColor.GRAY + target.getName());
}
Helpers.getHelpers().add(target);
}
return false;
}
}

View File

@ -0,0 +1,13 @@
package xyz.inlineyt.stamper.gameState;
public class State {
public static String State;
public static String getState() {
return State;
}
public static void setState(String state) {
State = state;
}
}

View File

@ -0,0 +1,80 @@
package xyz.inlineyt.stamper.gameState;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player;
import xyz.inlineyt.stamper.kits.SelectedOPKit;
import xyz.inlineyt.stamper.kits.TestKit;
import xyz.inlineyt.stamper.kits.TestKitOP;
import xyz.inlineyt.stamper.kits.TestKitOPTank;
import xyz.inlineyt.stamper.player.Helpers;
import xyz.inlineyt.stamper.player.OP;
public class StateManager {
public static void setState(String GameState) {
switch (GameState){
case "Lobby":
State.setState("Lobby");
break;
case "inGame":
State.setState("Inagme");
for (Player players : Bukkit.getOnlinePlayers()) {
String kitName = SelectedOPKit.getKit();
if (OP.getOPPlayers().contains(players)) {
switch (kitName) {
case "TestOP":
TestKitOP.kit(players);
break;
case "TestTank":
TestKitOPTank.kit(players);
break;
}
if (Helpers.getHelpers().contains(players)) {
switch (kitName) {
case "TestOP":
TestKitOP.kit(players);
break;
case "TestTank":
TestKitOPTank.kit(players);
break;
}
}
} else TestKit.kit(players);
}
break;
case "stop":
State.setState("Stop");
Bukkit.getServer().shutdown();
break;
}
}
}

View File

@ -0,0 +1,22 @@
package xyz.inlineyt.stamper.kits;
import org.bukkit.entity.Player;
import org.bukkit.inventory.PlayerInventory;
public interface Kit {
public static PlayerInventory kit(Player player) {
PlayerInventory inventory = player.getInventory();
return inventory;
};
public static String Kit(){
String KitName = "KitName";
return KitName;
};
}

View File

@ -0,0 +1,13 @@
package xyz.inlineyt.stamper.kits;
import java.util.ArrayList;
public class Kits {
public static ArrayList<String> Kits = new ArrayList<String>();
public static ArrayList<String> getKits() {
return Kits;
}
}

View File

@ -0,0 +1,14 @@
package xyz.inlineyt.stamper.kits;
public class SelectedKit {
public static String Kit;
public static String getKit() {
return Kit;
}
public static void setKit(String kit) {
Kit = kit;
}
}

View File

@ -0,0 +1,14 @@
package xyz.inlineyt.stamper.kits;
public class SelectedOPKit {
public static String Kit;
public static String getKit() {
return Kit;
}
public static void setKit(String kit) {
Kit = kit;
}
}

View File

@ -0,0 +1,29 @@
package xyz.inlineyt.stamper.kits;
import org.bukkit.Material;
import org.bukkit.entity.Player;
import org.bukkit.inventory.PlayerInventory;
import xyz.inlineyt.stamper.builder.ItemBuilder;
public class TestKit implements Kit{
public static PlayerInventory kit(Player player) {
PlayerInventory inventory = player.getInventory();
inventory.setItem(0, new ItemBuilder(Material.DIAMOND_SWORD).setDisplayname("Dia Schwert zum Test Kit").build());
inventory.setItem(1, new ItemBuilder(Material.DIAMOND_AXE).setDisplayname("Dia Axt zum Test Kit").build());
inventory.setItem(2, new ItemBuilder(Material.DIAMOND_PICKAXE).setDisplayname("Dia PickAxt zum Test Kit").build());
return inventory;
}
public static String Kit(Player player){
String KitName = "Test-Kit";
return KitName;
}
}

View File

@ -0,0 +1,25 @@
package xyz.inlineyt.stamper.kits;
import org.bukkit.Material;
import org.bukkit.entity.Player;
import org.bukkit.inventory.PlayerInventory;
import xyz.inlineyt.stamper.builder.ItemBuilder;
public class TestKitOP implements Kit{
public static PlayerInventory kit(Player player) {
PlayerInventory inventory = player.getInventory();
inventory.setItem(0, new ItemBuilder(Material.DIAMOND_SWORD).setDisplayname("Dia Schwert zum Test Kit des OP").build());
inventory.setItem(1, new ItemBuilder(Material.DIAMOND_AXE).setDisplayname("Dia Axt zum Test Kit des OP").build());
inventory.setItem(2, new ItemBuilder(Material.DIAMOND_PICKAXE).setDisplayname("Dia PickAxt zum Test Kit des OP").build());
return inventory;
}
}

View File

@ -0,0 +1,21 @@
package xyz.inlineyt.stamper.kits;
import org.bukkit.Material;
import org.bukkit.entity.Player;
import org.bukkit.inventory.PlayerInventory;
import xyz.inlineyt.stamper.builder.ItemBuilder;
public class TestKitOPTank implements Kit{
public static PlayerInventory kit(Player player) {
PlayerInventory inventory = player.getInventory();
inventory.setItem(0, new ItemBuilder(Material.DIAMOND_SWORD).setDisplayname("Dia Schwert zum Test Kit des OP").build());
inventory.setItem(1, new ItemBuilder(Material.DIAMOND_AXE).setDisplayname("Dia Axt zum Test Kit des OP").build());
inventory.setItem(2, new ItemBuilder(Material.DIAMOND_PICKAXE).setDisplayname("Dia PickAxt zum Test Kit des OP").build());
inventory.setItem(3, new ItemBuilder(Material.SHIELD).setDisplayname("Tank Shield").build());
return inventory;
}
}

View File

@ -0,0 +1,23 @@
package xyz.inlineyt.stamper.listener;
import org.bukkit.ChatColor;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.player.AsyncPlayerChatEvent;
public class ChatListener implements Listener {
@EventHandler(ignoreCancelled = true)
public void onAsyncPlayerChat(AsyncPlayerChatEvent event) {
if (event.getPlayer().hasPermission("event.rank.op")){
event.setFormat(ChatColor.RED + "OP " + event.getPlayer().getName() + " > " + event.getMessage());
} else event.setFormat(ChatColor.GREEN + "Spieler "+ event.getPlayer().getName( ) + " > " + event.getMessage());
}
}

View File

@ -0,0 +1,26 @@
package xyz.inlineyt.stamper.listener;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.entity.PlayerDeathEvent;
public class DeathListener implements Listener {
@EventHandler(ignoreCancelled = true)
public void onPlayerDeath(PlayerDeathEvent event) {
if (event.getEntity().getKiller() == null) {
event.getEntity().kickPlayer("du bist Gestorben");
event.setDeathMessage(event.getEntity().getName() + "ist Gestorben." );
} else {
event.setDeathMessage(event.getEntity().getName() + "wurde von " + event.getEntity().getKiller().getName() + "getötet");
event.getEntity().kickPlayer("du bist Gestorben");
event.getEntity().getKiller().sendMessage("Du hast " + event.getEntity().getName() + " getötet");
}
}
}

View File

@ -0,0 +1,33 @@
package xyz.inlineyt.stamper.listener;
import org.bukkit.entity.Player;
import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityDamageByEntityEvent;
import xyz.inlineyt.stamper.gameState.State;
import xyz.inlineyt.stamper.player.OP;
import xyz.inlineyt.stamper.player.Players;
public class EntityHitListener implements Listener {
public void onEntityDamageByEntity(EntityDamageByEntityEvent event) {
if (event.getDamager() instanceof Player) {
if(OP.getOPPlayers().contains(((Player) event.getDamager()).getPlayer())) {return;}
if (State.getState() == "Ingame") {
if (Players.getPlayers().contains(event.getEntity())){
if (Players.getPlayers().contains(event.getEntity())){
event.setCancelled(true);
} else if (OP.getOPPlayers().contains(((Player) event.getDamager()).getPlayer())){
return;
}
} else return;
}
else event.setCancelled(true);
}
}
}

View File

@ -0,0 +1,76 @@
package xyz.inlineyt.stamper.listener;
import org.bukkit.Bukkit;
import org.bukkit.Material;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.inventory.InventoryClickEvent;
import org.bukkit.inventory.Inventory;
import xyz.inlineyt.stamper.builder.ItemBuilder;
import xyz.inlineyt.stamper.kits.SelectedOPKit;
public class InvClickListener implements Listener {
@EventHandler(ignoreCancelled = true)
public void onInventoryClick(InventoryClickEvent event) {
if (event.getView().getTitle() == "Kit Art Auswählen") {
if (event.getCurrentItem().getItemMeta().hasLocalizedName()) {
Player player = (Player) event.getWhoClicked();
event.setCancelled(true);
switch (event.getCurrentItem().getItemMeta().getLocalizedName()) {
case "KitKat_OP":
Inventory inventoryOP = Bukkit.createInventory(null, 5 * 9, "Kit Auswählen");
inventoryOP.setItem(11, new ItemBuilder(Material.NETHERITE_CHESTPLATE).setDisplayname("Test Kit OP").setLocalizedName("Kit_OP_Test").build());
inventoryOP.setItem(13, new ItemBuilder(Material.NETHERITE_CHESTPLATE).setDisplayname("Tank Kit OP").setLocalizedName("Kit_OP_Test_Tank").build());
player.openInventory(inventoryOP);
break;
case "KitKat_Player":
Inventory inventoryPlayer = Bukkit.createInventory(null, 5 * 9, "Kit Auswählen für Spieler");
inventoryPlayer.setItem(11, new ItemBuilder(Material.NETHERITE_CHESTPLATE).setDisplayname("Test Kit OP").setLocalizedName("Kit_Test").build());
player.openInventory(inventoryPlayer);
break;
}
}
} else if (event.getView().getTitle() == "Kit Auswählen") {
if (event.getCurrentItem().getItemMeta().hasLocalizedName()) {
Player player = (Player) event.getWhoClicked();
event.setCancelled(true);
switch (event.getCurrentItem().getItemMeta().getLocalizedName()) {
case "Kit_OP_Test":
SelectedOPKit.setKit("TestOP");
break;
case "Kit_OP_Test_Tank":
SelectedOPKit.setKit("TestTank");
break;
}
}
}
}
}

View File

@ -0,0 +1,33 @@
package xyz.inlineyt.stamper.listener;
import org.bukkit.ChatColor;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerJoinEvent;
import xyz.inlineyt.stamper.player.OP;
import xyz.inlineyt.stamper.player.Players;
import xyz.inlineyt.stamper.tablist.Tablist;
public class JoinListener implements Listener {
public void onPlayerJoin(PlayerJoinEvent event) {
if (event.getPlayer().hasPermission("event.rank.op")){
Tablist.updatePlayerDisplay( event.getPlayer() ,"" + ChatColor.GRAY + event.getPlayer().getName() );
event.setJoinMessage("" + ChatColor.GRAY + event.getPlayer().getName() + " hat den Server betreten");
OP.getOPPlayers().add(event.getPlayer());
}else {
event.setJoinMessage("" + ChatColor.GRAY + event.getPlayer().getName() + " hat den Server betreten");
Tablist.updatePlayerDisplay(event.getPlayer(), "" + ChatColor.GRAY + event.getPlayer().getName());
Players.getPlayers().add(event.getPlayer());
}
}
}

View File

@ -0,0 +1,20 @@
package xyz.inlineyt.stamper.listener;
import org.bukkit.ChatColor;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerQuitEvent;
public class QuitListener implements Listener {
@EventHandler(ignoreCancelled = true)
public void onPlayerQuit(PlayerQuitEvent event) {
if (event.getPlayer().hasPermission("event.rank.op")){
event.setQuitMessage(ChatColor.RED + "OP " + ChatColor.DARK_GRAY + "| " + ChatColor.GRAY + event.getPlayer().getName() + " hat den Server verlassen");
} else event.setQuitMessage(ChatColor.GREEN + "Spieler " + ChatColor.DARK_GRAY + "| " + ChatColor.GRAY + event.getPlayer().getName() + " hat den Server verlassen");
}
}

View File

@ -0,0 +1,16 @@
package xyz.inlineyt.stamper.player;
import org.bukkit.entity.Player;
import java.util.ArrayList;
public class Helpers {
public static ArrayList<Player> Helpers = new ArrayList<Player>() ;
public static ArrayList<Player> getHelpers() {
return Helpers;
}
}

View File

@ -0,0 +1,16 @@
package xyz.inlineyt.stamper.player;
import org.bukkit.entity.Player;
import java.util.ArrayList;
public class OP {
public static ArrayList<Player> OPPlayers = new ArrayList<Player>();
public static ArrayList<Player> getOPPlayers() {
return OPPlayers;
}
}

View File

@ -0,0 +1,14 @@
package xyz.inlineyt.stamper.player;
import org.bukkit.entity.Player;
import java.util.ArrayList;
public class Players {
public static ArrayList<Player> Players = new ArrayList<Player>();
public static ArrayList<Player> getPlayers() {
return Players;
}
}

View File

@ -0,0 +1,29 @@
package xyz.inlineyt.stamper.tablist;
import org.bukkit.entity.Player;
public class Tablist {
public static void updatePlayerDisplay(Player player , String Display) {
player.setPlayerListName(Display);
player.setDisplayName(Display);
}
public static void updatePlayerTabHeaderFooter(Player player ,String DisplayHeader , String DisplayFooter) {
player.setPlayerListHeaderFooter(DisplayHeader , DisplayFooter);
}
}

View File

@ -0,0 +1,17 @@
name: Alle-gegen-Stamer
version: '${project.version}'
main: xyz.inlineyt.stamper.Main
api-version: 1.18
commands:
StartGame:
permission: event.rank.op
Compass:
permission: event.compass
Kits:
permission: event.kit
Rank:
permission: event.rank
GiveKit:
permission: event.kit
Teleport:
permission: event.kit