aboutsummaryrefslogtreecommitdiff
path: root/game/src/OptionMenu/SettingNodes/SettingRevertButton.gd
diff options
context:
space:
mode:
author George L. Albany <Megacake1234@gmail.com>2023-05-21 01:21:45 +0200
committer GitHub <noreply@github.com>2023-05-21 01:21:45 +0200
commit54afdfccd4ded46fd61ff11c45bbeb05489b73e7 (patch)
tree54d7092a3f68740e92008e073334d6beb3154a8b /game/src/OptionMenu/SettingNodes/SettingRevertButton.gd
parente80966ad4d92599bd5f899dfa708d2e6d131b7e7 (diff)
parent3bf63f1615868cb4a8625356a49eff4aed36879c (diff)
Merge pull request #120 from Spartan322/overhaul/resolution-revert
Diffstat (limited to 'game/src/OptionMenu/SettingNodes/SettingRevertButton.gd')
-rw-r--r--game/src/OptionMenu/SettingNodes/SettingRevertButton.gd27
1 files changed, 27 insertions, 0 deletions
diff --git a/game/src/OptionMenu/SettingNodes/SettingRevertButton.gd b/game/src/OptionMenu/SettingNodes/SettingRevertButton.gd
new file mode 100644
index 0000000..945d35b
--- /dev/null
+++ b/game/src/OptionMenu/SettingNodes/SettingRevertButton.gd
@@ -0,0 +1,27 @@
+extends SettingOptionButton
+class_name SettingRevertButton
+
+@export_group("Nodes")
+@export var revert_dialog : ResolutionRevertDialog
+
+var previous_index : int = -1
+
+func _ready():
+ super()
+ if revert_dialog != null:
+ revert_dialog.visibility_changed.connect(_on_revert_dialog_visibility_changed)
+ revert_dialog.dialog_accepted.connect(_on_accepted)
+ revert_dialog.dialog_reverted.connect(_on_reverted)
+
+func _on_revert_dialog_visibility_changed() -> void:
+ disabled = revert_dialog.visible
+ if not revert_dialog.visible:
+ previous_index = -1
+
+func _on_reverted(button : SettingRevertButton) -> void:
+ if button != self: return
+ selected = previous_index
+ option_selected.emit(selected, false)
+
+func _on_accepted(button : SettingRevertButton) -> void:
+ if button != self: return