aboutsummaryrefslogtreecommitdiff
path: root/src/main/kotlin/moe/nea/firmament
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/kotlin/moe/nea/firmament')
-rw-r--r--src/main/kotlin/moe/nea/firmament/gui/config/ManagedConfig.kt10
-rw-r--r--src/main/kotlin/moe/nea/firmament/jarvis/JarvisIntegration.kt37
2 files changed, 44 insertions, 3 deletions
diff --git a/src/main/kotlin/moe/nea/firmament/gui/config/ManagedConfig.kt b/src/main/kotlin/moe/nea/firmament/gui/config/ManagedConfig.kt
index 2115fb0..0204448 100644
--- a/src/main/kotlin/moe/nea/firmament/gui/config/ManagedConfig.kt
+++ b/src/main/kotlin/moe/nea/firmament/gui/config/ManagedConfig.kt
@@ -173,7 +173,7 @@ abstract class ManagedConfig(val name: String) {
latestGuiAppender?.reloadables?.forEach {it() }
}
- fun showConfigEditor(parent: Screen? = null) {
+ fun getConfigEditor(parent: Screen? = null): CottonClientScreen {
val lwgd = LightweightGuiDescription()
val guiapp = GuiAppender(20)
latestGuiAppender = guiapp
@@ -181,12 +181,16 @@ abstract class ManagedConfig(val name: String) {
sortedOptions.forEach { it.appendToGui(guiapp) }
guiapp.reloadables.forEach { it() }
lwgd.setRootPanel(guiapp.panel)
- setScreenLater(object : CottonClientScreen(lwgd) {
+ return object : CottonClientScreen(lwgd) {
override fun close() {
latestGuiAppender = null
MC.screen = parent
}
- })
+ }
+ }
+
+ fun showConfigEditor(parent: Screen? = null) {
+ setScreenLater(getConfigEditor(parent))
}
}
diff --git a/src/main/kotlin/moe/nea/firmament/jarvis/JarvisIntegration.kt b/src/main/kotlin/moe/nea/firmament/jarvis/JarvisIntegration.kt
new file mode 100644
index 0000000..3dfb7d0
--- /dev/null
+++ b/src/main/kotlin/moe/nea/firmament/jarvis/JarvisIntegration.kt
@@ -0,0 +1,37 @@
+package moe.nea.firmament.jarvis
+
+import moe.nea.jarvis.api.JarvisConfigOption
+import moe.nea.jarvis.api.JarvisPlugin
+import net.minecraft.client.gui.screen.Screen
+import net.minecraft.text.Text
+import moe.nea.firmament.Firmament
+import moe.nea.firmament.features.FeatureManager
+import moe.nea.firmament.repo.RepoManager
+
+class JarvisIntegration : JarvisPlugin {
+ override fun getModId(): String =
+ Firmament.MOD_ID
+
+ override fun getAllConfigOptions(): List<JarvisConfigOption> {
+ val configs = listOf(
+ RepoManager.Config
+ ) + FeatureManager.allFeatures.mapNotNull { it.config }
+ return configs.flatMap { config ->
+ config.sortedOptions.map {
+ object : JarvisConfigOption {
+ override fun title(): Text {
+ return it.labelText
+ }
+
+ override fun description(): List<Text> {
+ return emptyList()
+ }
+
+ override fun jumpTo(parentScreen: Screen?): Screen {
+ return config.getConfigEditor(parentScreen)
+ }
+ }
+ }
+ }
+ }
+}