pub struct FilePicker<'a, R: Runtime> { /* private fields */ }Expand description
API of file/dir picker.
§Examples
fn example(app: &tauri::AppHandle) {
    use tauri_plugin_android_fs::AndroidFsExt as _;
 
    let api = app.android_fs();
    let file_picker = api.file_picker();
}Implementations§
Source§impl<'a, R: Runtime> SyncFilePicker<'a, R>
 
impl<'a, R: Runtime> SyncFilePicker<'a, R>
Sourcepub fn pick_files(
    &self,
    initial_location: Option<&FileUri>,
    mime_types: &[&str],
) -> Result<Vec<FileUri>>
 
pub fn pick_files( &self, initial_location: Option<&FileUri>, mime_types: &[&str], ) -> Result<Vec<FileUri>>
Opens a system file picker and returns a read-write URIs.
If no file is selected or the user cancels, an empty vec is returned.
By default, returned URI is valid until the app or device is terminated.
If you want to persist it across app restarts, use AndroidFs::take_persistable_uri_permission.
This provides a standardized file explorer-style interface, and also allows file selection from part of third-party apps or cloud storage.
Removing the returned files is also supported in most cases, but note that files provided by third-party apps may not be removable.
§Args
- 
initial_location : 
 Indicate the initial location of dialog.
 This URI works even without any permissions.
 There is no need to use this if there is no special reason.
 System will do its best to launch the dialog in the specified entry if it’s a directory, or the directory that contains the specified file if not.
 If this is missing or failed to resolve the desired initial location, the initial location is system specific.
 This must be a URI taken from following :- PublicStorage::resolve_initial_location
- PublicStorage::resolve_initial_location_top
- AndroidFs::try_resolve_file_uri
- AndroidFs::try_resolve_dir_uri
- AndroidFs::resolve_uri
- AndroidFs::read_dir
- AndroidFs::create_new_file
- AndroidFs::create_dir_all
- AndroidFs::rename
- FilePicker::pick_files
- FilePicker::pick_file
- FilePicker::pick_dir
- FilePicker::save_file
 
- 
mime_types : 
 The MIME types of the file to be selected.
 However, there is no guarantee that the returned file will match the specified types.
 If left empty, all file types will be available (equivalent to["*/*"]).
§Support
All Android version.
§References
https://developer.android.com/reference/android/content/Intent#ACTION_OPEN_DOCUMENT
Sourcepub fn pick_file(
    &self,
    initial_location: Option<&FileUri>,
    mime_types: &[&str],
) -> Result<Option<FileUri>>
 
pub fn pick_file( &self, initial_location: Option<&FileUri>, mime_types: &[&str], ) -> Result<Option<FileUri>>
Opens a system file picker and returns a read-write URI.
If no file is selected or the user cancels, None is returned.
By default, returned URI is valid until the app or device is terminated.
If you want to persist it across app restarts, use AndroidFs::take_persistable_uri_permission.
This provides a standardized file explorer-style interface, and also allows file selection from part of third-party apps or cloud storage.
Removing the returned files is also supported in most cases, but note that files provided by third-party apps may not be removable.
§Args
- 
initial_location : 
 Indicate the initial location of dialog.
 This URI works even without any permissions.
 There is no need to use this if there is no special reason.
 System will do its best to launch the dialog in the specified entry if it’s a directory, or the directory that contains the specified file if not.
 If this is missing or failed to resolve the desired initial location, the initial location is system specific.
 This must be a URI taken from following :- PublicStorage::resolve_initial_location
- PublicStorage::resolve_initial_location_top
- AndroidFs::try_resolve_file_uri
- AndroidFs::try_resolve_dir_uri
- AndroidFs::resolve_uri
- AndroidFs::read_dir
- AndroidFs::create_new_file
- AndroidFs::create_dir_all
- AndroidFs::rename
- FilePicker::pick_files
- FilePicker::pick_file
- FilePicker::pick_dir
- FilePicker::save_file
 
- 
mime_types : 
 The MIME types of the file to be selected.
 However, there is no guarantee that the returned file will match the specified types.
 If left empty, all file types will be available (equivalent to["*/*"]).
