card.tsx 1.4 KB

1234567891011121314151617181920212223242526272829303132333435
  1. import * as React from 'react';
  2. import { cn } from '@/common/helpers/cn';
  3. function Card({ className, ...props }: React.ComponentProps<'div'>) {
  4. return (
  5. <div
  6. data-slot="card"
  7. className={cn('flex flex-col gap-6 rounded-xl border bg-card py-6 text-card-foreground shadow-sm', className)}
  8. {...props}
  9. />
  10. );
  11. }
  12. function CardHeader({ className, ...props }: React.ComponentProps<'div'>) {
  13. return <div data-slot="card-header" className={cn('flex flex-col gap-1.5 px-6', className)} {...props} />;
  14. }
  15. function CardTitle({ className, ...props }: React.ComponentProps<'div'>) {
  16. return <div data-slot="card-title" className={cn('leading-none font-semibold', className)} {...props} />;
  17. }
  18. function CardDescription({ className, ...props }: React.ComponentProps<'div'>) {
  19. return <div data-slot="card-description" className={cn('text-sm text-muted-foreground', className)} {...props} />;
  20. }
  21. function CardContent({ className, ...props }: React.ComponentProps<'div'>) {
  22. return <div data-slot="card-content" className={cn('px-6', className)} {...props} />;
  23. }
  24. function CardFooter({ className, ...props }: React.ComponentProps<'div'>) {
  25. return <div data-slot="card-footer" className={cn('flex items-center px-6', className)} {...props} />;
  26. }
  27. export { Card, CardContent, CardDescription, CardFooter, CardHeader, CardTitle };