aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/xmrvizzy/skyblocker/skyblock
diff options
context:
space:
mode:
authorAlexey Krainev <xmrvizzy@ya.ru>2021-01-30 06:27:29 +0500
committerAlexey Krainev <xmrvizzy@ya.ru>2021-01-30 06:27:29 +0500
commitc26890daab1b6ccf5ac9b6c5c52f4127fc1fc891 (patch)
tree2450cc98f551b92440ae91593b36f951908c2744 /src/main/java/me/xmrvizzy/skyblocker/skyblock
parentb851d1148c19e6daf51ed5228491777f26040442 (diff)
downloadSkyblocker-c26890daab1b6ccf5ac9b6c5c52f4127fc1fc891.tar.gz
Skyblocker-c26890daab1b6ccf5ac9b6c5c52f4127fc1fc891.tar.bz2
Skyblocker-c26890daab1b6ccf5ac9b6c5c52f4127fc1fc891.zip
v1.0.4
Diffstat (limited to 'src/main/java/me/xmrvizzy/skyblocker/skyblock')
-rw-r--r--src/main/java/me/xmrvizzy/skyblocker/skyblock/HotbarSlotLock.java41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/main/java/me/xmrvizzy/skyblocker/skyblock/HotbarSlotLock.java b/src/main/java/me/xmrvizzy/skyblocker/skyblock/HotbarSlotLock.java
new file mode 100644
index 00000000..42b9db1d
--- /dev/null
+++ b/src/main/java/me/xmrvizzy/skyblocker/skyblock/HotbarSlotLock.java
@@ -0,0 +1,41 @@
+package me.xmrvizzy.skyblocker.skyblock;
+
+import me.sargunvohra.mcmods.autoconfig1u.AutoConfig;
+import me.xmrvizzy.skyblocker.config.SkyblockerConfig;
+import net.fabricmc.fabric.api.client.keybinding.v1.KeyBindingHelper;
+import net.minecraft.client.network.ClientPlayerEntity;
+import net.minecraft.client.options.KeyBinding;
+import org.lwjgl.glfw.GLFW;
+import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
+
+import java.util.List;
+
+public class HotbarSlotLock {
+ public static KeyBinding hotbarSlotLock;
+
+ public static void init() {
+ hotbarSlotLock = KeyBindingHelper.registerKeyBinding(new KeyBinding(
+ "key.hotbarSlotLock",
+ GLFW.GLFW_KEY_H,
+ "key.categories.skyblocker"
+ ));
+ }
+
+ public static boolean isLocked(int slot) {
+ return SkyblockerConfig.get().general.lockedSlots.contains(slot);
+ }
+
+ public static void handleDropSelectedItem(int slot, CallbackInfoReturnable<Boolean> cir) {
+ if (isLocked(slot)) cir.setReturnValue(false);
+ }
+
+ public static void handleInputEvents(ClientPlayerEntity player) {
+ while (hotbarSlotLock.wasPressed()) {
+ List<Integer> lockedSlots = SkyblockerConfig.get().general.lockedSlots;
+ int selected = player.inventory.selectedSlot;
+ if (!isLocked(player.inventory.selectedSlot)) lockedSlots.add(selected);
+ else lockedSlots.remove(Integer.valueOf(selected));
+ AutoConfig.getConfigHolder(SkyblockerConfig.class).save();
+ }
+ }
+} \ No newline at end of file