A fork of https://github.com/JonasKruckenberg/tauri-sys that builds for my choices of features
Find a file
Jonas Kruckenberg e28a0bb749
feat: improve DX of events (#12)
* feat: improve DX of events

* Update global_shortcut.rs

* Update event.rs

* deploy docs to gh pages

* Delete rustdoc.yml

* add tests for global shortcut

* improve logs produced by tauri_log

* wip docs

* update docs

* move error to separate module

* feat: simplify functions returning array backed iterators

* rebase and cleanup

* fixes
2022-11-19 20:33:06 +01:00
.github Update rustdoc.yml 2022-11-19 13:21:25 +01:00
examples/test feat: improve DX of events (#12) 2022-11-19 20:33:06 +01:00
src feat: improve DX of events (#12) 2022-11-19 20:33:06 +01:00
tauri@2e1bd04775 update tauri to 1.2.0 2022-11-14 10:20:18 +01:00
tests expand tests 2022-11-01 17:31:50 +01:00
.gitignore initial commit 2022-11-01 15:19:25 +01:00
.gitmodules initial commit 2022-11-01 15:19:25 +01:00
.nojekyll Create .nojekyll 2022-11-19 13:15:53 +01:00
Cargo.lock feat: improve DX of events (#12) 2022-11-19 20:33:06 +01:00
Cargo.toml feat: improve DX of events (#12) 2022-11-19 20:33:06 +01:00
LICENSE_APACHE-2.0 add correct licenses 2022-11-01 15:26:42 +01:00
LICENSE_MIT add correct licenses 2022-11-01 15:26:42 +01:00
package.json remove build script 2022-11-13 21:05:51 +01:00
pnpm-lock.yaml remove build script 2022-11-13 21:05:51 +01:00
README.md Update README.md 2022-11-19 17:39:33 +01:00

tauri-sys

Raw bindings to the Tauri API for projects using wasm-bindgen

Documentation master MIT licensed

Installation

This crate is not yet published to crates.io, so you need to use it from git. You also need a global installation of esbuild.

tauri-sys = { git = "https://github.com/JonasKruckenberg/tauri-sys" }

Usage

use serde::{Deserialize, Serialize};
use tauri_sys::tauri;

#[derive(Serialize, Deserialize)]
struct GreetArgs<'a> {
    name: &'a str,
}

fn main() {
    wasm_bindgen_futures::spawn_local(async move {
        let new_msg: String = tauri::invoke("greet", &GreetArgs { name: &name.get() }).await.unwrap();

        println!("{}", new_msg);
    });
}

Features

All modules are gated by accordingly named Cargo features. It is recommended you keep this synced with the features enabled in your Tauri Allowlist but no automated tool for this exists (yet).

  • all: Enables all modules.
  • app: Enables the app module.
  • clipboard: Enables the clipboard module.
  • dialog: Enables the dialog module.
  • event: Enables the event module.
  • mocks: Enables the mocks module.
  • tauri: Enables the tauri module.

Are we Tauri yet?

These API bindings are not completely on-par with @tauri-apps/api yet, but here is the current status-quo:

  • app
  • cli
  • clipboard
  • dialog
  • event
  • fs
  • global_shortcut
  • http
  • mocks
  • notification
  • os
  • path
  • process
  • shell
  • tauri
  • updater
  • window

The current API also very closely mirrors the JS API even though that might not be the most ergonomic choice, ideas for improving the API with quality-of-life features beyond the regular JS API interface are very welcome.