From df4243b7df1ee23b20352341ca81141828da431e Mon Sep 17 00:00:00 2001 From: Lncvrt Date: Tue, 8 Apr 2025 20:51:51 -0700 Subject: [PATCH] Switch to Kotlin, Gradle and Stickynote by Syrent --- .gitignore | 32 ++- LICENSE => LICENSE.txt | 2 +- README.md | 5 + build.gradle.kts | 108 ++++++++ gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 43705 bytes gradle/wrapper/gradle-wrapper.properties | 7 + gradlew | 251 ++++++++++++++++++ gradlew.bat | 94 +++++++ pom.xml | 78 ------ settings.gradle.kts | 15 ++ .../xyz/lncvrt/galaxyboxpvp/GalaxyBoxPvP.java | 194 -------------- .../galaxyboxpvp/PlaceholderAPIExpansion.java | 62 ----- .../galaxyboxpvp/commands/Autocompress.java | 36 --- .../xyz/lncvrt/galaxyboxpvp/commands/Sky.java | 19 -- .../lncvrt/galaxyboxpvp/commands/Skyrtp.java | 51 ---- .../events/BlockBreakListener.java | 24 -- .../events/BlockPlaceListener.java | 26 -- .../events/CraftItemListener.java | 24 -- .../events/EntityPickupItemListener.java | 21 -- .../events/EntitySpawnListener.java | 13 - .../events/FurnaceBurnListener.java | 25 -- .../events/FurnaceSmeltListener.java | 21 -- .../events/PlayerDropItemListener.java | 20 -- .../events/PlayerJoinListener.java | 28 -- .../events/PlayerMoveListener.java | 20 -- .../events/PrepareAnvilListener.java | 22 -- .../events/PrepareItemEnchantListener.java | 15 -- .../events/ProjectileHitListener.java | 21 -- .../events/SignChangeListener.java | 19 -- .../lncvrt/galaxyboxpvp/GalaxyBoxPvPPlugin.kt | 207 +++++++++++++++ .../galaxyboxpvp/PlaceholderAPIExpansion.kt | 55 ++++ .../galaxyboxpvp/commands/Autocompress.kt | 26 ++ .../xyz/lncvrt/galaxyboxpvp/commands/Sky.kt | 17 ++ .../lncvrt/galaxyboxpvp/commands/Skyrtp.kt | 44 +++ .../galaxyboxpvp/events/BlockBreakListener.kt | 17 ++ .../galaxyboxpvp/events/BlockPlaceListener.kt | 20 ++ .../galaxyboxpvp/events/CraftItemListener.kt | 22 ++ .../events/EntityPickupItemListener.kt | 18 ++ .../events/EntitySpawnListener.kt | 13 + .../events/FurnaceBurnListener.kt | 17 ++ .../events/FurnaceSmeltListener.kt | 14 + .../events/PlayerDropItemListener.kt | 14 + .../galaxyboxpvp/events/PlayerJoinListener.kt | 18 ++ .../galaxyboxpvp/events/PlayerMoveListener.kt | 18 ++ .../events/PrepareAnvilListener.kt | 21 ++ .../events/PrepareItemEnchantListener.kt | 14 + .../galaxyboxpvp/events/SignChangeListener.kt | 13 + src/main/resources/plugin.yml | 18 -- 48 files changed, 1069 insertions(+), 770 deletions(-) rename LICENSE => LICENSE.txt (97%) create mode 100644 README.md create mode 100644 build.gradle.kts create mode 100644 gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/wrapper/gradle-wrapper.properties create mode 100644 gradlew create mode 100644 gradlew.bat delete mode 100644 pom.xml create mode 100644 settings.gradle.kts delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/GalaxyBoxPvP.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/PlaceholderAPIExpansion.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Autocompress.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Sky.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/commands/Skyrtp.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/BlockBreakListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/BlockPlaceListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/CraftItemListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/EntityPickupItemListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/EntitySpawnListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/FurnaceBurnListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/FurnaceSmeltListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerDropItemListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerJoinListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/PlayerMoveListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/PrepareAnvilListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/PrepareItemEnchantListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/ProjectileHitListener.java delete mode 100644 src/main/java/xyz/lncvrt/galaxyboxpvp/events/SignChangeListener.java create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/GalaxyBoxPvPPlugin.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/PlaceholderAPIExpansion.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Autocompress.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Sky.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/commands/Skyrtp.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/BlockBreakListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/BlockPlaceListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/CraftItemListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/EntityPickupItemListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/EntitySpawnListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/FurnaceBurnListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/FurnaceSmeltListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerDropItemListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerJoinListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PlayerMoveListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PrepareAnvilListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/PrepareItemEnchantListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxyboxpvp/events/SignChangeListener.kt delete mode 100644 src/main/resources/plugin.yml 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 0000000000000000000000000000000000000000..9bbc975c742b298b441bfb90dbc124400a3751b9 GIT binary patch literal 43705 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 a;23lZ@MdKLX;x%VWDwwGV3<4?!~*~~4acnj literal 0 HcmV?d00001 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