mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-25 05:35:48 +00:00
* feat(v4): update home page * fix * fix: cards * feat(v4): charts page * feat: update pages * feat: colors * fix * feat: add docs * feat: mdx work * fix * fix * fix: sidebar * fix: lint * feat: updates * feat: update components * feat: fix docs * fix: responsive * feat: implement cmdk * fix: update navigation menu demo * fix: code style * fix: themes * feat: implement blocks page * fix: docs config * refactor * fix: outputFileTracingIncludes * fix * fix: output * fix * fix: registry * refactor: move docs * debug: docs * debug * revert * fix: mjs * deps: pin fumadocs * debug * fix: downgrade next * fix: index page * refactor: move mdx components * fix: remove copy button * fix * was it zod * yes it was * remove copy page * fix: color page * fix: colors page * fix: meta colors * fix: copy button * feat: sync registry * fix: registry build script * feat: update port * feat: clean up examples * fix * fix: mobile nav * fix: blur for mobile * fix: sidebar nav * feat: update examples * fix: build scripts * feat: update components * feat: restyle * fix: types * fix: styles * fix: margins * fix: screenshots * fix * feat: update theme * fix: charts nav * fix: image * feat: optimize images * fix: menu * fix: card * fix: border * check * feat: implement charts page * fix: charts * fix: og images * feat: extend touch * fix: static * fix: sizing * fix: mobile screenshots * fix: page nav * fix * feat: update favicon * fix: theme selector * fix: feedback * fix: sink * docs: update * fix: styles * chore: update registry * fix: command * fix * fix: minor updates * fix: typography on smaller devices * fix: format * fix: remove unused icon * feat: update favicon * fix: typography * docs: typography page * fix: steps
128 lines
4.3 KiB
TypeScript
128 lines
4.3 KiB
TypeScript
"use client"
|
|
|
|
import { Button } from "@/registry/new-york-v4/ui/button"
|
|
import {
|
|
Card,
|
|
CardContent,
|
|
CardDescription,
|
|
CardFooter,
|
|
CardHeader,
|
|
CardTitle,
|
|
} from "@/registry/new-york-v4/ui/card"
|
|
import { Checkbox } from "@/registry/new-york-v4/ui/checkbox"
|
|
import { Input } from "@/registry/new-york-v4/ui/input"
|
|
import { Label } from "@/registry/new-york-v4/ui/label"
|
|
import {
|
|
RadioGroup,
|
|
RadioGroupItem,
|
|
} from "@/registry/new-york-v4/ui/radio-group"
|
|
import { Textarea } from "@/registry/new-york-v4/ui/textarea"
|
|
|
|
const plans = [
|
|
{
|
|
id: "starter",
|
|
name: "Starter Plan",
|
|
description: "Perfect for small businesses.",
|
|
price: "$10",
|
|
},
|
|
{
|
|
id: "pro",
|
|
name: "Pro Plan",
|
|
description: "More features and storage.",
|
|
price: "$20",
|
|
},
|
|
] as const
|
|
|
|
export function CardsForms() {
|
|
return (
|
|
<Card>
|
|
<CardHeader>
|
|
<CardTitle className="text-lg">Upgrade your subscription</CardTitle>
|
|
<CardDescription className="text-balance">
|
|
You are currently on the free plan. Upgrade to the pro plan to get
|
|
access to all features.
|
|
</CardDescription>
|
|
</CardHeader>
|
|
<CardContent>
|
|
<div className="flex flex-col gap-6">
|
|
<div className="flex flex-col gap-3 md:flex-row">
|
|
<div className="flex flex-1 flex-col gap-2">
|
|
<Label htmlFor="name">Name</Label>
|
|
<Input id="name" placeholder="Evil Rabbit" />
|
|
</div>
|
|
<div className="flex flex-1 flex-col gap-2">
|
|
<Label htmlFor="email">Email</Label>
|
|
<Input id="email" placeholder="example@acme.com" />
|
|
</div>
|
|
</div>
|
|
<div className="flex flex-col gap-2">
|
|
<Label htmlFor="card-number">Card Number</Label>
|
|
<div className="grid grid-cols-2 gap-3 md:grid-cols-[1fr_80px_60px]">
|
|
<Input
|
|
id="card-number"
|
|
placeholder="1234 1234 1234 1234"
|
|
className="col-span-2 md:col-span-1"
|
|
/>
|
|
<Input id="card-number-expiry" placeholder="MM/YY" />
|
|
<Input id="card-number-cvc" placeholder="CVC" />
|
|
</div>
|
|
</div>
|
|
<fieldset className="flex flex-col gap-3">
|
|
<legend className="text-sm font-medium">Plan</legend>
|
|
<p className="text-muted-foreground text-sm">
|
|
Select the plan that best fits your needs.
|
|
</p>
|
|
<RadioGroup
|
|
defaultValue="starter"
|
|
className="grid gap-3 md:grid-cols-2"
|
|
>
|
|
{plans.map((plan) => (
|
|
<Label
|
|
className="has-[[data-state=checked]]:border-ring has-[[data-state=checked]]:bg-input/20 flex items-start gap-3 rounded-lg border p-3"
|
|
key={plan.id}
|
|
>
|
|
<RadioGroupItem
|
|
value={plan.id}
|
|
id={plan.name}
|
|
className="data-[state=checked]:border-primary"
|
|
/>
|
|
<div className="grid gap-1 font-normal">
|
|
<div className="font-medium">{plan.name}</div>
|
|
<div className="text-muted-foreground text-xs leading-snug text-balance">
|
|
{plan.description}
|
|
</div>
|
|
</div>
|
|
</Label>
|
|
))}
|
|
</RadioGroup>
|
|
</fieldset>
|
|
<div className="flex flex-col gap-2">
|
|
<Label htmlFor="notes">Notes</Label>
|
|
<Textarea id="notes" placeholder="Enter notes" />
|
|
</div>
|
|
<div className="flex flex-col gap-3">
|
|
<div className="flex items-center gap-2">
|
|
<Checkbox id="terms" />
|
|
<Label htmlFor="terms" className="font-normal">
|
|
I agree to the terms and conditions
|
|
</Label>
|
|
</div>
|
|
<div className="flex items-center gap-2">
|
|
<Checkbox id="newsletter" defaultChecked />
|
|
<Label htmlFor="newsletter" className="font-normal">
|
|
Allow us to send you emails
|
|
</Label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</CardContent>
|
|
<CardFooter className="flex justify-between">
|
|
<Button variant="outline" size="sm">
|
|
Cancel
|
|
</Button>
|
|
<Button size="sm">Upgrade Plan</Button>
|
|
</CardFooter>
|
|
</Card>
|
|
)
|
|
}
|