Collapsible
Conceals or reveals content sections, enhancing space utilization and organization.
	<script lang="ts">
  import { Collapsible } from "$lib";
  import { CaretUpDown } from "$icons/index.js";
  import { slide } from "svelte/transition";
</script>
 
<Collapsible.Root class="w-[327px] space-y-3">
  <div class="flex items-center justify-between space-x-10">
    <h4 class="text-[15px] font-medium">@huntabyte starred 3 repositories</h4>
    <Collapsible.Trigger
      class="inline-flex h-10 w-10 items-center justify-center rounded-9px border border-border-input bg-background text-foreground shadow-btn transition-all hover:bg-muted active:scale-98"
    >
      <CaretUpDown class="size-4 " weight="bold" />
      <span class="sr-only">Toggle</span>
    </Collapsible.Trigger>
  </div>
 
  <Collapsible.Content
    class="space-y-2 font-mono text-[15px] tracking-[0.01em]"
    transition={slide}
  >
    <div
      class="inline-flex h-12 w-full items-center rounded-9px bg-muted px-[18px] py-3"
    >
      @huntabyte/bits-ui
    </div>
    <div
      class="inline-flex h-12 w-full items-center rounded-9px bg-muted px-[18px] py-3"
    >
      @huntabyte/shadcn-svelte
    </div>
    <div
      class="inline-flex h-12 w-full items-center rounded-9px bg-muted px-[18px] py-3"
    >
      @melt-ui/melt-ui
    </div>
  </Collapsible.Content>
</Collapsible.Root>
	
@huntabyte starred 3 repositories
Structure
	<script lang="ts">
  import { Collapsible } from "bits-ui";
</script>
 
<Collapsible.Root>
  <Collapsible.Trigger />
  <Collapsible.Content />
</Collapsible.Root>
	
Controlled Usage
Sometimes, you want to either control or be aware of the open state of the collapsible from outside of the component. To do so, you can bind to the open prop.
	<script lang="ts">
  import { Collapsible } from "bits-ui";
  let collapsibleOpen = false;
</script>
 
<button on:click={() => (collapsibleOpen = true)}>Open</button>
<Collapsible.Root bind:open={collapsibleOpen}>
  <Collapsible.Trigger />
  <Collapsible.Content />
</Collapsible.Root>
	
API Reference
The root collapsible container which manages the state of the collapsible.
| Property | Type | Description | 
|---|---|---|
| disabled | boolean | Whether or not the collapsible is disabled. This prevents the user from interacting with it. Default:
								 false  | 
| open | boolean | The open state of the collapsible. The content will be visible when this is true, and hidden when it's false. Default:
								 false  | 
| onOpenChange | function | A callback that is fired when the collapsible's open state changes. Default:
								 —— undefined   | 
| asChild | boolean | Whether to use render delegation with this component or not. Default:
								 false  | 
| el | HTMLDivElement | The underlying DOM element being rendered. You can bind to this to programatically interact with the element. Default:
								 —— undefined   | 
| Slot Property | Type | Description | 
|---|---|---|
| builder | object | The builder attributes and actions to apply to the element if using the  | 
| Data Attribute | Value | Description | 
|---|---|---|
| data-disabled | —— | Present when the checkbox is disabled. | 
| data-state | enum | The collapsible's open state. | 
| data-collapsible-root | —— | Present on the root element. | 
The button responsible for toggling the collapsible's open state.
| Property | Type | Description | 
|---|---|---|
| asChild | boolean | Whether to use render delegation with this component or not. Default:
								 false  | 
| el | HTMLButtonElement | The underlying DOM element being rendered. You can bind to this to programatically interact with the element. Default:
								 —— undefined   | 
| Slot Property | Type | Description | 
|---|---|---|
| builder | object | The builder attributes and actions to apply to the element if using the  | 
| Data Attribute | Value | Description | 
|---|---|---|
| data-disabled | —— | Present when the checkbox is disabled. | 
| data-state | enum | The collapsible's open state. | 
| data-collapsible-trigger | —— | Present on the trigger element. | 
The content displayed when the collapsible is open.
| Property | Type | Description | 
|---|---|---|
| transition | function | A Svelte transition function to use when transitioning the content in and out. Default:
								 —— undefined   | 
| transitionConfig | TransitionConfig | The configuration to apply to the transition. Default:
								 —— undefined   | 
| inTransition | function | A Svelte transition function to use when transitioning the content in and out. Default:
								 —— undefined   | 
| inTransitionConfig | TransitionConfig | The configuration to apply to the transition. Default:
								 —— undefined   | 
| outTransition | function | A Svelte transition function to use when transitioning the content in and out. Default:
								 —— undefined   | 
| outTransitionConfig | TransitionConfig | The configuration to apply to the transition. Default:
								 —— undefined   | 
| asChild | boolean | Whether to use render delegation with this component or not. Default:
								 false  | 
| el | HTMLDivElement | The underlying DOM element being rendered. You can bind to this to programatically interact with the element. Default:
								 —— undefined   | 
| Slot Property | Type | Description | 
|---|---|---|
| builder | object | The builder attributes and actions to apply to the element if using the  | 
| Data Attribute | Value | Description | 
|---|---|---|
| data-disabled | —— | Present when the checkbox is disabled. | 
| data-state | enum | The collapsible's open state. | 
| data-collapsible-content | —— | Present on the content element. |