canonrs-core 0.1.0

CanonRS core types, traits and primitives
//! @canon-level: strict
//! @canon-owner: primitives-team
//! Skeleton Primitive - HTML puro

use leptos::prelude::*;

#[derive(Clone, Copy, PartialEq, Default)]
pub enum SkeletonVariant {
    #[default]
    Rectangle,
    Text,
    Circle,
}
impl SkeletonVariant {
    pub fn as_str(&self) -> &'static str {
        match self {
            Self::Rectangle => "rectangle",
            Self::Text      => "text",
            Self::Circle    => "circle",
        }
    }
}

#[component]
pub fn SkeletonPrimitive(
    children: Children,
    #[prop(default = SkeletonVariant::Rectangle)] variant: SkeletonVariant,
    #[prop(into, default = String::new())] class: String,
) -> impl IntoView {
    let uid_skl = crate::infra::uid::generate("skl");
    view! {
        <div
            data-rs-skeleton=""
            data-rs-uid=uid_skl
            data-rs-variant=variant.as_str()
            aria-busy="true"
            aria-live="polite"
            class=class
        >
            {children()}
        </div>
    }
}