aboutsummaryrefslogtreecommitdiffstats
path: root/mail
diff options
context:
space:
mode:
Diffstat (limited to 'mail')
-rw-r--r--mail/e-mail-folder-pane.c117
-rw-r--r--mail/e-mail-folder-pane.h5
-rw-r--r--mail/e-mail-message-pane.c98
-rw-r--r--mail/e-mail-message-pane.h7
-rw-r--r--mail/e-mail-notebook-view.c607
-rw-r--r--mail/e-mail-notebook-view.h105
-rw-r--r--mail/e-mail-pane.c5
-rw-r--r--mail/e-mail-pane.h46
-rw-r--r--mail/e-mail-paned-view.c647
-rw-r--r--mail/e-mail-paned-view.h92
-rw-r--r--mail/e-mail-reader.c35
-rw-r--r--mail/e-mail-reader.h4
-rw-r--r--mail/e-mail-tab-picker.c24
-rw-r--r--mail/e-mail-tab-picker.h1
-rw-r--r--mail/e-mail-tab.c4
-rw-r--r--mail/e-mail-tab.h2
-rw-r--r--mail/e-mail-view.c244
-rw-r--r--mail/e-mail-view.h120
-rw-r--r--mail/em-format-html.c6
-rw-r--r--mail/message-list.c28
20 files changed, 1122 insertions, 1075 deletions
diff --git a/mail/e-mail-folder-pane.c b/mail/e-mail-folder-pane.c
index e8857ae785..3d9dfc2ea9 100644
--- a/mail/e-mail-folder-pane.c
+++ b/mail/e-mail-folder-pane.c
@@ -46,46 +46,24 @@
((obj), E_TYPE_MAIL_FOLDER_PANE, EMailFolderPanePrivate))
struct _EMailFolderPanePrivate {
- int fo;
+ gint placeholder;
};
enum {
PROP_0,
- PROP_PREVIEW_VISIBLE,
+ PROP_PREVIEW_VISIBLE
};
-static gpointer parent_class;
-
+G_DEFINE_TYPE (EMailFolderPane, e_mail_folder_pane, E_TYPE_MAIL_PANED_VIEW)
static void
-mail_folder_pane_dispose (GObject *object)
+folder_pane_set_preview_visible (EMailView *view,
+ gboolean preview_visible)
{
- EMailFolderPanePrivate *priv;
-
- priv = E_MAIL_FOLDER_PANE_GET_PRIVATE (object);
-
- /* Chain up to parent's dispose() method. */
- G_OBJECT_CLASS (parent_class)->dispose (object);
-}
-
-static void
-mail_folder_pane_constructed (GObject *object)
-{
- /* Chain up to parent's constructed() method. */
- if (G_OBJECT_CLASS (parent_class)->constructed)
- G_OBJECT_CLASS (parent_class)->constructed (object);
-
-}
-
-static void
-folder_pane_set_preview_visible (EMailPanedView *view,
- gboolean preview_visible)
-{
- return;
}
static gboolean
-folder_pane_get_preview_visible (EMailPanedView *view)
+folder_pane_get_preview_visible (EMailView *view)
{
return FALSE;
@@ -93,9 +71,9 @@ folder_pane_get_preview_visible (EMailPanedView *view)
static void
mail_folder_pane_get_property (GObject *object,
- guint property_id,
- GValue *value,
- GParamSpec *pspec)
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec)
{
switch (property_id) {
case PROP_PREVIEW_VISIBLE:
@@ -104,7 +82,6 @@ mail_folder_pane_get_property (GObject *object,
FALSE);
return;
-
}
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
@@ -112,9 +89,9 @@ mail_folder_pane_get_property (GObject *object,
static void
mail_folder_pane_set_property (GObject *object,
- guint property_id,
- const GValue *value,
- GParamSpec *pspec)
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec)
{
switch (property_id) {
case PROP_PREVIEW_VISIBLE:
@@ -124,22 +101,22 @@ mail_folder_pane_set_property (GObject *object,
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
}
-static void
+static guint
mfp_open_selected_mail (EMailPanedView *view)
{
GPtrArray *uids;
- int i;
+ gint i;
GtkWindow *window;
CamelFolder *folder;
const gchar *folder_uri;
- GPtrArray *views;
- guint ii;
+ GPtrArray *views;
+ guint n_views, ii;
- uids = e_mail_reader_get_selected_uids (E_MAIL_READER(view));
+ uids = e_mail_reader_get_selected_uids (E_MAIL_READER(view));
window = e_mail_reader_get_window (E_MAIL_READER(view));
if (!em_utils_ask_open_many (window, uids->len)) {
em_utils_uids_free (uids);
- return;
+ return 0;
}
folder = e_mail_reader_get_folder (E_MAIL_READER(view));
@@ -148,7 +125,7 @@ mfp_open_selected_mail (EMailPanedView *view)
em_utils_folder_is_outbox (folder, folder_uri) ||
em_utils_folder_is_templates (folder, folder_uri)) {
em_utils_edit_messages (folder, uids, TRUE);
- return;
+ return 0;
}
views = g_ptr_array_new ();
@@ -190,78 +167,48 @@ mfp_open_selected_mail (EMailPanedView *view)
camel_folder_free_message_info (folder, info);
}
-
- for (i=0; i<views->len; i++) {
+ n_views = views->len;
+ for (i = 0; i < n_views; i++)
g_signal_emit_by_name (view, "open-mail", views->pdata[i]);
- }
g_ptr_array_foreach (views, (GFunc) g_free, NULL);
g_ptr_array_free (views, TRUE);
em_utils_uids_free (uids);
+ return n_views;
}
static void
-mail_folder_pane_class_init (EMailPanedViewClass *class)
+e_mail_folder_pane_class_init (EMailFolderPaneClass *class)
{
GObjectClass *object_class;
+ EMailViewClass *mail_view_class;
+ EMailPanedViewClass *mail_paned_view_class;
- parent_class = g_type_class_peek_parent (class);
g_type_class_add_private (class, sizeof (EMailFolderPanePrivate));
object_class = G_OBJECT_CLASS (class);
- object_class->dispose = mail_folder_pane_dispose;
- object_class->constructed = mail_folder_pane_constructed;
object_class->set_property = mail_folder_pane_set_property;
object_class->get_property = mail_folder_pane_get_property;
- class->open_selected_mail = mfp_open_selected_mail;
+ mail_view_class = E_MAIL_VIEW_CLASS (class);
+ mail_view_class->set_preview_visible = folder_pane_set_preview_visible;
+ mail_view_class->get_preview_visible = folder_pane_get_preview_visible;
- E_MAIL_VIEW_CLASS(g_type_class_peek_parent(class))->set_preview_visible = folder_pane_set_preview_visible;
- E_MAIL_VIEW_CLASS(g_type_class_peek_parent(class))->get_preview_visible = folder_pane_get_preview_visible;
+ mail_paned_view_class = E_MAIL_PANED_VIEW_CLASS (class);
+ mail_paned_view_class->open_selected_mail = mfp_open_selected_mail;
g_object_class_override_property (
object_class,
PROP_PREVIEW_VISIBLE,
"preview-visible");
-
}
-
static void
-mail_folder_pane_init (EMailFolderPane *browser)
+e_mail_folder_pane_init (EMailFolderPane *browser)
{
-
browser->priv = E_MAIL_FOLDER_PANE_GET_PRIVATE (browser);
-
-}
-
-GType
-e_mail_folder_pane_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0)) {
- static const GTypeInfo type_info = {
- sizeof (EMailFolderPaneClass),
- (GBaseInitFunc) NULL,
- (GBaseFinalizeFunc) NULL,
- (GClassInitFunc) mail_folder_pane_class_init,
- (GClassFinalizeFunc) NULL,
- NULL, /* class_data */
- sizeof (EMailFolderPane),
- 0, /* n_preallocs */
- (GInstanceInitFunc) mail_folder_pane_init,
- NULL /* value_table */
- };
-
- type = g_type_register_static (
- E_MAIL_PANED_VIEW_TYPE, "EMailFolderPane", &type_info, 0);
-
- }
-
- return type;
}
GtkWidget *
@@ -271,7 +218,7 @@ e_mail_folder_pane_new (EShellContent *content)
return g_object_new (
E_TYPE_MAIL_FOLDER_PANE,
- "shell-content", content,
+ "shell-content", content,
"preview-visible", FALSE,
NULL);
}
diff --git a/mail/e-mail-folder-pane.h b/mail/e-mail-folder-pane.h
index 6071ce6417..a7a84a5edb 100644
--- a/mail/e-mail-folder-pane.h
+++ b/mail/e-mail-folder-pane.h
@@ -22,9 +22,8 @@
#ifndef E_MAIL_FOLDER_PANE_H
#define E_MAIL_FOLDER_PANE_H
-#include <gtk/gtk.h>
#include <shell/e-shell-content.h>
-#include "mail/e-mail-paned-view.h"
+#include <mail/e-mail-paned-view.h>
/* Standard GObject macros */
#define E_TYPE_MAIL_FOLDER_PANE \
@@ -60,7 +59,7 @@ struct _EMailFolderPaneClass {
EMailPanedViewClass parent_class;
};
-GType e_mail_folder_pane_get_type (void);
+GType e_mail_folder_pane_get_type (void);
GtkWidget * e_mail_folder_pane_new (EShellContent *content);
G_END_DECLS
diff --git a/mail/e-mail-message-pane.c b/mail/e-mail-message-pane.c
index 0f3488dccb..8ca6802639 100644
--- a/mail/e-mail-message-pane.c
+++ b/mail/e-mail-message-pane.c
@@ -28,13 +28,12 @@
#include "mail/e-mail-reader.h"
-#define e_mail_message_pane_GET_PRIVATE(obj) \
+#define E_MAIL_MESSAGE_PANE_GET_PRIVATE(obj) \
(G_TYPE_INSTANCE_GET_PRIVATE \
((obj), E_TYPE_MAIL_MESSAGE_PANE, EMailMessagePanePrivate))
-
struct _EMailMessagePanePrivate {
- int fo;
+ gint placeholder;
};
enum {
@@ -42,20 +41,19 @@ enum {
PROP_PREVIEW_VISIBLE
};
-static gpointer parent_class;
+G_DEFINE_TYPE (EMailMessagePane, e_mail_message_pane, E_TYPE_MAIL_PANED_VIEW)
/* This is too trivial to put in a file.
* It gets merged with the EMailReader UI. */
static void
mail_message_pane_set_property (GObject *object,
- guint property_id,
- const GValue *value,
- GParamSpec *pspec)
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec)
{
switch (property_id) {
case PROP_PREVIEW_VISIBLE:
return;
-
}
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
@@ -63,80 +61,66 @@ mail_message_pane_set_property (GObject *object,
static void
mail_message_pane_get_property (GObject *object,
- guint property_id,
- GValue *value,
- GParamSpec *pspec)
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec)
{
switch (property_id) {
case PROP_PREVIEW_VISIBLE:
g_value_set_boolean (
value,
TRUE);
- return;
+ return;
}
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
}
static void
-mail_message_pane_dispose (GObject *object)
+mail_message_pane_constructed (GObject *object)
{
EMailMessagePanePrivate *priv;
- priv = e_mail_message_pane_GET_PRIVATE (object);
-
-
- /* Chain up to parent's dispose() method. */
- G_OBJECT_CLASS (parent_class)->dispose (object);
-}
+ priv = E_MAIL_MESSAGE_PANE_GET_PRIVATE (object);
-static void
-mail_message_pane_constructed (GObject *object)
-{
- EMailMessagePanePrivate *priv;
-
/* Chain up to parent's constructed() method. */
- if (G_OBJECT_CLASS (parent_class)->constructed)
- G_OBJECT_CLASS (parent_class)->constructed (object);
-
- priv = e_mail_message_pane_GET_PRIVATE (object);
+ G_OBJECT_CLASS (e_mail_message_pane_parent_class)->constructed (object);
gtk_widget_hide (e_mail_reader_get_message_list (E_MAIL_READER(object)));
e_mail_paned_view_hide_message_list_pane (E_MAIL_PANED_VIEW(object), FALSE);
}
static void
-message_pane_set_preview_visible (EMailMessagePane *view,
- gboolean preview_visible)
+message_pane_set_preview_visible (EMailView *view,
+ gboolean preview_visible)
{
- e_mail_paned_view_set_preview_visible (E_MAIL_PANED_VIEW(view), TRUE);
-
- return;
+ /* Chain up to parent's set_preview_visible() method. */
+ E_MAIL_VIEW_CLASS (e_mail_message_pane_parent_class)->
+ set_preview_visible (view, TRUE);
}
static gboolean
-message_pane_get_preview_visible (EMailMessagePane *view)
+message_pane_get_preview_visible (EMailView *view)
{
-
return TRUE;
}
static void
-mail_message_pane_class_init (EMailMessagePaneClass *class)
+e_mail_message_pane_class_init (EMailMessagePaneClass *class)
{
GObjectClass *object_class;
+ EMailViewClass *mail_view_class;
- parent_class = g_type_class_peek_parent (class);
g_type_class_add_private (class, sizeof (EMailMessagePanePrivate));
object_class = G_OBJECT_CLASS (class);
object_class->set_property = mail_message_pane_set_property;
object_class->get_property = mail_message_pane_get_property;
- object_class->dispose = mail_message_pane_dispose;
object_class->constructed = mail_message_pane_constructed;
- E_MAIL_VIEW_CLASS(g_type_class_peek_parent(class))->set_preview_visible = message_pane_set_preview_visible;
- E_MAIL_VIEW_CLASS(g_type_class_peek_parent(class))->get_preview_visible = message_pane_get_preview_visible;
+ mail_view_class = E_MAIL_VIEW_CLASS (class);
+ mail_view_class->set_preview_visible = message_pane_set_preview_visible;
+ mail_view_class->get_preview_visible = message_pane_get_preview_visible;
g_object_class_override_property (
object_class,
@@ -145,37 +129,9 @@ mail_message_pane_class_init (EMailMessagePaneClass *class)
}
static void
-mail_message_pane_init (EMailMessagePane *browser)
-{
-
- browser->priv = e_mail_message_pane_GET_PRIVATE (browser);
-}
-
-GType
-e_mail_message_pane_get_type (void)
+e_mail_message_pane_init (EMailMessagePane *browser)
{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0)) {
- static const GTypeInfo type_info = {
- sizeof (EMailMessagePaneClass),
- (GBaseInitFunc) NULL,
- (GBaseFinalizeFunc) NULL,
- (GClassInitFunc) mail_message_pane_class_init,
- (GClassFinalizeFunc) NULL,
- NULL, /* class_data */
- sizeof (EMailMessagePane),
- 0, /* n_preallocs */
- (GInstanceInitFunc) mail_message_pane_init,
- NULL /* value_table */
- };
-
- type = g_type_register_static (
- E_MAIL_PANED_VIEW_TYPE , "EMailMessagePane", &type_info, 0);
-
- }
-
- return type;
+ browser->priv = E_MAIL_MESSAGE_PANE_GET_PRIVATE (browser);
}
GtkWidget *
@@ -185,7 +141,7 @@ e_mail_message_pane_new (EShellContent *content)
return g_object_new (
E_TYPE_MAIL_MESSAGE_PANE,
- "shell-content", content,
+ "shell-content", content,
"preview-visible", TRUE,
NULL);
}
diff --git a/mail/e-mail-message-pane.h b/mail/e-mail-message-pane.h
index ce5ea85ab5..f947f79cdf 100644
--- a/mail/e-mail-message-pane.h
+++ b/mail/e-mail-message-pane.h
@@ -1,5 +1,5 @@
/*
- * e-mail-pane.h
+ * e-mail-message-pane.h
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
@@ -22,8 +22,7 @@
#ifndef E_MAIL_MESSAGE_PANE_H
#define E_MAIL_MESSAGE_PANE_H
-#include <gtk/gtk.h>
-#include "e-mail-paned-view.h"
+#include <mail/e-mail-paned-view.h>
/* Standard GObject macros */
#define E_TYPE_MAIL_MESSAGE_PANE \
@@ -59,7 +58,7 @@ struct _EMailMessagePaneClass {
EMailPanedViewClass parent_class;
};
-GType e_mail_message_pane_get_type (void);
+GType e_mail_message_pane_get_type (void);
GtkWidget * e_mail_message_pane_new (EShellContent *content);
G_END_DECLS
diff --git a/mail/e-mail-notebook-view.c b/mail/e-mail-notebook-view.c
index 5403032b79..436804de06 100644
--- a/mail/e-mail-notebook-view.c
+++ b/mail/e-mail-notebook-view.c
@@ -10,7 +10,7 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
- * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
*
*
* Authors:
@@ -24,7 +24,6 @@
# include <config.h>
#endif
-
#include <glib.h>
#include <glib/gi18n.h>
@@ -45,18 +44,22 @@
#include "e-mail-tab-picker.h"
#endif
+#define E_MAIL_NOTEBOOK_VIEW_GET_PRIVATE(obj) \
+ (G_TYPE_INSTANCE_GET_PRIVATE \
+ ((obj), E_TYPE_MAIL_NOTEBOOK_VIEW, EMailNotebookViewPrivate))
+
struct _EMailNotebookViewPrivate {
GtkNotebook *book;
EMailView *current_view;
GHashTable *views;
gboolean inited;
-#if HAVE_CLUTTER
+#if HAVE_CLUTTER
EMailTabPicker *tab_picker;
GtkWidget *embed;
ClutterActor *actor;
ClutterActor *stage;
-#endif
+#endif
};
enum {
@@ -73,43 +76,26 @@ static GType mail_notebook_view_type;
#if HAVE_CLUTTER
static void
mnv_set_current_tab (EMailNotebookView *view,
- int page)
+ gint page)
{
ClutterAnimation *animation;
clutter_actor_set_opacity (view->priv->actor, 0);
gtk_notebook_set_current_page (view->priv->book, page);
- animation = clutter_actor_animate ((ClutterActor *)view->priv->actor, CLUTTER_EASE_IN_SINE, 500,
- "opacity", 255,
- NULL);
+ animation = clutter_actor_animate (
+ (ClutterActor *)view->priv->actor,
+ CLUTTER_EASE_IN_SINE, 500, "opacity", 255, NULL);
}
#endif
-static void
-mail_notebook_view_init (EMailNotebookView *shell)
-{
- shell->priv = g_new0(EMailNotebookViewPrivate, 1);
-
- shell->priv->inited = FALSE;
- shell->priv->views = g_hash_table_new (g_str_hash, g_str_equal);
-}
-
-static void
-e_mail_notebook_view_finalize (GObject *object)
-{
- /* EMailNotebookView *shell = (EMailNotebookView *)object; */
-
- G_OBJECT_CLASS (parent_class)->finalize (object);
-}
-
-static int
+static gint
emnv_get_page_num (EMailNotebookView *view,
GtkWidget *widget)
{
EMailNotebookViewPrivate *priv = view->priv;
- int i, n;
-
+ gint i, n;
+
n = gtk_notebook_get_n_pages (priv->book);
for (i=0; i<n; i++) {
@@ -130,7 +116,7 @@ mnv_page_changed (GtkNotebook *book, GtkWidget *page,
EShellView *shell_view = e_shell_content_get_shell_view (content);
EShellSidebar *sidebar = e_shell_view_get_shell_sidebar (shell_view);
EMFolderTree *tree;
- const char *uri = e_mail_reader_get_folder_uri (E_MAIL_READER(mview));
+ const gchar *uri = e_mail_reader_get_folder_uri (E_MAIL_READER(mview));
g_object_get (sidebar, "folder-tree", &tree, NULL);
if (uri && E_IS_MAIL_FOLDER_PANE (mview))
@@ -144,7 +130,7 @@ mnv_page_changed (GtkNotebook *book, GtkWidget *page,
/* For EMailReader related changes to EShellView*/
g_signal_emit_by_name (view, "changed");
g_signal_emit_by_name (view, "folder-loaded");
-
+
/* For EMailShellContent related changes */
g_signal_emit_by_name (view, "view-changed");
@@ -155,7 +141,7 @@ static void
fix_tab_picker_width (GtkWidget *widget, GtkAllocation *allocation, ClutterActor *actor)
{
ClutterActor *stage = g_object_get_data ((GObject *)actor, "stage");
-
+
clutter_actor_set_size (actor, allocation->width-1, -1);
clutter_actor_set_size (stage, allocation->width-1, -1);
}
@@ -167,9 +153,9 @@ fix_height_cb (ClutterActor *actor,
{
GtkWidget *embed = (GtkWidget *)g_object_get_data ((GObject *)actor, "embed");
ClutterActor *stage = g_object_get_data ((GObject *)actor, "stage");
-
+
clutter_actor_set_height (stage, clutter_actor_get_height(actor));
- gtk_widget_set_size_request (embed, -1, (int) clutter_actor_get_height(actor));
+ gtk_widget_set_size_request (embed, -1, (gint) clutter_actor_get_height(actor));
}
static void
@@ -207,9 +193,9 @@ tab_picker_preview_mode_notify (EMailTabPicker *picker,
/* Show all pages so that the preview clones work correctly */
clutter_actor_set_opacity (preview, 255);
clutter_actor_show (preview);
- } else {
- clutter_actor_hide (preview);
- }
+ } else {
+ clutter_actor_hide (preview);
+ }
}
g_list_free (tabs);
}
@@ -219,7 +205,7 @@ mnv_tab_anim_frame_cb (ClutterTimeline *timeline,
gint frame_num,
EMailTab *tab)
{
- if (!clutter_actor_get_parent (CLUTTER_ACTOR (tab))) {
+ if (!clutter_actor_get_parent (CLUTTER_ACTOR (tab))) {
clutter_timeline_stop (timeline);
g_object_unref (timeline);
g_object_unref (tab);
@@ -250,10 +236,10 @@ mnv_tab_closed_cb (ClutterTimeline *timeline,
struct _tab_data *data)
{
EMailView *page = g_object_get_data ((GObject *)data->tab, "page");
- const char *folder_uri = e_mail_reader_get_folder_uri (E_MAIL_READER(page));
+ const gchar *folder_uri = e_mail_reader_get_folder_uri (E_MAIL_READER(page));
EMailView *prev;
- int num;
-
+ gint num;
+
if (E_IS_MAIL_FOLDER_PANE (page))
g_hash_table_remove (data->view->priv->views, folder_uri);
prev = page->prev;
@@ -263,8 +249,8 @@ mnv_tab_closed_cb (ClutterTimeline *timeline,
e_mail_tab_picker_set_current_tab (data->view->priv->tab_picker, num);
}
- e_mail_tab_picker_remove_tab (data->view->priv->tab_picker, data->tab);
- gtk_notebook_remove_page (data->view->priv->book,
+ e_mail_tab_picker_remove_tab (data->view->priv->tab_picker, data->tab);
+ gtk_notebook_remove_page (data->view->priv->book,
gtk_notebook_page_num (data->view->priv->book, (GtkWidget *)page));
}
@@ -273,7 +259,7 @@ static void
mnv_tab_closed (EMailTab *tab, EMailNotebookView *view)
{
EMailNotebookViewPrivate *priv = view->priv;
- int page, cur;
+ gint page, cur;
gboolean select = FALSE;
ClutterTimeline *timeline;
struct _tab_data *data = g_new0 (struct _tab_data, 1);
@@ -293,14 +279,15 @@ mnv_tab_closed (EMailTab *tab, EMailNotebookView *view)
data->view = view;
clutter_actor_set_reactive (CLUTTER_ACTOR (tab), FALSE);
- timeline = clutter_timeline_new (150);
+ timeline = clutter_timeline_new (150);
clutter_timeline_set_direction (timeline, CLUTTER_TIMELINE_BACKWARD);
- g_signal_connect (timeline, "new-frame",
- G_CALLBACK (mnv_tab_anim_frame_cb), tab);
- g_signal_connect (timeline, "completed",
- G_CALLBACK (mnv_tab_closed_cb), data);
- clutter_timeline_start (timeline);
-
+ g_signal_connect (
+ timeline, "new-frame",
+ G_CALLBACK (mnv_tab_anim_frame_cb), tab);
+ g_signal_connect (
+ timeline, "completed",
+ G_CALLBACK (mnv_tab_closed_cb), data);
+ clutter_timeline_start (timeline);
}
static void
@@ -309,7 +296,7 @@ tab_activated_cb (EMailTabPicker *picker,
EMailNotebookView *view)
{
EMailView *page = g_object_get_data ((GObject *)tab, "page");
- int num = emnv_get_page_num (view, (GtkWidget *)page);
+ gint num = emnv_get_page_num (view, (GtkWidget *)page);
mnv_set_current_tab (view, num);
}
@@ -320,10 +307,10 @@ tab_remove_gtk_cb (GtkWidget *button,
EMailNotebookView *view)
{
EMailView *page = g_object_get_data ((GObject *)button, "page");
- const char *folder_uri = e_mail_reader_get_folder_uri (E_MAIL_READER(page));
+ const gchar *folder_uri = e_mail_reader_get_folder_uri (E_MAIL_READER(page));
EMailView *prev;
- int num;
-
+ gint num;
+
if (gtk_notebook_get_n_pages(view->priv->book) == 1)
return;
@@ -335,15 +322,15 @@ tab_remove_gtk_cb (GtkWidget *button,
num = emnv_get_page_num (view, (GtkWidget *)prev);
gtk_notebook_set_current_page (view->priv->book, num);
}
- gtk_notebook_remove_page (view->priv->book,
+ gtk_notebook_remove_page (view->priv->book,
gtk_notebook_page_num (view->priv->book, (GtkWidget *)page));
-
+
}
static GtkWidget *
-create_tab_label (EMailNotebookView *view,
+create_tab_label (EMailNotebookView *view,
EMailView *page,
- const char *str)
+ const gchar *str)
{
GtkWidget *container, *widget;
@@ -378,7 +365,7 @@ create_gtk_actor (GtkWidget *vbox)
bin = gtk_clutter_actor_get_widget (GTK_CLUTTER_ACTOR (gtk_actor));
gtk_container_add (GTK_CONTAINER (bin), vbox);
-
+
gtk_widget_show (bin);
gtk_widget_show(vbox);
return gtk_actor;
@@ -407,7 +394,7 @@ create_under_clutter (GtkWidget *widget, GtkWidget *paned)
clutter_actor_show (actor);
stage = gtk_clutter_embed_get_stage ((GtkClutterEmbed *)embed);
clutter_container_add_actor ((ClutterContainer *)stage, actor);
-
+
g_object_set_data ((GObject *)actor, "embed", embed);
g_object_set_data ((GObject *)actor, "stage", stage);
g_object_set_data ((GObject *)actor, "widget", widget);
@@ -416,7 +403,7 @@ create_under_clutter (GtkWidget *widget, GtkWidget *paned)
g_signal_connect (paned, "size-allocate", G_CALLBACK(fix_clutter_embed_width), actor);
clutter_actor_show(stage);
-
+
return embed;
}
@@ -437,7 +424,7 @@ mail_notebook_view_constructed (GObject *object)
container = GTK_WIDGET(object);
-#if HAVE_CLUTTER
+#if HAVE_CLUTTER
widget = gtk_clutter_embed_new ();
gtk_widget_show (widget);
gtk_box_pack_start (GTK_BOX(container), widget, FALSE, FALSE, 0);
@@ -448,29 +435,34 @@ mail_notebook_view_constructed (GObject *object)
priv->tab_picker = (EMailTabPicker *)e_mail_tab_picker_new ();
clutter_actor_show ((ClutterActor *)priv->tab_picker);
- g_signal_connect (priv->tab_picker, "tab-activated",
- G_CALLBACK (tab_activated_cb), object);
- g_signal_connect (priv->tab_picker, "chooser-clicked",
- G_CALLBACK (chooser_clicked_cb), object);
- g_signal_connect (priv->tab_picker, "notify::preview-mode",
- G_CALLBACK (tab_picker_preview_mode_notify), object);
- g_signal_connect (priv->tab_picker, "notify::height",
- G_CALLBACK(fix_height_cb), widget);
+ g_signal_connect (
+ priv->tab_picker, "tab-activated",
+ G_CALLBACK (tab_activated_cb), object);
+ g_signal_connect (
+ priv->tab_picker, "chooser-clicked",
+ G_CALLBACK (chooser_clicked_cb), object);
+ g_signal_connect (
+ priv->tab_picker, "notify::preview-mode",
+ G_CALLBACK (tab_picker_preview_mode_notify), object);
+ g_signal_connect (
+ priv->tab_picker, "notify::height",
+ G_CALLBACK(fix_height_cb), widget);
clutter_container_add_actor ((ClutterContainer *)stage, (ClutterActor *)priv->tab_picker);
g_object_set_data ((GObject *)priv->tab_picker, "embed", widget);
g_object_set_data ((GObject *)priv->tab_picker, "stage", stage);
- g_signal_connect (object, "size-allocate",
- G_CALLBACK(fix_tab_picker_width), priv->tab_picker);
+ g_signal_connect (
+ object, "size-allocate",
+ G_CALLBACK(fix_tab_picker_width), priv->tab_picker);
clutter_actor_set_height (stage, clutter_actor_get_height((ClutterActor *)priv->tab_picker));
- gtk_widget_set_size_request (widget, -1, (int) clutter_actor_get_height((ClutterActor *)priv->tab_picker));
+ gtk_widget_set_size_request (widget, -1, (gint) clutter_actor_get_height((ClutterActor *)priv->tab_picker));
tab = (EMailTab *) e_mail_tab_new_full ("", NULL, 1);
clone = e_mail_tab_new_full ("", NULL, 200);
-
+
e_mail_tab_set_can_close ((EMailTab *)clone, FALSE);
clutter_actor_set_reactive (clone, FALSE);
clutter_actor_show (clone);
@@ -484,14 +476,14 @@ mail_notebook_view_constructed (GObject *object)
e_mail_tab_picker_set_current_tab (priv->tab_picker, 0);
g_object_ref (tab);
- timeline = clutter_timeline_new (150);
- g_signal_connect (timeline, "new-frame",
- G_CALLBACK (mnv_tab_anim_frame_cb), tab);
- g_signal_connect (timeline, "completed",
- G_CALLBACK (mnv_tab_anim_complete_cb), tab);
+ timeline = clutter_timeline_new (150);
+ g_signal_connect (
+ timeline, "new-frame",
+ G_CALLBACK (mnv_tab_anim_frame_cb), tab);
+ g_signal_connect (
+ timeline, "completed",
+ G_CALLBACK (mnv_tab_anim_complete_cb), tab);
clutter_timeline_start (timeline);
-#else
-
#endif
widget = gtk_notebook_new ();
@@ -502,29 +494,29 @@ mail_notebook_view_constructed (GObject *object)
gtk_box_pack_start (GTK_BOX (container), priv->embed, TRUE, TRUE, 0);
priv->actor = g_object_get_data((GObject *)priv->embed, "actor");
priv->stage = g_object_get_data((GObject *)priv->actor, "stage");
-#else
+#else
gtk_box_pack_start (GTK_BOX(container), widget, TRUE, TRUE, 0);
#endif
#if HAVE_CLUTTER
gtk_notebook_set_show_tabs ((GtkNotebook *)widget, FALSE);
-#else
+#else
gtk_notebook_set_scrollable ((GtkNotebook *)widget, TRUE);
#endif
gtk_notebook_set_show_border ((GtkNotebook *)widget, FALSE);
- g_signal_connect (widget, "switch-page",
+ g_signal_connect (widget, "switch-page",
G_CALLBACK(mnv_page_changed), object);
priv->current_view = (EMailView *)e_mail_folder_pane_new (E_MAIL_VIEW(object)->content);
- e_mail_paned_view_set_preview_visible ((EMailPanedView *)priv->current_view, FALSE);
+ e_mail_view_set_preview_visible (priv->current_view, FALSE);
gtk_widget_show ((GtkWidget *)priv->current_view);
- gtk_notebook_append_page (priv->book, (GtkWidget *)priv->current_view,
+ gtk_notebook_append_page (priv->book, (GtkWidget *)priv->current_view,
create_tab_label (E_MAIL_NOTEBOOK_VIEW(object),
priv->current_view,
_("Please select a folder")));
-
+
}
static void
@@ -563,28 +555,155 @@ mail_notebook_view_get_property (GObject *object,
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
}
+static EShellSearchbar *
+mail_notebook_view_get_searchbar (EMailView *view)
+{
+ EShellView *shell_view;
+ EShellContent *shell_content;
+ GtkWidget *widget;
+
+ g_return_val_if_fail (
+ E_IS_MAIL_NOTEBOOK_VIEW (view), NULL);
+
+ shell_content = E_MAIL_VIEW (view)->content;
+ shell_view = e_shell_content_get_shell_view (shell_content);
+ widget = e_shell_view_get_searchbar (shell_view);
+
+ return E_SHELL_SEARCHBAR (widget);
+/*
+ if (!E_MAIL_NOTEBOOK_VIEW(view)->priv->current_view)
+ return NULL;
+ return e_mail_view_get_searchbar (E_MAIL_NOTEBOOK_VIEW(view)->priv->current_view); */
+}
+
static void
-mail_notebook_view_class_init (EMailViewClass *klass)
+mail_notebook_view_set_search_strings (EMailView *view,
+ GSList *search_strings)
{
- GObjectClass * object_class = G_OBJECT_CLASS (klass);
+ e_mail_view_set_search_strings (E_MAIL_NOTEBOOK_VIEW (view)->priv->current_view, search_strings);
+}
- parent_class = g_type_class_peek_parent (klass);
+static GalViewInstance *
+mail_notebook_view_get_view_instance (EMailView *view)
+{
+ if (!E_MAIL_NOTEBOOK_VIEW(view)->priv->current_view)
+ return NULL;
+
+ return e_mail_view_get_view_instance (E_MAIL_NOTEBOOK_VIEW (view)->priv->current_view);
+}
+
+static void
+mail_notebook_view_update_view_instance (EMailView *view)
+{
+ e_mail_view_update_view_instance (E_MAIL_NOTEBOOK_VIEW (view)->priv->current_view);
+}
+
+static void
+mail_notebook_view_set_orientation (EMailView *view,
+ GtkOrientation orientation)
+{
+ EMailNotebookViewPrivate *priv;
+
+ priv = E_MAIL_NOTEBOOK_VIEW_GET_PRIVATE (view);
+
+ if (!priv->current_view)
+ return;
+
+ e_mail_view_set_orientation (priv->current_view, orientation);
+}
+
+static GtkOrientation
+mail_notebook_view_get_orientation (EMailView *view)
+{
+ EMailNotebookViewPrivate *priv;
+
+ priv = E_MAIL_NOTEBOOK_VIEW_GET_PRIVATE (view);
+
+ if (!priv->current_view)
+ return GTK_ORIENTATION_VERTICAL;
+
+ return e_mail_view_get_orientation (priv->current_view);
+}
+
+static void
+mail_notebook_view_set_show_deleted (EMailView *view,
+ gboolean show_deleted)
+{
+ EMailNotebookViewPrivate *priv;
+
+ priv = E_MAIL_NOTEBOOK_VIEW_GET_PRIVATE (view);
+
+ if (!priv->current_view)
+ return;
+
+ e_mail_view_set_show_deleted (priv->current_view, show_deleted);
+}
+
+static gboolean
+mail_notebook_view_get_show_deleted (EMailView *view)
+{
+ EMailNotebookViewPrivate *priv;
+
+ priv = E_MAIL_NOTEBOOK_VIEW_GET_PRIVATE (view);
+
+ if (!priv->current_view)
+ return FALSE;
+
+ return e_mail_view_get_show_deleted (priv->current_view);
+}
+
+static void
+mail_notebook_view_set_preview_visible (EMailView *view,
+ gboolean preview_visible)
+{
+ EMailNotebookViewPrivate *priv;
+
+ priv = E_MAIL_NOTEBOOK_VIEW_GET_PRIVATE (view);
+
+ if (!priv->current_view)
+ return;
+
+ e_mail_view_set_preview_visible (priv->current_view, preview_visible);
+}
+
+static gboolean
+mail_notebook_view_get_preview_visible (EMailView *view)
+{
+ EMailNotebookViewPrivate *priv;
+
+ priv = E_MAIL_NOTEBOOK_VIEW_GET_PRIVATE (view);
+
+ if (!priv->current_view)
+ return FALSE;
+
+ return e_mail_view_get_preview_visible (priv->current_view);
+}
+
+static void
+mail_notebook_view_class_init (EMailNotebookViewClass *class)
+{
+ GObjectClass *object_class;
+ EMailViewClass *mail_view_class;
+
+ parent_class = g_type_class_peek_parent (class);
+ g_type_class_add_private (class, sizeof (EMailNotebookViewPrivate));
+
+ object_class = G_OBJECT_CLASS (class);
object_class->constructed = mail_notebook_view_constructed;
object_class->set_property = mail_notebook_view_set_property;
object_class->get_property = mail_notebook_view_get_property;
-
- object_class->finalize = e_mail_notebook_view_finalize;
-
- klass->get_searchbar = e_mail_notebook_view_get_searchbar;
- klass->set_search_strings = e_mail_notebook_view_set_search_strings;
- klass->get_view_instance = e_mail_notebook_view_get_view_instance;
- klass->update_view_instance = e_mail_notebook_view_update_view_instance;
- klass->set_orientation = e_mail_notebook_view_set_orientation;
- klass->get_orientation = e_mail_notebook_view_get_orientation;
- klass->set_show_deleted = e_mail_notebook_view_set_show_deleted;
- klass->get_show_deleted = e_mail_notebook_view_get_show_deleted;
- klass->set_preview_visible = e_mail_notebook_view_set_preview_visible;
- klass->get_preview_visible = e_mail_notebook_view_get_preview_visible;
+
+ mail_view_class = E_MAIL_VIEW_CLASS (class);
+ mail_view_class->get_searchbar = mail_notebook_view_get_searchbar;
+ mail_view_class->set_search_strings = mail_notebook_view_set_search_strings;
+ mail_view_class->get_view_instance = mail_notebook_view_get_view_instance;
+ mail_view_class->update_view_instance = mail_notebook_view_update_view_instance;
+ mail_view_class->set_orientation = mail_notebook_view_set_orientation;
+ mail_view_class->get_orientation = mail_notebook_view_get_orientation;
+ mail_view_class->set_show_deleted = mail_notebook_view_set_show_deleted;
+ mail_view_class->get_show_deleted = mail_notebook_view_get_show_deleted;
+ mail_view_class->set_preview_visible = mail_notebook_view_set_preview_visible;
+ mail_view_class->get_preview_visible = mail_notebook_view_get_preview_visible;
/* Inherited from EMailReader */
g_object_class_override_property (
@@ -613,7 +732,16 @@ mail_notebook_view_class_init (EMailViewClass *klass)
G_PARAM_READWRITE));
g_object_class_override_property (
- object_class, PROP_ORIENTATION, "orientation"); */
+ object_class, PROP_ORIENTATION, "orientation"); */
+}
+
+static void
+mail_notebook_view_init (EMailNotebookView *view)
+{
+ view->priv = E_MAIL_NOTEBOOK_VIEW_GET_PRIVATE (view);
+
+ view->priv->inited = FALSE;
+ view->priv->views = g_hash_table_new (g_str_hash, g_str_equal);
}
GtkWidget *
@@ -622,14 +750,13 @@ e_mail_notebook_view_new (EShellContent *content)
g_return_val_if_fail (E_IS_SHELL_CONTENT (content), NULL);
return g_object_new (
- E_MAIL_NOTEBOOK_VIEW_TYPE,
+ E_TYPE_MAIL_NOTEBOOK_VIEW,
"shell-content", content, NULL);
}
static GtkActionGroup *
mail_notebook_view_get_action_group (EMailReader *reader)
{
- EMailNotebookViewPrivate *priv = E_MAIL_NOTEBOOK_VIEW (reader)->priv;
EShellContent *shell_content;
EShellWindow *shell_window;
EShellView *shell_view;
@@ -638,19 +765,14 @@ mail_notebook_view_get_action_group (EMailReader *reader)
shell_view = e_shell_content_get_shell_view (shell_content);
shell_window = e_shell_view_get_shell_window (shell_view);
- return E_SHELL_WINDOW_ACTION_GROUP_MAIL (shell_window);
-/*
- if (!priv->current_view)
- return NULL;
-
- return e_mail_reader_get_action_group (E_MAIL_READER(priv->current_view));*/
+ return E_SHELL_WINDOW_ACTION_GROUP_MAIL (shell_window);
}
static EMFormatHTML *
mail_notebook_view_get_formatter (EMailReader *reader)
{
EMailNotebookViewPrivate *priv = E_MAIL_NOTEBOOK_VIEW (reader)->priv;
-
+
if (!priv->current_view)
return NULL;
@@ -661,7 +783,7 @@ static gboolean
mail_notebook_view_get_hide_deleted (EMailReader *reader)
{
EMailNotebookViewPrivate *priv = E_MAIL_NOTEBOOK_VIEW (reader)->priv;
-
+
if (!priv->current_view)
return FALSE;
@@ -672,22 +794,22 @@ static GtkWidget *
mail_notebook_view_get_message_list (EMailReader *reader)
{
EMailNotebookViewPrivate *priv = E_MAIL_NOTEBOOK_VIEW (reader)->priv;
-
+
if (!priv->current_view)
return NULL;
- return e_mail_reader_get_message_list (E_MAIL_READER(priv->current_view));
+ return e_mail_reader_get_message_list (E_MAIL_READER(priv->current_view));
}
static GtkMenu *
mail_notebook_view_get_popup_menu (EMailReader *reader)
{
EMailNotebookViewPrivate *priv = E_MAIL_NOTEBOOK_VIEW (reader)->priv;
-
+
if (!priv->current_view)
return NULL;
- return e_mail_reader_get_popup_menu (E_MAIL_READER(priv->current_view));
+ return e_mail_reader_get_popup_menu (E_MAIL_READER(priv->current_view));
}
static EShellBackend *
@@ -729,16 +851,16 @@ reconnect_folder_loaded_event (EMailReader *child, EMailReader *parent)
}
static void
-mail_netbook_view_open_mail (EMailView *view, const char *uid, EMailNotebookView *nview)
+mail_netbook_view_open_mail (EMailView *view, const gchar *uid, EMailNotebookView *nview)
{
const gchar *folder_uri;
- CamelFolder *folder;
+ CamelFolder *folder;
GtkWidget *pane;
- int page;
+ gint page;
EMailNotebookViewPrivate *priv = E_MAIL_NOTEBOOK_VIEW (nview)->priv;
CamelMessageInfo *info;
GtkWidget *preview;
- int pos;
+ gint pos;
#if HAVE_CLUTTER
EMailTab *tab;
@@ -746,17 +868,17 @@ mail_netbook_view_open_mail (EMailView *view, const char *uid, EMailNotebookView
ClutterTimeline *timeline;
GtkWidget *mlist;
- e_mail_tab_set_active (e_mail_tab_picker_get_tab (priv->tab_picker,
+ e_mail_tab_set_active (e_mail_tab_picker_get_tab (priv->tab_picker,
e_mail_tab_picker_get_current_tab (priv->tab_picker)),
FALSE);
-#endif
+#endif
pos = emnv_get_page_num (nview, (GtkWidget *)priv->current_view);
pane = e_mail_message_pane_new (E_MAIL_VIEW(nview)->content);
E_MAIL_VIEW(pane)->prev = priv->current_view;
priv->current_view = (EMailView *)pane;
-
+
gtk_widget_show (pane);
-
+
preview = e_mail_paned_view_get_preview (E_MAIL_PANED_VIEW(pane));
folder = e_mail_reader_get_folder (E_MAIL_READER(view));
@@ -764,62 +886,64 @@ mail_netbook_view_open_mail (EMailView *view, const char *uid, EMailNotebookView
info = camel_folder_get_message_info (folder, uid);
- page = gtk_notebook_insert_page (priv->book, pane,
+ page = gtk_notebook_insert_page (priv->book, pane,
create_tab_label (nview,
priv->current_view,
- camel_message_info_subject(info)),
+ camel_message_info_subject(info)),
pos+1);
#if HAVE_CLUTTER
mlist = e_mail_reader_get_message_list (E_MAIL_READER(pane));
mnv_set_current_tab (nview, page);
- g_object_set_data ((GObject *)priv->current_view, "stage", priv->stage);
- g_object_set_data ((GObject *)mlist, "stage", priv->stage);
- g_object_set_data ((GObject *)mlist, "preview-actor", priv->actor);
-#else
+ g_object_set_data ((GObject *)priv->current_view, "stage", priv->stage);
+ g_object_set_data ((GObject *)mlist, "stage", priv->stage);
+ g_object_set_data ((GObject *)mlist, "preview-actor", priv->actor);
+#else
gtk_notebook_set_current_page (priv->book, page);
#endif
-#if HAVE_CLUTTER
+#if HAVE_CLUTTER
tab = (EMailTab *)e_mail_tab_new_full (camel_message_info_subject(info), NULL, 1);
g_object_set_data ((GObject *)tab, "page", pane);
clutter_actor_show((ClutterActor *)tab);
clone = e_mail_tab_new_full (camel_message_info_subject(info), NULL, 200);
- clutter_actor_set_reactive (clone, FALSE);
+ clutter_actor_set_reactive (clone, FALSE);
clutter_actor_show (clone);
e_mail_tab_set_preview_actor (tab, clone);
e_mail_tab_set_can_close (tab, TRUE);
e_mail_tab_enable_drag (tab, TRUE);
e_mail_tab_picker_add_tab (priv->tab_picker, tab, pos+1);
-
+
page = e_mail_tab_picker_get_tab_no (priv->tab_picker, tab);
e_mail_tab_picker_set_current_tab (priv->tab_picker, page);
- g_signal_connect (tab , "closed",
+ g_signal_connect (tab , "closed",
G_CALLBACK (mnv_tab_closed), nview);
g_object_ref (tab);
timeline = clutter_timeline_new (150);
- g_signal_connect (timeline, "new-frame",
- G_CALLBACK (mnv_tab_anim_frame_cb), tab);
- g_signal_connect (timeline, "completed",
- G_CALLBACK (mnv_tab_anim_complete_cb), tab);
+ g_signal_connect (
+ timeline, "new-frame",
+ G_CALLBACK (mnv_tab_anim_frame_cb), tab);
+ g_signal_connect (
+ timeline, "completed",
+ G_CALLBACK (mnv_tab_anim_complete_cb), tab);
clutter_timeline_start (timeline);
#endif
- g_signal_connect ( E_MAIL_READER(pane), "changed",
- G_CALLBACK (reconnect_changed_event),
- nview);
- g_signal_connect ( E_MAIL_READER (pane), "folder-loaded",
- G_CALLBACK (reconnect_folder_loaded_event),
- nview);
+ g_signal_connect (
+ E_MAIL_READER(pane), "changed",
+ G_CALLBACK (reconnect_changed_event), nview);
+ g_signal_connect (
+ E_MAIL_READER (pane), "folder-loaded",
+ G_CALLBACK (reconnect_folder_loaded_event), nview);
e_mail_reader_set_folder (
E_MAIL_READER (pane), folder, folder_uri);
e_mail_reader_set_group_by_threads (
E_MAIL_READER (pane),
- e_mail_reader_get_group_by_threads (E_MAIL_READER(view)));
+ e_mail_reader_get_group_by_threads (E_MAIL_READER(view)));
e_mail_reader_set_message (E_MAIL_READER (pane), uid);
camel_message_info_free (info);
@@ -832,7 +956,7 @@ mail_notebook_view_set_folder (EMailReader *reader,
{
EMailNotebookViewPrivate *priv = E_MAIL_NOTEBOOK_VIEW (reader)->priv;
GtkWidget *new_view;
-#if HAVE_CLUTTER
+#if HAVE_CLUTTER
EMailTab *tab;
ClutterActor *clone;
ClutterTimeline *timeline;
@@ -843,35 +967,35 @@ mail_notebook_view_set_folder (EMailReader *reader,
new_view = g_hash_table_lookup (priv->views, folder_uri);
if (new_view) {
- int curr = emnv_get_page_num (E_MAIL_NOTEBOOK_VIEW (reader), new_view);
-#if HAVE_CLUTTER
+ gint curr = emnv_get_page_num (E_MAIL_NOTEBOOK_VIEW (reader), new_view);
+#if HAVE_CLUTTER
EMailTab *tab;
if (curr == e_mail_tab_picker_get_current_tab (priv->tab_picker))
return;
- e_mail_tab_set_active (e_mail_tab_picker_get_tab (priv->tab_picker,
+ e_mail_tab_set_active (e_mail_tab_picker_get_tab (priv->tab_picker,
e_mail_tab_picker_get_current_tab (priv->tab_picker)),
FALSE);
#endif
priv->current_view = (EMailView *)new_view;
-#if HAVE_CLUTTER
+#if HAVE_CLUTTER
mnv_set_current_tab (E_MAIL_NOTEBOOK_VIEW(reader), curr);
#else
gtk_notebook_set_current_page (priv->book, curr);
#endif
-#if HAVE_CLUTTER
+#if HAVE_CLUTTER
tab = (EMailTab *)g_object_get_data ((GObject *)priv->current_view, "page");
curr = e_mail_tab_picker_get_tab_no (priv->tab_picker, tab);
e_mail_tab_picker_set_current_tab (priv->tab_picker, curr);
-#endif
+#endif
return;
}
if (folder || folder_uri) {
- int page;
+ gint page;
GtkWidget *list;
if (priv->inited) {
@@ -880,21 +1004,26 @@ mail_notebook_view_set_folder (EMailReader *reader,
priv->current_view = (EMailView *)e_mail_folder_pane_new (E_MAIL_VIEW(reader)->content);
gtk_widget_show ((GtkWidget *)priv->current_view);
priv->current_view->prev = old_view;
- page = gtk_notebook_append_page (priv->book, (GtkWidget *)priv->current_view,
- create_tab_label (E_MAIL_NOTEBOOK_VIEW(reader),
- priv->current_view,
- camel_folder_get_full_name (folder)));
-#if HAVE_CLUTTER
+ page = gtk_notebook_append_page (
+ priv->book, (GtkWidget *)priv->current_view,
+ create_tab_label (
+ E_MAIL_NOTEBOOK_VIEW (reader),
+ priv->current_view,
+ camel_folder_get_full_name (folder)));
+#if HAVE_CLUTTER
mnv_set_current_tab (E_MAIL_NOTEBOOK_VIEW(reader), page);
#else
- gtk_notebook_set_current_page (priv->book, page);
+ gtk_notebook_set_current_page (priv->book, page);
#endif
#if HAVE_CLUTTER
- e_mail_tab_set_active (e_mail_tab_picker_get_tab (priv->tab_picker,
- e_mail_tab_picker_get_current_tab (priv->tab_picker)),
- FALSE);
-
+ e_mail_tab_set_active (
+ e_mail_tab_picker_get_tab (
+ priv->tab_picker,
+ e_mail_tab_picker_get_current_tab (
+ priv->tab_picker)),
+ FALSE);
+
tab = (EMailTab *)e_mail_tab_new_full (camel_folder_get_full_name(folder), NULL, 1);
g_object_set_data ((GObject *)tab, "page", priv->current_view);
g_object_set_data ((GObject *)priv->current_view, "page", tab);
@@ -914,22 +1043,24 @@ mail_notebook_view_set_folder (EMailReader *reader,
e_mail_tab_picker_set_current_tab (priv->tab_picker, page);
g_object_ref (tab);
- timeline = clutter_timeline_new (150);
- g_signal_connect (timeline, "new-frame",
- G_CALLBACK (mnv_tab_anim_frame_cb), tab);
- g_signal_connect (timeline, "completed",
- G_CALLBACK (mnv_tab_anim_complete_cb), tab);
- clutter_timeline_start (timeline);
-#endif
+ timeline = clutter_timeline_new (150);
+ g_signal_connect (
+ timeline, "new-frame",
+ G_CALLBACK (mnv_tab_anim_frame_cb), tab);
+ g_signal_connect (
+ timeline, "completed",
+ G_CALLBACK (mnv_tab_anim_complete_cb), tab);
+ clutter_timeline_start (timeline);
+#endif
} else {
priv->inited = TRUE;
- gtk_notebook_set_tab_label (priv->book, (GtkWidget *)priv->current_view,
+ gtk_notebook_set_tab_label (priv->book, (GtkWidget *)priv->current_view,
create_tab_label (E_MAIL_NOTEBOOK_VIEW(reader),
- priv->current_view,
+ priv->current_view,
camel_folder_get_full_name (folder)));
-#if HAVE_CLUTTER
- tab = e_mail_tab_picker_get_tab(priv->tab_picker,
+#if HAVE_CLUTTER
+ tab = e_mail_tab_picker_get_tab(priv->tab_picker,
e_mail_tab_picker_get_current_tab (priv->tab_picker));
g_object_set_data ((GObject *)tab, "page", priv->current_view);
g_object_set_data ((GObject *)priv->current_view, "page", tab);
@@ -937,18 +1068,18 @@ mail_notebook_view_set_folder (EMailReader *reader,
e_mail_tab_set_text (tab, camel_folder_get_full_name(folder));
clone = e_mail_tab_get_preview_actor (tab);
e_mail_tab_set_text ((EMailTab *)clone, camel_folder_get_full_name(folder));
-#endif
+#endif
}
-
+
list = e_mail_reader_get_message_list (E_MAIL_READER(priv->current_view));
-#if HAVE_CLUTTER
- g_signal_connect (tab , "closed",
+#if HAVE_CLUTTER
+ g_signal_connect (tab , "closed",
G_CALLBACK (mnv_tab_closed), reader);
- g_object_set_data ((GObject *)priv->current_view, "stage", priv->stage);
- g_object_set_data ((GObject *)list, "stage", priv->stage);
- g_object_set_data ((GObject *)list, "actor", priv->actor);
-
-#endif
+ g_object_set_data ((GObject *)priv->current_view, "stage", priv->stage);
+ g_object_set_data ((GObject *)list, "stage", priv->stage);
+ g_object_set_data ((GObject *)list, "actor", priv->actor);
+
+#endif
e_mail_reader_set_folder (E_MAIL_READER(priv->current_view), folder, folder_uri);
g_hash_table_insert (priv->views, g_strdup(folder_uri), priv->current_view);
g_signal_connect ( E_MAIL_READER(priv->current_view), "changed",
@@ -966,62 +1097,19 @@ static void
mail_notebook_view_show_search_bar (EMailReader *reader)
{
EMailNotebookViewPrivate *priv = E_MAIL_NOTEBOOK_VIEW (reader)->priv;
-
- e_mail_reader_show_search_bar (E_MAIL_READER(priv->current_view));
-}
-
-EShellSearchbar *
-e_mail_notebook_view_get_searchbar (EMailView *view)
-{
- EShellView *shell_view;
- EShellContent *shell_content;
- GtkWidget *widget;
-
- g_return_val_if_fail (
- E_IS_MAIL_NOTEBOOK_VIEW (view), NULL);
- shell_content = E_MAIL_VIEW (view)->content;
- shell_view = e_shell_content_get_shell_view (shell_content);
- widget = e_shell_view_get_searchbar (shell_view);
-
- return E_SHELL_SEARCHBAR (widget);
-/*
- if (!E_MAIL_NOTEBOOK_VIEW(view)->priv->current_view)
- return NULL;
- return e_mail_view_get_searchbar (E_MAIL_NOTEBOOK_VIEW(view)->priv->current_view); */
+ e_mail_reader_show_search_bar (E_MAIL_READER(priv->current_view));
}
-static void
+static guint
mail_notebook_view_open_selected_mail (EMailReader *reader)
{
EMailNotebookViewPrivate *priv = E_MAIL_NOTEBOOK_VIEW (reader)->priv;
-
- if (!priv->current_view)
- return ;
-
- return e_mail_reader_open_selected_mail (E_MAIL_READER(priv->current_view));
-}
-
-void
-e_mail_notebook_view_set_search_strings (EMailView *view,
- GSList *search_strings)
-{
- e_mail_view_set_search_strings (E_MAIL_NOTEBOOK_VIEW (view)->priv->current_view, search_strings);
-}
-
-GalViewInstance *
-e_mail_notebook_view_get_view_instance (EMailView *view)
-{
- if (!E_MAIL_NOTEBOOK_VIEW(view)->priv->current_view)
- return NULL;
- return e_mail_view_get_view_instance (E_MAIL_NOTEBOOK_VIEW (view)->priv->current_view);
-}
+ if (!priv->current_view)
+ return 0;
-void
-e_mail_notebook_view_update_view_instance (EMailView *view)
-{
- e_mail_view_update_view_instance (E_MAIL_NOTEBOOK_VIEW (view)->priv->current_view);
+ return e_mail_reader_open_selected_mail (E_MAIL_READER(priv->current_view));
}
static void
@@ -1068,7 +1156,7 @@ e_mail_notebook_view_register_type (GTypeModule *type_module)
};
mail_notebook_view_type = g_type_module_register_type (
- type_module, E_MAIL_VIEW_TYPE,
+ type_module, E_TYPE_MAIL_VIEW,
"EMailNotebookView", &type_info, 0);
g_type_module_add_interface (
@@ -1076,54 +1164,3 @@ e_mail_notebook_view_register_type (GTypeModule *type_module)
E_TYPE_MAIL_READER, &reader_info);
}
-void
-e_mail_notebook_view_set_show_deleted (EMailNotebookView *view,
- gboolean show_deleted)
-{
- if (!view->priv->current_view)
- return;
-
- e_mail_view_set_show_deleted (view->priv->current_view, show_deleted);
-}
-gboolean
-e_mail_notebook_view_get_show_deleted (EMailNotebookView *view)
-{
- if (!view->priv->current_view)
- return FALSE;
-
- return e_mail_view_get_show_deleted (view->priv->current_view);
-}
-void
-e_mail_notebook_view_set_preview_visible (EMailNotebookView *view,
- gboolean preview_visible)
-{
- if (!view->priv->current_view)
- return ;
-
- e_mail_view_set_preview_visible (view->priv->current_view, preview_visible);
-}
-gboolean
-e_mail_notebook_view_get_preview_visible (EMailNotebookView *view)
-{
- if (!view->priv->current_view)
- return FALSE;
-
- return e_mail_view_get_preview_visible (view->priv->current_view);
-}
-void
-e_mail_notebook_view_set_orientation (EMailNotebookView *view,
- GtkOrientation orientation)
-{
- if (!view->priv->current_view)
- return;
-
- e_mail_view_set_orientation (view->priv->current_view, orientation);
-}
-GtkOrientation
-e_mail_notebook_view_get_orientation (EMailNotebookView *view)
-{
- if (!view->priv->current_view)
- return GTK_ORIENTATION_VERTICAL;
-
- return e_mail_view_get_orientation (view->priv->current_view);
-}
diff --git a/mail/e-mail-notebook-view.h b/mail/e-mail-notebook-view.h
index 957737653b..cdc341ec4a 100644
--- a/mail/e-mail-notebook-view.h
+++ b/mail/e-mail-notebook-view.h
@@ -10,7 +10,7 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
- * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
*
*
* Authors:
@@ -20,59 +20,78 @@
*
*/
-#ifndef _E_MAIL_NOTEBOOK_VIEW_H_
-#define _E_MAIL_NOTEBOOK_VIEW_H_
+#ifndef E_MAIL_NOTEBOOK_VIEW_H
+#define E_MAIL_NOTEBOOK_VIEW_H
-#include <gtk/gtk.h>
-#include "e-mail-view.h"
+#include <mail/e-mail-view.h>
#include <shell/e-shell-searchbar.h>
-#include "widgets/menus/gal-view-instance.h"
+#include <menus/gal-view-instance.h>
-#define E_MAIL_NOTEBOOK_VIEW_TYPE (e_mail_notebook_view_get_type ())
-#define E_MAIL_NOTEBOOK_VIEW(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), E_MAIL_NOTEBOOK_VIEW_TYPE, EMailNotebookView))
-#define E_MAIL_NOTEBOOK_VIEW_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), E_MAIL_NOTEBOOK_VIEW_TYPE, EMailNotebookViewClass))
-#define E_IS_MAIL_NOTEBOOK_VIEW(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), E_MAIL_NOTEBOOK_VIEW_TYPE))
-#define E_IS_MAIL_NOTEBOOK_VIEW_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), E_MAIL_NOTEBOOK_VIEW_TYPE))
-#define E_MAIL_NOTEBOOK_VIEW_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), E_MAIL_NOTEBOOK_VIEW_TYPE, EMailNotebookViewClass))
+/* Standard GObject macros */
+#define E_TYPE_MAIL_NOTEBOOK_VIEW \
+ (e_mail_notebook_view_get_type ())
+#define E_MAIL_NOTEBOOK_VIEW(obj) \
+ (G_TYPE_CHECK_INSTANCE_CAST \
+ ((obj), E_TYPE_MAIL_NOTEBOOK_VIEW, EMailNotebookView))
+#define E_MAIL_NOTEBOOK_VIEW_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_CAST \
+ ((cls), E_TYPE_MAIL_NOTEBOOK_VIEW, EMailNotebookViewClass))
+#define E_IS_MAIL_NOTEBOOK_VIEW(obj) \
+ (G_TYPE_CHECK_INSTANCE_TYPE \
+ ((obj), E_TYPE_MAIL_NOTEBOOK_VIEW))
+#define E_IS_MAIL_NOTEBOOK_VIEW_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_TYPE \
+ ((cls), E_TYPE_MAIL_NOTEBOOK_VIEW))
+#define E_MAIL_NOTEBOOK_VIEW_GET_CLASS(obj) \
+ (G_TYPE_INSTANCE_GET_CLASS \
+ ((obj), E_TYPE_MAIL_NOTEBOOK_VIEW, EMailNotebookViewClass))
+G_BEGIN_DECLS
+typedef struct _EMailNotebookView EMailNotebookView;
+typedef struct _EMailNotebookViewClass EMailNotebookViewClass;
typedef struct _EMailNotebookViewPrivate EMailNotebookViewPrivate;
-typedef struct _EMailNotebookView {
+struct _EMailNotebookView {
EMailView parent;
-
EMailNotebookViewPrivate *priv;
-} EMailNotebookView;
+};
-typedef struct _EMailNotebookViewClass {
+struct _EMailNotebookViewClass {
EMailViewClass parent_class;
+};
-} EMailNotebookViewClass;
-
-GType e_mail_notebook_view_get_type (void);
-void e_mail_notebook_view_register_type (GTypeModule *type_module);
-GtkWidget * e_mail_notebook_view_new (EShellContent *content);
-
-EShellSearchbar * e_mail_notebook_view_get_searchbar (EMailView *view);
-void e_mail_notebook_view_set_search_strings (EMailView *view, GSList *search_strings);
-GalViewInstance * e_mail_notebook_view_get_view_instance (EMailView *view);
-void e_mail_notebook_view_update_view_instance (EMailView *view);
-
-void
-e_mail_notebook_view_set_show_deleted (EMailNotebookView *view,
- gboolean show_deleted);
-gboolean
-e_mail_notebook_view_get_show_deleted (EMailNotebookView *view);
+GType e_mail_notebook_view_get_type (void);
+void e_mail_notebook_view_register_type
+ (GTypeModule *type_module);
+GtkWidget * e_mail_notebook_view_new (EShellContent *content);
+EShellSearchbar *
+ e_mail_notebook_view_get_searchbar
+ (EMailNotebookView *view);
+void e_mail_notebook_view_set_search_strings
+ (EMailNotebookView *view,
+ GSList *search_strings);
+GalViewInstance *
+ e_mail_notebook_view_get_view_instance
+ (EMailNotebookView *view);
+void e_mail_notebook_view_update_view_instance
+ (EMailNotebookView *view);
+void e_mail_notebook_view_set_show_deleted
+ (EMailNotebookView *view,
+ gboolean show_deleted);
+gboolean e_mail_notebook_view_get_show_deleted
+ (EMailNotebookView *view);
+void e_mail_notebook_view_set_preview_visible
+ (EMailNotebookView *view,
+ gboolean preview_visible);
+gboolean e_mail_notebook_view_get_preview_visible
+ (EMailNotebookView *view);
+void e_mail_notebook_view_set_orientation
+ (EMailNotebookView *view,
+ GtkOrientation orientation);
+GtkOrientation e_mail_notebook_view_get_orientation
+ (EMailNotebookView *view);
-void
-e_mail_notebook_view_set_preview_visible (EMailNotebookView *view,
- gboolean preview_visible);
-gboolean
-e_mail_notebook_view_get_preview_visible (EMailNotebookView *view);
-void
-e_mail_notebook_view_set_orientation (EMailNotebookView *view,
- GtkOrientation orientation);
-GtkOrientation
-e_mail_notebook_view_get_orientation (EMailNotebookView *view);
+G_END_DECLS
-#endif
+#endif /* E_MAIL_NOTEBOOK_VIEW_H */
diff --git a/mail/e-mail-pane.c b/mail/e-mail-pane.c
index 879a90bce1..e58a645eec 100644
--- a/mail/e-mail-pane.c
+++ b/mail/e-mail-pane.c
@@ -10,7 +10,7 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
- * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
*
*
* Authors:
@@ -24,12 +24,10 @@
# include <config.h>
#endif
-
#include <glib.h>
#include <glib/gi18n.h>
#include "e-mail-pane.h"
-
G_DEFINE_TYPE (EMailPane, e_mail_pane, GTK_TYPE_VBOX)
enum {
@@ -72,4 +70,3 @@ e_mail_pane_class_init (EMailPaneClass *klass)
}
-
diff --git a/mail/e-mail-pane.h b/mail/e-mail-pane.h
index f8383d2b76..2e20dd772d 100644
--- a/mail/e-mail-pane.h
+++ b/mail/e-mail-pane.h
@@ -1,4 +1,6 @@
/*
+ * e-mail-pane.h
+ *
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
@@ -10,7 +12,7 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
- * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
*
*
* Authors:
@@ -20,30 +22,44 @@
*
*/
-#ifndef _E_MAIL_PANE_H_
-#define _E_MAIL_PANE_H_
+#ifndef E_MAIL_PANE_H
+#define E_MAIL_PANE_H
#include <gtk/gtk.h>
-#define E_MAIL_PANE_TYPE (e_mail_pane_get_type ())
-#define E_MAIL_PANE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), E_MAIL_PANE_TYPE, MailFolderView))
-#define E_MAIL_PANE_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), E_MAIL_PANE_TYPE, MailFolderViewClass))
-#define IS_E_MAIL_PANE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), E_MAIL_PANE_TYPE))
-#define IS_E_MAIL_PANE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), E_MAIL_PANE_TYPE))
-#define E_MAIL_PANE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), E_MAIL_PANE_TYPE, EMailPaneClass))
+#define E_TYPE_MAIL_PANE \
+ (e_mail_pane_get_type ())
+#define E_MAIL_PANE(obj) \
+ (G_TYPE_CHECK_INSTANCE_CAST \
+ ((obj), E_TYPE_MAIL_PANE, MailFolderView))
+#define E_MAIL_PANE_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_CAST \
+ ((cls), E_TYPE_MAIL_PANE, MailFolderViewClass))
+#define E_IS_MAIL_PANE(obj) \
+ (G_TYPE_CHECK_INSTANCE_TYPE \
+ ((obj), E_TYPE_MAIL_PANE))
+#define E_IS_MAIL_PANE_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_TYPE \
+ ((cls), E_TYPE_MAIL_PANE))
+#define E_MAIL_PANE_GET_CLASS(obj) \
+ (G_TYPE_INSTANCE_GET_CLASS \
+ ((obj), E_TYPE_MAIL_PANE, EMailPaneClass))
+G_BEGIN_DECLS
+typedef struct _EMailPane EMailPane;
+typedef struct _EMailPaneClass EMailPaneClass;
typedef struct _EMailPanePrivate EMailPanePrivate;
-typedef struct _EMailPane {
+struct _EMailPane {
GtkVBox parent;
-
EMailPanePrivate *priv;
-} EMailPane;
+};
-typedef struct _EMailPaneClass {
+struct _EMailPaneClass {
GtkVBoxClass parent_class;
+};
-} EMailPaneClass;
+G_END_DECLS
-#endif
+#endif /* E_MAIL_PANE_H */
diff --git a/mail/e-mail-paned-view.c b/mail/e-mail-paned-view.c
index 6733e40182..cf13ac5514 100644
--- a/mail/e-mail-paned-view.c
+++ b/mail/e-mail-paned-view.c
@@ -10,7 +10,7 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
- * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
*
*
* Authors:
@@ -24,7 +24,6 @@
# include <config.h>
#endif
-
#include <glib.h>
#include <glib/gi18n.h>
#include "e-mail-paned-view.h"
@@ -48,6 +47,10 @@
#include "message-list.h"
#include "e-mail-reader-utils.h"
+#define E_MAIL_PANED_VIEW_GET_PRIVATE(obj) \
+ (G_TYPE_INSTANCE_GET_PRIVATE \
+ ((obj), E_TYPE_MAIL_PANED_VIEW, EMailPanedViewPrivate))
+
#define E_SHELL_WINDOW_ACTION_GROUP_MAIL(window) \
E_SHELL_WINDOW_ACTION_GROUP ((window), "mail")
@@ -86,14 +89,13 @@ enum {
#define STATE_KEY_SELECTED_MESSAGE "SelectedMessage"
#define STATE_KEY_PREVIEW_VISIBLE "PreviewVisible"
-
static EMailViewClass *parent_class;
static GType mail_paned_view_type;
static void
mail_paned_view_save_boolean (EMailPanedView *view,
- const gchar *key,
- gboolean value)
+ const gchar *key,
+ gboolean value)
{
EShellView *shell_view;
EShellContent *shell_content;
@@ -121,7 +123,7 @@ mail_paned_view_save_boolean (EMailPanedView *view,
static void
mail_paned_view_message_list_built_cb (EMailPanedView *view,
- MessageList *message_list)
+ MessageList *message_list)
{
EMailPanedViewPrivate *priv = view->priv;
EShellView *shell_view;
@@ -169,8 +171,8 @@ mail_paned_view_message_list_built_cb (EMailPanedView *view,
static void
mail_paned_view_message_selected_cb (EMailPanedView *view,
- const gchar *message_uid,
- MessageList *message_list)
+ const gchar *message_uid,
+ MessageList *message_list)
{
EShellContent *shell_content;
EShellView *shell_view;
@@ -206,8 +208,8 @@ mail_paned_view_message_selected_cb (EMailPanedView *view,
static void
mail_paned_view_restore_state_cb (EShellWindow *shell_window,
- EShellView *shell_view,
- EMailPanedView *view)
+ EShellView *shell_view,
+ EMailPanedView *view)
{
EMailPanedViewPrivate *priv;
GConfBridge *bridge;
@@ -230,6 +232,22 @@ mail_paned_view_restore_state_cb (EShellWindow *shell_window,
}
static void
+mail_paned_display_view_cb (EMailView *view,
+ GalView *gal_view)
+{
+ EMailReader *reader;
+ GtkWidget *message_list;
+
+ reader = E_MAIL_READER (view);
+ message_list = e_mail_reader_get_message_list (reader);
+
+ if (GAL_IS_VIEW_ETABLE (gal_view))
+ gal_view_etable_attach_tree (
+ GAL_VIEW_ETABLE (gal_view),
+ E_TREE (message_list));
+}
+
+static void
mail_paned_view_notify_group_by_threads_cb (EMailReader *reader)
{
gboolean group_by_threads;
@@ -241,28 +259,11 @@ mail_paned_view_notify_group_by_threads_cb (EMailReader *reader)
STATE_KEY_GROUP_BY_THREADS, group_by_threads);
}
-GtkOrientation
-e_mail_paned_view_get_orientation (EMailPanedView *view)
-{
- return view->priv->orientation;
-}
-
-void
-e_mail_paned_view_set_orientation (EMailPanedView *view,
- GtkOrientation orientation)
-{
- view->priv->orientation = orientation;
-
- g_object_notify (G_OBJECT (view), "orientation");
-
- e_mail_paned_view_update_view_instance (view);
-}
-
static void
mail_paned_view_set_property (GObject *object,
- guint property_id,
- const GValue *value,
- GParamSpec *pspec)
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec)
{
switch (property_id) {
case PROP_GROUP_BY_THREADS:
@@ -272,20 +273,20 @@ mail_paned_view_set_property (GObject *object,
return;
case PROP_ORIENTATION:
- e_mail_paned_view_set_orientation (
- E_MAIL_PANED_VIEW (object),
+ e_mail_view_set_orientation (
+ E_MAIL_VIEW (object),
g_value_get_enum (value));
return;
case PROP_PREVIEW_VISIBLE:
- e_mail_paned_view_set_preview_visible (
- E_MAIL_PANED_VIEW (object),
+ e_mail_view_set_preview_visible (
+ E_MAIL_VIEW (object),
g_value_get_boolean (value));
return;
case PROP_SHOW_DELETED:
- e_mail_paned_view_set_show_deleted (
- E_MAIL_PANED_VIEW (object),
+ e_mail_view_set_show_deleted (
+ E_MAIL_VIEW (object),
g_value_get_boolean (value));
return;
}
@@ -295,9 +296,9 @@ mail_paned_view_set_property (GObject *object,
static void
mail_paned_view_get_property (GObject *object,
- guint property_id,
- GValue *value,
- GParamSpec *pspec)
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec)
{
switch (property_id) {
case PROP_GROUP_BY_THREADS:
@@ -310,22 +311,22 @@ mail_paned_view_get_property (GObject *object,
case PROP_ORIENTATION:
g_value_set_enum (
value,
- e_mail_paned_view_get_orientation (
- E_MAIL_PANED_VIEW (object)));
+ e_mail_view_get_orientation (
+ E_MAIL_VIEW (object)));
return;
case PROP_PREVIEW_VISIBLE:
g_value_set_boolean (
value,
- e_mail_paned_view_get_preview_visible (
- E_MAIL_PANED_VIEW (object)));
+ e_mail_view_get_preview_visible (
+ E_MAIL_VIEW (object)));
return;
case PROP_SHOW_DELETED:
g_value_set_boolean (
value,
- e_mail_paned_view_get_show_deleted (
- E_MAIL_PANED_VIEW (object)));
+ e_mail_view_get_show_deleted (
+ E_MAIL_VIEW (object)));
return;
}
@@ -337,7 +338,7 @@ mail_paned_view_dispose (GObject *object)
{
EMailPanedViewPrivate *priv;
- priv = E_MAIL_PANED_VIEW(object)->priv;
+ priv = E_MAIL_PANED_VIEW (object)->priv;
if (priv->paned != NULL) {
g_object_unref (priv->paned);
@@ -400,7 +401,7 @@ mail_paned_view_get_formatter (EMailReader *reader)
static gboolean
mail_paned_view_get_hide_deleted (EMailReader *reader)
{
- return !e_mail_paned_view_get_show_deleted (E_MAIL_PANED_VIEW(reader));
+ return !e_mail_view_get_show_deleted (E_MAIL_VIEW (reader));
}
static GtkWidget *
@@ -539,8 +540,7 @@ mail_paned_view_set_folder (EMailReader *reader,
value = FALSE;
}
- e_mail_paned_view_set_preview_visible (
- E_MAIL_PANED_VIEW (reader), value);
+ e_mail_view_set_preview_visible (E_MAIL_VIEW (reader), value);
g_free (group_name);
@@ -558,14 +558,14 @@ mail_paned_view_show_search_bar (EMailReader *reader)
gtk_widget_show (priv->search_bar);
}
-static void
-mail_paned_view_open_selected_mail (EMailReader *reader)
+static guint
+mail_paned_view_reader_open_selected_mail (EMailReader *reader)
{
EMailPanedViewPrivate *priv;
priv = E_MAIL_PANED_VIEW (reader)->priv;
- E_MAIL_PANED_VIEW_CLASS(G_OBJECT_GET_CLASS (reader))->open_selected_mail (E_MAIL_PANED_VIEW(reader));
+ return E_MAIL_PANED_VIEW_CLASS (G_OBJECT_GET_CLASS (reader))->open_selected_mail (E_MAIL_PANED_VIEW (reader));
}
static void
@@ -586,10 +586,6 @@ mail_paned_view_constructed (GObject *object)
priv = E_MAIL_PANED_VIEW (object)->priv;
priv->formatter = em_format_html_display_new ();
- /* Chain up to parent's constructed() method. */
- if (G_OBJECT_CLASS (parent_class)->constructed)
- G_OBJECT_CLASS (parent_class)->constructed (object);
-
shell_content = E_MAIL_VIEW (object)->content;
shell_view = e_shell_content_get_shell_view (shell_content);
shell_window = e_shell_view_get_shell_window (shell_view);
@@ -648,12 +644,11 @@ mail_paned_view_constructed (GObject *object)
/* Load the view instance. */
- e_mail_paned_view_update_view_instance (
- E_MAIL_PANED_VIEW (object));
+ e_mail_view_update_view_instance (E_MAIL_VIEW (object));
/* Message list customizations. */
- e_mail_reader_init_private (E_MAIL_READER(object));
+ e_mail_reader_init_private (E_MAIL_READER (object));
reader = E_MAIL_READER (object);
message_list = e_mail_reader_get_message_list (reader);
@@ -673,253 +668,31 @@ mail_paned_view_constructed (GObject *object)
e_mail_reader_connect_headers (reader);
}
-static void
-mpv_open_selected_mail (EMailPanedView *view)
-{
- e_mail_reader_open_selected (E_MAIL_READER(view));
-}
-
-static void
-mail_paned_view_init (EMailPanedView *shell)
-{
- shell->priv = g_new0(EMailPanedViewPrivate, 1);
-
- shell->priv->preview_visible = TRUE;
-
- g_signal_connect (
- shell, "notify::group-by-threads",
- G_CALLBACK (mail_paned_view_notify_group_by_threads_cb),
- NULL);
-
-}
-
-static void
-mail_paned_view_class_init (EMailViewClass *klass)
-{
- GObjectClass * object_class = G_OBJECT_CLASS (klass);
-
- parent_class = g_type_class_peek_parent (klass);
- object_class->dispose = mail_paned_view_dispose;
- object_class->constructed = mail_paned_view_constructed;
- object_class->set_property = mail_paned_view_set_property;
- object_class->get_property = mail_paned_view_get_property;
-
- klass->get_searchbar = e_mail_paned_view_get_searchbar;
- klass->set_search_strings = e_mail_paned_view_set_search_strings;
- klass->get_view_instance = e_mail_paned_view_get_view_instance;
- klass->update_view_instance = e_mail_paned_view_update_view_instance;
-
- klass->set_orientation = e_mail_paned_view_set_orientation;
- klass->get_orientation = e_mail_paned_view_get_orientation;
- klass->set_show_deleted = e_mail_paned_view_set_show_deleted;
- klass->get_show_deleted = e_mail_paned_view_get_show_deleted;
- klass->set_preview_visible = e_mail_paned_view_set_preview_visible;
- klass->get_preview_visible = e_mail_paned_view_get_preview_visible;
-
- E_MAIL_PANED_VIEW_CLASS(klass)->open_selected_mail = mpv_open_selected_mail;
-
- /* Inherited from EMailReader */
- g_object_class_override_property (
- object_class,
- PROP_GROUP_BY_THREADS,
- "group-by-threads");
-
- g_object_class_install_property (
- object_class,
- PROP_PREVIEW_VISIBLE,
- g_param_spec_boolean (
- "preview-visible",
- "Preview is Visible",
- "Whether the preview pane is visible",
- TRUE,
- G_PARAM_READWRITE));
-
- g_object_class_install_property (
- object_class,
- PROP_SHOW_DELETED,
- g_param_spec_boolean (
- "show-deleted",
- "Show Deleted",
- NULL,
- FALSE,
- G_PARAM_READWRITE));
-
- g_object_class_override_property (
- object_class, PROP_ORIENTATION, "orientation");
-}
-
-static void
-mail_paned_view_reader_init (EMailReaderIface *iface)
-{
- iface->get_action_group = mail_paned_view_get_action_group;
- iface->get_formatter = mail_paned_view_get_formatter;
- iface->get_hide_deleted = mail_paned_view_get_hide_deleted;
- iface->get_message_list = mail_paned_view_get_message_list;
- iface->get_popup_menu = mail_paned_view_get_popup_menu;
- iface->get_shell_backend = mail_paned_view_get_shell_backend;
- iface->get_window = mail_paned_view_get_window;
- iface->set_folder = mail_paned_view_set_folder;
- iface->show_search_bar = mail_paned_view_show_search_bar;
- iface->open_selected_mail = mail_paned_view_open_selected_mail;
-}
-
-GType
-e_mail_paned_view_get_type (void)
-{
- return mail_paned_view_type;
-}
-
-void
-e_mail_paned_view_register_type (GTypeModule *type_module)
-{
- static const GTypeInfo type_info = {
- sizeof (EMailPanedViewClass),
- (GBaseInitFunc) NULL,
- (GBaseFinalizeFunc) NULL,
- (GClassInitFunc) mail_paned_view_class_init,
- (GClassFinalizeFunc) NULL,
- NULL, /* class_data */
- sizeof (EMailPanedView),
- 0, /* n_preallocs */
- (GInstanceInitFunc) mail_paned_view_init,
- NULL /* value_table */
- };
-#if 0
- static const GInterfaceInfo orientable_info = {
- (GInterfaceInitFunc) NULL,
- (GInterfaceFinalizeFunc) NULL,
- NULL /* interface_data */
- };
-#endif
- static const GInterfaceInfo reader_info = {
- (GInterfaceInitFunc) mail_paned_view_reader_init,
- (GInterfaceFinalizeFunc) NULL,
- NULL /* interface_data */
- };
-
- mail_paned_view_type = g_type_module_register_type (
- type_module, E_MAIL_VIEW_TYPE,
- "EMailPanedView", &type_info, 0);
-#if 0
- g_type_module_add_interface (
- type_module, mail_paned_view_type,
- GTK_TYPE_ORIENTABLE, &orientable_info);
-#endif
- g_type_module_add_interface (
- type_module, mail_paned_view_type,
- E_TYPE_MAIL_READER, &reader_info);
-}
-
-
-GtkWidget *
-e_mail_paned_view_new (EShellContent *content)
-{
- g_return_val_if_fail (E_IS_SHELL_CONTENT (content), NULL);
-
- return g_object_new (
- E_MAIL_PANED_VIEW_TYPE,
- "shell-content", content, NULL);
-}
-
-gboolean
-e_mail_paned_view_get_preview_visible (EMailPanedView *view)
-{
- g_return_val_if_fail (
- E_IS_MAIL_PANED_VIEW (view), FALSE);
-
- return view->priv->preview_visible;
-}
-
-void
-e_mail_paned_view_set_preview_visible (EMailPanedView *view,
- gboolean preview_visible)
-{
- g_return_if_fail (E_IS_MAIL_PANED_VIEW (view));
-
- if (preview_visible == view->priv->preview_visible)
- return;
-
- /* If we're showing the preview, tell EMailReader to reload the
- * selected message. This should force it to download the full
- * message if necessary, so we don't get an empty preview. */
- if (preview_visible) {
- EMailReader *reader;
- GtkWidget *message_list;
- const gchar *cursor_uid;
-
- reader = E_MAIL_READER (view);
- message_list = e_mail_reader_get_message_list (reader);
- cursor_uid = MESSAGE_LIST (message_list)->cursor_uid;
-
- if (cursor_uid != NULL)
- e_mail_reader_set_message (reader, cursor_uid);
- }
-
- view->priv->preview_visible = preview_visible;
-
- mail_paned_view_save_boolean (
- view,
- STATE_KEY_PREVIEW_VISIBLE, preview_visible);
-
- g_object_notify (G_OBJECT (view), "preview-visible");
-}
-
-EShellSearchbar *
-e_mail_paned_view_get_searchbar (EMailPanedView *view)
+static EShellSearchbar *
+mail_paned_view_get_searchbar (EMailView *view)
{
EShellView *shell_view;
EShellContent *shell_content;
GtkWidget *widget;
- g_return_val_if_fail (
- E_IS_MAIL_PANED_VIEW (view), NULL);
-
- shell_content = E_MAIL_VIEW (view)->content;
+ shell_content = view->content;
shell_view = e_shell_content_get_shell_view (shell_content);
widget = e_shell_view_get_searchbar (shell_view);
return E_SHELL_SEARCHBAR (widget);
}
-gboolean
-e_mail_paned_view_get_show_deleted (EMailPanedView *view)
-{
- g_return_val_if_fail (
- E_IS_MAIL_PANED_VIEW (view), FALSE);
-
- return view->priv->show_deleted;
-}
-
-void
-e_mail_paned_view_set_show_deleted (EMailPanedView *view,
- gboolean show_deleted)
-{
- g_return_if_fail (E_IS_MAIL_PANED_VIEW (view));
-
- view->priv->show_deleted = show_deleted;
-
- g_object_notify (G_OBJECT (view), "show-deleted");
-}
-
-GalViewInstance *
-e_mail_paned_view_get_view_instance (EMailPanedView *view)
-{
- g_return_val_if_fail (
- E_IS_MAIL_PANED_VIEW (view), NULL);
-
- return view->priv->view_instance;
-}
-
-void
-e_mail_paned_view_set_search_strings (EMailPanedView *view,
- GSList *search_strings)
+static void
+mail_paned_view_set_search_strings (EMailView *view,
+ GSList *search_strings)
{
+ EMailPanedViewPrivate *priv;
ESearchBar *search_bar;
ESearchingTokenizer *tokenizer;
- g_return_if_fail (E_IS_MAIL_PANED_VIEW (view));
+ priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
- search_bar = E_SEARCH_BAR (view->priv->search_bar);
+ search_bar = E_SEARCH_BAR (priv->search_bar);
tokenizer = e_search_bar_get_tokenizer (search_bar);
e_searching_tokenizer_set_secondary_case_sensitivity (tokenizer, FALSE);
@@ -934,25 +707,20 @@ e_mail_paned_view_set_search_strings (EMailPanedView *view,
e_search_bar_changed (search_bar);
}
-static void
-mail_paned_display_view_cb (EMailPanedView *view,
- GalView *gal_view)
+static GalViewInstance *
+mail_paned_view_get_view_instance (EMailView *view)
{
- EMailReader *reader;
- GtkWidget *message_list;
+ EMailPanedViewPrivate *priv;
- reader = E_MAIL_READER (view);
- message_list = e_mail_reader_get_message_list (reader);
+ priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
- if (GAL_IS_VIEW_ETABLE (gal_view))
- gal_view_etable_attach_tree (
- GAL_VIEW_ETABLE (gal_view),
- E_TREE (message_list));
+ return priv->view_instance;
}
-void
-e_mail_paned_view_update_view_instance (EMailPanedView *view)
+static void
+mail_paned_view_update_view_instance (EMailView *view)
{
+ EMailPanedViewPrivate *priv;
EMailReader *reader;
EShell *shell;
EShellContent *shell_content;
@@ -970,7 +738,9 @@ e_mail_paned_view_update_view_instance (EMailPanedView *view)
const gchar *folder_uri;
gchar *view_id;
- shell_content = E_MAIL_VIEW(view)->content;
+ priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
+
+ shell_content = view->content;
shell_view = e_shell_content_get_shell_view (shell_content);
shell_view_class = E_SHELL_VIEW_GET_CLASS (shell_view);
view_collection = shell_view_class->view_collection;
@@ -990,9 +760,9 @@ e_mail_paned_view_update_view_instance (EMailPanedView *view)
/* If we have a folder, we should also have a URI. */
g_return_if_fail (folder_uri != NULL);
- if (view->priv->view_instance != NULL) {
- g_object_unref (view->priv->view_instance);
- view->priv->view_instance = NULL;
+ if (priv->view_instance != NULL) {
+ g_object_unref (priv->view_instance);
+ priv->view_instance = NULL;
}
view_id = mail_config_folder_to_safe_url (folder);
@@ -1001,7 +771,7 @@ e_mail_paned_view_update_view_instance (EMailPanedView *view)
else
view_instance = e_shell_view_new_view_instance (shell_view, view_id);
- view->priv->view_instance = view_instance;
+ priv->view_instance = view_instance;
orientable = GTK_ORIENTABLE (view);
orientation = gtk_orientable_get_orientation (orientable);
@@ -1096,29 +866,274 @@ e_mail_paned_view_update_view_instance (EMailPanedView *view)
g_signal_connect_swapped (
view_instance, "display-view",
- G_CALLBACK (mail_paned_display_view_cb),
- view);
+ G_CALLBACK (mail_paned_display_view_cb), view);
mail_paned_display_view_cb (
- view,
- gal_view_instance_get_current_view (view_instance));
+ view, gal_view_instance_get_current_view (view_instance));
+}
+
+static void
+mail_paned_view_set_orientation (EMailView *view,
+ GtkOrientation orientation)
+{
+ EMailPanedViewPrivate *priv;
+
+ priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
+
+ priv->orientation = orientation;
+
+ g_object_notify (G_OBJECT (view), "orientation");
+
+ e_mail_view_update_view_instance (view);
+}
+
+static GtkOrientation
+mail_paned_view_get_orientation (EMailView *view)
+{
+ EMailPanedViewPrivate *priv;
+
+ priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
+
+ return priv->orientation;
+}
+
+static void
+mail_paned_view_set_show_deleted (EMailView *view,
+ gboolean show_deleted)
+{
+ EMailPanedViewPrivate *priv;
+
+ priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
+
+ priv->show_deleted = show_deleted;
+
+ g_object_notify (G_OBJECT (view), "show-deleted");
+}
+
+static gboolean
+mail_paned_view_get_show_deleted (EMailView *view)
+{
+ EMailPanedViewPrivate *priv;
+
+ priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
+
+ return priv->show_deleted;
+}
+
+static void
+mail_paned_view_set_preview_visible (EMailView *view,
+ gboolean preview_visible)
+{
+ EMailPanedViewPrivate *priv;
+
+ priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
+
+ if (preview_visible == priv->preview_visible)
+ return;
+
+ /* If we're showing the preview, tell EMailReader to reload the
+ * selected message. This should force it to download the full
+ * message if necessary, so we don't get an empty preview. */
+ if (preview_visible) {
+ EMailReader *reader;
+ GtkWidget *message_list;
+ const gchar *cursor_uid;
+
+ reader = E_MAIL_READER (view);
+ message_list = e_mail_reader_get_message_list (reader);
+ cursor_uid = MESSAGE_LIST (message_list)->cursor_uid;
+
+ if (cursor_uid != NULL)
+ e_mail_reader_set_message (reader, cursor_uid);
+ }
+
+ priv->preview_visible = preview_visible;
+
+ mail_paned_view_save_boolean (
+ E_MAIL_PANED_VIEW (view),
+ STATE_KEY_PREVIEW_VISIBLE, preview_visible);
+
+ g_object_notify (G_OBJECT (view), "preview-visible");
+}
+
+static gboolean
+mail_paned_view_get_preview_visible (EMailView *view)
+{
+ EMailPanedViewPrivate *priv;
+
+ priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
+
+ return priv->preview_visible;
+}
+
+static guint
+mail_paned_view_open_selected_mail (EMailPanedView *view)
+{
+ return e_mail_reader_open_selected (E_MAIL_READER (view));
+}
+
+static void
+mail_paned_view_class_init (EMailPanedViewClass *class)
+{
+ GObjectClass *object_class;
+ EMailViewClass *mail_view_class;
+
+ parent_class = g_type_class_peek_parent (class);
+ g_type_class_add_private (class, sizeof (EMailPanedViewPrivate));
+
+ object_class = G_OBJECT_CLASS (class);
+ object_class->dispose = mail_paned_view_dispose;
+ object_class->constructed = mail_paned_view_constructed;
+ object_class->set_property = mail_paned_view_set_property;
+ object_class->get_property = mail_paned_view_get_property;
+
+ mail_view_class = E_MAIL_VIEW_CLASS (class);
+ mail_view_class->get_searchbar = mail_paned_view_get_searchbar;
+ mail_view_class->set_search_strings = mail_paned_view_set_search_strings;
+ mail_view_class->get_view_instance = mail_paned_view_get_view_instance;
+ mail_view_class->update_view_instance = mail_paned_view_update_view_instance;
+
+ mail_view_class->set_orientation = mail_paned_view_set_orientation;
+ mail_view_class->get_orientation = mail_paned_view_get_orientation;
+ mail_view_class->set_show_deleted = mail_paned_view_set_show_deleted;
+ mail_view_class->get_show_deleted = mail_paned_view_get_show_deleted;
+ mail_view_class->set_preview_visible = mail_paned_view_set_preview_visible;
+ mail_view_class->get_preview_visible = mail_paned_view_get_preview_visible;
+
+ class->open_selected_mail = mail_paned_view_open_selected_mail;
+
+ /* Inherited from EMailReader */
+ g_object_class_override_property (
+ object_class,
+ PROP_GROUP_BY_THREADS,
+ "group-by-threads");
+
+ g_object_class_install_property (
+ object_class,
+ PROP_PREVIEW_VISIBLE,
+ g_param_spec_boolean (
+ "preview-visible",
+ "Preview is Visible",
+ "Whether the preview pane is visible",
+ TRUE,
+ G_PARAM_READWRITE));
+
+ g_object_class_install_property (
+ object_class,
+ PROP_SHOW_DELETED,
+ g_param_spec_boolean (
+ "show-deleted",
+ "Show Deleted",
+ NULL,
+ FALSE,
+ G_PARAM_READWRITE));
+
+ g_object_class_override_property (
+ object_class, PROP_ORIENTATION, "orientation");
+}
+
+static void
+mail_paned_view_reader_init (EMailReaderIface *iface)
+{
+ iface->get_action_group = mail_paned_view_get_action_group;
+ iface->get_formatter = mail_paned_view_get_formatter;
+ iface->get_hide_deleted = mail_paned_view_get_hide_deleted;
+ iface->get_message_list = mail_paned_view_get_message_list;
+ iface->get_popup_menu = mail_paned_view_get_popup_menu;
+ iface->get_shell_backend = mail_paned_view_get_shell_backend;
+ iface->get_window = mail_paned_view_get_window;
+ iface->set_folder = mail_paned_view_set_folder;
+ iface->show_search_bar = mail_paned_view_show_search_bar;
+ iface->open_selected_mail = mail_paned_view_reader_open_selected_mail;
+}
+
+static void
+mail_paned_view_init (EMailPanedView *view)
+{
+ view->priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view);
+
+ view->priv->preview_visible = TRUE;
+
+ g_signal_connect (
+ view, "notify::group-by-threads",
+ G_CALLBACK (mail_paned_view_notify_group_by_threads_cb),
+ NULL);
+}
+
+GType
+e_mail_paned_view_get_type (void)
+{
+ return mail_paned_view_type;
+}
+
+void
+e_mail_paned_view_register_type (GTypeModule *type_module)
+{
+ static const GTypeInfo type_info = {
+ sizeof (EMailPanedViewClass),
+ (GBaseInitFunc) NULL,
+ (GBaseFinalizeFunc) NULL,
+ (GClassInitFunc) mail_paned_view_class_init,
+ (GClassFinalizeFunc) NULL,
+ NULL, /* class_data */
+ sizeof (EMailPanedView),
+ 0, /* n_preallocs */
+ (GInstanceInitFunc) mail_paned_view_init,
+ NULL /* value_table */
+ };
+#if 0
+ static const GInterfaceInfo orientable_info = {
+ (GInterfaceInitFunc) NULL,
+ (GInterfaceFinalizeFunc) NULL,
+ NULL /* interface_data */
+ };
+#endif
+ static const GInterfaceInfo reader_info = {
+ (GInterfaceInitFunc) mail_paned_view_reader_init,
+ (GInterfaceFinalizeFunc) NULL,
+ NULL /* interface_data */
+ };
+
+ mail_paned_view_type = g_type_module_register_type (
+ type_module, E_TYPE_MAIL_VIEW,
+ "EMailPanedView", &type_info, 0);
+#if 0
+ g_type_module_add_interface (
+ type_module, mail_paned_view_type,
+ GTK_TYPE_ORIENTABLE, &orientable_info);
+#endif
+ g_type_module_add_interface (
+ type_module, mail_paned_view_type,
+ E_TYPE_MAIL_READER, &reader_info);
+}
+
+GtkWidget *
+e_mail_paned_view_new (EShellContent *content)
+{
+ g_return_val_if_fail (E_IS_SHELL_CONTENT (content), NULL);
+
+ return g_object_new (
+ E_TYPE_MAIL_PANED_VIEW,
+ "shell-content", content, NULL);
}
void
e_mail_paned_view_hide_message_list_pane (EMailPanedView *view,
- gboolean visible)
+ gboolean visible)
{
- EMailPanedViewPrivate *priv = view->priv;
+ g_return_if_fail (E_IS_MAIL_PANED_VIEW (view));
if (visible)
- gtk_widget_show (priv->scrolled_window);
+ gtk_widget_show (view->priv->scrolled_window);
else
- gtk_widget_hide (priv->scrolled_window);
+ gtk_widget_hide (view->priv->scrolled_window);
}
GtkWidget *
e_mail_paned_view_get_preview (EMailPanedView *view)
{
+ g_return_val_if_fail (E_IS_MAIL_PANED_VIEW (view), NULL);
+
return view->priv->preview;
}
diff --git a/mail/e-mail-paned-view.h b/mail/e-mail-paned-view.h
index 8cb5a0e561..09d2299a4f 100644
--- a/mail/e-mail-paned-view.h
+++ b/mail/e-mail-paned-view.h
@@ -10,7 +10,7 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
- * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
*
*
* Authors:
@@ -20,11 +20,10 @@
*
*/
-#ifndef _E_MAIL_PANED_VIEW_H_
-#define _E_MAIL_PANED_VIEW_H_
+#ifndef E_MAIL_PANED_VIEW_H
+#define E_MAIL_PANED_VIEW_H
-#include <gtk/gtk.h>
-#include "e-mail-view.h"
+#include <mail/e-mail-view.h>
#include <shell/e-shell-content.h>
#include <shell/e-shell-searchbar.h>
@@ -32,63 +31,50 @@
#include <mail/em-format-html-display.h>
-#define E_MAIL_PANED_VIEW_TYPE (e_mail_paned_view_get_type ())
-#define E_MAIL_PANED_VIEW(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), E_MAIL_PANED_VIEW_TYPE, EMailPanedView))
-#define E_MAIL_PANED_VIEW_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), E_MAIL_PANED_VIEW_TYPE, EMailPanedViewClass))
-#define E_IS_MAIL_PANED_VIEW(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), E_MAIL_PANED_VIEW_TYPE))
-#define E_IS_MAIL_PANED_VIEW_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), E_MAIL_PANED_VIEW_TYPE))
-#define E_MAIL_PANED_VIEW_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), E_MAIL_PANED_VIEW_TYPE, EMailPanedViewClass))
+/* Standard GObject macros */
+#define E_TYPE_MAIL_PANED_VIEW \
+ (e_mail_paned_view_get_type ())
+#define E_MAIL_PANED_VIEW(obj) \
+ (G_TYPE_CHECK_INSTANCE_CAST \
+ ((obj), E_TYPE_MAIL_PANED_VIEW, EMailPanedView))
+#define E_MAIL_PANED_VIEW_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_CAST \
+ ((cls), E_TYPE_MAIL_PANED_VIEW, EMailPanedViewClass))
+#define E_IS_MAIL_PANED_VIEW(obj) \
+ (G_TYPE_CHECK_INSTANCE_TYPE \
+ ((obj), E_TYPE_MAIL_PANED_VIEW))
+#define E_IS_MAIL_PANED_VIEW_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_TYPE \
+ ((cls), E_TYPE_MAIL_PANED_VIEW))
+#define E_MAIL_PANED_VIEW_GET_CLASS(obj) \
+ (G_TYPE_INSTANCE_GET_CLASS \
+ ((obj), E_TYPE_MAIL_PANED_VIEW, EMailPanedViewClass))
+G_BEGIN_DECLS
+typedef struct _EMailPanedView EMailPanedView;
+typedef struct _EMailPanedViewClass EMailPanedViewClass;
typedef struct _EMailPanedViewPrivate EMailPanedViewPrivate;
-typedef struct _EMailPanedView {
+struct _EMailPanedView {
EMailView parent;
-
EMailPanedViewPrivate *priv;
-} EMailPanedView;
+};
-typedef struct _EMailPanedViewClass {
+struct _EMailPanedViewClass {
EMailViewClass parent_class;
- void (*open_selected_mail) (EMailPanedView *view);
-
-} EMailPanedViewClass;
+ guint (*open_selected_mail) (EMailPanedView *view);
+};
-GType e_mail_paned_view_get_type (void);
-void
-e_mail_paned_view_register_type (GTypeModule *type_module);
-GtkWidget *
-e_mail_paned_view_new (EShellContent *content);
-void
-e_mail_paned_view_update_view_instance (EMailPanedView *view);
-GalViewInstance *
-e_mail_paned_view_get_view_instance (EMailPanedView *view);
-void
-e_mail_paned_view_set_search_strings (EMailPanedView *view,
- GSList *search_strings);
-void
-e_mail_paned_view_set_show_deleted (EMailPanedView *view,
- gboolean show_deleted);
+GType e_mail_paned_view_get_type (void);
+void e_mail_paned_view_register_type (GTypeModule *type_module);
+GtkWidget * e_mail_paned_view_new (EShellContent *content);
+void e_mail_paned_view_hide_message_list_pane
+ (EMailPanedView *view,
+ gboolean visible);
+GtkWidget * e_mail_paned_view_get_preview (EMailPanedView *view);
-gboolean
-e_mail_paned_view_get_show_deleted (EMailPanedView *view);
-EShellSearchbar *
-e_mail_paned_view_get_searchbar (EMailPanedView *view);
-void
-e_mail_paned_view_set_preview_visible (EMailPanedView *view,
- gboolean preview_visible);
-gboolean
-e_mail_paned_view_get_preview_visible (EMailPanedView *view);
-void
-e_mail_paned_view_set_orientation (EMailPanedView *view,
- GtkOrientation orientation);
-GtkOrientation
-e_mail_paned_view_get_orientation (EMailPanedView *view);
-void
-e_mail_paned_view_hide_message_list_pane (EMailPanedView *view,
- gboolean visible);
-GtkWidget *
-e_mail_paned_view_get_preview (EMailPanedView *view);
+G_END_DECLS
-#endif
+#endif /* E_MAIL_PANED_VIEW_H */
diff --git a/mail/e-mail-reader.c b/mail/e-mail-reader.c
index 40622ea695..4c5b3fd039 100644
--- a/mail/e-mail-reader.c
+++ b/mail/e-mail-reader.c
@@ -53,7 +53,6 @@
#include "mail/mail-vfolder.h"
#include "mail/message-list.h"
-
#if HAVE_CLUTTER
#include <clutter/clutter.h>
#include <mx/mx.h>
@@ -682,7 +681,7 @@ action_mail_next_cb (GtkAction *action,
#if HAVE_CLUTTER
ClutterActor *actor;
#endif
-
+
direction = MESSAGE_LIST_SELECT_NEXT;
flags = 0;
mask = 0;
@@ -691,13 +690,12 @@ action_mail_next_cb (GtkAction *action,
#if HAVE_CLUTTER
actor = g_object_get_data ((GObject *)message_list, "preview-actor");
if (actor) {
- clutter_actor_set_opacity (actor, 0);
- clutter_actor_animate (actor, CLUTTER_EASE_OUT_SINE, 500,
- "opacity", 255,
- NULL);
+ clutter_actor_set_opacity (actor, 0);
+ clutter_actor_animate (
+ actor, CLUTTER_EASE_OUT_SINE,
+ 500, "opacity", 255, NULL);
}
-
-#endif
+#endif
message_list_select (
MESSAGE_LIST (message_list), direction, flags, mask);
}
@@ -887,7 +885,7 @@ action_mail_reply_all_check(CamelFolder *folder, const gchar *uid, CamelMimeMess
mode = REPLY_MODE_SENDER;
else if (response == GTK_RESPONSE_CANCEL)
return;
- }
+ }
e_mail_reader_reply_to_message (reader, message, mode);
}
@@ -966,7 +964,7 @@ action_mail_reply_sender_check(CamelFolder *folder, const gchar *uid, CamelMimeM
/* get_message_free() will unref the message, so we need to take an
extra ref for e_mail_reader_reply_to_message() to own. */
g_object_ref(message);
-
+
/* Don't do the "Are you sure you want to reply in private?" pop-up if
it's a Reply-To: munged list message... unless we're ignoring munging */
if (gconf_client_get_bool (gconf,
@@ -2190,13 +2188,12 @@ mail_reader_message_selected_timeout_cb (EMailReader *reader)
gboolean store_async;
MailMsgDispatchFunc disp_func;
-
string = g_strdup_printf (
_("Retrieving message '%s'"), cursor_uid);
#if HAVE_CLUTTER
if (!e_shell_get_express_mode(e_shell_get_default()))
- e_web_view_load_string (web_view, string);
-#else
+ e_web_view_load_string (web_view, string);
+#else
e_web_view_load_string (web_view, string);
#endif
g_free (string);
@@ -3037,7 +3034,7 @@ e_mail_reader_init_private (EMailReader *reader)
message_list = e_mail_reader_get_message_list (reader);
web_view = em_format_html_get_web_view (formatter);
-
+
quark_private = g_quark_from_static_string ("EMailReader-private");
/* Connect signals. */
@@ -3064,7 +3061,7 @@ e_mail_reader_init_private (EMailReader *reader)
g_signal_connect_swapped (
message_list, "selection-change",
- G_CALLBACK (e_mail_reader_changed), reader);
+ G_CALLBACK (e_mail_reader_changed), reader);
g_object_set_qdata_full (
G_OBJECT (reader), quark_private,
@@ -3457,17 +3454,17 @@ e_mail_reader_set_message (EMailReader *reader,
iface->set_message (reader, uid);
}
-void
+guint
e_mail_reader_open_selected_mail (EMailReader *reader)
{
EMailReaderIface *iface;
- g_return_if_fail (E_IS_MAIL_READER (reader));
+ g_return_val_if_fail (E_IS_MAIL_READER (reader), 0);
iface = E_MAIL_READER_GET_IFACE (reader);
- g_return_if_fail (iface->open_selected_mail != NULL);
+ g_return_val_if_fail (iface->open_selected_mail != NULL, 0);
- iface->open_selected_mail (reader);
+ return iface->open_selected_mail (reader);
}
gboolean
diff --git a/mail/e-mail-reader.h b/mail/e-mail-reader.h
index 911c2bdef5..842d3b0cb5 100644
--- a/mail/e-mail-reader.h
+++ b/mail/e-mail-reader.h
@@ -99,7 +99,7 @@ struct _EMailReaderIface {
const gchar *folder_uri);
void (*set_message) (EMailReader *reader,
const gchar *uid);
- void (*open_selected_mail) (EMailReader *reader);
+ guint (*open_selected_mail) (EMailReader *reader);
/* Signals */
void (*show_search_bar) (EMailReader *reader);
@@ -121,7 +121,7 @@ GtkActionGroup *
EMFormatHTML * e_mail_reader_get_formatter (EMailReader *reader);
gboolean e_mail_reader_get_hide_deleted (EMailReader *reader);
GtkWidget * e_mail_reader_get_message_list (EMailReader *reader);
-void e_mail_reader_open_selected_mail(EMailReader *reader);
+guint e_mail_reader_open_selected_mail(EMailReader *reader);
GtkMenu * e_mail_reader_get_popup_menu (EMailReader *reader);
GPtrArray * e_mail_reader_get_selected_uids (EMailReader *reader);
EShellBackend * e_mail_reader_get_shell_backend (EMailReader *reader);
diff --git a/mail/e-mail-tab-picker.c b/mail/e-mail-tab-picker.c
index 6e8f12f88b..5137a0c5ed 100644
--- a/mail/e-mail-tab-picker.c
+++ b/mail/e-mail-tab-picker.c
@@ -154,7 +154,7 @@ e_mail_tab_picker_drop (MxDroppable *droppable,
(tab->position + tab->width <= props->position) &&
!mx_draggable_is_enabled (MX_DRAGGABLE (props->tab)))
{
- new_position --;
+ new_position--;
break;
}
@@ -674,7 +674,7 @@ e_mail_tab_picker_allocate (ClutterActor *actor,
clutter_actor_get_preferred_width (actor, child_box.y2, NULL, &width);
- /* Fill out data - note it's ok to fill out docking here as when it
+ /* Fill out data - note it's ok to fill out docking here as when it
* changes, the tab queues a relayout.
*/
props->docking = e_mail_tab_get_docking (props->tab);
@@ -876,7 +876,7 @@ e_mail_tab_picker_scroll_event_cb (ClutterActor *actor,
e_mail_tab_picker_scroll_to (self, priv->scroll_end + 200, 150);
break;
}
-
+
return TRUE;
}
@@ -1021,12 +1021,12 @@ e_mail_tab_picker_add_tab (EMailTabPicker *picker, EMailTab *tab, gint position)
EMailTabPickerPrivate *priv = picker->priv;
if (priv->tabs && (priv->current_tab >= position))
- priv->current_tab ++;
+ priv->current_tab++;
props = g_slice_new (EMailTabPickerProps);
props->tab = tab;
priv->tabs = g_list_insert (priv->tabs, props, position);
- priv->n_tabs ++;
+ priv->n_tabs++;
clutter_actor_set_parent (CLUTTER_ACTOR (tab), CLUTTER_ACTOR (picker));
mx_draggable_set_axis (MX_DRAGGABLE (tab), MX_DRAG_AXIS_X);
@@ -1073,21 +1073,21 @@ e_mail_tab_picker_remove_tab (EMailTabPicker *picker, EMailTab *tab)
if (priv->current_tab)
{
if (priv->current_tab > position)
- priv->current_tab --;
+ priv->current_tab--;
else if (priv->current_tab == position)
e_mail_tab_picker_set_current_tab (picker, priv->current_tab - 1);
}
else if (priv->tabs->next && (position == 0))
{
e_mail_tab_picker_set_current_tab (picker, priv->current_tab + 1);
- priv->current_tab --;
+ priv->current_tab--;
}
}
g_slice_free (EMailTabPickerProps, tab_link->data);
priv->tabs = g_list_delete_link (priv->tabs, tab_link);
clutter_actor_unparent (CLUTTER_ACTOR (tab));
- priv->n_tabs --;
+ priv->n_tabs--;
clutter_actor_queue_relayout (CLUTTER_ACTOR (picker));
}
@@ -1096,9 +1096,9 @@ GList *
e_mail_tab_picker_get_tabs (EMailTabPicker *picker)
{
GList *tab_list, *t;
-
+
EMailTabPickerPrivate *priv = picker->priv;
-
+
tab_list = NULL;
for (t = g_list_last (priv->tabs); t; t = t->prev)
{
@@ -1184,10 +1184,10 @@ e_mail_tab_picker_reorder (EMailTabPicker *picker,
}
else if ((priv->current_tab > old_position) &&
(new_position >= priv->current_tab))
- priv->current_tab --;
+ priv->current_tab--;
else if ((priv->current_tab < old_position) &&
(new_position <= priv->current_tab))
- priv->current_tab ++;
+ priv->current_tab++;
clutter_actor_queue_relayout (CLUTTER_ACTOR (picker));
}
diff --git a/mail/e-mail-tab-picker.h b/mail/e-mail-tab-picker.h
index 7de3facc9d..0ee2c68fb1 100644
--- a/mail/e-mail-tab-picker.h
+++ b/mail/e-mail-tab-picker.h
@@ -16,7 +16,6 @@
* Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
*/
-
#ifndef _E_MAIL_TAB_PICKER_H
#define _E_MAIL_TAB_PICKER_H
diff --git a/mail/e-mail-tab.c b/mail/e-mail-tab.c
index 125f174775..d5909ce1cb 100644
--- a/mail/e-mail-tab.c
+++ b/mail/e-mail-tab.c
@@ -663,7 +663,7 @@ e_mail_tab_get_preferred_height (ClutterActor *actor,
padding.top + padding.bottom + priv->spacing +
label_nat_height;
- /* Sometimes the preview's natural height will be nan due to
+ /* Sometimes the preview's natural height will be nan due to
* keeping of the aspect ratio. This guards against that and stops
* Clutter from warning that the natural height is less than the
* minimum height.
@@ -1853,7 +1853,7 @@ e_mail_tab_alert_cb (EMailTab *tab)
name = (priv->private ^ (priv->alert_count % 2)) ? NULL : "private-tab";
if (!priv->preview_mode)
clutter_actor_set_name (CLUTTER_ACTOR (tab), name);
- priv->alert_count ++;
+ priv->alert_count++;
if (priv->alert_count < 4)
return TRUE;
diff --git a/mail/e-mail-tab.h b/mail/e-mail-tab.h
index 3966d2752c..55d69b8ba7 100644
--- a/mail/e-mail-tab.h
+++ b/mail/e-mail-tab.h
@@ -1,5 +1,5 @@
/*
- * Borrowed from Moblin-Web-Browser: The web browser for Moblin
+ * Borrowed from Moblin-Web-Browser: The web browser for Moblin
* Copyright (c) 2009, Intel Corporation.
*
* This program is free software; you can redistribute it and/or modify it
diff --git a/mail/e-mail-view.c b/mail/e-mail-view.c
index a4318ce7bf..a3a642ab7f 100644
--- a/mail/e-mail-view.c
+++ b/mail/e-mail-view.c
@@ -10,7 +10,7 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
- * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
*
*
* Authors:
@@ -24,13 +24,17 @@
# include <config.h>
#endif
-
-#include <glib.h>
-#include <glib/gi18n.h>
#include "e-mail-view.h"
+#include <glib/gi18n-lib.h>
-G_DEFINE_TYPE (EMailView, e_mail_view, GTK_TYPE_VBOX)
+#define E_MAIL_VIEW_GET_PRIVATE(obj) \
+ (G_TYPE_INSTANCE_GET_PRIVATE \
+ ((obj), E_TYPE_MAIL_VIEW, EMailViewPrivate))
+
+struct _EMailViewPrivate {
+ gint placeholder;
+};
enum {
PANE_CLOSE,
@@ -44,36 +48,20 @@ enum {
PROP_SHELL_VIEW
};
-struct _EMailViewPrivate {
-};
-
-static guint signals[LAST_SIGNAL] = { 0 };
-
-static void
-e_mail_view_init (EMailView *shell)
-{
- shell->priv = g_new0(EMailViewPrivate, 1);
- shell->prev = NULL;
-}
-
-static void
-e_mail_view_finalize (GObject *object)
-{
- /* EMailView *shell = (EMailView *)object; */
+static guint signals[LAST_SIGNAL];
- G_OBJECT_CLASS (e_mail_view_parent_class)->finalize (object);
-}
+G_DEFINE_TYPE (EMailView, e_mail_view, GTK_TYPE_VBOX)
static void
mail_view_set_property (GObject *object,
- guint property_id,
- const GValue *value,
- GParamSpec *pspec)
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec)
{
switch (property_id) {
case PROP_SHELL_VIEW:
- E_MAIL_VIEW(object)->content = g_value_get_object (value);
-
+ E_MAIL_VIEW(object)->content =
+ g_value_get_object (value);
return;
}
@@ -82,15 +70,14 @@ mail_view_set_property (GObject *object,
static void
mail_view_get_property (GObject *object,
- guint property_id,
- GValue *value,
- GParamSpec *pspec)
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec)
{
switch (property_id) {
case PROP_SHELL_VIEW:
g_value_set_object (
- value, E_MAIL_VIEW(object)->content);
-
+ value, E_MAIL_VIEW(object)->content);
return;
}
@@ -98,52 +85,43 @@ mail_view_get_property (GObject *object,
}
static void
-e_mail_view_class_init (EMailViewClass *klass)
+e_mail_view_class_init (EMailViewClass *class)
{
- GObjectClass * object_class = G_OBJECT_CLASS (klass);
+ GObjectClass *object_class;
- e_mail_view_parent_class = g_type_class_peek_parent (klass);
- object_class->finalize = e_mail_view_finalize;
+ g_type_class_add_private (class, sizeof (EMailViewPrivate));
+
+ object_class = G_OBJECT_CLASS (class);
object_class->set_property = mail_view_set_property;
object_class->get_property = mail_view_get_property;
- klass->get_searchbar = NULL;
- klass->set_search_strings = NULL;
- klass->get_view_instance = NULL;
- klass->update_view_instance = NULL;
- klass->set_orientation = NULL;
- klass->get_orientation = NULL;
- klass->set_show_deleted = NULL;
- klass->get_show_deleted = NULL;
- klass->set_preview_visible = NULL;
- klass->get_preview_visible = NULL;
-
- signals[PANE_CLOSE] =
- g_signal_new ("pane-close",
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (EMailViewClass , pane_close),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE, 0);
-
- signals[VIEW_CHANGED] =
- g_signal_new ("view-changed",
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (EMailViewClass , view_changed),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE, 0);
-
- signals[OPEN_MAIL] =
- g_signal_new ("open-mail",
- G_OBJECT_CLASS_TYPE (object_class),
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (EMailViewClass , open_mail),
- NULL, NULL,
- g_cclosure_marshal_VOID__STRING,
- G_TYPE_NONE, 1, G_TYPE_STRING);
+ signals[PANE_CLOSE] = g_signal_new (
+ "pane-close",
+ G_OBJECT_CLASS_TYPE (object_class),
+ G_SIGNAL_RUN_FIRST,
+ G_STRUCT_OFFSET (EMailViewClass , pane_close),
+ NULL, NULL,
+ g_cclosure_marshal_VOID__VOID,
+ G_TYPE_NONE, 0);
+
+ signals[VIEW_CHANGED] = g_signal_new (
+ "view-changed",
+ G_OBJECT_CLASS_TYPE (object_class),
+ G_SIGNAL_RUN_FIRST,
+ G_STRUCT_OFFSET (EMailViewClass , view_changed),
+ NULL, NULL,
+ g_cclosure_marshal_VOID__VOID,
+ G_TYPE_NONE, 0);
+
+ signals[OPEN_MAIL] = g_signal_new (
+ "open-mail",
+ G_OBJECT_CLASS_TYPE (object_class),
+ G_SIGNAL_RUN_FIRST,
+ G_STRUCT_OFFSET (EMailViewClass , open_mail),
+ NULL, NULL,
+ g_cclosure_marshal_VOID__STRING,
+ G_TYPE_NONE, 1, G_TYPE_STRING);
+
/**
* EMailView:shell-content
*
@@ -159,66 +137,144 @@ e_mail_view_class_init (EMailViewClass *klass)
E_TYPE_SHELL_CONTENT,
G_PARAM_READWRITE |
G_PARAM_CONSTRUCT_ONLY));
+}
+static void
+e_mail_view_init (EMailView *view)
+{
+ view->priv = E_MAIL_VIEW_GET_PRIVATE (view);
}
void
e_mail_view_update_view_instance (EMailView *view)
{
- E_MAIL_VIEW_GET_CLASS (view)->update_view_instance (view);
+ EMailViewClass *class;
+
+ g_return_if_fail (E_IS_MAIL_VIEW (view));
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_if_fail (class->update_view_instance != NULL);
+
+ class->update_view_instance (view);
}
GalViewInstance *
e_mail_view_get_view_instance (EMailView *view)
{
- return E_MAIL_VIEW_GET_CLASS (view)->get_view_instance (view);
+ EMailViewClass *class;
+
+ g_return_val_if_fail (E_IS_MAIL_VIEW (view), NULL);
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_val_if_fail (class->get_view_instance != NULL, NULL);
+
+ return class->get_view_instance (view);
}
void
e_mail_view_set_search_strings (EMailView *view,
- GSList *search_strings)
+ GSList *search_strings)
{
- E_MAIL_VIEW_GET_CLASS (view)->set_search_strings (view, search_strings);
+ EMailViewClass *class;
+
+ g_return_if_fail (E_IS_MAIL_VIEW (view));
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_if_fail (class->set_search_strings != NULL);
+
+ class->set_search_strings (view, search_strings);
}
EShellSearchbar *
e_mail_view_get_searchbar (EMailView *view)
{
- return E_MAIL_VIEW_GET_CLASS (view)->get_searchbar (view);
+ EMailViewClass *class;
+
+ g_return_val_if_fail (E_IS_MAIL_VIEW (view), NULL);
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_val_if_fail (class->get_searchbar != NULL, NULL);
+
+ return class->get_searchbar (view);
}
-void
-e_mail_view_set_orientation (EMailView *view, GtkOrientation orientation)
+void
+e_mail_view_set_orientation (EMailView *view,
+ GtkOrientation orientation)
{
- E_MAIL_VIEW_GET_CLASS (view)->set_orientation (view, orientation);
+ EMailViewClass *class;
+
+ g_return_if_fail (E_IS_MAIL_VIEW (view));
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_if_fail (class->set_orientation != NULL);
+
+ class->set_orientation (view, orientation);
}
-GtkOrientation
+GtkOrientation
e_mail_view_get_orientation (EMailView *view)
{
- return E_MAIL_VIEW_GET_CLASS (view)->get_orientation (view);
+ EMailViewClass *class;
+
+ g_return_val_if_fail (E_IS_MAIL_VIEW (view), 0);
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_val_if_fail (class->get_orientation != NULL, 0);
+
+ return class->get_orientation (view);
}
-void
-e_mail_view_set_preview_visible (EMailView *view, gboolean visible)
+void
+e_mail_view_set_preview_visible (EMailView *view,
+ gboolean visible)
{
- E_MAIL_VIEW_GET_CLASS (view)->set_preview_visible (view, visible);
+ EMailViewClass *class;
+
+ g_return_if_fail (E_IS_MAIL_VIEW (view));
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_if_fail (class->set_preview_visible != NULL);
+
+ class->set_preview_visible (view, visible);
}
-gboolean
+gboolean
e_mail_view_get_preview_visible (EMailView *view)
{
- return E_MAIL_VIEW_GET_CLASS (view)->get_preview_visible (view);
+ EMailViewClass *class;
+
+ g_return_val_if_fail (E_IS_MAIL_VIEW (view), FALSE);
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_val_if_fail (class->get_preview_visible != NULL, FALSE);
+
+ return class->get_preview_visible (view);
}
-void
-e_mail_view_set_show_deleted (EMailView *view, gboolean show_deleted)
+void
+e_mail_view_set_show_deleted (EMailView *view,
+ gboolean show_deleted)
{
- E_MAIL_VIEW_GET_CLASS (view)->set_show_deleted (view, show_deleted);
+ EMailViewClass *class;
+
+ g_return_if_fail (E_IS_MAIL_VIEW (view));
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_if_fail (class->set_show_deleted != NULL);
+
+ class->set_show_deleted (view, show_deleted);
}
-gboolean
+gboolean
e_mail_view_get_show_deleted (EMailView *view)
{
- return E_MAIL_VIEW_GET_CLASS (view)->get_show_deleted (view);
+ EMailViewClass *class;
+
+ g_return_val_if_fail (E_IS_MAIL_VIEW (view), FALSE);
+
+ class = E_MAIL_VIEW_GET_CLASS (view);
+ g_return_val_if_fail (class->get_show_deleted != NULL, FALSE);
+
+ return class->get_show_deleted (view);
}
diff --git a/mail/e-mail-view.h b/mail/e-mail-view.h
index d5b3ded6a7..5c6e6a42b2 100644
--- a/mail/e-mail-view.h
+++ b/mail/e-mail-view.h
@@ -10,7 +10,7 @@
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
- * License along with the program; if not, see <http://www.gnu.org/licenses/>
+ * License along with the program; if not, see <http://www.gnu.org/licenses/>
*
*
* Authors:
@@ -23,63 +23,87 @@
#ifndef _E_MAIL_VIEW_H_
#define _E_MAIL_VIEW_H_
-#include <gtk/gtk.h>
#include <shell/e-shell-content.h>
#include <shell/e-shell-searchbar.h>
#include "widgets/menus/gal-view-instance.h"
-#define E_MAIL_VIEW_TYPE (e_mail_view_get_type ())
-#define E_MAIL_VIEW(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), E_MAIL_VIEW_TYPE, EMailView))
-#define E_MAIL_VIEW_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), E_MAIL_VIEW_TYPE, EMailViewClass))
-#define IS_E_MAIL_VIEW(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), E_MAIL_VIEW_TYPE))
-#define IS_E_MAIL_VIEW_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), E_MAIL_VIEW_TYPE))
-#define E_MAIL_VIEW_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), E_MAIL_VIEW_TYPE, EMailViewClass))
-
-
+/* Standard GObject macros */
+#define E_TYPE_MAIL_VIEW \
+ (e_mail_view_get_type ())
+#define E_MAIL_VIEW(obj) \
+ (G_TYPE_CHECK_INSTANCE_CAST \
+ ((obj), E_TYPE_MAIL_VIEW, EMailView))
+#define E_MAIL_VIEW_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_CAST \
+ ((cls), E_TYPE_MAIL_VIEW, EMailViewClass))
+#define E_IS_MAIL_VIEW(obj) \
+ (G_TYPE_CHECK_INSTANCE_TYPE \
+ ((obj), E_TYPE_MAIL_VIEW))
+#define E_IS_MAIL_VIEW_CLASS(cls) \
+ (G_TYPE_CHECK_CLASS_TYPE \
+ ((cls), E_TYPE_MAIL_VIEW))
+#define E_MAIL_VIEW_GET_CLASS(obj) \
+ (G_TYPE_INSTANCE_GET_CLASS \
+ ((obj), E_TYPE_MAIL_VIEW, EMailViewClass))
+
+G_BEGIN_DECLS
+
+typedef struct _EMailView EMailView;
+typedef struct _EMailViewClass EMailViewClass;
typedef struct _EMailViewPrivate EMailViewPrivate;
-typedef struct _EMailView {
+struct _EMailView {
GtkVBox parent;
EMailViewPrivate *priv;
EShellContent *content;
- struct _EMailView *prev;
-} EMailView;
+ EMailView *prev;
+};
-typedef struct _EMailViewClass {
+struct _EMailViewClass {
GtkVBoxClass parent_class;
- void (*pane_close) (EMailView *);
- void (*view_changed) (EMailView *);
- void (*open_mail) (EMailView *, const char *);
-
- EShellSearchbar * (*get_searchbar) (EMailView *view);
- void (*set_search_strings) (EMailView *view, GSList *search_strings);
- GalViewInstance * (*get_view_instance) (EMailView *view);
- void (*update_view_instance) (EMailView *view);
- void (*set_orientation) (EMailView *view, GtkOrientation orientation);
- GtkOrientation (*get_orientation) (EMailView *);
- void (*set_preview_visible) (EMailView *view, gboolean visible);
- gboolean (*get_preview_visible) (EMailView *view);
- void (*set_show_deleted) (EMailView *view, gboolean show_deleted);
- gboolean (*get_show_deleted) (EMailView *view);
-
-} EMailViewClass;
-
-GType e_mail_view_get_type (void);
-
-void e_mail_view_update_view_instance (EMailView *view);
-GalViewInstance * e_mail_view_get_view_instance (EMailView *view);
-
-void e_mail_view_set_search_strings (EMailView *view, GSList *search_strings);
-
-void e_mail_view_set_orientation (EMailView *view, GtkOrientation orientation);
-GtkOrientation e_mail_view_get_orientation (EMailView *);
-void e_mail_view_set_preview_visible (EMailView *view, gboolean visible);
-gboolean e_mail_view_get_preview_visible (EMailView *view);
-void e_mail_view_set_show_deleted (EMailView *view, gboolean show_deleted);
-gboolean e_mail_view_get_show_deleted (EMailView *view);
-
-EShellSearchbar * e_mail_view_get_searchbar (EMailView *view);
-
-#endif
+ void (*pane_close) (EMailView *view);
+ void (*view_changed) (EMailView *view);
+ void (*open_mail) (EMailView *view,
+ const gchar *);
+
+ EShellSearchbar *
+ (*get_searchbar) (EMailView *view);
+ void (*set_search_strings) (EMailView *view,
+ GSList *search_strings);
+ GalViewInstance *
+ (*get_view_instance) (EMailView *view);
+ void (*update_view_instance) (EMailView *view);
+ void (*set_orientation) (EMailView *view,
+ GtkOrientation orientation);
+ GtkOrientation (*get_orientation) (EMailView *view);
+ void (*set_preview_visible) (EMailView *view,
+ gboolean visible);
+ gboolean (*get_preview_visible) (EMailView *view);
+ void (*set_show_deleted) (EMailView *view,
+ gboolean show_deleted);
+ gboolean (*get_show_deleted) (EMailView *view);
+};
+
+GType e_mail_view_get_type (void);
+void e_mail_view_update_view_instance(EMailView *view);
+GalViewInstance *
+ e_mail_view_get_view_instance (EMailView *view);
+void e_mail_view_set_search_strings (EMailView *view,
+ GSList *search_strings);
+void e_mail_view_set_orientation (EMailView *view,
+ GtkOrientation orientation);
+GtkOrientation e_mail_view_get_orientation (EMailView *);
+void e_mail_view_set_preview_visible (EMailView *view,
+ gboolean visible);
+gboolean e_mail_view_get_preview_visible (EMailView *view);
+void e_mail_view_set_show_deleted (EMailView *view,
+ gboolean show_deleted);
+gboolean e_mail_view_get_show_deleted (EMailView *view);
+EShellSearchbar *
+ e_mail_view_get_searchbar (EMailView *view);
+
+G_END_DECLS
+
+#endif /* E_MAIL_VIEW_H */
diff --git a/mail/em-format-html.c b/mail/em-format-html.c
index 95e1572e7c..302d5afc67 100644
--- a/mail/em-format-html.c
+++ b/mail/em-format-html.c
@@ -344,10 +344,10 @@ efh_format_timeout(struct _format_msg *m)
} else {
efh->state = EM_FORMAT_HTML_STATE_RENDERING;
#if HAVE_CLUTTER
- if (p->last_part != m->message && !e_shell_get_express_mode(e_shell_get_default())) {
-#else
+ if (p->last_part != m->message && !e_shell_get_express_mode(e_shell_get_default())) {
+#else
if (p->last_part != m->message) {
-#endif
+#endif
hstream = gtk_html_begin (GTK_HTML (web_view));
gtk_html_stream_printf (hstream, "<h5>%s</h5>", _("Formatting Message..."));
gtk_html_stream_close (hstream, GTK_HTML_STREAM_OK);
diff --git a/mail/message-list.c b/mail/message-list.c
index 96d2a68cbe..0a2a5d446d 100644
--- a/mail/message-list.c
+++ b/mail/message-list.c
@@ -2382,7 +2382,7 @@ message_list_init (MessageList *message_list)
message_list->priv->timeline = NULL;
message_list->priv->search_texture = NULL;
#endif
-
+
message_list->normalised_hash = g_hash_table_new_full (
g_str_hash, g_str_equal,
(GDestroyNotify) NULL,
@@ -4137,10 +4137,10 @@ on_timeline_stopped (ClutterTimeline *timeline, ClutterActor *actor)
void
message_list_set_search (MessageList *ml, const gchar *search)
{
-#if HAVE_CLUTTER
+#if HAVE_CLUTTER
if (ml->priv->timeline == NULL) {
ClutterActor *stage = g_object_get_data ((GObject *)ml, "stage");
-
+
if (stage) {
ClutterActor *texture = NULL;
ClutterPath *path;
@@ -4152,7 +4152,7 @@ message_list_set_search (MessageList *ml, const gchar *search)
"system-search",
72,
GTK_ICON_LOOKUP_NO_SVG);
-
+
if (info) {
texture = clutter_texture_new_from_file (gtk_icon_info_get_filename(info), NULL);
gtk_icon_info_free(info);
@@ -4174,18 +4174,18 @@ message_list_set_search (MessageList *ml, const gchar *search)
clutter_behaviour_apply (behaviour, texture);
clutter_timeline_set_loop (ml->priv->timeline, TRUE);
-
+
g_signal_connect(ml->priv->timeline, "started", G_CALLBACK(on_timeline_started), texture);
g_signal_connect(ml->priv->timeline, "paused", G_CALLBACK(on_timeline_stopped), texture);
//g_signal_connect(ml->priv->timeline, "completed", G_CALLBACK(on_timeline_stopped), texture);
-
- clutter_timeline_pause (ml->priv->timeline);
+
+ clutter_timeline_pause (ml->priv->timeline);
clutter_timeline_stop (ml->priv->timeline);
}
}
#endif
-
+
if (search == NULL || search[0] == '\0')
if (ml->search == NULL || ml->search[0] == '\0')
return;
@@ -4658,15 +4658,15 @@ regen_list_done (struct _regen_list_msg *m)
clutter_timeline_stop (m->ml->priv->timeline);
} else {
ClutterActor *pane = g_object_get_data ((GObject *)m->ml, "actor");
-
+
if (pane) {
- clutter_actor_set_opacity (pane, 0);
- clutter_actor_animate (pane, CLUTTER_EASE_OUT_SINE, 150,
- "opacity", 255,
- NULL);
+ clutter_actor_set_opacity (pane, 0);
+ clutter_actor_animate (
+ pane, CLUTTER_EASE_OUT_SINE,
+ 150, "opacity", 255, NULL);
}
}
-#endif
+#endif
}
static void