@paprika/calendar
v5.0.1
Published
Calendar component
Downloads
6,804
Keywords
Readme
Calendar
This package consists of two components (SingleDateCalendar
and DateRangeCalendar
) providing calendar views but with difference that SingleDateCalendar
allows selecting only one exact date and DateRangeCalendar
allows selection range of dates.
Installation
npm install --save @paprika/calendar
or
yarn add @paprika/calendar
Usage
Please use <L10n />
component to wrap calendar components or you application.
SingleDateCalendar
import SingleDateCalendar from "@paprika/calendar/lib/SingleDateCalendar";
// alternative (but has potential problems with tree-shaking):
// import { SingleDateCalendar } from "@paprika/calendar";
const [date, setDate] = React.useState(null);
const [possibleDate, setPossibleDate] = React.useState(null);
<SingleDateCalendar
date={date}
onSelect={setDate}
possibleDate={possibleDate}
resetPossibleDate={() => {
setPossibleDate(null);
}}
/>;
DateRangeCalendar
import DateRangeCalendar from "@paprika/calendar/lib/DateRangeCalendar";
// alternative (but has potential problems with tree-shaking):
// import { DateRangeCalendar } from "@paprika/calendar";
import { START_DATE } from "@paprika/calendar/lib/tokens";
const [currentInput, setCurrentInput] = React.useState(START_DATE);
const [{ startDate, endDate }, setDates] = React.useState({ startDate: null, endDate: null });
const [possibleDate, setPossibleDate] = React.useState(null);
<DateRangeCalendar
startDate={startDate}
endDate={endDate}
onDatesChange={setDates}
possibleDate={possibleDate}
resetPossibleDate={() => {
setPossibleDate(null);
}}
focusedInput={currentInput || START_DATE}
onFocusChange={setCurrentInput}
/>;
Props
SingleDateCalendar
date
(required)onSelect
(required)possibleDate
resetPossibleDate
DateRangeCalendar
startDate
(required)endDate
(required)onDatesChange
(required)possibleDate
resetPossibleDate
focusedInput
(required)onFocusChange
(required)