diff options
author | nea <nea@nea.moe> | 2023-05-18 03:20:22 +0200 |
---|---|---|
committer | nea <nea@nea.moe> | 2023-05-18 03:20:22 +0200 |
commit | 1dd603ab1cc42a602f1d82595dd15789ef63d2a3 (patch) | |
tree | 1658e1d32849d69102ff1e1b4c856da8428ab82b /src/main/kotlin/moe/nea/firmament/events | |
parent | 3ebe3e80b929b03ad0bcb0c76cec6b3285fe08bd (diff) | |
download | firmament-1dd603ab1cc42a602f1d82595dd15789ef63d2a3.tar.gz firmament-1dd603ab1cc42a602f1d82595dd15789ef63d2a3.tar.bz2 firmament-1dd603ab1cc42a602f1d82595dd15789ef63d2a3.zip |
Add slot locking
Diffstat (limited to 'src/main/kotlin/moe/nea/firmament/events')
3 files changed, 68 insertions, 0 deletions
diff --git a/src/main/kotlin/moe/nea/firmament/events/HandledScreenKeyPressedEvent.kt b/src/main/kotlin/moe/nea/firmament/events/HandledScreenKeyPressedEvent.kt new file mode 100644 index 0000000..1afbfe5 --- /dev/null +++ b/src/main/kotlin/moe/nea/firmament/events/HandledScreenKeyPressedEvent.kt @@ -0,0 +1,10 @@ +package moe.nea.firmament.events + +import net.minecraft.client.option.KeyBinding + +data class HandledScreenKeyPressedEvent(val keyCode: Int, val scanCode: Int, val modifiers: Int) : FirmamentEvent.Cancellable() { + companion object : FirmamentEventBus<HandledScreenKeyPressedEvent>() + fun matches(keyBinding: KeyBinding): Boolean { + return keyBinding.matchesKey(keyCode, scanCode) + } +} diff --git a/src/main/kotlin/moe/nea/firmament/events/IsSlotProtectedEvent.kt b/src/main/kotlin/moe/nea/firmament/events/IsSlotProtectedEvent.kt new file mode 100644 index 0000000..7ca6521 --- /dev/null +++ b/src/main/kotlin/moe/nea/firmament/events/IsSlotProtectedEvent.kt @@ -0,0 +1,26 @@ +package moe.nea.firmament.events + +import net.minecraft.screen.slot.Slot +import net.minecraft.text.Text +import moe.nea.firmament.util.CommonSoundEffects +import moe.nea.firmament.util.MC + +data class IsSlotProtectedEvent( + val slot: Slot, var isProtected: Boolean = false +) : FirmamentEvent() { + companion object : FirmamentEventBus<IsSlotProtectedEvent>() { + @JvmStatic + fun shouldBlockInteraction(slot: Slot): Boolean { + return publish(IsSlotProtectedEvent(slot)).isProtected.also { + if (it) { + MC.player?.sendMessage(Text.translatable("firmament.protectitem").append(slot.stack.name)) + CommonSoundEffects.playFailure() + } + } + } + } + + fun protect() { + isProtected = true + } +} diff --git a/src/main/kotlin/moe/nea/firmament/events/SlotRenderEvents.kt b/src/main/kotlin/moe/nea/firmament/events/SlotRenderEvents.kt new file mode 100644 index 0000000..afcddf2 --- /dev/null +++ b/src/main/kotlin/moe/nea/firmament/events/SlotRenderEvents.kt @@ -0,0 +1,32 @@ +package moe.nea.firmament.events + +import net.minecraft.client.util.math.MatrixStack +import net.minecraft.screen.slot.Slot + +interface SlotRenderEvents { + val matrices: MatrixStack + val slot: Slot + val mouseX: Int + val mouseY: Int + val delta: Float + + data class Before( + override val matrices: MatrixStack, override val slot: Slot, + override val mouseX: Int, + override val mouseY: Int, + override val delta: Float + ) : FirmamentEvent(), + SlotRenderEvents { + companion object : FirmamentEventBus<Before>() + } + + data class After( + override val matrices: MatrixStack, override val slot: Slot, + override val mouseX: Int, + override val mouseY: Int, + override val delta: Float + ) : FirmamentEvent(), + SlotRenderEvents { + companion object : FirmamentEventBus<After>() + } +} |