[gnome-calendar/calendar-editor] source-dialog: use GtkFileChooserButton



commit a524ec73618f5555db8a7c0f77461c8442df3c3f
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date:   Mon Feb 23 15:18:30 2015 -0300

    source-dialog: use GtkFileChooserButton

 data/ui/source-dialog.ui |    7 ++-
 src/gcal-source-dialog.c |  100 ++++++++++++++++++++--------------------------
 2 files changed, 47 insertions(+), 60 deletions(-)
---
diff --git a/data/ui/source-dialog.ui b/data/ui/source-dialog.ui
index f8a52db..9e1a5e0 100644
--- a/data/ui/source-dialog.ui
+++ b/data/ui/source-dialog.ui
@@ -207,13 +207,14 @@
                     <property name="border_width">18</property>
                     <property name="row_spacing">12</property>
                     <child>
-                      <object class="GtkButton" id="select_file_button">
-                        <property name="label" translatable="yes">Select Calendar File…</property>
+                      <object class="GtkFileChooserButton" id="select_file_button">
                         <property name="visible">True</property>
                         <property name="can_focus">True</property>
                         <property name="receives_default">True</property>
                         <property name="hexpand">True</property>
-                        <signal name="clicked" handler="select_calendar_file" object="GcalSourceDialog" 
swapped="no"/>
+                        <property name="action">GTK_FILE_CHOOSER_ACTION_OPEN</property>
+                        <property name="local_only">True</property>
+                        <signal name="file_set" handler="calendar_file_selected" object="GcalSourceDialog" 
swapped="no"/>
                       </object>
                       <packing>
                         <property name="left_attach">0</property>
diff --git a/src/gcal-source-dialog.c b/src/gcal-source-dialog.c
index 19692ca..50d449d 100644
--- a/src/gcal-source-dialog.c
+++ b/src/gcal-source-dialog.c
@@ -98,8 +98,8 @@ static void       response_signal                       (GtkDialog           *di
                                                          gint                 response_id,
                                                          gpointer             user_data);
 
-static void       select_calendar_file                 (GtkButton            *button,
-                                                        gpointer              user_data);
+static void       calendar_file_selected                (GtkFileChooserButton *button,
+                                                         gpointer              user_data);
 
 static void       setup_source_details                 (GcalSourceDialog     *dialog,
                                                         ESource              *source);
