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

Steps

stable:  0.1.1 Coverage: 100.00% Bundle: 22.62kb Lighthouse: 100 Axe Core Released: 0.30.0
Overview API Examples

Steps enables a multi-step workflow allowing a user to complete a goal in a specific sequence.

Step 1 Step 2 Step 3 Step 4 Disabled

Installation


    

    
CLI / MCP

By showing less information at a time, multi-step workflows allow users to focus better on the content pertinent to each step and decrease the chance of errors.

The Steps component consists of a steps parent element and many steps-item elements slotted as children. The selected attribute applied by the host application gives the selected step the proper selected styles.

Apply the disabled attribute to an item to get the proper visual cues and prevent interaction. The elements handle all default interaction, hover, and active states.

Additionally, the component handles all keyboard navigation and accessibility concerns out of the box. Try using left/right arrow keys on horizontal steps or up/down arrow keys on vertical steps.

Condensed

Demonstrates different container styles to accommodate visual weight and context.

Container Description condensed

Condensed step indicator with reduced visual weight. Ideal for space-constrained layouts or secondary navigation where steps need less prominence.

Step 1 Step 2 Step 3 Step 4 Disabled

Vertical Steps

Determines whether the steps should display in a vertical layout vs. defaulting to horizontal.

Vertical Description true false

Vertical step layout for sidebar navigation or tall containers. Use when horizontal space constrains layout or steps require longer labels.

Step 1 Step 2 Step 3 Disabled Step 5

Vertical Condensed Steps

Vertical condensed steps combining both layout options. Ideal for dense sidebar navigation with minimal visual footprint.

Step 1 Step 2 Step 3 Disabled Step 5

Stateless Steps

By default Steps is stateless. This means the host application must handle selection behavior. The component provides a way to opt in to stateful selection behavior where click events and keyboard enter trigger the selection state.

All other examples on this page set behavior-select on the parent steps to opt into stateful behavior. The following example shows the default stateless behavior, where the host app has to set/remove the selected attribute on child <nve-steps-item>.

Display-only steps without interactive selection behavior. Use for showing progress indicators where external logic controls step navigation.

Step 1 Step 2 Step 3 Step 4 Disabled

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