aboutsummaryrefslogtreecommitdiff
path: root/src/main/kotlin/moe/nea/firmament/gui/ConfigGui.kt
diff options
context:
space:
mode:
authornea <nea@nea.moe>2023-05-24 02:29:20 +0200
committernea <nea@nea.moe>2023-05-24 02:29:20 +0200
commit5984383d2c48b4ae84bac1827bc6ca1891af8cf0 (patch)
tree90aaae93147ce7aad48777be488039626b70512a /src/main/kotlin/moe/nea/firmament/gui/ConfigGui.kt
parent5ff50799b6c8baf6dd87ecbf44860d19a4acceab (diff)
downloadFirmament-5984383d2c48b4ae84bac1827bc6ca1891af8cf0.tar.gz
Firmament-5984383d2c48b4ae84bac1827bc6ca1891af8cf0.tar.bz2
Firmament-5984383d2c48b4ae84bac1827bc6ca1891af8cf0.zip
Common config gui
Diffstat (limited to 'src/main/kotlin/moe/nea/firmament/gui/ConfigGui.kt')
-rw-r--r--src/main/kotlin/moe/nea/firmament/gui/ConfigGui.kt94
1 files changed, 0 insertions, 94 deletions
diff --git a/src/main/kotlin/moe/nea/firmament/gui/ConfigGui.kt b/src/main/kotlin/moe/nea/firmament/gui/ConfigGui.kt
deleted file mode 100644
index 6acf68a..0000000
--- a/src/main/kotlin/moe/nea/firmament/gui/ConfigGui.kt
+++ /dev/null
@@ -1,94 +0,0 @@
-package moe.nea.firmament.gui
-
-import io.github.cottonmc.cotton.gui.client.LightweightGuiDescription
-import io.github.cottonmc.cotton.gui.widget.WButton
-import io.github.cottonmc.cotton.gui.widget.WLabel
-import io.github.cottonmc.cotton.gui.widget.WTextField
-import io.github.cottonmc.cotton.gui.widget.WToggleButton
-import io.github.cottonmc.cotton.gui.widget.data.HorizontalAlignment
-import io.github.cottonmc.cotton.gui.widget.data.Insets
-import io.github.cottonmc.cotton.gui.widget.data.VerticalAlignment
-import moe.nea.firmament.Firmament
-import moe.nea.firmament.util.data.DataHolder
-import net.minecraft.text.Text
-import kotlin.reflect.KMutableProperty1
-
-class ConfigGui<K>(val holder: DataHolder<K>, val build: ConfigGui<K>.() -> Unit) : LightweightGuiDescription() {
- private val root = WGridPanelWithPadding(verticalPadding = 4)
- private val reloadables = mutableListOf<(() -> Unit)>()
-
- init {
- setRootPanel(root)
- root.insets = Insets.ROOT_PANEL
- build()
- reload()
- }
-
- fun title(text: Text) {
- if (col != 0) {
- Firmament.logger.warn("Set title not at the top of the ConfigGui")
- }
- val label = WLabel(text)
- label.verticalAlignment = VerticalAlignment.TOP
- label.horizontalAlignment = HorizontalAlignment.CENTER
- root.add(label, 0, col, 11, 1)
- col++
- }
-
- private fun label(text: Text) {
- val label = WLabel(text)
- label.verticalAlignment = VerticalAlignment.CENTER
- root.add(label, 0, col, 5, 1)
- }
-
- fun toggle(text: Text, prop: KMutableProperty1<K, Boolean>) {
- val toggle = WToggleButton(text)
- reloadables.add { toggle.toggle = prop.get(holder.data) }
- toggle.setOnToggle {
- prop.set(holder.data, true)
- holder.markDirty()
- }
- root.add(toggle, 5, col, 6, 1)
- label(text)
- col++
- }
-
- fun button(text: Text, buttonText: Text, runnable: () -> Unit) {
- val button = WButton(buttonText)
- button.setOnClick {
- runnable.invoke()
- }
- root.add(button, 5, col, 6, 1)
- label(text)
- col++
- }
-
- fun textfield(
- text: Text,
- background: Text,
- prop: KMutableProperty1<K, String>,
- maxLength: Int = 255
- ) {
- val textfield = WTextField(background)
- textfield.isEditable = true
- reloadables.add {
- textfield.text = prop.get(holder.data)
- }
- textfield.maxLength = maxLength
- textfield.setChangedListener {
- prop.set(holder.data, it)
- holder.markDirty()
- }
- root.add(textfield, 5, col, 6, 11)
- label(text)
- col++
- }
-
- fun reload() {
- reloadables.forEach { it.invoke() }
- }
-
- private var col = 0
-
-
-}