All components
Calendar With Presets
calendarOrigin UI component.
responsive · 600px
Install
Same command in any shadcn project — React (Vite/CRA), Next.js, Remix, Astro, and more:
$
npx shadcn@latest add https://your-domain/r/comp-506.jsonUsage
import Cmp from "@/registry/origin-ui/comp-506";
export default function Demo() {
return <Cmp />;
}Component source
"use client";
import { subDays, subMonths, subYears } from "date-fns";
import { useState } from "react";
import { Button } from "@/components/ui/button";
import { Calendar } from "@/components/ui/calendar";
export default function Component() {
const today = new Date();
const yesterday = subDays(today, 1);
const lastWeek = subDays(today, 7);
const lastMonth = subMonths(today, 1);
const lastYear = subYears(today, 1);
const [month, setMonth] = useState(today);
const [date, setDate] = useState<Date>(today);
return (
<div>
<div className="rounded-md border">
<div className="flex max-sm:flex-col">
<div className="relative py-4 max-sm:order-1 max-sm:border-t sm:w-32">
<div className="h-full sm:border-e">
<div className="flex flex-col px-2">
<Button
className="w-full justify-start"
onClick={() => {
setDate(today);
setMonth(today);
}}
size="sm"
variant="ghost"
>
Today
</Button>
<Button
className="w-full justify-start"
onClick={() => {
setDate(yesterday);
setMonth(yesterday);
}}
size="sm"
variant="ghost"
>
Yesterday
</Button>
<Button
className="w-full justify-start"
onClick={() => {
setDate(lastWeek);
setMonth(lastWeek);
}}
size="sm"
variant="ghost"
>
Last week
</Button>
<Button
className="w-full justify-start"
onClick={() => {
setDate(lastMonth);
setMonth(lastMonth);
}}
size="sm"
variant="ghost"
>
Last month
</Button>
<Button
className="w-full justify-start"
onClick={() => {
setDate(lastYear);
setMonth(lastYear);
}}
size="sm"
variant="ghost"
>
Last year
</Button>
</div>
</div>
</div>
<Calendar
className="p-2"
disabled={[
{ after: today }, // Dates before today
]}
mode="single"
month={month}
onMonthChange={setMonth}
onSelect={(newDate) => {
if (newDate) {
setDate(newDate);
}
}}
selected={date}
/>
</div>
</div>
<p
aria-live="polite"
className="mt-4 text-center text-muted-foreground text-xs"
role="region"
>
Calendar with presets -{" "}
<a
className="underline hover:text-foreground"
href="https://daypicker.dev/"
rel="noreferrer noopener nofollow"
target="_blank"
>
React DayPicker
</a>
</p>
</div>
);
}Source: Origin UI