my/ui

Command Palette

Search for a command to run...

All components

Collapsible

accordions

Origin UI component.

responsive · 460px

Install

Same command in any shadcn project — React (Vite/CRA), Next.js, Remix, Astro, and more:

$npx shadcn@latest add https://your-domain/r/collapsible.json

Usage

"use client";

import { ChevronDownIcon } from "lucide-react";
import { useState } from "react";

import { Collapsible, CollapsibleContent, CollapsibleTrigger } from "@/registry/origin-ui/collapsible";

export default function Demo() {
  const [open, setOpen] = useState(false);

  return (
    <div className="w-full max-w-sm px-4">
      <Collapsible open={open} onOpenChange={setOpen} className="rounded-md border bg-background">
        <CollapsibleTrigger className="flex w-full items-center justify-between px-4 py-3 font-semibold text-sm [&[data-state=open]>svg]:rotate-180">
          What is a collapsible?
          <ChevronDownIcon
            aria-hidden="true"
            className="shrink-0 opacity-60 transition-transform duration-200"
            size={16}
          />
        </CollapsibleTrigger>
        <CollapsibleContent className="overflow-hidden px-4 pb-3 text-muted-foreground text-sm transition-all data-[state=closed]:animate-collapsible-up data-[state=open]:animate-collapsible-down">
          A collapsible is a single expandable section that shows or hides its
          content when triggered. It is simpler than an accordion and has no
          concept of exclusive open state.
        </CollapsibleContent>
      </Collapsible>
    </div>
  );
}

Component source

"use client";

import { Collapsible as CollapsiblePrimitive } from "radix-ui";

function Collapsible({
  ...props
}: React.ComponentProps<typeof CollapsiblePrimitive.Root>) {
  return <CollapsiblePrimitive.Root data-slot="collapsible" {...props} />;
}

function CollapsibleTrigger({
  ...props
}: React.ComponentProps<typeof CollapsiblePrimitive.CollapsibleTrigger>) {
  return (
    <CollapsiblePrimitive.CollapsibleTrigger
      data-slot="collapsible-trigger"
      {...props}
    />
  );
}

function CollapsibleContent({
  ...props
}: React.ComponentProps<typeof CollapsiblePrimitive.CollapsibleContent>) {
  return (
    <CollapsiblePrimitive.CollapsibleContent
      data-slot="collapsible-content"
      {...props}
    />
  );
}

export { Collapsible, CollapsibleContent, CollapsibleTrigger };

Dependencies

radix-ui

Source: Origin UI