aboutsummaryrefslogtreecommitdiff
path: root/src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt
diff options
context:
space:
mode:
authornea <nea@nea.moe>2023-07-31 21:27:07 +0200
committernea <nea@nea.moe>2023-07-31 21:27:07 +0200
commitc3e1bab941f47dfd5ef5c55805015ee5d47da802 (patch)
treeb4db354834ad01260b2c544ae6bfe7e73de00a07 /src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt
parentd8ee0c458a31352eefdb2100a53c3af268b2bb53 (diff)
downloadFirmament-c3e1bab941f47dfd5ef5c55805015ee5d47da802.tar.gz
Firmament-c3e1bab941f47dfd5ef5c55805015ee5d47da802.tar.bz2
Firmament-c3e1bab941f47dfd5ef5c55805015ee5d47da802.zip
Improve config gui handling
Diffstat (limited to 'src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt')
-rw-r--r--src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt22
1 files changed, 8 insertions, 14 deletions
diff --git a/src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt b/src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt
index c705f7f..c7a9a55 100644
--- a/src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt
+++ b/src/main/kotlin/moe/nea/firmament/gui/config/IntegerHandler.kt
@@ -1,5 +1,6 @@
package moe.nea.firmament.gui.config
+import io.github.cottonmc.cotton.gui.widget.WBox
import io.github.cottonmc.cotton.gui.widget.WLabel
import io.github.cottonmc.cotton.gui.widget.WSlider
import io.github.cottonmc.cotton.gui.widget.data.Axis
@@ -9,7 +10,9 @@ import kotlinx.serialization.json.JsonElement
import kotlinx.serialization.json.JsonPrimitive
import kotlinx.serialization.json.int
import kotlinx.serialization.json.jsonPrimitive
+import kotlin.time.Duration.Companion.milliseconds
import net.minecraft.text.Text
+import moe.nea.firmament.util.FirmFormatters
class IntegerHandler(val config: ManagedConfig, val min: Int, val max: Int) : ManagedConfig.OptionHandler<Int> {
override fun toJson(element: Int): JsonElement? {
@@ -21,20 +24,11 @@ class IntegerHandler(val config: ManagedConfig, val min: Int, val max: Int) : Ma
}
override fun emitGuiElements(opt: ManagedConfig.Option<Int>, guiAppender: GuiAppender) {
- val lw = guiAppender.width / 2
- guiAppender.set(
- 0, 0, lw, 1,
- WLabel(opt.labelText).setVerticalAlignment(VerticalAlignment.CENTER)
- )
val label =
WLabel(Text.literal(opt.value.toString())).setVerticalAlignment(VerticalAlignment.CENTER)
- guiAppender.set(lw, 0, 2, 1, label)
- guiAppender.set(
- lw + 2,
- 0,
- lw - 2,
- 1,
- WSlider(min, max, Axis.HORIZONTAL).apply {
+ guiAppender.appendLabeledRow(opt.labelText, WBox(Axis.HORIZONTAL).also {
+ it.add(label, 40, 18)
+ it.add(WSlider(min, max, Axis.HORIZONTAL).apply {
valueChangeListener = IntConsumer {
opt.value = it
label.text = Text.literal(opt.value.toString())
@@ -44,8 +38,8 @@ class IntegerHandler(val config: ManagedConfig, val min: Int, val max: Int) : Ma
value = opt.value
label.text = Text.literal(opt.value.toString())
}
- })
- guiAppender.skipRows(1)
+ }, 130, 18)
+ })
}
}