use leptos::prelude::*;
use crate::meta::VisibilityState;
#[derive(Clone, Copy, PartialEq, Default, Debug)]
pub enum ConfirmDialogVariant {
#[default]
Default,
Destructive,
Warning,
}
impl ConfirmDialogVariant {
pub fn as_str(&self) -> &'static str {
match self {
Self::Default => "primary",
Self::Destructive => "destructive",
Self::Warning => "warning",
}
}
}
#[component]
pub fn ConfirmDialogPrimitive(
children: Children,
#[prop(default = VisibilityState::Closed)] state: VisibilityState,
#[prop(default = ConfirmDialogVariant::Default)] variant: ConfirmDialogVariant,
#[prop(into, default = String::new())] uid: String,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
let uid_str = if uid.is_empty() { crate::infra::uid::generate("cd") } else { uid };
view! {
<div
data-rs-confirm-dialog=""
data-rs-interaction="overlay"
data-rs-uid=uid_str
data-rs-variant=variant.as_str()
data-rs-state=state.as_str()
class=class
>
{children()}
</div>
}
}
#[component]
pub fn ConfirmDialogOverlayPrimitive(
#[prop(default = VisibilityState::Closed)] state: VisibilityState,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<div
data-rs-confirm-dialog-overlay=""
data-rs-state=state.as_str()
class=class
/>
}
}
#[component]
pub fn ConfirmDialogTitlePrimitive(
children: Children,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<h2 data-rs-confirm-dialog-title="" class=class>
{children()}
</h2>
}
}
#[component]
pub fn ConfirmDialogDescriptionPrimitive(
children: Children,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<div data-rs-confirm-dialog-description="" class=class>
{children()}
</div>
}
}
#[component]
pub fn ConfirmDialogCancelPrimitive(
children: Children,
#[prop(into, default = "Cancel".to_string())] aria_label: String,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<button
type="button"
data-rs-confirm-dialog-cancel=""
aria-label=aria_label
class=class
>
{children()}
</button>
}
}
#[component]
pub fn ConfirmDialogConfirmPrimitive(
children: Children,
#[prop(default = ConfirmDialogVariant::Default)] variant: ConfirmDialogVariant,
#[prop(into, default = "Confirm".to_string())] aria_label: String,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<button
type="button"
data-rs-confirm-dialog-confirm=""
data-rs-variant=variant.as_str()
aria-label=aria_label
class=class
>
{children()}
</button>
}
}
#[component]
pub fn ConfirmDialogTriggerPrimitive(
children: Children,
#[prop(default = ConfirmDialogVariant::Default)] variant: ConfirmDialogVariant,
#[prop(into, default = String::new())] target: String,
#[prop(into, default = String::new())] value: String,
#[prop(into, default = String::new())] label: String,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<button
type="button"
data-rs-confirm-dialog-trigger=""
data-rs-variant=variant.as_str()
data-rs-target=target
data-rs-value=value
data-rs-label=label
aria-haspopup="alertdialog"
class=class
>
{children()}
</button>
}
}
#[component]
pub fn ConfirmDialogPortalPrimitive(children: ChildrenFn) -> impl IntoView {
view! {
<div data-rs-confirm-dialog-portal="">
{children()}
</div>
}
}
#[component]
pub fn ConfirmDialogContentPrimitive(
children: Children,
#[prop(default = VisibilityState::Closed)] state: VisibilityState,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<div
data-rs-confirm-dialog-content=""
data-rs-state=state.as_str()
role="alertdialog"
aria-modal="true"
tabindex="-1"
class=class
>
{children()}
</div>
}
}
#[component]
pub fn ConfirmDialogFooterPrimitive(
children: Children,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<div data-rs-confirm-dialog-footer="" class=class>
{children()}
</div>
}
}