Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(share_plus)!: SharePlus refactor #3404

Open
wants to merge 24 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
63a1c06
created new SharePlus public API
miquelbeltran Dec 18, 2024
cb779d1
file cleanup
miquelbeltran Dec 18, 2024
a9fd2fc
implemented Linux
miquelbeltran Dec 18, 2024
1ebcf0d
windows fallback implementation and documentation
miquelbeltran Dec 18, 2024
bc7d7ba
update example
miquelbeltran Dec 18, 2024
5952490
create constructor, fix linux and windows tests
miquelbeltran Dec 18, 2024
9294109
implemented web
miquelbeltran Dec 18, 2024
52ea7ab
implementing the method channel
miquelbeltran Dec 18, 2024
d2d38a3
remove unnecessary import
miquelbeltran Dec 18, 2024
031afbe
implemented and tested Android
miquelbeltran Dec 18, 2024
c03c6d5
fixing comments
miquelbeltran Dec 18, 2024
c67216e
add SharePlus public API tests
miquelbeltran Dec 19, 2024
91efda9
improve deprecated warning
miquelbeltran Dec 19, 2024
ed77e6d
refactor ios code
miquelbeltran Dec 19, 2024
5938996
backwards compatible with subject on iOS
miquelbeltran Dec 19, 2024
c595508
implemented macos
miquelbeltran Dec 19, 2024
69f0bad
Refactor windows
miquelbeltran Dec 20, 2024
c2bd175
update documentation
miquelbeltran Dec 20, 2024
476c7ce
Merge branch 'main' into 3403-share-plus-refactor
miquelbeltran Dec 20, 2024
869e03b
fix format
miquelbeltran Dec 20, 2024
d0504d2
Merge branch 'main' into 3403-share-plus-refactor
miquelbeltran Feb 20, 2025
e7ef5f2
Merge branch 'main' into 3403-share-plus-refactor
miquelbeltran Apr 1, 2025
f5ab0eb
Update packages/share_plus/share_plus/README.md
miquelbeltran Apr 1, 2025
bad0154
fix analysis in integration test
miquelbeltran Apr 4, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
121 changes: 92 additions & 29 deletions packages/share_plus/share_plus/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,11 @@ on iOS, or equivalent platform content sharing methods.

## Platform Support

| Method | Android | iOS | MacOS | Web | Linux | Windows |
| :-----------: | :-----: | :-: | :---: | :-: | :---: | :----: |
| `share` | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
| `shareUri` | | ✅ | | | | |
| `shareXFiles` | ✅ | ✅ | ✅ | ✅ | | ✅ |
| Shared content | Android | iOS | MacOS | Web | Linux | Windows |
| :------------: | :-----: | :-: | :---: | :-: | :---: | :-----: |
| Text | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
| URI | | | | As text | As text | As text |
| Files | ✅ | ✅ | ✅ | ✅ | | ✅ |

Also compatible with Windows and Linux by using "mailto" to share text via Email.

Expand Down Expand Up @@ -47,23 +47,30 @@ import 'package:share_plus/share_plus.dart';

### Share Text

Invoke the static `share()` method anywhere in your Dart code.
Access the `SharePlus` instance via `SharePlus.instance`.
Then, invoke the `share()` method anywhere in your Dart code.

```dart
Share.share('check out my website https://example.com');
SharePlus.instance.share(
ShareParams(text: 'check out my website https://example.com')
);
```

The `share` method also takes an optional `subject` that will be used when
sharing to email.
The `share()` method requires the `ShareParams` object,
which contains the content to share.

```dart
Share.share('check out my website https://example.com', subject: 'Look what I made!');
```
These are some of the accepted parameters of the `ShareParams` class:

- `text`: text to share.
- `title`: content or share-sheet title (if supported).
- `subject`: email subject (if supported).

Check the class documentation for more details.

`share()` returns `status` object that allows to check the result of user action in the share sheet.

```dart
final result = await Share.share('check out my website https://example.com');
final result = await SharePlus.instance.share(params);

if (result.status == ShareResultStatus.success) {
print('Thank you for sharing my website!');
Expand All @@ -72,18 +79,31 @@ if (result.status == ShareResultStatus.success) {

### Share Files

To share one or multiple files, invoke the static `shareXFiles` method anywhere in your Dart code. The method returns a `ShareResult`. Optionally, you can pass `subject`, `text` and `sharePositionOrigin`.
To share one or multiple files, provide the `files` list in `ShareParams`.
Optionally, you can pass `title`, `text` and `sharePositionOrigin`.

```dart
final result = await Share.shareXFiles([XFile('${directory.path}/image.jpg')], text: 'Great picture');
final params = ShareParams(
text: 'Great picture',
files: [XFile('${directory.path}/image.jpg')],
);

final result = await SharePlus.instance.share(params);

