diff --git a/Beem/.gitignore b/Beem/.gitignore
new file mode 100644
index 0000000..9563893
--- /dev/null
+++ b/Beem/.gitignore
@@ -0,0 +1,25 @@
+# gradle
+
+.gradle/
+build/
+out/
+classes/
+
+# idea
+
+.idea/
+*.iml
+*.ipr
+*.iws
+
+# vscode
+
+.settings/
+.vscode/
+bin/
+.classpath
+.project
+
+# fabric
+
+run/
\ No newline at end of file
diff --git a/Beem/CHANGELOG.md b/Beem/CHANGELOG.md
new file mode 100644
index 0000000..647cf15
--- /dev/null
+++ b/Beem/CHANGELOG.md
@@ -0,0 +1,40 @@
+# Beem - Changelog
+
+### Beem 1.3.8 - 1.20.5
+- Updated to Minecraft 1.20.5
+- Updated Gradle.
+- Updated Java requirement to Java 21.
+
+### Beem 1.3.7 - 1.20.1
+- Updated to Minecraft 1.20.1
+
+### Beem 1.3.6 - 22w18a
+- Updated to Minecraft snapshot 22w18a
+- Replaced deprecated feature
`net.fabricmc.fabric.api.client.rendereregistry.v1.BlockEntityRendererRegistry`
with
`net.fabricmc.fabric.api.client.rendering.v1.BlockEntityRendererRegistry`
+
+### Beem 1.3.6 - 22w17a
+- Updated to Minecraft snapshot 22w17a (thanks to Yuuki2012!)
+
+### Beem 1.3.5 - 21w03a
+- Updated to Minecraft snapshot 21w03a
+
+### Beem 1.3.4 - 1.16.3
+- Updated to Minecraft 1.16.3
+
+### Beem 1.3.3 - 1.16.2
+- Updated to Minecraft 1.16.2
+
+### Beem 1.3.2 - 20w22a
+- Updated to Minecraft snapshot 20w22a
+
+### Beem 1.3.1 - 20w17a
+- Updated to Minecraft snapshot 20w17a
+
+### Beem 1.3 - 20w09a
+- Updated to Minecraft snapshot 20w09a (thanks to Yuuki2012!)
+
+### Beem 1.2 - 20w06a
+- Updated to Minecraft snapshot 20w06a
+
+### Beem 1.1 - 1.15.1
+- Added a keybind to toggle beems; keybind by default is B
diff --git a/Beem/LICENSE b/Beem/LICENSE
new file mode 100644
index 0000000..0851dec
--- /dev/null
+++ b/Beem/LICENSE
@@ -0,0 +1,2 @@
+CC-BY-NC-SA 4.0
+https://creativecommons.org/licenses/by-nc-sa/4.0
diff --git a/Beem/README.md b/Beem/README.md
new file mode 100644
index 0000000..6258450
--- /dev/null
+++ b/Beem/README.md
@@ -0,0 +1,6 @@
+# Beem
+A Minecraft Fabric mod that displays light beams to help finding bee nests.
+
+# Contributors
+Creator: [Ladysnake](https://www.curseforge.com/minecraft/mc-mods/beem) ([src](https://github.com/Ladysnake/Beem))
+Current maintainer: [Yuuki2012](https://github.com/Yuuki2012/Beem)
diff --git a/Beem/build.gradle b/Beem/build.gradle
new file mode 100644
index 0000000..d8096fa
--- /dev/null
+++ b/Beem/build.gradle
@@ -0,0 +1,186 @@
+plugins {
+ id 'fabric-loom' version '1.6-SNAPSHOT'
+ id 'maven-publish'
+ id 'com.matthewprenger.cursegradle' version '1.4.0'
+ id 'org.ajoberstar.grgit' version '3.1.1'
+ id 'com.github.breadmoirai.github-release' version '2.2.9'
+ id 'com.wynprice.cursemaven' version '1.2.3'
+}
+
+java {
+ toolchain {
+ languageVersion = JavaLanguageVersion.of(21)
+ }
+ sourceCompatibility = JavaVersion.VERSION_21
+ targetCompatibility = JavaVersion.VERSION_21
+}
+// Adds a few utility methods like getProjectProperty
+apply from: 'https://raw.githubusercontent.com/NerdHubMC/Gradle-Scripts/master/scripts/utilities.gradle'
+apply from: 'https://raw.githubusercontent.com/NerdHubMC/Gradle-Scripts/master/scripts/fabric/publish/changelog.gradle'
+
+archivesBaseName = project.archives_base_name
+version = project.mod_version
+group = project.maven_group
+
+dependencies {
+ // To change the versions see the gradle.properties file
+ minecraft "com.mojang:minecraft:${project.minecraft_version}"
+ mappings "net.fabricmc:yarn:${project.yarn_mappings}:v2"
+ modImplementation "net.fabricmc:fabric-loader:${project.loader_version}"
+
+ // Fabric API. This is technically optional, but you probably want it anyway.
+ modImplementation "net.fabricmc.fabric-api:fabric-api:${project.fabric_version}"
+}
+
+processResources {
+ inputs.property "version", project.version
+
+ filesMatching("fabric.mod.json") {
+ expand "version": project.version
+ }
+}
+
+// ensure that the encoding is set to UTF-8, no matter what the system default is
+// this fixes some edge cases with special characters not displaying correctly
+// see http://yodaconditions.net/blog/fix-for-java-file-encoding-problems-with-gradle.html
+tasks.withType(JavaCompile).configureEach {
+ options.encoding = "UTF-8"
+ it.options.release = 21
+}
+
+jar {
+ from "LICENSE"
+}
+
+// configure the maven publication
+publishing {
+ publications {
+ mavenJava(MavenPublication) {
+ // add all the jars that should be included when publishing to maven
+ artifact(remapJar) {
+ builtBy remapJar
+ }
+ }
+ }
+
+ // select the repositories you want to publish to
+ repositories {
+ // uncomment to publish to the local maven
+ // mavenLocal()
+ }
+}
+
+
+tasks.register('checkGitStatus') {
+ group = 'publishing'
+ description = 'Checks that the git repository is in a state suitable for release'
+ doLast {
+ if (grgit == null) throw new RuntimeException('No git repository')
+ if (!grgit.status().isClean()) {
+ throw new RuntimeException("Git repository not ready for release (${grgit.status()})")
+ }
+ def currentBranch = grgit.branch.current().getName()
+ grgit.fetch()
+ if (grgit.tag.list().any { it.name == project.version }) {
+ throw new RuntimeException("A tag already exists for ${project.version}")
+ }
+ def status = grgit.branch.status(name: currentBranch)
+ if (status.aheadCount != 0) {
+ throw new RuntimeException('Some commits have not been pushed')
+ }
+ if (status.behindCount != 0) {
+ throw new RuntimeException('Some commits have not been pulled')
+ }
+ }
+}
+
+githubRelease {
+ repo "Beem"
+ token "${getProjectProperty('github_releases_token')}"
+ // default owner: last component of maven group
+ // default repo: name of the project
+ tagName = project.version
+ targetCommitish = { grgit.branch.current().name }
+ body = { project.getChangelogText() }
+
+ FilenameFilter filter = { dir, filename -> filename.contains(project.version) && !filename.contains('-dev.jar') }
+ releaseAssets = { jar.destinationDirectory.asFile.get().listFiles filter }
+}
+tasks.githubRelease.dependsOn(checkGitStatus)
+
+curseforge {
+
+ if (project.getProjectProperty('curse_key') != null) {
+ apiKey = project.getProjectProperty('curse_key')
+ }
+
+ if (project.hasProperty('curseforge_id')) {
+ project {
+ id = findProperty('curseforge_id')
+
+ releaseType = project.release_type
+
+ //usually automatically determined by the CurseGradle plugin, but won't work with fabric
+ "${project.curseforge_versions}".split('; ').each {
+ addGameVersion it
+ }
+ addGameVersion 'Fabric'
+
+ mainArtifact(remapJar) {
+ displayName = "${project.name}-${project.version}.jar"
+
+ if (project.hasProperty('cf_requirements') || project.hasProperty('cf_optionals') || project.hasProperty('cf_embeddeds') || project.hasProperty('cf_tools') || project.hasProperty('cf_incompatibles') || project.hasProperty('cf_includes')) {
+ relations {
+ if (project.hasProperty('cf_requirements')) {
+ "${project.cf_requirements}".split('; ').each {
+ requiredDependency "${it}"
+ }
+ }
+ if (project.hasProperty('cf_optionals')) {
+ "${project.cf_optionals}".split('; ').each {
+ optionalDependency "${it}"
+ }
+ }
+ if (project.hasProperty('cf_embeddeds')) {
+ "${project.cf_embeddeds}".split('; ').each {
+ embeddedLibrary "${it}"
+ }
+ }
+ if (project.hasProperty('cf_tools')) {
+ "${project.cf_tools}".split('; ').each {
+ tool "${it}"
+ }
+ }
+ if (project.hasProperty('cf_incompatibles')) {
+ "${project.cf_incompatibles}".split('; ').each {
+ incompatible "${it}"
+ }
+ }
+ if (project.hasProperty('cf_includes')) {
+ "${project.cf_includes}".split('; ').each {
+ include "${it}"
+ }
+ }
+ }
+ }
+ }
+
+ changelogType = 'markdown'
+ changelog = project.getChangelogText()
+
+ afterEvaluate {
+ uploadTask.dependsOn remapSourcesJar
+ }
+ }
+ options {
+ forgeGradleIntegration = false
+ }
+ }
+}
+
+tasks.curseforge.dependsOn(checkGitStatus)
+
+tasks.register('release') {
+ group = 'publishing'
+ description = 'Releases a new version to Github and Curseforge'
+}
diff --git a/Beem/gradle.properties b/Beem/gradle.properties
new file mode 100644
index 0000000..a245e54
--- /dev/null
+++ b/Beem/gradle.properties
@@ -0,0 +1,24 @@
+# Done to increase the memory available to gradle.
+org.gradle.jvmargs=-Xmx1G
+
+# Fabric Properties
+minecraft_version=1.20.5
+yarn_mappings=1.20.5+build.1
+loader_version=0.15.10
+
+# Fabric api
+fabric_version=0.97.6+1.20.5
+
+# Mod Properties
+mod_version = 1.3.8
+maven_group = io.github.ladysnake
+archives_base_name = beem
+
+#Publishing
+owners = Ladysnake
+license_header = CC-BY-NC-SA+4.0
+curseforge_id = 358105
+curseforge_versions = 1.17
+cf_requirements = fabric-api
+release_type = release
+changelog_url = https://github.com/Yuuki2012/Beem/blob/1.17/CHANGELOG.md
diff --git a/Beem/gradle/wrapper/gradle-wrapper.jar b/Beem/gradle/wrapper/gradle-wrapper.jar
new file mode 100644
index 0000000..5c2d1cf
Binary files /dev/null and b/Beem/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/Beem/gradle/wrapper/gradle-wrapper.properties b/Beem/gradle/wrapper/gradle-wrapper.properties
new file mode 100644
index 0000000..a8382d7
--- /dev/null
+++ b/Beem/gradle/wrapper/gradle-wrapper.properties
@@ -0,0 +1,5 @@
+distributionBase=GRADLE_USER_HOME
+distributionPath=wrapper/dists
+distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip
+zipStoreBase=GRADLE_USER_HOME
+zipStorePath=wrapper/dists
\ No newline at end of file
diff --git a/Beem/gradlew b/Beem/gradlew
new file mode 100644
index 0000000..8e25e6c
--- /dev/null
+++ b/Beem/gradlew
@@ -0,0 +1,188 @@
+#!/usr/bin/env sh
+
+#
+# Copyright 2015 the original author or 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.
+#
+
+##############################################################################
+##
+## Gradle start up script for UN*X
+##
+##############################################################################
+
+# Attempt to set APP_HOME
+# Resolve links: $0 may be a link
+PRG="$0"
+# Need this for relative symlinks.
+while [ -h "$PRG" ] ; do
+ ls=`ls -ld "$PRG"`
+ link=`expr "$ls" : '.*-> \(.*\)$'`
+ if expr "$link" : '/.*' > /dev/null; then
+ PRG="$link"
+ else
+ PRG=`dirname "$PRG"`"/$link"
+ fi
+done
+SAVED="`pwd`"
+cd "`dirname \"$PRG\"`/" >/dev/null
+APP_HOME="`pwd -P`"
+cd "$SAVED" >/dev/null
+
+APP_NAME="Gradle"
+APP_BASE_NAME=`basename "$0"`
+
+# 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"'
+
+# Use the maximum available, or set MAX_FD != -1 to use that value.
+MAX_FD="maximum"
+
+warn () {
+ echo "$*"
+}
+
+die () {
+ echo
+ echo "$*"
+ echo
+ exit 1
+}
+
+# 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
+ ;;
+ 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"
+ which java >/dev/null 2>&1 || 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
+
+# Increase the maximum file descriptors if we can.
+if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
+ MAX_FD_LIMIT=`ulimit -H -n`
+ if [ $? -eq 0 ] ; then
+ if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
+ MAX_FD="$MAX_FD_LIMIT"
+ fi
+ ulimit -n $MAX_FD
+ if [ $? -ne 0 ] ; then
+ warn "Could not set maximum file descriptor limit: $MAX_FD"
+ fi
+ else
+ warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
+ fi
+fi
+
+# For Darwin, add options to specify how the application appears in the dock
+if $darwin; then
+ GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
+fi
+
+# For Cygwin, switch paths to Windows format before running java
+if $cygwin ; then
+ APP_HOME=`cygpath --path --mixed "$APP_HOME"`
+ CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
+ JAVACMD=`cygpath --unix "$JAVACMD"`
+
+ # We build the pattern for arguments to be converted via cygpath
+ ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
+ SEP=""
+ for dir in $ROOTDIRSRAW ; do
+ ROOTDIRS="$ROOTDIRS$SEP$dir"
+ SEP="|"
+ done
+ OURCYGPATTERN="(^($ROOTDIRS))"
+ # Add a user-defined pattern to the cygpath arguments
+ if [ "$GRADLE_CYGPATTERN" != "" ] ; then
+ OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
+ fi
+ # Now convert the arguments - kludge to limit ourselves to /bin/sh
+ i=0
+ for arg in "$@" ; do
+ CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
+ CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
+
+ if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
+ eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
+ else
+ eval `echo args$i`="\"$arg\""
+ fi
+ i=$((i+1))
+ done
+ case $i in
+ (0) set -- ;;
+ (1) set -- "$args0" ;;
+ (2) set -- "$args0" "$args1" ;;
+ (3) set -- "$args0" "$args1" "$args2" ;;
+ (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
+ (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
+ (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
+ (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
+ (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
+ (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
+ esac
+fi
+
+# Escape application args
+save () {
+ for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
+ echo " "
+}
+APP_ARGS=$(save "$@")
+
+# Collect all arguments for the java command, following the shell quoting and substitution rules
+eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
+
+# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
+if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
+ cd "$(dirname "$0")"
+fi
+
+exec "$JAVACMD" "$@"
diff --git a/Beem/gradlew.bat b/Beem/gradlew.bat
new file mode 100644
index 0000000..9618d8d
--- /dev/null
+++ b/Beem/gradlew.bat
@@ -0,0 +1,100 @@
+@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
+
+@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=.
+set APP_BASE_NAME=%~n0
+set APP_HOME=%DIRNAME%
+
+@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%" == "0" goto init
+
+echo.
+echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:findJavaFromJavaHome
+set JAVA_HOME=%JAVA_HOME:"=%
+set JAVA_EXE=%JAVA_HOME%/bin/java.exe
+
+if exist "%JAVA_EXE%" goto init
+
+echo.
+echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:init
+@rem Get command-line arguments, handling Windows variants
+
+if not "%OS%" == "Windows_NT" goto win9xME_args
+
+:win9xME_args
+@rem Slurp the command line arguments.
+set CMD_LINE_ARGS=
+set _SKIP=2
+
+:win9xME_args_slurp
+if "x%~1" == "x" goto execute
+
+set CMD_LINE_ARGS=%*
+
+: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 %CMD_LINE_ARGS%
+
+:end
+@rem End local scope for the variables with windows NT shell
+if "%ERRORLEVEL%"=="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!
+if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
+exit /b 1
+
+:mainEnd
+if "%OS%"=="Windows_NT" endlocal
+
+:omega
diff --git a/Beem/settings.gradle b/Beem/settings.gradle
new file mode 100644
index 0000000..2875cde
--- /dev/null
+++ b/Beem/settings.gradle
@@ -0,0 +1,9 @@
+pluginManagement {
+ repositories {
+ maven {
+ name = 'Fabric'
+ url = 'https://maven.fabricmc.net/'
+ }
+ gradlePluginPortal()
+ }
+}
\ No newline at end of file
diff --git a/Beem/src/main/java/ladysnake/beem/BeeNestBlockEntityRenderer.java b/Beem/src/main/java/ladysnake/beem/BeeNestBlockEntityRenderer.java
new file mode 100644
index 0000000..df8c768
--- /dev/null
+++ b/Beem/src/main/java/ladysnake/beem/BeeNestBlockEntityRenderer.java
@@ -0,0 +1,26 @@
+package ladysnake.beem;
+
+import net.minecraft.block.Blocks;
+import net.minecraft.block.entity.BeehiveBlockEntity;
+import net.minecraft.client.render.VertexConsumerProvider;
+import net.minecraft.client.render.block.entity.BeaconBlockEntityRenderer;
+import net.minecraft.client.render.block.entity.BlockEntityRenderer;
+import net.minecraft.client.util.math.MatrixStack;
+import net.minecraft.util.DyeColor;
+import net.minecraft.util.Identifier;
+
+import java.util.Objects;
+
+public class BeeNestBlockEntityRenderer implements BlockEntityRenderer {
+ public static final Identifier BEAM_TEXTURE = new Identifier("beem:textures/entity/beem.png");
+ public static final DyeColor BEAM_COLOR = DyeColor.YELLOW;
+
+ public void render(BeehiveBlockEntity blockEntity, float tickDelta, MatrixStack matrices, VertexConsumerProvider vertexConsumers, int light, int overlay) {
+ if (Objects.requireNonNull(blockEntity.getWorld()).getBlockState(blockEntity.getPos()).getBlock().equals(Blocks.BEE_NEST) && Beem.beem) {
+ long time = blockEntity.getWorld().getTime();
+
+ BeaconBlockEntityRenderer.renderBeam(matrices, vertexConsumers, BEAM_TEXTURE, tickDelta, 1.0f, time, 0, 256, BEAM_COLOR.getColorComponents(), 0.25F, 0.35F);
+ BeaconBlockEntityRenderer.renderBeam(matrices, vertexConsumers, BEAM_TEXTURE, tickDelta, 1.0f, time, 0, -256, BEAM_COLOR.getColorComponents(), 0.25F, 0.35F);
+ }
+ }
+}
diff --git a/Beem/src/main/java/ladysnake/beem/Beem.java b/Beem/src/main/java/ladysnake/beem/Beem.java
new file mode 100644
index 0000000..3e6f716
--- /dev/null
+++ b/Beem/src/main/java/ladysnake/beem/Beem.java
@@ -0,0 +1,40 @@
+package ladysnake.beem;
+
+import net.fabricmc.api.ClientModInitializer;
+import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientTickEvents;
+import net.fabricmc.fabric.api.client.keybinding.v1.KeyBindingHelper;
+import net.minecraft.block.entity.BlockEntityType;
+import net.minecraft.client.MinecraftClient;
+import net.minecraft.client.option.KeyBinding;
+import net.minecraft.client.render.block.entity.BlockEntityRendererFactories;
+import net.minecraft.client.util.InputUtil;
+import net.minecraft.text.Style;
+import net.minecraft.text.Text;
+import net.minecraft.util.Formatting;
+import org.lwjgl.glfw.GLFW;
+
+public class Beem implements ClientModInitializer {
+ private static final KeyBinding TOGGLE_BEEM = new KeyBinding(
+ "beem:toggle_beem",
+ InputUtil.Type.KEYSYM,
+ GLFW.GLFW_KEY_B,
+ "key.categories.misc"
+ );
+ static boolean beem = true;
+
+ @Override
+ public void onInitializeClient() {
+ BlockEntityRendererFactories.register(BlockEntityType.BEEHIVE, d -> new BeeNestBlockEntityRenderer());
+ KeyBindingHelper.registerKeyBinding(TOGGLE_BEEM);
+
+ ClientTickEvents.START_CLIENT_TICK.register(e -> {
+ while (TOGGLE_BEEM.wasPressed()) {
+ beem = !beem;
+
+ if (MinecraftClient.getInstance().player != null) {
+ MinecraftClient.getInstance().player.sendMessage(Text.translatable("message.beem.toggled." + beem).setStyle(Style.EMPTY.withColor(Formatting.GOLD)), false);
+ }
+ }
+ });
+ }
+}
diff --git a/Beem/src/main/java/ladysnake/beem/mixin/BeehiveBlockEntityMixin.java b/Beem/src/main/java/ladysnake/beem/mixin/BeehiveBlockEntityMixin.java
new file mode 100644
index 0000000..da64ac0
--- /dev/null
+++ b/Beem/src/main/java/ladysnake/beem/mixin/BeehiveBlockEntityMixin.java
@@ -0,0 +1,21 @@
+package ladysnake.beem.mixin;
+
+import net.minecraft.block.BlockState;
+import net.minecraft.block.entity.BeehiveBlockEntity;
+import net.minecraft.block.entity.BlockEntity;
+import net.minecraft.block.entity.BlockEntityType;
+import net.minecraft.util.math.BlockPos;
+import org.spongepowered.asm.mixin.Mixin;
+import org.spongepowered.asm.mixin.Unique;
+
+@Mixin(BeehiveBlockEntity.class)
+public abstract class BeehiveBlockEntityMixin extends BlockEntity {
+ public BeehiveBlockEntityMixin(final BlockEntityType> type, final BlockPos pos, final BlockState state) {
+ super(type, pos, state);
+ }
+
+ @Unique
+ public double getSquaredRenderDistance() {
+ return 65536.0D;
+ }
+}
diff --git a/Beem/src/main/resources/assets/beem/icon.png b/Beem/src/main/resources/assets/beem/icon.png
new file mode 100644
index 0000000..8bbd1a8
Binary files /dev/null and b/Beem/src/main/resources/assets/beem/icon.png differ
diff --git a/Beem/src/main/resources/assets/beem/lang/en_us.json b/Beem/src/main/resources/assets/beem/lang/en_us.json
new file mode 100644
index 0000000..eadb853
--- /dev/null
+++ b/Beem/src/main/resources/assets/beem/lang/en_us.json
@@ -0,0 +1,5 @@
+{
+ "key.beem.toggle_beem": "Toggle Beem",
+ "message.beem.toggled.true": "Beem enabled",
+ "message.beem.toggled.false": "Beem disabled"
+}
\ No newline at end of file
diff --git a/Beem/src/main/resources/assets/beem/lang/pl_pl.json b/Beem/src/main/resources/assets/beem/lang/pl_pl.json
new file mode 100644
index 0000000..8dc6296
--- /dev/null
+++ b/Beem/src/main/resources/assets/beem/lang/pl_pl.json
@@ -0,0 +1,5 @@
+{
+ "key.beem.toggle_beem": "Ukryj pszczelą wiązkę",
+ "message.beem.toggled.true": "Pszczela wiązka aktywowana",
+ "message.beem.toggled.false": "Pszczela wiązka dezaktywowana"
+}
diff --git a/Beem/src/main/resources/assets/beem/textures/entity/beem.png b/Beem/src/main/resources/assets/beem/textures/entity/beem.png
new file mode 100644
index 0000000..188442b
Binary files /dev/null and b/Beem/src/main/resources/assets/beem/textures/entity/beem.png differ
diff --git a/Beem/src/main/resources/beem.mixins.json b/Beem/src/main/resources/beem.mixins.json
new file mode 100644
index 0000000..c1d5ce7
--- /dev/null
+++ b/Beem/src/main/resources/beem.mixins.json
@@ -0,0 +1,13 @@
+{
+ "required": true,
+ "package": "ladysnake.beem.mixin",
+ "compatibilityLevel": "JAVA_17",
+ "mixins": [
+ ],
+ "client": [
+ "BeehiveBlockEntityMixin"
+ ],
+ "injectors": {
+ "defaultRequire": 1
+ }
+}
\ No newline at end of file
diff --git a/Beem/src/main/resources/fabric.mod.json b/Beem/src/main/resources/fabric.mod.json
new file mode 100644
index 0000000..96ec6c8
--- /dev/null
+++ b/Beem/src/main/resources/fabric.mod.json
@@ -0,0 +1,33 @@
+{
+ "schemaVersion": 1,
+ "id": "beem",
+ "version": "${version}",
+
+ "name": "Beem",
+ "description": "A mod that displays light beams to help finding bee nests.",
+ "authors": [
+ "doctor4t",
+ "Yuuki2012"
+ ],
+ "contact": {
+ "sources": "https://github.com/Yuuki2012/Beem",
+ "issues": "https://github.com/Yuuki2012/Beem/issues",
+ "discord": "https://raiza.dev/invite"
+ },
+ "license": "CC-BY-NC-SA 4.0",
+ "icon": "assets/beem/icon.png",
+
+ "environment": "*",
+ "entrypoints": {
+ "client": [
+ "ladysnake.beem.Beem"
+ ]
+ },
+ "mixins": [
+ "beem.mixins.json"
+ ],
+ "depends": {
+ "fabricloader": ">=0.14.3",
+ "fabric": "*"
+ }
+}