- New APIs and options.
- There's no major breaking changes when updating to
v0.7.0
but there are deprecation notices over Media Store and Environment API.
openDocument
API with single and multiple files support @honjow.openDocumentTree
it now also supportspersistablePermission
option which flags an one-time operation to avoid unused permission issues.
- All non SAF APIs are deprecated (Media Store and Environment APIs), if you are using them, let us know by opening an issue with your use-case so we can implement a new compatible API using a cross-platform approach.
- Added a new button that implements
openDocument
API.
This release contains a severe API fixes and some minor doc changes:
- Unused arguments in
DocumentFile.getContent
andDocumentFile.getContentAsString
. #107 @clragon. - Package import it's now done through a single import.
This release contains:
- Major breaking changes.
- New API to edit existing files.
- Example project improvements.
- Bug fixes.
To see details, refer to rollup PR #100.
- Added
writeToFile
,writeToFileAsString
andwriteToFileAsBytes
APIs to allow overwrite existing files by appending (FileMode.append
) or truncatingFileMode.write
(@jfaltis).
listFiles
it's now returns aStream<DocumentFile>
instead ofStream<PartialDocumentFile>
.DocumentFile.lastModified
it's now returns aDateTime?
instead ofFuture<DateTime?>
(removed the asynchronous plugin call).- All
DocumentFile
class fields are now nullable except byDocumentFile.uri
. createFile
doesn't requirescontent
orbytes
anymore, it's now possible to just create the file reference without defining the file data, it'll be a emptyString
by default.
DocumentFile.canRead
it's now calling the right API (canRead
) instead of the similar one (canWrite
).- Fix infinite loading of
getDocumentThumbnail
API when thumbnail is not available.
- The example project is no longer dependant of
permission_handler
plugin to requeststorage
permission since it's already fully integrated with Storage Access Framework. - File cards have now a expanded and collapsed state instead of showing all data at once.
- Icon thumbnails were added to
.apk
image/*
,video/*
,text/plain
anddirectories
to make easier to see what is the type of the file while navigating between the folders. - 4 new buttons were added related to
writeToFile
API: Write to file (Overwrite file contents with a predefined string), Append to file (Append a predefined string to the end of the file), Ease file content (Self explanatory: erase it's data but do not delete the file) and Edit file content (Prompt the user with a text field to define the new file content), all buttons requires confirmation since it can cause data loss. - It's now possible to create a file with a custom name through the UI (Create a custom document action button on top center of the file list page).
- File card now shows the decoded uris to fix the visual pollution.
Minimal hotfix:
Minimal hotfix of the example project:
Fix the current behavior of listFiles
and openDocumentFile
API.
- It's now possible to list contents of all subfolders of a granted Uri opened from
openDocumentTree
(@EternityForest). - Now
ACTION_VIEW
intent builder throughopenDocumentFile
API was fixed. So it's now possible to open any file of any kind in third party apps without needing specify the mime type.
- Removed Android specific APIs:
DocumentFile.listFiles
(Now it's only available globally).buildDocumentUriUsingTree
removed due high coupling with Android API (Android specific API that are not useful on any other platforms).buildDocumentUri
removed due high coupling with Android API (Android specific API that are not useful on any other platforms).buildTreeDocumentUri
removed due high coupling with Android API (Android specific API that are not useful on any other platforms).
getDocumentThumbnail
now receives only theuri
param instead of arootUri
and adocumentId
.rootUri
field fromQueryMetadata
was removed due API ambiguity: there's no such concept in the Android API and this is not required by it to work well.
Minor improvements and bug fixes:
- Crash when ommiting
DocumentFileColumn.id
column onlistFiles
API. Thanks to @EternityForest. - Updated docs to info that now
DocumentFileColumn.id
column is optional when callinglistFiles
.
Major release focused on support for Storage Access Framework
.
minSdkVersion
set to19
.getMediaStoreContentDirectory
return type changed toUri
.- Import package directive path is now modular. Which means you need to import the modules you are using:
import 'package:shared_storage/saf.dart' as saf;
to enable Storage Access Framework API.import 'package:shared_storage/environment.dart' as environment;
to enable Environment API.import 'package:shared_storage/media_store.dart' as mediastore;
to enable Media Store API.import 'package:shared_storage/shared_storage' as sharedstorage;
if you want to import all above and as a single module (Not recommended because can conflict/override names/methods).
See the label reference here.
-
Original
listFiles
. This API does the same thing asDocumentFile.listFiles
but through Android queries and not calling directly theDocumentFile.listFiles
API for performance reasons. -
Internal
DocumentFile
fromDocumentFile
SAF class. -
Internal
QueryMetadata
metadata of the queries used bylistFiles
API. -
Internal
PartialDocumentFile
. Represents a partial document file returned bylistFiles
API. -
openDocumentTree
now acceptsgrantWritePermission
andinitialUri
params which, respectively, sets whether or not grant write permission level and the initial uri location of the folder authorization picker. -
Mirror
DocumentFileColumn
fromDocumentsContract.Document.<Column>
SAF class. -
Mirror
canRead
fromDocumentFile.canRead
. Returnstrue
if the caller can read the givenuri
. -
Mirror
canWrite
fromDocumentFile.canWrite
. Returnstrue
if the caller can write to the givenuri
. -
Mirror
getDocumentThumbnail
fromDocumentsContract.getDocumentThumbnail
. Returns the image thumbnail of a givenuri
, if any (e.g documents that can show a preview, like image or pdf, otherwisenull
). -
Mirror
exists
fromDocumentsContract.exists
. Returnstrue
if a givenuri
exists. -
Mirror
buildDocumentUriUsingTree
fromDocumentsContract.buildDocumentUriUsingTree
. -
Mirror
buildDocumentUri
fromDocumentsContract.buildDocumentUri
. -
Mirror
buildTreeDocumentUri
fromDocumentsContract.buildTreeDocumentUri
. -
Mirror
delete
fromDocumentFile.delete
. Self explanatory. -
Mirror
createDirectory
fromDocumentFile.createDirectory
. Creates a new child document file that represents a directory given thedisplayName
(folder name). -
Alias
createFile
. Alias forcreateFileAsBytes
orcreateFileAsString
depending which params are provided. -
Mirror
createFileAsBytes
fromDocumentFile.createFile
. Given the parent uri, creates a new child document file that represents a single file given thedisplayName
,mimeType
and itscontent
in bytes (file name, file type and file content in raw bytes, respectively). -
Alias
createFileAsString
. Alias forcreateFileAsBytes(bytes: Uint8List.fromList('file content...'.codeUnits))
. -
Mirror
documentLength
fromDocumentFile.length
. Returns the length of the given file (uri) in bytes. Returns 0 if the file does not exist, or if the length is unknown. -
Mirror
lastModified
fromDocumentFile.lastModified
. Returns the time when the given file (uri) was last modified, measured in milliseconds since January 1st, 1970, midnight. Returns 0 if the file does not exist, or if the modified time is unknown. -
Mirror
findFile
fromDocumentFile.findFile
. Search through listFiles() for the first document matching the given display name, this method has a really poor performance for large data sets, prefer usingchild
instead. -
Mirror
fromTreeUri
fromDocumentFile.fromTreeUri
. -
Mirror
renameTo
fromDocumentFile.renameTo
. Rename a document file given itsuri
to the givendisplayName
. -
Mirror
parentFile
fromDocumentFile.parentFile
. Get the parent document of the given document file from its uri. -
Mirror
copy
fromDocumentsContract.copyDocument
. Copies the given document to the givendestination
. -
Original
getDocumentContent
. Read a document file from its uri by opening a input stream and returning its bytes. -
External
child
fromcom.anggrayudi.storage.file.DocumentFile.child
. Find the child file of a given parent uri and child name, null if doesn't exists (faster thanfindFile
). -
Original
UNSTABLE
openDocumentFile
. Open a file uri in a external app, by starting a new activity withACTION_VIEW
Intent. -
Original
UNSTABLE
getRealPathFromUri
. Return the real path to work with native oldFile
API instead Uris, be aware this approach is no longer supported on Android 10+ (API 29+) and though new, this API is marked as deprecated and should be migrated to a scoped-storage approach. -
Alias
getDocumentContentAsString
. Alias forgetDocumentContent
. Convert all bytes returned by the original method into aString
. -
Internal
DocumentBitmap
class added. Commonly used as thumbnail image/bitmap of aDocumentFile
. -
Extension
UriDocumentFileUtils
onUri
(Accesible byuri.extensionMethod(...)
).- Alias
toDocumentFile
. Alias forDocumentFile.fromTreeUri(this)
which is an alias forfromTreeUri
. method: convertthis
to the respectiveDocumentFile
(if exists, otherwisenull
). - Alias
openDocumentFile
. Alias foropenDocumentFile
.
- Alias
-
Mirror
getDownloadCacheDirectory
fromEnvironment.getDataDirectory
. -
Mirror
getStorageDirectory
fromEnvironment.getStorageDirectory
.
getExternalStoragePublicDirectory
was marked as deprecated and should be replaced with an equivalent API depending on your use-case, see how to migrategetExternalStoragePublicDirectory
. This deprecation is originated from official Android documentation and not by the plugin itself.
Add basic support for Storage Access Framework
and targetSdk 31
.
- The package now supports basic intents from
Storage Access Framework
. - Your App needs update the
build.gradle
by targeting the current sdk to31
.
Minor improvements on pub.dev
documentation.
- Add
example/
folder. - Add missing
pubspec.yaml
properties.
Initial release.