mirror of
https://github.com/SimpleMobileTools/Simple-Calendar.git
synced 2025-06-05 21:59:17 +02:00
prefetch contacts available for attendee autocompletion
This commit is contained in:
@ -3,9 +3,12 @@ package com.simplemobiletools.calendar.pro.activities
|
|||||||
import android.app.DatePickerDialog
|
import android.app.DatePickerDialog
|
||||||
import android.app.TimePickerDialog
|
import android.app.TimePickerDialog
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
|
import android.database.Cursor
|
||||||
import android.net.Uri
|
import android.net.Uri
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.provider.CalendarContract
|
import android.provider.CalendarContract
|
||||||
|
import android.provider.ContactsContract
|
||||||
|
import android.text.TextUtils
|
||||||
import android.text.method.LinkMovementMethod
|
import android.text.method.LinkMovementMethod
|
||||||
import android.view.Menu
|
import android.view.Menu
|
||||||
import android.view.MenuItem
|
import android.view.MenuItem
|
||||||
@ -70,6 +73,7 @@ class EventActivity : SimpleActivity() {
|
|||||||
private var mWasContactsPermissionChecked = false
|
private var mWasContactsPermissionChecked = false
|
||||||
private var mAttendees = ArrayList<Attendee>()
|
private var mAttendees = ArrayList<Attendee>()
|
||||||
private var mAttendeeViews = ArrayList<MyEditText>()
|
private var mAttendeeViews = ArrayList<MyEditText>()
|
||||||
|
private var mAvailableContacts = ArrayList<Attendee>()
|
||||||
|
|
||||||
private lateinit var mEventStartDateTime: DateTime
|
private lateinit var mEventStartDateTime: DateTime
|
||||||
private lateinit var mEventEndDateTime: DateTime
|
private lateinit var mEventEndDateTime: DateTime
|
||||||
@ -96,6 +100,7 @@ class EventActivity : SimpleActivity() {
|
|||||||
runOnUiThread {
|
runOnUiThread {
|
||||||
gotEvent(savedInstanceState, localEventType, event)
|
gotEvent(savedInstanceState, localEventType, event)
|
||||||
}
|
}
|
||||||
|
fillAvailableContacts()
|
||||||
}.start()
|
}.start()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1113,6 +1118,19 @@ class EventActivity : SimpleActivity() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun fillAvailableContacts() {
|
||||||
|
mAvailableContacts = getEmails()
|
||||||
|
|
||||||
|
val names = getNames()
|
||||||
|
mAvailableContacts.forEach {
|
||||||
|
val contactId = it.contactId
|
||||||
|
val name = names.firstOrNull { it.contactId == contactId }?.name
|
||||||
|
if (name != null) {
|
||||||
|
it.name = name
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private fun updateAttendees() {
|
private fun updateAttendees() {
|
||||||
mAttendees.forEach {
|
mAttendees.forEach {
|
||||||
addAttendee(it.getPublicName())
|
addAttendee(it.getPublicName())
|
||||||
@ -1160,11 +1178,78 @@ class EventActivity : SimpleActivity() {
|
|||||||
val attendeeEmails = mAttendeeViews.map { it.value }.filter { it.isNotEmpty() }.toMutableList() as ArrayList<String>
|
val attendeeEmails = mAttendeeViews.map { it.value }.filter { it.isNotEmpty() }.toMutableList() as ArrayList<String>
|
||||||
val attendees = ArrayList<Attendee>()
|
val attendees = ArrayList<Attendee>()
|
||||||
attendeeEmails.mapTo(attendees) {
|
attendeeEmails.mapTo(attendees) {
|
||||||
Attendee("", it, CalendarContract.Attendees.ATTENDEE_STATUS_INVITED)
|
Attendee(0, "", it, CalendarContract.Attendees.ATTENDEE_STATUS_INVITED)
|
||||||
}
|
}
|
||||||
return Gson().toJson(attendees)
|
return Gson().toJson(attendees)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun getNames(): List<Attendee> {
|
||||||
|
val contacts = ArrayList<Attendee>()
|
||||||
|
val uri = ContactsContract.Data.CONTENT_URI
|
||||||
|
val projection = arrayOf(
|
||||||
|
ContactsContract.Data.CONTACT_ID,
|
||||||
|
ContactsContract.CommonDataKinds.StructuredName.PREFIX,
|
||||||
|
ContactsContract.CommonDataKinds.StructuredName.GIVEN_NAME,
|
||||||
|
ContactsContract.CommonDataKinds.StructuredName.MIDDLE_NAME,
|
||||||
|
ContactsContract.CommonDataKinds.StructuredName.FAMILY_NAME,
|
||||||
|
ContactsContract.CommonDataKinds.StructuredName.SUFFIX)
|
||||||
|
|
||||||
|
val selection = "${ContactsContract.Data.MIMETYPE} = ?"
|
||||||
|
val selectionArgs = arrayOf(ContactsContract.CommonDataKinds.StructuredName.CONTENT_ITEM_TYPE)
|
||||||
|
|
||||||
|
var cursor: Cursor? = null
|
||||||
|
try {
|
||||||
|
cursor = contentResolver.query(uri, projection, selection, selectionArgs, null)
|
||||||
|
if (cursor?.moveToFirst() == true) {
|
||||||
|
do {
|
||||||
|
val id = cursor.getIntValue(ContactsContract.Data.CONTACT_ID)
|
||||||
|
val prefix = cursor.getStringValue(ContactsContract.CommonDataKinds.StructuredName.PREFIX) ?: ""
|
||||||
|
val firstName = cursor.getStringValue(ContactsContract.CommonDataKinds.StructuredName.GIVEN_NAME) ?: ""
|
||||||
|
val middleName = cursor.getStringValue(ContactsContract.CommonDataKinds.StructuredName.MIDDLE_NAME) ?: ""
|
||||||
|
val surname = cursor.getStringValue(ContactsContract.CommonDataKinds.StructuredName.FAMILY_NAME) ?: ""
|
||||||
|
val suffix = cursor.getStringValue(ContactsContract.CommonDataKinds.StructuredName.SUFFIX) ?: ""
|
||||||
|
|
||||||
|
val names = arrayListOf(prefix, firstName, middleName, surname, suffix).filter { it.trim().isNotEmpty() }
|
||||||
|
val fullName = TextUtils.join("", names)
|
||||||
|
if (fullName.isNotEmpty()) {
|
||||||
|
val contact = Attendee(id, fullName, "", 0)
|
||||||
|
contacts.add(contact)
|
||||||
|
}
|
||||||
|
} while (cursor.moveToNext())
|
||||||
|
}
|
||||||
|
} catch (ignored: Exception) {
|
||||||
|
} finally {
|
||||||
|
cursor?.close()
|
||||||
|
}
|
||||||
|
return contacts
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun getEmails(): ArrayList<Attendee> {
|
||||||
|
val contacts = ArrayList<Attendee>()
|
||||||
|
val uri = ContactsContract.CommonDataKinds.Email.CONTENT_URI
|
||||||
|
val projection = arrayOf(
|
||||||
|
ContactsContract.Data.CONTACT_ID,
|
||||||
|
ContactsContract.CommonDataKinds.Email.DATA
|
||||||
|
)
|
||||||
|
|
||||||
|
var cursor: Cursor? = null
|
||||||
|
try {
|
||||||
|
cursor = contentResolver.query(uri, projection, null, null, null)
|
||||||
|
if (cursor?.moveToFirst() == true) {
|
||||||
|
do {
|
||||||
|
val id = cursor.getIntValue(ContactsContract.Data.CONTACT_ID)
|
||||||
|
val email = cursor.getStringValue(ContactsContract.CommonDataKinds.Email.DATA) ?: continue
|
||||||
|
val contact = Attendee(id, "", email, 0)
|
||||||
|
contacts.add(contact)
|
||||||
|
} while (cursor.moveToNext())
|
||||||
|
}
|
||||||
|
} catch (ignored: Exception) {
|
||||||
|
} finally {
|
||||||
|
cursor?.close()
|
||||||
|
}
|
||||||
|
return contacts
|
||||||
|
}
|
||||||
|
|
||||||
private fun updateIconColors() {
|
private fun updateIconColors() {
|
||||||
val textColor = config.textColor
|
val textColor = config.textColor
|
||||||
event_time_image.applyColorFilter(textColor)
|
event_time_image.applyColorFilter(textColor)
|
||||||
|
@ -514,7 +514,7 @@ class CalDAVHelper(val context: Context) {
|
|||||||
val name = cursor.getStringValue(CalendarContract.Attendees.ATTENDEE_NAME)
|
val name = cursor.getStringValue(CalendarContract.Attendees.ATTENDEE_NAME)
|
||||||
val email = cursor.getStringValue(CalendarContract.Attendees.ATTENDEE_EMAIL)
|
val email = cursor.getStringValue(CalendarContract.Attendees.ATTENDEE_EMAIL)
|
||||||
val status = cursor.getIntValue(CalendarContract.Attendees.ATTENDEE_STATUS)
|
val status = cursor.getIntValue(CalendarContract.Attendees.ATTENDEE_STATUS)
|
||||||
val attendee = Attendee(name, email, status)
|
val attendee = Attendee(0, name, email, status)
|
||||||
attendees.add(attendee)
|
attendees.add(attendee)
|
||||||
} while (cursor.moveToNext())
|
} while (cursor.moveToNext())
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
package com.simplemobiletools.calendar.pro.models
|
package com.simplemobiletools.calendar.pro.models
|
||||||
|
|
||||||
data class Attendee(val name: String, val email: String, val status: Int) {
|
data class Attendee(val contactId: Int, var name: String, val email: String, val status: Int) {
|
||||||
fun getPublicName() = if (name.isNotEmpty()) name else email
|
fun getPublicName() = if (name.isNotEmpty()) name else email
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user