Files
Flutter-Music-Player/lib/widgets/mp_lisview.dart
2018-03-24 18:43:41 +05:30

45 lines
1.4 KiB
Dart

import 'dart:io';
import 'package:flute_example/data/song_data.dart';
import 'package:flute_example/pages/now_playing.dart';
import 'package:flute_example/widgets/mp_circle_avatar.dart';
import 'package:flute_example/widgets/mp_inherited.dart';
import 'package:flutter/material.dart';
class MPListView extends StatelessWidget {
final List<MaterialColor> _colors = Colors.primaries;
@override
Widget build(BuildContext context) {
final rootIW = MPInheritedWidget.of(context);
SongData songData = rootIW.songData;
return new ListView.builder(
itemCount: songData.songs.length,
itemBuilder: (context, int index) {
var s = songData.songs[index];
final MaterialColor color = _colors[index % _colors.length];
var artFile =
s.albumArt == null ? null : new File.fromUri(Uri.parse(s.albumArt));
return new ListTile(
dense: false,
leading: new Hero(
child: avatar(artFile, s.title, color),
tag: s.title,
),
title: new Text(s.title),
subtitle: new Text(
"By ${s.artist}",
style: Theme.of(context).textTheme.caption,
),
onTap: () {
songData.setCurrentIndex(index);
Navigator.push(
context,
new MaterialPageRoute(
builder: (context) => new NowPlaying(songData, s)));
},
);
},
);
}
}