Collapsible
A component that can be expanded or collapsed to show or hide content.
@riipandi starred 3 repositories
@radix-ui/primitives
@radix-ui/colors
@stitches/react
Automatic Installation
This method is still working on progress, please use manual installation for now.
Manual Installation
Install dependencies
npm install radix-ui
Copy the code
import { Collapsible as CollapsiblePrimitive } from 'radix-ui'
import * as React from 'react'
import { collapsibleStyles } from './collapsible.css'
const Collapsible = React.forwardRef<
React.ComponentRef<typeof CollapsiblePrimitive.Root>,
React.ComponentPropsWithoutRef<typeof CollapsiblePrimitive.Root>
>(({ className, ...props }, forwardedRef) => {
const styles = collapsibleStyles()
return (
<CollapsiblePrimitive.Root
ref={forwardedRef}
className={styles.base({ className })}
{...props}
/>
)
})
const CollapsibleTrigger = React.forwardRef<
React.ComponentRef<typeof CollapsiblePrimitive.Trigger>,
React.ComponentPropsWithoutRef<typeof CollapsiblePrimitive.Trigger>
>(({ className, ...props }, forwardedRef) => {
const styles = collapsibleStyles()
return (
<CollapsiblePrimitive.Trigger
ref={forwardedRef}
className={styles.trigger({ className })}
{...props}
/>
)
})
const CollapsibleContent = React.forwardRef<
React.ComponentRef<typeof CollapsiblePrimitive.Content>,
React.ComponentPropsWithoutRef<typeof CollapsiblePrimitive.Content>
>(({ className, ...props }, forwardedRef) => {
const styles = collapsibleStyles()
return (
<CollapsiblePrimitive.Content
ref={forwardedRef}
className={styles.content({ className })}
{...props}
/>
)
})
Collapsible.displayName = 'Collapsible'
CollapsibleTrigger.displayName = 'CollapsibleTrigger'
CollapsibleContent.displayName = 'CollapsibleContent'
export { Collapsible, CollapsibleTrigger, CollapsibleContent }
Usage
Imports
import {
Collapsible,
CollapsibleTrigger,
CollapsibleContent
} from '#/components/collapsible'
Example
Browse the Storybook for more examples.
Anatomy
<Collapsible>
<CollapsibleTrigger/>
<CollapsibleContent />
</Collapsible>
Edit on GitHub
Last updated on 3/24/2025