| import { forwardRef } from 'react'; | |
| import { classNames } from '~/utils/classNames'; | |
| export interface CardProps extends React.HTMLAttributes<HTMLDivElement> {} | |
| const Card = forwardRef<HTMLDivElement, CardProps>(({ className, ...props }, ref) => { | |
| return ( | |
| <div | |
| ref={ref} | |
| className={classNames( | |
| 'rounded-lg border border-bolt-elements-borderColor bg-bolt-elements-background-depth-1 text-bolt-elements-textPrimary shadow-sm', | |
| className, | |
| )} | |
| {...props} | |
| /> | |
| ); | |
| }); | |
| Card.displayName = 'Card'; | |
| const CardHeader = forwardRef<HTMLDivElement, CardProps>(({ className, ...props }, ref) => { | |
| return <div ref={ref} className={classNames('flex flex-col space-y-1.5 p-6', className)} {...props} />; | |
| }); | |
| CardHeader.displayName = 'CardHeader'; | |
| const CardTitle = forwardRef<HTMLParagraphElement, React.HTMLAttributes<HTMLHeadingElement>>( | |
| ({ className, ...props }, ref) => { | |
| return ( | |
| <h3 | |
| ref={ref} | |
| className={classNames('text-2xl font-semibold leading-none tracking-tight', className)} | |
| {...props} | |
| /> | |
| ); | |
| }, | |
| ); | |
| CardTitle.displayName = 'CardTitle'; | |
| const CardDescription = forwardRef<HTMLParagraphElement, React.HTMLAttributes<HTMLParagraphElement>>( | |
| ({ className, ...props }, ref) => { | |
| return <p ref={ref} className={classNames('text-sm text-bolt-elements-textSecondary', className)} {...props} />; | |
| }, | |
| ); | |
| CardDescription.displayName = 'CardDescription'; | |
| const CardContent = forwardRef<HTMLDivElement, CardProps>(({ className, ...props }, ref) => { | |
| return <div ref={ref} className={classNames('p-6 pt-0', className)} {...props} />; | |
| }); | |
| CardContent.displayName = 'CardContent'; | |
| const CardFooter = forwardRef<HTMLDivElement, React.HTMLAttributes<HTMLDivElement>>(({ className, ...props }, ref) => ( | |
| <div ref={ref} className={classNames('flex items-center p-6 pt-0', className)} {...props} /> | |
| )); | |
| CardFooter.displayName = 'CardFooter'; | |
| export { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent }; | |