Skip to content

Commit

Permalink
Merge pull request #4745 from johnjohndoe/sharecompat
Browse files Browse the repository at this point in the history
Use ShareCompat.IntentBuilder for sharing content
  • Loading branch information
bmarty authored Jan 3, 2022
2 parents ff2e7d8 + 74363ff commit 9534abe
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 10 deletions.
1 change: 1 addition & 0 deletions changelog.d/4745.misc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Open share UI provides by the system when sharing media or text.
Original file line number Diff line number Diff line change
Expand Up @@ -305,26 +305,28 @@ fun shareMedia(context: Context, file: File, mediaMimeType: String?) {
return
}

val sendIntent = ShareCompat.IntentBuilder(context)
val chooserIntent = ShareCompat.IntentBuilder(context)
.setType(mediaMimeType)
.setStream(mediaUri)
.getIntent()
.setChooserTitle(R.string.share)
.createChooserIntent()

sendShareIntent(context, sendIntent)
createChooser(context, chooserIntent)
}

fun shareText(context: Context, text: String) {
val sendIntent = Intent()
sendIntent.action = Intent.ACTION_SEND
sendIntent.type = "text/plain"
sendIntent.putExtra(Intent.EXTRA_TEXT, text)
val chooserIntent = ShareCompat.IntentBuilder(context)
.setType("text/plain")
.setText(text)
.setChooserTitle(R.string.share)
.createChooserIntent()

sendShareIntent(context, sendIntent)
createChooser(context, chooserIntent)
}

private fun sendShareIntent(context: Context, intent: Intent) {
private fun createChooser(context: Context, intent: Intent) {
try {
context.startActivity(Intent.createChooser(intent, context.getString(R.string.share)))
context.startActivity(intent)
} catch (activityNotFoundException: ActivityNotFoundException) {
context.toast(R.string.error_no_external_application_found)
}
Expand Down

0 comments on commit 9534abe

Please sign in to comment.