[evolution/tabs-rewrite-v1] Make clutter mode even more appealing.
- From: Srinivasa Ragavan <sragavan src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution/tabs-rewrite-v1] Make clutter mode even more appealing.
- Date: Tue, 20 Jul 2010 15:38:11 +0000 (UTC)
commit 8ab1acb7b16ad4e3593d59ae188dc3d7cb91c2e5
Author: Srinivasa Ragavan <sragavan gnome org>
Date: Tue Jul 20 20:55:16 2010 +0530
Make clutter mode even more appealing.
mail/e-mail-notebook-view.c | 39 ++++++++++++---------------------------
mail/e-mail-paned-view.c | 20 +-------------------
mail/e-mail-reader.c | 29 +++++++++++++++++++++++++++--
mail/em-format-html.c | 7 ++++++-
mail/message-list.c | 7 ++++---
5 files changed, 50 insertions(+), 52 deletions(-)
---
diff --git a/mail/e-mail-notebook-view.c b/mail/e-mail-notebook-view.c
index 34ebd1d..d5f3109 100644
--- a/mail/e-mail-notebook-view.c
+++ b/mail/e-mail-notebook-view.c
@@ -71,37 +71,18 @@ static EMailViewClass *parent_class;
static GType mail_notebook_view_type;
#if HAVE_CLUTTER
-struct _anim_data {
- EMailNotebookView *view;
- int page;
-};
-
-static void
-start_tab_switch_cb (ClutterAnimation *animation,
- struct _anim_data *data)
-{
- gtk_notebook_set_current_page (data->view->priv->book, data->page);
- animation = clutter_actor_animate ((ClutterActor *)data->view->priv->actor, CLUTTER_EASE_IN_SINE, 150,
- "opacity", 255,
- NULL);
-
-}
-
-
static void
mnv_set_current_tab (EMailNotebookView *view,
int page)
{
ClutterAnimation *animation;
- struct _anim_data *data = g_new0 (struct _anim_data, 1);
-
- data->view = view;
- data->page = page;
- animation = clutter_actor_animate ((ClutterActor *)view->priv->actor, CLUTTER_EASE_OUT_SINE, 150,
- "opacity", 0,
+ 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);
- g_signal_connect_after (animation, "completed", G_CALLBACK(start_tab_switch_cb), data);
+
}
#endif
@@ -153,7 +134,6 @@ mnv_page_changed (GtkNotebook *book, GtkNotebookPage *page,
EMFolderTree *tree;
const char *uri = e_mail_reader_get_folder_uri (E_MAIL_READER(mview));
-
g_object_get (sidebar, "folder-tree", &tree, NULL);
if (uri)
em_folder_tree_set_selected (tree, uri, FALSE);
@@ -744,6 +724,7 @@ mail_netbook_view_open_mail (EMailView *view, const char *uid, EMailNotebookView
EMailTab *tab;
ClutterActor *clone;
ClutterTimeline *timeline;
+ GtkWidget *mlist;
e_mail_tab_set_active (e_mail_tab_picker_get_tab (priv->tab_picker,
e_mail_tab_picker_get_current_tab (priv->tab_picker)),
@@ -766,10 +747,11 @@ mail_netbook_view_open_mail (EMailView *view, const char *uid, EMailNotebookView
camel_message_info_subject(info)));
#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 *)preview, "stage", priv->stage);
- g_object_set_data ((GObject *)preview, "actor", priv->actor);
+ 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
@@ -838,6 +820,9 @@ 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 (curr == e_mail_tab_picker_get_current_tab (priv->tab_picker))
+ return;
#if HAVE_CLUTTER
EMailTab *tab;
diff --git a/mail/e-mail-paned-view.c b/mail/e-mail-paned-view.c
index 57f0c00..6733e40 100644
--- a/mail/e-mail-paned-view.c
+++ b/mail/e-mail-paned-view.c
@@ -48,12 +48,6 @@
#include "message-list.h"
#include "e-mail-reader-utils.h"
-#if HAVE_CLUTTER
-#include <clutter/clutter.h>
-#include <mx/mx.h>
-#include <clutter-gtk/clutter-gtk.h>
-#endif
-
#define E_SHELL_WINDOW_ACTION_GROUP_MAIL(window) \
E_SHELL_WINDOW_ACTION_GROUP ((window), "mail")
@@ -184,9 +178,7 @@ mail_paned_view_message_selected_cb (EMailPanedView *view,
const gchar *folder_uri;
const gchar *key;
gchar *group_name;
-#if HAVE_CLUTTER
- ClutterActor *actor = g_object_get_data ((GObject *)view->priv->preview, "actor");
-#endif
+
folder_uri = message_list->folder_uri;
/* This also gets triggered when selecting a store name on
@@ -210,16 +202,6 @@ mail_paned_view_message_selected_cb (EMailPanedView *view,
g_free (group_name);
-#if HAVE_CLUTTER
- if (actor) {
- clutter_actor_set_opacity (actor, 0);
- clutter_actor_animate (actor, CLUTTER_EASE_OUT_SINE, 150,
- "opacity", 255,
- NULL);
- }
-
-#endif
-
}
static void
diff --git a/mail/e-mail-reader.c b/mail/e-mail-reader.c
index 4395d78..40622ea 100644
--- a/mail/e-mail-reader.c
+++ b/mail/e-mail-reader.c
@@ -53,6 +53,13 @@
#include "mail/mail-vfolder.h"
#include "mail/message-list.h"
+
+#if HAVE_CLUTTER
+#include <clutter/clutter.h>
+#include <mx/mx.h>
+#include <clutter-gtk/clutter-gtk.h>
+#endif
+
#define E_MAIL_READER_GET_PRIVATE(obj) \
((EMailReaderPrivate *) g_object_get_qdata \
(G_OBJECT (obj), quark_private))
@@ -124,7 +131,7 @@ action_mail_add_sender_cb (GtkAction *action,
{
EShell *shell;
EShellBackend *shell_backend;
- CamelMessageInfo *info;
+ CamelMessageInfo *info = NULL;
CamelFolder *folder;
GPtrArray *uids;
const gchar *address;
@@ -672,13 +679,25 @@ action_mail_next_cb (GtkAction *action,
GtkWidget *message_list;
MessageListSelectDirection direction;
guint32 flags, mask;
-
+#if HAVE_CLUTTER
+ ClutterActor *actor;
+#endif
+
direction = MESSAGE_LIST_SELECT_NEXT;
flags = 0;
mask = 0;
message_list = e_mail_reader_get_message_list (reader);
+#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);
+ }
+#endif
message_list_select (
MESSAGE_LIST (message_list), direction, flags, mask);
}
@@ -2171,9 +2190,15 @@ 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);
+#endif
g_free (string);
store_async = parent_store->flags & CAMEL_STORE_ASYNC;
diff --git a/mail/em-format-html.c b/mail/em-format-html.c
index 361f754..95e1572 100644
--- a/mail/em-format-html.c
+++ b/mail/em-format-html.c
@@ -50,6 +50,8 @@
#include "e-util/e-extensible.h"
#include "misc/e-web-view.h"
+#include "shell/e-shell.h"
+
#include <gtkhtml/gtkhtml.h>
#include <gtkhtml/gtkhtml-stream.h>
@@ -341,8 +343,11 @@ efh_format_timeout(struct _format_msg *m)
p->last_part = NULL;
} 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) {
+#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 f19754a..96d2a68 100644
--- a/mail/message-list.c
+++ b/mail/message-list.c
@@ -4198,8 +4198,9 @@ message_list_set_search (MessageList *ml, const gchar *search)
ml->thread_tree = NULL;
}
-#if HAVE_CLUTTER
- clutter_timeline_start (ml->priv->timeline);
+#if HAVE_CLUTTER
+ if (ml->priv->timeline)
+ clutter_timeline_start (ml->priv->timeline);
#endif
if (ml->frozen == 0)
@@ -4653,7 +4654,7 @@ regen_list_done (struct _regen_list_msg *m)
m->ml->priv->any_row_changed = FALSE;
#if HAVE_CLUTTER
- if (clutter_timeline_is_playing(m->ml->priv->timeline)) {
+ if (m->ml->priv->timeline && clutter_timeline_is_playing(m->ml->priv->timeline)) {
clutter_timeline_stop (m->ml->priv->timeline);
} else {
ClutterActor *pane = g_object_get_data ((GObject *)m->ml, "actor");
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]