diff options
Diffstat (limited to 'src/bookmarks/ephy-bookmark-action.c')
-rw-r--r-- | src/bookmarks/ephy-bookmark-action.c | 127 |
1 files changed, 111 insertions, 16 deletions
diff --git a/src/bookmarks/ephy-bookmark-action.c b/src/bookmarks/ephy-bookmark-action.c index f47f46683..bea4cd18d 100644 --- a/src/bookmarks/ephy-bookmark-action.c +++ b/src/bookmarks/ephy-bookmark-action.c @@ -27,6 +27,8 @@ #include <gtk/gtktoolitem.h> #include "ephy-bookmark-action.h" +#include "ephy-dnd.h" +#include "ephy-bookmarksbar.h" #include "ephy-bookmarks.h" #include "ephy-favicon-cache.h" #include "ephy-shell.h" @@ -42,13 +44,23 @@ static void ephy_bookmark_action_class_init (EphyBookmarkActionClass *class); #define EPHY_BOOKMARK_ACTION_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_BOOKMARK_ACTION, EphyBookmarkActionPrivate)) +static GtkTargetEntry drag_targets[] = +{ + { EPHY_DND_URL_TYPE, 0, 0 } +}; +static int n_drag_targets = G_N_ELEMENTS (drag_targets); + struct EphyBookmarkActionPrivate { int bookmark_id; char *location; gboolean smart_url; char *icon; - guint cache_connection; + guint cache_handler; + + guint motion_handler; + gint drag_x; + gint drag_y; }; enum @@ -112,6 +124,7 @@ create_tool_item (GtkAction *action) gtk_container_add (GTK_CONTAINER (item), hbox); button = gtk_button_new (); + gtk_widget_add_events (GTK_WIDGET (button), GDK_BUTTON1_MOTION_MASK); gtk_button_set_relief (GTK_BUTTON (button), GTK_RELIEF_NONE); gtk_widget_show (button); gtk_container_add (GTK_CONTAINER (hbox), button); @@ -122,7 +135,7 @@ create_tool_item (GtkAction *action) gtk_box_pack_start (GTK_BOX (hbox), entry, TRUE, TRUE, 0); g_object_set_data (G_OBJECT (item), "entry", entry); - hbox = gtk_hbox_new (FALSE, 0); + hbox = gtk_hbox_new (FALSE, 3); gtk_widget_show (hbox); gtk_container_add (GTK_CONTAINER (button), hbox); @@ -168,8 +181,8 @@ favicon_cache_changed_cb (EphyFaviconCache *cache, { if (action->priv->icon && strcmp (icon, action->priv->icon) == 0) { - g_signal_handler_disconnect (cache, action->priv->cache_connection); - action->priv->cache_connection = 0; + g_signal_handler_disconnect (cache, action->priv->cache_handler); + action->priv->cache_handler = 0; g_object_notify (G_OBJECT (action), "icon"); } @@ -192,9 +205,9 @@ ephy_bookmark_action_sync_icon (GtkAction *action, GParamSpec *pspec, GtkWidget { pixbuf = ephy_favicon_cache_get (cache, icon_location); - if (pixbuf == NULL && bma->priv->cache_connection == 0) + if (pixbuf == NULL && bma->priv->cache_handler == 0) { - bma->priv->cache_connection = + bma->priv->cache_handler = g_signal_connect_object (cache, "changed", G_CALLBACK (favicon_cache_changed_cb), @@ -202,7 +215,11 @@ ephy_bookmark_action_sync_icon (GtkAction *action, GParamSpec *pspec, GtkWidget } } - if (pixbuf == NULL) return; + if (pixbuf == NULL) + { + pixbuf = gtk_widget_render_icon (proxy, GTK_STOCK_JUMP_TO, + GTK_ICON_SIZE_MENU, NULL); + } if (GTK_IS_TOOL_ITEM (proxy)) { @@ -325,15 +342,86 @@ activate_cb (GtkWidget *widget, GtkAction *action) g_free (text); } +static void +stop_drag_check (EphyBookmarkAction *action, GtkWidget *widget) +{ + if (action->priv->motion_handler) + { + g_signal_handler_disconnect (widget, action->priv->motion_handler); + action->priv->motion_handler = 0; + } +} + +static void +drag_data_get_cb (GtkWidget *widget, GdkDragContext *context, + GtkSelectionData *selection_data, guint info, + guint32 time, EphyBookmarkAction *action) +{ + char *address = action->priv->location; + + g_return_if_fail (address != NULL); + + gtk_selection_data_set (selection_data, selection_data->target, 8, + address, strlen (address)); +} + +static void +drag_data_delete_cb (GtkWidget *widget, GdkDragContext *context, + EphyBookmarkAction *action) +{ + EphyBookmarks *bookmarks; + EggToolbarsModel *model; + GtkWidget *item, *toolbar; + int pos; + + item = gtk_widget_get_ancestor (widget, GTK_TYPE_TOOL_ITEM); + g_return_if_fail (item != NULL); + + toolbar = gtk_widget_get_ancestor (widget, GTK_TYPE_TOOLBAR); + g_return_if_fail (toolbar != NULL); + + pos = gtk_toolbar_get_item_index (GTK_TOOLBAR (toolbar), + GTK_TOOL_ITEM (item)); + + bookmarks = ephy_shell_get_bookmarks (ephy_shell); + model = ephy_bookmarks_get_toolbars_model (bookmarks); + egg_toolbars_model_remove_item (model, 0, pos); +} + +static gboolean +drag_motion_cb (GtkWidget *widget, GdkEventMotion *event, EphyBookmarkAction *action) +{ + if (gtk_drag_check_threshold (widget, action->priv->drag_x, + action->priv->drag_y, event->x, event->y)) + { + GtkTargetList *target_list; + + target_list = gtk_target_list_new (drag_targets, n_drag_targets); + + stop_drag_check (action, widget); + gtk_drag_begin (widget, target_list, GDK_ACTION_MOVE, 1, (GdkEvent*)event); + } + + return TRUE; +} + static gboolean button_press_cb (GtkWidget *widget, GdkEventButton *event, - gpointer dummy) + EphyBookmarkAction *action) { - if (event->type == GDK_BUTTON_PRESS && event->button == 2) + if (event->button == 2) { gtk_button_pressed (GTK_BUTTON (widget)); } + else if (event->button == 1 && + gtk_widget_get_ancestor (widget, EPHY_TYPE_BOOKMARKSBAR)) + { + action->priv->drag_x = event->x; + action->priv->drag_y = event->y; + action->priv->motion_handler = g_signal_connect + (widget, "motion_notify_event", G_CALLBACK (drag_motion_cb), action); + } return FALSE; } @@ -341,13 +429,15 @@ button_press_cb (GtkWidget *widget, static gboolean button_release_cb (GtkWidget *widget, GdkEventButton *event, - gpointer dummy) + EphyBookmarkAction *action) { - if (event->type == GDK_BUTTON_RELEASE && event->button == 2) + if (event->button == 2) { gtk_button_released (GTK_BUTTON (widget)); - - return TRUE; + } + else if (event->button == 1) + { + stop_drag_check (action, widget); } return FALSE; @@ -379,9 +469,13 @@ connect_proxy (GtkAction *action, GtkWidget *proxy) button = GTK_WIDGET (g_object_get_data (G_OBJECT (proxy), "button")); g_signal_connect (button, "clicked", G_CALLBACK (activate_cb), action); g_signal_connect (button, "button-press-event", - G_CALLBACK (button_press_cb), NULL); + G_CALLBACK (button_press_cb), action); g_signal_connect (button, "button-release-event", - G_CALLBACK (button_release_cb), NULL); + G_CALLBACK (button_release_cb), action); + g_signal_connect (button, "drag_data_get", + G_CALLBACK (drag_data_get_cb), action); + g_signal_connect (button, "drag_data_delete", + G_CALLBACK (drag_data_delete_cb), action); entry = GTK_WIDGET (g_object_get_data (G_OBJECT (proxy), "entry")); g_signal_connect (entry, "activate", G_CALLBACK (activate_cb), action); @@ -612,7 +706,8 @@ ephy_bookmark_action_init (EphyBookmarkAction *action) action->priv->location = NULL; action->priv->icon = NULL; - action->priv->cache_connection = 0; + action->priv->cache_handler = 0; + action->priv->motion_handler = 0; bookmarks = ephy_shell_get_bookmarks (ephy_shell); node = ephy_bookmarks_get_bookmarks (bookmarks); |