[evolution/webkit: 99/177] Port context menu for mail-links in EMailDisplay
- From: Dan VrÃtil <dvratil src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution/webkit: 99/177] Port context menu for mail-links in EMailDisplay
- Date: Fri, 2 Mar 2012 11:37:57 +0000 (UTC)
commit 290f6fdffcc013a2119e46a7421cf4a0a54ac78a
Author: Dan VrÃtil <dvratil redhat com>
Date: Thu Jan 5 16:48:36 2012 +0100
Port context menu for mail-links in EMailDisplay
mail/e-mail-display.c | 40 +++++++++++++++++++++++-----------------
mail/e-mail-display.h | 3 +++
mail/e-mail-reader.c | 20 +++++++++++---------
3 files changed, 37 insertions(+), 26 deletions(-)
---
diff --git a/mail/e-mail-display.c b/mail/e-mail-display.c
index 2502704..bd469b5 100644
--- a/mail/e-mail-display.c
+++ b/mail/e-mail-display.c
@@ -64,6 +64,8 @@ struct _EMailDisplayPrivate {
GList *webviews;
GtkWidget *current_webview;
+
+ GtkActionGroup *actions;
};
enum {
@@ -101,7 +103,6 @@ static const gchar *ui =
" <menuitem action='search-folder-sender'/>"
" </menu>"
" </placeholder>"
-" <placeholder name='inspect' />"
" </popup>"
"</ui>";
@@ -370,7 +371,7 @@ mail_display_process_mailto (EWebView *web_view,
CamelFolder *folder = NULL;
EShell *shell;
- priv = E_MAIL_DISPLAY_GET_PRIVATE (web_view);
+ priv = E_MAIL_DISPLAY_GET_PRIVATE (display);
g_return_val_if_fail (priv->formatter != NULL, FALSE);
format = EM_FORMAT (priv->formatter);
@@ -609,10 +610,7 @@ mail_display_setup_webview (EMailDisplay *display,
EWebView *web_view;
WebKitWebSettings *settings;
GtkUIManager *ui_manager;
- GtkActionGroup *action_group;
GError *error = NULL;
- guint merge_id;
- EMailImageLoadingPolicy policy;
web_view = E_WEB_VIEW (e_web_view_new ());
@@ -642,24 +640,18 @@ mail_display_setup_webview (EMailDisplay *display,
else
g_object_set (G_OBJECT (settings), "auto-load-images", FALSE, NULL);
- /* EWebView's action groups are added during its instance
- * initialization function (like what we're in now), so it
- * is safe to fetch them this early in construction. */
- action_group = e_web_view_get_action_group (web_view, "mailto");
-
- /* We don't actually handle the actions we're adding.
- * EMailReader handles them. How devious is that? */
- gtk_action_group_add_actions (
- action_group, mailto_entries,
- G_N_ELEMENTS (mailto_entries), web_view);
/* Because we are loading from a hard-coded string, there is
* no chance of I/O errors. Failure here implies a malformed
* UI definition. Full stop. */
ui_manager = e_web_view_get_ui_manager (web_view);
+ gtk_ui_manager_insert_action_group (ui_manager, display->priv->actions, 0);
gtk_ui_manager_add_ui_from_string (ui_manager, ui, -1, &error);
- if (error != NULL)
+
+ if (error != NULL) {
g_error ("%s", error->message);
+ g_error_free (error);
+ }
return web_view;
}
@@ -1012,8 +1004,12 @@ mail_display_init (EMailDisplay *display)
display->priv->webviews = NULL;
- /* WEBKIT TODO: ESearchBar */
+ display->priv->actions = gtk_action_group_new ("mailto");
+ gtk_action_group_add_actions (display->priv->actions, mailto_entries,
+ G_N_ELEMENTS (mailto_entries), NULL);
+
+ /* WEBKIT TODO: ESearchBar */
/* Register our own handler for our own mail:// protocol */
session = webkit_get_default_session ();
@@ -1242,6 +1238,16 @@ e_mail_display_get_current_web_view (EMailDisplay *display)
return E_WEB_VIEW (display->priv->current_webview);
}
+GtkAction*
+e_mail_display_get_action (EMailDisplay *display,
+ const gchar *action_name)
+{
+ g_return_val_if_fail (E_IS_MAIL_DISPLAY (display), NULL);
+ g_return_val_if_fail (action_name != NULL, NULL);
+
+ return gtk_action_group_get_action (display->priv->actions, action_name);
+}
+
void
e_mail_display_set_status (EMailDisplay *display,
const gchar *status)
diff --git a/mail/e-mail-display.h b/mail/e-mail-display.h
index 2cbbb40..82bf5b7 100644
--- a/mail/e-mail-display.h
+++ b/mail/e-mail-display.h
@@ -93,6 +93,9 @@ void e_mail_display_reload (EMailDisplay *display);
EWebView * e_mail_display_get_current_web_view
(EMailDisplay *display);
+GtkAction * e_mail_display_get_action (EMailDisplay *display,
+ const gchar *action_name);
+
void e_mail_display_set_status (EMailDisplay *display,
const gchar *status);
void e_mail_display_clear (EMailDisplay *display);
diff --git a/mail/e-mail-reader.c b/mail/e-mail-reader.c
index 3dd98e8..27f6a7b 100644
--- a/mail/e-mail-reader.c
+++ b/mail/e-mail-reader.c
@@ -205,7 +205,7 @@ action_add_to_address_book_cb (GtkAction *action,
EShellBackend *shell_backend;
EMailDisplay *display;
CamelInternetAddress *cia;
- GtkWidget *web_view;
+ EWebView *web_view;
CamelURL *curl;
const gchar *uri;
gchar *email;
@@ -215,11 +215,11 @@ action_add_to_address_book_cb (GtkAction *action,
backend = e_mail_reader_get_backend (reader);
display = e_mail_reader_get_mail_display (reader);
- web_view = gtk_container_get_focus_child (GTK_CONTAINER (display));
+ web_view = e_mail_display_get_current_web_view (display);
if (!E_IS_WEB_VIEW (web_view))
return;
- uri = e_web_view_get_selected_uri (E_WEB_VIEW (web_view));
+ uri = e_web_view_get_selected_uri (web_view);
g_return_if_fail (uri != NULL);
curl = camel_url_new (uri, NULL);
@@ -3669,6 +3669,7 @@ e_mail_reader_init (EMailReader *reader,
GtkAction *action;
gboolean sensitive;
const gchar *action_name;
+ EMailDisplay *display;
#ifndef G_OS_WIN32
GSettings *settings;
@@ -3816,31 +3817,32 @@ e_mail_reader_init (EMailReader *reader,
gtk_action_set_is_important (action, TRUE);
gtk_action_set_short_label (action, _("Reply"));
- /* FIXME WEBKIT
+ display = e_mail_reader_get_mail_display (reader);
+
action_name = "add-to-address-book";
- action = e_web_view_get_action (web_view, action_name);
+ action = e_mail_display_get_action (display, action_name);
g_signal_connect (
action, "activate",
G_CALLBACK (action_add_to_address_book_cb), reader);
action_name = "send-reply";
- action = e_web_view_get_action (web_view, action_name);
+ action = e_mail_display_get_action (display, action_name);
g_signal_connect (
action, "activate",
G_CALLBACK (action_mail_reply_recipient_cb), reader);
action_name = "search-folder-recipient";
- action = e_web_view_get_action (web_view, action_name);
+ action = e_mail_display_get_action (display, action_name);
g_signal_connect (
action, "activate",
G_CALLBACK (action_search_folder_recipient_cb), reader);
action_name = "search-folder-sender";
- action = e_web_view_get_action (web_view, action_name);
+ action = e_mail_display_get_action (display, action_name);
g_signal_connect (
action, "activate",
G_CALLBACK (action_search_folder_sender_cb), reader);
- */
+
#ifndef G_OS_WIN32
/* Lockdown integration. */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]