mirror of
https://github.com/johrpan/musicus_mobile.git
synced 2025-10-25 19:27:24 +02:00
common: Fix recording editor initialization
This commit is contained in:
parent
19da47ea04
commit
7b63cc7aaf
1 changed files with 40 additions and 33 deletions
|
|
@ -25,30 +25,37 @@ class RecordingEditor extends StatefulWidget {
|
|||
}
|
||||
|
||||
class _RecordingEditorState extends State<RecordingEditor> {
|
||||
final commentController = TextEditingController();
|
||||
final _commentController = TextEditingController();
|
||||
|
||||
bool uploading = false;
|
||||
WorkInfo workInfo;
|
||||
List<PerformanceInfo> performanceInfos = [];
|
||||
MusicusBackendState _backend;
|
||||
bool _uploading = false;
|
||||
WorkInfo _workInfo;
|
||||
List<PerformanceInfo> _performanceInfos = [];
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
void didChangeDependencies() {
|
||||
super.didChangeDependencies();
|
||||
|
||||
if (widget.recordingInfo != null) {
|
||||
final backend = MusicusBackend.of(context);
|
||||
|
||||
() async {
|
||||
workInfo = await backend.db.getWork(widget.recordingInfo.recording.id);
|
||||
performanceInfos = List.from(widget.recordingInfo.performances);
|
||||
}();
|
||||
_backend = MusicusBackend.of(context);
|
||||
if (widget.recordingInfo != null &&
|
||||
_workInfo == null &&
|
||||
_performanceInfos.isEmpty) {
|
||||
_init();
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> _init() async {
|
||||
_workInfo = await _backend.db.getWork(widget.recordingInfo.recording.work);
|
||||
_performanceInfos = List.from(widget.recordingInfo.performances);
|
||||
|
||||
setState(() {
|
||||
this._workInfo = _workInfo;
|
||||
this._performanceInfos = _performanceInfos;
|
||||
});
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
final backend = MusicusBackend.of(context);
|
||||
|
||||
Future<void> selectWork() async {
|
||||
final WorkInfo newWorkInfo = await Navigator.push(
|
||||
context,
|
||||
|
|
@ -59,14 +66,14 @@ class _RecordingEditorState extends State<RecordingEditor> {
|
|||
|
||||
if (newWorkInfo != null) {
|
||||
setState(() {
|
||||
workInfo = newWorkInfo;
|
||||
_workInfo = newWorkInfo;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
final List<Widget> performanceTiles = [];
|
||||
for (var i = 0; i < performanceInfos.length; i++) {
|
||||
final p = performanceInfos[i];
|
||||
for (var i = 0; i < _performanceInfos.length; i++) {
|
||||
final p = _performanceInfos[i];
|
||||
|
||||
performanceTiles.add(ListTile(
|
||||
title: Text(p.person != null
|
||||
|
|
@ -77,7 +84,7 @@ class _RecordingEditorState extends State<RecordingEditor> {
|
|||
icon: const Icon(Icons.delete),
|
||||
onPressed: () {
|
||||
setState(() {
|
||||
performanceInfos.remove(p);
|
||||
_performanceInfos.remove(p);
|
||||
});
|
||||
},
|
||||
),
|
||||
|
|
@ -93,7 +100,7 @@ class _RecordingEditorState extends State<RecordingEditor> {
|
|||
|
||||
if (performanceInfo != null) {
|
||||
setState(() {
|
||||
performanceInfos[i] = performanceInfo;
|
||||
_performanceInfos[i] = performanceInfo;
|
||||
});
|
||||
}
|
||||
},
|
||||
|
|
@ -104,7 +111,7 @@ class _RecordingEditorState extends State<RecordingEditor> {
|
|||
appBar: AppBar(
|
||||
title: Text('Recording'),
|
||||
actions: <Widget>[
|
||||
uploading
|
||||
_uploading
|
||||
? Padding(
|
||||
padding: const EdgeInsets.all(16.0),
|
||||
child: Center(
|
||||
|
|
@ -121,31 +128,31 @@ class _RecordingEditorState extends State<RecordingEditor> {
|
|||
child: Text('DONE'),
|
||||
onPressed: () async {
|
||||
setState(() {
|
||||
uploading = true;
|
||||
_uploading = true;
|
||||
});
|
||||
|
||||
final recordingInfo = RecordingInfo(
|
||||
recording: Recording(
|
||||
id: widget?.recordingInfo?.recording?.id ??
|
||||
generateId(),
|
||||
work: workInfo.work.id,
|
||||
comment: commentController.text,
|
||||
work: _workInfo.work.id,
|
||||
comment: _commentController.text,
|
||||
),
|
||||
performances: performanceInfos,
|
||||
performances: _performanceInfos,
|
||||
);
|
||||
|
||||
final success =
|
||||
await backend.client.putRecording(recordingInfo);
|
||||
await _backend.client.putRecording(recordingInfo);
|
||||
|
||||
setState(() {
|
||||
uploading = false;
|
||||
_uploading = false;
|
||||
});
|
||||
|
||||
if (success) {
|
||||
Navigator.pop(
|
||||
context,
|
||||
RecordingSelectorResult(
|
||||
workInfo: workInfo,
|
||||
workInfo: _workInfo,
|
||||
recordingInfo: recordingInfo,
|
||||
),
|
||||
);
|
||||
|
|
@ -160,10 +167,10 @@ class _RecordingEditorState extends State<RecordingEditor> {
|
|||
),
|
||||
body: ListView(
|
||||
children: <Widget>[
|
||||
workInfo != null
|
||||
_workInfo != null
|
||||
? ListTile(
|
||||
title: Text(workInfo.work.title),
|
||||
subtitle: Text(workInfo.composers
|
||||
title: Text(_workInfo.work.title),
|
||||
subtitle: Text(_workInfo.composers
|
||||
.map((p) => '${p.firstName} ${p.lastName}')
|
||||
.join(', ')),
|
||||
onTap: selectWork,
|
||||
|
|
@ -181,7 +188,7 @@ class _RecordingEditorState extends State<RecordingEditor> {
|
|||
bottom: 16.0,
|
||||
),
|
||||
child: TextField(
|
||||
controller: commentController,
|
||||
controller: _commentController,
|
||||
decoration: InputDecoration(
|
||||
labelText: 'Comment',
|
||||
),
|
||||
|
|
@ -201,7 +208,7 @@ class _RecordingEditorState extends State<RecordingEditor> {
|
|||
|
||||
if (model != null) {
|
||||
setState(() {
|
||||
performanceInfos.add(model);
|
||||
_performanceInfos.add(model);
|
||||
});
|
||||
}
|
||||
},
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue