diff options
-rw-r--r-- | src/main/java/de/pixart/messenger/ui/UriHandlerActivity.java | 47 |
1 files changed, 41 insertions, 6 deletions
diff --git a/src/main/java/de/pixart/messenger/ui/UriHandlerActivity.java b/src/main/java/de/pixart/messenger/ui/UriHandlerActivity.java index 1229aae2e..43d2d6db7 100644 --- a/src/main/java/de/pixart/messenger/ui/UriHandlerActivity.java +++ b/src/main/java/de/pixart/messenger/ui/UriHandlerActivity.java @@ -2,6 +2,11 @@ package de.pixart.messenger.ui; import android.app.Activity; import android.content.Intent; +import android.net.Uri; + +import de.pixart.messenger.persistance.DatabaseBackend; +import de.pixart.messenger.utils.XmppUri; +import de.pixart.messenger.xmpp.jid.Jid; public class UriHandlerActivity extends Activity { @@ -16,6 +21,41 @@ public class UriHandlerActivity extends Activity { handleIntent(intent); } + private void handleUri(Uri uri) { + final Intent intent; + final XmppUri xmppUri = new XmppUri(uri); + final int numAccounts = DatabaseBackend.getInstance(this).getAccountJids().size(); + + if (numAccounts == 0) { + intent = new Intent(getApplicationContext(), WelcomeActivity.class); + startActivity(intent); + return; + } + + if (xmppUri.isAction(XmppUri.ACTION_MESSAGE)) { + final Jid jid = xmppUri.getJid(); + final String body = xmppUri.getBody(); + + if (jid != null) { + intent = new Intent(getApplicationContext(), ShareViaAccountActivity.class); + intent.putExtra(ShareViaAccountActivity.EXTRA_CONTACT, jid.toString()); + intent.putExtra(ShareViaAccountActivity.EXTRA_BODY, body); + } else { + intent = new Intent(getApplicationContext(), ShareWithActivity.class); + intent.setAction(Intent.ACTION_SEND); + intent.setType("text/plain"); + intent.putExtra(Intent.EXTRA_TEXT, body); + } + } else { + intent = new Intent(getApplicationContext(), StartConversationActivity.class); + intent.setAction(Intent.ACTION_VIEW); + intent.setFlags(Intent.FLAG_ACTIVITY_REORDER_TO_FRONT); + intent.setData(uri); + } + + startActivity(intent); + } + private void handleIntent(Intent data) { if (data == null) { finish(); @@ -25,12 +65,7 @@ public class UriHandlerActivity extends Activity { switch (data.getAction()) { case Intent.ACTION_VIEW: case Intent.ACTION_SENDTO: - final Intent intent = new Intent(getApplicationContext(), - StartConversationActivity.class); - intent.setAction(data.getAction()); - intent.setData(data.getData()); - intent.setAction(data.getAction()); - startActivity(intent); + handleUri(data.getData()); } finish(); |