mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-31 02:27:08 -04:00 
			
		
		
		
	* chore: add unawaited_futures lint as warning # Conflicts: # mobile/analysis_options.yaml * remove unused dcm lints They will be added back later on a case by case basis * fix warning # Conflicts: # mobile/lib/presentation/pages/drift_remote_album.page.dart * auto gen file * review changes * conflict resolution --------- Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
		
			
				
	
	
		
			63 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'dart:async';
 | |
| 
 | |
| import 'package:auto_route/auto_route.dart';
 | |
| import 'package:flutter/material.dart';
 | |
| import 'package:hooks_riverpod/hooks_riverpod.dart';
 | |
| import 'package:immich_mobile/providers/routes.provider.dart';
 | |
| import 'package:immich_mobile/routing/router.dart';
 | |
| 
 | |
| class AppNavigationObserver extends AutoRouterObserver {
 | |
|   /// Riverpod Instance
 | |
|   final WidgetRef ref;
 | |
| 
 | |
|   AppNavigationObserver({required this.ref});
 | |
| 
 | |
|   @override
 | |
|   Future<void> didChangeTabRoute(TabPageRoute route, TabPageRoute previousRoute) async {
 | |
|     unawaited(Future(() => ref.read(inLockedViewProvider.notifier).state = false));
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   void didPush(Route route, Route? previousRoute) {
 | |
|     _handleLockedViewState(route, previousRoute);
 | |
|     _handleDriftLockedFolderState(route, previousRoute);
 | |
|     Future(() {
 | |
|       ref.read(currentRouteNameProvider.notifier).state = route.settings.name;
 | |
|       ref.read(previousRouteNameProvider.notifier).state = previousRoute?.settings.name;
 | |
|       ref.read(previousRouteDataProvider.notifier).state = previousRoute?.settings;
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   _handleLockedViewState(Route route, Route? previousRoute) {
 | |
|     final isInLockedView = ref.read(inLockedViewProvider);
 | |
|     final isFromLockedViewToDetailView =
 | |
|         route.settings.name == GalleryViewerRoute.name && previousRoute?.settings.name == LockedRoute.name;
 | |
| 
 | |
|     final isFromDetailViewToInfoPanelView =
 | |
|         route.settings.name == null && previousRoute?.settings.name == GalleryViewerRoute.name && isInLockedView;
 | |
| 
 | |
|     if (route.settings.name == LockedRoute.name || isFromLockedViewToDetailView || isFromDetailViewToInfoPanelView) {
 | |
|       Future(() => ref.read(inLockedViewProvider.notifier).state = true);
 | |
|     } else {
 | |
|       Future(() => ref.read(inLockedViewProvider.notifier).state = false);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   _handleDriftLockedFolderState(Route route, Route? previousRoute) {
 | |
|     final isInLockedView = ref.read(inLockedViewProvider);
 | |
|     final isFromLockedViewToDetailView =
 | |
|         route.settings.name == AssetViewerRoute.name && previousRoute?.settings.name == DriftLockedFolderRoute.name;
 | |
| 
 | |
|     final isFromDetailViewToInfoPanelView =
 | |
|         route.settings.name == null && previousRoute?.settings.name == AssetViewerRoute.name && isInLockedView;
 | |
| 
 | |
|     if (route.settings.name == DriftLockedFolderRoute.name ||
 | |
|         isFromLockedViewToDetailView ||
 | |
|         isFromDetailViewToInfoPanelView) {
 | |
|       Future(() => ref.read(inLockedViewProvider.notifier).state = true);
 | |
|     } else {
 | |
|       Future(() => ref.read(inLockedViewProvider.notifier).state = false);
 | |
|     }
 | |
|   }
 | |
| }
 |