[glade/modern-ui: 13/34] GladeWindow: replace main notebook with stack



commit e9b8156a980de37875781e6c8e0e025cf7c3fdf5
Author: Juan Pablo Ugarte <juanpablougarte gmail com>
Date:   Fri Jun 23 18:35:06 2017 -0300

    GladeWindow: replace main notebook with stack
    
    Add popover button with a stack switcher to headerbar to replace notebook tabs

 src/glade-window.c |  625 ++++++++++++++++------------------------------------
 src/glade.glade    |  235 +++++++++++++++-----
 2 files changed, 370 insertions(+), 490 deletions(-)
---
diff --git a/src/glade-window.c b/src/glade-window.c
index 27d7320..fc2e488 100644
--- a/src/glade-window.c
+++ b/src/glade-window.c
@@ -1,7 +1,7 @@
 /*
  * Copyright (C) 2001 Ximian, Inc.
  * Copyright (C) 2007 Vincent Geddes.
- * Copyright (C) 2012 Juan Pablo Ugarte.
+ * Copyright (C) 2012-2017 Juan Pablo Ugarte.
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as
@@ -27,7 +27,6 @@
 #include <config.h>
 
 #include "glade-window.h"
-#include "glade-close-button.h"
 #include "glade-resources.h"
 #include "glade-preferences.h"
 #include "glade-registration.h"
@@ -71,19 +70,23 @@
 #define CONFIG_KEY_AUTOSAVE         "autosave"
 #define CONFIG_KEY_AUTOSAVE_SECONDS "autosave-seconds"
 
+#define GLADE_WINDOW_ACTIVE_VIEW(w) ((GladeDesignView *) gtk_stack_get_visible_child (w->priv->stack))
+
 struct _GladeWindowPrivate
 {
   GladeApp *app;
 
-  GtkWidget *notebook;
-  GladeDesignView *active_view;
-  gint num_tabs;
+  GtkStack *stack;
 
   GtkHeaderBar *headerbar;
   GtkWindow *about_dialog;
   GladePreferences *preferences;
 
-  GtkNotebook *inspectors_notebook;       /* Cached per project inspectors */
+  GtkLabel *title;
+  GtkLabel *subtitle;
+  GtkWidget *project_button;
+
+  GtkStack *inspectors_stack;           /* Cached per project inspectors */
 
   GladeEditor  *editor;                 /* The editor */
 
@@ -96,7 +99,6 @@ struct _GladeWindowPrivate
 
   GtkAction *save_action, *quit_action;
   GtkAction *undo_action, *redo_action, *cut_action, *copy_action, *paste_action, *delete_action;
-  GtkAction *previous_project_action, *next_project_action;
   GtkAction *selector_radioaction;
 
   GtkActionGroup *project_actiongroup;      /* All the project actions */
@@ -108,7 +110,6 @@ struct _GladeWindowPrivate
 
   GtkWidget *quit_menuitem;
   GtkWidget *about_menuitem;
-  GtkWidget *properties_menuitem;
 
   gchar *default_path;          /* the default path for open/save operations */
 
@@ -264,7 +265,6 @@ get_formatted_project_name_for_display (GladeProject *project,
   return pass3;
 }
 
-
 static void
 refresh_title (GladeWindow *window)
 {
@@ -272,9 +272,9 @@ refresh_title (GladeWindow *window)
   gchar *title, *name = NULL;
   const gchar *path;
 
-  if (window->priv->active_view)
+  if (GLADE_WINDOW_ACTIVE_VIEW (window))
     {
-      project = glade_design_view_get_project (window->priv->active_view);
+      project = glade_design_view_get_project (GLADE_WINDOW_ACTIVE_VIEW (window));
 
       name = get_formatted_project_name_for_display (project,
                                                      FORMAT_NAME_MARK_UNSAVED |
@@ -288,11 +288,9 @@ refresh_title (GladeWindow *window)
       g_free (name);
     }
   else
-    {
-      title = g_strdup (_("User Interface Designer"));
-    }
+    title = g_strdup (_("User Interface Designer"));
 
-  gtk_window_set_title (GTK_WINDOW (window), title);
+  gtk_label_set_label (window->priv->title, title);
 
   /* Show path */
   if (project && (path = glade_project_get_path (project)))
@@ -304,15 +302,23 @@ refresh_title (GladeWindow *window)
         {
           char *subtitle = &dirname[g_utf8_strlen (home, -1) - 1];
           subtitle[0] = '~';
-          gtk_header_bar_set_subtitle (window->priv->headerbar, subtitle);
+          gtk_label_set_label (window->priv->subtitle, subtitle);
         }
       else
-        gtk_header_bar_set_subtitle (window->priv->headerbar, dirname);
+        gtk_label_set_label (window->priv->subtitle, dirname);
 
+      gtk_style_context_add_class (gtk_widget_get_style_context (window->priv->project_button),
+                                   "glade-tight-fit");
+      gtk_widget_show (GTK_WIDGET (window->priv->subtitle));
       g_free (dirname);
     }
   else
-    gtk_header_bar_set_subtitle (window->priv->headerbar, NULL);
+    {
+      gtk_style_context_remove_class (gtk_widget_get_style_context (window->priv->project_button),
+                                     "glade-tight-fit");
+      gtk_label_set_label (window->priv->subtitle, NULL);
+      gtk_widget_hide (GTK_WIDGET (window->priv->subtitle));
+    }
 
   g_free (title);
 }
@@ -444,8 +450,8 @@ add_actions (GladeWindow *window, GladeWidget *widget, GList *actions)
 static GladeProject *
 get_active_project (GladeWindow *window)
 {
-  if (window->priv->active_view)
-    return glade_design_view_get_project (window->priv->active_view);
+  if (GLADE_WINDOW_ACTIVE_VIEW (window))
+    return glade_design_view_get_project (GLADE_WINDOW_ACTIVE_VIEW (window));
 
   return NULL;
 }
@@ -486,14 +492,6 @@ project_selection_changed_cb (GladeProject *project, GladeWindow *window)
   glade_editor_load_widget (window->priv->editor, glade_widget);
 }
 
-static GladeDesignView *
-get_active_view (GladeWindow *window)
-{
-  g_return_val_if_fail (GLADE_IS_WINDOW (window), NULL);
-
-  return window->priv->active_view;
-}
-
 static gchar *
 format_project_list_item_tooltip (GladeProject *project)
 {
@@ -532,55 +530,22 @@ format_project_list_item_tooltip (GladeProject *project)
 }
 
 static void
