This library provides the SimContactsInsert
API that allows you to create/insert contacts into the
SIM card.
An instance of the SimContactsInsert
API is obtained by,
val insert = Contacts(context).sim().insert()
Note that SIM card inserts will only work if there is a SIM card in the ready state. For more info, read SIM card state.
To create/insert a new contact into the SIM card,
val insertResult = Contacts(context)
.sim()
.insert()
.simContact(NewSimContact(name = "Dude", number = "5555555555"))
.commit()
If you need to insert multiple contacts,
val newContact1 = NewSimContact(name = "Dude1", number = "1234567890")
val newContact2 = NewSimContact(name = "Dude2", number = "0987654321")
val insertResult = Contacts(context)
.sim()
.insert()
.simContacts(newContact1, newContact2)
.commit()
For more info, read about SIM Contacts
For more info, read about SIM Contacts
To execute the insert,
.commit()
The commit
function returns a Result
.
To check if all inserts succeeded,
val allInsertsSuccessful = insertResult.isSuccessful
To check if a particular insert succeeded,
val firstInsertSuccessful = insertResult.isSuccessful(newContact1)
To get all newly created SimContacts, you may use the extensions provided
in SimContactsInsertResult
,
val simContacts = insertResult.simContacts(contactsApi)
To get a particular simContact,
val simContact = insertResult.simContact(contactsApi, newSimContact1)
⚠️ TheIccProvider
does not yet return the row ID of newly inserted contacts. Look at the "TODO" at line 259 of Android's IccProvider. Therefore, this library's insert API can only support getting the new rows from the result with some limitations around duplicate entries (see documentation inSimContactsInsertResult
).
The insert may fail for a particular SIM contact for various reasons,
insertResult.failureReason(newSimContact1)?.let {
when (it) {
NAME_EXCEEDED_MAX_CHAR_LIMIT -> tellUserTheNameIsTooLong()
NUMBER_EXCEEDED_MAX_CHAR_LIMIT -> tellUserTheNumberIsTooLong()
NAME_AND_NUMBER_ARE_BLANK -> tellUserTheNameAndNumberCannotBothBeBlank()
UNKNOWN -> showGenericErrorMessage()
}
}
To cancel an insert amid execution,
.commit { returnTrueIfInsertShouldBeCancelled() }
The commit
function optionally takes in a function that, if it returns true, will cancel insert
processing as soon as possible. The function is called numerous times during insert processing to
check if processing should stop or continue. This gives you the option to cancel the insert.
For example, to automatically cancel the insert inside a Kotlin coroutine when the coroutine is cancelled,
launch {
withContext(coroutineContext) {
val insertResult = insert.commit { !isActive }
}
}
Inserts are executed when the commit
function is invoked. The work is done in the same thread as
the call-site. This may result in a choppy UI.
To perform the work in a different thread, use the Kotlin coroutine extensions provided in
the async
module. For more info,
read Execute work outside of the UI thread using coroutines.
You may, of course, use other multi-threading libraries or just do it yourself =)
ℹ️ Extensions for Kotlin Flow and RxJava are also in the project roadmap.
Inserts require the android.permission.WRITE_CONTACTS
permission. If not granted, the insert will
do nothing and return a failed result.
To perform the insert with permission, use the extensions provided in the permissions
module.
For more info, read Permissions handling using coroutines.
You may, of course, use other permission handling libraries or just do it yourself =)