diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 10899b632f..343b4cc4db 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -110,11 +110,6 @@ - - - - - @@ -164,6 +159,11 @@ android:name="android.service.chooser.chooser_target_service" android:value="androidx.sharetarget.ChooserTargetServiceCompat" /> + + + + + diff --git a/app/src/main/java/com/nextcloud/talk/conversationlist/ConversationsListActivity.kt b/app/src/main/java/com/nextcloud/talk/conversationlist/ConversationsListActivity.kt index a2c4296a6d..239069e871 100644 --- a/app/src/main/java/com/nextcloud/talk/conversationlist/ConversationsListActivity.kt +++ b/app/src/main/java/com/nextcloud/talk/conversationlist/ConversationsListActivity.kt @@ -33,6 +33,8 @@ import androidx.work.WorkInfo import androidx.work.WorkManager import autodagger.AutoInjector import com.google.android.material.dialog.MaterialAlertDialogBuilder +import com.nextcloud.android.common.core.utils.ecosystem.AccountReceiverCallback +import com.nextcloud.android.common.core.utils.ecosystem.EcosystemManager import com.nextcloud.talk.R import com.nextcloud.talk.account.BrowserLoginActivity import com.nextcloud.talk.account.ServerSelectionActivity @@ -168,6 +170,8 @@ class ConversationsListActivity : BaseActivity() { private var selectedMessageId: String? = null private var pendingDirectShareToken: String? = null + lateinit var ecosystemManager: EcosystemManager + private val onBackPressedCallback = object : OnBackPressedCallback(true) { override fun handleOnBackPressed() { if (forwardMessage) { @@ -181,6 +185,7 @@ class ConversationsListActivity : BaseActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) NextcloudTalkApplication.sharedApplication!!.componentApplication.inject(this) + ecosystemManager = EcosystemManager(this@ConversationsListActivity) currentUser = currentUserProviderOld.currentUser.blockingGet() @@ -201,6 +206,9 @@ class ConversationsListActivity : BaseActivity() { ) } + intent?.let { + handleEcoSystemIntent(it) + } initObservers() } @@ -209,6 +217,11 @@ class ConversationsListActivity : BaseActivity() { outState.putBoolean(KEY_ACCOUNT_DIALOG_VISIBLE, showAccountDialogState.value) } + override fun onNewIntent(intent: Intent) { + super.onNewIntent(intent) + handleEcoSystemIntent(intent) + } + private fun buildScreenState() = ConversationsListScreenState( currentUser = currentUser, @@ -302,6 +315,35 @@ class ConversationsListActivity : BaseActivity() { onConversationOpsAction = { action, conversation -> handleConversationOpsAction(action, conversation) } ) + private fun handleEcoSystemIntent(intent: Intent) { + ecosystemManager.receiveAccount( + intent, + object : AccountReceiverCallback { + @SuppressLint("UseKtx") + override fun onAccountReceived(accountName: String) { + val users = userManager.users.blockingGet() + val baseUrl = accountName.substringAfterLast("@") + val accountName = accountName.substringBeforeLast("@") + val user = users.firstOrNull { user -> + user.username == accountName && baseUrl == user.baseUrl?.toUri()?.host + } + if (user != null) { + userManager.setUserAsActive(user) + val intent = Intent(context, ConversationsListActivity::class.java) + startActivity(intent) + } else { + showSnackbar(getString(R.string.nc_no_account_found)) + } + Log.d(TAG, accountName) + } + + override fun onAccountError(reason: String) { + Log.d(TAG, "handleEcosystemIntent: $reason") + } + } + ) + } + override fun onPostCreate(savedInstanceState: Bundle?) { super.onPostCreate(savedInstanceState) diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index d856713cc5..edc86177be 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -1001,4 +1001,5 @@ How to translate with transifex: Nextcloud app suggestions in account chooser dialog Turn on background blur Turn off background blur + Account not found