|
|
@ -35,12 +35,22 @@ enum Colorway {
|
|
|
|
|
|
|
|
|
|
|
|
#[component]
|
|
|
|
#[component]
|
|
|
|
fn ResultMessage(cx: Scope, message: ReadSignal<Option<ResultMessageData>>) -> impl IntoView {
|
|
|
|
fn ResultMessage(cx: Scope, message: ReadSignal<Option<ResultMessageData>>) -> impl IntoView {
|
|
|
|
move || message().map(|ResultMessageData { title, message, colorway }| view! { cx,
|
|
|
|
let (open, set_open) = create_signal(cx, true);
|
|
|
|
<div class=class_list!["box", <Colorway as Into<&str>>::into(colorway)]>
|
|
|
|
create_effect(cx, move |_| {
|
|
|
|
<h3>{title}</h3>
|
|
|
|
message.track();
|
|
|
|
|
|
|
|
set_open(true);
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
move || view! { cx,
|
|
|
|
|
|
|
|
<Show when=move || open() fallback=|_| ()>
|
|
|
|
|
|
|
|
{move || message().map(|ResultMessageData { title, message, colorway }| view! { cx,
|
|
|
|
|
|
|
|
<div class=class_list!["box", <Colorway as Into<&str>>::into(colorway)] style="position: relative">
|
|
|
|
|
|
|
|
<strong class="block titlebar">{title}</strong>
|
|
|
|
|
|
|
|
<button class="iconbutton" on:click=move |_| set_open(false) style="position: absolute; bottom: 0.5em; right: 0.5em">"×"</button>
|
|
|
|
<p>{message}</p>
|
|
|
|
<p>{message}</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
})
|
|
|
|
})}
|
|
|
|
|
|
|
|
</Show>
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[derive(From, IntoStaticStr)]
|
|
|
|
#[derive(From, IntoStaticStr)]
|
|
|
|