use leptos::prelude::*;
#[derive(serde::Serialize, serde::Deserialize, Debug, Clone, Copy, PartialEq, Default)]
pub enum InlineNoticeVariant {
#[default]
Default,
Info,
Success,
Warning,
Error,
}
impl InlineNoticeVariant {
pub fn as_str(&self) -> &'static str {
match self {
Self::Default => "default",
Self::Info => "info",
Self::Success => "success",
Self::Warning => "warning",
Self::Error => "error",
}
}
pub fn role(&self) -> &'static str {
match self {
Self::Error => "alert",
_ => "status",
}
}
pub fn aria_live(&self) -> &'static str {
match self {
Self::Error => "assertive",
_ => "polite",
}
}
}
#[component]
pub fn InlineNoticePrimitive(
children: Children,
#[prop(default = InlineNoticeVariant::Default)] variant: InlineNoticeVariant,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
let uid_in = crate::infra::uid::generate("in");
view! {
<div
data-rs-inline-notice=""
data-rs-uid=uid_in
data-rs-variant=variant.as_str()
role=variant.role()
aria-live=variant.aria_live()
aria-atomic="true"
class=class
>
{children()}
</div>
}
}
#[component]
pub fn InlineNoticeIconPrimitive(
children: Children,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<span
data-rs-inline-notice-icon=""
aria-hidden="true"
class=class
>
{children()}
</span>
}
}
#[component]
pub fn InlineNoticeContentPrimitive(
children: Children,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<span data-rs-inline-notice-content="" class=class>
{children()}
</span>
}
}