mirror of
https://github.com/gabehf/Fladder.git
synced 2026-03-08 23:18:16 -07:00
fix: Keyboard controls and translations (#79)
Co-authored-by: PartyDonut <PartyDonut@users.noreply.github.com>
This commit is contained in:
parent
7394077726
commit
1babf05834
11 changed files with 796 additions and 745 deletions
|
|
@ -1,46 +1,34 @@
|
|||
import 'package:flutter/material.dart';
|
||||
|
||||
import 'package:ficonsax/ficonsax.dart';
|
||||
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||
import 'package:universal_html/html.dart' as html;
|
||||
|
||||
class FullScreenButton extends StatefulWidget {
|
||||
import 'package:fladder/providers/video_player_provider.dart';
|
||||
|
||||
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));
|
||||
}
|
||||
|
||||
class FullScreenButton extends ConsumerWidget {
|
||||
const FullScreenButton({super.key});
|
||||
|
||||
@override
|
||||
State<FullScreenButton> createState() => _FullScreenButtonState();
|
||||
}
|
||||
|
||||
class _FullScreenButtonState extends State<FullScreenButton> {
|
||||
bool fullScreen = false;
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
_updateFullScreenStatus();
|
||||
}
|
||||
|
||||
void _updateFullScreenStatus() {
|
||||
setState(() {
|
||||
fullScreen = html.document.fullscreenElement != null;
|
||||
});
|
||||
}
|
||||
|
||||
void toggleFullScreen() async {
|
||||
if (fullScreen) {
|
||||
html.document.exitFullscreen();
|
||||
//Wait for 1 second
|
||||
await Future.delayed(const Duration(seconds: 1));
|
||||
} else {
|
||||
await html.document.documentElement?.requestFullscreen();
|
||||
}
|
||||
|
||||
_updateFullScreenStatus();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
Widget build(BuildContext context, WidgetRef ref) {
|
||||
final fullScreen = ref.watch(mediaPlaybackProvider.select((value) => value.fullScreen));
|
||||
return IconButton(
|
||||
onPressed: toggleFullScreen,
|
||||
onPressed: () => toggleFullScreen(ref),
|
||||
icon: Icon(
|
||||
fullScreen ? IconsaxOutline.close_square : IconsaxOutline.maximize_4,
|
||||
),
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue