mucke/lib/presentation/pages/artist_details_page.dart

119 lines
3.9 KiB
Dart
Raw Normal View History

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';
import '../state/audio_store.dart';
import '../state/music_data_store.dart';
import '../theming.dart';
2021-01-17 10:20:51 +01:00
import '../widgets/artist_albums.dart';
import '../widgets/artist_header.dart';
2021-05-04 18:45:57 +02:00
import '../widgets/artist_highlighted_songs.dart';
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);
final AudioStore audioStore = Provider.of<AudioStore>(context);
2021-01-17 10:20:51 +01:00
return Observer(
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(
[
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),
),
],
),
),
);
}
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,
),
),
);
}
}