diff --git a/.gitignore b/.gitignore index 87d4436..1104c40 100644 --- a/.gitignore +++ b/.gitignore @@ -7,6 +7,11 @@ # IntelliJ out/ +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml # Compiled class file *.class @@ -95,19 +100,22 @@ $RECYCLE.BIN/ # Windows shortcuts *.lnk -target/ +.gradle +build/ -pom.xml.tag -pom.xml.releaseBackup -pom.xml.versionsBackup -pom.xml.next +# Ignore Gradle GUI config +gradle-app.setting -release.properties -dependency-reduced-pom.xml -buildNumber.properties -.mvn/timing.properties -.mvn/wrapper/maven-wrapper.jar -.flattened-pom.xml +# Cache of project +.gradletasknamecache + +**/build/ # Common working directory -run/ \ No newline at end of file +run/ +runs/ + +# Avoid ignoring Gradle wrapper jar file (.jar files are usually ignored) +!gradle-wrapper.jar + +bin/ \ No newline at end of file diff --git a/LICENSE b/LICENSE.txt similarity index 97% rename from LICENSE rename to LICENSE.txt index e2a438f..5e52004 100644 --- a/LICENSE +++ b/LICENSE.txt @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2024 Lncvrt +Copyright (c) 2025 Lncvrt Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/README.md b/README.md new file mode 100644 index 0000000..8e8a5e2 --- /dev/null +++ b/README.md @@ -0,0 +1,5 @@ +# GalaxyTab + +Static MiniMessage based tablist plugin for servers like Auth and Limbo in Galaxy Network! + +Placeholders are now supported, you can choose to enable or disable that though diff --git a/build.gradle.kts b/build.gradle.kts new file mode 100644 index 0000000..b9f6515 --- /dev/null +++ b/build.gradle.kts @@ -0,0 +1,108 @@ +import org.sayandev.plugin.StickyNoteModules + +plugins { + java + kotlin("jvm") version "2.1.20" + id("xyz.jpenilla.run-paper") version "2.3.1" + id("de.eldoria.plugin-yml.bukkit") version "0.7.1" + id("org.sayandev.stickynote.project") +} + +val slug = rootProject.name.lowercase() +group = "xyz.lncvrt" +version = "1.0.0" + +stickynote { + modules(StickyNoteModules.BUKKIT) +} + +repositories { + mavenCentral() + mavenLocal() + + maven("https://repo.sayandev.org/snapshots") + maven("https://repo.sayandev.org/releases") + maven("https://repo.sayandev.org/private") + maven("https://repo.extendedclip.com/releases/") + maven("https://jitpack.io") + maven("https://ci.frostcast.net/plugin/repository/everything") +} + +dependencies { + compileOnly("io.papermc.paper:paper-api:1.21.4-R0.1-SNAPSHOT") + compileOnly("me.clip:placeholderapi:2.11.6") + compileOnly("com.github.booksaw:BetterTeams:4.11.0") + compileOnly("me.confuser.banmanager:BanManagerCommon:7.9.0") +} + +tasks { + jar { + manifest { + attributes["paperweight-mappings-namespace"] = "mojang" + } + } + + shadowJar { + archiveFileName.set("${rootProject.name}-${version}.jar") + archiveClassifier.set(null as String?) + destinationDirectory.set(file(rootProject.projectDir.path + "/bin")) + manifest { + attributes["paperweight-mappings-namespace"] = "mojang" + } + } + + runServer { + minecraftVersion("1.21.4") + + jvmArgs() + } + + compileJava { + options.encoding = Charsets.UTF_8.name() + } + + configurations { + create("compileOnlyApiResolved") { + isCanBeResolved = true + extendsFrom(configurations.getByName("compileOnlyApi")) + } + } + + build { + dependsOn(shadowJar) + } + + processResources { + filesMatching(listOf("**plugin.yml", "**plugin.json")) { + expand( + "version" to project.version as String, + "slug" to slug, + "name" to rootProject.name, + "description" to project.description + ) + } + } +} + +bukkit { + main = "$group.${slug}.${rootProject.name}Plugin" + version = rootProject.version.toString() + website = "lncvrt.xyz" + + + apiVersion = "1.13" + + depend = listOf() + + authors = listOf("Lncvrt") + prefix = rootProject.name +} + +java { + disableAutoTargetJvm() + if (gradle.startParameter.getTaskNames().any { it.startsWith("runServer") || it.startsWith("runFolia") || it.startsWith("runVelocity") }) { + toolchain.languageVersion.set(JavaLanguageVersion.of(21)) + } else { + toolchain.languageVersion.set(JavaLanguageVersion.of(21)) + } +} \ No newline at end of file diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000..9bbc975 Binary files /dev/null and b/gradle/wrapper/gradle-wrapper.jar differ diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties new file mode 100644 index 0000000..ed4c299 --- /dev/null +++ b/gradle/wrapper/gradle-wrapper.properties @@ -0,0 +1,7 @@ +distributionBase=GRADLE_USER_HOME +distributionPath=wrapper/dists +distributionUrl=https\://services.gradle.org/distributions/gradle-8.13-all.zip +networkTimeout=10000 +validateDistributionUrl=true +zipStoreBase=GRADLE_USER_HOME +zipStorePath=wrapper/dists diff --git a/gradlew b/gradlew new file mode 100644 index 0000000..faf9300 --- /dev/null +++ b/gradlew @@ -0,0 +1,251 @@ +#!/bin/sh + +# +# Copyright © 2015-2021 the original authors. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# https://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# SPDX-License-Identifier: Apache-2.0 +# + +############################################################################## +# +# Gradle start up script for POSIX generated by Gradle. +# +# Important for running: +# +# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is +# noncompliant, but you have some other compliant shell such as ksh or +# bash, then to run this script, type that shell name before the whole +# command line, like: +# +# ksh Gradle +# +# Busybox and similar reduced shells will NOT work, because this script +# requires all of these POSIX shell features: +# * functions; +# * expansions «$var», «${var}», «${var:-default}», «${var+SET}», +# «${var#prefix}», «${var%suffix}», and «$( cmd )»; +# * compound commands having a testable exit status, especially «case»; +# * various built-in commands including «command», «set», and «ulimit». +# +# Important for patching: +# +# (2) This script targets any POSIX shell, so it avoids extensions provided +# by Bash, Ksh, etc; in particular arrays are avoided. +# +# The "traditional" practice of packing multiple parameters into a +# space-separated string is a well documented source of bugs and security +# problems, so this is (mostly) avoided, by progressively accumulating +# options in "$@", and eventually passing that to Java. +# +# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, +# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; +# see the in-line comments for details. +# +# There are tweaks for specific operating systems such as AIX, CygWin, +# Darwin, MinGW, and NonStop. +# +# (3) This script is generated from the Groovy template +# https://github.com/gradle/gradle/blob/HEAD/platforms/jvm/plugins-application/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt +# within the Gradle project. +# +# You can find Gradle at https://github.com/gradle/gradle/. +# +############################################################################## + +# Attempt to set APP_HOME + +# Resolve links: $0 may be a link +app_path=$0 + +# Need this for daisy-chained symlinks. +while + APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path + [ -h "$app_path" ] +do + ls=$( ls -ld "$app_path" ) + link=${ls#*' -> '} + case $link in #( + /*) app_path=$link ;; #( + *) app_path=$APP_HOME$link ;; + esac +done + +# This is normally unused +# shellcheck disable=SC2034 +APP_BASE_NAME=${0##*/} +# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036) +APP_HOME=$( cd -P "${APP_HOME:-./}" > /dev/null && printf '%s\n' "$PWD" ) || exit + +# Use the maximum available, or set MAX_FD != -1 to use that value. +MAX_FD=maximum + +warn () { + echo "$*" +} >&2 + +die () { + echo + echo "$*" + echo + exit 1 +} >&2 + +# OS specific support (must be 'true' or 'false'). +cygwin=false +msys=false +darwin=false +nonstop=false +case "$( uname )" in #( + CYGWIN* ) cygwin=true ;; #( + Darwin* ) darwin=true ;; #( + MSYS* | MINGW* ) msys=true ;; #( + NONSTOP* ) nonstop=true ;; +esac + +CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar + + +# Determine the Java command to use to start the JVM. +if [ -n "$JAVA_HOME" ] ; then + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then + # IBM's JDK on AIX uses strange locations for the executables + JAVACMD=$JAVA_HOME/jre/sh/java + else + JAVACMD=$JAVA_HOME/bin/java + fi + if [ ! -x "$JAVACMD" ] ; then + die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." + fi +else + JAVACMD=java + if ! command -v java >/dev/null 2>&1 + then + die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." + fi +fi + +# Increase the maximum file descriptors if we can. +if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then + case $MAX_FD in #( + max*) + # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked. + # shellcheck disable=SC2039,SC3045 + MAX_FD=$( ulimit -H -n ) || + warn "Could not query maximum file descriptor limit" + esac + case $MAX_FD in #( + '' | soft) :;; #( + *) + # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked. + # shellcheck disable=SC2039,SC3045 + ulimit -n "$MAX_FD" || + warn "Could not set maximum file descriptor limit to $MAX_FD" + esac +fi + +# Collect all arguments for the java command, stacking in reverse order: +# * args from the command line +# * the main class name +# * -classpath +# * -D...appname settings +# * --module-path (only if needed) +# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. + +# For Cygwin or MSYS, switch paths to Windows format before running java +if "$cygwin" || "$msys" ; then + APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) + CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) + + JAVACMD=$( cygpath --unix "$JAVACMD" ) + + # Now convert the arguments - kludge to limit ourselves to /bin/sh + for arg do + if + case $arg in #( + -*) false ;; # don't mess with options #( + /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath + [ -e "$t" ] ;; #( + *) false ;; + esac + then + arg=$( cygpath --path --ignore --mixed "$arg" ) + fi + # Roll the args list around exactly as many times as the number of + # args, so each arg winds up back in the position where it started, but + # possibly modified. + # + # NB: a `for` loop captures its iteration list before it begins, so + # changing the positional parameters here affects neither the number of + # iterations, nor the values presented in `arg`. + shift # remove old arg + set -- "$@" "$arg" # push replacement arg + done +fi + + +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' + +# Collect all arguments for the java command: +# * DEFAULT_JVM_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments, +# and any embedded shellness will be escaped. +# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be +# treated as '${Hostname}' itself on the command line. + +set -- \ + "-Dorg.gradle.appname=$APP_BASE_NAME" \ + -classpath "$CLASSPATH" \ + org.gradle.wrapper.GradleWrapperMain \ + "$@" + +# Stop when "xargs" is not available. +if ! command -v xargs >/dev/null 2>&1 +then + die "xargs is not available" +fi + +# Use "xargs" to parse quoted args. +# +# With -n1 it outputs one arg per line, with the quotes and backslashes removed. +# +# In Bash we could simply go: +# +# readarray ARGS < <( xargs -n1 <<<"$var" ) && +# set -- "${ARGS[@]}" "$@" +# +# but POSIX shell has neither arrays nor command substitution, so instead we +# post-process each arg (as a line of input to sed) to backslash-escape any +# character that might be a shell metacharacter, then use eval to reverse +# that process (while maintaining the separation between arguments), and wrap +# the whole thing up as a single "set" statement. +# +# This will of course break if any of these variables contains a newline or +# an unmatched quote. +# + +eval "set -- $( + printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | + xargs -n1 | + sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | + tr '\n' ' ' + )" '"$@"' + +exec "$JAVACMD" "$@" diff --git a/gradlew.bat b/gradlew.bat new file mode 100644 index 0000000..9d21a21 --- /dev/null +++ b/gradlew.bat @@ -0,0 +1,94 @@ +@rem +@rem Copyright 2015 the original author or authors. +@rem +@rem Licensed under the Apache License, Version 2.0 (the "License"); +@rem you may not use this file except in compliance with the License. +@rem You may obtain a copy of the License at +@rem +@rem https://www.apache.org/licenses/LICENSE-2.0 +@rem +@rem Unless required by applicable law or agreed to in writing, software +@rem distributed under the License is distributed on an "AS IS" BASIS, +@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +@rem See the License for the specific language governing permissions and +@rem limitations under the License. +@rem +@rem SPDX-License-Identifier: Apache-2.0 +@rem + +@if "%DEBUG%"=="" @echo off +@rem ########################################################################## +@rem +@rem Gradle startup script for Windows +@rem +@rem ########################################################################## + +@rem Set local scope for the variables with windows NT shell +if "%OS%"=="Windows_NT" setlocal + +set DIRNAME=%~dp0 +if "%DIRNAME%"=="" set DIRNAME=. +@rem This is normally unused +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@rem Resolve any "." and ".." in APP_HOME to make it shorter. +for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi + +@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" + +@rem Find java.exe +if defined JAVA_HOME goto findJavaFromJavaHome + +set JAVA_EXE=java.exe +%JAVA_EXE% -version >NUL 2>&1 +if %ERRORLEVEL% equ 0 goto execute + +echo. 1>&2 +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2 +echo. 1>&2 +echo Please set the JAVA_HOME variable in your environment to match the 1>&2 +echo location of your Java installation. 1>&2 + +goto fail + +:findJavaFromJavaHome +set JAVA_HOME=%JAVA_HOME:"=% +set JAVA_EXE=%JAVA_HOME%/bin/java.exe + +if exist "%JAVA_EXE%" goto execute + +echo. 1>&2 +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2 +echo. 1>&2 +echo Please set the JAVA_HOME variable in your environment to match the 1>&2 +echo location of your Java installation. 1>&2 + +goto fail + +:execute +@rem Setup the command line + +set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar + + +@rem Execute Gradle +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* + +:end +@rem End local scope for the variables with windows NT shell +if %ERRORLEVEL% equ 0 goto mainEnd + +:fail +rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of +rem the _cmd.exe /c_ return code! +set EXIT_CODE=%ERRORLEVEL% +if %EXIT_CODE% equ 0 set EXIT_CODE=1 +if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% +exit /b %EXIT_CODE% + +:mainEnd +if "%OS%"=="Windows_NT" endlocal + +:omega diff --git a/pom.xml b/pom.xml deleted file mode 100644 index 7685997..0000000 --- a/pom.xml +++ /dev/null @@ -1,78 +0,0 @@ - - - 4.0.0 - xyz.lncvrt - GalaxyBoxPvP - GalaxyBoxPvP - 1.0.0 - - - - true - src/main/resources - - - - - maven-compiler-plugin - 3.8.1 - - ${java.version} - ${java.version} - - - - - - - papermc-repo - https://repo.papermc.io/repository/maven-public/ - - - sonatype - https://oss.sonatype.org/content/groups/public/ - - - placeholderapi-repo - https://repo.extendedclip.com/content/repositories/placeholderapi/ - - - jitpack.io - https://jitpack.io - - - confuser-repo - https://ci.frostcast.net/plugin/repository/everything - - - - - io.papermc.paper - paper-api - 1.21.4-R0.1-SNAPSHOT - provided - - - me.clip - placeholderapi - 2.11.6 - provided - - - com.github.booksaw - BetterTeams - 4.11.0 - provided - - - me.confuser.banmanager - BanManagerCommon - 7.9.0 - provided - - - - 21 - UTF-8 - - diff --git a/settings.gradle.kts b/settings.gradle.kts new file mode 100644 index 0000000..791acf8 --- /dev/null +++ b/settings.gradle.kts @@ -0,0 +1,15 @@ + +pluginManagement { + repositories { + gradlePluginPortal() + mavenLocal() + maven("https://repo.papermc.io/repository/maven-public/") + maven("https://repo.sayandev.org/snapshots") + } +} + +plugins { + id("org.sayandev.stickynote.settings") version "1.9.0.5" +} + +rootProject.name = "GalaxyBoxPvP" \ No newline at end of file diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/GalaxyBoxPvP.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/GalaxyBoxPvP.java deleted file mode 100644 index 293bbac..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/GalaxyBoxPvP.java +++ /dev/null @@ -1,194 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp; - -import me.confuser.banmanager.common.BanManagerPlugin; -import net.kyori.adventure.text.minimessage.MiniMessage; -import org.bukkit.Bukkit; -import org.bukkit.Material; -import org.bukkit.command.TabExecutor; -import org.bukkit.entity.Player; -import org.bukkit.inventory.Inventory; -import org.bukkit.inventory.ItemStack; -import org.bukkit.plugin.PluginManager; -import org.bukkit.plugin.java.JavaPlugin; -import org.json.simple.JSONObject; -import org.json.simple.parser.JSONParser; -import org.json.simple.parser.ParseException; -import xyz.lncvrt.galaxyboxpvp.commands.Autocompress; -import xyz.lncvrt.galaxyboxpvp.commands.Sky; -import xyz.lncvrt.galaxyboxpvp.commands.Skyrtp; -import xyz.lncvrt.galaxyboxpvp.events.*; - -import java.io.File; -import java.io.FileReader; -import java.io.FileWriter; -import java.io.IOException; -import java.util.HashMap; -import java.util.Map; -import java.util.Objects; -import java.util.UUID; -import java.util.logging.Level; - -public final class GalaxyBoxPvP extends JavaPlugin implements TabExecutor { - public final Map autoCompressStatus = new HashMap<>(); - public final Map skyRTPDelays = new HashMap<>(); - private final PlaceholderAPIExpansion placeholderAPIExpansion = new PlaceholderAPIExpansion(); - public final MiniMessage miniMessage = MiniMessage.miniMessage(); - - @Override - public void onEnable() { - if (placeholderAPIExpansion.register()) { - getLogger().info("Successfully registered PlaceholderAPIExpansion!"); - } else { - getLogger().warning("Failed to register PlaceholderAPIExpansion. Disabling plugin."); - getServer().getPluginManager().disablePlugin(this); - return; - } - - registerEvents(); - registerCommands(); - - loadAutoCompressStatus(); - } - - @Override - public void onDisable() { - placeholderAPIExpansion.unregister(); - saveAutoCompressStatus(); - } - - private void registerEvents() { - PluginManager pluginManager = getServer().getPluginManager(); - pluginManager.registerEvents(new BlockBreakListener(this), this); - pluginManager.registerEvents(new BlockPlaceListener(this), this); - pluginManager.registerEvents(new CraftItemListener(), this); - pluginManager.registerEvents(new EntityPickupItemListener(this), this); - pluginManager.registerEvents(new EntitySpawnListener(), this); - pluginManager.registerEvents(new FurnaceBurnListener(this), this); - pluginManager.registerEvents(new FurnaceSmeltListener(this), this); - pluginManager.registerEvents(new PlayerDropItemListener(this), this); - pluginManager.registerEvents(new PlayerJoinListener(this), this); - pluginManager.registerEvents(new PlayerMoveListener(), this); - pluginManager.registerEvents(new PrepareAnvilListener(), this); - pluginManager.registerEvents(new PrepareItemEnchantListener(), this); - pluginManager.registerEvents(new SignChangeListener(this), this); - } - - private void registerCommands() { - Objects.requireNonNull(getCommand("autocompress")).setExecutor(new Autocompress(this)); - Objects.requireNonNull(getCommand("sky")).setExecutor(new Sky()); - Objects.requireNonNull(getCommand("skyrtp")).setExecutor(new Skyrtp(this)); - } - - public boolean isRestrictedMaterial(Material material) { - return material == Material.IRON_ORE || material == Material.RAW_IRON || material == Material.GOLD_ORE || material == Material.RAW_GOLD || material == Material.ANCIENT_DEBRIS || material == Material.SAND; - } - - public void convertInventoryItemsPrep(Player player, UUID playerId) { - if (autoCompressStatus.getOrDefault(playerId, false)) { - convertInventoryItems(player, Material.DIAMOND, Material.DIAMOND_BLOCK, 9, 1); - convertInventoryItems(player, Material.LAPIS_LAZULI, Material.LAPIS_BLOCK, 9, 1); - convertInventoryItems(player, Material.REDSTONE, Material.REDSTONE_BLOCK, 9, 1); - convertInventoryItems(player, Material.EMERALD, Material.EMERALD_BLOCK, 9, 1); - convertInventoryItems(player, Material.RAW_GOLD, Material.RAW_GOLD_BLOCK, 9, 1); - convertInventoryItems(player, Material.GOLD_INGOT, Material.GOLD_BLOCK, 9, 1); - convertInventoryItems(player, Material.GOLD_NUGGET, Material.GOLD_INGOT, 9, 1); - convertInventoryItems(player, Material.IRON_ORE, Material.IRON_BLOCK, 9, 1); - convertInventoryItems(player, Material.RAW_IRON, Material.RAW_IRON_BLOCK, 9, 1); - convertInventoryItems(player, Material.COAL, Material.COAL_BLOCK, 9, 1); - convertInventoryItems(player, Material.RAW_COPPER, Material.COPPER_BLOCK, 9, 1); - convertInventoryItems(player, Material.COPPER_INGOT, Material.COPPER_BLOCK, 9, 1); - convertInventoryItems(player, Material.QUARTZ, Material.QUARTZ_BLOCK, 4, 1); - } - } - - private void convertInventoryItems(Player player, Material fromMaterial, Material toMaterial, int fromCount, @SuppressWarnings("SameParameterValue") int toCount) { - ItemStack[] inventoryContents = player.getInventory().getContents(); - - Bukkit.getScheduler().runTask(this, () -> { - for (int i = 0; i < inventoryContents.length; i++) { - ItemStack item = inventoryContents[i]; - - if (item != null && item.getType() == fromMaterial && item.getAmount() >= fromCount) { - int stacksToConvert = item.getAmount() / fromCount; - int remainingItems = item.getAmount() % fromCount; - - if (stacksToConvert > 0) { - item.setAmount(remainingItems); - player.getInventory().setItem(i, item); - - ItemStack toMaterialStack = new ItemStack(toMaterial, stacksToConvert * toCount); - HashMap remaining = player.getInventory().addItem(toMaterialStack); - - if (!remaining.isEmpty()) { - for (ItemStack remainingItem : remaining.values()) { - player.getWorld().dropItem(player.getLocation(), remainingItem); - } - } - } - } - } - mergeInventoryStacks(player.getInventory(), fromMaterial); - }); - } - - private void mergeInventoryStacks(Inventory inventory, Material material) { - int totalAmount = 0; - - for (ItemStack item : inventory.getContents()) { - if (item != null && item.getType() == material) { - totalAmount += item.getAmount(); - item.setAmount(0); - } - } - - int fullStacks = totalAmount / material.getMaxStackSize(); - int remainingItems = totalAmount % material.getMaxStackSize(); - - for (int i = 0; i < fullStacks; i++) { - inventory.addItem(new ItemStack(material, material.getMaxStackSize())); - } - if (remainingItems > 0) { - inventory.addItem(new ItemStack(material, remainingItems)); - } - } - - @SuppressWarnings("unchecked") - private void saveAutoCompressStatus() { - File file = new File(getDataFolder(), "autocompress.json"); - JSONObject jsonObject = new JSONObject(); - - for (Map.Entry entry : autoCompressStatus.entrySet()) { - jsonObject.put(entry.getKey().toString(), entry.getValue()); - } - - try (FileWriter writer = new FileWriter(file)) { - writer.write(jsonObject.toJSONString()); - } catch (IOException e) { - getLogger().log(Level.SEVERE, "Error saving statuses to autocompress.json", e); - } - } - - private void loadAutoCompressStatus() { - File file = new File(getDataFolder(), "autocompress.json"); - if (!file.exists()) { - return; - } - - try (FileReader reader = new FileReader(file)) { - JSONParser parser = new JSONParser(); - JSONObject jsonObject = (JSONObject) parser.parse(reader); - - for (Object key : jsonObject.keySet()) { - UUID playerId = UUID.fromString((String) key); - Boolean status = (Boolean) jsonObject.get(key); - autoCompressStatus.put(playerId, status); - } - } catch (IOException | ParseException e) { - getLogger().log(Level.SEVERE, "Error loading statuses from autocompress.json", e); - } - } - - public boolean isMuted(Player player) { - return BanManagerPlugin.getInstance().getPlayerMuteStorage().isMuted(player.getUniqueId()); - } -} \ No newline at end of file diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/PlaceholderAPIExpansion.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/PlaceholderAPIExpansion.java deleted file mode 100644 index d7ad427..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/PlaceholderAPIExpansion.java +++ /dev/null @@ -1,62 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp; - -import com.booksaw.betterTeams.Team; -import me.clip.placeholderapi.expansion.PlaceholderExpansion; -import org.bukkit.ChatColor; -import org.bukkit.Statistic; -import org.bukkit.entity.Player; -import org.jetbrains.annotations.NotNull; -import org.jetbrains.annotations.Nullable; - -public final class PlaceholderAPIExpansion extends PlaceholderExpansion { - @Override - public @NotNull String getIdentifier() { - return "galaxyboxpvp"; - } - - @Override - public @NotNull String getAuthor() { - return "Lncvrt"; - } - - @Override - public @NotNull String getVersion() { - return "1.0.0"; - } - - @Override - public boolean persist() { - return true; - } - - @Override - public boolean canRegister() { - return true; - } - - @Override - public @Nullable String onPlaceholderRequest(Player player, @NotNull String identifier) { - switch (identifier) { - case "hearts": - return String.format("%.1f", player.getHealth() / 2); - case "kills": - return String.valueOf(player.getStatistic(Statistic.PLAYER_KILLS)); - case "deaths": - return String.valueOf(player.getStatistic(Statistic.DEATHS)); - case "kdr": - int kills = player.getStatistic(Statistic.PLAYER_KILLS); - int deaths = player.getStatistic(Statistic.DEATHS); - return deaths == 0 ? String.valueOf(kills) : String.format("%.1f", (double) kills / deaths); - case "team": - Team team1 = Team.getTeam(player); - if (team1 == null) return ""; - return ChatColor.translateAlternateColorCodes('&', "%s[%s%s%s%s]%s ".formatted(ChatColor.GRAY, ChatColor.RESET, team1.getDisplayName(), ChatColor.RESET, ChatColor.GRAY, ChatColor.RESET)); - case "teamname": - Team team2 = Team.getTeam(player); - if (team2 == null) return "None"; - return team2.getName(); - default: - return null; - } - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Autocompress.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Autocompress.java deleted file mode 100644 index 45d25ae..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Autocompress.java +++ /dev/null @@ -1,36 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.commands; - -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; -import org.bukkit.command.Command; -import org.bukkit.command.CommandExecutor; -import org.bukkit.command.CommandSender; -import org.bukkit.entity.Player; -import org.jetbrains.annotations.NotNull; - -import java.util.UUID; - -import static org.bukkit.ChatColor.GREEN; -import static org.bukkit.ChatColor.RED; - -public record Autocompress(GalaxyBoxPvP plugin) implements CommandExecutor { - - @Override - public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String label, String @NotNull [] args) { - if (!(sender instanceof Player player)) { - sender.sendMessage(RED + "This command can only be executed by a player."); - return true; - } - - UUID playerId = player.getUniqueId(); - - boolean currentStatus = plugin.autoCompressStatus.getOrDefault(playerId, false); - plugin.autoCompressStatus.put(playerId, !currentStatus); - - if (!currentStatus) { - player.sendMessage(GREEN + "Auto-compress enabled."); - } else { - player.sendMessage(RED + "Auto-compress disabled."); - } - return true; - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Sky.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Sky.java deleted file mode 100644 index c4d6aaf..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Sky.java +++ /dev/null @@ -1,19 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.commands; - -import net.kyori.adventure.text.minimessage.MiniMessage; -import org.bukkit.command.Command; -import org.bukkit.command.CommandExecutor; -import org.bukkit.command.CommandSender; -import org.bukkit.entity.Player; -import org.jetbrains.annotations.NotNull; - -public class Sky implements CommandExecutor { - @Override - public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String label, String @NotNull [] args) { - if (sender instanceof Player player) { - player.performCommand("warp sky"); - player.sendMessage(MiniMessage.miniMessage().deserialize("You can do /skyrtp (click the bold text) to randomly teleport around here!")); - } - return true; - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Skyrtp.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Skyrtp.java deleted file mode 100644 index f4c7d7b..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Skyrtp.java +++ /dev/null @@ -1,51 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.commands; - -import org.bukkit.Location; -import org.bukkit.Material; -import org.bukkit.World; -import org.bukkit.block.Block; -import org.bukkit.command.Command; -import org.bukkit.command.CommandExecutor; -import org.bukkit.command.CommandSender; -import org.bukkit.entity.Player; -import org.jetbrains.annotations.NotNull; -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; - -import java.util.concurrent.ThreadLocalRandom; - -public class Skyrtp implements CommandExecutor { - private final GalaxyBoxPvP plugin; - - public Skyrtp(GalaxyBoxPvP plugin) { - this.plugin = plugin; - } - - @Override - public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String label, String @NotNull [] args) { - if (sender instanceof Player player) { - Long last = plugin.skyRTPDelays.get(player.getUniqueId()); - Long time = System.currentTimeMillis(); - if (last != null && time - last < 30000) { - Long timeLeft = (30000 - (System.currentTimeMillis() - last)) / 1000; - player.sendMessage(plugin.miniMessage.deserialize("You can't RTP in the sky world so often, please wait %s second(s)!".formatted(timeLeft))); - return true; - } - World world = plugin.getServer().getWorld("sky"); - if (world == null) { - player.sendMessage(plugin.miniMessage.deserialize("Failed, please try again!")); - return true; - } - int randomX = ThreadLocalRandom.current().nextInt(100, 15000); - int randomZ = ThreadLocalRandom.current().nextInt(100, 15000); - Location location = new Location(world, randomX, 100, randomZ); - Block block = world.getBlockAt(location); - if (block.getType() == Material.AIR) { - block.setType(Material.GRASS_BLOCK); - } - player.teleport(location.add(0.5f, 1, 0.5f)); - player.sendMessage(plugin.miniMessage.deserialize("You have been randomly teleported to %s 100 %s".formatted(randomX, randomZ))); - plugin.skyRTPDelays.put(player.getUniqueId(), time); - } - return true; - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/BlockBreakListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/BlockBreakListener.java deleted file mode 100644 index 8a1f08c..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/BlockBreakListener.java +++ /dev/null @@ -1,24 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; -import org.bukkit.entity.Player; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.block.BlockBreakEvent; - -public class BlockBreakListener implements Listener { - private final GalaxyBoxPvP plugin; - - public BlockBreakListener(GalaxyBoxPvP plugin) { - this.plugin = plugin; - } - - @EventHandler - public void onBlockBreak(BlockBreakEvent event) { - Player player = event.getPlayer(); - plugin.convertInventoryItemsPrep(player, player.getUniqueId()); - if (event.getBlock().getLocation().getY() == 100 && event.getBlock().getWorld().getName().equals("world")) { - event.setCancelled(true); - } - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/BlockPlaceListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/BlockPlaceListener.java deleted file mode 100644 index 9e2dec3..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/BlockPlaceListener.java +++ /dev/null @@ -1,26 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import org.bukkit.Material; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.block.BlockPlaceEvent; -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; - -public class BlockPlaceListener implements Listener { - private final GalaxyBoxPvP plugin; - - public BlockPlaceListener(GalaxyBoxPvP plugin) { - this.plugin = plugin; - } - - @EventHandler - public void onBlockPlace(BlockPlaceEvent event) { - if (event.getBlockPlaced().getType() == Material.POLISHED_BLACKSTONE_BUTTON) { - if (event.getItemInHand().hasItemMeta() && event.getItemInHand().getItemMeta().hasDisplayName()) { - event.setCancelled(true); //temp fix - } - } else if (event.getBlockPlaced().getType() == Material.FURNACE || event.getBlockPlaced().getType() == Material.FURNACE_MINECART || event.getBlockPlaced().getType() == Material.BLAST_FURNACE) { - event.getPlayer().sendMessage(plugin.miniMessage.deserialize("[TIP] If you are trying to smelt iron, gold, etc you can use the Smelter Shop. Click [HERE] to teleport to the smelter shop!")); - } - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/CraftItemListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/CraftItemListener.java deleted file mode 100644 index e3c95df..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/CraftItemListener.java +++ /dev/null @@ -1,24 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import org.bukkit.Material; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.inventory.CraftItemEvent; -import org.bukkit.inventory.ItemStack; -import org.bukkit.inventory.meta.ItemMeta; - -public class CraftItemListener implements Listener { - @EventHandler - public void onCraftItem(CraftItemEvent event) { - if (event.getCurrentItem() != null && event.getCurrentItem().getType() == Material.DIAMOND_PICKAXE) { - ItemStack pickaxe = event.getCurrentItem(); - ItemMeta meta = pickaxe.getItemMeta(); - - if (meta != null) { - meta.setUnbreakable(true); - pickaxe.setItemMeta(meta); - event.setCurrentItem(pickaxe); - } - } - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/EntityPickupItemListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/EntityPickupItemListener.java deleted file mode 100644 index fee8d9f..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/EntityPickupItemListener.java +++ /dev/null @@ -1,21 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; -import org.bukkit.entity.Player; -import org.bukkit.event.EventHandler; -import org.bukkit.event.EventPriority; -import org.bukkit.event.Listener; -import org.bukkit.event.entity.EntityPickupItemEvent; - -public class EntityPickupItemListener implements Listener { - private final GalaxyBoxPvP plugin; - - public EntityPickupItemListener(GalaxyBoxPvP plugin) { - this.plugin = plugin; - } - - @EventHandler(priority = EventPriority.LOWEST) - public void onItemPickup(EntityPickupItemEvent event) { - if (event.getEntity() instanceof Player player) plugin.convertInventoryItemsPrep(player, player.getUniqueId()); - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/EntitySpawnListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/EntitySpawnListener.java deleted file mode 100644 index c5ba51d..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/EntitySpawnListener.java +++ /dev/null @@ -1,13 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import org.bukkit.entity.EntityType; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.entity.EntitySpawnEvent; - -public class EntitySpawnListener implements Listener { - @EventHandler - public void onEntitySpawnEvent(EntitySpawnEvent event) { - if (event.getEntityType() == EntityType.WITHER) event.setCancelled(true); - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/FurnaceBurnListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/FurnaceBurnListener.java deleted file mode 100644 index bba6697..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/FurnaceBurnListener.java +++ /dev/null @@ -1,25 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; -import org.bukkit.Material; -import org.bukkit.block.Furnace; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.inventory.FurnaceBurnEvent; - -import java.util.Objects; - -public class FurnaceBurnListener implements Listener { - private final GalaxyBoxPvP plugin; - - public FurnaceBurnListener(GalaxyBoxPvP plugin) { - this.plugin = plugin; - } - - @EventHandler - public void onFurnaceBurn(FurnaceBurnEvent event) { - Furnace furnace = (Furnace) event.getBlock().getState(); - Material smelting = Objects.requireNonNull(furnace.getInventory().getSmelting()).getType(); - if (plugin.isRestrictedMaterial(smelting)) event.setCancelled(true); - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/FurnaceSmeltListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/FurnaceSmeltListener.java deleted file mode 100644 index 9575e1f..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/FurnaceSmeltListener.java +++ /dev/null @@ -1,21 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; -import org.bukkit.Material; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.inventory.FurnaceSmeltEvent; - -public class FurnaceSmeltListener implements Listener { - private final GalaxyBoxPvP plugin; - - public FurnaceSmeltListener(GalaxyBoxPvP plugin) { - this.plugin = plugin; - } - - @EventHandler - public void onFurnaceSmelt(FurnaceSmeltEvent event) { - Material smelted = event.getSource().getType(); - if (plugin.isRestrictedMaterial(smelted)) event.setCancelled(true); - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerDropItemListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerDropItemListener.java deleted file mode 100644 index 10a2239..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerDropItemListener.java +++ /dev/null @@ -1,20 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; -import org.bukkit.event.EventHandler; -import org.bukkit.event.EventPriority; -import org.bukkit.event.Listener; -import org.bukkit.event.player.PlayerDropItemEvent; - -public class PlayerDropItemListener implements Listener { - private final GalaxyBoxPvP plugin; - - public PlayerDropItemListener(GalaxyBoxPvP plugin) { - this.plugin = plugin; - } - - @EventHandler(priority = EventPriority.LOWEST) - public void onItemDrop(PlayerDropItemEvent event) { - plugin.convertInventoryItemsPrep(event.getPlayer(), event.getPlayer().getUniqueId()); - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerJoinListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerJoinListener.java deleted file mode 100644 index cfc8dad..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerJoinListener.java +++ /dev/null @@ -1,28 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; -import org.bukkit.entity.Player; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.player.PlayerJoinEvent; - -import java.util.UUID; - -import static org.bukkit.ChatColor.GREEN; - -public class PlayerJoinListener implements Listener { - private final GalaxyBoxPvP plugin; - - public PlayerJoinListener(GalaxyBoxPvP plugin) { - this.plugin = plugin; - } - - @EventHandler - public void onPlayerJoin(PlayerJoinEvent event) { - Player player = event.getPlayer(); - UUID playerId = player.getUniqueId(); - - if (!plugin.autoCompressStatus.containsKey(playerId)) plugin.autoCompressStatus.put(playerId, false); - player.sendMessage("%sWelcome to LncvrtBox, %s! This is a PvP arena gamemode that was originally called LncvrtBox, and is almost a year old! We reset the server for GalaxyNetwork and a fresh start".formatted(GREEN, player.getName())); - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerMoveListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerMoveListener.java deleted file mode 100644 index c215222..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerMoveListener.java +++ /dev/null @@ -1,20 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import org.bukkit.Location; -import org.bukkit.entity.Player; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.player.PlayerMoveEvent; - -public class PlayerMoveListener implements Listener { - @EventHandler - private void onSignPlace(PlayerMoveEvent event) { - Player player = event.getPlayer(); - int maxY = player.getWorld().getMaxHeight(); - if (player.getLocation().getY() >= maxY) { - Location newLocation = player.getLocation().clone(); - newLocation.setY(maxY - 1); - player.teleport(newLocation); - } - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PrepareAnvilListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PrepareAnvilListener.java deleted file mode 100644 index 9a7a52b..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PrepareAnvilListener.java +++ /dev/null @@ -1,22 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import org.bukkit.Material; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.inventory.PrepareAnvilEvent; -import org.bukkit.inventory.ItemStack; - -public class PrepareAnvilListener implements Listener { - @EventHandler - public void onPrepareAnvil(PrepareAnvilEvent event) { - ItemStack left = event.getInventory().getItem(0); - ItemStack right = event.getInventory().getItem(1); - - if (left != null && (left.getType() == Material.DIAMOND_PICKAXE || left.getType() == Material.NETHERITE_PICKAXE)) { - event.setResult(null); - } - if (right != null && (right.getType() == Material.DIAMOND_PICKAXE || right.getType() == Material.NETHERITE_PICKAXE)) { - event.setResult(null); - } - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PrepareItemEnchantListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PrepareItemEnchantListener.java deleted file mode 100644 index f873f96..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/PrepareItemEnchantListener.java +++ /dev/null @@ -1,15 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import org.bukkit.Material; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.enchantment.PrepareItemEnchantEvent; -import org.bukkit.inventory.ItemStack; - -public class PrepareItemEnchantListener implements Listener { - @EventHandler - public void onPrepareItemEnchant(PrepareItemEnchantEvent event) { - ItemStack item = event.getItem(); - if (item.getType() == Material.DIAMOND_PICKAXE || item.getType() == Material.NETHERITE_PICKAXE) event.setCancelled(true); - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/ProjectileHitListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/ProjectileHitListener.java deleted file mode 100644 index 36612c6..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/ProjectileHitListener.java +++ /dev/null @@ -1,21 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import org.bukkit.entity.EntityType; -import org.bukkit.entity.Projectile; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.entity.ProjectileHitEvent; -import org.bukkit.projectiles.ProjectileSource; - -public class ProjectileHitListener implements Listener { - @EventHandler - public void onProjectileHit(ProjectileHitEvent event) { - Projectile projectile = event.getEntity(); - if (projectile.getType() == EntityType.WITHER_SKULL) { - ProjectileSource shooter = projectile.getShooter(); - if (shooter instanceof org.bukkit.entity.Wither) { - event.getEntity().remove(); - } - } - } -} diff --git a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/SignChangeListener.java b/src/main/java/xyz/lncvrt/galaxyboxpvp/events/SignChangeListener.java deleted file mode 100644 index 3ed4c68..0000000 --- a/src/main/java/xyz/lncvrt/galaxyboxpvp/events/SignChangeListener.java +++ /dev/null @@ -1,19 +0,0 @@ -package xyz.lncvrt.galaxyboxpvp.events; - -import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP; -import org.bukkit.event.EventHandler; -import org.bukkit.event.Listener; -import org.bukkit.event.block.SignChangeEvent; - -public class SignChangeListener implements Listener { - private final GalaxyBoxPvP plugin; - - public SignChangeListener(GalaxyBoxPvP plugin) { - this.plugin = plugin; - } - - @EventHandler - private void onSignPlace(SignChangeEvent event) { - if (plugin.isMuted(event.getPlayer())) event.setCancelled(true); - } -} diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/GalaxyBoxPvPPlugin.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/GalaxyBoxPvPPlugin.kt new file mode 100644 index 0000000..f7a8b46 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/GalaxyBoxPvPPlugin.kt @@ -0,0 +1,207 @@ +package xyz.lncvrt.galaxyboxpvp + +import me.confuser.banmanager.common.BanManagerPlugin +import org.bukkit.Bukkit +import org.bukkit.Material +import org.bukkit.command.TabExecutor +import org.bukkit.entity.Player +import org.bukkit.inventory.Inventory +import org.bukkit.inventory.ItemStack +import org.bukkit.plugin.java.JavaPlugin +import org.json.simple.JSONObject +import org.json.simple.parser.JSONParser +import org.sayandev.stickynote.loader.bukkit.StickyNoteBukkitLoader +import xyz.lncvrt.galaxyboxpvp.commands.Autocompress +import xyz.lncvrt.galaxyboxpvp.commands.Sky +import xyz.lncvrt.galaxyboxpvp.commands.Skyrtp +import xyz.lncvrt.galaxyboxpvp.events.* +import java.io.File +import java.io.FileReader +import java.io.FileWriter +import java.io.IOException +import java.text.ParseException +import java.util.* + + +class GalaxyBoxPvPPlugin : JavaPlugin(), TabExecutor { + internal val autoCompressStatus: MutableMap = HashMap() + internal val skyRTPDelays: MutableMap = HashMap() + private val placeholderAPIExpansion: PlaceholderAPIExpansion = PlaceholderAPIExpansion() + + override fun onEnable() { + StickyNoteBukkitLoader(this) + instance = this + + if (placeholderAPIExpansion.register()) { + logger.info("Successfully registered PlaceholderAPIExpansion!") + } else { + logger.warning("Failed to register PlaceholderAPIExpansion. Disabling plugin.") + server.pluginManager.disablePlugin(this) + return + } + + registerEvents() + registerCommands() + + loadAutoCompressStatus() + } + + override fun onDisable() { + placeholderAPIExpansion.unregister() + saveAutoCompressStatus() + } + + private fun registerEvents() { + val pluginManager = server.pluginManager + pluginManager.registerEvents(BlockBreakListener(this), this) + pluginManager.registerEvents(BlockPlaceListener(), this) + pluginManager.registerEvents(CraftItemListener(), this) + pluginManager.registerEvents(EntityPickupItemListener(this), this) + pluginManager.registerEvents(EntitySpawnListener(), this) + pluginManager.registerEvents(FurnaceBurnListener(this), this) + pluginManager.registerEvents(FurnaceSmeltListener(this), this) + pluginManager.registerEvents(PlayerDropItemListener(this), this) + pluginManager.registerEvents(PlayerJoinListener(this), this) + pluginManager.registerEvents(PlayerMoveListener(), this) + pluginManager.registerEvents(PrepareAnvilListener(), this) + pluginManager.registerEvents(PrepareItemEnchantListener(), this) + pluginManager.registerEvents(SignChangeListener(this), this) + } + + private fun registerCommands() { + Autocompress + Sky + Skyrtp + } + + internal fun isRestrictedMaterial(material: Material?): Boolean { + return material == Material.IRON_ORE || material == Material.RAW_IRON || material == Material.GOLD_ORE || material == Material.RAW_GOLD || material == Material.ANCIENT_DEBRIS || material == Material.SAND + } + + internal fun convertInventoryItemsPrep(player: Player, playerId: UUID?) { + if (autoCompressStatus.getOrDefault(playerId, false) == true) { + convertInventoryItems(player, Material.DIAMOND, Material.DIAMOND_BLOCK, 9, 1) + convertInventoryItems(player, Material.LAPIS_LAZULI, Material.LAPIS_BLOCK, 9, 1) + convertInventoryItems(player, Material.REDSTONE, Material.REDSTONE_BLOCK, 9, 1) + convertInventoryItems(player, Material.EMERALD, Material.EMERALD_BLOCK, 9, 1) + convertInventoryItems(player, Material.RAW_GOLD, Material.RAW_GOLD_BLOCK, 9, 1) + convertInventoryItems(player, Material.GOLD_INGOT, Material.GOLD_BLOCK, 9, 1) + convertInventoryItems(player, Material.GOLD_NUGGET, Material.GOLD_INGOT, 9, 1) + convertInventoryItems(player, Material.IRON_ORE, Material.IRON_BLOCK, 9, 1) + convertInventoryItems(player, Material.RAW_IRON, Material.RAW_IRON_BLOCK, 9, 1) + convertInventoryItems(player, Material.COAL, Material.COAL_BLOCK, 9, 1) + convertInventoryItems(player, Material.RAW_COPPER, Material.COPPER_BLOCK, 9, 1) + convertInventoryItems(player, Material.COPPER_INGOT, Material.COPPER_BLOCK, 9, 1) + convertInventoryItems(player, Material.QUARTZ, Material.QUARTZ_BLOCK, 4, 1) + } + } + + private fun convertInventoryItems( + player: Player, + fromMaterial: Material, + toMaterial: Material, + fromCount: Int, + toCount: Int + ) { + val inventoryContents = player.inventory.contents + + Bukkit.getScheduler().runTask(this, Runnable { + for (i in inventoryContents.indices) { + val item = inventoryContents[i] + + if (item != null && item.type == fromMaterial && item.amount >= fromCount) { + val stacksToConvert = item.amount / fromCount + val remainingItems = item.amount % fromCount + + if (stacksToConvert > 0) { + item.amount = remainingItems + player.inventory.setItem(i, item) + + val toMaterialStack = ItemStack(toMaterial, stacksToConvert * toCount) + val remaining = player.inventory.addItem(toMaterialStack) + + if (!remaining.isEmpty()) { + for (remainingItem in remaining.values) { + player.world.dropItem(player.location, remainingItem) + } + } + } + } + } + mergeInventoryStacks(player.inventory, fromMaterial) + }) + } + + private fun mergeInventoryStacks(inventory: Inventory, material: Material) { + var totalAmount = 0 + + for (item in inventory.contents) { + if (item != null && item.type == material) { + totalAmount += item.amount + item.amount = 0 + } + } + + val fullStacks = totalAmount / material.maxStackSize + val remainingItems = totalAmount % material.maxStackSize + + for (i in 0.. 0) { + inventory.addItem(ItemStack(material, remainingItems)) + } + } + + private fun saveAutoCompressStatus() { + val file = File(dataFolder, "autocompress.json") + val jsonObject = JSONObject() + + for (entry in autoCompressStatus.entries) { + jsonObject.put(entry.key.toString(), entry.value) + } + + try { + FileWriter(file).use { writer -> + writer.write(jsonObject.toJSONString()) + } + } catch (e: IOException) { + e.printStackTrace() + } + } + + private fun loadAutoCompressStatus() { + val file = File(dataFolder, "autocompress.json") + if (!file.exists()) { + return + } + + try { + FileReader(file).use { reader -> + val parser = JSONParser() + val jsonObject = parser.parse(reader) as JSONObject + for (key in jsonObject.keys) { + val playerId = UUID.fromString(key as String?) + val status = jsonObject.get(key) as Boolean? + autoCompressStatus.put(playerId, status) + } + } + } catch (e: IOException) { + e.printStackTrace() + } catch (e: ParseException) { + e.printStackTrace() + } + } + + internal fun isMuted(player: Player): Boolean { + return BanManagerPlugin.getInstance().playerMuteStorage.isMuted(player.uniqueId) + } + + companion object { + private lateinit var instance: GalaxyBoxPvPPlugin + + fun getInstance(): GalaxyBoxPvPPlugin { + return instance + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/PlaceholderAPIExpansion.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/PlaceholderAPIExpansion.kt new file mode 100644 index 0000000..4ecc382 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/PlaceholderAPIExpansion.kt @@ -0,0 +1,55 @@ +package xyz.lncvrt.galaxyboxpvp + +import com.booksaw.betterTeams.Team +import me.clip.placeholderapi.expansion.PlaceholderExpansion +import org.bukkit.ChatColor +import org.bukkit.Statistic +import org.bukkit.entity.Player +import javax.annotation.Nullable + +class PlaceholderAPIExpansion : PlaceholderExpansion() { + override fun getIdentifier(): String { + return "galaxyboxpvp" + } + + override fun getAuthor(): String { + return "Lncvrt" + } + + override fun getVersion(): String { + return "1.0.0" + } + + override fun persist(): Boolean { + return true + } + + override fun canRegister(): Boolean { + return true + } + + @Nullable + override fun onPlaceholderRequest(player: Player, identifier: String): String? { + when (identifier) { + "hearts" -> return String.format("%.1f", player.health / 2) + "kills" -> return player.getStatistic(Statistic.PLAYER_KILLS).toString() + "deaths" -> return player.getStatistic(Statistic.DEATHS).toString() + "kdr" -> { + val kills = player.getStatistic(Statistic.PLAYER_KILLS) + val deaths = player.getStatistic(Statistic.DEATHS) + return if (deaths == 0) kills.toString() else String.format("%.1f", kills.toDouble() / deaths) + } + "team" -> { + val team1: Team? = Team.getTeam(player) + if (team1 == null) return "" + return "%s[%s%s%s%s]%s ".format(ChatColor.GRAY, ChatColor.RESET, team1.displayName, ChatColor.RESET, ChatColor.GRAY, ChatColor.RESET) + } + "teamname" -> { + val team2: Team? = Team.getTeam(player) + if (team2 == null) return "None" + return team2.name + } + else -> return null + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Autocompress.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Autocompress.kt new file mode 100644 index 0000000..79ad532 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Autocompress.kt @@ -0,0 +1,26 @@ +package xyz.lncvrt.galaxyboxpvp.commands + +import org.incendo.cloud.kotlin.MutableCommandBuilder +import org.sayandev.stickynote.bukkit.command.BukkitCommand +import org.sayandev.stickynote.bukkit.command.BukkitSender +import org.sayandev.stickynote.bukkit.extension.sendComponent +import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvPPlugin + +object Autocompress : BukkitCommand("autocompress") { + override fun rootBuilder(builder: MutableCommandBuilder) { + builder.handler { context -> + val player = context.sender().player() ?: return@handler + val playerId = player.uniqueId + val instance = GalaxyBoxPvPPlugin.getInstance() + + val currentStatus = instance.autoCompressStatus.getOrDefault(playerId, false) ?: return@handler + instance.autoCompressStatus.put(playerId, !currentStatus) + + if (!currentStatus) { + player.sendComponent("Auto-compress enabled.") + } else { + player.sendComponent("Auto-compress disabled.") + } + } + } +} diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Sky.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Sky.kt new file mode 100644 index 0000000..78eb793 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Sky.kt @@ -0,0 +1,17 @@ +package xyz.lncvrt.galaxyboxpvp.commands + +import org.incendo.cloud.kotlin.MutableCommandBuilder +import org.sayandev.stickynote.bukkit.command.BukkitCommand +import org.sayandev.stickynote.bukkit.command.BukkitSender +import org.sayandev.stickynote.bukkit.extension.sendComponent + +object Sky : BukkitCommand("sky") { + override fun rootBuilder(builder: MutableCommandBuilder) { + builder.handler { context -> + val player = context.sender().player() ?: return@handler + + player.performCommand("warp sky") + player.sendComponent("You can do /skyrtp (click the bold text) to randomly teleport around here!") + } + } +} diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Skyrtp.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Skyrtp.kt new file mode 100644 index 0000000..8ac00c5 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Skyrtp.kt @@ -0,0 +1,44 @@ +package xyz.lncvrt.galaxyboxpvp.commands + +import org.bukkit.Location +import org.bukkit.Material +import org.bukkit.World +import org.bukkit.block.Block +import org.incendo.cloud.kotlin.MutableCommandBuilder +import org.sayandev.stickynote.bukkit.command.BukkitCommand +import org.sayandev.stickynote.bukkit.command.BukkitSender +import org.sayandev.stickynote.bukkit.extension.sendComponent +import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvPPlugin +import java.util.concurrent.ThreadLocalRandom + +object Skyrtp : BukkitCommand("skyrtp") { + override fun rootBuilder(builder: MutableCommandBuilder) { + builder.handler { context -> + val player = context.sender().player() ?: return@handler + val instance = GalaxyBoxPvPPlugin.getInstance() + + val last: Long? = instance.skyRTPDelays.get(player.uniqueId) + val time = System.currentTimeMillis() + if (last != null && time - last < 30000) { + val timeLeft = (30000 - (System.currentTimeMillis() - last)) / 1000 + player.sendComponent("You can't RTP in the sky world so often, please wait $timeLeft second(s)!") + return@handler + } + val world: World? = instance.server.getWorld("sky") + if (world == null) { + player.sendComponent("Failed, please try again!") + return@handler + } + val randomX = ThreadLocalRandom.current().nextInt(100, 15000) + val randomZ = ThreadLocalRandom.current().nextInt(100, 15000) + val location = Location(world, randomX.toDouble(), 100.0, randomZ.toDouble()) + val block: Block = world.getBlockAt(location) + if (block.type === Material.AIR) { + block.type = Material.GRASS_BLOCK + } + player.teleport(location.add(0.5, 1.0, 0.5)) + player.sendComponent("You have been randomly teleported to $randomX 100 $randomZ") + instance.skyRTPDelays.put(player.uniqueId, time) + } + } +} diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/BlockBreakListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/BlockBreakListener.kt new file mode 100644 index 0000000..d49d57f --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/BlockBreakListener.kt @@ -0,0 +1,17 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.block.BlockBreakEvent +import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvPPlugin + +class BlockBreakListener(private val plugin: GalaxyBoxPvPPlugin) : Listener { + @EventHandler + fun onBlockBreak(event: BlockBreakEvent) { + val player = event.player + plugin.convertInventoryItemsPrep(player, player.uniqueId) + if (event.getBlock().location.y == 100.0 && event.getBlock().world.name == "world") { + event.isCancelled = true + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/BlockPlaceListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/BlockPlaceListener.kt new file mode 100644 index 0000000..2d6577f --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/BlockPlaceListener.kt @@ -0,0 +1,20 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.Material +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.block.BlockPlaceEvent +import org.sayandev.stickynote.bukkit.extension.sendComponent + +class BlockPlaceListener() : Listener { + @EventHandler + fun onBlockPlace(event: BlockPlaceEvent) { + if (event.blockPlaced.type == Material.POLISHED_BLACKSTONE_BUTTON) { + if (event.getItemInHand().hasItemMeta() && event.getItemInHand().itemMeta.hasDisplayName()) { + event.isCancelled = true //temp fix + } + } else if (event.blockPlaced.type == Material.FURNACE || event.blockPlaced.type == Material.FURNACE_MINECART || event.blockPlaced.type == Material.BLAST_FURNACE) { + event.getPlayer().sendComponent("[TIP] If you are trying to smelt iron, gold, etc you can use the Smelter Shop. Click [HERE] to teleport to the smelter shop!") + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/CraftItemListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/CraftItemListener.kt new file mode 100644 index 0000000..80983a8 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/CraftItemListener.kt @@ -0,0 +1,22 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.Material +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.inventory.CraftItemEvent + +class CraftItemListener : Listener { + @EventHandler + fun onCraftItem(event: CraftItemEvent) { + if (event.currentItem != null && event.currentItem!!.type == Material.DIAMOND_PICKAXE) { + val pickaxe = event.currentItem + val meta = pickaxe!!.itemMeta + + if (meta != null) { + meta.isUnbreakable = true + pickaxe.setItemMeta(meta) + event.currentItem = pickaxe + } + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/EntityPickupItemListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/EntityPickupItemListener.kt new file mode 100644 index 0000000..92f9573 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/EntityPickupItemListener.kt @@ -0,0 +1,18 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.entity.Player +import org.bukkit.event.EventHandler +import org.bukkit.event.EventPriority +import org.bukkit.event.Listener +import org.bukkit.event.entity.EntityPickupItemEvent +import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvPPlugin + +class EntityPickupItemListener(private val plugin: GalaxyBoxPvPPlugin) : Listener { + @EventHandler(priority = EventPriority.LOWEST) + fun onItemPickup(event: EntityPickupItemEvent) { + if (event.getEntity() is Player) { + val player = event.entity as Player + plugin.convertInventoryItemsPrep(player, player.uniqueId) + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/EntitySpawnListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/EntitySpawnListener.kt new file mode 100644 index 0000000..5f62ed9 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/EntitySpawnListener.kt @@ -0,0 +1,13 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.entity.EntityType +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.entity.EntitySpawnEvent + +class EntitySpawnListener : Listener { + @EventHandler + fun onEntitySpawnEvent(event: EntitySpawnEvent) { + if (event.entityType == EntityType.WITHER) event.isCancelled = true + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/FurnaceBurnListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/FurnaceBurnListener.kt new file mode 100644 index 0000000..afc4d48 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/FurnaceBurnListener.kt @@ -0,0 +1,17 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.Material +import org.bukkit.block.Furnace +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.inventory.FurnaceBurnEvent +import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvPPlugin + +class FurnaceBurnListener(private val plugin: GalaxyBoxPvPPlugin) : Listener { + @EventHandler + fun onFurnaceBurn(event: FurnaceBurnEvent) { + val furnace: Furnace = event.getBlock().state as Furnace + val smelting: Material? = furnace.inventory.smelting?.type + if (plugin.isRestrictedMaterial(smelting)) event.isCancelled = true + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/FurnaceSmeltListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/FurnaceSmeltListener.kt new file mode 100644 index 0000000..1c670ec --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/FurnaceSmeltListener.kt @@ -0,0 +1,14 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.inventory.FurnaceSmeltEvent +import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvPPlugin + +class FurnaceSmeltListener(private val plugin: GalaxyBoxPvPPlugin) : Listener { + @EventHandler + fun onFurnaceSmelt(event: FurnaceSmeltEvent) { + val smelted = event.source.type + if (plugin.isRestrictedMaterial(smelted)) event.isCancelled = true + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerDropItemListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerDropItemListener.kt new file mode 100644 index 0000000..8eec2ce --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerDropItemListener.kt @@ -0,0 +1,14 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.event.EventHandler +import org.bukkit.event.EventPriority +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerDropItemEvent +import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvPPlugin + +class PlayerDropItemListener(private val plugin: GalaxyBoxPvPPlugin) : Listener { + @EventHandler(priority = EventPriority.LOWEST) + fun onItemDrop(event: PlayerDropItemEvent) { + plugin.convertInventoryItemsPrep(event.getPlayer(), event.getPlayer().uniqueId) + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerJoinListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerJoinListener.kt new file mode 100644 index 0000000..797b27a --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerJoinListener.kt @@ -0,0 +1,18 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerJoinEvent +import org.sayandev.stickynote.bukkit.extension.sendComponent +import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvPPlugin + +class PlayerJoinListener(private val plugin: GalaxyBoxPvPPlugin) : Listener { + @EventHandler + fun onPlayerJoin(event: PlayerJoinEvent) { + val player = event.getPlayer() + val playerId = player.uniqueId + + if (!plugin.autoCompressStatus.containsKey(playerId)) plugin.autoCompressStatus.put(playerId, false) + player.sendComponent("Welcome to LncvrtBox, ${player.name}! This is a PvP arena gamemode that was originally called LncvrtBox, and is almost a year old! We reset the server for GalaxyNetwork and a fresh start") + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerMoveListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerMoveListener.kt new file mode 100644 index 0000000..ad975d5 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerMoveListener.kt @@ -0,0 +1,18 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerMoveEvent + +class PlayerMoveListener : Listener { + @EventHandler + private fun onSignPlace(event: PlayerMoveEvent) { + val player = event.getPlayer() + val maxY = player.world.maxHeight + if (player.location.y >= maxY) { + val newLocation = player.location.clone() + newLocation.y = (maxY - 1).toDouble() + player.teleport(newLocation) + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PrepareAnvilListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PrepareAnvilListener.kt new file mode 100644 index 0000000..2a298da --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PrepareAnvilListener.kt @@ -0,0 +1,21 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.Material +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.inventory.PrepareAnvilEvent + +class PrepareAnvilListener : Listener { + @EventHandler + fun onPrepareAnvil(event: PrepareAnvilEvent) { + val left = event.inventory.getItem(0) + val right = event.inventory.getItem(1) + + if (left != null && (left.type == Material.DIAMOND_PICKAXE || left.type == Material.NETHERITE_PICKAXE)) { + event.result = null + } + if (right != null && (right.type == Material.DIAMOND_PICKAXE || right.type == Material.NETHERITE_PICKAXE)) { + event.result = null + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PrepareItemEnchantListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PrepareItemEnchantListener.kt new file mode 100644 index 0000000..98e5f1f --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PrepareItemEnchantListener.kt @@ -0,0 +1,14 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.Material +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.enchantment.PrepareItemEnchantEvent + +class PrepareItemEnchantListener : Listener { + @EventHandler + fun onPrepareItemEnchant(event: PrepareItemEnchantEvent) { + val item = event.item + if (item.type == Material.DIAMOND_PICKAXE || item.type == Material.NETHERITE_PICKAXE) event.isCancelled = true + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/SignChangeListener.kt b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/SignChangeListener.kt new file mode 100644 index 0000000..3a8638e --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/SignChangeListener.kt @@ -0,0 +1,13 @@ +package xyz.lncvrt.galaxyboxpvp.events + +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.block.SignChangeEvent +import xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvPPlugin + +class SignChangeListener(private val plugin: GalaxyBoxPvPPlugin) : Listener { + @EventHandler + private fun onSignPlace(event: SignChangeEvent) { + if (plugin.isMuted(event.player)) event.isCancelled = true + } +} \ No newline at end of file diff --git a/src/main/resources/plugin.yml b/src/main/resources/plugin.yml deleted file mode 100644 index f9ecad6..0000000 --- a/src/main/resources/plugin.yml +++ /dev/null @@ -1,18 +0,0 @@ -name: GalaxyBoxPvP -version: '${version}' -main: xyz.lncvrt.galaxyboxpvp.GalaxyBoxPvP -api-version: '1.21' -depend: - - PlaceholderAPI - - Essentials - - BetterTeams -commands: - autocompress: - description: Auto compressor - usage: /autocompress - sky: - description: Teleports you to sky world - usage: /sky - skyrtp: - description: Teleports you to a random location in sky world - usage: /sky \ No newline at end of file