aboutsummaryrefslogtreecommitdiffstats
path: root/lib/widgets
diff options
context:
space:
mode:
Diffstat (limited to 'lib/widgets')
-rw-r--r--lib/widgets/ephy-location-entry.c304
1 files changed, 153 insertions, 151 deletions
diff --git a/lib/widgets/ephy-location-entry.c b/lib/widgets/ephy-location-entry.c
index fc7cf0a8d..36172df01 100644
--- a/lib/widgets/ephy-location-entry.c
+++ b/lib/widgets/ephy-location-entry.c
@@ -3,6 +3,7 @@
* Copyright © 2002 Ricardo Fernández Pascual
* Copyright © 2003, 2004 Marco Pesenti Gritti
* Copyright © 2003, 2004, 2005 Christian Persch
+ * Copyright © 2008 Xan López
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
@@ -22,7 +23,6 @@
#include "config.h"
-#include "ephy-icon-entry.h"
#include "ephy-tree-model-node.h"
#include "ephy-location-entry.h"
#include "ephy-marshal.h"
@@ -43,11 +43,8 @@
struct _EphyLocationEntryPrivate
{
- EphyIconEntry *icon_entry;
- GtkWidget *icon_ebox;
- GtkWidget *icon;
- GtkWidget *lock_ebox;
- GtkWidget *lock;
+ GtkWidget *entry;
+ char *lock_stock_id;
GdkPixbuf *favicon;
GdkColor secure_bg_colour;
GdkColor secure_fg_colour;
@@ -132,9 +129,9 @@ ephy_location_entry_style_set (GtkWidget *widget,
title_fg_colour = widget->style->text[GTK_STATE_INSENSITIVE];
g_object_set (entry->priv->extracell,
- "foreground-gdk", &title_fg_colour,
- "foreground-set", TRUE,
- NULL);
+ "foreground-gdk", &title_fg_colour,
+ "foreground-set", TRUE,
+ NULL);
settings = gtk_settings_get_for_screen (gtk_widget_get_screen (widget));
g_object_get (settings, "gtk-theme-name", &theme, NULL);
@@ -269,23 +266,25 @@ update_address_state (EphyLocationEntry *entry)
EphyLocationEntryPrivate *priv = entry->priv;
const char *text;
- text = gtk_entry_get_text (GTK_ENTRY (priv->icon_entry->entry));
+ text = gtk_entry_get_text (GTK_ENTRY (priv->entry));
priv->original_address = text != NULL &&
g_str_hash (text) == priv->hash;
}
static void
-update_favicon (EphyLocationEntry *entry)
+update_favicon (EphyLocationEntry *lentry)
{
- EphyLocationEntryPrivate *priv = entry->priv;
- GtkImage *image = GTK_IMAGE (priv->icon);
+ EphyLocationEntryPrivate *priv = lentry->priv;
+ GtkEntry *entry = GTK_ENTRY (priv->entry);
/* Only show the favicon if the entry's text is the
* address of the current page.
*/
if (priv->favicon != NULL && priv->original_address)
{
- gtk_image_set_from_pixbuf (image, priv->favicon);
+ gtk_entry_set_icon_from_pixbuf (entry,
+ GTK_ENTRY_ICON_PRIMARY,
+ priv->favicon);
}
else
{
@@ -293,9 +292,9 @@ update_favicon (EphyLocationEntry *entry)
* the page MIME type, though text/html should be good enough
* most of the time. See #337140
*/
- gtk_image_set_from_icon_name (image,
- "text-html",
- GTK_ICON_SIZE_MENU);
+ gtk_entry_set_icon_from_icon_name (entry,
+ GTK_ENTRY_ICON_PRIMARY,
+ "text-html");
}
}
@@ -433,8 +432,8 @@ match_selected_cb (GtkEntryCompletion *completion,
state == (GDK_CONTROL_MASK | GDK_SHIFT_MASK));
ephy_location_entry_set_location (entry, item, NULL);
- gtk_im_context_reset (GTK_ENTRY (entry->priv->icon_entry->entry)->im_context);
- g_signal_emit_by_name (priv->icon_entry->entry, "activate");
+ gtk_im_context_reset (GTK_ENTRY (entry->priv->entry)->im_context);
+ g_signal_emit_by_name (priv->entry, "activate");
g_free (item);
@@ -510,7 +509,7 @@ entry_clear_activate_cb (GtkMenuItem *item,
EphyLocationEntryPrivate *priv = entry->priv;
priv->block_update = TRUE;
- gtk_entry_set_text (GTK_ENTRY (priv->icon_entry->entry), "");
+ gtk_entry_set_text (GTK_ENTRY (priv->entry), "");
priv->block_update = FALSE;
priv->user_changed = TRUE;
}
@@ -553,7 +552,7 @@ entry_populate_popup_cb (GtkEntry *entry,
gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (clear_menuitem), image);
g_signal_connect (clear_menuitem , "activate",
G_CALLBACK (entry_clear_activate_cb), lentry);
- is_editable = gtk_editable_get_editable (GTK_EDITABLE (priv->icon_entry->entry));
+ is_editable = gtk_editable_get_editable (GTK_EDITABLE (priv->entry));
gtk_widget_set_sensitive (clear_menuitem, is_editable);
gtk_widget_show (clear_menuitem);
@@ -733,11 +732,19 @@ favicon_create_drag_pixmap (EphyLocationEntry *entry,
static void
favicon_drag_begin_cb (GtkWidget *widget,
GdkDragContext *context,
- EphyLocationEntry *entry)
+ EphyLocationEntry *lentry)
{
GdkPixmap *pixmap;
+ GtkEntry *entry;
+ gint index;
- pixmap = favicon_create_drag_pixmap (entry, widget);
+ entry = GTK_ENTRY (widget);
+
+ index = gtk_entry_get_current_icon_drag_source (entry);
+ if (index != GTK_ENTRY_ICON_PRIMARY)
+ return;
+
+ pixmap = favicon_create_drag_pixmap (lentry, widget);
if (pixmap != NULL)
{
@@ -754,50 +761,50 @@ favicon_drag_data_get_cb (GtkWidget *widget,
GtkSelectionData *selection_data,
guint info,
guint32 time,
- EphyLocationEntry *entry)
+ EphyLocationEntry *lentry)
{
+ gint index;
+ GtkEntry *entry;
+
g_assert (widget != NULL);
g_return_if_fail (context != NULL);
- ephy_dnd_drag_data_get (widget, context, selection_data,
- time, entry, each_url_get_data_binder);
+ entry = GTK_ENTRY (widget);
+
+ index = gtk_entry_get_current_icon_drag_source (entry);
+ if (index == GTK_ENTRY_ICON_PRIMARY)
+ {
+ ephy_dnd_drag_data_get (widget, context, selection_data,
+ time, lentry, each_url_get_data_binder);
+ }
}
static gboolean
-icon_button_press_event_cb (GtkWidget *ebox,
+icon_button_press_event_cb (GtkWidget *entry,
+ GtkEntryIconPosition position,
GdkEventButton *event,
- EphyLocationEntry *entry)
+ EphyLocationEntry *lentry)
{
guint state = event->state & gtk_accelerator_get_default_mod_mask ();
if (event->type == GDK_BUTTON_PRESS &&
- event->button == 1 &&
+ event->button == 1 &&
state == 0 /* left */)
{
- GtkWidget *toplevel;
- EphyLocationEntryPrivate *priv = entry->priv;
+ if (position == GTK_ENTRY_ICON_PRIMARY)
+ {
+ GtkWidget *toplevel;
- toplevel = gtk_widget_get_toplevel (GTK_WIDGET (entry));
- gtk_window_set_focus (GTK_WINDOW(toplevel),
- priv->icon_entry->entry);
+ toplevel = gtk_widget_get_toplevel (GTK_WIDGET (entry));
+ gtk_window_set_focus (GTK_WINDOW (toplevel), entry);
- gtk_editable_select_region (GTK_EDITABLE (priv->icon_entry->entry),
- 0, -1);
-
- return TRUE;
- }
-
- return FALSE;
-}
-
-static gboolean
-lock_button_press_event_cb (GtkWidget *ebox,
- GdkEventButton *event,
- EphyLocationEntry *entry)
-{
- if (event->type == GDK_BUTTON_PRESS && event->button == 1 /* left */)
- {
- g_signal_emit (entry, signals[LOCK_CLICKED], 0);
+ gtk_editable_select_region (GTK_EDITABLE (entry),
+ 0, -1);
+ }
+ else
+ {
+ g_signal_emit (lentry, signals[LOCK_CLICKED], 0);
+ }
return TRUE;
}
@@ -806,76 +813,62 @@ lock_button_press_event_cb (GtkWidget *ebox,
}
static void
-ephy_location_entry_construct_contents (EphyLocationEntry *entry)
+ephy_location_entry_construct_contents (EphyLocationEntry *lentry)
{
- EphyLocationEntryPrivate *priv = entry->priv;
- GtkWidget *alignment;
-
- LOG ("EphyLocationEntry constructing contents %p", entry);
-
- alignment = gtk_alignment_new (0.0, 0.5, 1.0, 0.0);
- gtk_alignment_set_padding (GTK_ALIGNMENT (alignment), 0, 0, 1, 1);
- gtk_container_add (GTK_CONTAINER (entry), alignment);
-
- priv->icon_entry = EPHY_ICON_ENTRY (ephy_icon_entry_new ());
- gtk_container_add (GTK_CONTAINER (alignment),
- GTK_WIDGET (priv->icon_entry));
-
- priv->icon_ebox = gtk_event_box_new ();
- gtk_container_set_border_width (GTK_CONTAINER (priv->icon_ebox), 2);
- gtk_event_box_set_visible_window (GTK_EVENT_BOX (priv->icon_ebox), FALSE);
- gtk_widget_add_events (priv->icon_ebox, GDK_BUTTON_PRESS_MASK |
- GDK_BUTTON_RELEASE_MASK |
- GDK_POINTER_MOTION_HINT_MASK);
- gtk_drag_source_set (priv->icon_ebox, GDK_BUTTON1_MASK,
- url_drag_types, G_N_ELEMENTS (url_drag_types),
- GDK_ACTION_ASK | GDK_ACTION_COPY | GDK_ACTION_LINK);
- g_signal_connect (priv->icon_ebox, "button-press-event",
- G_CALLBACK (icon_button_press_event_cb), entry);
-
- gtk_widget_set_tooltip_text (priv->icon_ebox,
- _("Drag and drop this icon to create a link to this page"));
-
- priv->icon = gtk_image_new ();
- gtk_container_add (GTK_CONTAINER (priv->icon_ebox), priv->icon);
-
- ephy_icon_entry_pack_widget (priv->icon_entry, priv->icon_ebox, TRUE);
-
- priv->lock_ebox = gtk_event_box_new ();
- gtk_container_set_border_width (GTK_CONTAINER (priv->lock_ebox), 2);
- gtk_widget_add_events (priv->lock_ebox, GDK_BUTTON_PRESS_MASK);
- gtk_event_box_set_visible_window (GTK_EVENT_BOX (priv->lock_ebox), FALSE);
-
- priv->lock = gtk_image_new_from_stock (STOCK_LOCK_INSECURE,
- GTK_ICON_SIZE_MENU);
- gtk_container_add (GTK_CONTAINER (priv->lock_ebox), priv->lock);
-
- ephy_icon_entry_pack_widget (priv->icon_entry, priv->lock_ebox, FALSE);
-
- g_signal_connect (priv->icon_ebox, "drag-data-get",
- G_CALLBACK (favicon_drag_data_get_cb), entry);
- g_signal_connect (priv->icon_ebox, "drag-begin",
- G_CALLBACK (favicon_drag_begin_cb), entry);
-
- g_signal_connect (priv->lock_ebox, "button-press-event",
- G_CALLBACK (lock_button_press_event_cb), entry);
-
- g_signal_connect (priv->icon_entry->entry, "populate_popup",
- G_CALLBACK (entry_populate_popup_cb), entry);
- g_signal_connect (priv->icon_entry->entry, "key-press-event",
- G_CALLBACK (entry_key_press_cb), entry);
- g_signal_connect_after (priv->icon_entry->entry, "key-press-event",
- G_CALLBACK (entry_key_press_after_cb), entry);
- g_signal_connect_after (priv->icon_entry->entry, "activate",
- G_CALLBACK (entry_activate_after_cb), entry);
- g_signal_connect (priv->icon_entry->entry, "changed",
- G_CALLBACK (editable_changed_cb), entry);
- g_signal_connect (priv->icon_entry->entry, "drag-motion",
- G_CALLBACK (entry_drag_motion_cb), entry);
- g_signal_connect (priv->icon_entry->entry, "drag-drop",
- G_CALLBACK (entry_drag_drop_cb), entry);
-
- gtk_widget_show_all (alignment);
+ EphyLocationEntryPrivate *priv = lentry->priv;
+ GtkTargetList *targetlist;
+
+ LOG ("EphyLocationEntry constructing contents %p", lentry);
+
+ priv->entry = gtk_entry_new ();
+ gtk_container_add (GTK_CONTAINER (lentry), priv->entry);
+
+ /* Favicon */
+ targetlist = gtk_target_list_new (url_drag_types,
+ G_N_ELEMENTS (url_drag_types));
+ gtk_entry_set_icon_drag_source (GTK_ENTRY (priv->entry),
+ GTK_ENTRY_ICON_PRIMARY,
+ targetlist,
+ GDK_ACTION_ASK | GDK_ACTION_COPY | GDK_ACTION_LINK);
+ gtk_target_list_unref (targetlist);
+
+ g_signal_connect (priv->entry, "drag-data-get",
+ G_CALLBACK (favicon_drag_data_get_cb), lentry);
+ g_signal_connect (priv->entry, "drag-begin",
+ G_CALLBACK (favicon_drag_begin_cb), lentry);
+
+ gtk_entry_set_icon_tooltip_text (GTK_ENTRY (priv->entry),
+ GTK_ENTRY_ICON_PRIMARY,
+ _("Drag and drop this icon to create a link to this page"));
+
+ gtk_entry_set_icon_activatable (GTK_ENTRY (priv->entry),
+ GTK_ENTRY_ICON_PRIMARY,
+ TRUE);
+ gtk_entry_set_icon_from_stock (GTK_ENTRY (priv->entry),
+ GTK_ENTRY_ICON_SECONDARY,
+ STOCK_LOCK_INSECURE);
+ gtk_entry_set_icon_activatable (GTK_ENTRY (priv->entry),
+ GTK_ENTRY_ICON_SECONDARY,
+ TRUE);
+ g_signal_connect (priv->entry, "icon-pressed",
+ G_CALLBACK (icon_button_press_event_cb), lentry);
+
+ g_signal_connect (priv->entry, "populate_popup",
+ G_CALLBACK (entry_populate_popup_cb), lentry);
+ g_signal_connect (priv->entry, "key-press-event",
+ G_CALLBACK (entry_key_press_cb), lentry);
+ g_signal_connect_after (priv->entry, "key-press-event",
+ G_CALLBACK (entry_key_press_after_cb), lentry);
+ g_signal_connect_after (priv->entry, "activate",
+ G_CALLBACK (entry_activate_after_cb), lentry);
+ g_signal_connect (priv->entry, "changed",
+ G_CALLBACK (editable_changed_cb), lentry);
+ g_signal_connect (priv->entry, "drag-motion",
+ G_CALLBACK (entry_drag_motion_cb), lentry);
+ g_signal_connect (priv->entry, "drag-drop",
+ G_CALLBACK (entry_drag_drop_cb), lentry);
+
+ gtk_widget_show (priv->entry);
}
static void
@@ -975,7 +968,7 @@ ephy_location_entry_set_match_func (EphyLocationEntry *entry,
EphyLocationEntryPrivate *priv = entry->priv;
GtkEntryCompletion *completion;
- completion = gtk_entry_get_completion (GTK_ENTRY (priv->icon_entry->entry));
+ completion = gtk_entry_get_completion (GTK_ENTRY (priv->entry));
gtk_entry_completion_set_match_func (completion, match_func, user_data, notify);
}
@@ -1046,9 +1039,9 @@ ephy_location_entry_set_completion (EphyLocationEntry *entry,
cell = gtk_cell_renderer_text_new ();
g_object_set (cell,
- "ellipsize", PANGO_ELLIPSIZE_END,
- "ellipsize-set", TRUE,
- NULL);
+ "ellipsize", PANGO_ELLIPSIZE_END,
+ "ellipsize-set", TRUE,
+ NULL);
gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (completion),
cell, TRUE);
gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (completion),
@@ -1056,10 +1049,10 @@ ephy_location_entry_set_completion (EphyLocationEntry *entry,
entry->priv->extracell = gtk_cell_renderer_text_new ();
g_object_set (entry->priv->extracell,
- "ellipsize", PANGO_ELLIPSIZE_END,
- "ellipsize-set", TRUE,
- "alignment", PANGO_ALIGN_LEFT,
- NULL);
+ "ellipsize", PANGO_ELLIPSIZE_END,
+ "ellipsize-set", TRUE,
+ "alignment", PANGO_ALIGN_LEFT,
+ NULL);
gtk_cell_layout_pack_end (GTK_CELL_LAYOUT (completion),
entry->priv->extracell, TRUE);
@@ -1073,7 +1066,7 @@ ephy_location_entry_set_completion (EphyLocationEntry *entry,
g_signal_connect (completion, "cursor-on-match",
G_CALLBACK (cursor_on_match_cb), entry);
- gtk_entry_set_completion (GTK_ENTRY (priv->icon_entry->entry), completion);
+ gtk_entry_set_completion (GTK_ENTRY (priv->entry), completion);
g_object_unref (completion);
}
@@ -1106,19 +1099,17 @@ ephy_location_entry_set_location (EphyLocationEntry *entry,
* bug #155824. So we save the selection iff the clipboard was owned by
* the location entry.
*/
- if (GTK_WIDGET_REALIZED (GTK_WIDGET (priv->icon_entry)))
+ if (GTK_WIDGET_REALIZED (GTK_WIDGET (priv->entry)))
{
- GtkWidget *gtkentry = priv->icon_entry->entry;
-
- clipboard = gtk_widget_get_clipboard (gtkentry,
+ clipboard = gtk_widget_get_clipboard (priv->entry,
GDK_SELECTION_PRIMARY);
g_return_if_fail (clipboard != NULL);
- if (gtk_clipboard_get_owner (clipboard) == G_OBJECT (gtkentry) &&
- gtk_editable_get_selection_bounds (GTK_EDITABLE (gtkentry),
+ if (gtk_clipboard_get_owner (clipboard) == G_OBJECT (priv->entry) &&
+ gtk_editable_get_selection_bounds (GTK_EDITABLE (priv->entry),
&start, &end))
{
- selection = gtk_editable_get_chars (GTK_EDITABLE (gtkentry),
+ selection = gtk_editable_get_chars (GTK_EDITABLE (priv->entry),
start, end);
}
}
@@ -1140,7 +1131,7 @@ ephy_location_entry_set_location (EphyLocationEntry *entry,
priv->hash = g_str_hash (address);
priv->block_update = TRUE;
- gtk_entry_set_text (GTK_ENTRY (priv->icon_entry->entry), text);
+ gtk_entry_set_text (GTK_ENTRY (priv->entry), text);
priv->block_update = FALSE;
/* We need to call update_address_state() here, as the 'changed' signal
@@ -1210,7 +1201,7 @@ ephy_location_entry_get_location (EphyLocationEntry *entry)
{
EphyLocationEntryPrivate *priv = entry->priv;
- return gtk_entry_get_text (GTK_ENTRY (priv->icon_entry->entry));
+ return gtk_entry_get_text (GTK_ENTRY (priv->entry));
}
static gboolean
@@ -1224,7 +1215,7 @@ ephy_location_entry_reset_internal (EphyLocationEntry *entry,
g_signal_emit (entry, signals[GET_LOCATION], 0, &url);
text = url != NULL ? url : "";
- old_text = gtk_entry_get_text (GTK_ENTRY (priv->icon_entry->entry));
+ old_text = gtk_entry_get_text (GTK_ENTRY (priv->entry));
old_text = old_text != NULL ? old_text : "";
g_free (priv->saved_text);
@@ -1258,7 +1249,7 @@ ephy_location_entry_undo_reset (EphyLocationEntry *entry)
{
EphyLocationEntryPrivate *priv = entry->priv;
- gtk_entry_set_text (GTK_ENTRY (priv->icon_entry->entry), priv->saved_text);
+ gtk_entry_set_text (GTK_ENTRY (priv->entry), priv->saved_text);
priv->can_redo = FALSE;
priv->user_changed = TRUE;
}
@@ -1296,10 +1287,10 @@ ephy_location_entry_activate (EphyLocationEntry *entry)
toplevel = gtk_widget_get_toplevel (GTK_WIDGET (entry));
- gtk_editable_select_region (GTK_EDITABLE(priv->icon_entry->entry),
+ gtk_editable_select_region (GTK_EDITABLE (priv->entry),
0, -1);
- gtk_window_set_focus (GTK_WINDOW(toplevel),
- priv->icon_entry->entry);
+ gtk_window_set_focus (GTK_WINDOW (toplevel),
+ priv->entry);
}
/**
@@ -1316,7 +1307,7 @@ ephy_location_entry_get_entry (EphyLocationEntry *entry)
{
EphyLocationEntryPrivate *priv = entry->priv;
- return priv->icon_entry->entry;
+ return priv->entry;
}
/**
@@ -1360,7 +1351,7 @@ ephy_location_entry_set_secure (EphyLocationEntry *entry,
{
EphyLocationEntryPrivate *priv = entry->priv;
GtkWidget *widget = GTK_WIDGET (entry);
- GtkWidget *gentry = ephy_icon_entry_get_entry (entry->priv->icon_entry);
+ GtkWidget *gentry = priv->entry;
priv->secure = secure;
@@ -1395,9 +1386,15 @@ void
ephy_location_entry_set_show_lock (EphyLocationEntry *entry,
gboolean show_lock)
{
- EphyLocationEntryPrivate *priv = entry->priv;
+ EphyLocationEntryPrivate *priv;
- g_object_set (priv->lock_ebox, "visible", show_lock, NULL);
+ g_return_if_fail (EPHY_IS_LOCATION_ENTRY (entry));
+
+ priv = entry->priv;
+
+ gtk_entry_set_icon_from_stock (GTK_ENTRY (priv->entry),
+ GTK_ENTRY_ICON_SECONDARY,
+ show_lock ? priv->lock_stock_id : NULL);
}
/**
@@ -1414,10 +1411,13 @@ ephy_location_entry_set_lock_stock (EphyLocationEntry *entry,
const char *stock_id)
{
- EphyLocationEntryPrivate *priv = entry->priv;
+ g_return_if_fail (EPHY_IS_LOCATION_ENTRY (entry));
+
+ entry->priv->lock_stock_id = (char*)stock_id;
- gtk_image_set_from_stock (GTK_IMAGE (priv->lock), stock_id,
- GTK_ICON_SIZE_MENU);
+ gtk_entry_set_icon_from_stock (GTK_ENTRY (entry->priv->entry),
+ GTK_ENTRY_ICON_SECONDARY,
+ stock_id);
}
/**
@@ -1434,7 +1434,9 @@ ephy_location_entry_set_lock_tooltip (EphyLocationEntry *entry,
{
EphyLocationEntryPrivate *priv = entry->priv;
- gtk_widget_set_tooltip_text (priv->lock_ebox, tooltip);
+ gtk_entry_set_icon_tooltip_text (GTK_ENTRY (priv->entry),
+ GTK_ENTRY_ICON_SECONDARY,
+ tooltip);
}
/**