DateRangePicker

PreviousNext
Docs
react-ariaui

Preview

Loading preview…
components/ui/DateRangePicker.tsx
'use client';
import {
  DateRangePicker as AriaDateRangePicker,
  DateRangePickerProps as AriaDateRangePickerProps,
  DateValue,
  Group,
  ValidationResult
} from 'react-aria-components';
import {DateInput, DateSegment} from '@/registry/react-aria/ui/DateField';
import {Description, FieldButton} from '@/registry/react-aria/ui/Form';
import {Popover} from '@/registry/react-aria/ui/Popover';
import {Label, FieldError} from '@/registry/react-aria/ui/Form';
import {RangeCalendar} from '@/registry/react-aria/ui/RangeCalendar';
import {ChevronDown} from 'lucide-react';
import './DateRangePicker.css';

export interface DateRangePickerProps<T extends DateValue>
  extends AriaDateRangePickerProps<T> {
  label?: string;
  description?: string;
  errorMessage?: string | ((validation: ValidationResult) => string);
}

export function DateRangePicker<T extends DateValue>(
  { label, description, errorMessage, ...props }: DateRangePickerProps<T>
) {
  return (
    <AriaDateRangePicker {...props}>
      <Label>{label}</Label>
      <Group className="react-aria-Group inset">
        <div className="date-fields">
          <DateInput slot="start">
            {(segment) => <DateSegment segment={segment} />}
          </DateInput>
          <span aria-hidden="true">–</span>
          <DateInput slot="end">
            {(segment) => <DateSegment segment={segment} />}
          </DateInput>
        </div>
        <FieldButton><ChevronDown /></FieldButton>
      </Group>
      {description && <Description>{description}</Description>}
      <FieldError>{errorMessage}</FieldError>
      <Popover hideArrow>
        <RangeCalendar />
      </Popover>
    </AriaDateRangePicker>
  );
}

Installation

npx shadcn@latest add @react-aria/css-daterangepicker

Usage

import { CssDaterangepicker } from "@/components/ui/css-daterangepicker"
<CssDaterangepicker />