-refresh_notebook_tab_for_project (GladeWindow *window, GladeProject *project)
+refresh_stack_title_for_project (GladeWindow *window, GladeProject *project)
 {
-  GtkWidget *tab_label, *label, *view, *eventbox;
   GList *children, *l;
-  gchar *str;
 
-  children =
-      gtk_container_get_children (GTK_CONTAINER (window->priv->notebook));
+  children = gtk_container_get_children (GTK_CONTAINER (window->priv->stack));
   for (l = children; l; l = l->next)
     {
-      view = l->data;
+      GtkWidget *view = l->data;
 
       if (project == glade_design_view_get_project (GLADE_DESIGN_VIEW (view)))
         {
-          gchar *path, *deps;
-
-          tab_label =
-              gtk_notebook_get_tab_label (GTK_NOTEBOOK (window->priv->notebook),
-                                          view);
-          label = g_object_get_data (G_OBJECT (tab_label), "tab-label");
-          eventbox = g_object_get_data (G_OBJECT (tab_label), "tab-event-box");
-
-          str = get_formatted_project_name_for_display (project,
-                                                        FORMAT_NAME_MARK_UNSAVED |
-                                                        FORMAT_NAME_MIDDLE_TRUNCATE);
-          gtk_label_set_text (GTK_LABEL (label), str);
-          g_free (str);
-
-          if (glade_project_get_path (project))
-            path =
-                glade_utils_replace_home_dir_with_tilde (glade_project_get_path
-                                                         (project));
-          else
-            path = glade_project_get_name (project);
-
-
-          deps = glade_project_display_dependencies (project);
-          str = g_markup_printf_escaped (" <b>%s</b> %s \n"
-                                         " %s \n"
-                                         " <b>%s</b> %s ",
-                                         _("Name:"), path,
-                                         glade_project_get_readonly (project) ?
-                                         READONLY_INDICATOR : "",
-                                         _("Requires:"), deps);
-
-          gtk_widget_set_tooltip_markup (eventbox, str);
-
-          g_free (path);
-          g_free (deps);
+          gchar *str = get_formatted_project_name_for_display (project,
+                                                               FORMAT_NAME_MARK_UNSAVED |
+                                                               FORMAT_NAME_MIDDLE_TRUNCATE);
+          gtk_container_child_set (GTK_CONTAINER (window->priv->stack), view,
+                                   "title", str, NULL);
           g_free (str);
 
           break;
@@ -592,7 +557,7 @@ refresh_notebook_tab_for_project (GladeWindow *window, GladeProject *project)
 static void
 project_targets_changed_cb (GladeProject *project, GladeWindow *window)
 {
-  refresh_notebook_tab_for_project (window, project);
+  refresh_stack_title_for_project (window, project);
 }
 
 static void
@@ -764,32 +729,6 @@ refresh_projects_list_item (GladeWindow *window, GladeProject *project)
 }
 
 static void
-refresh_next_prev_project_sensitivity (GladeWindow *window)
-{
-  GladeDesignView *view = get_active_view (window);
-  GladeWindowPrivate *priv = window->priv;
-
-  if (view != NULL)
-    {
-      gint view_number = gtk_notebook_page_num (GTK_NOTEBOOK (priv->notebook),
-                                                GTK_WIDGET (view));
-      g_return_if_fail (view_number >= 0);
-
-      gtk_action_set_sensitive (priv->previous_project_action, view_number != 0);
-
-      gtk_action_set_sensitive (priv->next_project_action,
-                                view_number <
-                                gtk_notebook_get_n_pages (GTK_NOTEBOOK
-                                                          (priv->notebook)) - 1);
-    }
-  else
-    {
-      gtk_action_set_sensitive (priv->previous_project_action, FALSE);
-      gtk_action_set_sensitive (priv->next_project_action, FALSE);
-    }
-}
-
-static void
 project_notify_handler_cb (GladeProject *project,
                            GParamSpec *spec,
                            GladeWindow *window)
@@ -800,21 +739,21 @@ project_notify_handler_cb (GladeProject *project,
   if (strcmp (spec->name, "path") == 0)
     {
       refresh_title (window);
-      refresh_notebook_tab_for_project (window, project);
+      refresh_stack_title_for_project (window, project);
     }
   else if (strcmp (spec->name, "format") == 0)
     {
-      refresh_notebook_tab_for_project (window, project);
+      refresh_stack_title_for_project (window, project);
     }
   else if (strcmp (spec->name, "modified") == 0)
     {
       refresh_title (window);
       refresh_projects_list_item (window, project);
-      refresh_notebook_tab_for_project (window, project);
+      refresh_stack_title_for_project (window, project);
     }
   else if (strcmp (spec->name, "read-only") == 0)
     {
-      refresh_notebook_tab_for_project (window, project);
+      refresh_stack_title_for_project (window, project);
 
       gtk_action_set_sensitive (priv->save_action, !glade_project_get_readonly (project));
     }
@@ -883,8 +822,6 @@ set_sensitivity_according_to_project (GladeWindow  *window,
                             (glade_app_get_clipboard ()));
 
   gtk_action_set_sensitive (priv->delete_action, glade_project_get_has_selection (project));
-
-  refresh_next_prev_project_sensitivity (window);
 }
 
 static gchar *
@@ -959,26 +896,11 @@ static void
 switch_to_project (GladeWindow *window, GladeProject *project)
 {
   GladeWindowPrivate *priv = window->priv;
-  guint i, n = gtk_notebook_get_n_pages (GTK_NOTEBOOK (priv->notebook));
+  GtkWidget *view;
 
-  /* increase project popularity */
-  recent_add (window, glade_project_get_path (project));
-  update_default_path (window, glade_project_get_path (project));
-
-  for (i = 0; i < n; i++)
-    {
-      GladeProject *project_i;
-      GtkWidget *view;
+  view = GTK_WIDGET (glade_design_view_get_from_project (project));
+  gtk_stack_set_visible_child (priv->stack, view);
 
-      view = gtk_notebook_get_nth_page (GTK_NOTEBOOK (priv->notebook), i);
-      project_i = glade_design_view_get_project (GLADE_DESIGN_VIEW (view));
-
-      if (project == project_i)
-        {
-          gtk_notebook_set_current_page (GTK_NOTEBOOK (priv->notebook), i);
-          break;
-        }
-    }
   check_reload_project (window, project);
 }
 
@@ -1149,7 +1071,7 @@ save (GladeWindow *window, GladeProject *project, const gchar *path)
   /* refresh names */
   refresh_title (window);
   refresh_projects_list_item (window, project);
-  refresh_notebook_tab_for_project (window, project);
+  refresh_stack_title_for_project (window, project);
 
   glade_util_flash_message (window->priv->statusbar,
                             window->priv->statusbar_actions_context_id,
@@ -1176,7 +1098,7 @@ save_as (GladeWindow *window)
   gchar *path = NULL;
   gchar *project_name;
 
-  project = glade_design_view_get_project (window->priv->active_view);
+  project = glade_design_view_get_project (GLADE_WINDOW_ACTIVE_VIEW (window));
 
   if (project == NULL)
     return;
@@ -1293,7 +1215,7 @@ on_save_action_activate (GtkAction *action, GladeWindow *window)
 {
   GladeProject *project;
 
-  project = glade_design_view_get_project (window->priv->active_view);
+  project = glade_design_view_get_project (GLADE_WINDOW_ACTIVE_VIEW (window));
 
   if (project == NULL)
     {
@@ -1425,22 +1347,10 @@ confirm_close_project (GladeWindow *window, GladeProject *project)
 }
 
 static void
-glade_window_notebook_tabs_update (GladeWindow *window)
-{
-  GList *projects = glade_app_get_projects ();
-
-  gtk_notebook_set_show_tabs (GTK_NOTEBOOK (window->priv->notebook),
-                              !(projects == NULL || g_list_next (projects) == NULL));
-}
-
-static void
-do_close (GladeWindow *window, GladeProject *project)
+close_project (GladeWindow *window, GladeProject *project)
 {
+  GladeDesignView *view = glade_design_view_get_from_project (project);
   GladeWindowPrivate *priv = window->priv;
-  GladeDesignView *view;
-  gint n;
-
-  view = glade_design_view_get_from_project (project);
 
   /* Cancel any queued autosave activity */
   project_cancel_autosave (project);
@@ -1451,19 +1361,42 @@ do_close (GladeWindow *window, GladeProject *project)
       return;
     }
 
-  n = gtk_notebook_page_num (GTK_NOTEBOOK (priv->notebook),
-                             GTK_WIDGET (view));
+  g_signal_handlers_disconnect_by_func (project, project_notify_handler_cb, window);
+  g_signal_handlers_disconnect_by_func (project, project_selection_changed_cb, window);
+  g_signal_handlers_disconnect_by_func (project, project_targets_changed_cb, window);
+  g_signal_handlers_disconnect_by_func (project, project_changed_cb, window);
+  g_signal_handlers_disconnect_by_func (project, on_pointer_mode_changed, window);
+
+  /* remove inspector first */
+  gtk_container_remove (GTK_CONTAINER (priv->inspectors_stack),
+                        g_object_get_data (G_OBJECT (view), "glade-window-view-inspector"));
+
+  /* then the main view */
+  gtk_container_remove (GTK_CONTAINER (priv->stack), GTK_WIDGET (view));
+
+  clean_actions (window);
+
+  /* Refresh the editor and some of the actions */
+  project_selection_changed_cb (project, window);
 
-  g_object_ref (view);
+  on_pointer_mode_changed (project, NULL, window);
 
-  gtk_notebook_remove_page (GTK_NOTEBOOK (priv->notebook), n);
+  glade_app_remove_project (project);
 
-  g_object_unref (view);
+  refresh_title (window);
 
-  glade_window_notebook_tabs_update (window);
+  if (GLADE_WINDOW_ACTIVE_VIEW (window))
+    set_sensitivity_according_to_project (window,
+                                          glade_design_view_get_project
+                                          (GLADE_WINDOW_ACTIVE_VIEW (window)));
+  else
+    gtk_action_group_set_sensitive (priv->project_actiongroup, FALSE);
 
   if (!glade_app_get_projects ())
     gtk_widget_hide (priv->center_paned);
+
+  if (GLADE_WINDOW_ACTIVE_VIEW (window) == NULL)
+    gtk_widget_hide (GTK_WIDGET (priv->editor));
 }
 
 static void
@@ -1473,7 +1406,7 @@ on_close_action_activate (GtkAction *action, GladeWindow *window)
   GladeProject *project;
   gboolean close;
 
-  view = window->priv->active_view;
+  view = GLADE_WINDOW_ACTIVE_VIEW (window);
 
   project = glade_design_view_get_project (view);
 
@@ -1486,7 +1419,7 @@ on_close_action_activate (GtkAction *action, GladeWindow *window)
       if (!close)
         return;
     }
-  do_close (window, project);
+  close_project (window, project);
 }
 
 static void
@@ -1494,10 +1427,10 @@ on_copy_action_activate (GtkAction *action, GladeWindow *window)
 {
   GladeProject *project;
 
-  if (!window->priv->active_view)
+  if (!GLADE_WINDOW_ACTIVE_VIEW (window))
     return;
 
-  project = glade_design_view_get_project (window->priv->active_view);
+  project = glade_design_view_get_project (GLADE_WINDOW_ACTIVE_VIEW (window));
 
   glade_project_copy_selection (project);
 }
@@ -1507,10 +1440,10 @@ on_cut_action_activate (GtkAction *action, GladeWindow *window)
 {
   GladeProject *project;
 
-  if (!window->priv->active_view)
+  if (!GLADE_WINDOW_ACTIVE_VIEW (window))
     return;
 
-  project = glade_design_view_get_project (window->priv->active_view);
+  project = glade_design_view_get_project (GLADE_WINDOW_ACTIVE_VIEW (window));
 
   glade_project_command_cut (project);
 }
@@ -1521,10 +1454,10 @@ on_paste_action_activate (GtkAction *action, GladeWindow *window)
   GtkWidget *placeholder;
   GladeProject *project;
 
-  if (!window->priv->active_view)
+  if (!GLADE_WINDOW_ACTIVE_VIEW (window))
     return;
 
-  project = glade_design_view_get_project (window->priv->active_view);
+  project = glade_design_view_get_project (GLADE_WINDOW_ACTIVE_VIEW (window));
   placeholder = glade_util_get_placeholder_from_pointer (GTK_CONTAINER (window));
 
   /* If this action is activated with a key binging (ctrl-v) the widget will be 
@@ -1538,23 +1471,54 @@ on_delete_action_activate (GtkAction *action, GladeWindow *window)
 {
   GladeProject *project;
 
-  if (!window->priv->active_view)
+  if (!GLADE_WINDOW_ACTIVE_VIEW (window))
     return;
 
-  project = glade_design_view_get_project (window->priv->active_view);
+  project = glade_design_view_get_project (GLADE_WINDOW_ACTIVE_VIEW (window));
 
   glade_project_command_delete (project);
 }
 
 static void
+stack_visible_child_next_prev (GladeWindow *window, gboolean next)
+{
+  GladeDesignView *view;
+  GList *children, *node;
+
+  if (!(view = GLADE_WINDOW_ACTIVE_VIEW (window)))
+    return;
+
+  children = gtk_container_get_children (GTK_CONTAINER (window->priv->stack));
+
+  if ((node = g_list_find (children, view)) && 
+      ((next && node->next) || (!next && node->prev)))
+    gtk_stack_set_visible_child (window->priv->stack, 
+                                 (next) ? node->next->data : node->prev->data);
+
+  g_list_free (children);
+}
+
+static void
+on_previous_project_action_activate (GtkAction *action, GladeWindow *window)
+{
+  stack_visible_child_next_prev (window, FALSE);
+}
+
+static void
+on_next_project_action_activate (GtkAction *action, GladeWindow *window)
+{
+  stack_visible_child_next_prev (window, TRUE);
+}
+
+static void
 on_properties_action_activate (GtkAction *action, GladeWindow *window)
 {
   GladeProject *project;
 
-  if (!window->priv->active_view)
+  if (!GLADE_WINDOW_ACTIVE_VIEW (window))
     return;
 
-  project = glade_design_view_get_project (window->priv->active_view);
+  project = glade_design_view_get_project (GLADE_WINDOW_ACTIVE_VIEW (window));
 
   glade_project_properties (project);
 }
@@ -1598,152 +1562,32 @@ doc_search_cb (GladeEditor *editor,
 }
 
 static void
-on_notebook_switch_page (GtkNotebook *notebook,
-                         GtkWidget *page,
-                         guint page_num,
-                         GladeWindow *window)
+on_stack_visible_child_notify (GObject    *gobject,
+                               GParamSpec *pspec,
+                               GladeWindow *window)
 {
+  GladeDesignView *view = GLADE_WINDOW_ACTIVE_VIEW (window);
   GladeWindowPrivate *priv = window->priv;
-  GladeDesignView *view;
-  GladeProject *project;
-
-  view = GLADE_DESIGN_VIEW (gtk_notebook_get_nth_page (notebook, page_num));
-
-  /* CHECK: I don't know why but it seems notebook_switch_page is called
-     two times every time the user change the active tab */
-  if (view == priv->active_view)
-    return;
-
-  window->priv->active_view = view;
-
-  project = glade_design_view_get_project (view);
-
-  refresh_title (window);
-
-  set_sensitivity_according_to_project (window, project);
-
-  /* switch to the project's inspector */
-  gtk_notebook_set_current_page (priv->inspectors_notebook, page_num);
 
-  refresh_undo_redo (window, project);
-
-  /* Refresh the editor and some of the actions */
-  project_selection_changed_cb (project, window);
-
-  on_pointer_mode_changed (project, NULL, window);
-}
-
-static void
-project_parse_finished_cb (GladeProject *project, GtkWidget *inspector)
-{
-  gtk_widget_set_sensitive (inspector, TRUE);
-
-  glade_inspector_set_project (GLADE_INSPECTOR (inspector), project);
-}
-
-static void
-on_notebook_tab_added (GtkNotebook *notebook,
-                       GladeDesignView *view,
-                       guint page_num,
-                       GladeWindow *window)
-{
-  GladeProject *project;
-  GtkWidget *inspector;
-
-  ++window->priv->num_tabs;
-
-  project = glade_design_view_get_project (view);
-
-  g_signal_connect (G_OBJECT (project), "notify::modified",
-                    G_CALLBACK (project_notify_handler_cb), window);
-  g_signal_connect (G_OBJECT (project), "notify::path",
-                    G_CALLBACK (project_notify_handler_cb), window);
-  g_signal_connect (G_OBJECT (project), "notify::format",
-                    G_CALLBACK (project_notify_handler_cb), window);
-  g_signal_connect (G_OBJECT (project), "notify::has-selection",
-                    G_CALLBACK (project_notify_handler_cb), window);
-  g_signal_connect (G_OBJECT (project), "notify::read-only",
-                    G_CALLBACK (project_notify_handler_cb), window);
-  g_signal_connect (G_OBJECT (project), "notify::pointer-mode",
-                    G_CALLBACK (on_pointer_mode_changed), window);
-  g_signal_connect (G_OBJECT (project), "selection-changed",
-                    G_CALLBACK (project_selection_changed_cb), window);
-  g_signal_connect (G_OBJECT (project), "targets-changed",
-                    G_CALLBACK (project_targets_changed_cb), window);
-  g_signal_connect (G_OBJECT (project), "changed",
-                    G_CALLBACK (project_changed_cb), window);
-
-  /* create inspector */
-  inspector = glade_inspector_new ();
-  gtk_widget_show (inspector);
-  gtk_notebook_append_page (GTK_NOTEBOOK (window->priv->inspectors_notebook),
-                            inspector, NULL);
-  
-  if (GPOINTER_TO_INT
-      (g_object_get_data (G_OBJECT (view), "view-added-while-loading")))
+  if (view)
     {
-      gtk_widget_set_sensitive (inspector, FALSE);
-      g_signal_connect (project, "parse-finished",
-                        G_CALLBACK (project_parse_finished_cb), inspector);
-    }
-  else
-    glade_inspector_set_project (GLADE_INSPECTOR (inspector), project);
-
-  set_sensitivity_according_to_project (window, project);
-
-  refresh_title (window);
+      GladeProject *project = glade_design_view_get_project (view);
 
-  if (window->priv->num_tabs > 0)
-    gtk_action_group_set_sensitive (window->priv->project_actiongroup, TRUE);
+      /* switch to the project's inspector */
+      gtk_stack_set_visible_child (priv->inspectors_stack,
+                                   g_object_get_data (G_OBJECT (view), "glade-window-view-inspector"));
 
-}
+      set_sensitivity_according_to_project (window, project);
 
