2024-10-30 14:27:13 -05:00
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
|
|
import 'package:immich_mobile/models/search/search_result.model.dart';
|
2025-02-25 11:33:48 -06:00
|
|
|
import 'package:immich_mobile/services/timeline.service.dart';
|
2024-05-06 23:04:21 -05:00
|
|
|
import 'package:immich_mobile/widgets/asset_grid/asset_grid_data_structure.dart';
|
2024-04-30 21:36:40 -05:00
|
|
|
import 'package:immich_mobile/models/search/search_filter.model.dart';
|
2024-05-02 15:59:14 -05:00
|
|
|
import 'package:immich_mobile/services/search.service.dart';
|
2024-04-01 09:45:11 -05:00
|
|
|
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
|
|
|
|
|
|
|
part 'paginated_search.provider.g.dart';
|
|
|
|
|
2024-10-30 14:27:13 -05:00
|
|
|
final paginatedSearchProvider =
|
|
|
|
StateNotifierProvider<PaginatedSearchNotifier, SearchResult>(
|
|
|
|
(ref) => PaginatedSearchNotifier(ref.watch(searchServiceProvider)),
|
|
|
|
);
|
2024-04-01 09:45:11 -05:00
|
|
|
|
2024-10-30 14:27:13 -05:00
|
|
|
class PaginatedSearchNotifier extends StateNotifier<SearchResult> {
|
|
|
|
final SearchService _searchService;
|
2024-04-01 09:45:11 -05:00
|
|
|
|
2024-10-30 14:27:13 -05:00
|
|
|
PaginatedSearchNotifier(this._searchService)
|
2025-06-25 13:06:24 +05:30
|
|
|
: super(const SearchResult(assets: [], nextPage: 1));
|
2024-04-01 09:45:11 -05:00
|
|
|
|
2025-01-30 21:12:57 -06:00
|
|
|
Future<bool> search(SearchFilter filter) async {
|
|
|
|
if (state.nextPage == null) {
|
|
|
|
return false;
|
|
|
|
}
|
2024-04-01 09:45:11 -05:00
|
|
|
|
2024-10-30 14:27:13 -05:00
|
|
|
final result = await _searchService.search(filter, state.nextPage!);
|
2024-04-01 09:45:11 -05:00
|
|
|
|
2025-01-30 21:12:57 -06:00
|
|
|
if (result == null) {
|
|
|
|
return false;
|
|
|
|
}
|
2024-04-01 09:45:11 -05:00
|
|
|
|
2024-10-30 14:27:13 -05:00
|
|
|
state = SearchResult(
|
|
|
|
assets: [...state.assets, ...result.assets],
|
|
|
|
nextPage: result.nextPage,
|
|
|
|
);
|
2025-01-30 21:12:57 -06:00
|
|
|
|
|
|
|
return true;
|
2024-04-01 09:45:11 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
clear() {
|
2025-06-25 13:06:24 +05:30
|
|
|
state = const SearchResult(assets: [], nextPage: 1);
|
2024-04-01 09:45:11 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@riverpod
|
2025-02-25 11:33:48 -06:00
|
|
|
Future<RenderList> paginatedSearchRenderList(
|
2025-03-09 20:30:58 -05:00
|
|
|
Ref ref,
|
2024-04-01 09:45:11 -05:00
|
|
|
) {
|
2024-10-30 14:27:13 -05:00
|
|
|
final result = ref.watch(paginatedSearchProvider);
|
2025-02-25 11:33:48 -06:00
|
|
|
final timelineService = ref.watch(timelineServiceProvider);
|
|
|
|
return timelineService.getTimelineFromAssets(
|
|
|
|
result.assets,
|
|
|
|
GroupAssetsBy.none,
|
2024-10-30 14:27:13 -05:00
|
|
|
);
|
2024-04-01 09:45:11 -05:00
|
|
|
}
|