tauri_plugin_music_notification_api/
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::MusicNotification;
21#[cfg(mobile)]
22use mobile::MusicNotification;
23
24/// Extensions to [`tauri::App`], [`tauri::AppHandle`] and [`tauri::Window`] to access the music-notification APIs.
25pub trait MusicNotificationExt<R: Runtime> {
26  fn music_notification(&self) -> &MusicNotification<R>;
27}
28
29impl<R: Runtime, T: Manager<R>> crate::MusicNotificationExt<R> for T {
30  fn music_notification(&self) -> &MusicNotification<R> {
31    self.state::<MusicNotification<R>>().inner()
32  }
33}
34
35/// Initializes the plugin.
36pub fn init<R: Runtime>() -> TauriPlugin<R> {
37  Builder::new("music-notification")
38    .invoke_handler(tauri::generate_handler![
39      commands::ping,
40      commands::play,
41      commands::pause,
42      commands::resume,
43      commands::stop,
44      commands::next,
45      commands::previous,
46      commands::seek,
47      commands::get_state
48    ])
49    .setup(|app, api| {
50      #[cfg(mobile)]
51      let music_notification = mobile::init(app, api)?;
52      #[cfg(desktop)]
53      let music_notification = desktop::init(app, api)?;
54      app.manage(music_notification);
55      Ok(())
56    })
57    .build()
58}