summaryrefslogtreewikicommitdiff
path: root/core/src/command/map/blockhunt
diff options
context:
space:
mode:
authorFreya Murphy <freya@freyacat.org>2026-03-26 23:15:33 -0400
committerFreya Murphy <freya@freyacat.org>2026-03-27 23:09:23 -0400
commitf8322cd21cde68a72b05efbad3a05b8e67c0bdd0 (patch)
treed7e60bc8fedadc8fa7ae725571cad1f398eaf6dc /core/src/command/map/blockhunt
downloadkenshinshideandseek2-f8322cd21cde68a72b05efbad3a05b8e67c0bdd0.tar.gz
kenshinshideandseek2-f8322cd21cde68a72b05efbad3a05b8e67c0bdd0.tar.bz2
kenshinshideandseek2-f8322cd21cde68a72b05efbad3a05b8e67c0bdd0.zip
initial
Diffstat (limited to 'core/src/command/map/blockhunt')
-rw-r--r--core/src/command/map/blockhunt/Debug.kt35
-rw-r--r--core/src/command/map/blockhunt/Enabled.kt39
-rw-r--r--core/src/command/map/blockhunt/block/Add.kt55
-rw-r--r--core/src/command/map/blockhunt/block/List.kt46
-rw-r--r--core/src/command/map/blockhunt/block/Remove.kt56
5 files changed, 231 insertions, 0 deletions
diff --git a/core/src/command/map/blockhunt/Debug.kt b/core/src/command/map/blockhunt/Debug.kt
new file mode 100644
index 0000000..0620e3d
--- /dev/null
+++ b/core/src/command/map/blockhunt/Debug.kt
@@ -0,0 +1,35 @@
+package cat.freya.khs.command.map.blockhunt
+
+import cat.freya.khs.Khs
+import cat.freya.khs.command.util.Command
+import cat.freya.khs.inv.createBlockHuntPicker
+import cat.freya.khs.player.Player
+import cat.freya.khs.runChecks
+
+class KhsMapBlockHuntDebug : Command {
+ override val label = "debug"
+ override val usage = listOf("map")
+ override val description = "Manually open the blockhunt picker for a map"
+
+ override fun execute(plugin: Khs, player: Player, args: List<String>) {
+ val (name) = args
+ runChecks(plugin, player) {
+ blockHuntSupported()
+ blockHuntEnabled(name)
+ }
+
+ val map = plugin.maps.get(name) ?: return
+ val inv = createBlockHuntPicker(plugin, map) ?: return
+ player.showInventory(inv)
+ }
+
+ override fun autoComplete(plugin: Khs, parameter: String, typed: String): List<String> =
+ when (parameter) {
+ "map" ->
+ plugin.maps
+ .filter { it.value.config.blockHunt.enabled }
+ .map { it.key }
+ .filter { it.startsWith(typed) }
+ else -> listOf()
+ }
+}
diff --git a/core/src/command/map/blockhunt/Enabled.kt b/core/src/command/map/blockhunt/Enabled.kt
new file mode 100644
index 0000000..a2ccdb7
--- /dev/null
+++ b/core/src/command/map/blockhunt/Enabled.kt
@@ -0,0 +1,39 @@
+package cat.freya.khs.command.map.blockhunt
+
+import cat.freya.khs.Khs
+import cat.freya.khs.command.util.Command
+import cat.freya.khs.player.Player
+import cat.freya.khs.runChecks
+
+class KhsMapBlockHuntEnabled : Command {
+ override val label = "enabled"
+ override val usage = listOf("map", "bool")
+ override val description = "Enable/disable blockhunt on a map"
+
+ override fun execute(plugin: Khs, player: Player, args: List<String>) {
+ val (name, enabled) = args
+ runChecks(plugin, player) {
+ blockHuntSupported()
+ mapExists(name)
+ gameNotInProgress()
+ }
+
+ val map = plugin.maps.get(name) ?: return
+ map.config.blockHunt.enabled = (enabled.lowercase() == "true")
+ map.reloadConfig()
+
+ val msg =
+ if (map.config.blockHunt.enabled) plugin.locale.blockHunt.enabled
+ else plugin.locale.blockHunt.disabled
+
+ plugin.saveConfig()
+ player.message(plugin.locale.prefix.default + msg)
+ }
+
+ override fun autoComplete(plugin: Khs, parameter: String, typed: String): List<String> =
+ when (parameter) {
+ "map" -> plugin.maps.keys.filter { it.startsWith(typed) }
+ "bool" -> listOf("true", "false").filter { it.startsWith(typed) }
+ else -> listOf()
+ }
+}
diff --git a/core/src/command/map/blockhunt/block/Add.kt b/core/src/command/map/blockhunt/block/Add.kt
new file mode 100644
index 0000000..6ed17be
--- /dev/null
+++ b/core/src/command/map/blockhunt/block/Add.kt
@@ -0,0 +1,55 @@
+package cat.freya.khs.command.map.blockhunt.block
+
+import cat.freya.khs.Khs
+import cat.freya.khs.command.util.Command
+import cat.freya.khs.player.Player
+import cat.freya.khs.runChecks
+
+class KhsMapBlockHuntBlockAdd : Command {
+ override val label = "add"
+ override val usage = listOf("map", "block")
+ override val description = "Add a block to a block hunt map"
+
+ override fun execute(plugin: Khs, player: Player, args: List<String>) {
+ val (name, blockName) = args
+ runChecks(plugin, player) {
+ blockHuntSupported()
+ blockHuntEnabled(name)
+ gameNotInProgress()
+ lobbyEmpty()
+ }
+
+ val material = plugin.shim.parseMaterial(blockName)
+ if (material == null) {
+ player.message(plugin.locale.prefix.error + plugin.locale.blockHunt.block.unknown)
+ return
+ }
+
+ val map = plugin.maps.get(name) ?: return
+ if (map.config.blockHunt.blocks.contains(material)) {
+ player.message(
+ plugin.locale.prefix.error + plugin.locale.blockHunt.block.exists.with(material)
+ )
+ return
+ }
+
+ map.config.blockHunt.blocks += material
+ map.reloadConfig()
+
+ plugin.saveConfig()
+ player.message(
+ plugin.locale.prefix.default + plugin.locale.blockHunt.block.added.with(material)
+ )
+ }
+
+ override fun autoComplete(plugin: Khs, parameter: String, typed: String): List<String> =
+ when (parameter) {
+ "map" ->
+ plugin.maps
+ .filter { it.value.config.blockHunt.enabled }
+ .map { it.key }
+ .filter { it.startsWith(typed) }
+ "block" -> listOf(parameter)
+ else -> listOf()
+ }
+}
diff --git a/core/src/command/map/blockhunt/block/List.kt b/core/src/command/map/blockhunt/block/List.kt
new file mode 100644
index 0000000..b7df70d
--- /dev/null
+++ b/core/src/command/map/blockhunt/block/List.kt
@@ -0,0 +1,46 @@
+package cat.freya.khs.command.map.blockhunt.block
+
+import cat.freya.khs.Khs
+import cat.freya.khs.command.util.Command
+import cat.freya.khs.player.Player
+import cat.freya.khs.runChecks
+
+class KhsMapBlockHuntBlockList : Command {
+ override val label = "list"
+ override val usage = listOf("map")
+ override val description = "List blocks in use on a block hunt map"
+
+ override fun execute(plugin: Khs, player: Player, args: List<String>) {
+ val (name) = args
+ runChecks(plugin, player) {
+ blockHuntSupported()
+ blockHuntEnabled(name)
+ }
+
+ val map = plugin.maps.get(name) ?: return
+ val blocks = map.config.blockHunt.blocks
+ if (blocks.isEmpty()) {
+ player.message(plugin.locale.prefix.default + plugin.locale.blockHunt.block.none)
+ return
+ }
+
+ val message = buildString {
+ appendLine(plugin.locale.blockHunt.block.list)
+ for (block in blocks) {
+ appendLine("&e- &f$block")
+ }
+ }
+
+ player.message(message)
+ }
+
+ override fun autoComplete(plugin: Khs, parameter: String, typed: String): List<String> =
+ when (parameter) {
+ "map" ->
+ plugin.maps
+ .filter { it.value.config.blockHunt.enabled }
+ .map { it.key }
+ .filter { it.startsWith(typed) }
+ else -> listOf()
+ }
+}
diff --git a/core/src/command/map/blockhunt/block/Remove.kt b/core/src/command/map/blockhunt/block/Remove.kt
new file mode 100644
index 0000000..3e81371
--- /dev/null
+++ b/core/src/command/map/blockhunt/block/Remove.kt
@@ -0,0 +1,56 @@
+package cat.freya.khs.command.map.blockhunt.block
+
+import cat.freya.khs.Khs
+import cat.freya.khs.command.util.Command
+import cat.freya.khs.player.Player
+import cat.freya.khs.runChecks
+
+class KhsMapBlockHuntBlockRemove : Command {
+ override val label = "remove"
+ override val usage = listOf("map", "block")
+ override val description = "Remove a block from a block hunt map"
+
+ override fun execute(plugin: Khs, player: Player, args: List<String>) {
+ val (name, blockName) = args
+ runChecks(plugin, player) {
+ blockHuntSupported()
+ blockHuntEnabled(name)
+ gameNotInProgress()
+ lobbyEmpty()
+ }
+
+ val material = plugin.shim.parseMaterial(blockName)
+ if (material == null) {
+ player.message(plugin.locale.prefix.error + plugin.locale.blockHunt.block.unknown)
+ return
+ }
+
+ val map = plugin.maps.get(name) ?: return
+ if (!map.config.blockHunt.blocks.contains(material)) {
+ player.message(
+ plugin.locale.prefix.error +
+ plugin.locale.blockHunt.block.doesntExist.with(material)
+ )
+ return
+ }
+
+ map.config.blockHunt.blocks -= material
+ map.reloadConfig()
+
+ plugin.saveConfig()
+ player.message(
+ plugin.locale.prefix.default + plugin.locale.blockHunt.block.removed.with(material)
+ )
+ }
+
+ override fun autoComplete(plugin: Khs, parameter: String, typed: String): List<String> =
+ when (parameter) {
+ "map" ->
+ plugin.maps
+ .filter { it.value.config.blockHunt.enabled }
+ .map { it.key }
+ .filter { it.startsWith(typed) }
+ "block" -> listOf(parameter)
+ else -> listOf()
+ }
+}