This library provides several query APIs that support custom data integration.
Query
BroadQuery
RawContactsQuery
ProfileQuery
DataQuery
To help illustrate how custom data integrates with these query APIs, we'll use the HandleName
and Gender
custom data.
ℹ️ For more info, read Integrate the gender custom data and Integrate the handle name custom data.
Custom data, just like regular data kinds, are attached to a RawContact. They follow the same rules as regular data kinds.
ℹ️ For more info, read about API Entities.
For example, you are able to get the handle names and gender of a RawContact,
val handleNames = rawContact.handleNames(contactsApi)
val gender = rawContact.gender(contactsApi)
There are also extensions that allow you to get custom data from a Contact, which can be made up of one or more RawContacts,
val handleNames = contact.handleNames(contactsApi)
val genders = contact.genders(contactsApi)
Every custom data provides an extension to the DataQuery
that allows you to query for only that
specific custom data kind.
For example, to get all available HandleName
s and Gender
s from all contacts,
val handleNames = Contacts(context).data().query().handleNames().find()
val genders = Contacts(context).data().query().genders().find()
To get all HandleName
s starting with the letter "h",
val handleNames = Contacts(context)
.data()
.query()
.handleNames()
.where { Handle startsWith "h" }
.find()
For more info, read Query specific data kinds.
All of the above mentioned APIs provide an include
function that allows you to include only a
given set of fields (data) in each of the returned entities. Custom data entries provides fields
that can be used in this function.
By default, not calling the include
function will include all fields, including custom data fields.
For example, to explicitly include all HandleName
fields,
.include(HandleNameFields.all)
For more info, read Include only certain fields for read and write operations.
The Query
, RawContactsQuery
, and DataQuery
APIs provides a where
function that allows you
to specify a matching criteria based on specific field values. Custom data entries provides fields
that can be used in this function. For example, to match HandleName
s starting with the letter "h",
.where { Handle startsWith "h" }
The BroadQuery
API provides a wherePartiallyMatches
function that NOT support matching custom
data. Only AOSP data are included in the matching process.
The ProfileQuery
API does not provide a where function as there can only be one profile Contact
per device.
The DataQuery
API provides an orderBy
function that supports custom data. For example, to order
HandleName
s,
.orderBy(HandleNameFields.Handle.asc())
The Query
, BroadQuery
, and RawContactsQuery
APIs provides an orderBy
function that only
takes in fields from the Contacts/RawContacts table, not the Data table. So there is no custom
data, or AOSP data, support for this.
The ProfileQuery
API does not provide an orderBy
function as there can only be at most one
profile Contact on the device.