From 5e0d2170875391086b0930bba897cbe254653a2f Mon Sep 17 00:00:00 2001 From: Tristan Guichaoua Date: Sat, 7 Dec 2024 13:18:49 +0100 Subject: [PATCH 1/2] demo_web: make hash anchor case insensitive --- crates/egui_demo_app/src/wrap_app.rs | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/crates/egui_demo_app/src/wrap_app.rs b/crates/egui_demo_app/src/wrap_app.rs index bd313fb0c08..3c6774d58bc 100644 --- a/crates/egui_demo_app/src/wrap_app.rs +++ b/crates/egui_demo_app/src/wrap_app.rs @@ -111,11 +111,19 @@ impl Anchor { Self::Rendering, ] } + + #[cfg(target_arch = "wasm32")] + fn from_str_case_insensitive(anchor: &str) -> Option { + let anchor = anchor.to_lowercase(); + Anchor::all().into_iter().find(|x| x.to_string() == anchor) + } } impl std::fmt::Display for Anchor { fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - write!(f, "{self:?}") + let mut name = format!("{self:?}"); + name.make_ascii_lowercase(); + f.write_str(&name) } } @@ -263,11 +271,15 @@ impl eframe::App for WrapApp { fn update(&mut self, ctx: &egui::Context, frame: &mut eframe::Frame) { #[cfg(target_arch = "wasm32")] - if let Some(anchor) = frame.info().web_info.location.hash.strip_prefix('#') { - let anchor = Anchor::all().into_iter().find(|x| x.to_string() == anchor); - if let Some(v) = anchor { - self.state.selected_anchor = v; - } + if let Some(anchor) = frame + .info() + .web_info + .location + .hash + .strip_prefix('#') + .and_then(Anchor::from_str_case_insensitive) + { + self.state.selected_anchor = anchor; } #[cfg(not(target_arch = "wasm32"))] From 6f47bf2aff6d77b6edad825adf7cf15633a48537 Mon Sep 17 00:00:00 2001 From: Tristan Guichaoua Date: Wed, 11 Dec 2024 11:06:55 +0100 Subject: [PATCH 2/2] fix clippy lint --- crates/egui_demo_app/src/wrap_app.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/egui_demo_app/src/wrap_app.rs b/crates/egui_demo_app/src/wrap_app.rs index 3c6774d58bc..cbed988fa68 100644 --- a/crates/egui_demo_app/src/wrap_app.rs +++ b/crates/egui_demo_app/src/wrap_app.rs @@ -115,7 +115,7 @@ impl Anchor { #[cfg(target_arch = "wasm32")] fn from_str_case_insensitive(anchor: &str) -> Option { let anchor = anchor.to_lowercase(); - Anchor::all().into_iter().find(|x| x.to_string() == anchor) + Self::all().into_iter().find(|x| x.to_string() == anchor) } }