maud-ui 0.2.0

59 headless, accessible UI components for Rust web apps — plus block templates, a live theme customiser, and shell hooks for 15 third-party widgets (Monaco, xyflow, Excalidraw, Three.js, AG Grid, Leaflet, FullCalendar, SortableJS, and more). Built on maud + htmx, styled like shadcn/ui.
Documentation
/* data::table_full — full-featured table with search, filters, bulk
   actions, row selection, and per-row view link. */

.mui-block--data {
    width: 100%;
}

.mui-block--data__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.25rem 0 1rem;
    border-bottom: 1px solid var(--mui-border);
    margin-bottom: 1rem;
}

.mui-block--data__title {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--mui-text);
    letter-spacing: -0.01em;
}

.mui-block--data__subtitle {
    margin: 0.25rem 0 0;
    font-size: 0.875rem;
    color: var(--mui-text-muted);
}

/* Filter + search row */
.mui-block--data__filters {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    align-items: stretch;
    margin-bottom: 1rem;
}

.mui-block--data__search {
    flex: 1;
    min-width: 14rem;
}

.mui-block--data__search .mui-input {
    width: 100%;
}

.mui-block--data__filter {
    min-width: 10rem;
}

.mui-block--data__filter .mui-native-select,
.mui-block--data__filter .mui-native-select__root {
    width: 100%;
}

/* Bulk action row */
.mui-block--data__bulk {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 0.875rem;
    background: var(--mui-bg-input);
    border: 1px solid var(--mui-border);
    border-radius: var(--mui-radius-md);
    margin-bottom: 1rem;
    font-size: 0.875rem;
    color: var(--mui-text-muted);
}

.mui-block--data__bulk-label {
    white-space: nowrap;
}

.mui-block--data__bulk .mui-native-select,
.mui-block--data__bulk .mui-native-select__root {
    flex: 1;
    min-width: 0;
    max-width: 14rem;
}

@media (max-width: 640px) {
    .mui-block--data__bulk {
        flex-wrap: wrap;
    }
}

/* The table itself */
.mui-block--data__table-wrap {
    overflow-x: auto;
    border: 1px solid var(--mui-border);
    border-radius: var(--mui-radius-md);
    background: var(--mui-bg);
}

.mui-block--data__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.mui-block--data__table th {
    text-align: start;
    padding: 0.75rem;
    font-weight: 500;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--mui-text-muted);
    background: var(--mui-bg-card);
    border-bottom: 1px solid var(--mui-border);
    white-space: nowrap;
}

.mui-block--data__table td {
    padding: 0.875rem 0.75rem;
    border-bottom: 1px solid var(--mui-border);
    vertical-align: middle;
    color: var(--mui-text);
}

.mui-block--data__table tbody tr:last-child td {
    border-bottom: none;
}

.mui-block--data__table tbody tr:hover {
    background: var(--mui-bg-card);
}

.mui-block--data__select-col {
    width: 1%;
    padding-inline-start: 0.875rem;
    padding-inline-end: 0.5rem;
}

.mui-block--data__select-col input[type="checkbox"] {
    margin: 0;
    accent-color: var(--mui-accent);
    cursor: pointer;
}

.mui-block--data__stacked {
    display: flex;
    flex-direction: column;
    line-height: 1.25;
    min-width: 10rem;
}

.mui-block--data__stacked-primary {
    font-weight: 500;
    color: var(--mui-text);
}

.mui-block--data__stacked-secondary {
    color: var(--mui-text-muted);
    font-size: 0.8125rem;
}

.mui-block--data__row-link {
    color: inherit;
    text-decoration: none;
}

.mui-block--data__row-link:hover {
    color: var(--mui-accent-text);
}

.mui-block--data__actions-col {
    width: 1%;
    white-space: nowrap;
    text-align: end;
    padding-inline-end: 0.875rem;
}

.mui-block--data__row-action {
    color: var(--mui-text-muted);
    text-decoration: none;
    font-size: 0.8125rem;
    font-weight: 500;
}

.mui-block--data__row-action:hover {
    color: var(--mui-accent-text);
}

.mui-block--data__empty td {
    text-align: center;
    padding: 2rem 1rem;
    color: var(--mui-text-muted);
}

.mui-block--data__pagination-summary {
    margin: 0.75rem 0 0;
    font-size: 0.8125rem;
    color: var(--mui-text-muted);
    text-align: end;
}