summaryrefslogtreewikicommitdiff
path: root/core/src/command/map/blockhunt/Enabled.kt
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/Enabled.kt
downloadkenshinshideandseek2-f8322cd21cde68a72b05efbad3a05b8e67c0bdd0.tar.gz
kenshinshideandseek2-f8322cd21cde68a72b05efbad3a05b8e67c0bdd0.tar.bz2
kenshinshideandseek2-f8322cd21cde68a72b05efbad3a05b8e67c0bdd0.zip
initial
Diffstat (limited to 'core/src/command/map/blockhunt/Enabled.kt')
-rw-r--r--core/src/command/map/blockhunt/Enabled.kt39
1 files changed, 39 insertions, 0 deletions
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()
+ }
+}