if (result.status == ShareResultStatus.success) {
print('Thank you for sharing the picture!');
}
```

```dart
final result = await Share.shareXFiles([XFile('${directory.path}/image1.jpg'), XFile('${directory.path}/image2.jpg')]);
final params = ShareParams(
files: [
XFile('${directory.path}/image1.jpg'),
XFile('${directory.path}/image2.jpg'),
],
);

final result = await SharePlus.instance.share(params);

if (result.status == ShareResultStatus.dismissed) {
print('Did you not like the pictures?');
Expand All @@ -96,15 +116,13 @@ See [Can I Use - Web Share API](https://caniuse.com/web-share) to understand
which browsers are supported. This builds on the [`cross_file`](https://pub.dev/packages/cross_file)
package.


```dart
Share.shareXFiles([XFile('assets/hello.txt')], text: 'Great picture');
```

File downloading fallback mechanism for web can be disabled by setting:

```dart
Share.downloadFallbackEnabled = false;
ShareParams(
// rest of params
downloadFallbackEnabled: false,
)
```

#### Share Data
Expand All @@ -114,7 +132,12 @@ You can also share files that you dynamically generate from its data using [`XFi
To set the name of such files, use the `fileNameOverrides` parameter, otherwise the file name will be a random UUID string.

```dart
Share.shareXFiles([XFile.fromData(utf8.encode(text), mimeType: 'text/plain')], fileNameOverrides: ['myfile.txt']);
final params = ShareParams(
files: [XFile.fromData(utf8.encode(text), mimeType: 'text/plain')],
fileNameOverrides: ['myfile.txt']
);

SharePlus.instance.share(params);
```

> [!CAUTION]
Expand All @@ -123,10 +146,13 @@ Share.shareXFiles([XFile.fromData(utf8.encode(text), mimeType: 'text/plain')], f
### Share URI

iOS supports fetching metadata from a URI when shared using `UIActivityViewController`.
This special method is only properly supported on iOS.
This special functionality is only properly supported on iOS.
On other platforms, the URI will be shared as plain text.

```dart
Share.shareUri(uri: uri);
final params = ShareParams(uri: uri);

SharePlus.instance.share(params);
```

### Share Results
Expand Down Expand Up @@ -201,15 +227,52 @@ Builder(
// _onShare method:
final box = context.findRenderObject() as RenderBox?;

await Share.share(
text,
subject: subject,
sharePositionOrigin: box!.localToGlobal(Offset.zero) & box.size,
await SharePlus.instance.share(
ShareParams(
text: text,
sharePositionOrigin: box!.localToGlobal(Offset.zero) & box.size,
)
);
```

See the `main.dart` in the `example` for a complete example.

## Migrating from `Share.share()` to `SharePlus.instance.share()`

The static methods `Share.share()`, `Share.shareUri()` and `Share.shareXFiles()`
have been deprecated in favor of the `SharePlus.instance.share(params)`.

To convert code using `Share.share()` to the new `SharePlus` class:

1. Wrap the current parameters in a `ShareParams` object.
2. Change the call to `SharePlus.instance.share()`.

e.g.

```dart
Share.share("Shared text");

Share.shareUri("http://example.com");

Share.shareXFiles(files);
```

Becomes:

```dart
SharePlus.instance.share(
ShareParams(text: "Shared text"),
);

SharePlus.instance.share(
ShareParams(uri: "http://example.com"),
);

SharePlus.instance.share(
ShareParams(files: files),
);
```

## Learn more

- [API Documentation](https://pub.dev/documentation/share_plus/latest/share_plus/share_plus-library.html)
Original file line number Diff line number Diff line change
@@ -1,10 +1,8 @@
package dev.fluttercommunity.plus.share

import android.os.Build
import io.flutter.BuildConfig
import io.flutter.plugin.common.MethodCall
import io.flutter.plugin.common.MethodChannel
import java.io.IOException

/** Handles the method calls for the plugin. */
internal class MethodCallHandler(
Expand All @@ -24,35 +22,13 @@ internal class MethodCallHandler(

try {
when (call.method) {
"shareUri" -> {
share.share(
call.argument<Any>("uri") as String,
subject = null,
withResult = isWithResult,
)
success(isWithResult, result)
}

"share" -> {
share.share(
call.argument<Any>("text") as String,
call.argument<Any>("subject") as String?,
isWithResult,
)
success(isWithResult, result)
}

"shareFiles" -> {
share.shareFiles(
call.argument<List<String>>("paths")!!,
call.argument<List<String>?>("mimeTypes"),
call.argument<String?>("text"),
call.argument<String?>("subject"),
isWithResult,
arguments = call.arguments<Map<String, Any>>()!!,
withResult = isWithResult,
)
success(isWithResult, result)
}

else -> result.notImplemented()
}
} catch (e: Throwable) {
Expand Down
Loading
Loading