Add composers and work texts

These replace the work tile widget.
This commit is contained in:
Elias Projahn 2020-04-06 11:29:55 +02:00
parent 40db00d88d
commit e834abe1e0
4 changed files with 68 additions and 87 deletions

View file

@ -74,33 +74,36 @@ class _PerformancesTextState extends State<PerformancesText> {
.performancesByRecording(widget.recordingId)
.watch()
.listen((performances) async {
final List<String> texts = [];
final List<String> texts = [];
for (final performance in performances) {
final buffer = StringBuffer();
for (final performance in performances) {
final buffer = StringBuffer();
if (performance.person != null) {
final person = await backend.db.personById(performance.person).getSingle();
buffer.write('${person.firstName} ${person.lastName}');
} else if (performance.ensemble != null) {
final ensemble = await backend.db.ensembleById(performance.ensemble).getSingle();
buffer.write(ensemble.name);
} else {
buffer.write('Unknown');
}
if (performance.person != null) {
final person =
await backend.db.personById(performance.person).getSingle();
buffer.write('${person.firstName} ${person.lastName}');
} else if (performance.ensemble != null) {
final ensemble =
await backend.db.ensembleById(performance.ensemble).getSingle();
buffer.write(ensemble.name);
} else {
buffer.write('Unknown');
}
if (performance.role != null) {
final role = await backend.db.instrumentById(performance.role).getSingle();
buffer.write(' (${role.name})');
}
if (performance.role != null) {
final role =
await backend.db.instrumentById(performance.role).getSingle();
buffer.write(' (${role.name})');
}
texts.add(buffer.toString());
}
texts.add(buffer.toString());
}
setState(() {
text = texts.join(', ');
});
});
setState(() {
text = texts.join(', ');
});
});
}
@override
@ -113,4 +116,38 @@ class _PerformancesTextState extends State<PerformancesText> {
super.dispose();
performancesSubscription?.cancel();
}
}
}
class WorkText extends StatelessWidget {
final int workId;
WorkText(this.workId);
@override
Widget build(BuildContext context) {
final backend = Backend.of(context);
return StreamBuilder<Work>(
stream: backend.db.workById(workId).watchSingle(),
builder: (context, snapshot) => Text(snapshot.data?.title ?? '...'),
);
}
}
class ComposersText extends StatelessWidget {
final int workId;
ComposersText(this.workId);
@override
Widget build(BuildContext context) {
final backend = Backend.of(context);
return StreamBuilder<List<Person>>(
stream: backend.db.composersByWork(workId).watch(),
builder: (context, snapshot) => Text(snapshot.hasData
? snapshot.data.map((p) => '${p.firstName} ${p.lastName}').join(', ')
: '...'),
);
}
}

View file

@ -1,56 +0,0 @@
import 'package:flutter/material.dart';
import '../backend.dart';
import '../database.dart';
class WorkTile extends StatelessWidget {
final Widget leading;
final int workId;
final void Function() onTap;
WorkTile({
this.leading,
this.workId,
this.onTap,
});
@override
Widget build(BuildContext context) {
final backend = Backend.of(context);
return StreamBuilder<Work>(
stream: backend.db.workById(workId).watchSingle(),
builder: (context, snapshot) {
final titleText = snapshot.data?.title ?? '...';
return StreamBuilder<List<Person>>(
stream: backend.db.composersByWork(workId).watch(),
builder: (context, snapshot) {
final subtitleText = snapshot.hasData
? snapshot.data
.map((p) => '${p.firstName} ${p.lastName}')
.join(', ')
: '...';
return ListTile(
leading: leading,
title: DefaultTextStyle(
style: Theme.of(context).textTheme.bodyText2,
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Text(
subtitleText,
style: TextStyle(fontWeight: FontWeight.bold),
),
Text(titleText),
],
),
),
onTap: onTap ?? null,
);
},
);
},
);
}
}