| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- import * as React from "react"
- import { cn } from "@/lib/utils"
- function Card({
- className,
- ...props
- }) {
- return (
- <div
- data-slot="card"
- className={cn(
- "bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm",
- className
- )}
- {...props} />
- );
- }
- function CardHeader({
- className,
- ...props
- }) {
- return (
- <div
- data-slot="card-header"
- className={cn(
- "@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-2 px-6 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6",
- className
- )}
- {...props} />
- );
- }
- function CardTitle({
- className,
- ...props
- }) {
- return (
- <div
- data-slot="card-title"
- className={cn("leading-none font-semibold", className)}
- {...props} />
- );
- }
- function CardDescription({
- className,
- ...props
- }) {
- return (
- <div
- data-slot="card-description"
- className={cn("text-muted-foreground text-sm", className)}
- {...props} />
- );
- }
- function CardAction({
- className,
- ...props
- }) {
- return (
- <div
- data-slot="card-action"
- className={cn(
- "col-start-2 row-span-2 row-start-1 self-start justify-self-end",
- className
- )}
- {...props} />
- );
- }
- function CardContent({
- className,
- ...props
- }) {
- return (<div data-slot="card-content" className={cn("px-6", className)} {...props} />);
- }
- function CardFooter({
- className,
- ...props
- }) {
- return (
- <div
- data-slot="card-footer"
- className={cn("flex items-center px-6 [.border-t]:pt-6", className)}
- {...props} />
- );
- }
- export {
- Card,
- CardHeader,
- CardFooter,
- CardTitle,
- CardAction,
- CardDescription,
- CardContent,
- }
|