Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | import { format } from "date-fns"; import { Calendar as CalendarIcon } from "lucide-react"; import { Button } from "@/components/ui/button"; import { Calendar } from "@/components/ui/calendar"; import { Popover, PopoverContent, PopoverTrigger } from "@/components/ui/popover"; import { ui } from "@/config/theme"; import { cn } from "@/lib/utils"; export type DatePickerProps = { date?: Date; onDateChange?: (date: Date | undefined) => void; placeholder?: string; className?: string; disabled?: boolean; }; export function DatePicker({ date, onDateChange, placeholder = "Pick a date", className, disabled, }: DatePickerProps) { return ( <Popover> <PopoverTrigger asChild> <Button type="button" variant="outline" disabled={disabled} className={cn(ui("datePickerTrigger"), !date && ui("typographyMuted"), className)} > <CalendarIcon className="mr-2 h-4 w-4" /> {date ? format(date, "PPP") : <span>{placeholder}</span>} </Button> </PopoverTrigger> <PopoverContent className={ui("datePickerPopoverContent")} align="start"> <Calendar mode="single" selected={date} onSelect={onDateChange} initialFocus /> </PopoverContent> </Popover> ); } |