Skip to content

Commit

Permalink
Merge pull request #832 from GetStream/video-fix
Browse files Browse the repository at this point in the history
feat(ui): added autoplay to videos
  • Loading branch information
imtoori authored Dec 20, 2021
2 parents 536fb45 + 0aed43b commit 13a863f
Show file tree
Hide file tree
Showing 5 changed files with 55 additions and 8 deletions.
6 changes: 6 additions & 0 deletions packages/stream_chat_flutter/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
## Upcoming

✅ Added

- Videos can now be auto-played in `FullScreenMedia`

## 3.3.2

- Updated `stream_chat_flutter_core` dependency to [`3.3.1`](https://pub.dev/packages/stream_chat_flutter_core/changelog).
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -246,7 +246,8 @@ class GiphyAttachment extends AttachmentWidget {
return StreamChannel(
channel: channel,
child: FullScreenMedia(
mediaAttachments: [attachment],
mediaAttachments: message.attachments,
startIndex: message.attachments.indexOf(attachment),
userName: message.user?.name,
message: message,
onShowMessage: onShowMessage,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,9 @@ class ImageAttachment extends AttachmentWidget {
return StreamChannel(
channel: channel,
child: FullScreenMedia(
mediaAttachments: [attachment],
mediaAttachments: message.attachments,
startIndex:
message.attachments.indexOf(attachment),
userName: message.user?.name,
message: message,
onShowMessage: onShowMessage,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,9 @@ class VideoAttachment extends AttachmentWidget {
builder: (_) => StreamChannel(
channel: channel,
child: FullScreenMedia(
mediaAttachments: [attachment],
mediaAttachments: message.attachments,
startIndex:
message.attachments.indexOf(attachment),
userName: message.user?.name,
message: message,
onShowMessage: onShowMessage,
Expand Down
46 changes: 41 additions & 5 deletions packages/stream_chat_flutter/lib/src/full_screen_media.dart
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ class FullScreenMedia extends StatefulWidget {
String? userName,
this.onShowMessage,
this.attachmentActionsModalBuilder,
this.autoplayVideos = false,
}) : userName = userName ?? '',
super(key: key);

Expand All @@ -57,6 +58,9 @@ class FullScreenMedia extends StatefulWidget {
/// Use [defaultActionsModal.copyWith] to easily customize it
final AttachmentActionsBuilder? attachmentActionsModalBuilder;

/// Auto-play videos when page is opened
final bool autoplayVideos;

@override
_FullScreenMediaState createState() => _FullScreenMediaState();
}
Expand All @@ -81,7 +85,8 @@ class _FullScreenMediaState extends State<FullScreenMedia>
);
_pageController = PageController(initialPage: widget.startIndex);
_currentPage = widget.startIndex;
for (final attachment in widget.mediaAttachments) {
for (var i = 0; i < widget.mediaAttachments.length; i++) {
final attachment = widget.mediaAttachments[i];
if (attachment.type != 'video') continue;
final package = VideoPackage(attachment, showControls: true);
videoPackages[attachment.id] = package;
Expand All @@ -90,9 +95,21 @@ class _FullScreenMediaState extends State<FullScreenMedia>
}

Future<void> initializePlayers() async {
if (videoPackages.isEmpty) {
return;
}

final currentAttachment = widget.mediaAttachments[widget.startIndex];

await Future.wait(videoPackages.values.map(
(it) => it.initialize(),
));

if (widget.autoplayVideos && currentAttachment.type == 'video') {
final package = videoPackages.values
.firstWhere((e) => e._attachment == currentAttachment);
package._chewieController?.play();
}
setState(() {}); // ignore: no-empty-block
}

Expand All @@ -109,6 +126,24 @@ class _FullScreenMediaState extends State<FullScreenMedia>
setState(() {
_currentPage = val;
});

if (videoPackages.isEmpty) {
return;
}

final currentAttachment = widget.mediaAttachments[val];

for (final e in videoPackages.values) {
if (e._attachment != currentAttachment) {
e._chewieController?.pause();
}
}

if (widget.autoplayVideos &&
currentAttachment.type == 'video') {
final controller = videoPackages[currentAttachment.id]!;
controller._chewieController?.play();
}
},
itemBuilder: (context, index) {
final attachment = widget.mediaAttachments[index];
Expand Down Expand Up @@ -243,15 +278,16 @@ class _FullScreenMediaState extends State<FullScreenMedia>
class VideoPackage {
/// Constructor for creating [VideoPackage]
VideoPackage(
Attachment attachment, {
this._attachment, {
bool showControls = false,
bool autoInitialize = true,
}) : _showControls = showControls,
_autoInitialize = autoInitialize,
_videoPlayerController = attachment.localUri != null
? VideoPlayerController.file(File.fromUri(attachment.localUri!))
: VideoPlayerController.network(attachment.assetUrl!);
_videoPlayerController = _attachment.localUri != null
? VideoPlayerController.file(File.fromUri(_attachment.localUri!))
: VideoPlayerController.network(_attachment.assetUrl!);

final Attachment _attachment;
final bool _showControls;
final bool _autoInitialize;
final VideoPlayerController _videoPlayerController;
Expand Down

0 comments on commit 13a863f

Please sign in to comment.