Range Picker

Use the DateRangePicker compound API to build a fully custom range picker with a custom trigger and preset sidebar.

import { useState } from "react";
import { DateRangePicker } from "react-date-range-picker-styled";
import "react-date-range-picker-styled/rdrp-styles.css";
const presets = [
{ label: "Last 7 days", value: { start: new Date(Date.now() - 7 * 86400000), end: new Date() } },
{
label: "Last 30 days",
value: { start: new Date(Date.now() - 30 * 86400000), end: new Date() },
},
{
label: "This month",
value: { start: new Date(new Date().getFullYear(), new Date().getMonth(), 1), end: new Date() },
},
];
function CompoundRangePicker() {
const [value, setValue] = useState<{ start: Date | null; end: Date | null }>({
start: null,
end: null,
});
return (
<DateRangePicker.Root value={value} onChange={setValue} presets={presets}>
<DateRangePicker.Trigger>
{({ displayValue, isOpen, onToggle, triggerRef }) => (
<button
ref={triggerRef as React.Ref<HTMLButtonElement>}
onClick={onToggle}
style={{
display: "inline-flex",
alignItems: "center",
gap: 8,
padding: "8px 16px",
border: "1px solid #d1d5db",
borderRadius: 6,
background: isOpen ? "#eff6ff" : "#fff",
cursor: "pointer",
fontSize: 14,
fontWeight: 500,
}}
>
<span>{displayValue || "Select date range"}</span>
</button>
)}
</DateRangePicker.Trigger>
<DateRangePicker.Content>
<div style={{ display: "flex" }}>
<DateRangePicker.Presets>
{presets.map((p, i) => (
<DateRangePicker.PresetItem key={p.label} index={i} />
))}
</DateRangePicker.Presets>
<div>
<DateRangePicker.Header>
<DateRangePicker.PrevButton />
<DateRangePicker.Title calendarIndex={0} />
<div style={{ flex: 1 }} />
<DateRangePicker.Title calendarIndex={1} />
<DateRangePicker.NextButton />
</DateRangePicker.Header>
<DateRangePicker.Calendars>
<DateRangePicker.Grid calendarIndex={0} />
<DateRangePicker.Grid calendarIndex={1} />
</DateRangePicker.Calendars>
<DateRangePicker.Footer>
<DateRangePicker.ClearButton />
<DateRangePicker.CancelButton />
<DateRangePicker.ConfirmButton />
</DateRangePicker.Footer>
</div>
</div>
</DateRangePicker.Content>
</DateRangePicker.Root>
);
}

Inline with Presets

Display the range picker inline with a presets sidebar:

import { useState } from "react";
import { DateRangePicker } from "react-date-range-picker-styled";
import "react-date-range-picker-styled/rdrp-styles.css";
const presets = [
{ label: "Today", value: { start: new Date(), end: new Date() } },
{ label: "Last 7 days", value: { start: new Date(Date.now() - 7 * 86400000), end: new Date() } },
{
label: "Last 14 days",
value: { start: new Date(Date.now() - 14 * 86400000), end: new Date() },
},
{
label: "Last 30 days",
value: { start: new Date(Date.now() - 30 * 86400000), end: new Date() },
},
{
label: "This month",
value: {
start: new Date(new Date().getFullYear(), new Date().getMonth(), 1),
end: new Date(),
},
},
];
function CompoundRangeInline() {
const [value, setValue] = useState<{ start: Date | null; end: Date | null }>({
start: null,
end: null,
});
return (
<DateRangePicker.Root value={value} onChange={setValue} inline presets={presets}>
<DateRangePicker.Content>
<div style={{ display: "flex" }}>
<DateRangePicker.Presets>
{presets.map((p, i) => (
<DateRangePicker.PresetItem key={p.label} index={i} />
))}
</DateRangePicker.Presets>
<div>
<DateRangePicker.Header>
<DateRangePicker.PrevButton />
<DateRangePicker.Title calendarIndex={0} />
<div style={{ flex: 1 }} />
<DateRangePicker.Title calendarIndex={1} />
<DateRangePicker.NextButton />
</DateRangePicker.Header>
<DateRangePicker.Calendars>
<DateRangePicker.Grid calendarIndex={0} />
<DateRangePicker.Grid calendarIndex={1} />
</DateRangePicker.Calendars>
</div>
</div>
</DateRangePicker.Content>
</DateRangePicker.Root>
);
}
March 2026
April 2026
Su
Mo
Tu
We
Th
Fr
Sa
Su
Mo
Tu
We
Th
Fr
Sa