From df3d8aa03c9f6625deeb93e47099d342b58df986 Mon Sep 17 00:00:00 2001 From: Lncvrt Date: Tue, 15 Apr 2025 19:37:24 -0700 Subject: [PATCH] Initial commit --- .gitattributes | 2 + .gitignore | 119 +++++++++ LICENSE.txt | 21 ++ README.md | 3 + build.gradle.kts | 107 ++++++++ gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 43705 bytes gradle/wrapper/gradle-wrapper.properties | 7 + gradlew | 251 ++++++++++++++++++ gradlew.bat | 94 +++++++ settings.gradle.kts | 16 ++ .../lncvrt/galaxylobby/GalaxyLobbyPlugin.kt | 87 ++++++ .../galaxylobby/command/DiscordCommand.kt | 16 ++ .../galaxylobby/command/WebsiteCommand.kt | 16 ++ .../listener/InventoryClickListener.kt | 17 ++ .../listener/PlayerGameModeChangeListener.kt | 22 ++ .../listener/PlayerInteractListener.kt | 37 +++ .../listener/PlayerItemDamageListener.kt | 12 + .../listener/PlayerItemHeldListener.kt | 22 ++ .../listener/PlayerJoinListener.kt | 31 +++ .../listener/PlayerMoveListener.kt | 89 +++++++ .../listener/PlayerMoveListenerOld.kt | 92 +++++++ .../listener/PlayerSwapHandItemsListener.kt | 13 + .../listener/PlayerToggleFlightListener.kt | 26 ++ .../listener/ProjectileLaunchListener.kt | 29 ++ 24 files changed, 1129 insertions(+) create mode 100644 .gitattributes create mode 100644 .gitignore create mode 100644 LICENSE.txt 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 create mode 100644 settings.gradle.kts create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/GalaxyLobbyPlugin.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/command/DiscordCommand.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/command/WebsiteCommand.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/InventoryClickListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerGameModeChangeListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerInteractListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerItemDamageListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerItemHeldListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerJoinListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerMoveListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerMoveListenerOld.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerSwapHandItemsListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerToggleFlightListener.kt create mode 100644 src/main/kotlin/xyz/lncvrt/galaxylobby/listener/ProjectileLaunchListener.kt diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 0000000..dfe0770 --- /dev/null +++ b/.gitattributes @@ -0,0 +1,2 @@ +# Auto detect text files and perform LF normalization +* text=auto diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..d5f737e --- /dev/null +++ b/.gitignore @@ -0,0 +1,119 @@ +# User-specific stuff +.idea/ + +*.iml +*.ipr +*.iws + +# IntelliJ +out/ +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Compiled class file +*.class + +# Log file +*.log + +# BlueJ files +*.ctxt + +# Package Files # +*.jar +*.war +*.nar +*.ear +*.zip +*.tar.gz +*.rar + +# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml +hs_err_pid* + +*~ + +# temporary files which can be created if a process still has a handle open of a deleted file +.fuse_hidden* + +# KDE directory preferences +.directory + +# Linux trash folder which might appear on any partition or disk +.Trash-* + +# .nfs files are created when an open file is removed but is still being accessed +.nfs* + +# General +.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + +# Thumbnails +._* + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.Spotlight-V100 +.TemporaryItems +.Trashes +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# Windows thumbnail cache files +Thumbs.db +Thumbs.db:encryptable +ehthumbs.db +ehthumbs_vista.db + +# Dump file +*.stackdump + +# Folder config file +[Dd]esktop.ini + +# Recycle Bin used on file shares +$RECYCLE.BIN/ + +# Windows Installer files +*.cab +*.msi +*.msix +*.msm +*.msp + +# Windows shortcuts +*.lnk + +.gradle +build/ + +# Ignore Gradle GUI config +gradle-app.setting + +# Cache of project +.gradletasknamecache + +**/build/ + +# Common working directory +run/ +runs/ + +# Avoid ignoring Gradle wrapper jar file (.jar files are usually ignored) +!gradle-wrapper.jar diff --git a/LICENSE.txt b/LICENSE.txt new file mode 100644 index 0000000..5e52004 --- /dev/null +++ b/LICENSE.txt @@ -0,0 +1,21 @@ +MIT License + +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 +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/README.md b/README.md new file mode 100644 index 0000000..fda13eb --- /dev/null +++ b/README.md @@ -0,0 +1,3 @@ +# GalaxyLobby + +The plugin used for the lobby server on GalaxyNetwork diff --git a/build.gradle.kts b/build.gradle.kts new file mode 100644 index 0000000..94b739a --- /dev/null +++ b/build.gradle.kts @@ -0,0 +1,107 @@ +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.lncvrt.xyz/releases") + maven("https://repo.lncvrt.xyz/snapshots") +} + +dependencies { + compileOnly("io.papermc.paper:paper-api:1.20.1-R0.1-SNAPSHOT") + compileOnly("xyz.lncvrt:galaxyapi:1.0.6") +} + +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.20.1") + + javaLauncher = project.javaToolchains.launcherFor { + vendor = JvmVendorSpec.JETBRAINS + languageVersion = JavaLanguageVersion.of("21") + } + + jvmArgs("-XX:+AllowEnhancedClassRedefinition") + } + + 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" + foliaSupported = true + apiVersion = "1.20" + 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/settings.gradle.kts b/settings.gradle.kts new file mode 100644 index 0000000..ff8d6ef --- /dev/null +++ b/settings.gradle.kts @@ -0,0 +1,16 @@ + +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" + id("org.gradle.toolchains.foojay-resolver-convention") version "0.9.0" +} + +rootProject.name = "GalaxyLobby" \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/GalaxyLobbyPlugin.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/GalaxyLobbyPlugin.kt new file mode 100644 index 0000000..a51023c --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/GalaxyLobbyPlugin.kt @@ -0,0 +1,87 @@ +package xyz.lncvrt.galaxylobby + +import net.kyori.adventure.text.minimessage.MiniMessage +import org.bukkit.GameMode +import org.bukkit.Location +import org.bukkit.Material +import org.bukkit.attribute.Attribute +import org.bukkit.entity.Player +import org.bukkit.inventory.ItemStack +import org.bukkit.plugin.java.JavaPlugin +import org.bukkit.potion.PotionEffect +import org.bukkit.potion.PotionEffectType +import org.sayandev.stickynote.loader.bukkit.StickyNoteBukkitLoader +import xyz.lncvrt.galaxyapi.utils.MessageFormat +import xyz.lncvrt.galaxylobby.command.DiscordCommand +import xyz.lncvrt.galaxylobby.command.WebsiteCommand +import xyz.lncvrt.galaxylobby.listener.* +import java.util.* + + +class GalaxyLobbyPlugin : JavaPlugin() { + internal val jumpPadCooldowns = HashMap() + internal val cooldowns = HashMap>() + internal val miniMessage: MiniMessage = MiniMessage.miniMessage() + + override fun onEnable() { + StickyNoteBukkitLoader(this) + DiscordCommand + WebsiteCommand + registerEvents() + } + + private fun registerEvents() { + val pluginManager = server.pluginManager + pluginManager.registerEvents(InventoryClickListener(), this) + pluginManager.registerEvents(PlayerGameModeChangeListener(this), this) + pluginManager.registerEvents(PlayerInteractListener(this), this) + pluginManager.registerEvents(PlayerItemDamageListener(), this) + pluginManager.registerEvents(PlayerItemHeldListener(), this) + pluginManager.registerEvents(PlayerJoinListener(this), this) + pluginManager.registerEvents(PlayerMoveListener(this), this) + pluginManager.registerEvents(PlayerSwapHandItemsListener(), this) + pluginManager.registerEvents(PlayerToggleFlightListener(), this) + pluginManager.registerEvents(ProjectileLaunchListener(this), this) + } + + internal fun resetPlayer(player: Player, teleport: Boolean, setGamemode: Boolean) { + val effect = PotionEffect(PotionEffectType.SPEED, PotionEffect.INFINITE_DURATION, 1, false, false) + + player.inventory.clear() + player.inventory.heldItemSlot = 4 + + val discordItem = ItemStack(Material.DIAMOND) + val discordMeta = discordItem.itemMeta + discordMeta.displayName(miniMessage.deserialize(MessageFormat.setPrimaryColor("Our Socials ${MessageFormat.setSecondaryColor("(Right Click)")}"))) + discordItem.setItemMeta(discordMeta) + player.inventory.setItem(1, discordItem) + + val serverSelectorItem = ItemStack(Material.NETHER_STAR) + val serverSelectorMeta = serverSelectorItem.itemMeta + serverSelectorMeta.displayName(miniMessage.deserialize(MessageFormat.setPrimaryColor("Server Selector ${MessageFormat.setSecondaryColor("(Right Click)")}"))) + serverSelectorItem.setItemMeta(serverSelectorMeta) + player.inventory.setItem(4, serverSelectorItem) + + val fireworkItem = ItemStack(Material.FIREWORK_ROCKET) + val fireworkMeta = fireworkItem.itemMeta + fireworkMeta.displayName(miniMessage.deserialize(MessageFormat.setPrimaryColor("Elytra ${MessageFormat.setSecondaryColor("(Fly around the lobby!)")}"))) + fireworkItem.setItemMeta(fireworkMeta) + player.inventory.setItem(7, fireworkItem) + + player.health = player.getAttribute(Attribute.GENERIC_MAX_HEALTH)?.value ?: 20.0 + player.foodLevel = 20 + player.saturation = 20f + player.clearActivePotionEffects() + player.addPotionEffect(effect) + if (setGamemode) player.gameMode = GameMode.ADVENTURE + + if (teleport) { + val world = server.getWorld("world") + player.teleport(Location(world, 0.5, 65.0, 0.5, 0F, 0F)) + } + } + + internal fun resetPlayer(player: Player, teleport: Boolean) { + resetPlayer(player, teleport, true) + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/command/DiscordCommand.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/command/DiscordCommand.kt new file mode 100644 index 0000000..a4bbad6 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/command/DiscordCommand.kt @@ -0,0 +1,16 @@ +package xyz.lncvrt.galaxylobby.command + +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.galaxyapi.utils.MessageFormat + +object DiscordCommand : BukkitCommand("discord") { + override fun rootBuilder(builder: MutableCommandBuilder) { + builder.handler { context -> + val player = context.sender().player() ?: return@handler + player.sendComponent(MessageFormat.setPrefix(MessageFormat.setPrimaryColor("Click ${MessageFormat.setSecondaryColor("HERE")} to join our Discord Server!"))) + } + } +} diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/command/WebsiteCommand.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/command/WebsiteCommand.kt new file mode 100644 index 0000000..295967d --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/command/WebsiteCommand.kt @@ -0,0 +1,16 @@ +package xyz.lncvrt.galaxylobby.command + +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.galaxyapi.utils.MessageFormat + +object WebsiteCommand : BukkitCommand("website") { + override fun rootBuilder(builder: MutableCommandBuilder) { + builder.handler { context -> + val player = context.sender().player() ?: return@handler + player.sendComponent(MessageFormat.setPrefix(MessageFormat.setPrimaryColor("Click ${MessageFormat.setSecondaryColor("HERE")} to view our Website!"))) + } + } +} diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/InventoryClickListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/InventoryClickListener.kt new file mode 100644 index 0000000..ac9df22 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/InventoryClickListener.kt @@ -0,0 +1,17 @@ +package xyz.lncvrt.galaxylobby.listener + +import org.bukkit.GameMode +import org.bukkit.entity.Player +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.inventory.InventoryClickEvent + +class InventoryClickListener : Listener { + @EventHandler + fun onInventoryClickEvent(event: InventoryClickEvent) { + val entity = event.whoClicked + if (entity is Player) { + if (entity.gameMode != GameMode.CREATIVE) event.isCancelled = true + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerGameModeChangeListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerGameModeChangeListener.kt new file mode 100644 index 0000000..37a0fb8 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerGameModeChangeListener.kt @@ -0,0 +1,22 @@ +package xyz.lncvrt.galaxylobby.listener + +import org.bukkit.GameMode +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerGameModeChangeEvent +import xyz.lncvrt.galaxylobby.GalaxyLobbyPlugin + +class PlayerGameModeChangeListener(val plugin: GalaxyLobbyPlugin) : Listener { + @EventHandler + fun onPlayerGameModeChangeEvent(event: PlayerGameModeChangeEvent) { + val player = event.getPlayer() + if (event.newGameMode === GameMode.CREATIVE) { + player.inventory.clear() + } else if (event.newGameMode === GameMode.ADVENTURE) { + plugin.resetPlayer(player, false, false) + } else { + event.isCancelled = true + player.gameMode = GameMode.ADVENTURE + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerInteractListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerInteractListener.kt new file mode 100644 index 0000000..3f93df1 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerInteractListener.kt @@ -0,0 +1,37 @@ +package xyz.lncvrt.galaxylobby.listener + +import net.kyori.adventure.text.serializer.plain.PlainTextComponentSerializer +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.block.Action +import org.bukkit.event.player.PlayerInteractEvent +import org.sayandev.stickynote.bukkit.extension.sendComponent +import xyz.lncvrt.galaxyapi.utils.CommandHelper +import xyz.lncvrt.galaxyapi.utils.MessageFormat +import xyz.lncvrt.galaxylobby.GalaxyLobbyPlugin + +class PlayerInteractListener(val plugin: GalaxyLobbyPlugin) : Listener { + @EventHandler + fun onPlayerInteractEvent(event: PlayerInteractEvent) { + if (event.getAction() !== Action.RIGHT_CLICK_AIR && event.getAction() !== Action.RIGHT_CLICK_BLOCK) { + return + } + + val player = event.getPlayer() + val item = player.inventory.itemInMainHand + val name = PlainTextComponentSerializer.plainText().serialize(item.displayName().asComponent()) + + val playerCooldowns = plugin.cooldowns.computeIfAbsent(player) { HashMap() } + + val currentTime = System.currentTimeMillis() + + if (playerCooldowns.containsKey(name) && currentTime - playerCooldowns[name]!! < 1000) return + + when (name) { + "[Our Socials (Right Click)]" -> player.sendComponent(MessageFormat.setPrefix(MessageFormat.setPrimaryColor("Click ${MessageFormat.setSecondaryColor("HERE")} to join our Discord Server, or click ${MessageFormat.setSecondaryColor("HERE")} to view our Website!"))) + "[Server Selector (Right Click)]" -> CommandHelper().executeAsConsole("dmenu open serverselector ${player.name}") + } + + playerCooldowns.put(name, currentTime) + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerItemDamageListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerItemDamageListener.kt new file mode 100644 index 0000000..f6f4e9b --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerItemDamageListener.kt @@ -0,0 +1,12 @@ +package xyz.lncvrt.galaxylobby.listener + +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerItemDamageEvent + +class PlayerItemDamageListener : Listener { + @EventHandler + fun onItemDurabilityChange(event: PlayerItemDamageEvent) { + event.isCancelled = true + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerItemHeldListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerItemHeldListener.kt new file mode 100644 index 0000000..5c6ffb1 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerItemHeldListener.kt @@ -0,0 +1,22 @@ +package xyz.lncvrt.galaxylobby.listener + +import org.bukkit.GameMode +import org.bukkit.Material +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerItemHeldEvent +import org.bukkit.inventory.ItemStack + +class PlayerItemHeldListener : Listener { + @EventHandler + fun onPlayerItemHeldEvent(event: PlayerItemHeldEvent) { + val player = event.getPlayer() + if (player.gameMode == GameMode.ADVENTURE) { + if (event.newSlot == 7) { + player.inventory.chestplate = ItemStack(Material.ELYTRA) + } else { + player.inventory.chestplate = null + } + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerJoinListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerJoinListener.kt new file mode 100644 index 0000000..77b5b65 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerJoinListener.kt @@ -0,0 +1,31 @@ +package xyz.lncvrt.galaxylobby.listener + +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.galaxyapi.utils.MessageFormat +import xyz.lncvrt.galaxylobby.GalaxyLobbyPlugin + +class PlayerJoinListener(val plugin: GalaxyLobbyPlugin) : Listener { + @EventHandler + fun onPlayerJoinEvent(event: PlayerJoinEvent) { + val player = event.getPlayer() + + plugin.server.scheduler.runTaskLater(plugin, Runnable { + plugin.resetPlayer(player, true) + }, 1) + + plugin.server.scheduler.runTaskLater(plugin, Runnable { + player.sendComponent("+---------------------***---------------------+") + player.sendMessage("") + player.sendComponent("Welcome to ${MessageFormat.name()}, ${MessageFormat.setPrimaryColor("${player.name}")}!") + player.sendMessage("") + player.sendComponent("${MessageFormat.setPrimaryColor("WEBSITE:")} ${MessageFormat.setSecondaryColor("galaxy.lncvrt.xyz")}") + player.sendComponent("${MessageFormat.setPrimaryColor("DISCORD:")} ${MessageFormat.setSecondaryColor("galaxy.lncvrt.xyz/discord")}") + player.sendMessage("") + player.sendComponent("+---------------------***---------------------+") + player.sendComponent("Please note, we are working on improving this server to make it a more enjoyable place, we spend a lot of time and even develop our own plugins (click). It takes a lot of time and effort :)") + }, 5) + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerMoveListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerMoveListener.kt new file mode 100644 index 0000000..51d391c --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerMoveListener.kt @@ -0,0 +1,89 @@ +package xyz.lncvrt.galaxylobby.listener + +import org.bukkit.GameMode +import org.bukkit.Material +import org.bukkit.Sound +import org.bukkit.World +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerMoveEvent +import org.bukkit.util.Vector +import org.sayandev.stickynote.bukkit.extension.sendComponent +import xyz.lncvrt.galaxyapi.utils.MessageFormat +import xyz.lncvrt.galaxylobby.GalaxyLobbyPlugin + +class PlayerMoveListener(val plugin: GalaxyLobbyPlugin) : Listener { + @EventHandler + fun onPlayerMove(event: PlayerMoveEvent) { + val player = event.getPlayer() + val location = player.location + + if (location.y < 0) { + plugin.resetPlayer(player, true) + player.sendComponent(MessageFormat.setPrefix("You happy with yourself?")) + } else if (location.y > 200) { + location.y = 200.0 + player.teleport(location) + player.sendComponent(MessageFormat.setPrefix(MessageFormat.setSecondaryColor("You can't go that high!"))) + } + } + + @EventHandler + fun onPlayerMoveLaunchPad(event: PlayerMoveEvent) { + val player = event.getPlayer() + val world: World? = plugin.server.getWorld("world") + if (world == null) return + val playerBlock = world.getBlockAt(player.location) + + val playerId = player.uniqueId + val currentTime = System.currentTimeMillis() + + if (plugin.jumpPadCooldowns.containsKey(playerId)) { + val lastActivation: Long = plugin.jumpPadCooldowns.get(playerId)!! + if (currentTime - lastActivation < 1000) return + } + + if (playerBlock.type === Material.CHERRY_PRESSURE_PLATE) { + plugin.jumpPadCooldowns.put(playerId, currentTime) + + if (player.gameMode == GameMode.ADVENTURE && player.inventory.heldItemSlot == 7) { + player.velocity = Vector(0, 1, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.0f) + player.sendComponent(MessageFormat.setPrefix("Hacks!?!?!?!")) + val scheduler = plugin.server.scheduler + scheduler.runTaskLater(plugin, Runnable { + player.velocity = Vector(0, 2, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.0f) + }, 10) + scheduler.runTaskLater(plugin, Runnable { + player.velocity = Vector(0, 2, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.0f) + }, 20) + scheduler.runTaskLater(plugin, Runnable { + player.velocity = Vector(0, 2, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.0f) + }, 30) + scheduler.runTaskLater(plugin, Runnable { + player.velocity = Vector(0, 5, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.25f) + }, 40) + return + } + player.velocity = Vector(0.0, 1.0, 3.5) + player.playSound(player.location, Sound.ENTITY_BAT_TAKEOFF, 1.0f, 1.0f) + } + } + + @EventHandler + fun onPlayerMoveDoubleJump(event: PlayerMoveEvent) { + val player = event.getPlayer() + + if (!player.isFlying && player.gameMode == GameMode.ADVENTURE) { + if (player.inventory.heldItemSlot == 7) { + player.allowFlight = false + return + } + player.allowFlight = true + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerMoveListenerOld.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerMoveListenerOld.kt new file mode 100644 index 0000000..5fc792d --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerMoveListenerOld.kt @@ -0,0 +1,92 @@ +package xyz.lncvrt.galaxylobby.listener + +import org.bukkit.GameMode +import org.bukkit.Material +import org.bukkit.Sound +import org.bukkit.World +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerMoveEvent +import org.bukkit.util.Vector +import org.sayandev.stickynote.bukkit.extension.sendComponent +import xyz.lncvrt.galaxyapi.utils.MessageFormat +import xyz.lncvrt.galaxylobby.GalaxyLobbyPlugin + + +class PlayerMoveListenerOld(val plugin: GalaxyLobbyPlugin) : Listener { + @EventHandler + fun onPlayerMove(event: PlayerMoveEvent) { + val player = event.getPlayer() + val location = player.location + + if (location.y < 0) { + plugin.resetPlayer(player, true) + player.sendComponent(MessageFormat.setPrefix("You happy with yourself?")) + } else if (location.y > 200) { + location.y = 200.0 + player.teleport(location) + player.sendComponent(MessageFormat.setPrefix(MessageFormat.setSecondaryColor("You can't go that high!"))) + } + } + + @EventHandler + fun onPlayerMoveLaunchPad(event: PlayerMoveEvent) { + val player = event.getPlayer() + val world: World? = plugin.server.getWorld("world") + if (world == null) return + val playerBlock = world.getBlockAt(player.location) + + val playerId = player.uniqueId + val currentTime = System.currentTimeMillis() + + if (plugin.jumpPadCooldowns.containsKey(playerId)) { + val lastActivation: Long = plugin.jumpPadCooldowns.get(playerId)!! + if (currentTime - lastActivation < 1000) return + } + + if (playerBlock.type === Material.CHERRY_PRESSURE_PLATE) { + plugin.jumpPadCooldowns.put(playerId, currentTime) + + if (player.gameMode == GameMode.ADVENTURE && player.inventory.heldItemSlot == 7) { + player.velocity = Vector(0, 1, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.0f) + player.sendComponent(MessageFormat.setPrefix("Hacks!?!?!?!")) + val scheduler = plugin.server.scheduler + scheduler.runTaskLater(plugin, Runnable { + player.velocity = Vector(0, 2, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.0f) + }, 10) + scheduler.runTaskLater(plugin, Runnable { + player.velocity = Vector(0, 2, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.0f) + }, 20) + scheduler.runTaskLater(plugin, Runnable { + player.velocity = Vector(0, 2, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.0f) + }, 30) + scheduler.runTaskLater(plugin, Runnable { + player.velocity = Vector(0, 5, 0) + player.playSound(player.location, Sound.ENTITY_FIREWORK_ROCKET_BLAST, 2.0f, 1.25f) + }, 40) + return + } + player.velocity = Vector(0.0, 1.0, 3.5) + player.playSound(player.location, Sound.ENTITY_BAT_TAKEOFF, 1.0f, 1.0f) + } + } + + @EventHandler + fun onPlayerMoveDoubleJump(event: PlayerMoveEvent) { + val player = event.getPlayer() + val location = player.location + val world = player.world + + if (!player.isFlying && player.gameMode == GameMode.ADVENTURE) { + if (player.inventory.heldItemSlot == 7) { + player.allowFlight = false + return + } + player.allowFlight = world.getBlockAt(location.subtract(0.0, 2.0, 0.0)).type != Material.AIR + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerSwapHandItemsListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerSwapHandItemsListener.kt new file mode 100644 index 0000000..5a40177 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerSwapHandItemsListener.kt @@ -0,0 +1,13 @@ +package xyz.lncvrt.galaxylobby.listener + +import org.bukkit.GameMode +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerSwapHandItemsEvent + +class PlayerSwapHandItemsListener : Listener { + @EventHandler + fun onPlayerSwapHandItemsEvent(event: PlayerSwapHandItemsEvent) { + if (event.getPlayer().gameMode != GameMode.CREATIVE) event.isCancelled = true + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerToggleFlightListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerToggleFlightListener.kt new file mode 100644 index 0000000..c185fc3 --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/PlayerToggleFlightListener.kt @@ -0,0 +1,26 @@ +package xyz.lncvrt.galaxylobby.listener + +import org.bukkit.GameMode +import org.bukkit.Sound +import org.bukkit.entity.Player +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.player.PlayerToggleFlightEvent + +class PlayerToggleFlightListener : Listener { + @EventHandler + fun onPlayerToggleFlightEvent(event: PlayerToggleFlightEvent) { + val player: Player = event.getPlayer() + + if (!player.isFlying && player.gameMode == GameMode.ADVENTURE && player.inventory.heldItemSlot != 7) { + val direction = player.location.direction.normalize() + + event.isCancelled = true + player.allowFlight = false + direction.multiply(2.5f) + direction.setY(1) + player.velocity = direction + player.playSound(player.location, Sound.ENTITY_ENDER_DRAGON_FLAP, 1.0f, 1.0f) + } + } +} \ No newline at end of file diff --git a/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/ProjectileLaunchListener.kt b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/ProjectileLaunchListener.kt new file mode 100644 index 0000000..13d28fd --- /dev/null +++ b/src/main/kotlin/xyz/lncvrt/galaxylobby/listener/ProjectileLaunchListener.kt @@ -0,0 +1,29 @@ +package xyz.lncvrt.galaxylobby.listener + +import org.bukkit.Material +import org.bukkit.entity.Firework +import org.bukkit.entity.Player +import org.bukkit.event.EventHandler +import org.bukkit.event.Listener +import org.bukkit.event.entity.ProjectileLaunchEvent +import org.bukkit.inventory.ItemStack +import xyz.lncvrt.galaxyapi.utils.MessageFormat +import xyz.lncvrt.galaxylobby.GalaxyLobbyPlugin + +class ProjectileLaunchListener(val plugin: GalaxyLobbyPlugin) : Listener { + @EventHandler + fun onProjectileLaunchEvent(event: ProjectileLaunchEvent) { + val firework = event.getEntity() + val player = firework.shooter + if (firework is Firework) { + if (player is Player) { + val fireworkItem = ItemStack(Material.FIREWORK_ROCKET) + val fireworkMeta = fireworkItem.itemMeta + fireworkMeta.displayName(plugin.miniMessage.deserialize(MessageFormat.setPrimaryColor("Elytra ${MessageFormat.setSecondaryColor("(Fly around the lobby!)")}"))) + fireworkItem.setItemMeta(fireworkMeta) + player.inventory.setItem(7, fireworkItem) + player.setCooldown(fireworkItem.type, 20) + } + } + } +} \ No newline at end of file