-static void
-on_notebook_tab_removed (GtkNotebook     *notebook,
-                         GladeDesignView *view,
-                         guint            page_num, 
-                         GladeWindow     *window)
-{
-  GladeWindowPrivate *priv = window->priv;
-  GladeProject *project;
+      refresh_undo_redo (window, project);
 
-  --priv->num_tabs;
+      /* Refresh the editor and some of the actions */
+      project_selection_changed_cb (project, window);
 
-  if (priv->num_tabs == 0)
-    {
-      gtk_widget_hide (GTK_WIDGET (priv->editor));
-      priv->active_view = NULL;
+      on_pointer_mode_changed (project, NULL, window);
     }
 
-  project = glade_design_view_get_project (view);
-
-  g_signal_handlers_disconnect_by_func (project, project_notify_handler_cb, window);
-  g_signal_handlers_disconnect_by_func (project, project_selection_changed_cb, window);
-  g_signal_handlers_disconnect_by_func (project, project_targets_changed_cb, window);
-  g_signal_handlers_disconnect_by_func (project, project_changed_cb, window);
-  g_signal_handlers_disconnect_by_func (project, on_pointer_mode_changed, window);
-
-  gtk_notebook_remove_page (priv->inspectors_notebook, page_num);
-
-  clean_actions (window);
-
-  /* Refresh the editor and some of the actions */
-  project_selection_changed_cb (project, window);
-
-  on_pointer_mode_changed (project, NULL, window);
-
-  /* FIXME: this function needs to be preferably called somewhere else */
-  glade_app_remove_project (project);
-
   refresh_title (window);
-
-  if (priv->active_view)
-    set_sensitivity_according_to_project (window,
-                                          glade_design_view_get_project
-                                          (priv->active_view));
-  else
-    gtk_action_group_set_sensitive (priv->project_actiongroup, FALSE);
-
 }
 
 static void
