{"version":3,"sources":["webpack:///./node_modules/date-fns/esm/isAfter/index.js","webpack:///./node_modules/date-fns/esm/_lib/startOfUTCWeekYear/index.js","webpack:///./node_modules/date-fns/esm/_lib/getUTCWeek/index.js","webpack:///./node_modules/date-fns/esm/getDay/index.js","webpack:///./node_modules/date-fns/esm/_lib/format/longFormatters/index.js","webpack:///./node_modules/date-fns/esm/add/index.js","webpack:///./node_modules/date-fns/esm/_lib/getTimezoneOffsetInMilliseconds/index.js","webpack:///./node_modules/date-fns/esm/_lib/assign/index.js","webpack:///./node_modules/date-fns/esm/_lib/setUTCDay/index.js","webpack:///./node_modules/date-fns/esm/_lib/setUTCISODay/index.js","webpack:///./node_modules/date-fns/esm/_lib/setUTCISOWeek/index.js","webpack:///./node_modules/date-fns/esm/_lib/setUTCWeek/index.js","webpack:///./node_modules/date-fns/esm/parse/_lib/parsers/index.js","webpack:///./node_modules/date-fns/esm/parse/index.js","webpack:///./node_modules/date-fns/esm/endOfWeek/index.js","webpack:///./node_modules/date-fns/esm/setMilliseconds/index.js","webpack:///./node_modules/date-fns/esm/isValid/index.js","webpack:///./node_modules/date-fns/esm/_lib/getUTCWeekYear/index.js","webpack:///./node_modules/date-fns/esm/setHours/index.js","webpack:///./node_modules/date-fns/esm/getSeconds/index.js","webpack:///./node_modules/date-fns/esm/startOfWeek/index.js","webpack:///./node_modules/date-fns/esm/getMonth/index.js","webpack:///./node_modules/date-fns/esm/getYear/index.js","webpack:///./node_modules/date-fns/esm/addMonths/index.js","webpack:///./node_modules/date-fns/esm/isBefore/index.js","webpack:///./node_modules/date-fns/esm/set/index.js","webpack:///./node_modules/date-fns/esm/startOfDay/index.js","webpack:///./node_modules/date-fns/esm/differenceInCalendarDays/index.js","webpack:///./node_modules/date-fns/esm/_lib/getUTCISOWeekYear/index.js","webpack:///./node_modules/date-fns/esm/addMilliseconds/index.js","webpack:///./node_modules/date-fns/esm/subMilliseconds/index.js","webpack:///./node_modules/date-fns/esm/locale/en-US/_lib/formatDistance/index.js","webpack:///./node_modules/date-fns/esm/locale/_lib/buildFormatLongFn/index.js","webpack:///./node_modules/date-fns/esm/locale/en-US/_lib/formatLong/index.js","webpack:///./node_modules/date-fns/esm/locale/en-US/_lib/formatRelative/index.js","webpack:///./node_modules/date-fns/esm/locale/_lib/buildLocalizeFn/index.js","webpack:///./node_modules/date-fns/esm/locale/en-US/_lib/localize/index.js","webpack:///./node_modules/date-fns/esm/locale/_lib/buildMatchFn/index.js","webpack:///./node_modules/date-fns/esm/locale/_lib/buildMatchPatternFn/index.js","webpack:///./node_modules/date-fns/esm/locale/en-US/_lib/match/index.js","webpack:///./node_modules/date-fns/esm/locale/en-US/index.js","webpack:///./node_modules/date-fns/esm/_lib/requiredArgs/index.js","webpack:///./node_modules/date-fns/esm/_lib/startOfUTCISOWeekYear/index.js","webpack:///./node_modules/date-fns/esm/_lib/getUTCISOWeek/index.js","webpack:///./node_modules/date-fns/esm/getDaysInMonth/index.js","webpack:///./node_modules/date-fns/esm/setMonth/index.js","webpack:///./node_modules/date-fns/esm/subMonths/index.js","webpack:///./node_modules/date-fns/esm/isDate/index.js","webpack:///./node_modules/date-fns/esm/startOfISOWeek/index.js","webpack:///./node_modules/date-fns/esm/getISOWeekYear/index.js","webpack:///./node_modules/date-fns/esm/startOfISOWeekYear/index.js","webpack:///./node_modules/date-fns/esm/getISOWeek/index.js","webpack:///./node_modules/date-fns/esm/_lib/getUTCDayOfYear/index.js","webpack:///./node_modules/date-fns/esm/_lib/addLeadingZeros/index.js","webpack:///./node_modules/date-fns/esm/_lib/format/lightFormatters/index.js","webpack:///./node_modules/date-fns/esm/_lib/format/formatters/index.js","webpack:///./node_modules/date-fns/esm/format/index.js","webpack:///./node_modules/date-fns/esm/subYears/index.js","webpack:///./node_modules/date-fns/esm/_lib/startOfUTCISOWeek/index.js","webpack:///./node_modules/date-fns/esm/setSeconds/index.js","webpack:///./node_modules/date-fns/esm/isEqual/index.js","webpack:///./node_modules/date-fns/esm/addYears/index.js","webpack:///./node_modules/date-fns/esm/getHours/index.js","webpack:///./node_modules/date-fns/esm/_lib/startOfUTCWeek/index.js","webpack:///./node_modules/date-fns/esm/_lib/protectedTokens/index.js","webpack:///./node_modules/date-fns/esm/getMinutes/index.js","webpack:///./node_modules/date-fns/esm/setMinutes/index.js","webpack:///./node_modules/date-fns/esm/constants/index.js","webpack:///./node_modules/date-fns/esm/parseISO/index.js","webpack:///./node_modules/date-fns/esm/setYear/index.js","webpack:///./node_modules/date-fns/esm/subDays/index.js","webpack:///./node_modules/date-fns/esm/sub/index.js","webpack:///./node_modules/date-fns/esm/addDays/index.js","webpack:///./node_modules/date-fns/esm/toDate/index.js","webpack:///./node_modules/date-fns/esm/_lib/toInteger/index.js","webpack:///./node_modules/date-fns/esm/eachDayOfInterval/index.js"],"names":["isAfter","dirtyDate","dirtyDateToCompare","arguments","date","dateToCompare","getTime","startOfUTCWeekYear","dirtyOptions","requiredArgs","options","locale","localeFirstWeekContainsDate","firstWeekContainsDate","defaultFirstWeekContainsDate","toInteger","year","getUTCWeekYear","firstWeek","Date","setUTCFullYear","setUTCHours","startOfUTCWeek","MILLISECONDS_IN_WEEK","getUTCWeek","toDate","diff","Math","round","getDay","day","dateLongFormatter","pattern","formatLong","width","timeLongFormatter","time","dateTimeLongFormatter","dateTimeFormat","matchResult","match","datePattern","timePattern","dateTime","replace","longFormatters","p","P","add","duration","NaN","years","months","weeks","days","hours","minutes","seconds","dateWithMonths","dateWithDays","minutesToAdd","secondsToAdd","msToAdd","finalDate","getTimezoneOffsetInMilliseconds","utcDate","UTC","getFullYear","getMonth","getDate","getHours","getMinutes","getSeconds","getMilliseconds","target","dirtyObject","TypeError","property","Object","prototype","hasOwnProperty","call","setUTCDay","dirtyDay","localeWeekStartsOn","weekStartsOn","defaultWeekStartsOn","RangeError","currentDay","getUTCDay","remainder","dayIndex","setUTCDate","getUTCDate","setUTCISODay","setUTCISOWeek","dirtyISOWeek","isoWeek","getUTCISOWeek","setUTCWeek","dirtyWeek","week","MILLISECONDS_IN_HOUR","MILLISECONDS_IN_MINUTE","MILLISECONDS_IN_SECOND","numericPatterns","month","dayOfYear","hour23h","hour24h","hour11h","hour12h","minute","second","singleDigit","twoDigits","threeDigits","fourDigits","anyDigitsSigned","singleDigitSigned","twoDigitsSigned","threeDigitsSigned","fourDigitsSigned","timezonePatterns","basicOptionalMinutes","basic","basicOptionalSeconds","extended","extendedOptionalSeconds","parseNumericPattern","string","valueCallback","value","parseInt","rest","slice","length","parseTimezonePattern","sign","parseAnyDigitsSigned","parseNDigits","n","RegExp","parseNDigitsSigned","dayPeriodEnumToHours","enumValue","normalizeTwoDigitYear","twoDigitYear","currentYear","result","isCommonEra","absCurrentYear","rangeEnd","rangeEndCentury","floor","isPreviousCentury","DAYS_IN_MONTH","DAYS_IN_MONTH_LEAP_YEAR","isLeapYearIndex","parsers","G","priority","parse","token","_options","era","set","flags","incompatibleTokens","y","isTwoDigitYear","ordinalNumber","unit","validate","_date","getUTCFullYear","normalizedTwoDigitYear","Y","R","_match","_flags","firstWeekOfYear","startOfUTCISOWeek","u","Q","quarter","context","setUTCMonth","q","M","L","w","I","d","subPriority","isLeapYear","getUTCMonth","D","E","e","wholeWeekDays","c","i","a","dayPeriod","b","B","h","isPM","getUTCHours","H","K","k","m","setUTCMinutes","s","setUTCSeconds","S","pow","setUTCMilliseconds","X","timestampIsSet","x","t","_token","T","TIMEZONE_UNIT_PRIORITY","formattingTokensRegExp","longFormattingTokensRegExp","escapedStringRegExp","doubleQuoteRegExp","notWhitespaceRegExp","unescapedLatinCharacterRegExp","dirtyDateString","dirtyFormatString","dirtyReferenceDate","dateString","String","formatString","subFnOptions","setters","dateToSystemTimezone","index","tokens","map","substring","firstCharacter","longFormatter","join","usedTokens","useAdditionalWeekYearTokens","useAdditionalDayOfYearTokens","parser","Array","isArray","incompatibleToken","_i","usedToken","indexOf","concat","fullToken","push","parseResult","cleanEscapedString","test","uniquePrioritySetters","setter","sort","filter","array","setterArray","isNaN","subMilliseconds","convertedDate","setFullYear","setHours","getUTCMinutes","getUTCSeconds","getUTCMilliseconds","input","endOfWeek","setDate","setMilliseconds","dirtyMilliseconds","milliseconds","isValid","Number","firstWeekOfNextYear","startOfNextYear","firstWeekOfThisYear","startOfThisYear","dirtyHours","startOfWeek","getYear","addMonths","dirtyAmount","amount","dayOfMonth","endOfDesiredMonth","setMonth","daysInMonth","isBefore","values","setMinutes","setSeconds","startOfDay","MILLISECONDS_IN_DAY","differenceInCalendarDays","dirtyDateLeft","dirtyDateRight","startOfDayLeft","startOfDayRight","timestampLeft","timestampRight","getUTCISOWeekYear","fourthOfJanuaryOfNextYear","fourthOfJanuaryOfThisYear","addMilliseconds","timestamp","formatDistanceLocale","lessThanXSeconds","one","other","xSeconds","halfAMinute","lessThanXMinutes","xMinutes","aboutXHours","xHours","xDays","aboutXWeeks","xWeeks","aboutXMonths","xMonths","aboutXYears","xYears","overXYears","almostXYears","formatDistance","count","tokenValue","toString","addSuffix","comparison","buildFormatLongFn","args","undefined","defaultWidth","format","formats","dateFormats","full","long","medium","short","timeFormats","dateTimeFormats","formatRelativeLocale","lastWeek","yesterday","today","tomorrow","nextWeek","formatRelative","_baseDate","buildLocalizeFn","dirtyIndex","valuesArray","formattingValues","defaultFormattingWidth","_defaultWidth","_width","argumentCallback","eraValues","narrow","abbreviated","wide","quarterValues","monthValues","dayValues","dayPeriodValues","am","pm","midnight","noon","morning","afternoon","evening","night","formattingDayPeriodValues","dirtyNumber","number","rem100","localize","buildMatchFn","matchPattern","matchPatterns","defaultMatchWidth","matchedString","parsePatterns","defaultParseWidth","key","findIndex","findKey","object","predicate","buildMatchPatternFn","parsePattern","matchOrdinalNumberPattern","parseOrdinalNumberPattern","matchEraPatterns","parseEraPatterns","any","matchQuarterPatterns","parseQuarterPatterns","matchMonthPatterns","parseMonthPatterns","matchDayPatterns","parseDayPatterns","matchDayPeriodPatterns","parseDayPeriodPatterns","code","required","startOfUTCISOWeekYear","fourthOfJanuary","getDaysInMonth","monthIndex","lastDayOfMonth","dirtyMonth","dateWithDesiredMonth","min","subMonths","isDate","startOfISOWeek","getISOWeekYear","startOfISOWeekYear","getISOWeek","getUTCDayOfYear","startOfYearTimestamp","difference","addLeadingZeros","targetLength","output","abs","formatters","signedYear","dayPeriodEnumValue","toUpperCase","numberOfDigits","fractionalSeconds","dayPeriodEnum","lightFormatters","signedWeekYear","weekYear","isoWeekYear","ceil","dayOfWeek","localDayOfWeek","isoDayOfWeek","toLowerCase","_localize","originalDate","_originalDate","timezoneOffset","getTimezoneOffset","formatTimezoneWithOptionalMinutes","formatTimezone","O","formatTimezoneShort","z","offset","dirtyDelimiter","absOffset","delimiter","dirtyFormatStr","formatStr","formatterOptions","formatter","subYears","dirtySeconds","isEqual","dirtyLeftDate","dirtyRightDate","dateLeft","dateRight","addYears","protectedDayOfYearTokens","protectedWeekYearTokens","isProtectedDayOfYearToken","isProtectedWeekYearToken","throwProtectedError","dirtyMinutes","millisecondsInMinute","millisecondsInHour","parseISO","argument","additionalDigits","dateStrings","splitDateString","parseYearResult","parseYear","parseDate","restDateString","parseTime","timezone","parseTimezone","patterns","dateTimeDelimiter","timeZoneDelimiter","dateRegex","timeRegex","timezoneRegex","timeString","split","substr","exec","regex","captures","century","isWeekDate","parseDateUnit","validateWeekDate","dayOfISOWeekYear","validateDate","validateDayOfYearDate","max","parseTimeUnit","validateTime","parseFloat","timezoneString","validateTimezone","fourthOfJanuaryDay","daysInMonths","_year","_hours","setYear","dirtyYear","subDays","addDays","sub","dateWithoutMonths","dateWithoutDays","minutestoSub","secondstoSub","mstoSub","argStr","console","warn","Error","stack","eachDayOfInterval","dirtyInterval","interval","startDate","start","endDate","end","endTime","dates","currentDate","step"],"mappings":"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","file":"js/group-account~4e44fb25.3e18843a.js","sourcesContent":["import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name isAfter\n * @category Common Helpers\n * @summary Is the first date after the second one?\n *\n * @description\n * Is the first date after the second one?\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date that should be after the other one to return true\n * @param {Date|Number} dateToCompare - the date to compare with\n * @returns {Boolean} the first date is after the second date\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Is 10 July 1989 after 11 February 1987?\n * var result = isAfter(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> true\n */\n\nexport default function isAfter(dirtyDate, dirtyDateToCompare) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var dateToCompare = toDate(dirtyDateToCompare);\n return date.getTime() > dateToCompare.getTime();\n}","import getUTCWeekYear from \"../getUTCWeekYear/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport startOfUTCWeek from \"../startOfUTCWeek/index.js\";\nimport toInteger from \"../toInteger/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function startOfUTCWeekYear(dirtyDate, dirtyOptions) {\n requiredArgs(1, arguments);\n var options = dirtyOptions || {};\n var locale = options.locale;\n var localeFirstWeekContainsDate = locale && locale.options && locale.options.firstWeekContainsDate;\n var defaultFirstWeekContainsDate = localeFirstWeekContainsDate == null ? 1 : toInteger(localeFirstWeekContainsDate);\n var firstWeekContainsDate = options.firstWeekContainsDate == null ? defaultFirstWeekContainsDate : toInteger(options.firstWeekContainsDate);\n var year = getUTCWeekYear(dirtyDate, dirtyOptions);\n var firstWeek = new Date(0);\n firstWeek.setUTCFullYear(year, 0, firstWeekContainsDate);\n firstWeek.setUTCHours(0, 0, 0, 0);\n var date = startOfUTCWeek(firstWeek, dirtyOptions);\n return date;\n}","import toDate from \"../../toDate/index.js\";\nimport startOfUTCWeek from \"../startOfUTCWeek/index.js\";\nimport startOfUTCWeekYear from \"../startOfUTCWeekYear/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nvar MILLISECONDS_IN_WEEK = 604800000; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function getUTCWeek(dirtyDate, options) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var diff = startOfUTCWeek(date, options).getTime() - startOfUTCWeekYear(date, options).getTime(); // Round the number of days to the nearest integer\n // because the number of milliseconds in a week is not constant\n // (e.g. it's different in the week of the daylight saving time clock shift)\n\n return Math.round(diff / MILLISECONDS_IN_WEEK) + 1;\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name getDay\n * @category Weekday Helpers\n * @summary Get the day of the week of the given date.\n *\n * @description\n * Get the day of the week of the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the given date\n * @returns {0|1|2|3|4|5|6} the day of week, 0 represents Sunday\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // Which day of the week is 29 February 2012?\n * const result = getDay(new Date(2012, 1, 29))\n * //=> 3\n */\n\nexport default function getDay(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var day = date.getDay();\n return day;\n}","function dateLongFormatter(pattern, formatLong) {\n switch (pattern) {\n case 'P':\n return formatLong.date({\n width: 'short'\n });\n\n case 'PP':\n return formatLong.date({\n width: 'medium'\n });\n\n case 'PPP':\n return formatLong.date({\n width: 'long'\n });\n\n case 'PPPP':\n default:\n return formatLong.date({\n width: 'full'\n });\n }\n}\n\nfunction timeLongFormatter(pattern, formatLong) {\n switch (pattern) {\n case 'p':\n return formatLong.time({\n width: 'short'\n });\n\n case 'pp':\n return formatLong.time({\n width: 'medium'\n });\n\n case 'ppp':\n return formatLong.time({\n width: 'long'\n });\n\n case 'pppp':\n default:\n return formatLong.time({\n width: 'full'\n });\n }\n}\n\nfunction dateTimeLongFormatter(pattern, formatLong) {\n var matchResult = pattern.match(/(P+)(p+)?/) || [];\n var datePattern = matchResult[1];\n var timePattern = matchResult[2];\n\n if (!timePattern) {\n return dateLongFormatter(pattern, formatLong);\n }\n\n var dateTimeFormat;\n\n switch (datePattern) {\n case 'P':\n dateTimeFormat = formatLong.dateTime({\n width: 'short'\n });\n break;\n\n case 'PP':\n dateTimeFormat = formatLong.dateTime({\n width: 'medium'\n });\n break;\n\n case 'PPP':\n dateTimeFormat = formatLong.dateTime({\n width: 'long'\n });\n break;\n\n case 'PPPP':\n default:\n dateTimeFormat = formatLong.dateTime({\n width: 'full'\n });\n break;\n }\n\n return dateTimeFormat.replace('{{date}}', dateLongFormatter(datePattern, formatLong)).replace('{{time}}', timeLongFormatter(timePattern, formatLong));\n}\n\nvar longFormatters = {\n p: timeLongFormatter,\n P: dateTimeLongFormatter\n};\nexport default longFormatters;","import addDays from \"../addDays/index.js\";\nimport addMonths from \"../addMonths/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\n\n/**\n * @name add\n * @category Common Helpers\n * @summary Add the specified years, months, weeks, days, hours, minutes and seconds to the given date.\n *\n * @description\n * Add the specified years, months, weeks, days, hours, minutes and seconds to the given date.\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Duration} duration - the object with years, months, weeks, days, hours, minutes and seconds to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n *\n * | Key | Description |\n * |----------------|------------------------------------|\n * | years | Amount of years to be added |\n * | months | Amount of months to be added |\n * | weeks | Amount of weeks to be added |\n * | days | Amount of days to be added |\n * | hours | Amount of hours to be added |\n * | minutes | Amount of minutes to be added |\n * | seconds | Amount of seconds to be added |\n *\n * All values default to 0\n *\n * @returns {Date} the new date with the seconds added\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Add the following duration to 1 September 2014, 10:19:50\n * const result = add(new Date(2014, 8, 1, 10, 19, 50), {\n * years: 2,\n * months: 9,\n * weeks: 1,\n * days: 7,\n * hours: 5,\n * minutes: 9,\n * seconds: 30,\n * })\n * //=> Thu Jun 15 2017 15:29:20\n */\nexport default function add(dirtyDate, duration) {\n requiredArgs(2, arguments);\n if (!duration || typeof duration !== 'object') return new Date(NaN);\n var years = duration.years ? toInteger(duration.years) : 0;\n var months = duration.months ? toInteger(duration.months) : 0;\n var weeks = duration.weeks ? toInteger(duration.weeks) : 0;\n var days = duration.days ? toInteger(duration.days) : 0;\n var hours = duration.hours ? toInteger(duration.hours) : 0;\n var minutes = duration.minutes ? toInteger(duration.minutes) : 0;\n var seconds = duration.seconds ? toInteger(duration.seconds) : 0; // Add years and months\n\n var date = toDate(dirtyDate);\n var dateWithMonths = months || years ? addMonths(date, months + years * 12) : date; // Add weeks and days\n\n var dateWithDays = days || weeks ? addDays(dateWithMonths, days + weeks * 7) : dateWithMonths; // Add days, hours, minutes and seconds\n\n var minutesToAdd = minutes + hours * 60;\n var secondsToAdd = seconds + minutesToAdd * 60;\n var msToAdd = secondsToAdd * 1000;\n var finalDate = new Date(dateWithDays.getTime() + msToAdd);\n return finalDate;\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 default function getTimezoneOffsetInMilliseconds(date) {\n var utcDate = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds()));\n utcDate.setUTCFullYear(date.getFullYear());\n return date.getTime() - utcDate.getTime();\n}","export default function assign(target, dirtyObject) {\n if (target == null) {\n throw new TypeError('assign requires that input parameter not be null or undefined');\n }\n\n dirtyObject = dirtyObject || {};\n\n for (var property in dirtyObject) {\n if (Object.prototype.hasOwnProperty.call(dirtyObject, property)) {\n target[property] = dirtyObject[property];\n }\n }\n\n return target;\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport toInteger from \"../toInteger/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function setUTCDay(dirtyDate, dirtyDay, dirtyOptions) {\n requiredArgs(2, arguments);\n var options = dirtyOptions || {};\n var locale = options.locale;\n var localeWeekStartsOn = locale && locale.options && locale.options.weekStartsOn;\n var defaultWeekStartsOn = localeWeekStartsOn == null ? 0 : toInteger(localeWeekStartsOn);\n var weekStartsOn = options.weekStartsOn == null ? defaultWeekStartsOn : toInteger(options.weekStartsOn); // Test if weekStartsOn is between 0 and 6 _and_ is not NaN\n\n if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {\n throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');\n }\n\n var date = toDate(dirtyDate);\n var day = toInteger(dirtyDay);\n var currentDay = date.getUTCDay();\n var remainder = day % 7;\n var dayIndex = (remainder + 7) % 7;\n var diff = (dayIndex < weekStartsOn ? 7 : 0) + day - currentDay;\n date.setUTCDate(date.getUTCDate() + diff);\n return date;\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport toInteger from \"../toInteger/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function setUTCISODay(dirtyDate, dirtyDay) {\n requiredArgs(2, arguments);\n var day = toInteger(dirtyDay);\n\n if (day % 7 === 0) {\n day = day - 7;\n }\n\n var weekStartsOn = 1;\n var date = toDate(dirtyDate);\n var currentDay = date.getUTCDay();\n var remainder = day % 7;\n var dayIndex = (remainder + 7) % 7;\n var diff = (dayIndex < weekStartsOn ? 7 : 0) + day - currentDay;\n date.setUTCDate(date.getUTCDate() + diff);\n return date;\n}","import toInteger from \"../toInteger/index.js\";\nimport toDate from \"../../toDate/index.js\";\nimport getUTCISOWeek from \"../getUTCISOWeek/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function setUTCISOWeek(dirtyDate, dirtyISOWeek) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var isoWeek = toInteger(dirtyISOWeek);\n var diff = getUTCISOWeek(date) - isoWeek;\n date.setUTCDate(date.getUTCDate() - diff * 7);\n return date;\n}","import toInteger from \"../toInteger/index.js\";\nimport toDate from \"../../toDate/index.js\";\nimport getUTCWeek from \"../getUTCWeek/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function setUTCWeek(dirtyDate, dirtyWeek, options) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var week = toInteger(dirtyWeek);\n var diff = getUTCWeek(date, options) - week;\n date.setUTCDate(date.getUTCDate() - diff * 7);\n return date;\n}","import getUTCWeekYear from \"../../../_lib/getUTCWeekYear/index.js\";\nimport setUTCDay from \"../../../_lib/setUTCDay/index.js\";\nimport setUTCISODay from \"../../../_lib/setUTCISODay/index.js\";\nimport setUTCISOWeek from \"../../../_lib/setUTCISOWeek/index.js\";\nimport setUTCWeek from \"../../../_lib/setUTCWeek/index.js\";\nimport startOfUTCISOWeek from \"../../../_lib/startOfUTCISOWeek/index.js\";\nimport startOfUTCWeek from \"../../../_lib/startOfUTCWeek/index.js\";\nvar MILLISECONDS_IN_HOUR = 3600000;\nvar MILLISECONDS_IN_MINUTE = 60000;\nvar MILLISECONDS_IN_SECOND = 1000;\nvar numericPatterns = {\n month: /^(1[0-2]|0?\\d)/,\n // 0 to 12\n date: /^(3[0-1]|[0-2]?\\d)/,\n // 0 to 31\n dayOfYear: /^(36[0-6]|3[0-5]\\d|[0-2]?\\d?\\d)/,\n // 0 to 366\n week: /^(5[0-3]|[0-4]?\\d)/,\n // 0 to 53\n hour23h: /^(2[0-3]|[0-1]?\\d)/,\n // 0 to 23\n hour24h: /^(2[0-4]|[0-1]?\\d)/,\n // 0 to 24\n hour11h: /^(1[0-1]|0?\\d)/,\n // 0 to 11\n hour12h: /^(1[0-2]|0?\\d)/,\n // 0 to 12\n minute: /^[0-5]?\\d/,\n // 0 to 59\n second: /^[0-5]?\\d/,\n // 0 to 59\n singleDigit: /^\\d/,\n // 0 to 9\n twoDigits: /^\\d{1,2}/,\n // 0 to 99\n threeDigits: /^\\d{1,3}/,\n // 0 to 999\n fourDigits: /^\\d{1,4}/,\n // 0 to 9999\n anyDigitsSigned: /^-?\\d+/,\n singleDigitSigned: /^-?\\d/,\n // 0 to 9, -0 to -9\n twoDigitsSigned: /^-?\\d{1,2}/,\n // 0 to 99, -0 to -99\n threeDigitsSigned: /^-?\\d{1,3}/,\n // 0 to 999, -0 to -999\n fourDigitsSigned: /^-?\\d{1,4}/ // 0 to 9999, -0 to -9999\n\n};\nvar timezonePatterns = {\n basicOptionalMinutes: /^([+-])(\\d{2})(\\d{2})?|Z/,\n basic: /^([+-])(\\d{2})(\\d{2})|Z/,\n basicOptionalSeconds: /^([+-])(\\d{2})(\\d{2})((\\d{2}))?|Z/,\n extended: /^([+-])(\\d{2}):(\\d{2})|Z/,\n extendedOptionalSeconds: /^([+-])(\\d{2}):(\\d{2})(:(\\d{2}))?|Z/\n};\n\nfunction parseNumericPattern(pattern, string, valueCallback) {\n var matchResult = string.match(pattern);\n\n if (!matchResult) {\n return null;\n }\n\n var value = parseInt(matchResult[0], 10);\n return {\n value: valueCallback ? valueCallback(value) : value,\n rest: string.slice(matchResult[0].length)\n };\n}\n\nfunction parseTimezonePattern(pattern, string) {\n var matchResult = string.match(pattern);\n\n if (!matchResult) {\n return null;\n } // Input is 'Z'\n\n\n if (matchResult[0] === 'Z') {\n return {\n value: 0,\n rest: string.slice(1)\n };\n }\n\n var sign = matchResult[1] === '+' ? 1 : -1;\n var hours = matchResult[2] ? parseInt(matchResult[2], 10) : 0;\n var minutes = matchResult[3] ? parseInt(matchResult[3], 10) : 0;\n var seconds = matchResult[5] ? parseInt(matchResult[5], 10) : 0;\n return {\n value: sign * (hours * MILLISECONDS_IN_HOUR + minutes * MILLISECONDS_IN_MINUTE + seconds * MILLISECONDS_IN_SECOND),\n rest: string.slice(matchResult[0].length)\n };\n}\n\nfunction parseAnyDigitsSigned(string, valueCallback) {\n return parseNumericPattern(numericPatterns.anyDigitsSigned, string, valueCallback);\n}\n\nfunction parseNDigits(n, string, valueCallback) {\n switch (n) {\n case 1:\n return parseNumericPattern(numericPatterns.singleDigit, string, valueCallback);\n\n case 2:\n return parseNumericPattern(numericPatterns.twoDigits, string, valueCallback);\n\n case 3:\n return parseNumericPattern(numericPatterns.threeDigits, string, valueCallback);\n\n case 4:\n return parseNumericPattern(numericPatterns.fourDigits, string, valueCallback);\n\n default:\n return parseNumericPattern(new RegExp('^\\\\d{1,' + n + '}'), string, valueCallback);\n }\n}\n\nfunction parseNDigitsSigned(n, string, valueCallback) {\n switch (n) {\n case 1:\n return parseNumericPattern(numericPatterns.singleDigitSigned, string, valueCallback);\n\n case 2:\n return parseNumericPattern(numericPatterns.twoDigitsSigned, string, valueCallback);\n\n case 3:\n return parseNumericPattern(numericPatterns.threeDigitsSigned, string, valueCallback);\n\n case 4:\n return parseNumericPattern(numericPatterns.fourDigitsSigned, string, valueCallback);\n\n default:\n return parseNumericPattern(new RegExp('^-?\\\\d{1,' + n + '}'), string, valueCallback);\n }\n}\n\nfunction dayPeriodEnumToHours(enumValue) {\n switch (enumValue) {\n case 'morning':\n return 4;\n\n case 'evening':\n return 17;\n\n case 'pm':\n case 'noon':\n case 'afternoon':\n return 12;\n\n case 'am':\n case 'midnight':\n case 'night':\n default:\n return 0;\n }\n}\n\nfunction normalizeTwoDigitYear(twoDigitYear, currentYear) {\n var isCommonEra = currentYear > 0; // Absolute number of the current year:\n // 1 -> 1 AC\n // 0 -> 1 BC\n // -1 -> 2 BC\n\n var absCurrentYear = isCommonEra ? currentYear : 1 - currentYear;\n var result;\n\n if (absCurrentYear <= 50) {\n result = twoDigitYear || 100;\n } else {\n var rangeEnd = absCurrentYear + 50;\n var rangeEndCentury = Math.floor(rangeEnd / 100) * 100;\n var isPreviousCentury = twoDigitYear >= rangeEnd % 100;\n result = twoDigitYear + rangeEndCentury - (isPreviousCentury ? 100 : 0);\n }\n\n return isCommonEra ? result : 1 - result;\n}\n\nvar DAYS_IN_MONTH = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\nvar DAYS_IN_MONTH_LEAP_YEAR = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]; // User for validation\n\nfunction isLeapYearIndex(year) {\n return year % 400 === 0 || year % 4 === 0 && year % 100 !== 0;\n}\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | Milliseconds in day |\n * | b | AM, PM, noon, midnight | B | Flexible day period |\n * | c | Stand-alone local day of week | C* | Localized hour w/ day period |\n * | d | Day of month | D | Day of year |\n * | e | Local day of week | E | Day of week |\n * | f | | F* | Day of week in month |\n * | g* | Modified Julian day | G | Era |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | i! | ISO day of week | I! | ISO week of year |\n * | j* | Localized hour w/ day period | J* | Localized hour w/o day period |\n * | k | Hour [1-24] | K | Hour [0-11] |\n * | l* | (deprecated) | L | Stand-alone month |\n * | m | Minute | M | Month |\n * | n | | N | |\n * | o! | Ordinal number modifier | O* | Timezone (GMT) |\n * | p | | P | |\n * | q | Stand-alone quarter | Q | Quarter |\n * | r* | Related Gregorian year | R! | ISO week-numbering year |\n * | s | Second | S | Fraction of second |\n * | t! | Seconds timestamp | T! | Milliseconds timestamp |\n * | u | Extended year | U* | Cyclic year |\n * | v* | Timezone (generic non-locat.) | V* | Timezone (location) |\n * | w | Local week of year | W* | Week of month |\n * | x | Timezone (ISO-8601 w/o Z) | X | Timezone (ISO-8601) |\n * | y | Year (abs) | Y | Local week-numbering year |\n * | z* | Timezone (specific non-locat.) | Z* | Timezone (aliases) |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n *\n * Letters marked by ! are non-standard, but implemented by date-fns:\n * - `o` modifies the previous token to turn it into an ordinal (see `parse` docs)\n * - `i` is ISO day of week. For `i` and `ii` is returns numeric ISO week days,\n * i.e. 7 for Sunday, 1 for Monday, etc.\n * - `I` is ISO week of year, as opposed to `w` which is local week of year.\n * - `R` is ISO week-numbering year, as opposed to `Y` which is local week-numbering year.\n * `R` is supposed to be used in conjunction with `I` and `i`\n * for universal ISO week-numbering date, whereas\n * `Y` is supposed to be used in conjunction with `w` and `e`\n * for week-numbering date specific to the locale.\n */\n\n\nvar parsers = {\n // Era\n G: {\n priority: 140,\n parse: function (string, token, match, _options) {\n switch (token) {\n // AD, BC\n case 'G':\n case 'GG':\n case 'GGG':\n return match.era(string, {\n width: 'abbreviated'\n }) || match.era(string, {\n width: 'narrow'\n });\n // A, B\n\n case 'GGGGG':\n return match.era(string, {\n width: 'narrow'\n });\n // Anno Domini, Before Christ\n\n case 'GGGG':\n default:\n return match.era(string, {\n width: 'wide'\n }) || match.era(string, {\n width: 'abbreviated'\n }) || match.era(string, {\n width: 'narrow'\n });\n }\n },\n set: function (date, flags, value, _options) {\n flags.era = value;\n date.setUTCFullYear(value, 0, 1);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['R', 'u', 't', 'T']\n },\n // Year\n y: {\n // From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_Patterns\n // | Year | y | yy | yyy | yyyy | yyyyy |\n // |----------|-------|----|-------|-------|-------|\n // | AD 1 | 1 | 01 | 001 | 0001 | 00001 |\n // | AD 12 | 12 | 12 | 012 | 0012 | 00012 |\n // | AD 123 | 123 | 23 | 123 | 0123 | 00123 |\n // | AD 1234 | 1234 | 34 | 1234 | 1234 | 01234 |\n // | AD 12345 | 12345 | 45 | 12345 | 12345 | 12345 |\n priority: 130,\n parse: function (string, token, match, _options) {\n var valueCallback = function (year) {\n return {\n year: year,\n isTwoDigitYear: token === 'yy'\n };\n };\n\n switch (token) {\n case 'y':\n return parseNDigits(4, string, valueCallback);\n\n case 'yo':\n return match.ordinalNumber(string, {\n unit: 'year',\n valueCallback: valueCallback\n });\n\n default:\n return parseNDigits(token.length, string, valueCallback);\n }\n },\n validate: function (_date, value, _options) {\n return value.isTwoDigitYear || value.year > 0;\n },\n set: function (date, flags, value, _options) {\n var currentYear = date.getUTCFullYear();\n\n if (value.isTwoDigitYear) {\n var normalizedTwoDigitYear = normalizeTwoDigitYear(value.year, currentYear);\n date.setUTCFullYear(normalizedTwoDigitYear, 0, 1);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n }\n\n var year = !('era' in flags) || flags.era === 1 ? value.year : 1 - value.year;\n date.setUTCFullYear(year, 0, 1);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['Y', 'R', 'u', 'w', 'I', 'i', 'e', 'c', 't', 'T']\n },\n // Local week-numbering year\n Y: {\n priority: 130,\n parse: function (string, token, match, _options) {\n var valueCallback = function (year) {\n return {\n year: year,\n isTwoDigitYear: token === 'YY'\n };\n };\n\n switch (token) {\n case 'Y':\n return parseNDigits(4, string, valueCallback);\n\n case 'Yo':\n return match.ordinalNumber(string, {\n unit: 'year',\n valueCallback: valueCallback\n });\n\n default:\n return parseNDigits(token.length, string, valueCallback);\n }\n },\n validate: function (_date, value, _options) {\n return value.isTwoDigitYear || value.year > 0;\n },\n set: function (date, flags, value, options) {\n var currentYear = getUTCWeekYear(date, options);\n\n if (value.isTwoDigitYear) {\n var normalizedTwoDigitYear = normalizeTwoDigitYear(value.year, currentYear);\n date.setUTCFullYear(normalizedTwoDigitYear, 0, options.firstWeekContainsDate);\n date.setUTCHours(0, 0, 0, 0);\n return startOfUTCWeek(date, options);\n }\n\n var year = !('era' in flags) || flags.era === 1 ? value.year : 1 - value.year;\n date.setUTCFullYear(year, 0, options.firstWeekContainsDate);\n date.setUTCHours(0, 0, 0, 0);\n return startOfUTCWeek(date, options);\n },\n incompatibleTokens: ['y', 'R', 'u', 'Q', 'q', 'M', 'L', 'I', 'd', 'D', 'i', 't', 'T']\n },\n // ISO week-numbering year\n R: {\n priority: 130,\n parse: function (string, token, _match, _options) {\n if (token === 'R') {\n return parseNDigitsSigned(4, string);\n }\n\n return parseNDigitsSigned(token.length, string);\n },\n set: function (_date, _flags, value, _options) {\n var firstWeekOfYear = new Date(0);\n firstWeekOfYear.setUTCFullYear(value, 0, 4);\n firstWeekOfYear.setUTCHours(0, 0, 0, 0);\n return startOfUTCISOWeek(firstWeekOfYear);\n },\n incompatibleTokens: ['G', 'y', 'Y', 'u', 'Q', 'q', 'M', 'L', 'w', 'd', 'D', 'e', 'c', 't', 'T']\n },\n // Extended year\n u: {\n priority: 130,\n parse: function (string, token, _match, _options) {\n if (token === 'u') {\n return parseNDigitsSigned(4, string);\n }\n\n return parseNDigitsSigned(token.length, string);\n },\n set: function (date, _flags, value, _options) {\n date.setUTCFullYear(value, 0, 1);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['G', 'y', 'Y', 'R', 'w', 'I', 'i', 'e', 'c', 't', 'T']\n },\n // Quarter\n Q: {\n priority: 120,\n parse: function (string, token, match, _options) {\n switch (token) {\n // 1, 2, 3, 4\n case 'Q':\n case 'QQ':\n // 01, 02, 03, 04\n return parseNDigits(token.length, string);\n // 1st, 2nd, 3rd, 4th\n\n case 'Qo':\n return match.ordinalNumber(string, {\n unit: 'quarter'\n });\n // Q1, Q2, Q3, Q4\n\n case 'QQQ':\n return match.quarter(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.quarter(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n\n case 'QQQQQ':\n return match.quarter(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // 1st quarter, 2nd quarter, ...\n\n case 'QQQQ':\n default:\n return match.quarter(string, {\n width: 'wide',\n context: 'formatting'\n }) || match.quarter(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.quarter(string, {\n width: 'narrow',\n context: 'formatting'\n });\n }\n },\n validate: function (_date, value, _options) {\n return value >= 1 && value <= 4;\n },\n set: function (date, _flags, value, _options) {\n date.setUTCMonth((value - 1) * 3, 1);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['Y', 'R', 'q', 'M', 'L', 'w', 'I', 'd', 'D', 'i', 'e', 'c', 't', 'T']\n },\n // Stand-alone quarter\n q: {\n priority: 120,\n parse: function (string, token, match, _options) {\n switch (token) {\n // 1, 2, 3, 4\n case 'q':\n case 'qq':\n // 01, 02, 03, 04\n return parseNDigits(token.length, string);\n // 1st, 2nd, 3rd, 4th\n\n case 'qo':\n return match.ordinalNumber(string, {\n unit: 'quarter'\n });\n // Q1, Q2, Q3, Q4\n\n case 'qqq':\n return match.quarter(string, {\n width: 'abbreviated',\n context: 'standalone'\n }) || match.quarter(string, {\n width: 'narrow',\n context: 'standalone'\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n\n case 'qqqqq':\n return match.quarter(string, {\n width: 'narrow',\n context: 'standalone'\n });\n // 1st quarter, 2nd quarter, ...\n\n case 'qqqq':\n default:\n return match.quarter(string, {\n width: 'wide',\n context: 'standalone'\n }) || match.quarter(string, {\n width: 'abbreviated',\n context: 'standalone'\n }) || match.quarter(string, {\n width: 'narrow',\n context: 'standalone'\n });\n }\n },\n validate: function (_date, value, _options) {\n return value >= 1 && value <= 4;\n },\n set: function (date, _flags, value, _options) {\n date.setUTCMonth((value - 1) * 3, 1);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['Y', 'R', 'Q', 'M', 'L', 'w', 'I', 'd', 'D', 'i', 'e', 'c', 't', 'T']\n },\n // Month\n M: {\n priority: 110,\n parse: function (string, token, match, _options) {\n var valueCallback = function (value) {\n return value - 1;\n };\n\n switch (token) {\n // 1, 2, ..., 12\n case 'M':\n return parseNumericPattern(numericPatterns.month, string, valueCallback);\n // 01, 02, ..., 12\n\n case 'MM':\n return parseNDigits(2, string, valueCallback);\n // 1st, 2nd, ..., 12th\n\n case 'Mo':\n return match.ordinalNumber(string, {\n unit: 'month',\n valueCallback: valueCallback\n });\n // Jan, Feb, ..., Dec\n\n case 'MMM':\n return match.month(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.month(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // J, F, ..., D\n\n case 'MMMMM':\n return match.month(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // January, February, ..., December\n\n case 'MMMM':\n default:\n return match.month(string, {\n width: 'wide',\n context: 'formatting'\n }) || match.month(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.month(string, {\n width: 'narrow',\n context: 'formatting'\n });\n }\n },\n validate: function (_date, value, _options) {\n return value >= 0 && value <= 11;\n },\n set: function (date, _flags, value, _options) {\n date.setUTCMonth(value, 1);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['Y', 'R', 'q', 'Q', 'L', 'w', 'I', 'D', 'i', 'e', 'c', 't', 'T']\n },\n // Stand-alone month\n L: {\n priority: 110,\n parse: function (string, token, match, _options) {\n var valueCallback = function (value) {\n return value - 1;\n };\n\n switch (token) {\n // 1, 2, ..., 12\n case 'L':\n return parseNumericPattern(numericPatterns.month, string, valueCallback);\n // 01, 02, ..., 12\n\n case 'LL':\n return parseNDigits(2, string, valueCallback);\n // 1st, 2nd, ..., 12th\n\n case 'Lo':\n return match.ordinalNumber(string, {\n unit: 'month',\n valueCallback: valueCallback\n });\n // Jan, Feb, ..., Dec\n\n case 'LLL':\n return match.month(string, {\n width: 'abbreviated',\n context: 'standalone'\n }) || match.month(string, {\n width: 'narrow',\n context: 'standalone'\n });\n // J, F, ..., D\n\n case 'LLLLL':\n return match.month(string, {\n width: 'narrow',\n context: 'standalone'\n });\n // January, February, ..., December\n\n case 'LLLL':\n default:\n return match.month(string, {\n width: 'wide',\n context: 'standalone'\n }) || match.month(string, {\n width: 'abbreviated',\n context: 'standalone'\n }) || match.month(string, {\n width: 'narrow',\n context: 'standalone'\n });\n }\n },\n validate: function (_date, value, _options) {\n return value >= 0 && value <= 11;\n },\n set: function (date, _flags, value, _options) {\n date.setUTCMonth(value, 1);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['Y', 'R', 'q', 'Q', 'M', 'w', 'I', 'D', 'i', 'e', 'c', 't', 'T']\n },\n // Local week of year\n w: {\n priority: 100,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'w':\n return parseNumericPattern(numericPatterns.week, string);\n\n case 'wo':\n return match.ordinalNumber(string, {\n unit: 'week'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (_date, value, _options) {\n return value >= 1 && value <= 53;\n },\n set: function (date, _flags, value, options) {\n return startOfUTCWeek(setUTCWeek(date, value, options), options);\n },\n incompatibleTokens: ['y', 'R', 'u', 'q', 'Q', 'M', 'L', 'I', 'd', 'D', 'i', 't', 'T']\n },\n // ISO week of year\n I: {\n priority: 100,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'I':\n return parseNumericPattern(numericPatterns.week, string);\n\n case 'Io':\n return match.ordinalNumber(string, {\n unit: 'week'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (_date, value, _options) {\n return value >= 1 && value <= 53;\n },\n set: function (date, _flags, value, options) {\n return startOfUTCISOWeek(setUTCISOWeek(date, value, options), options);\n },\n incompatibleTokens: ['y', 'Y', 'u', 'q', 'Q', 'M', 'L', 'w', 'd', 'D', 'e', 'c', 't', 'T']\n },\n // Day of the month\n d: {\n priority: 90,\n subPriority: 1,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'd':\n return parseNumericPattern(numericPatterns.date, string);\n\n case 'do':\n return match.ordinalNumber(string, {\n unit: 'date'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (date, value, _options) {\n var year = date.getUTCFullYear();\n var isLeapYear = isLeapYearIndex(year);\n var month = date.getUTCMonth();\n\n if (isLeapYear) {\n return value >= 1 && value <= DAYS_IN_MONTH_LEAP_YEAR[month];\n } else {\n return value >= 1 && value <= DAYS_IN_MONTH[month];\n }\n },\n set: function (date, _flags, value, _options) {\n date.setUTCDate(value);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['Y', 'R', 'q', 'Q', 'w', 'I', 'D', 'i', 'e', 'c', 't', 'T']\n },\n // Day of year\n D: {\n priority: 90,\n subPriority: 1,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'D':\n case 'DD':\n return parseNumericPattern(numericPatterns.dayOfYear, string);\n\n case 'Do':\n return match.ordinalNumber(string, {\n unit: 'date'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (date, value, _options) {\n var year = date.getUTCFullYear();\n var isLeapYear = isLeapYearIndex(year);\n\n if (isLeapYear) {\n return value >= 1 && value <= 366;\n } else {\n return value >= 1 && value <= 365;\n }\n },\n set: function (date, _flags, value, _options) {\n date.setUTCMonth(0, value);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['Y', 'R', 'q', 'Q', 'M', 'L', 'w', 'I', 'd', 'E', 'i', 'e', 'c', 't', 'T']\n },\n // Day of week\n E: {\n priority: 90,\n parse: function (string, token, match, _options) {\n switch (token) {\n // Tue\n case 'E':\n case 'EE':\n case 'EEE':\n return match.day(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.day(string, {\n width: 'short',\n context: 'formatting'\n }) || match.day(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // T\n\n case 'EEEEE':\n return match.day(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // Tu\n\n case 'EEEEEE':\n return match.day(string, {\n width: 'short',\n context: 'formatting'\n }) || match.day(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // Tuesday\n\n case 'EEEE':\n default:\n return match.day(string, {\n width: 'wide',\n context: 'formatting'\n }) || match.day(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.day(string, {\n width: 'short',\n context: 'formatting'\n }) || match.day(string, {\n width: 'narrow',\n context: 'formatting'\n });\n }\n },\n validate: function (_date, value, _options) {\n return value >= 0 && value <= 6;\n },\n set: function (date, _flags, value, options) {\n date = setUTCDay(date, value, options);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['D', 'i', 'e', 'c', 't', 'T']\n },\n // Local day of week\n e: {\n priority: 90,\n parse: function (string, token, match, options) {\n var valueCallback = function (value) {\n var wholeWeekDays = Math.floor((value - 1) / 7) * 7;\n return (value + options.weekStartsOn + 6) % 7 + wholeWeekDays;\n };\n\n switch (token) {\n // 3\n case 'e':\n case 'ee':\n // 03\n return parseNDigits(token.length, string, valueCallback);\n // 3rd\n\n case 'eo':\n return match.ordinalNumber(string, {\n unit: 'day',\n valueCallback: valueCallback\n });\n // Tue\n\n case 'eee':\n return match.day(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.day(string, {\n width: 'short',\n context: 'formatting'\n }) || match.day(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // T\n\n case 'eeeee':\n return match.day(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // Tu\n\n case 'eeeeee':\n return match.day(string, {\n width: 'short',\n context: 'formatting'\n }) || match.day(string, {\n width: 'narrow',\n context: 'formatting'\n });\n // Tuesday\n\n case 'eeee':\n default:\n return match.day(string, {\n width: 'wide',\n context: 'formatting'\n }) || match.day(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.day(string, {\n width: 'short',\n context: 'formatting'\n }) || match.day(string, {\n width: 'narrow',\n context: 'formatting'\n });\n }\n },\n validate: function (_date, value, _options) {\n return value >= 0 && value <= 6;\n },\n set: function (date, _flags, value, options) {\n date = setUTCDay(date, value, options);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['y', 'R', 'u', 'q', 'Q', 'M', 'L', 'I', 'd', 'D', 'E', 'i', 'c', 't', 'T']\n },\n // Stand-alone local day of week\n c: {\n priority: 90,\n parse: function (string, token, match, options) {\n var valueCallback = function (value) {\n var wholeWeekDays = Math.floor((value - 1) / 7) * 7;\n return (value + options.weekStartsOn + 6) % 7 + wholeWeekDays;\n };\n\n switch (token) {\n // 3\n case 'c':\n case 'cc':\n // 03\n return parseNDigits(token.length, string, valueCallback);\n // 3rd\n\n case 'co':\n return match.ordinalNumber(string, {\n unit: 'day',\n valueCallback: valueCallback\n });\n // Tue\n\n case 'ccc':\n return match.day(string, {\n width: 'abbreviated',\n context: 'standalone'\n }) || match.day(string, {\n width: 'short',\n context: 'standalone'\n }) || match.day(string, {\n width: 'narrow',\n context: 'standalone'\n });\n // T\n\n case 'ccccc':\n return match.day(string, {\n width: 'narrow',\n context: 'standalone'\n });\n // Tu\n\n case 'cccccc':\n return match.day(string, {\n width: 'short',\n context: 'standalone'\n }) || match.day(string, {\n width: 'narrow',\n context: 'standalone'\n });\n // Tuesday\n\n case 'cccc':\n default:\n return match.day(string, {\n width: 'wide',\n context: 'standalone'\n }) || match.day(string, {\n width: 'abbreviated',\n context: 'standalone'\n }) || match.day(string, {\n width: 'short',\n context: 'standalone'\n }) || match.day(string, {\n width: 'narrow',\n context: 'standalone'\n });\n }\n },\n validate: function (_date, value, _options) {\n return value >= 0 && value <= 6;\n },\n set: function (date, _flags, value, options) {\n date = setUTCDay(date, value, options);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['y', 'R', 'u', 'q', 'Q', 'M', 'L', 'I', 'd', 'D', 'E', 'i', 'e', 't', 'T']\n },\n // ISO day of week\n i: {\n priority: 90,\n parse: function (string, token, match, _options) {\n var valueCallback = function (value) {\n if (value === 0) {\n return 7;\n }\n\n return value;\n };\n\n switch (token) {\n // 2\n case 'i':\n case 'ii':\n // 02\n return parseNDigits(token.length, string);\n // 2nd\n\n case 'io':\n return match.ordinalNumber(string, {\n unit: 'day'\n });\n // Tue\n\n case 'iii':\n return match.day(string, {\n width: 'abbreviated',\n context: 'formatting',\n valueCallback: valueCallback\n }) || match.day(string, {\n width: 'short',\n context: 'formatting',\n valueCallback: valueCallback\n }) || match.day(string, {\n width: 'narrow',\n context: 'formatting',\n valueCallback: valueCallback\n });\n // T\n\n case 'iiiii':\n return match.day(string, {\n width: 'narrow',\n context: 'formatting',\n valueCallback: valueCallback\n });\n // Tu\n\n case 'iiiiii':\n return match.day(string, {\n width: 'short',\n context: 'formatting',\n valueCallback: valueCallback\n }) || match.day(string, {\n width: 'narrow',\n context: 'formatting',\n valueCallback: valueCallback\n });\n // Tuesday\n\n case 'iiii':\n default:\n return match.day(string, {\n width: 'wide',\n context: 'formatting',\n valueCallback: valueCallback\n }) || match.day(string, {\n width: 'abbreviated',\n context: 'formatting',\n valueCallback: valueCallback\n }) || match.day(string, {\n width: 'short',\n context: 'formatting',\n valueCallback: valueCallback\n }) || match.day(string, {\n width: 'narrow',\n context: 'formatting',\n valueCallback: valueCallback\n });\n }\n },\n validate: function (_date, value, _options) {\n return value >= 1 && value <= 7;\n },\n set: function (date, _flags, value, options) {\n date = setUTCISODay(date, value, options);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['y', 'Y', 'u', 'q', 'Q', 'M', 'L', 'w', 'd', 'D', 'E', 'e', 'c', 't', 'T']\n },\n // AM or PM\n a: {\n priority: 80,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'a':\n case 'aa':\n case 'aaa':\n return match.dayPeriod(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.dayPeriod(string, {\n width: 'narrow',\n context: 'formatting'\n });\n\n case 'aaaaa':\n return match.dayPeriod(string, {\n width: 'narrow',\n context: 'formatting'\n });\n\n case 'aaaa':\n default:\n return match.dayPeriod(string, {\n width: 'wide',\n context: 'formatting'\n }) || match.dayPeriod(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.dayPeriod(string, {\n width: 'narrow',\n context: 'formatting'\n });\n }\n },\n set: function (date, _flags, value, _options) {\n date.setUTCHours(dayPeriodEnumToHours(value), 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['b', 'B', 'H', 'k', 't', 'T']\n },\n // AM, PM, midnight\n b: {\n priority: 80,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'b':\n case 'bb':\n case 'bbb':\n return match.dayPeriod(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.dayPeriod(string, {\n width: 'narrow',\n context: 'formatting'\n });\n\n case 'bbbbb':\n return match.dayPeriod(string, {\n width: 'narrow',\n context: 'formatting'\n });\n\n case 'bbbb':\n default:\n return match.dayPeriod(string, {\n width: 'wide',\n context: 'formatting'\n }) || match.dayPeriod(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.dayPeriod(string, {\n width: 'narrow',\n context: 'formatting'\n });\n }\n },\n set: function (date, _flags, value, _options) {\n date.setUTCHours(dayPeriodEnumToHours(value), 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['a', 'B', 'H', 'k', 't', 'T']\n },\n // in the morning, in the afternoon, in the evening, at night\n B: {\n priority: 80,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'B':\n case 'BB':\n case 'BBB':\n return match.dayPeriod(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.dayPeriod(string, {\n width: 'narrow',\n context: 'formatting'\n });\n\n case 'BBBBB':\n return match.dayPeriod(string, {\n width: 'narrow',\n context: 'formatting'\n });\n\n case 'BBBB':\n default:\n return match.dayPeriod(string, {\n width: 'wide',\n context: 'formatting'\n }) || match.dayPeriod(string, {\n width: 'abbreviated',\n context: 'formatting'\n }) || match.dayPeriod(string, {\n width: 'narrow',\n context: 'formatting'\n });\n }\n },\n set: function (date, _flags, value, _options) {\n date.setUTCHours(dayPeriodEnumToHours(value), 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['a', 'b', 't', 'T']\n },\n // Hour [1-12]\n h: {\n priority: 70,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'h':\n return parseNumericPattern(numericPatterns.hour12h, string);\n\n case 'ho':\n return match.ordinalNumber(string, {\n unit: 'hour'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (_date, value, _options) {\n return value >= 1 && value <= 12;\n },\n set: function (date, _flags, value, _options) {\n var isPM = date.getUTCHours() >= 12;\n\n if (isPM && value < 12) {\n date.setUTCHours(value + 12, 0, 0, 0);\n } else if (!isPM && value === 12) {\n date.setUTCHours(0, 0, 0, 0);\n } else {\n date.setUTCHours(value, 0, 0, 0);\n }\n\n return date;\n },\n incompatibleTokens: ['H', 'K', 'k', 't', 'T']\n },\n // Hour [0-23]\n H: {\n priority: 70,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'H':\n return parseNumericPattern(numericPatterns.hour23h, string);\n\n case 'Ho':\n return match.ordinalNumber(string, {\n unit: 'hour'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (_date, value, _options) {\n return value >= 0 && value <= 23;\n },\n set: function (date, _flags, value, _options) {\n date.setUTCHours(value, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['a', 'b', 'h', 'K', 'k', 't', 'T']\n },\n // Hour [0-11]\n K: {\n priority: 70,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'K':\n return parseNumericPattern(numericPatterns.hour11h, string);\n\n case 'Ko':\n return match.ordinalNumber(string, {\n unit: 'hour'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (_date, value, _options) {\n return value >= 0 && value <= 11;\n },\n set: function (date, _flags, value, _options) {\n var isPM = date.getUTCHours() >= 12;\n\n if (isPM && value < 12) {\n date.setUTCHours(value + 12, 0, 0, 0);\n } else {\n date.setUTCHours(value, 0, 0, 0);\n }\n\n return date;\n },\n incompatibleTokens: ['h', 'H', 'k', 't', 'T']\n },\n // Hour [1-24]\n k: {\n priority: 70,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'k':\n return parseNumericPattern(numericPatterns.hour24h, string);\n\n case 'ko':\n return match.ordinalNumber(string, {\n unit: 'hour'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (_date, value, _options) {\n return value >= 1 && value <= 24;\n },\n set: function (date, _flags, value, _options) {\n var hours = value <= 24 ? value % 24 : value;\n date.setUTCHours(hours, 0, 0, 0);\n return date;\n },\n incompatibleTokens: ['a', 'b', 'h', 'H', 'K', 't', 'T']\n },\n // Minute\n m: {\n priority: 60,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 'm':\n return parseNumericPattern(numericPatterns.minute, string);\n\n case 'mo':\n return match.ordinalNumber(string, {\n unit: 'minute'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (_date, value, _options) {\n return value >= 0 && value <= 59;\n },\n set: function (date, _flags, value, _options) {\n date.setUTCMinutes(value, 0, 0);\n return date;\n },\n incompatibleTokens: ['t', 'T']\n },\n // Second\n s: {\n priority: 50,\n parse: function (string, token, match, _options) {\n switch (token) {\n case 's':\n return parseNumericPattern(numericPatterns.second, string);\n\n case 'so':\n return match.ordinalNumber(string, {\n unit: 'second'\n });\n\n default:\n return parseNDigits(token.length, string);\n }\n },\n validate: function (_date, value, _options) {\n return value >= 0 && value <= 59;\n },\n set: function (date, _flags, value, _options) {\n date.setUTCSeconds(value, 0);\n return date;\n },\n incompatibleTokens: ['t', 'T']\n },\n // Fraction of second\n S: {\n priority: 30,\n parse: function (string, token, _match, _options) {\n var valueCallback = function (value) {\n return Math.floor(value * Math.pow(10, -token.length + 3));\n };\n\n return parseNDigits(token.length, string, valueCallback);\n },\n set: function (date, _flags, value, _options) {\n date.setUTCMilliseconds(value);\n return date;\n },\n incompatibleTokens: ['t', 'T']\n },\n // Timezone (ISO-8601. +00:00 is `'Z'`)\n X: {\n priority: 10,\n parse: function (string, token, _match, _options) {\n switch (token) {\n case 'X':\n return parseTimezonePattern(timezonePatterns.basicOptionalMinutes, string);\n\n case 'XX':\n return parseTimezonePattern(timezonePatterns.basic, string);\n\n case 'XXXX':\n return parseTimezonePattern(timezonePatterns.basicOptionalSeconds, string);\n\n case 'XXXXX':\n return parseTimezonePattern(timezonePatterns.extendedOptionalSeconds, string);\n\n case 'XXX':\n default:\n return parseTimezonePattern(timezonePatterns.extended, string);\n }\n },\n set: function (date, flags, value, _options) {\n if (flags.timestampIsSet) {\n return date;\n }\n\n return new Date(date.getTime() - value);\n },\n incompatibleTokens: ['t', 'T', 'x']\n },\n // Timezone (ISO-8601)\n x: {\n priority: 10,\n parse: function (string, token, _match, _options) {\n switch (token) {\n case 'x':\n return parseTimezonePattern(timezonePatterns.basicOptionalMinutes, string);\n\n case 'xx':\n return parseTimezonePattern(timezonePatterns.basic, string);\n\n case 'xxxx':\n return parseTimezonePattern(timezonePatterns.basicOptionalSeconds, string);\n\n case 'xxxxx':\n return parseTimezonePattern(timezonePatterns.extendedOptionalSeconds, string);\n\n case 'xxx':\n default:\n return parseTimezonePattern(timezonePatterns.extended, string);\n }\n },\n set: function (date, flags, value, _options) {\n if (flags.timestampIsSet) {\n return date;\n }\n\n return new Date(date.getTime() - value);\n },\n incompatibleTokens: ['t', 'T', 'X']\n },\n // Seconds timestamp\n t: {\n priority: 40,\n parse: function (string, _token, _match, _options) {\n return parseAnyDigitsSigned(string);\n },\n set: function (_date, _flags, value, _options) {\n return [new Date(value * 1000), {\n timestampIsSet: true\n }];\n },\n incompatibleTokens: '*'\n },\n // Milliseconds timestamp\n T: {\n priority: 20,\n parse: function (string, _token, _match, _options) {\n return parseAnyDigitsSigned(string);\n },\n set: function (_date, _flags, value, _options) {\n return [new Date(value), {\n timestampIsSet: true\n }];\n },\n incompatibleTokens: '*'\n }\n};\nexport default parsers;","import defaultLocale from \"../locale/en-US/index.js\";\nimport subMilliseconds from \"../subMilliseconds/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport assign from \"../_lib/assign/index.js\";\nimport longFormatters from \"../_lib/format/longFormatters/index.js\";\nimport getTimezoneOffsetInMilliseconds from \"../_lib/getTimezoneOffsetInMilliseconds/index.js\";\nimport { isProtectedDayOfYearToken, isProtectedWeekYearToken, throwProtectedError } from \"../_lib/protectedTokens/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\nimport parsers from \"./_lib/parsers/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\nvar TIMEZONE_UNIT_PRIORITY = 10; // 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\n\nvar formattingTokensRegExp = /[yYQqMLwIdDecihHKkms]o|(\\w)\\1*|''|'(''|[^'])+('|$)|./g; // This RegExp catches symbols escaped by quotes, and also\n// sequences of symbols P, p, and the combinations like `PPPPPPPppppp`\n\nvar longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;\nvar escapedStringRegExp = /^'([^]*?)'?$/;\nvar doubleQuoteRegExp = /''/g;\nvar notWhitespaceRegExp = /\\S/;\nvar unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n/**\n * @name parse\n * @category Common Helpers\n * @summary Parse the date.\n *\n * @description\n * Return the date parsed from string using the given format string.\n *\n * > ⚠️ Please note that the `format` tokens differ from Moment.js and other libraries.\n * > See: https://git.io/fxCyr\n *\n * The characters in the format string wrapped between two single quotes characters (') are escaped.\n * Two single quotes in a row, whether inside or outside a quoted sequence, represent a 'real' single quote.\n *\n * Format of the format string is based on Unicode Technical Standard #35:\n * https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table\n * with a few additions (see note 5 below the table).\n *\n * Not all tokens are compatible. Combinations that don't make sense or could lead to bugs are prohibited\n * and will throw `RangeError`. For example usage of 24-hour format token with AM/PM token will throw an exception:\n *\n * ```javascript\n * parse('23 AM', 'HH a', new Date())\n * //=> RangeError: The format string mustn't contain `HH` and `a` at the same time\n * ```\n *\n * See the compatibility table: https://docs.google.com/spreadsheets/d/e/2PACX-1vQOPU3xUhplll6dyoMmVUXHKl_8CRDs6_ueLmex3SoqwhuolkuN3O05l4rqx5h1dKX8eb46Ul-CCSrq/pubhtml?gid=0&single=true\n *\n * Accepted format string patterns:\n * | Unit |Prior| Pattern | Result examples | Notes |\n * |---------------------------------|-----|---------|-----------------------------------|-------|\n * | Era | 140 | G..GGG | AD, BC | |\n * | | | GGGG | Anno Domini, Before Christ | 2 |\n * | | | GGGGG | A, B | |\n * | Calendar year | 130 | y | 44, 1, 1900, 2017, 9999 | 4 |\n * | | | yo | 44th, 1st, 1900th, 9999999th | 4,5 |\n * | | | yy | 44, 01, 00, 17 | 4 |\n * | | | yyy | 044, 001, 123, 999 | 4 |\n * | | | yyyy | 0044, 0001, 1900, 2017 | 4 |\n * | | | yyyyy | ... | 2,4 |\n * | Local week-numbering year | 130 | Y | 44, 1, 1900, 2017, 9000 | 4 |\n * | | | Yo | 44th, 1st, 1900th, 9999999th | 4,5 |\n * | | | YY | 44, 01, 00, 17 | 4,6 |\n * | | | YYY | 044, 001, 123, 999 | 4 |\n * | | | YYYY | 0044, 0001, 1900, 2017 | 4,6 |\n * | | | YYYYY | ... | 2,4 |\n * | ISO week-numbering year | 130 | R | -43, 1, 1900, 2017, 9999, -9999 | 4,5 |\n * | | | RR | -43, 01, 00, 17 | 4,5 |\n * | | | RRR | -043, 001, 123, 999, -999 | 4,5 |\n * | | | RRRR | -0043, 0001, 2017, 9999, -9999 | 4,5 |\n * | | | RRRRR | ... | 2,4,5 |\n * | Extended year | 130 | u | -43, 1, 1900, 2017, 9999, -999 | 4 |\n * | | | uu | -43, 01, 99, -99 | 4 |\n * | | | uuu | -043, 001, 123, 999, -999 | 4 |\n * | | | uuuu | -0043, 0001, 2017, 9999, -9999 | 4 |\n * | | | uuuuu | ... | 2,4 |\n * | Quarter (formatting) | 120 | Q | 1, 2, 3, 4 | |\n * | | | Qo | 1st, 2nd, 3rd, 4th | 5 |\n * | | | QQ | 01, 02, 03, 04 | |\n * | | | QQQ | Q1, Q2, Q3, Q4 | |\n * | | | QQQQ | 1st quarter, 2nd quarter, ... | 2 |\n * | | | QQQQQ | 1, 2, 3, 4 | 4 |\n * | Quarter (stand-alone) | 120 | q | 1, 2, 3, 4 | |\n * | | | qo | 1st, 2nd, 3rd, 4th | 5 |\n * | | | qq | 01, 02, 03, 04 | |\n * | | | qqq | Q1, Q2, Q3, Q4 | |\n * | | | qqqq | 1st quarter, 2nd quarter, ... | 2 |\n * | | | qqqqq | 1, 2, 3, 4 | 3 |\n * | Month (formatting) | 110 | M | 1, 2, ..., 12 | |\n * | | | Mo | 1st, 2nd, ..., 12th | 5 |\n * | | | MM | 01, 02, ..., 12 | |\n * | | | MMM | Jan, Feb, ..., Dec | |\n * | | | MMMM | January, February, ..., December | 2 |\n * | | | MMMMM | J, F, ..., D | |\n * | Month (stand-alone) | 110 | L | 1, 2, ..., 12 | |\n * | | | Lo | 1st, 2nd, ..., 12th | 5 |\n * | | | LL | 01, 02, ..., 12 | |\n * | | | LLL | Jan, Feb, ..., Dec | |\n * | | | LLLL | January, February, ..., December | 2 |\n * | | | LLLLL | J, F, ..., D | |\n * | Local week of year | 100 | w | 1, 2, ..., 53 | |\n * | | | wo | 1st, 2nd, ..., 53th | 5 |\n * | | | ww | 01, 02, ..., 53 | |\n * | ISO week of year | 100 | I | 1, 2, ..., 53 | 5 |\n * | | | Io | 1st, 2nd, ..., 53th | 5 |\n * | | | II | 01, 02, ..., 53 | 5 |\n * | Day of month | 90 | d | 1, 2, ..., 31 | |\n * | | | do | 1st, 2nd, ..., 31st | 5 |\n * | | | dd | 01, 02, ..., 31 | |\n * | Day of year | 90 | D | 1, 2, ..., 365, 366 | 7 |\n * | | | Do | 1st, 2nd, ..., 365th, 366th | 5 |\n * | | | DD | 01, 02, ..., 365, 366 | 7 |\n * | | | DDD | 001, 002, ..., 365, 366 | |\n * | | | DDDD | ... | 2 |\n * | Day of week (formatting) | 90 | E..EEE | Mon, Tue, Wed, ..., Sun | |\n * | | | EEEE | Monday, Tuesday, ..., Sunday | 2 |\n * | | | EEEEE | M, T, W, T, F, S, S | |\n * | | | EEEEEE | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | ISO day of week (formatting) | 90 | i | 1, 2, 3, ..., 7 | 5 |\n * | | | io | 1st, 2nd, ..., 7th | 5 |\n * | | | ii | 01, 02, ..., 07 | 5 |\n * | | | iii | Mon, Tue, Wed, ..., Sun | 5 |\n * | | | iiii | Monday, Tuesday, ..., Sunday | 2,5 |\n * | | | iiiii | M, T, W, T, F, S, S | 5 |\n * | | | iiiiii | Mo, Tu, We, Th, Fr, Sa, Su | 5 |\n * | Local day of week (formatting) | 90 | e | 2, 3, 4, ..., 1 | |\n * | | | eo | 2nd, 3rd, ..., 1st | 5 |\n * | | | ee | 02, 03, ..., 01 | |\n * | | | eee | Mon, Tue, Wed, ..., Sun | |\n * | | | eeee | Monday, Tuesday, ..., Sunday | 2 |\n * | | | eeeee | M, T, W, T, F, S, S | |\n * | | | eeeeee | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | Local day of week (stand-alone) | 90 | c | 2, 3, 4, ..., 1 | |\n * | | | co | 2nd, 3rd, ..., 1st | 5 |\n * | | | cc | 02, 03, ..., 01 | |\n * | | | ccc | Mon, Tue, Wed, ..., Sun | |\n * | | | cccc | Monday, Tuesday, ..., Sunday | 2 |\n * | | | ccccc | M, T, W, T, F, S, S | |\n * | | | cccccc | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | AM, PM | 80 | a..aaa | AM, PM | |\n * | | | aaaa | a.m., p.m. | 2 |\n * | | | aaaaa | a, p | |\n * | AM, PM, noon, midnight | 80 | b..bbb | AM, PM, noon, midnight | |\n * | | | bbbb | a.m., p.m., noon, midnight | 2 |\n * | | | bbbbb | a, p, n, mi | |\n * | Flexible day period | 80 | B..BBB | at night, in the morning, ... | |\n * | | | BBBB | at night, in the morning, ... | 2 |\n * | | | BBBBB | at night, in the morning, ... | |\n * | Hour [1-12] | 70 | h | 1, 2, ..., 11, 12 | |\n * | | | ho | 1st, 2nd, ..., 11th, 12th | 5 |\n * | | | hh | 01, 02, ..., 11, 12 | |\n * | Hour [0-23] | 70 | H | 0, 1, 2, ..., 23 | |\n * | | | Ho | 0th, 1st, 2nd, ..., 23rd | 5 |\n * | | | HH | 00, 01, 02, ..., 23 | |\n * | Hour [0-11] | 70 | K | 1, 2, ..., 11, 0 | |\n * | | | Ko | 1st, 2nd, ..., 11th, 0th | 5 |\n * | | | KK | 01, 02, ..., 11, 00 | |\n * | Hour [1-24] | 70 | k | 24, 1, 2, ..., 23 | |\n * | | | ko | 24th, 1st, 2nd, ..., 23rd | 5 |\n * | | | kk | 24, 01, 02, ..., 23 | |\n * | Minute | 60 | m | 0, 1, ..., 59 | |\n * | | | mo | 0th, 1st, ..., 59th | 5 |\n * | | | mm | 00, 01, ..., 59 | |\n * | Second | 50 | s | 0, 1, ..., 59 | |\n * | | | so | 0th, 1st, ..., 59th | 5 |\n * | | | ss | 00, 01, ..., 59 | |\n * | Seconds timestamp | 40 | t | 512969520 | |\n * | | | tt | ... | 2 |\n * | Fraction of second | 30 | S | 0, 1, ..., 9 | |\n * | | | SS | 00, 01, ..., 99 | |\n * | | | SSS | 000, 001, ..., 999 | |\n * | | | SSSS | ... | 2 |\n * | Milliseconds timestamp | 20 | T | 512969520900 | |\n * | | | TT | ... | 2 |\n * | Timezone (ISO-8601 w/ Z) | 10 | X | -08, +0530, Z | |\n * | | | XX | -0800, +0530, Z | |\n * | | | XXX | -08:00, +05:30, Z | |\n * | | | XXXX | -0800, +0530, Z, +123456 | 2 |\n * | | | XXXXX | -08:00, +05:30, Z, +12:34:56 | |\n * | Timezone (ISO-8601 w/o Z) | 10 | x | -08, +0530, +00 | |\n * | | | xx | -0800, +0530, +0000 | |\n * | | | xxx | -08:00, +05:30, +00:00 | 2 |\n * | | | xxxx | -0800, +0530, +0000, +123456 | |\n * | | | xxxxx | -08:00, +05:30, +00:00, +12:34:56 | |\n * | Long localized date | NA | P | 05/29/1453 | 5,8 |\n * | | | PP | May 29, 1453 | |\n * | | | PPP | May 29th, 1453 | |\n * | | | PPPP | Sunday, May 29th, 1453 | 2,5,8 |\n * | Long localized time | NA | p | 12:00 AM | 5,8 |\n * | | | pp | 12:00:00 AM | |\n * | Combination of date and time | NA | Pp | 05/29/1453, 12:00 AM | |\n * | | | PPpp | May 29, 1453, 12:00:00 AM | |\n * | | | PPPpp | May 29th, 1453 at ... | |\n * | | | PPPPpp | Sunday, May 29th, 1453 at ... | 2,5,8 |\n * Notes:\n * 1. \"Formatting\" units (e.g. formatting quarter) in the default en-US locale\n * are the same as \"stand-alone\" units, but are different in some languages.\n * \"Formatting\" units are declined according to the rules of the language\n * in the context of a date. \"Stand-alone\" units are always nominative singular.\n * In `format` function, they will produce different result:\n *\n * `format(new Date(2017, 10, 6), 'do LLLL', {locale: cs}) //=> '6. listopad'`\n *\n * `format(new Date(2017, 10, 6), 'do MMMM', {locale: cs}) //=> '6. listopadu'`\n *\n * `parse` will try to match both formatting and stand-alone units interchangably.\n *\n * 2. Any sequence of the identical letters is a pattern, unless it is escaped by\n * the single quote characters (see below).\n * If the sequence is longer than listed in table:\n * - for numerical units (`yyyyyyyy`) `parse` will try to match a number\n * as wide as the sequence\n * - for text units (`MMMMMMMM`) `parse` will try to match the widest variation of the unit.\n * These variations are marked with \"2\" in the last column of the table.\n *\n * 3. `QQQQQ` and `qqqqq` could be not strictly numerical in some locales.\n * These tokens represent the shortest form of the quarter.\n *\n * 4. The main difference between `y` and `u` patterns are B.C. years:\n *\n * | Year | `y` | `u` |\n * |------|-----|-----|\n * | AC 1 | 1 | 1 |\n * | BC 1 | 1 | 0 |\n * | BC 2 | 2 | -1 |\n *\n * Also `yy` will try to guess the century of two digit year by proximity with `referenceDate`:\n *\n * `parse('50', 'yy', new Date(2018, 0, 1)) //=> Sat Jan 01 2050 00:00:00`\n *\n * `parse('75', 'yy', new Date(2018, 0, 1)) //=> Wed Jan 01 1975 00:00:00`\n *\n * while `uu` will just assign the year as is:\n *\n * `parse('50', 'uu', new Date(2018, 0, 1)) //=> Sat Jan 01 0050 00:00:00`\n *\n * `parse('75', 'uu', new Date(2018, 0, 1)) //=> Tue Jan 01 0075 00:00:00`\n *\n * The same difference is true for local and ISO week-numbering years (`Y` and `R`),\n * except local week-numbering years are dependent on `options.weekStartsOn`\n * and `options.firstWeekContainsDate` (compare [setISOWeekYear]{@link https://date-fns.org/docs/setISOWeekYear}\n * and [setWeekYear]{@link https://date-fns.org/docs/setWeekYear}).\n *\n * 5. These patterns are not in the Unicode Technical Standard #35:\n * - `i`: ISO day of week\n * - `I`: ISO week of year\n * - `R`: ISO week-numbering year\n * - `o`: ordinal number modifier\n * - `P`: long localized date\n * - `p`: long localized time\n *\n * 6. `YY` and `YYYY` tokens represent week-numbering years but they are often confused with years.\n * You should enable `options.useAdditionalWeekYearTokens` to use them. See: https://git.io/fxCyr\n *\n * 7. `D` and `DD` tokens represent days of the year but they are ofthen confused with days of the month.\n * You should enable `options.useAdditionalDayOfYearTokens` to use them. See: https://git.io/fxCyr\n *\n * 8. `P+` tokens do not have a defined priority since they are merely aliases to other tokens based\n * on the given locale.\n *\n * using `en-US` locale: `P` => `MM/dd/yyyy`\n * using `en-US` locale: `p` => `hh:mm a`\n * using `pt-BR` locale: `P` => `dd/MM/yyyy`\n * using `pt-BR` locale: `p` => `HH:mm`\n *\n * Values will be assigned to the date in the descending order of its unit's priority.\n * Units of an equal priority overwrite each other in the order of appearance.\n *\n * If no values of higher priority are parsed (e.g. when parsing string 'January 1st' without a year),\n * the values will be taken from 3rd argument `referenceDate` which works as a context of parsing.\n *\n * `referenceDate` must be passed for correct work of the function.\n * If you're not sure which `referenceDate` to supply, create a new instance of Date:\n * `parse('02/11/2014', 'MM/dd/yyyy', new Date())`\n * In this case parsing will be done in the context of the current date.\n * If `referenceDate` is `Invalid Date` or a value not convertible to valid `Date`,\n * then `Invalid Date` will be returned.\n *\n * The result may vary by locale.\n *\n * If `formatString` matches with `dateString` but does not provides tokens, `referenceDate` will be returned.\n *\n * If parsing failed, `Invalid Date` will be returned.\n * Invalid Date is a Date, whose time value is NaN.\n * Time value of Date: http://es5.github.io/#x15.9.1.1\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * - Old `parse` was renamed to `toDate`.\n * Now `parse` is a new function which parses a string using a provided format.\n *\n * ```javascript\n * // Before v2.0.0\n * parse('2016-01-01')\n *\n * // v2.0.0 onward (toDate no longer accepts a string)\n * toDate(1392098430000) // Unix to timestamp\n * toDate(new Date(2014, 1, 11, 11, 30, 30)) // Cloning the date\n * parse('2016-01-01', 'yyyy-MM-dd', new Date())\n * ```\n *\n * @param {String} dateString - the string to parse\n * @param {String} formatString - the string of tokens\n * @param {Date|Number} referenceDate - defines values missing from the parsed dateString\n * @param {Object} [options] - an object with options.\n * @param {Locale} [options.locale=defaultLocale] - the locale object. See [Locale]{@link https://date-fns.org/docs/Locale}\n * @param {0|1|2|3|4|5|6} [options.weekStartsOn=0] - the index of the first day of the week (0 - Sunday)\n * @param {1|2|3|4|5|6|7} [options.firstWeekContainsDate=1] - the day of January, which is always in the first week of the year\n * @param {Boolean} [options.useAdditionalWeekYearTokens=false] - if true, allows usage of the week-numbering year tokens `YY` and `YYYY`;\n * see: https://git.io/fxCyr\n * @param {Boolean} [options.useAdditionalDayOfYearTokens=false] - if true, allows usage of the day of year tokens `D` and `DD`;\n * see: https://git.io/fxCyr\n * @returns {Date} the parsed date\n * @throws {TypeError} 3 arguments required\n * @throws {RangeError} `options.weekStartsOn` must be between 0 and 6\n * @throws {RangeError} `options.firstWeekContainsDate` must be between 1 and 7\n * @throws {RangeError} `options.locale` must contain `match` property\n * @throws {RangeError} use `yyyy` instead of `YYYY` for formatting years using [format provided] to the input [input provided]; see: https://git.io/fxCyr\n * @throws {RangeError} use `yy` instead of `YY` for formatting years using [format provided] to the input [input provided]; see: https://git.io/fxCyr\n * @throws {RangeError} use `d` instead of `D` for formatting days of the month using [format provided] to the input [input provided]; see: https://git.io/fxCyr\n * @throws {RangeError} use `dd` instead of `DD` for formatting days of the month using [format provided] to the input [input provided]; see: https://git.io/fxCyr\n * @throws {RangeError} format string contains an unescaped latin alphabet character\n *\n * @example\n * // Parse 11 February 2014 from middle-endian format:\n * var result = parse('02/11/2014', 'MM/dd/yyyy', new Date())\n * //=> Tue Feb 11 2014 00:00:00\n *\n * @example\n * // Parse 28th of February in Esperanto locale in the context of 2010 year:\n * import eo from 'date-fns/locale/eo'\n * var result = parse('28-a de februaro', \"do 'de' MMMM\", new Date(2010, 0, 1), {\n * locale: eo\n * })\n * //=> Sun Feb 28 2010 00:00:00\n */\n\nexport default function parse(dirtyDateString, dirtyFormatString, dirtyReferenceDate, dirtyOptions) {\n requiredArgs(3, arguments);\n var dateString = String(dirtyDateString);\n var formatString = String(dirtyFormatString);\n var options = dirtyOptions || {};\n var locale = options.locale || defaultLocale;\n\n if (!locale.match) {\n throw new RangeError('locale must contain match property');\n }\n\n var localeFirstWeekContainsDate = locale.options && locale.options.firstWeekContainsDate;\n var defaultFirstWeekContainsDate = localeFirstWeekContainsDate == null ? 1 : toInteger(localeFirstWeekContainsDate);\n var firstWeekContainsDate = options.firstWeekContainsDate == null ? defaultFirstWeekContainsDate : toInteger(options.firstWeekContainsDate); // Test if weekStartsOn is between 1 and 7 _and_ is not NaN\n\n if (!(firstWeekContainsDate >= 1 && firstWeekContainsDate <= 7)) {\n throw new RangeError('firstWeekContainsDate must be between 1 and 7 inclusively');\n }\n\n var localeWeekStartsOn = locale.options && locale.options.weekStartsOn;\n var defaultWeekStartsOn = localeWeekStartsOn == null ? 0 : toInteger(localeWeekStartsOn);\n var weekStartsOn = options.weekStartsOn == null ? defaultWeekStartsOn : toInteger(options.weekStartsOn); // Test if weekStartsOn is between 0 and 6 _and_ is not NaN\n\n if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {\n throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');\n }\n\n if (formatString === '') {\n if (dateString === '') {\n return toDate(dirtyReferenceDate);\n } else {\n return new Date(NaN);\n }\n }\n\n var subFnOptions = {\n firstWeekContainsDate: firstWeekContainsDate,\n weekStartsOn: weekStartsOn,\n locale: locale\n }; // If timezone isn't specified, it will be set to the system timezone\n\n var setters = [{\n priority: TIMEZONE_UNIT_PRIORITY,\n subPriority: -1,\n set: dateToSystemTimezone,\n index: 0\n }];\n var i;\n var tokens = formatString.match(longFormattingTokensRegExp).map(function (substring) {\n var firstCharacter = substring[0];\n\n if (firstCharacter === 'p' || firstCharacter === 'P') {\n var longFormatter = longFormatters[firstCharacter];\n return longFormatter(substring, locale.formatLong, subFnOptions);\n }\n\n return substring;\n }).join('').match(formattingTokensRegExp);\n var usedTokens = [];\n\n for (i = 0; i < tokens.length; i++) {\n var token = tokens[i];\n\n if (!options.useAdditionalWeekYearTokens && isProtectedWeekYearToken(token)) {\n throwProtectedError(token, formatString, dirtyDateString);\n }\n\n if (!options.useAdditionalDayOfYearTokens && isProtectedDayOfYearToken(token)) {\n throwProtectedError(token, formatString, dirtyDateString);\n }\n\n var firstCharacter = token[0];\n var parser = parsers[firstCharacter];\n\n if (parser) {\n var incompatibleTokens = parser.incompatibleTokens;\n\n if (Array.isArray(incompatibleTokens)) {\n var incompatibleToken = void 0;\n\n for (var _i = 0; _i < usedTokens.length; _i++) {\n var usedToken = usedTokens[_i].token;\n\n if (incompatibleTokens.indexOf(usedToken) !== -1 || usedToken === firstCharacter) {\n incompatibleToken = usedTokens[_i];\n break;\n }\n }\n\n if (incompatibleToken) {\n throw new RangeError(\"The format string mustn't contain `\".concat(incompatibleToken.fullToken, \"` and `\").concat(token, \"` at the same time\"));\n }\n } else if (parser.incompatibleTokens === '*' && usedTokens.length) {\n throw new RangeError(\"The format string mustn't contain `\".concat(token, \"` and any other token at the same time\"));\n }\n\n usedTokens.push({\n token: firstCharacter,\n fullToken: token\n });\n var parseResult = parser.parse(dateString, token, locale.match, subFnOptions);\n\n if (!parseResult) {\n return new Date(NaN);\n }\n\n setters.push({\n priority: parser.priority,\n subPriority: parser.subPriority || 0,\n set: parser.set,\n validate: parser.validate,\n value: parseResult.value,\n index: setters.length\n });\n dateString = parseResult.rest;\n } else {\n if (firstCharacter.match(unescapedLatinCharacterRegExp)) {\n throw new RangeError('Format string contains an unescaped latin alphabet character `' + firstCharacter + '`');\n } // Replace two single quote characters with one single quote character\n\n\n if (token === \"''\") {\n token = \"'\";\n } else if (firstCharacter === \"'\") {\n token = cleanEscapedString(token);\n } // Cut token from string, or, if string doesn't match the token, return Invalid Date\n\n\n if (dateString.indexOf(token) === 0) {\n dateString = dateString.slice(token.length);\n } else {\n return new Date(NaN);\n }\n }\n } // Check if the remaining input contains something other than whitespace\n\n\n if (dateString.length > 0 && notWhitespaceRegExp.test(dateString)) {\n return new Date(NaN);\n }\n\n var uniquePrioritySetters = setters.map(function (setter) {\n return setter.priority;\n }).sort(function (a, b) {\n return b - a;\n }).filter(function (priority, index, array) {\n return array.indexOf(priority) === index;\n }).map(function (priority) {\n return setters.filter(function (setter) {\n return setter.priority === priority;\n }).sort(function (a, b) {\n return b.subPriority - a.subPriority;\n });\n }).map(function (setterArray) {\n return setterArray[0];\n });\n var date = toDate(dirtyReferenceDate);\n\n if (isNaN(date)) {\n return new Date(NaN);\n } // Convert the date in system timezone to the same date in UTC+00:00 timezone.\n // This ensures that when UTC functions will be implemented, locales will be compatible with them.\n // See an issue about UTC functions: https://github.com/date-fns/date-fns/issues/37\n\n\n var utcDate = subMilliseconds(date, getTimezoneOffsetInMilliseconds(date));\n var flags = {};\n\n for (i = 0; i < uniquePrioritySetters.length; i++) {\n var setter = uniquePrioritySetters[i];\n\n if (setter.validate && !setter.validate(utcDate, setter.value, subFnOptions)) {\n return new Date(NaN);\n }\n\n var result = setter.set(utcDate, flags, setter.value, subFnOptions); // Result is tuple (date, flags)\n\n if (result[0]) {\n utcDate = result[0];\n assign(flags, result[1]); // Result is date\n } else {\n utcDate = result;\n }\n }\n\n return utcDate;\n}\n\nfunction dateToSystemTimezone(date, flags) {\n if (flags.timestampIsSet) {\n return date;\n }\n\n var convertedDate = new Date(0);\n convertedDate.setFullYear(date.getUTCFullYear(), date.getUTCMonth(), date.getUTCDate());\n convertedDate.setHours(date.getUTCHours(), date.getUTCMinutes(), date.getUTCSeconds(), date.getUTCMilliseconds());\n return convertedDate;\n}\n\nfunction cleanEscapedString(input) {\n return input.match(escapedStringRegExp)[1].replace(doubleQuoteRegExp, \"'\");\n}","import toDate from \"../toDate/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n\n/**\n * @name endOfWeek\n * @category Week Helpers\n * @summary Return the end of a week for the given date.\n *\n * @description\n * Return the end of a week for the given date.\n * The result will be in the local timezone.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the original date\n * @param {Object} [options] - an object with options.\n * @param {Locale} [options.locale=defaultLocale] - the locale object. See [Locale]{@link https://date-fns.org/docs/Locale}\n * @param {0|1|2|3|4|5|6} [options.weekStartsOn=0] - the index of the first day of the week (0 - Sunday)\n * @returns {Date} the end of a week\n * @throws {TypeError} 1 argument required\n * @throws {RangeError} `options.weekStartsOn` must be between 0 and 6\n *\n * @example\n * // The end of a week for 2 September 2014 11:55:00:\n * const result = endOfWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Sat Sep 06 2014 23:59:59.999\n *\n * @example\n * // If the week starts on Monday, the end of the week for 2 September 2014 11:55:00:\n * const result = endOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })\n * //=> Sun Sep 07 2014 23:59:59.999\n */\nexport default function endOfWeek(dirtyDate, dirtyOptions) {\n requiredArgs(1, arguments);\n var options = dirtyOptions || {};\n var locale = options.locale;\n var localeWeekStartsOn = locale && locale.options && locale.options.weekStartsOn;\n var defaultWeekStartsOn = localeWeekStartsOn == null ? 0 : toInteger(localeWeekStartsOn);\n var weekStartsOn = options.weekStartsOn == null ? defaultWeekStartsOn : toInteger(options.weekStartsOn); // Test if weekStartsOn is between 0 and 6 _and_ is not NaN\n\n if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {\n throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');\n }\n\n var date = toDate(dirtyDate);\n var day = date.getDay();\n var diff = (day < weekStartsOn ? -7 : 0) + 6 - (day - weekStartsOn);\n date.setDate(date.getDate() + diff);\n date.setHours(23, 59, 59, 999);\n return date;\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name setMilliseconds\n * @category Millisecond Helpers\n * @summary Set the milliseconds to the given date.\n *\n * @description\n * Set the milliseconds to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} milliseconds - the milliseconds of the new date\n * @returns {Date} the new date with the milliseconds set\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Set 300 milliseconds to 1 September 2014 11:30:40.500:\n * const result = setMilliseconds(new Date(2014, 8, 1, 11, 30, 40, 500), 300)\n * //=> Mon Sep 01 2014 11:30:40.300\n */\n\nexport default function setMilliseconds(dirtyDate, dirtyMilliseconds) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var milliseconds = toInteger(dirtyMilliseconds);\n date.setMilliseconds(milliseconds);\n return date;\n}","import isDate from \"../isDate/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\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]{@link 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 * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * - Now `isValid` doesn't throw an exception\n * if the first argument is not an instance of Date.\n * Instead, argument is converted beforehand using `toDate`.\n *\n * Examples:\n *\n * | `isValid` argument | Before v2.0.0 | v2.0.0 onward |\n * |---------------------------|---------------|---------------|\n * | `new Date()` | `true` | `true` |\n * | `new Date('2016-01-01')` | `true` | `true` |\n * | `new Date('')` | `false` | `false` |\n * | `new Date(1488370835081)` | `true` | `true` |\n * | `new Date(NaN)` | `false` | `false` |\n * | `'2016-01-01'` | `TypeError` | `false` |\n * | `''` | `TypeError` | `false` |\n * | `1488370835081` | `TypeError` | `true` |\n * | `NaN` | `TypeError` | `false` |\n *\n * We introduce this change to make *date-fns* consistent with ECMAScript behavior\n * that try to coerce arguments to the expected type\n * (which is also the case with other *date-fns* functions).\n *\n * @param {*} date - the date to check\n * @returns {Boolean} the date is valid\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // For the valid date:\n * const result = isValid(new Date(2014, 1, 31))\n * //=> true\n *\n * @example\n * // For the value, convertable into a date:\n * const result = isValid(1393804800000)\n * //=> true\n *\n * @example\n * // For the invalid date:\n * const result = isValid(new Date(''))\n * //=> false\n */\n\nexport default function isValid(dirtyDate) {\n requiredArgs(1, arguments);\n\n if (!isDate(dirtyDate) && typeof dirtyDate !== 'number') {\n return false;\n }\n\n var date = toDate(dirtyDate);\n return !isNaN(Number(date));\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport startOfUTCWeek from \"../startOfUTCWeek/index.js\";\nimport toInteger from \"../toInteger/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function getUTCWeekYear(dirtyDate, dirtyOptions) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var year = date.getUTCFullYear();\n var options = dirtyOptions || {};\n var locale = options.locale;\n var localeFirstWeekContainsDate = locale && locale.options && locale.options.firstWeekContainsDate;\n var defaultFirstWeekContainsDate = localeFirstWeekContainsDate == null ? 1 : toInteger(localeFirstWeekContainsDate);\n var firstWeekContainsDate = options.firstWeekContainsDate == null ? defaultFirstWeekContainsDate : toInteger(options.firstWeekContainsDate); // Test if weekStartsOn is between 1 and 7 _and_ is not NaN\n\n if (!(firstWeekContainsDate >= 1 && firstWeekContainsDate <= 7)) {\n throw new RangeError('firstWeekContainsDate must be between 1 and 7 inclusively');\n }\n\n var firstWeekOfNextYear = new Date(0);\n firstWeekOfNextYear.setUTCFullYear(year + 1, 0, firstWeekContainsDate);\n firstWeekOfNextYear.setUTCHours(0, 0, 0, 0);\n var startOfNextYear = startOfUTCWeek(firstWeekOfNextYear, dirtyOptions);\n var firstWeekOfThisYear = new Date(0);\n firstWeekOfThisYear.setUTCFullYear(year, 0, firstWeekContainsDate);\n firstWeekOfThisYear.setUTCHours(0, 0, 0, 0);\n var startOfThisYear = startOfUTCWeek(firstWeekOfThisYear, dirtyOptions);\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}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name setHours\n * @category Hour Helpers\n * @summary Set the hours to the given date.\n *\n * @description\n * Set the hours to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} hours - the hours of the new date\n * @returns {Date} the new date with the hours set\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Set 4 hours to 1 September 2014 11:30:00:\n * var result = setHours(new Date(2014, 8, 1, 11, 30), 4)\n * //=> Mon Sep 01 2014 04:30:00\n */\n\nexport default function setHours(dirtyDate, dirtyHours) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var hours = toInteger(dirtyHours);\n date.setHours(hours);\n return date;\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name getSeconds\n * @category Second Helpers\n * @summary Get the seconds of the given date.\n *\n * @description\n * Get the seconds of the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the given date\n * @returns {Number} the seconds\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // Get the seconds of 29 February 2012 11:45:05.123:\n * const result = getSeconds(new Date(2012, 1, 29, 11, 45, 5, 123))\n * //=> 5\n */\n\nexport default function getSeconds(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var seconds = date.getSeconds();\n return seconds;\n}","import toDate from \"../toDate/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\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 * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the original date\n * @param {Object} [options] - an object with options.\n * @param {Locale} [options.locale=defaultLocale] - the locale object. See [Locale]{@link https://date-fns.org/docs/Locale}\n * @param {0|1|2|3|4|5|6} [options.weekStartsOn=0] - the index of the first day of the week (0 - Sunday)\n * @returns {Date} the start of a week\n * @throws {TypeError} 1 argument required\n * @throws {RangeError} `options.weekStartsOn` must be between 0 and 6\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 */\n\nexport default function startOfWeek(dirtyDate, dirtyOptions) {\n requiredArgs(1, arguments);\n var options = dirtyOptions || {};\n var locale = options.locale;\n var localeWeekStartsOn = locale && locale.options && locale.options.weekStartsOn;\n var defaultWeekStartsOn = localeWeekStartsOn == null ? 0 : toInteger(localeWeekStartsOn);\n var weekStartsOn = options.weekStartsOn == null ? defaultWeekStartsOn : toInteger(options.weekStartsOn); // Test if weekStartsOn is between 0 and 6 _and_ is not NaN\n\n if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {\n throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');\n }\n\n var date = toDate(dirtyDate);\n var day = date.getDay();\n var diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n date.setDate(date.getDate() - diff);\n date.setHours(0, 0, 0, 0);\n return date;\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name getMonth\n * @category Month Helpers\n * @summary Get the month of the given date.\n *\n * @description\n * Get the month of the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the given date\n * @returns {Number} the month\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // Which month is 29 February 2012?\n * const result = getMonth(new Date(2012, 1, 29))\n * //=> 1\n */\n\nexport default function getMonth(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var month = date.getMonth();\n return month;\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name getYear\n * @category Year Helpers\n * @summary Get the year of the given date.\n *\n * @description\n * Get the year of the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the given date\n * @returns {Number} the year\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // Which year is 2 July 2014?\n * const result = getYear(new Date(2014, 6, 2))\n * //=> 2014\n */\n\nexport default function getYear(dirtyDate) {\n requiredArgs(1, arguments);\n return toDate(dirtyDate).getFullYear();\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name addMonths\n * @category Month Helpers\n * @summary Add the specified number of months to the given date.\n *\n * @description\n * Add the specified number of months to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of months to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the months added\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Add 5 months to 1 September 2014:\n * const result = addMonths(new Date(2014, 8, 1), 5)\n * //=> Sun Feb 01 2015 00:00:00\n */\n\nexport default function addMonths(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var amount = toInteger(dirtyAmount);\n\n if (isNaN(amount)) {\n return new Date(NaN);\n }\n\n if (!amount) {\n // If 0 months, no-op to avoid changing times in the hour before end of DST\n return date;\n }\n\n var dayOfMonth = date.getDate(); // The JS Date object supports date math by accepting out-of-bounds values for\n // month, day, etc. For example, new Date(2020, 0, 0) returns 31 Dec 2019 and\n // new Date(2020, 13, 1) returns 1 Feb 2021. This is *almost* the behavior we\n // want except that dates will wrap around the end of a month, meaning that\n // new Date(2020, 13, 31) will return 3 Mar 2021 not 28 Feb 2021 as desired. So\n // we'll default to the end of the desired month by adding 1 to the desired\n // month and using a date of 0 to back up one day to the end of the desired\n // month.\n\n var endOfDesiredMonth = new Date(date.getTime());\n endOfDesiredMonth.setMonth(date.getMonth() + amount + 1, 0);\n var daysInMonth = endOfDesiredMonth.getDate();\n\n if (dayOfMonth >= daysInMonth) {\n // If we're already at the end of the month, then this is the correct date\n // and we're done.\n return endOfDesiredMonth;\n } else {\n // Otherwise, we now know that setting the original day-of-month value won't\n // cause an overflow, so set the desired day-of-month. Note that we can't\n // just set the date of `endOfDesiredMonth` because that object may have had\n // its time changed in the unusual case where where a DST transition was on\n // the last day of the month and its local time was in the hour skipped or\n // repeated next to a DST transition. So we use `date` instead which is\n // guaranteed to still have the original time.\n date.setFullYear(endOfDesiredMonth.getFullYear(), endOfDesiredMonth.getMonth(), dayOfMonth);\n return date;\n }\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name isBefore\n * @category Common Helpers\n * @summary Is the first date before the second one?\n *\n * @description\n * Is the first date before the second one?\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date that should be before the other one to return true\n * @param {Date|Number} dateToCompare - the date to compare with\n * @returns {Boolean} the first date is before the second date\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Is 10 July 1989 before 11 February 1987?\n * var result = isBefore(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> false\n */\n\nexport default function isBefore(dirtyDate, dirtyDateToCompare) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var dateToCompare = toDate(dirtyDateToCompare);\n return date.getTime() < dateToCompare.getTime();\n}","import toDate from \"../toDate/index.js\";\nimport setMonth from \"../setMonth/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n\n/**\n * @name set\n * @category Common Helpers\n * @summary Set date values to a given date.\n *\n * @description\n * Set date values to a given date.\n *\n * Sets time values to date from object `values`.\n * A value is not set if it is undefined or null or doesn't exist in `values`.\n *\n * Note about bundle size: `set` does not internally use `setX` functions from date-fns but instead opts\n * to use native `Date#setX` methods. If you use this function, you may not want to include the\n * other `setX` functions that date-fns provides if you are concerned about the bundle size.\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Object} values - an object with options\n * @param {Number} [values.year] - the number of years to be set\n * @param {Number} [values.month] - the number of months to be set\n * @param {Number} [values.date] - the number of days to be set\n * @param {Number} [values.hours] - the number of hours to be set\n * @param {Number} [values.minutes] - the number of minutes to be set\n * @param {Number} [values.seconds] - the number of seconds to be set\n * @param {Number} [values.milliseconds] - the number of milliseconds to be set\n * @returns {Date} the new date with options set\n * @throws {TypeError} 2 arguments required\n * @throws {RangeError} `values` must be an object\n *\n * @example\n * // Transform 1 September 2014 into 20 October 2015 in a single line:\n * var result = set(new Date(2014, 8, 20), { year: 2015, month: 9, date: 20 })\n * //=> Tue Oct 20 2015 00:00:00\n *\n * @example\n * // Set 12 PM to 1 September 2014 01:23:45 to 1 September 2014 12:00:00:\n * var result = set(new Date(2014, 8, 1, 1, 23, 45), { hours: 12 })\n * //=> Mon Sep 01 2014 12:23:45\n */\nexport default function set(dirtyDate, values) {\n requiredArgs(2, arguments);\n\n if (typeof values !== 'object' || values === null) {\n throw new RangeError('values parameter must be an object');\n }\n\n var date = toDate(dirtyDate); // Check if date is Invalid Date because Date.prototype.setFullYear ignores the value of Invalid Date\n\n if (isNaN(date.getTime())) {\n return new Date(NaN);\n }\n\n if (values.year != null) {\n date.setFullYear(values.year);\n }\n\n if (values.month != null) {\n date = setMonth(date, values.month);\n }\n\n if (values.date != null) {\n date.setDate(toInteger(values.date));\n }\n\n if (values.hours != null) {\n date.setHours(toInteger(values.hours));\n }\n\n if (values.minutes != null) {\n date.setMinutes(toInteger(values.minutes));\n }\n\n if (values.seconds != null) {\n date.setSeconds(toInteger(values.seconds));\n }\n\n if (values.milliseconds != null) {\n date.setMilliseconds(toInteger(values.milliseconds));\n }\n\n return date;\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\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 * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the original date\n * @returns {Date} the start of a day\n * @throws {TypeError} 1 argument required\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 */\n\nexport default function startOfDay(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n date.setHours(0, 0, 0, 0);\n return date;\n}","import getTimezoneOffsetInMilliseconds from \"../_lib/getTimezoneOffsetInMilliseconds/index.js\";\nimport startOfDay from \"../startOfDay/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\nvar MILLISECONDS_IN_DAY = 86400000;\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 * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} dateLeft - the later date\n * @param {Date|Number} dateRight - the earlier date\n * @returns {Number} the number of calendar days\n * @throws {TypeError} 2 arguments required\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 */\n\nexport default function differenceInCalendarDays(dirtyDateLeft, dirtyDateRight) {\n requiredArgs(2, arguments);\n var startOfDayLeft = startOfDay(dirtyDateLeft);\n var startOfDayRight = startOfDay(dirtyDateRight);\n var timestampLeft = startOfDayLeft.getTime() - getTimezoneOffsetInMilliseconds(startOfDayLeft);\n var timestampRight = startOfDayRight.getTime() - getTimezoneOffsetInMilliseconds(startOfDayRight); // Round the number of days to the nearest integer\n // because the number of milliseconds in a day is not constant\n // (e.g. it's different in the day of the daylight saving time clock shift)\n\n return Math.round((timestampLeft - timestampRight) / MILLISECONDS_IN_DAY);\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport startOfUTCISOWeek from \"../startOfUTCISOWeek/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function getUTCISOWeekYear(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var year = date.getUTCFullYear();\n var fourthOfJanuaryOfNextYear = new Date(0);\n fourthOfJanuaryOfNextYear.setUTCFullYear(year + 1, 0, 4);\n fourthOfJanuaryOfNextYear.setUTCHours(0, 0, 0, 0);\n var startOfNextYear = startOfUTCISOWeek(fourthOfJanuaryOfNextYear);\n var fourthOfJanuaryOfThisYear = new Date(0);\n fourthOfJanuaryOfThisYear.setUTCFullYear(year, 0, 4);\n fourthOfJanuaryOfThisYear.setUTCHours(0, 0, 0, 0);\n var startOfThisYear = startOfUTCISOWeek(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}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name addMilliseconds\n * @category Millisecond Helpers\n * @summary Add the specified number of milliseconds to the given date.\n *\n * @description\n * Add the specified number of milliseconds to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of milliseconds to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the milliseconds added\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Add 750 milliseconds to 10 July 2014 12:45:30.000:\n * const result = addMilliseconds(new Date(2014, 6, 10, 12, 45, 30, 0), 750)\n * //=> Thu Jul 10 2014 12:45:30.750\n */\n\nexport default function addMilliseconds(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var timestamp = toDate(dirtyDate).getTime();\n var amount = toInteger(dirtyAmount);\n return new Date(timestamp + amount);\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport addMilliseconds from \"../addMilliseconds/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name subMilliseconds\n * @category Millisecond Helpers\n * @summary Subtract the specified number of milliseconds from the given date.\n *\n * @description\n * Subtract the specified number of milliseconds from the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of milliseconds to be subtracted. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the milliseconds subtracted\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Subtract 750 milliseconds from 10 July 2014 12:45:30.000:\n * const result = subMilliseconds(new Date(2014, 6, 10, 12, 45, 30, 0), 750)\n * //=> Thu Jul 10 2014 12:45:29.250\n */\n\nexport default function subMilliseconds(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var amount = toInteger(dirtyAmount);\n return addMilliseconds(dirtyDate, -amount);\n}","var formatDistanceLocale = {\n lessThanXSeconds: {\n one: 'less than a second',\n other: 'less than {{count}} seconds'\n },\n xSeconds: {\n one: '1 second',\n other: '{{count}} seconds'\n },\n halfAMinute: 'half a minute',\n lessThanXMinutes: {\n one: 'less than a minute',\n other: 'less than {{count}} minutes'\n },\n xMinutes: {\n one: '1 minute',\n other: '{{count}} minutes'\n },\n aboutXHours: {\n one: 'about 1 hour',\n other: 'about {{count}} hours'\n },\n xHours: {\n one: '1 hour',\n other: '{{count}} hours'\n },\n xDays: {\n one: '1 day',\n other: '{{count}} days'\n },\n aboutXWeeks: {\n one: 'about 1 week',\n other: 'about {{count}} weeks'\n },\n xWeeks: {\n one: '1 week',\n other: '{{count}} weeks'\n },\n aboutXMonths: {\n one: 'about 1 month',\n other: 'about {{count}} months'\n },\n xMonths: {\n one: '1 month',\n other: '{{count}} months'\n },\n aboutXYears: {\n one: 'about 1 year',\n other: 'about {{count}} years'\n },\n xYears: {\n one: '1 year',\n other: '{{count}} years'\n },\n overXYears: {\n one: 'over 1 year',\n other: 'over {{count}} years'\n },\n almostXYears: {\n one: 'almost 1 year',\n other: 'almost {{count}} years'\n }\n};\n\nvar formatDistance = function (token, count, options) {\n var result;\n var tokenValue = formatDistanceLocale[token];\n\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 !== null && options !== void 0 && 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\nexport default formatDistance;","export default function buildFormatLongFn(args) {\n return function () {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n // TODO: Remove String()\n var width = options.width ? String(options.width) : args.defaultWidth;\n var format = args.formats[width] || args.formats[args.defaultWidth];\n return format;\n };\n}","import buildFormatLongFn from \"../../../_lib/buildFormatLongFn/index.js\";\nvar dateFormats = {\n full: 'EEEE, MMMM do, y',\n long: 'MMMM do, y',\n medium: 'MMM d, y',\n short: 'MM/dd/yyyy'\n};\nvar 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};\nvar dateTimeFormats = {\n full: \"{{date}} 'at' {{time}}\",\n long: \"{{date}} 'at' {{time}}\",\n medium: '{{date}}, {{time}}',\n short: '{{date}}, {{time}}'\n};\nvar formatLong = {\n date: buildFormatLongFn({\n formats: dateFormats,\n defaultWidth: 'full'\n }),\n time: buildFormatLongFn({\n formats: timeFormats,\n defaultWidth: 'full'\n }),\n dateTime: buildFormatLongFn({\n formats: dateTimeFormats,\n defaultWidth: 'full'\n })\n};\nexport default formatLong;","var 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\nvar formatRelative = function (token, _date, _baseDate, _options) {\n return formatRelativeLocale[token];\n};\n\nexport default formatRelative;","export default function buildLocalizeFn(args) {\n return function (dirtyIndex, dirtyOptions) {\n var options = dirtyOptions || {};\n var context = options.context ? String(options.context) : 'standalone';\n var valuesArray;\n\n if (context === 'formatting' && args.formattingValues) {\n var defaultWidth = args.defaultFormattingWidth || args.defaultWidth;\n var width = options.width ? String(options.width) : defaultWidth;\n valuesArray = args.formattingValues[width] || args.formattingValues[defaultWidth];\n } else {\n var _defaultWidth = args.defaultWidth;\n\n var _width = options.width ? String(options.width) : args.defaultWidth;\n\n valuesArray = args.values[_width] || args.values[_defaultWidth];\n }\n\n var index = args.argumentCallback ? args.argumentCallback(dirtyIndex) : dirtyIndex; // @ts-ignore: 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\n return valuesArray[index];\n };\n}","import buildLocalizeFn from \"../../../_lib/buildLocalizeFn/index.js\";\nvar eraValues = {\n narrow: ['B', 'A'],\n abbreviated: ['BC', 'AD'],\n wide: ['Before Christ', 'Anno Domini']\n};\nvar quarterValues = {\n narrow: ['1', '2', '3', '4'],\n abbreviated: ['Q1', 'Q2', 'Q3', 'Q4'],\n wide: ['1st quarter', '2nd quarter', '3rd quarter', '4th quarter']\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.\n\nvar monthValues = {\n narrow: ['J', 'F', 'M', 'A', 'M', 'J', 'J', 'A', 'S', 'O', 'N', 'D'],\n abbreviated: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n wide: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']\n};\nvar 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: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']\n};\nvar 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};\nvar 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\nvar ordinalNumber = function (dirtyNumber, _options) {\n var number = Number(dirtyNumber); // 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 var rem100 = number % 100;\n\n if (rem100 > 20 || rem100 < 10) {\n switch (rem100 % 10) {\n case 1:\n return number + 'st';\n\n case 2:\n return number + 'nd';\n\n case 3:\n return number + 'rd';\n }\n }\n\n return number + 'th';\n};\n\nvar localize = {\n ordinalNumber: ordinalNumber,\n era: buildLocalizeFn({\n values: eraValues,\n defaultWidth: 'wide'\n }),\n quarter: buildLocalizeFn({\n values: quarterValues,\n defaultWidth: 'wide',\n argumentCallback: function (quarter) {\n return quarter - 1;\n }\n }),\n month: buildLocalizeFn({\n values: monthValues,\n defaultWidth: 'wide'\n }),\n day: buildLocalizeFn({\n values: dayValues,\n defaultWidth: 'wide'\n }),\n dayPeriod: buildLocalizeFn({\n values: dayPeriodValues,\n defaultWidth: 'wide',\n formattingValues: formattingDayPeriodValues,\n defaultFormattingWidth: 'wide'\n })\n};\nexport default localize;","export default function buildMatchFn(args) {\n return function (string) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var width = options.width;\n var matchPattern = width && args.matchPatterns[width] || args.matchPatterns[args.defaultMatchWidth];\n var matchResult = string.match(matchPattern);\n\n if (!matchResult) {\n return null;\n }\n\n var matchedString = matchResult[0];\n var parsePatterns = width && args.parsePatterns[width] || args.parsePatterns[args.defaultParseWidth];\n var key = Array.isArray(parsePatterns) ? findIndex(parsePatterns, function (pattern) {\n return pattern.test(matchedString);\n }) : findKey(parsePatterns, function (pattern) {\n return pattern.test(matchedString);\n });\n var value;\n value = args.valueCallback ? args.valueCallback(key) : key;\n value = options.valueCallback ? options.valueCallback(value) : value;\n var rest = string.slice(matchedString.length);\n return {\n value: value,\n rest: rest\n };\n };\n}\n\nfunction findKey(object, predicate) {\n for (var key in object) {\n if (object.hasOwnProperty(key) && predicate(object[key])) {\n return key;\n }\n }\n\n return undefined;\n}\n\nfunction findIndex(array, predicate) {\n for (var key = 0; key < array.length; key++) {\n if (predicate(array[key])) {\n return key;\n }\n }\n\n return undefined;\n}","export default function buildMatchPatternFn(args) {\n return function (string) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var matchResult = string.match(args.matchPattern);\n if (!matchResult) return null;\n var matchedString = matchResult[0];\n var parseResult = string.match(args.parsePattern);\n if (!parseResult) return null;\n var value = args.valueCallback ? args.valueCallback(parseResult[0]) : parseResult[0];\n value = options.valueCallback ? options.valueCallback(value) : value;\n var rest = string.slice(matchedString.length);\n return {\n value: value,\n rest: rest\n };\n };\n}","import buildMatchFn from \"../../../_lib/buildMatchFn/index.js\";\nimport buildMatchPatternFn from \"../../../_lib/buildMatchPatternFn/index.js\";\nvar matchOrdinalNumberPattern = /^(\\d+)(th|st|nd|rd)?/i;\nvar parseOrdinalNumberPattern = /\\d+/i;\nvar 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};\nvar parseEraPatterns = {\n any: [/^b/i, /^(a|c)/i]\n};\nvar matchQuarterPatterns = {\n narrow: /^[1234]/i,\n abbreviated: /^q[1234]/i,\n wide: /^[1234](th|st|nd|rd)? quarter/i\n};\nvar parseQuarterPatterns = {\n any: [/1/i, /2/i, /3/i, /4/i]\n};\nvar 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};\nvar parseMonthPatterns = {\n narrow: [/^j/i, /^f/i, /^m/i, /^a/i, /^m/i, /^j/i, /^j/i, /^a/i, /^s/i, /^o/i, /^n/i, /^d/i],\n any: [/^ja/i, /^f/i, /^mar/i, /^ap/i, /^may/i, /^jun/i, /^jul/i, /^au/i, /^s/i, /^o/i, /^n/i, /^d/i]\n};\nvar 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};\nvar 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};\nvar 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};\nvar 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};\nvar match = {\n ordinalNumber: buildMatchPatternFn({\n matchPattern: matchOrdinalNumberPattern,\n parsePattern: parseOrdinalNumberPattern,\n valueCallback: function (value) {\n return parseInt(value, 10);\n }\n }),\n era: buildMatchFn({\n matchPatterns: matchEraPatterns,\n defaultMatchWidth: 'wide',\n parsePatterns: parseEraPatterns,\n defaultParseWidth: 'any'\n }),\n quarter: buildMatchFn({\n matchPatterns: matchQuarterPatterns,\n defaultMatchWidth: 'wide',\n parsePatterns: parseQuarterPatterns,\n defaultParseWidth: 'any',\n valueCallback: function (index) {\n return index + 1;\n }\n }),\n month: buildMatchFn({\n matchPatterns: matchMonthPatterns,\n defaultMatchWidth: 'wide',\n parsePatterns: parseMonthPatterns,\n defaultParseWidth: 'any'\n }),\n day: buildMatchFn({\n matchPatterns: matchDayPatterns,\n defaultMatchWidth: 'wide',\n parsePatterns: parseDayPatterns,\n defaultParseWidth: 'any'\n }),\n dayPeriod: buildMatchFn({\n matchPatterns: matchDayPeriodPatterns,\n defaultMatchWidth: 'any',\n parsePatterns: parseDayPeriodPatterns,\n defaultParseWidth: 'any'\n })\n};\nexport default match;","import formatDistance from \"./_lib/formatDistance/index.js\";\nimport formatLong from \"./_lib/formatLong/index.js\";\nimport formatRelative from \"./_lib/formatRelative/index.js\";\nimport localize from \"./_lib/localize/index.js\";\nimport match from \"./_lib/match/index.js\";\n\n/**\n * @type {Locale}\n * @category Locales\n * @summary English locale (United States).\n * @language English\n * @iso-639-2 eng\n * @author Sasha Koss [@kossnocorp]{@link https://github.com/kossnocorp}\n * @author Lesha Koss [@leshakoss]{@link https://github.com/leshakoss}\n */\nvar locale = {\n code: 'en-US',\n formatDistance: formatDistance,\n formatLong: formatLong,\n formatRelative: formatRelative,\n localize: localize,\n match: match,\n options: {\n weekStartsOn: 0\n /* Sunday */\n ,\n firstWeekContainsDate: 1\n }\n};\nexport default locale;","export default function requiredArgs(required, args) {\n if (args.length < required) {\n throw new TypeError(required + ' argument' + (required > 1 ? 's' : '') + ' required, but only ' + args.length + ' present');\n }\n}","import getUTCISOWeekYear from \"../getUTCISOWeekYear/index.js\";\nimport startOfUTCISOWeek from \"../startOfUTCISOWeek/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function startOfUTCISOWeekYear(dirtyDate) {\n requiredArgs(1, arguments);\n var year = getUTCISOWeekYear(dirtyDate);\n var fourthOfJanuary = new Date(0);\n fourthOfJanuary.setUTCFullYear(year, 0, 4);\n fourthOfJanuary.setUTCHours(0, 0, 0, 0);\n var date = startOfUTCISOWeek(fourthOfJanuary);\n return date;\n}","import toDate from \"../../toDate/index.js\";\nimport startOfUTCISOWeek from \"../startOfUTCISOWeek/index.js\";\nimport startOfUTCISOWeekYear from \"../startOfUTCISOWeekYear/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nvar MILLISECONDS_IN_WEEK = 604800000; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function getUTCISOWeek(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var diff = startOfUTCISOWeek(date).getTime() - startOfUTCISOWeekYear(date).getTime(); // Round the number of days to the nearest integer\n // because the number of milliseconds in a week is not constant\n // (e.g. it's different in the week of the daylight saving time clock shift)\n\n return Math.round(diff / MILLISECONDS_IN_WEEK) + 1;\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name getDaysInMonth\n * @category Month Helpers\n * @summary Get the number of days in a month of the given date.\n *\n * @description\n * Get the number of days in a month of the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the given date\n * @returns {Number} the number of days in a month\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // How many days are in February 2000?\n * const result = getDaysInMonth(new Date(2000, 1))\n * //=> 29\n */\n\nexport default function getDaysInMonth(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var year = date.getFullYear();\n var monthIndex = date.getMonth();\n var lastDayOfMonth = new Date(0);\n lastDayOfMonth.setFullYear(year, monthIndex + 1, 0);\n lastDayOfMonth.setHours(0, 0, 0, 0);\n return lastDayOfMonth.getDate();\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport getDaysInMonth from \"../getDaysInMonth/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name setMonth\n * @category Month Helpers\n * @summary Set the month to the given date.\n *\n * @description\n * Set the month to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} month - the month of the new date\n * @returns {Date} the new date with the month set\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Set February to 1 September 2014:\n * const result = setMonth(new Date(2014, 8, 1), 1)\n * //=> Sat Feb 01 2014 00:00:00\n */\n\nexport default function setMonth(dirtyDate, dirtyMonth) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var month = toInteger(dirtyMonth);\n var year = date.getFullYear();\n var day = date.getDate();\n var dateWithDesiredMonth = new Date(0);\n dateWithDesiredMonth.setFullYear(year, month, 15);\n dateWithDesiredMonth.setHours(0, 0, 0, 0);\n var daysInMonth = getDaysInMonth(dateWithDesiredMonth); // Set the last day of the new month\n // if the original date was the last day of the longer month\n\n date.setMonth(month, Math.min(day, daysInMonth));\n return date;\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport addMonths from \"../addMonths/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name subMonths\n * @category Month Helpers\n * @summary Subtract the specified number of months from the given date.\n *\n * @description\n * Subtract the specified number of months from the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of months to be subtracted. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the months subtracted\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Subtract 5 months from 1 February 2015:\n * const result = subMonths(new Date(2015, 1, 1), 5)\n * //=> Mon Sep 01 2014 00:00:00\n */\n\nexport default function subMonths(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var amount = toInteger(dirtyAmount);\n return addMonths(dirtyDate, -amount);\n}","import requiredArgs from \"../_lib/requiredArgs/index.js\";\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 * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {*} value - the value to check\n * @returns {boolean} true if the given value is a date\n * @throws {TypeError} 1 arguments required\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 */\n\nexport default function isDate(value) {\n requiredArgs(1, arguments);\n return value instanceof Date || typeof value === 'object' && Object.prototype.toString.call(value) === '[object Date]';\n}","import startOfWeek from \"../startOfWeek/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\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 * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the original date\n * @returns {Date} the start of an ISO week\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // The start of an ISO week for 2 September 2014 11:55:00:\n * var result = startOfISOWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Mon Sep 01 2014 00:00:00\n */\n\nexport default function startOfISOWeek(dirtyDate) {\n requiredArgs(1, arguments);\n return startOfWeek(dirtyDate, {\n weekStartsOn: 1\n });\n}","import toDate from \"../toDate/index.js\";\nimport startOfISOWeek from \"../startOfISOWeek/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\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 * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * - The function was renamed from `getISOYear` to `getISOWeekYear`.\n * \"ISO week year\" is short for [ISO week-numbering year](https://en.wikipedia.org/wiki/ISO_week_date).\n * This change makes the name consistent with\n * locale-dependent week-numbering year helpers, e.g., `getWeekYear`.\n *\n * @param {Date|Number} date - the given date\n * @returns {Number} the ISO week-numbering year\n * @throws {TypeError} 1 argument required\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 */\n\nexport default function getISOWeekYear(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var year = date.getFullYear();\n var fourthOfJanuaryOfNextYear = new Date(0);\n fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4);\n fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0);\n var startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear);\n var fourthOfJanuaryOfThisYear = new Date(0);\n fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4);\n fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0);\n var 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}","import getISOWeekYear from \"../getISOWeekYear/index.js\";\nimport startOfISOWeek from \"../startOfISOWeek/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\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 * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the original date\n * @returns {Date} the start of an ISO week-numbering year\n * @throws {TypeError} 1 argument required\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 */\n\nexport default function startOfISOWeekYear(dirtyDate) {\n requiredArgs(1, arguments);\n var year = getISOWeekYear(dirtyDate);\n var fourthOfJanuary = new Date(0);\n fourthOfJanuary.setFullYear(year, 0, 4);\n fourthOfJanuary.setHours(0, 0, 0, 0);\n var date = startOfISOWeek(fourthOfJanuary);\n return date;\n}","import toDate from \"../toDate/index.js\";\nimport startOfISOWeek from \"../startOfISOWeek/index.js\";\nimport startOfISOWeekYear from \"../startOfISOWeekYear/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\nvar MILLISECONDS_IN_WEEK = 604800000;\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 * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the given date\n * @returns {Number} the ISO week\n * @throws {TypeError} 1 argument required\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 */\n\nexport default function getISOWeek(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var diff = startOfISOWeek(date).getTime() - startOfISOWeekYear(date).getTime(); // Round the number of days to the nearest integer\n // because the number of milliseconds in a week is not constant\n // (e.g. it's different in the week of the daylight saving time clock shift)\n\n return Math.round(diff / MILLISECONDS_IN_WEEK) + 1;\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nvar MILLISECONDS_IN_DAY = 86400000; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function getUTCDayOfYear(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var timestamp = date.getTime();\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n var startOfYearTimestamp = date.getTime();\n var difference = timestamp - startOfYearTimestamp;\n return Math.floor(difference / MILLISECONDS_IN_DAY) + 1;\n}","export default function addLeadingZeros(number, targetLength) {\n var sign = number < 0 ? '-' : '';\n var output = Math.abs(number).toString();\n\n while (output.length < targetLength) {\n output = '0' + output;\n }\n\n return sign + output;\n}","import addLeadingZeros from \"../../addLeadingZeros/index.js\";\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\nvar formatters = {\n // Year\n y: function (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 var signedYear = date.getUTCFullYear(); // Returns 1 for 1 BC (which is year 0 in JavaScript)\n\n var year = signedYear > 0 ? signedYear : 1 - signedYear;\n return addLeadingZeros(token === 'yy' ? year % 100 : year, token.length);\n },\n // Month\n M: function (date, token) {\n var month = date.getUTCMonth();\n return token === 'M' ? String(month + 1) : addLeadingZeros(month + 1, 2);\n },\n // Day of the month\n d: function (date, token) {\n return addLeadingZeros(date.getUTCDate(), token.length);\n },\n // AM or PM\n a: function (date, token) {\n var dayPeriodEnumValue = date.getUTCHours() / 12 >= 1 ? 'pm' : 'am';\n\n switch (token) {\n case 'a':\n case 'aa':\n return dayPeriodEnumValue.toUpperCase();\n\n case 'aaa':\n return dayPeriodEnumValue;\n\n case 'aaaaa':\n return dayPeriodEnumValue[0];\n\n case 'aaaa':\n default:\n return dayPeriodEnumValue === 'am' ? 'a.m.' : 'p.m.';\n }\n },\n // Hour [1-12]\n h: function (date, token) {\n return addLeadingZeros(date.getUTCHours() % 12 || 12, token.length);\n },\n // Hour [0-23]\n H: function (date, token) {\n return addLeadingZeros(date.getUTCHours(), token.length);\n },\n // Minute\n m: function (date, token) {\n return addLeadingZeros(date.getUTCMinutes(), token.length);\n },\n // Second\n s: function (date, token) {\n return addLeadingZeros(date.getUTCSeconds(), token.length);\n },\n // Fraction of second\n S: function (date, token) {\n var numberOfDigits = token.length;\n var milliseconds = date.getUTCMilliseconds();\n var fractionalSeconds = Math.floor(milliseconds * Math.pow(10, numberOfDigits - 3));\n return addLeadingZeros(fractionalSeconds, token.length);\n }\n};\nexport default formatters;","import getUTCDayOfYear from \"../../../_lib/getUTCDayOfYear/index.js\";\nimport getUTCISOWeek from \"../../../_lib/getUTCISOWeek/index.js\";\nimport getUTCISOWeekYear from \"../../../_lib/getUTCISOWeekYear/index.js\";\nimport getUTCWeek from \"../../../_lib/getUTCWeek/index.js\";\nimport getUTCWeekYear from \"../../../_lib/getUTCWeekYear/index.js\";\nimport addLeadingZeros from \"../../addLeadingZeros/index.js\";\nimport lightFormatters from \"../lightFormatters/index.js\";\nvar 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 * | | 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\nvar formatters = {\n // Era\n G: function (date, token, localize) {\n var era = date.getUTCFullYear() > 0 ? 1 : 0;\n\n switch (token) {\n // AD, BC\n case 'G':\n case 'GG':\n case 'GGG':\n return localize.era(era, {\n width: 'abbreviated'\n });\n // A, B\n\n case 'GGGGG':\n return localize.era(era, {\n width: 'narrow'\n });\n // Anno Domini, Before Christ\n\n case 'GGGG':\n default:\n return localize.era(era, {\n width: 'wide'\n });\n }\n },\n // Year\n y: function (date, token, localize) {\n // Ordinal number\n if (token === 'yo') {\n var signedYear = date.getUTCFullYear(); // Returns 1 for 1 BC (which is year 0 in JavaScript)\n\n var year = signedYear > 0 ? signedYear : 1 - signedYear;\n return localize.ordinalNumber(year, {\n unit: 'year'\n });\n }\n\n return lightFormatters.y(date, token);\n },\n // Local week-numbering year\n Y: function (date, token, localize, options) {\n var signedWeekYear = getUTCWeekYear(date, options); // Returns 1 for 1 BC (which is year 0 in JavaScript)\n\n var weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear; // Two digit year\n\n if (token === 'YY') {\n var twoDigitYear = weekYear % 100;\n return addLeadingZeros(twoDigitYear, 2);\n } // Ordinal number\n\n\n if (token === 'Yo') {\n return localize.ordinalNumber(weekYear, {\n unit: 'year'\n });\n } // Padding\n\n\n return addLeadingZeros(weekYear, token.length);\n },\n // ISO week-numbering year\n R: function (date, token) {\n var isoWeekYear = getUTCISOWeekYear(date); // Padding\n\n return addLeadingZeros(isoWeekYear, token.length);\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 var year = date.getUTCFullYear();\n return addLeadingZeros(year, token.length);\n },\n // Quarter\n Q: function (date, token, localize) {\n var quarter = Math.ceil((date.getUTCMonth() + 1) / 3);\n\n switch (token) {\n // 1, 2, 3, 4\n case 'Q':\n return String(quarter);\n // 01, 02, 03, 04\n\n case 'QQ':\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n\n case 'Qo':\n return localize.ordinalNumber(quarter, {\n unit: 'quarter'\n });\n // Q1, Q2, Q3, Q4\n\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\n case 'QQQQQ':\n return localize.quarter(quarter, {\n width: 'narrow',\n context: 'formatting'\n });\n // 1st quarter, 2nd quarter, ...\n\n case 'QQQQ':\n default:\n return localize.quarter(quarter, {\n width: 'wide',\n context: 'formatting'\n });\n }\n },\n // Stand-alone quarter\n q: function (date, token, localize) {\n var quarter = Math.ceil((date.getUTCMonth() + 1) / 3);\n\n switch (token) {\n // 1, 2, 3, 4\n case 'q':\n return String(quarter);\n // 01, 02, 03, 04\n\n case 'qq':\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n\n case 'qo':\n return localize.ordinalNumber(quarter, {\n unit: 'quarter'\n });\n // Q1, Q2, Q3, Q4\n\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\n case 'qqqqq':\n return localize.quarter(quarter, {\n width: 'narrow',\n context: 'standalone'\n });\n // 1st quarter, 2nd quarter, ...\n\n case 'qqqq':\n default:\n return localize.quarter(quarter, {\n width: 'wide',\n context: 'standalone'\n });\n }\n },\n // Month\n M: function (date, token, localize) {\n var month = date.getUTCMonth();\n\n switch (token) {\n case 'M':\n case 'MM':\n return lightFormatters.M(date, token);\n // 1st, 2nd, ..., 12th\n\n case 'Mo':\n return localize.ordinalNumber(month + 1, {\n unit: 'month'\n });\n // Jan, Feb, ..., Dec\n\n case 'MMM':\n return localize.month(month, {\n width: 'abbreviated',\n context: 'formatting'\n });\n // J, F, ..., D\n\n case 'MMMMM':\n return localize.month(month, {\n width: 'narrow',\n context: 'formatting'\n });\n // January, February, ..., December\n\n case 'MMMM':\n default:\n return localize.month(month, {\n width: 'wide',\n context: 'formatting'\n });\n }\n },\n // Stand-alone month\n L: function (date, token, localize) {\n var month = date.getUTCMonth();\n\n switch (token) {\n // 1, 2, ..., 12\n case 'L':\n return String(month + 1);\n // 01, 02, ..., 12\n\n case 'LL':\n return addLeadingZeros(month + 1, 2);\n // 1st, 2nd, ..., 12th\n\n case 'Lo':\n return localize.ordinalNumber(month + 1, {\n unit: 'month'\n });\n // Jan, Feb, ..., Dec\n\n case 'LLL':\n return localize.month(month, {\n width: 'abbreviated',\n context: 'standalone'\n });\n // J, F, ..., D\n\n case 'LLLLL':\n return localize.month(month, {\n width: 'narrow',\n context: 'standalone'\n });\n // January, February, ..., December\n\n case 'LLLL':\n default:\n return localize.month(month, {\n width: 'wide',\n context: 'standalone'\n });\n }\n },\n // Local week of year\n w: function (date, token, localize, options) {\n var week = getUTCWeek(date, options);\n\n if (token === 'wo') {\n return localize.ordinalNumber(week, {\n unit: 'week'\n });\n }\n\n return addLeadingZeros(week, token.length);\n },\n // ISO week of year\n I: function (date, token, localize) {\n var isoWeek = getUTCISOWeek(date);\n\n if (token === 'Io') {\n return localize.ordinalNumber(isoWeek, {\n unit: 'week'\n });\n }\n\n return addLeadingZeros(isoWeek, token.length);\n },\n // Day of the month\n d: function (date, token, localize) {\n if (token === 'do') {\n return localize.ordinalNumber(date.getUTCDate(), {\n unit: 'date'\n });\n }\n\n return lightFormatters.d(date, token);\n },\n // Day of year\n D: function (date, token, localize) {\n var dayOfYear = getUTCDayOfYear(date);\n\n if (token === 'Do') {\n return localize.ordinalNumber(dayOfYear, {\n unit: 'dayOfYear'\n });\n }\n\n return addLeadingZeros(dayOfYear, token.length);\n },\n // Day of week\n E: function (date, token, localize) {\n var dayOfWeek = date.getUTCDay();\n\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\n case 'EEEEE':\n return localize.day(dayOfWeek, {\n width: 'narrow',\n context: 'formatting'\n });\n // Tu\n\n case 'EEEEEE':\n return localize.day(dayOfWeek, {\n width: 'short',\n context: 'formatting'\n });\n // Tuesday\n\n case 'EEEE':\n default:\n return localize.day(dayOfWeek, {\n width: 'wide',\n context: 'formatting'\n });\n }\n },\n // Local day of week\n e: function (date, token, localize, options) {\n var dayOfWeek = date.getUTCDay();\n var localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n\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\n case 'ee':\n return addLeadingZeros(localDayOfWeek, 2);\n // 1st, 2nd, ..., 7th\n\n case 'eo':\n return localize.ordinalNumber(localDayOfWeek, {\n unit: 'day'\n });\n\n case 'eee':\n return localize.day(dayOfWeek, {\n width: 'abbreviated',\n context: 'formatting'\n });\n // T\n\n case 'eeeee':\n return localize.day(dayOfWeek, {\n width: 'narrow',\n context: 'formatting'\n });\n // Tu\n\n case 'eeeeee':\n return localize.day(dayOfWeek, {\n width: 'short',\n context: 'formatting'\n });\n // Tuesday\n\n case 'eeee':\n default:\n return localize.day(dayOfWeek, {\n width: 'wide',\n context: 'formatting'\n });\n }\n },\n // Stand-alone local day of week\n c: function (date, token, localize, options) {\n var dayOfWeek = date.getUTCDay();\n var localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n\n switch (token) {\n // Numerical value (same as in `e`)\n case 'c':\n return String(localDayOfWeek);\n // Padded numerical value\n\n case 'cc':\n return addLeadingZeros(localDayOfWeek, token.length);\n // 1st, 2nd, ..., 7th\n\n case 'co':\n return localize.ordinalNumber(localDayOfWeek, {\n unit: 'day'\n });\n\n case 'ccc':\n return localize.day(dayOfWeek, {\n width: 'abbreviated',\n context: 'standalone'\n });\n // T\n\n case 'ccccc':\n return localize.day(dayOfWeek, {\n width: 'narrow',\n context: 'standalone'\n });\n // Tu\n\n case 'cccccc':\n return localize.day(dayOfWeek, {\n width: 'short',\n context: 'standalone'\n });\n // Tuesday\n\n case 'cccc':\n default:\n return localize.day(dayOfWeek, {\n width: 'wide',\n context: 'standalone'\n });\n }\n },\n // ISO day of week\n i: function (date, token, localize) {\n var dayOfWeek = date.getUTCDay();\n var isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek;\n\n switch (token) {\n // 2\n case 'i':\n return String(isoDayOfWeek);\n // 02\n\n case 'ii':\n return addLeadingZeros(isoDayOfWeek, token.length);\n // 2nd\n\n case 'io':\n return localize.ordinalNumber(isoDayOfWeek, {\n unit: 'day'\n });\n // Tue\n\n case 'iii':\n return localize.day(dayOfWeek, {\n width: 'abbreviated',\n context: 'formatting'\n });\n // T\n\n case 'iiiii':\n return localize.day(dayOfWeek, {\n width: 'narrow',\n context: 'formatting'\n });\n // Tu\n\n case 'iiiiii':\n return localize.day(dayOfWeek, {\n width: 'short',\n context: 'formatting'\n });\n // Tuesday\n\n case 'iiii':\n default:\n return localize.day(dayOfWeek, {\n width: 'wide',\n context: 'formatting'\n });\n }\n },\n // AM or PM\n a: function (date, token, localize) {\n var hours = date.getUTCHours();\n var 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\n case 'aaa':\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: 'abbreviated',\n context: 'formatting'\n }).toLowerCase();\n\n case 'aaaaa':\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: 'narrow',\n context: 'formatting'\n });\n\n case 'aaaa':\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: 'wide',\n context: 'formatting'\n });\n }\n },\n // AM, PM, midnight, noon\n b: function (date, token, localize) {\n var hours = date.getUTCHours();\n var dayPeriodEnumValue;\n\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\n case 'bbb':\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: 'abbreviated',\n context: 'formatting'\n }).toLowerCase();\n\n case 'bbbbb':\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: 'narrow',\n context: 'formatting'\n });\n\n case 'bbbb':\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: 'wide',\n context: 'formatting'\n });\n }\n },\n // in the morning, in the afternoon, in the evening, at night\n B: function (date, token, localize) {\n var hours = date.getUTCHours();\n var dayPeriodEnumValue;\n\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\n case 'BBBBB':\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: 'narrow',\n context: 'formatting'\n });\n\n case 'BBBB':\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: 'wide',\n context: 'formatting'\n });\n }\n },\n // Hour [1-12]\n h: function (date, token, localize) {\n if (token === 'ho') {\n var hours = date.getUTCHours() % 12;\n if (hours === 0) hours = 12;\n return localize.ordinalNumber(hours, {\n unit: 'hour'\n });\n }\n\n return lightFormatters.h(date, token);\n },\n // Hour [0-23]\n H: function (date, token, localize) {\n if (token === 'Ho') {\n return localize.ordinalNumber(date.getUTCHours(), {\n unit: 'hour'\n });\n }\n\n return lightFormatters.H(date, token);\n },\n // Hour [0-11]\n K: function (date, token, localize) {\n var hours = date.getUTCHours() % 12;\n\n if (token === 'Ko') {\n return localize.ordinalNumber(hours, {\n unit: 'hour'\n });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n // Hour [1-24]\n k: function (date, token, localize) {\n var hours = date.getUTCHours();\n if (hours === 0) hours = 24;\n\n if (token === 'ko') {\n return localize.ordinalNumber(hours, {\n unit: 'hour'\n });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n // Minute\n m: function (date, token, localize) {\n if (token === 'mo') {\n return localize.ordinalNumber(date.getUTCMinutes(), {\n unit: 'minute'\n });\n }\n\n return lightFormatters.m(date, token);\n },\n // Second\n s: function (date, token, localize) {\n if (token === 'so') {\n return localize.ordinalNumber(date.getUTCSeconds(), {\n unit: 'second'\n });\n }\n\n return lightFormatters.s(date, token);\n },\n // Fraction of second\n S: function (date, token) {\n return lightFormatters.S(date, token);\n },\n // Timezone (ISO-8601. If offset is 0, output is always `'Z'`)\n X: function (date, token, _localize, options) {\n var originalDate = options._originalDate || date;\n var timezoneOffset = originalDate.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 // 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\n case 'XXXX':\n case 'XX':\n // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\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\n case 'XXXXX':\n case 'XXX': // Hours and minutes with `:` delimiter\n\n default:\n return formatTimezone(timezoneOffset, ':');\n }\n },\n // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent)\n x: function (date, token, _localize, options) {\n var originalDate = options._originalDate || date;\n var timezoneOffset = originalDate.getTimezoneOffset();\n\n switch (token) {\n // Hours and optional minutes\n case 'x':\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\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\n case 'xxxx':\n case 'xx':\n // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\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\n case 'xxxxx':\n case 'xxx': // Hours and minutes with `:` delimiter\n\n default:\n return formatTimezone(timezoneOffset, ':');\n }\n },\n // Timezone (GMT)\n O: function (date, token, _localize, options) {\n var originalDate = options._originalDate || date;\n var timezoneOffset = originalDate.getTimezoneOffset();\n\n switch (token) {\n // Short\n case 'O':\n case 'OO':\n case 'OOO':\n return 'GMT' + formatTimezoneShort(timezoneOffset, ':');\n // Long\n\n case 'OOOO':\n default:\n return 'GMT' + formatTimezone(timezoneOffset, ':');\n }\n },\n // Timezone (specific non-location)\n z: function (date, token, _localize, options) {\n var originalDate = options._originalDate || date;\n var timezoneOffset = originalDate.getTimezoneOffset();\n\n switch (token) {\n // Short\n case 'z':\n case 'zz':\n case 'zzz':\n return 'GMT' + formatTimezoneShort(timezoneOffset, ':');\n // Long\n\n case 'zzzz':\n default:\n return 'GMT' + formatTimezone(timezoneOffset, ':');\n }\n },\n // Seconds timestamp\n t: function (date, token, _localize, options) {\n var originalDate = options._originalDate || date;\n var timestamp = Math.floor(originalDate.getTime() / 1000);\n return addLeadingZeros(timestamp, token.length);\n },\n // Milliseconds timestamp\n T: function (date, token, _localize, options) {\n var originalDate = options._originalDate || date;\n var timestamp = originalDate.getTime();\n return addLeadingZeros(timestamp, token.length);\n }\n};\n\nfunction formatTimezoneShort(offset, dirtyDelimiter) {\n var sign = offset > 0 ? '-' : '+';\n var absOffset = Math.abs(offset);\n var hours = Math.floor(absOffset / 60);\n var minutes = absOffset % 60;\n\n if (minutes === 0) {\n return sign + String(hours);\n }\n\n var delimiter = dirtyDelimiter || '';\n return sign + String(hours) + delimiter + addLeadingZeros(minutes, 2);\n}\n\nfunction formatTimezoneWithOptionalMinutes(offset, dirtyDelimiter) {\n if (offset % 60 === 0) {\n var sign = offset > 0 ? '-' : '+';\n return sign + addLeadingZeros(Math.abs(offset) / 60, 2);\n }\n\n return formatTimezone(offset, dirtyDelimiter);\n}\n\nfunction formatTimezone(offset, dirtyDelimiter) {\n var delimiter = dirtyDelimiter || '';\n var sign = offset > 0 ? '-' : '+';\n var absOffset = Math.abs(offset);\n var hours = addLeadingZeros(Math.floor(absOffset / 60), 2);\n var minutes = addLeadingZeros(absOffset % 60, 2);\n return sign + hours + delimiter + minutes;\n}\n\nexport default formatters;","import isValid from \"../isValid/index.js\";\nimport defaultLocale from \"../locale/en-US/index.js\";\nimport subMilliseconds from \"../subMilliseconds/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport formatters from \"../_lib/format/formatters/index.js\";\nimport longFormatters from \"../_lib/format/longFormatters/index.js\";\nimport getTimezoneOffsetInMilliseconds from \"../_lib/getTimezoneOffsetInMilliseconds/index.js\";\nimport { isProtectedDayOfYearToken, isProtectedWeekYearToken, throwProtectedError } from \"../_lib/protectedTokens/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\"; // 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\n\nvar formattingTokensRegExp = /[yYQqMLwIdDecihHKkms]o|(\\w)\\1*|''|'(''|[^'])+('|$)|./g; // This RegExp catches symbols escaped by quotes, and also\n// sequences of symbols P, p, and the combinations like `PPPPPPPppppp`\n\nvar longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;\nvar escapedStringRegExp = /^'([^]*?)'?$/;\nvar doubleQuoteRegExp = /''/g;\nvar unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n/**\n * @name format\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://git.io/fxCyr\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]{@link https://date-fns.org/docs/getISOWeekYear}\n * and [getWeekYear]{@link 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://git.io/fxCyr\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://git.io/fxCyr\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * - The second argument is now required for the sake of explicitness.\n *\n * ```javascript\n * // Before v2.0.0\n * format(new Date(2016, 0, 1))\n *\n * // v2.0.0 onward\n * format(new Date(2016, 0, 1), \"yyyy-MM-dd'T'HH:mm:ss.SSSxxx\")\n * ```\n *\n * - New format string API for `format` function\n * which is based on [Unicode Technical Standard #35](https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table).\n * See [this post](https://blog.date-fns.org/post/unicode-tokens-in-date-fns-v2-sreatyki91jg) for more details.\n *\n * - Characters are now escaped using single quote symbols (`'`) instead of square brackets.\n *\n * @param {Date|Number} date - the original date\n * @param {String} format - the string of tokens\n * @param {Object} [options] - an object with options.\n * @param {Locale} [options.locale=defaultLocale] - the locale object. See [Locale]{@link https://date-fns.org/docs/Locale}\n * @param {0|1|2|3|4|5|6} [options.weekStartsOn=0] - the index of the first day of the week (0 - Sunday)\n * @param {Number} [options.firstWeekContainsDate=1] - the day of January, which is\n * @param {Boolean} [options.useAdditionalWeekYearTokens=false] - if true, allows usage of the week-numbering year tokens `YY` and `YYYY`;\n * see: https://git.io/fxCyr\n * @param {Boolean} [options.useAdditionalDayOfYearTokens=false] - if true, allows usage of the day of year tokens `D` and `DD`;\n * see: https://git.io/fxCyr\n * @returns {String} the formatted date string\n * @throws {TypeError} 2 arguments required\n * @throws {RangeError} `date` must not be Invalid Date\n * @throws {RangeError} `options.locale` must contain `localize` property\n * @throws {RangeError} `options.locale` must contain `formatLong` property\n * @throws {RangeError} `options.weekStartsOn` must be between 0 and 6\n * @throws {RangeError} `options.firstWeekContainsDate` must be between 1 and 7\n * @throws {RangeError} use `yyyy` instead of `YYYY` for formatting years using [format provided] to the input [input provided]; see: https://git.io/fxCyr\n * @throws {RangeError} use `yy` instead of `YY` for formatting years using [format provided] to the input [input provided]; see: https://git.io/fxCyr\n * @throws {RangeError} use `d` instead of `D` for formatting days of the month using [format provided] to the input [input provided]; see: https://git.io/fxCyr\n * @throws {RangeError} use `dd` instead of `DD` for formatting days of the month using [format provided] to the input [input provided]; see: https://git.io/fxCyr\n * @throws {RangeError} format string contains an unescaped latin alphabet character\n *\n * @example\n * // Represent 11 February 2014 in middle-endian format:\n * var 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 * var 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 * var result = format(new Date(2014, 6, 2, 15), \"h 'o''clock'\")\n * //=> \"3 o'clock\"\n */\n\nexport default function format(dirtyDate, dirtyFormatStr, dirtyOptions) {\n requiredArgs(2, arguments);\n var formatStr = String(dirtyFormatStr);\n var options = dirtyOptions || {};\n var locale = options.locale || defaultLocale;\n var localeFirstWeekContainsDate = locale.options && locale.options.firstWeekContainsDate;\n var defaultFirstWeekContainsDate = localeFirstWeekContainsDate == null ? 1 : toInteger(localeFirstWeekContainsDate);\n var firstWeekContainsDate = options.firstWeekContainsDate == null ? defaultFirstWeekContainsDate : toInteger(options.firstWeekContainsDate); // Test if weekStartsOn is between 1 and 7 _and_ is not NaN\n\n if (!(firstWeekContainsDate >= 1 && firstWeekContainsDate <= 7)) {\n throw new RangeError('firstWeekContainsDate must be between 1 and 7 inclusively');\n }\n\n var localeWeekStartsOn = locale.options && locale.options.weekStartsOn;\n var defaultWeekStartsOn = localeWeekStartsOn == null ? 0 : toInteger(localeWeekStartsOn);\n var weekStartsOn = options.weekStartsOn == null ? defaultWeekStartsOn : toInteger(options.weekStartsOn); // Test if weekStartsOn is between 0 and 6 _and_ is not NaN\n\n if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {\n throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');\n }\n\n if (!locale.localize) {\n throw new RangeError('locale must contain localize property');\n }\n\n if (!locale.formatLong) {\n throw new RangeError('locale must contain formatLong property');\n }\n\n var originalDate = toDate(dirtyDate);\n\n if (!isValid(originalDate)) {\n throw new RangeError('Invalid time value');\n } // Convert the date in system timezone to the same date in UTC+00:00 timezone.\n // This ensures that when UTC functions will be implemented, locales will be compatible with them.\n // See an issue about UTC functions: https://github.com/date-fns/date-fns/issues/376\n\n\n var timezoneOffset = getTimezoneOffsetInMilliseconds(originalDate);\n var utcDate = subMilliseconds(originalDate, timezoneOffset);\n var formatterOptions = {\n firstWeekContainsDate: firstWeekContainsDate,\n weekStartsOn: weekStartsOn,\n locale: locale,\n _originalDate: originalDate\n };\n var result = formatStr.match(longFormattingTokensRegExp).map(function (substring) {\n var firstCharacter = substring[0];\n\n if (firstCharacter === 'p' || firstCharacter === 'P') {\n var longFormatter = longFormatters[firstCharacter];\n return longFormatter(substring, locale.formatLong, formatterOptions);\n }\n\n return substring;\n }).join('').match(formattingTokensRegExp).map(function (substring) {\n // Replace two single quote characters with one single quote character\n if (substring === \"''\") {\n return \"'\";\n }\n\n var firstCharacter = substring[0];\n\n if (firstCharacter === \"'\") {\n return cleanEscapedString(substring);\n }\n\n var formatter = formatters[firstCharacter];\n\n if (formatter) {\n if (!options.useAdditionalWeekYearTokens && isProtectedWeekYearToken(substring)) {\n throwProtectedError(substring, dirtyFormatStr, dirtyDate);\n }\n\n if (!options.useAdditionalDayOfYearTokens && isProtectedDayOfYearToken(substring)) {\n throwProtectedError(substring, dirtyFormatStr, dirtyDate);\n }\n\n return formatter(utcDate, substring, locale.localize, formatterOptions);\n }\n\n if (firstCharacter.match(unescapedLatinCharacterRegExp)) {\n throw new RangeError('Format string contains an unescaped latin alphabet character `' + firstCharacter + '`');\n }\n\n return substring;\n }).join('');\n return result;\n}\n\nfunction cleanEscapedString(input) {\n return input.match(escapedStringRegExp)[1].replace(doubleQuoteRegExp, \"'\");\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport addYears from \"../addYears/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name subYears\n * @category Year Helpers\n * @summary Subtract the specified number of years from the given date.\n *\n * @description\n * Subtract the specified number of years from the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of years to be subtracted. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the years subtracted\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Subtract 5 years from 1 September 2014:\n * const result = subYears(new Date(2014, 8, 1), 5)\n * //=> Tue Sep 01 2009 00:00:00\n */\n\nexport default function subYears(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var amount = toInteger(dirtyAmount);\n return addYears(dirtyDate, -amount);\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function startOfUTCISOWeek(dirtyDate) {\n requiredArgs(1, arguments);\n var weekStartsOn = 1;\n var date = toDate(dirtyDate);\n var day = date.getUTCDay();\n var diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n date.setUTCDate(date.getUTCDate() - diff);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name setSeconds\n * @category Second Helpers\n * @summary Set the seconds to the given date.\n *\n * @description\n * Set the seconds to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} seconds - the seconds of the new date\n * @returns {Date} the new date with the seconds set\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Set 45 seconds to 1 September 2014 11:30:40:\n * const result = setSeconds(new Date(2014, 8, 1, 11, 30, 40), 45)\n * //=> Mon Sep 01 2014 11:30:45\n */\n\nexport default function setSeconds(dirtyDate, dirtySeconds) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var seconds = toInteger(dirtySeconds);\n date.setSeconds(seconds);\n return date;\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name isEqual\n * @category Common Helpers\n * @summary Are the given dates equal?\n *\n * @description\n * Are the given dates equal?\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} dateLeft - the first date to compare\n * @param {Date|Number} dateRight - the second date to compare\n * @returns {Boolean} the dates are equal\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Are 2 July 2014 06:30:45.000 and 2 July 2014 06:30:45.500 equal?\n * var result = isEqual(\n * new Date(2014, 6, 2, 6, 30, 45, 0),\n * new Date(2014, 6, 2, 6, 30, 45, 500)\n * )\n * //=> false\n */\n\nexport default function isEqual(dirtyLeftDate, dirtyRightDate) {\n requiredArgs(2, arguments);\n var dateLeft = toDate(dirtyLeftDate);\n var dateRight = toDate(dirtyRightDate);\n return dateLeft.getTime() === dateRight.getTime();\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport addMonths from \"../addMonths/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name addYears\n * @category Year Helpers\n * @summary Add the specified number of years to the given date.\n *\n * @description\n * Add the specified number of years to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of years to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the years added\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Add 5 years to 1 September 2014:\n * const result = addYears(new Date(2014, 8, 1), 5)\n * //=> Sun Sep 01 2019 00:00:00\n */\n\nexport default function addYears(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var amount = toInteger(dirtyAmount);\n return addMonths(dirtyDate, amount * 12);\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name getHours\n * @category Hour Helpers\n * @summary Get the hours of the given date.\n *\n * @description\n * Get the hours of the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the given date\n * @returns {Number} the hours\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // Get the hours of 29 February 2012 11:45:00:\n * const result = getHours(new Date(2012, 1, 29, 11, 45))\n * //=> 11\n */\n\nexport default function getHours(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var hours = date.getHours();\n return hours;\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport toInteger from \"../toInteger/index.js\"; // This function will be a part of public API when UTC function will be implemented.\n// See issue: https://github.com/date-fns/date-fns/issues/376\n\nexport default function startOfUTCWeek(dirtyDate, dirtyOptions) {\n requiredArgs(1, arguments);\n var options = dirtyOptions || {};\n var locale = options.locale;\n var localeWeekStartsOn = locale && locale.options && locale.options.weekStartsOn;\n var defaultWeekStartsOn = localeWeekStartsOn == null ? 0 : toInteger(localeWeekStartsOn);\n var weekStartsOn = options.weekStartsOn == null ? defaultWeekStartsOn : toInteger(options.weekStartsOn); // Test if weekStartsOn is between 0 and 6 _and_ is not NaN\n\n if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {\n throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');\n }\n\n var date = toDate(dirtyDate);\n var day = date.getUTCDay();\n var diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n date.setUTCDate(date.getUTCDate() - diff);\n date.setUTCHours(0, 0, 0, 0);\n return date;\n}","var protectedDayOfYearTokens = ['D', 'DD'];\nvar protectedWeekYearTokens = ['YY', 'YYYY'];\nexport function isProtectedDayOfYearToken(token) {\n return protectedDayOfYearTokens.indexOf(token) !== -1;\n}\nexport function isProtectedWeekYearToken(token) {\n return protectedWeekYearTokens.indexOf(token) !== -1;\n}\nexport function throwProtectedError(token, format, input) {\n if (token === 'YYYY') {\n throw new RangeError(\"Use `yyyy` instead of `YYYY` (in `\".concat(format, \"`) for formatting years to the input `\").concat(input, \"`; see: https://git.io/fxCyr\"));\n } else if (token === 'YY') {\n throw new RangeError(\"Use `yy` instead of `YY` (in `\".concat(format, \"`) for formatting years to the input `\").concat(input, \"`; see: https://git.io/fxCyr\"));\n } else if (token === 'D') {\n throw new RangeError(\"Use `d` instead of `D` (in `\".concat(format, \"`) for formatting days of the month to the input `\").concat(input, \"`; see: https://git.io/fxCyr\"));\n } else if (token === 'DD') {\n throw new RangeError(\"Use `dd` instead of `DD` (in `\".concat(format, \"`) for formatting days of the month to the input `\").concat(input, \"`; see: https://git.io/fxCyr\"));\n }\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name getMinutes\n * @category Minute Helpers\n * @summary Get the minutes of the given date.\n *\n * @description\n * Get the minutes of the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the given date\n * @returns {Number} the minutes\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // Get the minutes of 29 February 2012 11:45:05:\n * const result = getMinutes(new Date(2012, 1, 29, 11, 45, 5))\n * //=> 45\n */\n\nexport default function getMinutes(dirtyDate) {\n requiredArgs(1, arguments);\n var date = toDate(dirtyDate);\n var minutes = date.getMinutes();\n return minutes;\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name setMinutes\n * @category Minute Helpers\n * @summary Set the minutes to the given date.\n *\n * @description\n * Set the minutes to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} minutes - the minutes of the new date\n * @returns {Date} the new date with the minutes set\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Set 45 minutes to 1 September 2014 11:30:40:\n * const result = setMinutes(new Date(2014, 8, 1, 11, 30, 40), 45)\n * //=> Mon Sep 01 2014 11:45:40\n */\n\nexport default function setMinutes(dirtyDate, dirtyMinutes) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var minutes = toInteger(dirtyMinutes);\n date.setMinutes(minutes);\n return date;\n}","/**\n * Days in 1 week.\n *\n * @name daysInWeek\n * @constant\n * @type {number}\n * @default\n */\nexport var daysInWeek = 7;\n/**\n * Maximum allowed time.\n *\n * @name maxTime\n * @constant\n * @type {number}\n * @default\n */\n\nexport var maxTime = Math.pow(10, 8) * 24 * 60 * 60 * 1000;\n/**\n * Milliseconds in 1 minute\n *\n * @name millisecondsInMinute\n * @constant\n * @type {number}\n * @default\n */\n\nexport var millisecondsInMinute = 60000;\n/**\n * Milliseconds in 1 hour\n *\n * @name millisecondsInHour\n * @constant\n * @type {number}\n * @default\n */\n\nexport var millisecondsInHour = 3600000;\n/**\n * Milliseconds in 1 second\n *\n * @name millisecondsInSecond\n * @constant\n * @type {number}\n * @default\n */\n\nexport var millisecondsInSecond = 1000;\n/**\n * Minimum allowed time.\n *\n * @name minTime\n * @constant\n * @type {number}\n * @default\n */\n\nexport var minTime = -maxTime;\n/**\n * Minutes in 1 hour\n *\n * @name minutesInHour\n * @constant\n * @type {number}\n * @default\n */\n\nexport var minutesInHour = 60;\n/**\n * Months in 1 quarter\n *\n * @name monthsInQuarter\n * @constant\n * @type {number}\n * @default\n */\n\nexport var monthsInQuarter = 3;\n/**\n * Months in 1 year\n *\n * @name monthsInYear\n * @constant\n * @type {number}\n * @default\n */\n\nexport var monthsInYear = 12;\n/**\n * Quarters in 1 year\n *\n * @name quartersInYear\n * @constant\n * @type {number}\n * @default\n */\n\nexport var quartersInYear = 4;\n/**\n * Seconds in 1 hour\n *\n * @name secondsInHour\n * @constant\n * @type {number}\n * @default\n */\n\nexport var secondsInHour = 3600;\n/**\n * Seconds in 1 minute\n *\n * @name secondsInMinute\n * @constant\n * @type {number}\n * @default\n */\n\nexport var secondsInMinute = 60;","import { millisecondsInHour, millisecondsInMinute } from \"../constants/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\n/**\n * @name parseISO\n * @category Common Helpers\n * @summary Parse ISO string\n *\n * @description\n * Parse the given string in ISO 8601 format and return an instance of Date.\n *\n * Function accepts complete ISO 8601 formats as well as partial implementations.\n * ISO 8601: http://en.wikipedia.org/wiki/ISO_8601\n *\n * If the argument isn't a string, the function cannot parse the string or\n * the values are invalid, it returns Invalid Date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * - The previous `parse` implementation was renamed to `parseISO`.\n *\n * ```javascript\n * // Before v2.0.0\n * parse('2016-01-01')\n *\n * // v2.0.0 onward\n * parseISO('2016-01-01')\n * ```\n *\n * - `parseISO` now validates separate date and time values in ISO-8601 strings\n * and returns `Invalid Date` if the date is invalid.\n *\n * ```javascript\n * parseISO('2018-13-32')\n * //=> Invalid Date\n * ```\n *\n * - `parseISO` now doesn't fall back to `new Date` constructor\n * if it fails to parse a string argument. Instead, it returns `Invalid Date`.\n *\n * @param {String} argument - the value to convert\n * @param {Object} [options] - an object with options.\n * @param {0|1|2} [options.additionalDigits=2] - the additional number of digits in the extended year format\n * @returns {Date} the parsed date in the local time zone\n * @throws {TypeError} 1 argument required\n * @throws {RangeError} `options.additionalDigits` must be 0, 1 or 2\n *\n * @example\n * // Convert string '2014-02-11T11:30:30' to date:\n * const result = parseISO('2014-02-11T11:30:30')\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert string '+02014101' to date,\n * // if the additional number of digits in the extended year format is 1:\n * const result = parseISO('+02014101', { additionalDigits: 1 })\n * //=> Fri Apr 11 2014 00:00:00\n */\n\nexport default function parseISO(argument, dirtyOptions) {\n requiredArgs(1, arguments);\n var options = dirtyOptions || {};\n var additionalDigits = options.additionalDigits == null ? 2 : toInteger(options.additionalDigits);\n\n if (additionalDigits !== 2 && additionalDigits !== 1 && additionalDigits !== 0) {\n throw new RangeError('additionalDigits must be 0, 1 or 2');\n }\n\n if (!(typeof argument === 'string' || Object.prototype.toString.call(argument) === '[object String]')) {\n return new Date(NaN);\n }\n\n var dateStrings = splitDateString(argument);\n var date;\n\n if (dateStrings.date) {\n var parseYearResult = parseYear(dateStrings.date, additionalDigits);\n date = parseDate(parseYearResult.restDateString, parseYearResult.year);\n }\n\n if (!date || isNaN(date.getTime())) {\n return new Date(NaN);\n }\n\n var timestamp = date.getTime();\n var time = 0;\n var offset;\n\n if (dateStrings.time) {\n time = parseTime(dateStrings.time);\n\n if (isNaN(time)) {\n return new Date(NaN);\n }\n }\n\n if (dateStrings.timezone) {\n offset = parseTimezone(dateStrings.timezone);\n\n if (isNaN(offset)) {\n return new Date(NaN);\n }\n } else {\n var dirtyDate = new Date(timestamp + time); // js parsed string assuming it's in UTC timezone\n // but we need it to be parsed in our timezone\n // so we use utc values to build date in our timezone.\n // Year values from 0 to 99 map to the years 1900 to 1999\n // so set year explicitly with setFullYear.\n\n var result = new Date(0);\n result.setFullYear(dirtyDate.getUTCFullYear(), dirtyDate.getUTCMonth(), dirtyDate.getUTCDate());\n result.setHours(dirtyDate.getUTCHours(), dirtyDate.getUTCMinutes(), dirtyDate.getUTCSeconds(), dirtyDate.getUTCMilliseconds());\n return result;\n }\n\n return new Date(timestamp + time + offset);\n}\nvar patterns = {\n dateTimeDelimiter: /[T ]/,\n timeZoneDelimiter: /[Z ]/i,\n timezone: /([Z+-].*)$/\n};\nvar dateRegex = /^-?(?:(\\d{3})|(\\d{2})(?:-?(\\d{2}))?|W(\\d{2})(?:-?(\\d{1}))?|)$/;\nvar timeRegex = /^(\\d{2}(?:[.,]\\d*)?)(?::?(\\d{2}(?:[.,]\\d*)?))?(?::?(\\d{2}(?:[.,]\\d*)?))?$/;\nvar timezoneRegex = /^([+-])(\\d{2})(?::?(\\d{2}))?$/;\n\nfunction splitDateString(dateString) {\n var dateStrings = {};\n var array = dateString.split(patterns.dateTimeDelimiter);\n var timeString; // The regex match should only return at maximum two array elements.\n // [date], [time], or [date, time].\n\n if (array.length > 2) {\n return dateStrings;\n }\n\n if (/:/.test(array[0])) {\n timeString = array[0];\n } else {\n dateStrings.date = array[0];\n timeString = array[1];\n\n if (patterns.timeZoneDelimiter.test(dateStrings.date)) {\n dateStrings.date = dateString.split(patterns.timeZoneDelimiter)[0];\n timeString = dateString.substr(dateStrings.date.length, dateString.length);\n }\n }\n\n if (timeString) {\n var token = patterns.timezone.exec(timeString);\n\n if (token) {\n dateStrings.time = timeString.replace(token[1], '');\n dateStrings.timezone = token[1];\n } else {\n dateStrings.time = timeString;\n }\n }\n\n return dateStrings;\n}\n\nfunction parseYear(dateString, additionalDigits) {\n var regex = new RegExp('^(?:(\\\\d{4}|[+-]\\\\d{' + (4 + additionalDigits) + '})|(\\\\d{2}|[+-]\\\\d{' + (2 + additionalDigits) + '})$)');\n var captures = dateString.match(regex); // Invalid ISO-formatted year\n\n if (!captures) return {\n year: NaN,\n restDateString: ''\n };\n var year = captures[1] ? parseInt(captures[1]) : null;\n var century = captures[2] ? parseInt(captures[2]) : null; // either year or century is null, not both\n\n return {\n year: century === null ? year : century * 100,\n restDateString: dateString.slice((captures[1] || captures[2]).length)\n };\n}\n\nfunction parseDate(dateString, year) {\n // Invalid ISO-formatted year\n if (year === null) return new Date(NaN);\n var captures = dateString.match(dateRegex); // Invalid ISO-formatted string\n\n if (!captures) return new Date(NaN);\n var isWeekDate = !!captures[4];\n var dayOfYear = parseDateUnit(captures[1]);\n var month = parseDateUnit(captures[2]) - 1;\n var day = parseDateUnit(captures[3]);\n var week = parseDateUnit(captures[4]);\n var dayOfWeek = parseDateUnit(captures[5]) - 1;\n\n if (isWeekDate) {\n if (!validateWeekDate(year, week, dayOfWeek)) {\n return new Date(NaN);\n }\n\n return dayOfISOWeekYear(year, week, dayOfWeek);\n } else {\n var date = new Date(0);\n\n if (!validateDate(year, month, day) || !validateDayOfYearDate(year, dayOfYear)) {\n return new Date(NaN);\n }\n\n date.setUTCFullYear(year, month, Math.max(dayOfYear, day));\n return date;\n }\n}\n\nfunction parseDateUnit(value) {\n return value ? parseInt(value) : 1;\n}\n\nfunction parseTime(timeString) {\n var captures = timeString.match(timeRegex);\n if (!captures) return NaN; // Invalid ISO-formatted time\n\n var hours = parseTimeUnit(captures[1]);\n var minutes = parseTimeUnit(captures[2]);\n var seconds = parseTimeUnit(captures[3]);\n\n if (!validateTime(hours, minutes, seconds)) {\n return NaN;\n }\n\n return hours * millisecondsInHour + minutes * millisecondsInMinute + seconds * 1000;\n}\n\nfunction parseTimeUnit(value) {\n return value && parseFloat(value.replace(',', '.')) || 0;\n}\n\nfunction parseTimezone(timezoneString) {\n if (timezoneString === 'Z') return 0;\n var captures = timezoneString.match(timezoneRegex);\n if (!captures) return 0;\n var sign = captures[1] === '+' ? -1 : 1;\n var hours = parseInt(captures[2]);\n var minutes = captures[3] && parseInt(captures[3]) || 0;\n\n if (!validateTimezone(hours, minutes)) {\n return NaN;\n }\n\n return sign * (hours * millisecondsInHour + minutes * millisecondsInMinute);\n}\n\nfunction dayOfISOWeekYear(isoWeekYear, week, day) {\n var date = new Date(0);\n date.setUTCFullYear(isoWeekYear, 0, 4);\n var fourthOfJanuaryDay = date.getUTCDay() || 7;\n var diff = (week - 1) * 7 + day + 1 - fourthOfJanuaryDay;\n date.setUTCDate(date.getUTCDate() + diff);\n return date;\n} // Validation functions\n// February is null to handle the leap year (using ||)\n\n\nvar daysInMonths = [31, null, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\n\nfunction isLeapYearIndex(year) {\n return year % 400 === 0 || year % 4 === 0 && year % 100 !== 0;\n}\n\nfunction validateDate(year, month, date) {\n return month >= 0 && month <= 11 && date >= 1 && date <= (daysInMonths[month] || (isLeapYearIndex(year) ? 29 : 28));\n}\n\nfunction validateDayOfYearDate(year, dayOfYear) {\n return dayOfYear >= 1 && dayOfYear <= (isLeapYearIndex(year) ? 366 : 365);\n}\n\nfunction validateWeekDate(_year, week, day) {\n return week >= 1 && week <= 53 && day >= 0 && day <= 6;\n}\n\nfunction validateTime(hours, minutes, seconds) {\n if (hours === 24) {\n return minutes === 0 && seconds === 0;\n }\n\n return seconds >= 0 && seconds < 60 && minutes >= 0 && minutes < 60 && hours >= 0 && hours < 25;\n}\n\nfunction validateTimezone(_hours, minutes) {\n return minutes >= 0 && minutes <= 59;\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name setYear\n * @category Year Helpers\n * @summary Set the year to the given date.\n *\n * @description\n * Set the year to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} year - the year of the new date\n * @returns {Date} the new date with the year set\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Set year 2013 to 1 September 2014:\n * const result = setYear(new Date(2014, 8, 1), 2013)\n * //=> Sun Sep 01 2013 00:00:00\n */\n\nexport default function setYear(dirtyDate, dirtyYear) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var year = toInteger(dirtyYear); // Check if date is Invalid Date because Date.prototype.setFullYear ignores the value of Invalid Date\n\n if (isNaN(date.getTime())) {\n return new Date(NaN);\n }\n\n date.setFullYear(year);\n return date;\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport addDays from \"../addDays/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name subDays\n * @category Day Helpers\n * @summary Subtract the specified number of days from the given date.\n *\n * @description\n * Subtract the specified number of days from the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of days to be subtracted. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the days subtracted\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Subtract 10 days from 1 September 2014:\n * const result = subDays(new Date(2014, 8, 1), 10)\n * //=> Fri Aug 22 2014 00:00:00\n */\n\nexport default function subDays(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var amount = toInteger(dirtyAmount);\n return addDays(dirtyDate, -amount);\n}","import subDays from \"../subDays/index.js\";\nimport subMonths from \"../subMonths/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\n/**\n * @name sub\n * @category Common Helpers\n * @summary Subtract the specified years, months, weeks, days, hours, minutes and seconds from the given date.\n *\n * @description\n * Subtract the specified years, months, weeks, days, hours, minutes and seconds from the given date.\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Duration} duration - the object with years, months, weeks, days, hours, minutes and seconds to be subtracted\n *\n * | Key | Description |\n * |---------|------------------------------------|\n * | years | Amount of years to be subtracted |\n * | months | Amount of months to be subtracted |\n * | weeks | Amount of weeks to be subtracted |\n * | days | Amount of days to be subtracted |\n * | hours | Amount of hours to be subtracted |\n * | minutes | Amount of minutes to be subtracted |\n * | seconds | Amount of seconds to be subtracted |\n *\n * All values default to 0\n *\n * @returns {Date} the new date with the seconds subtracted\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Subtract the following duration from 15 June 2017 15:29:20\n * const result = sub(new Date(2017, 5, 15, 15, 29, 20), {\n * years: 2,\n * months: 9,\n * weeks: 1,\n * days: 7,\n * hours: 5,\n * minutes: 9,\n * seconds: 30\n * })\n * //=> Mon Sep 1 2014 10:19:50\n */\n\nexport default function sub(date, duration) {\n requiredArgs(2, arguments);\n if (!duration || typeof duration !== 'object') return new Date(NaN);\n var years = duration.years ? toInteger(duration.years) : 0;\n var months = duration.months ? toInteger(duration.months) : 0;\n var weeks = duration.weeks ? toInteger(duration.weeks) : 0;\n var days = duration.days ? toInteger(duration.days) : 0;\n var hours = duration.hours ? toInteger(duration.hours) : 0;\n var minutes = duration.minutes ? toInteger(duration.minutes) : 0;\n var seconds = duration.seconds ? toInteger(duration.seconds) : 0; // Subtract years and months\n\n var dateWithoutMonths = subMonths(date, months + years * 12); // Subtract weeks and days\n\n var dateWithoutDays = subDays(dateWithoutMonths, days + weeks * 7); // Subtract hours, minutes and seconds\n\n var minutestoSub = minutes + hours * 60;\n var secondstoSub = seconds + minutestoSub * 60;\n var mstoSub = secondstoSub * 1000;\n var finalDate = new Date(dateWithoutDays.getTime() - mstoSub);\n return finalDate;\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name addDays\n * @category Day Helpers\n * @summary Add the specified number of days to the given date.\n *\n * @description\n * Add the specified number of days to the given date.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of days to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} - the new date with the days added\n * @throws {TypeError} - 2 arguments required\n *\n * @example\n * // Add 10 days to 1 September 2014:\n * const result = addDays(new Date(2014, 8, 1), 10)\n * //=> Thu Sep 11 2014 00:00:00\n */\n\nexport default function addDays(dirtyDate, dirtyAmount) {\n requiredArgs(2, arguments);\n var date = toDate(dirtyDate);\n var amount = toInteger(dirtyAmount);\n\n if (isNaN(amount)) {\n return new Date(NaN);\n }\n\n if (!amount) {\n // If 0 days, no-op to avoid changing times in the hour before end of DST\n return date;\n }\n\n date.setDate(date.getDate() + amount);\n return date;\n}","import requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name toDate\n * @category Common Helpers\n * @summary Convert the given argument to an instance of Date.\n *\n * @description\n * Convert the given argument to an instance of Date.\n *\n * If the argument is an instance of Date, the function returns its clone.\n *\n * If the argument is a number, it is treated as a timestamp.\n *\n * If the argument is none of the above, the function returns Invalid Date.\n *\n * **Note**: *all* Date arguments passed to any *date-fns* function is processed by `toDate`.\n *\n * @param {Date|Number} argument - the value to convert\n * @returns {Date} the parsed date in the local time zone\n * @throws {TypeError} 1 argument required\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 */\n\nexport default function toDate(argument) {\n requiredArgs(1, arguments);\n var argStr = Object.prototype.toString.call(argument); // Clone the date\n\n if (argument instanceof Date || typeof argument === 'object' && argStr === '[object Date]') {\n // Prevent the date to lose the milliseconds when passed to new Date() in IE10\n return new Date(argument.getTime());\n } else if (typeof argument === 'number' || argStr === '[object Number]') {\n return new Date(argument);\n } else {\n if ((typeof argument === 'string' || argStr === '[object String]') && typeof console !== 'undefined') {\n // eslint-disable-next-line no-console\n console.warn(\"Starting with v2.0.0-beta.1 date-fns doesn't accept strings as date arguments. Please use `parseISO` to parse strings. See: https://git.io/fjule\"); // eslint-disable-next-line no-console\n\n console.warn(new Error().stack);\n }\n\n return new Date(NaN);\n }\n}","export default function toInteger(dirtyNumber) {\n if (dirtyNumber === null || dirtyNumber === true || dirtyNumber === false) {\n return NaN;\n }\n\n var number = Number(dirtyNumber);\n\n if (isNaN(number)) {\n return number;\n }\n\n return number < 0 ? Math.ceil(number) : Math.floor(number);\n}","import toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name eachDayOfInterval\n * @category Interval Helpers\n * @summary Return the array of dates within the specified time interval.\n *\n * @description\n * Return the array of dates within the specified time interval.\n *\n * ### v2.0.0 breaking changes:\n *\n * - [Changes that are common for the whole library](https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#Common-Changes).\n *\n * - The function was renamed from `eachDay` to `eachDayOfInterval`.\n * This change was made to mirror the use of the word \"interval\" in standard ISO 8601:2004 terminology:\n *\n * ```\n * 2.1.3\n * time interval\n * part of the time axis limited by two instants\n * ```\n *\n * Also, this function now accepts an object with `start` and `end` properties\n * instead of two arguments as an interval.\n * This function now throws `RangeError` if the start of the interval is after its end\n * or if any date in the interval is `Invalid Date`.\n *\n * ```javascript\n * // Before v2.0.0\n *\n * eachDay(new Date(2014, 0, 10), new Date(2014, 0, 20))\n *\n * // v2.0.0 onward\n *\n * eachDayOfInterval(\n * { start: new Date(2014, 0, 10), end: new Date(2014, 0, 20) }\n * )\n * ```\n *\n * @param {Interval} interval - the interval. See [Interval]{@link https://date-fns.org/docs/Interval}\n * @param {Object} [options] - an object with options.\n * @param {Number} [options.step=1] - the step to increment by. The value should be more than 1.\n * @returns {Date[]} the array with starts of days from the day of the interval start to the day of the interval end\n * @throws {TypeError} 1 argument required\n * @throws {RangeError} `options.step` must be a number greater than 1\n * @throws {RangeError} The start of an interval cannot be after its end\n * @throws {RangeError} Date in interval cannot be `Invalid Date`\n *\n * @example\n * // Each day between 6 October 2014 and 10 October 2014:\n * const result = eachDayOfInterval({\n * start: new Date(2014, 9, 6),\n * end: new Date(2014, 9, 10)\n * })\n * //=> [\n * // Mon Oct 06 2014 00:00:00,\n * // Tue Oct 07 2014 00:00:00,\n * // Wed Oct 08 2014 00:00:00,\n * // Thu Oct 09 2014 00:00:00,\n * // Fri Oct 10 2014 00:00:00\n * // ]\n */\n\nexport default function eachDayOfInterval(dirtyInterval, options) {\n requiredArgs(1, arguments);\n var interval = dirtyInterval || {};\n var startDate = toDate(interval.start);\n var endDate = toDate(interval.end);\n var endTime = endDate.getTime(); // Throw an exception if start date is after end date or if any date is `Invalid Date`\n\n if (!(startDate.getTime() <= endTime)) {\n throw new RangeError('Invalid interval');\n }\n\n var dates = [];\n var currentDate = startDate;\n currentDate.setHours(0, 0, 0, 0);\n var step = options && 'step' in options ? Number(options.step) : 1;\n if (step < 1 || isNaN(step)) throw new RangeError('`options.step` must be a number greater than 1');\n\n while (currentDate.getTime() <= endTime) {\n dates.push(toDate(currentDate));\n currentDate.setDate(currentDate.getDate() + step);\n currentDate.setHours(0, 0, 0, 0);\n }\n\n return dates;\n}"],"sourceRoot":""}