DelegateModelGroup QML Type
Encapsulates a filtered set of visual data items. More...
Import Statement: | import QtQml.Models |
Properties
- count : int
- includeByDefault : bool
- name : string
Signals
- changed(array removed, array inserted)
Methods
- addGroups(int index, int count, stringlist groups)
- create(int index)
- create(int index, jsdict data, array groups)
- create(jsdict data, array groups)
- object get(int index)
- insert(int index, jsdict data, array groups)
- insert(jsdict data, var groups)
- move(var from, var to, int count)
- remove(int index, int count)
- removeGroups(int index, int count, stringlist groups)
- resolve(int from, int to)
- setGroups(int index, int count, stringlist groups)
Detailed Description
The DelegateModelGroup type provides a means to address the model data of a DelegateModel's delegate items, as well as sort and filter these delegate items.
The initial set of instantiable delegate items in a DelegateModel is represented by its items group, which normally directly reflects the contents of the model assigned to DelegateModel::model. This set can be changed to the contents of any other member of DelegateModel::groups by assigning the name of that DelegateModelGroup to the DelegateModel::filterOnGroup property.
The data of an item in a DelegateModelGroup can be accessed using the get() function, which returns information about group membership and indexes as well as model data. In combination with the move() function this can be used to implement view sorting, with remove() to filter items out of a view, or with setGroups() and Package delegates to categorize items into different views. Different groups can only be sorted independently if they are disjunct. Moving an item in one group will also move it in all other groups it is a part of.
Data from models can be supplemented by inserting data directly into a DelegateModelGroup with the insert() function. This can be used to introduce mock items into a view, or placeholder items that are later resolved to real model data when it becomes available.
Delegate items can also be instantiated directly from a DelegateModelGroup using the create() function, making it possible to use DelegateModel without an accompanying view type or to cherry-pick specific items that should be instantiated irregardless of whether they're currently within a view's visible area.
See also QML Dynamic View Ordering Tutorial.
Property Documentation
count : int |
This property holds the number of items in the group.
includeByDefault : bool |
This property holds whether new items are assigned to this group by default.
name : string |
This property holds the name of the group.
Each group in a model must have a unique name starting with a lower case letter.
Signal Documentation
changed(array removed, array inserted) |
This signal is emitted when items have been removed from or inserted into the group.
Each object in the removed and inserted arrays has two values; the index of the first item inserted or removed and a count of the number of consecutive items inserted or removed.
Each index is adjusted for previous changes with all removed items preceding any inserted items.
Note: The corresponding handler is onChanged
.
Method Documentation
Creates a new entry at index in a DelegateModel with the values from data that correspond to roles in the model assigned to DelegateModel::model.
If no index is supplied the data is appended to the model.
The optional groups parameter identifies the groups the new entry should belong to, if unspecified this is equal to the group insert was called on.
Data inserted into a DelegateModel can later be merged with an existing entry in DelegateModel::model using the resolve() function. This can be used to create placeholder items that are later replaced by actual data.
Returns a reference to the instantiated item at index in the group.
If a data object is provided it will be inserted at index and an item referencing this new entry will be returned. The optional groups parameter identifies the groups the new entry should belong to, if unspecified this is equal to the group create() was called on.
All items returned by create are added to the persistedItems group. Items in this group remain instantiated when not referenced by any view.
object get(int index) |
Returns a javascript object describing the item at index in the group.
The returned object contains the same information that is available to a delegate from the DelegateModel attached as well as the model for that item. It has the properties:
- model The model data of the item. This is the same as the model context property in a delegate
- groups A list the of names of groups the item is a member of. This property can be written to change the item's membership.
- inItems Whether the item belongs to the items group. Writing to this property will add or remove the item from the group.
- itemsIndex The index of the item within the items group.
- in<GroupName> Whether the item belongs to the dynamic group groupName. Writing to this property will add or remove the item from the group.
- <groupName>Index The index of the item within the dynamic group groupName.
- isUnresolved Whether the item is bound to an index in the model assigned to DelegateModel::model. Returns true if the item is not bound to the model, and false if it is.
Moves count at from in a group to a new position.
Note: The DelegateModel acts as a proxy model: it holds the delegates in a different order than the underlying model has them. Any subsequent changes to the underlying model will not undo whatever reordering you have done via this function.
Removes count items starting at index from groups.
Binds an unresolved item at from to an item in DelegateModel::model at index to.
Unresolved items are entries whose data has been inserted into a DelegateModelGroup instead of being derived from a DelegateModel::model index. Resolving an item will replace the item at the target index with the unresolved item. A resolved an item will reflect the data of the source model at its bound index and will move when that index moves like any other item.
If a new item is replaced in the DelegateModelGroup onChanged() handler its insertion and replacement will be communicated to views as an atomic operation, creating the appearance that the model contents have not changed, or if the unresolved and model item are not adjacent that the previously unresolved item has simply moved.
Changes the group membership of count items starting at index. The items are removed from their existing groups and added to groups.