{"version":3,"file":"day-picker-48bc1a92.js","sources":["../node_modules/react-day-picker/dist/esm/UI.js","../node_modules/react-day-picker/node_modules/date-fns/constants.js","../node_modules/react-day-picker/node_modules/date-fns/constructFrom.js","../node_modules/react-day-picker/node_modules/date-fns/toDate.js","../node_modules/react-day-picker/node_modules/date-fns/addDays.js","../node_modules/react-day-picker/node_modules/date-fns/addMonths.js","../node_modules/react-day-picker/node_modules/date-fns/_lib/defaultOptions.js","../node_modules/react-day-picker/node_modules/date-fns/startOfWeek.js","../node_modules/react-day-picker/node_modules/date-fns/startOfISOWeek.js","../node_modules/react-day-picker/node_modules/date-fns/getISOWeekYear.js","../node_modules/react-day-picker/node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds.js","../node_modules/react-day-picker/node_modules/date-fns/_lib/normalizeDates.js","../node_modules/react-day-picker/node_modules/date-fns/startOfDay.js","../node_modules/react-day-picker/node_modules/date-fns/differenceInCalendarDays.js","../node_modules/react-day-picker/node_modules/date-fns/startOfISOWeekYear.js","../node_modules/react-day-picker/node_modules/date-fns/addWeeks.js","../node_modules/react-day-picker/node_modules/date-fns/addYears.js","../node_modules/react-day-picker/node_modules/date-fns/max.js","../node_modules/react-day-picker/node_modules/date-fns/min.js","../node_modules/react-day-picker/node_modules/date-fns/isSameDay.js","../node_modules/react-day-picker/node_modules/date-fns/isDate.js","../node_modules/react-day-picker/node_modules/date-fns/isValid.js","../node_modules/react-day-picker/node_modules/date-fns/differenceInCalendarMonths.js","../node_modules/react-day-picker/node_modules/date-fns/endOfMonth.js","../node_modules/react-day-picker/node_modules/date-fns/startOfMonth.js","../node_modules/react-day-picker/node_modules/date-fns/endOfYear.js","../node_modules/react-day-picker/node_modules/date-fns/startOfYear.js","../node_modules/react-day-picker/node_modules/date-fns/endOfWeek.js","../node_modules/react-day-picker/node_modules/date-fns/endOfISOWeek.js","../node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/formatDistance.js","../node_modules/react-day-picker/node_modules/date-fns/locale/_lib/buildFormatLongFn.js","../node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/formatLong.js","../node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/formatRelative.js","../node_modules/react-day-picker/node_modules/date-fns/locale/_lib/buildLocalizeFn.js","../node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/localize.js","../node_modules/react-day-picker/node_modules/date-fns/locale/_lib/buildMatchFn.js","../node_modules/react-day-picker/node_modules/date-fns/locale/_lib/buildMatchPatternFn.js","../node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/match.js","../node_modules/react-day-picker/node_modules/date-fns/locale/en-US.js","../node_modules/react-day-picker/node_modules/date-fns/getDayOfYear.js","../node_modules/react-day-picker/node_modules/date-fns/getISOWeek.js","../node_modules/react-day-picker/node_modules/date-fns/getWeekYear.js","../node_modules/react-day-picker/node_modules/date-fns/startOfWeekYear.js","../node_modules/react-day-picker/node_modules/date-fns/getWeek.js","../node_modules/react-day-picker/node_modules/date-fns/_lib/addLeadingZeros.js","../node_modules/react-day-picker/node_modules/date-fns/_lib/format/lightFormatters.js","../node_modules/react-day-picker/node_modules/date-fns/_lib/format/formatters.js","../node_modules/react-day-picker/node_modules/date-fns/_lib/format/longFormatters.js","../node_modules/react-day-picker/node_modules/date-fns/_lib/protectedTokens.js","../node_modules/react-day-picker/node_modules/date-fns/format.js","../node_modules/react-day-picker/node_modules/date-fns/getDaysInMonth.js","../node_modules/react-day-picker/node_modules/date-fns/isAfter.js","../node_modules/react-day-picker/node_modules/date-fns/isBefore.js","../node_modules/react-day-picker/node_modules/date-fns/isSameMonth.js","../node_modules/react-day-picker/node_modules/date-fns/isSameYear.js","../node_modules/react-day-picker/node_modules/date-fns/setMonth.js","../node_modules/react-day-picker/node_modules/date-fns/setYear.js","../node_modules/react-day-picker/dist/esm/helpers/getBroadcastWeeksInMonth.js","../node_modules/react-day-picker/dist/esm/helpers/startOfBroadcastWeek.js","../node_modules/react-day-picker/dist/esm/helpers/endOfBroadcastWeek.js","../node_modules/react-day-picker/dist/esm/classes/DateLib.js","../node_modules/react-day-picker/dist/esm/helpers/getClassNamesForModifiers.js","../node_modules/react-day-picker/dist/esm/components/Button.js","../node_modules/react-day-picker/dist/esm/components/CaptionLabel.js","../node_modules/react-day-picker/dist/esm/components/Chevron.js","../node_modules/react-day-picker/dist/esm/components/Day.js","../node_modules/react-day-picker/dist/esm/components/DayButton.js","../node_modules/react-day-picker/dist/esm/components/Dropdown.js","../node_modules/react-day-picker/dist/esm/components/DropdownNav.js","../node_modules/react-day-picker/dist/esm/components/Footer.js","../node_modules/react-day-picker/dist/esm/components/Month.js","../node_modules/react-day-picker/dist/esm/components/MonthCaption.js","../node_modules/react-day-picker/dist/esm/components/MonthGrid.js","../node_modules/react-day-picker/dist/esm/components/Months.js","../node_modules/react-day-picker/dist/esm/useDayPicker.js","../node_modules/react-day-picker/dist/esm/components/MonthsDropdown.js","../node_modules/react-day-picker/dist/esm/components/Nav.js","../node_modules/react-day-picker/dist/esm/components/NextMonthButton.js","../node_modules/react-day-picker/dist/esm/components/Option.js","../node_modules/react-day-picker/dist/esm/components/PreviousMonthButton.js","../node_modules/react-day-picker/dist/esm/components/Root.js","../node_modules/react-day-picker/dist/esm/components/Select.js","../node_modules/react-day-picker/dist/esm/components/Week.js","../node_modules/react-day-picker/dist/esm/components/Weekday.js","../node_modules/react-day-picker/dist/esm/components/Weekdays.js","../node_modules/react-day-picker/dist/esm/components/WeekNumber.js","../node_modules/react-day-picker/dist/esm/components/WeekNumberHeader.js","../node_modules/react-day-picker/dist/esm/components/Weeks.js","../node_modules/react-day-picker/dist/esm/components/YearsDropdown.js","../node_modules/react-day-picker/dist/esm/helpers/getComponents.js","../node_modules/react-day-picker/dist/esm/helpers/getDataAttributes.js","../node_modules/react-day-picker/dist/esm/helpers/getDefaultClassNames.js","../node_modules/react-day-picker/dist/esm/formatters/formatCaption.js","../node_modules/react-day-picker/dist/esm/formatters/formatDay.js","../node_modules/react-day-picker/dist/esm/formatters/formatMonthDropdown.js","../node_modules/react-day-picker/dist/esm/formatters/formatWeekNumber.js","../node_modules/react-day-picker/dist/esm/formatters/formatWeekNumberHeader.js","../node_modules/react-day-picker/dist/esm/formatters/formatWeekdayName.js","../node_modules/react-day-picker/dist/esm/formatters/formatYearDropdown.js","../node_modules/react-day-picker/dist/esm/helpers/getFormatters.js","../node_modules/react-day-picker/dist/esm/helpers/getMonthOptions.js","../node_modules/react-day-picker/dist/esm/helpers/getStyleForModifiers.js","../node_modules/@date-fns/tz/tzOffset/index.js","../node_modules/@date-fns/tz/date/mini.js","../node_modules/@date-fns/tz/date/index.js","../node_modules/react-day-picker/dist/esm/helpers/getWeekdays.js","../node_modules/react-day-picker/dist/esm/helpers/getYearOptions.js","../node_modules/react-day-picker/dist/esm/labels/labelGrid.js","../node_modules/react-day-picker/dist/esm/labels/labelGridcell.js","../node_modules/react-day-picker/dist/esm/labels/labelDayButton.js","../node_modules/react-day-picker/dist/esm/labels/labelNav.js","../node_modules/react-day-picker/dist/esm/labels/labelMonthDropdown.js","../node_modules/react-day-picker/dist/esm/labels/labelNext.js","../node_modules/react-day-picker/dist/esm/labels/labelPrevious.js","../node_modules/react-day-picker/dist/esm/labels/labelWeekday.js","../node_modules/react-day-picker/dist/esm/labels/labelWeekNumber.js","../node_modules/react-day-picker/dist/esm/labels/labelWeekNumberHeader.js","../node_modules/react-day-picker/dist/esm/labels/labelYearDropdown.js","../node_modules/react-day-picker/dist/esm/helpers/getDates.js","../node_modules/react-day-picker/dist/esm/helpers/getDays.js","../node_modules/react-day-picker/dist/esm/helpers/getDisplayMonths.js","../node_modules/react-day-picker/dist/esm/helpers/getInitialMonth.js","../node_modules/react-day-picker/dist/esm/classes/CalendarDay.js","../node_modules/react-day-picker/dist/esm/classes/CalendarMonth.js","../node_modules/react-day-picker/dist/esm/classes/CalendarWeek.js","../node_modules/react-day-picker/dist/esm/helpers/getMonths.js","../node_modules/react-day-picker/dist/esm/helpers/getNavMonth.js","../node_modules/react-day-picker/dist/esm/helpers/getNextMonth.js","../node_modules/react-day-picker/dist/esm/helpers/getPreviousMonth.js","../node_modules/react-day-picker/dist/esm/helpers/getWeeks.js","../node_modules/react-day-picker/dist/esm/helpers/useControlledValue.js","../node_modules/react-day-picker/dist/esm/useCalendar.js","../node_modules/react-day-picker/dist/esm/helpers/calculateFocusTarget.js","../node_modules/react-day-picker/dist/esm/utils/rangeIncludesDate.js","../node_modules/react-day-picker/dist/esm/utils/typeguards.js","../node_modules/react-day-picker/dist/esm/utils/dateMatchModifiers.js","../node_modules/react-day-picker/dist/esm/helpers/getFocusableDate.js","../node_modules/react-day-picker/dist/esm/helpers/getNextFocus.js","../node_modules/react-day-picker/dist/esm/useFocus.js","../node_modules/react-day-picker/dist/esm/useGetModifiers.js","../node_modules/react-day-picker/dist/esm/selection/useMulti.js","../node_modules/react-day-picker/dist/esm/utils/addToRange.js","../node_modules/react-day-picker/dist/esm/utils/rangeContainsDayOfWeek.js","../node_modules/react-day-picker/dist/esm/utils/rangeOverlaps.js","../node_modules/react-day-picker/dist/esm/utils/rangeContainsModifiers.js","../node_modules/react-day-picker/dist/esm/selection/useRange.js","../node_modules/react-day-picker/dist/esm/selection/useSingle.js","../node_modules/react-day-picker/dist/esm/useSelection.js","../node_modules/react-day-picker/dist/esm/DayPicker.js"],"sourcesContent":["/**\n * The UI elements composing DayPicker. These elements are mapped to\n * {@link CustomComponents}, the {@link ClassNames} and the {@link Styles} used by\n * DayPicker.\n *\n * Some of these elements are extended by flags and modifiers.\n */\nexport var UI;\n(function (UI) {\n /** The root component displaying the months and the navigation bar. */\n UI[\"Root\"] = \"root\";\n /** The Chevron SVG element used by navigation buttons and dropdowns. */\n UI[\"Chevron\"] = \"chevron\";\n /**\n * The grid cell with the day's date. Extended by {@link DayFlag} and\n * {@link SelectionFlag}.\n */\n UI[\"Day\"] = \"day\";\n /** The button containing the formatted day's date, inside the grid cell. */\n UI[\"DayButton\"] = \"day_button\";\n /** The caption label of the month (when not showing the dropdown navigation). */\n UI[\"CaptionLabel\"] = \"caption_label\";\n /** The container of the dropdown navigation (when enabled). */\n UI[\"Dropdowns\"] = \"dropdowns\";\n /** The dropdown element to select for years and months. */\n UI[\"Dropdown\"] = \"dropdown\";\n /** The container element of the dropdown. */\n UI[\"DropdownRoot\"] = \"dropdown_root\";\n /** The root element of the footer. */\n UI[\"Footer\"] = \"footer\";\n /** The month grid. */\n UI[\"MonthGrid\"] = \"month_grid\";\n /** Contains the dropdown navigation or the caption label. */\n UI[\"MonthCaption\"] = \"month_caption\";\n /** The dropdown with the months. */\n UI[\"MonthsDropdown\"] = \"months_dropdown\";\n /** Wrapper of the month grid. */\n UI[\"Month\"] = \"month\";\n /** The container of the displayed months. */\n UI[\"Months\"] = \"months\";\n /** The navigation bar with the previous and next buttons. */\n UI[\"Nav\"] = \"nav\";\n /**\n * The next month button in the navigation. *\n *\n * @since 9.1.0\n */\n UI[\"NextMonthButton\"] = \"button_next\";\n /**\n * The previous month button in the navigation.\n *\n * @since 9.1.0\n */\n UI[\"PreviousMonthButton\"] = \"button_previous\";\n /** The row containing the week. */\n UI[\"Week\"] = \"week\";\n /** The group of row weeks in a month (`tbody`). */\n UI[\"Weeks\"] = \"weeks\";\n /** The column header with the weekday. */\n UI[\"Weekday\"] = \"weekday\";\n /** The row grouping the weekdays in the column headers. */\n UI[\"Weekdays\"] = \"weekdays\";\n /** The cell containing the week number. */\n UI[\"WeekNumber\"] = \"week_number\";\n /** The cell header of the week numbers column. */\n UI[\"WeekNumberHeader\"] = \"week_number_header\";\n /** The dropdown with the years. */\n UI[\"YearsDropdown\"] = \"years_dropdown\";\n})(UI || (UI = {}));\n/** The flags for the {@link UI.Day}. */\nexport var DayFlag;\n(function (DayFlag) {\n /** The day is disabled. */\n DayFlag[\"disabled\"] = \"disabled\";\n /** The day is hidden. */\n DayFlag[\"hidden\"] = \"hidden\";\n /** The day is outside the current month. */\n DayFlag[\"outside\"] = \"outside\";\n /** The day is focused. */\n DayFlag[\"focused\"] = \"focused\";\n /** The day is today. */\n DayFlag[\"today\"] = \"today\";\n})(DayFlag || (DayFlag = {}));\n/**\n * The state that can be applied to the {@link UI.Day} element when in selection\n * mode.\n */\nexport var SelectionState;\n(function (SelectionState) {\n /** The day is at the end of a selected range. */\n SelectionState[\"range_end\"] = \"range_end\";\n /** The day is at the middle of a selected range. */\n SelectionState[\"range_middle\"] = \"range_middle\";\n /** The day is at the start of a selected range. */\n SelectionState[\"range_start\"] = \"range_start\";\n /** The day is selected. */\n SelectionState[\"selected\"] = \"selected\";\n})(SelectionState || (SelectionState = {}));\n//# sourceMappingURL=UI.js.map","/**\n * @module constants\n * @summary Useful constants\n * @description\n * Collection of useful date constants.\n *\n * The constants could be imported from `date-fns/constants`:\n *\n * ```ts\n * import { maxTime, minTime } from \"./constants/date-fns/constants\";\n *\n * function isAllowedTime(time) {\n * return time <= maxTime && time >= minTime;\n * }\n * ```\n */\n\n/**\n * @constant\n * @name daysInWeek\n * @summary Days in 1 week.\n */\nexport const daysInWeek = 7;\n\n/**\n * @constant\n * @name daysInYear\n * @summary Days in 1 year.\n *\n * @description\n * How many days in a year.\n *\n * One years equals 365.2425 days according to the formula:\n *\n * > Leap year occurs every 4 years, except for years that are divisible by 100 and not divisible by 400.\n * > 1 mean year = (365+1/4-1/100+1/400) days = 365.2425 days\n */\nexport const daysInYear = 365.2425;\n\n/**\n * @constant\n * @name maxTime\n * @summary Maximum allowed time.\n *\n * @example\n * import { maxTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = 8640000000000001 <= maxTime;\n * //=> false\n *\n * new Date(8640000000000001);\n * //=> Invalid Date\n */\nexport const maxTime = Math.pow(10, 8) * 24 * 60 * 60 * 1000;\n\n/**\n * @constant\n * @name minTime\n * @summary Minimum allowed time.\n *\n * @example\n * import { minTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = -8640000000000001 >= minTime;\n * //=> false\n *\n * new Date(-8640000000000001)\n * //=> Invalid Date\n */\nexport const minTime = -maxTime;\n\n/**\n * @constant\n * @name millisecondsInWeek\n * @summary Milliseconds in 1 week.\n */\nexport const millisecondsInWeek = 604800000;\n\n/**\n * @constant\n * @name millisecondsInDay\n * @summary Milliseconds in 1 day.\n */\nexport const millisecondsInDay = 86400000;\n\n/**\n * @constant\n * @name millisecondsInMinute\n * @summary Milliseconds in 1 minute\n */\nexport const millisecondsInMinute = 60000;\n\n/**\n * @constant\n * @name millisecondsInHour\n * @summary Milliseconds in 1 hour\n */\nexport const millisecondsInHour = 3600000;\n\n/**\n * @constant\n * @name millisecondsInSecond\n * @summary Milliseconds in 1 second\n */\nexport const millisecondsInSecond = 1000;\n\n/**\n * @constant\n * @name minutesInYear\n * @summary Minutes in 1 year.\n */\nexport const minutesInYear = 525600;\n\n/**\n * @constant\n * @name minutesInMonth\n * @summary Minutes in 1 month.\n */\nexport const minutesInMonth = 43200;\n\n/**\n * @constant\n * @name minutesInDay\n * @summary Minutes in 1 day.\n */\nexport const minutesInDay = 1440;\n\n/**\n * @constant\n * @name minutesInHour\n * @summary Minutes in 1 hour.\n */\nexport const minutesInHour = 60;\n\n/**\n * @constant\n * @name monthsInQuarter\n * @summary Months in 1 quarter.\n */\nexport const monthsInQuarter = 3;\n\n/**\n * @constant\n * @name monthsInYear\n * @summary Months in 1 year.\n */\nexport const monthsInYear = 12;\n\n/**\n * @constant\n * @name quartersInYear\n * @summary Quarters in 1 year\n */\nexport const quartersInYear = 4;\n\n/**\n * @constant\n * @name secondsInHour\n * @summary Seconds in 1 hour.\n */\nexport const secondsInHour = 3600;\n\n/**\n * @constant\n * @name secondsInMinute\n * @summary Seconds in 1 minute.\n */\nexport const secondsInMinute = 60;\n\n/**\n * @constant\n * @name secondsInDay\n * @summary Seconds in 1 day.\n */\nexport const secondsInDay = secondsInHour * 24;\n\n/**\n * @constant\n * @name secondsInWeek\n * @summary Seconds in 1 week.\n */\nexport const secondsInWeek = secondsInDay * 7;\n\n/**\n * @constant\n * @name secondsInYear\n * @summary Seconds in 1 year.\n */\nexport const secondsInYear = secondsInDay * daysInYear;\n\n/**\n * @constant\n * @name secondsInMonth\n * @summary Seconds in 1 month\n */\nexport const secondsInMonth = secondsInYear / 12;\n\n/**\n * @constant\n * @name secondsInQuarter\n * @summary Seconds in 1 quarter.\n */\nexport const secondsInQuarter = secondsInMonth * 3;\n\n/**\n * @constant\n * @name constructFromSymbol\n * @summary Symbol enabling Date extensions to inherit properties from the reference date.\n *\n * The symbol is used to enable the `constructFrom` function to construct a date\n * using a reference date and a value. It allows to transfer extra properties\n * from the reference date to the new date. It's useful for extensions like\n * [`TZDate`](https://github.com/date-fns/tz) that accept a time zone as\n * a constructor argument.\n */\nexport const constructFromSymbol = Symbol.for(\"constructDateFrom\");\n","import { constructFromSymbol } from \"./constants.js\";\n\n/**\n * @name constructFrom\n * @category Generic Helpers\n * @summary Constructs a date using the reference date and the value\n *\n * @description\n * The function constructs a new date using the constructor from the reference\n * date and the given value. It helps to build generic functions that accept\n * date extensions.\n *\n * It defaults to `Date` if the passed reference date is a number or a string.\n *\n * Starting from v3.7.0, it allows to construct a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The reference date to take constructor from\n * @param value - The value to create the date\n *\n * @returns Date initialized using the given date and value\n *\n * @example\n * import { constructFrom } from \"./constructFrom/date-fns\";\n *\n * // A function that clones a date preserving the original type\n * function cloneDate(date: DateType): DateType {\n * return constructFrom(\n * date, // Use constructor from the given date\n * date.getTime() // Use the date value to create a new date\n * );\n * }\n */\nexport function constructFrom(date, value) {\n if (typeof date === \"function\") return date(value);\n\n if (date && typeof date === \"object\" && constructFromSymbol in date)\n return date[constructFromSymbol](value);\n\n if (date instanceof Date) return new date.constructor(value);\n\n return new Date(value);\n}\n\n// Fallback for modularized imports:\nexport default constructFrom;\n","import { constructFrom } from \"./constructFrom.js\";\n\n/**\n * @name toDate\n * @category Common Helpers\n * @summary Convert the given argument to an instance of Date.\n *\n * @description\n * Convert the given argument to an instance of Date.\n *\n * If the argument is an instance of Date, the function returns its clone.\n *\n * If the argument is a number, it is treated as a timestamp.\n *\n * If the argument is none of the above, the function returns Invalid Date.\n *\n * Starting from v3.7.0, it clones a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * **Note**: *all* Date arguments passed to any *date-fns* function is processed by `toDate`.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param argument - The value to convert\n *\n * @returns The parsed date in the local time zone\n *\n * @example\n * // Clone the date:\n * const result = toDate(new Date(2014, 1, 11, 11, 30, 30))\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert the timestamp to date:\n * const result = toDate(1392098430000)\n * //=> Tue Feb 11 2014 11:30:30\n */\nexport function toDate(argument, context) {\n // [TODO] Get rid of `toDate` or `constructFrom`?\n return constructFrom(context || argument, argument);\n}\n\n// Fallback for modularized imports:\nexport default toDate;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link addDays} function options.\n */\n\n/**\n * @name addDays\n * @category Day Helpers\n * @summary Add the specified number of days to the given date.\n *\n * @description\n * Add the specified number of days to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The date to be changed\n * @param amount - The amount of days to be added.\n * @param options - An object with options\n *\n * @returns The new date with the days added\n *\n * @example\n * // Add 10 days to 1 September 2014:\n * const result = addDays(new Date(2014, 8, 1), 10)\n * //=> Thu Sep 11 2014 00:00:00\n */\nexport function addDays(date, amount, options) {\n const _date = toDate(date, options?.in);\n if (isNaN(amount)) return constructFrom(options?.in || date, NaN);\n\n // If 0 days, no-op to avoid changing times in the hour before end of DST\n if (!amount) return _date;\n\n _date.setDate(_date.getDate() + amount);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default addDays;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link addMonths} function options.\n */\n\n/**\n * @name addMonths\n * @category Month Helpers\n * @summary Add the specified number of months to the given date.\n *\n * @description\n * Add the specified number of months to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The date to be changed\n * @param amount - The amount of months to be added.\n * @param options - The options object\n *\n * @returns The new date with the months added\n *\n * @example\n * // Add 5 months to 1 September 2014:\n * const result = addMonths(new Date(2014, 8, 1), 5)\n * //=> Sun Feb 01 2015 00:00:00\n *\n * // Add one month to 30 January 2023:\n * const result = addMonths(new Date(2023, 0, 30), 1)\n * //=> Tue Feb 28 2023 00:00:00\n */\nexport function addMonths(date, amount, options) {\n const _date = toDate(date, options?.in);\n if (isNaN(amount)) return constructFrom(options?.in || date, NaN);\n if (!amount) {\n // If 0 months, no-op to avoid changing times in the hour before end of DST\n return _date;\n }\n const dayOfMonth = _date.getDate();\n\n // The JS Date object supports date math by accepting out-of-bounds values for\n // month, day, etc. For example, new Date(2020, 0, 0) returns 31 Dec 2019 and\n // new Date(2020, 13, 1) returns 1 Feb 2021. This is *almost* the behavior we\n // want except that dates will wrap around the end of a month, meaning that\n // new Date(2020, 13, 31) will return 3 Mar 2021 not 28 Feb 2021 as desired. So\n // we'll default to the end of the desired month by adding 1 to the desired\n // month and using a date of 0 to back up one day to the end of the desired\n // month.\n const endOfDesiredMonth = constructFrom(options?.in || date, _date.getTime());\n endOfDesiredMonth.setMonth(_date.getMonth() + amount + 1, 0);\n const daysInMonth = endOfDesiredMonth.getDate();\n if (dayOfMonth >= daysInMonth) {\n // If we're already at the end of the month, then this is the correct date\n // and we're done.\n return endOfDesiredMonth;\n } else {\n // Otherwise, we now know that setting the original day-of-month value won't\n // cause an overflow, so set the desired day-of-month. Note that we can't\n // just set the date of `endOfDesiredMonth` because that object may have had\n // its time changed in the unusual case where where a DST transition was on\n // the last day of the month and its local time was in the hour skipped or\n // repeated next to a DST transition. So we use `date` instead which is\n // guaranteed to still have the original time.\n _date.setFullYear(\n endOfDesiredMonth.getFullYear(),\n endOfDesiredMonth.getMonth(),\n dayOfMonth,\n );\n return _date;\n }\n}\n\n// Fallback for modularized imports:\nexport default addMonths;\n","let defaultOptions = {};\n\nexport function getDefaultOptions() {\n return defaultOptions;\n}\n\nexport function setDefaultOptions(newOptions) {\n defaultOptions = newOptions;\n}\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfWeek} function options.\n */\n\n/**\n * @name startOfWeek\n * @category Week Helpers\n * @summary Return the start of a week for the given date.\n *\n * @description\n * Return the start of a week for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week\n *\n * @example\n * // The start of a week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Sun Aug 31 2014 00:00:00\n *\n * @example\n * // If the week starts on Monday, the start of the week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfWeek(date, options) {\n const defaultOptions = getDefaultOptions();\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const _date = toDate(date, options?.in);\n const day = _date.getDay();\n const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n\n _date.setDate(_date.getDate() - diff);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeek;\n","import { startOfWeek } from \"./startOfWeek.js\";\n\n/**\n * The {@link startOfISOWeek} function options.\n */\n\n/**\n * @name startOfISOWeek\n * @category ISO Week Helpers\n * @summary Return the start of an ISO week for the given date.\n *\n * @description\n * Return the start of an ISO week for the given date.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of an ISO week\n *\n * @example\n * // The start of an ISO week for 2 September 2014 11:55:00:\n * const result = startOfISOWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfISOWeek(date, options) {\n return startOfWeek(date, { ...options, weekStartsOn: 1 });\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeek;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getISOWeekYear} function options.\n */\n\n/**\n * @name getISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Get the ISO week-numbering year of the given date.\n *\n * @description\n * Get the ISO week-numbering year of the given date,\n * which always starts 3 days before the year's first Thursday.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @param date - The given date\n *\n * @returns The ISO week-numbering year\n *\n * @example\n * // Which ISO-week numbering year is 2 January 2005?\n * const result = getISOWeekYear(new Date(2005, 0, 2))\n * //=> 2004\n */\nexport function getISOWeekYear(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n\n const fourthOfJanuaryOfNextYear = constructFrom(_date, 0);\n fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4);\n fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear);\n\n const fourthOfJanuaryOfThisYear = constructFrom(_date, 0);\n fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4);\n fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfISOWeek(fourthOfJanuaryOfThisYear);\n\n if (_date.getTime() >= startOfNextYear.getTime()) {\n return year + 1;\n } else if (_date.getTime() >= startOfThisYear.getTime()) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getISOWeekYear;\n","import { toDate } from \"../toDate.js\";\n\n/**\n * Google Chrome as of 67.0.3396.87 introduced timezones with offset that includes seconds.\n * They usually appear for dates that denote time before the timezones were introduced\n * (e.g. for 'Europe/Prague' timezone the offset is GMT+00:57:44 before 1 October 1891\n * and GMT+01:00:00 after that date)\n *\n * Date#getTimezoneOffset returns the offset in minutes and would return 57 for the example above,\n * which would lead to incorrect calculations.\n *\n * This function returns the timezone offset in milliseconds that takes seconds in account.\n */\nexport function getTimezoneOffsetInMilliseconds(date) {\n const _date = toDate(date);\n const utcDate = new Date(\n Date.UTC(\n _date.getFullYear(),\n _date.getMonth(),\n _date.getDate(),\n _date.getHours(),\n _date.getMinutes(),\n _date.getSeconds(),\n _date.getMilliseconds(),\n ),\n );\n utcDate.setUTCFullYear(_date.getFullYear());\n return +date - +utcDate;\n}\n","import { constructFrom } from \"../constructFrom.js\";\n\nexport function normalizeDates(context, ...dates) {\n const normalize = constructFrom.bind(\n null,\n context || dates.find((date) => typeof date === \"object\"),\n );\n return dates.map(normalize);\n}\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfDay} function options.\n */\n\n/**\n * @name startOfDay\n * @category Day Helpers\n * @summary Return the start of a day for the given date.\n *\n * @description\n * Return the start of a day for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - The options\n *\n * @returns The start of a day\n *\n * @example\n * // The start of a day for 2 September 2014 11:55:00:\n * const result = startOfDay(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Tue Sep 02 2014 00:00:00\n */\nexport function startOfDay(date, options) {\n const _date = toDate(date, options?.in);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfDay;\n","import { getTimezoneOffsetInMilliseconds } from \"./_lib/getTimezoneOffsetInMilliseconds.js\";\nimport { normalizeDates } from \"./_lib/normalizeDates.js\";\nimport { millisecondsInDay } from \"./constants.js\";\nimport { startOfDay } from \"./startOfDay.js\";\n\n/**\n * The {@link differenceInCalendarDays} function options.\n */\n\n/**\n * @name differenceInCalendarDays\n * @category Day Helpers\n * @summary Get the number of calendar days between the given dates.\n *\n * @description\n * Get the number of calendar days between the given dates. This means that the times are removed\n * from the dates and then the difference in days is calculated.\n *\n * @param laterDate - The later date\n * @param earlierDate - The earlier date\n * @param options - The options object\n *\n * @returns The number of calendar days\n *\n * @example\n * // How many calendar days are between\n * // 2 July 2011 23:00:00 and 2 July 2012 00:00:00?\n * const result = differenceInCalendarDays(\n * new Date(2012, 6, 2, 0, 0),\n * new Date(2011, 6, 2, 23, 0)\n * )\n * //=> 366\n * // How many calendar days are between\n * // 2 July 2011 23:59:00 and 3 July 2011 00:01:00?\n * const result = differenceInCalendarDays(\n * new Date(2011, 6, 3, 0, 1),\n * new Date(2011, 6, 2, 23, 59)\n * )\n * //=> 1\n */\nexport function differenceInCalendarDays(laterDate, earlierDate, options) {\n const [laterDate_, earlierDate_] = normalizeDates(\n options?.in,\n laterDate,\n earlierDate,\n );\n\n const laterStartOfDay = startOfDay(laterDate_);\n const earlierStartOfDay = startOfDay(earlierDate_);\n\n const laterTimestamp =\n +laterStartOfDay - getTimezoneOffsetInMilliseconds(laterStartOfDay);\n const earlierTimestamp =\n +earlierStartOfDay - getTimezoneOffsetInMilliseconds(earlierStartOfDay);\n\n // Round the number of days to the nearest integer because the number of\n // milliseconds in a day is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round((laterTimestamp - earlierTimestamp) / millisecondsInDay);\n}\n\n// Fallback for modularized imports:\nexport default differenceInCalendarDays;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { getISOWeekYear } from \"./getISOWeekYear.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\n\n/**\n * The {@link startOfISOWeekYear} function options.\n */\n\n/**\n * @name startOfISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Return the start of an ISO week-numbering year for the given date.\n *\n * @description\n * Return the start of an ISO week-numbering year,\n * which always starts 3 days before the year's first Thursday.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of an ISO week-numbering year\n *\n * @example\n * // The start of an ISO week-numbering year for 2 July 2005:\n * const result = startOfISOWeekYear(new Date(2005, 6, 2))\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfISOWeekYear(date, options) {\n const year = getISOWeekYear(date, options);\n const fourthOfJanuary = constructFrom(options?.in || date, 0);\n fourthOfJanuary.setFullYear(year, 0, 4);\n fourthOfJanuary.setHours(0, 0, 0, 0);\n return startOfISOWeek(fourthOfJanuary);\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeekYear;\n","import { addDays } from \"./addDays.js\";\n\n/**\n * The {@link addWeeks} function options.\n */\n\n/**\n * @name addWeeks\n * @category Week Helpers\n * @summary Add the specified number of weeks to the given date.\n *\n * @description\n * Add the specified number of weeks to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The date to be changed\n * @param amount - The amount of weeks to be added.\n * @param options - An object with options\n *\n * @returns The new date with the weeks added\n *\n * @example\n * // Add 4 weeks to 1 September 2014:\n * const result = addWeeks(new Date(2014, 8, 1), 4)\n * //=> Mon Sep 29 2014 00:00:00\n */\nexport function addWeeks(date, amount, options) {\n return addDays(date, amount * 7, options);\n}\n\n// Fallback for modularized imports:\nexport default addWeeks;\n","import { addMonths } from \"./addMonths.js\";\n\n/**\n * The {@link addYears} function options.\n */\n\n/**\n * @name addYears\n * @category Year Helpers\n * @summary Add the specified number of years to the given date.\n *\n * @description\n * Add the specified number of years to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type.\n *\n * @param date - The date to be changed\n * @param amount - The amount of years to be added.\n * @param options - The options\n *\n * @returns The new date with the years added\n *\n * @example\n * // Add 5 years to 1 September 2014:\n * const result = addYears(new Date(2014, 8, 1), 5)\n * //=> Sun Sep 01 2019 00:00:00\n */\nexport function addYears(date, amount, options) {\n return addMonths(date, amount * 12, options);\n}\n\n// Fallback for modularized imports:\nexport default addYears;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link max} function options.\n */\n\n/**\n * @name max\n * @category Common Helpers\n * @summary Return the latest of the given dates.\n *\n * @description\n * Return the latest of the given dates.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param dates - The dates to compare\n *\n * @returns The latest of the dates\n *\n * @example\n * // Which of these dates is the latest?\n * const result = max([\n * new Date(1989, 6, 10),\n * new Date(1987, 1, 11),\n * new Date(1995, 6, 2),\n * new Date(1990, 0, 1)\n * ])\n * //=> Sun Jul 02 1995 00:00:00\n */\nexport function max(dates, options) {\n let result;\n let context = options?.in;\n\n dates.forEach((date) => {\n // Use the first date object as the context function\n if (!context && typeof date === \"object\")\n context = constructFrom.bind(null, date);\n\n const date_ = toDate(date, context);\n if (!result || result < date_ || isNaN(+date_)) result = date_;\n });\n\n return constructFrom(context, result || NaN);\n}\n\n// Fallback for modularized imports:\nexport default max;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link min} function options.\n */\n\n/**\n * @name min\n * @category Common Helpers\n * @summary Returns the earliest of the given dates.\n *\n * @description\n * Returns the earliest of the given dates.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param dates - The dates to compare\n *\n * @returns The earliest of the dates\n *\n * @example\n * // Which of these dates is the earliest?\n * const result = min([\n * new Date(1989, 6, 10),\n * new Date(1987, 1, 11),\n * new Date(1995, 6, 2),\n * new Date(1990, 0, 1)\n * ])\n * //=> Wed Feb 11 1987 00:00:00\n */\nexport function min(dates, options) {\n let result;\n let context = options?.in;\n\n dates.forEach((date) => {\n // Use the first date object as the context function\n if (!context && typeof date === \"object\")\n context = constructFrom.bind(null, date);\n\n const date_ = toDate(date, context);\n if (!result || result > date_ || isNaN(+date_)) result = date_;\n });\n\n return constructFrom(context, result || NaN);\n}\n\n// Fallback for modularized imports:\nexport default min;\n","import { normalizeDates } from \"./_lib/normalizeDates.js\";\nimport { startOfDay } from \"./startOfDay.js\";\n\n/**\n * The {@link isSameDay} function options.\n */\n\n/**\n * @name isSameDay\n * @category Day Helpers\n * @summary Are the given dates in the same day (and year and month)?\n *\n * @description\n * Are the given dates in the same day (and year and month)?\n *\n * @param laterDate - The first date to check\n * @param earlierDate - The second date to check\n * @param options - An object with options\n *\n * @returns The dates are in the same day (and year and month)\n *\n * @example\n * // Are 4 September 06:00:00 and 4 September 18:00:00 in the same day?\n * const result = isSameDay(new Date(2014, 8, 4, 6, 0), new Date(2014, 8, 4, 18, 0))\n * //=> true\n *\n * @example\n * // Are 4 September and 4 October in the same day?\n * const result = isSameDay(new Date(2014, 8, 4), new Date(2014, 9, 4))\n * //=> false\n *\n * @example\n * // Are 4 September, 2014 and 4 September, 2015 in the same day?\n * const result = isSameDay(new Date(2014, 8, 4), new Date(2015, 8, 4))\n * //=> false\n */\nexport function isSameDay(laterDate, earlierDate, options) {\n const [dateLeft_, dateRight_] = normalizeDates(\n options?.in,\n laterDate,\n earlierDate,\n );\n return +startOfDay(dateLeft_) === +startOfDay(dateRight_);\n}\n\n// Fallback for modularized imports:\nexport default isSameDay;\n","/**\n * @name isDate\n * @category Common Helpers\n * @summary Is the given value a date?\n *\n * @description\n * Returns true if the given value is an instance of Date. The function works for dates transferred across iframes.\n *\n * @param value - The value to check\n *\n * @returns True if the given value is a date\n *\n * @example\n * // For a valid date:\n * const result = isDate(new Date())\n * //=> true\n *\n * @example\n * // For an invalid date:\n * const result = isDate(new Date(NaN))\n * //=> true\n *\n * @example\n * // For some value:\n * const result = isDate('2014-02-31')\n * //=> false\n *\n * @example\n * // For an object:\n * const result = isDate({})\n * //=> false\n */\nexport function isDate(value) {\n return (\n value instanceof Date ||\n (typeof value === \"object\" &&\n Object.prototype.toString.call(value) === \"[object Date]\")\n );\n}\n\n// Fallback for modularized imports:\nexport default isDate;\n","import { isDate } from \"./isDate.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * @name isValid\n * @category Common Helpers\n * @summary Is the given date valid?\n *\n * @description\n * Returns false if argument is Invalid Date and true otherwise.\n * Argument is converted to Date using `toDate`. See [toDate](https://date-fns.org/docs/toDate)\n * Invalid Date is a Date, whose time value is NaN.\n *\n * Time value of Date: http://es5.github.io/#x15.9.1.1\n *\n * @param date - The date to check\n *\n * @returns The date is valid\n *\n * @example\n * // For the valid date:\n * const result = isValid(new Date(2014, 1, 31))\n * //=> true\n *\n * @example\n * // For the value, convertible into a date:\n * const result = isValid(1393804800000)\n * //=> true\n *\n * @example\n * // For the invalid date:\n * const result = isValid(new Date(''))\n * //=> false\n */\nexport function isValid(date) {\n return !((!isDate(date) && typeof date !== \"number\") || isNaN(+toDate(date)));\n}\n\n// Fallback for modularized imports:\nexport default isValid;\n","import { normalizeDates } from \"./_lib/normalizeDates.js\";\n\n/**\n * The {@link differenceInCalendarMonths} function options.\n */\n\n/**\n * @name differenceInCalendarMonths\n * @category Month Helpers\n * @summary Get the number of calendar months between the given dates.\n *\n * @description\n * Get the number of calendar months between the given dates.\n *\n * @param laterDate - The later date\n * @param earlierDate - The earlier date\n * @param options - An object with options\n *\n * @returns The number of calendar months\n *\n * @example\n * // How many calendar months are between 31 January 2014 and 1 September 2014?\n * const result = differenceInCalendarMonths(\n * new Date(2014, 8, 1),\n * new Date(2014, 0, 31)\n * )\n * //=> 8\n */\nexport function differenceInCalendarMonths(laterDate, earlierDate, options) {\n const [laterDate_, earlierDate_] = normalizeDates(\n options?.in,\n laterDate,\n earlierDate,\n );\n\n const yearsDiff = laterDate_.getFullYear() - earlierDate_.getFullYear();\n const monthsDiff = laterDate_.getMonth() - earlierDate_.getMonth();\n\n return yearsDiff * 12 + monthsDiff;\n}\n\n// Fallback for modularized imports:\nexport default differenceInCalendarMonths;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link endOfMonth} function options.\n */\n\n/**\n * @name endOfMonth\n * @category Month Helpers\n * @summary Return the end of a month for the given date.\n *\n * @description\n * Return the end of a month for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The end of a month\n *\n * @example\n * // The end of a month for 2 September 2014 11:55:00:\n * const result = endOfMonth(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Tue Sep 30 2014 23:59:59.999\n */\nexport function endOfMonth(date, options) {\n const _date = toDate(date, options?.in);\n const month = _date.getMonth();\n _date.setFullYear(_date.getFullYear(), month + 1, 0);\n _date.setHours(23, 59, 59, 999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfMonth;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfMonth} function options.\n */\n\n/**\n * @name startOfMonth\n * @category Month Helpers\n * @summary Return the start of a month for the given date.\n *\n * @description\n * Return the start of a month for the given date. The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments.\n * Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed,\n * or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a month\n *\n * @example\n * // The start of a month for 2 September 2014 11:55:00:\n * const result = startOfMonth(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfMonth(date, options) {\n const _date = toDate(date, options?.in);\n _date.setDate(1);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfMonth;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link endOfYear} function options.\n */\n\n/**\n * @name endOfYear\n * @category Year Helpers\n * @summary Return the end of a year for the given date.\n *\n * @description\n * Return the end of a year for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - The options\n *\n * @returns The end of a year\n *\n * @example\n * // The end of a year for 2 September 2014 11:55:00:\n * const result = endOfYear(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Wed Dec 31 2014 23:59:59.999\n */\nexport function endOfYear(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n _date.setFullYear(year + 1, 0, 0);\n _date.setHours(23, 59, 59, 999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfYear;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfYear} function options.\n */\n\n/**\n * @name startOfYear\n * @category Year Helpers\n * @summary Return the start of a year for the given date.\n *\n * @description\n * Return the start of a year for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - The options\n *\n * @returns The start of a year\n *\n * @example\n * // The start of a year for 2 September 2014 11:55:00:\n * const result = startOfYear(new Date(2014, 8, 2, 11, 55, 00))\n * //=> Wed Jan 01 2014 00:00:00\n */\nexport function startOfYear(date, options) {\n const date_ = toDate(date, options?.in);\n date_.setFullYear(date_.getFullYear(), 0, 1);\n date_.setHours(0, 0, 0, 0);\n return date_;\n}\n\n// Fallback for modularized imports:\nexport default startOfYear;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link endOfWeek} function options.\n */\n\n/**\n * @name endOfWeek\n * @category Week Helpers\n * @summary Return the end of a week for the given date.\n *\n * @description\n * Return the end of a week for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The end of a week\n *\n * @example\n * // The end of a week for 2 September 2014 11:55:00:\n * const result = endOfWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Sat Sep 06 2014 23:59:59.999\n *\n * @example\n * // If the week starts on Monday, the end of the week for 2 September 2014 11:55:00:\n * const result = endOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })\n * //=> Sun Sep 07 2014 23:59:59.999\n */\nexport function endOfWeek(date, options) {\n const defaultOptions = getDefaultOptions();\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const _date = toDate(date, options?.in);\n const day = _date.getDay();\n const diff = (day < weekStartsOn ? -7 : 0) + 6 - (day - weekStartsOn);\n\n _date.setDate(_date.getDate() + diff);\n _date.setHours(23, 59, 59, 999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfWeek;\n","import { endOfWeek } from \"./endOfWeek.js\";\n\n/**\n * The {@link endOfISOWeek} function options.\n */\n\n/**\n * @name endOfISOWeek\n * @category ISO Week Helpers\n * @summary Return the end of an ISO week for the given date.\n *\n * @description\n * Return the end of an ISO week for the given date.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The end of an ISO week\n *\n * @example\n * // The end of an ISO week for 2 September 2014 11:55:00:\n * const result = endOfISOWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Sun Sep 07 2014 23:59:59.999\n */\nexport function endOfISOWeek(date, options) {\n return endOfWeek(date, { ...options, weekStartsOn: 1 });\n}\n\n// Fallback for modularized imports:\nexport default endOfISOWeek;\n","const formatDistanceLocale = {\n lessThanXSeconds: {\n one: \"less than a second\",\n other: \"less than {{count}} seconds\",\n },\n\n xSeconds: {\n one: \"1 second\",\n other: \"{{count}} seconds\",\n },\n\n halfAMinute: \"half a minute\",\n\n lessThanXMinutes: {\n one: \"less than a minute\",\n other: \"less than {{count}} minutes\",\n },\n\n xMinutes: {\n one: \"1 minute\",\n other: \"{{count}} minutes\",\n },\n\n aboutXHours: {\n one: \"about 1 hour\",\n other: \"about {{count}} hours\",\n },\n\n xHours: {\n one: \"1 hour\",\n other: \"{{count}} hours\",\n },\n\n xDays: {\n one: \"1 day\",\n other: \"{{count}} days\",\n },\n\n aboutXWeeks: {\n one: \"about 1 week\",\n other: \"about {{count}} weeks\",\n },\n\n xWeeks: {\n one: \"1 week\",\n other: \"{{count}} weeks\",\n },\n\n aboutXMonths: {\n one: \"about 1 month\",\n other: \"about {{count}} months\",\n },\n\n xMonths: {\n one: \"1 month\",\n other: \"{{count}} months\",\n },\n\n aboutXYears: {\n one: \"about 1 year\",\n other: \"about {{count}} years\",\n },\n\n xYears: {\n one: \"1 year\",\n other: \"{{count}} years\",\n },\n\n overXYears: {\n one: \"over 1 year\",\n other: \"over {{count}} years\",\n },\n\n almostXYears: {\n one: \"almost 1 year\",\n other: \"almost {{count}} years\",\n },\n};\n\nexport const formatDistance = (token, count, options) => {\n let result;\n\n const tokenValue = formatDistanceLocale[token];\n if (typeof tokenValue === \"string\") {\n result = tokenValue;\n } else if (count === 1) {\n result = tokenValue.one;\n } else {\n result = tokenValue.other.replace(\"{{count}}\", count.toString());\n }\n\n if (options?.addSuffix) {\n if (options.comparison && options.comparison > 0) {\n return \"in \" + result;\n } else {\n return result + \" ago\";\n }\n }\n\n return result;\n};\n","export function buildFormatLongFn(args) {\n return (options = {}) => {\n // TODO: Remove String()\n const width = options.width ? String(options.width) : args.defaultWidth;\n const format = args.formats[width] || args.formats[args.defaultWidth];\n return format;\n };\n}\n","import { buildFormatLongFn } from \"../../_lib/buildFormatLongFn.js\";\n\nconst dateFormats = {\n full: \"EEEE, MMMM do, y\",\n long: \"MMMM do, y\",\n medium: \"MMM d, y\",\n short: \"MM/dd/yyyy\",\n};\n\nconst timeFormats = {\n full: \"h:mm:ss a zzzz\",\n long: \"h:mm:ss a z\",\n medium: \"h:mm:ss a\",\n short: \"h:mm a\",\n};\n\nconst dateTimeFormats = {\n full: \"{{date}} 'at' {{time}}\",\n long: \"{{date}} 'at' {{time}}\",\n medium: \"{{date}}, {{time}}\",\n short: \"{{date}}, {{time}}\",\n};\n\nexport const formatLong = {\n date: buildFormatLongFn({\n formats: dateFormats,\n defaultWidth: \"full\",\n }),\n\n time: buildFormatLongFn({\n formats: timeFormats,\n defaultWidth: \"full\",\n }),\n\n dateTime: buildFormatLongFn({\n formats: dateTimeFormats,\n defaultWidth: \"full\",\n }),\n};\n","const formatRelativeLocale = {\n lastWeek: \"'last' eeee 'at' p\",\n yesterday: \"'yesterday at' p\",\n today: \"'today at' p\",\n tomorrow: \"'tomorrow at' p\",\n nextWeek: \"eeee 'at' p\",\n other: \"P\",\n};\n\nexport const formatRelative = (token, _date, _baseDate, _options) =>\n formatRelativeLocale[token];\n","/**\n * The localize function argument callback which allows to convert raw value to\n * the actual type.\n *\n * @param value - The value to convert\n *\n * @returns The converted value\n */\n\n/**\n * The map of localized values for each width.\n */\n\n/**\n * The index type of the locale unit value. It types conversion of units of\n * values that don't start at 0 (i.e. quarters).\n */\n\n/**\n * Converts the unit value to the tuple of values.\n */\n\n/**\n * The tuple of localized era values. The first element represents BC,\n * the second element represents AD.\n */\n\n/**\n * The tuple of localized quarter values. The first element represents Q1.\n */\n\n/**\n * The tuple of localized day values. The first element represents Sunday.\n */\n\n/**\n * The tuple of localized month values. The first element represents January.\n */\n\nexport function buildLocalizeFn(args) {\n return (value, options) => {\n const context = options?.context ? String(options.context) : \"standalone\";\n\n let valuesArray;\n if (context === \"formatting\" && args.formattingValues) {\n const defaultWidth = args.defaultFormattingWidth || args.defaultWidth;\n const width = options?.width ? String(options.width) : defaultWidth;\n\n valuesArray =\n args.formattingValues[width] || args.formattingValues[defaultWidth];\n } else {\n const defaultWidth = args.defaultWidth;\n const width = options?.width ? String(options.width) : args.defaultWidth;\n\n valuesArray = args.values[width] || args.values[defaultWidth];\n }\n const index = args.argumentCallback ? args.argumentCallback(value) : value;\n\n // @ts-expect-error - For some reason TypeScript just don't want to match it, no matter how hard we try. I challenge you to try to remove it!\n return valuesArray[index];\n };\n}\n","import { buildLocalizeFn } from \"../../_lib/buildLocalizeFn.js\";\n\nconst eraValues = {\n narrow: [\"B\", \"A\"],\n abbreviated: [\"BC\", \"AD\"],\n wide: [\"Before Christ\", \"Anno Domini\"],\n};\n\nconst quarterValues = {\n narrow: [\"1\", \"2\", \"3\", \"4\"],\n abbreviated: [\"Q1\", \"Q2\", \"Q3\", \"Q4\"],\n wide: [\"1st quarter\", \"2nd quarter\", \"3rd quarter\", \"4th quarter\"],\n};\n\n// Note: in English, the names of days of the week and months are capitalized.\n// If you are making a new locale based on this one, check if the same is true for the language you're working on.\n// Generally, formatted dates should look like they are in the middle of a sentence,\n// e.g. in Spanish language the weekdays and months should be in the lowercase.\nconst monthValues = {\n narrow: [\"J\", \"F\", \"M\", \"A\", \"M\", \"J\", \"J\", \"A\", \"S\", \"O\", \"N\", \"D\"],\n abbreviated: [\n \"Jan\",\n \"Feb\",\n \"Mar\",\n \"Apr\",\n \"May\",\n \"Jun\",\n \"Jul\",\n \"Aug\",\n \"Sep\",\n \"Oct\",\n \"Nov\",\n \"Dec\",\n ],\n\n wide: [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\",\n ],\n};\n\nconst dayValues = {\n narrow: [\"S\", \"M\", \"T\", \"W\", \"T\", \"F\", \"S\"],\n short: [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"],\n abbreviated: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n wide: [\n \"Sunday\",\n \"Monday\",\n \"Tuesday\",\n \"Wednesday\",\n \"Thursday\",\n \"Friday\",\n \"Saturday\",\n ],\n};\n\nconst dayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n};\n\nconst formattingDayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n};\n\nconst ordinalNumber = (dirtyNumber, _options) => {\n const number = Number(dirtyNumber);\n\n // If ordinal numbers depend on context, for example,\n // if they are different for different grammatical genders,\n // use `options.unit`.\n //\n // `unit` can be 'year', 'quarter', 'month', 'week', 'date', 'dayOfYear',\n // 'day', 'hour', 'minute', 'second'.\n\n const rem100 = number % 100;\n if (rem100 > 20 || rem100 < 10) {\n switch (rem100 % 10) {\n case 1:\n return number + \"st\";\n case 2:\n return number + \"nd\";\n case 3:\n return number + \"rd\";\n }\n }\n return number + \"th\";\n};\n\nexport const localize = {\n ordinalNumber,\n\n era: buildLocalizeFn({\n values: eraValues,\n defaultWidth: \"wide\",\n }),\n\n quarter: buildLocalizeFn({\n values: quarterValues,\n defaultWidth: \"wide\",\n argumentCallback: (quarter) => quarter - 1,\n }),\n\n month: buildLocalizeFn({\n values: monthValues,\n defaultWidth: \"wide\",\n }),\n\n day: buildLocalizeFn({\n values: dayValues,\n defaultWidth: \"wide\",\n }),\n\n dayPeriod: buildLocalizeFn({\n values: dayPeriodValues,\n defaultWidth: \"wide\",\n formattingValues: formattingDayPeriodValues,\n defaultFormattingWidth: \"wide\",\n }),\n};\n","export function buildMatchFn(args) {\n return (string, options = {}) => {\n const width = options.width;\n\n const matchPattern =\n (width && args.matchPatterns[width]) ||\n args.matchPatterns[args.defaultMatchWidth];\n const matchResult = string.match(matchPattern);\n\n if (!matchResult) {\n return null;\n }\n const matchedString = matchResult[0];\n\n const parsePatterns =\n (width && args.parsePatterns[width]) ||\n args.parsePatterns[args.defaultParseWidth];\n\n const key = Array.isArray(parsePatterns)\n ? findIndex(parsePatterns, (pattern) => pattern.test(matchedString))\n : // [TODO] -- I challenge you to fix the type\n findKey(parsePatterns, (pattern) => pattern.test(matchedString));\n\n let value;\n\n value = args.valueCallback ? args.valueCallback(key) : key;\n value = options.valueCallback\n ? // [TODO] -- I challenge you to fix the type\n options.valueCallback(value)\n : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n\nfunction findKey(object, predicate) {\n for (const key in object) {\n if (\n Object.prototype.hasOwnProperty.call(object, key) &&\n predicate(object[key])\n ) {\n return key;\n }\n }\n return undefined;\n}\n\nfunction findIndex(array, predicate) {\n for (let key = 0; key < array.length; key++) {\n if (predicate(array[key])) {\n return key;\n }\n }\n return undefined;\n}\n","export function buildMatchPatternFn(args) {\n return (string, options = {}) => {\n const matchResult = string.match(args.matchPattern);\n if (!matchResult) return null;\n const matchedString = matchResult[0];\n\n const parseResult = string.match(args.parsePattern);\n if (!parseResult) return null;\n let value = args.valueCallback\n ? args.valueCallback(parseResult[0])\n : parseResult[0];\n\n // [TODO] I challenge you to fix the type\n value = options.valueCallback ? options.valueCallback(value) : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n","import { buildMatchFn } from \"../../_lib/buildMatchFn.js\";\nimport { buildMatchPatternFn } from \"../../_lib/buildMatchPatternFn.js\";\n\nconst matchOrdinalNumberPattern = /^(\\d+)(th|st|nd|rd)?/i;\nconst parseOrdinalNumberPattern = /\\d+/i;\n\nconst matchEraPatterns = {\n narrow: /^(b|a)/i,\n abbreviated: /^(b\\.?\\s?c\\.?|b\\.?\\s?c\\.?\\s?e\\.?|a\\.?\\s?d\\.?|c\\.?\\s?e\\.?)/i,\n wide: /^(before christ|before common era|anno domini|common era)/i,\n};\nconst parseEraPatterns = {\n any: [/^b/i, /^(a|c)/i],\n};\n\nconst matchQuarterPatterns = {\n narrow: /^[1234]/i,\n abbreviated: /^q[1234]/i,\n wide: /^[1234](th|st|nd|rd)? quarter/i,\n};\nconst parseQuarterPatterns = {\n any: [/1/i, /2/i, /3/i, /4/i],\n};\n\nconst matchMonthPatterns = {\n narrow: /^[jfmasond]/i,\n abbreviated: /^(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)/i,\n wide: /^(january|february|march|april|may|june|july|august|september|october|november|december)/i,\n};\nconst parseMonthPatterns = {\n narrow: [\n /^j/i,\n /^f/i,\n /^m/i,\n /^a/i,\n /^m/i,\n /^j/i,\n /^j/i,\n /^a/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n\n any: [\n /^ja/i,\n /^f/i,\n /^mar/i,\n /^ap/i,\n /^may/i,\n /^jun/i,\n /^jul/i,\n /^au/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n};\n\nconst matchDayPatterns = {\n narrow: /^[smtwf]/i,\n short: /^(su|mo|tu|we|th|fr|sa)/i,\n abbreviated: /^(sun|mon|tue|wed|thu|fri|sat)/i,\n wide: /^(sunday|monday|tuesday|wednesday|thursday|friday|saturday)/i,\n};\nconst parseDayPatterns = {\n narrow: [/^s/i, /^m/i, /^t/i, /^w/i, /^t/i, /^f/i, /^s/i],\n any: [/^su/i, /^m/i, /^tu/i, /^w/i, /^th/i, /^f/i, /^sa/i],\n};\n\nconst matchDayPeriodPatterns = {\n narrow: /^(a|p|mi|n|(in the|at) (morning|afternoon|evening|night))/i,\n any: /^([ap]\\.?\\s?m\\.?|midnight|noon|(in the|at) (morning|afternoon|evening|night))/i,\n};\nconst parseDayPeriodPatterns = {\n any: {\n am: /^a/i,\n pm: /^p/i,\n midnight: /^mi/i,\n noon: /^no/i,\n morning: /morning/i,\n afternoon: /afternoon/i,\n evening: /evening/i,\n night: /night/i,\n },\n};\n\nexport const match = {\n ordinalNumber: buildMatchPatternFn({\n matchPattern: matchOrdinalNumberPattern,\n parsePattern: parseOrdinalNumberPattern,\n valueCallback: (value) => parseInt(value, 10),\n }),\n\n era: buildMatchFn({\n matchPatterns: matchEraPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseEraPatterns,\n defaultParseWidth: \"any\",\n }),\n\n quarter: buildMatchFn({\n matchPatterns: matchQuarterPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseQuarterPatterns,\n defaultParseWidth: \"any\",\n valueCallback: (index) => index + 1,\n }),\n\n month: buildMatchFn({\n matchPatterns: matchMonthPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseMonthPatterns,\n defaultParseWidth: \"any\",\n }),\n\n day: buildMatchFn({\n matchPatterns: matchDayPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseDayPatterns,\n defaultParseWidth: \"any\",\n }),\n\n dayPeriod: buildMatchFn({\n matchPatterns: matchDayPeriodPatterns,\n defaultMatchWidth: \"any\",\n parsePatterns: parseDayPeriodPatterns,\n defaultParseWidth: \"any\",\n }),\n};\n","import { formatDistance } from \"./en-US/_lib/formatDistance.js\";\nimport { formatLong } from \"./en-US/_lib/formatLong.js\";\nimport { formatRelative } from \"./en-US/_lib/formatRelative.js\";\nimport { localize } from \"./en-US/_lib/localize.js\";\nimport { match } from \"./en-US/_lib/match.js\";\n\n/**\n * @category Locales\n * @summary English locale (United States).\n * @language English\n * @iso-639-2 eng\n * @author Sasha Koss [@kossnocorp](https://github.com/kossnocorp)\n * @author Lesha Koss [@leshakoss](https://github.com/leshakoss)\n */\nexport const enUS = {\n code: \"en-US\",\n formatDistance: formatDistance,\n formatLong: formatLong,\n formatRelative: formatRelative,\n localize: localize,\n match: match,\n options: {\n weekStartsOn: 0 /* Sunday */,\n firstWeekContainsDate: 1,\n },\n};\n\n// Fallback for modularized imports:\nexport default enUS;\n","import { differenceInCalendarDays } from \"./differenceInCalendarDays.js\";\nimport { startOfYear } from \"./startOfYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getDayOfYear} function options.\n */\n\n/**\n * @name getDayOfYear\n * @category Day Helpers\n * @summary Get the day of the year of the given date.\n *\n * @description\n * Get the day of the year of the given date.\n *\n * @param date - The given date\n * @param options - The options\n *\n * @returns The day of year\n *\n * @example\n * // Which day of the year is 2 July 2014?\n * const result = getDayOfYear(new Date(2014, 6, 2))\n * //=> 183\n */\nexport function getDayOfYear(date, options) {\n const _date = toDate(date, options?.in);\n const diff = differenceInCalendarDays(_date, startOfYear(_date));\n const dayOfYear = diff + 1;\n return dayOfYear;\n}\n\n// Fallback for modularized imports:\nexport default getDayOfYear;\n","import { millisecondsInWeek } from \"./constants.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\nimport { startOfISOWeekYear } from \"./startOfISOWeekYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getISOWeek} function options.\n */\n\n/**\n * @name getISOWeek\n * @category ISO Week Helpers\n * @summary Get the ISO week of the given date.\n *\n * @description\n * Get the ISO week of the given date.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @param date - The given date\n * @param options - The options\n *\n * @returns The ISO week\n *\n * @example\n * // Which week of the ISO-week numbering year is 2 January 2005?\n * const result = getISOWeek(new Date(2005, 0, 2))\n * //=> 53\n */\nexport function getISOWeek(date, options) {\n const _date = toDate(date, options?.in);\n const diff = +startOfISOWeek(_date) - +startOfISOWeekYear(_date);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getISOWeek;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { constructFrom } from \"./constructFrom.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getWeekYear} function options.\n */\n\n/**\n * @name getWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Get the local week-numbering year of the given date.\n *\n * @description\n * Get the local week-numbering year of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @param date - The given date\n * @param options - An object with options.\n *\n * @returns The local week-numbering year\n *\n * @example\n * // Which week numbering year is 26 December 2004 with the default settings?\n * const result = getWeekYear(new Date(2004, 11, 26))\n * //=> 2005\n *\n * @example\n * // Which week numbering year is 26 December 2004 if week starts on Saturday?\n * const result = getWeekYear(new Date(2004, 11, 26), { weekStartsOn: 6 })\n * //=> 2004\n *\n * @example\n * // Which week numbering year is 26 December 2004 if the first week contains 4 January?\n * const result = getWeekYear(new Date(2004, 11, 26), { firstWeekContainsDate: 4 })\n * //=> 2004\n */\nexport function getWeekYear(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const firstWeekOfNextYear = constructFrom(options?.in || date, 0);\n firstWeekOfNextYear.setFullYear(year + 1, 0, firstWeekContainsDate);\n firstWeekOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfWeek(firstWeekOfNextYear, options);\n\n const firstWeekOfThisYear = constructFrom(options?.in || date, 0);\n firstWeekOfThisYear.setFullYear(year, 0, firstWeekContainsDate);\n firstWeekOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfWeek(firstWeekOfThisYear, options);\n\n if (+_date >= +startOfNextYear) {\n return year + 1;\n } else if (+_date >= +startOfThisYear) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getWeekYear;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { constructFrom } from \"./constructFrom.js\";\nimport { getWeekYear } from \"./getWeekYear.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\n\n/**\n * The {@link startOfWeekYear} function options.\n */\n\n/**\n * @name startOfWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Return the start of a local week-numbering year for the given date.\n *\n * @description\n * Return the start of a local week-numbering year.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week-numbering year\n *\n * @example\n * // The start of an a week-numbering year for 2 July 2005 with default settings:\n * const result = startOfWeekYear(new Date(2005, 6, 2))\n * //=> Sun Dec 26 2004 00:00:00\n *\n * @example\n * // The start of a week-numbering year for 2 July 2005\n * // if Monday is the first day of week\n * // and 4 January is always in the first week of the year:\n * const result = startOfWeekYear(new Date(2005, 6, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfWeekYear(date, options) {\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const year = getWeekYear(date, options);\n const firstWeek = constructFrom(options?.in || date, 0);\n firstWeek.setFullYear(year, 0, firstWeekContainsDate);\n firstWeek.setHours(0, 0, 0, 0);\n const _date = startOfWeek(firstWeek, options);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeekYear;\n","import { millisecondsInWeek } from \"./constants.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\nimport { startOfWeekYear } from \"./startOfWeekYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getWeek} function options.\n */\n\n/**\n * @name getWeek\n * @category Week Helpers\n * @summary Get the local week index of the given date.\n *\n * @description\n * Get the local week index of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @param date - The given date\n * @param options - An object with options\n *\n * @returns The week\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005 with default options?\n * const result = getWeek(new Date(2005, 0, 2))\n * //=> 2\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005,\n * // if Monday is the first day of the week,\n * // and the first week of the year always contains 4 January?\n * const result = getWeek(new Date(2005, 0, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> 53\n */\nexport function getWeek(date, options) {\n const _date = toDate(date, options?.in);\n const diff = +startOfWeek(_date, options) - +startOfWeekYear(_date, options);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getWeek;\n","export function addLeadingZeros(number, targetLength) {\n const sign = number < 0 ? \"-\" : \"\";\n const output = Math.abs(number).toString().padStart(targetLength, \"0\");\n return sign + output;\n}\n","import { addLeadingZeros } from \"../addLeadingZeros.js\";\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | |\n * | d | Day of month | D | |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | m | Minute | M | Month |\n * | s | Second | S | Fraction of second |\n * | y | Year (abs) | Y | |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n */\n\nexport const lightFormatters = {\n // Year\n y(date, token) {\n // From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_tokens\n // | Year | y | yy | yyy | yyyy | yyyyy |\n // |----------|-------|----|-------|-------|-------|\n // | AD 1 | 1 | 01 | 001 | 0001 | 00001 |\n // | AD 12 | 12 | 12 | 012 | 0012 | 00012 |\n // | AD 123 | 123 | 23 | 123 | 0123 | 00123 |\n // | AD 1234 | 1234 | 34 | 1234 | 1234 | 01234 |\n // | AD 12345 | 12345 | 45 | 12345 | 12345 | 12345 |\n\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return addLeadingZeros(token === \"yy\" ? year % 100 : year, token.length);\n },\n\n // Month\n M(date, token) {\n const month = date.getMonth();\n return token === \"M\" ? String(month + 1) : addLeadingZeros(month + 1, 2);\n },\n\n // Day of the month\n d(date, token) {\n return addLeadingZeros(date.getDate(), token.length);\n },\n\n // AM or PM\n a(date, token) {\n const dayPeriodEnumValue = date.getHours() / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return dayPeriodEnumValue.toUpperCase();\n case \"aaa\":\n return dayPeriodEnumValue;\n case \"aaaaa\":\n return dayPeriodEnumValue[0];\n case \"aaaa\":\n default:\n return dayPeriodEnumValue === \"am\" ? \"a.m.\" : \"p.m.\";\n }\n },\n\n // Hour [1-12]\n h(date, token) {\n return addLeadingZeros(date.getHours() % 12 || 12, token.length);\n },\n\n // Hour [0-23]\n H(date, token) {\n return addLeadingZeros(date.getHours(), token.length);\n },\n\n // Minute\n m(date, token) {\n return addLeadingZeros(date.getMinutes(), token.length);\n },\n\n // Second\n s(date, token) {\n return addLeadingZeros(date.getSeconds(), token.length);\n },\n\n // Fraction of second\n S(date, token) {\n const numberOfDigits = token.length;\n const milliseconds = date.getMilliseconds();\n const fractionalSeconds = Math.trunc(\n milliseconds * Math.pow(10, numberOfDigits - 3),\n );\n return addLeadingZeros(fractionalSeconds, token.length);\n },\n};\n","import { getDayOfYear } from \"../../getDayOfYear.js\";\nimport { getISOWeek } from \"../../getISOWeek.js\";\nimport { getISOWeekYear } from \"../../getISOWeekYear.js\";\nimport { getWeek } from \"../../getWeek.js\";\nimport { getWeekYear } from \"../../getWeekYear.js\";\n\nimport { addLeadingZeros } from \"../addLeadingZeros.js\";\nimport { lightFormatters } from \"./lightFormatters.js\";\n\nconst dayPeriodEnum = {\n am: \"am\",\n pm: \"pm\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n};\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | Milliseconds in day |\n * | b | AM, PM, noon, midnight | B | Flexible day period |\n * | c | Stand-alone local day of week | C* | Localized hour w/ day period |\n * | d | Day of month | D | Day of year |\n * | e | Local day of week | E | Day of week |\n * | f | | F* | Day of week in month |\n * | g* | Modified Julian day | G | Era |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | i! | ISO day of week | I! | ISO week of year |\n * | j* | Localized hour w/ day period | J* | Localized hour w/o day period |\n * | k | Hour [1-24] | K | Hour [0-11] |\n * | l* | (deprecated) | L | Stand-alone month |\n * | m | Minute | M | Month |\n * | n | | N | |\n * | o! | Ordinal number modifier | O | Timezone (GMT) |\n * | p! | Long localized time | P! | Long localized date |\n * | q | Stand-alone quarter | Q | Quarter |\n * | r* | Related Gregorian year | R! | ISO week-numbering year |\n * | s | Second | S | Fraction of second |\n * | t! | Seconds timestamp | T! | Milliseconds timestamp |\n * | u | Extended year | U* | Cyclic year |\n * | v* | Timezone (generic non-locat.) | V* | Timezone (location) |\n * | w | Local week of year | W* | Week of month |\n * | x | Timezone (ISO-8601 w/o Z) | X | Timezone (ISO-8601) |\n * | y | Year (abs) | Y | Local week-numbering year |\n * | z | Timezone (specific non-locat.) | Z* | Timezone (aliases) |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n *\n * Letters marked by ! are non-standard, but implemented by date-fns:\n * - `o` modifies the previous token to turn it into an ordinal (see `format` docs)\n * - `i` is ISO day of week. For `i` and `ii` is returns numeric ISO week days,\n * i.e. 7 for Sunday, 1 for Monday, etc.\n * - `I` is ISO week of year, as opposed to `w` which is local week of year.\n * - `R` is ISO week-numbering year, as opposed to `Y` which is local week-numbering year.\n * `R` is supposed to be used in conjunction with `I` and `i`\n * for universal ISO week-numbering date, whereas\n * `Y` is supposed to be used in conjunction with `w` and `e`\n * for week-numbering date specific to the locale.\n * - `P` is long localized date format\n * - `p` is long localized time format\n */\n\nexport const formatters = {\n // Era\n G: function (date, token, localize) {\n const era = date.getFullYear() > 0 ? 1 : 0;\n switch (token) {\n // AD, BC\n case \"G\":\n case \"GG\":\n case \"GGG\":\n return localize.era(era, { width: \"abbreviated\" });\n // A, B\n case \"GGGGG\":\n return localize.era(era, { width: \"narrow\" });\n // Anno Domini, Before Christ\n case \"GGGG\":\n default:\n return localize.era(era, { width: \"wide\" });\n }\n },\n\n // Year\n y: function (date, token, localize) {\n // Ordinal number\n if (token === \"yo\") {\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return localize.ordinalNumber(year, { unit: \"year\" });\n }\n\n return lightFormatters.y(date, token);\n },\n\n // Local week-numbering year\n Y: function (date, token, localize, options) {\n const signedWeekYear = getWeekYear(date, options);\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear;\n\n // Two digit year\n if (token === \"YY\") {\n const twoDigitYear = weekYear % 100;\n return addLeadingZeros(twoDigitYear, 2);\n }\n\n // Ordinal number\n if (token === \"Yo\") {\n return localize.ordinalNumber(weekYear, { unit: \"year\" });\n }\n\n // Padding\n return addLeadingZeros(weekYear, token.length);\n },\n\n // ISO week-numbering year\n R: function (date, token) {\n const isoWeekYear = getISOWeekYear(date);\n\n // Padding\n return addLeadingZeros(isoWeekYear, token.length);\n },\n\n // Extended year. This is a single number designating the year of this calendar system.\n // The main difference between `y` and `u` localizers are B.C. years:\n // | Year | `y` | `u` |\n // |------|-----|-----|\n // | AC 1 | 1 | 1 |\n // | BC 1 | 1 | 0 |\n // | BC 2 | 2 | -1 |\n // Also `yy` always returns the last two digits of a year,\n // while `uu` pads single digit years to 2 characters and returns other years unchanged.\n u: function (date, token) {\n const year = date.getFullYear();\n return addLeadingZeros(year, token.length);\n },\n\n // Quarter\n Q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"Q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"QQ\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"Qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"QQQ\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"QQQQQ\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"QQQQ\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone quarter\n q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"qq\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"qqq\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"qqqqq\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"qqqq\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // Month\n M: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n case \"M\":\n case \"MM\":\n return lightFormatters.M(date, token);\n // 1st, 2nd, ..., 12th\n case \"Mo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"MMM\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // J, F, ..., D\n case \"MMMMM\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // January, February, ..., December\n case \"MMMM\":\n default:\n return localize.month(month, { width: \"wide\", context: \"formatting\" });\n }\n },\n\n // Stand-alone month\n L: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n // 1, 2, ..., 12\n case \"L\":\n return String(month + 1);\n // 01, 02, ..., 12\n case \"LL\":\n return addLeadingZeros(month + 1, 2);\n // 1st, 2nd, ..., 12th\n case \"Lo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"LLL\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // J, F, ..., D\n case \"LLLLL\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // January, February, ..., December\n case \"LLLL\":\n default:\n return localize.month(month, { width: \"wide\", context: \"standalone\" });\n }\n },\n\n // Local week of year\n w: function (date, token, localize, options) {\n const week = getWeek(date, options);\n\n if (token === \"wo\") {\n return localize.ordinalNumber(week, { unit: \"week\" });\n }\n\n return addLeadingZeros(week, token.length);\n },\n\n // ISO week of year\n I: function (date, token, localize) {\n const isoWeek = getISOWeek(date);\n\n if (token === \"Io\") {\n return localize.ordinalNumber(isoWeek, { unit: \"week\" });\n }\n\n return addLeadingZeros(isoWeek, token.length);\n },\n\n // Day of the month\n d: function (date, token, localize) {\n if (token === \"do\") {\n return localize.ordinalNumber(date.getDate(), { unit: \"date\" });\n }\n\n return lightFormatters.d(date, token);\n },\n\n // Day of year\n D: function (date, token, localize) {\n const dayOfYear = getDayOfYear(date);\n\n if (token === \"Do\") {\n return localize.ordinalNumber(dayOfYear, { unit: \"dayOfYear\" });\n }\n\n return addLeadingZeros(dayOfYear, token.length);\n },\n\n // Day of week\n E: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n switch (token) {\n // Tue\n case \"E\":\n case \"EE\":\n case \"EEE\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"EEEEE\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"EEEEEE\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"EEEE\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Local day of week\n e: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (Nth day of week with current locale or weekStartsOn)\n case \"e\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"ee\":\n return addLeadingZeros(localDayOfWeek, 2);\n // 1st, 2nd, ..., 7th\n case \"eo\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"eee\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"eeeee\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"eeeeee\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"eeee\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone local day of week\n c: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (same as in `e`)\n case \"c\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"cc\":\n return addLeadingZeros(localDayOfWeek, token.length);\n // 1st, 2nd, ..., 7th\n case \"co\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"ccc\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // T\n case \"ccccc\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // Tu\n case \"cccccc\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"standalone\",\n });\n // Tuesday\n case \"cccc\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // ISO day of week\n i: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n const isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek;\n switch (token) {\n // 2\n case \"i\":\n return String(isoDayOfWeek);\n // 02\n case \"ii\":\n return addLeadingZeros(isoDayOfWeek, token.length);\n // 2nd\n case \"io\":\n return localize.ordinalNumber(isoDayOfWeek, { unit: \"day\" });\n // Tue\n case \"iii\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"iiiii\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"iiiiii\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"iiii\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM or PM\n a: function (date, token, localize) {\n const hours = date.getHours();\n const dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"aaa\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"aaaaa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"aaaa\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM, PM, midnight, noon\n b: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours === 12) {\n dayPeriodEnumValue = dayPeriodEnum.noon;\n } else if (hours === 0) {\n dayPeriodEnumValue = dayPeriodEnum.midnight;\n } else {\n dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n }\n\n switch (token) {\n case \"b\":\n case \"bb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"bbb\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"bbbbb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"bbbb\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // in the morning, in the afternoon, in the evening, at night\n B: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours >= 17) {\n dayPeriodEnumValue = dayPeriodEnum.evening;\n } else if (hours >= 12) {\n dayPeriodEnumValue = dayPeriodEnum.afternoon;\n } else if (hours >= 4) {\n dayPeriodEnumValue = dayPeriodEnum.morning;\n } else {\n dayPeriodEnumValue = dayPeriodEnum.night;\n }\n\n switch (token) {\n case \"B\":\n case \"BB\":\n case \"BBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"BBBBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"BBBB\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Hour [1-12]\n h: function (date, token, localize) {\n if (token === \"ho\") {\n let hours = date.getHours() % 12;\n if (hours === 0) hours = 12;\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return lightFormatters.h(date, token);\n },\n\n // Hour [0-23]\n H: function (date, token, localize) {\n if (token === \"Ho\") {\n return localize.ordinalNumber(date.getHours(), { unit: \"hour\" });\n }\n\n return lightFormatters.H(date, token);\n },\n\n // Hour [0-11]\n K: function (date, token, localize) {\n const hours = date.getHours() % 12;\n\n if (token === \"Ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Hour [1-24]\n k: function (date, token, localize) {\n let hours = date.getHours();\n if (hours === 0) hours = 24;\n\n if (token === \"ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Minute\n m: function (date, token, localize) {\n if (token === \"mo\") {\n return localize.ordinalNumber(date.getMinutes(), { unit: \"minute\" });\n }\n\n return lightFormatters.m(date, token);\n },\n\n // Second\n s: function (date, token, localize) {\n if (token === \"so\") {\n return localize.ordinalNumber(date.getSeconds(), { unit: \"second\" });\n }\n\n return lightFormatters.s(date, token);\n },\n\n // Fraction of second\n S: function (date, token) {\n return lightFormatters.S(date, token);\n },\n\n // Timezone (ISO-8601. If offset is 0, output is always `'Z'`)\n X: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n if (timezoneOffset === 0) {\n return \"Z\";\n }\n\n switch (token) {\n // Hours and optional minutes\n case \"X\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XX`\n case \"XXXX\":\n case \"XX\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XXX`\n case \"XXXXX\":\n case \"XXX\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent)\n x: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Hours and optional minutes\n case \"x\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xx`\n case \"xxxx\":\n case \"xx\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xxx`\n case \"xxxxx\":\n case \"xxx\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (GMT)\n O: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"O\":\n case \"OO\":\n case \"OOO\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"OOOO\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (specific non-location)\n z: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"z\":\n case \"zz\":\n case \"zzz\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"zzzz\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Seconds timestamp\n t: function (date, token, _localize) {\n const timestamp = Math.trunc(+date / 1000);\n return addLeadingZeros(timestamp, token.length);\n },\n\n // Milliseconds timestamp\n T: function (date, token, _localize) {\n return addLeadingZeros(+date, token.length);\n },\n};\n\nfunction formatTimezoneShort(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = Math.trunc(absOffset / 60);\n const minutes = absOffset % 60;\n if (minutes === 0) {\n return sign + String(hours);\n }\n return sign + String(hours) + delimiter + addLeadingZeros(minutes, 2);\n}\n\nfunction formatTimezoneWithOptionalMinutes(offset, delimiter) {\n if (offset % 60 === 0) {\n const sign = offset > 0 ? \"-\" : \"+\";\n return sign + addLeadingZeros(Math.abs(offset) / 60, 2);\n }\n return formatTimezone(offset, delimiter);\n}\n\nfunction formatTimezone(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = addLeadingZeros(Math.trunc(absOffset / 60), 2);\n const minutes = addLeadingZeros(absOffset % 60, 2);\n return sign + hours + delimiter + minutes;\n}\n","const dateLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"P\":\n return formatLong.date({ width: \"short\" });\n case \"PP\":\n return formatLong.date({ width: \"medium\" });\n case \"PPP\":\n return formatLong.date({ width: \"long\" });\n case \"PPPP\":\n default:\n return formatLong.date({ width: \"full\" });\n }\n};\n\nconst timeLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"p\":\n return formatLong.time({ width: \"short\" });\n case \"pp\":\n return formatLong.time({ width: \"medium\" });\n case \"ppp\":\n return formatLong.time({ width: \"long\" });\n case \"pppp\":\n default:\n return formatLong.time({ width: \"full\" });\n }\n};\n\nconst dateTimeLongFormatter = (pattern, formatLong) => {\n const matchResult = pattern.match(/(P+)(p+)?/) || [];\n const datePattern = matchResult[1];\n const timePattern = matchResult[2];\n\n if (!timePattern) {\n return dateLongFormatter(pattern, formatLong);\n }\n\n let dateTimeFormat;\n\n switch (datePattern) {\n case \"P\":\n dateTimeFormat = formatLong.dateTime({ width: \"short\" });\n break;\n case \"PP\":\n dateTimeFormat = formatLong.dateTime({ width: \"medium\" });\n break;\n case \"PPP\":\n dateTimeFormat = formatLong.dateTime({ width: \"long\" });\n break;\n case \"PPPP\":\n default:\n dateTimeFormat = formatLong.dateTime({ width: \"full\" });\n break;\n }\n\n return dateTimeFormat\n .replace(\"{{date}}\", dateLongFormatter(datePattern, formatLong))\n .replace(\"{{time}}\", timeLongFormatter(timePattern, formatLong));\n};\n\nexport const longFormatters = {\n p: timeLongFormatter,\n P: dateTimeLongFormatter,\n};\n","const dayOfYearTokenRE = /^D+$/;\nconst weekYearTokenRE = /^Y+$/;\n\nconst throwTokens = [\"D\", \"DD\", \"YY\", \"YYYY\"];\n\nexport function isProtectedDayOfYearToken(token) {\n return dayOfYearTokenRE.test(token);\n}\n\nexport function isProtectedWeekYearToken(token) {\n return weekYearTokenRE.test(token);\n}\n\nexport function warnOrThrowProtectedError(token, format, input) {\n const _message = message(token, format, input);\n console.warn(_message);\n if (throwTokens.includes(token)) throw new RangeError(_message);\n}\n\nfunction message(token, format, input) {\n const subject = token[0] === \"Y\" ? \"years\" : \"days of the month\";\n return `Use \\`${token.toLowerCase()}\\` instead of \\`${token}\\` (in \\`${format}\\`) for formatting ${subject} to the input \\`${input}\\`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md`;\n}\n","import { defaultLocale } from \"./_lib/defaultLocale.js\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { formatters } from \"./_lib/format/formatters.js\";\nimport { longFormatters } from \"./_lib/format/longFormatters.js\";\nimport {\n isProtectedDayOfYearToken,\n isProtectedWeekYearToken,\n warnOrThrowProtectedError,\n} from \"./_lib/protectedTokens.js\";\nimport { isValid } from \"./isValid.js\";\nimport { toDate } from \"./toDate.js\";\n\n// Rexports of internal for libraries to use.\n// See: https://github.com/date-fns/date-fns/issues/3638#issuecomment-1877082874\nexport { formatters, longFormatters };\n\n// This RegExp consists of three parts separated by `|`:\n// - [yYQqMLwIdDecihHKkms]o matches any available ordinal number token\n// (one of the certain letters followed by `o`)\n// - (\\w)\\1* matches any sequences of the same letter\n// - '' matches two quote characters in a row\n// - '(''|[^'])+('|$) matches anything surrounded by two quote characters ('),\n// except a single quote symbol, which ends the sequence.\n// Two quote characters do not end the sequence.\n// If there is no matching single quote\n// then the sequence will continue until the end of the string.\n// - . matches any single character unmatched by previous parts of the RegExps\nconst formattingTokensRegExp =\n /[yYQqMLwIdDecihHKkms]o|(\\w)\\1*|''|'(''|[^'])+('|$)|./g;\n\n// This RegExp catches symbols escaped by quotes, and also\n// sequences of symbols P, p, and the combinations like `PPPPPPPppppp`\nconst longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;\n\nconst escapedStringRegExp = /^'([^]*?)'?$/;\nconst doubleQuoteRegExp = /''/g;\nconst unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n\nexport { format as formatDate };\n\n/**\n * The {@link format} function options.\n */\n\n/**\n * @name format\n * @alias formatDate\n * @category Common Helpers\n * @summary Format the date.\n *\n * @description\n * Return the formatted date string in the given format. The result may vary by locale.\n *\n * > ⚠️ Please note that the `format` tokens differ from Moment.js and other libraries.\n * > See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * The characters wrapped between two single quotes characters (') are escaped.\n * Two single quotes in a row, whether inside or outside a quoted sequence, represent a 'real' single quote.\n * (see the last example)\n *\n * Format of the string is based on Unicode Technical Standard #35:\n * https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table\n * with a few additions (see note 7 below the table).\n *\n * Accepted patterns:\n * | Unit | Pattern | Result examples | Notes |\n * |---------------------------------|---------|-----------------------------------|-------|\n * | Era | G..GGG | AD, BC | |\n * | | GGGG | Anno Domini, Before Christ | 2 |\n * | | GGGGG | A, B | |\n * | Calendar year | y | 44, 1, 1900, 2017 | 5 |\n * | | yo | 44th, 1st, 0th, 17th | 5,7 |\n * | | yy | 44, 01, 00, 17 | 5 |\n * | | yyy | 044, 001, 1900, 2017 | 5 |\n * | | yyyy | 0044, 0001, 1900, 2017 | 5 |\n * | | yyyyy | ... | 3,5 |\n * | Local week-numbering year | Y | 44, 1, 1900, 2017 | 5 |\n * | | Yo | 44th, 1st, 1900th, 2017th | 5,7 |\n * | | YY | 44, 01, 00, 17 | 5,8 |\n * | | YYY | 044, 001, 1900, 2017 | 5 |\n * | | YYYY | 0044, 0001, 1900, 2017 | 5,8 |\n * | | YYYYY | ... | 3,5 |\n * | ISO week-numbering year | R | -43, 0, 1, 1900, 2017 | 5,7 |\n * | | RR | -43, 00, 01, 1900, 2017 | 5,7 |\n * | | RRR | -043, 000, 001, 1900, 2017 | 5,7 |\n * | | RRRR | -0043, 0000, 0001, 1900, 2017 | 5,7 |\n * | | RRRRR | ... | 3,5,7 |\n * | Extended year | u | -43, 0, 1, 1900, 2017 | 5 |\n * | | uu | -43, 01, 1900, 2017 | 5 |\n * | | uuu | -043, 001, 1900, 2017 | 5 |\n * | | uuuu | -0043, 0001, 1900, 2017 | 5 |\n * | | uuuuu | ... | 3,5 |\n * | Quarter (formatting) | Q | 1, 2, 3, 4 | |\n * | | Qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | QQ | 01, 02, 03, 04 | |\n * | | QQQ | Q1, Q2, Q3, Q4 | |\n * | | QQQQ | 1st quarter, 2nd quarter, ... | 2 |\n * | | QQQQQ | 1, 2, 3, 4 | 4 |\n * | Quarter (stand-alone) | q | 1, 2, 3, 4 | |\n * | | qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | qq | 01, 02, 03, 04 | |\n * | | qqq | Q1, Q2, Q3, Q4 | |\n * | | qqqq | 1st quarter, 2nd quarter, ... | 2 |\n * | | qqqqq | 1, 2, 3, 4 | 4 |\n * | Month (formatting) | M | 1, 2, ..., 12 | |\n * | | Mo | 1st, 2nd, ..., 12th | 7 |\n * | | MM | 01, 02, ..., 12 | |\n * | | MMM | Jan, Feb, ..., Dec | |\n * | | MMMM | January, February, ..., December | 2 |\n * | | MMMMM | J, F, ..., D | |\n * | Month (stand-alone) | L | 1, 2, ..., 12 | |\n * | | Lo | 1st, 2nd, ..., 12th | 7 |\n * | | LL | 01, 02, ..., 12 | |\n * | | LLL | Jan, Feb, ..., Dec | |\n * | | LLLL | January, February, ..., December | 2 |\n * | | LLLLL | J, F, ..., D | |\n * | Local week of year | w | 1, 2, ..., 53 | |\n * | | wo | 1st, 2nd, ..., 53th | 7 |\n * | | ww | 01, 02, ..., 53 | |\n * | ISO week of year | I | 1, 2, ..., 53 | 7 |\n * | | Io | 1st, 2nd, ..., 53th | 7 |\n * | | II | 01, 02, ..., 53 | 7 |\n * | Day of month | d | 1, 2, ..., 31 | |\n * | | do | 1st, 2nd, ..., 31st | 7 |\n * | | dd | 01, 02, ..., 31 | |\n * | Day of year | D | 1, 2, ..., 365, 366 | 9 |\n * | | Do | 1st, 2nd, ..., 365th, 366th | 7 |\n * | | DD | 01, 02, ..., 365, 366 | 9 |\n * | | DDD | 001, 002, ..., 365, 366 | |\n * | | DDDD | ... | 3 |\n * | Day of week (formatting) | E..EEE | Mon, Tue, Wed, ..., Sun | |\n * | | EEEE | Monday, Tuesday, ..., Sunday | 2 |\n * | | EEEEE | M, T, W, T, F, S, S | |\n * | | EEEEEE | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | ISO day of week (formatting) | i | 1, 2, 3, ..., 7 | 7 |\n * | | io | 1st, 2nd, ..., 7th | 7 |\n * | | ii | 01, 02, ..., 07 | 7 |\n * | | iii | Mon, Tue, Wed, ..., Sun | 7 |\n * | | iiii | Monday, Tuesday, ..., Sunday | 2,7 |\n * | | iiiii | M, T, W, T, F, S, S | 7 |\n * | | iiiiii | Mo, Tu, We, Th, Fr, Sa, Su | 7 |\n * | Local day of week (formatting) | e | 2, 3, 4, ..., 1 | |\n * | | eo | 2nd, 3rd, ..., 1st | 7 |\n * | | ee | 02, 03, ..., 01 | |\n * | | eee | Mon, Tue, Wed, ..., Sun | |\n * | | eeee | Monday, Tuesday, ..., Sunday | 2 |\n * | | eeeee | M, T, W, T, F, S, S | |\n * | | eeeeee | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | Local day of week (stand-alone) | c | 2, 3, 4, ..., 1 | |\n * | | co | 2nd, 3rd, ..., 1st | 7 |\n * | | cc | 02, 03, ..., 01 | |\n * | | ccc | Mon, Tue, Wed, ..., Sun | |\n * | | cccc | Monday, Tuesday, ..., Sunday | 2 |\n * | | ccccc | M, T, W, T, F, S, S | |\n * | | cccccc | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | AM, PM | a..aa | AM, PM | |\n * | | aaa | am, pm | |\n * | | aaaa | a.m., p.m. | 2 |\n * | | aaaaa | a, p | |\n * | AM, PM, noon, midnight | b..bb | AM, PM, noon, midnight | |\n * | | bbb | am, pm, noon, midnight | |\n * | | bbbb | a.m., p.m., noon, midnight | 2 |\n * | | bbbbb | a, p, n, mi | |\n * | Flexible day period | B..BBB | at night, in the morning, ... | |\n * | | BBBB | at night, in the morning, ... | 2 |\n * | | BBBBB | at night, in the morning, ... | |\n * | Hour [1-12] | h | 1, 2, ..., 11, 12 | |\n * | | ho | 1st, 2nd, ..., 11th, 12th | 7 |\n * | | hh | 01, 02, ..., 11, 12 | |\n * | Hour [0-23] | H | 0, 1, 2, ..., 23 | |\n * | | Ho | 0th, 1st, 2nd, ..., 23rd | 7 |\n * | | HH | 00, 01, 02, ..., 23 | |\n * | Hour [0-11] | K | 1, 2, ..., 11, 0 | |\n * | | Ko | 1st, 2nd, ..., 11th, 0th | 7 |\n * | | KK | 01, 02, ..., 11, 00 | |\n * | Hour [1-24] | k | 24, 1, 2, ..., 23 | |\n * | | ko | 24th, 1st, 2nd, ..., 23rd | 7 |\n * | | kk | 24, 01, 02, ..., 23 | |\n * | Minute | m | 0, 1, ..., 59 | |\n * | | mo | 0th, 1st, ..., 59th | 7 |\n * | | mm | 00, 01, ..., 59 | |\n * | Second | s | 0, 1, ..., 59 | |\n * | | so | 0th, 1st, ..., 59th | 7 |\n * | | ss | 00, 01, ..., 59 | |\n * | Fraction of second | S | 0, 1, ..., 9 | |\n * | | SS | 00, 01, ..., 99 | |\n * | | SSS | 000, 001, ..., 999 | |\n * | | SSSS | ... | 3 |\n * | Timezone (ISO-8601 w/ Z) | X | -08, +0530, Z | |\n * | | XX | -0800, +0530, Z | |\n * | | XXX | -08:00, +05:30, Z | |\n * | | XXXX | -0800, +0530, Z, +123456 | 2 |\n * | | XXXXX | -08:00, +05:30, Z, +12:34:56 | |\n * | Timezone (ISO-8601 w/o Z) | x | -08, +0530, +00 | |\n * | | xx | -0800, +0530, +0000 | |\n * | | xxx | -08:00, +05:30, +00:00 | 2 |\n * | | xxxx | -0800, +0530, +0000, +123456 | |\n * | | xxxxx | -08:00, +05:30, +00:00, +12:34:56 | |\n * | Timezone (GMT) | O...OOO | GMT-8, GMT+5:30, GMT+0 | |\n * | | OOOO | GMT-08:00, GMT+05:30, GMT+00:00 | 2 |\n * | Timezone (specific non-locat.) | z...zzz | GMT-8, GMT+5:30, GMT+0 | 6 |\n * | | zzzz | GMT-08:00, GMT+05:30, GMT+00:00 | 2,6 |\n * | Seconds timestamp | t | 512969520 | 7 |\n * | | tt | ... | 3,7 |\n * | Milliseconds timestamp | T | 512969520900 | 7 |\n * | | TT | ... | 3,7 |\n * | Long localized date | P | 04/29/1453 | 7 |\n * | | PP | Apr 29, 1453 | 7 |\n * | | PPP | April 29th, 1453 | 7 |\n * | | PPPP | Friday, April 29th, 1453 | 2,7 |\n * | Long localized time | p | 12:00 AM | 7 |\n * | | pp | 12:00:00 AM | 7 |\n * | | ppp | 12:00:00 AM GMT+2 | 7 |\n * | | pppp | 12:00:00 AM GMT+02:00 | 2,7 |\n * | Combination of date and time | Pp | 04/29/1453, 12:00 AM | 7 |\n * | | PPpp | Apr 29, 1453, 12:00:00 AM | 7 |\n * | | PPPppp | April 29th, 1453 at ... | 7 |\n * | | PPPPpppp| Friday, April 29th, 1453 at ... | 2,7 |\n * Notes:\n * 1. \"Formatting\" units (e.g. formatting quarter) in the default en-US locale\n * are the same as \"stand-alone\" units, but are different in some languages.\n * \"Formatting\" units are declined according to the rules of the language\n * in the context of a date. \"Stand-alone\" units are always nominative singular:\n *\n * `format(new Date(2017, 10, 6), 'do LLLL', {locale: cs}) //=> '6. listopad'`\n *\n * `format(new Date(2017, 10, 6), 'do MMMM', {locale: cs}) //=> '6. listopadu'`\n *\n * 2. Any sequence of the identical letters is a pattern, unless it is escaped by\n * the single quote characters (see below).\n * If the sequence is longer than listed in table (e.g. `EEEEEEEEEEE`)\n * the output will be the same as default pattern for this unit, usually\n * the longest one (in case of ISO weekdays, `EEEE`). Default patterns for units\n * are marked with \"2\" in the last column of the table.\n *\n * `format(new Date(2017, 10, 6), 'MMM') //=> 'Nov'`\n *\n * `format(new Date(2017, 10, 6), 'MMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMM') //=> 'N'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMMM') //=> 'November'`\n *\n * 3. Some patterns could be unlimited length (such as `yyyyyyyy`).\n * The output will be padded with zeros to match the length of the pattern.\n *\n * `format(new Date(2017, 10, 6), 'yyyyyyyy') //=> '00002017'`\n *\n * 4. `QQQQQ` and `qqqqq` could be not strictly numerical in some locales.\n * These tokens represent the shortest form of the quarter.\n *\n * 5. The main difference between `y` and `u` patterns are B.C. years:\n *\n * | Year | `y` | `u` |\n * |------|-----|-----|\n * | AC 1 | 1 | 1 |\n * | BC 1 | 1 | 0 |\n * | BC 2 | 2 | -1 |\n *\n * Also `yy` always returns the last two digits of a year,\n * while `uu` pads single digit years to 2 characters and returns other years unchanged:\n *\n * | Year | `yy` | `uu` |\n * |------|------|------|\n * | 1 | 01 | 01 |\n * | 14 | 14 | 14 |\n * | 376 | 76 | 376 |\n * | 1453 | 53 | 1453 |\n *\n * The same difference is true for local and ISO week-numbering years (`Y` and `R`),\n * except local week-numbering years are dependent on `options.weekStartsOn`\n * and `options.firstWeekContainsDate` (compare [getISOWeekYear](https://date-fns.org/docs/getISOWeekYear)\n * and [getWeekYear](https://date-fns.org/docs/getWeekYear)).\n *\n * 6. Specific non-location timezones are currently unavailable in `date-fns`,\n * so right now these tokens fall back to GMT timezones.\n *\n * 7. These patterns are not in the Unicode Technical Standard #35:\n * - `i`: ISO day of week\n * - `I`: ISO week of year\n * - `R`: ISO week-numbering year\n * - `t`: seconds timestamp\n * - `T`: milliseconds timestamp\n * - `o`: ordinal number modifier\n * - `P`: long localized date\n * - `p`: long localized time\n *\n * 8. `YY` and `YYYY` tokens represent week-numbering years but they are often confused with years.\n * You should enable `options.useAdditionalWeekYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * 9. `D` and `DD` tokens represent days of the year but they are often confused with days of the month.\n * You should enable `options.useAdditionalDayOfYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * @param date - The original date\n * @param format - The string of tokens\n * @param options - An object with options\n *\n * @returns The formatted date string\n *\n * @throws `date` must not be Invalid Date\n * @throws `options.locale` must contain `localize` property\n * @throws `options.locale` must contain `formatLong` property\n * @throws use `yyyy` instead of `YYYY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `yy` instead of `YY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `d` instead of `D` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `dd` instead of `DD` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws format string contains an unescaped latin alphabet character\n *\n * @example\n * // Represent 11 February 2014 in middle-endian format:\n * const result = format(new Date(2014, 1, 11), 'MM/dd/yyyy')\n * //=> '02/11/2014'\n *\n * @example\n * // Represent 2 July 2014 in Esperanto:\n * import { eoLocale } from 'date-fns/locale/eo'\n * const result = format(new Date(2014, 6, 2), \"do 'de' MMMM yyyy\", {\n * locale: eoLocale\n * })\n * //=> '2-a de julio 2014'\n *\n * @example\n * // Escape string by single quote characters:\n * const result = format(new Date(2014, 6, 2, 15), \"h 'o''clock'\")\n * //=> \"3 o'clock\"\n */\nexport function format(date, formatStr, options) {\n const defaultOptions = getDefaultOptions();\n const locale = options?.locale ?? defaultOptions.locale ?? defaultLocale;\n\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const originalDate = toDate(date, options?.in);\n\n if (!isValid(originalDate)) {\n throw new RangeError(\"Invalid time value\");\n }\n\n let parts = formatStr\n .match(longFormattingTokensRegExp)\n .map((substring) => {\n const firstCharacter = substring[0];\n if (firstCharacter === \"p\" || firstCharacter === \"P\") {\n const longFormatter = longFormatters[firstCharacter];\n return longFormatter(substring, locale.formatLong);\n }\n return substring;\n })\n .join(\"\")\n .match(formattingTokensRegExp)\n .map((substring) => {\n // Replace two single quote characters with one single quote character\n if (substring === \"''\") {\n return { isToken: false, value: \"'\" };\n }\n\n const firstCharacter = substring[0];\n if (firstCharacter === \"'\") {\n return { isToken: false, value: cleanEscapedString(substring) };\n }\n\n if (formatters[firstCharacter]) {\n return { isToken: true, value: substring };\n }\n\n if (firstCharacter.match(unescapedLatinCharacterRegExp)) {\n throw new RangeError(\n \"Format string contains an unescaped latin alphabet character `\" +\n firstCharacter +\n \"`\",\n );\n }\n\n return { isToken: false, value: substring };\n });\n\n // invoke localize preprocessor (only for french locales at the moment)\n if (locale.localize.preprocessor) {\n parts = locale.localize.preprocessor(originalDate, parts);\n }\n\n const formatterOptions = {\n firstWeekContainsDate,\n weekStartsOn,\n locale,\n };\n\n return parts\n .map((part) => {\n if (!part.isToken) return part.value;\n\n const token = part.value;\n\n if (\n (!options?.useAdditionalWeekYearTokens &&\n isProtectedWeekYearToken(token)) ||\n (!options?.useAdditionalDayOfYearTokens &&\n isProtectedDayOfYearToken(token))\n ) {\n warnOrThrowProtectedError(token, formatStr, String(date));\n }\n\n const formatter = formatters[token[0]];\n return formatter(originalDate, token, locale.localize, formatterOptions);\n })\n .join(\"\");\n}\n\nfunction cleanEscapedString(input) {\n const matched = input.match(escapedStringRegExp);\n\n if (!matched) {\n return input;\n }\n\n return matched[1].replace(doubleQuoteRegExp, \"'\");\n}\n\n// Fallback for modularized imports:\nexport default format;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getDaysInMonth} function options.\n */\n\n/**\n * @name getDaysInMonth\n * @category Month Helpers\n * @summary Get the number of days in a month of the given date.\n *\n * @description\n * Get the number of days in a month of the given date, considering the context if provided.\n *\n * @param date - The given date\n * @param options - An object with options\n *\n * @returns The number of days in a month\n *\n * @example\n * // How many days are in February 2000?\n * const result = getDaysInMonth(new Date(2000, 1))\n * //=> 29\n */\nexport function getDaysInMonth(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n const monthIndex = _date.getMonth();\n const lastDayOfMonth = constructFrom(_date, 0);\n lastDayOfMonth.setFullYear(year, monthIndex + 1, 0);\n lastDayOfMonth.setHours(0, 0, 0, 0);\n return lastDayOfMonth.getDate();\n}\n\n// Fallback for modularized imports:\nexport default getDaysInMonth;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * @name isAfter\n * @category Common Helpers\n * @summary Is the first date after the second one?\n *\n * @description\n * Is the first date after the second one?\n *\n * @param date - The date that should be after the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is after the second date\n *\n * @example\n * // Is 10 July 1989 after 11 February 1987?\n * const result = isAfter(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> true\n */\nexport function isAfter(date, dateToCompare) {\n return +toDate(date) > +toDate(dateToCompare);\n}\n\n// Fallback for modularized imports:\nexport default isAfter;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * @name isBefore\n * @category Common Helpers\n * @summary Is the first date before the second one?\n *\n * @description\n * Is the first date before the second one?\n *\n * @param date - The date that should be before the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is before the second date\n *\n * @example\n * // Is 10 July 1989 before 11 February 1987?\n * const result = isBefore(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> false\n */\nexport function isBefore(date, dateToCompare) {\n return +toDate(date) < +toDate(dateToCompare);\n}\n\n// Fallback for modularized imports:\nexport default isBefore;\n","import { normalizeDates } from \"./_lib/normalizeDates.js\";\n\n/**\n * The {@link isSameMonth} function options.\n */\n\n/**\n * @name isSameMonth\n * @category Month Helpers\n * @summary Are the given dates in the same month (and year)?\n *\n * @description\n * Are the given dates in the same month (and year)?\n *\n * @param laterDate - The first date to check\n * @param earlierDate - The second date to check\n * @param options - An object with options\n *\n * @returns The dates are in the same month (and year)\n *\n * @example\n * // Are 2 September 2014 and 25 September 2014 in the same month?\n * const result = isSameMonth(new Date(2014, 8, 2), new Date(2014, 8, 25))\n * //=> true\n *\n * @example\n * // Are 2 September 2014 and 25 September 2015 in the same month?\n * const result = isSameMonth(new Date(2014, 8, 2), new Date(2015, 8, 25))\n * //=> false\n */\nexport function isSameMonth(laterDate, earlierDate, options) {\n const [laterDate_, earlierDate_] = normalizeDates(\n options?.in,\n laterDate,\n earlierDate,\n );\n return (\n laterDate_.getFullYear() === earlierDate_.getFullYear() &&\n laterDate_.getMonth() === earlierDate_.getMonth()\n );\n}\n\n// Fallback for modularized imports:\nexport default isSameMonth;\n","import { normalizeDates } from \"./_lib/normalizeDates.js\";\n\n/**\n * The {@link isSameYear} function options.\n */\n\n/**\n * @name isSameYear\n * @category Year Helpers\n * @summary Are the given dates in the same year?\n *\n * @description\n * Are the given dates in the same year?\n *\n * @param laterDate - The first date to check\n * @param earlierDate - The second date to check\n * @param options - An object with options\n *\n * @returns The dates are in the same year\n *\n * @example\n * // Are 2 September 2014 and 25 September 2014 in the same year?\n * const result = isSameYear(new Date(2014, 8, 2), new Date(2014, 8, 25))\n * //=> true\n */\nexport function isSameYear(laterDate, earlierDate, options) {\n const [laterDate_, earlierDate_] = normalizeDates(\n options?.in,\n laterDate,\n earlierDate,\n );\n return laterDate_.getFullYear() === earlierDate_.getFullYear();\n}\n\n// Fallback for modularized imports:\nexport default isSameYear;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { getDaysInMonth } from \"./getDaysInMonth.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link setMonth} function options.\n */\n\n/**\n * @name setMonth\n * @category Month Helpers\n * @summary Set the month to the given date.\n *\n * @description\n * Set the month to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The date to be changed\n * @param month - The month index to set (0-11)\n * @param options - The options\n *\n * @returns The new date with the month set\n *\n * @example\n * // Set February to 1 September 2014:\n * const result = setMonth(new Date(2014, 8, 1), 1)\n * //=> Sat Feb 01 2014 00:00:00\n */\nexport function setMonth(date, month, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n const day = _date.getDate();\n\n const midMonth = constructFrom(options?.in || date, 0);\n midMonth.setFullYear(year, month, 15);\n midMonth.setHours(0, 0, 0, 0);\n const daysInMonth = getDaysInMonth(midMonth);\n\n // Set the earlier date, allows to wrap Jan 31 to Feb 28\n _date.setMonth(month, Math.min(day, daysInMonth));\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setMonth;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link setYear} function options.\n */\n\n/**\n * @name setYear\n * @category Year Helpers\n * @summary Set the year to the given date.\n *\n * @description\n * Set the year to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The date to be changed\n * @param year - The year of the new date\n * @param options - An object with options.\n *\n * @returns The new date with the year set\n *\n * @example\n * // Set year 2013 to 1 September 2014:\n * const result = setYear(new Date(2014, 8, 1), 2013)\n * //=> Sun Sep 01 2013 00:00:00\n */\nexport function setYear(date, year, options) {\n const date_ = toDate(date, options?.in);\n\n // Check if date is Invalid Date because Date.prototype.setFullYear ignores the value of Invalid Date\n if (isNaN(+date_)) return constructFrom(options?.in || date, NaN);\n\n date_.setFullYear(year);\n return date_;\n}\n\n// Fallback for modularized imports:\nexport default setYear;\n","const FIVE_WEEKS = 5;\nconst FOUR_WEEKS = 4;\n/**\n * Return the number of weeks to display in the broadcast calendar.\n *\n * @since 9.4.0\n */\nexport function getBroadcastWeeksInMonth(month, dateLib) {\n // Get the first day of the month\n const firstDayOfMonth = dateLib.startOfMonth(month);\n // Get the day of the week for the first day of the month (1-7, where 1 is Monday)\n const firstDayOfWeek = firstDayOfMonth.getDay() > 0 ? firstDayOfMonth.getDay() : 7;\n const broadcastStartDate = dateLib.addDays(month, -firstDayOfWeek + 1);\n const lastDateOfLastWeek = dateLib.addDays(broadcastStartDate, FIVE_WEEKS * 7 - 1);\n const numberOfWeeks = month.getMonth() === lastDateOfLastWeek.getMonth()\n ? FIVE_WEEKS\n : FOUR_WEEKS;\n return numberOfWeeks;\n}\n//# sourceMappingURL=getBroadcastWeeksInMonth.js.map","/**\n * Return the start date of the week in the broadcast calendar.\n *\n * @since 9.4.0\n */\nexport function startOfBroadcastWeek(date, dateLib) {\n const firstOfMonth = dateLib.startOfMonth(date);\n const dayOfWeek = firstOfMonth.getDay();\n if (dayOfWeek === 1) {\n return firstOfMonth;\n }\n else if (dayOfWeek === 0) {\n return dateLib.addDays(firstOfMonth, -1 * 6);\n }\n else {\n return dateLib.addDays(firstOfMonth, -1 * (dayOfWeek - 1));\n }\n}\n//# sourceMappingURL=startOfBroadcastWeek.js.map","import { getBroadcastWeeksInMonth } from \"./getBroadcastWeeksInMonth.js\";\nimport { startOfBroadcastWeek } from \"./startOfBroadcastWeek.js\";\n/**\n * Return the end date of the week in the broadcast calendar.\n *\n * @since 9.4.0\n */\nexport function endOfBroadcastWeek(date, dateLib) {\n const startDate = startOfBroadcastWeek(date, dateLib);\n const numberOfWeeks = getBroadcastWeeksInMonth(date, dateLib);\n const endDate = dateLib.addDays(startDate, numberOfWeeks * 7 - 1);\n return endDate;\n}\n//# sourceMappingURL=endOfBroadcastWeek.js.map","import { addDays, addMonths, addWeeks, addYears, differenceInCalendarDays, differenceInCalendarMonths, endOfISOWeek, endOfMonth, endOfWeek, endOfYear, format, getISOWeek, getWeek, isAfter, isBefore, isDate, isSameDay, isSameMonth, isSameYear, max, min, setMonth, setYear, startOfDay, startOfISOWeek, startOfMonth, startOfWeek, startOfYear } from \"date-fns\";\nimport { enUS } from \"date-fns/locale\";\nimport { endOfBroadcastWeek } from \"../helpers/endOfBroadcastWeek.js\";\nimport { startOfBroadcastWeek } from \"../helpers/startOfBroadcastWeek.js\";\n/**\n * A wrapper class around [date-fns](http://date-fns.org) sharing the same\n * options. Methods of this class can be overridden using the\n * {@link PropsBase.dateLib} prop.\n *\n * @since 9.2.0\n * @example\n * const dateLib = new DateLib({ locale: es });\n * const newDate = dateLib.addDays(new Date(), 5);\n */\nexport class DateLib {\n /**\n * Creates an instance of DateLib.\n *\n * @param options The options for the date library.\n * @param overrides Overrides for the date library functions.\n */\n constructor(options, overrides) {\n /** Reference to the built-in Date constructor. */\n this.Date = Date;\n /**\n * Adds the specified number of days to the given date.\n *\n * @param date The date to add days to.\n * @param amount The number of days to add.\n * @returns The new date with the days added.\n */\n this.addDays = (date, amount) => {\n return this.overrides?.addDays\n ? this.overrides.addDays(date, amount)\n : addDays(date, amount);\n };\n /**\n * Adds the specified number of months to the given date.\n *\n * @param date The date to add months to.\n * @param amount The number of months to add.\n * @returns The new date with the months added.\n */\n this.addMonths = (date, amount) => {\n return this.overrides?.addMonths\n ? this.overrides.addMonths(date, amount)\n : addMonths(date, amount);\n };\n /**\n * Adds the specified number of weeks to the given date.\n *\n * @param date The date to add weeks to.\n * @param amount The number of weeks to add.\n * @returns The new date with the weeks added.\n */\n this.addWeeks = (date, amount) => {\n return this.overrides?.addWeeks\n ? this.overrides.addWeeks(date, amount)\n : addWeeks(date, amount);\n };\n /**\n * Adds the specified number of years to the given date.\n *\n * @param date The date to add years to.\n * @param amount The number of years to add.\n * @returns The new date with the years added.\n */\n this.addYears = (date, amount) => {\n return this.overrides?.addYears\n ? this.overrides.addYears(date, amount)\n : addYears(date, amount);\n };\n /**\n * Returns the number of calendar days between the given dates.\n *\n * @param dateLeft The later date.\n * @param dateRight The earlier date.\n * @returns The number of calendar days between the dates.\n */\n this.differenceInCalendarDays = (dateLeft, dateRight) => {\n return this.overrides?.differenceInCalendarDays\n ? this.overrides.differenceInCalendarDays(dateLeft, dateRight)\n : differenceInCalendarDays(dateLeft, dateRight);\n };\n /**\n * Returns the number of calendar months between the given dates.\n *\n * @param dateLeft The later date.\n * @param dateRight The earlier date.\n * @returns The number of calendar months between the dates.\n */\n this.differenceInCalendarMonths = (dateLeft, dateRight) => {\n return this.overrides?.differenceInCalendarMonths\n ? this.overrides.differenceInCalendarMonths(dateLeft, dateRight)\n : differenceInCalendarMonths(dateLeft, dateRight);\n };\n /**\n * Returns the end of the broadcast week for the given date.\n *\n * @param date The original date.\n * @returns The end of the broadcast week.\n */\n this.endOfBroadcastWeek = (date) => {\n return this.overrides?.endOfBroadcastWeek\n ? this.overrides.endOfBroadcastWeek(date, this)\n : endOfBroadcastWeek(date, this);\n };\n /**\n * Returns the end of the ISO week for the given date.\n *\n * @param date The original date.\n * @returns The end of the ISO week.\n */\n this.endOfISOWeek = (date) => {\n return this.overrides?.endOfISOWeek\n ? this.overrides.endOfISOWeek(date)\n : endOfISOWeek(date);\n };\n /**\n * Returns the end of the month for the given date.\n *\n * @param date The original date.\n * @returns The end of the month.\n */\n this.endOfMonth = (date) => {\n return this.overrides?.endOfMonth\n ? this.overrides.endOfMonth(date)\n : endOfMonth(date);\n };\n /**\n * Returns the end of the week for the given date.\n *\n * @param date The original date.\n * @returns The end of the week.\n */\n this.endOfWeek = (date) => {\n return this.overrides?.endOfWeek\n ? this.overrides.endOfWeek(date, this.options)\n : endOfWeek(date, this.options);\n };\n /**\n * Returns the end of the year for the given date.\n *\n * @param date The original date.\n * @returns The end of the year.\n */\n this.endOfYear = (date) => {\n return this.overrides?.endOfYear\n ? this.overrides.endOfYear(date)\n : endOfYear(date);\n };\n /**\n * Formats the given date using the specified format string.\n *\n * @param date The date to format.\n * @param formatStr The format string.\n * @returns The formatted date string.\n */\n this.format = (date, formatStr) => {\n return this.overrides?.format\n ? this.overrides.format(date, formatStr, this.options)\n : format(date, formatStr, this.options);\n };\n /**\n * Returns the ISO week number for the given date.\n *\n * @param date The date to get the ISO week number for.\n * @returns The ISO week number.\n */\n this.getISOWeek = (date) => {\n return this.overrides?.getISOWeek\n ? this.overrides.getISOWeek(date)\n : getISOWeek(date);\n };\n /**\n * Returns the local week number for the given date.\n *\n * @param date The date to get the week number for.\n * @returns The week number.\n */\n this.getWeek = (date) => {\n return this.overrides?.getWeek\n ? this.overrides.getWeek(date, this.options)\n : getWeek(date, this.options);\n };\n /**\n * Checks if the first date is after the second date.\n *\n * @param date The date to compare.\n * @param dateToCompare The date to compare with.\n * @returns True if the first date is after the second date.\n */\n this.isAfter = (date, dateToCompare) => {\n return this.overrides?.isAfter\n ? this.overrides.isAfter(date, dateToCompare)\n : isAfter(date, dateToCompare);\n };\n /**\n * Checks if the first date is before the second date.\n *\n * @param date The date to compare.\n * @param dateToCompare The date to compare with.\n * @returns True if the first date is before the second date.\n */\n this.isBefore = (date, dateToCompare) => {\n return this.overrides?.isBefore\n ? this.overrides.isBefore(date, dateToCompare)\n : isBefore(date, dateToCompare);\n };\n /**\n * Checks if the given value is a Date object.\n *\n * @param value The value to check.\n * @returns True if the value is a Date object.\n */\n this.isDate = (value) => {\n return this.overrides?.isDate\n ? this.overrides.isDate(value)\n : isDate(value);\n };\n /**\n * Checks if the given dates are on the same day.\n *\n * @param dateLeft The first date to compare.\n * @param dateRight The second date to compare.\n * @returns True if the dates are on the same day.\n */\n this.isSameDay = (dateLeft, dateRight) => {\n return this.overrides?.isSameDay\n ? this.overrides.isSameDay(dateLeft, dateRight)\n : isSameDay(dateLeft, dateRight);\n };\n /**\n * Checks if the given dates are in the same month.\n *\n * @param dateLeft The first date to compare.\n * @param dateRight The second date to compare.\n * @returns True if the dates are in the same month.\n */\n this.isSameMonth = (dateLeft, dateRight) => {\n return this.overrides?.isSameMonth\n ? this.overrides.isSameMonth(dateLeft, dateRight)\n : isSameMonth(dateLeft, dateRight);\n };\n /**\n * Checks if the given dates are in the same year.\n *\n * @param dateLeft The first date to compare.\n * @param dateRight The second date to compare.\n * @returns True if the dates are in the same year.\n */\n this.isSameYear = (dateLeft, dateRight) => {\n return this.overrides?.isSameYear\n ? this.overrides.isSameYear(dateLeft, dateRight)\n : isSameYear(dateLeft, dateRight);\n };\n /**\n * Returns the latest date in the given array of dates.\n *\n * @param dates The array of dates to compare.\n * @returns The latest date.\n */\n this.max = (dates) => {\n return this.overrides?.max ? this.overrides.max(dates) : max(dates);\n };\n /**\n * Returns the earliest date in the given array of dates.\n *\n * @param dates The array of dates to compare.\n * @returns The earliest date.\n */\n this.min = (dates) => {\n return this.overrides?.min ? this.overrides.min(dates) : min(dates);\n };\n /**\n * Sets the month of the given date.\n *\n * @param date The date to set the month on.\n * @param month The month to set (0-11).\n * @returns The new date with the month set.\n */\n this.setMonth = (date, month) => {\n return this.overrides?.setMonth\n ? this.overrides.setMonth(date, month)\n : setMonth(date, month);\n };\n /**\n * Sets the year of the given date.\n *\n * @param date The date to set the year on.\n * @param year The year to set.\n * @returns The new date with the year set.\n */\n this.setYear = (date, year) => {\n return this.overrides?.setYear\n ? this.overrides.setYear(date, year)\n : setYear(date, year);\n };\n /**\n * Returns the start of the broadcast week for the given date.\n *\n * @param date The original date.\n * @returns The start of the broadcast week.\n */\n this.startOfBroadcastWeek = (date) => {\n return this.overrides?.startOfBroadcastWeek\n ? this.overrides.startOfBroadcastWeek(date, this)\n : startOfBroadcastWeek(date, this);\n };\n /**\n * Returns the start of the day for the given date.\n *\n * @param date The original date.\n * @returns The start of the day.\n */\n this.startOfDay = (date) => {\n return this.overrides?.startOfDay\n ? this.overrides.startOfDay(date)\n : startOfDay(date);\n };\n /**\n * Returns the start of the ISO week for the given date.\n *\n * @param date The original date.\n * @returns The start of the ISO week.\n */\n this.startOfISOWeek = (date) => {\n return this.overrides?.startOfISOWeek\n ? this.overrides.startOfISOWeek(date)\n : startOfISOWeek(date);\n };\n /**\n * Returns the start of the month for the given date.\n *\n * @param date The original date.\n * @returns The start of the month.\n */\n this.startOfMonth = (date) => {\n return this.overrides?.startOfMonth\n ? this.overrides.startOfMonth(date)\n : startOfMonth(date);\n };\n /**\n * Returns the start of the week for the given date.\n *\n * @param date The original date.\n * @returns The start of the week.\n */\n this.startOfWeek = (date) => {\n return this.overrides?.startOfWeek\n ? this.overrides.startOfWeek(date, this.options)\n : startOfWeek(date, this.options);\n };\n /**\n * Returns the start of the year for the given date.\n *\n * @param date The original date.\n * @returns The start of the year.\n */\n this.startOfYear = (date) => {\n return this.overrides?.startOfYear\n ? this.overrides.startOfYear(date)\n : startOfYear(date);\n };\n this.options = { locale: enUS, ...options };\n this.overrides = overrides;\n }\n}\n/** The default locale (English). */\nexport { enUS as defaultLocale } from \"date-fns/locale/en-US\";\n/**\n * The default date library with English locale.\n *\n * @since 9.2.0\n */\nexport const defaultDateLib = new DateLib();\n/** @deprecated Use `defaultDateLib`. */\nexport const dateLib = defaultDateLib;\n//# sourceMappingURL=DateLib.js.map","import { DayFlag, SelectionState, UI } from \"../UI.js\";\nexport function getClassNamesForModifiers(modifiers, classNames, modifiersClassNames = {}) {\n const modifierClassNames = Object.entries(modifiers)\n .filter(([, active]) => active === true)\n .reduce((previousValue, [key]) => {\n if (modifiersClassNames[key]) {\n previousValue.push(modifiersClassNames[key]);\n }\n else if (classNames[DayFlag[key]]) {\n previousValue.push(classNames[DayFlag[key]]);\n }\n else if (classNames[SelectionState[key]]) {\n previousValue.push(classNames[SelectionState[key]]);\n }\n return previousValue;\n }, [classNames[UI.Day]]);\n return modifierClassNames;\n}\n//# sourceMappingURL=getClassNamesForModifiers.js.map","import React from \"react\";\n/**\n * Render the button elements in the calendar.\n *\n * @private\n * @deprecated Use `PreviousMonthButton` or `@link NextMonthButton` instead.\n */\nexport function Button(props) {\n return React.createElement(\"button\", { ...props });\n}\n//# sourceMappingURL=Button.js.map","import React from \"react\";\n/**\n * Render the label in the month caption.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function CaptionLabel(props) {\n return React.createElement(\"span\", { ...props });\n}\n//# sourceMappingURL=CaptionLabel.js.map","import React from \"react\";\n/**\n * Render the chevron icon used in the navigation buttons and dropdowns.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Chevron(props) {\n const { size = 24, orientation = \"left\", className } = props;\n return (React.createElement(\"svg\", { className: className, width: size, height: size, viewBox: \"0 0 24 24\" },\n orientation === \"up\" && (React.createElement(\"polygon\", { points: \"6.77 17 12.5 11.43 18.24 17 20 15.28 12.5 8 5 15.28\" })),\n orientation === \"down\" && (React.createElement(\"polygon\", { points: \"6.77 8 12.5 13.57 18.24 8 20 9.72 12.5 17 5 9.72\" })),\n orientation === \"left\" && (React.createElement(\"polygon\", { points: \"16 18.112 9.81111111 12 16 5.87733333 14.0888889 4 6 12 14.0888889 20\" })),\n orientation === \"right\" && (React.createElement(\"polygon\", { points: \"8 18.612 14.1888889 12.5 8 6.37733333 9.91111111 4.5 18 12.5 9.91111111 20.5\" }))));\n}\n//# sourceMappingURL=Chevron.js.map","import React from \"react\";\n/**\n * Render the gridcell of a day in the calendar and handle the interaction and\n * the focus with they day.\n *\n * If you need to just change the content of the day cell, consider swapping the\n * `DayDate` component instead.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Day(props) {\n const { day, modifiers, ...tdProps } = props;\n return React.createElement(\"td\", { ...tdProps });\n}\n//# sourceMappingURL=Day.js.map","import React from \"react\";\n/**\n * Render the button for a day in the calendar.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function DayButton(props) {\n const { day, modifiers, ...buttonProps } = props;\n const ref = React.useRef(null);\n React.useEffect(() => {\n if (modifiers.focused)\n ref.current?.focus();\n }, [modifiers.focused]);\n return React.createElement(\"button\", { ref: ref, ...buttonProps });\n}\n//# sourceMappingURL=DayButton.js.map","import React from \"react\";\nimport { UI } from \"../UI.js\";\n/**\n * Render a dropdown component to use in the navigation bar.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Dropdown(props) {\n const { options, className, components, classNames, ...selectProps } = props;\n const cssClassSelect = [classNames[UI.Dropdown], className].join(\" \");\n const selectedOption = options?.find(({ value }) => value === selectProps.value);\n return (React.createElement(\"span\", { \"data-disabled\": selectProps.disabled, className: classNames[UI.DropdownRoot] },\n React.createElement(components.Select, { className: cssClassSelect, ...selectProps }, options?.map(({ value, label, disabled }) => (React.createElement(components.Option, { key: value, value: value, disabled: disabled }, label)))),\n React.createElement(\"span\", { className: classNames[UI.CaptionLabel], \"aria-hidden\": true },\n selectedOption?.label,\n React.createElement(components.Chevron, { orientation: \"down\", size: 18, className: classNames[UI.Chevron] }))));\n}\n//# sourceMappingURL=Dropdown.js.map","import React from \"react\";\n/**\n * Render the the navigation dropdowns.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function DropdownNav(props) {\n return React.createElement(\"div\", { ...props });\n}\n//# sourceMappingURL=DropdownNav.js.map","import React from \"react\";\n/**\n * Component wrapping the footer.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Footer(props) {\n return React.createElement(\"div\", { ...props });\n}\n//# sourceMappingURL=Footer.js.map","import React from \"react\";\n/**\n * Render the grid with the weekday header row and the weeks for the given\n * month.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Month(props) {\n const { calendarMonth, displayIndex, ...divProps } = props;\n return React.createElement(\"div\", { ...divProps }, props.children);\n}\n//# sourceMappingURL=Month.js.map","import React from \"react\";\n/**\n * Render the caption of a month in the calendar.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function MonthCaption(props) {\n const { calendarMonth, displayIndex, ...divProps } = props;\n return React.createElement(\"div\", { ...divProps });\n}\n//# sourceMappingURL=MonthCaption.js.map","import React from \"react\";\n/**\n * Render the grid of days in a month.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function MonthGrid(props) {\n return React.createElement(\"table\", { ...props });\n}\n//# sourceMappingURL=MonthGrid.js.map","import React from \"react\";\n/**\n * Component wrapping the month grids.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Months(props) {\n return React.createElement(\"div\", { ...props });\n}\n//# sourceMappingURL=Months.js.map","import { createContext, useContext } from \"react\";\n/** @ignore */\nexport const dayPickerContext = createContext(undefined);\n/**\n * Returns the context to work with `` inside custom components.\n *\n * This hook provides access to the DayPicker context, which includes various\n * properties and methods to interact with the DayPicker component. It must be\n * used within a custom component.\n *\n * @template T - Use this type to refine the returned context type with a\n * specific selection mode.\n * @returns {DayPickerContext} The context to work with DayPicker.\n * @throws {Error} If the hook is used outside of a DayPicker provider.\n * @group Hooks\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function useDayPicker() {\n const context = useContext(dayPickerContext);\n if (context === undefined) {\n throw new Error(\"useDayPicker() must be used within a custom component.\");\n }\n return context;\n}\n//# sourceMappingURL=useDayPicker.js.map","import React from \"react\";\nimport { useDayPicker } from \"../useDayPicker.js\";\n/**\n * Render the dropdown to navigate between months.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function MonthsDropdown(props) {\n const { components } = useDayPicker();\n return React.createElement(components.Dropdown, { ...props });\n}\n//# sourceMappingURL=MonthsDropdown.js.map","import React from \"react\";\nimport { UI } from \"../UI.js\";\nimport { useDayPicker } from \"../useDayPicker.js\";\n/**\n * Render the toolbar with the navigation button.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Nav(props) {\n const { onPreviousClick, onNextClick, previousMonth, nextMonth, ...navProps } = props;\n const { components, classNames, labels: { labelPrevious, labelNext } } = useDayPicker();\n return (React.createElement(\"nav\", { ...navProps },\n React.createElement(components.PreviousMonthButton, { type: \"button\", className: classNames[UI.PreviousMonthButton], tabIndex: previousMonth ? undefined : -1, disabled: previousMonth ? undefined : true, \"aria-label\": labelPrevious(previousMonth), onClick: props.onPreviousClick },\n React.createElement(components.Chevron, { disabled: previousMonth ? undefined : true, className: classNames[UI.Chevron], orientation: \"left\" })),\n React.createElement(components.NextMonthButton, { type: \"button\", className: classNames[UI.NextMonthButton], tabIndex: nextMonth ? undefined : -1, disabled: nextMonth ? undefined : true, \"aria-label\": labelNext(nextMonth), onClick: props.onNextClick },\n React.createElement(components.Chevron, { disabled: nextMonth ? undefined : true, orientation: \"right\", className: classNames[UI.Chevron] }))));\n}\n//# sourceMappingURL=Nav.js.map","import React from \"react\";\nimport { useDayPicker } from \"../useDayPicker.js\";\n/**\n * Render the next month button element in the calendar.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function NextMonthButton(props) {\n const { components } = useDayPicker();\n return React.createElement(components.Button, { ...props });\n}\n//# sourceMappingURL=NextMonthButton.js.map","import React from \"react\";\n/**\n * Render the `option` element.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Option(props) {\n return React.createElement(\"option\", { ...props });\n}\n//# sourceMappingURL=Option.js.map","import React from \"react\";\nimport { useDayPicker } from \"../useDayPicker.js\";\n/**\n * Render the previous month button element in the calendar.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function PreviousMonthButton(props) {\n const { components } = useDayPicker();\n return React.createElement(components.Button, { ...props });\n}\n//# sourceMappingURL=PreviousMonthButton.js.map","import React from \"react\";\n/**\n * Render the root element.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Root(props) {\n return React.createElement(\"div\", { ...props });\n}\n//# sourceMappingURL=Root.js.map","import React from \"react\";\n/**\n * Render the `select` element.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Select(props) {\n return React.createElement(\"select\", { ...props });\n}\n//# sourceMappingURL=Select.js.map","import React from \"react\";\n/**\n * Render a row in the calendar, with the days and the week number.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Week(props) {\n const { week, ...trProps } = props;\n return React.createElement(\"tr\", { ...trProps });\n}\n//# sourceMappingURL=Week.js.map","import React from \"react\";\n/**\n * Render the column header with the weekday name (e.g. \"Mo\", \"Tu\", etc.).\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Weekday(props) {\n return React.createElement(\"th\", { ...props });\n}\n//# sourceMappingURL=Weekday.js.map","import React from \"react\";\n/**\n * Render the row with the weekday names.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Weekdays(props) {\n return (React.createElement(\"thead\", { \"aria-hidden\": true },\n React.createElement(\"tr\", { ...props })));\n}\n//# sourceMappingURL=Weekdays.js.map","import React from \"react\";\n/**\n * Render the cell with the number of the week.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function WeekNumber(props) {\n const { week, ...thProps } = props;\n return React.createElement(\"th\", { ...thProps });\n}\n//# sourceMappingURL=WeekNumber.js.map","import React from \"react\";\n/**\n * Render the column header for the week numbers.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function WeekNumberHeader(props) {\n return React.createElement(\"th\", { ...props });\n}\n//# sourceMappingURL=WeekNumberHeader.js.map","import React from \"react\";\n/**\n * Render the weeks in the month grid.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function Weeks(props) {\n return React.createElement(\"tbody\", { ...props });\n}\n//# sourceMappingURL=Weeks.js.map","import React from \"react\";\nimport { useDayPicker } from \"../useDayPicker.js\";\n/**\n * Render the dropdown to navigate between years.\n *\n * @group Components\n * @see https://daypicker.dev/guides/custom-components\n */\nexport function YearsDropdown(props) {\n const { components } = useDayPicker();\n return React.createElement(components.Dropdown, { ...props });\n}\n//# sourceMappingURL=YearsDropdown.js.map","import * as components from \"../components/custom-components.js\";\nexport function getComponents(customComponents) {\n return {\n ...components,\n ...customComponents\n };\n}\n//# sourceMappingURL=getComponents.js.map","/** Return the `data-` attributes from the props. */\nexport function getDataAttributes(props) {\n const dataAttributes = {\n \"data-mode\": props.mode ?? undefined,\n \"data-required\": \"required\" in props ? props.required : undefined,\n \"data-multiple-months\": (props.numberOfMonths && props.numberOfMonths > 1) || undefined,\n \"data-week-numbers\": props.showWeekNumber || undefined,\n \"data-broadcast-calendar\": props.broadcastCalendar || undefined\n };\n Object.entries(props).forEach(([key, val]) => {\n if (key.startsWith(\"data-\")) {\n dataAttributes[key] = val;\n }\n });\n return dataAttributes;\n}\n//# sourceMappingURL=getDataAttributes.js.map","import { UI, DayFlag, SelectionState } from \"../UI.js\";\n/**\n * Get the default class names for the UI elements.\n *\n * @group Utilities\n */\nexport function getDefaultClassNames() {\n const classNames = {};\n for (const key in UI) {\n classNames[UI[key]] =\n `rdp-${UI[key]}`;\n }\n for (const key in DayFlag) {\n classNames[DayFlag[key]] =\n `rdp-${DayFlag[key]}`;\n }\n for (const key in SelectionState) {\n classNames[SelectionState[key]] =\n `rdp-${SelectionState[key]}`;\n }\n return classNames;\n}\n//# sourceMappingURL=getDefaultClassNames.js.map","import { DateLib } from \"../classes/DateLib.js\";\n/**\n * Format the caption of the month.\n *\n * @defaultValue `LLLL y` (e.g. \"November 2022\")\n * @group Formatters\n * @see https://daypicker.dev/docs/translation#custom-formatters\n */\nexport function formatCaption(month, options, dateLib) {\n return (dateLib ?? new DateLib(options)).format(month, \"LLLL y\");\n}\n/**\n * @private\n * @deprecated Use {@link formatCaption} instead.\n * @group Formatters\n */\nexport const formatMonthCaption = formatCaption;\n//# sourceMappingURL=formatCaption.js.map","import { DateLib } from \"../classes/DateLib.js\";\n/**\n * Format the day date shown in the day cell.\n *\n * @defaultValue `d` (e.g. \"1\")\n * @group Formatters\n * @see https://daypicker.dev/docs/translation#custom-formatters\n */\nexport function formatDay(date, options, dateLib) {\n return (dateLib ?? new DateLib(options)).format(date, \"d\");\n}\n//# sourceMappingURL=formatDay.js.map","/**\n * Format the month number for the dropdown option label.\n *\n * @defaultValue The localized month name\n * @group Formatters\n * @see https://daypicker.dev/docs/translation#custom-formatters\n */\nexport function formatMonthDropdown(\n/** The month number to format. */\nmonthNumber, \n/** The locale to use for formatting. */\nlocale) {\n return locale.localize?.month(monthNumber);\n}\n//# sourceMappingURL=formatMonthDropdown.js.map","/**\n * Format the week number.\n *\n * @defaultValue `weekNumber.toLocaleString()` with a leading zero for single-digit numbers\n * @group Formatters\n * @see https://daypicker.dev/docs/translation#custom-formatters\n */\nexport function formatWeekNumber(weekNumber) {\n if (weekNumber < 10) {\n return `0${weekNumber.toLocaleString()}`;\n }\n return `${weekNumber.toLocaleString()}`;\n}\n//# sourceMappingURL=formatWeekNumber.js.map","/**\n * Format the week number header.\n *\n * @defaultValue `\"\"`\n * @group Formatters\n * @see https://daypicker.dev/docs/translation#custom-formatters\n */\nexport function formatWeekNumberHeader() {\n return ``;\n}\n//# sourceMappingURL=formatWeekNumberHeader.js.map","import { DateLib } from \"../classes/DateLib.js\";\n/**\n * Format the weekday name to be displayed in the weekdays header.\n *\n * @defaultValue `cccccc` (e.g. \"Mo\" for Monday)\n * @group Formatters\n * @see https://daypicker.dev/docs/translation#custom-formatters\n */\nexport function formatWeekdayName(weekday, options, dateLib) {\n return (dateLib ?? new DateLib(options)).format(weekday, \"cccccc\");\n}\n//# sourceMappingURL=formatWeekdayName.js.map","/**\n * Format the years for the dropdown option label.\n *\n * @defaultValue `year.toString()`\n * @group Formatters\n * @see https://daypicker.dev/docs/translation#custom-formatters\n */\nexport function formatYearDropdown(year) {\n return year.toString();\n}\n/**\n * @private\n * @deprecated Use `formatYearDropdown` instead.\n * @group Formatters\n */\nexport const formatYearCaption = formatYearDropdown;\n//# sourceMappingURL=formatYearDropdown.js.map","import * as defaultFormatters from \"../formatters/index.js\";\n/** Return the formatters from the props merged with the default formatters. */\nexport function getFormatters(customFormatters) {\n if (customFormatters?.formatMonthCaption && !customFormatters.formatCaption) {\n customFormatters.formatCaption = customFormatters.formatMonthCaption;\n }\n if (customFormatters?.formatYearCaption &&\n !customFormatters.formatYearDropdown) {\n customFormatters.formatYearDropdown = customFormatters.formatYearCaption;\n }\n return {\n ...defaultFormatters,\n ...customFormatters\n };\n}\n//# sourceMappingURL=getFormatters.js.map","import { defaultLocale } from \"../classes/DateLib.js\";\n/** Return the months to show in the dropdown. */\nexport function getMonthOptions(displayMonth, navStart, navEnd, formatters, dateLib) {\n if (!navStart)\n return undefined;\n if (!navEnd)\n return undefined;\n const { addMonths, startOfMonth } = dateLib;\n const year = displayMonth.getFullYear();\n const months = [];\n let month = navStart;\n while (months.length < 12) {\n months.push(month.getMonth());\n month = addMonths(month, 1);\n }\n const sortedMonths = months.sort((a, b) => {\n return a - b;\n });\n const options = sortedMonths.map((value) => {\n const label = formatters.formatMonthDropdown(value, dateLib.options.locale ?? defaultLocale);\n const month = dateLib.Date\n ? new dateLib.Date(year, value)\n : new Date(year, value);\n const disabled = (navStart && month < startOfMonth(navStart)) ||\n (navEnd && month > startOfMonth(navEnd)) ||\n false;\n return { value, label, disabled };\n });\n return options;\n}\n//# sourceMappingURL=getMonthOptions.js.map","import { UI } from \"../UI.js\";\nexport function getStyleForModifiers(dayModifiers, styles = {}, modifiersStyles = {}) {\n let style = { ...styles?.[UI.Day] };\n Object.entries(dayModifiers)\n .filter(([, active]) => active === true)\n .forEach(([modifier]) => {\n style = {\n ...style,\n ...modifiersStyles?.[modifier]\n };\n });\n return style;\n}\n//# sourceMappingURL=getStyleForModifiers.js.map","const offsetFormatCache = {};\nconst offsetCache = {};\n\n/**\n * The function extracts UTC offset in minutes from the given date in specified\n * time zone.\n *\n * Unlike `Date.prototype.getTimezoneOffset`, this function returns the value\n * mirrored to the sign of the offset in the time zone. For Asia/Singapore\n * (UTC+8), `tzOffset` returns 480, while `getTimezoneOffset` returns -480.\n *\n * @param timeZone - Time zone name (IANA or UTC offset)\n * @param date - Date to check the offset for\n *\n * @returns UTC offset in minutes\n */\nexport function tzOffset(timeZone, date) {\n try {\n const format = offsetFormatCache[timeZone] ||= new Intl.DateTimeFormat(\"en-GB\", {\n timeZone,\n hour: \"numeric\",\n timeZoneName: \"longOffset\"\n }).format;\n const offsetStr = format(date).split('GMT')[1] || '';\n if (offsetStr in offsetCache) return offsetCache[offsetStr];\n return calcOffset(offsetStr, offsetStr.split(\":\"));\n } catch {\n // Fallback to manual parsing if the runtime doesn't support ±HH:MM/±HHMM/±HH\n // See: https://github.com/nodejs/node/issues/53419\n if (timeZone in offsetCache) return offsetCache[timeZone];\n const captures = timeZone?.match(offsetRe);\n if (captures) return calcOffset(timeZone, captures.slice(1));\n return NaN;\n }\n}\nconst offsetRe = /([+-]\\d\\d):?(\\d\\d)?/;\nfunction calcOffset(cacheStr, values) {\n const hours = +values[0];\n const minutes = +(values[1] || 0);\n return offsetCache[cacheStr] = hours > 0 ? hours * 60 + minutes : hours * 60 - minutes;\n}","import { tzOffset } from \"../tzOffset/index.js\";\nexport class TZDateMini extends Date {\n //#region static\n\n constructor(...args) {\n super();\n if (args.length > 1 && typeof args[args.length - 1] === \"string\") {\n this.timeZone = args.pop();\n }\n this.internal = new Date();\n if (isNaN(tzOffset(this.timeZone, this))) {\n this.setTime(NaN);\n } else {\n if (!args.length) {\n this.setTime(Date.now());\n } else if (typeof args[0] === \"number\" && (args.length === 1 || args.length === 2 && typeof args[1] !== \"number\")) {\n this.setTime(args[0]);\n } else if (typeof args[0] === \"string\") {\n this.setTime(+new Date(args[0]));\n } else if (args[0] instanceof Date) {\n this.setTime(+args[0]);\n } else {\n this.setTime(+new Date(...args));\n adjustToSystemTZ(this, NaN);\n syncToInternal(this);\n }\n }\n }\n static tz(tz, ...args) {\n return args.length ? new TZDateMini(...args, tz) : new TZDateMini(Date.now(), tz);\n }\n\n //#endregion\n\n //#region time zone\n\n withTimeZone(timeZone) {\n return new TZDateMini(+this, timeZone);\n }\n getTimezoneOffset() {\n return -tzOffset(this.timeZone, this);\n }\n\n //#endregion\n\n //#region time\n\n setTime(time) {\n Date.prototype.setTime.apply(this, arguments);\n syncToInternal(this);\n return +this;\n }\n\n //#endregion\n\n //#region date-fns integration\n\n [Symbol.for(\"constructDateFrom\")](date) {\n return new TZDateMini(+new Date(date), this.timeZone);\n }\n\n //#endregion\n}\n\n// Assign getters and setters\nconst re = /^(get|set)(?!UTC)/;\nObject.getOwnPropertyNames(Date.prototype).forEach(method => {\n if (!re.test(method)) return;\n const utcMethod = method.replace(re, \"$1UTC\");\n // Filter out methods without UTC counterparts\n if (!TZDateMini.prototype[utcMethod]) return;\n if (method.startsWith(\"get\")) {\n // Delegate to internal date's UTC method\n TZDateMini.prototype[method] = function () {\n return this.internal[utcMethod]();\n };\n } else {\n // Assign regular setter\n TZDateMini.prototype[method] = function () {\n Date.prototype[utcMethod].apply(this.internal, arguments);\n syncFromInternal(this);\n return +this;\n };\n\n // Assign UTC setter\n TZDateMini.prototype[utcMethod] = function () {\n Date.prototype[utcMethod].apply(this, arguments);\n syncToInternal(this);\n return +this;\n };\n }\n});\n\n/**\n * Function syncs time to internal date, applying the time zone offset.\n *\n * @param {Date} date - Date to sync\n */\nfunction syncToInternal(date) {\n date.internal.setTime(+date);\n date.internal.setUTCMinutes(date.internal.getUTCMinutes() - date.getTimezoneOffset());\n}\n\n/**\n * Function syncs the internal date UTC values to the date. It allows to get\n * accurate timestamp value.\n *\n * @param {Date} date - The date to sync\n */\nfunction syncFromInternal(date) {\n // First we transpose the internal values\n Date.prototype.setFullYear.call(date, date.internal.getUTCFullYear(), date.internal.getUTCMonth(), date.internal.getUTCDate());\n Date.prototype.setHours.call(date, date.internal.getUTCHours(), date.internal.getUTCMinutes(), date.internal.getUTCSeconds(), date.internal.getUTCMilliseconds());\n\n // Now we have to adjust the date to the system time zone\n adjustToSystemTZ(date);\n}\n\n/**\n * Function adjusts the date to the system time zone. It uses the time zone\n * differences to calculate the offset and adjust the date.\n *\n * @param {Date} date - Date to adjust\n */\nfunction adjustToSystemTZ(date) {\n // Save the time zone offset before all the adjustments\n const offset = tzOffset(date.timeZone, date);\n\n //#region System DST adjustment\n\n // The biggest problem with using the system time zone is that when we create\n // a date from internal values stored in UTC, the system time zone might end\n // up on the DST hour:\n //\n // $ TZ=America/New_York node\n // > new Date(2020, 2, 8, 1).toString()\n // 'Sun Mar 08 2020 01:00:00 GMT-0500 (Eastern Standard Time)'\n // > new Date(2020, 2, 8, 2).toString()\n // 'Sun Mar 08 2020 03:00:00 GMT-0400 (Eastern Daylight Time)'\n // > new Date(2020, 2, 8, 3).toString()\n // 'Sun Mar 08 2020 03:00:00 GMT-0400 (Eastern Daylight Time)'\n // > new Date(2020, 2, 8, 4).toString()\n // 'Sun Mar 08 2020 04:00:00 GMT-0400 (Eastern Daylight Time)'\n //\n // Here we get the same hour for both 2 and 3, because the system time zone\n // has DST beginning at 8 March 2020, 2 a.m. and jumps to 3 a.m. So we have\n // to adjust the internal date to reflect that.\n //\n // However we want to adjust only if that's the DST hour the change happenes,\n // not the hour where DST moves to.\n\n // We calculate the previous hour to see if the time zone offset has changed\n // and we have landed on the DST hour.\n const prevHour = new Date(+date);\n // We use UTC methods here as we don't want to land on the same hour again\n // in case of DST.\n prevHour.setUTCHours(prevHour.getUTCHours() - 1);\n\n // Calculate if we are on the system DST hour.\n const systemOffset = -new Date(+date).getTimezoneOffset();\n const prevHourSystemOffset = -new Date(+prevHour).getTimezoneOffset();\n const systemDSTChange = systemOffset - prevHourSystemOffset;\n // Detect the DST shift. System DST change will occur both on\n const dstShift = Date.prototype.getHours.apply(date) !== date.internal.getUTCHours();\n\n // Move the internal date when we are on the system DST hour.\n if (systemDSTChange && dstShift) date.internal.setUTCMinutes(date.internal.getUTCMinutes() + systemDSTChange);\n\n //#endregion\n\n //#region System diff adjustment\n\n // Now we need to adjust the date, since we just applied internal values.\n // We need to calculate the difference between the system and date time zones\n // and apply it to the date.\n\n const offsetDiff = systemOffset - offset;\n if (offsetDiff) Date.prototype.setUTCMinutes.call(date, Date.prototype.getUTCMinutes.call(date) + offsetDiff);\n\n //#endregion\n\n //#region Post-adjustment DST fix\n\n const postOffset = tzOffset(date.timeZone, date);\n const postSystemOffset = -new Date(+date).getTimezoneOffset();\n const postOffsetDiff = postSystemOffset - postOffset;\n const offsetChanged = postOffset !== offset;\n const postDiff = postOffsetDiff - offsetDiff;\n if (offsetChanged && postDiff) {\n Date.prototype.setUTCMinutes.call(date, Date.prototype.getUTCMinutes.call(date) + postDiff);\n\n // Now we need to check if got offset change during the post-adjustment.\n // If so, we also need both dates to reflect that.\n\n const newOffset = tzOffset(date.timeZone, date);\n const offsetChange = postOffset - newOffset;\n if (offsetChange) {\n date.internal.setUTCMinutes(date.internal.getUTCMinutes() + offsetChange);\n Date.prototype.setUTCMinutes.call(date, Date.prototype.getUTCMinutes.call(date) + offsetChange);\n }\n }\n\n //#endregion\n}","import { TZDateMini } from \"./mini.js\";\n\n/**\n * UTC date class. It maps getters and setters to corresponding UTC methods,\n * forcing all calculations in the UTC time zone.\n *\n * Combined with date-fns, it allows using the class the same way as\n * the original date class.\n *\n * This complete version provides not only getters, setters,\n * and `getTimezoneOffset`, but also the formatter functions, mirroring\n * all original `Date` functionality. Use this version when you need to format\n * a string or in an environment you don't fully control (a library).\n * For a minimal version, see `UTCDateMini`.\n */\nexport class TZDate extends TZDateMini {\n //#region static\n\n static tz(tz, ...args) {\n return args.length ? new TZDate(...args, tz) : new TZDate(Date.now(), tz);\n }\n\n //#endregion\n\n //#region representation\n\n toISOString() {\n const [sign, hours, minutes] = this.tzComponents();\n const tz = `${sign}${hours}:${minutes}`;\n return this.internal.toISOString().slice(0, -1) + tz;\n }\n toString() {\n // \"Tue Aug 13 2024 07:50:19 GMT+0800 (Singapore Standard Time)\";\n return `${this.toDateString()} ${this.toTimeString()}`;\n }\n toDateString() {\n // toUTCString returns RFC 7231 (\"Mon, 12 Aug 2024 23:36:08 GMT\")\n const [day, date, month, year] = this.internal.toUTCString().split(\" \");\n // \"Tue Aug 13 2024\"\n return `${day?.slice(0, -1) /* Remove \",\" */} ${month} ${date} ${year}`;\n }\n toTimeString() {\n // toUTCString returns RFC 7231 (\"Mon, 12 Aug 2024 23:36:08 GMT\")\n const time = this.internal.toUTCString().split(\" \")[4];\n const [sign, hours, minutes] = this.tzComponents();\n // \"07:42:23 GMT+0800 (Singapore Standard Time)\"\n return `${time} GMT${sign}${hours}${minutes} (${tzName(this.timeZone, this)})`;\n }\n toLocaleString(locales, options) {\n return Date.prototype.toLocaleString.call(this, locales, {\n ...options,\n timeZone: options?.timeZone || this.timeZone\n });\n }\n toLocaleDateString(locales, options) {\n return Date.prototype.toLocaleDateString.call(this, locales, {\n ...options,\n timeZone: options?.timeZone || this.timeZone\n });\n }\n toLocaleTimeString(locales, options) {\n return Date.prototype.toLocaleTimeString.call(this, locales, {\n ...options,\n timeZone: options?.timeZone || this.timeZone\n });\n }\n\n //#endregion\n\n //#region private\n\n tzComponents() {\n const offset = this.getTimezoneOffset();\n const sign = offset > 0 ? \"-\" : \"+\";\n const hours = String(Math.floor(Math.abs(offset) / 60)).padStart(2, \"0\");\n const minutes = String(Math.abs(offset) % 60).padStart(2, \"0\");\n return [sign, hours, minutes];\n }\n\n //#endregion\n\n withTimeZone(timeZone) {\n return new TZDate(+this, timeZone);\n }\n\n //#region date-fns integration\n\n [Symbol.for(\"constructDateFrom\")](date) {\n return new TZDate(+new Date(date), this.timeZone);\n }\n\n //#endregion\n}\nfunction tzName(tz, date) {\n return new Intl.DateTimeFormat(\"en-GB\", {\n timeZone: tz,\n timeZoneName: \"long\"\n }).format(date).slice(12);\n}","import { TZDate } from \"@date-fns/tz\";\n/**\n * Generate a series of 7 days, starting from the week, to use for formatting\n * the weekday names (Monday, Tuesday, etc.).\n */\nexport function getWeekdays(\n/** The date library. */\ndateLib, \n/** Use ISOWeek instead of locale/ */\nISOWeek, timeZone, \n/** @since 9.4.0 */\nbroadcastCalendar) {\n const date = timeZone\n ? TZDate.tz(timeZone)\n : dateLib.Date\n ? new dateLib.Date()\n : new Date();\n const start = broadcastCalendar\n ? dateLib.startOfBroadcastWeek(date, dateLib)\n : ISOWeek\n ? dateLib.startOfISOWeek(date)\n : dateLib.startOfWeek(date);\n const days = [];\n for (let i = 0; i < 7; i++) {\n const day = dateLib.addDays(start, i);\n days.push(day);\n }\n return days;\n}\n//# sourceMappingURL=getWeekdays.js.map","/** Return the years to show in the dropdown. */\nexport function getYearOptions(navStart, navEnd, formatters, dateLib) {\n if (!navStart)\n return undefined;\n if (!navEnd)\n return undefined;\n const { startOfYear, endOfYear, addYears, isBefore, isSameYear } = dateLib;\n const firstNavYear = startOfYear(navStart);\n const lastNavYear = endOfYear(navEnd);\n const years = [];\n let year = firstNavYear;\n while (isBefore(year, lastNavYear) || isSameYear(year, lastNavYear)) {\n years.push(year.getFullYear());\n year = addYears(year, 1);\n }\n return years.map((value) => {\n const label = formatters.formatYearDropdown(value);\n return {\n value,\n label,\n disabled: false\n };\n });\n}\n//# sourceMappingURL=getYearOptions.js.map","import { DateLib } from \"../classes/DateLib.js\";\n/**\n * Return an ARIA label for the month grid, that will be announced when entering\n * the grid.\n *\n * @defaultValue `LLLL y` (e.g. \"November 2022\")\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelGrid(date, options, dateLib) {\n return (dateLib ?? new DateLib(options)).format(date, \"LLLL y\");\n}\n/**\n * @deprecated Use {@link labelGrid} instead.\n * @protected\n */\nexport const labelCaption = labelGrid;\n//# sourceMappingURL=labelGrid.js.map","import { DateLib } from \"../classes/DateLib.js\";\n/**\n * The label for the day gridcell when the calendar is not interactive.\n *\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelGridcell(date, \n/** The modifiers for the day. */\nmodifiers, options, dateLib) {\n let label = (dateLib ?? new DateLib(options)).format(date, \"PPPP\");\n if (modifiers?.today) {\n label = `Today, ${label}`;\n }\n return label;\n}\n//# sourceMappingURL=labelGridcell.js.map","import { DateLib } from \"../classes/DateLib.js\";\n/**\n * The ARIA label for the day button.\n *\n * Use the `modifiers` argument to add additional context to the label, e.g.\n * when a day is selected or is today.\n *\n * @defaultValue The formatted date.\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelDayButton(date, \n/** The modifiers for the day. */\nmodifiers, options, dateLib) {\n let label = (dateLib ?? new DateLib(options)).format(date, \"PPPP\");\n if (modifiers.today)\n label = `Today, ${label}`;\n if (modifiers.selected)\n label = `${label}, selected`;\n return label;\n}\n/** @deprecated Use `labelDayButton` instead. */\nexport const labelDay = labelDayButton;\n//# sourceMappingURL=labelDayButton.js.map","/**\n * The ARIA label for the navigation toolbar.\n *\n * @defaultValue `\"\"`\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelNav() {\n return \"\";\n}\n//# sourceMappingURL=labelNav.js.map","/**\n * The ARIA label for the months dropdown.\n *\n * @defaultValue `\"Choose the Month\"`\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelMonthDropdown(options) {\n return \"Choose the Month\";\n}\n//# sourceMappingURL=labelMonthDropdown.js.map","/**\n * The ARIA label for next month button.\n *\n * @defaultValue `\"Go to the Next Month\"`\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelNext(\n/** `undefined` where there's no next month to navigate to. */\nmonth) {\n return \"Go to the Next Month\";\n}\n//# sourceMappingURL=labelNext.js.map","/**\n * The ARIA label for previous month button.\n *\n * @defaultValue `\"Go to the Previous Month\"`\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelPrevious(\n/** Undefined where there's no previous month to navigate to. */\nmonth) {\n return \"Go to the Previous Month\";\n}\n//# sourceMappingURL=labelPrevious.js.map","import { DateLib } from \"../classes/DateLib.js\";\n/**\n * The ARIA label for the Weekday column header.\n *\n * @defaultValue `\"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\", \"Sunday\"`\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelWeekday(date, options, dateLib) {\n return (dateLib ?? new DateLib(options)).format(date, \"cccc\");\n}\n//# sourceMappingURL=labelWeekday.js.map","/**\n * The ARIA label for the week number cell (the first cell in the row).\n *\n * @defaultValue `Week ${weekNumber}`\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelWeekNumber(weekNumber, options) {\n return `Week ${weekNumber}`;\n}\n//# sourceMappingURL=labelWeekNumber.js.map","/**\n * The ARIA label for the week number header element.\n *\n * @defaultValue `\"Week Number\"`\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelWeekNumberHeader(options) {\n return \"Week Number\";\n}\n//# sourceMappingURL=labelWeekNumberHeader.js.map","/**\n * The ARIA label for the years dropdown.\n *\n * @defaultValue `\"Choose the Year\"`\n * @group Labels\n * @see https://daypicker.dev/docs/translation#aria-labels\n */\nexport function labelYearDropdown(options) {\n return \"Choose the Year\";\n}\n//# sourceMappingURL=labelYearDropdown.js.map","/** Return all the dates to display in the calendar. */\nexport function getDates(displayMonths, maxDate, props, dateLib) {\n const firstMonth = displayMonths[0];\n const lastMonth = displayMonths[displayMonths.length - 1];\n const { ISOWeek, fixedWeeks, broadcastCalendar } = props ?? {};\n const { addDays, differenceInCalendarDays, differenceInCalendarMonths, endOfBroadcastWeek, endOfISOWeek, endOfMonth, endOfWeek, isAfter, startOfBroadcastWeek, startOfISOWeek, startOfWeek } = dateLib;\n const startWeekFirstDate = broadcastCalendar\n ? startOfBroadcastWeek(firstMonth, dateLib)\n : ISOWeek\n ? startOfISOWeek(firstMonth)\n : startOfWeek(firstMonth);\n const endWeekLastDate = broadcastCalendar\n ? endOfBroadcastWeek(lastMonth, dateLib)\n : ISOWeek\n ? endOfISOWeek(endOfMonth(lastMonth))\n : endOfWeek(endOfMonth(lastMonth));\n const nOfDays = differenceInCalendarDays(endWeekLastDate, startWeekFirstDate);\n const nOfMonths = differenceInCalendarMonths(lastMonth, firstMonth) + 1;\n const dates = [];\n for (let i = 0; i <= nOfDays; i++) {\n const date = addDays(startWeekFirstDate, i);\n if (maxDate && isAfter(date, maxDate)) {\n break;\n }\n dates.push(date);\n }\n // If fixed weeks is enabled, add the extra dates to the array\n const nrOfDaysWithFixedWeeks = broadcastCalendar ? 35 : 42;\n const extraDates = nrOfDaysWithFixedWeeks * nOfMonths;\n if (fixedWeeks && dates.length < extraDates) {\n const daysToAdd = extraDates - dates.length;\n for (let i = 0; i < daysToAdd; i++) {\n const date = addDays(dates[dates.length - 1], 1);\n dates.push(date);\n }\n }\n return dates;\n}\n//# sourceMappingURL=getDates.js.map","/**\n * Returns all the days belonging to the calendar by merging the days in the\n * weeks for each month.\n */\nexport function getDays(calendarMonths) {\n const initialDays = [];\n return calendarMonths.reduce((days, month) => {\n const initialDays = [];\n const weekDays = month.weeks.reduce((weekDays, week) => {\n return [...weekDays, ...week.days];\n }, initialDays);\n return [...days, ...weekDays];\n }, initialDays);\n}\n//# sourceMappingURL=getDays.js.map","export function getDisplayMonths(firstDisplayedMonth, calendarEndMonth, props, dateLib) {\n const { numberOfMonths = 1 } = props;\n const months = [];\n for (let i = 0; i < numberOfMonths; i++) {\n const month = dateLib.addMonths(firstDisplayedMonth, i);\n if (calendarEndMonth && month > calendarEndMonth) {\n break;\n }\n months.push(month);\n }\n return months;\n}\n//# sourceMappingURL=getDisplayMonths.js.map","import { TZDate } from \"@date-fns/tz\";\n/** Return the start month based on the props passed to DayPicker. */\nexport function getInitialMonth(props, dateLib) {\n const { month, defaultMonth, today = props.timeZone\n ? TZDate.tz(props.timeZone)\n : dateLib.Date\n ? new dateLib.Date()\n : new Date(), numberOfMonths = 1, endMonth, startMonth } = props;\n let initialMonth = month || defaultMonth || today;\n const { differenceInCalendarMonths, addMonths, startOfMonth } = dateLib;\n // Fix the initialMonth if is after the to-date\n if (endMonth && differenceInCalendarMonths(endMonth, initialMonth) < 0) {\n const offset = -1 * (numberOfMonths - 1);\n initialMonth = addMonths(endMonth, offset);\n }\n // Fix the initialMonth if is before the from-date\n if (startMonth && differenceInCalendarMonths(initialMonth, startMonth) < 0) {\n initialMonth = startMonth;\n }\n return startOfMonth(initialMonth);\n}\n//# sourceMappingURL=getInitialMonth.js.map","import { defaultDateLib } from \"./DateLib.js\";\n/**\n * Represent the day displayed in the calendar.\n *\n * In DayPicker, a `Day` is a `Date` that can be displayed in the calendar. It\n * is used as extension of the native `Date` object to provide additional\n * information about the day.\n */\nexport class CalendarDay {\n constructor(date, displayMonth, dateLib = defaultDateLib) {\n this.date = date;\n this.displayMonth = displayMonth;\n this.outside = Boolean(displayMonth && !dateLib.isSameMonth(date, displayMonth));\n this.dateLib = dateLib;\n }\n /**\n * Check if the day is the same as the given day: considering if it is in the\n * same display month.\n */\n isEqualTo(day) {\n return (this.dateLib.isSameDay(day.date, this.date) &&\n this.dateLib.isSameMonth(day.displayMonth, this.displayMonth));\n }\n}\n//# sourceMappingURL=CalendarDay.js.map","/** Represent a month in a calendar year. Contains the weeks within the month. */\nexport class CalendarMonth {\n constructor(month, weeks) {\n this.date = month;\n this.weeks = weeks;\n }\n}\n//# sourceMappingURL=CalendarMonth.js.map","/** Represent a week in a calendar month. */\nexport class CalendarWeek {\n constructor(weekNumber, days) {\n this.days = days;\n this.weekNumber = weekNumber;\n }\n}\n//# sourceMappingURL=CalendarWeek.js.map","import { CalendarWeek, CalendarDay, CalendarMonth } from \"../classes/index.js\";\n/** Return the months to display in the calendar. */\nexport function getMonths(\n/** The months (as dates) to display in the calendar. */\ndisplayMonths, \n/** The dates to display in the calendar. */\ndates, \n/** Options from the props context. */\nprops, dateLib) {\n const { addDays, endOfBroadcastWeek, endOfISOWeek, endOfMonth, endOfWeek, getISOWeek, getWeek, startOfBroadcastWeek, startOfISOWeek, startOfWeek } = dateLib;\n const dayPickerMonths = displayMonths.reduce((months, month) => {\n const firstDateOfFirstWeek = props.broadcastCalendar\n ? startOfBroadcastWeek(month, dateLib)\n : props.ISOWeek\n ? startOfISOWeek(month)\n : startOfWeek(month);\n const lastDateOfLastWeek = props.broadcastCalendar\n ? endOfBroadcastWeek(month, dateLib)\n : props.ISOWeek\n ? endOfISOWeek(endOfMonth(month))\n : endOfWeek(endOfMonth(month));\n /** The dates to display in the month. */\n const monthDates = dates.filter((date) => {\n return date >= firstDateOfFirstWeek && date <= lastDateOfLastWeek;\n });\n const nrOfDaysWithFixedWeeks = props.broadcastCalendar ? 35 : 42;\n if (props.fixedWeeks && monthDates.length < nrOfDaysWithFixedWeeks) {\n const extraDates = dates.filter((date) => {\n const daysToAdd = nrOfDaysWithFixedWeeks - monthDates.length;\n return (date > lastDateOfLastWeek &&\n date <= addDays(lastDateOfLastWeek, daysToAdd));\n });\n monthDates.push(...extraDates);\n }\n const weeks = monthDates.reduce((weeks, date) => {\n const weekNumber = props.ISOWeek ? getISOWeek(date) : getWeek(date);\n const week = weeks.find((week) => week.weekNumber === weekNumber);\n const day = new CalendarDay(date, month, dateLib);\n if (!week) {\n weeks.push(new CalendarWeek(weekNumber, [day]));\n }\n else {\n week.days.push(day);\n }\n return weeks;\n }, []);\n const dayPickerMonth = new CalendarMonth(month, weeks);\n months.push(dayPickerMonth);\n return months;\n }, []);\n if (!props.reverseMonths) {\n return dayPickerMonths;\n }\n else {\n return dayPickerMonths.reverse();\n }\n}\n//# sourceMappingURL=getMonths.js.map","import { TZDate } from \"@date-fns/tz\";\n/** Return the start and end months for the calendar navigation. */\nexport function getNavMonths(props, dateLib) {\n let { startMonth, endMonth } = props;\n const { startOfYear, startOfDay, startOfMonth, endOfMonth, addYears, endOfYear } = dateLib;\n // Handle deprecated code\n const { fromYear, toYear, fromMonth, toMonth } = props;\n if (!startMonth && fromMonth) {\n startMonth = fromMonth;\n }\n if (!startMonth && fromYear) {\n startMonth = new Date(fromYear, 0, 1);\n }\n if (!endMonth && toMonth) {\n endMonth = toMonth;\n }\n if (!endMonth && toYear) {\n endMonth = new Date(toYear, 11, 31);\n }\n const hasDropdowns = props.captionLayout?.startsWith(\"dropdown\");\n if (startMonth) {\n startMonth = startOfMonth(startMonth);\n }\n else if (fromYear) {\n startMonth = new Date(fromYear, 0, 1);\n }\n else if (!startMonth && hasDropdowns) {\n const today = props.today ??\n (props.timeZone\n ? TZDate.tz(props.timeZone)\n : dateLib.Date\n ? new dateLib.Date()\n : new Date());\n startMonth = startOfYear(addYears(today, -100));\n }\n if (endMonth) {\n endMonth = endOfMonth(endMonth);\n }\n else if (toYear) {\n endMonth = new Date(toYear, 11, 31);\n }\n else if (!endMonth && hasDropdowns) {\n const today = props.today ??\n (props.timeZone\n ? TZDate.tz(props.timeZone)\n : dateLib.Date\n ? new dateLib.Date()\n : new Date());\n endMonth = endOfYear(today);\n }\n return [\n startMonth ? startOfDay(startMonth) : startMonth,\n endMonth ? startOfDay(endMonth) : endMonth\n ];\n}\n//# sourceMappingURL=getNavMonth.js.map","/**\n * Return the next month the user can navigate to according to the given\n * options.\n *\n * Please note that the next month is not always the next calendar month:\n *\n * - If after the `calendarEndMonth` range, is `undefined`;\n * - If the navigation is paged , is the number of months displayed ahead.\n */\nexport function getNextMonth(firstDisplayedMonth, calendarEndMonth, options, dateLib) {\n if (options.disableNavigation) {\n return undefined;\n }\n const { pagedNavigation, numberOfMonths = 1 } = options;\n const { startOfMonth, addMonths, differenceInCalendarMonths } = dateLib;\n const offset = pagedNavigation ? numberOfMonths : 1;\n const month = startOfMonth(firstDisplayedMonth);\n if (!calendarEndMonth) {\n return addMonths(month, offset);\n }\n const monthsDiff = differenceInCalendarMonths(calendarEndMonth, firstDisplayedMonth);\n if (monthsDiff < numberOfMonths) {\n return undefined;\n }\n // Jump forward as the number of months when paged navigation\n return addMonths(month, offset);\n}\n//# sourceMappingURL=getNextMonth.js.map","/**\n * Return the next previous the user can navigate to, according to the given\n * options.\n *\n * Please note that the previous month is not always the previous calendar\n * month:\n *\n * - If before the `calendarStartMonth` date, is `undefined`;\n * - If the navigation is paged, is the number of months displayed before.\n */\nexport function getPreviousMonth(firstDisplayedMonth, calendarStartMonth, options, dateLib) {\n if (options.disableNavigation) {\n return undefined;\n }\n const { pagedNavigation, numberOfMonths } = options;\n const { startOfMonth, addMonths, differenceInCalendarMonths } = dateLib;\n const offset = pagedNavigation ? (numberOfMonths ?? 1) : 1;\n const month = startOfMonth(firstDisplayedMonth);\n if (!calendarStartMonth) {\n return addMonths(month, -offset);\n }\n const monthsDiff = differenceInCalendarMonths(month, calendarStartMonth);\n if (monthsDiff <= 0) {\n return undefined;\n }\n return addMonths(month, -offset);\n}\n//# sourceMappingURL=getPreviousMonth.js.map","/** Returns an array of calendar weeks from an array of calendar months. */\nexport function getWeeks(months) {\n const initialWeeks = [];\n return months.reduce((weeks, month) => {\n return [...weeks, ...month.weeks];\n }, initialWeeks);\n}\n//# sourceMappingURL=getWeeks.js.map","import { useState } from \"react\";\n/**\n * A custom hook for managing both controlled and uncontrolled component states.\n *\n * @example\n * // Uncontrolled usage\n * const [value, setValue] = useControlledValue(0, undefined);\n *\n * // Controlled usage\n * const [value, setValue] = useControlledValue(0, props.value);\n *\n * @template T - The type of the value.\n * @param {T} defaultValue - The initial value for the uncontrolled state.\n * @param {T | undefined} controlledValue - The value for the controlled state.\n * If undefined, the component will use the uncontrolled state.\n * @returns {[T, DispatchStateAction]} - Returns a tuple where the first\n * element is the current value (either controlled or uncontrolled) and the\n * second element is a setter function to update the value.\n */\nexport function useControlledValue(defaultValue, controlledValue) {\n const [uncontrolledValue, setValue] = useState(defaultValue);\n const value = controlledValue === undefined ? uncontrolledValue : controlledValue;\n return [value, setValue];\n}\n//# sourceMappingURL=useControlledValue.js.map","import { useEffect } from \"react\";\nimport { getDates } from \"./helpers/getDates.js\";\nimport { getDays } from \"./helpers/getDays.js\";\nimport { getDisplayMonths } from \"./helpers/getDisplayMonths.js\";\nimport { getInitialMonth } from \"./helpers/getInitialMonth.js\";\nimport { getMonths } from \"./helpers/getMonths.js\";\nimport { getNavMonths } from \"./helpers/getNavMonth.js\";\nimport { getNextMonth } from \"./helpers/getNextMonth.js\";\nimport { getPreviousMonth } from \"./helpers/getPreviousMonth.js\";\nimport { getWeeks } from \"./helpers/getWeeks.js\";\nimport { useControlledValue } from \"./helpers/useControlledValue.js\";\n/** @private */\nexport function useCalendar(props, dateLib) {\n const [navStart, navEnd] = getNavMonths(props, dateLib);\n const { startOfMonth, endOfMonth } = dateLib;\n const initialMonth = getInitialMonth(props, dateLib);\n const [firstMonth, setFirstMonth] = useControlledValue(initialMonth, props.month ? startOfMonth(props.month) : undefined);\n useEffect(() => {\n const newInitialMonth = getInitialMonth(props, dateLib);\n setFirstMonth(newInitialMonth);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props.timeZone]);\n /** The months displayed in the calendar. */\n const displayMonths = getDisplayMonths(firstMonth, navEnd, props, dateLib);\n /** The dates displayed in the calendar. */\n const dates = getDates(displayMonths, props.endMonth ? endOfMonth(props.endMonth) : undefined, props, dateLib);\n /** The Months displayed in the calendar. */\n const months = getMonths(displayMonths, dates, props, dateLib);\n /** The Weeks displayed in the calendar. */\n const weeks = getWeeks(months);\n /** The Days displayed in the calendar. */\n const days = getDays(months);\n const previousMonth = getPreviousMonth(firstMonth, navStart, props, dateLib);\n const nextMonth = getNextMonth(firstMonth, navEnd, props, dateLib);\n const { disableNavigation, onMonthChange } = props;\n const isDayInCalendar = (day) => weeks.some((week) => week.days.some((d) => d.isEqualTo(day)));\n const goToMonth = (date) => {\n if (disableNavigation) {\n return;\n }\n let newMonth = startOfMonth(date);\n // if month is before start, use the first month instead\n if (navStart && newMonth < startOfMonth(navStart)) {\n newMonth = startOfMonth(navStart);\n }\n // if month is after endMonth, use the last month instead\n if (navEnd && newMonth > startOfMonth(navEnd)) {\n newMonth = startOfMonth(navEnd);\n }\n setFirstMonth(newMonth);\n onMonthChange?.(newMonth);\n };\n const goToDay = (day) => {\n // is this check necessary?\n if (isDayInCalendar(day)) {\n return;\n }\n goToMonth(day.date);\n };\n const calendar = {\n months,\n weeks,\n days,\n navStart,\n navEnd,\n previousMonth,\n nextMonth,\n goToMonth,\n goToDay\n };\n return calendar;\n}\n//# sourceMappingURL=useCalendar.js.map","import { DayFlag } from \"../UI.js\";\nexport function calculateFocusTarget(days, getModifiers, isSelected, lastFocused) {\n let focusTarget;\n let index = 0;\n let found = false;\n while (index < days.length && !found) {\n const day = days[index];\n const modifiers = getModifiers(day);\n if (!modifiers[DayFlag.disabled] &&\n !modifiers[DayFlag.hidden] &&\n !modifiers[DayFlag.outside]) {\n if (modifiers[DayFlag.focused]) {\n focusTarget = day;\n found = true;\n }\n else if (lastFocused?.isEqualTo(day)) {\n focusTarget = day;\n found = true;\n }\n else if (isSelected(day.date)) {\n focusTarget = day;\n found = true;\n }\n else if (modifiers[DayFlag.today]) {\n focusTarget = day;\n found = true;\n }\n }\n index++;\n }\n if (!focusTarget) {\n // return the first day that is focusable\n focusTarget = days.find((day) => {\n const m = getModifiers(day);\n return !m[DayFlag.disabled] && !m[DayFlag.hidden] && !m[DayFlag.outside];\n });\n }\n return focusTarget;\n}\n//# sourceMappingURL=calculateFocusTarget.js.map","import { defaultDateLib } from \"../classes/index.js\";\n/**\n * Determines whether a given date is inside a specified date range.\n *\n * @since 9.0.0\n * @group Utilities\n */\nexport function rangeIncludesDate(range, date, \n/** If `true`, the ends of the range are excluded. */\nexcludeEnds = false, dateLib = defaultDateLib) {\n let { from, to } = range;\n const { differenceInCalendarDays, isSameDay } = dateLib;\n if (from && to) {\n const isRangeInverted = differenceInCalendarDays(to, from) < 0;\n if (isRangeInverted) {\n [from, to] = [to, from];\n }\n const isInRange = differenceInCalendarDays(date, from) >= (excludeEnds ? 1 : 0) &&\n differenceInCalendarDays(to, date) >= (excludeEnds ? 1 : 0);\n return isInRange;\n }\n if (!excludeEnds && to) {\n return isSameDay(to, date);\n }\n if (!excludeEnds && from) {\n return isSameDay(from, date);\n }\n return false;\n}\n/**\n * @private\n * @deprecated Use {@link rangeIncludesDate} instead.\n */\nexport const isDateInRange = (range, date) => rangeIncludesDate(range, date, false, defaultDateLib);\n//# sourceMappingURL=rangeIncludesDate.js.map","/**\n * Returns true if `matcher` is of type {@link DateInterval}.\n *\n * @group Utilities\n */\nexport function isDateInterval(matcher) {\n return Boolean(matcher &&\n typeof matcher === \"object\" &&\n \"before\" in matcher &&\n \"after\" in matcher);\n}\n/**\n * Returns true if `value` is a {@link DateRange} type.\n *\n * @group Utilities\n */\nexport function isDateRange(value) {\n return Boolean(value && typeof value === \"object\" && \"from\" in value);\n}\n/**\n * Returns true if `value` is of type {@link DateAfter}.\n *\n * @group Utilities\n */\nexport function isDateAfterType(value) {\n return Boolean(value && typeof value === \"object\" && \"after\" in value);\n}\n/**\n * Returns true if `value` is of type {@link DateBefore}.\n *\n * @group Utilities\n */\nexport function isDateBeforeType(value) {\n return Boolean(value && typeof value === \"object\" && \"before\" in value);\n}\n/**\n * Returns true if `value` is a {@link DayOfWeek} type.\n *\n * @group Utilities\n */\nexport function isDayOfWeekType(value) {\n return Boolean(value && typeof value === \"object\" && \"dayOfWeek\" in value);\n}\n/**\n * Returns true if `value` is an array of valid dates.\n *\n * @private\n */\nexport function isDatesArray(value, dateLib) {\n return Array.isArray(value) && value.every(dateLib.isDate);\n}\n//# sourceMappingURL=typeguards.js.map","import { defaultDateLib } from \"../classes/DateLib.js\";\nimport { rangeIncludesDate } from \"./rangeIncludesDate.js\";\nimport { isDateAfterType, isDateBeforeType, isDateInterval, isDateRange, isDatesArray, isDayOfWeekType } from \"./typeguards.js\";\n/**\n * Returns whether a day matches against at least one of the given\n * {@link Matcher}.\n *\n * ```tsx\n * const date = new Date(2022, 5, 19);\n * const matcher1: DateRange = {\n * from: new Date(2021, 12, 21),\n * to: new Date(2021, 12, 30)\n * };\n * const matcher2: DateRange = {\n * from: new Date(2022, 5, 1),\n * to: new Date(2022, 5, 23)\n * };\n * dateMatchModifiers(date, [matcher1, matcher2]); // true, since day is in the matcher1 range.\n * ```\n *\n * @group Utilities\n */\nexport function dateMatchModifiers(date, matchers, dateLib = defaultDateLib) {\n const matchersArr = !Array.isArray(matchers) ? [matchers] : matchers;\n const { isSameDay, differenceInCalendarDays, isAfter } = dateLib;\n return matchersArr.some((matcher) => {\n if (typeof matcher === \"boolean\") {\n return matcher;\n }\n if (dateLib.isDate(matcher)) {\n return isSameDay(date, matcher);\n }\n if (isDatesArray(matcher, dateLib)) {\n return matcher.includes(date);\n }\n if (isDateRange(matcher)) {\n return rangeIncludesDate(matcher, date, false, dateLib);\n }\n if (isDayOfWeekType(matcher)) {\n if (!Array.isArray(matcher.dayOfWeek)) {\n return matcher.dayOfWeek === date.getDay();\n }\n return matcher.dayOfWeek.includes(date.getDay());\n }\n if (isDateInterval(matcher)) {\n const diffBefore = differenceInCalendarDays(matcher.before, date);\n const diffAfter = differenceInCalendarDays(matcher.after, date);\n const isDayBefore = diffBefore > 0;\n const isDayAfter = diffAfter < 0;\n const isClosedInterval = isAfter(matcher.before, matcher.after);\n if (isClosedInterval) {\n return isDayAfter && isDayBefore;\n }\n else {\n return isDayBefore || isDayAfter;\n }\n }\n if (isDateAfterType(matcher)) {\n return differenceInCalendarDays(date, matcher.after) > 0;\n }\n if (isDateBeforeType(matcher)) {\n return differenceInCalendarDays(matcher.before, date) > 0;\n }\n if (typeof matcher === \"function\") {\n return matcher(date);\n }\n return false;\n });\n}\n/**\n * @private\n * @deprecated Use {@link dateMatchModifiers} instead.\n */\nexport const isMatch = dateMatchModifiers;\n//# sourceMappingURL=dateMatchModifiers.js.map","/** Return the next date that should be focused. */\nexport function getFocusableDate(moveBy, moveDir, refDate, navStart, navEnd, props, dateLib) {\n const { ISOWeek, broadcastCalendar } = props;\n const { addDays, addMonths, addWeeks, addYears, endOfBroadcastWeek, endOfISOWeek, endOfWeek, max, min, startOfBroadcastWeek, startOfISOWeek, startOfWeek } = dateLib;\n const moveFns = {\n day: addDays,\n week: addWeeks,\n month: addMonths,\n year: addYears,\n startOfWeek: (date) => broadcastCalendar\n ? startOfBroadcastWeek(date, dateLib)\n : ISOWeek\n ? startOfISOWeek(date)\n : startOfWeek(date),\n endOfWeek: (date) => broadcastCalendar\n ? endOfBroadcastWeek(date, dateLib)\n : ISOWeek\n ? endOfISOWeek(date)\n : endOfWeek(date)\n };\n let focusableDate = moveFns[moveBy](refDate, moveDir === \"after\" ? 1 : -1);\n if (moveDir === \"before\" && navStart) {\n focusableDate = max([navStart, focusableDate]);\n }\n else if (moveDir === \"after\" && navEnd) {\n focusableDate = min([navEnd, focusableDate]);\n }\n return focusableDate;\n}\n//# sourceMappingURL=getFocusableDate.js.map","import { CalendarDay } from \"../classes/index.js\";\nimport { dateMatchModifiers } from \"../utils/dateMatchModifiers.js\";\nimport { getFocusableDate } from \"./getFocusableDate.js\";\nexport function getNextFocus(moveBy, moveDir, \n/** The date that is currently focused. */\nrefDay, calendarStartMonth, calendarEndMonth, props, dateLib, attempt = 0) {\n if (attempt > 365) {\n // Limit the recursion to 365 attempts\n return undefined;\n }\n const focusableDate = getFocusableDate(moveBy, moveDir, refDay.date, // should be refDay? or refDay.date?\n calendarStartMonth, calendarEndMonth, props, dateLib);\n const isDisabled = Boolean(props.disabled && dateMatchModifiers(focusableDate, props.disabled, dateLib));\n const isHidden = Boolean(props.hidden && dateMatchModifiers(focusableDate, props.hidden, dateLib));\n const targetMonth = focusableDate;\n const focusDay = new CalendarDay(focusableDate, targetMonth, dateLib);\n if (!isDisabled && !isHidden) {\n return focusDay;\n }\n // Recursively attempt to find the next focusable date\n return getNextFocus(moveBy, moveDir, focusDay, calendarStartMonth, calendarEndMonth, props, dateLib, attempt + 1);\n}\n//# sourceMappingURL=getNextFocus.js.map","import { useState } from \"react\";\nimport { calculateFocusTarget } from \"./helpers/calculateFocusTarget.js\";\nimport { getNextFocus } from \"./helpers/getNextFocus.js\";\n/** @private */\nexport function useFocus(props, calendar, getModifiers, isSelected, dateLib) {\n const { autoFocus } = props;\n const [lastFocused, setLastFocused] = useState();\n const focusTarget = calculateFocusTarget(calendar.days, getModifiers, isSelected || (() => false), lastFocused);\n const [focusedDay, setFocused] = useState(autoFocus ? focusTarget : undefined);\n const blur = () => {\n setLastFocused(focusedDay);\n setFocused(undefined);\n };\n const moveFocus = (moveBy, moveDir) => {\n if (!focusedDay)\n return;\n const nextFocus = getNextFocus(moveBy, moveDir, focusedDay, calendar.navStart, calendar.navEnd, props, dateLib);\n if (!nextFocus)\n return;\n calendar.goToDay(nextFocus);\n setFocused(nextFocus);\n };\n const isFocusTarget = (day) => {\n return Boolean(focusTarget?.isEqualTo(day));\n };\n const useFocus = {\n isFocusTarget,\n setFocused,\n focused: focusedDay,\n blur,\n moveFocus\n };\n return useFocus;\n}\n//# sourceMappingURL=useFocus.js.map","import { TZDate } from \"@date-fns/tz\";\nimport { DayFlag } from \"./UI.js\";\nimport { dateMatchModifiers } from \"./utils/dateMatchModifiers.js\";\n/**\n * Return a function to get the modifiers for a given day.\n *\n * NOTE: this is not an hook, but a factory for `getModifiers`.\n *\n * @private\n */\nexport function useGetModifiers(days, props, dateLib) {\n const { disabled, hidden, modifiers, showOutsideDays, broadcastCalendar, today } = props;\n const { isSameDay, isSameMonth, startOfMonth, isBefore, endOfMonth, isAfter } = dateLib;\n const startMonth = props.startMonth && startOfMonth(props.startMonth);\n const endMonth = props.endMonth && endOfMonth(props.endMonth);\n const internalModifiersMap = {\n [DayFlag.focused]: [],\n [DayFlag.outside]: [],\n [DayFlag.disabled]: [],\n [DayFlag.hidden]: [],\n [DayFlag.today]: []\n };\n const customModifiersMap = {};\n for (const day of days) {\n const { date, displayMonth } = day;\n const isOutside = Boolean(displayMonth && !isSameMonth(date, displayMonth));\n const isBeforeStartMonth = Boolean(startMonth && isBefore(date, startMonth));\n const isAfterEndMonth = Boolean(endMonth && isAfter(date, endMonth));\n const isDisabled = Boolean(disabled && dateMatchModifiers(date, disabled, dateLib));\n const isHidden = Boolean(hidden && dateMatchModifiers(date, hidden, dateLib)) ||\n isBeforeStartMonth ||\n isAfterEndMonth ||\n // Broadcast calendar will show outside days as default\n (!broadcastCalendar && !showOutsideDays && isOutside) ||\n (broadcastCalendar && showOutsideDays === false && isOutside);\n const isToday = isSameDay(date, today ??\n (props.timeZone\n ? TZDate.tz(props.timeZone)\n : dateLib.Date\n ? new dateLib.Date()\n : new Date()));\n if (isOutside)\n internalModifiersMap.outside.push(day);\n if (isDisabled)\n internalModifiersMap.disabled.push(day);\n if (isHidden)\n internalModifiersMap.hidden.push(day);\n if (isToday)\n internalModifiersMap.today.push(day);\n // Add custom modifiers\n if (modifiers) {\n Object.keys(modifiers).forEach((name) => {\n const modifierValue = modifiers?.[name];\n const isMatch = modifierValue\n ? dateMatchModifiers(date, modifierValue, dateLib)\n : false;\n if (!isMatch)\n return;\n if (customModifiersMap[name]) {\n customModifiersMap[name].push(day);\n }\n else {\n customModifiersMap[name] = [day];\n }\n });\n }\n }\n return (day) => {\n // Initialize all the modifiers to false\n const dayFlags = {\n [DayFlag.focused]: false,\n [DayFlag.disabled]: false,\n [DayFlag.hidden]: false,\n [DayFlag.outside]: false,\n [DayFlag.today]: false\n };\n const customModifiers = {};\n // Find the modifiers for the given day\n for (const name in internalModifiersMap) {\n const days = internalModifiersMap[name];\n dayFlags[name] = days.some((d) => d === day);\n }\n for (const name in customModifiersMap) {\n customModifiers[name] = customModifiersMap[name].some((d) => d === day);\n }\n return {\n ...dayFlags,\n // custom modifiers should override all the previous ones\n ...customModifiers\n };\n };\n}\n//# sourceMappingURL=useGetModifiers.js.map","import { useControlledValue } from \"../helpers/useControlledValue.js\";\nexport function useMulti(props, dateLib) {\n const { selected: initiallySelected, required, onSelect } = props;\n const [internallySelected, setSelected] = useControlledValue(initiallySelected, onSelect ? initiallySelected : undefined);\n const selected = !onSelect ? internallySelected : initiallySelected;\n const { isSameDay } = dateLib;\n const isSelected = (date) => {\n return selected?.some((d) => isSameDay(d, date)) ?? false;\n };\n const { min, max } = props;\n const select = (triggerDate, modifiers, e) => {\n let newDates = [...(selected ?? [])];\n if (isSelected(triggerDate)) {\n if (selected?.length === min) {\n // Min value reached, do nothing\n return;\n }\n if (required && selected?.length === 1) {\n // Required value already selected do nothing\n return;\n }\n newDates = selected?.filter((d) => !isSameDay(d, triggerDate));\n }\n else {\n if (selected?.length === max) {\n // Max value reached, reset the selection to date\n newDates = [triggerDate];\n }\n else {\n // Add the date to the selection\n newDates = [...newDates, triggerDate];\n }\n }\n if (!onSelect) {\n setSelected(newDates);\n }\n onSelect?.(newDates, triggerDate, modifiers, e);\n return newDates;\n };\n return {\n selected,\n select,\n isSelected\n };\n}\n//# sourceMappingURL=useMulti.js.map","import { defaultDateLib } from \"../classes/DateLib.js\";\n/**\n * Add a day to an existing range.\n *\n * The returned range takes in account the `undefined` values and if the added\n * day is already present in the range.\n *\n * @group Utilities\n */\nexport function addToRange(\n/** The date to add to the range. */\ndate, \n/** The range where to add `date`. */\ninitialRange, min = 0, max = 0, required = false, \n/** @ignore */\ndateLib = defaultDateLib) {\n const { from, to } = initialRange || {};\n const { isSameDay, isAfter, isBefore } = dateLib;\n let range;\n if (!from && !to) {\n // the range is empty, add the date\n range = { from: date, to: min > 0 ? undefined : date };\n }\n else if (from && !to) {\n // adding date to an incomplete range\n if (isSameDay(from, date)) {\n // adding a date equal to the start of the range\n if (required) {\n range = { from, to: undefined };\n }\n else {\n range = undefined;\n }\n }\n else if (isBefore(date, from)) {\n // adding a date before the start of the range\n range = { from: date, to: from };\n }\n else {\n // adding a date after the start of the range\n range = { from, to: date };\n }\n }\n else if (from && to) {\n // adding date to a complete range\n if (isSameDay(from, date) && isSameDay(to, date)) {\n // adding a date that is equal to both start and end of the range\n if (required) {\n range = { from, to };\n }\n else {\n range = undefined;\n }\n }\n else if (isSameDay(from, date)) {\n // adding a date equal to the the start of the range\n range = { from, to: min > 0 ? undefined : date };\n }\n else if (isSameDay(to, date)) {\n // adding a dare equal to the end of the range\n range = { from: date, to: min > 0 ? undefined : date };\n }\n else if (isBefore(date, from)) {\n // adding a date before the start of the range\n range = { from: date, to: to };\n }\n else if (isAfter(date, from)) {\n // adding a date after the start of the range\n range = { from, to: date };\n }\n else if (isAfter(date, to)) {\n // adding a date after the end of the range\n range = { from, to: date };\n }\n else {\n throw new Error(\"Invalid range\");\n }\n }\n // check for min / max\n if (range?.from && range?.to) {\n const diff = dateLib.differenceInCalendarDays(range.to, range.from);\n if (max > 0 && diff > max) {\n range = { from: date, to: undefined };\n }\n else if (min > 1 && diff < min) {\n range = { from: date, to: undefined };\n }\n }\n return range;\n}\n//# sourceMappingURL=addToRange.js.map","import { defaultDateLib } from \"../classes/DateLib.js\";\n/**\n * Returns whether a date range contains one or more days of the week.\n *\n * ```tsx\n * const range: DateRange = {\n * from: new Date(2024, 8, 1), // Sunday\n * to: new Date(2024, 8, 6) // Thursday\n * };\n * rangeContainsDayOfWeek(date, 1); // true: contains range contains Monday\n * ```\n *\n * @since 9.2.2\n * @group Utilities\n */\nexport function rangeContainsDayOfWeek(range, dayOfWeek, dateLib = defaultDateLib) {\n const dayOfWeekArr = !Array.isArray(dayOfWeek) ? [dayOfWeek] : dayOfWeek;\n let date = range.from;\n const totalDays = dateLib.differenceInCalendarDays(range.to, range.from);\n // iterate at maximum one week or the total days if the range is shorter than one week\n const totalDaysLimit = Math.min(totalDays, 6);\n for (let i = 0; i <= totalDaysLimit; i++) {\n if (dayOfWeekArr.includes(date.getDay())) {\n return true;\n }\n date = dateLib.addDays(date, 1);\n }\n return false;\n}\n//# sourceMappingURL=rangeContainsDayOfWeek.js.map","import { defaultDateLib } from \"../classes/index.js\";\nimport { rangeIncludesDate } from \"./rangeIncludesDate.js\";\n/**\n * Determines whether a given range overlaps with another range.\n *\n * @since 9.2.2\n * @group Utilities\n */\nexport function rangeOverlaps(rangeLeft, rangeRight, dateLib = defaultDateLib) {\n return (rangeIncludesDate(rangeLeft, rangeRight.from, false, dateLib) ||\n rangeIncludesDate(rangeLeft, rangeRight.to, false, dateLib) ||\n rangeIncludesDate(rangeRight, rangeLeft.from, false, dateLib) ||\n rangeIncludesDate(rangeRight, rangeLeft.to, false, dateLib));\n}\n//# sourceMappingURL=rangeOverlaps.js.map","import { defaultDateLib } from \"../classes/DateLib.js\";\nimport { dateMatchModifiers } from \"./dateMatchModifiers.js\";\nimport { rangeContainsDayOfWeek } from \"./rangeContainsDayOfWeek.js\";\nimport { rangeIncludesDate } from \"./rangeIncludesDate.js\";\nimport { rangeOverlaps } from \"./rangeOverlaps.js\";\nimport { isDateAfterType, isDateBeforeType, isDateInterval, isDateRange, isDatesArray, isDayOfWeekType } from \"./typeguards.js\";\n/**\n * Returns whether a range contains dates that match the given modifiers.\n *\n * ```tsx\n * const range: DateRange = {\n * from: new Date(2021, 12, 21),\n * to: new Date(2021, 12, 30)\n * };\n * const matcher1: Date = new Date(2021, 12, 21);\n * const matcher2: DateRange = {\n * from: new Date(2022, 5, 1),\n * to: new Date(2022, 5, 23)\n * };\n * rangeContainsModifiers(range, [matcher1, matcher2]); // true, since matcher1 is in the date.\n * ```\n *\n * @since 9.2.2\n * @group Utilities\n */\nexport function rangeContainsModifiers(range, modifiers, dateLib = defaultDateLib) {\n const matchers = Array.isArray(modifiers) ? modifiers : [modifiers];\n // Defer function matchers evaluation as they are the least performant.\n const nonFunctionMatchers = matchers.filter((matcher) => typeof matcher !== \"function\");\n const nonFunctionMatchersResult = nonFunctionMatchers.some((matcher) => {\n if (typeof matcher === \"boolean\")\n return matcher;\n if (dateLib.isDate(matcher)) {\n return rangeIncludesDate(range, matcher, false, dateLib);\n }\n if (isDatesArray(matcher, dateLib)) {\n return matcher.some((date) => rangeIncludesDate(range, date, false, dateLib));\n }\n if (isDateRange(matcher)) {\n if (matcher.from && matcher.to) {\n return rangeOverlaps(range, { from: matcher.from, to: matcher.to }, dateLib);\n }\n return false;\n }\n if (isDayOfWeekType(matcher)) {\n return rangeContainsDayOfWeek(range, matcher.dayOfWeek, dateLib);\n }\n if (isDateInterval(matcher)) {\n const isClosedInterval = dateLib.isAfter(matcher.before, matcher.after);\n if (isClosedInterval) {\n return rangeOverlaps(range, {\n from: dateLib.addDays(matcher.after, 1),\n to: dateLib.addDays(matcher.before, -1)\n }, dateLib);\n }\n return (dateMatchModifiers(range.from, matcher, dateLib) ||\n dateMatchModifiers(range.to, matcher, dateLib));\n }\n if (isDateAfterType(matcher) || isDateBeforeType(matcher)) {\n return (dateMatchModifiers(range.from, matcher, dateLib) ||\n dateMatchModifiers(range.to, matcher, dateLib));\n }\n return false;\n });\n if (nonFunctionMatchersResult) {\n return true;\n }\n const functionMatchers = matchers.filter((matcher) => typeof matcher === \"function\");\n if (functionMatchers.length) {\n let date = range.from;\n const totalDays = dateLib.differenceInCalendarDays(range.to, range.from);\n for (let i = 0; i <= totalDays; i++) {\n if (functionMatchers.some((matcher) => matcher(date))) {\n return true;\n }\n date = dateLib.addDays(date, 1);\n }\n }\n return false;\n}\n//# sourceMappingURL=rangeContainsModifiers.js.map","import { useControlledValue } from \"../helpers/useControlledValue.js\";\nimport { addToRange, rangeContainsModifiers } from \"../utils/index.js\";\nimport { rangeIncludesDate } from \"../utils/rangeIncludesDate.js\";\nexport function useRange(props, dateLib) {\n const { disabled, excludeDisabled, selected: initiallySelected, required, onSelect } = props;\n const [internallySelected, setSelected] = useControlledValue(initiallySelected, onSelect ? initiallySelected : undefined);\n const selected = !onSelect ? internallySelected : initiallySelected;\n const isSelected = (date) => selected && rangeIncludesDate(selected, date, false, dateLib);\n const select = (triggerDate, modifiers, e) => {\n const { min, max } = props;\n const newRange = triggerDate\n ? addToRange(triggerDate, selected, min, max, required, dateLib)\n : undefined;\n if (excludeDisabled && disabled && newRange?.from && newRange.to) {\n if (rangeContainsModifiers({ from: newRange.from, to: newRange.to }, disabled, dateLib)) {\n // if a disabled days is found, the range is reset\n newRange.from = triggerDate;\n newRange.to = undefined;\n }\n }\n if (!onSelect) {\n setSelected(newRange);\n }\n onSelect?.(newRange, triggerDate, modifiers, e);\n return newRange;\n };\n return {\n selected,\n select,\n isSelected\n };\n}\n//# sourceMappingURL=useRange.js.map","import { useControlledValue } from \"../helpers/useControlledValue.js\";\nexport function useSingle(props, dateLib) {\n const { selected: initiallySelected, required, onSelect } = props;\n const [internallySelected, setSelected] = useControlledValue(initiallySelected, onSelect ? initiallySelected : undefined);\n const selected = !onSelect ? internallySelected : initiallySelected;\n const { isSameDay } = dateLib;\n const isSelected = (compareDate) => {\n return selected ? isSameDay(selected, compareDate) : false;\n };\n const select = (triggerDate, modifiers, e) => {\n let newDate = triggerDate;\n if (!required && selected && selected && isSameDay(triggerDate, selected)) {\n // If the date is the same, clear the selection.\n newDate = undefined;\n }\n if (!onSelect) {\n setSelected(newDate);\n }\n if (required) {\n onSelect?.(newDate, triggerDate, modifiers, e);\n }\n else {\n onSelect?.(newDate, triggerDate, modifiers, e);\n }\n return newDate;\n };\n return {\n selected,\n select,\n isSelected\n };\n}\n//# sourceMappingURL=useSingle.js.map","import { useMulti } from \"./selection/useMulti.js\";\nimport { useRange } from \"./selection/useRange.js\";\nimport { useSingle } from \"./selection/useSingle.js\";\nexport function useSelection(props, dateLib) {\n const single = useSingle(props, dateLib);\n const multi = useMulti(props, dateLib);\n const range = useRange(props, dateLib);\n switch (props.mode) {\n case \"single\":\n return single;\n case \"multiple\":\n return multi;\n case \"range\":\n return range;\n default:\n return undefined;\n }\n}\n//# sourceMappingURL=useSelection.js.map","import React, { useCallback, useMemo } from \"react\";\nimport { UI, DayFlag, SelectionState } from \"./UI.js\";\nimport { DateLib, defaultLocale } from \"./classes/DateLib.js\";\nimport { getClassNamesForModifiers } from \"./helpers/getClassNamesForModifiers.js\";\nimport { getComponents } from \"./helpers/getComponents.js\";\nimport { getDataAttributes } from \"./helpers/getDataAttributes.js\";\nimport { getDefaultClassNames } from \"./helpers/getDefaultClassNames.js\";\nimport { getFormatters } from \"./helpers/getFormatters.js\";\nimport { getMonthOptions } from \"./helpers/getMonthOptions.js\";\nimport { getStyleForModifiers } from \"./helpers/getStyleForModifiers.js\";\nimport { getWeekdays } from \"./helpers/getWeekdays.js\";\nimport { getYearOptions } from \"./helpers/getYearOptions.js\";\nimport * as defaultLabels from \"./labels/index.js\";\nimport { useCalendar } from \"./useCalendar.js\";\nimport { dayPickerContext } from \"./useDayPicker.js\";\nimport { useFocus } from \"./useFocus.js\";\nimport { useGetModifiers } from \"./useGetModifiers.js\";\nimport { useSelection } from \"./useSelection.js\";\nimport { rangeIncludesDate } from \"./utils/rangeIncludesDate.js\";\nimport { isDateRange } from \"./utils/typeguards.js\";\n/**\n * Render the date picker calendar.\n *\n * @group DayPicker\n * @see https://daypicker.dev\n */\nexport function DayPicker(props) {\n const { components, formatters, labels, dateLib, locale, classNames } = useMemo(() => {\n const locale = { ...defaultLocale, ...props.locale };\n const dateLib = new DateLib({\n locale,\n weekStartsOn: props.broadcastCalendar ? 1 : props.weekStartsOn,\n firstWeekContainsDate: props.firstWeekContainsDate,\n useAdditionalWeekYearTokens: props.useAdditionalWeekYearTokens,\n useAdditionalDayOfYearTokens: props.useAdditionalDayOfYearTokens\n }, props.dateLib);\n return {\n dateLib,\n components: getComponents(props.components),\n formatters: getFormatters(props.formatters),\n labels: { ...defaultLabels, ...props.labels },\n locale,\n classNames: { ...getDefaultClassNames(), ...props.classNames }\n };\n }, [\n props.classNames,\n props.components,\n props.dateLib,\n props.firstWeekContainsDate,\n props.formatters,\n props.labels,\n props.locale,\n props.useAdditionalDayOfYearTokens,\n props.useAdditionalWeekYearTokens,\n props.weekStartsOn,\n props.broadcastCalendar\n ]);\n const { captionLayout, mode, onDayBlur, onDayClick, onDayFocus, onDayKeyDown, onDayMouseEnter, onDayMouseLeave, onNextClick, onPrevClick, showWeekNumber, styles } = props;\n const { formatCaption, formatDay, formatMonthDropdown, formatWeekNumber, formatWeekNumberHeader, formatWeekdayName, formatYearDropdown } = formatters;\n const calendar = useCalendar(props, dateLib);\n const { days, months, navStart, navEnd, previousMonth, nextMonth, goToMonth } = calendar;\n const getModifiers = useGetModifiers(days, props, dateLib);\n const { isSelected, select, selected: selectedValue } = useSelection(props, dateLib) ?? {};\n const { blur, focused, isFocusTarget, moveFocus, setFocused } = useFocus(props, calendar, getModifiers, isSelected ?? (() => false), dateLib);\n const { labelDayButton, labelGridcell, labelGrid, labelMonthDropdown, labelNav, labelWeekday, labelWeekNumber, labelWeekNumberHeader, labelYearDropdown } = labels;\n const weekdays = useMemo(() => getWeekdays(dateLib, props.ISOWeek, props.timeZone), [dateLib, props.ISOWeek, props.timeZone]);\n const isInteractive = mode !== undefined || onDayClick !== undefined;\n const handlePreviousClick = useCallback(() => {\n if (!previousMonth)\n return;\n goToMonth(previousMonth);\n onPrevClick?.(previousMonth);\n }, [previousMonth, goToMonth, onPrevClick]);\n const handleNextClick = useCallback(() => {\n if (!nextMonth)\n return;\n goToMonth(nextMonth);\n onNextClick?.(nextMonth);\n }, [goToMonth, nextMonth, onNextClick]);\n const handleDayClick = useCallback((day, m) => (e) => {\n e.preventDefault();\n e.stopPropagation();\n setFocused(day);\n select?.(day.date, m, e);\n onDayClick?.(day.date, m, e);\n }, [select, onDayClick, setFocused]);\n const handleDayFocus = useCallback((day, m) => (e) => {\n setFocused(day);\n onDayFocus?.(day.date, m, e);\n }, [onDayFocus, setFocused]);\n const handleDayBlur = useCallback((day, m) => (e) => {\n blur();\n onDayBlur?.(day.date, m, e);\n }, [blur, onDayBlur]);\n const handleDayKeyDown = useCallback((day, modifiers) => (e) => {\n const keyMap = {\n ArrowLeft: [\"day\", props.dir === \"rtl\" ? \"after\" : \"before\"],\n ArrowRight: [\"day\", props.dir === \"rtl\" ? \"before\" : \"after\"],\n ArrowDown: [\"week\", \"after\"],\n ArrowUp: [\"week\", \"before\"],\n PageUp: [e.shiftKey ? \"year\" : \"month\", \"before\"],\n PageDown: [e.shiftKey ? \"year\" : \"month\", \"after\"],\n Home: [\"startOfWeek\", \"before\"],\n End: [\"endOfWeek\", \"after\"]\n };\n if (keyMap[e.key]) {\n e.preventDefault();\n e.stopPropagation();\n const [moveBy, moveDir] = keyMap[e.key];\n moveFocus(moveBy, moveDir);\n }\n onDayKeyDown?.(day.date, modifiers, e);\n }, [moveFocus, onDayKeyDown, props.dir]);\n const handleDayMouseEnter = useCallback((day, modifiers) => (e) => {\n onDayMouseEnter?.(day.date, modifiers, e);\n }, [onDayMouseEnter]);\n const handleDayMouseLeave = useCallback((day, modifiers) => (e) => {\n onDayMouseLeave?.(day.date, modifiers, e);\n }, [onDayMouseLeave]);\n const handleMonthChange = useCallback((date) => (e) => {\n const selectedMonth = Number(e.target.value);\n const month = dateLib.setMonth(dateLib.startOfMonth(date), selectedMonth);\n goToMonth(month);\n }, [dateLib, goToMonth]);\n const handleYearChange = useCallback((date) => (e) => {\n const selectedYear = Number(e.target.value);\n const month = dateLib.setYear(dateLib.startOfMonth(date), selectedYear);\n goToMonth(month);\n }, [dateLib, goToMonth]);\n const { className, style } = useMemo(() => ({\n className: [classNames[UI.Root], props.className]\n .filter(Boolean)\n .join(\" \"),\n style: { ...styles?.[UI.Root], ...props.style }\n }), [classNames, props.className, props.style, styles]);\n const dataAttributes = getDataAttributes(props);\n const contextValue = {\n dayPickerProps: props,\n selected: selectedValue,\n select: select,\n isSelected,\n months,\n nextMonth,\n previousMonth,\n goToMonth,\n getModifiers,\n components,\n classNames,\n styles,\n labels,\n formatters\n };\n return (React.createElement(dayPickerContext.Provider, { value: contextValue },\n React.createElement(components.Root, { className: className, style: style, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, \"aria-label\": props[\"aria-label\"], ...dataAttributes },\n React.createElement(components.Months, { className: classNames[UI.Months], style: styles?.[UI.Months] },\n !props.hideNavigation && (React.createElement(components.Nav, { className: classNames[UI.Nav], style: styles?.[UI.Nav], \"aria-label\": labelNav(), onPreviousClick: handlePreviousClick, onNextClick: handleNextClick, previousMonth: previousMonth, nextMonth: nextMonth })),\n months.map((calendarMonth, displayIndex) => {\n const dropdownMonths = getMonthOptions(calendarMonth.date, navStart, navEnd, formatters, dateLib);\n const dropdownYears = getYearOptions(navStart, navEnd, formatters, dateLib);\n return (React.createElement(components.Month, { className: classNames[UI.Month], style: styles?.[UI.Month], key: displayIndex, displayIndex: displayIndex, calendarMonth: calendarMonth },\n React.createElement(components.MonthCaption, { className: classNames[UI.MonthCaption], style: styles?.[UI.MonthCaption], calendarMonth: calendarMonth, displayIndex: displayIndex }, captionLayout?.startsWith(\"dropdown\") ? (React.createElement(components.DropdownNav, { className: classNames[UI.Dropdowns], style: styles?.[UI.Dropdowns] },\n captionLayout === \"dropdown\" ||\n captionLayout === \"dropdown-months\" ? (React.createElement(components.MonthsDropdown, { className: classNames[UI.MonthsDropdown], \"aria-label\": labelMonthDropdown(), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleMonthChange(calendarMonth.date), options: dropdownMonths, style: styles?.[UI.Dropdown], value: calendarMonth.date.getMonth() })) : (React.createElement(\"span\", { role: \"status\", \"aria-live\": \"polite\" }, formatMonthDropdown(calendarMonth.date.getMonth(), locale))),\n captionLayout === \"dropdown\" ||\n captionLayout === \"dropdown-years\" ? (React.createElement(components.YearsDropdown, { className: classNames[UI.YearsDropdown], \"aria-label\": labelYearDropdown(dateLib.options), classNames: classNames, components: components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: dropdownYears, style: styles?.[UI.Dropdown], value: calendarMonth.date.getFullYear() })) : (React.createElement(\"span\", { role: \"status\", \"aria-live\": \"polite\" }, formatYearDropdown(calendarMonth.date.getFullYear()))))) : (React.createElement(components.CaptionLabel, { className: classNames[UI.CaptionLabel], role: \"status\", \"aria-live\": \"polite\" }, formatCaption(calendarMonth.date, dateLib.options, dateLib)))),\n React.createElement(components.MonthGrid, { role: \"grid\", \"aria-multiselectable\": mode === \"multiple\" || mode === \"range\", \"aria-label\": labelGrid(calendarMonth.date, dateLib.options, dateLib) ||\n undefined, className: classNames[UI.MonthGrid], style: styles?.[UI.MonthGrid] },\n !props.hideWeekdays && (React.createElement(components.Weekdays, { className: classNames[UI.Weekdays], style: styles?.[UI.Weekdays] },\n showWeekNumber && (React.createElement(components.WeekNumberHeader, { \"aria-label\": labelWeekNumberHeader(dateLib.options), className: classNames[UI.WeekNumberHeader], style: styles?.[UI.WeekNumberHeader], scope: \"col\" }, formatWeekNumberHeader())),\n weekdays.map((weekday, i) => (React.createElement(components.Weekday, { \"aria-label\": labelWeekday(weekday, dateLib.options, dateLib), className: classNames[UI.Weekday], key: i, style: styles?.[UI.Weekday], scope: \"col\" }, formatWeekdayName(weekday, dateLib.options, dateLib)))))),\n React.createElement(components.Weeks, { className: classNames[UI.Weeks], style: styles?.[UI.Weeks] }, calendarMonth.weeks.map((week, weekIndex) => {\n return (React.createElement(components.Week, { className: classNames[UI.Week], key: week.weekNumber, style: styles?.[UI.Week], week: week },\n showWeekNumber && (React.createElement(components.WeekNumber, { week: week, style: styles?.[UI.WeekNumber], \"aria-label\": labelWeekNumber(week.weekNumber, {\n locale\n }), className: classNames[UI.WeekNumber], scope: \"row\", role: \"rowheader\" }, formatWeekNumber(week.weekNumber))),\n week.days.map((day) => {\n const { date } = day;\n const modifiers = getModifiers(day);\n modifiers[DayFlag.focused] =\n !modifiers.hidden &&\n Boolean(focused?.isEqualTo(day));\n modifiers[SelectionState.selected] =\n !modifiers.disabled &&\n (isSelected?.(date) || modifiers.selected);\n if (isDateRange(selectedValue)) {\n // add range modifiers\n const { from, to } = selectedValue;\n modifiers[SelectionState.range_start] = Boolean(from && to && dateLib.isSameDay(date, from));\n modifiers[SelectionState.range_end] = Boolean(from && to && dateLib.isSameDay(date, to));\n modifiers[SelectionState.range_middle] =\n rangeIncludesDate(selectedValue, date, true, dateLib);\n }\n const style = getStyleForModifiers(modifiers, styles, props.modifiersStyles);\n const className = getClassNamesForModifiers(modifiers, classNames, props.modifiersClassNames);\n const ariaLabel = !isInteractive && !modifiers.hidden\n ? labelGridcell(date, modifiers, dateLib.options, dateLib)\n : undefined;\n return (React.createElement(components.Day, { key: `${dateLib.format(date, \"yyyy-MM-dd\")}_${dateLib.format(day.displayMonth, \"yyyy-MM\")}`, day: day, modifiers: modifiers, className: className.join(\" \"), style: style, role: \"gridcell\", \"aria-selected\": modifiers.selected || undefined, \"aria-label\": ariaLabel, \"data-day\": dateLib.format(date, \"yyyy-MM-dd\"), \"data-month\": day.outside\n ? dateLib.format(date, \"yyyy-MM\")\n : undefined, \"data-selected\": modifiers.selected || undefined, \"data-disabled\": modifiers.disabled || undefined, \"data-hidden\": modifiers.hidden || undefined, \"data-outside\": day.outside || undefined, \"data-focused\": modifiers.focused || undefined, \"data-today\": modifiers.today || undefined }, !modifiers.hidden && isInteractive ? (React.createElement(components.DayButton, { className: classNames[UI.DayButton], style: styles?.[UI.DayButton], type: \"button\", day: day, modifiers: modifiers, disabled: modifiers.disabled || undefined, tabIndex: isFocusTarget(day) ? 0 : -1, \"aria-label\": labelDayButton(date, modifiers, dateLib.options, dateLib), onClick: handleDayClick(day, modifiers), onBlur: handleDayBlur(day, modifiers), onFocus: handleDayFocus(day, modifiers), onKeyDown: handleDayKeyDown(day, modifiers), onMouseEnter: handleDayMouseEnter(day, modifiers), onMouseLeave: handleDayMouseLeave(day, modifiers) }, formatDay(date, dateLib.options, dateLib))) : (!modifiers.hidden &&\n formatDay(day.date, dateLib.options, dateLib))));\n })));\n })))));\n })),\n props.footer && (React.createElement(components.Footer, { className: classNames[UI.Footer], style: styles?.[UI.Footer], role: \"status\", \"aria-live\": \"polite\" }, props.footer)))));\n}\n//# sourceMappingURL=DayPicker.js.map"],"names":["UI","DayFlag","SelectionState","millisecondsInWeek","millisecondsInDay","constructFromSymbol","constructFrom","date","value","toDate","argument","context","addDays","amount","options","_date","addMonths","dayOfMonth","endOfDesiredMonth","daysInMonth","defaultOptions","getDefaultOptions","startOfWeek","weekStartsOn","_b","_a","_d","_c","day","diff","startOfISOWeek","getISOWeekYear","year","fourthOfJanuaryOfNextYear","startOfNextYear","fourthOfJanuaryOfThisYear","startOfThisYear","getTimezoneOffsetInMilliseconds","utcDate","normalizeDates","dates","normalize","startOfDay","differenceInCalendarDays","laterDate","earlierDate","laterDate_","earlierDate_","laterStartOfDay","earlierStartOfDay","laterTimestamp","earlierTimestamp","startOfISOWeekYear","fourthOfJanuary","addWeeks","addYears","max","result","date_","min","isSameDay","dateLeft_","dateRight_","isDate","isValid","differenceInCalendarMonths","yearsDiff","monthsDiff","endOfMonth","month","startOfMonth","endOfYear","startOfYear","endOfWeek","endOfISOWeek","formatDistanceLocale","formatDistance","token","count","tokenValue","buildFormatLongFn","args","width","dateFormats","timeFormats","dateTimeFormats","formatLong","formatRelativeLocale","formatRelative","_baseDate","_options","buildLocalizeFn","valuesArray","defaultWidth","index","eraValues","quarterValues","monthValues","dayValues","dayPeriodValues","formattingDayPeriodValues","ordinalNumber","dirtyNumber","number","rem100","localize","quarter","buildMatchFn","string","matchPattern","matchResult","matchedString","parsePatterns","key","findIndex","pattern","findKey","rest","object","predicate","array","buildMatchPatternFn","parseResult","matchOrdinalNumberPattern","parseOrdinalNumberPattern","matchEraPatterns","parseEraPatterns","matchQuarterPatterns","parseQuarterPatterns","matchMonthPatterns","parseMonthPatterns","matchDayPatterns","parseDayPatterns","matchDayPeriodPatterns","parseDayPeriodPatterns","match","enUS","getDayOfYear","getISOWeek","getWeekYear","firstWeekContainsDate","firstWeekOfNextYear","firstWeekOfThisYear","startOfWeekYear","firstWeek","getWeek","addLeadingZeros","targetLength","sign","output","lightFormatters","signedYear","dayPeriodEnumValue","numberOfDigits","milliseconds","fractionalSeconds","dayPeriodEnum","formatters","era","signedWeekYear","weekYear","twoDigitYear","isoWeekYear","week","isoWeek","dayOfYear","dayOfWeek","localDayOfWeek","isoDayOfWeek","hours","_localize","timezoneOffset","formatTimezoneWithOptionalMinutes","formatTimezone","formatTimezoneShort","timestamp","offset","delimiter","absOffset","minutes","dateLongFormatter","timeLongFormatter","dateTimeLongFormatter","datePattern","timePattern","dateTimeFormat","longFormatters","dayOfYearTokenRE","weekYearTokenRE","throwTokens","isProtectedDayOfYearToken","isProtectedWeekYearToken","warnOrThrowProtectedError","format","input","_message","message","subject","formattingTokensRegExp","longFormattingTokensRegExp","escapedStringRegExp","doubleQuoteRegExp","unescapedLatinCharacterRegExp","formatStr","locale","defaultLocale","_f","_e","_h","_g","originalDate","parts","substring","firstCharacter","longFormatter","cleanEscapedString","formatterOptions","part","formatter","matched","getDaysInMonth","monthIndex","lastDayOfMonth","isAfter","dateToCompare","isBefore","isSameMonth","isSameYear","setMonth","midMonth","setYear","FIVE_WEEKS","FOUR_WEEKS","getBroadcastWeeksInMonth","dateLib","firstDayOfMonth","firstDayOfWeek","broadcastStartDate","lastDateOfLastWeek","startOfBroadcastWeek","firstOfMonth","endOfBroadcastWeek","startDate","numberOfWeeks","DateLib","overrides","dateLeft","dateRight","defaultDateLib","getClassNamesForModifiers","modifiers","classNames","modifiersClassNames","active","previousValue","Button","props","React","CaptionLabel","Chevron","size","orientation","className","Day","tdProps","DayButton","buttonProps","ref","Dropdown","components","selectProps","cssClassSelect","selectedOption","label","disabled","DropdownNav","Footer","Month","calendarMonth","displayIndex","divProps","MonthCaption","MonthGrid","Months","dayPickerContext","createContext","useDayPicker","useContext","MonthsDropdown","Nav","onPreviousClick","onNextClick","previousMonth","nextMonth","navProps","labelPrevious","labelNext","NextMonthButton","Option","PreviousMonthButton","Root","Select","Week","trProps","Weekday","Weekdays","WeekNumber","thProps","WeekNumberHeader","Weeks","YearsDropdown","getComponents","customComponents","getDataAttributes","dataAttributes","val","getDefaultClassNames","formatCaption","formatMonthCaption","formatDay","formatMonthDropdown","monthNumber","formatWeekNumber","weekNumber","formatWeekNumberHeader","formatWeekdayName","weekday","formatYearDropdown","formatYearCaption","getFormatters","customFormatters","defaultFormatters","getMonthOptions","displayMonth","navStart","navEnd","months","a","b","getStyleForModifiers","dayModifiers","styles","modifiersStyles","style","modifier","offsetFormatCache","offsetCache","tzOffset","timeZone","offsetStr","calcOffset","captures","offsetRe","cacheStr","values","TZDateMini","adjustToSystemTZ","syncToInternal","tz","time","re","method","utcMethod","syncFromInternal","prevHour","systemOffset","prevHourSystemOffset","systemDSTChange","dstShift","offsetDiff","postOffset","postOffsetDiff","offsetChanged","postDiff","newOffset","offsetChange","TZDate","tzName","locales","getWeekdays","ISOWeek","broadcastCalendar","start","days","i","getYearOptions","firstNavYear","lastNavYear","years","labelGrid","labelCaption","labelGridcell","labelDayButton","labelDay","labelNav","labelMonthDropdown","labelWeekday","labelWeekNumber","labelWeekNumberHeader","labelYearDropdown","getDates","displayMonths","maxDate","firstMonth","lastMonth","fixedWeeks","startWeekFirstDate","endWeekLastDate","nOfDays","nOfMonths","extraDates","daysToAdd","getDays","calendarMonths","initialDays","weekDays","getDisplayMonths","firstDisplayedMonth","calendarEndMonth","numberOfMonths","getInitialMonth","defaultMonth","today","endMonth","startMonth","initialMonth","CalendarDay","CalendarMonth","weeks","CalendarWeek","getMonths","dayPickerMonths","firstDateOfFirstWeek","monthDates","nrOfDaysWithFixedWeeks","dayPickerMonth","getNavMonths","fromYear","toYear","fromMonth","toMonth","hasDropdowns","getNextMonth","pagedNavigation","getPreviousMonth","calendarStartMonth","getWeeks","initialWeeks","useControlledValue","defaultValue","controlledValue","uncontrolledValue","setValue","useState","useCalendar","setFirstMonth","useEffect","newInitialMonth","disableNavigation","onMonthChange","isDayInCalendar","d","goToMonth","newMonth","calculateFocusTarget","getModifiers","isSelected","lastFocused","focusTarget","found","m","rangeIncludesDate","range","excludeEnds","from","to","isDateInterval","matcher","isDateRange","isDateAfterType","isDateBeforeType","isDayOfWeekType","isDatesArray","dateMatchModifiers","matchers","matchersArr","diffBefore","diffAfter","isDayBefore","isDayAfter","getFocusableDate","moveBy","moveDir","refDate","focusableDate","getNextFocus","refDay","attempt","isDisabled","isHidden","targetMonth","focusDay","useFocus","calendar","autoFocus","setLastFocused","focusedDay","setFocused","nextFocus","useGetModifiers","hidden","showOutsideDays","internalModifiersMap","customModifiersMap","isOutside","isBeforeStartMonth","isAfterEndMonth","isToday","name","modifierValue","dayFlags","customModifiers","useMulti","initiallySelected","required","onSelect","internallySelected","setSelected","selected","triggerDate","e","newDates","addToRange","initialRange","rangeContainsDayOfWeek","dayOfWeekArr","totalDays","totalDaysLimit","rangeOverlaps","rangeLeft","rangeRight","rangeContainsModifiers","functionMatchers","useRange","excludeDisabled","newRange","useSingle","newDate","compareDate","useSelection","single","multi","DayPicker","labels","useMemo","defaultLabels","captionLayout","mode","onDayBlur","onDayClick","onDayFocus","onDayKeyDown","onDayMouseEnter","onDayMouseLeave","onPrevClick","showWeekNumber","select","selectedValue","blur","focused","isFocusTarget","moveFocus","weekdays","isInteractive","handlePreviousClick","useCallback","handleNextClick","handleDayClick","handleDayFocus","handleDayBlur","handleDayKeyDown","keyMap","handleDayMouseEnter","handleDayMouseLeave","handleMonthChange","selectedMonth","handleYearChange","selectedYear","contextValue","dropdownMonths","dropdownYears","weekIndex","ariaLabel"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148]}