tauri_plugin_preferences/
lib.rs

1use tauri::{
2  plugin::{Builder, TauriPlugin},
3  Manager, Runtime,
4};
5
6pub use models::*;
7
8#[cfg(desktop)]
9mod desktop;
10#[cfg(mobile)]
11mod mobile;
12
13mod commands;
14mod error;
15mod models;
16
17pub use error::{Error, Result};
18
19#[cfg(desktop)]
20use desktop::Preferences;
21#[cfg(mobile)]
22use mobile::Preferences;
23
24/// Extensions to [`tauri::App`], [`tauri::AppHandle`] and [`tauri::Window`] to access the preferences APIs.
25pub trait PreferencesExt<R: Runtime> {
26  fn preferences(&self) -> &Preferences<R>;
27}
28
29impl<R: Runtime, T: Manager<R>> crate::PreferencesExt<R> for T {
30  fn preferences(&self) -> &Preferences<R> {
31    self.state::<Preferences<R>>().inner()
32  }
33}
34
35/// Initializes the plugin.
36pub fn init<R: Runtime>() -> TauriPlugin<R> {
37  Builder::new("preferences")
38    .invoke_handler(tauri::generate_handler![
39      commands::get,
40      commands::set,
41      commands::remove,
42      commands::clear,
43      commands::has
44    ])
45    .setup(|app, api| {
46      #[cfg(mobile)]
47      let preferences = mobile::init(app, api)?;
48      #[cfg(desktop)]
49      let preferences = desktop::init(app, api)?;
50      app.manage(preferences);
51      Ok(())
52    })
53    .build()
54}