1.1.1 • Published 28 days ago

shadcn-date-range-picker v1.1.1

Weekly downloads
-
License
MIT
Repository
github
Last release
28 days ago

DateRangePicker Component

DateRangePicker is a reusable component built for Shadcn using beautifully designed components from Radix UI and Tailwind CSS. It provides a dropdown interface to allow users to select or enter a range of dates and includes additional options such as preset date ranges and an optional date comparison feature.

View the Demo

Installation

The DateRangePicker depends on the following components from shadcn:

If you are using the CLI for installation, you can do this:

npx shadcn-ui@latest add button calendar label popover switch

The DateRangePicker uses icons from Radix UI so you will need to install that or update the component to use a different library.

npm install @radix-ui/react-icons

Next, copy and paste the code from the /src directory for DateInput and DateRangePicker into your project and customize to your needs. The code is yours.

Props

NameTypeDefaultDescription
onUpdatefunction-Callback function that is called when the date range is updated. The function receives an object containing the selected date range and, if the compare feature is enabled, the compare date range.
initialDateFromDate or stringToday’s DateThe initial start date for the main date range.
initialDateToDate or string-The initial end date for the main date range.
initialCompareFromDate or string-The initial start date for the compare date range.
initialCompareToDate or string-The initial end date for the compare date range.
alignstring'end'The alignment of the dropdown popover. Options are 'start', 'center', or 'end'.
localestring'en-US'The locale used for date formatting.
showComparebooleantrueWhether to show the compare date range feature.

Example

<DateRangePicker
  onUpdate={(values) => console.log(values)}
  initialDateFrom="2023-01-01"
  initialDateTo="2023-12-31"
  align="start"
  locale="en-GB"
  showCompare={false}
/>

This example creates a DateRangePicker component with an initial date range from January 1, 2023 to December 31, 2023. The dropdown popover is aligned to the start of the trigger button, the dates are formatted according to the 'en-GB' locale, and the compare feature is hidden. The onUpdate function logs the selected date range to the console.