NV Elements Catalog Starters Repo System Themes About Getting Started Changelog Metrics Support Accessibility Contributions Requests Migration Integrations Installation MCP CLI Lint Angular Bundles Extensions Golang Hugo Import Maps Lit NextJS Nuxt Preact React SolidJS Svelte TypeScript Vue Foundations Typography Iconography Themes Design Tokens Size & Space Objects Interactions Support Status Color Animation Fonts Layers Custom Layout Horizontal Vertical Grid Popovers i18n Visualization View Transitions Elements Accordion Alert Avatar Badge Breadcrumb Button Button Group Card Chat Message Checkbox Color Combobox Copy Button Datagrid Integrations Column Action Column Alignment Column Fixed Column width Container Card Display Settings Footer Heatmap Keynav Multi Select Pagination Panel Detail Panel Grid Performance Placeholder Row Action Row Groups Row Sort Scroll Height Single Select Stripe Date Datetime Dialog Divider Dot Drawer Dropdown Dropdown Group Dropzone File Format Datetime Format Number Format Relative Time Forms Validation Actions Control Icon Icon Button Input Input Group Logo Menu Month Notification Page Page Header Page Loader Pagination Panel Progressive Filter Chip Progress Bar Progress Ring Password Preferences Input Pulse Radio Range Resize Handle Search Select Skeleton Sort Button Sparkline Star Rating Steps Switch Tabs Tag Textarea Time Toast Toggletip Toolbar Tooltip Tree Week Patterns Authentication Browse Dashboard Editor Empty States Heatmap Keyboard Shortcut Logging Media Navigation Onboarding Panel Responsive Search Subheader Trend Code Codeblock Monaco Input Diff Input Editor Diff Editor Problems Markdown Markdown CSS Utility Labs Responsive Layout Viewport Container Patterns Forms API Design Properties & Attributes Slots Registration CustomEvents Stateless Composition Styles Packaging Glossary Logs Internal Guidelines Agent Harness Documentation Examples TypeScript Testing Unit Testing Accessibility Testing Lighthouse Testing SSR Testing Visual Testing Troubleshooting Component Creation Internal Examples All Examples

Controls

stable:  0.1.1 Coverage: 92.10% Bundle: 19.73kb Lighthouse: 100 Axe Core Released: 0.3.0
Overview API Examples

Wraps a form input with its associated label and validation messages, managing layout and accessibility associations.

message

Installation


    

The <nve-control> element is the base control that the <nve-* form controls extend. It works for generic input type as well as custom or third party form controls.

Responsive

All control elements are responsive and adjust to one of the set layouts based on the available space.

The element breakpoints use the available space to the element rather than the viewport.

Responsive form controls with layout adaptation in resizable containers.

message message message message

Prominence Muted

Use the prominence muted state to lower visual weight of controls in forms.

Custom Controls

Custom inputs work with and leverage the same form layouts and validation statuses as the built in controls.

Place the nve-control attribute on the element that is the custom input.


    

Form Associated Elements

Many of the form controls wrap the native HTML form element or <input> element with the corresponding type attribute set.


    

But Elements includes Form Associated Elements which emit change / input events and work with native HTML <form> validation and FormData submission.

On these elements, subscribe to event changes and set the value directly on the custom <nve-* elements rather than on an <input>:


    

All form elements display the Form Control badge in the docs.

Release Status

All elements and features go through 3 phases of stability, pre-release, beta and stable.

pre-release
Docs Preview API Documentation Fully Themeable
beta
Robust unit test coverages Passed API Review Passed Designer VQA Review Included in library package
stable
No known outstanding AA WCAG issues No known outstanding performance issues Adapts to different screen/container sizes No breaking API changes for at least 90 days