mirror of
https://github.com/immich-app/immich.git
synced 2025-01-24 04:32:45 +01:00
e1feba2198
* refactor video controls * inline * make mute icon const * move placeholder to private widget * adjust text width, move volume button slightly right
35 lines
1.2 KiB
Dart
35 lines
1.2 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:immich_mobile/constants/immich_colors.dart';
|
|
import 'package:immich_mobile/providers/asset_viewer/show_controls.provider.dart';
|
|
import 'package:immich_mobile/widgets/asset_viewer/video_position.dart';
|
|
|
|
/// The video controls for the [videoPlayerControlsProvider]
|
|
class VideoControls extends ConsumerWidget {
|
|
const VideoControls({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
final isPortrait =
|
|
MediaQuery.orientationOf(context) == Orientation.portrait;
|
|
return AnimatedOpacity(
|
|
opacity: ref.watch(showControlsProvider) ? 1.0 : 0.0,
|
|
duration: const Duration(milliseconds: 100),
|
|
child: isPortrait
|
|
? const ColoredBox(
|
|
color: blackOpacity40,
|
|
child: Padding(
|
|
padding: EdgeInsets.symmetric(horizontal: 24.0),
|
|
child: VideoPosition(),
|
|
),
|
|
)
|
|
: const ColoredBox(
|
|
color: blackOpacity40,
|
|
child: Padding(
|
|
padding: EdgeInsets.symmetric(horizontal: 128.0),
|
|
child: VideoPosition(),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|