Accordions display a list of high-level options that can expand/collapse to reveal more information.
See CAccordion
's accessibility report
Chakra UI Vue provides 5 Accordion related components:
CAccordion
: The wrapper that clones its children to forward its props to the CAccordionItem
.CAccordionItem
: A single accordion item.CAccordionHeader
: The button that toggles the expand/collapse state of the CAccordionItem
.CAccordionPanel
: The container for the details to be revealed.CAccordionIcon
: A chevron-down icon that rotates based on the expanded/collapsed stateimport {
CAccordion,
CAccordionItem,
CAccordionHeader,
CAccordionPanel,
CAccordionIcon,
} from "@chakra-ui/vue";
By default, only one accordion item may be expanded. It can only be collapsed again by expanding another accordion item.
<c-accordion>
<c-accordion-item>
<c-accordion-header>
<c-box flex="1" text-align="left">
Section 1 title
</c-box>
<c-accordion-icon />
</c-accordion-header>
<c-accordion-panel pb="4">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat.
</c-accordion-panel>
</c-accordion-item>
<c-accordion-item>
<c-accordion-header>
<c-box flex="1" text-align="left">
Section 2 title
</c-box>
<c-accordion-icon />
</c-accordion-header>
<c-accordion-panel pb="4">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat.
</c-accordion-panel>
</c-accordion-item>
</c-accordion>
Setting the allowMultiple
prop to true
allows the accordion to permit multiple items to be expanded at once.
If you pass this prop, ensure that the
index
ordefaultIndex
prop is an array.
<c-accordion :allow-multiple="true" :default-index="[0]">
<c-accordion-item>
<c-accordion-header>
<c-box flex="1" text-align="left">
Section 1 title
</c-box>
<c-accordion-icon />
</c-accordion-header>
<c-accordion-panel pb="4">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat.
</c-accordion-panel>
</c-accordion-item>
<c-accordion-item>
<c-accordion-header>
<c-box flex="1" text-align="left">
Section 2 title
</c-box>
<c-accordion-icon />
</c-accordion-header>
<c-accordion-panel pb="4">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat.
</c-accordion-panel>
</c-accordion-item>
</c-accordion>
Setting the allowToggle
prop to true allows any expanded item to be collapsed again.
<c-accordion :allow-toggle="true">
<c-accordion-item>
<c-accordion-header>
<c-box flex="1" text-align="left">
Section 1 title
</c-box>
<c-accordion-icon />
</c-accordion-header>
<c-accordion-panel pb="4">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat.
</c-accordion-panel>
</c-accordion-item>
<c-accordion-item>
<c-accordion-header>
<c-box flex="1" text-align="left">
Section 2 title
</c-box>
<c-accordion-icon />
</c-accordion-header>
<c-accordion-panel pb="4">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat.
</c-accordion-panel>
</c-accordion-item>
</c-accordion>
The CAccordionHeader
component has aria-expanded
set to true
or false
depending on the state of the CAccordionItem
.
Use the style prop _expanded
to style this state.
<c-accordion-item>
<c-accordion-header :_expanded="{ bg: 'tomato', color: 'white' }">
<c-box flex="1" text-align="left">
Section 1 title
</c-box>
<c-accordion-icon />
</c-accordion-header>
<c-accordion-panel pb="4">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat.
</c-accordion-panel>
</c-accordion-item>
The CAccordionItem
component exposes a scoped slot with two variables: isExpanded
and isDisabled
.
In the example below, we change the icon rendered by the CAccordionIcon
based on the CAccordionItems
expanded state.
<c-accordion-item>
<c-accordion-header>
<c-box flex="1" text-align="left">
Section 1 title
</c-box>
<c-accordion-icon />
</c-accordion-header>
<c-accordion-panel pb="4">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat.
</c-accordion-panel>
</c-accordion-item>
<c-accordion-item v-slot="{ isExpanded }">
<c-accordion-header>
<c-box flex="1" text-align="left">
Section 2 title
</c-box>
<c-accordion-icon size="12px" :name="isExpanded ? 'minus' : 'add'" />
</c-accordion-header>
<c-accordion-panel pb="4">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat.
</c-accordion-panel>
</c-accordion-item>
</c-accordion>
Pressing space
or enter
when focus is on the CAccordionHeader
will toggle (expand or collapse) the accordion item.
CAccordion
#Name | Type | Default | Description |
---|---|---|---|
allowMultiple | boolean | false | If true , multiple accordion items can be expanded at once. |
allowToggle | boolean | false | If true , any expanded accordion item can be collapsed again. |
index | Number or Array of Number | 0 | The index(es) of the expanded accordion item |
defaultIndex | Number or Array of Number | The initial index(es) of the expanded accordion item |
Name | Payload type | Default | Description |
---|---|---|---|
change | Number | Array of Number |
Name | Description |
---|---|
default | Slot for CAccordionItems components |
CAccordionItem
#Name | Type | Default | Description |
---|---|---|---|
isOpen | boolean | false | If true , expands the accordion in the controlled mode. |
defaultIsOpen | boolean | false | If true , expands the accordion by on initial mount. |
id | string | A unique id for the accordion item. | |
isDisabled | boolean | false | If true , the accordion header will be disabled. |
Name | Payload type | Default | Description |
---|---|---|---|
change | Number | Array of Number |
Name | Type | Slot | Default | Description |
---|---|---|---|---|
isExpanded | Number | Array of Number | default | |
isDisabled | Number | Array of Number | default |
CAccordionHeader
#CAccordionHeader
renders a button
and composes CPseudoBox
, this means you can
style it by passing the pseudo style props _expanded
, _disabled
, _hover
,
etc.
CAccordionPanel
#CAccordionPanel
renders a div
and composes Collapse
to provide the height
animation.
Caught a mistake or want to contribute to the documentation? Edit this page on GitHub!