2020-12-29 21:01:31 +01:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
|
|
|
|
import '../../domain/entities/album.dart';
|
|
|
|
import '../../domain/entities/artist.dart';
|
2021-01-21 21:49:29 +01:00
|
|
|
import '../state/audio_store.dart';
|
2020-12-29 21:01:31 +01:00
|
|
|
import '../state/music_data_store.dart';
|
2021-01-21 21:49:29 +01:00
|
|
|
import '../theming.dart';
|
2021-01-17 10:20:51 +01:00
|
|
|
import '../widgets/artist_albums.dart';
|
2021-01-21 21:49:29 +01:00
|
|
|
import '../widgets/artist_header.dart';
|
2021-05-04 18:45:57 +02:00
|
|
|
import '../widgets/artist_highlighted_songs.dart';
|
2020-12-29 21:01:31 +01:00
|
|
|
import 'album_details_page.dart';
|
|
|
|
|
|
|
|
class ArtistDetailsPage extends StatelessWidget {
|
|
|
|
const ArtistDetailsPage({Key key, @required this.artist}) : super(key: key);
|
|
|
|
|
|
|
|
final Artist artist;
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
final MusicDataStore musicDataStore = Provider.of<MusicDataStore>(context);
|
2021-01-21 21:49:29 +01:00
|
|
|
final AudioStore audioStore = Provider.of<AudioStore>(context);
|
2020-12-29 21:01:31 +01:00
|
|
|
|
2021-01-17 10:20:51 +01:00
|
|
|
return Observer(
|
2021-01-21 21:49:29 +01:00
|
|
|
builder: (BuildContext context) => SafeArea(
|
|
|
|
child: CustomScrollView(
|
|
|
|
slivers: [
|
|
|
|
ArtistHeader(artist: artist),
|
|
|
|
SliverList(
|
|
|
|
delegate: SliverChildListDelegate(
|
|
|
|
[
|
|
|
|
Padding(
|
|
|
|
padding: const EdgeInsets.only(
|
|
|
|
left: HORIZONTAL_PADDING,
|
|
|
|
right: HORIZONTAL_PADDING,
|
|
|
|
bottom: 8.0,
|
|
|
|
),
|
|
|
|
child: ElevatedButton(
|
|
|
|
child: const Text('SHUFFLE'),
|
|
|
|
onPressed: () => audioStore.shuffleArtist(artist),
|
|
|
|
),
|
|
|
|
),
|
2021-05-04 18:45:57 +02:00
|
|
|
const Padding(
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
left: HORIZONTAL_PADDING + 2,
|
|
|
|
right: HORIZONTAL_PADDING + 2,
|
|
|
|
bottom: 4.0,
|
|
|
|
),
|
|
|
|
child: Text(
|
|
|
|
'Highlights',
|
|
|
|
style: TEXT_HEADER,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(
|
|
|
|
horizontal: HORIZONTAL_PADDING,
|
|
|
|
vertical: 4.0,
|
|
|
|
),
|
|
|
|
child: Container(
|
|
|
|
height: 1.0,
|
|
|
|
color: Colors.white10,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
ArtistHighlightedSongs(songs: musicDataStore.artistHighlightedSongStream.value),
|
|
|
|
SliverList(
|
|
|
|
delegate: SliverChildListDelegate(
|
|
|
|
[
|
2021-01-21 21:49:29 +01:00
|
|
|
const Padding(
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
left: HORIZONTAL_PADDING + 2,
|
|
|
|
right: HORIZONTAL_PADDING + 2,
|
|
|
|
bottom: 4.0,
|
|
|
|
),
|
|
|
|
child: Text(
|
|
|
|
'Albums',
|
|
|
|
style: TEXT_HEADER,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(
|
|
|
|
horizontal: HORIZONTAL_PADDING,
|
|
|
|
vertical: 4.0,
|
|
|
|
),
|
|
|
|
child: Container(
|
|
|
|
height: 1.0,
|
|
|
|
color: Colors.white10,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
ArtistAlbumSliverList(
|
|
|
|
albums: musicDataStore.sortedArtistAlbums,
|
|
|
|
onTap: (Album album) => _tapAlbum(album, context, musicDataStore),
|
|
|
|
onTapPlay: (Album album) => audioStore.playAlbum(album),
|
|
|
|
),
|
|
|
|
],
|
2020-12-29 21:01:31 +01:00
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
2021-01-17 10:20:51 +01:00
|
|
|
|
|
|
|
void _tapAlbum(Album album, BuildContext context, MusicDataStore musicDataStore) {
|
|
|
|
musicDataStore.fetchSongsFromAlbum(album);
|
|
|
|
Navigator.push(
|
|
|
|
context,
|
|
|
|
MaterialPageRoute<Widget>(
|
|
|
|
builder: (BuildContext context) => AlbumDetailsPage(
|
|
|
|
album: album,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
2020-12-29 21:01:31 +01:00
|
|
|
}
|