summaryrefslogtreecommitdiff
path: root/font-viewer/font-view.c
diff options
context:
space:
mode:
Diffstat (limited to 'font-viewer/font-view.c')
-rw-r--r--font-viewer/font-view.c72
1 files changed, 70 insertions, 2 deletions
diff --git a/font-viewer/font-view.c b/font-viewer/font-view.c
index 1daf198c..4d77b071 100644
--- a/font-viewer/font-view.c
+++ b/font-viewer/font-view.c
@@ -60,8 +60,12 @@ typedef struct {
GtkWidget *swin_view;
GtkWidget *swin_preview;
GtkWidget *icon_view;
+ GtkWidget *search_bar;
+ GtkWidget *entry;
+ GtkWidget *search_button;
GtkTreeModel *model;
+ GtkTreeModel *filter_model;
GFile *font_file;
} FontViewApplication;
@@ -497,6 +501,39 @@ info_button_clicked_cb (GtkButton *button,
gtk_widget_show_all (dialog);
}
+static gboolean
+font_visible_func (GtkTreeModel *model,
+ GtkTreeIter *iter,
+ gpointer data)
+{
+ FontViewApplication *self = data;
+ gboolean ret;
+ const char *search;
+ char *name;
+ char *cf_name;
+ char *cf_search;
+
+ if (!gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (self->search_button)))
+ return TRUE;
+
+ search = gtk_entry_get_text (GTK_ENTRY (self->entry));
+
+ gtk_tree_model_get (model, iter,
+ COLUMN_NAME, &name,
+ -1);
+
+ cf_name = g_utf8_casefold (name, -1);
+ cf_search = g_utf8_casefold (search, -1);
+
+ ret = strstr (cf_name, cf_search) != NULL;
+
+ g_free (name);
+ g_free (cf_name);
+ g_free (cf_search);
+
+ return ret;
+}
+
static void
font_view_ensure_model (FontViewApplication *self)
{
@@ -506,6 +543,9 @@ font_view_ensure_model (FontViewApplication *self)
self->model = font_view_model_new ();
g_signal_connect (self->model, "config-changed",
G_CALLBACK (font_model_config_changed_cb), self);
+ self->filter_model = gtk_tree_model_filter_new (self->model, NULL);
+ gtk_tree_model_filter_set_visible_func (GTK_TREE_MODEL_FILTER (self->filter_model),
+ font_visible_func, self, NULL);
}
static void
@@ -579,6 +619,7 @@ icon_view_release_cb (GtkWidget *widget,
FontViewApplication *self = user_data;
GtkTreePath *path;
GtkTreeIter iter;
+ GtkTreeIter filter_iter;
gchar *font_path;
gint face_index;
GFile *file;
@@ -591,7 +632,10 @@ icon_view_release_cb (GtkWidget *widget,
event->x, event->y);
if (path != NULL &&
- gtk_tree_model_get_iter (self->model, &iter, path)) {
+ gtk_tree_model_get_iter (self->filter_model, &filter_iter, path)) {
+ gtk_tree_model_filter_convert_iter_to_child_iter (GTK_TREE_MODEL_FILTER (self->filter_model),
+ &iter,
+ &filter_iter);
gtk_tree_model_get (self->model, &iter,
COLUMN_PATH, &font_path,
COLUMN_FACE_INDEX, &face_index,
@@ -637,7 +681,7 @@ font_view_application_do_overview (FontViewApplication *self)
GtkWidget *icon_view;
GtkCellRenderer *cell;
- self->icon_view = icon_view = gtk_icon_view_new_with_model (self->model);
+ self->icon_view = icon_view = gtk_icon_view_new_with_model (self->filter_model);
g_object_set (icon_view,
"column-spacing", VIEW_COLUMN_SPACING,
"margin", VIEW_MARGIN,
@@ -751,6 +795,13 @@ static GActionEntry action_entries[] = {
};
static void
+search_text_changed (GtkEntry *entry,
+ FontViewApplication *self)
+{
+ gtk_tree_model_filter_refilter (GTK_TREE_MODEL_FILTER (self->filter_model));
+}
+
+static void
font_view_application_startup (GApplication *application)
{
FontViewApplication *self = FONT_VIEW_APPLICATION (application);
@@ -786,6 +837,9 @@ font_view_application_startup (GApplication *application)
self->toolbar = gd_main_toolbar_new ();
gtk_style_context_add_class (gtk_widget_get_style_context (self->toolbar), "menubar");
+ self->search_button = gd_main_toolbar_add_toggle (GD_MAIN_TOOLBAR (self->toolbar),
+ NULL, _("Search"),
+ FALSE);
gtk_container_add (GTK_CONTAINER (self->main_grid), self->toolbar);
self->notebook = gtk_notebook_new ();
@@ -806,6 +860,19 @@ font_view_application_startup (GApplication *application)
GTK_POLICY_AUTOMATIC, GTK_POLICY_NEVER);
gtk_container_add (GTK_CONTAINER (self->notebook), swin);
+ self->search_bar = gtk_search_bar_new();
+ gtk_container_add (GTK_CONTAINER (self->main_grid), self->search_bar);
+
+ self->entry = gtk_search_entry_new();
+ gtk_entry_set_width_chars (GTK_ENTRY (self->entry), 40);
+ gtk_container_add (GTK_CONTAINER (self->search_bar), self->entry);
+
+ g_object_bind_property (self->search_bar, "search-mode-enabled",
+ self->search_button, "active",
+ G_BINDING_BIDIRECTIONAL);
+
+ g_signal_connect (self->entry, "search-changed", G_CALLBACK (search_text_changed), self);
+
gtk_widget_show_all (window);
}
@@ -832,6 +899,7 @@ font_view_application_dispose (GObject *obj)
FontViewApplication *self = FONT_VIEW_APPLICATION (obj);
g_clear_object (&self->model);
+ g_clear_object (&self->filter_model);
G_OBJECT_CLASS (font_view_application_parent_class)->dispose (obj);
}