mirror of
				https://github.com/johrpan/musicus_mobile.git
				synced 2025-10-26 10:47:25 +01:00 
			
		
		
		
	Rename top level directories
This commit is contained in:
		
							parent
							
								
									256bda1b72
								
							
						
					
					
						commit
						674ce19414
					
				
					 90 changed files with 0 additions and 0 deletions
				
			
		
							
								
								
									
										113
									
								
								mobile/lib/platform.dart
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								mobile/lib/platform.dart
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,113 @@ | |||
| import 'package:flutter/services.dart'; | ||||
| 
 | ||||
| /// Object representing a document in Storage Access Framework terms. | ||||
| class Document { | ||||
|   /// Unique document ID given by the SAF. | ||||
|   final String id; | ||||
| 
 | ||||
|   /// Name of the document (i.e. file name). | ||||
|   final String name; | ||||
| 
 | ||||
|   /// Document ID of the parent document. | ||||
|   final String parent; | ||||
| 
 | ||||
|   /// Whether this document represents a directory. | ||||
|   final bool isDirectory; | ||||
| 
 | ||||
|   // Use Map<dynamic, dynamic> here, as we get casting errors otherwise. This | ||||
|   // won't be typesafe anyway. | ||||
|   Document.fromJson(Map<dynamic, dynamic> json) | ||||
|       : id = json['id'], | ||||
|         name = json['name'], | ||||
|         parent = json['parent'], | ||||
|         isDirectory = json['isDirectory']; | ||||
| } | ||||
| 
 | ||||
| /// Collection of methods that are implemented platform dependent. | ||||
| class Platform { | ||||
|   static const _platform = MethodChannel('de.johrpan.musicus/platform'); | ||||
| 
 | ||||
|   /// Get child documents. | ||||
|   /// | ||||
|   /// [treeId] is the base URI as requested from the SAF. | ||||
|   /// [parentId] is the document ID of the parent. If this is null, the children | ||||
|   /// of the tree base will be returned. | ||||
|   static Future<List<Document>> getChildren( | ||||
|       String treeUri, String parentId) async { | ||||
|     final List<Map<dynamic, dynamic>> childrenJson = | ||||
|         await _platform.invokeListMethod( | ||||
|       'getChildren', | ||||
|       { | ||||
|         'treeUri': treeUri, | ||||
|         'parentId': parentId, | ||||
|       }, | ||||
|     ); | ||||
| 
 | ||||
|     return childrenJson | ||||
|         .map((childJson) => Document.fromJson(childJson)) | ||||
|         .toList(); | ||||
|   } | ||||
| 
 | ||||
|   /// Read contents of file. | ||||
|   /// | ||||
|   /// [treeId] is the base URI from the SAF, [id] is the document ID of the | ||||
|   /// file. | ||||
|   static Future<String> readFile(String treeUri, String id) async { | ||||
|     return await _platform.invokeMethod( | ||||
|       'readFile', | ||||
|       { | ||||
|         'treeUri': treeUri, | ||||
|         'id': id, | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   /// Get document URI by file name | ||||
|   /// | ||||
|   /// [treeId] is the base URI from the SAF, [parentId] is the document ID of | ||||
|   /// the parent directory. | ||||
|   static Future<String> getUriByName( | ||||
|       String treeUri, String parentId, String fileName) async { | ||||
|     return await _platform.invokeMethod( | ||||
|       'getUriByName', | ||||
|       { | ||||
|         'treeUri': treeUri, | ||||
|         'parentId': parentId, | ||||
|         'fileName': fileName, | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   /// Read contents of file by name | ||||
|   /// | ||||
|   /// [treeId] is the base URI from the SAF, [parentId] is the document ID of | ||||
|   /// the parent directory. | ||||
|   static Future<String> readFileByName( | ||||
|       String treeUri, String parentId, String fileName) async { | ||||
|     return await _platform.invokeMethod( | ||||
|       'readFileByName', | ||||
|       { | ||||
|         'treeUri': treeUri, | ||||
|         'parentId': parentId, | ||||
|         'fileName': fileName, | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   /// Write to file by name | ||||
|   /// | ||||
|   /// [treeId] is the base URI from the SAF, [parentId] is the document ID of | ||||
|   /// the parent directory. | ||||
|   static Future<void> writeFileByName( | ||||
|       String treeUri, String parentId, String fileName, String content) async { | ||||
|     await _platform.invokeMethod( | ||||
|       'writeFileByName', | ||||
|       { | ||||
|         'treeUri': treeUri, | ||||
|         'parentId': parentId, | ||||
|         'fileName': fileName, | ||||
|         'content': content, | ||||
|       }, | ||||
|     ); | ||||
|   } | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Elias Projahn
						Elias Projahn