mirror of
https://github.com/gabehf/Fladder.git
synced 2026-03-14 09:46:01 -07:00
feature: HTPC mode startup argument (#358)
Co-authored-by: PartyDonut <PartyDonut@users.noreply.github.com>
This commit is contained in:
parent
a8795cf0c9
commit
69a5e3db7a
24 changed files with 416 additions and 151 deletions
34
lib/widgets/full_screen_helpers/full_screen_helper_web.dart
Normal file
34
lib/widgets/full_screen_helpers/full_screen_helper_web.dart
Normal file
|
|
@ -0,0 +1,34 @@
|
|||
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||
import 'package:universal_html/html.dart' as html;
|
||||
|
||||
import 'package:fladder/providers/video_player_provider.dart';
|
||||
import 'package:fladder/widgets/full_screen_helpers/full_screen_wrapper.dart';
|
||||
|
||||
class FullScreenHelper implements FullScreenWrapper {
|
||||
const FullScreenHelper._();
|
||||
factory FullScreenHelper.instantiate() => const FullScreenHelper._();
|
||||
@override
|
||||
Future<void> closeFullScreen(WidgetRef ref) async {
|
||||
if (html.document.fullscreenElement != null) {
|
||||
html.document.exitFullscreen();
|
||||
await Future.delayed(const Duration(milliseconds: 500));
|
||||
ref.read(mediaPlaybackProvider.notifier).update((state) => state.copyWith(fullScreen: false));
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
Future<void> toggleFullScreen(WidgetRef ref) async {
|
||||
final isFullScreen = html.document.fullscreenElement != null;
|
||||
|
||||
if (isFullScreen) {
|
||||
html.document.exitFullscreen();
|
||||
//Wait for 1 second
|
||||
await Future.delayed(const Duration(seconds: 1));
|
||||
} else {
|
||||
await html.document.documentElement?.requestFullscreen();
|
||||
}
|
||||
ref
|
||||
.read(mediaPlaybackProvider.notifier)
|
||||
.update((state) => state.copyWith(fullScreen: html.document.fullscreenElement != null));
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue