Compare commits
2 Commits
030d1c2ebe
...
d63e72ad35
| Author | SHA1 | Date | |
|---|---|---|---|
| d63e72ad35 | |||
| 33c0a106b7 |
18
Cargo.lock
generated
18
Cargo.lock
generated
@ -3168,7 +3168,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "letterbox-notmuch"
|
name = "letterbox-notmuch"
|
||||||
version = "0.17.43"
|
version = "0.17.44"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"itertools",
|
"itertools",
|
||||||
"log",
|
"log",
|
||||||
@ -3183,7 +3183,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "letterbox-procmail2notmuch"
|
name = "letterbox-procmail2notmuch"
|
||||||
version = "0.17.43"
|
version = "0.17.44"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"clap",
|
"clap",
|
||||||
@ -3196,7 +3196,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "letterbox-server"
|
name = "letterbox-server"
|
||||||
version = "0.17.43"
|
version = "0.17.44"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ammonia",
|
"ammonia",
|
||||||
"anyhow",
|
"anyhow",
|
||||||
@ -3219,8 +3219,8 @@ dependencies = [
|
|||||||
"html-escape",
|
"html-escape",
|
||||||
"html2text",
|
"html2text",
|
||||||
"ical",
|
"ical",
|
||||||
"letterbox-notmuch 0.17.43",
|
"letterbox-notmuch 0.17.44",
|
||||||
"letterbox-shared 0.17.43",
|
"letterbox-shared 0.17.44",
|
||||||
"linkify",
|
"linkify",
|
||||||
"lol_html",
|
"lol_html",
|
||||||
"mailparse",
|
"mailparse",
|
||||||
@ -3261,10 +3261,10 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "letterbox-shared"
|
name = "letterbox-shared"
|
||||||
version = "0.17.43"
|
version = "0.17.44"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"build-info",
|
"build-info",
|
||||||
"letterbox-notmuch 0.17.43",
|
"letterbox-notmuch 0.17.44",
|
||||||
"regex",
|
"regex",
|
||||||
"serde",
|
"serde",
|
||||||
"sqlx",
|
"sqlx",
|
||||||
@ -3274,7 +3274,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "letterbox-web"
|
name = "letterbox-web"
|
||||||
version = "0.17.43"
|
version = "0.17.44"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"build-info",
|
"build-info",
|
||||||
"build-info-build",
|
"build-info-build",
|
||||||
@ -3286,7 +3286,7 @@ dependencies = [
|
|||||||
"graphql_client",
|
"graphql_client",
|
||||||
"human_format",
|
"human_format",
|
||||||
"itertools",
|
"itertools",
|
||||||
"letterbox-shared 0.17.43",
|
"letterbox-shared 0.17.44",
|
||||||
"log",
|
"log",
|
||||||
"seed",
|
"seed",
|
||||||
"seed_hooks",
|
"seed_hooks",
|
||||||
|
|||||||
@ -8,7 +8,7 @@ authors = ["Bill Thiede <git@xinu.tv>"]
|
|||||||
edition = "2021"
|
edition = "2021"
|
||||||
license = "UNLICENSED"
|
license = "UNLICENSED"
|
||||||
publish = ["xinu"]
|
publish = ["xinu"]
|
||||||
version = "0.17.43"
|
version = "0.17.44"
|
||||||
repository = "https://git.z.xinu.tv/wathiede/letterbox"
|
repository = "https://git.z.xinu.tv/wathiede/letterbox"
|
||||||
|
|
||||||
[profile.dev]
|
[profile.dev]
|
||||||
|
|||||||
@ -32,8 +32,8 @@ futures = "0.3.31"
|
|||||||
headers = "0.4.0"
|
headers = "0.4.0"
|
||||||
html-escape = "0.2.13"
|
html-escape = "0.2.13"
|
||||||
ical = "0.11"
|
ical = "0.11"
|
||||||
letterbox-notmuch = { path = "../notmuch", version = "0.17.43", registry = "xinu" }
|
letterbox-notmuch = { path = "../notmuch", version = "0.17.44", registry = "xinu" }
|
||||||
letterbox-shared = { path = "../shared", version = "0.17.43", registry = "xinu" }
|
letterbox-shared = { path = "../shared", version = "0.17.44", registry = "xinu" }
|
||||||
linkify = "0.10.0"
|
linkify = "0.10.0"
|
||||||
lol_html = "2.3.0"
|
lol_html = "2.3.0"
|
||||||
mailparse = "0.16.1"
|
mailparse = "0.16.1"
|
||||||
|
|||||||
@ -2157,28 +2157,28 @@ mod tests {
|
|||||||
let meta = extract_calendar_metadata_from_mail(&parsed, &body);
|
let meta = extract_calendar_metadata_from_mail(&parsed, &body);
|
||||||
// Assert detection as Google Calendar
|
// Assert detection as Google Calendar
|
||||||
assert!(meta.is_google_calendar_event);
|
assert!(meta.is_google_calendar_event);
|
||||||
// Debug: print the rendered HTML for inspection
|
|
||||||
let html = meta.body_html.expect("body_html");
|
let html = meta.body_html.expect("body_html");
|
||||||
|
|
||||||
|
// Print event date info for debugging
|
||||||
|
for part in parsed.subparts.iter() {
|
||||||
|
if part.ctype.mimetype == TEXT_CALENDAR {
|
||||||
|
if let Ok(ical) = part.get_body() {
|
||||||
|
println!("ICAL data: {}", ical);
|
||||||
|
if let Some(start) = ical.lines().find(|l| l.starts_with("DTSTART:")) {
|
||||||
|
println!("Start date: {}", start);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
println!("Rendered HTML: {}", html);
|
println!("Rendered HTML: {}", html);
|
||||||
// Check that the calendar table highlights Thursday, not Friday
|
|
||||||
// Look for a table header row with days of week (allow whitespace)
|
// Look for September 11 (Thursday) being highlighted
|
||||||
let thursday_idx = html
|
// The calendar should show Sept 11 highlighted with background:#ffd700 and the correct data-event-day
|
||||||
.find(">\n Thu<")
|
assert!(html.contains(r#"data-event-day="2025-09-11""#));
|
||||||
.or_else(|| html.find(">Thu<"))
|
assert!(html.contains(r#"background:#ffd700"#));
|
||||||
.expect("Should have a Thursday column");
|
|
||||||
let friday_idx = html
|
// Since 1:00 AM UTC on Friday 9/12 is 6:00 PM PDT on Thursday 9/11, verify times are correct
|
||||||
.find(">\n Fri<")
|
assert!(html.contains("6:00 PM Thu Sep 11, 2025"));
|
||||||
.or_else(|| html.find(">Fri<"))
|
|
||||||
.expect("Should have a Friday column");
|
|
||||||
// Find the first highlighted cell (background:#ffd700)
|
|
||||||
let highlight_idx = html
|
|
||||||
.find("background:#ffd700")
|
|
||||||
.expect("Should highlight a day");
|
|
||||||
// The highlight should be closer to Thursday than Friday
|
|
||||||
assert!(
|
|
||||||
highlight_idx > thursday_idx && highlight_idx < friday_idx,
|
|
||||||
"Thursday should be highlighted, not Friday"
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
use super::*;
|
use super::*;
|
||||||
#[test]
|
#[test]
|
||||||
|
|||||||
@ -74,13 +74,7 @@
|
|||||||
{% for week in all_days|batch(7) %}
|
{% for week in all_days|batch(7) %}
|
||||||
<tr>
|
<tr>
|
||||||
{% for day in week %}
|
{% for day in week %}
|
||||||
{% if event_days.contains(day) && today.is_some() && today.unwrap() == day %}
|
{% if event_days.contains(day) %}
|
||||||
<td
|
|
||||||
data-event-day="{{ day.format("%Y-%m-%d") }}"
|
|
||||||
style="background:#ffd700; color:#222; font-weight:bold; border:2px solid #2196f3; border-radius:4px; text-align:center; box-shadow:0 0 0 2px #2196f3;">
|
|
||||||
{{ day.day() }}
|
|
||||||
</td>
|
|
||||||
{% elif event_days.contains(day) %}
|
|
||||||
<td
|
<td
|
||||||
data-event-day="{{ day.format("%Y-%m-%d") }}"
|
data-event-day="{{ day.format("%Y-%m-%d") }}"
|
||||||
style="background:#ffd700; color:#222; font-weight:bold; border:1px solid #aaa; border-radius:4px; text-align:center;">
|
style="background:#ffd700; color:#222; font-weight:bold; border:1px solid #aaa; border-radius:4px; text-align:center;">
|
||||||
|
|||||||
@ -12,7 +12,7 @@ version.workspace = true
|
|||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
build-info = "0.0.41"
|
build-info = "0.0.41"
|
||||||
letterbox-notmuch = { path = "../notmuch", version = "0.17.43", registry = "xinu" }
|
letterbox-notmuch = { path = "../notmuch", version = "0.17.44", registry = "xinu" }
|
||||||
regex = "1.11.1"
|
regex = "1.11.1"
|
||||||
serde = { version = "1.0.219", features = ["derive"] }
|
serde = { version = "1.0.219", features = ["derive"] }
|
||||||
sqlx = "0.8.5"
|
sqlx = "0.8.5"
|
||||||
|
|||||||
@ -33,7 +33,7 @@ wasm-bindgen = "=0.2.100"
|
|||||||
uuid = { version = "1.16.0", features = [
|
uuid = { version = "1.16.0", features = [
|
||||||
"js",
|
"js",
|
||||||
] } # direct dep to set js feature, prevents Rng issues
|
] } # direct dep to set js feature, prevents Rng issues
|
||||||
letterbox-shared = { path = "../shared/", version = "0.17.43", registry = "xinu" }
|
letterbox-shared = { path = "../shared/", version = "0.17.44", registry = "xinu" }
|
||||||
seed_hooks = { version = "0.4.1", registry = "xinu" }
|
seed_hooks = { version = "0.4.1", registry = "xinu" }
|
||||||
strum_macros = "0.27.1"
|
strum_macros = "0.27.1"
|
||||||
gloo-console = "0.3.0"
|
gloo-console = "0.3.0"
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user