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

components/collapsible/collapsible.tsx
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

On this page