@@ -2007,148 +1851,61 @@ on_selector_radioaction_changed (GtkRadioAction *action,
 }
 
 static void
-tab_close_button_clicked_cb (GtkWidget *close_button, GladeProject *project)
-{
-  GladeWindow *window = GLADE_WINDOW (glade_app_get_window ());
-  gboolean close;
-
-  if (glade_project_get_modified (project))
-    {
-      close = confirm_close_project (window, project);
-      if (!close)
-        return;
-    }
-  do_close (window, project);
-}
-
-static void
-project_load_progress_cb (GladeProject *project,
-                          gint total, gint step,
-                          GtkProgressBar *progress)
-{
-  gint fraction = (step * 1.0 / total) * 100;
-  gchar *str, *name;
-
-  if (fraction/100.0 == gtk_progress_bar_get_fraction (progress))
-    return;
-  
-  name = glade_project_get_name (project);
-  str = g_strdup_printf ("%s (%d%%)", name, fraction);
-
-  gtk_progress_bar_set_text (progress, str);
-  g_free (name);
-  g_free (str);
-
-  gtk_progress_bar_set_fraction (progress, fraction/100.0);
-
-  while (gtk_events_pending ()) gtk_main_iteration ();
-}
-
-static void
-project_load_finished_cb (GladeProject *project, GtkWidget *tab_label)
-{
-  GtkWidget *progress, *label;
-
-  progress = g_object_get_data (G_OBJECT (tab_label), "tab-progress");
-  label = g_object_get_data (G_OBJECT (tab_label), "tab-label");
-
-  gtk_widget_hide (progress);
-  gtk_widget_show (label);
-}
-
-static GtkWidget *
-create_notebook_tab (GladeWindow *window,
-                     GladeProject *project,
-                     gboolean for_file)
-{
-  GtkWidget *tab_label, *ebox, *hbox, *close_button, *label, *dummy_label;
-  GtkWidget *progress;
-
-  tab_label = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 4);
-
-  ebox = gtk_event_box_new ();
-  gtk_event_box_set_visible_window (GTK_EVENT_BOX (ebox), FALSE);
-  gtk_box_pack_start (GTK_BOX (tab_label), ebox, TRUE, TRUE, 0);
-
-  hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 4);
-  gtk_container_add (GTK_CONTAINER (ebox), hbox);
-
-  close_button = glade_close_button_new ();
-  gtk_widget_set_tooltip_text (close_button, _("Close document"));
-  gtk_box_pack_start (GTK_BOX (tab_label), close_button, FALSE, FALSE, 0);
-
-  g_signal_connect (close_button,
-                    "clicked",
-                    G_CALLBACK (tab_close_button_clicked_cb), project);
-
-  label = gtk_label_new ("");
-  gtk_widget_set_halign (label, GTK_ALIGN_START);
-  gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
-
-  progress = gtk_progress_bar_new ();
-  gtk_progress_bar_set_show_text (GTK_PROGRESS_BAR (progress), TRUE);
-  gtk_widget_add_events (progress,
-                         GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK);
-  gtk_widget_set_name (progress, "glade-tab-label-progress");
-  gtk_box_pack_start (GTK_BOX (hbox), progress, FALSE, FALSE, 0);
-  g_signal_connect (project, "load-progress",
-                    G_CALLBACK (project_load_progress_cb), progress);
-
-  dummy_label = gtk_label_new ("");
-  gtk_box_pack_start (GTK_BOX (hbox), dummy_label, TRUE, TRUE, 0);
-
-  gtk_widget_show (ebox);
-  gtk_widget_show (hbox);
-  gtk_widget_show (close_button);
-  gtk_widget_show (dummy_label);
-
-  if (for_file)
-    {
-      gtk_widget_show (progress);
-
-      g_signal_connect (project, "parse-finished",
-                        G_CALLBACK (project_load_finished_cb), tab_label);
-    }
-  else
-    gtk_widget_show (label);
-
-  g_object_set_data (G_OBJECT (tab_label), "tab-progress", progress);
-  g_object_set_data (G_OBJECT (tab_label), "tab-event-box", ebox);
-  g_object_set_data (G_OBJECT (tab_label), "tab-label", label);
-
-  return tab_label;
-}
-
-static void
 add_project (GladeWindow *window, GladeProject *project, gboolean for_file)
 {
   GladeWindowPrivate *priv = window->priv;
-  GtkWidget *view, *label;
+  GtkWidget *view, *inspector;
 
   g_return_if_fail (GLADE_IS_PROJECT (project));
 
+  /* Create a new view for project */
   view = glade_design_view_new (project);
-  gtk_widget_show (view);
 
-  g_object_set_data (G_OBJECT (view), "view-added-while-loading",
-                     GINT_TO_POINTER (for_file));
+  gtk_widget_show (priv->center_paned);
+  gtk_widget_show (GTK_WIDGET (priv->editor));
+
+  g_signal_connect (G_OBJECT (project), "notify::modified",
+                    G_CALLBACK (project_notify_handler_cb), window);
+  g_signal_connect (G_OBJECT (project), "notify::path",
+                    G_CALLBACK (project_notify_handler_cb), window);
+  g_signal_connect (G_OBJECT (project), "notify::format",
+                    G_CALLBACK (project_notify_handler_cb), window);
+  g_signal_connect (G_OBJECT (project), "notify::has-selection",
+                    G_CALLBACK (project_notify_handler_cb), window);
+  g_signal_connect (G_OBJECT (project), "notify::read-only",
+                    G_CALLBACK (project_notify_handler_cb), window);
+  g_signal_connect (G_OBJECT (project), "notify::pointer-mode",
+                    G_CALLBACK (on_pointer_mode_changed), window);
+  g_signal_connect (G_OBJECT (project), "selection-changed",
+                    G_CALLBACK (project_selection_changed_cb), window);
+  g_signal_connect (G_OBJECT (project), "targets-changed",
+                    G_CALLBACK (project_targets_changed_cb), window);
+  g_signal_connect (G_OBJECT (project), "changed",
+                    G_CALLBACK (project_changed_cb), window);
+
+  /* create inspector */
+  inspector = glade_inspector_new ();
+  g_object_set_data (G_OBJECT (view), "glade-window-view-inspector", inspector);
+  glade_inspector_set_project (GLADE_INSPECTOR (inspector), project);
+  gtk_container_add (GTK_CONTAINER (priv->inspectors_stack), inspector);
+  gtk_widget_show (inspector);
+
+  set_sensitivity_according_to_project (window, project);
+  refresh_title (window);
+
+  gtk_action_group_set_sensitive (priv->project_actiongroup, TRUE);
 
   /* Pass ownership of the project to the app */
   glade_app_add_project (project);
   g_object_unref (project);
 
-  /* Custom notebook tab label (will be refreshed later) */
-  label = create_notebook_tab (window, project, for_file);
-
-  gtk_notebook_append_page (GTK_NOTEBOOK (priv->notebook), GTK_WIDGET (view), label);
-  gtk_notebook_set_current_page (GTK_NOTEBOOK (priv->notebook), -1);
 
-  refresh_notebook_tab_for_project (window, project);
-
-  glade_window_notebook_tabs_update (window);
+  /* Add view to stack */
+  gtk_container_add (GTK_CONTAINER (priv->stack), view);
+  gtk_widget_show (view);
+  gtk_stack_set_visible_child (priv->stack, view);
 
-  gtk_widget_show (priv->center_paned);
-  gtk_widget_show (GTK_WIDGET (priv->editor));
+  refresh_stack_title_for_project (window, project);
 }
 
 static void
