mirror of
https://github.com/gabehf/Fladder.git
synced 2026-03-07 21:48:14 -08: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
|
|
@ -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));
|
||||
}
|
||||
}
|
||||
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));
|
||||
}
|
||||
}
|
||||
32
lib/widgets/full_screen_helpers/full_screen_wrapper.dart
Normal file
32
lib/widgets/full_screen_helpers/full_screen_wrapper.dart
Normal 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,
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
@ -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) ...{
|
||||
|
|
|
|||
|
|
@ -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,
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
@ -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,
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue