React Chip Set Component

Chip Set

Release candidate (RC)

This component is in the Release Candidate phase and its API is considered stable. Minor adjustments may still occur before the final release.

React Chip Set component groups chips into an accessible, keyboard-navigable container with single or multiple selection.

Overview#

The CoreUI React Chip Set component groups multiple chips into a single container that manages roving focus, keyboard navigation, and selection. While an individual chip handles its own state (selection, removal), the chip set is responsible for everything that spans the whole group:

  • Arrow-key navigation between chips, with Home/End jumping to the edges.
  • Moving focus to a neighboring chip after one is removed.
  • Single or multiple selection through the selectionMode prop.
  • A flexible, wrapping layout with a configurable gap.

The chip set forwards selectable, filter, removable, disabled, removeIcon, selectedIcon, and ariaRemoveLabel to every chip it manages, so you set them once on the set. Each CChip is identified by its value prop.

Basic chip set#

Pass a chips array to render the chips from data. Each item is a string or an object with a value, an optional label, and any CChip props (so per-chip overrides work).

AppleBananaCherryDate

You can also compose CChip children instead of passing chips:

<CChipSet>
<CChip value="apple">Apple</CChip>
<CChip value="banana">Banana</CChip>
<CChip value="cherry">Cherry</CChip>
<CChip value="date">Date</CChip>
</CChipSet>

Selectable chips#

Set selectable to make every chip in the set selectable. With the default selectionMode of multiple, any number of chips can be active at once — useful for filters. Use selected / defaultSelected / onSelect to control the selection.

DesignDevelopmentMarketingSales

Single selection#

Use selectionMode="single" to allow only one selected chip at a time — selecting a chip deselects its siblings. This is useful for choice chips.

SmallMediumLarge

Filter chips#

Set filter to turn the chips into filter chips. A check icon is shown on each selected chip and removed when it is deselected. filter implies selectable, so you don't need to set both.

DesignDevelopmentMarketingSales

Customize the check with the selectedIcon prop, the same way you customize the remove icon.

Removable chips#

Set removable to add a remove button to every chip. When a chip is removed, focus moves to a neighboring chip.

With defaultChips the set keeps the list uncontrolled and removes chips for you (onRemove just notifies):

Filter oneFilter twoFilter three

For a controlled list use chips and drop the chip from your data in onRemove:

const [chips, setChips] = useState(['Apple', 'Banana', 'Cherry'])
return (
<CChipSet
removable
chips={chips}
onRemove={(value) => setChips((prev) => prev.filter((chip) => chip !== value))}
/>
)

Keyboard behavior#

When a chip inside a chip set is focused:

KeyAction
Enter / SpaceToggle selection of the focused chip (when selectable is enabled)
Backspace / DeleteRemove the focused chip (when removable is enabled)
ArrowLeftMove focus to the previous chip
ArrowRightMove focus to the next chip
HomeMove focus to the first chip
EndMove focus to the last chip

Disabled chips are skipped while navigating. In right-to-left layouts the arrow keys are mirrored — ArrowLeft moves to the next chip and ArrowRight to the previous one — while Home and End always jump to the first and last chip.

Accessibility#

  • The chip set manages roving focus, so the arrow keys move focus between chips rather than relying on the browser's default tab order.
  • Add a descriptive aria-label to the chip set when the group has a meaningful role (e.g., "Applied filters").
  • Selection state is reflected on each chip via aria-selected; see the Chip accessibility notes.

API#

Check out the documentation below for a comprehensive guide to all the props you can use with the components mentioned here.