import 'dart:async'; import 'package:flutter/material.dart'; import 'package:video_player/video_player.dart'; import 'package:cached_network_image/cached_network_image.dart'; import 'package:f0ckapp/models/MediaItem.dart'; import 'package:f0ckapp/widgets/VideoOverlay.dart'; class VideoWidget extends StatefulWidget { final MediaItem details; const VideoWidget({super.key, required this.details}); @override State createState() => _VideoWidgetState(); } class _VideoWidgetState extends State { late VideoPlayerController _controller; bool _showControls = false; Timer? _hideControlsTimer; @override void initState() { super.initState(); _initController(); } Future _initController() async { _controller = VideoPlayerController.networkUrl( Uri.parse(widget.details.mediaUrl), ); await _controller.initialize(); setState(() {}); _controller.addListener(() => setState(() {})); _controller.play(); _controller.setLooping(true); } @override void dispose() { _controller.dispose(); _hideControlsTimer?.cancel(); super.dispose(); } void _onTap({bool ctrlButton = false}) { if (!ctrlButton) { setState(() => _showControls = !_showControls); } if (_showControls) { _hideControlsTimer?.cancel(); _hideControlsTimer = Timer(Duration(seconds: 5), () { setState(() => _showControls = false); }); } } @override Widget build(BuildContext context) { bool isAudio = widget.details.mime.startsWith('audio'); return Column( mainAxisSize: MainAxisSize.min, children: [ AspectRatio( aspectRatio: _controller.value.isInitialized ? _controller.value.aspectRatio : 9 / 16, child: Stack( alignment: Alignment.center, children: [ GestureDetector( onTap: _onTap, child: isAudio ? CachedNetworkImage( imageUrl: widget.details.coverUrl, fit: BoxFit.cover, placeholder: (context, url) => CircularProgressIndicator(), errorWidget: (context, url, error) => Image.network( "https://f0ck.me/s/img/music.webp", fit: BoxFit.contain, ), ) : _controller.value.isInitialized ? VideoPlayer(_controller) : Center(child: CircularProgressIndicator()), ), if (_controller.value.isInitialized && _showControls) ...[ VideoControlsOverlay(controller: _controller, button: () => _onTap(ctrlButton: true)), ], ], ), ), ], ); } }