This plugin only works on tauri v2, if you need the v1 plugin, feel free to submit a PR!
What is the difference with @tauri-apps/plugin-fs
?
The stat
method of @tauri-apps/plugin-fs
supports only files when getting size, while the metadata
method of tauri-plugin-fs-pro
supports both files and directories when getting size. And some additional methods are provided. More methods will be expanded in the future.
iShot_2024-12-12_14.46.13.mp4
cargo add tauri-plugin-fs-pro
You can install the JavaScript Guest bindings using your preferred JavaScript package manager:
pnpm add tauri-plugin-fs-pro-api
src-tauri/src/lib.rs
pub fn run() {
tauri::Builder::default()
+ .plugin(tauri_plugin_fs_pro::init())
.run(tauri::generate_context!())
.expect("error while running tauri application");
}
src-tauri/capabilities/default.json
{
...
"permissions": [
...
+ "fs-pro:default"
]
}
Afterwards all the plugin's APIs are available through the JavaScript guest bindings:
import { isExist } from "tauri-plugin-fs-pro-api";
const exists = await isExist("/Users/xxx/EcoPaste.txt");
console.log(exists); // true
Method | Description |
---|---|
isExist |
Whether the path exists. |
isDir |
Whether the path is a directory. |
isFile |
Whether the path is a file. |
size |
Get the size of the path in bytes, or 0 if it does not exist. |
name |
Get the file or directory name of the path. |
fullName |
Get the file or directory name of the path, including the extension name if it is a file. |
extname |
Get the extension name of the file. |
icon |
Get the system icon of the path. |
metadata |
Get the metadata of the path. |
open |
Open the path in file explorer or the default application. |
compress |
Compress the source path into a tar.gz file to the destination path. |
decompress |
Decompress the tar.gz file from the source path to the destination path. |
transfer |
Move the source path to the destination path. |
git clone https://github.com/ayangweb/tauri-plugin-fs-pro.git
pnpm install
pnpm build
pnpm dev