| 
									
										
										
										
											2019-12-11 13:07:46 +01:00
										 |  |  | import 'package:flutter/material.dart'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import '../backend.dart'; | 
					
						
							|  |  |  | import '../database.dart'; | 
					
						
							| 
									
										
										
										
											2019-12-11 13:17:23 +01:00
										 |  |  | import '../selectors/instruments.dart'; | 
					
						
							| 
									
										
										
										
											2019-12-11 13:07:46 +01:00
										 |  |  | import '../selectors/person.dart'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class WorkEditor extends StatefulWidget { | 
					
						
							|  |  |  |   final Work work; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   WorkEditor({ | 
					
						
							|  |  |  |     this.work, | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   @override | 
					
						
							|  |  |  |   _WorkEditorState createState() => _WorkEditorState(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class _WorkEditorState extends State<WorkEditor> { | 
					
						
							|  |  |  |   final titleController = TextEditingController(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Backend backend; | 
					
						
							|  |  |  |   Person composer; | 
					
						
							| 
									
										
										
										
											2019-12-11 13:17:23 +01:00
										 |  |  |   List<Instrument> instruments = []; | 
					
						
							| 
									
										
										
										
											2019-12-11 13:07:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   @override | 
					
						
							|  |  |  |   void initState() { | 
					
						
							|  |  |  |     super.initState(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (widget.work != null) { | 
					
						
							|  |  |  |       titleController.text = widget.work.title; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   @override | 
					
						
							|  |  |  |   void didChangeDependencies() { | 
					
						
							|  |  |  |     super.didChangeDependencies(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     backend = Backend.of(context); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-11 13:17:23 +01:00
										 |  |  |     if (widget.work != null) { | 
					
						
							|  |  |  |       if (widget.work.composer != null) { | 
					
						
							|  |  |  |         () async { | 
					
						
							|  |  |  |           final person = | 
					
						
							|  |  |  |               await backend.db.personById(widget.work.composer).getSingle(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           // We don't want to override a newly selected composer.
 | 
					
						
							|  |  |  |           if (composer != null) { | 
					
						
							|  |  |  |             setState(() { | 
					
						
							|  |  |  |               composer = person; | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         }(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-11 13:07:46 +01:00
										 |  |  |       () async { | 
					
						
							| 
									
										
										
										
											2019-12-11 13:17:23 +01:00
										 |  |  |         final selection = | 
					
						
							|  |  |  |             await backend.db.instrumentsByWork(widget.work.id).get(); | 
					
						
							| 
									
										
										
										
											2019-12-11 13:07:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-11 13:17:23 +01:00
										 |  |  |         // We don't want to override already selected instruments.
 | 
					
						
							|  |  |  |         if (instruments.isEmpty) { | 
					
						
							| 
									
										
										
										
											2019-12-11 13:07:46 +01:00
										 |  |  |           setState(() { | 
					
						
							| 
									
										
										
										
											2019-12-11 13:17:23 +01:00
										 |  |  |             instruments = selection; | 
					
						
							| 
									
										
										
										
											2019-12-11 13:07:46 +01:00
										 |  |  |           }); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   @override | 
					
						
							|  |  |  |   Widget build(BuildContext context) { | 
					
						
							|  |  |  |     return Scaffold( | 
					
						
							|  |  |  |       appBar: AppBar( | 
					
						
							|  |  |  |         title: Text('Work'), | 
					
						
							|  |  |  |         actions: <Widget>[ | 
					
						
							|  |  |  |           FlatButton( | 
					
						
							|  |  |  |             child: Text('DONE'), | 
					
						
							|  |  |  |             onPressed: () {}, | 
					
						
							|  |  |  |           ), | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |       ), | 
					
						
							|  |  |  |       body: ListView( | 
					
						
							|  |  |  |         children: <Widget>[ | 
					
						
							|  |  |  |           Padding( | 
					
						
							|  |  |  |             padding: const EdgeInsets.all(16.0), | 
					
						
							|  |  |  |             child: TextField( | 
					
						
							|  |  |  |               controller: titleController, | 
					
						
							|  |  |  |               decoration: InputDecoration( | 
					
						
							|  |  |  |                 labelText: 'Title', | 
					
						
							|  |  |  |               ), | 
					
						
							|  |  |  |             ), | 
					
						
							|  |  |  |           ), | 
					
						
							|  |  |  |           ListTile( | 
					
						
							|  |  |  |             title: Text('Composer'), | 
					
						
							|  |  |  |             subtitle: Text(composer != null | 
					
						
							|  |  |  |                 ? '${composer.firstName} ${composer.lastName}' | 
					
						
							|  |  |  |                 : 'Select composer'), | 
					
						
							|  |  |  |             onTap: () async { | 
					
						
							|  |  |  |               final Person person = await Navigator.push( | 
					
						
							|  |  |  |                   context, | 
					
						
							|  |  |  |                   MaterialPageRoute( | 
					
						
							|  |  |  |                     builder: (context) => PersonsSelector(), | 
					
						
							|  |  |  |                     fullscreenDialog: true, | 
					
						
							|  |  |  |                   )); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               if (person != null) { | 
					
						
							|  |  |  |                 setState(() { | 
					
						
							|  |  |  |                   composer = person; | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |           ), | 
					
						
							| 
									
										
										
										
											2019-12-11 13:17:23 +01:00
										 |  |  |           ListTile( | 
					
						
							|  |  |  |             title: Text('Instruments'), | 
					
						
							|  |  |  |             subtitle: Text(instruments.isNotEmpty | 
					
						
							|  |  |  |                 ? instruments.map((i) => i.name).join(', ') | 
					
						
							|  |  |  |                 : 'Select instruments'), | 
					
						
							|  |  |  |             onTap: () async { | 
					
						
							|  |  |  |               final List<Instrument> selection = await Navigator.push( | 
					
						
							|  |  |  |                   context, | 
					
						
							|  |  |  |                   MaterialPageRoute( | 
					
						
							| 
									
										
										
										
											2019-12-11 13:19:56 +01:00
										 |  |  |                     builder: (context) => InstrumentsSelector( | 
					
						
							|  |  |  |                       selection: instruments, | 
					
						
							|  |  |  |                     ), | 
					
						
							| 
									
										
										
										
											2019-12-11 13:17:23 +01:00
										 |  |  |                     fullscreenDialog: true, | 
					
						
							|  |  |  |                   )); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               if (selection != null) { | 
					
						
							|  |  |  |                 setState(() { | 
					
						
							|  |  |  |                   instruments = selection; | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |           ), | 
					
						
							| 
									
										
										
										
											2019-12-11 13:07:46 +01:00
										 |  |  |         ], | 
					
						
							|  |  |  |       ), | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } |