EnginioModel QML Type

Makes accessing collections of objects easy More...

Import Statement: import Enginio 1.0
Since: Qt 5.3

Properties

Methods

  • EnginioReply append(QJSValue object)
  • EnginioReply remove(int row)
  • EnginioReply setProperty(int row, string propertyName, QVariant value)

Detailed Description

import Enginio 1.0

The query property of the model takes a JSON object.

To get a model of each object of type "objects.city" use:

EnginioModel {
    id: enginioModel
    client: client
    query: { "objectType": "objects.city" }
}

It is then possible to use a regular Qt Quick ListView to display the list of cities that the backend contains.

ListView {
    anchors.fill: parent
    model: enginioModel
    delegate: Text {
        text: name + ": " + population
    }
}

Note that the properties of the objects can be directly accessed. In this example, we have the type "objects.city" in the backend with two properties: "name" and "population".

The model supports several function to modify the data, for example append(), remove(), setProperty()

The QML version of EnginioModel supports the same functionality as the C++ version. EnginioModel C++

Property Documentation

client : EnginioClient

The instance of EnginioClient used for this model.


operation : Enginio::Operation

The operation used for the query.


query : QJSValue

The query used to populate the model with data from the backend.

See EnginioClient::query() documentation for information on how to construct a query.

While the EnginioClient implementation of query() returns the data of a query as a JSON object, for the model the query will be interpreted as the model data.

Usually, the query is for a single object type and will return all objects in the database of that type. The model will then represent each returned object as one row. It can be limited and sorted just like its counterpart in EnginioClient.

One important thing to note is that the model cannot keep the same sorting as the backend, and thus sorting and limits are only preserved until an insertion or deletion happens.

See also EnginioClient::query().


Method Documentation

EnginioReply append(QJSValue object)

Add a new object to the model and database.

This function appends the new object to the local model cache and makes an asynchronous request to the backend.

Since adding an object to the database may fail for various reasons, the returned reply must be kept and used for error handling (see EnginioReply). If the operation fails, the object that was supposed to be appended will be removed from the local model again. If the model is used in a view and the backend does not accept the object because it violates a validator, it will be visible to the user that a new row in the view appears and disappears again.

Returns the EnginioReply from the backend

To add a "city" object to the model by appending it:

function addCity() {
    var berlin = {
        "objectType": "objects.city",
        "name": "Berlin",
        "population": 3300000
    }
    enginioModel.append(berlin)
}

EnginioReply remove(int row)

Removes the row from the model and database.

This function immediately removes the row from the local cache and sends a remove request to the Enginio backend.

Returns the EnginioReply from the backend.

See also EnginioClient::remove().


EnginioReply setProperty(int row, string propertyName, QVariant value)

Change a property of an object in the model

The property propertyName of the object at row will be set to value. The model will locally reflect the change immediately and propagage the change to the server in the background.


© 2015 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.