#tauri-plugin #tauri #tauri-app #fs-extra #fs-pro

sys tauri-plugin-fs-pro

Extended with additional methods for files and directories

4 stable releases

2.3.0 Dec 12, 2024
2.2.0 Nov 25, 2024
2.1.0 Nov 25, 2024
2.0.0 Nov 23, 2024

#438 in Filesystem

Download history 88/week @ 2024-11-17 436/week @ 2024-11-24 104/week @ 2024-12-01 280/week @ 2024-12-08 178/week @ 2024-12-15 135/week @ 2024-12-22 59/week @ 2024-12-29 91/week @ 2025-01-05

496 downloads per month

MIT license

42KB
463 lines

tauri-plugin-fs-pro

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.

https://github.com/user-attachments/assets/33dff210-9962-4d73-9648-5227d8fd9519

Install

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

Usage

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

Methods

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.

Example

git clone https://github.com/ayangweb/tauri-plugin-fs-pro.git
pnpm install

pnpm build

cd examples/tauri-app

pnpm install

pnpm tauri dev

Thanks

  • Use file_icon_provider and image to get the system icon for a path.

  • Use open to open the path in default application.

  • Use showfile to open the path in file explorer.

  • Use flate2 and tar to compress and decompress tar.gz.

  • Use fs_extra to implement the move path.

Dependencies

~22–64MB
~1M SLoC