aboutsummaryrefslogtreecommitdiffstats
path: root/src/popup-commands.c
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <marco@it.gnome.org>2003-01-21 02:57:20 +0800
committerMarco Pesenti Gritti <mpeseng@src.gnome.org>2003-01-21 02:57:20 +0800
commitc2beffd03405e6db4295afd6c2982388b808cb2e (patch)
tree819e50881626c5109ccdba5abb158585a3ca148b /src/popup-commands.c
parent822ca51797e05edbe42b80f1a33a70a7327d732e (diff)
downloadgsoc2013-epiphany-c2beffd03405e6db4295afd6c2982388b808cb2e.tar
gsoc2013-epiphany-c2beffd03405e6db4295afd6c2982388b808cb2e.tar.gz
gsoc2013-epiphany-c2beffd03405e6db4295afd6c2982388b808cb2e.tar.bz2
gsoc2013-epiphany-c2beffd03405e6db4295afd6c2982388b808cb2e.tar.lz
gsoc2013-epiphany-c2beffd03405e6db4295afd6c2982388b808cb2e.tar.xz
gsoc2013-epiphany-c2beffd03405e6db4295afd6c2982388b808cb2e.tar.zst
gsoc2013-epiphany-c2beffd03405e6db4295afd6c2982388b808cb2e.zip
Merge eog-menu-api branch
2003-01-20 Marco Pesenti Gritti <marco@it.gnome.org> * Merge eog-menu-api branch
Diffstat (limited to 'src/popup-commands.c')
-rw-r--r--src/popup-commands.c364
1 files changed, 304 insertions, 60 deletions
diff --git a/src/popup-commands.c b/src/popup-commands.c
index f1ec8ae74..84ce259c8 100644
--- a/src/popup-commands.c
+++ b/src/popup-commands.c
@@ -18,47 +18,60 @@
#include "popup-commands.h"
#include "ephy-shell.h"
+#include "ephy-new-bookmark.h"
+#include "ephy-embed-persist.h"
+#include "ephy-prefs.h"
+#include "ephy-embed-utils.h"
+#include "eel-gconf-extensions.h"
+#include "ephy-file-helpers.h"
-static EphyWindow *
-get_window_from_popup (EphyEmbedPopup *popup)
+#include <string.h>
+
+static EphyEmbedEvent *
+get_event_info (EphyWindow *window)
{
- return EPHY_WINDOW (g_object_get_data(G_OBJECT(popup), "EphyWindow"));
+ EphyEmbedEvent *info;
+ EphyTab *tab;
+
+ tab = ephy_window_get_active_tab (window);
+ g_return_val_if_fail (tab != NULL, NULL);
+
+ info = ephy_tab_get_event (tab);
+ g_return_val_if_fail (info != NULL, NULL);
+
+ return info;
}
-void popup_cmd_new_window (BonoboUIComponent *uic,
- EphyEmbedPopup *popup,
- const char* verbname)
+void
+popup_cmd_link_in_new_window (EggAction *action,
+ EphyWindow *window)
{
EphyEmbedEvent *info;
EphyTab *tab;
const GValue *value;
- tab = ephy_window_get_active_tab (get_window_from_popup (popup));
+ tab = ephy_window_get_active_tab (window);
- info = ephy_embed_popup_get_event (popup);
+ info = get_event_info (window);
ephy_embed_event_get_property (info, "link", &value);
ephy_shell_new_tab (ephy_shell, NULL, tab,
- g_value_get_string (value),
- EPHY_NEW_TAB_IN_NEW_WINDOW);
+ g_value_get_string (value),
+ EPHY_NEW_TAB_IN_NEW_WINDOW);
}
-void popup_cmd_new_tab (BonoboUIComponent *uic,
- EphyEmbedPopup *popup,
- const char* verbname)
+void
+popup_cmd_link_in_new_tab (EggAction *action,
+ EphyWindow *window)
{
EphyEmbedEvent *info;
EphyTab *tab;
- EphyWindow *window;
const GValue *value;
- window = get_window_from_popup (popup);
- g_return_if_fail (window != NULL);
-
tab = ephy_window_get_active_tab (window);
- info = ephy_embed_popup_get_event (popup);
+ info = get_event_info (window);
ephy_embed_event_get_property (info, "link", &value);
@@ -67,21 +80,17 @@ void popup_cmd_new_tab (BonoboUIComponent *uic,
EPHY_NEW_TAB_IN_EXISTING_WINDOW);
}
-void popup_cmd_image_in_new_tab (BonoboUIComponent *uic,
- EphyEmbedPopup *popup,
- const char* verbname)
+void
+popup_cmd_image_in_new_tab (EggAction *action,
+ EphyWindow *window)
{
EphyEmbedEvent *info;
EphyTab *tab;
- EphyWindow *window;
const GValue *value;
- window = get_window_from_popup (popup);
- g_return_if_fail (window != NULL);
-
tab = ephy_window_get_active_tab (window);
- info = ephy_embed_popup_get_event (popup);
+ info = get_event_info (window);
ephy_embed_event_get_property (info, "image", &value);
@@ -90,17 +99,17 @@ void popup_cmd_image_in_new_tab (BonoboUIComponent *uic,
EPHY_NEW_TAB_IN_EXISTING_WINDOW);
}
-void popup_cmd_image_in_new_window (BonoboUIComponent *uic,
- EphyEmbedPopup *popup,
- const char* verbname)
+void
+popup_cmd_image_in_new_window (EggAction *action,
+ EphyWindow *window)
{
EphyEmbedEvent *info;
EphyTab *tab;
const GValue *value;
- tab = ephy_window_get_active_tab (get_window_from_popup (popup));
+ tab = ephy_window_get_active_tab (window);
- info = ephy_embed_popup_get_event (popup);
+ info = get_event_info (window);
ephy_embed_event_get_property (info, "image", &value);
@@ -109,15 +118,14 @@ void popup_cmd_image_in_new_window (BonoboUIComponent *uic,
EPHY_NEW_TAB_IN_NEW_WINDOW);
}
-void popup_cmd_add_bookmark (BonoboUIComponent *uic,
- EphyEmbedPopup *popup,
- const char* verbname)
+void
+popup_cmd_add_link_bookmark (EggAction *action,
+ EphyWindow *window)
{
GtkWidget *new_bookmark;
EphyBookmarks *bookmarks;
- EphyEmbedEvent *info = ephy_embed_popup_get_event (popup);
+ EphyEmbedEvent *info;
EphyEmbed *embed;
- GtkWidget *window;
const GValue *link_title;
const GValue *link_rel;
const GValue *link;
@@ -127,8 +135,8 @@ void popup_cmd_add_bookmark (BonoboUIComponent *uic,
const char *rel;
gboolean is_smart;
- embed = ephy_embed_popup_get_embed (popup);
- window = gtk_widget_get_toplevel (GTK_WIDGET (embed));
+ info = get_event_info (window);
+ embed = ephy_window_get_active_embed (window);
ephy_embed_event_get_property (info, "link_is_smart", &link_is_smart);
ephy_embed_event_get_property (info, "link", &link);
@@ -157,18 +165,14 @@ void popup_cmd_add_bookmark (BonoboUIComponent *uic,
gtk_widget_show (new_bookmark);
}
-void popup_cmd_frame_in_new_tab (BonoboUIComponent *uic,
- EphyEmbedPopup *popup,
- const char* verbname)
+void
+popup_cmd_frame_in_new_tab (EggAction *action,
+ EphyWindow *window)
{
EphyTab *tab;
- EphyWindow *window;
EphyEmbed *embed;
char *location;
- window = get_window_from_popup (popup);
- g_return_if_fail (window != NULL);
-
tab = ephy_window_get_active_tab (window);
embed = ephy_window_get_active_embed (window);
@@ -182,18 +186,14 @@ void popup_cmd_frame_in_new_tab (BonoboUIComponent *uic,
g_free (location);
}
-void popup_cmd_frame_in_new_window (BonoboUIComponent *uic,
- EphyEmbedPopup *popup,
- const char* verbname)
+void
+popup_cmd_frame_in_new_window (EggAction *action,
+ EphyWindow *window)
{
EphyTab *tab;
EphyEmbed *embed;
- EphyWindow *window;
char *location;
- window = get_window_from_popup (popup);
- g_return_if_fail (window != NULL);
-
tab = ephy_window_get_active_tab (window);
embed = ephy_window_get_active_embed (window);
@@ -207,16 +207,260 @@ void popup_cmd_frame_in_new_window (BonoboUIComponent *uic,
g_free (location);
}
-void popup_cmd_add_frame_bookmark (BonoboUIComponent *uic,
- EphyEmbedPopup *popup,
- const char* verbname)
+static void
+popup_cmd_copy_to_clipboard (EphyWindow *window, const char *text)
+{
+ gtk_clipboard_set_text (gtk_clipboard_get (GDK_NONE),
+ text, -1);
+ gtk_clipboard_set_text (gtk_clipboard_get (GDK_SELECTION_PRIMARY),
+ text, -1);
+}
+
+void
+popup_cmd_copy_page_location (EggAction *action,
+ EphyWindow *window)
+{
+ char *location;
+ EphyEmbed *embed;
+
+ embed = ephy_window_get_active_embed (window);
+ g_return_if_fail (embed != NULL);
+
+ ephy_embed_get_location (embed, FALSE, &location);
+ popup_cmd_copy_to_clipboard (window, location);
+ g_free (location);
+}
+
+void
+popup_cmd_copy_email (EggAction *action,
+ EphyWindow *window)
+{
+ EphyEmbedEvent *info;
+ const char *location;
+ const GValue *value;
+ EphyEmbed *embed;
+
+ embed = ephy_window_get_active_embed (window);
+ g_return_if_fail (embed != NULL);
+
+ info = get_event_info (window);
+ ephy_embed_event_get_property (info, "email", &value);
+ location = g_value_get_string (value);
+ popup_cmd_copy_to_clipboard (window, location);
+}
+
+void
+popup_cmd_copy_link_location (EggAction *action,
+ EphyWindow *window)
+{
+ EphyEmbedEvent *info;
+ const char *location;
+ const GValue *value;
+ EphyEmbed *embed;
+
+ embed = ephy_window_get_active_embed (window);
+ g_return_if_fail (embed != NULL);
+
+ info = get_event_info (window);
+ ephy_embed_event_get_property (info, "link", &value);
+ location = g_value_get_string (value);
+ popup_cmd_copy_to_clipboard (window, location);
+}
+
+static void
+save_property_url (EggAction *action,
+ EphyWindow *window,
+ gboolean ask_dest,
+ gboolean show_progress,
+ const char *property)
+{
+ EphyEmbedEvent *info;
+ const char *location;
+ const GValue *value;
+ GtkWidget *widget;
+ EphyEmbedPersist *persist;
+ EphyEmbed *embed;
+
+ embed = ephy_window_get_active_embed (window);
+ g_return_if_fail (embed != NULL);
+
+ info = get_event_info (window);
+ ephy_embed_event_get_property (info, property, &value);
+ location = g_value_get_string (value);
+
+ widget = GTK_WIDGET (embed);
+
+ persist = ephy_embed_persist_new (embed);
+
+ ephy_embed_persist_set_source (persist, location);
+
+ if (show_progress)
+ {
+ ephy_embed_persist_set_flags (persist,
+ EMBED_PERSIST_SHOW_PROGRESS);
+ }
+
+ ephy_embed_utils_save (GTK_WIDGET (window),
+ CONF_STATE_DOWNLOADING_DIR,
+ ask_dest,
+ FALSE,
+ persist);
+}
+
+void
+popup_cmd_open_link (EggAction *action,
+ EphyWindow *window)
+{
+ EphyEmbedEvent *info;
+ const char *location;
+ const GValue *value;
+ EphyEmbed *embed;
+
+ embed = ephy_window_get_active_embed (window);
+ g_return_if_fail (embed != NULL);
+
+ info = get_event_info (window);
+ ephy_embed_event_get_property (info, "link", &value);
+ location = g_value_get_string (value);
+
+ ephy_embed_load_url (embed, location);
+}
+
+void
+popup_cmd_download_link (EggAction *action,
+ EphyWindow *window)
+{
+ save_property_url (action, window,
+ eel_gconf_get_boolean
+ (CONF_STATE_DOWNLOADING_DIR),
+ TRUE, "link");
+}
+
+void
+popup_cmd_save_image_as (EggAction *action,
+ EphyWindow *window)
+{
+ save_property_url (action, window, TRUE, FALSE, "image");
+}
+
+#define CONF_DESKTOP_BG_PICTURE "/desktop/gnome/background/picture_filename"
+#define CONF_DESKTOP_BG_TYPE "/desktop/gnome/background/picture_options"
+
+static void
+background_download_completed (EphyEmbedPersist *persist,
+ gpointer data)
+{
+ const char *bg;
+ char *type;
+
+ ephy_embed_persist_get_dest (persist, &bg);
+ eel_gconf_set_string (CONF_DESKTOP_BG_PICTURE, bg);
+
+ type = eel_gconf_get_string (CONF_DESKTOP_BG_TYPE);
+ if (type || strcmp (type, "none") == 0)
+ {
+ eel_gconf_set_string (CONF_DESKTOP_BG_TYPE,
+ "wallpaper");
+ }
+
+ g_free (type);
+
+ g_object_unref (persist);
+}
+
+void
+popup_cmd_set_image_as_background (EggAction *action,
+ EphyWindow *window)
+{
+ EphyEmbedEvent *info;
+ const char *location;
+ char *dest, *base;
+ const GValue *value;
+ EphyEmbedPersist *persist;
+ EphyEmbed *embed;
+
+ embed = ephy_window_get_active_embed (window);
+ g_return_if_fail (embed != NULL);
+
+ info = get_event_info (window);
+ ephy_embed_event_get_property (info, "image", &value);
+ location = g_value_get_string (value);
+
+ persist = ephy_embed_persist_new (embed);
+
+ base = g_path_get_basename (location);
+ dest = g_build_filename (ephy_dot_dir (),
+ base, NULL);
+
+ ephy_embed_persist_set_source (persist, location);
+ ephy_embed_persist_set_dest (persist, dest);
+
+ ephy_embed_persist_save (persist);
+
+ g_signal_connect (persist, "completed",
+ G_CALLBACK (background_download_completed),
+ NULL);
+
+ g_free (dest);
+ g_free (base);
+}
+
+void
+popup_cmd_copy_image_location (EggAction *action,
+ EphyWindow *window)
+{
+ EphyEmbedEvent *info;
+ const char *location;
+ const GValue *value;
+ EphyEmbed *embed;
+
+ embed = ephy_window_get_active_embed (window);
+ g_return_if_fail (embed != NULL);
+
+ info = get_event_info (window);
+ ephy_embed_event_get_property (info, "image", &value);
+ location = g_value_get_string (value);
+ popup_cmd_copy_to_clipboard (window, location);
+}
+
+void
+popup_cmd_save_background_as (EggAction *action,
+ EphyWindow *window)
+{
+ save_property_url (action, window, TRUE, FALSE, "background_image");
+}
+
+void
+popup_cmd_open_frame (EggAction *action,
+ EphyWindow *window)
{
- /* FIXME implement */
+ char *location;
+ EphyEmbed *embed;
+
+ embed = ephy_window_get_active_embed (window);
+ g_return_if_fail (embed != NULL);
+
+ ephy_embed_get_location (embed, FALSE, &location);
+
+ ephy_embed_load_url (embed, location);
}
-void popup_cmd_view_source (BonoboUIComponent *uic,
- EphyEmbedPopup *popup,
- const char* verbname)
+void
+popup_cmd_open_image (EggAction *action,
+ EphyWindow *window)
{
- /* FIXME implement */
+ EphyEmbedEvent *info;
+ const char *location;
+ const GValue *value;
+ EphyEmbed *embed;
+
+ embed = ephy_window_get_active_embed (window);
+ g_return_if_fail (embed != NULL);
+
+ info = get_event_info (window);
+ ephy_embed_event_get_property (info, "image", &value);
+ location = g_value_get_string (value);
+
+ ephy_embed_load_url (embed, location);
}
+