sync pause state

This commit is contained in:
Julian Freeman
2026-03-22 15:55:06 -04:00
parent 7a82f3fb81
commit 7f9e0de193
4 changed files with 35 additions and 13 deletions

View File

@@ -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);