diff --git a/lib/main.dart b/lib/main.dart index 9f1a0d8f..b19bcd35 100644 --- a/lib/main.dart +++ b/lib/main.dart @@ -63,6 +63,7 @@ Future main(List args) async { WidgetsFlutterBinding.ensureInitialized(); app_links.register('rtsp'); + app_links.init(); app_links.listen(); // https://github.com/flutter/flutter/issues/41980#issuecomment-1231760866 diff --git a/lib/utils/app_links.dart b/lib/utils/app_links.dart index eec5c3c2..5062ddfd 100644 --- a/lib/utils/app_links.dart +++ b/lib/utils/app_links.dart @@ -4,6 +4,7 @@ import 'package:app_links/app_links.dart'; import 'package:bluecherry_client/main.dart'; import 'package:bluecherry_client/widgets/device_grid/device_grid.dart'; import 'package:flutter/foundation.dart'; +import 'package:flutter/material.dart'; import 'package:win32_registry/win32_registry.dart'; final instance = AppLinks(); @@ -31,6 +32,20 @@ Future register(String scheme) async { } } +Future init() async { + final initialUri = await instance.getInitialAppLink(); + debugPrint('Initial URI: $initialUri'); + if (initialUri != null) { + final url = initialUri.toString(); + WidgetsBinding.instance.addPostFrameCallback((_) { + final context = navigatorKey.currentContext; + if (context != null && context.mounted) { + AddExternalStreamDialog.addStream(context, url); + } + }); + } +} + void listen() { instance.allUriLinkStream.listen((uri) { final navigator = navigatorKey.currentState;