react-day-picker
Version:
Customizable Date Picker for React
58 lines (57 loc) • 2.45 kB
JavaScript
import * as dateFnsJalali from "date-fns-jalali";
import React from "react";
import { DateLib, DayPicker as DayPickerComponent, } from "./index.js";
import { enUSJalali } from "./locale/en-US-jalali.js";
import { faIRJalali } from "./locale/fa-IR-jalali.js";
import { createJalaliNoonOverrides } from "./noonJalaliDateLib.js";
/** Persian (Iran) Jalali locale with DayPicker labels. */
export const faIR = faIRJalali;
/** English (US) Jalali locale with DayPicker labels. */
export const enUS = enUSJalali;
/**
* Renders the Persian calendar using the DayPicker component.
*
* @defaultValue
* - `locale`: `faIR`
* - `dir`: `rtl`
* - `dateLib`: `jalaliDateLib` from `date-fns-jalali`
* - `numerals`: `arabext` (Eastern Arabic-Indic)
* @param props - The props for the Persian calendar, including locale, text
* direction, date library, and numeral system.
* @returns The Persian calendar component.
* @see https://daypicker.dev/docs/localization#persian-calendar
*/
export function DayPicker(props) {
const { locale: localeProp, dir, dateLib: dateLibProp, numerals, noonSafe, ...restProps } = props;
const dateLib = getDateLib({
locale: localeProp,
weekStartsOn: props.broadcastCalendar ? 1 : props.weekStartsOn,
firstWeekContainsDate: props.firstWeekContainsDate,
useAdditionalWeekYearTokens: props.useAdditionalWeekYearTokens,
useAdditionalDayOfYearTokens: props.useAdditionalDayOfYearTokens,
timeZone: props.timeZone,
numerals: numerals ?? "arabext",
noonSafe,
overrides: dateLibProp,
});
return (React.createElement(DayPickerComponent, { ...restProps, locale: localeProp ?? faIR, numerals: numerals ?? "arabext", dir: dir ?? "rtl", dateLib: dateLib }));
}
/**
* Returns the date library used in the Persian calendar.
*
* @param options - Optional configuration for the date library.
* @returns The date library instance.
*/
export const getDateLib = (options) => {
const { noonSafe, overrides, ...dateLibOptions } = options ?? {};
const baseOverrides = noonSafe && dateLibOptions.timeZone
? {
...dateFnsJalali,
...createJalaliNoonOverrides(dateLibOptions.timeZone, {
weekStartsOn: dateLibOptions.weekStartsOn,
locale: dateLibOptions.locale,
}),
}
: dateFnsJalali;
return new DateLib(dateLibOptions, { ...baseOverrides, ...overrides });
};