@@ -2188,7 +1945,7 @@ open_project (GladeWindow *window, const gchar *path)
 
   if (!glade_project_load_from_file (project, path))
     {
-      do_close (window, project);
+      close_project (window, project);
 
       recent_remove (window, path);
       return FALSE;
@@ -2277,7 +2034,7 @@ check_reload_project (GladeWindow *window, GladeProject *project)
   /* Reopen */
   path = g_strdup (glade_project_get_path (project));
 
-  do_close (window, project);
+  close_project (window, project);
   open_project (window, path);
   g_free (path);
 }
@@ -2577,7 +2334,7 @@ on_quit_action_activate (GtkAction *action, GladeWindow *window)
   for (list = projects; list; list = list->next)
     {
       GladeProject *project = GLADE_PROJECT (glade_app_get_projects ()->data);
-      do_close (window, project);
+      close_project (window, project);
     }
 
   glade_window_config_save (window);
@@ -2683,11 +2440,9 @@ glade_window_constructed (GObject *object)
     g_object_ref(sep);
     gtkosx_application_insert_app_menu_item (theApp, sep, 1);
 
-    gtkosx_application_insert_app_menu_item (theApp, priv->properties_menuitem,
-                                             2);
     sep = gtk_separator_menu_item_new();
     g_object_ref(sep);
