From 2bb00917a2c05b0349d8a75dc0396741cd662533 Mon Sep 17 00:00:00 2001 From: deltragon Date: Wed, 6 Mar 2024 21:06:41 +0100 Subject: [PATCH] fixup confirmation dialogs for gtk4 --- safeeyes/ui/settings_dialog.py | 59 +++++++++++++++++----------------- 1 file changed, 30 insertions(+), 29 deletions(-) diff --git a/safeeyes/ui/settings_dialog.py b/safeeyes/ui/settings_dialog.py index 3b95e443..38ec2637 100644 --- a/safeeyes/ui/settings_dialog.py +++ b/safeeyes/ui/settings_dialog.py @@ -164,56 +164,57 @@ def __create_break_item(self, break_config, is_short): def on_reset_menu_clicked(self, button): self.popover.hide() - def __confirmation_dialog_response(widget, response_id): - if response_id == Gtk.ResponseType.OK: + def __confirmation_dialog_response(dialog, result): + response_id = dialog.choose_finish(result) + if response_id == 1: utility.reset_config() self.config = Config() # Remove breaks from the container - self.box_short_breaks.foreach(lambda element: self.box_short_breaks.remove(element)) - self.box_long_breaks.foreach(lambda element: self.box_long_breaks.remove(element)) - # Remove plugins from the container - self.box_plugins.foreach(lambda element: self.box_plugins.remove(element)) + self.__clear_children(self.box_short_breaks) + self.__clear_children(self.box_long_breaks) + self.__clear_children(self.box_plugins) # Initialize again self.__initialize(self.config) - widget.destroy() - messagedialog = Gtk.MessageDialog() + messagedialog = Gtk.AlertDialog() messagedialog.set_modal(True) - messagedialog.set_transient_for(self.window) - messagedialog.set_property('message_type', Gtk.MessageType.WARNING) - messagedialog.set_property('text', _("Are you sure you want to reset all settings to default?")) - messagedialog.set_property('secondary-text', _("You can't undo this action.")) - messagedialog.add_button('_Cancel', Gtk.ResponseType.CANCEL) - messagedialog.add_button(_("Reset"), Gtk.ResponseType.OK) + messagedialog.set_buttons(['_Cancel', _("Reset")]) + messagedialog.set_message(_("Are you sure you want to reset all settings to default?")) + messagedialog.set_detail(_("You can't undo this action.")) - messagedialog.connect("response", __confirmation_dialog_response) - messagedialog.show() + messagedialog.set_cancel_button(0) + messagedialog.set_default_button(0) + + messagedialog.choose(self.window, None, __confirmation_dialog_response) + + def __clear_children(self, widget): + while widget.get_last_child() is not None: + widget.remove(widget.get_last_child()) def __delete_break(self, break_config, is_short, on_remove): """ Remove the break after a confirmation. """ - def __confirmation_dialog_response(widget, response_id): - if response_id == Gtk.ResponseType.OK: + def __confirmation_dialog_response(dialog, result): + response_id = dialog.choose_finish(result) + if response_id == 1: if is_short: self.config.get('short_breaks').remove(break_config) else: self.config.get('long_breaks').remove(break_config) on_remove() - widget.destroy() - messagedialog = Gtk.MessageDialog() + messagedialog = Gtk.AlertDialog() messagedialog.set_modal(True) - messagedialog.set_transient_for(self.window) - messagedialog.set_property('message_type', Gtk.MessageType.WARNING) - messagedialog.set_property('text', _("Are you sure you want to delete this break?")) - messagedialog.set_property('secondary-text', _("You can't undo this action.")) - messagedialog.add_button('_Cancel', Gtk.ResponseType.CANCEL) - messagedialog.add_button(_("Delete"), Gtk.ResponseType.OK) - - messagedialog.connect("response", __confirmation_dialog_response) - messagedialog.show() + messagedialog.set_buttons(['_Cancel', _("Delete")]) + messagedialog.set_message(_("Are you sure you want to delete this break?")) + messagedialog.set_detail(_("You can't undo this action.")) + + messagedialog.set_cancel_button(0) + messagedialog.set_default_button(0) + + messagedialog.choose(self.window, None, __confirmation_dialog_response) def __create_plugin_item(self, plugin_config): """