mirror of
https://gitlab.bixilon.de/bixilon/minosoft.git
synced 2025-09-18 03:44:54 -04:00
eros: hide dialogs with escape, confirm with enter
This commit is contained in:
parent
a9ab04b41f
commit
f13a4e8593
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* Minosoft
|
||||||
|
* Copyright (C) 2021 Moritz Zwerger
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package de.bixilon.minosoft.gui.eros.controller
|
||||||
|
|
||||||
|
import javafx.scene.input.KeyCode
|
||||||
|
import javafx.scene.input.KeyEvent
|
||||||
|
|
||||||
|
abstract class DialogController : JavaFXWindowController() {
|
||||||
|
|
||||||
|
|
||||||
|
override fun postInit() {
|
||||||
|
super.postInit()
|
||||||
|
|
||||||
|
stage.scene.root.addEventFilter(KeyEvent.KEY_PRESSED) {
|
||||||
|
if (it.code == KeyCode.ESCAPE) {
|
||||||
|
stage.close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -14,7 +14,7 @@
|
|||||||
package de.bixilon.minosoft.gui.eros.dialog
|
package de.bixilon.minosoft.gui.eros.dialog
|
||||||
|
|
||||||
import de.bixilon.minosoft.Minosoft
|
import de.bixilon.minosoft.Minosoft
|
||||||
import de.bixilon.minosoft.gui.eros.controller.JavaFXWindowController
|
import de.bixilon.minosoft.gui.eros.controller.DialogController
|
||||||
import de.bixilon.minosoft.gui.eros.crash.ErosCrashReport.Companion.crash
|
import de.bixilon.minosoft.gui.eros.crash.ErosCrashReport.Companion.crash
|
||||||
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil
|
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil
|
||||||
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.ctext
|
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.ctext
|
||||||
@ -30,7 +30,7 @@ import javafx.scene.control.TextArea
|
|||||||
import javafx.scene.text.TextFlow
|
import javafx.scene.text.TextFlow
|
||||||
|
|
||||||
|
|
||||||
class ErosErrorReport : JavaFXWindowController() {
|
class ErosErrorReport : DialogController() {
|
||||||
@FXML private lateinit var headerFX: TextFlow
|
@FXML private lateinit var headerFX: TextFlow
|
||||||
@FXML private lateinit var descriptionFX: TextFlow
|
@FXML private lateinit var descriptionFX: TextFlow
|
||||||
@FXML private lateinit var detailsFX: TextArea
|
@FXML private lateinit var detailsFX: TextArea
|
||||||
|
@ -15,7 +15,7 @@ package de.bixilon.minosoft.gui.eros.dialog
|
|||||||
|
|
||||||
import de.bixilon.minosoft.Minosoft
|
import de.bixilon.minosoft.Minosoft
|
||||||
import de.bixilon.minosoft.data.text.ChatComponent
|
import de.bixilon.minosoft.data.text.ChatComponent
|
||||||
import de.bixilon.minosoft.gui.eros.controller.JavaFXWindowController
|
import de.bixilon.minosoft.gui.eros.controller.DialogController
|
||||||
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil
|
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil
|
||||||
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.text
|
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.text
|
||||||
import de.bixilon.minosoft.util.KUtil.asResourceLocation
|
import de.bixilon.minosoft.util.KUtil.asResourceLocation
|
||||||
@ -23,6 +23,8 @@ import de.bixilon.minosoft.util.task.pool.DefaultThreadPool
|
|||||||
import javafx.application.Platform
|
import javafx.application.Platform
|
||||||
import javafx.fxml.FXML
|
import javafx.fxml.FXML
|
||||||
import javafx.scene.control.Button
|
import javafx.scene.control.Button
|
||||||
|
import javafx.scene.input.KeyCode
|
||||||
|
import javafx.scene.input.KeyEvent
|
||||||
import javafx.scene.text.TextFlow
|
import javafx.scene.text.TextFlow
|
||||||
|
|
||||||
class SimpleErosConfirmationDialog(
|
class SimpleErosConfirmationDialog(
|
||||||
@ -33,7 +35,7 @@ class SimpleErosConfirmationDialog(
|
|||||||
val confirmButtonText: Any = DEFAULT_CONFIRM_TEXT,
|
val confirmButtonText: Any = DEFAULT_CONFIRM_TEXT,
|
||||||
val onCancel: () -> Unit = {},
|
val onCancel: () -> Unit = {},
|
||||||
val onConfirm: () -> Unit,
|
val onConfirm: () -> Unit,
|
||||||
) : JavaFXWindowController() {
|
) : DialogController() {
|
||||||
@FXML private lateinit var headerFX: TextFlow
|
@FXML private lateinit var headerFX: TextFlow
|
||||||
@FXML private lateinit var descriptionFX: TextFlow
|
@FXML private lateinit var descriptionFX: TextFlow
|
||||||
@FXML private lateinit var cancelButtonFX: Button
|
@FXML private lateinit var cancelButtonFX: Button
|
||||||
@ -53,16 +55,30 @@ class SimpleErosConfirmationDialog(
|
|||||||
confirmButtonFX.text = Minosoft.LANGUAGE_MANAGER.translate(confirmButtonText).message
|
confirmButtonFX.text = Minosoft.LANGUAGE_MANAGER.translate(confirmButtonText).message
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun postInit() {
|
||||||
|
super.postInit()
|
||||||
|
|
||||||
|
stage.setOnCloseRequest {
|
||||||
|
DefaultThreadPool += onCancel
|
||||||
|
}
|
||||||
|
|
||||||
|
stage.scene.root.addEventFilter(KeyEvent.KEY_PRESSED) {
|
||||||
|
if (it.code == KeyCode.ENTER) {
|
||||||
|
confirm()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
fun confirm() {
|
fun confirm() {
|
||||||
DefaultThreadPool += onConfirm
|
DefaultThreadPool += onConfirm
|
||||||
stage.hide()
|
stage.close()
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
fun cancel() {
|
fun cancel() {
|
||||||
DefaultThreadPool += onCancel
|
DefaultThreadPool += onCancel
|
||||||
stage.hide()
|
stage.close()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@ import de.bixilon.minosoft.data.registries.versions.Version
|
|||||||
import de.bixilon.minosoft.data.registries.versions.VersionTypes
|
import de.bixilon.minosoft.data.registries.versions.VersionTypes
|
||||||
import de.bixilon.minosoft.data.registries.versions.Versions
|
import de.bixilon.minosoft.data.registries.versions.Versions
|
||||||
import de.bixilon.minosoft.data.text.TranslatableComponents
|
import de.bixilon.minosoft.data.text.TranslatableComponents
|
||||||
import de.bixilon.minosoft.gui.eros.controller.JavaFXWindowController
|
import de.bixilon.minosoft.gui.eros.controller.DialogController
|
||||||
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil
|
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil
|
||||||
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.ctext
|
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.ctext
|
||||||
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.placeholder
|
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.placeholder
|
||||||
@ -31,6 +31,8 @@ import de.bixilon.minosoft.util.task.pool.DefaultThreadPool
|
|||||||
import javafx.application.Platform
|
import javafx.application.Platform
|
||||||
import javafx.fxml.FXML
|
import javafx.fxml.FXML
|
||||||
import javafx.scene.control.*
|
import javafx.scene.control.*
|
||||||
|
import javafx.scene.input.KeyCode
|
||||||
|
import javafx.scene.input.KeyEvent
|
||||||
import javafx.scene.text.TextFlow
|
import javafx.scene.text.TextFlow
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -38,9 +40,8 @@ import javafx.scene.text.TextFlow
|
|||||||
*/
|
*/
|
||||||
class UpdateServerDialog(
|
class UpdateServerDialog(
|
||||||
private val server: Server? = null,
|
private val server: Server? = null,
|
||||||
val onCancel: () -> Unit = {},
|
|
||||||
val onUpdate: (name: String, address: String, forcedVersion: Version?) -> Unit,
|
val onUpdate: (name: String, address: String, forcedVersion: Version?) -> Unit,
|
||||||
) : JavaFXWindowController() {
|
) : DialogController() {
|
||||||
@FXML private lateinit var descriptionFX: TextFlow
|
@FXML private lateinit var descriptionFX: TextFlow
|
||||||
|
|
||||||
@FXML private lateinit var serverNameLabelFX: TextFlow
|
@FXML private lateinit var serverNameLabelFX: TextFlow
|
||||||
@ -165,8 +166,22 @@ class UpdateServerDialog(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun postInit() {
|
||||||
|
super.postInit()
|
||||||
|
|
||||||
|
|
||||||
|
stage.scene.root.addEventFilter(KeyEvent.KEY_PRESSED) {
|
||||||
|
if (it.code == KeyCode.ENTER) {
|
||||||
|
update()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
fun update() {
|
fun update() {
|
||||||
|
if (updateServerButtonFX.isDisable) {
|
||||||
|
return
|
||||||
|
}
|
||||||
val forcedVersion = (forcedVersionFX.selectionModel.selectedItem == Versions.AUTOMATIC_VERSION).decide(null) { forcedVersionFX.selectionModel.selectedItem }
|
val forcedVersion = (forcedVersionFX.selectionModel.selectedItem == Versions.AUTOMATIC_VERSION).decide(null) { forcedVersionFX.selectionModel.selectedItem }
|
||||||
DefaultThreadPool += { onUpdate(serverNameFX.text.isBlank().decide({ serverAddressFX.text.toString() }, { serverNameFX.text.trim() }), serverAddressFX.text, forcedVersion) }
|
DefaultThreadPool += { onUpdate(serverNameFX.text.isBlank().decide({ serverAddressFX.text.toString() }, { serverNameFX.text.trim() }), serverAddressFX.text, forcedVersion) }
|
||||||
stage.close()
|
stage.close()
|
||||||
@ -174,7 +189,6 @@ class UpdateServerDialog(
|
|||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
fun cancel() {
|
fun cancel() {
|
||||||
DefaultThreadPool += onCancel
|
|
||||||
stage.close()
|
stage.close()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@ package de.bixilon.minosoft.gui.eros.dialog.connection
|
|||||||
|
|
||||||
import de.bixilon.minosoft.Minosoft
|
import de.bixilon.minosoft.Minosoft
|
||||||
import de.bixilon.minosoft.data.text.ChatComponent
|
import de.bixilon.minosoft.data.text.ChatComponent
|
||||||
import de.bixilon.minosoft.gui.eros.controller.JavaFXWindowController
|
import de.bixilon.minosoft.gui.eros.controller.DialogController
|
||||||
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil
|
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil
|
||||||
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.text
|
import de.bixilon.minosoft.gui.eros.util.JavaFXUtil.text
|
||||||
import de.bixilon.minosoft.util.KUtil.asResourceLocation
|
import de.bixilon.minosoft.util.KUtil.asResourceLocation
|
||||||
@ -29,7 +29,7 @@ class KickDialog(
|
|||||||
val header: Any,
|
val header: Any,
|
||||||
val description: Any? = null,
|
val description: Any? = null,
|
||||||
val reason: ChatComponent,
|
val reason: ChatComponent,
|
||||||
) : JavaFXWindowController() {
|
) : DialogController() {
|
||||||
@FXML private lateinit var headerFX: TextFlow
|
@FXML private lateinit var headerFX: TextFlow
|
||||||
@FXML private lateinit var descriptionFX: TextFlow
|
@FXML private lateinit var descriptionFX: TextFlow
|
||||||
@FXML private lateinit var reasonFX: TextFlow
|
@FXML private lateinit var reasonFX: TextFlow
|
||||||
|
Loading…
x
Reference in New Issue
Block a user