Table Of Contents
Source code for kivy.adapters.models
'''
SelectableDataItem
==================
.. versionadded:: 1.5
.. deprecated:: 1.10.0
The feature has been deprecated.
.. warning::
This code is still experimental, and its API is subject to change in a
future version.
Data Models
-----------
Kivy is open about the type of data used in applications built with
the system. However, base classes are sometimes needed to ensure data conforms
to the requirements of some parts of the system.
A :class:`SelectableDataItem` is a basic Python data model class that can be
used as a mixin to build data objects that are compatible with Kivy's
:class:`~kivy.adapters.adapter.Adapter`
and selection system and which work with views such as a
:class:`~kivy.uix.listview.ListView`. A boolean *is_selected*
property a requirement.
The default operation of the selection system is to not propagate selection in
views such as ListView to the underlying data: selection is by default a
view-only operation. However, in some cases, it is useful to propagate
selection to the actual data items.
You may, of course, build your own Python data model system as the backend for
a Kivy application. For instance, to use the `Google App Engine Data Modeling
<https://cloud.google.com/appengine/docs/python/datastore/datamodeling>`_
system with Kivy, you could define your class as follows::
from google.appengine.ext import db
class MySelectableDataItem(db.Model):
# ... other properties
is_selected = db.BooleanProperty()
It is easy to build such a class with plain Python.
'''
__all__ = ('SelectableDataItem', )
from kivy.utils import deprecated
[docs]class SelectableDataItem(object):
'''
A mixin class containing requirements for selection operations.
'''
@deprecated
def __init__(self, is_selected=False):
super(SelectableDataItem, self).__init__()
self._is_selected = is_selected
@property
def is_selected(self):
"""A boolean property indicating whether the data item is selected or
not."""
return self._is_selected
@is_selected.setter
def is_selected(self, value):
self._is_selected = value