§Support
All Android version.
§References
https://developer.android.com/reference/android/content/Intent#ACTION_OPEN_DOCUMENT
Sourcepub fn pick_visual_medias(
    &self,
    target: VisualMediaTarget<'_>,
) -> Result<Vec<FileUri>>
 
pub fn pick_visual_medias( &self, target: VisualMediaTarget<'_>, ) -> Result<Vec<FileUri>>
Opens a media picker and returns a readonly URIs.
If no file is selected or the user cancels, an empty vec is returned.
By default, returned URI is valid until the app or device is terminated.
If you want to persist it across app restarts, use AndroidFs::take_persistable_uri_permission.
This media picker provides a gallery, sorted by date from newest to oldest.
§Args
- target :
 The media type of the file to be selected.
 Images or videos, or both.
§Note
The file obtained from this function cannot retrieve the correct file name using AndroidFs::get_name.
Instead, it will be assigned a sequential number, such as 1000091523.png.
And this is marked intended behavior, not a bug.
§Support
This feature is available on devices that meet the following criteria:
- Running Android 11 (API level 30) or higher
- Receive changes to Modular System Components through Google System Updates
Availability on a given device can be verified by calling FilePicker::is_visual_media_picker_available.
If not supported, this function behaves the same as FilePicker::pick_files.
§References
https://developer.android.com/training/data-storage/shared/photopicker
Sourcepub fn pick_visual_media(
    &self,
    target: VisualMediaTarget<'_>,
) -> Result<Option<FileUri>>
 
pub fn pick_visual_media( &self, target: VisualMediaTarget<'_>, ) -> Result<Option<FileUri>>
Opens a media picker and returns a readonly URI.
If no file is selected or the user cancels, None is returned.
By default, returned URI is valid until the app or device is terminated.
If you want to persist it across app restarts, use AndroidFs::take_persistable_uri_permission.
This media picker provides a gallery, sorted by date from newest to oldest.
§Args
- target :
 The media type of the file to be selected.
 Images or videos, or both.
§Note
The file obtained from this function cannot retrieve the correct file name using AndroidFs::get_name.
Instead, it will be assigned a sequential number, such as 1000091523.png.
And this is marked intended behavior, not a bug.
§Support
This feature is available on devices that meet the following criteria:
- Running Android 11 (API level 30) or higher
- Receive changes to Modular System Components through Google System Updates
Availability on a given device can be verified by calling FilePicker::is_visual_media_picker_available.
If not supported, this function behaves the same as FilePicker::pick_file.
§References
https://developer.android.com/training/data-storage/shared/photopicker
Sourcepub fn pick_contents(&self, mime_types: &[&str]) -> Result<Vec<FileUri>>
 
pub fn pick_contents(&self, mime_types: &[&str]) -> Result<Vec<FileUri>>
Opens a file picker and returns a readonly URIs.
If no file is selected or the user cancels, an empty vec is returned.
Returned URI is valid until the app or device is terminated. Can not persist it.
This works differently depending on the model and version.
Recent devices often have the similar behaviour as FilePicker::pick_visual_medias or FilePicker::pick_files.
In older versions, third-party apps often handle request instead.
§Args
- mime_types :
 The MIME types of the file to be selected.
 However, there is no guarantee that the returned file will match the specified types.
 If left empty, all file types will be available (equivalent to["*/*"]).
§Support
All Android version.
§References
https://developer.android.com/reference/android/content/Intent#ACTION_GET_CONTENT
Sourcepub fn pick_content(&self, mime_types: &[&str]) -> Result<Option<FileUri>>
 
pub fn pick_content(&self, mime_types: &[&str]) -> Result<Option<FileUri>>
Opens a file picker and returns a readonly URI.
If no file is selected or the user cancels, None is returned.
Returned URI is valid until the app or device is terminated. Can not persist it.
This works differently depending on the model and version.
Recent devices often have the similar behaviour as FilePicker::pick_visual_media or FilePicker::pick_file.
In older versions, third-party apps often handle request instead.
§Args
- mime_types :
 The MIME types of the file to be selected.
 However, there is no guarantee that the returned file will match the specified types.
 If left empty, all file types will be available (equivalent to["*/*"]).
§Support
All Android version.
§References
https://developer.android.com/reference/android/content/Intent#ACTION_GET_CONTENT
Sourcepub fn pick_dir(
    &self,
    initial_location: Option<&FileUri>,
) -> Result<Option<FileUri>>
 
pub fn pick_dir( &self, initial_location: Option<&FileUri>, ) -> Result<Option<FileUri>>
Opens a system directory picker, allowing the creation of a new directory or the selection of an existing one,
and returns a read-write directory URI.
App can fully manage entries within the returned directory.
If no directory is selected or the user cancels, None is returned.
By default, returned URI is valid until the app or device is terminated.
If you want to persist it across app restarts, use AndroidFs::take_persistable_uri_permission.
This provides a standardized file explorer-style interface, and also allows directory selection from part of third-party apps or cloud storage.
§Args
- initial_location :
 Indicate the initial location of dialog.
 This URI works even without any permissions.
 There is no need to use this if there is no special reason.
 System will do its best to launch the dialog in the specified entry if it’s a directory, or the directory that contains the specified file if not.
 If this is missing or failed to resolve the desired initial location, the initial location is system specific.
 This must be a URI taken from following :- PublicStorage::resolve_initial_location
- PublicStorage::resolve_initial_location_top
- AndroidFs::try_resolve_file_uri
- AndroidFs::try_resolve_dir_uri
- AndroidFs::resolve_uri
- AndroidFs::read_dir
- AndroidFs::create_new_file
- AndroidFs::create_dir_all
- AndroidFs::rename
- FilePicker::pick_files
- FilePicker::pick_file
- FilePicker::pick_dir
- FilePicker::save_file
 
§Support
All Android version.
§References
https://developer.android.com/reference/android/content/Intent#ACTION_OPEN_DOCUMENT_TREE
Sourcepub fn save_file(
    &self,
    initial_location: Option<&FileUri>,
    initial_file_name: impl AsRef<str>,
    mime_type: Option<&str>,
) -> Result<Option<FileUri>>
 
pub fn save_file( &self, initial_location: Option<&FileUri>, initial_file_name: impl AsRef<str>, mime_type: Option<&str>, ) -> Result<Option<FileUri>>
Opens a system file saver and returns a writeonly URI.
The returned file may be a newly created file with no content,
or it may be an existing file with the requested MIME type.
If the user cancels, None is returned.
By default, returned URI is valid until the app or device is terminated.
If you want to persist it across app restarts, use AndroidFs::take_persistable_uri_permission.
This provides a standardized file explorer-style interface, and also allows file selection from part of third-party apps or cloud storage.
Removing and reading the returned files is also supported in most cases, but note that files provided by third-party apps may not.
§Args
- 
initial_location : 
 Indicate the initial location of dialog.
 This URI works even without any permissions.
 There is no need to use this if there is no special reason.
 System will do its best to launch the dialog in the specified entry if it’s a directory, or the directory that contains the specified file if not.
 If this is missing or failed to resolve the desired initial location, the initial location is system specific.
 This must be a URI taken from following :- PublicStorage::resolve_initial_location
- PublicStorage::resolve_initial_location_top
- AndroidFs::try_resolve_file_uri
- AndroidFs::try_resolve_dir_uri
- AndroidFs::resolve_uri
- AndroidFs::read_dir
- AndroidFs::create_new_file
- AndroidFs::create_dir_all
- AndroidFs::rename
- FilePicker::pick_files
- FilePicker::pick_file
- FilePicker::pick_dir
- FilePicker::save_file
 
- 
initial_file_name : 
 An initial file name.
 The user may change this value before creating the file.
 If no extension is present, the system may infer one from mime_type and may append it to the file name. But this append-extension operation depends on the model and version.
- 
mime_type : 
 The MIME type of the file to be saved.
 If this is None, MIME type is inferred from the extension of initial_file_name (not file name by user input) and if that fails,application/octet-streamis used.
§Support
All Android version.
§References
https://developer.android.com/reference/android/content/Intent#ACTION_CREATE_DOCUMENT
Sourcepub fn is_visual_media_picker_available(&self) -> Result<bool>
 
pub fn is_visual_media_picker_available(&self) -> Result<bool>
Verify whether FilePicker::pick_visual_medias is available on a given device.
§Support
All Android version.