"use client"
import * as React from "react"
import * as CollapsiblePrimitive from "@radix-ui/react-collapsible"
import { motion } from "framer-motion"
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"
asChild
{...props}
>
<motion.div
whileHover={{ scale: 1.01 }}
whileTap={{ scale: 0.99 }}
transition={{ duration: 0.2 }}
>
{props.children}
</motion.div>
</CollapsiblePrimitive.CollapsibleTrigger>
)
}
function CollapsibleContent({
...props
}: React.ComponentProps<typeof CollapsiblePrimitive.CollapsibleContent>) {
return (
<CollapsiblePrimitive.CollapsibleContent
data-slot="collapsible-content"
asChild
{...props}
>
<motion.div
initial={{ height: 0, opacity: 0 }}
animate={{ height: "auto", opacity: 1 }}
exit={{ height: 0, opacity: 0 }}
transition={{
duration: 0.3,
ease: "easeInOut"
}}
style={{ overflow: "hidden" }}
>
{props.children}
</motion.div>
</CollapsiblePrimitive.CollapsibleContent>
)
}
export { Collapsible, CollapsibleTrigger, CollapsibleContent }