-    gtkosx_application_insert_app_menu_item (theApp, sep, 3);
+    gtkosx_application_insert_app_menu_item (theApp, sep, 2);
 
     g_signal_connect(theApp, "NSApplicationWillTerminate",
                      G_CALLBACK(on_quit_action_activate), window);
@@ -2746,12 +2501,10 @@ glade_window_class_init (GladeWindowClass *klass)
                                    "GladeDesignView * {\n"
                                    "  -gtk-key-bindings: DisableBindings;\n"
                                    "}\n"
-                                   "GtkProgressBar#glade-tab-label-progress {\n"
-                                   "   -GtkProgressBar-min-horizontal-bar-width : 1;\n"
-                                   "   -GtkProgressBar-min-horizontal-bar-height : 1;\n"
-                                   "   -GtkProgressBar-xspacing : 4;\n"
-                                   "   -GtkProgressBar-yspacing : 0;\n"
-                                   "   padding : 0;\n" " }", -1, NULL);
+                                   ".glade-tight-fit {\n"
+                                   "  margin: 0;\n"
+                                   "  padding: 0;\n"
+                                   "}", -1, NULL);
 
   gtk_style_context_add_provider_for_screen (gdk_screen_get_default (),
                                              GTK_STYLE_PROVIDER (provider),
@@ -2762,12 +2515,15 @@ glade_window_class_init (GladeWindowClass *klass)
 
   /* Internal children */
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, headerbar);
+  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, title);
+  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, subtitle);
+  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, project_button);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, about_dialog);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, center_paned);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, left_paned);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, open_button_box);
-  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, notebook);
-  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, inspectors_notebook);
+  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, stack);
+  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, inspectors_stack);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, editor);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, statusbar);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, toolbar);
@@ -2778,7 +2534,6 @@ glade_window_class_init (GladeWindowClass *klass)
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, pointer_mode_actiongroup);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, static_actiongroup);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, quit_menuitem);
-  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, properties_menuitem);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, about_menuitem);
 
   /* Actions */
@@ -2790,8 +2545,6 @@ glade_window_class_init (GladeWindowClass *klass)
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, copy_action);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, paste_action);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, delete_action);
-  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, previous_project_action);
-  gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, next_project_action);
   gtk_widget_class_bind_template_child_private (widget_class, GladeWindow, selector_radioaction);
 
   /* Callbacks */
@@ -2803,6 +2556,8 @@ glade_window_class_init (GladeWindowClass *klass)
   gtk_widget_class_bind_template_callback (widget_class, on_cut_action_activate);
   gtk_widget_class_bind_template_callback (widget_class, on_paste_action_activate);
   gtk_widget_class_bind_template_callback (widget_class, on_delete_action_activate);
+  gtk_widget_class_bind_template_callback (widget_class, on_previous_project_action_activate);
+  gtk_widget_class_bind_template_callback (widget_class, on_next_project_action_activate);
   gtk_widget_class_bind_template_callback (widget_class, on_properties_action_activate);
   gtk_widget_class_bind_template_callback (widget_class, on_undo_action_activate);
   gtk_widget_class_bind_template_callback (widget_class, on_redo_action_activate);
@@ -2816,9 +2571,7 @@ glade_window_class_init (GladeWindowClass *klass)
   gtk_widget_class_bind_template_callback (widget_class, on_selector_radioaction_changed);
   gtk_widget_class_bind_template_callback (widget_class, on_actiongroup_connect_proxy);
   gtk_widget_class_bind_template_callback (widget_class, on_actiongroup_disconnect_proxy);
-  gtk_widget_class_bind_template_callback (widget_class, on_notebook_switch_page);
-  gtk_widget_class_bind_template_callback (widget_class, on_notebook_tab_added);
-  gtk_widget_class_bind_template_callback (widget_class, on_notebook_tab_removed);
+  gtk_widget_class_bind_template_callback (widget_class, on_stack_visible_child_notify);
   gtk_widget_class_bind_template_callback (widget_class, on_recent_menu_insert);
   gtk_widget_class_bind_template_callback (widget_class, on_recent_menu_remove);
 }
diff --git a/src/glade.glade b/src/glade.glade
index ad74610..78b5cda 100644
--- a/src/glade.glade
+++ b/src/glade.glade
@@ -246,7 +246,7 @@ Andreas Nilsson &lt;andreas andreasn se&gt;</property>
       <object class="GtkAction" id="previous_project_action">
         <property name="label" translatable="yes">_Previous Project</property>
         <property name="tooltip" translatable="yes">Activate previous project</property>
-        <signal name="activate" handler="gtk_notebook_prev_page" object="notebook" swapped="yes"/>
+        <signal name="activate" handler="on_previous_project_action_activate"/>
       </object>
       <accelerator key="Page_Up" modifiers="GDK_CONTROL_MASK"/>
     </child>
@@ -254,7 +254,7 @@ Andreas Nilsson &lt;andreas andreasn se&gt;</property>
       <object class="GtkAction" id="next_project_action">
         <property name="label" translatable="yes">_Next Project</property>
         <property name="tooltip" translatable="yes">Activate next project</property>
-        <signal name="activate" handler="gtk_notebook_next_page" object="notebook" swapped="yes"/>
+        <signal name="activate" handler="on_next_project_action_activate"/>
       </object>
       <accelerator key="Page_Down" modifiers="GDK_CONTROL_MASK"/>
     </child>
@@ -345,42 +345,6 @@ Andreas Nilsson &lt;andreas andreasn se&gt;</property>
     <property name="accel_group">accelgroup</property>
     <property name="menu_type_hint">dropdown-menu</property>
     <child>
-      <object class="GtkImageMenuItem" id="save_as_menuitem">
-        <property name="use_action_appearance">True</property>
-        <property name="related_action">save_as_action</property>
-        <property name="visible">True</property>
-        <property name="can_focus">False</property>
-        <property name="use_underline">True</property>
-        <property name="use_stock">True</property>
-      </object>
-    </child>
-    <child>
-      <object class="GtkImageMenuItem" id="properties_menuitem">
-        <property name="use_action_appearance">True</property>
-        <property name="related_action">properties_action</property>
-        <property name="visible">True</property>
-        <property name="can_focus">False</property>
-        <property name="use_underline">True</property>
-        <property name="use_stock">True</property>
-      </object>
-    </child>
-    <child>
-      <object class="GtkImageMenuItem" id="close_menuitem">
-        <property name="use_action_appearance">True</property>
-        <property name="related_action">close_action</property>
-        <property name="visible">True</property>
-        <property name="can_focus">False</property>
-        <property name="use_underline">True</property>
-        <property name="use_stock">True</property>
-      </object>
-    </child>
-    <child>
-      <object class="GtkSeparatorMenuItem">
-        <property name="visible">True</property>
-        <property name="can_focus">False</property>
-      </object>
-    </child>
-    <child>
       <object class="GtkMenuItem" id="registration_menuitem">
         <property name="use_action_appearance">True</property>
         <property name="related_action">registration_action</property>
@@ -471,15 +435,17 @@ Andreas Nilsson &lt;andreas andreasn se&gt;</property>
                 <property name="can_focus">False</property>
                 <property name="orientation">vertical</property>
                 <child>
-                  <object class="GtkNotebook" id="inspectors_notebook">
-                    <property name="width_request">256</property>
+                  <object class="GtkStack" id="inspectors_stack">
                     <property name="visible">True</property>
-                    <property name="can_focus">True</property>
-                    <property name="margin_left">4</property>
+                    <property name="can_focus">False</property>
+                    <property name="margin_left">3</property>
                     <property name="margin_right">3</property>
-                    <property name="margin_bottom">2</property>
-                    <property name="show_tabs">False</property>
-                    <property name="show_border">False</property>
+                    <property name="margin_bottom">3</property>
+                    <property name="transition_duration">128</property>
+                    <property name="transition_type">crossfade</property>
+                    <child>
+                      <placeholder/>
+                    </child>
                   </object>
                   <packing>
                     <property name="expand">True</property>
@@ -566,16 +532,15 @@ Andreas Nilsson &lt;andreas andreasn se&gt;</property>
                 <property name="visible">True</property>
                 <property name="can_focus">False</property>
                 <child>
