import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:immich_mobile/modules/asset_viewer/providers/render_list.provider.dart'; import 'package:immich_mobile/modules/home/ui/asset_grid/asset_grid_data_structure.dart'; import 'package:immich_mobile/modules/search/models/search_result_page_state.model.dart'; import 'package:immich_mobile/modules/search/services/search.service.dart'; import 'package:immich_mobile/shared/models/asset.dart'; class SearchResultPageNotifier extends StateNotifier { SearchResultPageNotifier(this._searchService) : super( SearchResultPageState( searchResult: [], isError: false, isLoading: true, isSuccess: false, isClip: false, ), ); final SearchService _searchService; Future search(String searchTerm, {bool clipEnable = true}) async { state = state.copyWith( searchResult: [], isError: false, isLoading: true, isSuccess: false, ); List? assets = await _searchService.searchAsset( searchTerm, clipEnable: clipEnable, ); if (assets != null) { state = state.copyWith( searchResult: assets, isError: false, isLoading: false, isSuccess: true, isClip: clipEnable, ); } else { state = state.copyWith( searchResult: [], isError: true, isLoading: false, isSuccess: false, isClip: clipEnable, ); } } } final searchResultPageProvider = StateNotifierProvider( (ref) { return SearchResultPageNotifier(ref.watch(searchServiceProvider)); }); final searchRenderListProvider = Provider((ref) { final result = ref.watch(searchResultPageProvider); return ref.watch( renderListProviderWithGrouping( (result.searchResult, result.isClip ? GroupAssetsBy.none : null), ), ); });