@@ -152,7 +152,6 @@ clear_pages (GcalSourceDialog *dialog)
 {
   GcalSourceDialogPrivate *priv = dialog->priv;
 
-  gtk_button_set_label (GTK_BUTTON (priv->select_file_button), _("Select Calendar File…"));
   gtk_entry_set_text (GTK_ENTRY (priv->calendar_address_entry), "");
   gtk_widget_set_sensitive (priv->add_button, FALSE);
 
@@ -320,7 +319,7 @@ response_signal (GtkDialog *dialog,
 }
 
 /**
- * select_calendar_file:
+ * calendar_file_selected:
  *
  * Opens a file selector dialog and
  * parse the resulting selection.
@@ -328,70 +327,49 @@ response_signal (GtkDialog *dialog,
  * Returns:
  */
 static void
-select_calendar_file (GtkButton *button,
-                      gpointer   user_data)
+calendar_file_selected (GtkFileChooserButton *button,
+                        gpointer              user_data)
 {
   GcalSourceDialogPrivate *priv = GCAL_SOURCE_DIALOG (user_data)->priv;
-  GtkFileFilter *filter;
-  GtkWidget *dialog;
-  gint response;
-
-  /* File filter */
-  filter = gtk_file_filter_new ();
-  gtk_file_filter_set_name (filter, _("Calendar files"));
-  gtk_file_filter_add_mime_type (filter, "text/calendar");
+  ESourceExtension *ext;
+  ESource *source;
+  GFile *file;
 
-  /* File chooser dialog */
-  dialog = gtk_file_chooser_dialog_new (_("Select a calendar file"), GTK_WINDOW (user_data),
-                                        GTK_FILE_CHOOSER_ACTION_OPEN, _("Cancel"), GTK_RESPONSE_CANCEL, 
_("Open"),
-                                        GTK_RESPONSE_OK, NULL);
+  file = gtk_file_chooser_get_file (GTK_FILE_CHOOSER (priv->select_file_button));
 
-  gtk_file_chooser_add_filter (GTK_FILE_CHOOSER (dialog), filter);
+  if (file == NULL)
+    return;
 
-  response = gtk_dialog_run (GTK_DIALOG (dialog));
-
-  if (response == GTK_RESPONSE_OK)
-    {
-      ESourceExtension *ext;
-      ESource *source;
-      GFile *file;
-
-      file = gtk_file_chooser_get_file (GTK_FILE_CHOOSER (dialog));
-
-      /**
-       * Remove any reminescent ESources
-       * cached before.
-       */
-      if (priv->local_source != NULL)
-        g_clear_pointer (&(priv->local_source), g_object_unref);
-
-      /**
-       * Create the new source and add the needed
-       * extensions.
-       */
-      source = e_source_new (NULL, NULL, NULL);
-      e_source_set_parent (source, "local-stub");
+  /**
+   * Remove any reminescent ESources
+   * cached before.
+   */
+  if (priv->local_source != NULL)
+    g_clear_pointer (&(priv->local_source), g_object_unref);
 
-      ext = e_source_get_extension (source, E_SOURCE_EXTENSION_CALENDAR);
-      e_source_backend_set_backend_name (E_SOURCE_BACKEND (ext), "local");
+  /**
+   * Create the new source and add the needed
+   * extensions.
+   */
+  source = e_source_new (NULL, NULL, NULL);
+  e_source_set_parent (source, "local-stub");
 
-      ext = e_source_get_extension (source, E_SOURCE_EXTENSION_LOCAL_BACKEND);
-      e_source_local_set_custom_file (E_SOURCE_LOCAL (ext), file);
+  ext = e_source_get_extension (source, E_SOURCE_EXTENSION_CALENDAR);
+  e_source_backend_set_backend_name (E_SOURCE_BACKEND (ext), "local");
 
-      /* update the source properties */
-      e_source_set_display_name (source, g_file_get_basename (file));
+  ext = e_source_get_extension (source, E_SOURCE_EXTENSION_LOCAL_BACKEND);
+  e_source_local_set_custom_file (E_SOURCE_LOCAL (ext), file);
 
-      /* Set the private source so it saves at closing */
-      priv->local_source = source;
+  /* update the source properties */
+  e_source_set_display_name (source, g_file_get_basename (file));
 
-      /* Update buttons */
-      gtk_button_set_label (GTK_BUTTON (priv->select_file_button), g_file_get_basename (file));
-      gtk_widget_set_sensitive (priv->add_button, source != NULL);
+  /* Set the private source so it saves at closing */
+  priv->local_source = source;
 
-      setup_source_details (GCAL_SOURCE_DIALOG (user_data), source);
-    }
+  /* Update buttons */
+  gtk_widget_set_sensitive (priv->add_button, source != NULL);
 
-  gtk_widget_destroy (dialog);
+  setup_source_details (GCAL_SOURCE_DIALOG (user_data), source);
 }
 
 /**
@@ -533,6 +511,7 @@ gcal_source_dialog_constructed (GObject *object)
 {
   GcalSourceDialog *self = (GcalSourceDialog *)object;
   GcalSourceDialogPrivate *priv = gcal_source_dialog_get_instance_private (self);
+  GtkFileFilter *filter;
 
   G_OBJECT_CLASS (gcal_source_dialog_parent_class)->constructed (object);
 
@@ -543,6 +522,13 @@ gcal_source_dialog_constructed (GObject *object)
   g_object_set_data (G_OBJECT (priv->cancel_button), "response", GINT_TO_POINTER (GTK_RESPONSE_CANCEL));
   g_object_set_data (G_OBJECT (priv->remove_button), "response", GINT_TO_POINTER 
(GCAL_RESPONSE_REMOVE_SOURCE));
 
+  /* File filter */
+  filter = gtk_file_filter_new ();
+  gtk_file_filter_set_name (filter, _("Calendar files"));
+  gtk_file_filter_add_mime_type (filter, "text/calendar");
+
+  gtk_file_chooser_add_filter (GTK_FILE_CHOOSER (priv->select_file_button), filter);
+
   /* setup titlebar */
   gtk_window_set_titlebar (GTK_WINDOW (object), priv->headerbar);
 }
@@ -588,13 +574,13 @@ gcal_source_dialog_class_init (GcalSourceDialogClass *klass)
   gtk_widget_class_bind_template_child_private (widget_class, GcalSourceDialog, web_source_grid);
 
   gtk_widget_class_bind_template_callback (widget_class, action_widget_activated);
+  gtk_widget_class_bind_template_callback (widget_class, calendar_file_selected);
   gtk_widget_class_bind_template_callback (widget_class, color_set);
   gtk_widget_class_bind_template_callback (widget_class, default_check_toggled);
   gtk_widget_class_bind_template_callback (widget_class, description_label_link_activated);
   gtk_widget_class_bind_template_callback (widget_class, name_entry_text_changed);
   gtk_widget_class_bind_template_callback (widget_class, notebook_page_switched);
   gtk_widget_class_bind_template_callback (widget_class, response_signal);
-  gtk_widget_class_bind_template_callback (widget_class, select_calendar_file);
   gtk_widget_class_bind_template_callback (widget_class, spinner_damaged);
   gtk_widget_class_bind_template_callback (widget_class, url_entry_text_changed);
 }


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]