2023-11-28 13:15:19 -05:00
|
|
|
// Copyright (c) Tailscale Inc & AUTHORS
|
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
|
2023-11-17 16:05:14 -08:00
|
|
|
import * as Primitive from "@radix-ui/react-collapsible"
|
|
|
|
import React, { useState } from "react"
|
|
|
|
import { ReactComponent as ChevronDown } from "src/assets/icons/chevron-down.svg"
|
|
|
|
|
|
|
|
type CollapsibleProps = {
|
|
|
|
trigger?: string
|
|
|
|
children: React.ReactNode
|
|
|
|
open?: boolean
|
|
|
|
onOpenChange?: (open: boolean) => void
|
|
|
|
}
|
|
|
|
|
|
|
|
export default function Collapsible(props: CollapsibleProps) {
|
|
|
|
const { children, trigger, onOpenChange } = props
|
|
|
|
const [open, setOpen] = useState(props.open)
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Primitive.Root
|
|
|
|
open={open}
|
|
|
|
onOpenChange={(open) => {
|
|
|
|
setOpen(open)
|
|
|
|
onOpenChange?.(open)
|
|
|
|
}}
|
|
|
|
>
|
2023-12-04 15:20:38 -05:00
|
|
|
<Primitive.Trigger className="inline-flex items-center text-gray-600 cursor-pointer hover:bg-gray-100 rounded text-sm font-medium pr-3 py-1 transition-colors">
|
2023-11-17 16:05:14 -08:00
|
|
|
<span className="ml-2 mr-1.5 group-hover:text-gray-500 -rotate-90 state-open:rotate-0">
|
|
|
|
<ChevronDown strokeWidth={3} className="stroke-gray-400 w-4" />
|
|
|
|
</span>
|
|
|
|
{trigger}
|
|
|
|
</Primitive.Trigger>
|
|
|
|
<Primitive.Content className="mt-2">{children}</Primitive.Content>
|
|
|
|
</Primitive.Root>
|
|
|
|
)
|
|
|
|
}
|