Headless calendar hook for React
npm install @tuplo/use-calendar* No dependencies, tiny footprint
* Configurable available dates, minimum and maximum dates
* Weekends, adjacent month's days
* Previous and next month/year navigation
* Events
* WAI-ARIA compliant

``bash
$ npm install @tuplo/use-calendar
Usage
Minimal example
`jsx
import { useCalendar } from '@tuplo/use-calendar'function Calendar() {
const {
months,
getDayProps,
getPrevMonthProps,
getNextMonthProps
} = useCalendar()
return (
<>
{months.map(({ year, month, weeks }) => (
{month} {year}
{
weeks.map((week) =>
week.map((day) =>
))
}
))}
>
)
}
`Options
`typescript
const calendarProps = useCalendar({
availableDates: [new Date('2022-07-11'), new Date('2022-07-12')],
events: [{ start: new Date('2022-12-25'), title: 'Christmas' }],
firstDayOfWeek: 1,
minDate: new Date('2022-07-01'),
maxDate: new Date('2022-07-31'),
monthsToDisplay: 1,
onDateSelected: (day) => console.log(day.date),
selectedDate: new Date('2022-07-11'),
});
`$3
>
Date[] | optionalWhich days should be selectable on the calendar.
$3
>
{ start: Date, end?: Date, [k: string]: unknown }[] | optionalList of events. The only required attribute on a
Event is the start date. Any custom attributes you send in, will be returned back on the corresponding days, ex: isAllDay: true$3
>
number | defaults to 0First day of the week with possible values 0-6 (Sunday to Saturday). Defaults to
Sunday.
$3
>
Date | optionalUsed to calculate the minimum month to render.
$3
>
Date | optionalUsed to calculate the maximum month to render.
$3
>
number | defaults to 1Number of months returned, based off the
selectedDate. Infinity will display all months with available dates.
$3
>
function(day: Day) | optionalCalled when the user selects a date.
$3
>
Date | string | number | optionalUsed to calculate what month to display on initial render.
Outputs
The hook will return an object with the following shape:
`typescript
interface ICalendarProps {
getDayProps: IGetDayPropsFn;
getPrevMonthProps: IGetPrevNextPropsFn;
getNextMonthProps: IGetPrevNextPropsFn;
getPrevYearProps: IGetPrevNextPropsFn;
getNextYearProps: IGetPrevNextPropsFn;
months: IMonth[];
resetState: () => void;
}
`Each month has the shape:
`typescript
interface IMonth {
weeks: IDay[][];
month: number;
year: number;
}
`Each day returned on each week of the months to display is:
`typescript
interface IDay {
date: Date;
events?: IEvent[];
isSelectable?: boolean;
isSelected?: boolean;
isToday?: boolean;
isWeekend?: boolean;
isAdjacentMonth?: boolean;
}
`An event is represented by (it can hold any extra data needed):
`typescript
interface IEvent {
\[key: string\]: unknown;
end?: Date;
start: Date;
}
``MIT