mirror of
				https://github.com/johrpan/musicus_mobile.git
				synced 2025-10-26 18:57:25 +01:00 
			
		
		
		
	Add composers and work texts
These replace the work tile widget.
This commit is contained in:
		
							parent
							
								
									40db00d88d
								
							
						
					
					
						commit
						e834abe1e0
					
				
					 4 changed files with 68 additions and 87 deletions
				
			
		|  | @ -4,7 +4,7 @@ import '../backend.dart'; | ||||||
| import '../database.dart'; | import '../database.dart'; | ||||||
| import '../selectors/performer.dart'; | import '../selectors/performer.dart'; | ||||||
| import '../selectors/work.dart'; | import '../selectors/work.dart'; | ||||||
| import '../widgets/work_tile.dart'; | import '../widgets/texts.dart'; | ||||||
| 
 | 
 | ||||||
| class RecordingEditor extends StatefulWidget { | class RecordingEditor extends StatefulWidget { | ||||||
|   final Recording recording; |   final Recording recording; | ||||||
|  | @ -70,9 +70,9 @@ class _RecordingEditorState extends State<RecordingEditor> { | ||||||
|       body: ListView( |       body: ListView( | ||||||
|         children: <Widget>[ |         children: <Widget>[ | ||||||
|           work != null |           work != null | ||||||
|               ? WorkTile( |               ? ListTile( | ||||||
|                   workId: work.id, |                 title: WorkText(work.id), | ||||||
|                   onTap: selectWork, |                 subtitle: ComposersText(work.id), | ||||||
|               ) |               ) | ||||||
|               : ListTile( |               : ListTile( | ||||||
|                   title: Text('Work'), |                   title: Text('Work'), | ||||||
|  |  | ||||||
|  | @ -5,7 +5,6 @@ import '../database.dart'; | ||||||
| import '../editors/recording.dart'; | import '../editors/recording.dart'; | ||||||
| import '../widgets/texts.dart'; | import '../widgets/texts.dart'; | ||||||
| import '../widgets/works_by_composer.dart'; | import '../widgets/works_by_composer.dart'; | ||||||
| import '../widgets/work_tile.dart'; |  | ||||||
| 
 | 
 | ||||||
| class PersonList extends StatelessWidget { | class PersonList extends StatelessWidget { | ||||||
|   final void Function(int personId) onSelect; |   final void Function(int personId) onSelect; | ||||||
|  | @ -102,12 +101,13 @@ class RecordingList extends StatelessWidget { | ||||||
|       children: <Widget>[ |       children: <Widget>[ | ||||||
|         Material( |         Material( | ||||||
|           elevation: 2.0, |           elevation: 2.0, | ||||||
|           child: WorkTile( |           child: ListTile( | ||||||
|             leading: IconButton( |             leading: IconButton( | ||||||
|               icon: const Icon(Icons.arrow_back), |               icon: const Icon(Icons.arrow_back), | ||||||
|               onPressed: () => Navigator.pop(context), |               onPressed: () => Navigator.pop(context), | ||||||
|             ), |             ), | ||||||
|             workId: workId, |             title: WorkText(workId), | ||||||
|  |             subtitle: ComposersText(workId), | ||||||
|           ), |           ), | ||||||
|         ), |         ), | ||||||
|         Expanded( |         Expanded( | ||||||
|  |  | ||||||
|  | @ -80,17 +80,20 @@ class _PerformancesTextState extends State<PerformancesText> { | ||||||
|         final buffer = StringBuffer(); |         final buffer = StringBuffer(); | ||||||
| 
 | 
 | ||||||
|         if (performance.person != null) { |         if (performance.person != null) { | ||||||
|               final person = await backend.db.personById(performance.person).getSingle(); |           final person = | ||||||
|  |               await backend.db.personById(performance.person).getSingle(); | ||||||
|           buffer.write('${person.firstName} ${person.lastName}'); |           buffer.write('${person.firstName} ${person.lastName}'); | ||||||
|         } else if (performance.ensemble != null) { |         } else if (performance.ensemble != null) { | ||||||
|               final ensemble = await backend.db.ensembleById(performance.ensemble).getSingle(); |           final ensemble = | ||||||
|  |               await backend.db.ensembleById(performance.ensemble).getSingle(); | ||||||
|           buffer.write(ensemble.name); |           buffer.write(ensemble.name); | ||||||
|         } else { |         } else { | ||||||
|           buffer.write('Unknown'); |           buffer.write('Unknown'); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (performance.role != null) { |         if (performance.role != null) { | ||||||
|               final role = await backend.db.instrumentById(performance.role).getSingle(); |           final role = | ||||||
|  |               await backend.db.instrumentById(performance.role).getSingle(); | ||||||
|           buffer.write(' (${role.name})'); |           buffer.write(' (${role.name})'); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -114,3 +117,37 @@ class _PerformancesTextState extends State<PerformancesText> { | ||||||
|     performancesSubscription?.cancel(); |     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(', ') | ||||||
|  |           : '...'), | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -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, |  | ||||||
|             ); |  | ||||||
|           }, |  | ||||||
|         ); |  | ||||||
|       }, |  | ||||||
|     ); |  | ||||||
|   } |  | ||||||
| } |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Elias Projahn
						Elias Projahn