-                  <object class="GtkNotebook" id="notebook">
-                    <property name="width_request">256</property>
+                  <object class="GtkStack" id="stack">
                     <property name="visible">True</property>
                     <property name="can_focus">False</property>
-                    <property name="show_tabs">False</property>
-                    <property name="show_border">False</property>
-                    <property name="scrollable">True</property>
-                    <signal name="page-added" handler="on_notebook_tab_added" swapped="no"/>
-                    <signal name="page-removed" handler="on_notebook_tab_removed" swapped="no"/>
-                    <signal name="switch-page" handler="on_notebook_switch_page" swapped="no"/>
+                    <property name="transition_duration">128</property>
+                    <property name="transition_type">crossfade</property>
+                    <signal name="notify::visible-child" handler="on_stack_visible_child_notify" 
swapped="no"/>
+                    <child>
+                      <placeholder/>
+                    </child>
                   </object>
                   <packing>
                     <property name="index">-1</property>
@@ -687,7 +652,7 @@ Andreas Nilsson &lt;andreas andreasn se&gt;</property>
               <object class="GtkImage">
                 <property name="visible">True</property>
                 <property name="can_focus">False</property>
-                <property name="icon_name">tab-new-symbolic</property>
+                <property name="icon_name">document-new-symbolic</property>
               </object>
             </child>
           </object>
@@ -807,6 +772,56 @@ Andreas Nilsson &lt;andreas andreasn se&gt;</property>
             <property name="position">6</property>
           </packing>
         </child>
+        <child type="title">
+          <object class="GtkMenuButton" id="project_button">
+            <property name="visible">True</property>
+            <property name="can_focus">False</property>
+            <property name="receives_default">True</property>
+            <property name="valign">center</property>
+            <property name="use_popover">False</property>
+            <property name="popover">project_popover</property>
+            <child>
+              <object class="GtkBox">
+                <property name="visible">True</property>
+                <property name="can_focus">False</property>
+                <property name="halign">center</property>
+                <property name="orientation">vertical</property>
+                <child>
+                  <object class="GtkLabel" id="title">
+                    <property name="visible">True</property>
+                    <property name="can_focus">False</property>
+                    <style>
+                      <class name="title"/>
+                    </style>
+                  </object>
+                  <packing>
+                    <property name="expand">False</property>
+                    <property name="fill">True</property>
+                    <property name="position">0</property>
+                  </packing>
+                </child>
+                <child>
+                  <object class="GtkLabel" id="subtitle">
+                    <property name="visible">True</property>
+                    <property name="can_focus">False</property>
+                    <style>
+                      <class name="subtitle"/>
+                    </style>
+                  </object>
+                  <packing>
+                    <property name="expand">False</property>
+                    <property name="fill">True</property>
+                    <property name="position">1</property>
+                  </packing>
+                </child>
+              </object>
+            </child>
+            <style>
+              <class name="titlebutton"/>
+              <class name="glade-tight-fit"/>
+            </style>
+          </object>
+        </child>
         <child>
           <object class="GtkMenuButton">
             <property name="visible">True</property>
@@ -844,4 +859,116 @@ Andreas Nilsson &lt;andreas andreasn se&gt;</property>
       </object>
     </child>
   </template>
+  <object class="GtkPopover" id="project_popover">
+    <property name="can_focus">False</property>
+    <child>
+      <object class="GtkBox">
+        <property name="visible">True</property>
+        <property name="can_focus">False</property>
+        <property name="margin_left">2</property>
+        <property name="margin_right">2</property>
+        <property name="margin_top">2</property>
+        <property name="margin_bottom">2</property>
+        <property name="orientation">vertical</property>
+        <property name="spacing">6</property>
+        <child>
+          <object class="GtkButtonBox">
+            <property name="visible">True</property>
+            <property name="can_focus">False</property>
+            <property name="homogeneous">True</property>
+            <property name="layout_style">expand</property>
+            <child>
+              <object class="GtkButton">
+                <property name="use_action_appearance">False</property>
+                <property name="related_action">save_as_action</property>
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="receives_default">True</property>
+                <property name="tooltip_text" translatable="yes">Save the current project with a different 
name</property>
+                <property name="use_underline">True</property>
+                <property name="always_show_image">True</property>
+                <child>
+                  <object class="GtkImage">
+                    <property name="visible">True</property>
+                    <property name="can_focus">False</property>
+                    <property name="icon_name">document-save-as-symbolic</property>
+                  </object>
+                </child>
+              </object>
+              <packing>
+                <property name="expand">True</property>
+                <property name="fill">True</property>
+                <property name="position">0</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkButton">
+                <property name="use_action_appearance">False</property>
+                <property name="related_action">properties_action</property>
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="receives_default">True</property>
+                <property name="tooltip_text" translatable="yes">Edit project properties</property>
+                <property name="use_underline">True</property>
+                <property name="always_show_image">True</property>
+                <child>
+                  <object class="GtkImage">
+                    <property name="visible">True</property>
+                    <property name="can_focus">False</property>
+                    <property name="icon_name">document-properties-symbolic</property>
+                  </object>
+                </child>
+              </object>
+              <packing>
+                <property name="expand">True</property>
+                <property name="fill">True</property>
+                <property name="position">1</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkButton">
+                <property name="use_action_appearance">False</property>
+                <property name="related_action">close_action</property>
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="receives_default">True</property>
+                <property name="tooltip_text" translatable="yes">Close the current project</property>
+                <property name="use_underline">True</property>
+                <child>
+                  <object class="GtkImage">
+                    <property name="visible">True</property>
+                    <property name="can_focus">False</property>
+                    <property name="icon_name">window-close-symbolic</property>
+                  </object>
+                </child>
+              </object>
+              <packing>
+                <property name="expand">True</property>
+                <property name="fill">True</property>
+                <property name="position">2</property>
+              </packing>
+            </child>
+          </object>
+          <packing>
+            <property name="expand">False</property>
+            <property name="fill">True</property>
+            <property name="position">0</property>
+          </packing>
+        </child>
+        <child>
+          <object class="GtkStackSwitcher">
+            <property name="visible">True</property>
+            <property name="can_focus">False</property>
+            <property name="orientation">vertical</property>
+            <property name="stack">stack</property>
+          </object>
+          <packing>
+            <property name="expand">False</property>
+            <property name="fill">True</property>
+            <property name="position">1</property>
+          </packing>
+        </child>
+      </object>
+    </child>
+  </object>
 </interface>


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