]> git.0d.be Git - empathy.git/blobdiff - libempathy-gtk/empathy-webkit-utils.c
Merge branch 'gnome-3-8'
[empathy.git] / libempathy-gtk / empathy-webkit-utils.c
index cac9af9d89160e98e611e0144a9c22fe11812dca..0fc31908814ab1a3b74fb8da64ca72117197d9ce 100644 (file)
  */
 
 #include "config.h"
+#include "empathy-webkit-utils.h"
 
-#include <glib/gi18n.h>
+#include <glib/gi18n-lib.h>
 
-#include "empathy-webkit-utils.h"
 #include "empathy-smiley-manager.h"
+#include "empathy-theme-adium.h"
 #include "empathy-ui-utils.h"
 
 #define BORING_DPI_DEFAULT 96
@@ -160,6 +161,7 @@ empathy_webkit_bind_font_setting (WebKitWebView *webview,
       webkit_get_font_family,
       NULL,
       NULL, NULL);
+
   g_settings_bind_with_mapping (gsettings, key,
       settings, "default-font-size",
       G_SETTINGS_BIND_GET,
@@ -170,11 +172,11 @@ empathy_webkit_bind_font_setting (WebKitWebView *webview,
 
 static void
 empathy_webkit_copy_address_cb (GtkMenuItem *menuitem,
-    gpointer     user_data)
+    gpointer user_data)
 {
-  WebKitHitTestResult   *hit_test_result = WEBKIT_HIT_TEST_RESULT (user_data);
-  gchar                 *uri;
-  GtkClipboard          *clipboard;
+  WebKitHitTestResult *hit_test_result = WEBKIT_HIT_TEST_RESULT (user_data);
+  gchar *uri;
+  GtkClipboard *clipboard;
 
   g_object_get (G_OBJECT (hit_test_result),
       "link-uri", &uri,
@@ -193,8 +195,8 @@ static void
 empathy_webkit_open_address_cb (GtkMenuItem *menuitem,
     gpointer     user_data)
 {
-  WebKitHitTestResult   *hit_test_result = WEBKIT_HIT_TEST_RESULT (user_data);
-  gchar                 *uri;
+  WebKitHitTestResult *hit_test_result = WEBKIT_HIT_TEST_RESULT (user_data);
+  gchar *uri;
 
   g_object_get (G_OBJECT (hit_test_result),
       "link-uri", &uri,
@@ -205,6 +207,13 @@ empathy_webkit_open_address_cb (GtkMenuItem *menuitem,
   g_free (uri);
 }
 
+static void
+empathy_webkit_inspect_cb (GtkMenuItem *menuitem,
+    WebKitWebView *view)
+{
+  empathy_webkit_show_inspector (view);
+}
+
 static void
 empathy_webkit_context_menu_selection_done_cb (GtkMenuShell *menu,
     gpointer user_data)
@@ -214,17 +223,15 @@ empathy_webkit_context_menu_selection_done_cb (GtkMenuShell *menu,
   g_object_unref (hit_test_result);
 }
 
-void
-empathy_webkit_context_menu_for_event (WebKitWebView *view,
-    GdkEventButton *event,
+GtkWidget *
+empathy_webkit_create_context_menu (WebKitWebView *view,
+    WebKitHitTestResult *hit_test_result,
     EmpathyWebKitMenuFlags flags)
 {
-  WebKitHitTestResult        *hit_test_result;
-  WebKitHitTestResultContext  context;
-  GtkWidget                  *menu;
-  GtkWidget                  *item;
+  WebKitHitTestResultContext context;
+  GtkWidget *menu;
+  GtkWidget *item;
 
-  hit_test_result = webkit_web_view_get_hit_test_result (view, event);
   g_object_get (G_OBJECT (hit_test_result),
       "context", &context,
       NULL);
@@ -261,7 +268,7 @@ empathy_webkit_context_menu_for_event (WebKitWebView *view,
       gtk_menu_shell_prepend (GTK_MENU_SHELL (menu), item);
 
       g_signal_connect_swapped (item, "activate",
-          G_CALLBACK (empathy_chat_view_clear),
+          G_CALLBACK (empathy_theme_adium_clear),
           view);
     }
 
@@ -288,13 +295,53 @@ empathy_webkit_context_menu_for_event (WebKitWebView *view,
       gtk_menu_shell_prepend (GTK_MENU_SHELL (menu), item);
     }
 
+  if ((flags & EMPATHY_WEBKIT_MENU_INSPECT) != 0)
+    {
+      /* Separator */
+      item = gtk_separator_menu_item_new ();
+      gtk_menu_shell_append (GTK_MENU_SHELL (menu), item);
+
+      /* Inspector */
+      item = gtk_menu_item_new_with_mnemonic (_("Inspect HTML"));
+      g_signal_connect (item, "activate",
+          G_CALLBACK (empathy_webkit_inspect_cb), view);
+      gtk_menu_shell_append (GTK_MENU_SHELL (menu), item);
+    }
+
   g_signal_connect (GTK_MENU_SHELL (menu), "selection-done",
       G_CALLBACK (empathy_webkit_context_menu_selection_done_cb),
-      hit_test_result);
+      g_object_ref (hit_test_result));
+
+  return menu;
+}
+
+void
+empathy_webkit_context_menu_for_event (WebKitWebView *view,
+    GdkEventButton *event,
+    EmpathyWebKitMenuFlags flags)
+{
+  GtkWidget *menu;
+  WebKitHitTestResult *hit_test_result;
+
+  hit_test_result = webkit_web_view_get_hit_test_result (view, event);
+
+  menu = empathy_webkit_create_context_menu (view, hit_test_result, flags);
 
-  /* Display the menu */
   gtk_widget_show_all (menu);
   gtk_menu_popup (GTK_MENU (menu), NULL, NULL, NULL, NULL,
       event->button, event->time);
+
+  g_object_unref (hit_test_result);
 }
 
+void
+empathy_webkit_show_inspector (WebKitWebView *view)
+{
+  WebKitWebInspector *inspector;
+
+  g_object_set (G_OBJECT (webkit_web_view_get_settings (view)),
+      "enable-developer-extras", TRUE, NULL);
+
+  inspector = webkit_web_view_get_inspector (view);
+  webkit_web_inspector_show (inspector);
+}