mobile: Check server errors in editors

This commit is contained in:
Elias Projahn 2020-04-26 18:29:21 +02:00
parent 00c31296e5
commit 9d4554b67f
6 changed files with 247 additions and 91 deletions

View file

@ -25,6 +25,13 @@ class App extends StatelessWidget {
primary: Colors.amber, primary: Colors.amber,
secondary: Colors.amber, secondary: Colors.amber,
), ),
snackBarTheme: SnackBarThemeData(
backgroundColor: Colors.grey[800],
contentTextStyle: TextStyle(
color: Colors.white,
),
behavior: SnackBarBehavior.floating,
),
fontFamily: 'Libertinus Sans', fontFamily: 'Libertinus Sans',
), ),
home: Builder( home: Builder(

View file

@ -17,6 +17,8 @@ class EnsembleEditor extends StatefulWidget {
class _EnsembleEditorState extends State<EnsembleEditor> { class _EnsembleEditorState extends State<EnsembleEditor> {
final nameController = TextEditingController(); final nameController = TextEditingController();
bool uploading = false;
@override @override
void initState() { void initState() {
super.initState(); super.initState();
@ -34,18 +36,46 @@ class _EnsembleEditorState extends State<EnsembleEditor> {
appBar: AppBar( appBar: AppBar(
title: Text('Ensemble'), title: Text('Ensemble'),
actions: <Widget>[ actions: <Widget>[
FlatButton( uploading
? Padding(
padding: const EdgeInsets.all(16.0),
child: Center(
child: SizedBox(
width: 24.0,
height: 24.0,
child: CircularProgressIndicator(
strokeWidth: 2.0,
),
),
),
)
: FlatButton(
child: Text('DONE'), child: Text('DONE'),
onPressed: () async { onPressed: () async {
setState(() {
uploading = true;
});
final ensemble = Ensemble( final ensemble = Ensemble(
id: widget.ensemble?.id ?? generateId(), id: widget.ensemble?.id ?? generateId(),
name: nameController.text, name: nameController.text,
); );
await backend.client.putEnsemble(ensemble); final success = await backend.client.putEnsemble(ensemble);
setState(() {
uploading = false;
});
if (success) {
Navigator.pop(context, ensemble); Navigator.pop(context, ensemble);
} else {
Scaffold.of(context).showSnackBar(SnackBar(
content: Text('Failed to upload'),
));
}
}, },
) ),
], ],
), ),
body: ListView( body: ListView(

View file

@ -17,6 +17,8 @@ class InstrumentEditor extends StatefulWidget {
class _InstrumentEditorState extends State<InstrumentEditor> { class _InstrumentEditorState extends State<InstrumentEditor> {
final nameController = TextEditingController(); final nameController = TextEditingController();
bool uploading = false;
@override @override
void initState() { void initState() {
super.initState(); super.initState();
@ -34,18 +36,47 @@ class _InstrumentEditorState extends State<InstrumentEditor> {
appBar: AppBar( appBar: AppBar(
title: Text('Instrument/Role'), title: Text('Instrument/Role'),
actions: <Widget>[ actions: <Widget>[
FlatButton( uploading
? Padding(
padding: const EdgeInsets.all(16.0),
child: Center(
child: SizedBox(
width: 24.0,
height: 24.0,
child: CircularProgressIndicator(
strokeWidth: 2.0,
),
),
),
)
: FlatButton(
child: Text('DONE'), child: Text('DONE'),
onPressed: () async { onPressed: () async {
setState(() {
uploading = true;
});
final instrument = Instrument( final instrument = Instrument(
id: widget.instrument?.id ?? generateId(), id: widget.instrument?.id ?? generateId(),
name: nameController.text, name: nameController.text,
); );
final success =
await backend.client.putInstrument(instrument); await backend.client.putInstrument(instrument);
setState(() {
uploading = false;
});
if (success) {
Navigator.pop(context, instrument); Navigator.pop(context, instrument);
} else {
Scaffold.of(context).showSnackBar(SnackBar(
content: Text('Failed to upload'),
));
}
}, },
) ),
], ],
), ),
body: ListView( body: ListView(

View file

@ -18,6 +18,8 @@ class _PersonEditorState extends State<PersonEditor> {
final firstNameController = TextEditingController(); final firstNameController = TextEditingController();
final lastNameController = TextEditingController(); final lastNameController = TextEditingController();
bool uploading = false;
@override @override
void initState() { void initState() {
super.initState(); super.initState();
@ -36,17 +38,45 @@ class _PersonEditorState extends State<PersonEditor> {
appBar: AppBar( appBar: AppBar(
title: Text('Person'), title: Text('Person'),
actions: <Widget>[ actions: <Widget>[
FlatButton( uploading
? Padding(
padding: const EdgeInsets.all(16.0),
child: Center(
child: SizedBox(
width: 24.0,
height: 24.0,
child: CircularProgressIndicator(
strokeWidth: 2.0,
),
),
),
)
: FlatButton(
child: Text('DONE'), child: Text('DONE'),
onPressed: () async { onPressed: () async {
setState(() {
uploading = true;
});
final person = Person( final person = Person(
id: widget.person?.id ?? generateId(), id: widget.person?.id ?? generateId(),
firstName: firstNameController.text, firstName: firstNameController.text,
lastName: lastNameController.text, lastName: lastNameController.text,
); );
await backend.client.putPerson(person); final success = await backend.client.putPerson(person);
setState(() {
uploading = false;
});
if (success) {
Navigator.pop(context, person); Navigator.pop(context, person);
} else {
Scaffold.of(context).showSnackBar(SnackBar(
content: Text('Failed to upload'),
));
}
}, },
), ),
], ],

View file

@ -27,6 +27,7 @@ class RecordingEditor extends StatefulWidget {
class _RecordingEditorState extends State<RecordingEditor> { class _RecordingEditorState extends State<RecordingEditor> {
final commentController = TextEditingController(); final commentController = TextEditingController();
bool uploading = false;
WorkInfo workInfo; WorkInfo workInfo;
List<PerformanceInfo> performanceInfos = []; List<PerformanceInfo> performanceInfos = [];
@ -103,20 +104,44 @@ class _RecordingEditorState extends State<RecordingEditor> {
appBar: AppBar( appBar: AppBar(
title: Text('Recording'), title: Text('Recording'),
actions: <Widget>[ actions: <Widget>[
FlatButton( uploading
? Padding(
padding: const EdgeInsets.all(16.0),
child: Center(
child: SizedBox(
width: 24.0,
height: 24.0,
child: CircularProgressIndicator(
strokeWidth: 2.0,
),
),
),
)
: FlatButton(
child: Text('DONE'), child: Text('DONE'),
onPressed: () async { onPressed: () async {
setState(() {
uploading = true;
});
final recordingInfo = RecordingInfo( final recordingInfo = RecordingInfo(
recording: Recording( recording: Recording(
id: widget?.recordingInfo?.recording?.id ?? generateId(), id: widget?.recordingInfo?.recording?.id ??
generateId(),
work: workInfo.work.id, work: workInfo.work.id,
comment: commentController.text, comment: commentController.text,
), ),
performances: performanceInfos, performances: performanceInfos,
); );
final success =
await backend.client.putRecording(recordingInfo); await backend.client.putRecording(recordingInfo);
setState(() {
uploading = false;
});
if (success) {
Navigator.pop( Navigator.pop(
context, context,
RecordingSelectorResult( RecordingSelectorResult(
@ -124,8 +149,13 @@ class _RecordingEditorState extends State<RecordingEditor> {
recordingInfo: recordingInfo, recordingInfo: recordingInfo,
), ),
); );
} else {
Scaffold.of(context).showSnackBar(SnackBar(
content: Text('Failed to upload'),
));
}
}, },
) ),
], ],
), ),
body: ListView( body: ListView(

View file

@ -173,6 +173,7 @@ class WorkEditor extends StatefulWidget {
class _WorkEditorState extends State<WorkEditor> { class _WorkEditorState extends State<WorkEditor> {
final titleController = TextEditingController(); final titleController = TextEditingController();
bool uploading = false;
Person composer; Person composer;
List<Instrument> instruments = []; List<Instrument> instruments = [];
List<PartData> parts = []; List<PartData> parts = [];
@ -249,9 +250,26 @@ class _WorkEditorState extends State<WorkEditor> {
appBar: AppBar( appBar: AppBar(
title: Text('Work'), title: Text('Work'),
actions: <Widget>[ actions: <Widget>[
FlatButton( uploading
? Padding(
padding: const EdgeInsets.all(16.0),
child: Center(
child: SizedBox(
width: 24.0,
height: 24.0,
child: CircularProgressIndicator(
strokeWidth: 2.0,
),
),
),
)
: FlatButton(
child: Text('DONE'), child: Text('DONE'),
onPressed: () async { onPressed: () async {
setState(() {
uploading = true;
});
final workId = widget?.workInfo?.work?.id ?? generateId(); final workId = widget?.workInfo?.work?.id ?? generateId();
List<PartInfo> partInfos = []; List<PartInfo> partInfos = [];
@ -277,15 +295,25 @@ class _WorkEditorState extends State<WorkEditor> {
composer: composer?.id, composer: composer?.id,
), ),
instruments: instruments, instruments: instruments,
// TODO: Theoretically, this should include all composers from // TODO: Theoretically, this should include all composers
// the parts. // from the parts.
composers: [composer], composers: [composer],
parts: partInfos, parts: partInfos,
); );
await backend.client.putWork(workInfo); final success = await backend.client.putWork(workInfo);
setState(() {
uploading = false;
});
if (success) {
Navigator.pop(context, workInfo); Navigator.pop(context, workInfo);
} else {
Scaffold.of(context).showSnackBar(SnackBar(
content: Text('Failed to upload'),
));
}
}, },
), ),
], ],