Improve pause info display and error handling

This commit is contained in:
Alexandr Stelnykovych
2025-11-26 13:01:24 +02:00
parent 4913147dd5
commit d635db77c2
4 changed files with 51 additions and 16 deletions

View File

@@ -222,8 +222,8 @@
<span class="text-secondary">
<span class="text-secondary">{{ pauseInfo }} </span>
</span>
<span class="text-secondary">
Auto-resume at <span class="text-secondary">{{ pauseInfoTillTime }} </span>
<span class="text-secondary" *ngIf="pauseInfoTillTime">
{{ pauseInfoTillTime }}
</span>
</div>
<hr/>

View File

@@ -50,8 +50,12 @@ export class NavigationComponent implements OnInit {
return '';
}
get pauseInfoTillTime(): string {
if (this.isPaused && this.pauseState?.TillTime)
return new Date(this.pauseState.TillTime).toLocaleTimeString(undefined, { hour12: false });
if (this.isPaused && this.pauseState?.TillTime) {
const date = new Date(this.pauseState.TillTime);
if (isNaN(date.getTime()) || date.getTime() < Date.now())
return '';
return `Auto-resume at ${date.toLocaleTimeString(undefined, { hour12: false })}`;
}
return '';
}

View File

@@ -2,7 +2,7 @@ use std::ops::Deref;
use std::sync::atomic::AtomicBool;
use std::sync::RwLock;
use std::{sync::atomic::Ordering};
use chrono::{DateTime};
use chrono::{DateTime, Local};
use log::{debug, error};
use tauri::{
@@ -163,14 +163,22 @@ fn build_tray_menu(
(false, true) => "SPN is paused",
_ => unreachable!(), // We already checked at least one is true
};
let status_item = MenuItemBuilder::with_id(PAUSE_INFO_KEY, status_text).enabled(false).build(app)?;
let status_item = MenuItemBuilder::with_id(PAUSE_INFO_KEY, status_text).enabled(false).build(app).ok();
let formatted_time = DateTime::parse_from_rfc3339(&pause_info.till_time)
.map(|dt| dt.with_timezone(&chrono::Local).format("%H:%M:%S").to_string())
.unwrap_or_else(|_| pause_info.till_time.clone());
let time_item = MenuItemBuilder::with_id(PAUSE_INFO_TIME_KEY, format!("Auto-resume at {}", formatted_time)).enabled(false).build(app)?;
let resume_item = MenuItemBuilder::with_id(RESUME_KEY, "Resume now").build(app)?;
(Some(status_item), Some(time_item), Some(resume_item))
let time_item = if let Ok(resume_time) = DateTime::parse_from_rfc3339(&pause_info.till_time) {
let resume_time_local = resume_time.with_timezone(&Local);
if resume_time_local > Local::now() {
let formatted_time = resume_time_local.format("%H:%M:%S").to_string();
MenuItemBuilder::with_id(PAUSE_INFO_TIME_KEY, format!("Auto-resume at {}", formatted_time)).enabled(false).build(app).ok()
} else {
None
}
} else {
None
};
let resume_item = MenuItemBuilder::with_id(RESUME_KEY, "Resume now").build(app).ok();
(status_item, time_item, resume_item)
} else {
(None, None, None)
};