On this pageWhat is Foldkit UI?
Foldkit UI
Foldkit UI is a set of headless, accessible UI components. Each component is renderless. You provide the markup and styling through a toView callback, and Foldkit UI provides the accessibility attributes, keyboard navigation, and (where applicable) state management.
Foldkit UI components fall into two categories, distinguished by whether they carry state.
Stateful Submodels (Menu, Listbox, Combobox, Calendar, Disclosure, Dialog, Popover, and most others) manage their own Model, Message, update, and OutMessage. You embed them via h.submodel and handle their events by pattern-matching the OutMessage in your update.
Stateless render helpers (Button, Input, Textarea, Select, Fieldset) are called directly with a ViewConfig and return Html. They bundle ARIA and data attributes onto consumer-rendered DOM. No Model, no Message, no h.submodel wiring. The “Kind” column in the table below marks which is which.
| Component | Kind | Description |
|---|---|---|
| Button | Helper | Accessible button with consistent ARIA attributes and data-attribute hooks for styling. |
| Input | Helper | Text input with ARIA label/description linking and data-attribute hooks. |
| Textarea | Helper | Multi-line text input with ARIA label/description linking and data-attribute hooks. |
| Checkbox | Submodel | Toggle with accessible labeling, keyboard support, indeterminate state, and optional form integration. |
| Fieldset | Helper | Groups related form controls with a legend and description. Disabled state propagates to all children. |
| Radio Group | Submodel | Radio options with roving tabindex, keyboard navigation, and per-option label/description linking. |
| Switch | Submodel | On/off toggle with accessible labeling, keyboard support, and optional form integration. |
| Slider | Submodel | Numeric range input with pointer drag, keyboard step / page / home / end navigation, and ARIA slider semantics. |
| Select | Helper | Native select wrapper with ARIA label/description linking and data-attribute hooks. |
| Listbox | Submodel | Custom select dropdown with persistent selection, keyboard navigation, and typeahead search. |
| Combobox | Submodel | Autocomplete input with filtering, keyboard navigation, and custom rendering. |
| Dialog | Submodel | Modal dialog using native <dialog> with focus trapping, backdrop, and scroll locking. |
| Menu | Submodel | Dropdown menu with keyboard navigation, typeahead search, and aria-activedescendant focus. |
| Popover | Submodel | Floating panel with arbitrary content and natural Tab navigation. |
| Disclosure | Submodel | Show/hide toggle for building collapsible sections like FAQs and accordions. |
| Tabs | Submodel | Tabbed interface with keyboard navigation, Home/End support, and wrapping. |
| Drag and Drop | Submodel | Sortable lists and cross-container movement with pointer tracking, keyboard navigation, auto-scrolling, and screen reader announcements. |
| File Drop | Submodel | File input with drag-and-drop support, configurable accept patterns, and multiple-file mode. Emits typed OutMessages for received files and non-file drops. |
| Calendar | Submodel | Inline calendar grid with 2D keyboard navigation, locale-aware headers, min/max constraints, and disabled-date support. Foundation for date pickers. |
| Date Picker | Submodel | Input paired with a popover Calendar. Inherits the calendar’s constraint and keyboard-navigation support, with programmatic open/close and setters. |
| Animation | Submodel | Coordinates CSS enter/leave animations via a state machine and data attributes. Works with both CSS transitions and CSS keyframe animations. Sends an OutMessage when the leave animation completes. |
The UI Showcase example demonstrates every component with styled, interactive examples. It’s a good reference for how to wire up component state, handle Messages, and compose views.