{"version":3,"file":"js/417-424071441eba78dd68f1.js","mappings":"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","sources":["webpack://app/./node_modules/clsx/dist/clsx.js","webpack://app/./node_modules/dayjs/dayjs.min.js","webpack://app/./node_modules/date-fns/locale/en-US/_lib/formatDistance.js","webpack://app/./node_modules/date-fns/locale/_lib/buildFormatLongFn.js","webpack://app/./node_modules/date-fns/locale/en-US/_lib/formatLong.js","webpack://app/./node_modules/date-fns/locale/en-US/_lib/formatRelative.js","webpack://app/./node_modules/date-fns/locale/_lib/buildLocalizeFn.js","webpack://app/./node_modules/date-fns/locale/_lib/buildMatchFn.js","webpack://app/./node_modules/date-fns/locale/_lib/buildMatchPatternFn.js","webpack://app/./node_modules/date-fns/locale/en-US.js","webpack://app/./node_modules/date-fns/locale/en-US/_lib/localize.js","webpack://app/./node_modules/date-fns/locale/en-US/_lib/match.js","webpack://app/./node_modules/date-fns/_lib/defaultOptions.js","webpack://app/./node_modules/date-fns/constants.js","webpack://app/./node_modules/date-fns/constructFrom.js","webpack://app/./node_modules/date-fns/toDate.js","webpack://app/./node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds.js","webpack://app/./node_modules/date-fns/startOfDay.js","webpack://app/./node_modules/date-fns/differenceInCalendarDays.js","webpack://app/./node_modules/date-fns/_lib/normalizeDates.js","webpack://app/./node_modules/date-fns/startOfYear.js","webpack://app/./node_modules/date-fns/getDayOfYear.js","webpack://app/./node_modules/date-fns/startOfWeek.js","webpack://app/./node_modules/date-fns/startOfISOWeek.js","webpack://app/./node_modules/date-fns/getISOWeekYear.js","webpack://app/./node_modules/date-fns/startOfISOWeekYear.js","webpack://app/./node_modules/date-fns/getISOWeek.js","webpack://app/./node_modules/date-fns/getWeekYear.js","webpack://app/./node_modules/date-fns/startOfWeekYear.js","webpack://app/./node_modules/date-fns/getWeek.js","webpack://app/./node_modules/date-fns/_lib/addLeadingZeros.js","webpack://app/./node_modules/date-fns/_lib/format/lightFormatters.js","webpack://app/./node_modules/date-fns/_lib/format/formatters.js","webpack://app/./node_modules/date-fns/_lib/format/longFormatters.js","webpack://app/./node_modules/date-fns/_lib/protectedTokens.js","webpack://app/./node_modules/date-fns/isDate.js","webpack://app/./node_modules/date-fns/isValid.js","webpack://app/./node_modules/date-fns/format.js"],"sourcesContent":["function r(e){var o,t,f=\"\";if(\"string\"==typeof e||\"number\"==typeof e)f+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var n=e.length;for(o=0;o=e?t:\"\"+Array(e+1-r.length).join(n)+t},v={s:m,z:function(t){var e=-t.utcOffset(),n=Math.abs(e),r=Math.floor(n/60),i=n%60;return(e<=0?\"+\":\"-\")+m(r,2,\"0\")+\":\"+m(i,2,\"0\")},m:function t(e,n){if(e.date()1)return t(u[0])}else{var a=e.name;D[a]=e,i=a}return!r&&i&&(g=i),i||!r&&g},O=function(t,e){if(S(t))return t.clone();var n=\"object\"==typeof e?e:{};return n.date=t,n.args=arguments,new _(n)},b=v;b.l=w,b.i=S,b.w=function(t,e){return O(t,{locale:e.$L,utc:e.$u,x:e.$x,$offset:e.$offset})};var _=function(){function M(t){this.$L=w(t.locale,null,!0),this.parse(t),this.$x=this.$x||t.x||{},this[p]=!0}var m=M.prototype;return m.parse=function(t){this.$d=function(t){var e=t.date,n=t.utc;if(null===e)return new Date(NaN);if(b.u(e))return new Date;if(e instanceof Date)return new Date(e);if(\"string\"==typeof e&&!/Z$/i.test(e)){var r=e.match($);if(r){var i=r[2]-1||0,s=(r[7]||\"0\").substring(0,3);return n?new Date(Date.UTC(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)):new Date(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)}}return new Date(e)}(t),this.init()},m.init=function(){var t=this.$d;this.$y=t.getFullYear(),this.$M=t.getMonth(),this.$D=t.getDate(),this.$W=t.getDay(),this.$H=t.getHours(),this.$m=t.getMinutes(),this.$s=t.getSeconds(),this.$ms=t.getMilliseconds()},m.$utils=function(){return b},m.isValid=function(){return!(this.$d.toString()===l)},m.isSame=function(t,e){var n=O(t);return this.startOf(e)<=n&&n<=this.endOf(e)},m.isAfter=function(t,e){return O(t) {\n let result;\n\n const tokenValue = formatDistanceLocale[token];\n if (typeof tokenValue === \"string\") {\n result = tokenValue;\n } else if (count === 1) {\n result = tokenValue.one;\n } else {\n result = tokenValue.other.replace(\"{{count}}\", count.toString());\n }\n\n if (options?.addSuffix) {\n if (options.comparison && options.comparison > 0) {\n return \"in \" + result;\n } else {\n return result + \" ago\";\n }\n }\n\n return result;\n};\n","export function buildFormatLongFn(args) {\n return (options = {}) => {\n // TODO: Remove String()\n const width = options.width ? String(options.width) : args.defaultWidth;\n const format = args.formats[width] || args.formats[args.defaultWidth];\n return format;\n };\n}\n","import { buildFormatLongFn } from \"../../_lib/buildFormatLongFn.js\";\n\nconst dateFormats = {\n full: \"EEEE, MMMM do, y\",\n long: \"MMMM do, y\",\n medium: \"MMM d, y\",\n short: \"MM/dd/yyyy\",\n};\n\nconst timeFormats = {\n full: \"h:mm:ss a zzzz\",\n long: \"h:mm:ss a z\",\n medium: \"h:mm:ss a\",\n short: \"h:mm a\",\n};\n\nconst dateTimeFormats = {\n full: \"{{date}} 'at' {{time}}\",\n long: \"{{date}} 'at' {{time}}\",\n medium: \"{{date}}, {{time}}\",\n short: \"{{date}}, {{time}}\",\n};\n\nexport const formatLong = {\n date: buildFormatLongFn({\n formats: dateFormats,\n defaultWidth: \"full\",\n }),\n\n time: buildFormatLongFn({\n formats: timeFormats,\n defaultWidth: \"full\",\n }),\n\n dateTime: buildFormatLongFn({\n formats: dateTimeFormats,\n defaultWidth: \"full\",\n }),\n};\n","const formatRelativeLocale = {\n lastWeek: \"'last' eeee 'at' p\",\n yesterday: \"'yesterday at' p\",\n today: \"'today at' p\",\n tomorrow: \"'tomorrow at' p\",\n nextWeek: \"eeee 'at' p\",\n other: \"P\",\n};\n\nexport const formatRelative = (token, _date, _baseDate, _options) =>\n formatRelativeLocale[token];\n","/**\n * The localize function argument callback which allows to convert raw value to\n * the actual type.\n *\n * @param value - The value to convert\n *\n * @returns The converted value\n */\n\n/**\n * The map of localized values for each width.\n */\n\n/**\n * The index type of the locale unit value. It types conversion of units of\n * values that don't start at 0 (i.e. quarters).\n */\n\n/**\n * Converts the unit value to the tuple of values.\n */\n\n/**\n * The tuple of localized era values. The first element represents BC,\n * the second element represents AD.\n */\n\n/**\n * The tuple of localized quarter values. The first element represents Q1.\n */\n\n/**\n * The tuple of localized day values. The first element represents Sunday.\n */\n\n/**\n * The tuple of localized month values. The first element represents January.\n */\n\nexport function buildLocalizeFn(args) {\n return (value, options) => {\n const context = options?.context ? String(options.context) : \"standalone\";\n\n let valuesArray;\n if (context === \"formatting\" && args.formattingValues) {\n const defaultWidth = args.defaultFormattingWidth || args.defaultWidth;\n const width = options?.width ? String(options.width) : defaultWidth;\n\n valuesArray =\n args.formattingValues[width] || args.formattingValues[defaultWidth];\n } else {\n const defaultWidth = args.defaultWidth;\n const width = options?.width ? String(options.width) : args.defaultWidth;\n\n valuesArray = args.values[width] || args.values[defaultWidth];\n }\n const index = args.argumentCallback ? args.argumentCallback(value) : value;\n\n // @ts-expect-error - For some reason TypeScript just don't want to match it, no matter how hard we try. I challenge you to try to remove it!\n return valuesArray[index];\n };\n}\n","export function buildMatchFn(args) {\n return (string, options = {}) => {\n const width = options.width;\n\n const matchPattern =\n (width && args.matchPatterns[width]) ||\n args.matchPatterns[args.defaultMatchWidth];\n const matchResult = string.match(matchPattern);\n\n if (!matchResult) {\n return null;\n }\n const matchedString = matchResult[0];\n\n const parsePatterns =\n (width && args.parsePatterns[width]) ||\n args.parsePatterns[args.defaultParseWidth];\n\n const key = Array.isArray(parsePatterns)\n ? findIndex(parsePatterns, (pattern) => pattern.test(matchedString))\n : // [TODO] -- I challenge you to fix the type\n findKey(parsePatterns, (pattern) => pattern.test(matchedString));\n\n let value;\n\n value = args.valueCallback ? args.valueCallback(key) : key;\n value = options.valueCallback\n ? // [TODO] -- I challenge you to fix the type\n options.valueCallback(value)\n : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n\nfunction findKey(object, predicate) {\n for (const key in object) {\n if (\n Object.prototype.hasOwnProperty.call(object, key) &&\n predicate(object[key])\n ) {\n return key;\n }\n }\n return undefined;\n}\n\nfunction findIndex(array, predicate) {\n for (let key = 0; key < array.length; key++) {\n if (predicate(array[key])) {\n return key;\n }\n }\n return undefined;\n}\n","export function buildMatchPatternFn(args) {\n return (string, options = {}) => {\n const matchResult = string.match(args.matchPattern);\n if (!matchResult) return null;\n const matchedString = matchResult[0];\n\n const parseResult = string.match(args.parsePattern);\n if (!parseResult) return null;\n let value = args.valueCallback\n ? args.valueCallback(parseResult[0])\n : parseResult[0];\n\n // [TODO] I challenge you to fix the type\n value = options.valueCallback ? options.valueCallback(value) : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n","import { formatDistance } from \"./en-US/_lib/formatDistance.js\";\nimport { formatLong } from \"./en-US/_lib/formatLong.js\";\nimport { formatRelative } from \"./en-US/_lib/formatRelative.js\";\nimport { localize } from \"./en-US/_lib/localize.js\";\nimport { match } from \"./en-US/_lib/match.js\";\n\n/**\n * @category Locales\n * @summary English locale (United States).\n * @language English\n * @iso-639-2 eng\n * @author Sasha Koss [@kossnocorp](https://github.com/kossnocorp)\n * @author Lesha Koss [@leshakoss](https://github.com/leshakoss)\n */\nexport const enUS = {\n code: \"en-US\",\n formatDistance: formatDistance,\n formatLong: formatLong,\n formatRelative: formatRelative,\n localize: localize,\n match: match,\n options: {\n weekStartsOn: 0 /* Sunday */,\n firstWeekContainsDate: 1,\n },\n};\n\n// Fallback for modularized imports:\nexport default enUS;\n","import { buildLocalizeFn } from \"../../_lib/buildLocalizeFn.js\";\n\nconst eraValues = {\n narrow: [\"B\", \"A\"],\n abbreviated: [\"BC\", \"AD\"],\n wide: [\"Before Christ\", \"Anno Domini\"],\n};\n\nconst quarterValues = {\n narrow: [\"1\", \"2\", \"3\", \"4\"],\n abbreviated: [\"Q1\", \"Q2\", \"Q3\", \"Q4\"],\n wide: [\"1st quarter\", \"2nd quarter\", \"3rd quarter\", \"4th quarter\"],\n};\n\n// Note: in English, the names of days of the week and months are capitalized.\n// If you are making a new locale based on this one, check if the same is true for the language you're working on.\n// Generally, formatted dates should look like they are in the middle of a sentence,\n// e.g. in Spanish language the weekdays and months should be in the lowercase.\nconst monthValues = {\n narrow: [\"J\", \"F\", \"M\", \"A\", \"M\", \"J\", \"J\", \"A\", \"S\", \"O\", \"N\", \"D\"],\n abbreviated: [\n \"Jan\",\n \"Feb\",\n \"Mar\",\n \"Apr\",\n \"May\",\n \"Jun\",\n \"Jul\",\n \"Aug\",\n \"Sep\",\n \"Oct\",\n \"Nov\",\n \"Dec\",\n ],\n\n wide: [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\",\n ],\n};\n\nconst dayValues = {\n narrow: [\"S\", \"M\", \"T\", \"W\", \"T\", \"F\", \"S\"],\n short: [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"],\n abbreviated: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n wide: [\n \"Sunday\",\n \"Monday\",\n \"Tuesday\",\n \"Wednesday\",\n \"Thursday\",\n \"Friday\",\n \"Saturday\",\n ],\n};\n\nconst dayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n};\n\nconst formattingDayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n};\n\nconst ordinalNumber = (dirtyNumber, _options) => {\n const number = Number(dirtyNumber);\n\n // If ordinal numbers depend on context, for example,\n // if they are different for different grammatical genders,\n // use `options.unit`.\n //\n // `unit` can be 'year', 'quarter', 'month', 'week', 'date', 'dayOfYear',\n // 'day', 'hour', 'minute', 'second'.\n\n const rem100 = number % 100;\n if (rem100 > 20 || rem100 < 10) {\n switch (rem100 % 10) {\n case 1:\n return number + \"st\";\n case 2:\n return number + \"nd\";\n case 3:\n return number + \"rd\";\n }\n }\n return number + \"th\";\n};\n\nexport const localize = {\n ordinalNumber,\n\n era: buildLocalizeFn({\n values: eraValues,\n defaultWidth: \"wide\",\n }),\n\n quarter: buildLocalizeFn({\n values: quarterValues,\n defaultWidth: \"wide\",\n argumentCallback: (quarter) => quarter - 1,\n }),\n\n month: buildLocalizeFn({\n values: monthValues,\n defaultWidth: \"wide\",\n }),\n\n day: buildLocalizeFn({\n values: dayValues,\n defaultWidth: \"wide\",\n }),\n\n dayPeriod: buildLocalizeFn({\n values: dayPeriodValues,\n defaultWidth: \"wide\",\n formattingValues: formattingDayPeriodValues,\n defaultFormattingWidth: \"wide\",\n }),\n};\n","import { buildMatchFn } from \"../../_lib/buildMatchFn.js\";\nimport { buildMatchPatternFn } from \"../../_lib/buildMatchPatternFn.js\";\n\nconst matchOrdinalNumberPattern = /^(\\d+)(th|st|nd|rd)?/i;\nconst parseOrdinalNumberPattern = /\\d+/i;\n\nconst matchEraPatterns = {\n narrow: /^(b|a)/i,\n abbreviated: /^(b\\.?\\s?c\\.?|b\\.?\\s?c\\.?\\s?e\\.?|a\\.?\\s?d\\.?|c\\.?\\s?e\\.?)/i,\n wide: /^(before christ|before common era|anno domini|common era)/i,\n};\nconst parseEraPatterns = {\n any: [/^b/i, /^(a|c)/i],\n};\n\nconst matchQuarterPatterns = {\n narrow: /^[1234]/i,\n abbreviated: /^q[1234]/i,\n wide: /^[1234](th|st|nd|rd)? quarter/i,\n};\nconst parseQuarterPatterns = {\n any: [/1/i, /2/i, /3/i, /4/i],\n};\n\nconst matchMonthPatterns = {\n narrow: /^[jfmasond]/i,\n abbreviated: /^(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)/i,\n wide: /^(january|february|march|april|may|june|july|august|september|october|november|december)/i,\n};\nconst parseMonthPatterns = {\n narrow: [\n /^j/i,\n /^f/i,\n /^m/i,\n /^a/i,\n /^m/i,\n /^j/i,\n /^j/i,\n /^a/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n\n any: [\n /^ja/i,\n /^f/i,\n /^mar/i,\n /^ap/i,\n /^may/i,\n /^jun/i,\n /^jul/i,\n /^au/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n};\n\nconst matchDayPatterns = {\n narrow: /^[smtwf]/i,\n short: /^(su|mo|tu|we|th|fr|sa)/i,\n abbreviated: /^(sun|mon|tue|wed|thu|fri|sat)/i,\n wide: /^(sunday|monday|tuesday|wednesday|thursday|friday|saturday)/i,\n};\nconst parseDayPatterns = {\n narrow: [/^s/i, /^m/i, /^t/i, /^w/i, /^t/i, /^f/i, /^s/i],\n any: [/^su/i, /^m/i, /^tu/i, /^w/i, /^th/i, /^f/i, /^sa/i],\n};\n\nconst matchDayPeriodPatterns = {\n narrow: /^(a|p|mi|n|(in the|at) (morning|afternoon|evening|night))/i,\n any: /^([ap]\\.?\\s?m\\.?|midnight|noon|(in the|at) (morning|afternoon|evening|night))/i,\n};\nconst parseDayPeriodPatterns = {\n any: {\n am: /^a/i,\n pm: /^p/i,\n midnight: /^mi/i,\n noon: /^no/i,\n morning: /morning/i,\n afternoon: /afternoon/i,\n evening: /evening/i,\n night: /night/i,\n },\n};\n\nexport const match = {\n ordinalNumber: buildMatchPatternFn({\n matchPattern: matchOrdinalNumberPattern,\n parsePattern: parseOrdinalNumberPattern,\n valueCallback: (value) => parseInt(value, 10),\n }),\n\n era: buildMatchFn({\n matchPatterns: matchEraPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseEraPatterns,\n defaultParseWidth: \"any\",\n }),\n\n quarter: buildMatchFn({\n matchPatterns: matchQuarterPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseQuarterPatterns,\n defaultParseWidth: \"any\",\n valueCallback: (index) => index + 1,\n }),\n\n month: buildMatchFn({\n matchPatterns: matchMonthPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseMonthPatterns,\n defaultParseWidth: \"any\",\n }),\n\n day: buildMatchFn({\n matchPatterns: matchDayPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseDayPatterns,\n defaultParseWidth: \"any\",\n }),\n\n dayPeriod: buildMatchFn({\n matchPatterns: matchDayPeriodPatterns,\n defaultMatchWidth: \"any\",\n parsePatterns: parseDayPeriodPatterns,\n defaultParseWidth: \"any\",\n }),\n};\n","let defaultOptions = {};\n\nexport function getDefaultOptions() {\n return defaultOptions;\n}\n\nexport function setDefaultOptions(newOptions) {\n defaultOptions = newOptions;\n}\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 occurs every 4 years, except for years that are divisible by 100 and not divisible by 400.\n * > 1 mean year = (365+1/4-1/100+1/400) days = 365.2425 days\n */\nexport const daysInYear = 365.2425;\n\n/**\n * @constant\n * @name maxTime\n * @summary Maximum allowed time.\n *\n * @example\n * import { maxTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = 8640000000000001 <= maxTime;\n * //=> false\n *\n * new Date(8640000000000001);\n * //=> Invalid Date\n */\nexport const maxTime = Math.pow(10, 8) * 24 * 60 * 60 * 1000;\n\n/**\n * @constant\n * @name minTime\n * @summary Minimum allowed time.\n *\n * @example\n * import { minTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = -8640000000000001 >= minTime;\n * //=> false\n *\n * new Date(-8640000000000001)\n * //=> Invalid Date\n */\nexport const minTime = -maxTime;\n\n/**\n * @constant\n * @name millisecondsInWeek\n * @summary Milliseconds in 1 week.\n */\nexport const millisecondsInWeek = 604800000;\n\n/**\n * @constant\n * @name millisecondsInDay\n * @summary Milliseconds in 1 day.\n */\nexport const millisecondsInDay = 86400000;\n\n/**\n * @constant\n * @name millisecondsInMinute\n * @summary Milliseconds in 1 minute\n */\nexport const millisecondsInMinute = 60000;\n\n/**\n * @constant\n * @name millisecondsInHour\n * @summary Milliseconds in 1 hour\n */\nexport const millisecondsInHour = 3600000;\n\n/**\n * @constant\n * @name millisecondsInSecond\n * @summary Milliseconds in 1 second\n */\nexport const millisecondsInSecond = 1000;\n\n/**\n * @constant\n * @name minutesInYear\n * @summary Minutes in 1 year.\n */\nexport const minutesInYear = 525600;\n\n/**\n * @constant\n * @name minutesInMonth\n * @summary Minutes in 1 month.\n */\nexport const minutesInMonth = 43200;\n\n/**\n * @constant\n * @name minutesInDay\n * @summary Minutes in 1 day.\n */\nexport const minutesInDay = 1440;\n\n/**\n * @constant\n * @name minutesInHour\n * @summary Minutes in 1 hour.\n */\nexport const minutesInHour = 60;\n\n/**\n * @constant\n * @name monthsInQuarter\n * @summary Months in 1 quarter.\n */\nexport const monthsInQuarter = 3;\n\n/**\n * @constant\n * @name monthsInYear\n * @summary Months in 1 year.\n */\nexport const monthsInYear = 12;\n\n/**\n * @constant\n * @name quartersInYear\n * @summary Quarters in 1 year\n */\nexport const quartersInYear = 4;\n\n/**\n * @constant\n * @name secondsInHour\n * @summary Seconds in 1 hour.\n */\nexport const secondsInHour = 3600;\n\n/**\n * @constant\n * @name secondsInMinute\n * @summary Seconds in 1 minute.\n */\nexport const secondsInMinute = 60;\n\n/**\n * @constant\n * @name secondsInDay\n * @summary Seconds in 1 day.\n */\nexport const secondsInDay = secondsInHour * 24;\n\n/**\n * @constant\n * @name secondsInWeek\n * @summary Seconds in 1 week.\n */\nexport const secondsInWeek = secondsInDay * 7;\n\n/**\n * @constant\n * @name secondsInYear\n * @summary Seconds in 1 year.\n */\nexport const secondsInYear = secondsInDay * daysInYear;\n\n/**\n * @constant\n * @name secondsInMonth\n * @summary Seconds in 1 month\n */\nexport const secondsInMonth = secondsInYear / 12;\n\n/**\n * @constant\n * @name secondsInQuarter\n * @summary Seconds in 1 quarter.\n */\nexport const secondsInQuarter = secondsInMonth * 3;\n\n/**\n * @constant\n * @name constructFromSymbol\n * @summary Symbol enabling Date extensions to inherit properties from the reference date.\n *\n * The symbol is used to enable the `constructFrom` function to construct a date\n * using a reference date and a value. It allows to transfer extra properties\n * from the reference date to the new date. It's useful for extensions like\n * [`TZDate`](https://github.com/date-fns/tz) that accept a time zone as\n * a constructor argument.\n */\nexport const constructFromSymbol = Symbol.for(\"constructDateFrom\");\n","import { constructFromSymbol } from \"./constants.js\";\n\n/**\n * @name constructFrom\n * @category Generic Helpers\n * @summary Constructs a date using the reference date and the value\n *\n * @description\n * The function constructs a new date using the constructor from the reference\n * date and the given value. It helps to build generic functions that accept\n * date extensions.\n *\n * It defaults to `Date` if the passed reference date is a number or a string.\n *\n * Starting from v3.7.0, it allows to construct a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The reference date to take constructor from\n * @param value - The value to create the date\n *\n * @returns Date initialized using the given date and value\n *\n * @example\n * import { constructFrom } from \"./constructFrom/date-fns\";\n *\n * // A function that clones a date preserving the original type\n * function cloneDate(date: DateType): DateType {\n * return constructFrom(\n * date, // Use constructor from the given date\n * date.getTime() // Use the date value to create a new date\n * );\n * }\n */\nexport function constructFrom(date, value) {\n if (typeof date === \"function\") return date(value);\n\n if (date && typeof date === \"object\" && constructFromSymbol in date)\n return date[constructFromSymbol](value);\n\n if (date instanceof Date) return new date.constructor(value);\n\n return new Date(value);\n}\n\n// Fallback for modularized imports:\nexport default constructFrom;\n","import { constructFrom } from \"./constructFrom.js\";\n\n/**\n * @name toDate\n * @category Common Helpers\n * @summary Convert the given argument to an instance of Date.\n *\n * @description\n * Convert the given argument to an instance of Date.\n *\n * If the argument is an instance of Date, the function returns its clone.\n *\n * If the argument is a number, it is treated as a timestamp.\n *\n * If the argument is none of the above, the function returns Invalid Date.\n *\n * Starting from v3.7.0, it clones a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * **Note**: *all* Date arguments passed to any *date-fns* function is processed by `toDate`.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param argument - The value to convert\n *\n * @returns The parsed date in the local time zone\n *\n * @example\n * // Clone the date:\n * const result = toDate(new Date(2014, 1, 11, 11, 30, 30))\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert the timestamp to date:\n * const result = toDate(1392098430000)\n * //=> Tue Feb 11 2014 11:30:30\n */\nexport function toDate(argument, context) {\n // [TODO] Get rid of `toDate` or `constructFrom`?\n return constructFrom(context || argument, argument);\n}\n\n// Fallback for modularized imports:\nexport default toDate;\n","import { toDate } from \"../toDate.js\";\n\n/**\n * Google Chrome as of 67.0.3396.87 introduced timezones with offset that includes seconds.\n * They usually appear for dates that denote time before the timezones were introduced\n * (e.g. for 'Europe/Prague' timezone the offset is GMT+00:57:44 before 1 October 1891\n * and GMT+01:00:00 after that date)\n *\n * Date#getTimezoneOffset returns the offset in minutes and would return 57 for the example above,\n * which would lead to incorrect calculations.\n *\n * This function returns the timezone offset in milliseconds that takes seconds in account.\n */\nexport function getTimezoneOffsetInMilliseconds(date) {\n const _date = toDate(date);\n const utcDate = new Date(\n Date.UTC(\n _date.getFullYear(),\n _date.getMonth(),\n _date.getDate(),\n _date.getHours(),\n _date.getMinutes(),\n _date.getSeconds(),\n _date.getMilliseconds(),\n ),\n );\n utcDate.setUTCFullYear(_date.getFullYear());\n return +date - +utcDate;\n}\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfDay} function options.\n */\n\n/**\n * @name startOfDay\n * @category Day Helpers\n * @summary Return the start of a day for the given date.\n *\n * @description\n * Return the start of a day for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - The options\n *\n * @returns The start of a day\n *\n * @example\n * // The start of a day for 2 September 2014 11:55:00:\n * const result = startOfDay(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Tue Sep 02 2014 00:00:00\n */\nexport function startOfDay(date, options) {\n const _date = toDate(date, options?.in);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfDay;\n","import { getTimezoneOffsetInMilliseconds } from \"./_lib/getTimezoneOffsetInMilliseconds.js\";\nimport { normalizeDates } from \"./_lib/normalizeDates.js\";\nimport { millisecondsInDay } from \"./constants.js\";\nimport { startOfDay } from \"./startOfDay.js\";\n\n/**\n * The {@link differenceInCalendarDays} function options.\n */\n\n/**\n * @name differenceInCalendarDays\n * @category Day Helpers\n * @summary Get the number of calendar days between the given dates.\n *\n * @description\n * Get the number of calendar days between the given dates. This means that the times are removed\n * from the dates and then the difference in days is calculated.\n *\n * @param laterDate - The later date\n * @param earlierDate - The earlier date\n * @param options - The options object\n *\n * @returns The number of calendar days\n *\n * @example\n * // How many calendar days are between\n * // 2 July 2011 23:00:00 and 2 July 2012 00:00:00?\n * const result = differenceInCalendarDays(\n * new Date(2012, 6, 2, 0, 0),\n * new Date(2011, 6, 2, 23, 0)\n * )\n * //=> 366\n * // How many calendar days are between\n * // 2 July 2011 23:59:00 and 3 July 2011 00:01:00?\n * const result = differenceInCalendarDays(\n * new Date(2011, 6, 3, 0, 1),\n * new Date(2011, 6, 2, 23, 59)\n * )\n * //=> 1\n */\nexport function differenceInCalendarDays(laterDate, earlierDate, options) {\n const [laterDate_, earlierDate_] = normalizeDates(\n options?.in,\n laterDate,\n earlierDate,\n );\n\n const laterStartOfDay = startOfDay(laterDate_);\n const earlierStartOfDay = startOfDay(earlierDate_);\n\n const laterTimestamp =\n +laterStartOfDay - getTimezoneOffsetInMilliseconds(laterStartOfDay);\n const earlierTimestamp =\n +earlierStartOfDay - getTimezoneOffsetInMilliseconds(earlierStartOfDay);\n\n // Round the number of days to the nearest integer because the number of\n // milliseconds in a day is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round((laterTimestamp - earlierTimestamp) / millisecondsInDay);\n}\n\n// Fallback for modularized imports:\nexport default differenceInCalendarDays;\n","import { constructFrom } from \"../constructFrom.js\";\n\nexport function normalizeDates(context, ...dates) {\n const normalize = constructFrom.bind(\n null,\n context || dates.find((date) => typeof date === \"object\"),\n );\n return dates.map(normalize);\n}\n","import { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfYear} function options.\n */\n\n/**\n * @name startOfYear\n * @category Year Helpers\n * @summary Return the start of a year for the given date.\n *\n * @description\n * Return the start of a year for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - The options\n *\n * @returns The start of a year\n *\n * @example\n * // The start of a year for 2 September 2014 11:55:00:\n * const result = startOfYear(new Date(2014, 8, 2, 11, 55, 00))\n * //=> Wed Jan 01 2014 00:00:00\n */\nexport function startOfYear(date, options) {\n const date_ = toDate(date, options?.in);\n date_.setFullYear(date_.getFullYear(), 0, 1);\n date_.setHours(0, 0, 0, 0);\n return date_;\n}\n\n// Fallback for modularized imports:\nexport default startOfYear;\n","import { differenceInCalendarDays } from \"./differenceInCalendarDays.js\";\nimport { startOfYear } from \"./startOfYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getDayOfYear} function options.\n */\n\n/**\n * @name getDayOfYear\n * @category Day Helpers\n * @summary Get the day of the year of the given date.\n *\n * @description\n * Get the day of the year of the given date.\n *\n * @param date - The given date\n * @param options - The options\n *\n * @returns The day of year\n *\n * @example\n * // Which day of the year is 2 July 2014?\n * const result = getDayOfYear(new Date(2014, 6, 2))\n * //=> 183\n */\nexport function getDayOfYear(date, options) {\n const _date = toDate(date, options?.in);\n const diff = differenceInCalendarDays(_date, startOfYear(_date));\n const dayOfYear = diff + 1;\n return dayOfYear;\n}\n\n// Fallback for modularized imports:\nexport default getDayOfYear;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link startOfWeek} function options.\n */\n\n/**\n * @name startOfWeek\n * @category Week Helpers\n * @summary Return the start of a week for the given date.\n *\n * @description\n * Return the start of a week for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week\n *\n * @example\n * // The start of a week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Sun Aug 31 2014 00:00:00\n *\n * @example\n * // If the week starts on Monday, the start of the week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfWeek(date, options) {\n const defaultOptions = getDefaultOptions();\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const _date = toDate(date, options?.in);\n const day = _date.getDay();\n const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n\n _date.setDate(_date.getDate() - diff);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeek;\n","import { startOfWeek } from \"./startOfWeek.js\";\n\n/**\n * The {@link startOfISOWeek} function options.\n */\n\n/**\n * @name startOfISOWeek\n * @category ISO Week Helpers\n * @summary Return the start of an ISO week for the given date.\n *\n * @description\n * Return the start of an ISO week for the given date.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of an ISO week\n *\n * @example\n * // The start of an ISO week for 2 September 2014 11:55:00:\n * const result = startOfISOWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfISOWeek(date, options) {\n return startOfWeek(date, { ...options, weekStartsOn: 1 });\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeek;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getISOWeekYear} function options.\n */\n\n/**\n * @name getISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Get the ISO week-numbering year of the given date.\n *\n * @description\n * Get the ISO week-numbering year of the given date,\n * which always starts 3 days before the year's first Thursday.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @param date - The given date\n *\n * @returns The ISO week-numbering year\n *\n * @example\n * // Which ISO-week numbering year is 2 January 2005?\n * const result = getISOWeekYear(new Date(2005, 0, 2))\n * //=> 2004\n */\nexport function getISOWeekYear(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n\n const fourthOfJanuaryOfNextYear = constructFrom(_date, 0);\n fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4);\n fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear);\n\n const fourthOfJanuaryOfThisYear = constructFrom(_date, 0);\n fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4);\n fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfISOWeek(fourthOfJanuaryOfThisYear);\n\n if (_date.getTime() >= startOfNextYear.getTime()) {\n return year + 1;\n } else if (_date.getTime() >= startOfThisYear.getTime()) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getISOWeekYear;\n","import { constructFrom } from \"./constructFrom.js\";\nimport { getISOWeekYear } from \"./getISOWeekYear.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\n\n/**\n * The {@link startOfISOWeekYear} function options.\n */\n\n/**\n * @name startOfISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Return the start of an ISO week-numbering year for the given date.\n *\n * @description\n * Return the start of an ISO week-numbering year,\n * which always starts 3 days before the year's first Thursday.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of an ISO week-numbering year\n *\n * @example\n * // The start of an ISO week-numbering year for 2 July 2005:\n * const result = startOfISOWeekYear(new Date(2005, 6, 2))\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfISOWeekYear(date, options) {\n const year = getISOWeekYear(date, options);\n const fourthOfJanuary = constructFrom(options?.in || date, 0);\n fourthOfJanuary.setFullYear(year, 0, 4);\n fourthOfJanuary.setHours(0, 0, 0, 0);\n return startOfISOWeek(fourthOfJanuary);\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeekYear;\n","import { millisecondsInWeek } from \"./constants.js\";\nimport { startOfISOWeek } from \"./startOfISOWeek.js\";\nimport { startOfISOWeekYear } from \"./startOfISOWeekYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getISOWeek} function options.\n */\n\n/**\n * @name getISOWeek\n * @category ISO Week Helpers\n * @summary Get the ISO week of the given date.\n *\n * @description\n * Get the ISO week of the given date.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @param date - The given date\n * @param options - The options\n *\n * @returns The ISO week\n *\n * @example\n * // Which week of the ISO-week numbering year is 2 January 2005?\n * const result = getISOWeek(new Date(2005, 0, 2))\n * //=> 53\n */\nexport function getISOWeek(date, options) {\n const _date = toDate(date, options?.in);\n const diff = +startOfISOWeek(_date) - +startOfISOWeekYear(_date);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getISOWeek;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { constructFrom } from \"./constructFrom.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getWeekYear} function options.\n */\n\n/**\n * @name getWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Get the local week-numbering year of the given date.\n *\n * @description\n * Get the local week-numbering year of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @param date - The given date\n * @param options - An object with options.\n *\n * @returns The local week-numbering year\n *\n * @example\n * // Which week numbering year is 26 December 2004 with the default settings?\n * const result = getWeekYear(new Date(2004, 11, 26))\n * //=> 2005\n *\n * @example\n * // Which week numbering year is 26 December 2004 if week starts on Saturday?\n * const result = getWeekYear(new Date(2004, 11, 26), { weekStartsOn: 6 })\n * //=> 2004\n *\n * @example\n * // Which week numbering year is 26 December 2004 if the first week contains 4 January?\n * const result = getWeekYear(new Date(2004, 11, 26), { firstWeekContainsDate: 4 })\n * //=> 2004\n */\nexport function getWeekYear(date, options) {\n const _date = toDate(date, options?.in);\n const year = _date.getFullYear();\n\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const firstWeekOfNextYear = constructFrom(options?.in || date, 0);\n firstWeekOfNextYear.setFullYear(year + 1, 0, firstWeekContainsDate);\n firstWeekOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfWeek(firstWeekOfNextYear, options);\n\n const firstWeekOfThisYear = constructFrom(options?.in || date, 0);\n firstWeekOfThisYear.setFullYear(year, 0, firstWeekContainsDate);\n firstWeekOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfWeek(firstWeekOfThisYear, options);\n\n if (+_date >= +startOfNextYear) {\n return year + 1;\n } else if (+_date >= +startOfThisYear) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getWeekYear;\n","import { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { constructFrom } from \"./constructFrom.js\";\nimport { getWeekYear } from \"./getWeekYear.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\n\n/**\n * The {@link startOfWeekYear} function options.\n */\n\n/**\n * @name startOfWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Return the start of a local week-numbering year for the given date.\n *\n * @description\n * Return the start of a local week-numbering year.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type.\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week-numbering year\n *\n * @example\n * // The start of an a week-numbering year for 2 July 2005 with default settings:\n * const result = startOfWeekYear(new Date(2005, 6, 2))\n * //=> Sun Dec 26 2004 00:00:00\n *\n * @example\n * // The start of a week-numbering year for 2 July 2005\n * // if Monday is the first day of week\n * // and 4 January is always in the first week of the year:\n * const result = startOfWeekYear(new Date(2005, 6, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfWeekYear(date, options) {\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const year = getWeekYear(date, options);\n const firstWeek = constructFrom(options?.in || date, 0);\n firstWeek.setFullYear(year, 0, firstWeekContainsDate);\n firstWeek.setHours(0, 0, 0, 0);\n const _date = startOfWeek(firstWeek, options);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeekYear;\n","import { millisecondsInWeek } from \"./constants.js\";\nimport { startOfWeek } from \"./startOfWeek.js\";\nimport { startOfWeekYear } from \"./startOfWeekYear.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * The {@link getWeek} function options.\n */\n\n/**\n * @name getWeek\n * @category Week Helpers\n * @summary Get the local week index of the given date.\n *\n * @description\n * Get the local week index of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @param date - The given date\n * @param options - An object with options\n *\n * @returns The week\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005 with default options?\n * const result = getWeek(new Date(2005, 0, 2))\n * //=> 2\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005,\n * // if Monday is the first day of the week,\n * // and the first week of the year always contains 4 January?\n * const result = getWeek(new Date(2005, 0, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> 53\n */\nexport function getWeek(date, options) {\n const _date = toDate(date, options?.in);\n const diff = +startOfWeek(_date, options) - +startOfWeekYear(_date, options);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getWeek;\n","export function addLeadingZeros(number, targetLength) {\n const sign = number < 0 ? \"-\" : \"\";\n const output = Math.abs(number).toString().padStart(targetLength, \"0\");\n return sign + output;\n}\n","import { addLeadingZeros } from \"../addLeadingZeros.js\";\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | |\n * | d | Day of month | D | |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | m | Minute | M | Month |\n * | s | Second | S | Fraction of second |\n * | y | Year (abs) | Y | |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n */\n\nexport const lightFormatters = {\n // Year\n y(date, token) {\n // From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_tokens\n // | Year | y | yy | yyy | yyyy | yyyyy |\n // |----------|-------|----|-------|-------|-------|\n // | AD 1 | 1 | 01 | 001 | 0001 | 00001 |\n // | AD 12 | 12 | 12 | 012 | 0012 | 00012 |\n // | AD 123 | 123 | 23 | 123 | 0123 | 00123 |\n // | AD 1234 | 1234 | 34 | 1234 | 1234 | 01234 |\n // | AD 12345 | 12345 | 45 | 12345 | 12345 | 12345 |\n\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return addLeadingZeros(token === \"yy\" ? year % 100 : year, token.length);\n },\n\n // Month\n M(date, token) {\n const month = date.getMonth();\n return token === \"M\" ? String(month + 1) : addLeadingZeros(month + 1, 2);\n },\n\n // Day of the month\n d(date, token) {\n return addLeadingZeros(date.getDate(), token.length);\n },\n\n // AM or PM\n a(date, token) {\n const dayPeriodEnumValue = date.getHours() / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return dayPeriodEnumValue.toUpperCase();\n case \"aaa\":\n return dayPeriodEnumValue;\n case \"aaaaa\":\n return dayPeriodEnumValue[0];\n case \"aaaa\":\n default:\n return dayPeriodEnumValue === \"am\" ? \"a.m.\" : \"p.m.\";\n }\n },\n\n // Hour [1-12]\n h(date, token) {\n return addLeadingZeros(date.getHours() % 12 || 12, token.length);\n },\n\n // Hour [0-23]\n H(date, token) {\n return addLeadingZeros(date.getHours(), token.length);\n },\n\n // Minute\n m(date, token) {\n return addLeadingZeros(date.getMinutes(), token.length);\n },\n\n // Second\n s(date, token) {\n return addLeadingZeros(date.getSeconds(), token.length);\n },\n\n // Fraction of second\n S(date, token) {\n const numberOfDigits = token.length;\n const milliseconds = date.getMilliseconds();\n const fractionalSeconds = Math.trunc(\n milliseconds * Math.pow(10, numberOfDigits - 3),\n );\n return addLeadingZeros(fractionalSeconds, token.length);\n },\n};\n","import { getDayOfYear } from \"../../getDayOfYear.js\";\nimport { getISOWeek } from \"../../getISOWeek.js\";\nimport { getISOWeekYear } from \"../../getISOWeekYear.js\";\nimport { getWeek } from \"../../getWeek.js\";\nimport { getWeekYear } from \"../../getWeekYear.js\";\n\nimport { addLeadingZeros } from \"../addLeadingZeros.js\";\nimport { lightFormatters } from \"./lightFormatters.js\";\n\nconst dayPeriodEnum = {\n am: \"am\",\n pm: \"pm\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n};\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | Milliseconds in day |\n * | b | AM, PM, noon, midnight | B | Flexible day period |\n * | c | Stand-alone local day of week | C* | Localized hour w/ day period |\n * | d | Day of month | D | Day of year |\n * | e | Local day of week | E | Day of week |\n * | f | | F* | Day of week in month |\n * | g* | Modified Julian day | G | Era |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | i! | ISO day of week | I! | ISO week of year |\n * | j* | Localized hour w/ day period | J* | Localized hour w/o day period |\n * | k | Hour [1-24] | K | Hour [0-11] |\n * | l* | (deprecated) | L | Stand-alone month |\n * | m | Minute | M | Month |\n * | n | | N | |\n * | o! | Ordinal number modifier | O | Timezone (GMT) |\n * | p! | Long localized time | P! | Long localized date |\n * | q | Stand-alone quarter | Q | Quarter |\n * | r* | Related Gregorian year | R! | ISO week-numbering year |\n * | s | Second | S | Fraction of second |\n * | t! | Seconds timestamp | T! | Milliseconds timestamp |\n * | u | Extended year | U* | Cyclic year |\n * | v* | Timezone (generic non-locat.) | V* | Timezone (location) |\n * | w | Local week of year | W* | Week of month |\n * | x | Timezone (ISO-8601 w/o Z) | X | Timezone (ISO-8601) |\n * | y | Year (abs) | Y | Local week-numbering year |\n * | z | Timezone (specific non-locat.) | Z* | Timezone (aliases) |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n *\n * Letters marked by ! are non-standard, but implemented by date-fns:\n * - `o` modifies the previous token to turn it into an ordinal (see `format` docs)\n * - `i` is ISO day of week. For `i` and `ii` is returns numeric ISO week days,\n * i.e. 7 for Sunday, 1 for Monday, etc.\n * - `I` is ISO week of year, as opposed to `w` which is local week of year.\n * - `R` is ISO week-numbering year, as opposed to `Y` which is local week-numbering year.\n * `R` is supposed to be used in conjunction with `I` and `i`\n * for universal ISO week-numbering date, whereas\n * `Y` is supposed to be used in conjunction with `w` and `e`\n * for week-numbering date specific to the locale.\n * - `P` is long localized date format\n * - `p` is long localized time format\n */\n\nexport const formatters = {\n // Era\n G: function (date, token, localize) {\n const era = date.getFullYear() > 0 ? 1 : 0;\n switch (token) {\n // AD, BC\n case \"G\":\n case \"GG\":\n case \"GGG\":\n return localize.era(era, { width: \"abbreviated\" });\n // A, B\n case \"GGGGG\":\n return localize.era(era, { width: \"narrow\" });\n // Anno Domini, Before Christ\n case \"GGGG\":\n default:\n return localize.era(era, { width: \"wide\" });\n }\n },\n\n // Year\n y: function (date, token, localize) {\n // Ordinal number\n if (token === \"yo\") {\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return localize.ordinalNumber(year, { unit: \"year\" });\n }\n\n return lightFormatters.y(date, token);\n },\n\n // Local week-numbering year\n Y: function (date, token, localize, options) {\n const signedWeekYear = getWeekYear(date, options);\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear;\n\n // Two digit year\n if (token === \"YY\") {\n const twoDigitYear = weekYear % 100;\n return addLeadingZeros(twoDigitYear, 2);\n }\n\n // Ordinal number\n if (token === \"Yo\") {\n return localize.ordinalNumber(weekYear, { unit: \"year\" });\n }\n\n // Padding\n return addLeadingZeros(weekYear, token.length);\n },\n\n // ISO week-numbering year\n R: function (date, token) {\n const isoWeekYear = getISOWeekYear(date);\n\n // Padding\n return addLeadingZeros(isoWeekYear, token.length);\n },\n\n // Extended year. This is a single number designating the year of this calendar system.\n // The main difference between `y` and `u` localizers are B.C. years:\n // | Year | `y` | `u` |\n // |------|-----|-----|\n // | AC 1 | 1 | 1 |\n // | BC 1 | 1 | 0 |\n // | BC 2 | 2 | -1 |\n // Also `yy` always returns the last two digits of a year,\n // while `uu` pads single digit years to 2 characters and returns other years unchanged.\n u: function (date, token) {\n const year = date.getFullYear();\n return addLeadingZeros(year, token.length);\n },\n\n // Quarter\n Q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"Q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"QQ\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"Qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"QQQ\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"QQQQQ\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"QQQQ\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone quarter\n q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"qq\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"qqq\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"qqqqq\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"qqqq\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // Month\n M: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n case \"M\":\n case \"MM\":\n return lightFormatters.M(date, token);\n // 1st, 2nd, ..., 12th\n case \"Mo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"MMM\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // J, F, ..., D\n case \"MMMMM\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // January, February, ..., December\n case \"MMMM\":\n default:\n return localize.month(month, { width: \"wide\", context: \"formatting\" });\n }\n },\n\n // Stand-alone month\n L: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n // 1, 2, ..., 12\n case \"L\":\n return String(month + 1);\n // 01, 02, ..., 12\n case \"LL\":\n return addLeadingZeros(month + 1, 2);\n // 1st, 2nd, ..., 12th\n case \"Lo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"LLL\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // J, F, ..., D\n case \"LLLLL\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // January, February, ..., December\n case \"LLLL\":\n default:\n return localize.month(month, { width: \"wide\", context: \"standalone\" });\n }\n },\n\n // Local week of year\n w: function (date, token, localize, options) {\n const week = getWeek(date, options);\n\n if (token === \"wo\") {\n return localize.ordinalNumber(week, { unit: \"week\" });\n }\n\n return addLeadingZeros(week, token.length);\n },\n\n // ISO week of year\n I: function (date, token, localize) {\n const isoWeek = getISOWeek(date);\n\n if (token === \"Io\") {\n return localize.ordinalNumber(isoWeek, { unit: \"week\" });\n }\n\n return addLeadingZeros(isoWeek, token.length);\n },\n\n // Day of the month\n d: function (date, token, localize) {\n if (token === \"do\") {\n return localize.ordinalNumber(date.getDate(), { unit: \"date\" });\n }\n\n return lightFormatters.d(date, token);\n },\n\n // Day of year\n D: function (date, token, localize) {\n const dayOfYear = getDayOfYear(date);\n\n if (token === \"Do\") {\n return localize.ordinalNumber(dayOfYear, { unit: \"dayOfYear\" });\n }\n\n return addLeadingZeros(dayOfYear, token.length);\n },\n\n // Day of week\n E: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n switch (token) {\n // Tue\n case \"E\":\n case \"EE\":\n case \"EEE\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"EEEEE\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"EEEEEE\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"EEEE\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Local day of week\n e: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (Nth day of week with current locale or weekStartsOn)\n case \"e\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"ee\":\n return addLeadingZeros(localDayOfWeek, 2);\n // 1st, 2nd, ..., 7th\n case \"eo\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"eee\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"eeeee\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"eeeeee\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"eeee\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone local day of week\n c: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (same as in `e`)\n case \"c\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"cc\":\n return addLeadingZeros(localDayOfWeek, token.length);\n // 1st, 2nd, ..., 7th\n case \"co\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"ccc\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // T\n case \"ccccc\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // Tu\n case \"cccccc\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"standalone\",\n });\n // Tuesday\n case \"cccc\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // ISO day of week\n i: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n const isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek;\n switch (token) {\n // 2\n case \"i\":\n return String(isoDayOfWeek);\n // 02\n case \"ii\":\n return addLeadingZeros(isoDayOfWeek, token.length);\n // 2nd\n case \"io\":\n return localize.ordinalNumber(isoDayOfWeek, { unit: \"day\" });\n // Tue\n case \"iii\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"iiiii\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"iiiiii\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"iiii\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM or PM\n a: function (date, token, localize) {\n const hours = date.getHours();\n const dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"aaa\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"aaaaa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"aaaa\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM, PM, midnight, noon\n b: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours === 12) {\n dayPeriodEnumValue = dayPeriodEnum.noon;\n } else if (hours === 0) {\n dayPeriodEnumValue = dayPeriodEnum.midnight;\n } else {\n dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n }\n\n switch (token) {\n case \"b\":\n case \"bb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"bbb\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"bbbbb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"bbbb\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // in the morning, in the afternoon, in the evening, at night\n B: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours >= 17) {\n dayPeriodEnumValue = dayPeriodEnum.evening;\n } else if (hours >= 12) {\n dayPeriodEnumValue = dayPeriodEnum.afternoon;\n } else if (hours >= 4) {\n dayPeriodEnumValue = dayPeriodEnum.morning;\n } else {\n dayPeriodEnumValue = dayPeriodEnum.night;\n }\n\n switch (token) {\n case \"B\":\n case \"BB\":\n case \"BBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"BBBBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"BBBB\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Hour [1-12]\n h: function (date, token, localize) {\n if (token === \"ho\") {\n let hours = date.getHours() % 12;\n if (hours === 0) hours = 12;\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return lightFormatters.h(date, token);\n },\n\n // Hour [0-23]\n H: function (date, token, localize) {\n if (token === \"Ho\") {\n return localize.ordinalNumber(date.getHours(), { unit: \"hour\" });\n }\n\n return lightFormatters.H(date, token);\n },\n\n // Hour [0-11]\n K: function (date, token, localize) {\n const hours = date.getHours() % 12;\n\n if (token === \"Ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Hour [1-24]\n k: function (date, token, localize) {\n let hours = date.getHours();\n if (hours === 0) hours = 24;\n\n if (token === \"ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Minute\n m: function (date, token, localize) {\n if (token === \"mo\") {\n return localize.ordinalNumber(date.getMinutes(), { unit: \"minute\" });\n }\n\n return lightFormatters.m(date, token);\n },\n\n // Second\n s: function (date, token, localize) {\n if (token === \"so\") {\n return localize.ordinalNumber(date.getSeconds(), { unit: \"second\" });\n }\n\n return lightFormatters.s(date, token);\n },\n\n // Fraction of second\n S: function (date, token) {\n return lightFormatters.S(date, token);\n },\n\n // Timezone (ISO-8601. If offset is 0, output is always `'Z'`)\n X: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n if (timezoneOffset === 0) {\n return \"Z\";\n }\n\n switch (token) {\n // Hours and optional minutes\n case \"X\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XX`\n case \"XXXX\":\n case \"XX\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XXX`\n case \"XXXXX\":\n case \"XXX\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent)\n x: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Hours and optional minutes\n case \"x\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xx`\n case \"xxxx\":\n case \"xx\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xxx`\n case \"xxxxx\":\n case \"xxx\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (GMT)\n O: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"O\":\n case \"OO\":\n case \"OOO\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"OOOO\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (specific non-location)\n z: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"z\":\n case \"zz\":\n case \"zzz\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"zzzz\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Seconds timestamp\n t: function (date, token, _localize) {\n const timestamp = Math.trunc(+date / 1000);\n return addLeadingZeros(timestamp, token.length);\n },\n\n // Milliseconds timestamp\n T: function (date, token, _localize) {\n return addLeadingZeros(+date, token.length);\n },\n};\n\nfunction formatTimezoneShort(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = Math.trunc(absOffset / 60);\n const minutes = absOffset % 60;\n if (minutes === 0) {\n return sign + String(hours);\n }\n return sign + String(hours) + delimiter + addLeadingZeros(minutes, 2);\n}\n\nfunction formatTimezoneWithOptionalMinutes(offset, delimiter) {\n if (offset % 60 === 0) {\n const sign = offset > 0 ? \"-\" : \"+\";\n return sign + addLeadingZeros(Math.abs(offset) / 60, 2);\n }\n return formatTimezone(offset, delimiter);\n}\n\nfunction formatTimezone(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = addLeadingZeros(Math.trunc(absOffset / 60), 2);\n const minutes = addLeadingZeros(absOffset % 60, 2);\n return sign + hours + delimiter + minutes;\n}\n","const dateLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"P\":\n return formatLong.date({ width: \"short\" });\n case \"PP\":\n return formatLong.date({ width: \"medium\" });\n case \"PPP\":\n return formatLong.date({ width: \"long\" });\n case \"PPPP\":\n default:\n return formatLong.date({ width: \"full\" });\n }\n};\n\nconst timeLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"p\":\n return formatLong.time({ width: \"short\" });\n case \"pp\":\n return formatLong.time({ width: \"medium\" });\n case \"ppp\":\n return formatLong.time({ width: \"long\" });\n case \"pppp\":\n default:\n return formatLong.time({ width: \"full\" });\n }\n};\n\nconst dateTimeLongFormatter = (pattern, formatLong) => {\n const matchResult = pattern.match(/(P+)(p+)?/) || [];\n const datePattern = matchResult[1];\n const timePattern = matchResult[2];\n\n if (!timePattern) {\n return dateLongFormatter(pattern, formatLong);\n }\n\n let dateTimeFormat;\n\n switch (datePattern) {\n case \"P\":\n dateTimeFormat = formatLong.dateTime({ width: \"short\" });\n break;\n case \"PP\":\n dateTimeFormat = formatLong.dateTime({ width: \"medium\" });\n break;\n case \"PPP\":\n dateTimeFormat = formatLong.dateTime({ width: \"long\" });\n break;\n case \"PPPP\":\n default:\n dateTimeFormat = formatLong.dateTime({ width: \"full\" });\n break;\n }\n\n return dateTimeFormat\n .replace(\"{{date}}\", dateLongFormatter(datePattern, formatLong))\n .replace(\"{{time}}\", timeLongFormatter(timePattern, formatLong));\n};\n\nexport const longFormatters = {\n p: timeLongFormatter,\n P: dateTimeLongFormatter,\n};\n","const dayOfYearTokenRE = /^D+$/;\nconst weekYearTokenRE = /^Y+$/;\n\nconst throwTokens = [\"D\", \"DD\", \"YY\", \"YYYY\"];\n\nexport function isProtectedDayOfYearToken(token) {\n return dayOfYearTokenRE.test(token);\n}\n\nexport function isProtectedWeekYearToken(token) {\n return weekYearTokenRE.test(token);\n}\n\nexport function warnOrThrowProtectedError(token, format, input) {\n const _message = message(token, format, input);\n console.warn(_message);\n if (throwTokens.includes(token)) throw new RangeError(_message);\n}\n\nfunction message(token, format, input) {\n const subject = token[0] === \"Y\" ? \"years\" : \"days of the month\";\n return `Use \\`${token.toLowerCase()}\\` instead of \\`${token}\\` (in \\`${format}\\`) for formatting ${subject} to the input \\`${input}\\`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md`;\n}\n","/**\n * @name isDate\n * @category Common Helpers\n * @summary Is the given value a date?\n *\n * @description\n * Returns true if the given value is an instance of Date. The function works for dates transferred across iframes.\n *\n * @param value - The value to check\n *\n * @returns True if the given value is a date\n *\n * @example\n * // For a valid date:\n * const result = isDate(new Date())\n * //=> true\n *\n * @example\n * // For an invalid date:\n * const result = isDate(new Date(NaN))\n * //=> true\n *\n * @example\n * // For some value:\n * const result = isDate('2014-02-31')\n * //=> false\n *\n * @example\n * // For an object:\n * const result = isDate({})\n * //=> false\n */\nexport function isDate(value) {\n return (\n value instanceof Date ||\n (typeof value === \"object\" &&\n Object.prototype.toString.call(value) === \"[object Date]\")\n );\n}\n\n// Fallback for modularized imports:\nexport default isDate;\n","import { isDate } from \"./isDate.js\";\nimport { toDate } from \"./toDate.js\";\n\n/**\n * @name isValid\n * @category Common Helpers\n * @summary Is the given date valid?\n *\n * @description\n * Returns false if argument is Invalid Date and true otherwise.\n * Argument is converted to Date using `toDate`. See [toDate](https://date-fns.org/docs/toDate)\n * Invalid Date is a Date, whose time value is NaN.\n *\n * Time value of Date: http://es5.github.io/#x15.9.1.1\n *\n * @param date - The date to check\n *\n * @returns The date is valid\n *\n * @example\n * // For the valid date:\n * const result = isValid(new Date(2014, 1, 31))\n * //=> true\n *\n * @example\n * // For the value, convertible into a date:\n * const result = isValid(1393804800000)\n * //=> true\n *\n * @example\n * // For the invalid date:\n * const result = isValid(new Date(''))\n * //=> false\n */\nexport function isValid(date) {\n return !((!isDate(date) && typeof date !== \"number\") || isNaN(+toDate(date)));\n}\n\n// Fallback for modularized imports:\nexport default isValid;\n","import { defaultLocale } from \"./_lib/defaultLocale.js\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.js\";\nimport { formatters } from \"./_lib/format/formatters.js\";\nimport { longFormatters } from \"./_lib/format/longFormatters.js\";\nimport {\n isProtectedDayOfYearToken,\n isProtectedWeekYearToken,\n warnOrThrowProtectedError,\n} from \"./_lib/protectedTokens.js\";\nimport { isValid } from \"./isValid.js\";\nimport { toDate } from \"./toDate.js\";\n\n// Rexports of internal for libraries to use.\n// See: https://github.com/date-fns/date-fns/issues/3638#issuecomment-1877082874\nexport { formatters, longFormatters };\n\n// This RegExp consists of three parts separated by `|`:\n// - [yYQqMLwIdDecihHKkms]o matches any available ordinal number token\n// (one of the certain letters followed by `o`)\n// - (\\w)\\1* matches any sequences of the same letter\n// - '' matches two quote characters in a row\n// - '(''|[^'])+('|$) matches anything surrounded by two quote characters ('),\n// except a single quote symbol, which ends the sequence.\n// Two quote characters do not end the sequence.\n// If there is no matching single quote\n// then the sequence will continue until the end of the string.\n// - . matches any single character unmatched by previous parts of the RegExps\nconst formattingTokensRegExp =\n /[yYQqMLwIdDecihHKkms]o|(\\w)\\1*|''|'(''|[^'])+('|$)|./g;\n\n// This RegExp catches symbols escaped by quotes, and also\n// sequences of symbols P, p, and the combinations like `PPPPPPPppppp`\nconst longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;\n\nconst escapedStringRegExp = /^'([^]*?)'?$/;\nconst doubleQuoteRegExp = /''/g;\nconst unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n\nexport { format as formatDate };\n\n/**\n * The {@link format} function options.\n */\n\n/**\n * @name format\n * @alias formatDate\n * @category Common Helpers\n * @summary Format the date.\n *\n * @description\n * Return the formatted date string in the given format. The result may vary by locale.\n *\n * > ⚠️ Please note that the `format` tokens differ from Moment.js and other libraries.\n * > See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * The characters wrapped between two single quotes characters (') are escaped.\n * Two single quotes in a row, whether inside or outside a quoted sequence, represent a 'real' single quote.\n * (see the last example)\n *\n * Format of the string is based on Unicode Technical Standard #35:\n * https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table\n * with a few additions (see note 7 below the table).\n *\n * Accepted patterns:\n * | Unit | Pattern | Result examples | Notes |\n * |---------------------------------|---------|-----------------------------------|-------|\n * | Era | G..GGG | AD, BC | |\n * | | GGGG | Anno Domini, Before Christ | 2 |\n * | | GGGGG | A, B | |\n * | Calendar year | y | 44, 1, 1900, 2017 | 5 |\n * | | yo | 44th, 1st, 0th, 17th | 5,7 |\n * | | yy | 44, 01, 00, 17 | 5 |\n * | | yyy | 044, 001, 1900, 2017 | 5 |\n * | | yyyy | 0044, 0001, 1900, 2017 | 5 |\n * | | yyyyy | ... | 3,5 |\n * | Local week-numbering year | Y | 44, 1, 1900, 2017 | 5 |\n * | | Yo | 44th, 1st, 1900th, 2017th | 5,7 |\n * | | YY | 44, 01, 00, 17 | 5,8 |\n * | | YYY | 044, 001, 1900, 2017 | 5 |\n * | | YYYY | 0044, 0001, 1900, 2017 | 5,8 |\n * | | YYYYY | ... | 3,5 |\n * | ISO week-numbering year | R | -43, 0, 1, 1900, 2017 | 5,7 |\n * | | RR | -43, 00, 01, 1900, 2017 | 5,7 |\n * | | RRR | -043, 000, 001, 1900, 2017 | 5,7 |\n * | | RRRR | -0043, 0000, 0001, 1900, 2017 | 5,7 |\n * | | RRRRR | ... | 3,5,7 |\n * | Extended year | u | -43, 0, 1, 1900, 2017 | 5 |\n * | | uu | -43, 01, 1900, 2017 | 5 |\n * | | uuu | -043, 001, 1900, 2017 | 5 |\n * | | uuuu | -0043, 0001, 1900, 2017 | 5 |\n * | | uuuuu | ... | 3,5 |\n * | Quarter (formatting) | Q | 1, 2, 3, 4 | |\n * | | Qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | QQ | 01, 02, 03, 04 | |\n * | | QQQ | Q1, Q2, Q3, Q4 | |\n * | | QQQQ | 1st quarter, 2nd quarter, ... | 2 |\n * | | QQQQQ | 1, 2, 3, 4 | 4 |\n * | Quarter (stand-alone) | q | 1, 2, 3, 4 | |\n * | | qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | qq | 01, 02, 03, 04 | |\n * | | qqq | Q1, Q2, Q3, Q4 | |\n * | | qqqq | 1st quarter, 2nd quarter, ... | 2 |\n * | | qqqqq | 1, 2, 3, 4 | 4 |\n * | Month (formatting) | M | 1, 2, ..., 12 | |\n * | | Mo | 1st, 2nd, ..., 12th | 7 |\n * | | MM | 01, 02, ..., 12 | |\n * | | MMM | Jan, Feb, ..., Dec | |\n * | | MMMM | January, February, ..., December | 2 |\n * | | MMMMM | J, F, ..., D | |\n * | Month (stand-alone) | L | 1, 2, ..., 12 | |\n * | | Lo | 1st, 2nd, ..., 12th | 7 |\n * | | LL | 01, 02, ..., 12 | |\n * | | LLL | Jan, Feb, ..., Dec | |\n * | | LLLL | January, February, ..., December | 2 |\n * | | LLLLL | J, F, ..., D | |\n * | Local week of year | w | 1, 2, ..., 53 | |\n * | | wo | 1st, 2nd, ..., 53th | 7 |\n * | | ww | 01, 02, ..., 53 | |\n * | ISO week of year | I | 1, 2, ..., 53 | 7 |\n * | | Io | 1st, 2nd, ..., 53th | 7 |\n * | | II | 01, 02, ..., 53 | 7 |\n * | Day of month | d | 1, 2, ..., 31 | |\n * | | do | 1st, 2nd, ..., 31st | 7 |\n * | | dd | 01, 02, ..., 31 | |\n * | Day of year | D | 1, 2, ..., 365, 366 | 9 |\n * | | Do | 1st, 2nd, ..., 365th, 366th | 7 |\n * | | DD | 01, 02, ..., 365, 366 | 9 |\n * | | DDD | 001, 002, ..., 365, 366 | |\n * | | DDDD | ... | 3 |\n * | Day of week (formatting) | E..EEE | Mon, Tue, Wed, ..., Sun | |\n * | | EEEE | Monday, Tuesday, ..., Sunday | 2 |\n * | | EEEEE | M, T, W, T, F, S, S | |\n * | | EEEEEE | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | ISO day of week (formatting) | i | 1, 2, 3, ..., 7 | 7 |\n * | | io | 1st, 2nd, ..., 7th | 7 |\n * | | ii | 01, 02, ..., 07 | 7 |\n * | | iii | Mon, Tue, Wed, ..., Sun | 7 |\n * | | iiii | Monday, Tuesday, ..., Sunday | 2,7 |\n * | | iiiii | M, T, W, T, F, S, S | 7 |\n * | | iiiiii | Mo, Tu, We, Th, Fr, Sa, Su | 7 |\n * | Local day of week (formatting) | e | 2, 3, 4, ..., 1 | |\n * | | eo | 2nd, 3rd, ..., 1st | 7 |\n * | | ee | 02, 03, ..., 01 | |\n * | | eee | Mon, Tue, Wed, ..., Sun | |\n * | | eeee | Monday, Tuesday, ..., Sunday | 2 |\n * | | eeeee | M, T, W, T, F, S, S | |\n * | | eeeeee | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | Local day of week (stand-alone) | c | 2, 3, 4, ..., 1 | |\n * | | co | 2nd, 3rd, ..., 1st | 7 |\n * | | cc | 02, 03, ..., 01 | |\n * | | ccc | Mon, Tue, Wed, ..., Sun | |\n * | | cccc | Monday, Tuesday, ..., Sunday | 2 |\n * | | ccccc | M, T, W, T, F, S, S | |\n * | | cccccc | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | AM, PM | a..aa | AM, PM | |\n * | | aaa | am, pm | |\n * | | aaaa | a.m., p.m. | 2 |\n * | | aaaaa | a, p | |\n * | AM, PM, noon, midnight | b..bb | AM, PM, noon, midnight | |\n * | | bbb | am, pm, noon, midnight | |\n * | | bbbb | a.m., p.m., noon, midnight | 2 |\n * | | bbbbb | a, p, n, mi | |\n * | Flexible day period | B..BBB | at night, in the morning, ... | |\n * | | BBBB | at night, in the morning, ... | 2 |\n * | | BBBBB | at night, in the morning, ... | |\n * | Hour [1-12] | h | 1, 2, ..., 11, 12 | |\n * | | ho | 1st, 2nd, ..., 11th, 12th | 7 |\n * | | hh | 01, 02, ..., 11, 12 | |\n * | Hour [0-23] | H | 0, 1, 2, ..., 23 | |\n * | | Ho | 0th, 1st, 2nd, ..., 23rd | 7 |\n * | | HH | 00, 01, 02, ..., 23 | |\n * | Hour [0-11] | K | 1, 2, ..., 11, 0 | |\n * | | Ko | 1st, 2nd, ..., 11th, 0th | 7 |\n * | | KK | 01, 02, ..., 11, 00 | |\n * | Hour [1-24] | k | 24, 1, 2, ..., 23 | |\n * | | ko | 24th, 1st, 2nd, ..., 23rd | 7 |\n * | | kk | 24, 01, 02, ..., 23 | |\n * | Minute | m | 0, 1, ..., 59 | |\n * | | mo | 0th, 1st, ..., 59th | 7 |\n * | | mm | 00, 01, ..., 59 | |\n * | Second | s | 0, 1, ..., 59 | |\n * | | so | 0th, 1st, ..., 59th | 7 |\n * | | ss | 00, 01, ..., 59 | |\n * | Fraction of second | S | 0, 1, ..., 9 | |\n * | | SS | 00, 01, ..., 99 | |\n * | | SSS | 000, 001, ..., 999 | |\n * | | SSSS | ... | 3 |\n * | Timezone (ISO-8601 w/ Z) | X | -08, +0530, Z | |\n * | | XX | -0800, +0530, Z | |\n * | | XXX | -08:00, +05:30, Z | |\n * | | XXXX | -0800, +0530, Z, +123456 | 2 |\n * | | XXXXX | -08:00, +05:30, Z, +12:34:56 | |\n * | Timezone (ISO-8601 w/o Z) | x | -08, +0530, +00 | |\n * | | xx | -0800, +0530, +0000 | |\n * | | xxx | -08:00, +05:30, +00:00 | 2 |\n * | | xxxx | -0800, +0530, +0000, +123456 | |\n * | | xxxxx | -08:00, +05:30, +00:00, +12:34:56 | |\n * | Timezone (GMT) | O...OOO | GMT-8, GMT+5:30, GMT+0 | |\n * | | OOOO | GMT-08:00, GMT+05:30, GMT+00:00 | 2 |\n * | Timezone (specific non-locat.) | z...zzz | GMT-8, GMT+5:30, GMT+0 | 6 |\n * | | zzzz | GMT-08:00, GMT+05:30, GMT+00:00 | 2,6 |\n * | Seconds timestamp | t | 512969520 | 7 |\n * | | tt | ... | 3,7 |\n * | Milliseconds timestamp | T | 512969520900 | 7 |\n * | | TT | ... | 3,7 |\n * | Long localized date | P | 04/29/1453 | 7 |\n * | | PP | Apr 29, 1453 | 7 |\n * | | PPP | April 29th, 1453 | 7 |\n * | | PPPP | Friday, April 29th, 1453 | 2,7 |\n * | Long localized time | p | 12:00 AM | 7 |\n * | | pp | 12:00:00 AM | 7 |\n * | | ppp | 12:00:00 AM GMT+2 | 7 |\n * | | pppp | 12:00:00 AM GMT+02:00 | 2,7 |\n * | Combination of date and time | Pp | 04/29/1453, 12:00 AM | 7 |\n * | | PPpp | Apr 29, 1453, 12:00:00 AM | 7 |\n * | | PPPppp | April 29th, 1453 at ... | 7 |\n * | | PPPPpppp| Friday, April 29th, 1453 at ... | 2,7 |\n * Notes:\n * 1. \"Formatting\" units (e.g. formatting quarter) in the default en-US locale\n * are the same as \"stand-alone\" units, but are different in some languages.\n * \"Formatting\" units are declined according to the rules of the language\n * in the context of a date. \"Stand-alone\" units are always nominative singular:\n *\n * `format(new Date(2017, 10, 6), 'do LLLL', {locale: cs}) //=> '6. listopad'`\n *\n * `format(new Date(2017, 10, 6), 'do MMMM', {locale: cs}) //=> '6. listopadu'`\n *\n * 2. Any sequence of the identical letters is a pattern, unless it is escaped by\n * the single quote characters (see below).\n * If the sequence is longer than listed in table (e.g. `EEEEEEEEEEE`)\n * the output will be the same as default pattern for this unit, usually\n * the longest one (in case of ISO weekdays, `EEEE`). Default patterns for units\n * are marked with \"2\" in the last column of the table.\n *\n * `format(new Date(2017, 10, 6), 'MMM') //=> 'Nov'`\n *\n * `format(new Date(2017, 10, 6), 'MMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMM') //=> 'N'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMMM') //=> 'November'`\n *\n * 3. Some patterns could be unlimited length (such as `yyyyyyyy`).\n * The output will be padded with zeros to match the length of the pattern.\n *\n * `format(new Date(2017, 10, 6), 'yyyyyyyy') //=> '00002017'`\n *\n * 4. `QQQQQ` and `qqqqq` could be not strictly numerical in some locales.\n * These tokens represent the shortest form of the quarter.\n *\n * 5. The main difference between `y` and `u` patterns are B.C. years:\n *\n * | Year | `y` | `u` |\n * |------|-----|-----|\n * | AC 1 | 1 | 1 |\n * | BC 1 | 1 | 0 |\n * | BC 2 | 2 | -1 |\n *\n * Also `yy` always returns the last two digits of a year,\n * while `uu` pads single digit years to 2 characters and returns other years unchanged:\n *\n * | Year | `yy` | `uu` |\n * |------|------|------|\n * | 1 | 01 | 01 |\n * | 14 | 14 | 14 |\n * | 376 | 76 | 376 |\n * | 1453 | 53 | 1453 |\n *\n * The same difference is true for local and ISO week-numbering years (`Y` and `R`),\n * except local week-numbering years are dependent on `options.weekStartsOn`\n * and `options.firstWeekContainsDate` (compare [getISOWeekYear](https://date-fns.org/docs/getISOWeekYear)\n * and [getWeekYear](https://date-fns.org/docs/getWeekYear)).\n *\n * 6. Specific non-location timezones are currently unavailable in `date-fns`,\n * so right now these tokens fall back to GMT timezones.\n *\n * 7. These patterns are not in the Unicode Technical Standard #35:\n * - `i`: ISO day of week\n * - `I`: ISO week of year\n * - `R`: ISO week-numbering year\n * - `t`: seconds timestamp\n * - `T`: milliseconds timestamp\n * - `o`: ordinal number modifier\n * - `P`: long localized date\n * - `p`: long localized time\n *\n * 8. `YY` and `YYYY` tokens represent week-numbering years but they are often confused with years.\n * You should enable `options.useAdditionalWeekYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * 9. `D` and `DD` tokens represent days of the year but they are often confused with days of the month.\n * You should enable `options.useAdditionalDayOfYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * @param date - The original date\n * @param format - The string of tokens\n * @param options - An object with options\n *\n * @returns The formatted date string\n *\n * @throws `date` must not be Invalid Date\n * @throws `options.locale` must contain `localize` property\n * @throws `options.locale` must contain `formatLong` property\n * @throws use `yyyy` instead of `YYYY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `yy` instead of `YY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `d` instead of `D` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `dd` instead of `DD` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws format string contains an unescaped latin alphabet character\n *\n * @example\n * // Represent 11 February 2014 in middle-endian format:\n * const result = format(new Date(2014, 1, 11), 'MM/dd/yyyy')\n * //=> '02/11/2014'\n *\n * @example\n * // Represent 2 July 2014 in Esperanto:\n * import { eoLocale } from 'date-fns/locale/eo'\n * const result = format(new Date(2014, 6, 2), \"do 'de' MMMM yyyy\", {\n * locale: eoLocale\n * })\n * //=> '2-a de julio 2014'\n *\n * @example\n * // Escape string by single quote characters:\n * const result = format(new Date(2014, 6, 2, 15), \"h 'o''clock'\")\n * //=> \"3 o'clock\"\n */\nexport function format(date, formatStr, options) {\n const defaultOptions = getDefaultOptions();\n const locale = options?.locale ?? defaultOptions.locale ?? defaultLocale;\n\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const originalDate = toDate(date, options?.in);\n\n if (!isValid(originalDate)) {\n throw new RangeError(\"Invalid time value\");\n }\n\n let parts = formatStr\n .match(longFormattingTokensRegExp)\n .map((substring) => {\n const firstCharacter = substring[0];\n if (firstCharacter === \"p\" || firstCharacter === \"P\") {\n const longFormatter = longFormatters[firstCharacter];\n return longFormatter(substring, locale.formatLong);\n }\n return substring;\n })\n .join(\"\")\n .match(formattingTokensRegExp)\n .map((substring) => {\n // Replace two single quote characters with one single quote character\n if (substring === \"''\") {\n return { isToken: false, value: \"'\" };\n }\n\n const firstCharacter = substring[0];\n if (firstCharacter === \"'\") {\n return { isToken: false, value: cleanEscapedString(substring) };\n }\n\n if (formatters[firstCharacter]) {\n return { isToken: true, value: substring };\n }\n\n if (firstCharacter.match(unescapedLatinCharacterRegExp)) {\n throw new RangeError(\n \"Format string contains an unescaped latin alphabet character `\" +\n firstCharacter +\n \"`\",\n );\n }\n\n return { isToken: false, value: substring };\n });\n\n // invoke localize preprocessor (only for french locales at the moment)\n if (locale.localize.preprocessor) {\n parts = locale.localize.preprocessor(originalDate, parts);\n }\n\n const formatterOptions = {\n firstWeekContainsDate,\n weekStartsOn,\n locale,\n };\n\n return parts\n .map((part) => {\n if (!part.isToken) return part.value;\n\n const token = part.value;\n\n if (\n (!options?.useAdditionalWeekYearTokens &&\n isProtectedWeekYearToken(token)) ||\n (!options?.useAdditionalDayOfYearTokens &&\n isProtectedDayOfYearToken(token))\n ) {\n warnOrThrowProtectedError(token, formatStr, String(date));\n }\n\n const formatter = formatters[token[0]];\n return formatter(originalDate, token, locale.localize, formatterOptions);\n })\n .join(\"\");\n}\n\nfunction cleanEscapedString(input) {\n const matched = input.match(escapedStringRegExp);\n\n if (!matched) {\n return input;\n }\n\n return matched[1].replace(doubleQuoteRegExp, \"'\");\n}\n\n// Fallback for modularized imports:\nexport default format;\n"],"names":["r","e","o","t","f","Array","isArray","n","length","arguments","module","exports","clsx","i","s","u","a","c","h","d","l","$","y","M","name","weekdays","split","months","ordinal","m","String","join","v","z","utcOffset","Math","abs","floor","date","year","month","clone","add","ceil","p","w","D","ms","Q","toLowerCase","replace","g","S","_","O","args","b","locale","$L","utc","$u","x","$x","$offset","this","parse","prototype","$d","Date","NaN","test","match","substring","UTC","init","$y","getFullYear","$M","getMonth","$D","getDate","$W","getDay","$H","getHours","$m","getMinutes","$s","getSeconds","$ms","getMilliseconds","$utils","isValid","toString","isSame","startOf","endOf","isAfter","isBefore","$g","set","unix","valueOf","getTime","toDate","apply","slice","$locale","weekStart","$set","min","daysInMonth","get","Number","round","subtract","format","invalidDate","meridiem","monthsShort","weekdaysMin","weekdaysShort","getTimezoneOffset","diff","toJSON","toISOString","toUTCString","k","forEach","extend","$i","isDayjs","en","Ls","formatDistanceLocale","lessThanXSeconds","one","other","xSeconds","halfAMinute","lessThanXMinutes","xMinutes","aboutXHours","xHours","xDays","aboutXWeeks","xWeeks","aboutXMonths","xMonths","aboutXYears","xYears","overXYears","almostXYears","buildFormatLongFn","options","width","defaultWidth","formats","formatLong","full","long","medium","short","time","dateTime","formatRelativeLocale","lastWeek","yesterday","today","tomorrow","nextWeek","buildLocalizeFn","value","valuesArray","context","formattingValues","defaultFormattingWidth","values","argumentCallback","buildMatchFn","string","matchPattern","matchPatterns","defaultMatchWidth","matchResult","matchedString","parsePatterns","defaultParseWidth","key","array","predicate","findIndex","pattern","object","Object","hasOwnProperty","call","findKey","valueCallback","rest","enUS","code","formatDistance","token","count","result","tokenValue","addSuffix","comparison","formatRelative","_date","_baseDate","_options","localize","ordinalNumber","dirtyNumber","number","rem100","era","narrow","abbreviated","wide","quarter","day","dayPeriod","am","pm","midnight","noon","morning","afternoon","evening","night","parsePattern","parseInt","parseResult","any","index","weekStartsOn","firstWeekContainsDate","defaultOptions","getDefaultOptions","pow","millisecondsInWeek","constructFromSymbol","Symbol","for","constructFrom","constructor","argument","getTimezoneOffsetInMilliseconds","utcDate","setUTCFullYear","startOfDay","in","setHours","differenceInCalendarDays","laterDate","earlierDate","laterDate_","earlierDate_","dates","normalize","bind","find","map","normalizeDates","laterStartOfDay","earlierStartOfDay","laterTimestamp","earlierTimestamp","startOfYear","date_","setFullYear","getDayOfYear","startOfWeek","setDate","startOfISOWeek","getISOWeekYear","fourthOfJanuaryOfNextYear","startOfNextYear","fourthOfJanuaryOfThisYear","startOfThisYear","startOfISOWeekYear","fourthOfJanuary","getISOWeek","getWeekYear","firstWeekOfNextYear","firstWeekOfThisYear","startOfWeekYear","firstWeek","getWeek","addLeadingZeros","targetLength","padStart","lightFormatters","signedYear","dayPeriodEnumValue","toUpperCase","H","numberOfDigits","milliseconds","trunc","dayPeriodEnum","formatters","G","unit","Y","signedWeekYear","weekYear","R","q","L","week","I","isoWeek","dayOfYear","E","dayOfWeek","localDayOfWeek","isoDayOfWeek","hours","B","K","X","_localize","timezoneOffset","formatTimezoneWithOptionalMinutes","formatTimezone","formatTimezoneShort","T","offset","delimiter","sign","absOffset","minutes","dateLongFormatter","timeLongFormatter","longFormatters","P","datePattern","timePattern","dateTimeFormat","dayOfYearTokenRE","weekYearTokenRE","throwTokens","isDate","isNaN","formattingTokensRegExp","longFormattingTokensRegExp","escapedStringRegExp","doubleQuoteRegExp","unescapedLatinCharacterRegExp","formatStr","originalDate","RangeError","parts","firstCharacter","longFormatter","isToken","cleanEscapedString","preprocessor","formatterOptions","part","useAdditionalWeekYearTokens","isProtectedWeekYearToken","useAdditionalDayOfYearTokens","isProtectedDayOfYearToken","input","_message","subject","message","console","warn","includes","warnOrThrowProtectedError","formatter","matched"],"sourceRoot":""}