mirror of
				https://github.com/johrpan/musicus_mobile.git
				synced 2025-10-26 18:57:25 +01:00 
			
		
		
		
	Move PerformanceModel to database
This commit is contained in:
		
							parent
							
								
									7f783bd016
								
							
						
					
					
						commit
						8c36988da9
					
				
					 2 changed files with 20 additions and 13 deletions
				
			
		|  | @ -17,6 +17,18 @@ class WorkModel { | |||
|   }); | ||||
| } | ||||
| 
 | ||||
| class PerformanceModel { | ||||
|   final Person person; | ||||
|   final Ensemble ensemble; | ||||
|   final Role role; | ||||
| 
 | ||||
|   PerformanceModel({ | ||||
|     this.person, | ||||
|     this.ensemble, | ||||
|     this.role, | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| @UseMoor( | ||||
|   include: { | ||||
|     'database.moor', | ||||
|  | @ -75,14 +87,19 @@ class Database extends _$Database { | |||
|   } | ||||
| 
 | ||||
|   Future<void> updateRecording( | ||||
|       Recording recording, List<Performance> perfs) async { | ||||
|       Recording recording, List<PerformanceModel> models) async { | ||||
|     await transaction(() async { | ||||
|       await (delete(performances) | ||||
|             ..where((p) => p.recording.equals(recording.id))) | ||||
|           .go(); | ||||
|       await into(recordings).insert(recording, orReplace: true); | ||||
|       for (final perf in perfs) { | ||||
|         await into(performances).insert(perf); | ||||
|       for (final model in models) { | ||||
|         await into(performances).insert(Performance( | ||||
|           recording: recording.id, | ||||
|           person: model.person.id, | ||||
|           ensemble: model.ensemble.id, | ||||
|           role: model.role.id, | ||||
|         )); | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Elias Projahn
						Elias Projahn