aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-find-toolbar.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/ephy-find-toolbar.c')
-rw-r--r--src/ephy-find-toolbar.c90
1 files changed, 77 insertions, 13 deletions
diff --git a/src/ephy-find-toolbar.c b/src/ephy-find-toolbar.c
index 3e9ac57ac..4c6054f2a 100644
--- a/src/ephy-find-toolbar.c
+++ b/src/ephy-find-toolbar.c
@@ -52,6 +52,9 @@ struct _EphyFindToolbarPrivate
GtkWidget *entry;
GtkToolItem *next;
GtkToolItem *prev;
+ GtkToolItem *sep;
+ GtkToolItem *status_item;
+ GtkWidget *status_label;
gulong set_focus_handler;
guint preedit_changed : 1;
guint prevent_activate : 1;
@@ -112,6 +115,42 @@ set_controls (EphyFindToolbar *toolbar,
}
static void
+set_status (EphyFindToolbar *toolbar,
+ EphyEmbedFindResult result)
+{
+ EphyFindToolbarPrivate *priv = toolbar->priv;
+ char *text = NULL;
+
+ switch (result)
+ {
+ case EPHY_EMBED_FIND_FOUND:
+ text = NULL;
+ break;
+ case EPHY_EMBED_FIND_NOTFOUND:
+ text = _("Phrase not found");
+ break;
+ case EPHY_EMBED_FIND_FOUNDWRAPPED:
+ text = _("Find wrapped");
+ break;
+ }
+
+ gtk_label_set_text (GTK_LABEL (priv->status_label),
+ text != NULL ? text : "");
+
+ g_object_set (priv->sep, "visible", text != NULL, NULL);
+ g_object_set (priv->status_item, "visible", text != NULL, NULL);
+}
+
+static void
+clear_status (EphyFindToolbar *toolbar)
+{
+ EphyFindToolbarPrivate *priv = toolbar->priv;
+
+ gtk_widget_hide (GTK_WIDGET (priv->sep));
+ gtk_widget_hide (GTK_WIDGET (priv->status_item));
+}
+
+static void
tab_content_changed_cb (EphyEmbed *embed,
const char *uri,
EphyFindToolbar *toolbar)
@@ -268,6 +307,7 @@ entry_changed_cb (GtkEntry *entry,
EphyFindToolbarPrivate *priv = toolbar->priv;
const char *text;
char *lowercase;
+ EphyEmbedFindResult result;
gboolean found = TRUE, case_sensitive;
text = gtk_entry_get_text (GTK_ENTRY (priv->entry));
@@ -281,7 +321,10 @@ entry_changed_cb (GtkEntry *entry,
ephy_embed_find_set_properties (get_find (toolbar), text, case_sensitive);
#ifdef HAVE_TYPEAHEADFIND
- found = ephy_embed_find_find (get_find (toolbar), text, priv->links_only);
+ result = ephy_embed_find_find (get_find (toolbar), text, priv->links_only);
+
+ found = result == EPHY_EMBED_FIND_FOUND;
+ set_status (toolbar, result);
#endif
set_controls (toolbar, found, found);
}
@@ -449,6 +492,17 @@ ephy_find_toolbar_init (EphyFindToolbar *toolbar)
gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1);
gtk_widget_show_all (GTK_WIDGET (item));
+ /* Prev */
+ arrow = gtk_arrow_new (GTK_ARROW_LEFT, GTK_SHADOW_NONE);
+ label = gtk_label_new (_("Find Previous"));
+ priv->prev = gtk_tool_button_new (arrow, _("Find Previous"));
+ gtk_tool_item_set_is_important (priv->prev, TRUE);
+ gtk_tool_item_set_tooltip (priv->prev, gtoolbar->tooltips,
+ _("Find previous occurrence of the search string"),
+ NULL);
+ gtk_toolbar_insert (GTK_TOOLBAR (toolbar), priv->prev, -1);
+ gtk_widget_show_all (GTK_WIDGET (priv->prev));
+
/* Next */
arrow = gtk_arrow_new (GTK_ARROW_RIGHT, GTK_SHADOW_NONE);
label = gtk_label_new (_("Find Next"));
@@ -460,16 +514,17 @@ ephy_find_toolbar_init (EphyFindToolbar *toolbar)
gtk_toolbar_insert (GTK_TOOLBAR (toolbar), priv->next, -1);
gtk_widget_show_all (GTK_WIDGET (priv->next));
- /* Prev */
- arrow = gtk_arrow_new (GTK_ARROW_LEFT, GTK_SHADOW_NONE);
- label = gtk_label_new (_("Find Previous"));
- priv->prev = gtk_tool_button_new (arrow, _("Find Previous"));
- gtk_tool_item_set_is_important (priv->prev, TRUE);
- gtk_tool_item_set_tooltip (priv->prev, gtoolbar->tooltips,
- _("Find previous occurrence of the search string"),
- NULL);
- gtk_toolbar_insert (GTK_TOOLBAR (toolbar), priv->prev, -1);
- gtk_widget_show_all (GTK_WIDGET (priv->prev));
+ priv->sep = gtk_separator_tool_item_new ();
+ gtk_toolbar_insert (GTK_TOOLBAR (toolbar), priv->sep, -1);
+
+ priv->status_item = gtk_tool_item_new ();
+ gtk_tool_item_set_expand (priv->status_item, TRUE);
+ priv->status_label = gtk_label_new ("");
+ gtk_misc_set_alignment (GTK_MISC (priv->status_label), 0.0, 0.5);
+ gtk_label_set_ellipsize (GTK_LABEL (priv->status_label), PANGO_ELLIPSIZE_END);
+ gtk_container_add (GTK_CONTAINER (priv->status_item), priv->status_label);
+ gtk_widget_show (priv->status_label);
+ gtk_toolbar_insert (GTK_TOOLBAR (toolbar), priv->status_item, -1);
/* connect signals */
g_signal_connect (priv->entry, "key-press-event",
@@ -676,19 +731,26 @@ ephy_find_toolbar_set_embed (EphyFindToolbar *toolbar,
void
ephy_find_toolbar_find_next (EphyFindToolbar *toolbar)
{
+ EphyEmbedFindResult result;
gboolean found;
- found = ephy_embed_find_find_again (get_find (toolbar), TRUE);
+ result = ephy_embed_find_find_again (get_find (toolbar), TRUE);
+
+ found = result == EPHY_EMBED_FIND_FOUND;
set_controls (toolbar, found, found);
+ set_status (toolbar, result);
}
void
ephy_find_toolbar_find_previous (EphyFindToolbar *toolbar)
{
+ EphyEmbedFindResult result;
gboolean found;
- found = ephy_embed_find_find_again (get_find (toolbar), FALSE);
+ result = ephy_embed_find_find_again (get_find (toolbar), FALSE);
+ found = result == EPHY_EMBED_FIND_FOUND;
set_controls (toolbar, found, found);
+ set_status (toolbar, result);
}
void
@@ -705,6 +767,8 @@ ephy_find_toolbar_open (EphyFindToolbar *toolbar,
priv->links_only = links_only;
priv->explicit_focus = FALSE;
+ clear_status (toolbar);
+
if (clear_search)
{
gtk_entry_set_text (GTK_ENTRY (priv->entry), "");