{"version":3,"file":"public-date-fns.js","sources":["webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/_lib/defaultOptions.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/_lib/format/longFormatters.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/_lib/protectedTokens.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/addDays.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/addHours.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/addMilliseconds.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/addMinutes.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/addMonths.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/addQuarters.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/addSeconds.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/addWeeks.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/addYears.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/constants.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/constructFrom.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/differenceInCalendarDays.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/differenceInCalendarMonths.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/differenceInCalendarQuarters.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/differenceInCalendarYears.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/differenceInDays.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/endOfDay.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/endOfMonth.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/endOfWeek.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/endOfYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/_lib/addLeadingZeros.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/_lib/format/lightFormatters.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/_lib/format/formatters.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getDayOfYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/format.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getDate.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getDay.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getHours.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getISOWeek.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/startOfISOWeekYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getISOWeekYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getMinutes.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getMonth.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getQuarter.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getSeconds.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getTime.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getWeek.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/startOfWeekYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getWeekYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isAfter.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isBefore.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isDate.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isEqual.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isSameDay.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isSameMonth.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isSameQuarter.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isSameYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isValid.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/isWithinInterval.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/_lib/buildMatchPatternFn.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/en-US/_lib/formatDistance.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/_lib/buildFormatLongFn.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/en-US/_lib/formatLong.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/en-US/_lib/formatRelative.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/_lib/buildLocalizeFn.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/_lib/buildMatchFn.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/en-US.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/en-US/_lib/localize.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/locale/en-US/_lib/match.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/max.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/min.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/Setter.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/transpose.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/Parser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/constants.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/utils.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/DateParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setDay.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/EraParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/YearParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/LocalWeekYearParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/ISOWeekYearParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/ExtendedYearParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/QuarterParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/StandAloneQuarterParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/MonthParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/StandAloneMonthParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/LocalWeekParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setWeek.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/ISOWeekParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setISOWeek.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/DayOfYearParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/DayParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/LocalDayParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/StandAloneLocalDayParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/ISODayParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setISODay.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getISODay.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/AMPMParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/AMPMMidnightParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/DayPeriodParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/Hour1to12Parser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/Hour0to23Parser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/Hour0To11Parser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/Hour1To24Parser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/MinuteParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/SecondParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/FractionOfSecondParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/ISOTimezoneWithZParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/ISOTimezoneParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/TimestampSecondsParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse/_lib/parsers/TimestampMillisecondsParser.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parse.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getDefaultOptions.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/parseISO.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/set.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setHours.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setMinutes.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setMonth.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/getDaysInMonth.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setQuarter.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setSeconds.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/setYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/startOfDay.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/startOfISOWeek.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/startOfMonth.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/startOfQuarter.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/startOfWeek.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/startOfYear.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/subDays.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/subMonths.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/subQuarters.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/subWeeks.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/subYears.mjs","webpack://pp-bos/./node_modules/.pnpm/date-fns@3.6.0/node_modules/date-fns/toDate.mjs"],"sourcesContent":["let defaultOptions = {};\n\nexport function getDefaultOptions() {\n return defaultOptions;\n}\n\nexport function setDefaultOptions(newOptions) {\n defaultOptions = newOptions;\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","import { toDate } from \"../toDate.mjs\";\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","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 { toDate } from \"./toDate.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\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 *\n * @param date - The date to be changed\n * @param amount - The amount of days to be added.\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) {\n const _date = toDate(date);\n if (isNaN(amount)) return constructFrom(date, NaN);\n if (!amount) {\n // If 0 days, no-op to avoid changing times in the hour before end of DST\n return _date;\n }\n _date.setDate(_date.getDate() + amount);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default addDays;\n","import { addMilliseconds } from \"./addMilliseconds.mjs\";\nimport { millisecondsInHour } from \"./constants.mjs\";\n\n/**\n * @name addHours\n * @category Hour Helpers\n * @summary Add the specified number of hours to the given date.\n *\n * @description\n * Add the specified number of hours 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 *\n * @param date - The date to be changed\n * @param amount - The amount of hours to be added.\n *\n * @returns The new date with the hours added\n *\n * @example\n * // Add 2 hours to 10 July 2014 23:00:00:\n * const result = addHours(new Date(2014, 6, 10, 23, 0), 2)\n * //=> Fri Jul 11 2014 01:00:00\n */\nexport function addHours(date, amount) {\n return addMilliseconds(date, amount * millisecondsInHour);\n}\n\n// Fallback for modularized imports:\nexport default addHours;\n","import { toDate } from \"./toDate.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\n\n/**\n * @name addMilliseconds\n * @category Millisecond Helpers\n * @summary Add the specified number of milliseconds to the given date.\n *\n * @description\n * Add the specified number of milliseconds 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 *\n * @param date - The date to be changed\n * @param amount - The amount of milliseconds to be added.\n *\n * @returns The new date with the milliseconds added\n *\n * @example\n * // Add 750 milliseconds to 10 July 2014 12:45:30.000:\n * const result = addMilliseconds(new Date(2014, 6, 10, 12, 45, 30, 0), 750)\n * //=> Thu Jul 10 2014 12:45:30.750\n */\nexport function addMilliseconds(date, amount) {\n const timestamp = +toDate(date);\n return constructFrom(date, timestamp + amount);\n}\n\n// Fallback for modularized imports:\nexport default addMilliseconds;\n","import { addMilliseconds } from \"./addMilliseconds.mjs\";\nimport { millisecondsInMinute } from \"./constants.mjs\";\n\n/**\n * @name addMinutes\n * @category Minute Helpers\n * @summary Add the specified number of minutes to the given date.\n *\n * @description\n * Add the specified number of minutes 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 *\n * @param date - The date to be changed\n * @param amount - The amount of minutes to be added.\n *\n * @returns The new date with the minutes added\n *\n * @example\n * // Add 30 minutes to 10 July 2014 12:00:00:\n * const result = addMinutes(new Date(2014, 6, 10, 12, 0), 30)\n * //=> Thu Jul 10 2014 12:30:00\n */\nexport function addMinutes(date, amount) {\n return addMilliseconds(date, amount * millisecondsInMinute);\n}\n\n// Fallback for modularized imports:\nexport default addMinutes;\n","import { toDate } from \"./toDate.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\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 *\n * @param date - The date to be changed\n * @param amount - The amount of months to be added.\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) {\n const _date = toDate(date);\n if (isNaN(amount)) return constructFrom(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(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","import { addMonths } from \"./addMonths.mjs\";\n\n/**\n * @name addQuarters\n * @category Quarter Helpers\n * @summary Add the specified number of year quarters to the given date.\n *\n * @description\n * Add the specified number of year quarters 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 *\n * @param date - The date to be changed\n * @param amount - The amount of quarters to be added.\n *\n * @returns The new date with the quarters added\n *\n * @example\n * // Add 1 quarter to 1 September 2014:\n * const result = addQuarters(new Date(2014, 8, 1), 1)\n * //=> Mon Dec 01 2014 00:00:00\n */\nexport function addQuarters(date, amount) {\n const months = amount * 3;\n return addMonths(date, months);\n}\n\n// Fallback for modularized imports:\nexport default addQuarters;\n","import { addMilliseconds } from \"./addMilliseconds.mjs\";\n\n/**\n * @name addSeconds\n * @category Second Helpers\n * @summary Add the specified number of seconds to the given date.\n *\n * @description\n * Add the specified number of seconds 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 *\n * @param date - The date to be changed\n * @param amount - The amount of seconds to be added.\n *\n * @returns The new date with the seconds added\n *\n * @example\n * // Add 30 seconds to 10 July 2014 12:45:00:\n * const result = addSeconds(new Date(2014, 6, 10, 12, 45, 0), 30)\n * //=> Thu Jul 10 2014 12:45:30\n */\nexport function addSeconds(date, amount) {\n return addMilliseconds(date, amount * 1000);\n}\n\n// Fallback for modularized imports:\nexport default addSeconds;\n","import { addDays } from \"./addDays.mjs\";\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 week 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 *\n * @param date - The date to be changed\n * @param amount - The amount of weeks to be added.\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) {\n const days = amount * 7;\n return addDays(date, days);\n}\n\n// Fallback for modularized imports:\nexport default addWeeks;\n","import { addMonths } from \"./addMonths.mjs\";\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 *\n * @param date - The date to be changed\n * @param amount - The amount of years to be added.\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) {\n return addMonths(date, amount * 12);\n}\n\n// Fallback for modularized imports:\nexport default addYears;\n","/**\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 occures every 4 years, except for years that are divisable by 100 and not divisable 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 * @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 * @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 'date-fns'\n *\n * // A function that clones a date preserving the original type\n * function cloneDate 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(dateLeft, dateRight) {\n const startOfDayLeft = startOfDay(dateLeft);\n const startOfDayRight = startOfDay(dateRight);\n\n const timestampLeft =\n +startOfDayLeft - getTimezoneOffsetInMilliseconds(startOfDayLeft);\n const timestampRight =\n +startOfDayRight - getTimezoneOffsetInMilliseconds(startOfDayRight);\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((timestampLeft - timestampRight) / millisecondsInDay);\n}\n\n// Fallback for modularized imports:\nexport default differenceInCalendarDays;\n","import { toDate } from \"./toDate.mjs\";\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 * @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 dateLeft - The later date\n * @param dateRight - The earlier date\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(dateLeft, dateRight) {\n const _dateLeft = toDate(dateLeft);\n const _dateRight = toDate(dateRight);\n\n const yearDiff = _dateLeft.getFullYear() - _dateRight.getFullYear();\n const monthDiff = _dateLeft.getMonth() - _dateRight.getMonth();\n\n return yearDiff * 12 + monthDiff;\n}\n\n// Fallback for modularized imports:\nexport default differenceInCalendarMonths;\n","import { getQuarter } from \"./getQuarter.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name differenceInCalendarQuarters\n * @category Quarter Helpers\n * @summary Get the number of calendar quarters between the given dates.\n *\n * @description\n * Get the number of calendar quarters between 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 *\n * @param dateLeft - The later date\n * @param dateRight - The earlier date\n\n * @returns The number of calendar quarters\n *\n * @example\n * // How many calendar quarters are between 31 December 2013 and 2 July 2014?\n * const result = differenceInCalendarQuarters(\n * new Date(2014, 6, 2),\n * new Date(2013, 11, 31)\n * )\n * //=> 3\n */\nexport function differenceInCalendarQuarters(dateLeft, dateRight) {\n const _dateLeft = toDate(dateLeft);\n const _dateRight = toDate(dateRight);\n\n const yearDiff = _dateLeft.getFullYear() - _dateRight.getFullYear();\n const quarterDiff = getQuarter(_dateLeft) - getQuarter(_dateRight);\n\n return yearDiff * 4 + quarterDiff;\n}\n\n// Fallback for modularized imports:\nexport default differenceInCalendarQuarters;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name differenceInCalendarYears\n * @category Year Helpers\n * @summary Get the number of calendar years between the given dates.\n *\n * @description\n * Get the number of calendar years between 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 *\n * @param dateLeft - The later date\n * @param dateRight - The earlier date\n\n * @returns The number of calendar years\n *\n * @example\n * // How many calendar years are between 31 December 2013 and 11 February 2015?\n * const result = differenceInCalendarYears(\n * new Date(2015, 1, 11),\n * new Date(2013, 11, 31)\n * )\n * //=> 2\n */\nexport function differenceInCalendarYears(dateLeft, dateRight) {\n const _dateLeft = toDate(dateLeft);\n const _dateRight = toDate(dateRight);\n\n return _dateLeft.getFullYear() - _dateRight.getFullYear();\n}\n\n// Fallback for modularized imports:\nexport default differenceInCalendarYears;\n","import { differenceInCalendarDays } from \"./differenceInCalendarDays.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name differenceInDays\n * @category Day Helpers\n * @summary Get the number of full days between the given dates.\n *\n * @description\n * Get the number of full day periods between two dates. Fractional days are\n * truncated towards zero.\n *\n * One \"full day\" is the distance between a local time in one day to the same\n * local time on the next or previous day. A full day can sometimes be less than\n * or more than 24 hours if a daylight savings change happens between two dates.\n *\n * To ignore DST and only measure exact 24-hour periods, use this instead:\n * `Math.trunc(differenceInHours(dateLeft, dateRight)/24)|0`.\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 dateLeft - The later date\n * @param dateRight - The earlier date\n *\n * @returns The number of full days according to the local timezone\n *\n * @example\n * // How many full days are between\n * // 2 July 2011 23:00:00 and 2 July 2012 00:00:00?\n * const result = differenceInDays(\n * new Date(2012, 6, 2, 0, 0),\n * new Date(2011, 6, 2, 23, 0)\n * )\n * //=> 365\n *\n * @example\n * // How many full days are between\n * // 2 July 2011 23:59:00 and 3 July 2011 00:01:00?\n * const result = differenceInDays(\n * new Date(2011, 6, 3, 0, 1),\n * new Date(2011, 6, 2, 23, 59)\n * )\n * //=> 0\n *\n * @example\n * // How many full days are between\n * // 1 March 2020 0:00 and 1 June 2020 0:00 ?\n * // Note: because local time is used, the\n * // result will always be 92 days, even in\n * // time zones where DST starts and the\n * // period has only 92*24-1 hours.\n * const result = differenceInDays(\n * new Date(2020, 5, 1),\n * new Date(2020, 2, 1)\n * )\n * //=> 92\n */\nexport function differenceInDays(dateLeft, dateRight) {\n const _dateLeft = toDate(dateLeft);\n const _dateRight = toDate(dateRight);\n\n const sign = compareLocalAsc(_dateLeft, _dateRight);\n const difference = Math.abs(differenceInCalendarDays(_dateLeft, _dateRight));\n\n _dateLeft.setDate(_dateLeft.getDate() - sign * difference);\n\n // Math.abs(diff in full days - diff in calendar days) === 1 if last calendar day is not full\n // If so, result must be decreased by 1 in absolute value\n const isLastDayNotFull = Number(\n compareLocalAsc(_dateLeft, _dateRight) === -sign,\n );\n const result = sign * (difference - isLastDayNotFull);\n // Prevent negative zero\n return result === 0 ? 0 : result;\n}\n\n// Like `compareAsc` but uses local time not UTC, which is needed\n// for accurate equality comparisons of UTC timestamps that end up\n// having the same representation in local time, e.g. one hour before\n// DST ends vs. the instant that DST ends.\nfunction compareLocalAsc(dateLeft, dateRight) {\n const diff =\n dateLeft.getFullYear() - dateRight.getFullYear() ||\n dateLeft.getMonth() - dateRight.getMonth() ||\n dateLeft.getDate() - dateRight.getDate() ||\n dateLeft.getHours() - dateRight.getHours() ||\n dateLeft.getMinutes() - dateRight.getMinutes() ||\n dateLeft.getSeconds() - dateRight.getSeconds() ||\n dateLeft.getMilliseconds() - dateRight.getMilliseconds();\n\n if (diff < 0) {\n return -1;\n } else if (diff > 0) {\n return 1;\n // Return 0 if diff is 0; return NaN if diff is NaN\n } else {\n return diff;\n }\n}\n\n// Fallback for modularized imports:\nexport default differenceInDays;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name endOfDay\n * @category Day Helpers\n * @summary Return the end of a day for the given date.\n *\n * @description\n * Return the end 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 *\n * @param date - The original date\n *\n * @returns The end of a day\n *\n * @example\n * // The end of a day for 2 September 2014 11:55:00:\n * const result = endOfDay(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Tue Sep 02 2014 23:59:59.999\n */\nexport function endOfDay(date) {\n const _date = toDate(date);\n _date.setHours(23, 59, 59, 999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfDay;\n","import { toDate } from \"./toDate.mjs\";\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 *\n * @param date - The original date\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) {\n const _date = toDate(date);\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.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\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 *\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);\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 { toDate } from \"./toDate.mjs\";\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 *\n * @param date - The original date\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, 00))\n * //=> Wed Dec 31 2014 23:59:59.999\n */\nexport function endOfYear(date) {\n const _date = toDate(date);\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","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.mjs\";\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.mjs\";\nimport { getISOWeek } from \"../../getISOWeek.mjs\";\nimport { getISOWeekYear } from \"../../getISOWeekYear.mjs\";\nimport { getWeek } from \"../../getWeek.mjs\";\nimport { getWeekYear } from \"../../getWeekYear.mjs\";\nimport { addLeadingZeros } from \"../addLeadingZeros.mjs\";\nimport { lightFormatters } from \"./lightFormatters.mjs\";\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.getTime() / 1000);\n return addLeadingZeros(timestamp, token.length);\n },\n\n // Milliseconds timestamp\n T: function (date, token, _localize) {\n const timestamp = date.getTime();\n return addLeadingZeros(timestamp, 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","import { differenceInCalendarDays } from \"./differenceInCalendarDays.mjs\";\nimport { startOfYear } from \"./startOfYear.mjs\";\nimport { toDate } from \"./toDate.mjs\";\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 * @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 given date\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) {\n const _date = toDate(date);\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 { defaultLocale } from \"./_lib/defaultLocale.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\nimport { formatters } from \"./_lib/format/formatters.mjs\";\nimport { longFormatters } from \"./_lib/format/longFormatters.mjs\";\nimport {\n isProtectedDayOfYearToken,\n isProtectedWeekYearToken,\n warnOrThrowProtectedError,\n} from \"./_lib/protectedTokens.mjs\";\nimport { isValid } from \"./isValid.mjs\";\nimport { toDate } from \"./toDate.mjs\";\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 * @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 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);\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 { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getDate\n * @category Day Helpers\n * @summary Get the day of the month of the given date.\n *\n * @description\n * Get the day of the month of 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 *\n * @param date - The given date\n *\n * @returns The day of month\n *\n * @example\n * // Which day of the month is 29 February 2012?\n * const result = getDate(new Date(2012, 1, 29))\n * //=> 29\n */\nexport function getDate(date) {\n const _date = toDate(date);\n const dayOfMonth = _date.getDate();\n return dayOfMonth;\n}\n\n// Fallback for modularized imports:\nexport default getDate;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getDay\n * @category Weekday Helpers\n * @summary Get the day of the week of the given date.\n *\n * @description\n * Get the day of the week of 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 *\n * @param date - The given date\n *\n * @returns The day of week, 0 represents Sunday\n *\n * @example\n * // Which day of the week is 29 February 2012?\n * const result = getDay(new Date(2012, 1, 29))\n * //=> 3\n */\nexport function getDay(date) {\n const _date = toDate(date);\n const day = _date.getDay();\n return day;\n}\n\n// Fallback for modularized imports:\nexport default getDay;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getHours\n * @category Hour Helpers\n * @summary Get the hours of the given date.\n *\n * @description\n * Get the hours of 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 *\n * @param date - The given date\n *\n * @returns The hours\n *\n * @example\n * // Get the hours of 29 February 2012 11:45:00:\n * const result = getHours(new Date(2012, 1, 29, 11, 45))\n * //=> 11\n */\nexport function getHours(date) {\n const _date = toDate(date);\n const hours = _date.getHours();\n return hours;\n}\n\n// Fallback for modularized imports:\nexport default getHours;\n","import { millisecondsInWeek } from \"./constants.mjs\";\nimport { startOfISOWeek } from \"./startOfISOWeek.mjs\";\nimport { startOfISOWeekYear } from \"./startOfISOWeekYear.mjs\";\nimport { toDate } from \"./toDate.mjs\";\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 * @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 given date\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) {\n const _date = toDate(date);\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 { getISOWeekYear } from \"./getISOWeekYear.mjs\";\nimport { startOfISOWeek } from \"./startOfISOWeek.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\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 *\n * @param date - The original date\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) {\n const year = getISOWeekYear(date);\n const fourthOfJanuary = constructFrom(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 { constructFrom } from \"./constructFrom.mjs\";\nimport { startOfISOWeek } from \"./startOfISOWeek.mjs\";\nimport { toDate } from \"./toDate.mjs\";\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 * @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 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) {\n const _date = toDate(date);\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.mjs\";\n\n/**\n * @name getMinutes\n * @category Minute Helpers\n * @summary Get the minutes of the given date.\n *\n * @description\n * Get the minutes of 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 *\n * @param date - The given date\n *\n * @returns The minutes\n *\n * @example\n * // Get the minutes of 29 February 2012 11:45:05:\n * const result = getMinutes(new Date(2012, 1, 29, 11, 45, 5))\n * //=> 45\n */\nexport function getMinutes(date) {\n const _date = toDate(date);\n const minutes = _date.getMinutes();\n return minutes;\n}\n\n// Fallback for modularized imports:\nexport default getMinutes;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getMonth\n * @category Month Helpers\n * @summary Get the month of the given date.\n *\n * @description\n * Get the month of 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 *\n * @param date - The given date\n *\n * @returns The month index (0-11)\n *\n * @example\n * // Which month is 29 February 2012?\n * const result = getMonth(new Date(2012, 1, 29))\n * //=> 1\n */\nexport function getMonth(date) {\n const _date = toDate(date);\n const month = _date.getMonth();\n return month;\n}\n\n// Fallback for modularized imports:\nexport default getMonth;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getQuarter\n * @category Quarter Helpers\n * @summary Get the year quarter of the given date.\n *\n * @description\n * Get the year quarter of 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 *\n * @param date - The given date\n *\n * @returns The quarter\n *\n * @example\n * // Which quarter is 2 July 2014?\n * const result = getQuarter(new Date(2014, 6, 2))\n * //=> 3\n */\nexport function getQuarter(date) {\n const _date = toDate(date);\n const quarter = Math.trunc(_date.getMonth() / 3) + 1;\n return quarter;\n}\n\n// Fallback for modularized imports:\nexport default getQuarter;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getSeconds\n * @category Second Helpers\n * @summary Get the seconds of the given date.\n *\n * @description\n * Get the seconds of 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 *\n * @param date - The given date\n *\n * @returns The seconds\n *\n * @example\n * // Get the seconds of 29 February 2012 11:45:05.123:\n * const result = getSeconds(new Date(2012, 1, 29, 11, 45, 5, 123))\n * //=> 5\n */\nexport function getSeconds(date) {\n const _date = toDate(date);\n const seconds = _date.getSeconds();\n return seconds;\n}\n\n// Fallback for modularized imports:\nexport default getSeconds;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getTime\n * @category Timestamp Helpers\n * @summary Get the milliseconds timestamp of the given date.\n *\n * @description\n * Get the milliseconds timestamp of 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 *\n * @param date - The given date\n *\n * @returns The timestamp\n *\n * @example\n * // Get the timestamp of 29 February 2012 11:45:05.123:\n * const result = getTime(new Date(2012, 1, 29, 11, 45, 5, 123))\n * //=> 1330515905123\n */\nexport function getTime(date) {\n const _date = toDate(date);\n const timestamp = _date.getTime();\n return timestamp;\n}\n\n// Fallback for modularized imports:\nexport default getTime;\n","import { millisecondsInWeek } from \"./constants.mjs\";\nimport { startOfWeek } from \"./startOfWeek.mjs\";\nimport { startOfWeekYear } from \"./startOfWeekYear.mjs\";\nimport { toDate } from \"./toDate.mjs\";\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 * @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 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 */\n\nexport function getWeek(date, options) {\n const _date = toDate(date);\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","import { constructFrom } from \"./constructFrom.mjs\";\nimport { getWeekYear } from \"./getWeekYear.mjs\";\nimport { startOfWeek } from \"./startOfWeek.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\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 *\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(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 { constructFrom } from \"./constructFrom.mjs\";\nimport { startOfWeek } from \"./startOfWeek.mjs\";\nimport { toDate } from \"./toDate.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\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 * @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 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);\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(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(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.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 getWeekYear;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getYear\n * @category Year Helpers\n * @summary Get the year of the given date.\n *\n * @description\n * Get the year of 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 *\n * @param date - The given date\n *\n * @returns The year\n *\n * @example\n * // Which year is 2 July 2014?\n * const result = getYear(new Date(2014, 6, 2))\n * //=> 2014\n */\nexport function getYear(date) {\n return toDate(date).getFullYear();\n}\n\n// Fallback for modularized imports:\nexport default getYear;\n","import { toDate } from \"./toDate.mjs\";\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 * @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 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 const _date = toDate(date);\n const _dateToCompare = toDate(dateToCompare);\n return _date.getTime() > _dateToCompare.getTime();\n}\n\n// Fallback for modularized imports:\nexport default isAfter;\n","import { toDate } from \"./toDate.mjs\";\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 * @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 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 const _date = toDate(date);\n const _dateToCompare = toDate(dateToCompare);\n return +_date < +_dateToCompare;\n}\n\n// Fallback for modularized imports:\nexport default isBefore;\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 { toDate } from \"./toDate.mjs\";\n\n/**\n * @name isEqual\n * @category Common Helpers\n * @summary Are the given dates equal?\n *\n * @description\n * Are the given dates equal?\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 dateLeft - The first date to compare\n * @param dateRight - The second date to compare\n *\n * @returns The dates are equal\n *\n * @example\n * // Are 2 July 2014 06:30:45.000 and 2 July 2014 06:30:45.500 equal?\n * const result = isEqual(\n * new Date(2014, 6, 2, 6, 30, 45, 0),\n * new Date(2014, 6, 2, 6, 30, 45, 500)\n * )\n * //=> false\n */\nexport function isEqual(leftDate, rightDate) {\n const _dateLeft = toDate(leftDate);\n const _dateRight = toDate(rightDate);\n return +_dateLeft === +_dateRight;\n}\n\n// Fallback for modularized imports:\nexport default isEqual;\n","import { startOfDay } from \"./startOfDay.mjs\";\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 * @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 dateLeft - The first date to check\n * @param dateRight - The second date to check\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(dateLeft, dateRight) {\n const dateLeftStartOfDay = startOfDay(dateLeft);\n const dateRightStartOfDay = startOfDay(dateRight);\n\n return +dateLeftStartOfDay === +dateRightStartOfDay;\n}\n\n// Fallback for modularized imports:\nexport default isSameDay;\n","import { toDate } from \"./toDate.mjs\";\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 * @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 dateLeft - The first date to check\n * @param dateRight - The second date to check\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(dateLeft, dateRight) {\n const _dateLeft = toDate(dateLeft);\n const _dateRight = toDate(dateRight);\n return (\n _dateLeft.getFullYear() === _dateRight.getFullYear() &&\n _dateLeft.getMonth() === _dateRight.getMonth()\n );\n}\n\n// Fallback for modularized imports:\nexport default isSameMonth;\n","import { startOfQuarter } from \"./startOfQuarter.mjs\";\n\n/**\n * @name isSameQuarter\n * @category Quarter Helpers\n * @summary Are the given dates in the same quarter (and year)?\n *\n * @description\n * Are the given dates in the same quarter (and year)?\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 dateLeft - The first date to check\n * @param dateRight - The second date to check\n\n * @returns The dates are in the same quarter (and year)\n *\n * @example\n * // Are 1 January 2014 and 8 March 2014 in the same quarter?\n * const result = isSameQuarter(new Date(2014, 0, 1), new Date(2014, 2, 8))\n * //=> true\n *\n * @example\n * // Are 1 January 2014 and 1 January 2015 in the same quarter?\n * const result = isSameQuarter(new Date(2014, 0, 1), new Date(2015, 0, 1))\n * //=> false\n */\nexport function isSameQuarter(dateLeft, dateRight) {\n const dateLeftStartOfQuarter = startOfQuarter(dateLeft);\n const dateRightStartOfQuarter = startOfQuarter(dateRight);\n\n return +dateLeftStartOfQuarter === +dateRightStartOfQuarter;\n}\n\n// Fallback for modularized imports:\nexport default isSameQuarter;\n","import { toDate } from \"./toDate.mjs\";\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 * @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 dateLeft - The first date to check\n * @param dateRight - The second date to check\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(dateLeft, dateRight) {\n const _dateLeft = toDate(dateLeft);\n const _dateRight = toDate(dateRight);\n return _dateLeft.getFullYear() === _dateRight.getFullYear();\n}\n\n// Fallback for modularized imports:\nexport default isSameYear;\n","import { isDate } from \"./isDate.mjs\";\nimport { toDate } from \"./toDate.mjs\";\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 * @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 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, convertable 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 if (!isDate(date) && typeof date !== \"number\") {\n return false;\n }\n const _date = toDate(date);\n return !isNaN(Number(_date));\n}\n\n// Fallback for modularized imports:\nexport default isValid;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name isWithinInterval\n * @category Interval Helpers\n * @summary Is the given date within the interval?\n *\n * @description\n * Is the given date within the interval? (Including start and end.)\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 date to check\n * @param interval - The interval to check\n *\n * @returns The date is within the interval\n *\n * @example\n * // For the date within the interval:\n * isWithinInterval(new Date(2014, 0, 3), {\n * start: new Date(2014, 0, 1),\n * end: new Date(2014, 0, 7)\n * })\n * //=> true\n *\n * @example\n * // For the date outside of the interval:\n * isWithinInterval(new Date(2014, 0, 10), {\n * start: new Date(2014, 0, 1),\n * end: new Date(2014, 0, 7)\n * })\n * //=> false\n *\n * @example\n * // For date equal to interval start:\n * isWithinInterval(date, { start, end: date })\n * // => true\n *\n * @example\n * // For date equal to interval end:\n * isWithinInterval(date, { start: date, end })\n * // => true\n */\nexport function isWithinInterval(date, interval) {\n const time = +toDate(date);\n const [startTime, endTime] = [\n +toDate(interval.start),\n +toDate(interval.end),\n ].sort((a, b) => a - b);\n\n return time >= startTime && time <= endTime;\n}\n\n// Fallback for modularized imports:\nexport default isWithinInterval;\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 // eslint-disable-next-line @typescript-eslint/no-explicit-any -- I challange 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","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.mjs\";\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","/* eslint-disable no-unused-vars */\n\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","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 : // eslint-disable-next-line @typescript-eslint/no-explicit-any -- I challange 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 ? // eslint-disable-next-line @typescript-eslint/no-explicit-any -- I challange 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","import { formatDistance } from \"./en-US/_lib/formatDistance.mjs\";\nimport { formatLong } from \"./en-US/_lib/formatLong.mjs\";\nimport { formatRelative } from \"./en-US/_lib/formatRelative.mjs\";\nimport { localize } from \"./en-US/_lib/localize.mjs\";\nimport { match } from \"./en-US/_lib/match.mjs\";\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 { buildLocalizeFn } from \"../../_lib/buildLocalizeFn.mjs\";\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","import { buildMatchFn } from \"../../_lib/buildMatchFn.mjs\";\nimport { buildMatchPatternFn } from \"../../_lib/buildMatchPatternFn.mjs\";\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 { toDate } from \"./toDate.mjs\";\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 *\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) {\n let result;\n dates.forEach(function (dirtyDate) {\n const currentDate = toDate(dirtyDate);\n\n if (\n result === undefined ||\n result < currentDate ||\n isNaN(Number(currentDate))\n ) {\n result = currentDate;\n }\n });\n\n return result || new Date(NaN);\n}\n\n// Fallback for modularized imports:\nexport default max;\n","import { toDate } from \"./toDate.mjs\";\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 *\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) {\n let result;\n\n dates.forEach((dirtyDate) => {\n const date = toDate(dirtyDate);\n if (!result || result > date || isNaN(+date)) {\n result = date;\n }\n });\n\n return result || new Date(NaN);\n}\n\n// Fallback for modularized imports:\nexport default min;\n","import { transpose } from \"../../transpose.mjs\";\nimport { constructFrom } from \"../../constructFrom.mjs\";\n\nconst TIMEZONE_UNIT_PRIORITY = 10;\n\nexport class Setter {\n subPriority = 0;\n\n validate(_utcDate, _options) {\n return true;\n }\n}\n\nexport class ValueSetter extends Setter {\n constructor(\n value,\n\n validateValue,\n\n setValue,\n\n priority,\n subPriority,\n ) {\n super();\n this.value = value;\n this.validateValue = validateValue;\n this.setValue = setValue;\n this.priority = priority;\n if (subPriority) {\n this.subPriority = subPriority;\n }\n }\n\n validate(date, options) {\n return this.validateValue(date, this.value, options);\n }\n\n set(date, flags, options) {\n return this.setValue(date, flags, this.value, options);\n }\n}\n\nexport class DateToSystemTimezoneSetter extends Setter {\n priority = TIMEZONE_UNIT_PRIORITY;\n subPriority = -1;\n set(date, flags) {\n if (flags.timestampIsSet) return date;\n return constructFrom(date, transpose(date, Date));\n }\n}\n","import { constructFrom } from \"./constructFrom.mjs\";\n\n/**\n * @name transpose\n * @category Generic Helpers\n * @summary Transpose the date to the given constructor.\n *\n * @description\n * The function transposes the date to the given constructor. It helps you\n * to transpose the date in the system time zone to say `UTCDate` or any other\n * date extension.\n *\n * @typeParam DateInputType - The input `Date` type derived from the passed argument.\n * @typeParam DateOutputType - The output `Date` type derived from the passed constructor.\n *\n * @param fromDate - The date to use values from\n * @param constructor - The date constructor to use\n *\n * @returns Date transposed to the given constructor\n *\n * @example\n * // Create July 10, 2022 00:00 in locale time zone\n * const date = new Date(2022, 6, 10)\n * //=> 'Sun Jul 10 2022 00:00:00 GMT+0800 (Singapore Standard Time)'\n *\n * @example\n * // Transpose the date to July 10, 2022 00:00 in UTC\n * transpose(date, UTCDate)\n * //=> 'Sun Jul 10 2022 00:00:00 GMT+0000 (Coordinated Universal Time)'\n */\nexport function transpose(fromDate, constructor) {\n const date =\n constructor instanceof Date\n ? constructFrom(constructor, 0)\n : new constructor(0);\n date.setFullYear(\n fromDate.getFullYear(),\n fromDate.getMonth(),\n fromDate.getDate(),\n );\n date.setHours(\n fromDate.getHours(),\n fromDate.getMinutes(),\n fromDate.getSeconds(),\n fromDate.getMilliseconds(),\n );\n return date;\n}\n\n// Fallback for modularized imports:\nexport default transpose;\n","import { ValueSetter } from \"./Setter.mjs\";\n\nexport class Parser {\n run(dateString, token, match, options) {\n const result = this.parse(dateString, token, match, options);\n if (!result) {\n return null;\n }\n\n return {\n setter: new ValueSetter(\n result.value,\n this.validate,\n this.set,\n this.priority,\n this.subPriority,\n ),\n rest: result.rest,\n };\n }\n\n validate(_utcDate, _value, _options) {\n return true;\n }\n}\n","export const numericPatterns = {\n month: /^(1[0-2]|0?\\d)/, // 0 to 12\n date: /^(3[0-1]|[0-2]?\\d)/, // 0 to 31\n dayOfYear: /^(36[0-6]|3[0-5]\\d|[0-2]?\\d?\\d)/, // 0 to 366\n week: /^(5[0-3]|[0-4]?\\d)/, // 0 to 53\n hour23h: /^(2[0-3]|[0-1]?\\d)/, // 0 to 23\n hour24h: /^(2[0-4]|[0-1]?\\d)/, // 0 to 24\n hour11h: /^(1[0-1]|0?\\d)/, // 0 to 11\n hour12h: /^(1[0-2]|0?\\d)/, // 0 to 12\n minute: /^[0-5]?\\d/, // 0 to 59\n second: /^[0-5]?\\d/, // 0 to 59\n\n singleDigit: /^\\d/, // 0 to 9\n twoDigits: /^\\d{1,2}/, // 0 to 99\n threeDigits: /^\\d{1,3}/, // 0 to 999\n fourDigits: /^\\d{1,4}/, // 0 to 9999\n\n anyDigitsSigned: /^-?\\d+/,\n singleDigitSigned: /^-?\\d/, // 0 to 9, -0 to -9\n twoDigitsSigned: /^-?\\d{1,2}/, // 0 to 99, -0 to -99\n threeDigitsSigned: /^-?\\d{1,3}/, // 0 to 999, -0 to -999\n fourDigitsSigned: /^-?\\d{1,4}/, // 0 to 9999, -0 to -9999\n};\n\nexport const timezonePatterns = {\n basicOptionalMinutes: /^([+-])(\\d{2})(\\d{2})?|Z/,\n basic: /^([+-])(\\d{2})(\\d{2})|Z/,\n basicOptionalSeconds: /^([+-])(\\d{2})(\\d{2})((\\d{2}))?|Z/,\n extended: /^([+-])(\\d{2}):(\\d{2})|Z/,\n extendedOptionalSeconds: /^([+-])(\\d{2}):(\\d{2})(:(\\d{2}))?|Z/,\n};\n","import {\n millisecondsInHour,\n millisecondsInMinute,\n millisecondsInSecond,\n} from \"../../constants.mjs\";\nimport { numericPatterns } from \"./constants.mjs\";\n\nexport function mapValue(parseFnResult, mapFn) {\n if (!parseFnResult) {\n return parseFnResult;\n }\n\n return {\n value: mapFn(parseFnResult.value),\n rest: parseFnResult.rest,\n };\n}\n\nexport function parseNumericPattern(pattern, dateString) {\n const matchResult = dateString.match(pattern);\n\n if (!matchResult) {\n return null;\n }\n\n return {\n value: parseInt(matchResult[0], 10),\n rest: dateString.slice(matchResult[0].length),\n };\n}\n\nexport function parseTimezonePattern(pattern, dateString) {\n const matchResult = dateString.match(pattern);\n\n if (!matchResult) {\n return null;\n }\n\n // Input is 'Z'\n if (matchResult[0] === \"Z\") {\n return {\n value: 0,\n rest: dateString.slice(1),\n };\n }\n\n const sign = matchResult[1] === \"+\" ? 1 : -1;\n const hours = matchResult[2] ? parseInt(matchResult[2], 10) : 0;\n const minutes = matchResult[3] ? parseInt(matchResult[3], 10) : 0;\n const seconds = matchResult[5] ? parseInt(matchResult[5], 10) : 0;\n\n return {\n value:\n sign *\n (hours * millisecondsInHour +\n minutes * millisecondsInMinute +\n seconds * millisecondsInSecond),\n rest: dateString.slice(matchResult[0].length),\n };\n}\n\nexport function parseAnyDigitsSigned(dateString) {\n return parseNumericPattern(numericPatterns.anyDigitsSigned, dateString);\n}\n\nexport function parseNDigits(n, dateString) {\n switch (n) {\n case 1:\n return parseNumericPattern(numericPatterns.singleDigit, dateString);\n case 2:\n return parseNumericPattern(numericPatterns.twoDigits, dateString);\n case 3:\n return parseNumericPattern(numericPatterns.threeDigits, dateString);\n case 4:\n return parseNumericPattern(numericPatterns.fourDigits, dateString);\n default:\n return parseNumericPattern(new RegExp(\"^\\\\d{1,\" + n + \"}\"), dateString);\n }\n}\n\nexport function parseNDigitsSigned(n, dateString) {\n switch (n) {\n case 1:\n return parseNumericPattern(numericPatterns.singleDigitSigned, dateString);\n case 2:\n return parseNumericPattern(numericPatterns.twoDigitsSigned, dateString);\n case 3:\n return parseNumericPattern(numericPatterns.threeDigitsSigned, dateString);\n case 4:\n return parseNumericPattern(numericPatterns.fourDigitsSigned, dateString);\n default:\n return parseNumericPattern(new RegExp(\"^-?\\\\d{1,\" + n + \"}\"), dateString);\n }\n}\n\nexport function dayPeriodEnumToHours(dayPeriod) {\n switch (dayPeriod) {\n case \"morning\":\n return 4;\n case \"evening\":\n return 17;\n case \"pm\":\n case \"noon\":\n case \"afternoon\":\n return 12;\n case \"am\":\n case \"midnight\":\n case \"night\":\n default:\n return 0;\n }\n}\n\nexport function normalizeTwoDigitYear(twoDigitYear, currentYear) {\n const isCommonEra = currentYear > 0;\n // Absolute number of the current year:\n // 1 -> 1 AC\n // 0 -> 1 BC\n // -1 -> 2 BC\n const absCurrentYear = isCommonEra ? currentYear : 1 - currentYear;\n\n let result;\n if (absCurrentYear <= 50) {\n result = twoDigitYear || 100;\n } else {\n const rangeEnd = absCurrentYear + 50;\n const rangeEndCentury = Math.trunc(rangeEnd / 100) * 100;\n const isPreviousCentury = twoDigitYear >= rangeEnd % 100;\n result = twoDigitYear + rangeEndCentury - (isPreviousCentury ? 100 : 0);\n }\n\n return isCommonEra ? result : 1 - result;\n}\n\nexport function isLeapYearIndex(year) {\n return year % 400 === 0 || (year % 4 === 0 && year % 100 !== 0);\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport {\n isLeapYearIndex,\n parseNDigits,\n parseNumericPattern,\n} from \"../utils.mjs\";\n\nconst DAYS_IN_MONTH = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\nconst DAYS_IN_MONTH_LEAP_YEAR = [\n 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31,\n];\n\n// Day of the month\nexport class DateParser extends Parser {\n priority = 90;\n subPriority = 1;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"d\":\n return parseNumericPattern(numericPatterns.date, dateString);\n case \"do\":\n return match.ordinalNumber(dateString, { unit: \"date\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(date, value) {\n const year = date.getFullYear();\n const isLeapYear = isLeapYearIndex(year);\n const month = date.getMonth();\n if (isLeapYear) {\n return value >= 1 && value <= DAYS_IN_MONTH_LEAP_YEAR[month];\n } else {\n return value >= 1 && value <= DAYS_IN_MONTH[month];\n }\n }\n\n set(date, _flags, value) {\n date.setDate(value);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"Q\",\n \"w\",\n \"I\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { addDays } from \"./addDays.mjs\";\nimport { toDate } from \"./toDate.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\n\n/**\n * The {@link setDay} function options.\n */\n\n/**\n * @name setDay\n * @category Weekday Helpers\n * @summary Set the day of the week to the given date.\n *\n * @description\n * Set the day of the week 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 *\n * @param date - The date to be changed\n * @param day - The day of the week of the new date\n * @param options - An object with options.\n *\n * @returns The new date with the day of the week set\n *\n * @example\n * // Set week day to Sunday, with the default weekStartsOn of Sunday:\n * const result = setDay(new Date(2014, 8, 1), 0)\n * //=> Sun Aug 31 2014 00:00:00\n *\n * @example\n * // Set week day to Sunday, with a weekStartsOn of Monday:\n * const result = setDay(new Date(2014, 8, 1), 0, { weekStartsOn: 1 })\n * //=> Sun Sep 07 2014 00:00:00\n */\nexport function setDay(date, day, 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);\n const currentDay = _date.getDay();\n\n const remainder = day % 7;\n const dayIndex = (remainder + 7) % 7;\n\n const delta = 7 - weekStartsOn;\n const diff =\n day < 0 || day > 6\n ? day - ((currentDay + delta) % 7)\n : ((dayIndex + delta) % 7) - ((currentDay + delta) % 7);\n return addDays(_date, diff);\n}\n\n// Fallback for modularized imports:\nexport default setDay;\n","import { EraParser } from \"./parsers/EraParser.mjs\";\nimport { YearParser } from \"./parsers/YearParser.mjs\";\nimport { LocalWeekYearParser } from \"./parsers/LocalWeekYearParser.mjs\";\nimport { ISOWeekYearParser } from \"./parsers/ISOWeekYearParser.mjs\";\nimport { ExtendedYearParser } from \"./parsers/ExtendedYearParser.mjs\";\nimport { QuarterParser } from \"./parsers/QuarterParser.mjs\";\nimport { StandAloneQuarterParser } from \"./parsers/StandAloneQuarterParser.mjs\";\nimport { MonthParser } from \"./parsers/MonthParser.mjs\";\nimport { StandAloneMonthParser } from \"./parsers/StandAloneMonthParser.mjs\";\nimport { LocalWeekParser } from \"./parsers/LocalWeekParser.mjs\";\nimport { ISOWeekParser } from \"./parsers/ISOWeekParser.mjs\";\nimport { DateParser } from \"./parsers/DateParser.mjs\";\nimport { DayOfYearParser } from \"./parsers/DayOfYearParser.mjs\";\nimport { DayParser } from \"./parsers/DayParser.mjs\";\nimport { LocalDayParser } from \"./parsers/LocalDayParser.mjs\";\nimport { StandAloneLocalDayParser } from \"./parsers/StandAloneLocalDayParser.mjs\";\nimport { ISODayParser } from \"./parsers/ISODayParser.mjs\";\nimport { AMPMParser } from \"./parsers/AMPMParser.mjs\";\nimport { AMPMMidnightParser } from \"./parsers/AMPMMidnightParser.mjs\";\nimport { DayPeriodParser } from \"./parsers/DayPeriodParser.mjs\";\nimport { Hour1to12Parser } from \"./parsers/Hour1to12Parser.mjs\";\nimport { Hour0to23Parser } from \"./parsers/Hour0to23Parser.mjs\";\nimport { Hour0To11Parser } from \"./parsers/Hour0To11Parser.mjs\";\nimport { Hour1To24Parser } from \"./parsers/Hour1To24Parser.mjs\";\nimport { MinuteParser } from \"./parsers/MinuteParser.mjs\";\nimport { SecondParser } from \"./parsers/SecondParser.mjs\";\nimport { FractionOfSecondParser } from \"./parsers/FractionOfSecondParser.mjs\";\nimport { ISOTimezoneWithZParser } from \"./parsers/ISOTimezoneWithZParser.mjs\";\nimport { ISOTimezoneParser } from \"./parsers/ISOTimezoneParser.mjs\";\nimport { TimestampSecondsParser } from \"./parsers/TimestampSecondsParser.mjs\";\nimport { TimestampMillisecondsParser } from \"./parsers/TimestampMillisecondsParser.mjs\";\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 | | P | |\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 `parse` 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 */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- It's ok, we want any here\nexport const parsers = {\n G: new EraParser(),\n y: new YearParser(),\n Y: new LocalWeekYearParser(),\n R: new ISOWeekYearParser(),\n u: new ExtendedYearParser(),\n Q: new QuarterParser(),\n q: new StandAloneQuarterParser(),\n M: new MonthParser(),\n L: new StandAloneMonthParser(),\n w: new LocalWeekParser(),\n I: new ISOWeekParser(),\n d: new DateParser(),\n D: new DayOfYearParser(),\n E: new DayParser(),\n e: new LocalDayParser(),\n c: new StandAloneLocalDayParser(),\n i: new ISODayParser(),\n a: new AMPMParser(),\n b: new AMPMMidnightParser(),\n B: new DayPeriodParser(),\n h: new Hour1to12Parser(),\n H: new Hour0to23Parser(),\n K: new Hour0To11Parser(),\n k: new Hour1To24Parser(),\n m: new MinuteParser(),\n s: new SecondParser(),\n S: new FractionOfSecondParser(),\n X: new ISOTimezoneWithZParser(),\n x: new ISOTimezoneParser(),\n t: new TimestampSecondsParser(),\n T: new TimestampMillisecondsParser(),\n};\n","import { Parser } from \"../Parser.mjs\";\n\nexport class EraParser extends Parser {\n priority = 140;\n\n parse(dateString, token, match) {\n switch (token) {\n // AD, BC\n case \"G\":\n case \"GG\":\n case \"GGG\":\n return (\n match.era(dateString, { width: \"abbreviated\" }) ||\n match.era(dateString, { width: \"narrow\" })\n );\n\n // A, B\n case \"GGGGG\":\n return match.era(dateString, { width: \"narrow\" });\n // Anno Domini, Before Christ\n case \"GGGG\":\n default:\n return (\n match.era(dateString, { width: \"wide\" }) ||\n match.era(dateString, { width: \"abbreviated\" }) ||\n match.era(dateString, { width: \"narrow\" })\n );\n }\n }\n\n set(date, flags, value) {\n flags.era = value;\n date.setFullYear(value, 0, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"R\", \"u\", \"t\", \"T\"];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { mapValue, normalizeTwoDigitYear, parseNDigits } from \"../utils.mjs\";\n\n// From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_Patterns\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 |\nexport class YearParser extends Parser {\n priority = 130;\n incompatibleTokens = [\"Y\", \"R\", \"u\", \"w\", \"I\", \"i\", \"e\", \"c\", \"t\", \"T\"];\n\n parse(dateString, token, match) {\n const valueCallback = (year) => ({\n year,\n isTwoDigitYear: token === \"yy\",\n });\n\n switch (token) {\n case \"y\":\n return mapValue(parseNDigits(4, dateString), valueCallback);\n case \"yo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"year\",\n }),\n valueCallback,\n );\n default:\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n }\n }\n\n validate(_date, value) {\n return value.isTwoDigitYear || value.year > 0;\n }\n\n set(date, flags, value) {\n const currentYear = date.getFullYear();\n\n if (value.isTwoDigitYear) {\n const normalizedTwoDigitYear = normalizeTwoDigitYear(\n value.year,\n currentYear,\n );\n date.setFullYear(normalizedTwoDigitYear, 0, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n const year =\n !(\"era\" in flags) || flags.era === 1 ? value.year : 1 - value.year;\n date.setFullYear(year, 0, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n}\n","import { getWeekYear } from \"../../../getWeekYear.mjs\";\nimport { startOfWeek } from \"../../../startOfWeek.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, normalizeTwoDigitYear, parseNDigits } from \"../utils.mjs\";\n\n// Local week-numbering year\nexport class LocalWeekYearParser extends Parser {\n priority = 130;\n\n parse(dateString, token, match) {\n const valueCallback = (year) => ({\n year,\n isTwoDigitYear: token === \"YY\",\n });\n\n switch (token) {\n case \"Y\":\n return mapValue(parseNDigits(4, dateString), valueCallback);\n case \"Yo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"year\",\n }),\n valueCallback,\n );\n default:\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n }\n }\n\n validate(_date, value) {\n return value.isTwoDigitYear || value.year > 0;\n }\n\n set(date, flags, value, options) {\n const currentYear = getWeekYear(date, options);\n\n if (value.isTwoDigitYear) {\n const normalizedTwoDigitYear = normalizeTwoDigitYear(\n value.year,\n currentYear,\n );\n date.setFullYear(\n normalizedTwoDigitYear,\n 0,\n options.firstWeekContainsDate,\n );\n date.setHours(0, 0, 0, 0);\n return startOfWeek(date, options);\n }\n\n const year =\n !(\"era\" in flags) || flags.era === 1 ? value.year : 1 - value.year;\n date.setFullYear(year, 0, options.firstWeekContainsDate);\n date.setHours(0, 0, 0, 0);\n return startOfWeek(date, options);\n }\n\n incompatibleTokens = [\n \"y\",\n \"R\",\n \"u\",\n \"Q\",\n \"q\",\n \"M\",\n \"L\",\n \"I\",\n \"d\",\n \"D\",\n \"i\",\n \"t\",\n \"T\",\n ];\n}\n","import { startOfISOWeek } from \"../../../startOfISOWeek.mjs\";\nimport { constructFrom } from \"../../../constructFrom.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigitsSigned } from \"../utils.mjs\";\n\n// ISO week-numbering year\nexport class ISOWeekYearParser extends Parser {\n priority = 130;\n\n parse(dateString, token) {\n if (token === \"R\") {\n return parseNDigitsSigned(4, dateString);\n }\n\n return parseNDigitsSigned(token.length, dateString);\n }\n\n set(date, _flags, value) {\n const firstWeekOfYear = constructFrom(date, 0);\n firstWeekOfYear.setFullYear(value, 0, 4);\n firstWeekOfYear.setHours(0, 0, 0, 0);\n return startOfISOWeek(firstWeekOfYear);\n }\n\n incompatibleTokens = [\n \"G\",\n \"y\",\n \"Y\",\n \"u\",\n \"Q\",\n \"q\",\n \"M\",\n \"L\",\n \"w\",\n \"d\",\n \"D\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { parseNDigitsSigned } from \"../utils.mjs\";\n\nexport class ExtendedYearParser extends Parser {\n priority = 130;\n\n parse(dateString, token) {\n if (token === \"u\") {\n return parseNDigitsSigned(4, dateString);\n }\n\n return parseNDigitsSigned(token.length, dateString);\n }\n\n set(date, _flags, value) {\n date.setFullYear(value, 0, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"G\", \"y\", \"Y\", \"R\", \"w\", \"I\", \"i\", \"e\", \"c\", \"t\", \"T\"];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { parseNDigits } from \"../utils.mjs\";\n\nexport class QuarterParser extends Parser {\n priority = 120;\n\n parse(dateString, token, match) {\n switch (token) {\n // 1, 2, 3, 4\n case \"Q\":\n case \"QQ\": // 01, 02, 03, 04\n return parseNDigits(token.length, dateString);\n // 1st, 2nd, 3rd, 4th\n case \"Qo\":\n return match.ordinalNumber(dateString, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"QQQ\":\n return (\n match.quarter(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.quarter(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"QQQQQ\":\n return match.quarter(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"QQQQ\":\n default:\n return (\n match.quarter(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.quarter(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.quarter(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 4;\n }\n\n set(date, _flags, value) {\n date.setMonth((value - 1) * 3, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"M\",\n \"L\",\n \"w\",\n \"I\",\n \"d\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { parseNDigits } from \"../utils.mjs\";\n\nexport class StandAloneQuarterParser extends Parser {\n priority = 120;\n\n parse(dateString, token, match) {\n switch (token) {\n // 1, 2, 3, 4\n case \"q\":\n case \"qq\": // 01, 02, 03, 04\n return parseNDigits(token.length, dateString);\n // 1st, 2nd, 3rd, 4th\n case \"qo\":\n return match.ordinalNumber(dateString, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"qqq\":\n return (\n match.quarter(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.quarter(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n })\n );\n\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"qqqqq\":\n return match.quarter(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"qqqq\":\n default:\n return (\n match.quarter(dateString, {\n width: \"wide\",\n context: \"standalone\",\n }) ||\n match.quarter(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.quarter(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 4;\n }\n\n set(date, _flags, value) {\n date.setMonth((value - 1) * 3, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"Q\",\n \"M\",\n \"L\",\n \"w\",\n \"I\",\n \"d\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class MonthParser extends Parser {\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"Q\",\n \"L\",\n \"w\",\n \"I\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n\n priority = 110;\n\n parse(dateString, token, match) {\n const valueCallback = (value) => value - 1;\n\n switch (token) {\n // 1, 2, ..., 12\n case \"M\":\n return mapValue(\n parseNumericPattern(numericPatterns.month, dateString),\n valueCallback,\n );\n // 01, 02, ..., 12\n case \"MM\":\n return mapValue(parseNDigits(2, dateString), valueCallback);\n // 1st, 2nd, ..., 12th\n case \"Mo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"month\",\n }),\n valueCallback,\n );\n // Jan, Feb, ..., Dec\n case \"MMM\":\n return (\n match.month(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.month(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // J, F, ..., D\n case \"MMMMM\":\n return match.month(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // January, February, ..., December\n case \"MMMM\":\n default:\n return (\n match.month(dateString, { width: \"wide\", context: \"formatting\" }) ||\n match.month(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.month(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 11;\n }\n\n set(date, _flags, value) {\n date.setMonth(value, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class StandAloneMonthParser extends Parser {\n priority = 110;\n\n parse(dateString, token, match) {\n const valueCallback = (value) => value - 1;\n\n switch (token) {\n // 1, 2, ..., 12\n case \"L\":\n return mapValue(\n parseNumericPattern(numericPatterns.month, dateString),\n valueCallback,\n );\n // 01, 02, ..., 12\n case \"LL\":\n return mapValue(parseNDigits(2, dateString), valueCallback);\n // 1st, 2nd, ..., 12th\n case \"Lo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"month\",\n }),\n valueCallback,\n );\n // Jan, Feb, ..., Dec\n case \"LLL\":\n return (\n match.month(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.month(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n\n // J, F, ..., D\n case \"LLLLL\":\n return match.month(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // January, February, ..., December\n case \"LLLL\":\n default:\n return (\n match.month(dateString, { width: \"wide\", context: \"standalone\" }) ||\n match.month(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.month(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 11;\n }\n\n set(date, _flags, value) {\n date.setMonth(value, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"Q\",\n \"M\",\n \"w\",\n \"I\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { setWeek } from \"../../../setWeek.mjs\";\nimport { startOfWeek } from \"../../../startOfWeek.mjs\";\nimport { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\n// Local week of year\nexport class LocalWeekParser extends Parser {\n priority = 100;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"w\":\n return parseNumericPattern(numericPatterns.week, dateString);\n case \"wo\":\n return match.ordinalNumber(dateString, { unit: \"week\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 53;\n }\n\n set(date, _flags, value, options) {\n return startOfWeek(setWeek(date, value, options), options);\n }\n\n incompatibleTokens = [\n \"y\",\n \"R\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"I\",\n \"d\",\n \"D\",\n \"i\",\n \"t\",\n \"T\",\n ];\n}\n","import { getWeek } from \"./getWeek.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * The {@link setWeek} function options.\n */\n\n/**\n * @name setWeek\n * @category Week Helpers\n * @summary Set the local week to the given date.\n *\n * @description\n * Set the local week to the given date, saving the weekday number.\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 *\n * @param date - The date to be changed\n * @param week - The week of the new date\n * @param options - An object with options\n *\n * @returns The new date with the local week set\n *\n * @example\n * // Set the 1st week to 2 January 2005 with default options:\n * const result = setWeek(new Date(2005, 0, 2), 1)\n * //=> Sun Dec 26 2004 00:00:00\n *\n * @example\n * // Set the 1st week to 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 = setWeek(new Date(2005, 0, 2), 1, {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> Sun Jan 4 2004 00:00:00\n */\nexport function setWeek(date, week, options) {\n const _date = toDate(date);\n const diff = getWeek(_date, options) - week;\n _date.setDate(_date.getDate() - diff * 7);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setWeek;\n","import { setISOWeek } from \"../../../setISOWeek.mjs\";\nimport { startOfISOWeek } from \"../../../startOfISOWeek.mjs\";\nimport { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\n// ISO week of year\nexport class ISOWeekParser extends Parser {\n priority = 100;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"I\":\n return parseNumericPattern(numericPatterns.week, dateString);\n case \"Io\":\n return match.ordinalNumber(dateString, { unit: \"week\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 53;\n }\n\n set(date, _flags, value) {\n return startOfISOWeek(setISOWeek(date, value));\n }\n\n incompatibleTokens = [\n \"y\",\n \"Y\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"w\",\n \"d\",\n \"D\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { getISOWeek } from \"./getISOWeek.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name setISOWeek\n * @category ISO Week Helpers\n * @summary Set the ISO week to the given date.\n *\n * @description\n * Set the ISO week to the given date, saving the weekday number.\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 *\n * @param date - The date to be changed\n * @param week - The ISO week of the new date\n *\n * @returns The new date with the ISO week set\n *\n * @example\n * // Set the 53rd ISO week to 7 August 2004:\n * const result = setISOWeek(new Date(2004, 7, 7), 53)\n * //=> Sat Jan 01 2005 00:00:00\n */\nexport function setISOWeek(date, week) {\n const _date = toDate(date);\n const diff = getISOWeek(_date) - week;\n _date.setDate(_date.getDate() - diff * 7);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setISOWeek;\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport {\n isLeapYearIndex,\n parseNDigits,\n parseNumericPattern,\n} from \"../utils.mjs\";\n\nexport class DayOfYearParser extends Parser {\n priority = 90;\n\n subpriority = 1;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"D\":\n case \"DD\":\n return parseNumericPattern(numericPatterns.dayOfYear, dateString);\n case \"Do\":\n return match.ordinalNumber(dateString, { unit: \"date\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(date, value) {\n const year = date.getFullYear();\n const isLeapYear = isLeapYearIndex(year);\n if (isLeapYear) {\n return value >= 1 && value <= 366;\n } else {\n return value >= 1 && value <= 365;\n }\n }\n\n set(date, _flags, value) {\n date.setMonth(0, value);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"w\",\n \"I\",\n \"d\",\n \"E\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { setDay } from \"../../../setDay.mjs\";\nimport { Parser } from \"../Parser.mjs\";\n\n// Day of week\nexport class DayParser extends Parser {\n priority = 90;\n\n parse(dateString, token, match) {\n switch (token) {\n // Tue\n case \"E\":\n case \"EE\":\n case \"EEE\":\n return (\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // T\n case \"EEEEE\":\n return match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"EEEEEE\":\n return (\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // Tuesday\n case \"EEEE\":\n default:\n return (\n match.day(dateString, { width: \"wide\", context: \"formatting\" }) ||\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 6;\n }\n\n set(date, _flags, value, options) {\n date = setDay(date, value, options);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"D\", \"i\", \"e\", \"c\", \"t\", \"T\"];\n}\n","import { setDay } from \"../../../setDay.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits } from \"../utils.mjs\";\n\n// Local day of week\nexport class LocalDayParser extends Parser {\n priority = 90;\n parse(dateString, token, match, options) {\n const valueCallback = (value) => {\n // We want here floor instead of trunc, so we get -7 for value 0 instead of 0\n const wholeWeekDays = Math.floor((value - 1) / 7) * 7;\n return ((value + options.weekStartsOn + 6) % 7) + wholeWeekDays;\n };\n\n switch (token) {\n // 3\n case \"e\":\n case \"ee\": // 03\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n // 3rd\n case \"eo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"day\",\n }),\n valueCallback,\n );\n // Tue\n case \"eee\":\n return (\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // T\n case \"eeeee\":\n return match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"eeeeee\":\n return (\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // Tuesday\n case \"eeee\":\n default:\n return (\n match.day(dateString, { width: \"wide\", context: \"formatting\" }) ||\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 6;\n }\n\n set(date, _flags, value, options) {\n date = setDay(date, value, options);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"y\",\n \"R\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"I\",\n \"d\",\n \"D\",\n \"E\",\n \"i\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { setDay } from \"../../../setDay.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits } from \"../utils.mjs\";\n\n// Stand-alone local day of week\nexport class StandAloneLocalDayParser extends Parser {\n priority = 90;\n\n parse(dateString, token, match, options) {\n const valueCallback = (value) => {\n // We want here floor instead of trunc, so we get -7 for value 0 instead of 0\n const wholeWeekDays = Math.floor((value - 1) / 7) * 7;\n return ((value + options.weekStartsOn + 6) % 7) + wholeWeekDays;\n };\n\n switch (token) {\n // 3\n case \"c\":\n case \"cc\": // 03\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n // 3rd\n case \"co\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"day\",\n }),\n valueCallback,\n );\n // Tue\n case \"ccc\":\n return (\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"standalone\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n\n // T\n case \"ccccc\":\n return match.day(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // Tu\n case \"cccccc\":\n return (\n match.day(dateString, { width: \"short\", context: \"standalone\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n\n // Tuesday\n case \"cccc\":\n default:\n return (\n match.day(dateString, { width: \"wide\", context: \"standalone\" }) ||\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"standalone\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 6;\n }\n\n set(date, _flags, value, options) {\n date = setDay(date, value, options);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"y\",\n \"R\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"I\",\n \"d\",\n \"D\",\n \"E\",\n \"i\",\n \"e\",\n \"t\",\n \"T\",\n ];\n}\n","import { setISODay } from \"../../../setISODay.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits } from \"../utils.mjs\";\n\n// ISO day of week\nexport class ISODayParser extends Parser {\n priority = 90;\n\n parse(dateString, token, match) {\n const valueCallback = (value) => {\n if (value === 0) {\n return 7;\n }\n return value;\n };\n\n switch (token) {\n // 2\n case \"i\":\n case \"ii\": // 02\n return parseNDigits(token.length, dateString);\n // 2nd\n case \"io\":\n return match.ordinalNumber(dateString, { unit: \"day\" });\n // Tue\n case \"iii\":\n return mapValue(\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"short\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n }),\n valueCallback,\n );\n // T\n case \"iiiii\":\n return mapValue(\n match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n }),\n valueCallback,\n );\n // Tu\n case \"iiiiii\":\n return mapValue(\n match.day(dateString, {\n width: \"short\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n }),\n valueCallback,\n );\n // Tuesday\n case \"iiii\":\n default:\n return mapValue(\n match.day(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"short\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n }),\n valueCallback,\n );\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 7;\n }\n\n set(date, _flags, value) {\n date = setISODay(date, value);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"y\",\n \"Y\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"w\",\n \"d\",\n \"D\",\n \"E\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { addDays } from \"./addDays.mjs\";\nimport { getISODay } from \"./getISODay.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name setISODay\n * @category Weekday Helpers\n * @summary Set the day of the ISO week to the given date.\n *\n * @description\n * Set the day of the ISO week to the given date.\n * ISO week starts with Monday.\n * 7 is the index of Sunday, 1 is the index of Monday etc.\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 date to be changed\n * @param day - The day of the ISO week of the new date\n *\n * @returns The new date with the day of the ISO week set\n *\n * @example\n * // Set Sunday to 1 September 2014:\n * const result = setISODay(new Date(2014, 8, 1), 7)\n * //=> Sun Sep 07 2014 00:00:00\n */\nexport function setISODay(date, day) {\n const _date = toDate(date);\n const currentDay = getISODay(_date);\n const diff = day - currentDay;\n return addDays(_date, diff);\n}\n\n// Fallback for modularized imports:\nexport default setISODay;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getISODay\n * @category Weekday Helpers\n * @summary Get the day of the ISO week of the given date.\n *\n * @description\n * Get the day of the ISO week of the given date,\n * which is 7 for Sunday, 1 for Monday etc.\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 *\n * @param date - The given date\n *\n * @returns The day of ISO week\n *\n * @example\n * // Which day of the ISO week is 26 February 2012?\n * const result = getISODay(new Date(2012, 1, 26))\n * //=> 7\n */\nexport function getISODay(date) {\n const _date = toDate(date);\n let day = _date.getDay();\n\n if (day === 0) {\n day = 7;\n }\n\n return day;\n}\n\n// Fallback for modularized imports:\nexport default getISODay;\n","import { Parser } from \"../Parser.mjs\";\nimport { dayPeriodEnumToHours } from \"../utils.mjs\";\n\nexport class AMPMParser extends Parser {\n priority = 80;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"a\":\n case \"aa\":\n case \"aaa\":\n return (\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n\n case \"aaaaa\":\n return match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"aaaa\":\n default:\n return (\n match.dayPeriod(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n }\n }\n\n set(date, _flags, value) {\n date.setHours(dayPeriodEnumToHours(value), 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"b\", \"B\", \"H\", \"k\", \"t\", \"T\"];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { dayPeriodEnumToHours } from \"../utils.mjs\";\n\nexport class AMPMMidnightParser extends Parser {\n priority = 80;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"b\":\n case \"bb\":\n case \"bbb\":\n return (\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n\n case \"bbbbb\":\n return match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"bbbb\":\n default:\n return (\n match.dayPeriod(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n }\n }\n\n set(date, _flags, value) {\n date.setHours(dayPeriodEnumToHours(value), 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"a\", \"B\", \"H\", \"k\", \"t\", \"T\"];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { dayPeriodEnumToHours } from \"../utils.mjs\";\n\n// in the morning, in the afternoon, in the evening, at night\nexport class DayPeriodParser extends Parser {\n priority = 80;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"B\":\n case \"BB\":\n case \"BBB\":\n return (\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n\n case \"BBBBB\":\n return match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"BBBB\":\n default:\n return (\n match.dayPeriod(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n }\n }\n\n set(date, _flags, value) {\n date.setHours(dayPeriodEnumToHours(value), 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"a\", \"b\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class Hour1to12Parser extends Parser {\n priority = 70;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"h\":\n return parseNumericPattern(numericPatterns.hour12h, dateString);\n case \"ho\":\n return match.ordinalNumber(dateString, { unit: \"hour\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 12;\n }\n\n set(date, _flags, value) {\n const isPM = date.getHours() >= 12;\n if (isPM && value < 12) {\n date.setHours(value + 12, 0, 0, 0);\n } else if (!isPM && value === 12) {\n date.setHours(0, 0, 0, 0);\n } else {\n date.setHours(value, 0, 0, 0);\n }\n return date;\n }\n\n incompatibleTokens = [\"H\", \"K\", \"k\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class Hour0to23Parser extends Parser {\n priority = 70;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"H\":\n return parseNumericPattern(numericPatterns.hour23h, dateString);\n case \"Ho\":\n return match.ordinalNumber(dateString, { unit: \"hour\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 23;\n }\n\n set(date, _flags, value) {\n date.setHours(value, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"a\", \"b\", \"h\", \"K\", \"k\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class Hour0To11Parser extends Parser {\n priority = 70;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"K\":\n return parseNumericPattern(numericPatterns.hour11h, dateString);\n case \"Ko\":\n return match.ordinalNumber(dateString, { unit: \"hour\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 11;\n }\n\n set(date, _flags, value) {\n const isPM = date.getHours() >= 12;\n if (isPM && value < 12) {\n date.setHours(value + 12, 0, 0, 0);\n } else {\n date.setHours(value, 0, 0, 0);\n }\n return date;\n }\n\n incompatibleTokens = [\"h\", \"H\", \"k\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class Hour1To24Parser extends Parser {\n priority = 70;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"k\":\n return parseNumericPattern(numericPatterns.hour24h, dateString);\n case \"ko\":\n return match.ordinalNumber(dateString, { unit: \"hour\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 24;\n }\n\n set(date, _flags, value) {\n const hours = value <= 24 ? value % 24 : value;\n date.setHours(hours, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"a\", \"b\", \"h\", \"H\", \"K\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class MinuteParser extends Parser {\n priority = 60;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"m\":\n return parseNumericPattern(numericPatterns.minute, dateString);\n case \"mo\":\n return match.ordinalNumber(dateString, { unit: \"minute\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 59;\n }\n\n set(date, _flags, value) {\n date.setMinutes(value, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class SecondParser extends Parser {\n priority = 50;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"s\":\n return parseNumericPattern(numericPatterns.second, dateString);\n case \"so\":\n return match.ordinalNumber(dateString, { unit: \"second\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 59;\n }\n\n set(date, _flags, value) {\n date.setSeconds(value, 0);\n return date;\n }\n\n incompatibleTokens = [\"t\", \"T\"];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits } from \"../utils.mjs\";\n\nexport class FractionOfSecondParser extends Parser {\n priority = 30;\n\n parse(dateString, token) {\n const valueCallback = (value) =>\n Math.trunc(value * Math.pow(10, -token.length + 3));\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n }\n\n set(date, _flags, value) {\n date.setMilliseconds(value);\n return date;\n }\n\n incompatibleTokens = [\"t\", \"T\"];\n}\n","import { constructFrom } from \"../../../constructFrom.mjs\";\nimport { getTimezoneOffsetInMilliseconds } from \"../../../_lib/getTimezoneOffsetInMilliseconds.mjs\";\nimport { timezonePatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseTimezonePattern } from \"../utils.mjs\";\n\n// Timezone (ISO-8601. +00:00 is `'Z'`)\nexport class ISOTimezoneWithZParser extends Parser {\n priority = 10;\n\n parse(dateString, token) {\n switch (token) {\n case \"X\":\n return parseTimezonePattern(\n timezonePatterns.basicOptionalMinutes,\n dateString,\n );\n case \"XX\":\n return parseTimezonePattern(timezonePatterns.basic, dateString);\n case \"XXXX\":\n return parseTimezonePattern(\n timezonePatterns.basicOptionalSeconds,\n dateString,\n );\n case \"XXXXX\":\n return parseTimezonePattern(\n timezonePatterns.extendedOptionalSeconds,\n dateString,\n );\n case \"XXX\":\n default:\n return parseTimezonePattern(timezonePatterns.extended, dateString);\n }\n }\n\n set(date, flags, value) {\n if (flags.timestampIsSet) return date;\n return constructFrom(\n date,\n date.getTime() - getTimezoneOffsetInMilliseconds(date) - value,\n );\n }\n\n incompatibleTokens = [\"t\", \"T\", \"x\"];\n}\n","import { constructFrom } from \"../../../constructFrom.mjs\";\nimport { getTimezoneOffsetInMilliseconds } from \"../../../_lib/getTimezoneOffsetInMilliseconds.mjs\";\nimport { timezonePatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseTimezonePattern } from \"../utils.mjs\";\n\n// Timezone (ISO-8601)\nexport class ISOTimezoneParser extends Parser {\n priority = 10;\n\n parse(dateString, token) {\n switch (token) {\n case \"x\":\n return parseTimezonePattern(\n timezonePatterns.basicOptionalMinutes,\n dateString,\n );\n case \"xx\":\n return parseTimezonePattern(timezonePatterns.basic, dateString);\n case \"xxxx\":\n return parseTimezonePattern(\n timezonePatterns.basicOptionalSeconds,\n dateString,\n );\n case \"xxxxx\":\n return parseTimezonePattern(\n timezonePatterns.extendedOptionalSeconds,\n dateString,\n );\n case \"xxx\":\n default:\n return parseTimezonePattern(timezonePatterns.extended, dateString);\n }\n }\n\n set(date, flags, value) {\n if (flags.timestampIsSet) return date;\n return constructFrom(\n date,\n date.getTime() - getTimezoneOffsetInMilliseconds(date) - value,\n );\n }\n\n incompatibleTokens = [\"t\", \"T\", \"X\"];\n}\n","import { constructFrom } from \"../../../constructFrom.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseAnyDigitsSigned } from \"../utils.mjs\";\n\nexport class TimestampSecondsParser extends Parser {\n priority = 40;\n\n parse(dateString) {\n return parseAnyDigitsSigned(dateString);\n }\n\n set(date, _flags, value) {\n return [constructFrom(date, value * 1000), { timestampIsSet: true }];\n }\n\n incompatibleTokens = \"*\";\n}\n","import { constructFrom } from \"../../../constructFrom.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseAnyDigitsSigned } from \"../utils.mjs\";\n\nexport class TimestampMillisecondsParser extends Parser {\n priority = 20;\n\n parse(dateString) {\n return parseAnyDigitsSigned(dateString);\n }\n\n set(date, _flags, value) {\n return [constructFrom(date, value), { timestampIsSet: true }];\n }\n\n incompatibleTokens = \"*\";\n}\n","import { constructFrom } from \"./constructFrom.mjs\";\nimport { getDefaultOptions } from \"./getDefaultOptions.mjs\";\nimport { defaultLocale } from \"./_lib/defaultLocale.mjs\";\nimport { toDate } from \"./toDate.mjs\";\nimport { longFormatters } from \"./_lib/format/longFormatters.mjs\";\nimport {\n isProtectedDayOfYearToken,\n isProtectedWeekYearToken,\n warnOrThrowProtectedError,\n} from \"./_lib/protectedTokens.mjs\";\nimport { parsers } from \"./parse/_lib/parsers.mjs\";\nimport { DateToSystemTimezoneSetter } from \"./parse/_lib/Setter.mjs\";\n\n// Rexports of internal for libraries to use.\n// See: https://github.com/date-fns/date-fns/issues/3638#issuecomment-1877082874\nexport { longFormatters, parsers };\n\n/**\n * The {@link parse} function options.\n */\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;\n\nconst notWhitespaceRegExp = /\\S/;\nconst unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n\n/**\n * @name parse\n * @category Common Helpers\n * @summary Parse the date.\n *\n * @description\n * Return the date parsed from string using the given format string.\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 in the format string 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 *\n * Format of the format 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 5 below the table).\n *\n * Not all tokens are compatible. Combinations that don't make sense or could lead to bugs are prohibited\n * and will throw `RangeError`. For example usage of 24-hour format token with AM/PM token will throw an exception:\n *\n * ```javascript\n * parse('23 AM', 'HH a', new Date())\n * //=> RangeError: The format string mustn't contain `HH` and `a` at the same time\n * ```\n *\n * See the compatibility table: https://docs.google.com/spreadsheets/d/e/2PACX-1vQOPU3xUhplll6dyoMmVUXHKl_8CRDs6_ueLmex3SoqwhuolkuN3O05l4rqx5h1dKX8eb46Ul-CCSrq/pubhtml?gid=0&single=true\n *\n * Accepted format string patterns:\n * | Unit |Prior| Pattern | Result examples | Notes |\n * |---------------------------------|-----|---------|-----------------------------------|-------|\n * | Era | 140 | G..GGG | AD, BC | |\n * | | | GGGG | Anno Domini, Before Christ | 2 |\n * | | | GGGGG | A, B | |\n * | Calendar year | 130 | y | 44, 1, 1900, 2017, 9999 | 4 |\n * | | | yo | 44th, 1st, 1900th, 9999999th | 4,5 |\n * | | | yy | 44, 01, 00, 17 | 4 |\n * | | | yyy | 044, 001, 123, 999 | 4 |\n * | | | yyyy | 0044, 0001, 1900, 2017 | 4 |\n * | | | yyyyy | ... | 2,4 |\n * | Local week-numbering year | 130 | Y | 44, 1, 1900, 2017, 9000 | 4 |\n * | | | Yo | 44th, 1st, 1900th, 9999999th | 4,5 |\n * | | | YY | 44, 01, 00, 17 | 4,6 |\n * | | | YYY | 044, 001, 123, 999 | 4 |\n * | | | YYYY | 0044, 0001, 1900, 2017 | 4,6 |\n * | | | YYYYY | ... | 2,4 |\n * | ISO week-numbering year | 130 | R | -43, 1, 1900, 2017, 9999, -9999 | 4,5 |\n * | | | RR | -43, 01, 00, 17 | 4,5 |\n * | | | RRR | -043, 001, 123, 999, -999 | 4,5 |\n * | | | RRRR | -0043, 0001, 2017, 9999, -9999 | 4,5 |\n * | | | RRRRR | ... | 2,4,5 |\n * | Extended year | 130 | u | -43, 1, 1900, 2017, 9999, -999 | 4 |\n * | | | uu | -43, 01, 99, -99 | 4 |\n * | | | uuu | -043, 001, 123, 999, -999 | 4 |\n * | | | uuuu | -0043, 0001, 2017, 9999, -9999 | 4 |\n * | | | uuuuu | ... | 2,4 |\n * | Quarter (formatting) | 120 | Q | 1, 2, 3, 4 | |\n * | | | Qo | 1st, 2nd, 3rd, 4th | 5 |\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) | 120 | q | 1, 2, 3, 4 | |\n * | | | qo | 1st, 2nd, 3rd, 4th | 5 |\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 | 3 |\n * | Month (formatting) | 110 | M | 1, 2, ..., 12 | |\n * | | | Mo | 1st, 2nd, ..., 12th | 5 |\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) | 110 | L | 1, 2, ..., 12 | |\n * | | | Lo | 1st, 2nd, ..., 12th | 5 |\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 | 100 | w | 1, 2, ..., 53 | |\n * | | | wo | 1st, 2nd, ..., 53th | 5 |\n * | | | ww | 01, 02, ..., 53 | |\n * | ISO week of year | 100 | I | 1, 2, ..., 53 | 5 |\n * | | | Io | 1st, 2nd, ..., 53th | 5 |\n * | | | II | 01, 02, ..., 53 | 5 |\n * | Day of month | 90 | d | 1, 2, ..., 31 | |\n * | | | do | 1st, 2nd, ..., 31st | 5 |\n * | | | dd | 01, 02, ..., 31 | |\n * | Day of year | 90 | D | 1, 2, ..., 365, 366 | 7 |\n * | | | Do | 1st, 2nd, ..., 365th, 366th | 5 |\n * | | | DD | 01, 02, ..., 365, 366 | 7 |\n * | | | DDD | 001, 002, ..., 365, 366 | |\n * | | | DDDD | ... | 2 |\n * | Day of week (formatting) | 90 | 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) | 90 | i | 1, 2, 3, ..., 7 | 5 |\n * | | | io | 1st, 2nd, ..., 7th | 5 |\n * | | | ii | 01, 02, ..., 07 | 5 |\n * | | | iii | Mon, Tue, Wed, ..., Sun | 5 |\n * | | | iiii | Monday, Tuesday, ..., Sunday | 2,5 |\n * | | | iiiii | M, T, W, T, F, S, S | 5 |\n * | | | iiiiii | Mo, Tu, We, Th, Fr, Sa, Su | 5 |\n * | Local day of week (formatting) | 90 | e | 2, 3, 4, ..., 1 | |\n * | | | eo | 2nd, 3rd, ..., 1st | 5 |\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) | 90 | c | 2, 3, 4, ..., 1 | |\n * | | | co | 2nd, 3rd, ..., 1st | 5 |\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 | 80 | a..aaa | AM, PM | |\n * | | | aaaa | a.m., p.m. | 2 |\n * | | | aaaaa | a, p | |\n * | AM, PM, noon, midnight | 80 | b..bbb | AM, PM, noon, midnight | |\n * | | | bbbb | a.m., p.m., noon, midnight | 2 |\n * | | | bbbbb | a, p, n, mi | |\n * | Flexible day period | 80 | 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] | 70 | h | 1, 2, ..., 11, 12 | |\n * | | | ho | 1st, 2nd, ..., 11th, 12th | 5 |\n * | | | hh | 01, 02, ..., 11, 12 | |\n * | Hour [0-23] | 70 | H | 0, 1, 2, ..., 23 | |\n * | | | Ho | 0th, 1st, 2nd, ..., 23rd | 5 |\n * | | | HH | 00, 01, 02, ..., 23 | |\n * | Hour [0-11] | 70 | K | 1, 2, ..., 11, 0 | |\n * | | | Ko | 1st, 2nd, ..., 11th, 0th | 5 |\n * | | | KK | 01, 02, ..., 11, 00 | |\n * | Hour [1-24] | 70 | k | 24, 1, 2, ..., 23 | |\n * | | | ko | 24th, 1st, 2nd, ..., 23rd | 5 |\n * | | | kk | 24, 01, 02, ..., 23 | |\n * | Minute | 60 | m | 0, 1, ..., 59 | |\n * | | | mo | 0th, 1st, ..., 59th | 5 |\n * | | | mm | 00, 01, ..., 59 | |\n * | Second | 50 | s | 0, 1, ..., 59 | |\n * | | | so | 0th, 1st, ..., 59th | 5 |\n * | | | ss | 00, 01, ..., 59 | |\n * | Seconds timestamp | 40 | t | 512969520 | |\n * | | | tt | ... | 2 |\n * | Fraction of second | 30 | S | 0, 1, ..., 9 | |\n * | | | SS | 00, 01, ..., 99 | |\n * | | | SSS | 000, 001, ..., 999 | |\n * | | | SSSS | ... | 2 |\n * | Milliseconds timestamp | 20 | T | 512969520900 | |\n * | | | TT | ... | 2 |\n * | Timezone (ISO-8601 w/ Z) | 10 | 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) | 10 | 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 * | Long localized date | NA | P | 05/29/1453 | 5,8 |\n * | | | PP | May 29, 1453 | |\n * | | | PPP | May 29th, 1453 | |\n * | | | PPPP | Sunday, May 29th, 1453 | 2,5,8 |\n * | Long localized time | NA | p | 12:00 AM | 5,8 |\n * | | | pp | 12:00:00 AM | |\n * | Combination of date and time | NA | Pp | 05/29/1453, 12:00 AM | |\n * | | | PPpp | May 29, 1453, 12:00:00 AM | |\n * | | | PPPpp | May 29th, 1453 at ... | |\n * | | | PPPPpp | Sunday, May 29th, 1453 at ... | 2,5,8 |\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 * In `format` function, they will produce different result:\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 * `parse` will try to match both formatting and stand-alone units interchangably.\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:\n * - for numerical units (`yyyyyyyy`) `parse` will try to match a number\n * as wide as the sequence\n * - for text units (`MMMMMMMM`) `parse` will try to match the widest variation of the unit.\n * These variations are marked with \"2\" in the last column of the table.\n *\n * 3. `QQQQQ` and `qqqqq` could be not strictly numerical in some locales.\n * These tokens represent the shortest form of the quarter.\n *\n * 4. 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` will try to guess the century of two digit year by proximity with `referenceDate`:\n *\n * `parse('50', 'yy', new Date(2018, 0, 1)) //=> Sat Jan 01 2050 00:00:00`\n *\n * `parse('75', 'yy', new Date(2018, 0, 1)) //=> Wed Jan 01 1975 00:00:00`\n *\n * while `uu` will just assign the year as is:\n *\n * `parse('50', 'uu', new Date(2018, 0, 1)) //=> Sat Jan 01 0050 00:00:00`\n *\n * `parse('75', 'uu', new Date(2018, 0, 1)) //=> Tue Jan 01 0075 00:00:00`\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 [setISOWeekYear](https://date-fns.org/docs/setISOWeekYear)\n * and [setWeekYear](https://date-fns.org/docs/setWeekYear)).\n *\n * 5. 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 * - `o`: ordinal number modifier\n * - `P`: long localized date\n * - `p`: long localized time\n *\n * 6. `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 * 7. `D` and `DD` tokens represent days of the year but they are ofthen 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 * 8. `P+` tokens do not have a defined priority since they are merely aliases to other tokens based\n * on the given locale.\n *\n * using `en-US` locale: `P` => `MM/dd/yyyy`\n * using `en-US` locale: `p` => `hh:mm a`\n * using `pt-BR` locale: `P` => `dd/MM/yyyy`\n * using `pt-BR` locale: `p` => `HH:mm`\n *\n * Values will be assigned to the date in the descending order of its unit's priority.\n * Units of an equal priority overwrite each other in the order of appearance.\n *\n * If no values of higher priority are parsed (e.g. when parsing string 'January 1st' without a year),\n * the values will be taken from 3rd argument `referenceDate` which works as a context of parsing.\n *\n * `referenceDate` must be passed for correct work of the function.\n * If you're not sure which `referenceDate` to supply, create a new instance of Date:\n * `parse('02/11/2014', 'MM/dd/yyyy', new Date())`\n * In this case parsing will be done in the context of the current date.\n * If `referenceDate` is `Invalid Date` or a value not convertible to valid `Date`,\n * then `Invalid Date` will be returned.\n *\n * The result may vary by locale.\n *\n * If `formatString` matches with `dateString` but does not provides tokens, `referenceDate` will be returned.\n *\n * If parsing failed, `Invalid Date` will be returned.\n * Invalid Date is a Date, whose time value is NaN.\n * Time value of Date: http://es5.github.io/#x15.9.1.1\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 dateStr - The string to parse\n * @param formatStr - The string of tokens\n * @param referenceDate - defines values missing from the parsed dateString\n * @param options - An object with options.\n * see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * @returns The parsed date\n *\n * @throws `options.locale` must contain `match` 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 * // Parse 11 February 2014 from middle-endian format:\n * var result = parse('02/11/2014', 'MM/dd/yyyy', new Date())\n * //=> Tue Feb 11 2014 00:00:00\n *\n * @example\n * // Parse 28th of February in Esperanto locale in the context of 2010 year:\n * import eo from 'date-fns/locale/eo'\n * var result = parse('28-a de februaro', \"do 'de' MMMM\", new Date(2010, 0, 1), {\n * locale: eo\n * })\n * //=> Sun Feb 28 2010 00:00:00\n */\nexport function parse(dateStr, formatStr, referenceDate, 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 if (formatStr === \"\") {\n if (dateStr === \"\") {\n return toDate(referenceDate);\n } else {\n return constructFrom(referenceDate, NaN);\n }\n }\n\n const subFnOptions = {\n firstWeekContainsDate,\n weekStartsOn,\n locale,\n };\n\n // If timezone isn't specified, it will be set to the system timezone\n const setters = [new DateToSystemTimezoneSetter()];\n\n const tokens = formatStr\n .match(longFormattingTokensRegExp)\n .map((substring) => {\n const firstCharacter = substring[0];\n if (firstCharacter in longFormatters) {\n const longFormatter = longFormatters[firstCharacter];\n return longFormatter(substring, locale.formatLong);\n }\n return substring;\n })\n .join(\"\")\n .match(formattingTokensRegExp);\n\n const usedTokens = [];\n\n for (let token of tokens) {\n if (\n !options?.useAdditionalWeekYearTokens &&\n isProtectedWeekYearToken(token)\n ) {\n warnOrThrowProtectedError(token, formatStr, dateStr);\n }\n if (\n !options?.useAdditionalDayOfYearTokens &&\n isProtectedDayOfYearToken(token)\n ) {\n warnOrThrowProtectedError(token, formatStr, dateStr);\n }\n\n const firstCharacter = token[0];\n const parser = parsers[firstCharacter];\n if (parser) {\n const { incompatibleTokens } = parser;\n if (Array.isArray(incompatibleTokens)) {\n const incompatibleToken = usedTokens.find(\n (usedToken) =>\n incompatibleTokens.includes(usedToken.token) ||\n usedToken.token === firstCharacter,\n );\n if (incompatibleToken) {\n throw new RangeError(\n `The format string mustn't contain \\`${incompatibleToken.fullToken}\\` and \\`${token}\\` at the same time`,\n );\n }\n } else if (parser.incompatibleTokens === \"*\" && usedTokens.length > 0) {\n throw new RangeError(\n `The format string mustn't contain \\`${token}\\` and any other token at the same time`,\n );\n }\n\n usedTokens.push({ token: firstCharacter, fullToken: token });\n\n const parseResult = parser.run(\n dateStr,\n token,\n locale.match,\n subFnOptions,\n );\n\n if (!parseResult) {\n return constructFrom(referenceDate, NaN);\n }\n\n setters.push(parseResult.setter);\n\n dateStr = parseResult.rest;\n } else {\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 // Replace two single quote characters with one single quote character\n if (token === \"''\") {\n token = \"'\";\n } else if (firstCharacter === \"'\") {\n token = cleanEscapedString(token);\n }\n\n // Cut token from string, or, if string doesn't match the token, return Invalid Date\n if (dateStr.indexOf(token) === 0) {\n dateStr = dateStr.slice(token.length);\n } else {\n return constructFrom(referenceDate, NaN);\n }\n }\n }\n\n // Check if the remaining input contains something other than whitespace\n if (dateStr.length > 0 && notWhitespaceRegExp.test(dateStr)) {\n return constructFrom(referenceDate, NaN);\n }\n\n const uniquePrioritySetters = setters\n .map((setter) => setter.priority)\n .sort((a, b) => b - a)\n .filter((priority, index, array) => array.indexOf(priority) === index)\n .map((priority) =>\n setters\n .filter((setter) => setter.priority === priority)\n .sort((a, b) => b.subPriority - a.subPriority),\n )\n .map((setterArray) => setterArray[0]);\n\n let date = toDate(referenceDate);\n\n if (isNaN(date.getTime())) {\n return constructFrom(referenceDate, NaN);\n }\n\n const flags = {};\n for (const setter of uniquePrioritySetters) {\n if (!setter.validate(date, subFnOptions)) {\n return constructFrom(referenceDate, NaN);\n }\n\n const result = setter.set(date, flags, subFnOptions);\n // Result is tuple (date, flags)\n if (Array.isArray(result)) {\n date = result[0];\n Object.assign(flags, result[1]);\n // Result is date\n } else {\n date = result;\n }\n }\n\n return constructFrom(referenceDate, date);\n}\n\nfunction cleanEscapedString(input) {\n return input.match(escapedStringRegExp)[1].replace(doubleQuoteRegExp, \"'\");\n}\n\n// Fallback for modularized imports:\nexport default parse;\n","import { getDefaultOptions as getInternalDefaultOptions } from \"./_lib/defaultOptions.mjs\";\n\n/**\n * @name getDefaultOptions\n * @category Common Helpers\n * @summary Get default options.\n * @pure false\n *\n * @description\n * Returns an object that contains defaults for\n * `options.locale`, `options.weekStartsOn` and `options.firstWeekContainsDate`\n * arguments for all functions.\n *\n * You can change these with [setDefaultOptions](https://date-fns.org/docs/setDefaultOptions).\n *\n * @returns The default options\n *\n * @example\n * const result = getDefaultOptions()\n * //=> {}\n *\n * @example\n * setDefaultOptions({ weekStarsOn: 1, firstWeekContainsDate: 4 })\n * const result = getDefaultOptions()\n * //=> { weekStarsOn: 1, firstWeekContainsDate: 4 }\n */\nexport function getDefaultOptions() {\n return Object.assign({}, getInternalDefaultOptions());\n}\n\n// Fallback for modularized imports:\nexport default getDefaultOptions;\n","import { millisecondsInHour, millisecondsInMinute } from \"./constants.mjs\";\n\n/**\n * The {@link parseISO} function options.\n */\n\n/**\n * @name parseISO\n * @category Common Helpers\n * @summary Parse ISO string\n *\n * @description\n * Parse the given string in ISO 8601 format and return an instance of Date.\n *\n * Function accepts complete ISO 8601 formats as well as partial implementations.\n * ISO 8601: http://en.wikipedia.org/wiki/ISO_8601\n *\n * If the argument isn't a string, the function cannot parse the string or\n * the values are invalid, it returns Invalid 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 *\n * @param argument - The value to convert\n * @param options - An object with options\n *\n * @returns The parsed date in the local time zone\n *\n * @example\n * // Convert string '2014-02-11T11:30:30' to date:\n * const result = parseISO('2014-02-11T11:30:30')\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert string '+02014101' to date,\n * // if the additional number of digits in the extended year format is 1:\n * const result = parseISO('+02014101', { additionalDigits: 1 })\n * //=> Fri Apr 11 2014 00:00:00\n */\nexport function parseISO(argument, options) {\n const additionalDigits = options?.additionalDigits ?? 2;\n const dateStrings = splitDateString(argument);\n\n let date;\n if (dateStrings.date) {\n const parseYearResult = parseYear(dateStrings.date, additionalDigits);\n date = parseDate(parseYearResult.restDateString, parseYearResult.year);\n }\n\n if (!date || isNaN(date.getTime())) {\n return new Date(NaN);\n }\n\n const timestamp = date.getTime();\n let time = 0;\n let offset;\n\n if (dateStrings.time) {\n time = parseTime(dateStrings.time);\n if (isNaN(time)) {\n return new Date(NaN);\n }\n }\n\n if (dateStrings.timezone) {\n offset = parseTimezone(dateStrings.timezone);\n if (isNaN(offset)) {\n return new Date(NaN);\n }\n } else {\n const dirtyDate = new Date(timestamp + time);\n // JS parsed string assuming it's in UTC timezone\n // but we need it to be parsed in our timezone\n // so we use utc values to build date in our timezone.\n // Year values from 0 to 99 map to the years 1900 to 1999\n // so set year explicitly with setFullYear.\n const result = new Date(0);\n result.setFullYear(\n dirtyDate.getUTCFullYear(),\n dirtyDate.getUTCMonth(),\n dirtyDate.getUTCDate(),\n );\n result.setHours(\n dirtyDate.getUTCHours(),\n dirtyDate.getUTCMinutes(),\n dirtyDate.getUTCSeconds(),\n dirtyDate.getUTCMilliseconds(),\n );\n return result;\n }\n\n return new Date(timestamp + time + offset);\n}\n\nconst patterns = {\n dateTimeDelimiter: /[T ]/,\n timeZoneDelimiter: /[Z ]/i,\n timezone: /([Z+-].*)$/,\n};\n\nconst dateRegex =\n /^-?(?:(\\d{3})|(\\d{2})(?:-?(\\d{2}))?|W(\\d{2})(?:-?(\\d{1}))?|)$/;\nconst timeRegex =\n /^(\\d{2}(?:[.,]\\d*)?)(?::?(\\d{2}(?:[.,]\\d*)?))?(?::?(\\d{2}(?:[.,]\\d*)?))?$/;\nconst timezoneRegex = /^([+-])(\\d{2})(?::?(\\d{2}))?$/;\n\nfunction splitDateString(dateString) {\n const dateStrings = {};\n const array = dateString.split(patterns.dateTimeDelimiter);\n let timeString;\n\n // The regex match should only return at maximum two array elements.\n // [date], [time], or [date, time].\n if (array.length > 2) {\n return dateStrings;\n }\n\n if (/:/.test(array[0])) {\n timeString = array[0];\n } else {\n dateStrings.date = array[0];\n timeString = array[1];\n if (patterns.timeZoneDelimiter.test(dateStrings.date)) {\n dateStrings.date = dateString.split(patterns.timeZoneDelimiter)[0];\n timeString = dateString.substr(\n dateStrings.date.length,\n dateString.length,\n );\n }\n }\n\n if (timeString) {\n const token = patterns.timezone.exec(timeString);\n if (token) {\n dateStrings.time = timeString.replace(token[1], \"\");\n dateStrings.timezone = token[1];\n } else {\n dateStrings.time = timeString;\n }\n }\n\n return dateStrings;\n}\n\nfunction parseYear(dateString, additionalDigits) {\n const regex = new RegExp(\n \"^(?:(\\\\d{4}|[+-]\\\\d{\" +\n (4 + additionalDigits) +\n \"})|(\\\\d{2}|[+-]\\\\d{\" +\n (2 + additionalDigits) +\n \"})$)\",\n );\n\n const captures = dateString.match(regex);\n // Invalid ISO-formatted year\n if (!captures) return { year: NaN, restDateString: \"\" };\n\n const year = captures[1] ? parseInt(captures[1]) : null;\n const century = captures[2] ? parseInt(captures[2]) : null;\n\n // either year or century is null, not both\n return {\n year: century === null ? year : century * 100,\n restDateString: dateString.slice((captures[1] || captures[2]).length),\n };\n}\n\nfunction parseDate(dateString, year) {\n // Invalid ISO-formatted year\n if (year === null) return new Date(NaN);\n\n const captures = dateString.match(dateRegex);\n // Invalid ISO-formatted string\n if (!captures) return new Date(NaN);\n\n const isWeekDate = !!captures[4];\n const dayOfYear = parseDateUnit(captures[1]);\n const month = parseDateUnit(captures[2]) - 1;\n const day = parseDateUnit(captures[3]);\n const week = parseDateUnit(captures[4]);\n const dayOfWeek = parseDateUnit(captures[5]) - 1;\n\n if (isWeekDate) {\n if (!validateWeekDate(year, week, dayOfWeek)) {\n return new Date(NaN);\n }\n return dayOfISOWeekYear(year, week, dayOfWeek);\n } else {\n const date = new Date(0);\n if (\n !validateDate(year, month, day) ||\n !validateDayOfYearDate(year, dayOfYear)\n ) {\n return new Date(NaN);\n }\n date.setUTCFullYear(year, month, Math.max(dayOfYear, day));\n return date;\n }\n}\n\nfunction parseDateUnit(value) {\n return value ? parseInt(value) : 1;\n}\n\nfunction parseTime(timeString) {\n const captures = timeString.match(timeRegex);\n if (!captures) return NaN; // Invalid ISO-formatted time\n\n const hours = parseTimeUnit(captures[1]);\n const minutes = parseTimeUnit(captures[2]);\n const seconds = parseTimeUnit(captures[3]);\n\n if (!validateTime(hours, minutes, seconds)) {\n return NaN;\n }\n\n return (\n hours * millisecondsInHour + minutes * millisecondsInMinute + seconds * 1000\n );\n}\n\nfunction parseTimeUnit(value) {\n return (value && parseFloat(value.replace(\",\", \".\"))) || 0;\n}\n\nfunction parseTimezone(timezoneString) {\n if (timezoneString === \"Z\") return 0;\n\n const captures = timezoneString.match(timezoneRegex);\n if (!captures) return 0;\n\n const sign = captures[1] === \"+\" ? -1 : 1;\n const hours = parseInt(captures[2]);\n const minutes = (captures[3] && parseInt(captures[3])) || 0;\n\n if (!validateTimezone(hours, minutes)) {\n return NaN;\n }\n\n return sign * (hours * millisecondsInHour + minutes * millisecondsInMinute);\n}\n\nfunction dayOfISOWeekYear(isoWeekYear, week, day) {\n const date = new Date(0);\n date.setUTCFullYear(isoWeekYear, 0, 4);\n const fourthOfJanuaryDay = date.getUTCDay() || 7;\n const diff = (week - 1) * 7 + day + 1 - fourthOfJanuaryDay;\n date.setUTCDate(date.getUTCDate() + diff);\n return date;\n}\n\n// Validation functions\n\n// February is null to handle the leap year (using ||)\nconst daysInMonths = [31, null, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\n\nfunction isLeapYearIndex(year) {\n return year % 400 === 0 || (year % 4 === 0 && year % 100 !== 0);\n}\n\nfunction validateDate(year, month, date) {\n return (\n month >= 0 &&\n month <= 11 &&\n date >= 1 &&\n date <= (daysInMonths[month] || (isLeapYearIndex(year) ? 29 : 28))\n );\n}\n\nfunction validateDayOfYearDate(year, dayOfYear) {\n return dayOfYear >= 1 && dayOfYear <= (isLeapYearIndex(year) ? 366 : 365);\n}\n\nfunction validateWeekDate(_year, week, day) {\n return week >= 1 && week <= 53 && day >= 0 && day <= 6;\n}\n\nfunction validateTime(hours, minutes, seconds) {\n if (hours === 24) {\n return minutes === 0 && seconds === 0;\n }\n\n return (\n seconds >= 0 &&\n seconds < 60 &&\n minutes >= 0 &&\n minutes < 60 &&\n hours >= 0 &&\n hours < 25\n );\n}\n\nfunction validateTimezone(_hours, minutes) {\n return minutes >= 0 && minutes <= 59;\n}\n\n// Fallback for modularized imports:\nexport default parseISO;\n","import { constructFrom } from \"./constructFrom.mjs\";\nimport { setMonth } from \"./setMonth.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name set\n * @category Common Helpers\n * @summary Set date values to a given date.\n *\n * @description\n * Set date values to a given date.\n *\n * Sets time values to date from object `values`.\n * A value is not set if it is undefined or null or doesn't exist in `values`.\n *\n * Note about bundle size: `set` does not internally use `setX` functions from date-fns but instead opts\n * to use native `Date#setX` methods. If you use this function, you may not want to include the\n * other `setX` functions that date-fns provides if you are concerned about the bundle size.\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 date to be changed\n * @param values - The date values to be set\n *\n * @returns The new date with options set\n *\n * @example\n * // Transform 1 September 2014 into 20 October 2015 in a single line:\n * const result = set(new Date(2014, 8, 20), { year: 2015, month: 9, date: 20 })\n * //=> Tue Oct 20 2015 00:00:00\n *\n * @example\n * // Set 12 PM to 1 September 2014 01:23:45 to 1 September 2014 12:00:00:\n * const result = set(new Date(2014, 8, 1, 1, 23, 45), { hours: 12 })\n * //=> Mon Sep 01 2014 12:23:45\n */\n\nexport function set(date, values) {\n let _date = toDate(date);\n\n // Check if date is Invalid Date because Date.prototype.setFullYear ignores the value of Invalid Date\n if (isNaN(+_date)) {\n return constructFrom(date, NaN);\n }\n\n if (values.year != null) {\n _date.setFullYear(values.year);\n }\n\n if (values.month != null) {\n _date = setMonth(_date, values.month);\n }\n\n if (values.date != null) {\n _date.setDate(values.date);\n }\n\n if (values.hours != null) {\n _date.setHours(values.hours);\n }\n\n if (values.minutes != null) {\n _date.setMinutes(values.minutes);\n }\n\n if (values.seconds != null) {\n _date.setSeconds(values.seconds);\n }\n\n if (values.milliseconds != null) {\n _date.setMilliseconds(values.milliseconds);\n }\n\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default set;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name setHours\n * @category Hour Helpers\n * @summary Set the hours to the given date.\n *\n * @description\n * Set the hours 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 *\n * @param date - The date to be changed\n * @param hours - The hours of the new date\n *\n * @returns The new date with the hours set\n *\n * @example\n * // Set 4 hours to 1 September 2014 11:30:00:\n * const result = setHours(new Date(2014, 8, 1, 11, 30), 4)\n * //=> Mon Sep 01 2014 04:30:00\n */\nexport function setHours(date, hours) {\n const _date = toDate(date);\n _date.setHours(hours);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setHours;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name setMinutes\n * @category Minute Helpers\n * @summary Set the minutes to the given date.\n *\n * @description\n * Set the minutes 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 *\n * @param date - The date to be changed\n * @param minutes - The minutes of the new date\n *\n * @returns The new date with the minutes set\n *\n * @example\n * // Set 45 minutes to 1 September 2014 11:30:40:\n * const result = setMinutes(new Date(2014, 8, 1, 11, 30, 40), 45)\n * //=> Mon Sep 01 2014 11:45:40\n */\nexport function setMinutes(date, minutes) {\n const _date = toDate(date);\n _date.setMinutes(minutes);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setMinutes;\n","import { constructFrom } from \"./constructFrom.mjs\";\nimport { getDaysInMonth } from \"./getDaysInMonth.mjs\";\nimport { toDate } from \"./toDate.mjs\";\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 *\n * @param date - The date to be changed\n * @param month - The month index to set (0-11)\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) {\n const _date = toDate(date);\n const year = _date.getFullYear();\n const day = _date.getDate();\n\n const dateWithDesiredMonth = constructFrom(date, 0);\n dateWithDesiredMonth.setFullYear(year, month, 15);\n dateWithDesiredMonth.setHours(0, 0, 0, 0);\n const daysInMonth = getDaysInMonth(dateWithDesiredMonth);\n // Set the last day of the new month\n // if the original date was the last day of the longer month\n _date.setMonth(month, Math.min(day, daysInMonth));\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setMonth;\n","import { toDate } from \"./toDate.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\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.\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 given date\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) {\n const _date = toDate(date);\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 { setMonth } from \"./setMonth.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name setQuarter\n * @category Quarter Helpers\n * @summary Set the year quarter to the given date.\n *\n * @description\n * Set the year quarter 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 *\n * @param date - The date to be changed\n * @param quarter - The quarter of the new date\n *\n * @returns The new date with the quarter set\n *\n * @example\n * // Set the 2nd quarter to 2 July 2014:\n * const result = setQuarter(new Date(2014, 6, 2), 2)\n * //=> Wed Apr 02 2014 00:00:00\n */\nexport function setQuarter(date, quarter) {\n const _date = toDate(date);\n const oldQuarter = Math.trunc(_date.getMonth() / 3) + 1;\n const diff = quarter - oldQuarter;\n return setMonth(_date, _date.getMonth() + diff * 3);\n}\n\n// Fallback for modularized imports:\nexport default setQuarter;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name setSeconds\n * @category Second Helpers\n * @summary Set the seconds to the given date.\n *\n * @description\n * Set the seconds 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 *\n * @param date - The date to be changed\n * @param seconds - The seconds of the new date\n *\n * @returns The new date with the seconds set\n *\n * @example\n * // Set 45 seconds to 1 September 2014 11:30:40:\n * const result = setSeconds(new Date(2014, 8, 1, 11, 30, 40), 45)\n * //=> Mon Sep 01 2014 11:30:45\n */\nexport function setSeconds(date, seconds) {\n const _date = toDate(date);\n _date.setSeconds(seconds);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setSeconds;\n","import { constructFrom } from \"./constructFrom.mjs\";\nimport { toDate } from \"./toDate.mjs\";\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 *\n * @param date - The date to be changed\n * @param year - The year of the new date\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) {\n const _date = toDate(date);\n\n // Check if date is Invalid Date because Date.prototype.setFullYear ignores the value of Invalid Date\n if (isNaN(+_date)) {\n return constructFrom(date, NaN);\n }\n\n _date.setFullYear(year);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setYear;\n","import { toDate } from \"./toDate.mjs\";\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 *\n * @param date - The original date\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) {\n const _date = toDate(date);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfDay;\n","import { startOfWeek } from \"./startOfWeek.mjs\";\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 *\n * @param date - The original date\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) {\n return startOfWeek(date, { weekStartsOn: 1 });\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeek;\n","import { toDate } from \"./toDate.mjs\";\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.\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 *\n * @param date - The original date\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) {\n const _date = toDate(date);\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.mjs\";\n\n/**\n * @name startOfQuarter\n * @category Quarter Helpers\n * @summary Return the start of a year quarter for the given date.\n *\n * @description\n * Return the start of a year quarter 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 *\n * @param date - The original date\n *\n * @returns The start of a quarter\n *\n * @example\n * // The start of a quarter for 2 September 2014 11:55:00:\n * const result = startOfQuarter(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Tue Jul 01 2014 00:00:00\n */\nexport function startOfQuarter(date) {\n const _date = toDate(date);\n const currentMonth = _date.getMonth();\n const month = currentMonth - (currentMonth % 3);\n _date.setMonth(month, 1);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfQuarter;\n","import { toDate } from \"./toDate.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\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 *\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);\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 { toDate } from \"./toDate.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\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 *\n * @param date - The original date\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) {\n const cleanDate = toDate(date);\n const _date = constructFrom(date, 0);\n _date.setFullYear(cleanDate.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 { addDays } from \"./addDays.mjs\";\n\n/**\n * @name subDays\n * @category Day Helpers\n * @summary Subtract the specified number of days from the given date.\n *\n * @description\n * Subtract the specified number of days from 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 *\n * @param date - The date to be changed\n * @param amount - The amount of days to be subtracted.\n *\n * @returns The new date with the days subtracted\n *\n * @example\n * // Subtract 10 days from 1 September 2014:\n * const result = subDays(new Date(2014, 8, 1), 10)\n * //=> Fri Aug 22 2014 00:00:00\n */\nexport function subDays(date, amount) {\n return addDays(date, -amount);\n}\n\n// Fallback for modularized imports:\nexport default subDays;\n","import { addMonths } from \"./addMonths.mjs\";\n\n/**\n * @name subMonths\n * @category Month Helpers\n * @summary Subtract the specified number of months from the given date.\n *\n * @description\n * Subtract the specified number of months from 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 *\n * @param date - The date to be changed\n * @param amount - The amount of months to be subtracted.\n *\n * @returns The new date with the months subtracted\n *\n * @example\n * // Subtract 5 months from 1 February 2015:\n * const result = subMonths(new Date(2015, 1, 1), 5)\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function subMonths(date, amount) {\n return addMonths(date, -amount);\n}\n\n// Fallback for modularized imports:\nexport default subMonths;\n","import { addQuarters } from \"./addQuarters.mjs\";\n\n/**\n * @name subQuarters\n * @category Quarter Helpers\n * @summary Subtract the specified number of year quarters from the given date.\n *\n * @description\n * Subtract the specified number of year quarters from 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 *\n * @param date - The date to be changed\n * @param amount - The amount of quarters to be subtracted.\n *\n * @returns The new date with the quarters subtracted\n *\n * @example\n * // Subtract 3 quarters from 1 September 2014:\n * const result = subQuarters(new Date(2014, 8, 1), 3)\n * //=> Sun Dec 01 2013 00:00:00\n */\nexport function subQuarters(date, amount) {\n return addQuarters(date, -amount);\n}\n\n// Fallback for modularized imports:\nexport default subQuarters;\n","import { addWeeks } from \"./addWeeks.mjs\";\n\n/**\n * @name subWeeks\n * @category Week Helpers\n * @summary Subtract the specified number of weeks from the given date.\n *\n * @description\n * Subtract the specified number of weeks from 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 *\n * @param date - The date to be changed\n * @param amount - The amount of weeks to be subtracted.\n *\n * @returns The new date with the weeks subtracted\n *\n * @example\n * // Subtract 4 weeks from 1 September 2014:\n * const result = subWeeks(new Date(2014, 8, 1), 4)\n * //=> Mon Aug 04 2014 00:00:00\n */\nexport function subWeeks(date, amount) {\n return addWeeks(date, -amount);\n}\n\n// Fallback for modularized imports:\nexport default subWeeks;\n","import { addYears } from \"./addYears.mjs\";\n\n/**\n * @name subYears\n * @category Year Helpers\n * @summary Subtract the specified number of years from the given date.\n *\n * @description\n * Subtract the specified number of years from 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 *\n * @param date - The date to be changed\n * @param amount - The amount of years to be subtracted.\n *\n * @returns The new date with the years subtracted\n *\n * @example\n * // Subtract 5 years from 1 September 2014:\n * const result = subYears(new Date(2014, 8, 1), 5)\n * //=> Tue Sep 01 2009 00:00:00\n */\nexport function subYears(date, amount) {\n return addYears(date, -amount);\n}\n\n// Fallback for modularized imports:\nexport default subYears;\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 * **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 *\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) {\n const argStr = Object.prototype.toString.call(argument);\n\n // Clone the date\n if (\n argument instanceof Date ||\n (typeof argument === \"object\" && argStr === \"[object Date]\")\n ) {\n // Prevent the date to lose the milliseconds when passed to new Date() in IE10\n return new argument.constructor(+argument);\n } else if (\n typeof argument === \"number\" ||\n argStr === \"[object Number]\" ||\n typeof argument === \"string\" ||\n argStr === \"[object String]\"\n ) {\n // TODO: Can we get rid of as?\n return new Date(argument);\n } else {\n // TODO: Can we get rid of as?\n return new Date(NaN);\n }\n}\n\n// Fallback for modularized imports:\nexport default toDate;\n"],"names":["defaultOptions","getDefaultOptions","dateLongFormatter","pattern","formatLong","timeLongFormatter","longFormatters","dateTimeFormat","matchResult","datePattern","timePattern","getTimezoneOffsetInMilliseconds","date","_date","utcDate","Date","dayOfYearTokenRE","weekYearTokenRE","throwTokens","isProtectedDayOfYearToken","token","isProtectedWeekYearToken","warnOrThrowProtectedError","format","input","_message","message","subject","console","RangeError","addDays","amount","isNaN","NaN","addHours","addMilliseconds","timestamp","addMinutes","addMonths","dayOfMonth","endOfDesiredMonth","addQuarters","addSeconds","addWeeks","addYears","millisecondsInWeek","millisecondsInDay","millisecondsInMinute","millisecondsInHour","millisecondsInSecond","constructFrom","value","differenceInCalendarDays","dateLeft","dateRight","startOfDayLeft","startOfDayRight","Math","timestampLeft","differenceInCalendarMonths","_dateLeft","_dateRight","yearDiff","differenceInCalendarQuarters","differenceInCalendarYears","differenceInDays","sign","compareLocalAsc","difference","isLastDayNotFull","Number","result","diff","endOfDay","endOfMonth","month","endOfWeek","options","weekStartsOn","day","endOfYear","year","addLeadingZeros","number","targetLength","output","lightFormatters","signedYear","String","dayPeriodEnumValue","numberOfDigits","milliseconds","dayPeriodEnum","formatters","localize","era","signedWeekYear","getWeekYear","weekYear","getISOWeekYear","quarter","week","getWeek","isoWeek","getISOWeek","dayOfYear","toDate","startOfYear","dayOfWeek","localDayOfWeek","isoDayOfWeek","hours","_localize","timezoneOffset","formatTimezoneWithOptionalMinutes","formatTimezone","formatTimezoneShort","offset","delimiter","absOffset","minutes","formattingTokensRegExp","longFormattingTokensRegExp","escapedStringRegExp","doubleQuoteRegExp","unescapedLatinCharacterRegExp","formatStr","locale","firstWeekContainsDate","originalDate","isValid","parts","substring","firstCharacter","longFormatter","cleanEscapedString","matched","formatterOptions","part","formatter","getDate","getDay","getHours","startOfISOWeek","startOfISOWeekYear","fourthOfJanuary","fourthOfJanuaryOfNextYear","startOfNextYear","fourthOfJanuaryOfThisYear","startOfThisYear","getMinutes","getMonth","getQuarter","getSeconds","getTime","startOfWeek","startOfWeekYear","firstWeek","firstWeekOfNextYear","firstWeekOfThisYear","getYear","isAfter","dateToCompare","_dateToCompare","isBefore","isDate","Object","isEqual","leftDate","rightDate","isSameDay","isSameMonth","isSameQuarter","isSameYear","isWithinInterval","interval","time","startTime","endTime","a","b","args","formatDistanceLocale","buildFormatLongFn","width","formatRelativeLocale","buildLocalizeFn","valuesArray","context","defaultWidth","buildMatchFn","string","matchPattern","matchedString","parsePatterns","key","Array","findIndex","array","predicate","findKey","object","rest","enUS","count","tokenValue","_baseDate","_options","ordinalNumber","dirtyNumber","rem100","parseInt","parseResult","index","max","dates","dirtyDate","currentDate","undefined","min","Setter","_utcDate","ValueSetter","validateValue","setValue","priority","subPriority","flags","DateToSystemTimezoneSetter","transpose","fromDate","constructor","Parser","dateString","match","_value","numericPatterns","timezonePatterns","mapValue","parseFnResult","mapFn","parseNumericPattern","parseTimezonePattern","seconds","parseAnyDigitsSigned","parseNDigits","n","RegExp","parseNDigitsSigned","dayPeriodEnumToHours","dayPeriod","normalizeTwoDigitYear","twoDigitYear","currentYear","isCommonEra","absCurrentYear","rangeEnd","isPreviousCentury","isLeapYearIndex","DAYS_IN_MONTH","DAYS_IN_MONTH_LEAP_YEAR","setDay","currentDay","delta","dayIndex","remainder","parsers","valueCallback","normalizedTwoDigitYear","_flags","firstWeekOfYear","isLeapYear","wholeWeekDays","setISODay","isPM","notWhitespaceRegExp","dateStr","referenceDate","subFnOptions","setters","tokens","usedTokens","parser","incompatibleTokens","incompatibleToken","usedToken","uniquePrioritySetters","setter","setterArray","parseISO","argument","additionalDigits","dateStrings","splitDateString","timeString","patterns","parseYearResult","parseYear","regex","captures","century","parseDate","_year","dateRegex","isWeekDate","parseDateUnit","dayOfISOWeekYear","isoWeekYear","fourthOfJanuaryDay","daysInMonths","parseTime","timeRegex","parseTimeUnit","parseTimezone","timezoneString","_hours","timezoneRegex","parseFloat","set","values","setHours","setMinutes","dateWithDesiredMonth","daysInMonth","monthIndex","lastDayOfMonth","setQuarter","oldQuarter","setSeconds","setYear","startOfDay","startOfMonth","startOfQuarter","currentMonth","cleanDate","subDays","subMonths","subQuarters","subWeeks","subYears","argStr"],"mappings":"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"}