75 lines
2.2 KiB
Dart
75 lines
2.2 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter/services.dart';
|
|
|
|
import 'package:cached_network_image/cached_network_image.dart';
|
|
|
|
import 'package:f0ckapp/models/media_item.dart';
|
|
import 'package:f0ckapp/widgets/video_widget.dart';
|
|
|
|
class FullScreenMediaView extends StatefulWidget {
|
|
final MediaItem item;
|
|
|
|
const FullScreenMediaView({super.key, required this.item});
|
|
|
|
@override
|
|
State createState() => _FullScreenMediaViewState();
|
|
}
|
|
|
|
class _FullScreenMediaViewState extends State<FullScreenMediaView> {
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
SystemChrome.setPreferredOrientations(DeviceOrientation.values);
|
|
SystemChrome.setEnabledSystemUIMode(SystemUiMode.immersive);
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
SystemChrome.setEnabledSystemUIMode(SystemUiMode.edgeToEdge);
|
|
SystemChrome.setPreferredOrientations([DeviceOrientation.portraitUp]);
|
|
super.dispose();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Scaffold(
|
|
backgroundColor: Colors.black,
|
|
body: Stack(
|
|
children: [
|
|
Positioned.fill(
|
|
child: widget.item.mime.startsWith('image')
|
|
? InteractiveViewer(
|
|
minScale: 1.0,
|
|
maxScale: 7.0,
|
|
child: CachedNetworkImage(
|
|
imageUrl: widget.item.mediaUrl,
|
|
fit: BoxFit.contain,
|
|
placeholder: (context, url) =>
|
|
const Center(child: CircularProgressIndicator()),
|
|
errorWidget: (context, url, error) =>
|
|
const Icon(Icons.error),
|
|
),
|
|
)
|
|
: SizedBox.expand(
|
|
child: VideoWidget(
|
|
details: widget.item,
|
|
isActive: true,
|
|
fullScreen: true,
|
|
),
|
|
),
|
|
),
|
|
SafeArea(
|
|
child: Align(
|
|
alignment: Alignment.topLeft,
|
|
child: IconButton(
|
|
icon: const Icon(Icons.arrow_back, color: Colors.white),
|
|
onPressed: () => Navigator.of(context).pop(),
|
|
),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|