sync pause state
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
use tauri::{
|
||||
menu::{Menu, MenuItem},
|
||||
tray::{MouseButton, MouseButtonState, TrayIconBuilder, TrayIconEvent},
|
||||
AppHandle, Manager,
|
||||
AppHandle, Manager, Emitter,
|
||||
};
|
||||
|
||||
pub fn create_tray(app: &AppHandle) -> tauri::Result<()> {
|
||||
@@ -11,7 +11,9 @@ pub fn create_tray(app: &AppHandle) -> tauri::Result<()> {
|
||||
|
||||
let menu = Menu::with_items(app, &[&open_i, &toggle_i, &quit_i])?;
|
||||
|
||||
let toggle_i_clone = toggle_i.clone();
|
||||
// Store the toggle item in state for future updates
|
||||
let state = app.state::<crate::engine::AppState>();
|
||||
*state.toggle_menu_item.lock().unwrap() = Some(toggle_i.clone());
|
||||
|
||||
TrayIconBuilder::with_id("main_tray")
|
||||
.tooltip("Chrono Snap")
|
||||
@@ -31,8 +33,13 @@ pub fn create_tray(app: &AppHandle) -> tauri::Result<()> {
|
||||
let new_state = !current;
|
||||
state.is_paused.store(new_state, std::sync::atomic::Ordering::SeqCst);
|
||||
|
||||
let text = if new_state { "恢复记录" } else { "暂停记录" };
|
||||
let _ = toggle_i_clone.set_text(text);
|
||||
// Update menu text
|
||||
if let Some(item) = state.toggle_menu_item.lock().unwrap().as_ref() {
|
||||
let text = if new_state { "恢复记录" } else { "暂停记录" };
|
||||
let _ = item.set_text(text);
|
||||
}
|
||||
|
||||
let _ = app.emit("pause-state-changed", new_state);
|
||||
}
|
||||
"quit" => {
|
||||
app.exit(0);
|
||||
|
||||
Reference in New Issue
Block a user