[libnma/lr/gtk-4.0: 10/33] ws/eap-fast: replace the GtkFileChooserButton
- From: Lubomir Rintel <lkundrak src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libnma/lr/gtk-4.0: 10/33] ws/eap-fast: replace the GtkFileChooserButton
- Date: Fri, 15 Oct 2021 12:24:13 +0000 (UTC)
commit bff70858aca8e5ff58b520c13281579ce38a3ba8
Author: Lubomir Rintel <lkundrak v3 sk>
Date: Mon Oct 11 11:55:21 2021 +0200
ws/eap-fast: replace the GtkFileChooserButton
It is gone from Gtk4. The migration manuals suggest replacing it with a
GtkButton & GtkFileChooser directly, which is what we do here.
src/nma-ws/nma-eap-fast.c | 93 ++++++++++++++++++++++++++++++++++++----------
src/nma-ws/nma-eap-fast.ui | 83 ++++++++++++++++++++++++++++++++++++++++-
2 files changed, 156 insertions(+), 20 deletions(-)
---
diff --git a/src/nma-ws/nma-eap-fast.c b/src/nma-ws/nma-eap-fast.c
index c3b3e42a..545c23f5 100644
--- a/src/nma-ws/nma-eap-fast.c
+++ b/src/nma-ws/nma-eap-fast.c
@@ -2,7 +2,7 @@
/*
* EAP-FAST authentication method (RFC4851)
*
- * Copyright 2012 - 2019 Red Hat, Inc.
+ * Copyright (C) 2012 - 2021 Red Hat, Inc.
*/
#include "nm-default.h"
@@ -26,6 +26,7 @@ struct _NMAEapFast {
GtkSizeGroup *size_group;
NMAWs8021x *ws_8021x;
gboolean is_editor;
+ char *pac_file_name;
};
static void
@@ -40,11 +41,11 @@ destroy (NMAEap *parent)
static gboolean
validate (NMAEap *parent, GError **error)
{
+ NMAEapFast *method = (NMAEapFast *) parent;
GtkWidget *widget;
GtkTreeModel *model;
GtkTreeIter iter;
NMAEap *eap = NULL;
- const char *file;
gboolean provisioning;
gboolean valid = TRUE;
@@ -53,8 +54,7 @@ validate (NMAEap *parent, GError **error)
provisioning = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget));
widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_fast_pac_file_button"));
g_assert (widget);
- file = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (widget));
- if (!provisioning && !file) {
+ if (!provisioning && !method->pac_file_name) {
widget_set_error (widget);
g_set_error_literal (error, NMA_ERROR, NMA_ERROR_GENERIC, _("missing EAP-FAST PAC file"));
valid = FALSE;
@@ -115,10 +115,10 @@ add_to_size_group (NMAEap *parent, GtkSizeGroup *group)
static void
fill_connection (NMAEap *parent, NMConnection *connection)
{
+ NMAEapFast *method = (NMAEapFast *) parent;
NMSetting8021x *s_8021x;
GtkWidget *widget;
const char *text;
- char *filename;
NMAEap *eap = NULL;
GtkTreeModel *model;
GtkTreeIter iter;
@@ -136,10 +136,7 @@ fill_connection (NMAEap *parent, NMConnection *connection)
if (text && strlen (text))
g_object_set (s_8021x, NM_SETTING_802_1X_ANONYMOUS_IDENTITY, text, NULL);
- widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_fast_pac_file_button"));
- g_assert (widget);
- filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (widget));
- g_object_set (s_8021x, NM_SETTING_802_1X_PAC_FILE, filename, NULL);
+ g_object_set (s_8021x, NM_SETTING_802_1X_PAC_FILE, method->pac_file_name, NULL);
widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_fast_pac_provision_checkbutton"));
enabled = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget));
@@ -318,6 +315,58 @@ pac_toggled_cb (GtkWidget *widget, gpointer user_data)
nma_ws_changed_cb (widget, method->ws_8021x);
}
+static void
+update_pac_chooser_button_label (NMAEap *parent, GtkWidget *chooser)
+{
+ NMAEapFast *method = (NMAEapFast *) parent;
+ GtkWidget *label;
+ char *basename;
+
+ label = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_fast_pac_file_button_label"));
+ g_assert (label);
+
+ if (method->pac_file_name) {
+ basename = g_filename_display_basename (method->pac_file_name);
+ gtk_label_set_text (GTK_LABEL (label), basename);
+ g_free (basename);
+ } else {
+ gtk_label_set_text (GTK_LABEL (label), _("(None)"));
+ }
+}
+
+static void
+pac_chooser_clicked (GtkButton* self, gpointer user_data)
+{
+ NMAEap *parent = (NMAEap *) user_data;
+ NMAEapFast *method = (NMAEapFast *) parent;
+ GtkWidget *chooser;
+ GFile *file;
+ GtkRoot *toplevel;
+
+ toplevel = gtk_widget_get_root (GTK_WIDGET (self));
+ if (toplevel && !GTK_IS_WINDOW (toplevel))
+ toplevel = NULL;
+
+ chooser = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_fast_pac_file_chooser"));
+ g_assert (chooser);
+
+ gtk_window_set_transient_for (GTK_WINDOW (chooser), (GtkWindow *) toplevel);
+
+ if (nma_gtk_dialog_run (GTK_DIALOG (chooser)) == GTK_RESPONSE_ACCEPT) {
+ if (method->pac_file_name)
+ g_clear_pointer (&method->pac_file_name, g_free);
+
+ file = gtk_file_chooser_get_file (GTK_FILE_CHOOSER (chooser));
+ if (file) {
+ method->pac_file_name = g_file_get_path (file);
+ g_object_unref (file);
+ }
+
+ update_pac_chooser_button_label (parent, chooser);
+ nma_ws_changed_cb (NULL, method->ws_8021x);
+ }
+}
+
NMAEapFast *
nma_eap_fast_new (NMAWs8021x *ws_8021x,
NMConnection *connection,
@@ -329,7 +378,7 @@ nma_eap_fast_new (NMAWs8021x *ws_8021x,
GtkWidget *widget;
GtkFileFilter *filter;
NMSetting8021x *s_8021x = NULL;
- const char *filename;
+ GFile *file;
gboolean provisioning_enabled = TRUE;
parent = nma_eap_init (sizeof (NMAEapFast),
@@ -390,12 +439,13 @@ nma_eap_fast_new (NMAWs8021x *ws_8021x,
widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_fast_pac_file_button"));
g_assert (widget);
- gtk_file_chooser_set_local_only (GTK_FILE_CHOOSER (widget), TRUE);
- gtk_file_chooser_button_set_title (GTK_FILE_CHOOSER_BUTTON (widget),
- _("Choose a PAC file"));
- g_signal_connect (G_OBJECT (widget), "selection-changed",
- (GCallback) nma_ws_changed_cb,
- ws_8021x);
+
+ g_signal_connect (G_OBJECT (widget), "clicked",
+ (GCallback) pac_chooser_clicked,
+ parent);
+
+ widget = GTK_WIDGET (gtk_builder_get_object (parent->builder, "eap_fast_pac_file_chooser"));
+ g_assert (widget);
filter = gtk_file_filter_new ();
gtk_file_filter_add_pattern (filter, "*.pac");
@@ -407,11 +457,16 @@ nma_eap_fast_new (NMAWs8021x *ws_8021x,
gtk_file_chooser_add_filter (GTK_FILE_CHOOSER (widget), filter);
if (connection && s_8021x) {
- filename = nm_setting_802_1x_get_pac_file (s_8021x);
- if (filename)
- gtk_file_chooser_set_filename (GTK_FILE_CHOOSER (widget), filename);
+ method->pac_file_name = g_strdup (nm_setting_802_1x_get_pac_file (s_8021x));
+ if (method->pac_file_name) {
+ file = g_file_new_for_path (method->pac_file_name);
+ gtk_file_chooser_set_file (GTK_FILE_CHOOSER (widget), file, NULL);
+ g_object_unref (file);
+ }
}
+ update_pac_chooser_button_label (parent, widget);
+
widget = inner_auth_combo_init (method, connection, s_8021x, secrets_only);
inner_auth_combo_changed_cb (widget, (gpointer) method);
diff --git a/src/nma-ws/nma-eap-fast.ui b/src/nma-ws/nma-eap-fast.ui
index 261206b5..80270ff4 100644
--- a/src/nma-ws/nma-eap-fast.ui
+++ b/src/nma-ws/nma-eap-fast.ui
@@ -2,6 +2,55 @@
<!-- Generated with glade 3.22.1 -->
<interface domain="libnma">
<requires lib="gtk+" version="3.10"/>
+ <object class="GtkFileChooserDialog" id="eap_fast_pac_file_chooser">
+ <property name="can-focus">False</property>
+ <action-widgets>
+ <action-widget response="-6">cancel_button</action-widget>
+ <action-widget response="-3">open_button</action-widget>
+ </action-widgets>
+ <child type="titlebar">
+ <object class="GtkHeaderBar">
+ <property name="visible">True</property>
+ <property name="can-focus">False</property>
+ <child type="title">
+ <object class="GtkLabel">
+ <property name="visible">True</property>
+ <property name="can-focus">False</property>
+ <property name="label" translatable="yes">Choose a PAC file</property>
+ <style>
+ <class name="title"/>
+ </style>
+ </object>
+ </child>
+ <child>
+ <object class="GtkButton" id="cancel_button">
+ <property name="label" translatable="yes">_Cancel</property>
+ <property name="visible">True</property>
+ <property name="can-focus">True</property>
+ <property name="receives-default">True</property>
+ <property name="use-underline">True</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkButton" id="open_button">
+ <property name="label" translatable="yes">_Open</property>
+ <property name="visible">True</property>
+ <property name="can-focus">True</property>
+ <property name="receives-default">True</property>
+ <property name="use-underline">True</property>
+ <style>
+ <class name="default"/>
+ <class name="suggested-action"/>
+ </style>
+ </object>
+ <packing>
+ <property name="pack-type">end</property>
+ <property name="position">1</property>
+ </packing>
+ </child>
+ </object>
+ </child>
+ </object>
<object class="GtkListStore" id="model8">
<columns>
<!-- column-name gchararray -->
@@ -76,9 +125,41 @@
</packing>
</child>
<child>
- <object class="GtkFileChooserButton" id="eap_fast_pac_file_button">
+ <object class="GtkButton" id="eap_fast_pac_file_button">
<property name="visible">True</property>
<property name="can_focus">False</property>
+ <child>
+ <object class="GtkBox">
+ <property name="visible">True</property>
+ <property name="can-focus">False</property>
+ <child>
+ <object class="GtkLabel" id="eap_fast_pac_file_button_label">
+ <property name="visible">True</property>
+ <property name="hexpand">True</property>
+ <property name="can-focus">False</property>
+ <property name="xalign">0</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">0</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkImage">
+ <property name="visible">True</property>
+ <property name="can-focus">False</property>
+ <property name="icon-name">document-open-symbolic</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="pack-type">end</property>
+ <property name="position">1</property>
+ </packing>
+ </child>
+ </object>
+ </child>
</object>
<packing>
<property name="left_attach">1</property>
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]