maud-ui 0.1.0

58 headless, accessible UI components for Rust web apps. Built on maud + htmx, styled like shadcn/ui.
Documentation
/* ── Menubar ──────────────────────────────────────────────────────────── */

.mui-menubar {
  display: inline-flex;
  align-items: center;
  background: var(--mui-bg-card);
  border: 1px solid var(--mui-border);
  border-radius: var(--mui-radius-md);
  padding: 0.25rem;
  gap: 0.125rem;
}

/* ── Trigger buttons ────────────────────────────────────────────────── */

.mui-menubar__menu {
  position: relative;
}

.mui-menubar__trigger {
  display: inline-flex;
  align-items: center;
  padding: 0.375rem 0.5rem;
  background: transparent;
  border: none;
  font-family: inherit;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.25rem;
  color: var(--mui-text);
  cursor: pointer;
  border-radius: var(--mui-radius-sm);
  -webkit-user-select: none;
  user-select: none;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1),
              color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}

.mui-menubar__trigger:hover,
.mui-menubar__trigger:focus-visible {
  background: var(--mui-bg-input);
  color: var(--mui-text);
  outline: none;
}

.mui-menubar__trigger[aria-expanded="true"] {
  background: var(--mui-bg-input);
  color: var(--mui-text);
}

/* ── Dropdown content ───────────────────────────────────────────────── */

.mui-menubar__content {
  position: absolute;
  top: calc(100% + 0.25rem);
  left: 0;
  min-width: 12rem;
  background: var(--mui-bg-card);
  border: 1px solid var(--mui-border);
  border-radius: var(--mui-radius-md);
  box-shadow: var(--mui-shadow-lg);
  padding: 0.25rem;
  z-index: 50;
}

.mui-menubar__content[hidden] {
  display: none;
}

/* Reuse menu item styles inside menubar dropdowns */
.mui-menubar__content .mui-menu__item,
.mui-menubar__content .mui-menu__separator,
.mui-menubar__content .mui-menu__label,
.mui-menubar__content .mui-menu__shortcut {
  /* Inherits all styles from menu.css — no overrides needed */
}

/* Mobile: allow menubar to wrap and dropdowns to fit viewport */
@media (max-width: 640px) {
  .mui-menubar {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    max-width: 100%;
  }

  .mui-menubar__content {
    min-width: 12rem;
    max-width: calc(100vw - 2rem);
  }
}