mirror of
https://github.com/KRTirtho/spotube.git
synced 2025-09-16 00:55:17 +00:00

* 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
91 lines
2.2 KiB
Dart
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 ?? [];
|
|
});
|