add some more third party intent handling

This commit is contained in:
tibbi
2018-01-02 14:57:19 +01:00
parent f2f22a34ff
commit 29c16d543f
3 changed files with 33 additions and 12 deletions

View File

@ -94,6 +94,15 @@
<data android:mimeType="vnd.android.cursor.item/group"/> <data android:mimeType="vnd.android.cursor.item/group"/>
</intent-filter> </intent-filter>
<intent-filter android:label="@string/edit_contact">
<action android:name="android.intent.action.VIEW"/>
<category android:name="android.intent.category.DEFAULT"/>
<data android:mimeType="vnd.android.cursor.item/person"/>
<data android:mimeType="vnd.android.cursor.item/contact"/>
<data android:mimeType="vnd.android.cursor.item/raw_contact"/>
</intent-filter>
<intent-filter> <intent-filter>
<action android:name="android.intent.action.EDIT"/> <action android:name="android.intent.action.EDIT"/>
<category android:name="android.intent.category.DEFAULT"/> <category android:name="android.intent.category.DEFAULT"/>

View File

@ -95,10 +95,16 @@ class ContactActivity : SimpleActivity() {
private fun initContact() { private fun initContact() {
var contactId = intent.getIntExtra(CONTACT_ID, 0) var contactId = intent.getIntExtra(CONTACT_ID, 0)
if (contactId == 0 && intent.action == ContactsContract.QuickContact.ACTION_QUICK_CONTACT) { val action = intent.action
if (contactId == 0 && (action == ContactsContract.QuickContact.ACTION_QUICK_CONTACT || action == Intent.ACTION_VIEW)) {
val data = intent.data val data = intent.data
if (data != null) { if (data != null) {
val rawId = getContactRawId(data) ?: -1 val rawId = if (data.path.contains("lookup")) {
getLookupUriRawId(data)
} else {
getContactUriRawId(data)
}
if (rawId != -1) { if (rawId != -1) {
contactId = rawId contactId = rawId
} }

View File

@ -48,10 +48,17 @@ fun Context.sendSMSIntent(recipient: String) {
} }
@TargetApi(Build.VERSION_CODES.LOLLIPOP) @TargetApi(Build.VERSION_CODES.LOLLIPOP)
fun Context.getContactRawId(dataUri: Uri): Int? { fun Context.getLookupUriRawId(dataUri: Uri): Int {
val lookupKey = getLookupKeyFromUri(dataUri) val lookupKey = getLookupKeyFromUri(dataUri)
if (lookupKey != null && isLollipopPlus()) { if (lookupKey != null && isLollipopPlus()) {
val uri = lookupContactUri(lookupKey, this) val uri = lookupContactUri(lookupKey, this)
return getContactUriRawId(uri)
}
return -1
}
@TargetApi(Build.VERSION_CODES.LOLLIPOP)
fun Context.getContactUriRawId(uri: Uri): Int {
val projection = arrayOf(ContactsContract.Contacts.NAME_RAW_CONTACT_ID) val projection = arrayOf(ContactsContract.Contacts.NAME_RAW_CONTACT_ID)
var cursor: Cursor? = null var cursor: Cursor? = null
try { try {
@ -62,7 +69,6 @@ fun Context.getContactRawId(dataUri: Uri): Int? {
} finally { } finally {
cursor?.close() cursor?.close()
} }
}
return -1 return -1
} }