musicus_mobile/mobile/lib/widgets/recording_tile.dart

52 lines
1.3 KiB
Dart
Raw Normal View History

2020-04-06 11:42:07 +02:00
import 'package:flutter/material.dart';
import '../backend.dart';
import '../database.dart';
import 'texts.dart';
class RecordingTile extends StatelessWidget {
final int recordingId;
RecordingTile({
this.recordingId,
});
@override
Widget build(BuildContext context) {
final backend = Backend.of(context);
final textTheme = Theme.of(context).textTheme;
return StreamBuilder<Recording>(
stream: backend.db.recordingById(recordingId).watchSingle(),
2020-04-22 10:10:25 +02:00
builder: (context, snapshot) => Padding(
padding: const EdgeInsets.symmetric(
vertical: 8.0,
),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
if (snapshot.hasData) ...[
DefaultTextStyle(
style: textTheme.subtitle1,
child: ComposersText(snapshot.data.work),
2020-04-06 11:42:07 +02:00
),
DefaultTextStyle(
2020-04-22 10:10:25 +02:00
style: textTheme.headline6,
child: WorkText(snapshot.data.work),
2020-04-06 11:42:07 +02:00
),
],
2020-04-22 10:10:25 +02:00
const SizedBox(
height: 4.0,
),
DefaultTextStyle(
style: textTheme.bodyText1,
child: PerformancesText(recordingId),
),
],
2020-04-06 11:42:07 +02:00
),
),
);
}
}