spotube/lib/provider/spotify/album/releases.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

91 lines
2.2 KiB
Dart

part of '../spotify.dart';
class AlbumReleasesState extends PaginatedState<Album> {
AlbumReleasesState({
required super.items,
required super.offset,
required super.limit,
required super.hasMore,
});
@override
AlbumReleasesState copyWith({
List<Album>? items,
int? offset,
int? limit,
bool? hasMore,
}) {
return AlbumReleasesState(
items: items ?? this.items,
offset: offset ?? this.offset,
limit: limit ?? this.limit,
hasMore: hasMore ?? this.hasMore,
);
}
}
class AlbumReleasesNotifier
extends PaginatedAsyncNotifier<Album, AlbumReleasesState> {
AlbumReleasesNotifier() : super();
@override
fetch(int offset, int limit) async {
final market = ref.read(userPreferencesProvider).recommendationMarket;
final albums = await spotify.browse
.newReleases(country: market)
.getPage(limit, offset);
return albums.items
?.map(TypeConversionUtils.simpleAlbum_X_Album)
.toList() ??
[];
}
@override
build() async {
ref.watch(spotifyProvider);
ref.watch(
userPreferencesProvider.select((s) => s.recommendationMarket),
);
ref.watch(allFollowedArtistsProvider);
final albums = await fetch(0, 20);
return AlbumReleasesState(
items: albums,
offset: 0,
limit: 20,
hasMore: albums.length == 20,
);
}
}
final albumReleasesProvider =
AsyncNotifierProvider<AlbumReleasesNotifier, AlbumReleasesState>(
() => AlbumReleasesNotifier(),
);
final userArtistAlbumReleasesProvider = Provider<List<Album>>((ref) {
final newReleases = ref.watch(albumReleasesProvider);
final userArtistsQuery = ref.watch(allFollowedArtistsProvider);
if (newReleases.isLoading || userArtistsQuery.isLoading) {
return const [];
}
final userArtists =
userArtistsQuery.asData?.value.map((s) => s.id!).toList() ?? const [];
final allReleases = newReleases.asData?.value.items;
final userArtistReleases = allReleases?.where((album) {
return album.artists?.any((artist) => userArtists.contains(artist.id!)) ==
true;
}).toList();
if (userArtistReleases?.isEmpty == true) {
return allReleases?.toList() ?? [];
}
return userArtistReleases ?? [];
});