Fix Image Picker to Handle Partial Failures Gracefully #1554
Fix #1643
Fix #872
- Fixes a crash when sometimes user swipe the modal down and call it again. 1357
- Fixes a null object reference error #1604
- Fixes a cache deletion issue #1505
- Migrate the web example to use the new web bootstrapping, introduced in Flutter 3.22.
- Updates the minimum Flutter version to 3.22.0, to support Dart 3.4.
- Updates the
package:web
dependency to 1.0.0. - Removes a redundant
FilePickerWeb.platform
static field. UseFilePicker.platform
instead.
- Fixes an issue relating to incorrect registration of platform-specific implementations. #1555.
- Fixes an issue that required users to use
kIsWeb
andFilePickerWeb
when running on the web.
Updates the minimum Android SDK version to 21, to match the current Flutter minimum Android SDK version. Fixes #1522, #1528, and #1531. Thanks @navaronbracke.
Release picked file data in memory to avoid memory leak
Removes references to Flutter v1 android embedding classes.
Fixes a TypeError with pickFiles()
when using the HTML renderer.
Fixes the bug #1412 that picking a folder in iOS causes the original folder to be deleted.
Fixes an issue preventing compilation on iOS when using Pod::PICKER_DOCUMENT = false.
Removes linter warnings and fixes CI/CD.
Removes Flutter GO support.
Adds privacy manifest #1418.
Fixes typo on docs (there was some refernces to FileType.all
instead of the correct FileType.any
).
- Adds
xFiles
getter to [FilePickerResult] andXFile
toPlatformFile
to retrieve aList<XFile>
or singleXFile
accordingly. - Bumps win32, flutter_plugin_android_lifecycle, plugin_platform_interface and lints versions.
- Fixes NPE when compressing images from gallery on Android 14 #1455. Thanks @mauriziopinotti.
- Other minor bugs & fixes.
- File picker extensions for Linux Zenity are case insensitive now
- Fixes #1322
Fixes an issue where sequencial picks could replace the previous file #1466. Thanks @Arsanjuan87.
Adds possibility to save files on mobile platforms as well #1452. Thanks @Samoy.
Save file to mobile platforms with bytes
.
The initialDirectory
parameter of getDirectoryPath()
now works (#970).
Add ability to compress images on android by specifying a compression quality value ([#735] (#735)).
Android's CSV mime type is text/comma-separated-values
. Added standard text/csv
when the
CSV extension is specified which fixes issues when picking CSV files from Google Drive
on Android devices.
- Fixed endless loop on ios safari when canceling picking. (#1364). Thank you @test0terter0n!
- Add
readSequential
flag for web. IfreadSequential
is true, order of picked files will be preserved. If flag is false, files will be read parallel. Thank you @test0terter0n!
Update minimum Flutter version to 3.7.0.
- Update minimum iOS version to 11.0.
- Fix several warnings in the iOS plugin implementation.
- Fix if selecting from gallery multiple files from remote sources (eg GoPro, Drone) imported to the device gallery and uploaded to iCloud they would have the same file name and it shows only one image repeated
- Fix returned images are in different onder from the gallery selection
Fix #1317
Fix #1312
Bumps the dependency win32
to 5.0.2 (#1281). Thank you @frg2089!
Bump Dart SDK lower bound to <4.0.0 to support Dart 3
Updates Gradle to version 7.5 Adds the namespace property for compatibility with Gradle 8
Updates dependencies, including win32 bump to 4.1.3 (#1255).
Fixes the bug that the result of the save-file dialog was incorrect when it was invoked with a long default file name but the user selected a file with a much short file name (#1257).
Fixes the errors Type 'Uint8List' not found
and 'Uint8List' isn't a type
(#1260). Thank you @miguelslemos!
Fixes the bug that the current directory sometimes changed after the user picked a file. Now, after the dialog is closed, the current directory is automatically restored to its original value even if the user changed the directory while searching for files (#1254). Thank you @Tokenyet!
Fixes the behavior of the saveFile()
dialog on Ubuntu/Kubuntu. This fix should have been committed in the previous version 5.2.7 but was forgotten. Now, when the user selects an already existing file, then Ubuntu prompts the user to confirm overwriting this file. This change finally makes the dialog behave the same on all desktop platforms (macOS, Linux, and Windows) (#989).
Fixes the behavior of the saveFile()
dialog on Windows. Now, when the user selects an already existing file, then Windows prompts the user to confirm overwriting this file. This change makes the dialog behave the same on all desktop platforms (macOS, Linux, and Windows). Previously, Windows would not have asked the user for confirmation (#989).
- Increase time to wait on js result
- Fix preprocessor definitions in podspec (thanks @tomk9)
- Calling pick/save file dialog will no longer freeze ui thread.
- Fixes an issue when picking live photos where the key photo was changed.
- Fix deprecation warning for
getParcelable(String key)
method.
- Reverts 5.2.0 due to multiple regressions.
- Fixes issue with caching on android
- Files will be retrieved without caching to avoid delay (Only cached if paths cannot be retrieved directly )
- Update Dependencies to latest versions (Win32 2.7.0 to 3.0.0). (Thank you @ishangavidusha)
- Set default dialog title to empty. (Thank you @whuhewei)
Fixes an issue when picking live photos. (Thank you @nagibazad)
Removes READ_EXTERNAL_STORAGE on SDKs targeting 33 or above. (Thank you @alexmercerind)
Replaces random number generation with milliseconds timestamp in file name fallback.
Updated dependecies (most importantly is upgrade from ffi 1.1.2 to 2.0.1). Update lints from 1.0.1 to 2.0.0 (with several fixes of code).
Handle UTTypeCreatePreferredIdentifierForTag
returning NULL
. This prevents a crash observed
on the iOS simulator on Apple Silicon (#1040).
Add conditional compilation of media, audio and document pickers for iOS. This prevents error messages for permissions (NSPhotoLibraryUsageDescription, NSAppleMusicUsageDescription, etc.) when publishing to app store connect, in case you don't need either category. This addresses #783 in a different way.
Adds display:none
to the internal input element to fix a display issue in specific scenario's.
Changes the implementation of getDirectoryPath()
on Windows to provide a modern dialog that looks the same as a file picker dialog (#915).
Adds the additional parameter initialDirectory
to configure the initial directory where the dialog should be opened. This parameter is supported for all three dialogs (pick files, pick directory, and save file). The only exception is that the parameter does not work on Windows for the function getDirectoryPath()
. Please note that this feature has not been implemented for Android and iOS.
Introduces two fixes for the KDE Plasma Linux implementation which uses kdialog
to open the file picker dialogs. Firstly, the selection of multiple files is fixed so that file paths with blanks/spaces are handled correctly. Secondly, file type filters are implemented. Thank you @w1th0utnam3.
Fixes the issue under Windows that the save-file dialog did not open if the specified file name contained an illegal character. Windows prohibits the usage of reserved characters in file names. Now the exception IllegalCharacterInFileNameException
is thrown if the specified file name contains forbidden characters
(#926).
Adds KDE Plasma's kdialog
arguments, allowing filepicker
to invoke kdialog
for file system manipulation using shell scripts on distributions that use KDE Plasma as their Desktop Environment and don't ship zenity
or qarma
.
Adds the parameter lockParentWindow
for Windows desktop. This parameter makes the file picker dialog behave like a modal window. That is, the file picker always stays in front of the Flutter window until it is closed. Thank you @vinicios-cervantes.
Fixes the issue under Windows that the user could not select more than about 256 files (depending on the length of the file paths) because the buffer size for storing the selected file paths was too small. (#918).
Fixes the issue under Windows that the user could select all file types even though a file type filter was enabled. This error existed because the user could select the entry All Files (*.*)
in the file type filter dropdown. Also, fixes the bug under macOS that users could select files without file extension even when one of the pre-defined file type filters (audio, image, video, or media) was enabled. (#871).
Fixes linting error during builds (#851).
Fixes the issue of picking filenames that contain a comma followed by a space (#890).
Improves error handling when device can't fetch files due to low storage space (#885).
Fixed an issue that was creating a crash when media in PHPickerViewController in iOs was tapped several times very fast, we check that _result is not empty to avoid the crash. No Github issue created.
Reverts Android READ_EXTERNAL_STORAGE
permission removal.
Removes <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
permission from the platform implementation Manifest since may not be required for some applications and devs can manually add it to their own application if needed (#864).
Fixes an issue where onFileLoading
would be called while picking directories (#863).
Adds the identifier
property to the PlatformFile
which references the original file identifier for both iOS & Android (#804).
Fixes the issue that users could not pick .app
files on macOS because FilePicker tried to determine the file size of .app
files. On macOS, these special kind of files are actually Unix directories in a special format (read more on StackExchange). Now, if a file is picked, which is actually a directory, then the file size will be zero. (#856)
- Fixes an issue that would prevent the call to return when both
withReadStream
andallowMultiple
were set. (#843). - Addresses an issue in the example app.
Addresses an issue where multiple media files couldn't be picked in some 3rd party explorers (#846). Thank you @innim98.
Fixes an issue where Live Photos were being picked as .pvt
packages (since iOS 15). From now on, if allowCompression
is set to true
, Live Photos will automatically be converted to static JPEG pictures. (#835)
Fixes the issue that on Linux the file type filter FileType.any
did not allow the selection of files without file extension. (#836)
Fixes an issue that would result in picker being dismissed by pulling down the modal sheet without an event. (#828)
Addresses an issue when comparing files on Web would result in an error due to path
not being accessible. (#822)
Extends API by new function saveFiles()
for opening a save-file dialog as requested in #799. This feature is only supported on desktop platforms (Linux, macOS, and Windows).
Makes the path
getter nullable to match with its property (#823).
Fixes custom extension filter. Thank you @jgoyvaerts.
Overrides equality and toString for platform_file
and file_picker_result
for better comparison different results. Thank you @Nolence.
- Changes the presentation type of the picker from
UIModalPresentationCurrentContext
toUIModalPresentationAutomatic
(#813).
- Fixes regression of #746.
- Updates exception text when trying to access
path
on Web. Thank you @maxzod.
Desktop support added for all platforms (MacOS, Linux & Windows) (#271) 🎉
From now on, you'll be able to use file_picker with all your platforms, a big thanks to @philenius, which made this possible and allowed the flutter_file_picker_desktop to be merged with this one.
Have in mind that because of platforms differences, that the following API methods aren't available to use on Desktop:
- The
onFileLoading()
isn't necessary, hence,FilePickerStatus
won't change, since it hasn't any effect on those; clearTemporaryFiles()
isn't necessary since those files aren't created — the platforms will always use a reference to the original file;- There is a new optional parameter
dialogTitle
which can be used to set the title of the modal dialog when picking the files;
Adds onFileLoading()
to Web. (#766).
- Addresses an issue where an invalid custom file extension wouldn't throw an error when it should. Thank you @Jahn08.
- Fixes
getDirectoryPath()
#745. Thank you @tomm1e.
- Removes analysis_options.yaml from the plugin and fixes the Don't import implementation files from another package warning (#746).
- Addresses an issue where bytes might be missing after first picking when
withData
is set totrue
. (#616).
- Patches README import path. (Thank you @voynichteru)
- Fixes #725.
name
andsize
properties are now non-nullable types.
- Updates README;
- Updates API docs;
- Updates Android example app to V2;
- Removes deprecated call warnings;
- Adds analysis_options.yaml with linter rule to surpress warnings from generated_plugin_registrant.
- Use MediaStore Opener (which goes through the gallery) instead of default explorer. (Thank you @tmthecoder).
- Add event when canceling the picker. (Thank you @letranloc).
- Updates example app to null safety.
Adds null safety support (#510).
- Fixes an issue where a crash could happen when picking a lot of media files in low memory devices (#606).
- Updates
preferredAssetRepresentationMode
. Thank you @nrikiji.
- Addresses an issue on iOS 14 and later where events
onFileLoading
events weren't being provided (#577).
- Web: Updates
size
property fromPlatformFile
to be in bytes instead of kb; - Applies minor refactor to example app. Thank you @Abhishek01039;
iOS & Android: Updates size
property from PlatformFile
to be in bytes instead of kb.
iOS: Fixes iOS ViewController which is nil when UIWindow.rootViewController have changed. (#525). Thank you @devcxm.
Android: Updates file name handling method. (#487)
Desktop (Go): Fixed desktop plugin implementation. Thank you @DenchikBY. (#382)
iOS: Fixes an issue that could result in a crash when selecting a media item twice. (#518)
Adds withReadStream
that allows bigger files to be streamed read into a Stream<List<int>>
. Thanks @redsolver.
Updates extension
helper getter to use the name
property instead of path
, since the latest isn't available on the Web, hence, the extension wouldn't be as well. Thank you @markgrancapal.
Android:
- Fixes an issue that could result in some files not being properly retrieved due to special characters on their names. (#472)
- Fixes a NPE that could happen with some devices. (#482)
iOS: Fixes FileType.audio
exports to support ipod-library content (non DRM protected). From now on, a cached asset (m4a) will be exported from the selected music file in the Music app, so it can later be used. Fixes (#441).
Adds missing extension to name
property of PlatformFile
. (#444)
Minor fix on CHANGELOG regarding version 2.0.9
.
Android: Updates package visibility to fully support Android 11 (SDK 30 and later). (#440)
Note: If you have build issues from now on because <queries>
aren't recognized, you'll need to update your build.gradle to use one of the following patched versions.
- iOS: Updates media picker to launch in app context (instead of modal).
- Minor update to README file.
Fixes an issue on iOS 14, where canceling with swipe gestures, could result in cancel event not being dispatched. (#431).
Fixes #425 and updates iOS to use NSDocumentDirectory on iOS 12 or lower. Thanks @allanwolski.
iOS: Fixes iOS 14 media picker (image & video) (#405, #407).
Android: Fixes #402.
Desktop (Go): Fixes directory pick on Linux.
Android: Fixes out of memory issue on some devices when picking big files.
Fixes multi-pick example on README.
iOS: Fixes conditional import for backwards compatibility with Xcode 11.
Web: Adds mobile Safari support and other minor improvements. iOS: Adds conditional import for backwards compatibility with Xcode 11.
iOS: Addresses an issue that could prevent users from viewing picked media elements (pictures/videos) from gallery on iOS 14.
Fixes README screenshots.
iOS: Updates picker to use new PHPickerController for both single and multi media (image/video) picks (iOS 14 and above only).
Breaking Changes
- Unifies all platforms (IO, Web and Desktop) in a single plugin (file_picker) that can be used seamlessly across all. Both file_picker_interface and file_picker_web are no longer mantained from now on.
- You'll now have to use
FilePicker.platform.pickFiles()
and extract the files fromFilePickerResult
; - Because platforms are unified and mixing
File
instances from dart:io and dart:html required stubbing and bloated code, it's no longer available as helper method so you'll have to instanciate aFile
with the picked paths;
New features
- Simplified usage, now you only need to use
FilePicker.platform.pickFiles()
with desired parameters which will return aFilePickerResult
with aList<PlatformFile>
containing the picked data; - Added classes
FilePickerResult
andPlatformFile
classes with helper getters; - On Android all picked files are scoped cached which should result in most of files being available. Caching process is only made once, so once done, the picked instance should be the same;
- On iOS picking audio now supports multiple and cloud picks;
- Added parameter
withData
that allows file data to be immediately available on memory asUint8List
(part ofPlatformFile
instance). This is particularly helpful on web or if you are going to upload to somehwere else; - Major refactor with some clean-up and improvements;
Removed
- Single methods such as
getFilePath()
,getMultiFilePath()
,getFile()
andgetMultiFile()
are no longer availble in favor opickFiles()
;
Go: Updates MacOS directory picker to applescript (thank you @trister1997).
Android: fixes picking paths from Downloads directory on versions below Android Q.
Android: adds support to non-legacy picking on Android Q or above (thank you @lakshyab1995).
Fixes an issue that could prevent 1.13.0
from being built due to missing allowCompression
property.
Adds allowCompression
property that will define if media (video & image) files are allowed to be compressed by OS when picked. On Android this has no effect as it already returns the original file or an integral copy.
Adds getDirectoryPath()
desktop (go) implementation.
Updates tearDown() call order on Android's implementation.
Updates README file (iOS preview).
Updates README file.
Adds onFileLoading
handler for every picking method that will provide picking status: FilePickerStatus.loading
and FilePickerStatus.done
so you can, for example, display a custom loader.
Adds getDirectoryPath()
method that allows you to select and pick directory paths. Android, requires SDK 21 or above for this to work, and iOS requires iOS 11 or above.
Adds a temporary workaround on Android where it can trigger onRequestPermissionsResult
twice, related to Flutter issue 49365 for anyone affected in Flutter versions below 1.14.6.
Adds clearTemporaryFiles()
that allows you to explicitly remove cached files — on Android applies typically to those picked from remote providers, on iOS all picked files are cached.
Updates podspec to use only PhotoGallery from DKImagePickerController (thanks @jamesdixon!)
Minor fix on getFile()
method — should affect only those on 1.8.0.
Adds FileType.media
that will allow you to pick video and images at the same time. On iOS, this will let you pick directly from Photos app (gallery), if you want to use Files app, you must use FileType.custom
with desired extensions.
Updates iOS multi gallery picker dependency and adds a modal loading while fetching exporting assets.
Breaking change
Added support for multi-picks of videos and photos from Photos app on iOS through DKImagePicker — use any of the getMulti
methods with FileType.image
or FileType.video
. From now on, you'll need to add use_frameworks!
in your ios/Podfile.
- Fixes a crash on Android when a file has an id that can't be resolved and uses a name instead (#221);
- Minor fix on Go (Desktop) - Windows (thanks @marchellodev);
Addresses an issue with plugin calls on Go (Desktop) - Linux & Windows
Addresses an issue with plugin calls on Go (Desktop) - MacOS
Updates Go (Desktop) to support multiple extension filters.
Addresses an issue that could result in permission handler resolving requests from other activities.
- Adds multiple file extension filter support. From now on, you must provide a
List
of extensions with typeFileType.custom
when restricting types while picking. - Other minor improvements;
- iOS: Fixes an issue that could result in a crash when selecting files (with repeated taps) from 3rd party remote providers (Google Drive, Dropbox etc.);
- Go: Updates channel name;
- Adds check that ensures that you one uses
FileType.custom
when providing a custom file extension filter;
Updates channel name on iOS.
Adds temporary workaround for (#49365)(flutter/flutter#49365) until 1.14.6 lands on stable channel.
- Breaking change: Refactored
FileType
to match lower camelCase Dart guideline (eg.FileType.ALL
now isFileType.any
); - Added support for new Android plugins APIs (Android V2 embedding);
Updates dependencies.
Removes checked flutter_export_environment.sh from example app.
Bug fix
- Fixes an issue that could result in a crash when tapping multiple times in the same media file while picking, on some iOS devices (#171).
Updates go-flutter dependencies.
Bug fix
- Fixes an issue that could cause a crash when picking video files in iOS 13 or above due to SDK changes.
- Updates Go-Flutter with go 1.13.
Bug fix: Fixes an issue that could result in some cached files, picked from Google Photos (remote file), to have the name set as null
.
Bug fix: Fixes an issue that could prevent internal storage files from being properly picked.
New features
- Adds Desktop support throught go-flutter, you can see detailed instructions on how to get in runing here.
- Adds Desktop example, to run it just do
hover init
and thenhover run
within the plugin's example folder (you must have go and hover installed, check the previous point). - Similar to
getFile
, now there is also agetMultiFile
which behaves the same way, but returning a list of files instead.
Improvements
- Updates Android SDK deprecated code.
- Sometimes when a big file was being picked from a remote directory (GDrive for example), the UI could be blocked. Now this shouldn't happen anymore.
Bug fix: Fixes an issue that could cause a crash when picking files with very long names.
Changes: Updates Android target API to 29.
Rollback - Breaking change: Re-adds runtime verification for external storage read permission. Don't forget to add the permission to the AndroidManifest.xml
file as well. More info in the README file.
Bug fix: Fixes a crash that could cause some Android API to crash when multiple files were selected from external storage.
Improvements
- Removes the Android write permissions requirement.
- Minor improvements in the example app.
- Now the exceptions are rethrown in case the user wants to handle them, despite that already being done in the plugin call.
Bug fix: Fixes an issue that could prevent users to pick files from the iCloud Drive app, on versions below iOS 11.
Rollback: Removes a local dependency that shouldn't have been committed with 1.3.4
which would cause Android build to fail.
Bug fix: Protects the registrar.activity()
in the Android side of being accessed when it's null
.
Bug fixes
- Fixes an issue where sometimes a single file path was being returned as a
List
instead ofString
. requestCode
in Android intents are now restricted to 16 bits.
Bug fix: Returns a null
value in the getFile()
when the picker is canceled.
Bug fix: Fixes an issue on Android, where other activity would try to call FilePicker
's result object when it shouldn't.
Breaking changes
FileType.CAMERA
is no longer available, if you need it, you can use this package along with image_picker.
New features
- You can now pick multiple files by using the
getMultiFilePath()
method which will return aMap<String,String>
with all paths from selected files, where the key matches the file name and the value its path. Optionally, it also supports filtering by file extension, otherwise all files will be selectable. Nevertheless, you should keep usinggetFilePath()
for single path picking. - You can now use
FileType.AUDIO
to pick audio files. In iOS this will let you select from your music library. Paths from DRM protected files won't be loaded (see README for more details). - Adds
getFile()
utility method that does the same ofgetFilePath()
but returns aFile
object instead, for the returned path.
Bug fixes and updates
- This package is no longer attached to the image_picker, and because of that, camera permission is also no longer required.
- Fixes an issue where sometimes the InputStream wasn't being properly closed. Also, its exception is now being forward to the plugin caller.
- Fixes an issue where the picker, when canceled, wasn't calling the result callback on the underlying platforms.
Breaking change: Migrate from the deprecated original Android Support Library to AndroidX. This shouldn't result in any functional changes, but it requires any Android apps using this plugin to also migrate if they're using the original support library.
- Updates README file.
Breaking changes
FileType.PDF
was removed since now it can be used along with custom file types by using theFileType.CUSTOM
and providing the file extension (e.g. PDF, SVG, ZIP, etc.).FileType.CAPTURE
is nowFileType.CAMERA
New features
- Now it is possible to provide a custom file extension to filter file picking options by using
FileType.CUSTOM
Bug fixes and updates
- Fixes file names from cloud on Android. Previously it would always display Document
- Fixes an issue on iOS where an exception was being thrown after canceling and re-opening the picker.
- Fixes an issue where collision could happen with request codes on Android.
- Adds public documentation to
file_picker
- Example app updated.
- Updates .gitignore
- Fixes
build.gradle
.
- Minor update of README file.
- Adds comments for public API
- Version 1.0 release.
- Adds support for ANY and VIDEO files.
- Fixes an issue where permissions were recursively asked on Android.
- Fixes an issue where some paths from document files couldn't be loaded with Android 8.0.
- Updates README file to match changes.
- General refactor & cleanup.
- Replaces commons dependency with FilePath class on Android, to handle path resolution on different SDK.
- Minor correction in the README file.
- Changed Meta minimum version due to versioning conflict with flutter_localization.
- Updated readme.
- Changed license from Apache 2.0 to MIT.
- Adds demo screenshot.
- Adds license information (Apache 2.0).
- Adds CHANGELOG details.
- Initial release.
- Supports picking paths from files on local storage, cloud.
- Supports picking paths from both gallery & camera due to image_picker dependency.