use leptos::prelude::*;
use crate::meta::DisabledState;
#[component]
pub fn MenubarPrimitive(
children: Children,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
let uid_mb = crate::infra::uid::generate("mb");
view! {
<div
data-rs-menubar=""
data-rs-uid=uid_mb
data-rs-interaction="nav"
role="menubar"
class=class
>
{children()}
</div>
}
}
#[component]
pub fn MenubarMenuPrimitive(
children: Children,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<div data-rs-menubar-menu="" class=class>
{children()}
</div>
}
}
#[component]
pub fn MenubarTriggerPrimitive(
children: Children,
#[prop(default = DisabledState::Enabled)] disabled: DisabledState,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<button
type="button"
data-rs-menubar-trigger=""
role="menuitem"
aria-haspopup="menu"
aria-expanded="false"
data-rs-disabled=if disabled.disabled() { Some("disabled") } else { None }
aria-disabled=disabled.aria_disabled()
class=class
>
{children()}
<svg data-rs-menubar-chevron="" xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" aria-hidden="true"><path d="m6 9 6 6 6-6"/></svg>
</button>
}
}
#[component]
pub fn MenubarContentPrimitive(
children: Children,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<div
data-rs-menubar-content=""
role="menu"
class=class
>
{children()}
</div>
}
}
#[component]
pub fn MenubarItemPrimitive(
children: Children,
#[prop(default = DisabledState::Enabled)] disabled: DisabledState,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<button
type="button"
data-rs-menubar-item=""
role="menuitem"
data-rs-disabled=if disabled.disabled() { Some("disabled") } else { None }
aria-disabled=disabled.aria_disabled()
tabindex=if disabled.disabled() { "-1" } else { "0" }
class=class
>
{children()}
</button>
}
}
#[component]
pub fn MenubarSeparatorPrimitive(
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<div data-rs-menubar-separator="" role="separator" class=class />
}
}
#[component]
pub fn MenubarLabelPrimitive(
children: Children,
#[prop(into, default = String::new())] class: String,
) -> impl IntoView {
view! {
<div
data-rs-menubar-label=""
role="presentation"
aria-hidden="true"
class=class
>
{children()}
</div>
}
}