From 02e283b8ccd026d6893e3d68e6b86a7b51a5f896 Mon Sep 17 00:00:00 2001 From: Elias Projahn Date: Sun, 22 Mar 2020 17:38:08 +0100 Subject: [PATCH] PerformerSelector: Allow changing the person --- lib/selectors/performer.dart | 35 +++++++++++++++++++++++++++-------- 1 file changed, 27 insertions(+), 8 deletions(-) diff --git a/lib/selectors/performer.dart b/lib/selectors/performer.dart index 86cec2f..b1c3215 100644 --- a/lib/selectors/performer.dart +++ b/lib/selectors/performer.dart @@ -14,6 +14,7 @@ class PerformerSelector extends StatefulWidget { class _PerformerSelectorState extends State { Role role; + Person person; @override Widget build(BuildContext context) { @@ -22,6 +23,18 @@ class _PerformerSelectorState extends State { return Scaffold( appBar: AppBar( title: Text('Select performer'), + actions: [ + FlatButton( + child: Text('DONE'), + onPressed: () => Navigator.pop( + context, + PerformanceModel( + person: person, + role: role, + ), + ), + ), + ], ), body: Column( children: [ @@ -65,13 +78,17 @@ class _PerformerSelectorState extends State { itemBuilder: (context, index) { final person = snapshot.data[index]; - return ListTile( - title: Text('${person.lastName}, ${person.firstName}'), - onTap: () => Navigator.pop(context, PerformanceModel( - person: person, - role: role, - )), - ); + return RadioListTile( + controlAffinity: ListTileControlAffinity.trailing, + title: + Text('${person.lastName}, ${person.firstName}'), + value: person, + groupValue: this.person, + onChanged: (newPerson) { + setState(() { + this.person = newPerson; + }); + }); }, ); } else { @@ -93,7 +110,9 @@ class _PerformerSelectorState extends State { )); if (person != null) { - Navigator.pop(context, person); + setState(() { + this.person = person; + }); } }, ),