[glade/modern-ui: 23/34] GladeAdaptorChooserWidget: add show-group-title property
- From: Juan Pablo Ugarte <jpu src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glade/modern-ui: 23/34] GladeAdaptorChooserWidget: add show-group-title property
- Date: Sat, 30 Dec 2017 16:36:56 +0000 (UTC)
commit df78778ae0cb3f6153f925708228c0d5754a7ff9
Author: Juan Pablo Ugarte <juanpablougarte gmail com>
Date: Mon Jun 26 23:14:44 2017 -0300
GladeAdaptorChooserWidget: add show-group-title property
gladeui/glade-adaptor-chooser-widget.c | 132 ++++++++++++++++++++++++------
gladeui/glade-adaptor-chooser-widget.ui | 4 +-
2 files changed, 108 insertions(+), 28 deletions(-)
---
diff --git a/gladeui/glade-adaptor-chooser-widget.c b/gladeui/glade-adaptor-chooser-widget.c
index 36b7fad..e37db5a 100644
--- a/gladeui/glade-adaptor-chooser-widget.c
+++ b/gladeui/glade-adaptor-chooser-widget.c
@@ -30,6 +30,7 @@
enum
{
COLUMN_ADAPTOR = 0,
+ COLUMN_GROUP,
COLUMN_NORMALIZED_NAME,
COLUMN_NORMALIZED_NAME_LEN,
N_COLUMN
@@ -37,6 +38,7 @@ enum
struct _GladeAdaptorChooserWidgetPrivate
{
+ GtkTreeView *treeview;
GtkListStore *store;
GtkTreeModelFilter *treemodelfilter;
GtkSearchEntry *searchentry;
@@ -51,6 +53,8 @@ struct _GladeAdaptorChooserWidgetPrivate
/* Properties */
_GladeAdaptorChooserWidgetFlags flags;
GladeProject *project;
+ gboolean show_group_title;
+ gchar *search_text;
};
enum
@@ -58,7 +62,8 @@ enum
PROP_0,
PROP_SHOW_FLAGS,
- PROP_PROJECT
+ PROP_PROJECT,
+ PROP_SHOW_GROUP_TITLE
};
enum
@@ -83,6 +88,11 @@ _glade_adaptor_chooser_widget_init (_GladeAdaptorChooserWidget *chooser)
static void
_glade_adaptor_chooser_widget_finalize (GObject *object)
{
+ _GladeAdaptorChooserWidgetPrivate *priv = GET_PRIVATE (object);
+
+ g_clear_pointer (&priv->search_text, g_free);
+ g_clear_object (&priv->project);
+
G_OBJECT_CLASS (_glade_adaptor_chooser_widget_parent_class)->finalize (object);
}
@@ -107,6 +117,9 @@ _glade_adaptor_chooser_widget_set_property (GObject *object,
_glade_adaptor_chooser_widget_set_project (GLADE_ADAPTOR_CHOOSER_WIDGET (object),
g_value_get_object (value));
break;
+ case PROP_SHOW_GROUP_TITLE:
+ priv->show_group_title = g_value_get_boolean (value);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -133,6 +146,9 @@ _glade_adaptor_chooser_widget_get_property (GObject *object,
case PROP_PROJECT:
g_value_set_object (value, priv->project);
break;
+ case PROP_SHOW_GROUP_TITLE:
+ g_value_set_boolean (value, priv->show_group_title);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -176,6 +192,9 @@ on_treeview_row_activated (GtkTreeView *tree_view,
gtk_tree_model_get (model, &iter, COLUMN_ADAPTOR, &adaptor, -1);
+ if (!adaptor)
+ return;
+
/* Emit selected signal */
g_signal_emit (chooser, adaptor_chooser_signals[ADAPTOR_SELECTED], 0, adaptor);
@@ -184,6 +203,21 @@ on_treeview_row_activated (GtkTreeView *tree_view,
}
static void
+on_searchentry_search_changed (GtkEntry *entry,
+ _GladeAdaptorChooserWidget *chooser)
+{
+ _GladeAdaptorChooserWidgetPrivate *priv = GET_PRIVATE (chooser);
+ const gchar *text = gtk_entry_get_text (entry);
+
+ g_clear_pointer (&priv->search_text, g_free);
+
+ if (g_utf8_strlen (text, -1))
+ priv->search_text = normalize_name (text);
+
+ gtk_tree_model_filter_refilter (priv->treemodelfilter);
+}
+
+static void
on_searchentry_activate (GtkEntry *entry, _GladeAdaptorChooserWidget *chooser)
{
_GladeAdaptorChooserWidgetPrivate *priv = GET_PRIVATE (chooser);
@@ -248,6 +282,8 @@ chooser_match_func (_GladeAdaptorChooserWidget *chooser,
COLUMN_NORMALIZED_NAME, &name,
COLUMN_NORMALIZED_NAME_LEN, &name_len,
-1);
+ if (!name)
+ return FALSE;
visible = (g_strstr_len (name, name_len, key) != NULL);
g_free (name);
@@ -264,8 +300,11 @@ treemodelfilter_visible_func (GtkTreeModel *model, GtkTreeIter *iter, gpointer d
gtk_tree_model_get (model, iter, COLUMN_ADAPTOR, &adaptor, -1);
+ if (!adaptor)
+ return priv->show_group_title && !priv->search_text;
+
/* Skip classes not available in project target version */
- if (adaptor && priv->project)
+ if (priv->project)
{
const gchar *catalog = NULL;
gint major, minor;
@@ -276,7 +315,7 @@ treemodelfilter_visible_func (GtkTreeModel *model, GtkTreeIter *iter, gpointer d
visible = GWA_VERSION_CHECK (adaptor, major, minor);
}
- if (visible && adaptor && priv->flags)
+ if (visible && priv->flags)
{
GType type = glade_widget_adaptor_get_object_type (adaptor);
_GladeAdaptorChooserWidgetFlags flags = priv->flags;
@@ -292,14 +331,10 @@ treemodelfilter_visible_func (GtkTreeModel *model, GtkTreeIter *iter, gpointer d
visible = FALSE;
}
- if (visible)
- {
- gchar *key = normalize_name (gtk_entry_get_text (GTK_ENTRY (priv->searchentry)));
- visible = chooser_match_func (data, model, key, iter);
- g_free (key);
- }
+ if (visible && priv->search_text)
+ visible = chooser_match_func (data, model, priv->search_text, iter);
- g_object_unref (adaptor);
+ g_clear_object (&adaptor);
return visible;
}
@@ -311,21 +346,52 @@ entrycompletion_match_func (GtkEntryCompletion *entry, const gchar *key, GtkTree
}
static void
-adaptor_cell_data_func (GtkTreeViewColumn *tree_column,
- GtkCellRenderer *cell,
- GtkTreeModel *tree_model,
- GtkTreeIter *iter,
- gpointer data)
+adaptor_icon_cell_data_func (GtkTreeViewColumn *tree_column,
+ GtkCellRenderer *cell,
+ GtkTreeModel *tree_model,
+ GtkTreeIter *iter,
+ gpointer data)
{
GladeWidgetAdaptor *adaptor;
gtk_tree_model_get (tree_model, iter, COLUMN_ADAPTOR, &adaptor, -1);
- if (GPOINTER_TO_SIZE (data))
- g_object_set (cell, "icon-name", glade_widget_adaptor_get_icon_name (adaptor), NULL);
+ if (adaptor)
+ g_object_set (cell, "sensitive", TRUE, "icon-name", glade_widget_adaptor_get_icon_name (adaptor), NULL);
else
- g_object_set (cell, "text", glade_widget_adaptor_get_name (adaptor), NULL);
+ g_object_set (cell, "sensitive", FALSE, "icon-name", "go-down-symbolic", NULL);
- g_object_unref (adaptor);
+ g_clear_object (&adaptor);
+}
+
+static void
+adaptor_text_cell_data_func (GtkTreeViewColumn *tree_column,
+ GtkCellRenderer *cell,
+ GtkTreeModel *tree_model,
+ GtkTreeIter *iter,
+ gpointer data)
+{
+ GladeWidgetAdaptor *adaptor;
+ gchar *group;
+
+ gtk_tree_model_get (tree_model, iter,
+ COLUMN_ADAPTOR, &adaptor,
+ COLUMN_GROUP, &group,
+ -1);
+ if (adaptor)
+ g_object_set (cell,
+ "sensitive", TRUE,
+ "text", glade_widget_adaptor_get_name (adaptor),
+ "style", PANGO_STYLE_NORMAL,
+ NULL);
+ else
+ g_object_set (cell,
+ "sensitive", FALSE,
+ "text", group,
+ "style", PANGO_STYLE_ITALIC,
+ NULL);
+
+ g_clear_object (&adaptor);
+ g_free (group);
}
static void
@@ -337,14 +403,12 @@ _glade_adaptor_chooser_widget_constructed (GObject *object)
/* Set cell data function: this save us from alocating name and icon name for each adaptor. */
gtk_tree_view_column_set_cell_data_func (priv->column_icon,
priv->icon_cell,
- adaptor_cell_data_func,
- GSIZE_TO_POINTER (TRUE),
- NULL);
+ adaptor_icon_cell_data_func,
+ NULL, NULL);
gtk_tree_view_column_set_cell_data_func (priv->column_adaptor,
priv->adaptor_cell,
- adaptor_cell_data_func,
- GSIZE_TO_POINTER (FALSE),
- NULL);
+ adaptor_text_cell_data_func,
+ NULL, NULL);
/* Set tree model filter function */
gtk_tree_model_filter_set_visible_func (priv->treemodelfilter,
treemodelfilter_visible_func,
@@ -392,6 +456,13 @@ _glade_adaptor_chooser_widget_class_init (_GladeAdaptorChooserWidgetClass *klass
0,
G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
g_object_class_install_property (object_class,
+ PROP_SHOW_GROUP_TITLE,
+ g_param_spec_boolean ("show-group-title",
+ "Show group title",
+ "Whether to show the group title",
+ FALSE,
+ G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
+ g_object_class_install_property (object_class,
PROP_PROJECT,
g_param_spec_object ("project",
"Glade Project",
@@ -406,6 +477,7 @@ _glade_adaptor_chooser_widget_class_init (_GladeAdaptorChooserWidgetClass *klass
GLADE_TYPE_WIDGET_ADAPTOR);
gtk_widget_class_set_template_from_resource (widget_class,
"/org/gnome/gladeui/glade-adaptor-chooser-widget.ui");
+ gtk_widget_class_bind_template_child_private (widget_class, _GladeAdaptorChooserWidget, treeview);
gtk_widget_class_bind_template_child_private (widget_class, _GladeAdaptorChooserWidget, store);
gtk_widget_class_bind_template_child_private (widget_class, _GladeAdaptorChooserWidget, treemodelfilter);
gtk_widget_class_bind_template_child_private (widget_class, _GladeAdaptorChooserWidget, searchentry);
@@ -415,6 +487,7 @@ _glade_adaptor_chooser_widget_class_init (_GladeAdaptorChooserWidgetClass *klass
gtk_widget_class_bind_template_child_private (widget_class, _GladeAdaptorChooserWidget, column_adaptor);
gtk_widget_class_bind_template_child_private (widget_class, _GladeAdaptorChooserWidget, adaptor_cell);
gtk_widget_class_bind_template_callback (widget_class, on_treeview_row_activated);
+ gtk_widget_class_bind_template_callback (widget_class, on_searchentry_search_changed);
gtk_widget_class_bind_template_callback (widget_class, on_searchentry_activate);
}
@@ -455,7 +528,7 @@ _glade_adaptor_chooser_widget_populate (_GladeAdaptorChooserWidget *chooser)
void
_glade_adaptor_chooser_widget_add_catalog (_GladeAdaptorChooserWidget *chooser,
- GladeCatalog *catalog)
+ GladeCatalog *catalog)
{
GList *groups;
@@ -468,7 +541,7 @@ _glade_adaptor_chooser_widget_add_catalog (_GladeAdaptorChooserWidget *chooser,
void
_glade_adaptor_chooser_widget_add_group (_GladeAdaptorChooserWidget *chooser,
- GladeWidgetGroup *group)
+ GladeWidgetGroup *group)
{
_GladeAdaptorChooserWidgetPrivate *priv;
const GList *adaptors;
@@ -476,6 +549,11 @@ _glade_adaptor_chooser_widget_add_group (_GladeAdaptorChooserWidget *chooser,
g_return_if_fail (GLADE_IS_ADAPTOR_CHOOSER_WIDGET (chooser));
priv = GET_PRIVATE (chooser);
+ if (priv->show_group_title)
+ gtk_list_store_insert_with_values (priv->store, NULL, -1,
+ COLUMN_GROUP, glade_widget_group_get_title (group),
+ -1);
+
for (adaptors = glade_widget_group_get_adaptors (group); adaptors;
adaptors = g_list_next (adaptors))
store_append_adaptor (priv->store, adaptors->data);
diff --git a/gladeui/glade-adaptor-chooser-widget.ui b/gladeui/glade-adaptor-chooser-widget.ui
index 4ff85df..4819b23 100644
--- a/gladeui/glade-adaptor-chooser-widget.ui
+++ b/gladeui/glade-adaptor-chooser-widget.ui
@@ -6,6 +6,8 @@
<columns>
<!-- column-name adaptor -->
<column type="GObject"/>
+ <!-- column-name group -->
+ <column type="gchararray"/>
<!-- column-name normalized-name -->
<column type="gchararray"/>
<!-- column-name normalized-name-len -->
@@ -38,7 +40,7 @@
<property name="completion">entrycompletion</property>
<property name="input_hints">GTK_INPUT_HINT_WORD_COMPLETION | GTK_INPUT_HINT_NONE</property>
<signal name="activate" handler="on_searchentry_activate" swapped="no"/>
- <signal name="search-changed" handler="gtk_tree_model_filter_refilter" object="treemodelfilter"
swapped="yes"/>
+ <signal name="search-changed" handler="on_searchentry_search_changed" swapped="no"/>
</object>
<packing>
<property name="expand">False</property>
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]