feat(corp/rih): implement routing support for privacy policy

Mounts the privacy policy at `/privacy-policy`. Using yew_router
"properly" is difficult in components that don't make use of macros
and context magic, so I've opted to use the gloo history handling
directly to parse the location here.

Change-Id: Icde11485f9947bc860a7b2c43772bb0f4cdf2ea1
Reviewed-on: https://cl.tvl.fyi/c/depot/+/8653
Tested-by: BuildkiteCI
Reviewed-by: tazjin <tazjin@tvl.su>
This commit is contained in:
Vincent Ambo 2023-05-27 13:48:28 +03:00 committed by tazjin
parent f2ed94b9d7
commit c7e7f6d682

View file

@ -1,6 +1,8 @@
use fuzzy_matcher::skim::SkimMatcherV2; use fuzzy_matcher::skim::SkimMatcherV2;
use fuzzy_matcher::FuzzyMatcher; use fuzzy_matcher::FuzzyMatcher;
use gloo::console; use gloo::console;
use gloo::history::BrowserHistory;
use gloo::history::History;
use gloo::storage::{LocalStorage, Storage}; use gloo::storage::{LocalStorage, Storage};
use rand::seq::IteratorRandom; use rand::seq::IteratorRandom;
use rand::thread_rng; use rand::thread_rng;
@ -12,6 +14,7 @@ use wasm_bindgen::JsCast;
use web_sys::{HtmlInputElement, HtmlTextAreaElement, KeyboardEvent}; use web_sys::{HtmlInputElement, HtmlTextAreaElement, KeyboardEvent};
use yew::html::Scope; use yew::html::Scope;
use yew::prelude::*; use yew::prelude::*;
use yew_router::prelude::*;
/// This code ends up being compiled for the native and for the /// This code ends up being compiled for the native and for the
/// webassembly architectures during the build & test process. /// webassembly architectures during the build & test process.
@ -59,6 +62,17 @@ impl CountryCodeAccess for rust_iso3166::CountryCode {
const VISTA_URL: &'static str = "https://vista-immigration.ru/"; const VISTA_URL: &'static str = "https://vista-immigration.ru/";
#[derive(Debug, Clone, Copy, PartialEq, Routable)]
enum Route {
#[at("/")]
Home,
#[at("/privacy-policy")]
PrivacyPolicy,
#[not_found]
#[at("/404")]
NotFound,
}
/// Represents a single record as filled in by a user. This is the /// Represents a single record as filled in by a user. This is the
/// primary data structure we want to populate and persist somewhere. /// primary data structure we want to populate and persist somewhere.
#[derive(Default, Debug, Deserialize, Serialize)] #[derive(Default, Debug, Deserialize, Serialize)]
@ -86,6 +100,9 @@ struct App {
// Current query in the citizenship field. // Current query in the citizenship field.
citizenship_query: String, citizenship_query: String,
// History handler.
history: BrowserHistory,
} }
#[derive(Clone, Debug)] #[derive(Clone, Debug)]
@ -360,8 +377,16 @@ impl Component for App {
fn view(&self, ctx: &Context<Self>) -> Html { fn view(&self, ctx: &Context<Self>) -> Html {
let link = ctx.link(); let link = ctx.link();
let location = self.history.location();
let route = Route::recognize(location.path()).unwrap_or(Route::NotFound);
include!("home.html") match route {
Route::Home => include!("home.html"),
Route::PrivacyPolicy => html! {
<main>{include!("privacy-policy.md")}</main>
},
Route::NotFound => todo!(),
}
} }
} }