|
@@ -1,274 +1,7 @@
|
|
|
-// Copyright 2019-2021 Tauri Programme within The Commons Conservancy
|
|
|
-// SPDX-License-Identifier: Apache-2.0
|
|
|
-// SPDX-License-Identifier: MIT
|
|
|
-
|
|
|
-#![cfg_attr(
|
|
|
- all(not(debug_assertions), target_os = "windows"),
|
|
|
- windows_subsystem = "windows"
|
|
|
-)]
|
|
|
-
|
|
|
-mod cmd;
|
|
|
-
|
|
|
-use serde::Serialize;
|
|
|
-use tauri::{window::WindowBuilder, RunEvent, WindowUrl};
|
|
|
-
|
|
|
#[cfg(desktop)]
|
|
|
-mod desktop {
|
|
|
- pub use std::sync::atomic::{AtomicBool, Ordering};
|
|
|
- pub use tauri::{
|
|
|
- api::dialog::ask, CustomMenuItem, GlobalShortcutManager, Manager, SystemTray, SystemTrayEvent,
|
|
|
- SystemTrayMenu, WindowEvent,
|
|
|
- };
|
|
|
-}
|
|
|
-#[cfg(desktop)]
|
|
|
-pub use desktop::*;
|
|
|
-
|
|
|
-#[derive(Clone, Serialize)]
|
|
|
-struct Reply {
|
|
|
- data: String,
|
|
|
-}
|
|
|
+mod desktop;
|
|
|
|
|
|
fn main() {
|
|
|
- #[allow(unused_mut)]
|
|
|
- let mut builder = tauri::Builder::default()
|
|
|
- .setup(move |app| {
|
|
|
- #[cfg(desktop)]
|
|
|
- create_tray(app)?;
|
|
|
-
|
|
|
- #[allow(unused_mut)]
|
|
|
- let mut window_builder = WindowBuilder::new(app, "main", WindowUrl::default())
|
|
|
- .title("Tauri API Validation")
|
|
|
- .inner_size(1000., 800.)
|
|
|
- .min_inner_size(600., 400.);
|
|
|
-
|
|
|
- #[cfg(target_os = "windows")]
|
|
|
- {
|
|
|
- window_builder = window_builder.transparent(true);
|
|
|
- window_builder = window_builder.decorations(false);
|
|
|
- }
|
|
|
-
|
|
|
- let window = window_builder.build().unwrap();
|
|
|
-
|
|
|
- #[cfg(target_os = "windows")]
|
|
|
- {
|
|
|
- let _ = window_shadows::set_shadow(&window, true);
|
|
|
- let _ = window_vibrancy::apply_blur(&window, Some((0, 0, 0, 0)));
|
|
|
- }
|
|
|
-
|
|
|
- #[cfg(debug_assertions)]
|
|
|
- window.open_devtools();
|
|
|
-
|
|
|
- std::thread::spawn(|| {
|
|
|
- let server = match tiny_http::Server::http("localhost:3003") {
|
|
|
- Ok(s) => s,
|
|
|
- Err(e) => {
|
|
|
- eprintln!("{}", e);
|
|
|
- std::process::exit(1);
|
|
|
- }
|
|
|
- };
|
|
|
- loop {
|
|
|
- if let Ok(mut request) = server.recv() {
|
|
|
- let mut body = Vec::new();
|
|
|
- let _ = request.as_reader().read_to_end(&mut body);
|
|
|
- let response = tiny_http::Response::new(
|
|
|
- tiny_http::StatusCode(200),
|
|
|
- request.headers().to_vec(),
|
|
|
- std::io::Cursor::new(body),
|
|
|
- request.body_length(),
|
|
|
- None,
|
|
|
- );
|
|
|
- let _ = request.respond(response);
|
|
|
- }
|
|
|
- }
|
|
|
- });
|
|
|
-
|
|
|
- Ok(())
|
|
|
- })
|
|
|
- .on_page_load(|window, _| {
|
|
|
- let window_ = window.clone();
|
|
|
- window.listen("js-event", move |event| {
|
|
|
- println!("got js-event with message '{:?}'", event.payload());
|
|
|
- let reply = Reply {
|
|
|
- data: "something else".to_string(),
|
|
|
- };
|
|
|
-
|
|
|
- window_
|
|
|
- .emit("rust-event", Some(reply))
|
|
|
- .expect("failed to emit");
|
|
|
- });
|
|
|
- });
|
|
|
-
|
|
|
- #[cfg(target_os = "macos")]
|
|
|
- {
|
|
|
- builder = builder.menu(tauri::Menu::os_default("Tauri API Validation"));
|
|
|
- }
|
|
|
-
|
|
|
- #[allow(unused_mut)]
|
|
|
- let mut app = builder
|
|
|
- .invoke_handler(tauri::generate_handler![
|
|
|
- cmd::log_operation,
|
|
|
- cmd::perform_request,
|
|
|
- ])
|
|
|
- .build(tauri::tauri_build_context!())
|
|
|
- .expect("error while building tauri application");
|
|
|
-
|
|
|
- #[cfg(target_os = "macos")]
|
|
|
- app.set_activation_policy(tauri::ActivationPolicy::Regular);
|
|
|
-
|
|
|
- #[allow(unused_variables)]
|
|
|
- app.run(|app_handle, e| match e {
|
|
|
- // Application is ready (triggered only once)
|
|
|
- #[cfg(desktop)]
|
|
|
- RunEvent::Ready => {
|
|
|
- let app_handle = app_handle.clone();
|
|
|
- app_handle
|
|
|
- .global_shortcut_manager()
|
|
|
- .register("CmdOrCtrl+1", move || {
|
|
|
- let app_handle = app_handle.clone();
|
|
|
- let window = app_handle.get_window("main").unwrap();
|
|
|
- window.set_title("New title!").unwrap();
|
|
|
- })
|
|
|
- .unwrap();
|
|
|
- }
|
|
|
-
|
|
|
- // Triggered when a window is trying to close
|
|
|
- #[cfg(desktop)]
|
|
|
- RunEvent::WindowEvent {
|
|
|
- label,
|
|
|
- event: WindowEvent::CloseRequested { api, .. },
|
|
|
- ..
|
|
|
- } => {
|
|
|
- // for other windows, we handle it in JS
|
|
|
- if label == "main" {
|
|
|
- let app_handle = app_handle.clone();
|
|
|
- let window = app_handle.get_window(&label).unwrap();
|
|
|
- // use the exposed close api, and prevent the event loop to close
|
|
|
- api.prevent_close();
|
|
|
- // ask the user if he wants to quit
|
|
|
- ask(
|
|
|
- Some(&window),
|
|
|
- "Tauri API",
|
|
|
- "Are you sure that you want to close this window?",
|
|
|
- move |answer| {
|
|
|
- if answer {
|
|
|
- // .close() cannot be called on the main thread
|
|
|
- std::thread::spawn(move || {
|
|
|
- app_handle.get_window(&label).unwrap().close().unwrap();
|
|
|
- });
|
|
|
- }
|
|
|
- },
|
|
|
- );
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- // Keep the event loop running even if all windows are closed
|
|
|
- // This allow us to catch system tray events when there is no window
|
|
|
- RunEvent::ExitRequested { api, .. } => {
|
|
|
- api.prevent_exit();
|
|
|
- }
|
|
|
- _ => {}
|
|
|
- })
|
|
|
-}
|
|
|
-
|
|
|
-#[cfg(desktop)]
|
|
|
-fn create_tray(app: &tauri::App) -> tauri::Result<()> {
|
|
|
- let tray_menu1 = SystemTrayMenu::new()
|
|
|
- .add_item(CustomMenuItem::new("toggle", "Toggle"))
|
|
|
- .add_item(CustomMenuItem::new("new", "New window"))
|
|
|
- .add_item(CustomMenuItem::new("icon_1", "Tray Icon 1"))
|
|
|
- .add_item(CustomMenuItem::new("icon_2", "Tray Icon 2"))
|
|
|
- .add_item(CustomMenuItem::new("switch_menu", "Switch Menu"))
|
|
|
- .add_item(CustomMenuItem::new("exit_app", "Quit"))
|
|
|
- .add_item(CustomMenuItem::new("destroy", "Destroy"));
|
|
|
- let tray_menu2 = SystemTrayMenu::new()
|
|
|
- .add_item(CustomMenuItem::new("toggle", "Toggle"))
|
|
|
- .add_item(CustomMenuItem::new("new", "New window"))
|
|
|
- .add_item(CustomMenuItem::new("switch_menu", "Switch Menu"))
|
|
|
- .add_item(CustomMenuItem::new("exit_app", "Quit"))
|
|
|
- .add_item(CustomMenuItem::new("destroy", "Destroy"));
|
|
|
- let is_menu1 = AtomicBool::new(true);
|
|
|
-
|
|
|
- let handle = app.handle();
|
|
|
- let tray_id = "my-tray".to_string();
|
|
|
- SystemTray::new()
|
|
|
- .with_id(&tray_id)
|
|
|
- .with_menu(tray_menu1.clone())
|
|
|
- .on_event(move |event| {
|
|
|
- let tray_handle = handle.tray_handle_by_id(&tray_id).unwrap();
|
|
|
- match event {
|
|
|
- SystemTrayEvent::LeftClick {
|
|
|
- position: _,
|
|
|
- size: _,
|
|
|
- ..
|
|
|
- } => {
|
|
|
- let window = handle.get_window("main").unwrap();
|
|
|
- window.show().unwrap();
|
|
|
- window.set_focus().unwrap();
|
|
|
- }
|
|
|
- SystemTrayEvent::MenuItemClick { id, .. } => {
|
|
|
- let item_handle = tray_handle.get_item(&id);
|
|
|
- match id.as_str() {
|
|
|
- "exit_app" => {
|
|
|
- // exit the app
|
|
|
- handle.exit(0);
|
|
|
- }
|
|
|
- "destroy" => {
|
|
|
- tray_handle.destroy().unwrap();
|
|
|
- }
|
|
|
- "toggle" => {
|
|
|
- let window = handle.get_window("main").unwrap();
|
|
|
- let new_title = if window.is_visible().unwrap() {
|
|
|
- window.hide().unwrap();
|
|
|
- "Show"
|
|
|
- } else {
|
|
|
- window.show().unwrap();
|
|
|
- "Hide"
|
|
|
- };
|
|
|
- item_handle.set_title(new_title).unwrap();
|
|
|
- }
|
|
|
- "new" => {
|
|
|
- WindowBuilder::new(&handle, "new", WindowUrl::App("index.html".into()))
|
|
|
- .title("Tauri")
|
|
|
- .build()
|
|
|
- .unwrap();
|
|
|
- }
|
|
|
- "icon_1" => {
|
|
|
- #[cfg(target_os = "macos")]
|
|
|
- tray_handle.set_icon_as_template(true).unwrap();
|
|
|
-
|
|
|
- tray_handle
|
|
|
- .set_icon(tauri::Icon::Raw(
|
|
|
- include_bytes!("../../../.icons/tray_icon_with_transparency.png").to_vec(),
|
|
|
- ))
|
|
|
- .unwrap();
|
|
|
- }
|
|
|
- "icon_2" => {
|
|
|
- #[cfg(target_os = "macos")]
|
|
|
- tray_handle.set_icon_as_template(true).unwrap();
|
|
|
-
|
|
|
- tray_handle
|
|
|
- .set_icon(tauri::Icon::Raw(
|
|
|
- include_bytes!("../../../.icons/icon.ico").to_vec(),
|
|
|
- ))
|
|
|
- .unwrap();
|
|
|
- }
|
|
|
- "switch_menu" => {
|
|
|
- let flag = is_menu1.load(Ordering::Relaxed);
|
|
|
- tray_handle
|
|
|
- .set_menu(if flag {
|
|
|
- tray_menu2.clone()
|
|
|
- } else {
|
|
|
- tray_menu1.clone()
|
|
|
- })
|
|
|
- .unwrap();
|
|
|
- is_menu1.store(!flag, Ordering::Relaxed);
|
|
|
- }
|
|
|
- _ => {}
|
|
|
- }
|
|
|
- }
|
|
|
- _ => {}
|
|
|
- }
|
|
|
- })
|
|
|
- .build(app)
|
|
|
- .map(|_| ())
|
|
|
+ #[cfg(desktop)]
|
|
|
+ desktop::main();
|
|
|
}
|