This commit is contained in:
@@ -4,6 +4,8 @@ use serde::{Deserialize, Serialize};
|
|||||||
use sycamore::prelude::*;
|
use sycamore::prelude::*;
|
||||||
use web_sys::Event;
|
use web_sys::Event;
|
||||||
|
|
||||||
|
use crate::components::error_block::{ErrorBlock, ErrorBlockProps};
|
||||||
|
|
||||||
cfg_if::cfg_if! {
|
cfg_if::cfg_if! {
|
||||||
if #[cfg(client)] {
|
if #[cfg(client)] {
|
||||||
use crate::{
|
use crate::{
|
||||||
@@ -150,19 +152,7 @@ fn login_form_capsule<G: Html>(
|
|||||||
div (class="space-y-6 px-6 lg:px-8 pb-4 sm:pb-6 xl:pb-8") {
|
div (class="space-y-6 px-6 lg:px-8 pb-4 sm:pb-6 xl:pb-8") {
|
||||||
h3 (class="text-xl font-medium text-gray-900 dark:text-white"){"Sign in"}
|
h3 (class="text-xl font-medium text-gray-900 dark:text-white"){"Sign in"}
|
||||||
|
|
||||||
(match state.error.get().as_ref() != "" {
|
ErrorBlock(error = state.error.clone())
|
||||||
true => { view!{cx,
|
|
||||||
div (role="alert") {
|
|
||||||
div (class="bg-red-500 text-white font-bold rounded-t px-4 py-2") {
|
|
||||||
"Error"
|
|
||||||
}
|
|
||||||
div (class="border border-t-0 border-red-400 rounded-b bg-red-100 px-4 py-3 text-red-700"){
|
|
||||||
p {(state.error.get())}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}},
|
|
||||||
false => {view!{cx,}},
|
|
||||||
})
|
|
||||||
|
|
||||||
div {
|
div {
|
||||||
label (class="text-sm font-medium text-gray-900 block mb-2 dark:text-gray-300") {"Username"}
|
label (class="text-sm font-medium text-gray-900 block mb-2 dark:text-gray-300") {"Username"}
|
||||||
|
|||||||
36
src/components/error_block.rs
Normal file
36
src/components/error_block.rs
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
use perseus::prelude::*;
|
||||||
|
use sycamore::prelude::*;
|
||||||
|
use web_sys::Event;
|
||||||
|
|
||||||
|
cfg_if::cfg_if! {
|
||||||
|
if #[cfg(client)] {
|
||||||
|
use crate::{
|
||||||
|
state_enums::OpenState,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Prop, Debug, Clone)]
|
||||||
|
pub struct ErrorBlockProps {
|
||||||
|
error: RcSignal<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[component]
|
||||||
|
pub fn ErrorBlock<G: Html>(cx: Scope, props: ErrorBlockProps) -> View<G> {
|
||||||
|
let is_empty = create_selector(cx, || props.error.get().is_empty());
|
||||||
|
view! { cx,
|
||||||
|
(match *is_empty.get() {
|
||||||
|
true => { view!{cx,
|
||||||
|
div (role="alert") {
|
||||||
|
div (class="bg-red-500 text-white font-bold rounded-t px-4 py-2") {
|
||||||
|
"Error"
|
||||||
|
}
|
||||||
|
div (class="border border-t-0 border-red-400 rounded-b bg-red-100 px-4 py-3 text-red-700"){
|
||||||
|
p {(*props.error.get())}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}},
|
||||||
|
false => {view!{cx,}},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,2 +1,3 @@
|
|||||||
|
pub mod error_block;
|
||||||
mod header;
|
mod header;
|
||||||
pub mod layout;
|
pub mod layout;
|
||||||
|
|||||||
Reference in New Issue
Block a user