mirror of
https://github.com/Sosokker/B2D-Ventures.git
synced 2025-12-19 14:04:06 +01:00
164 lines
5.9 KiB
TypeScript
164 lines
5.9 KiB
TypeScript
"use client";
|
|
|
|
import { Icons } from "./ui/icons";
|
|
import { Button } from "./ui/button";
|
|
import {
|
|
Card,
|
|
CardContent,
|
|
CardDescription,
|
|
CardFooter,
|
|
CardHeader,
|
|
CardTitle,
|
|
} from "./ui/card";
|
|
import { Input } from "./ui/input";
|
|
import { Label } from "./ui/label";
|
|
import { RadioGroup, RadioGroupItem } from "./ui/radio-group";
|
|
import {
|
|
Select,
|
|
SelectContent,
|
|
SelectItem,
|
|
SelectTrigger,
|
|
SelectValue,
|
|
} from "./ui/select";
|
|
|
|
export function CardsPaymentMethod() {
|
|
return (
|
|
<Card className="lg:w-2/3 ">
|
|
<CardHeader>
|
|
<CardTitle className="text-xl md:text-2xl">Payment Method</CardTitle>
|
|
<CardDescription className="font-normal md:font-semibold">
|
|
Add a new payment method to your account.
|
|
</CardDescription>
|
|
</CardHeader>
|
|
<CardContent className="grid gap-6">
|
|
<RadioGroup defaultValue="card" className="flex w-full justify-center gap-1 md:gap-3">
|
|
<div className="w-[100px] lg:w-[130px]">
|
|
<RadioGroupItem
|
|
value="card"
|
|
id="card"
|
|
className="peer sr-only"
|
|
aria-label="Card"
|
|
/>
|
|
<Label
|
|
htmlFor="card"
|
|
className="flex flex-col items-center justify-between rounded-md border-2 border-muted bg-transparent p-4 hover:bg-accent hover:text-accent-foreground peer-data-[state=checked]:border-primary [&:has([data-state=checked])]:border-primary"
|
|
>
|
|
<svg
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
viewBox="0 0 24 24"
|
|
fill="none"
|
|
stroke="currentColor"
|
|
strokeLinecap="round"
|
|
strokeLinejoin="round"
|
|
strokeWidth="2"
|
|
className="mb-3 h-6 w-6"
|
|
>
|
|
<rect width="20" height="14" x="2" y="5" rx="2" />
|
|
<path d="M2 10h20" />
|
|
</svg>
|
|
Card
|
|
</Label>
|
|
</div>
|
|
|
|
<div className="w-[100px] lg:w-[130px]">
|
|
<RadioGroupItem
|
|
value="paypal"
|
|
id="paypal"
|
|
className="peer sr-only"
|
|
aria-label="Paypal"
|
|
/>
|
|
<Label
|
|
htmlFor="paypal"
|
|
className="flex flex-col items-center justify-between rounded-md border-2 border-muted bg-transparent p-4 hover:bg-accent hover:text-accent-foreground peer-data-[state=checked]:border-primary [&:has([data-state=checked])]:border-primary"
|
|
>
|
|
<Icons.paypal className="mb-3 h-6 w-6" />
|
|
Paypal
|
|
</Label>
|
|
</div>
|
|
|
|
<div className="w-[100px] lg:w-[130px]">
|
|
<RadioGroupItem
|
|
value="apple"
|
|
id="apple"
|
|
className="peer sr-only"
|
|
aria-label="Apple"
|
|
/>
|
|
<Label
|
|
htmlFor="apple"
|
|
className="flex flex-col items-center justify-between rounded-md border-2 border-muted bg-transparent p-4 hover:bg-accent hover:text-accent-foreground peer-data-[state=checked]:border-primary [&:has([data-state=checked])]:border-primary"
|
|
>
|
|
<Icons.apple className="mb-3 h-6 w-6" />
|
|
Apple
|
|
</Label>
|
|
</div>
|
|
</RadioGroup>
|
|
|
|
<div className="grid grid-cols-2">
|
|
<div className="grid gap-2">
|
|
<Label htmlFor="firstname">First Name</Label>
|
|
<Input id="firstname" placeholder="Your firstname..." />
|
|
</div>
|
|
<div className="grid gap-2">
|
|
<Label htmlFor="lastname">Last Name</Label>
|
|
<Input id="lastname" placeholder="Your lastname..." />
|
|
</div>
|
|
</div>
|
|
<div className="grid gap-2">
|
|
<Label htmlFor="city">City</Label>
|
|
<Input id="city" placeholder="" />
|
|
</div>
|
|
<div className="grid gap-2">
|
|
<Label htmlFor="number">Card number</Label>
|
|
<Input id="number" placeholder="" />
|
|
</div>
|
|
<div className="grid grid-cols-3 gap-4">
|
|
<div className="grid gap-2">
|
|
<Label htmlFor="month">Expires</Label>
|
|
<Select>
|
|
<SelectTrigger id="month" aria-label="Month">
|
|
<SelectValue placeholder="Month" />
|
|
</SelectTrigger>
|
|
<SelectContent>
|
|
<SelectItem value="1">January</SelectItem>
|
|
<SelectItem value="2">February</SelectItem>
|
|
<SelectItem value="3">March</SelectItem>
|
|
<SelectItem value="4">April</SelectItem>
|
|
<SelectItem value="5">May</SelectItem>
|
|
<SelectItem value="6">June</SelectItem>
|
|
<SelectItem value="7">July</SelectItem>
|
|
<SelectItem value="8">August</SelectItem>
|
|
<SelectItem value="9">September</SelectItem>
|
|
<SelectItem value="10">October</SelectItem>
|
|
<SelectItem value="11">November</SelectItem>
|
|
<SelectItem value="12">December</SelectItem>
|
|
</SelectContent>
|
|
</Select>
|
|
</div>
|
|
<div className="grid gap-2">
|
|
<Label htmlFor="year">Year</Label>
|
|
<Select>
|
|
<SelectTrigger id="year" aria-label="Year">
|
|
<SelectValue placeholder="Year" />
|
|
</SelectTrigger>
|
|
<SelectContent>
|
|
{Array.from({ length: 10 }, (_, i) => (
|
|
<SelectItem key={i} value={`${new Date().getFullYear() + i}`}>
|
|
{new Date().getFullYear() + i}
|
|
</SelectItem>
|
|
))}
|
|
</SelectContent>
|
|
</Select>
|
|
</div>
|
|
<div className="grid gap-2">
|
|
<Label htmlFor="cvc">CVC</Label>
|
|
<Input id="cvc" placeholder="CVC" />
|
|
</div>
|
|
</div>
|
|
</CardContent>
|
|
{/* <CardFooter>
|
|
<Button className="w-full">Continue</Button>
|
|
</CardFooter> */}
|
|
</Card>
|
|
);
|
|
}
|