116 lines
3.3 KiB
Dart
116 lines
3.3 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
|
import 'package:get_it/get_it.dart';
|
|
|
|
import '../../domain/entities/album.dart';
|
|
import '../../domain/entities/artist.dart';
|
|
import '../state/artist_page_store.dart';
|
|
import '../state/audio_store.dart';
|
|
import '../state/navigation_store.dart';
|
|
import '../theming.dart';
|
|
import '../widgets/artist_albums.dart';
|
|
import '../widgets/artist_header.dart';
|
|
import '../widgets/artist_highlighted_songs.dart';
|
|
import 'album_details_page.dart';
|
|
|
|
class ArtistDetailsPage extends StatefulWidget {
|
|
const ArtistDetailsPage({
|
|
Key? key,
|
|
required this.artist,
|
|
}) : super(key: key);
|
|
|
|
final Artist artist;
|
|
|
|
@override
|
|
_ArtistDetailsPageState createState() => _ArtistDetailsPageState();
|
|
}
|
|
|
|
class _ArtistDetailsPageState extends State<ArtistDetailsPage> {
|
|
late ArtistPageStore store;
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
|
|
store = GetIt.I<ArtistPageStore>(param1: widget.artist);
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
store.dispose();
|
|
super.dispose();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final AudioStore audioStore = GetIt.I<AudioStore>();
|
|
|
|
return Observer(
|
|
builder: (BuildContext context) => SafeArea(
|
|
child: CustomScrollView(
|
|
slivers: [
|
|
ArtistHeader(artist: widget.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(widget.artist),
|
|
),
|
|
),
|
|
const ListTile(
|
|
title: Text('Highlights', style: TEXT_HEADER),
|
|
contentPadding: EdgeInsets.symmetric(
|
|
horizontal: HORIZONTAL_PADDING,
|
|
vertical: 0.0,
|
|
),
|
|
),
|
|
const Divider(),
|
|
],
|
|
),
|
|
),
|
|
ArtistHighlightedSongs(artistPageStore: store),
|
|
SliverList(
|
|
delegate: SliverChildListDelegate(
|
|
[
|
|
const ListTile(
|
|
title: Text('Albums', style: TEXT_HEADER),
|
|
contentPadding: EdgeInsets.symmetric(
|
|
horizontal: HORIZONTAL_PADDING,
|
|
vertical: 0.0,
|
|
),
|
|
),
|
|
const Divider(),
|
|
],
|
|
),
|
|
),
|
|
ArtistAlbumSliverList(
|
|
albums: store.artistAlbumStream.value ?? [],
|
|
onTap: (Album album) => _tapAlbum(album, context),
|
|
onTapPlay: (Album album) => audioStore.playAlbum(album),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
void _tapAlbum(Album album, BuildContext context) {
|
|
final NavigationStore navStore = GetIt.I<NavigationStore>();
|
|
|
|
navStore.push(
|
|
context,
|
|
MaterialPageRoute<Widget>(
|
|
builder: (BuildContext context) => AlbumDetailsPage(
|
|
album: album,
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|