FilterListModel#
Superclasses: Object
Implemented Interfaces: ListModel, SectionModel
GtkFilterListModel is a list model that filters the elements of
the underlying model according to a GtkFilter.
It hides some elements from the other model according to
criteria given by a GtkFilter.
The model can be set up to do incremental filtering, so that
filtering long lists doesn’t block the UI. See
set_incremental for details.
GtkFilterListModel passes through sections from the underlying model.
Constructors#
Methods#
- class FilterListModel
-
- get_incremental() bool#
Returns whether incremental filtering is enabled.
See
set_incremental.
- get_pending() int#
Returns the number of items that have not been filtered yet.
You can use this value to check if
selfis busy filtering by comparing the return value to 0 or you can compute the percentage of the filter remaining by dividing the return value by the total number of items in the underlying model:pending = gtk_filter_list_model_get_pending (self); model = gtk_filter_list_model_get_model (self); percentage = pending / (double) g_list_model_get_n_items (model);
If no filter operation is ongoing - in particular when
incrementalisFalse- this function returns 0.
- set_filter(filter: Filter | None = None) None#
Sets the filter used to filter items.
- Parameters:
filter – filter to use
- set_incremental(incremental: bool) None#
Sets the filter model to do an incremental sort.
When incremental filtering is enabled, the
GtkFilterListModelwill not run filters immediately, but will instead queue an idle handler that incrementally filters the items and adds them to the list. This of course means that items are not instantly added to the list, but only appear incrementally.When your filter blocks the UI while filtering, you might consider turning this on. Depending on your model and filters, this may become interesting around 10,000 to 100,000 items.
By default, incremental filtering is disabled.
See
get_pendingfor progress information about an ongoing incremental filtering operation.- Parameters:
incremental –
Trueto enable incremental filtering
- set_model(model: ListModel | None = None) None#
Sets the model to be filtered.
Note that GTK makes no effort to ensure that
modelconforms to the item type ofself. It assumes that the caller knows what they are doing and have set up an appropriate filter to ensure that item types match.- Parameters:
model – The model to be filtered
Properties#
- class FilterListModel
-
- props.item_type: GType#
The type of the None singleton.
Added in version 4.8.