2018-06-23 01:22:04 +00:00
|
|
|
import 'dart:async';
|
2019-03-12 01:25:23 +00:00
|
|
|
import 'dart:io';
|
2018-06-23 01:22:04 +00:00
|
|
|
|
|
|
|
import 'package:flutter/services.dart';
|
2018-11-30 16:15:09 +00:00
|
|
|
|
2019-03-12 01:25:23 +00:00
|
|
|
enum FileType {
|
|
|
|
ANY,
|
|
|
|
IMAGE,
|
|
|
|
VIDEO,
|
|
|
|
AUDIO,
|
|
|
|
CUSTOM,
|
|
|
|
}
|
2018-06-23 01:22:04 +00:00
|
|
|
|
|
|
|
class FilePicker {
|
|
|
|
static const MethodChannel _channel = const MethodChannel('file_picker');
|
2018-12-27 14:02:24 +00:00
|
|
|
static const String _tag = 'FilePicker';
|
2018-06-23 01:22:04 +00:00
|
|
|
|
2019-03-08 01:42:07 +00:00
|
|
|
FilePicker._();
|
|
|
|
|
2019-03-12 01:25:23 +00:00
|
|
|
/// Returns an iterable `Map<String,String>` where the `key` is the name of the file
|
|
|
|
/// and the `value` the path.
|
|
|
|
///
|
|
|
|
/// A [fileExtension] can be provided to filter the picking results.
|
|
|
|
/// If provided, it will be use the `FileType.CUSTOM` for that [fileExtension].
|
|
|
|
/// If not, `FileType.ANY` will be used and any combination of files can be multi picked at once.
|
2019-06-24 10:10:19 +00:00
|
|
|
static Future<Map<String, String>> getMultiFilePath(
|
|
|
|
{FileType type = FileType.ANY, String fileExtension}) async =>
|
2019-03-12 01:25:23 +00:00
|
|
|
await _getPath(_handleType(type, fileExtension), true);
|
|
|
|
|
|
|
|
/// Returns an absolute file path from the calling platform.
|
|
|
|
///
|
|
|
|
/// A [type] must be provided to filter the picking results.
|
|
|
|
/// Can be used a custom file type with `FileType.CUSTOM`. A [fileExtension] must be provided (e.g. PDF, SVG, etc.)
|
|
|
|
/// Defaults to `FileType.ANY` which will display all file types.
|
2019-06-24 10:10:19 +00:00
|
|
|
static Future<String> getFilePath(
|
|
|
|
{FileType type = FileType.ANY, String fileExtension}) async =>
|
2019-03-12 01:25:23 +00:00
|
|
|
await _getPath(_handleType(type, fileExtension), false);
|
|
|
|
|
|
|
|
/// Returns a `File` object from the selected file path.
|
|
|
|
///
|
|
|
|
/// This is an utility method that does the same of `getFilePath()` but saving some boilerplate if
|
|
|
|
/// you are planing to create a `File` for the returned path.
|
2019-06-24 10:10:19 +00:00
|
|
|
static Future<File> getFile(
|
|
|
|
{FileType type = FileType.ANY, String fileExtension}) async {
|
|
|
|
final String filePath =
|
|
|
|
await _getPath(_handleType(type, fileExtension), false);
|
2019-03-16 12:18:10 +00:00
|
|
|
return filePath != null ? File(filePath) : null;
|
2019-03-12 01:25:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static Future<dynamic> _getPath(String type, bool multipleSelection) async {
|
2018-12-27 14:02:24 +00:00
|
|
|
try {
|
2019-03-06 01:16:35 +00:00
|
|
|
dynamic result = await _channel.invokeMethod(type, multipleSelection);
|
2019-03-08 01:42:07 +00:00
|
|
|
if (result != null && multipleSelection) {
|
2019-03-06 01:16:35 +00:00
|
|
|
if (result is String) {
|
|
|
|
result = [result];
|
|
|
|
}
|
2019-06-24 10:10:19 +00:00
|
|
|
return Map<String, String>.fromIterable(result,
|
|
|
|
key: (path) => path.split('/').last, value: (path) => path);
|
2019-03-06 01:16:35 +00:00
|
|
|
}
|
|
|
|
return result;
|
2018-12-27 14:02:24 +00:00
|
|
|
} on PlatformException catch (e) {
|
2019-06-24 10:10:19 +00:00
|
|
|
print('[$_tag] Platform exception: $e');
|
|
|
|
rethrow;
|
2018-12-27 14:02:24 +00:00
|
|
|
} catch (e) {
|
2019-06-24 10:10:19 +00:00
|
|
|
print(
|
|
|
|
'[$_tag] Unsupported operation. Method not found. The exception thrown was: $e');
|
|
|
|
rethrow;
|
2019-03-11 00:01:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-12 01:25:23 +00:00
|
|
|
static String _handleType(FileType type, String fileExtension) {
|
2018-09-11 14:59:35 +00:00
|
|
|
switch (type) {
|
|
|
|
case FileType.IMAGE:
|
2019-03-12 01:25:23 +00:00
|
|
|
return 'IMAGE';
|
2019-03-05 19:02:14 +00:00
|
|
|
case FileType.AUDIO:
|
2019-03-12 01:25:23 +00:00
|
|
|
return 'AUDIO';
|
2018-12-05 15:32:02 +00:00
|
|
|
case FileType.VIDEO:
|
2019-03-12 01:25:23 +00:00
|
|
|
return 'VIDEO';
|
2018-12-06 15:21:34 +00:00
|
|
|
case FileType.ANY:
|
2019-03-12 01:25:23 +00:00
|
|
|
return 'ANY';
|
2018-12-27 14:02:24 +00:00
|
|
|
case FileType.CUSTOM:
|
2019-03-12 01:25:23 +00:00
|
|
|
return '__CUSTOM_' + (fileExtension ?? '');
|
2018-11-30 16:15:09 +00:00
|
|
|
default:
|
2019-03-12 01:25:23 +00:00
|
|
|
return 'ANY';
|
2018-09-11 14:59:35 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|