shacn-dashboard/components/dashboard/payments-table.tsx
Pierre Wessman a1c3c2f43c dashboard v1
2025-12-12 10:46:15 +01:00

99 lines
3.1 KiB
TypeScript

import {
Card,
CardContent,
CardDescription,
CardHeader,
CardTitle,
} from "@/components/ui/card"
import {
Table,
TableBody,
TableCell,
TableHead,
TableHeader,
TableRow,
} from "@/components/ui/table"
import { Badge } from "@/components/ui/badge"
import {
DropdownMenu,
DropdownMenuContent,
DropdownMenuItem,
DropdownMenuLabel,
DropdownMenuTrigger,
} from "@/components/ui/dropdown-menu"
import { Button } from "@/components/ui/button"
import { MoreHorizontal } from "lucide-react"
import type { Payment } from "@/types/dashboard"
interface PaymentsTableProps {
payments: Payment[]
}
export function PaymentsTable({ payments }: PaymentsTableProps) {
const getStatusColor = (status: Payment["status"]) => {
switch (status) {
case "success":
return "bg-green-500/10 text-green-500 hover:bg-green-500/20"
case "processing":
return "bg-yellow-500/10 text-yellow-500 hover:bg-yellow-500/20"
case "failed":
return "bg-red-500/10 text-red-500 hover:bg-red-500/20"
default:
return ""
}
}
return (
<Card>
<CardHeader>
<CardTitle>Recent Payments</CardTitle>
<CardDescription>You have {payments.length} payments this month.</CardDescription>
</CardHeader>
<CardContent>
<div className="overflow-x-auto">
<Table>
<TableHeader>
<TableRow>
<TableHead>Status</TableHead>
<TableHead>Email</TableHead>
<TableHead className="text-right">Amount</TableHead>
<TableHead className="text-right">Actions</TableHead>
</TableRow>
</TableHeader>
<TableBody>
{payments.map((payment) => (
<TableRow key={payment.id}>
<TableCell>
<Badge className={getStatusColor(payment.status)} variant="secondary">
{payment.status}
</Badge>
</TableCell>
<TableCell className="font-medium">{payment.email}</TableCell>
<TableCell className="text-right">
${payment.amount.toFixed(2)}
</TableCell>
<TableCell className="text-right">
<DropdownMenu>
<DropdownMenuTrigger asChild>
<Button variant="ghost" className="h-8 w-8 p-0">
<span className="sr-only">Open menu</span>
<MoreHorizontal className="h-4 w-4" />
</Button>
</DropdownMenuTrigger>
<DropdownMenuContent align="end">
<DropdownMenuLabel>Actions</DropdownMenuLabel>
<DropdownMenuItem>View details</DropdownMenuItem>
<DropdownMenuItem>Download receipt</DropdownMenuItem>
</DropdownMenuContent>
</DropdownMenu>
</TableCell>
</TableRow>
))}
</TableBody>
</Table>
</div>
</CardContent>
</Card>
)
}