diff options
Diffstat (limited to 'shell/e-shell-window.c')
-rw-r--r-- | shell/e-shell-window.c | 78 |
1 files changed, 68 insertions, 10 deletions
diff --git a/shell/e-shell-window.c b/shell/e-shell-window.c index ed1e731922..063b0ff8e8 100644 --- a/shell/e-shell-window.c +++ b/shell/e-shell-window.c @@ -41,6 +41,47 @@ enum { static gpointer parent_class; +static EShellView * +shell_window_new_view (EShellWindow *shell_window, + GType shell_view_type, + const gchar *title) +{ + GHashTable *loaded_views; + EShellView *shell_view; + GtkNotebook *notebook; + GtkWidget *widget; + const gchar *name; + gint page_num; + + /* Determine the page number for the new shell view. */ + notebook = GTK_NOTEBOOK (shell_window->priv->content_notebook); + page_num = gtk_notebook_get_n_pages (notebook); + + shell_view = g_object_new ( + shell_view_type, "page-num", page_num, + "title", title, "window", shell_window, NULL); + + name = e_shell_view_get_name (shell_view); + loaded_views = shell_window->priv->loaded_views; + g_hash_table_insert (loaded_views, g_strdup (name), shell_view); + + /* Add pages to the various shell window notebooks. */ + + notebook = GTK_NOTEBOOK (shell_window->priv->content_notebook); + widget = e_shell_view_get_content_widget (shell_view); + gtk_notebook_append_page (notebook, widget, NULL); + + notebook = GTK_NOTEBOOK (shell_window->priv->sidebar_notebook); + widget = e_shell_view_get_sidebar_widget (shell_view); + gtk_notebook_append_page (notebook, widget, NULL); + + notebook = GTK_NOTEBOOK (shell_window->priv->status_notebook); + widget = e_shell_view_get_status_widget (shell_view); + gtk_notebook_append_page (notebook, widget, NULL); + + return shell_view; +} + static void shell_window_online_mode_notify_cb (EShell *shell, GParamSpec *pspec, @@ -286,14 +327,11 @@ e_shell_window_get_view (EShellWindow *shell_window, continue; } - if (strcmp (view_name, class->type_module->name) == 0) { - shell_view = g_object_new ( - shell_view_type, "title", class->label, - "window", shell_window, NULL); - g_hash_table_insert ( - loaded_views, - g_strdup (view_name), shell_view); - } + g_debug ("Comparing %s to %s (%s)", view_name, class->type_module->name, g_type_name (shell_view_type)); + + if (strcmp (view_name, class->type_module->name) == 0) + shell_view = shell_window_new_view ( + shell_window, shell_view_type, class->label); g_type_class_unref (class); } @@ -404,17 +442,37 @@ void e_shell_window_set_current_view (EShellWindow *shell_window, const gchar *name_or_alias) { + GtkNotebook *notebook; + EShellView *shell_view; const gchar *current_view; + gint page_num; g_return_if_fail (E_IS_SHELL_WINDOW (shell_window)); - if (name_or_alias != NULL) + current_view = name_or_alias; + + if (current_view != NULL) current_view = - e_shell_registry_get_canonical_name (name_or_alias); + e_shell_registry_get_canonical_name (current_view); if (current_view == NULL) current_view = shell_window->priv->default_view; + g_return_if_fail (current_view != NULL); + + shell_view = e_shell_window_get_view (shell_window, current_view); + page_num = e_shell_view_get_page_num (shell_view); + g_return_if_fail (page_num >= 0); + + notebook = GTK_NOTEBOOK (shell_window->priv->content_notebook); + gtk_notebook_set_current_page (notebook, page_num); + + notebook = GTK_NOTEBOOK (shell_window->priv->sidebar_notebook); + gtk_notebook_set_current_page (notebook, page_num); + + notebook = GTK_NOTEBOOK (shell_window->priv->status_notebook); + gtk_notebook_set_current_page (notebook, page_num); + shell_window->priv->current_view = current_view; g_object_notify (G_OBJECT (shell_window), "current-view"); |