boring.tools-poc/packages/ui/src/date-picker.tsx
Lars Hampe 5cfb15886f feat(ui): add new components
- calendar
- date-picker
- popover
- select
2024-10-10 22:05:15 +02:00

38 lines
1017 B
TypeScript

import { format } from 'date-fns'
import { Calendar as CalendarIcon } from 'lucide-react'
import * as React from 'react'
import { Button } from './button'
import { Calendar } from './calendar'
import { cn } from './lib/cn'
import { Popover, PopoverContent, PopoverTrigger } from './popover'
export function DatePickerDemo() {
const [date, setDate] = React.useState<Date>()
return (
<Popover>
<PopoverTrigger asChild>
<Button
variant={'outline'}
className={cn(
'w-[280px] justify-start text-left font-normal',
!date && 'text-muted-foreground',
)}
>
<CalendarIcon className="mr-2 h-4 w-4" />
{date ? format(date, 'PPP') : <span>Pick a date</span>}
</Button>
</PopoverTrigger>
<PopoverContent className="w-auto p-0">
<Calendar
mode="single"
selected={date}
onSelect={setDate}
initialFocus
/>
</PopoverContent>
</Popover>
)
}