Files
shadcn-ui/apps/v4/examples/base/data-picker-with-dropdowns.tsx
2026-01-14 09:25:14 +04:00

59 lines
1.6 KiB
TypeScript

"use client"
import * as React from "react"
import { Button } from "@/examples/base/ui/button"
import { Calendar } from "@/examples/base/ui/calendar"
import { Field, FieldLabel } from "@/examples/base/ui/field"
import {
Popover,
PopoverContent,
PopoverTrigger,
} from "@/examples/base/ui/popover"
import { format } from "date-fns"
import { ChevronDownIcon } from "lucide-react"
export function DataPickerWithDropdowns() {
const [date, setDate] = React.useState<Date>()
const [open, setOpen] = React.useState(false)
return (
<Field className="mx-auto w-72">
<Popover open={open} onOpenChange={setOpen}>
<FieldLabel htmlFor="date-picker-with-dropdowns-desktop">
Date
</FieldLabel>
<PopoverTrigger
render={
<Button
variant="outline"
id="date-picker-with-dropdowns-desktop"
className="justify-start px-2.5 font-normal"
/>
}
>
<ChevronDownIcon className="ml-auto" />
{date ? format(date, "PPP") : <span>Pick a date</span>}
</PopoverTrigger>
<PopoverContent className="w-auto p-0" align="start">
<Calendar
mode="single"
selected={date}
onSelect={setDate}
captionLayout="dropdown"
/>
<div className="flex gap-2 border-t p-2">
<Button
variant="outline"
size="sm"
className="w-full"
onClick={() => setOpen(false)}
>
Done
</Button>
</div>
</PopoverContent>
</Popover>
</Field>
)
}