Date Picker

A date picker component with range and presets.

Loading...
'use client'
 
import { format } from 'date-fns'
import * as React from 'react'
import { Calendar } from 'ui'
import {
  DatePicker,
  DatePickerButton,
  DatePickerContent,
  DatePickerTrigger,
} from 'ui-patterns/DatePicker'
 
export function DatePickerDemo() {
  const [date, setDate] = React.useState<Date>()
 
  return (
    <DatePicker>
      <DatePickerTrigger asChild>
        <DatePickerButton variant="outline" className="w-[280px]">
          {date ? format(date, 'PPP') : <span>Pick a date</span>}
        </DatePickerButton>
      </DatePickerTrigger>
      <DatePickerContent>
        <Calendar mode="single" selected={date} onSelect={setDate} initialFocus />
      </DatePickerContent>
    </DatePicker>
  )
}

Installation

The Date Picker is built using a composition of the <Popover />, <Button /> and <Calendar /> components.

See installation instructions for the Popover and the Calendar components.

Usage

'use client'
 
import { format } from 'date-fns'
import * as React from 'react'
import { Button, Calendar } from 'ui'
import {
  DatePicker,
  DatePickerButton,
  DatePickerContent,
  DatePickerTrigger,
} from 'ui-patterns/DatePicker'
 
export function DatePickerDemo() {
  const [date, setDate] = React.useState<Date>()
 
  return (
    <DatePicker>
      <DatePickerTrigger asChild>
        <DatePickerButton variant="outline" className="w-[280px]">
          {date ? format(date, 'PPP') : <span>Pick a date</span>}
        </DatePickerButton>
      </DatePickerTrigger>
      <DatePickerContent>
        <Calendar mode="single" selected={date} onSelect={setDate} initialFocus />
      </DatePickerContent>
    </DatePicker>
  )
}

See the React DayPicker documentation for more information.

API Reference

Examples

Date Picker

Loading...
'use client'
 
import { format } from 'date-fns'
import * as React from 'react'
import { Calendar } from 'ui'
import {
  DatePicker,
  DatePickerButton,
  DatePickerContent,
  DatePickerTrigger,
} from 'ui-patterns/DatePicker'
 
export function DatePickerDemo() {
  const [date, setDate] = React.useState<Date>()
 
  return (
    <DatePicker>
      <DatePickerTrigger asChild>
        <DatePickerButton variant="outline" className="w-[280px]">
          {date ? format(date, 'PPP') : <span>Pick a date</span>}
        </DatePickerButton>
      </DatePickerTrigger>
      <DatePickerContent>
        <Calendar mode="single" selected={date} onSelect={setDate} initialFocus />
      </DatePickerContent>
    </DatePicker>
  )
}

Date Range Picker

Loading...

With Presets

Loading...

Form

Loading...