FilterListModel

class FilterListModel(**properties: Any)

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

class FilterListModel
classmethod new(model: ListModel | None = None, filter: Filter | None = None) FilterListModel

Creates a new GtkFilterListModel that will filter model using the given filter.

Parameters:
  • model – the model to sort

  • filter – filter

Methods

class FilterListModel
get_filter() Filter | None

Gets the GtkFilter currently set on self.

get_incremental() bool

Returns whether incremental filtering is enabled.

See set_incremental.

get_model() ListModel | None

Gets the model currently filtered or None if none.

get_pending() int

Returns the number of items that have not been filtered yet.

You can use this value to check if self is 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 incremental is False - 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 GtkFilterListModel will 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_pending for progress information about an ongoing incremental filtering operation.

Parameters:

incrementalTrue to 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 model conforms to the item type of self. 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.filter: Filter

The filter for this model.

props.incremental: bool

If the model should filter items incrementally.

props.item_type: type

The type of items. See get_item_type.

Added in version 4.8.

props.model: ListModel

The model being filtered.

props.n_items: int

The number of items. See get_n_items.

Added in version 4.8.

props.pending: int

Number of items not yet filtered.