feature: HTPC mode startup argument (#358)

Co-authored-by: PartyDonut <PartyDonut@users.noreply.github.com>
This commit is contained in:
PartyDonut 2025-06-01 15:30:34 +02:00 committed by GitHub
parent a8795cf0c9
commit 69a5e3db7a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
24 changed files with 416 additions and 151 deletions

View file

@ -0,0 +1,28 @@
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:window_manager/window_manager.dart';
import 'package:fladder/providers/arguments_provider.dart';
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 (ref.watch(argumentsStateProvider.select((value) => value.htpcMode))) return;
final isFullScreen = await windowManager.isFullScreen();
if (isFullScreen) {
await windowManager.setFullScreen(false);
}
ref.read(mediaPlaybackProvider.notifier).update((state) => state.copyWith(fullScreen: false));
}
@override
Future<void> toggleFullScreen(WidgetRef ref) async {
if (ref.watch(argumentsStateProvider.select((value) => value.htpcMode))) return;
final isFullScreen = await windowManager.isFullScreen();
await windowManager.setFullScreen(!isFullScreen);
ref.read(mediaPlaybackProvider.notifier).update((state) => state.copyWith(fullScreen: !isFullScreen));
}
}

View 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));
}
}

View file

@ -0,0 +1,32 @@
import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:fladder/providers/arguments_provider.dart';
import 'package:fladder/providers/video_player_provider.dart';
import 'package:fladder/widgets/full_screen_helpers/full_screen_helper_desktop.dart'
if (dart.library.html) 'package:fladder/widgets/full_screen_helpers/full_screen_helper_web.dart';
import 'package:iconsax_plus/iconsax_plus.dart';
final FullScreenHelper fullScreenHelper = FullScreenHelper.instantiate();
abstract class FullScreenWrapper {
Future<void> closeFullScreen(WidgetRef ref);
Future<void> toggleFullScreen(WidgetRef ref);
}
class FullScreenButton extends ConsumerWidget {
const FullScreenButton({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
if (ref.watch(argumentsStateProvider.select((value) => value.htpcMode))) return const SizedBox.shrink();
final fullScreen = ref.watch(mediaPlaybackProvider.select((value) => value.fullScreen));
return IconButton(
onPressed: () => fullScreenHelper.toggleFullScreen(ref),
icon: Icon(
fullScreen ? IconsaxPlusLinear.screenmirroring : IconsaxPlusLinear.maximize_4,
),
);
}
}

View file

@ -58,7 +58,7 @@ class _SideNavigationBarState extends ConsumerState<SideNavigationBar> {
void stopTimer() {
timer?.cancel();
timer = Timer(const Duration(milliseconds: 350), () {
timer = Timer(const Duration(milliseconds: 125), () {
setState(() {
showOnHover = false;
});
@ -93,6 +93,7 @@ class _SideNavigationBarState extends ConsumerState<SideNavigationBar> {
child: MouseRegion(
onEnter: (value) => startTimer(),
onExit: (event) => stopTimer(),
onHover: (value) => startTimer(),
child: Column(
children: [
if (isDesktop && AdaptiveLayout.of(context).platform != TargetPlatform.macOS) ...{

View file

@ -1,35 +0,0 @@
import 'package:flutter/material.dart';
import 'package:iconsax_plus/iconsax_plus.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:window_manager/window_manager.dart';
import 'package:fladder/providers/video_player_provider.dart';
Future<void> closeFullScreen() async {
final isFullScreen = await windowManager.isFullScreen();
if (isFullScreen) {
await windowManager.setFullScreen(false);
}
}
Future<void> toggleFullScreen(WidgetRef ref) async {
final isFullScreen = await windowManager.isFullScreen();
await windowManager.setFullScreen(!isFullScreen);
ref.read(mediaPlaybackProvider.notifier).update((state) => state.copyWith(fullScreen: !isFullScreen));
}
class FullScreenButton extends ConsumerWidget {
const FullScreenButton({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
final fullScreen = ref.watch(mediaPlaybackProvider.select((value) => value.fullScreen));
return IconButton(
onPressed: () => toggleFullScreen(ref),
icon: Icon(
fullScreen ? IconsaxPlusLinear.screenmirroring : IconsaxPlusLinear.maximize_4,
),
);
}
}

View file

@ -1,44 +0,0 @@
import 'package:flutter/material.dart';
import 'package:iconsax_plus/iconsax_plus.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:universal_html/html.dart' as html;
import 'package:fladder/providers/video_player_provider.dart';
Future<void> closeFullScreen() async {
if (html.document.fullscreenElement != null) {
html.document.exitFullscreen();
await Future.delayed(const Duration(milliseconds: 500));
}
}
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
Widget build(BuildContext context, WidgetRef ref) {
final fullScreen = ref.watch(mediaPlaybackProvider.select((value) => value.fullScreen));
return IconButton(
onPressed: () => toggleFullScreen(ref),
icon: Icon(
fullScreen ? IconsaxPlusLinear.screenmirroring : IconsaxPlusLinear.maximize_4,
),
);
}
}