spotube/lib/provider/spotify/search/search.dart
Kingkor Roy Tirtho 6673e5a8a8
feat: improved caching based on riverpod (#1343)
* feat: add riverpod based favorite album provider

* feat: add album is saved, new releases and tracks providers

* feat: add artist related providers

* feat: add all categories providers

* feat: add lyrics provider

* feat: add playlist related providers

* feat: add search provider

* feat: add view and spotify friends provider

* feat: add playlist create and update and favorite handlers

* feat: use providers in home screen

* chore: fix dart lint issues

* feat: use new providers for playlist and albums screen

* feat: use providers in artist page

* feat: use providers on library page

* feat: use provider for playlist and album card and heart button

* feat: use provider in search page

* feat: use providers in generate playlist

* feat: use provider in lyrics screen

* feat: use provider for create playlist

* feat: use provider in add track dialog

* feat: use providers in remaining pages and remove fl_query

* fix: remove direct access to provider.value

* fix: glitching when loading

* fix: user album loading next page indicator

* feat: make many provider autoDispose after 5 minutes of no usage

* fix: ignore episodes in tracks
2024-03-20 23:38:39 +06:00

77 lines
1.7 KiB
Dart

part of '../spotify.dart';
final searchTermStateProvider = StateProvider.autoDispose<String>(
(ref) {
ref.cacheFor(const Duration(minutes: 2));
return "";
},
);
class SearchState<Y> extends PaginatedState<Y> {
SearchState({
required super.items,
required super.offset,
required super.limit,
required super.hasMore,
});
@override
SearchState<Y> copyWith({
List<Y>? items,
int? offset,
int? limit,
bool? hasMore,
}) {
return SearchState(
items: items ?? this.items,
offset: offset ?? this.offset,
limit: limit ?? this.limit,
hasMore: hasMore ?? this.hasMore,
);
}
}
class SearchNotifier<Y> extends AutoDisposeFamilyPaginatedAsyncNotifier<Y,
SearchState<Y>, SearchType> {
SearchNotifier() : super();
@override
fetch(arg, offset, limit) async {
if (state.value == null) return [];
final results = await spotify.search
.get(
ref.read(searchTermStateProvider),
types: [arg],
market: ref.read(userPreferencesProvider).recommendationMarket,
)
.getPage(limit, offset);
return results.expand((e) => e.items ?? <Y>[]).toList().cast<Y>();
}
@override
build(arg) async {
ref.cacheFor(const Duration(minutes: 2));
ref.watch(searchTermStateProvider);
ref.watch(spotifyProvider);
ref.watch(
userPreferencesProvider.select((value) => value.recommendationMarket),
);
final results = await fetch(arg, 0, 10);
return SearchState<Y>(
items: results,
offset: 0,
limit: 10,
hasMore: results.length == 10,
);
}
}
final searchProvider = AsyncNotifierProvider.autoDispose
.family<SearchNotifier, SearchState, SearchType>(
() => SearchNotifier(),
);