{"version":3,"file":"static/chunks/336-b949d42cff92ecdc.js","mappings":"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","sources":["webpack://_N_E/./node_modules/chartjs-plugin-zoom/dist/chartjs-plugin-zoom.esm.js","webpack://_N_E/./node_modules/hammerjs/hammer.js","webpack://_N_E/./node_modules/next/dist/api/image.js","webpack://_N_E/../../../src/shared/lib/image-external.tsx","webpack://_N_E/./node_modules/@kurkle/color/dist/color.esm.js","webpack://_N_E/./node_modules/chart.js/dist/chunks/helpers.segment.js","webpack://_N_E/./node_modules/date-fns/getDefaultOptions.mjs","webpack://_N_E/./node_modules/date-fns/transpose.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/Setter.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/Parser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/EraParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/constants.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/utils.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/YearParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/LocalWeekYearParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/ISOWeekYearParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/ExtendedYearParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/QuarterParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/StandAloneQuarterParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/MonthParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/StandAloneMonthParser.mjs","webpack://_N_E/./node_modules/date-fns/setWeek.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/LocalWeekParser.mjs","webpack://_N_E/./node_modules/date-fns/setISOWeek.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/ISOWeekParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/DateParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/DayOfYearParser.mjs","webpack://_N_E/./node_modules/date-fns/addDays.mjs","webpack://_N_E/./node_modules/date-fns/setDay.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/DayParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/LocalDayParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/StandAloneLocalDayParser.mjs","webpack://_N_E/./node_modules/date-fns/getISODay.mjs","webpack://_N_E/./node_modules/date-fns/setISODay.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/ISODayParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/AMPMParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/AMPMMidnightParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/DayPeriodParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/Hour1to12Parser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/Hour0to23Parser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/Hour0To11Parser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/Hour1To24Parser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/MinuteParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/SecondParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/FractionOfSecondParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/ISOTimezoneWithZParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/ISOTimezoneParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/TimestampSecondsParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers/TimestampMillisecondsParser.mjs","webpack://_N_E/./node_modules/date-fns/parse/_lib/parsers.mjs","webpack://_N_E/./node_modules/date-fns/parse.mjs","webpack://_N_E/./node_modules/date-fns/parseISO.mjs","webpack://_N_E/./node_modules/date-fns/addMilliseconds.mjs","webpack://_N_E/./node_modules/date-fns/addSeconds.mjs","webpack://_N_E/./node_modules/date-fns/addMinutes.mjs","webpack://_N_E/./node_modules/date-fns/addHours.mjs","webpack://_N_E/./node_modules/date-fns/addWeeks.mjs","webpack://_N_E/./node_modules/date-fns/addMonths.mjs","webpack://_N_E/./node_modules/date-fns/addQuarters.mjs","webpack://_N_E/./node_modules/date-fns/addYears.mjs","webpack://_N_E/./node_modules/date-fns/differenceInWeeks.mjs","webpack://_N_E/./node_modules/date-fns/differenceInQuarters.mjs","webpack://_N_E/./node_modules/date-fns/startOfSecond.mjs","webpack://_N_E/./node_modules/date-fns/startOfMinute.mjs","webpack://_N_E/./node_modules/date-fns/startOfHour.mjs","webpack://_N_E/./node_modules/date-fns/startOfMonth.mjs","webpack://_N_E/./node_modules/date-fns/startOfQuarter.mjs","webpack://_N_E/./node_modules/date-fns/endOfSecond.mjs","webpack://_N_E/./node_modules/date-fns/endOfMinute.mjs","webpack://_N_E/./node_modules/date-fns/endOfHour.mjs","webpack://_N_E/./node_modules/date-fns/endOfWeek.mjs","webpack://_N_E/./node_modules/date-fns/endOfQuarter.mjs","webpack://_N_E/./node_modules/date-fns/endOfYear.mjs","webpack://_N_E/./node_modules/chartjs-adapter-date-fns/dist/chartjs-adapter-date-fns.esm.js","webpack://_N_E/./node_modules/date-fns/_lib/defaultOptions.mjs","webpack://_N_E/./node_modules/date-fns/_lib/format/longFormatters.mjs","webpack://_N_E/./node_modules/date-fns/_lib/protectedTokens.mjs","webpack://_N_E/./node_modules/date-fns/constructFrom.mjs","webpack://_N_E/./node_modules/date-fns/getDayOfYear.mjs","webpack://_N_E/./node_modules/date-fns/_lib/addLeadingZeros.mjs","webpack://_N_E/./node_modules/date-fns/_lib/format/lightFormatters.mjs","webpack://_N_E/./node_modules/date-fns/_lib/format/formatters.mjs","webpack://_N_E/./node_modules/date-fns/format.mjs","webpack://_N_E/./node_modules/date-fns/startOfISOWeekYear.mjs","webpack://_N_E/./node_modules/date-fns/getISOWeek.mjs","webpack://_N_E/./node_modules/date-fns/getISOWeekYear.mjs","webpack://_N_E/./node_modules/date-fns/startOfWeekYear.mjs","webpack://_N_E/./node_modules/date-fns/getWeek.mjs","webpack://_N_E/./node_modules/date-fns/getWeekYear.mjs","webpack://_N_E/./node_modules/date-fns/isDate.mjs","webpack://_N_E/./node_modules/date-fns/isValid.mjs","webpack://_N_E/./node_modules/date-fns/locale/en-US/_lib/formatDistance.mjs","webpack://_N_E/./node_modules/date-fns/locale/_lib/buildFormatLongFn.mjs","webpack://_N_E/./node_modules/date-fns/locale/en-US/_lib/formatLong.mjs","webpack://_N_E/./node_modules/date-fns/locale/en-US/_lib/formatRelative.mjs","webpack://_N_E/./node_modules/date-fns/locale/_lib/buildLocalizeFn.mjs","webpack://_N_E/./node_modules/date-fns/locale/en-US/_lib/localize.mjs","webpack://_N_E/./node_modules/date-fns/locale/_lib/buildMatchFn.mjs","webpack://_N_E/./node_modules/date-fns/locale/_lib/buildMatchPatternFn.mjs","webpack://_N_E/./node_modules/date-fns/locale/en-US/_lib/match.mjs","webpack://_N_E/./node_modules/date-fns/locale/en-US.mjs","webpack://_N_E/./node_modules/date-fns/startOfISOWeek.mjs","webpack://_N_E/./node_modules/date-fns/startOfWeek.mjs","webpack://_N_E/./node_modules/date-fns/startOfYear.mjs"],"sourcesContent":["/*!\n* chartjs-plugin-zoom v2.0.1\n* undefined\n * (c) 2016-2023 chartjs-plugin-zoom Contributors\n * Released under the MIT License\n */\nimport Hammer from 'hammerjs';\nimport { each, valueOrDefault, callback, sign, getRelativePosition } from 'chart.js/helpers';\n\nconst getModifierKey = opts => opts && opts.enabled && opts.modifierKey;\nconst keyPressed = (key, event) => key && event[key + 'Key'];\nconst keyNotPressed = (key, event) => key && !event[key + 'Key'];\n\n/**\n * @param {string|function} mode can be 'x', 'y' or 'xy'\n * @param {string} dir can be 'x' or 'y'\n * @param {import('chart.js').Chart} chart instance of the chart in question\n * @returns {boolean}\n */\nfunction directionEnabled(mode, dir, chart) {\n if (mode === undefined) {\n return true;\n } else if (typeof mode === 'string') {\n return mode.indexOf(dir) !== -1;\n } else if (typeof mode === 'function') {\n return mode({chart}).indexOf(dir) !== -1;\n }\n\n return false;\n}\n\nfunction directionsEnabled(mode, chart) {\n if (typeof mode === 'function') {\n mode = mode({chart});\n }\n if (typeof mode === 'string') {\n return {x: mode.indexOf('x') !== -1, y: mode.indexOf('y') !== -1};\n }\n\n return {x: false, y: false};\n}\n\n/**\n * Debounces calling `fn` for `delay` ms\n * @param {function} fn - Function to call. No arguments are passed.\n * @param {number} delay - Delay in ms. 0 = immediate invocation.\n * @returns {function}\n */\nfunction debounce(fn, delay) {\n let timeout;\n return function() {\n clearTimeout(timeout);\n timeout = setTimeout(fn, delay);\n return delay;\n };\n}\n\n/**\n * Checks which axis is under the mouse cursor.\n * @param {{x: number, y: number}} point - the mouse location\n * @param {import('chart.js').Chart} [chart] instance of the chart in question\n * @return {import('chart.js').Scale}\n */\nfunction getScaleUnderPoint({x, y}, chart) {\n const scales = chart.scales;\n const scaleIds = Object.keys(scales);\n for (let i = 0; i < scaleIds.length; i++) {\n const scale = scales[scaleIds[i]];\n if (y >= scale.top && y <= scale.bottom && x >= scale.left && x <= scale.right) {\n return scale;\n }\n }\n return null;\n}\n\n/**\n * Evaluate the chart's mode, scaleMode, and overScaleMode properties to\n * determine which axes are eligible for scaling.\n * options.overScaleMode can be a function if user want zoom only one scale of many for example.\n * @param options - Zoom or pan options\n * @param {{x: number, y: number}} point - the mouse location\n * @param {import('chart.js').Chart} [chart] instance of the chart in question\n * @return {import('chart.js').Scale[]}\n */\nfunction getEnabledScalesByPoint(options, point, chart) {\n const {mode = 'xy', scaleMode, overScaleMode} = options || {};\n const scale = getScaleUnderPoint(point, chart);\n\n const enabled = directionsEnabled(mode, chart);\n const scaleEnabled = directionsEnabled(scaleMode, chart);\n\n // Convert deprecated overScaleEnabled to new scaleEnabled.\n if (overScaleMode) {\n const overScaleEnabled = directionsEnabled(overScaleMode, chart);\n for (const axis of ['x', 'y']) {\n if (overScaleEnabled[axis]) {\n scaleEnabled[axis] = enabled[axis];\n enabled[axis] = false;\n }\n }\n }\n\n if (scale && scaleEnabled[scale.axis]) {\n return [scale];\n }\n\n const enabledScales = [];\n each(chart.scales, function(scaleItem) {\n if (enabled[scaleItem.axis]) {\n enabledScales.push(scaleItem);\n }\n });\n return enabledScales;\n}\n\nconst chartStates = new WeakMap();\n\nfunction getState(chart) {\n let state = chartStates.get(chart);\n if (!state) {\n state = {\n originalScaleLimits: {},\n updatedScaleLimits: {},\n handlers: {},\n panDelta: {}\n };\n chartStates.set(chart, state);\n }\n return state;\n}\n\nfunction removeState(chart) {\n chartStates.delete(chart);\n}\n\nfunction zoomDelta(scale, zoom, center) {\n const range = scale.max - scale.min;\n const newRange = range * (zoom - 1);\n\n const centerPoint = scale.isHorizontal() ? center.x : center.y;\n // `scale.getValueForPixel()` can return a value less than the `scale.min` or\n // greater than `scale.max` when `centerPoint` is outside chartArea.\n const minPercent = Math.max(0, Math.min(1,\n (scale.getValueForPixel(centerPoint) - scale.min) / range || 0\n ));\n\n const maxPercent = 1 - minPercent;\n\n return {\n min: newRange * minPercent,\n max: newRange * maxPercent\n };\n}\n\nfunction getLimit(state, scale, scaleLimits, prop, fallback) {\n let limit = scaleLimits[prop];\n if (limit === 'original') {\n const original = state.originalScaleLimits[scale.id][prop];\n limit = valueOrDefault(original.options, original.scale);\n }\n return valueOrDefault(limit, fallback);\n}\n\nfunction getRange(scale, pixel0, pixel1) {\n const v0 = scale.getValueForPixel(pixel0);\n const v1 = scale.getValueForPixel(pixel1);\n return {\n min: Math.min(v0, v1),\n max: Math.max(v0, v1)\n };\n}\n\nfunction updateRange(scale, {min, max}, limits, zoom = false) {\n const state = getState(scale.chart);\n const {id, axis, options: scaleOpts} = scale;\n\n const scaleLimits = limits && (limits[id] || limits[axis]) || {};\n const {minRange = 0} = scaleLimits;\n const minLimit = getLimit(state, scale, scaleLimits, 'min', -Infinity);\n const maxLimit = getLimit(state, scale, scaleLimits, 'max', Infinity);\n\n const range = zoom ? Math.max(max - min, minRange) : scale.max - scale.min;\n const offset = (range - max + min) / 2;\n min -= offset;\n max += offset;\n\n if (min < minLimit) {\n min = minLimit;\n max = Math.min(minLimit + range, maxLimit);\n } else if (max > maxLimit) {\n max = maxLimit;\n min = Math.max(maxLimit - range, minLimit);\n }\n scaleOpts.min = min;\n scaleOpts.max = max;\n\n state.updatedScaleLimits[scale.id] = {min, max};\n\n // return true if the scale range is changed\n return scale.parse(min) !== scale.min || scale.parse(max) !== scale.max;\n}\n\nfunction zoomNumericalScale(scale, zoom, center, limits) {\n const delta = zoomDelta(scale, zoom, center);\n const newRange = {min: scale.min + delta.min, max: scale.max - delta.max};\n return updateRange(scale, newRange, limits, true);\n}\n\nfunction zoomRectNumericalScale(scale, from, to, limits) {\n updateRange(scale, getRange(scale, from, to), limits, true);\n}\n\nconst integerChange = (v) => v === 0 || isNaN(v) ? 0 : v < 0 ? Math.min(Math.round(v), -1) : Math.max(Math.round(v), 1);\n\nfunction existCategoryFromMaxZoom(scale) {\n const labels = scale.getLabels();\n const maxIndex = labels.length - 1;\n\n if (scale.min > 0) {\n scale.min -= 1;\n }\n if (scale.max < maxIndex) {\n scale.max += 1;\n }\n}\n\nfunction zoomCategoryScale(scale, zoom, center, limits) {\n const delta = zoomDelta(scale, zoom, center);\n if (scale.min === scale.max && zoom < 1) {\n existCategoryFromMaxZoom(scale);\n }\n const newRange = {min: scale.min + integerChange(delta.min), max: scale.max - integerChange(delta.max)};\n return updateRange(scale, newRange, limits, true);\n}\n\nfunction scaleLength(scale) {\n return scale.isHorizontal() ? scale.width : scale.height;\n}\n\nfunction panCategoryScale(scale, delta, limits) {\n const labels = scale.getLabels();\n const lastLabelIndex = labels.length - 1;\n let {min, max} = scale;\n // The visible range. Ticks can be skipped, and thus not reliable.\n const range = Math.max(max - min, 1);\n // How many pixels of delta is required before making a step. stepSize, but limited to max 1/10 of the scale length.\n const stepDelta = Math.round(scaleLength(scale) / Math.max(range, 10));\n const stepSize = Math.round(Math.abs(delta / stepDelta));\n let applied;\n if (delta < -stepDelta) {\n max = Math.min(max + stepSize, lastLabelIndex);\n min = range === 1 ? max : max - range;\n applied = max === lastLabelIndex;\n } else if (delta > stepDelta) {\n min = Math.max(0, min - stepSize);\n max = range === 1 ? min : min + range;\n applied = min === 0;\n }\n\n return updateRange(scale, {min, max}, limits) || applied;\n}\n\nconst OFFSETS = {\n second: 500, // 500 ms\n minute: 30 * 1000, // 30 s\n hour: 30 * 60 * 1000, // 30 m\n day: 12 * 60 * 60 * 1000, // 12 h\n week: 3.5 * 24 * 60 * 60 * 1000, // 3.5 d\n month: 15 * 24 * 60 * 60 * 1000, // 15 d\n quarter: 60 * 24 * 60 * 60 * 1000, // 60 d\n year: 182 * 24 * 60 * 60 * 1000 // 182 d\n};\n\nfunction panNumericalScale(scale, delta, limits, canZoom = false) {\n const {min: prevStart, max: prevEnd, options} = scale;\n const round = options.time && options.time.round;\n const offset = OFFSETS[round] || 0;\n const newMin = scale.getValueForPixel(scale.getPixelForValue(prevStart + offset) - delta);\n const newMax = scale.getValueForPixel(scale.getPixelForValue(prevEnd + offset) - delta);\n const {min: minLimit = -Infinity, max: maxLimit = Infinity} = canZoom && limits && limits[scale.axis] || {};\n if (isNaN(newMin) || isNaN(newMax) || newMin < minLimit || newMax > maxLimit) {\n // At limit: No change but return true to indicate no need to store the delta.\n // NaN can happen for 0-dimension scales (either because they were configured\n // with min === max or because the chart has 0 plottable area).\n return true;\n }\n return updateRange(scale, {min: newMin, max: newMax}, limits, canZoom);\n}\n\nfunction panNonLinearScale(scale, delta, limits) {\n return panNumericalScale(scale, delta, limits, true);\n}\n\nconst zoomFunctions = {\n category: zoomCategoryScale,\n default: zoomNumericalScale,\n};\n\nconst zoomRectFunctions = {\n default: zoomRectNumericalScale,\n};\n\nconst panFunctions = {\n category: panCategoryScale,\n default: panNumericalScale,\n logarithmic: panNonLinearScale,\n timeseries: panNonLinearScale,\n};\n\nfunction shouldUpdateScaleLimits(scale, originalScaleLimits, updatedScaleLimits) {\n const {id, options: {min, max}} = scale;\n if (!originalScaleLimits[id] || !updatedScaleLimits[id]) {\n return true;\n }\n const previous = updatedScaleLimits[id];\n return previous.min !== min || previous.max !== max;\n}\n\nfunction removeMissingScales(limits, scales) {\n each(limits, (opt, key) => {\n if (!scales[key]) {\n delete limits[key];\n }\n });\n}\n\nfunction storeOriginalScaleLimits(chart, state) {\n const {scales} = chart;\n const {originalScaleLimits, updatedScaleLimits} = state;\n\n each(scales, function(scale) {\n if (shouldUpdateScaleLimits(scale, originalScaleLimits, updatedScaleLimits)) {\n originalScaleLimits[scale.id] = {\n min: {scale: scale.min, options: scale.options.min},\n max: {scale: scale.max, options: scale.options.max},\n };\n }\n });\n\n removeMissingScales(originalScaleLimits, scales);\n removeMissingScales(updatedScaleLimits, scales);\n return originalScaleLimits;\n}\n\nfunction doZoom(scale, amount, center, limits) {\n const fn = zoomFunctions[scale.type] || zoomFunctions.default;\n callback(fn, [scale, amount, center, limits]);\n}\n\nfunction doZoomRect(scale, amount, from, to, limits) {\n const fn = zoomRectFunctions[scale.type] || zoomRectFunctions.default;\n callback(fn, [scale, amount, from, to, limits]);\n}\n\nfunction getCenter(chart) {\n const ca = chart.chartArea;\n return {\n x: (ca.left + ca.right) / 2,\n y: (ca.top + ca.bottom) / 2,\n };\n}\n\n/**\n * @param chart The chart instance\n * @param {number | {x?: number, y?: number, focalPoint?: {x: number, y: number}}} amount The zoom percentage or percentages and focal point\n * @param {string} [transition] Which transition mode to use. Defaults to 'none'\n */\nfunction zoom(chart, amount, transition = 'none') {\n const {x = 1, y = 1, focalPoint = getCenter(chart)} = typeof amount === 'number' ? {x: amount, y: amount} : amount;\n const state = getState(chart);\n const {options: {limits, zoom: zoomOptions}} = state;\n\n storeOriginalScaleLimits(chart, state);\n\n const xEnabled = x !== 1;\n const yEnabled = y !== 1;\n const enabledScales = getEnabledScalesByPoint(zoomOptions, focalPoint, chart);\n\n each(enabledScales || chart.scales, function(scale) {\n if (scale.isHorizontal() && xEnabled) {\n doZoom(scale, x, focalPoint, limits);\n } else if (!scale.isHorizontal() && yEnabled) {\n doZoom(scale, y, focalPoint, limits);\n }\n });\n\n chart.update(transition);\n\n callback(zoomOptions.onZoom, [{chart}]);\n}\n\nfunction zoomRect(chart, p0, p1, transition = 'none') {\n const state = getState(chart);\n const {options: {limits, zoom: zoomOptions}} = state;\n const {mode = 'xy'} = zoomOptions;\n\n storeOriginalScaleLimits(chart, state);\n const xEnabled = directionEnabled(mode, 'x', chart);\n const yEnabled = directionEnabled(mode, 'y', chart);\n\n each(chart.scales, function(scale) {\n if (scale.isHorizontal() && xEnabled) {\n doZoomRect(scale, p0.x, p1.x, limits);\n } else if (!scale.isHorizontal() && yEnabled) {\n doZoomRect(scale, p0.y, p1.y, limits);\n }\n });\n\n chart.update(transition);\n\n callback(zoomOptions.onZoom, [{chart}]);\n}\n\nfunction zoomScale(chart, scaleId, range, transition = 'none') {\n storeOriginalScaleLimits(chart, getState(chart));\n const scale = chart.scales[scaleId];\n updateRange(scale, range, undefined, true);\n chart.update(transition);\n}\n\nfunction resetZoom(chart, transition = 'default') {\n const state = getState(chart);\n const originalScaleLimits = storeOriginalScaleLimits(chart, state);\n\n each(chart.scales, function(scale) {\n const scaleOptions = scale.options;\n if (originalScaleLimits[scale.id]) {\n scaleOptions.min = originalScaleLimits[scale.id].min.options;\n scaleOptions.max = originalScaleLimits[scale.id].max.options;\n } else {\n delete scaleOptions.min;\n delete scaleOptions.max;\n }\n });\n chart.update(transition);\n callback(state.options.zoom.onZoomComplete, [{chart}]);\n}\n\nfunction getOriginalRange(state, scaleId) {\n const original = state.originalScaleLimits[scaleId];\n if (!original) {\n return;\n }\n const {min, max} = original;\n return valueOrDefault(max.options, max.scale) - valueOrDefault(min.options, min.scale);\n}\n\nfunction getZoomLevel(chart) {\n const state = getState(chart);\n let min = 1;\n let max = 1;\n each(chart.scales, function(scale) {\n const origRange = getOriginalRange(state, scale.id);\n if (origRange) {\n const level = Math.round(origRange / (scale.max - scale.min) * 100) / 100;\n min = Math.min(min, level);\n max = Math.max(max, level);\n }\n });\n return min < 1 ? min : max;\n}\n\nfunction panScale(scale, delta, limits, state) {\n const {panDelta} = state;\n // Add possible cumulative delta from previous pan attempts where scale did not change\n const storedDelta = panDelta[scale.id] || 0;\n if (sign(storedDelta) === sign(delta)) {\n delta += storedDelta;\n }\n const fn = panFunctions[scale.type] || panFunctions.default;\n if (callback(fn, [scale, delta, limits])) {\n // The scale changed, reset cumulative delta\n panDelta[scale.id] = 0;\n } else {\n // The scale did not change, store cumulative delta\n panDelta[scale.id] = delta;\n }\n}\n\nfunction pan(chart, delta, enabledScales, transition = 'none') {\n const {x = 0, y = 0} = typeof delta === 'number' ? {x: delta, y: delta} : delta;\n const state = getState(chart);\n const {options: {pan: panOptions, limits}} = state;\n const {onPan} = panOptions || {};\n\n storeOriginalScaleLimits(chart, state);\n\n const xEnabled = x !== 0;\n const yEnabled = y !== 0;\n\n each(enabledScales || chart.scales, function(scale) {\n if (scale.isHorizontal() && xEnabled) {\n panScale(scale, x, limits, state);\n } else if (!scale.isHorizontal() && yEnabled) {\n panScale(scale, y, limits, state);\n }\n });\n\n chart.update(transition);\n\n callback(onPan, [{chart}]);\n}\n\nfunction getInitialScaleBounds(chart) {\n const state = getState(chart);\n storeOriginalScaleLimits(chart, state);\n const scaleBounds = {};\n for (const scaleId of Object.keys(chart.scales)) {\n const {min, max} = state.originalScaleLimits[scaleId] || {min: {}, max: {}};\n scaleBounds[scaleId] = {min: min.scale, max: max.scale};\n }\n\n return scaleBounds;\n}\n\nfunction isZoomedOrPanned(chart) {\n const scaleBounds = getInitialScaleBounds(chart);\n for (const scaleId of Object.keys(chart.scales)) {\n const {min: originalMin, max: originalMax} = scaleBounds[scaleId];\n\n if (originalMin !== undefined && chart.scales[scaleId].min !== originalMin) {\n return true;\n }\n\n if (originalMax !== undefined && chart.scales[scaleId].max !== originalMax) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction removeHandler(chart, type) {\n const {handlers} = getState(chart);\n const handler = handlers[type];\n if (handler && handler.target) {\n handler.target.removeEventListener(type, handler);\n delete handlers[type];\n }\n}\n\nfunction addHandler(chart, target, type, handler) {\n const {handlers, options} = getState(chart);\n const oldHandler = handlers[type];\n if (oldHandler && oldHandler.target === target) {\n // already attached\n return;\n }\n removeHandler(chart, type);\n handlers[type] = (event) => handler(chart, event, options);\n handlers[type].target = target;\n target.addEventListener(type, handlers[type]);\n}\n\nfunction mouseMove(chart, event) {\n const state = getState(chart);\n if (state.dragStart) {\n state.dragging = true;\n state.dragEnd = event;\n chart.update('none');\n }\n}\n\nfunction keyDown(chart, event) {\n const state = getState(chart);\n if (!state.dragStart || event.key !== 'Escape') {\n return;\n }\n\n removeHandler(chart, 'keydown');\n state.dragging = false;\n state.dragStart = state.dragEnd = null;\n chart.update('none');\n}\n\nfunction zoomStart(chart, event, zoomOptions) {\n const {onZoomStart, onZoomRejected} = zoomOptions;\n if (onZoomStart) {\n const point = getRelativePosition(event, chart);\n if (callback(onZoomStart, [{chart, event, point}]) === false) {\n callback(onZoomRejected, [{chart, event}]);\n return false;\n }\n }\n}\n\nfunction mouseDown(chart, event) {\n const state = getState(chart);\n const {pan: panOptions, zoom: zoomOptions = {}} = state.options;\n if (\n event.button !== 0 ||\n keyPressed(getModifierKey(panOptions), event) ||\n keyNotPressed(getModifierKey(zoomOptions.drag), event)\n ) {\n return callback(zoomOptions.onZoomRejected, [{chart, event}]);\n }\n\n if (zoomStart(chart, event, zoomOptions) === false) {\n return;\n }\n state.dragStart = event;\n\n addHandler(chart, chart.canvas, 'mousemove', mouseMove);\n addHandler(chart, window.document, 'keydown', keyDown);\n}\n\nfunction computeDragRect(chart, mode, beginPointEvent, endPointEvent) {\n const xEnabled = directionEnabled(mode, 'x', chart);\n const yEnabled = directionEnabled(mode, 'y', chart);\n let {top, left, right, bottom, width: chartWidth, height: chartHeight} = chart.chartArea;\n\n const beginPoint = getRelativePosition(beginPointEvent, chart);\n const endPoint = getRelativePosition(endPointEvent, chart);\n\n if (xEnabled) {\n left = Math.min(beginPoint.x, endPoint.x);\n right = Math.max(beginPoint.x, endPoint.x);\n }\n\n if (yEnabled) {\n top = Math.min(beginPoint.y, endPoint.y);\n bottom = Math.max(beginPoint.y, endPoint.y);\n }\n const width = right - left;\n const height = bottom - top;\n\n return {\n left,\n top,\n right,\n bottom,\n width,\n height,\n zoomX: xEnabled && width ? 1 + ((chartWidth - width) / chartWidth) : 1,\n zoomY: yEnabled && height ? 1 + ((chartHeight - height) / chartHeight) : 1\n };\n}\n\nfunction mouseUp(chart, event) {\n const state = getState(chart);\n if (!state.dragStart) {\n return;\n }\n\n removeHandler(chart, 'mousemove');\n const {mode, onZoomComplete, drag: {threshold = 0}} = state.options.zoom;\n const rect = computeDragRect(chart, mode, state.dragStart, event);\n const distanceX = directionEnabled(mode, 'x', chart) ? rect.width : 0;\n const distanceY = directionEnabled(mode, 'y', chart) ? rect.height : 0;\n const distance = Math.sqrt(distanceX * distanceX + distanceY * distanceY);\n\n // Remove drag start and end before chart update to stop drawing selected area\n state.dragStart = state.dragEnd = null;\n\n if (distance <= threshold) {\n state.dragging = false;\n chart.update('none');\n return;\n }\n\n zoomRect(chart, {x: rect.left, y: rect.top}, {x: rect.right, y: rect.bottom}, 'zoom');\n\n setTimeout(() => (state.dragging = false), 500);\n callback(onZoomComplete, [{chart}]);\n}\n\nfunction wheelPreconditions(chart, event, zoomOptions) {\n // Before preventDefault, check if the modifier key required and pressed\n if (keyNotPressed(getModifierKey(zoomOptions.wheel), event)) {\n callback(zoomOptions.onZoomRejected, [{chart, event}]);\n return;\n }\n\n if (zoomStart(chart, event, zoomOptions) === false) {\n return;\n }\n\n // Prevent the event from triggering the default behavior (e.g. content scrolling).\n if (event.cancelable) {\n event.preventDefault();\n }\n\n // Firefox always fires the wheel event twice:\n // First without the delta and right after that once with the delta properties.\n if (event.deltaY === undefined) {\n return;\n }\n return true;\n}\n\nfunction wheel(chart, event) {\n const {handlers: {onZoomComplete}, options: {zoom: zoomOptions}} = getState(chart);\n\n if (!wheelPreconditions(chart, event, zoomOptions)) {\n return;\n }\n\n const rect = event.target.getBoundingClientRect();\n const speed = 1 + (event.deltaY >= 0 ? -zoomOptions.wheel.speed : zoomOptions.wheel.speed);\n const amount = {\n x: speed,\n y: speed,\n focalPoint: {\n x: event.clientX - rect.left,\n y: event.clientY - rect.top\n }\n };\n\n zoom(chart, amount);\n\n if (onZoomComplete) {\n onZoomComplete();\n }\n}\n\nfunction addDebouncedHandler(chart, name, handler, delay) {\n if (handler) {\n getState(chart).handlers[name] = debounce(() => callback(handler, [{chart}]), delay);\n }\n}\n\nfunction addListeners(chart, options) {\n const canvas = chart.canvas;\n const {wheel: wheelOptions, drag: dragOptions, onZoomComplete} = options.zoom;\n\n // Install listeners. Do this dynamically based on options so that we can turn zoom on and off\n // We also want to make sure listeners aren't always on. E.g. if you're scrolling down a page\n // and the mouse goes over a chart you don't want it intercepted unless the plugin is enabled\n if (wheelOptions.enabled) {\n addHandler(chart, canvas, 'wheel', wheel);\n addDebouncedHandler(chart, 'onZoomComplete', onZoomComplete, 250);\n } else {\n removeHandler(chart, 'wheel');\n }\n if (dragOptions.enabled) {\n addHandler(chart, canvas, 'mousedown', mouseDown);\n addHandler(chart, canvas.ownerDocument, 'mouseup', mouseUp);\n } else {\n removeHandler(chart, 'mousedown');\n removeHandler(chart, 'mousemove');\n removeHandler(chart, 'mouseup');\n removeHandler(chart, 'keydown');\n }\n}\n\nfunction removeListeners(chart) {\n removeHandler(chart, 'mousedown');\n removeHandler(chart, 'mousemove');\n removeHandler(chart, 'mouseup');\n removeHandler(chart, 'wheel');\n removeHandler(chart, 'click');\n removeHandler(chart, 'keydown');\n}\n\nfunction createEnabler(chart, state) {\n return function(recognizer, event) {\n const {pan: panOptions, zoom: zoomOptions = {}} = state.options;\n if (!panOptions || !panOptions.enabled) {\n return false;\n }\n const srcEvent = event && event.srcEvent;\n if (!srcEvent) { // Sometimes Hammer queries this with a null event.\n return true;\n }\n if (!state.panning && event.pointerType === 'mouse' && (\n keyNotPressed(getModifierKey(panOptions), srcEvent) || keyPressed(getModifierKey(zoomOptions.drag), srcEvent))\n ) {\n callback(panOptions.onPanRejected, [{chart, event}]);\n return false;\n }\n return true;\n };\n}\n\nfunction pinchAxes(p0, p1) {\n // fingers position difference\n const pinchX = Math.abs(p0.clientX - p1.clientX);\n const pinchY = Math.abs(p0.clientY - p1.clientY);\n\n // diagonal fingers will change both (xy) axes\n const p = pinchX / pinchY;\n let x, y;\n if (p > 0.3 && p < 1.7) {\n x = y = true;\n } else if (pinchX > pinchY) {\n x = true;\n } else {\n y = true;\n }\n return {x, y};\n}\n\nfunction handlePinch(chart, state, e) {\n if (state.scale) {\n const {center, pointers} = e;\n // Hammer reports the total scaling. We need the incremental amount\n const zoomPercent = 1 / state.scale * e.scale;\n const rect = e.target.getBoundingClientRect();\n const pinch = pinchAxes(pointers[0], pointers[1]);\n const mode = state.options.zoom.mode;\n const amount = {\n x: pinch.x && directionEnabled(mode, 'x', chart) ? zoomPercent : 1,\n y: pinch.y && directionEnabled(mode, 'y', chart) ? zoomPercent : 1,\n focalPoint: {\n x: center.x - rect.left,\n y: center.y - rect.top\n }\n };\n\n zoom(chart, amount);\n\n // Keep track of overall scale\n state.scale = e.scale;\n }\n}\n\nfunction startPinch(chart, state) {\n if (state.options.zoom.pinch.enabled) {\n state.scale = 1;\n }\n}\n\nfunction endPinch(chart, state, e) {\n if (state.scale) {\n handlePinch(chart, state, e);\n state.scale = null; // reset\n callback(state.options.zoom.onZoomComplete, [{chart}]);\n }\n}\n\nfunction handlePan(chart, state, e) {\n const delta = state.delta;\n if (delta) {\n state.panning = true;\n pan(chart, {x: e.deltaX - delta.x, y: e.deltaY - delta.y}, state.panScales);\n state.delta = {x: e.deltaX, y: e.deltaY};\n }\n}\n\nfunction startPan(chart, state, event) {\n const {enabled, onPanStart, onPanRejected} = state.options.pan;\n if (!enabled) {\n return;\n }\n const rect = event.target.getBoundingClientRect();\n const point = {\n x: event.center.x - rect.left,\n y: event.center.y - rect.top\n };\n\n if (callback(onPanStart, [{chart, event, point}]) === false) {\n return callback(onPanRejected, [{chart, event}]);\n }\n\n state.panScales = getEnabledScalesByPoint(state.options.pan, point, chart);\n state.delta = {x: 0, y: 0};\n clearTimeout(state.panEndTimeout);\n handlePan(chart, state, event);\n}\n\nfunction endPan(chart, state) {\n state.delta = null;\n if (state.panning) {\n state.panEndTimeout = setTimeout(() => (state.panning = false), 500);\n callback(state.options.pan.onPanComplete, [{chart}]);\n }\n}\n\nconst hammers = new WeakMap();\nfunction startHammer(chart, options) {\n const state = getState(chart);\n const canvas = chart.canvas;\n const {pan: panOptions, zoom: zoomOptions} = options;\n\n const mc = new Hammer.Manager(canvas);\n if (zoomOptions && zoomOptions.pinch.enabled) {\n mc.add(new Hammer.Pinch());\n mc.on('pinchstart', () => startPinch(chart, state));\n mc.on('pinch', (e) => handlePinch(chart, state, e));\n mc.on('pinchend', (e) => endPinch(chart, state, e));\n }\n\n if (panOptions && panOptions.enabled) {\n mc.add(new Hammer.Pan({\n threshold: panOptions.threshold,\n enable: createEnabler(chart, state)\n }));\n mc.on('panstart', (e) => startPan(chart, state, e));\n mc.on('panmove', (e) => handlePan(chart, state, e));\n mc.on('panend', () => endPan(chart, state));\n }\n\n hammers.set(chart, mc);\n}\n\nfunction stopHammer(chart) {\n const mc = hammers.get(chart);\n if (mc) {\n mc.remove('pinchstart');\n mc.remove('pinch');\n mc.remove('pinchend');\n mc.remove('panstart');\n mc.remove('pan');\n mc.remove('panend');\n mc.destroy();\n hammers.delete(chart);\n }\n}\n\nvar version = \"2.0.1\";\n\nfunction draw(chart, caller, options) {\n const dragOptions = options.zoom.drag;\n const {dragStart, dragEnd} = getState(chart);\n\n if (dragOptions.drawTime !== caller || !dragEnd) {\n return;\n }\n const {left, top, width, height} = computeDragRect(chart, options.zoom.mode, dragStart, dragEnd);\n const ctx = chart.ctx;\n\n ctx.save();\n ctx.beginPath();\n ctx.fillStyle = dragOptions.backgroundColor || 'rgba(225,225,225,0.3)';\n ctx.fillRect(left, top, width, height);\n\n if (dragOptions.borderWidth > 0) {\n ctx.lineWidth = dragOptions.borderWidth;\n ctx.strokeStyle = dragOptions.borderColor || 'rgba(225,225,225)';\n ctx.strokeRect(left, top, width, height);\n }\n ctx.restore();\n}\n\nvar plugin = {\n id: 'zoom',\n\n version,\n\n defaults: {\n pan: {\n enabled: false,\n mode: 'xy',\n threshold: 10,\n modifierKey: null,\n },\n zoom: {\n wheel: {\n enabled: false,\n speed: 0.1,\n modifierKey: null\n },\n drag: {\n enabled: false,\n drawTime: 'beforeDatasetsDraw',\n modifierKey: null\n },\n pinch: {\n enabled: false\n },\n mode: 'xy',\n }\n },\n\n start: function(chart, _args, options) {\n const state = getState(chart);\n state.options = options;\n\n if (Object.prototype.hasOwnProperty.call(options.zoom, 'enabled')) {\n console.warn('The option `zoom.enabled` is no longer supported. Please use `zoom.wheel.enabled`, `zoom.drag.enabled`, or `zoom.pinch.enabled`.');\n }\n if (Object.prototype.hasOwnProperty.call(options.zoom, 'overScaleMode')\n || Object.prototype.hasOwnProperty.call(options.pan, 'overScaleMode')) {\n console.warn('The option `overScaleMode` is deprecated. Please use `scaleMode` instead (and update `mode` as desired).');\n }\n\n if (Hammer) {\n startHammer(chart, options);\n }\n\n chart.pan = (delta, panScales, transition) => pan(chart, delta, panScales, transition);\n chart.zoom = (args, transition) => zoom(chart, args, transition);\n chart.zoomRect = (p0, p1, transition) => zoomRect(chart, p0, p1, transition);\n chart.zoomScale = (id, range, transition) => zoomScale(chart, id, range, transition);\n chart.resetZoom = (transition) => resetZoom(chart, transition);\n chart.getZoomLevel = () => getZoomLevel(chart);\n chart.getInitialScaleBounds = () => getInitialScaleBounds(chart);\n chart.isZoomedOrPanned = () => isZoomedOrPanned(chart);\n },\n\n beforeEvent(chart) {\n const state = getState(chart);\n if (state.panning || state.dragging) {\n // cancel any event handling while panning or dragging\n return false;\n }\n },\n\n beforeUpdate: function(chart, args, options) {\n const state = getState(chart);\n state.options = options;\n addListeners(chart, options);\n },\n\n beforeDatasetsDraw(chart, _args, options) {\n draw(chart, 'beforeDatasetsDraw', options);\n },\n\n afterDatasetsDraw(chart, _args, options) {\n draw(chart, 'afterDatasetsDraw', options);\n },\n\n beforeDraw(chart, _args, options) {\n draw(chart, 'beforeDraw', options);\n },\n\n afterDraw(chart, _args, options) {\n draw(chart, 'afterDraw', options);\n },\n\n stop: function(chart) {\n removeListeners(chart);\n\n if (Hammer) {\n stopHammer(chart);\n }\n removeState(chart);\n },\n\n panFunctions,\n zoomFunctions,\n zoomRectFunctions,\n};\n\nexport { plugin as default, pan, resetZoom, zoom, zoomRect, zoomScale };\n","/*! Hammer.JS - v2.0.7 - 2016-04-22\n * http://hammerjs.github.io/\n *\n * Copyright (c) 2016 Jorik Tangelder;\n * Licensed under the MIT license */\n(function(window, document, exportName, undefined) {\n 'use strict';\n\nvar VENDOR_PREFIXES = ['', 'webkit', 'Moz', 'MS', 'ms', 'o'];\nvar TEST_ELEMENT = document.createElement('div');\n\nvar TYPE_FUNCTION = 'function';\n\nvar round = Math.round;\nvar abs = Math.abs;\nvar now = Date.now;\n\n/**\n * set a timeout with a given scope\n * @param {Function} fn\n * @param {Number} timeout\n * @param {Object} context\n * @returns {number}\n */\nfunction setTimeoutContext(fn, timeout, context) {\n return setTimeout(bindFn(fn, context), timeout);\n}\n\n/**\n * if the argument is an array, we want to execute the fn on each entry\n * if it aint an array we don't want to do a thing.\n * this is used by all the methods that accept a single and array argument.\n * @param {*|Array} arg\n * @param {String} fn\n * @param {Object} [context]\n * @returns {Boolean}\n */\nfunction invokeArrayArg(arg, fn, context) {\n if (Array.isArray(arg)) {\n each(arg, context[fn], context);\n return true;\n }\n return false;\n}\n\n/**\n * walk objects and arrays\n * @param {Object} obj\n * @param {Function} iterator\n * @param {Object} context\n */\nfunction each(obj, iterator, context) {\n var i;\n\n if (!obj) {\n return;\n }\n\n if (obj.forEach) {\n obj.forEach(iterator, context);\n } else if (obj.length !== undefined) {\n i = 0;\n while (i < obj.length) {\n iterator.call(context, obj[i], i, obj);\n i++;\n }\n } else {\n for (i in obj) {\n obj.hasOwnProperty(i) && iterator.call(context, obj[i], i, obj);\n }\n }\n}\n\n/**\n * wrap a method with a deprecation warning and stack trace\n * @param {Function} method\n * @param {String} name\n * @param {String} message\n * @returns {Function} A new function wrapping the supplied method.\n */\nfunction deprecate(method, name, message) {\n var deprecationMessage = 'DEPRECATED METHOD: ' + name + '\\n' + message + ' AT \\n';\n return function() {\n var e = new Error('get-stack-trace');\n var stack = e && e.stack ? e.stack.replace(/^[^\\(]+?[\\n$]/gm, '')\n .replace(/^\\s+at\\s+/gm, '')\n .replace(/^Object.\\s*\\(/gm, '{anonymous}()@') : 'Unknown Stack Trace';\n\n var log = window.console && (window.console.warn || window.console.log);\n if (log) {\n log.call(window.console, deprecationMessage, stack);\n }\n return method.apply(this, arguments);\n };\n}\n\n/**\n * extend object.\n * means that properties in dest will be overwritten by the ones in src.\n * @param {Object} target\n * @param {...Object} objects_to_assign\n * @returns {Object} target\n */\nvar assign;\nif (typeof Object.assign !== 'function') {\n assign = function assign(target) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert undefined or null to object');\n }\n\n var output = Object(target);\n for (var index = 1; index < arguments.length; index++) {\n var source = arguments[index];\n if (source !== undefined && source !== null) {\n for (var nextKey in source) {\n if (source.hasOwnProperty(nextKey)) {\n output[nextKey] = source[nextKey];\n }\n }\n }\n }\n return output;\n };\n} else {\n assign = Object.assign;\n}\n\n/**\n * extend object.\n * means that properties in dest will be overwritten by the ones in src.\n * @param {Object} dest\n * @param {Object} src\n * @param {Boolean} [merge=false]\n * @returns {Object} dest\n */\nvar extend = deprecate(function extend(dest, src, merge) {\n var keys = Object.keys(src);\n var i = 0;\n while (i < keys.length) {\n if (!merge || (merge && dest[keys[i]] === undefined)) {\n dest[keys[i]] = src[keys[i]];\n }\n i++;\n }\n return dest;\n}, 'extend', 'Use `assign`.');\n\n/**\n * merge the values from src in the dest.\n * means that properties that exist in dest will not be overwritten by src\n * @param {Object} dest\n * @param {Object} src\n * @returns {Object} dest\n */\nvar merge = deprecate(function merge(dest, src) {\n return extend(dest, src, true);\n}, 'merge', 'Use `assign`.');\n\n/**\n * simple class inheritance\n * @param {Function} child\n * @param {Function} base\n * @param {Object} [properties]\n */\nfunction inherit(child, base, properties) {\n var baseP = base.prototype,\n childP;\n\n childP = child.prototype = Object.create(baseP);\n childP.constructor = child;\n childP._super = baseP;\n\n if (properties) {\n assign(childP, properties);\n }\n}\n\n/**\n * simple function bind\n * @param {Function} fn\n * @param {Object} context\n * @returns {Function}\n */\nfunction bindFn(fn, context) {\n return function boundFn() {\n return fn.apply(context, arguments);\n };\n}\n\n/**\n * let a boolean value also be a function that must return a boolean\n * this first item in args will be used as the context\n * @param {Boolean|Function} val\n * @param {Array} [args]\n * @returns {Boolean}\n */\nfunction boolOrFn(val, args) {\n if (typeof val == TYPE_FUNCTION) {\n return val.apply(args ? args[0] || undefined : undefined, args);\n }\n return val;\n}\n\n/**\n * use the val2 when val1 is undefined\n * @param {*} val1\n * @param {*} val2\n * @returns {*}\n */\nfunction ifUndefined(val1, val2) {\n return (val1 === undefined) ? val2 : val1;\n}\n\n/**\n * addEventListener with multiple events at once\n * @param {EventTarget} target\n * @param {String} types\n * @param {Function} handler\n */\nfunction addEventListeners(target, types, handler) {\n each(splitStr(types), function(type) {\n target.addEventListener(type, handler, false);\n });\n}\n\n/**\n * removeEventListener with multiple events at once\n * @param {EventTarget} target\n * @param {String} types\n * @param {Function} handler\n */\nfunction removeEventListeners(target, types, handler) {\n each(splitStr(types), function(type) {\n target.removeEventListener(type, handler, false);\n });\n}\n\n/**\n * find if a node is in the given parent\n * @method hasParent\n * @param {HTMLElement} node\n * @param {HTMLElement} parent\n * @return {Boolean} found\n */\nfunction hasParent(node, parent) {\n while (node) {\n if (node == parent) {\n return true;\n }\n node = node.parentNode;\n }\n return false;\n}\n\n/**\n * small indexOf wrapper\n * @param {String} str\n * @param {String} find\n * @returns {Boolean} found\n */\nfunction inStr(str, find) {\n return str.indexOf(find) > -1;\n}\n\n/**\n * split string on whitespace\n * @param {String} str\n * @returns {Array} words\n */\nfunction splitStr(str) {\n return str.trim().split(/\\s+/g);\n}\n\n/**\n * find if a array contains the object using indexOf or a simple polyFill\n * @param {Array} src\n * @param {String} find\n * @param {String} [findByKey]\n * @return {Boolean|Number} false when not found, or the index\n */\nfunction inArray(src, find, findByKey) {\n if (src.indexOf && !findByKey) {\n return src.indexOf(find);\n } else {\n var i = 0;\n while (i < src.length) {\n if ((findByKey && src[i][findByKey] == find) || (!findByKey && src[i] === find)) {\n return i;\n }\n i++;\n }\n return -1;\n }\n}\n\n/**\n * convert array-like objects to real arrays\n * @param {Object} obj\n * @returns {Array}\n */\nfunction toArray(obj) {\n return Array.prototype.slice.call(obj, 0);\n}\n\n/**\n * unique array with objects based on a key (like 'id') or just by the array's value\n * @param {Array} src [{id:1},{id:2},{id:1}]\n * @param {String} [key]\n * @param {Boolean} [sort=False]\n * @returns {Array} [{id:1},{id:2}]\n */\nfunction uniqueArray(src, key, sort) {\n var results = [];\n var values = [];\n var i = 0;\n\n while (i < src.length) {\n var val = key ? src[i][key] : src[i];\n if (inArray(values, val) < 0) {\n results.push(src[i]);\n }\n values[i] = val;\n i++;\n }\n\n if (sort) {\n if (!key) {\n results = results.sort();\n } else {\n results = results.sort(function sortUniqueArray(a, b) {\n return a[key] > b[key];\n });\n }\n }\n\n return results;\n}\n\n/**\n * get the prefixed property\n * @param {Object} obj\n * @param {String} property\n * @returns {String|Undefined} prefixed\n */\nfunction prefixed(obj, property) {\n var prefix, prop;\n var camelProp = property[0].toUpperCase() + property.slice(1);\n\n var i = 0;\n while (i < VENDOR_PREFIXES.length) {\n prefix = VENDOR_PREFIXES[i];\n prop = (prefix) ? prefix + camelProp : property;\n\n if (prop in obj) {\n return prop;\n }\n i++;\n }\n return undefined;\n}\n\n/**\n * get a unique id\n * @returns {number} uniqueId\n */\nvar _uniqueId = 1;\nfunction uniqueId() {\n return _uniqueId++;\n}\n\n/**\n * get the window object of an element\n * @param {HTMLElement} element\n * @returns {DocumentView|Window}\n */\nfunction getWindowForElement(element) {\n var doc = element.ownerDocument || element;\n return (doc.defaultView || doc.parentWindow || window);\n}\n\nvar MOBILE_REGEX = /mobile|tablet|ip(ad|hone|od)|android/i;\n\nvar SUPPORT_TOUCH = ('ontouchstart' in window);\nvar SUPPORT_POINTER_EVENTS = prefixed(window, 'PointerEvent') !== undefined;\nvar SUPPORT_ONLY_TOUCH = SUPPORT_TOUCH && MOBILE_REGEX.test(navigator.userAgent);\n\nvar INPUT_TYPE_TOUCH = 'touch';\nvar INPUT_TYPE_PEN = 'pen';\nvar INPUT_TYPE_MOUSE = 'mouse';\nvar INPUT_TYPE_KINECT = 'kinect';\n\nvar COMPUTE_INTERVAL = 25;\n\nvar INPUT_START = 1;\nvar INPUT_MOVE = 2;\nvar INPUT_END = 4;\nvar INPUT_CANCEL = 8;\n\nvar DIRECTION_NONE = 1;\nvar DIRECTION_LEFT = 2;\nvar DIRECTION_RIGHT = 4;\nvar DIRECTION_UP = 8;\nvar DIRECTION_DOWN = 16;\n\nvar DIRECTION_HORIZONTAL = DIRECTION_LEFT | DIRECTION_RIGHT;\nvar DIRECTION_VERTICAL = DIRECTION_UP | DIRECTION_DOWN;\nvar DIRECTION_ALL = DIRECTION_HORIZONTAL | DIRECTION_VERTICAL;\n\nvar PROPS_XY = ['x', 'y'];\nvar PROPS_CLIENT_XY = ['clientX', 'clientY'];\n\n/**\n * create new input type manager\n * @param {Manager} manager\n * @param {Function} callback\n * @returns {Input}\n * @constructor\n */\nfunction Input(manager, callback) {\n var self = this;\n this.manager = manager;\n this.callback = callback;\n this.element = manager.element;\n this.target = manager.options.inputTarget;\n\n // smaller wrapper around the handler, for the scope and the enabled state of the manager,\n // so when disabled the input events are completely bypassed.\n this.domHandler = function(ev) {\n if (boolOrFn(manager.options.enable, [manager])) {\n self.handler(ev);\n }\n };\n\n this.init();\n\n}\n\nInput.prototype = {\n /**\n * should handle the inputEvent data and trigger the callback\n * @virtual\n */\n handler: function() { },\n\n /**\n * bind the events\n */\n init: function() {\n this.evEl && addEventListeners(this.element, this.evEl, this.domHandler);\n this.evTarget && addEventListeners(this.target, this.evTarget, this.domHandler);\n this.evWin && addEventListeners(getWindowForElement(this.element), this.evWin, this.domHandler);\n },\n\n /**\n * unbind the events\n */\n destroy: function() {\n this.evEl && removeEventListeners(this.element, this.evEl, this.domHandler);\n this.evTarget && removeEventListeners(this.target, this.evTarget, this.domHandler);\n this.evWin && removeEventListeners(getWindowForElement(this.element), this.evWin, this.domHandler);\n }\n};\n\n/**\n * create new input type manager\n * called by the Manager constructor\n * @param {Hammer} manager\n * @returns {Input}\n */\nfunction createInputInstance(manager) {\n var Type;\n var inputClass = manager.options.inputClass;\n\n if (inputClass) {\n Type = inputClass;\n } else if (SUPPORT_POINTER_EVENTS) {\n Type = PointerEventInput;\n } else if (SUPPORT_ONLY_TOUCH) {\n Type = TouchInput;\n } else if (!SUPPORT_TOUCH) {\n Type = MouseInput;\n } else {\n Type = TouchMouseInput;\n }\n return new (Type)(manager, inputHandler);\n}\n\n/**\n * handle input events\n * @param {Manager} manager\n * @param {String} eventType\n * @param {Object} input\n */\nfunction inputHandler(manager, eventType, input) {\n var pointersLen = input.pointers.length;\n var changedPointersLen = input.changedPointers.length;\n var isFirst = (eventType & INPUT_START && (pointersLen - changedPointersLen === 0));\n var isFinal = (eventType & (INPUT_END | INPUT_CANCEL) && (pointersLen - changedPointersLen === 0));\n\n input.isFirst = !!isFirst;\n input.isFinal = !!isFinal;\n\n if (isFirst) {\n manager.session = {};\n }\n\n // source event is the normalized value of the domEvents\n // like 'touchstart, mouseup, pointerdown'\n input.eventType = eventType;\n\n // compute scale, rotation etc\n computeInputData(manager, input);\n\n // emit secret event\n manager.emit('hammer.input', input);\n\n manager.recognize(input);\n manager.session.prevInput = input;\n}\n\n/**\n * extend the data with some usable properties like scale, rotate, velocity etc\n * @param {Object} manager\n * @param {Object} input\n */\nfunction computeInputData(manager, input) {\n var session = manager.session;\n var pointers = input.pointers;\n var pointersLength = pointers.length;\n\n // store the first input to calculate the distance and direction\n if (!session.firstInput) {\n session.firstInput = simpleCloneInputData(input);\n }\n\n // to compute scale and rotation we need to store the multiple touches\n if (pointersLength > 1 && !session.firstMultiple) {\n session.firstMultiple = simpleCloneInputData(input);\n } else if (pointersLength === 1) {\n session.firstMultiple = false;\n }\n\n var firstInput = session.firstInput;\n var firstMultiple = session.firstMultiple;\n var offsetCenter = firstMultiple ? firstMultiple.center : firstInput.center;\n\n var center = input.center = getCenter(pointers);\n input.timeStamp = now();\n input.deltaTime = input.timeStamp - firstInput.timeStamp;\n\n input.angle = getAngle(offsetCenter, center);\n input.distance = getDistance(offsetCenter, center);\n\n computeDeltaXY(session, input);\n input.offsetDirection = getDirection(input.deltaX, input.deltaY);\n\n var overallVelocity = getVelocity(input.deltaTime, input.deltaX, input.deltaY);\n input.overallVelocityX = overallVelocity.x;\n input.overallVelocityY = overallVelocity.y;\n input.overallVelocity = (abs(overallVelocity.x) > abs(overallVelocity.y)) ? overallVelocity.x : overallVelocity.y;\n\n input.scale = firstMultiple ? getScale(firstMultiple.pointers, pointers) : 1;\n input.rotation = firstMultiple ? getRotation(firstMultiple.pointers, pointers) : 0;\n\n input.maxPointers = !session.prevInput ? input.pointers.length : ((input.pointers.length >\n session.prevInput.maxPointers) ? input.pointers.length : session.prevInput.maxPointers);\n\n computeIntervalInputData(session, input);\n\n // find the correct target\n var target = manager.element;\n if (hasParent(input.srcEvent.target, target)) {\n target = input.srcEvent.target;\n }\n input.target = target;\n}\n\nfunction computeDeltaXY(session, input) {\n var center = input.center;\n var offset = session.offsetDelta || {};\n var prevDelta = session.prevDelta || {};\n var prevInput = session.prevInput || {};\n\n if (input.eventType === INPUT_START || prevInput.eventType === INPUT_END) {\n prevDelta = session.prevDelta = {\n x: prevInput.deltaX || 0,\n y: prevInput.deltaY || 0\n };\n\n offset = session.offsetDelta = {\n x: center.x,\n y: center.y\n };\n }\n\n input.deltaX = prevDelta.x + (center.x - offset.x);\n input.deltaY = prevDelta.y + (center.y - offset.y);\n}\n\n/**\n * velocity is calculated every x ms\n * @param {Object} session\n * @param {Object} input\n */\nfunction computeIntervalInputData(session, input) {\n var last = session.lastInterval || input,\n deltaTime = input.timeStamp - last.timeStamp,\n velocity, velocityX, velocityY, direction;\n\n if (input.eventType != INPUT_CANCEL && (deltaTime > COMPUTE_INTERVAL || last.velocity === undefined)) {\n var deltaX = input.deltaX - last.deltaX;\n var deltaY = input.deltaY - last.deltaY;\n\n var v = getVelocity(deltaTime, deltaX, deltaY);\n velocityX = v.x;\n velocityY = v.y;\n velocity = (abs(v.x) > abs(v.y)) ? v.x : v.y;\n direction = getDirection(deltaX, deltaY);\n\n session.lastInterval = input;\n } else {\n // use latest velocity info if it doesn't overtake a minimum period\n velocity = last.velocity;\n velocityX = last.velocityX;\n velocityY = last.velocityY;\n direction = last.direction;\n }\n\n input.velocity = velocity;\n input.velocityX = velocityX;\n input.velocityY = velocityY;\n input.direction = direction;\n}\n\n/**\n * create a simple clone from the input used for storage of firstInput and firstMultiple\n * @param {Object} input\n * @returns {Object} clonedInputData\n */\nfunction simpleCloneInputData(input) {\n // make a simple copy of the pointers because we will get a reference if we don't\n // we only need clientXY for the calculations\n var pointers = [];\n var i = 0;\n while (i < input.pointers.length) {\n pointers[i] = {\n clientX: round(input.pointers[i].clientX),\n clientY: round(input.pointers[i].clientY)\n };\n i++;\n }\n\n return {\n timeStamp: now(),\n pointers: pointers,\n center: getCenter(pointers),\n deltaX: input.deltaX,\n deltaY: input.deltaY\n };\n}\n\n/**\n * get the center of all the pointers\n * @param {Array} pointers\n * @return {Object} center contains `x` and `y` properties\n */\nfunction getCenter(pointers) {\n var pointersLength = pointers.length;\n\n // no need to loop when only one touch\n if (pointersLength === 1) {\n return {\n x: round(pointers[0].clientX),\n y: round(pointers[0].clientY)\n };\n }\n\n var x = 0, y = 0, i = 0;\n while (i < pointersLength) {\n x += pointers[i].clientX;\n y += pointers[i].clientY;\n i++;\n }\n\n return {\n x: round(x / pointersLength),\n y: round(y / pointersLength)\n };\n}\n\n/**\n * calculate the velocity between two points. unit is in px per ms.\n * @param {Number} deltaTime\n * @param {Number} x\n * @param {Number} y\n * @return {Object} velocity `x` and `y`\n */\nfunction getVelocity(deltaTime, x, y) {\n return {\n x: x / deltaTime || 0,\n y: y / deltaTime || 0\n };\n}\n\n/**\n * get the direction between two points\n * @param {Number} x\n * @param {Number} y\n * @return {Number} direction\n */\nfunction getDirection(x, y) {\n if (x === y) {\n return DIRECTION_NONE;\n }\n\n if (abs(x) >= abs(y)) {\n return x < 0 ? DIRECTION_LEFT : DIRECTION_RIGHT;\n }\n return y < 0 ? DIRECTION_UP : DIRECTION_DOWN;\n}\n\n/**\n * calculate the absolute distance between two points\n * @param {Object} p1 {x, y}\n * @param {Object} p2 {x, y}\n * @param {Array} [props] containing x and y keys\n * @return {Number} distance\n */\nfunction getDistance(p1, p2, props) {\n if (!props) {\n props = PROPS_XY;\n }\n var x = p2[props[0]] - p1[props[0]],\n y = p2[props[1]] - p1[props[1]];\n\n return Math.sqrt((x * x) + (y * y));\n}\n\n/**\n * calculate the angle between two coordinates\n * @param {Object} p1\n * @param {Object} p2\n * @param {Array} [props] containing x and y keys\n * @return {Number} angle\n */\nfunction getAngle(p1, p2, props) {\n if (!props) {\n props = PROPS_XY;\n }\n var x = p2[props[0]] - p1[props[0]],\n y = p2[props[1]] - p1[props[1]];\n return Math.atan2(y, x) * 180 / Math.PI;\n}\n\n/**\n * calculate the rotation degrees between two pointersets\n * @param {Array} start array of pointers\n * @param {Array} end array of pointers\n * @return {Number} rotation\n */\nfunction getRotation(start, end) {\n return getAngle(end[1], end[0], PROPS_CLIENT_XY) + getAngle(start[1], start[0], PROPS_CLIENT_XY);\n}\n\n/**\n * calculate the scale factor between two pointersets\n * no scale is 1, and goes down to 0 when pinched together, and bigger when pinched out\n * @param {Array} start array of pointers\n * @param {Array} end array of pointers\n * @return {Number} scale\n */\nfunction getScale(start, end) {\n return getDistance(end[0], end[1], PROPS_CLIENT_XY) / getDistance(start[0], start[1], PROPS_CLIENT_XY);\n}\n\nvar MOUSE_INPUT_MAP = {\n mousedown: INPUT_START,\n mousemove: INPUT_MOVE,\n mouseup: INPUT_END\n};\n\nvar MOUSE_ELEMENT_EVENTS = 'mousedown';\nvar MOUSE_WINDOW_EVENTS = 'mousemove mouseup';\n\n/**\n * Mouse events input\n * @constructor\n * @extends Input\n */\nfunction MouseInput() {\n this.evEl = MOUSE_ELEMENT_EVENTS;\n this.evWin = MOUSE_WINDOW_EVENTS;\n\n this.pressed = false; // mousedown state\n\n Input.apply(this, arguments);\n}\n\ninherit(MouseInput, Input, {\n /**\n * handle mouse events\n * @param {Object} ev\n */\n handler: function MEhandler(ev) {\n var eventType = MOUSE_INPUT_MAP[ev.type];\n\n // on start we want to have the left mouse button down\n if (eventType & INPUT_START && ev.button === 0) {\n this.pressed = true;\n }\n\n if (eventType & INPUT_MOVE && ev.which !== 1) {\n eventType = INPUT_END;\n }\n\n // mouse must be down\n if (!this.pressed) {\n return;\n }\n\n if (eventType & INPUT_END) {\n this.pressed = false;\n }\n\n this.callback(this.manager, eventType, {\n pointers: [ev],\n changedPointers: [ev],\n pointerType: INPUT_TYPE_MOUSE,\n srcEvent: ev\n });\n }\n});\n\nvar POINTER_INPUT_MAP = {\n pointerdown: INPUT_START,\n pointermove: INPUT_MOVE,\n pointerup: INPUT_END,\n pointercancel: INPUT_CANCEL,\n pointerout: INPUT_CANCEL\n};\n\n// in IE10 the pointer types is defined as an enum\nvar IE10_POINTER_TYPE_ENUM = {\n 2: INPUT_TYPE_TOUCH,\n 3: INPUT_TYPE_PEN,\n 4: INPUT_TYPE_MOUSE,\n 5: INPUT_TYPE_KINECT // see https://twitter.com/jacobrossi/status/480596438489890816\n};\n\nvar POINTER_ELEMENT_EVENTS = 'pointerdown';\nvar POINTER_WINDOW_EVENTS = 'pointermove pointerup pointercancel';\n\n// IE10 has prefixed support, and case-sensitive\nif (window.MSPointerEvent && !window.PointerEvent) {\n POINTER_ELEMENT_EVENTS = 'MSPointerDown';\n POINTER_WINDOW_EVENTS = 'MSPointerMove MSPointerUp MSPointerCancel';\n}\n\n/**\n * Pointer events input\n * @constructor\n * @extends Input\n */\nfunction PointerEventInput() {\n this.evEl = POINTER_ELEMENT_EVENTS;\n this.evWin = POINTER_WINDOW_EVENTS;\n\n Input.apply(this, arguments);\n\n this.store = (this.manager.session.pointerEvents = []);\n}\n\ninherit(PointerEventInput, Input, {\n /**\n * handle mouse events\n * @param {Object} ev\n */\n handler: function PEhandler(ev) {\n var store = this.store;\n var removePointer = false;\n\n var eventTypeNormalized = ev.type.toLowerCase().replace('ms', '');\n var eventType = POINTER_INPUT_MAP[eventTypeNormalized];\n var pointerType = IE10_POINTER_TYPE_ENUM[ev.pointerType] || ev.pointerType;\n\n var isTouch = (pointerType == INPUT_TYPE_TOUCH);\n\n // get index of the event in the store\n var storeIndex = inArray(store, ev.pointerId, 'pointerId');\n\n // start and mouse must be down\n if (eventType & INPUT_START && (ev.button === 0 || isTouch)) {\n if (storeIndex < 0) {\n store.push(ev);\n storeIndex = store.length - 1;\n }\n } else if (eventType & (INPUT_END | INPUT_CANCEL)) {\n removePointer = true;\n }\n\n // it not found, so the pointer hasn't been down (so it's probably a hover)\n if (storeIndex < 0) {\n return;\n }\n\n // update the event in the store\n store[storeIndex] = ev;\n\n this.callback(this.manager, eventType, {\n pointers: store,\n changedPointers: [ev],\n pointerType: pointerType,\n srcEvent: ev\n });\n\n if (removePointer) {\n // remove from the store\n store.splice(storeIndex, 1);\n }\n }\n});\n\nvar SINGLE_TOUCH_INPUT_MAP = {\n touchstart: INPUT_START,\n touchmove: INPUT_MOVE,\n touchend: INPUT_END,\n touchcancel: INPUT_CANCEL\n};\n\nvar SINGLE_TOUCH_TARGET_EVENTS = 'touchstart';\nvar SINGLE_TOUCH_WINDOW_EVENTS = 'touchstart touchmove touchend touchcancel';\n\n/**\n * Touch events input\n * @constructor\n * @extends Input\n */\nfunction SingleTouchInput() {\n this.evTarget = SINGLE_TOUCH_TARGET_EVENTS;\n this.evWin = SINGLE_TOUCH_WINDOW_EVENTS;\n this.started = false;\n\n Input.apply(this, arguments);\n}\n\ninherit(SingleTouchInput, Input, {\n handler: function TEhandler(ev) {\n var type = SINGLE_TOUCH_INPUT_MAP[ev.type];\n\n // should we handle the touch events?\n if (type === INPUT_START) {\n this.started = true;\n }\n\n if (!this.started) {\n return;\n }\n\n var touches = normalizeSingleTouches.call(this, ev, type);\n\n // when done, reset the started state\n if (type & (INPUT_END | INPUT_CANCEL) && touches[0].length - touches[1].length === 0) {\n this.started = false;\n }\n\n this.callback(this.manager, type, {\n pointers: touches[0],\n changedPointers: touches[1],\n pointerType: INPUT_TYPE_TOUCH,\n srcEvent: ev\n });\n }\n});\n\n/**\n * @this {TouchInput}\n * @param {Object} ev\n * @param {Number} type flag\n * @returns {undefined|Array} [all, changed]\n */\nfunction normalizeSingleTouches(ev, type) {\n var all = toArray(ev.touches);\n var changed = toArray(ev.changedTouches);\n\n if (type & (INPUT_END | INPUT_CANCEL)) {\n all = uniqueArray(all.concat(changed), 'identifier', true);\n }\n\n return [all, changed];\n}\n\nvar TOUCH_INPUT_MAP = {\n touchstart: INPUT_START,\n touchmove: INPUT_MOVE,\n touchend: INPUT_END,\n touchcancel: INPUT_CANCEL\n};\n\nvar TOUCH_TARGET_EVENTS = 'touchstart touchmove touchend touchcancel';\n\n/**\n * Multi-user touch events input\n * @constructor\n * @extends Input\n */\nfunction TouchInput() {\n this.evTarget = TOUCH_TARGET_EVENTS;\n this.targetIds = {};\n\n Input.apply(this, arguments);\n}\n\ninherit(TouchInput, Input, {\n handler: function MTEhandler(ev) {\n var type = TOUCH_INPUT_MAP[ev.type];\n var touches = getTouches.call(this, ev, type);\n if (!touches) {\n return;\n }\n\n this.callback(this.manager, type, {\n pointers: touches[0],\n changedPointers: touches[1],\n pointerType: INPUT_TYPE_TOUCH,\n srcEvent: ev\n });\n }\n});\n\n/**\n * @this {TouchInput}\n * @param {Object} ev\n * @param {Number} type flag\n * @returns {undefined|Array} [all, changed]\n */\nfunction getTouches(ev, type) {\n var allTouches = toArray(ev.touches);\n var targetIds = this.targetIds;\n\n // when there is only one touch, the process can be simplified\n if (type & (INPUT_START | INPUT_MOVE) && allTouches.length === 1) {\n targetIds[allTouches[0].identifier] = true;\n return [allTouches, allTouches];\n }\n\n var i,\n targetTouches,\n changedTouches = toArray(ev.changedTouches),\n changedTargetTouches = [],\n target = this.target;\n\n // get target touches from touches\n targetTouches = allTouches.filter(function(touch) {\n return hasParent(touch.target, target);\n });\n\n // collect touches\n if (type === INPUT_START) {\n i = 0;\n while (i < targetTouches.length) {\n targetIds[targetTouches[i].identifier] = true;\n i++;\n }\n }\n\n // filter changed touches to only contain touches that exist in the collected target ids\n i = 0;\n while (i < changedTouches.length) {\n if (targetIds[changedTouches[i].identifier]) {\n changedTargetTouches.push(changedTouches[i]);\n }\n\n // cleanup removed touches\n if (type & (INPUT_END | INPUT_CANCEL)) {\n delete targetIds[changedTouches[i].identifier];\n }\n i++;\n }\n\n if (!changedTargetTouches.length) {\n return;\n }\n\n return [\n // merge targetTouches with changedTargetTouches so it contains ALL touches, including 'end' and 'cancel'\n uniqueArray(targetTouches.concat(changedTargetTouches), 'identifier', true),\n changedTargetTouches\n ];\n}\n\n/**\n * Combined touch and mouse input\n *\n * Touch has a higher priority then mouse, and while touching no mouse events are allowed.\n * This because touch devices also emit mouse events while doing a touch.\n *\n * @constructor\n * @extends Input\n */\n\nvar DEDUP_TIMEOUT = 2500;\nvar DEDUP_DISTANCE = 25;\n\nfunction TouchMouseInput() {\n Input.apply(this, arguments);\n\n var handler = bindFn(this.handler, this);\n this.touch = new TouchInput(this.manager, handler);\n this.mouse = new MouseInput(this.manager, handler);\n\n this.primaryTouch = null;\n this.lastTouches = [];\n}\n\ninherit(TouchMouseInput, Input, {\n /**\n * handle mouse and touch events\n * @param {Hammer} manager\n * @param {String} inputEvent\n * @param {Object} inputData\n */\n handler: function TMEhandler(manager, inputEvent, inputData) {\n var isTouch = (inputData.pointerType == INPUT_TYPE_TOUCH),\n isMouse = (inputData.pointerType == INPUT_TYPE_MOUSE);\n\n if (isMouse && inputData.sourceCapabilities && inputData.sourceCapabilities.firesTouchEvents) {\n return;\n }\n\n // when we're in a touch event, record touches to de-dupe synthetic mouse event\n if (isTouch) {\n recordTouches.call(this, inputEvent, inputData);\n } else if (isMouse && isSyntheticEvent.call(this, inputData)) {\n return;\n }\n\n this.callback(manager, inputEvent, inputData);\n },\n\n /**\n * remove the event listeners\n */\n destroy: function destroy() {\n this.touch.destroy();\n this.mouse.destroy();\n }\n});\n\nfunction recordTouches(eventType, eventData) {\n if (eventType & INPUT_START) {\n this.primaryTouch = eventData.changedPointers[0].identifier;\n setLastTouch.call(this, eventData);\n } else if (eventType & (INPUT_END | INPUT_CANCEL)) {\n setLastTouch.call(this, eventData);\n }\n}\n\nfunction setLastTouch(eventData) {\n var touch = eventData.changedPointers[0];\n\n if (touch.identifier === this.primaryTouch) {\n var lastTouch = {x: touch.clientX, y: touch.clientY};\n this.lastTouches.push(lastTouch);\n var lts = this.lastTouches;\n var removeLastTouch = function() {\n var i = lts.indexOf(lastTouch);\n if (i > -1) {\n lts.splice(i, 1);\n }\n };\n setTimeout(removeLastTouch, DEDUP_TIMEOUT);\n }\n}\n\nfunction isSyntheticEvent(eventData) {\n var x = eventData.srcEvent.clientX, y = eventData.srcEvent.clientY;\n for (var i = 0; i < this.lastTouches.length; i++) {\n var t = this.lastTouches[i];\n var dx = Math.abs(x - t.x), dy = Math.abs(y - t.y);\n if (dx <= DEDUP_DISTANCE && dy <= DEDUP_DISTANCE) {\n return true;\n }\n }\n return false;\n}\n\nvar PREFIXED_TOUCH_ACTION = prefixed(TEST_ELEMENT.style, 'touchAction');\nvar NATIVE_TOUCH_ACTION = PREFIXED_TOUCH_ACTION !== undefined;\n\n// magical touchAction value\nvar TOUCH_ACTION_COMPUTE = 'compute';\nvar TOUCH_ACTION_AUTO = 'auto';\nvar TOUCH_ACTION_MANIPULATION = 'manipulation'; // not implemented\nvar TOUCH_ACTION_NONE = 'none';\nvar TOUCH_ACTION_PAN_X = 'pan-x';\nvar TOUCH_ACTION_PAN_Y = 'pan-y';\nvar TOUCH_ACTION_MAP = getTouchActionProps();\n\n/**\n * Touch Action\n * sets the touchAction property or uses the js alternative\n * @param {Manager} manager\n * @param {String} value\n * @constructor\n */\nfunction TouchAction(manager, value) {\n this.manager = manager;\n this.set(value);\n}\n\nTouchAction.prototype = {\n /**\n * set the touchAction value on the element or enable the polyfill\n * @param {String} value\n */\n set: function(value) {\n // find out the touch-action by the event handlers\n if (value == TOUCH_ACTION_COMPUTE) {\n value = this.compute();\n }\n\n if (NATIVE_TOUCH_ACTION && this.manager.element.style && TOUCH_ACTION_MAP[value]) {\n this.manager.element.style[PREFIXED_TOUCH_ACTION] = value;\n }\n this.actions = value.toLowerCase().trim();\n },\n\n /**\n * just re-set the touchAction value\n */\n update: function() {\n this.set(this.manager.options.touchAction);\n },\n\n /**\n * compute the value for the touchAction property based on the recognizer's settings\n * @returns {String} value\n */\n compute: function() {\n var actions = [];\n each(this.manager.recognizers, function(recognizer) {\n if (boolOrFn(recognizer.options.enable, [recognizer])) {\n actions = actions.concat(recognizer.getTouchAction());\n }\n });\n return cleanTouchActions(actions.join(' '));\n },\n\n /**\n * this method is called on each input cycle and provides the preventing of the browser behavior\n * @param {Object} input\n */\n preventDefaults: function(input) {\n var srcEvent = input.srcEvent;\n var direction = input.offsetDirection;\n\n // if the touch action did prevented once this session\n if (this.manager.session.prevented) {\n srcEvent.preventDefault();\n return;\n }\n\n var actions = this.actions;\n var hasNone = inStr(actions, TOUCH_ACTION_NONE) && !TOUCH_ACTION_MAP[TOUCH_ACTION_NONE];\n var hasPanY = inStr(actions, TOUCH_ACTION_PAN_Y) && !TOUCH_ACTION_MAP[TOUCH_ACTION_PAN_Y];\n var hasPanX = inStr(actions, TOUCH_ACTION_PAN_X) && !TOUCH_ACTION_MAP[TOUCH_ACTION_PAN_X];\n\n if (hasNone) {\n //do not prevent defaults if this is a tap gesture\n\n var isTapPointer = input.pointers.length === 1;\n var isTapMovement = input.distance < 2;\n var isTapTouchTime = input.deltaTime < 250;\n\n if (isTapPointer && isTapMovement && isTapTouchTime) {\n return;\n }\n }\n\n if (hasPanX && hasPanY) {\n // `pan-x pan-y` means browser handles all scrolling/panning, do not prevent\n return;\n }\n\n if (hasNone ||\n (hasPanY && direction & DIRECTION_HORIZONTAL) ||\n (hasPanX && direction & DIRECTION_VERTICAL)) {\n return this.preventSrc(srcEvent);\n }\n },\n\n /**\n * call preventDefault to prevent the browser's default behavior (scrolling in most cases)\n * @param {Object} srcEvent\n */\n preventSrc: function(srcEvent) {\n this.manager.session.prevented = true;\n srcEvent.preventDefault();\n }\n};\n\n/**\n * when the touchActions are collected they are not a valid value, so we need to clean things up. *\n * @param {String} actions\n * @returns {*}\n */\nfunction cleanTouchActions(actions) {\n // none\n if (inStr(actions, TOUCH_ACTION_NONE)) {\n return TOUCH_ACTION_NONE;\n }\n\n var hasPanX = inStr(actions, TOUCH_ACTION_PAN_X);\n var hasPanY = inStr(actions, TOUCH_ACTION_PAN_Y);\n\n // if both pan-x and pan-y are set (different recognizers\n // for different directions, e.g. horizontal pan but vertical swipe?)\n // we need none (as otherwise with pan-x pan-y combined none of these\n // recognizers will work, since the browser would handle all panning\n if (hasPanX && hasPanY) {\n return TOUCH_ACTION_NONE;\n }\n\n // pan-x OR pan-y\n if (hasPanX || hasPanY) {\n return hasPanX ? TOUCH_ACTION_PAN_X : TOUCH_ACTION_PAN_Y;\n }\n\n // manipulation\n if (inStr(actions, TOUCH_ACTION_MANIPULATION)) {\n return TOUCH_ACTION_MANIPULATION;\n }\n\n return TOUCH_ACTION_AUTO;\n}\n\nfunction getTouchActionProps() {\n if (!NATIVE_TOUCH_ACTION) {\n return false;\n }\n var touchMap = {};\n var cssSupports = window.CSS && window.CSS.supports;\n ['auto', 'manipulation', 'pan-y', 'pan-x', 'pan-x pan-y', 'none'].forEach(function(val) {\n\n // If css.supports is not supported but there is native touch-action assume it supports\n // all values. This is the case for IE 10 and 11.\n touchMap[val] = cssSupports ? window.CSS.supports('touch-action', val) : true;\n });\n return touchMap;\n}\n\n/**\n * Recognizer flow explained; *\n * All recognizers have the initial state of POSSIBLE when a input session starts.\n * The definition of a input session is from the first input until the last input, with all it's movement in it. *\n * Example session for mouse-input: mousedown -> mousemove -> mouseup\n *\n * On each recognizing cycle (see Manager.recognize) the .recognize() method is executed\n * which determines with state it should be.\n *\n * If the recognizer has the state FAILED, CANCELLED or RECOGNIZED (equals ENDED), it is reset to\n * POSSIBLE to give it another change on the next cycle.\n *\n * Possible\n * |\n * +-----+---------------+\n * | |\n * +-----+-----+ |\n * | | |\n * Failed Cancelled |\n * +-------+------+\n * | |\n * Recognized Began\n * |\n * Changed\n * |\n * Ended/Recognized\n */\nvar STATE_POSSIBLE = 1;\nvar STATE_BEGAN = 2;\nvar STATE_CHANGED = 4;\nvar STATE_ENDED = 8;\nvar STATE_RECOGNIZED = STATE_ENDED;\nvar STATE_CANCELLED = 16;\nvar STATE_FAILED = 32;\n\n/**\n * Recognizer\n * Every recognizer needs to extend from this class.\n * @constructor\n * @param {Object} options\n */\nfunction Recognizer(options) {\n this.options = assign({}, this.defaults, options || {});\n\n this.id = uniqueId();\n\n this.manager = null;\n\n // default is enable true\n this.options.enable = ifUndefined(this.options.enable, true);\n\n this.state = STATE_POSSIBLE;\n\n this.simultaneous = {};\n this.requireFail = [];\n}\n\nRecognizer.prototype = {\n /**\n * @virtual\n * @type {Object}\n */\n defaults: {},\n\n /**\n * set options\n * @param {Object} options\n * @return {Recognizer}\n */\n set: function(options) {\n assign(this.options, options);\n\n // also update the touchAction, in case something changed about the directions/enabled state\n this.manager && this.manager.touchAction.update();\n return this;\n },\n\n /**\n * recognize simultaneous with an other recognizer.\n * @param {Recognizer} otherRecognizer\n * @returns {Recognizer} this\n */\n recognizeWith: function(otherRecognizer) {\n if (invokeArrayArg(otherRecognizer, 'recognizeWith', this)) {\n return this;\n }\n\n var simultaneous = this.simultaneous;\n otherRecognizer = getRecognizerByNameIfManager(otherRecognizer, this);\n if (!simultaneous[otherRecognizer.id]) {\n simultaneous[otherRecognizer.id] = otherRecognizer;\n otherRecognizer.recognizeWith(this);\n }\n return this;\n },\n\n /**\n * drop the simultaneous link. it doesnt remove the link on the other recognizer.\n * @param {Recognizer} otherRecognizer\n * @returns {Recognizer} this\n */\n dropRecognizeWith: function(otherRecognizer) {\n if (invokeArrayArg(otherRecognizer, 'dropRecognizeWith', this)) {\n return this;\n }\n\n otherRecognizer = getRecognizerByNameIfManager(otherRecognizer, this);\n delete this.simultaneous[otherRecognizer.id];\n return this;\n },\n\n /**\n * recognizer can only run when an other is failing\n * @param {Recognizer} otherRecognizer\n * @returns {Recognizer} this\n */\n requireFailure: function(otherRecognizer) {\n if (invokeArrayArg(otherRecognizer, 'requireFailure', this)) {\n return this;\n }\n\n var requireFail = this.requireFail;\n otherRecognizer = getRecognizerByNameIfManager(otherRecognizer, this);\n if (inArray(requireFail, otherRecognizer) === -1) {\n requireFail.push(otherRecognizer);\n otherRecognizer.requireFailure(this);\n }\n return this;\n },\n\n /**\n * drop the requireFailure link. it does not remove the link on the other recognizer.\n * @param {Recognizer} otherRecognizer\n * @returns {Recognizer} this\n */\n dropRequireFailure: function(otherRecognizer) {\n if (invokeArrayArg(otherRecognizer, 'dropRequireFailure', this)) {\n return this;\n }\n\n otherRecognizer = getRecognizerByNameIfManager(otherRecognizer, this);\n var index = inArray(this.requireFail, otherRecognizer);\n if (index > -1) {\n this.requireFail.splice(index, 1);\n }\n return this;\n },\n\n /**\n * has require failures boolean\n * @returns {boolean}\n */\n hasRequireFailures: function() {\n return this.requireFail.length > 0;\n },\n\n /**\n * if the recognizer can recognize simultaneous with an other recognizer\n * @param {Recognizer} otherRecognizer\n * @returns {Boolean}\n */\n canRecognizeWith: function(otherRecognizer) {\n return !!this.simultaneous[otherRecognizer.id];\n },\n\n /**\n * You should use `tryEmit` instead of `emit` directly to check\n * that all the needed recognizers has failed before emitting.\n * @param {Object} input\n */\n emit: function(input) {\n var self = this;\n var state = this.state;\n\n function emit(event) {\n self.manager.emit(event, input);\n }\n\n // 'panstart' and 'panmove'\n if (state < STATE_ENDED) {\n emit(self.options.event + stateStr(state));\n }\n\n emit(self.options.event); // simple 'eventName' events\n\n if (input.additionalEvent) { // additional event(panleft, panright, pinchin, pinchout...)\n emit(input.additionalEvent);\n }\n\n // panend and pancancel\n if (state >= STATE_ENDED) {\n emit(self.options.event + stateStr(state));\n }\n },\n\n /**\n * Check that all the require failure recognizers has failed,\n * if true, it emits a gesture event,\n * otherwise, setup the state to FAILED.\n * @param {Object} input\n */\n tryEmit: function(input) {\n if (this.canEmit()) {\n return this.emit(input);\n }\n // it's failing anyway\n this.state = STATE_FAILED;\n },\n\n /**\n * can we emit?\n * @returns {boolean}\n */\n canEmit: function() {\n var i = 0;\n while (i < this.requireFail.length) {\n if (!(this.requireFail[i].state & (STATE_FAILED | STATE_POSSIBLE))) {\n return false;\n }\n i++;\n }\n return true;\n },\n\n /**\n * update the recognizer\n * @param {Object} inputData\n */\n recognize: function(inputData) {\n // make a new copy of the inputData\n // so we can change the inputData without messing up the other recognizers\n var inputDataClone = assign({}, inputData);\n\n // is is enabled and allow recognizing?\n if (!boolOrFn(this.options.enable, [this, inputDataClone])) {\n this.reset();\n this.state = STATE_FAILED;\n return;\n }\n\n // reset when we've reached the end\n if (this.state & (STATE_RECOGNIZED | STATE_CANCELLED | STATE_FAILED)) {\n this.state = STATE_POSSIBLE;\n }\n\n this.state = this.process(inputDataClone);\n\n // the recognizer has recognized a gesture\n // so trigger an event\n if (this.state & (STATE_BEGAN | STATE_CHANGED | STATE_ENDED | STATE_CANCELLED)) {\n this.tryEmit(inputDataClone);\n }\n },\n\n /**\n * return the state of the recognizer\n * the actual recognizing happens in this method\n * @virtual\n * @param {Object} inputData\n * @returns {Const} STATE\n */\n process: function(inputData) { }, // jshint ignore:line\n\n /**\n * return the preferred touch-action\n * @virtual\n * @returns {Array}\n */\n getTouchAction: function() { },\n\n /**\n * called when the gesture isn't allowed to recognize\n * like when another is being recognized or it is disabled\n * @virtual\n */\n reset: function() { }\n};\n\n/**\n * get a usable string, used as event postfix\n * @param {Const} state\n * @returns {String} state\n */\nfunction stateStr(state) {\n if (state & STATE_CANCELLED) {\n return 'cancel';\n } else if (state & STATE_ENDED) {\n return 'end';\n } else if (state & STATE_CHANGED) {\n return 'move';\n } else if (state & STATE_BEGAN) {\n return 'start';\n }\n return '';\n}\n\n/**\n * direction cons to string\n * @param {Const} direction\n * @returns {String}\n */\nfunction directionStr(direction) {\n if (direction == DIRECTION_DOWN) {\n return 'down';\n } else if (direction == DIRECTION_UP) {\n return 'up';\n } else if (direction == DIRECTION_LEFT) {\n return 'left';\n } else if (direction == DIRECTION_RIGHT) {\n return 'right';\n }\n return '';\n}\n\n/**\n * get a recognizer by name if it is bound to a manager\n * @param {Recognizer|String} otherRecognizer\n * @param {Recognizer} recognizer\n * @returns {Recognizer}\n */\nfunction getRecognizerByNameIfManager(otherRecognizer, recognizer) {\n var manager = recognizer.manager;\n if (manager) {\n return manager.get(otherRecognizer);\n }\n return otherRecognizer;\n}\n\n/**\n * This recognizer is just used as a base for the simple attribute recognizers.\n * @constructor\n * @extends Recognizer\n */\nfunction AttrRecognizer() {\n Recognizer.apply(this, arguments);\n}\n\ninherit(AttrRecognizer, Recognizer, {\n /**\n * @namespace\n * @memberof AttrRecognizer\n */\n defaults: {\n /**\n * @type {Number}\n * @default 1\n */\n pointers: 1\n },\n\n /**\n * Used to check if it the recognizer receives valid input, like input.distance > 10.\n * @memberof AttrRecognizer\n * @param {Object} input\n * @returns {Boolean} recognized\n */\n attrTest: function(input) {\n var optionPointers = this.options.pointers;\n return optionPointers === 0 || input.pointers.length === optionPointers;\n },\n\n /**\n * Process the input and return the state for the recognizer\n * @memberof AttrRecognizer\n * @param {Object} input\n * @returns {*} State\n */\n process: function(input) {\n var state = this.state;\n var eventType = input.eventType;\n\n var isRecognized = state & (STATE_BEGAN | STATE_CHANGED);\n var isValid = this.attrTest(input);\n\n // on cancel input and we've recognized before, return STATE_CANCELLED\n if (isRecognized && (eventType & INPUT_CANCEL || !isValid)) {\n return state | STATE_CANCELLED;\n } else if (isRecognized || isValid) {\n if (eventType & INPUT_END) {\n return state | STATE_ENDED;\n } else if (!(state & STATE_BEGAN)) {\n return STATE_BEGAN;\n }\n return state | STATE_CHANGED;\n }\n return STATE_FAILED;\n }\n});\n\n/**\n * Pan\n * Recognized when the pointer is down and moved in the allowed direction.\n * @constructor\n * @extends AttrRecognizer\n */\nfunction PanRecognizer() {\n AttrRecognizer.apply(this, arguments);\n\n this.pX = null;\n this.pY = null;\n}\n\ninherit(PanRecognizer, AttrRecognizer, {\n /**\n * @namespace\n * @memberof PanRecognizer\n */\n defaults: {\n event: 'pan',\n threshold: 10,\n pointers: 1,\n direction: DIRECTION_ALL\n },\n\n getTouchAction: function() {\n var direction = this.options.direction;\n var actions = [];\n if (direction & DIRECTION_HORIZONTAL) {\n actions.push(TOUCH_ACTION_PAN_Y);\n }\n if (direction & DIRECTION_VERTICAL) {\n actions.push(TOUCH_ACTION_PAN_X);\n }\n return actions;\n },\n\n directionTest: function(input) {\n var options = this.options;\n var hasMoved = true;\n var distance = input.distance;\n var direction = input.direction;\n var x = input.deltaX;\n var y = input.deltaY;\n\n // lock to axis?\n if (!(direction & options.direction)) {\n if (options.direction & DIRECTION_HORIZONTAL) {\n direction = (x === 0) ? DIRECTION_NONE : (x < 0) ? DIRECTION_LEFT : DIRECTION_RIGHT;\n hasMoved = x != this.pX;\n distance = Math.abs(input.deltaX);\n } else {\n direction = (y === 0) ? DIRECTION_NONE : (y < 0) ? DIRECTION_UP : DIRECTION_DOWN;\n hasMoved = y != this.pY;\n distance = Math.abs(input.deltaY);\n }\n }\n input.direction = direction;\n return hasMoved && distance > options.threshold && direction & options.direction;\n },\n\n attrTest: function(input) {\n return AttrRecognizer.prototype.attrTest.call(this, input) &&\n (this.state & STATE_BEGAN || (!(this.state & STATE_BEGAN) && this.directionTest(input)));\n },\n\n emit: function(input) {\n\n this.pX = input.deltaX;\n this.pY = input.deltaY;\n\n var direction = directionStr(input.direction);\n\n if (direction) {\n input.additionalEvent = this.options.event + direction;\n }\n this._super.emit.call(this, input);\n }\n});\n\n/**\n * Pinch\n * Recognized when two or more pointers are moving toward (zoom-in) or away from each other (zoom-out).\n * @constructor\n * @extends AttrRecognizer\n */\nfunction PinchRecognizer() {\n AttrRecognizer.apply(this, arguments);\n}\n\ninherit(PinchRecognizer, AttrRecognizer, {\n /**\n * @namespace\n * @memberof PinchRecognizer\n */\n defaults: {\n event: 'pinch',\n threshold: 0,\n pointers: 2\n },\n\n getTouchAction: function() {\n return [TOUCH_ACTION_NONE];\n },\n\n attrTest: function(input) {\n return this._super.attrTest.call(this, input) &&\n (Math.abs(input.scale - 1) > this.options.threshold || this.state & STATE_BEGAN);\n },\n\n emit: function(input) {\n if (input.scale !== 1) {\n var inOut = input.scale < 1 ? 'in' : 'out';\n input.additionalEvent = this.options.event + inOut;\n }\n this._super.emit.call(this, input);\n }\n});\n\n/**\n * Press\n * Recognized when the pointer is down for x ms without any movement.\n * @constructor\n * @extends Recognizer\n */\nfunction PressRecognizer() {\n Recognizer.apply(this, arguments);\n\n this._timer = null;\n this._input = null;\n}\n\ninherit(PressRecognizer, Recognizer, {\n /**\n * @namespace\n * @memberof PressRecognizer\n */\n defaults: {\n event: 'press',\n pointers: 1,\n time: 251, // minimal time of the pointer to be pressed\n threshold: 9 // a minimal movement is ok, but keep it low\n },\n\n getTouchAction: function() {\n return [TOUCH_ACTION_AUTO];\n },\n\n process: function(input) {\n var options = this.options;\n var validPointers = input.pointers.length === options.pointers;\n var validMovement = input.distance < options.threshold;\n var validTime = input.deltaTime > options.time;\n\n this._input = input;\n\n // we only allow little movement\n // and we've reached an end event, so a tap is possible\n if (!validMovement || !validPointers || (input.eventType & (INPUT_END | INPUT_CANCEL) && !validTime)) {\n this.reset();\n } else if (input.eventType & INPUT_START) {\n this.reset();\n this._timer = setTimeoutContext(function() {\n this.state = STATE_RECOGNIZED;\n this.tryEmit();\n }, options.time, this);\n } else if (input.eventType & INPUT_END) {\n return STATE_RECOGNIZED;\n }\n return STATE_FAILED;\n },\n\n reset: function() {\n clearTimeout(this._timer);\n },\n\n emit: function(input) {\n if (this.state !== STATE_RECOGNIZED) {\n return;\n }\n\n if (input && (input.eventType & INPUT_END)) {\n this.manager.emit(this.options.event + 'up', input);\n } else {\n this._input.timeStamp = now();\n this.manager.emit(this.options.event, this._input);\n }\n }\n});\n\n/**\n * Rotate\n * Recognized when two or more pointer are moving in a circular motion.\n * @constructor\n * @extends AttrRecognizer\n */\nfunction RotateRecognizer() {\n AttrRecognizer.apply(this, arguments);\n}\n\ninherit(RotateRecognizer, AttrRecognizer, {\n /**\n * @namespace\n * @memberof RotateRecognizer\n */\n defaults: {\n event: 'rotate',\n threshold: 0,\n pointers: 2\n },\n\n getTouchAction: function() {\n return [TOUCH_ACTION_NONE];\n },\n\n attrTest: function(input) {\n return this._super.attrTest.call(this, input) &&\n (Math.abs(input.rotation) > this.options.threshold || this.state & STATE_BEGAN);\n }\n});\n\n/**\n * Swipe\n * Recognized when the pointer is moving fast (velocity), with enough distance in the allowed direction.\n * @constructor\n * @extends AttrRecognizer\n */\nfunction SwipeRecognizer() {\n AttrRecognizer.apply(this, arguments);\n}\n\ninherit(SwipeRecognizer, AttrRecognizer, {\n /**\n * @namespace\n * @memberof SwipeRecognizer\n */\n defaults: {\n event: 'swipe',\n threshold: 10,\n velocity: 0.3,\n direction: DIRECTION_HORIZONTAL | DIRECTION_VERTICAL,\n pointers: 1\n },\n\n getTouchAction: function() {\n return PanRecognizer.prototype.getTouchAction.call(this);\n },\n\n attrTest: function(input) {\n var direction = this.options.direction;\n var velocity;\n\n if (direction & (DIRECTION_HORIZONTAL | DIRECTION_VERTICAL)) {\n velocity = input.overallVelocity;\n } else if (direction & DIRECTION_HORIZONTAL) {\n velocity = input.overallVelocityX;\n } else if (direction & DIRECTION_VERTICAL) {\n velocity = input.overallVelocityY;\n }\n\n return this._super.attrTest.call(this, input) &&\n direction & input.offsetDirection &&\n input.distance > this.options.threshold &&\n input.maxPointers == this.options.pointers &&\n abs(velocity) > this.options.velocity && input.eventType & INPUT_END;\n },\n\n emit: function(input) {\n var direction = directionStr(input.offsetDirection);\n if (direction) {\n this.manager.emit(this.options.event + direction, input);\n }\n\n this.manager.emit(this.options.event, input);\n }\n});\n\n/**\n * A tap is ecognized when the pointer is doing a small tap/click. Multiple taps are recognized if they occur\n * between the given interval and position. The delay option can be used to recognize multi-taps without firing\n * a single tap.\n *\n * The eventData from the emitted event contains the property `tapCount`, which contains the amount of\n * multi-taps being recognized.\n * @constructor\n * @extends Recognizer\n */\nfunction TapRecognizer() {\n Recognizer.apply(this, arguments);\n\n // previous time and center,\n // used for tap counting\n this.pTime = false;\n this.pCenter = false;\n\n this._timer = null;\n this._input = null;\n this.count = 0;\n}\n\ninherit(TapRecognizer, Recognizer, {\n /**\n * @namespace\n * @memberof PinchRecognizer\n */\n defaults: {\n event: 'tap',\n pointers: 1,\n taps: 1,\n interval: 300, // max time between the multi-tap taps\n time: 250, // max time of the pointer to be down (like finger on the screen)\n threshold: 9, // a minimal movement is ok, but keep it low\n posThreshold: 10 // a multi-tap can be a bit off the initial position\n },\n\n getTouchAction: function() {\n return [TOUCH_ACTION_MANIPULATION];\n },\n\n process: function(input) {\n var options = this.options;\n\n var validPointers = input.pointers.length === options.pointers;\n var validMovement = input.distance < options.threshold;\n var validTouchTime = input.deltaTime < options.time;\n\n this.reset();\n\n if ((input.eventType & INPUT_START) && (this.count === 0)) {\n return this.failTimeout();\n }\n\n // we only allow little movement\n // and we've reached an end event, so a tap is possible\n if (validMovement && validTouchTime && validPointers) {\n if (input.eventType != INPUT_END) {\n return this.failTimeout();\n }\n\n var validInterval = this.pTime ? (input.timeStamp - this.pTime < options.interval) : true;\n var validMultiTap = !this.pCenter || getDistance(this.pCenter, input.center) < options.posThreshold;\n\n this.pTime = input.timeStamp;\n this.pCenter = input.center;\n\n if (!validMultiTap || !validInterval) {\n this.count = 1;\n } else {\n this.count += 1;\n }\n\n this._input = input;\n\n // if tap count matches we have recognized it,\n // else it has began recognizing...\n var tapCount = this.count % options.taps;\n if (tapCount === 0) {\n // no failing requirements, immediately trigger the tap event\n // or wait as long as the multitap interval to trigger\n if (!this.hasRequireFailures()) {\n return STATE_RECOGNIZED;\n } else {\n this._timer = setTimeoutContext(function() {\n this.state = STATE_RECOGNIZED;\n this.tryEmit();\n }, options.interval, this);\n return STATE_BEGAN;\n }\n }\n }\n return STATE_FAILED;\n },\n\n failTimeout: function() {\n this._timer = setTimeoutContext(function() {\n this.state = STATE_FAILED;\n }, this.options.interval, this);\n return STATE_FAILED;\n },\n\n reset: function() {\n clearTimeout(this._timer);\n },\n\n emit: function() {\n if (this.state == STATE_RECOGNIZED) {\n this._input.tapCount = this.count;\n this.manager.emit(this.options.event, this._input);\n }\n }\n});\n\n/**\n * Simple way to create a manager with a default set of recognizers.\n * @param {HTMLElement} element\n * @param {Object} [options]\n * @constructor\n */\nfunction Hammer(element, options) {\n options = options || {};\n options.recognizers = ifUndefined(options.recognizers, Hammer.defaults.preset);\n return new Manager(element, options);\n}\n\n/**\n * @const {string}\n */\nHammer.VERSION = '2.0.7';\n\n/**\n * default settings\n * @namespace\n */\nHammer.defaults = {\n /**\n * set if DOM events are being triggered.\n * But this is slower and unused by simple implementations, so disabled by default.\n * @type {Boolean}\n * @default false\n */\n domEvents: false,\n\n /**\n * The value for the touchAction property/fallback.\n * When set to `compute` it will magically set the correct value based on the added recognizers.\n * @type {String}\n * @default compute\n */\n touchAction: TOUCH_ACTION_COMPUTE,\n\n /**\n * @type {Boolean}\n * @default true\n */\n enable: true,\n\n /**\n * EXPERIMENTAL FEATURE -- can be removed/changed\n * Change the parent input target element.\n * If Null, then it is being set the to main element.\n * @type {Null|EventTarget}\n * @default null\n */\n inputTarget: null,\n\n /**\n * force an input class\n * @type {Null|Function}\n * @default null\n */\n inputClass: null,\n\n /**\n * Default recognizer setup when calling `Hammer()`\n * When creating a new Manager these will be skipped.\n * @type {Array}\n */\n preset: [\n // RecognizerClass, options, [recognizeWith, ...], [requireFailure, ...]\n [RotateRecognizer, {enable: false}],\n [PinchRecognizer, {enable: false}, ['rotate']],\n [SwipeRecognizer, {direction: DIRECTION_HORIZONTAL}],\n [PanRecognizer, {direction: DIRECTION_HORIZONTAL}, ['swipe']],\n [TapRecognizer],\n [TapRecognizer, {event: 'doubletap', taps: 2}, ['tap']],\n [PressRecognizer]\n ],\n\n /**\n * Some CSS properties can be used to improve the working of Hammer.\n * Add them to this method and they will be set when creating a new Manager.\n * @namespace\n */\n cssProps: {\n /**\n * Disables text selection to improve the dragging gesture. Mainly for desktop browsers.\n * @type {String}\n * @default 'none'\n */\n userSelect: 'none',\n\n /**\n * Disable the Windows Phone grippers when pressing an element.\n * @type {String}\n * @default 'none'\n */\n touchSelect: 'none',\n\n /**\n * Disables the default callout shown when you touch and hold a touch target.\n * On iOS, when you touch and hold a touch target such as a link, Safari displays\n * a callout containing information about the link. This property allows you to disable that callout.\n * @type {String}\n * @default 'none'\n */\n touchCallout: 'none',\n\n /**\n * Specifies whether zooming is enabled. Used by IE10>\n * @type {String}\n * @default 'none'\n */\n contentZooming: 'none',\n\n /**\n * Specifies that an entire element should be draggable instead of its contents. Mainly for desktop browsers.\n * @type {String}\n * @default 'none'\n */\n userDrag: 'none',\n\n /**\n * Overrides the highlight color shown when the user taps a link or a JavaScript\n * clickable element in iOS. This property obeys the alpha value, if specified.\n * @type {String}\n * @default 'rgba(0,0,0,0)'\n */\n tapHighlightColor: 'rgba(0,0,0,0)'\n }\n};\n\nvar STOP = 1;\nvar FORCED_STOP = 2;\n\n/**\n * Manager\n * @param {HTMLElement} element\n * @param {Object} [options]\n * @constructor\n */\nfunction Manager(element, options) {\n this.options = assign({}, Hammer.defaults, options || {});\n\n this.options.inputTarget = this.options.inputTarget || element;\n\n this.handlers = {};\n this.session = {};\n this.recognizers = [];\n this.oldCssProps = {};\n\n this.element = element;\n this.input = createInputInstance(this);\n this.touchAction = new TouchAction(this, this.options.touchAction);\n\n toggleCssProps(this, true);\n\n each(this.options.recognizers, function(item) {\n var recognizer = this.add(new (item[0])(item[1]));\n item[2] && recognizer.recognizeWith(item[2]);\n item[3] && recognizer.requireFailure(item[3]);\n }, this);\n}\n\nManager.prototype = {\n /**\n * set options\n * @param {Object} options\n * @returns {Manager}\n */\n set: function(options) {\n assign(this.options, options);\n\n // Options that need a little more setup\n if (options.touchAction) {\n this.touchAction.update();\n }\n if (options.inputTarget) {\n // Clean up existing event listeners and reinitialize\n this.input.destroy();\n this.input.target = options.inputTarget;\n this.input.init();\n }\n return this;\n },\n\n /**\n * stop recognizing for this session.\n * This session will be discarded, when a new [input]start event is fired.\n * When forced, the recognizer cycle is stopped immediately.\n * @param {Boolean} [force]\n */\n stop: function(force) {\n this.session.stopped = force ? FORCED_STOP : STOP;\n },\n\n /**\n * run the recognizers!\n * called by the inputHandler function on every movement of the pointers (touches)\n * it walks through all the recognizers and tries to detect the gesture that is being made\n * @param {Object} inputData\n */\n recognize: function(inputData) {\n var session = this.session;\n if (session.stopped) {\n return;\n }\n\n // run the touch-action polyfill\n this.touchAction.preventDefaults(inputData);\n\n var recognizer;\n var recognizers = this.recognizers;\n\n // this holds the recognizer that is being recognized.\n // so the recognizer's state needs to be BEGAN, CHANGED, ENDED or RECOGNIZED\n // if no recognizer is detecting a thing, it is set to `null`\n var curRecognizer = session.curRecognizer;\n\n // reset when the last recognizer is recognized\n // or when we're in a new session\n if (!curRecognizer || (curRecognizer && curRecognizer.state & STATE_RECOGNIZED)) {\n curRecognizer = session.curRecognizer = null;\n }\n\n var i = 0;\n while (i < recognizers.length) {\n recognizer = recognizers[i];\n\n // find out if we are allowed try to recognize the input for this one.\n // 1. allow if the session is NOT forced stopped (see the .stop() method)\n // 2. allow if we still haven't recognized a gesture in this session, or the this recognizer is the one\n // that is being recognized.\n // 3. allow if the recognizer is allowed to run simultaneous with the current recognized recognizer.\n // this can be setup with the `recognizeWith()` method on the recognizer.\n if (session.stopped !== FORCED_STOP && ( // 1\n !curRecognizer || recognizer == curRecognizer || // 2\n recognizer.canRecognizeWith(curRecognizer))) { // 3\n recognizer.recognize(inputData);\n } else {\n recognizer.reset();\n }\n\n // if the recognizer has been recognizing the input as a valid gesture, we want to store this one as the\n // current active recognizer. but only if we don't already have an active recognizer\n if (!curRecognizer && recognizer.state & (STATE_BEGAN | STATE_CHANGED | STATE_ENDED)) {\n curRecognizer = session.curRecognizer = recognizer;\n }\n i++;\n }\n },\n\n /**\n * get a recognizer by its event name.\n * @param {Recognizer|String} recognizer\n * @returns {Recognizer|Null}\n */\n get: function(recognizer) {\n if (recognizer instanceof Recognizer) {\n return recognizer;\n }\n\n var recognizers = this.recognizers;\n for (var i = 0; i < recognizers.length; i++) {\n if (recognizers[i].options.event == recognizer) {\n return recognizers[i];\n }\n }\n return null;\n },\n\n /**\n * add a recognizer to the manager\n * existing recognizers with the same event name will be removed\n * @param {Recognizer} recognizer\n * @returns {Recognizer|Manager}\n */\n add: function(recognizer) {\n if (invokeArrayArg(recognizer, 'add', this)) {\n return this;\n }\n\n // remove existing\n var existing = this.get(recognizer.options.event);\n if (existing) {\n this.remove(existing);\n }\n\n this.recognizers.push(recognizer);\n recognizer.manager = this;\n\n this.touchAction.update();\n return recognizer;\n },\n\n /**\n * remove a recognizer by name or instance\n * @param {Recognizer|String} recognizer\n * @returns {Manager}\n */\n remove: function(recognizer) {\n if (invokeArrayArg(recognizer, 'remove', this)) {\n return this;\n }\n\n recognizer = this.get(recognizer);\n\n // let's make sure this recognizer exists\n if (recognizer) {\n var recognizers = this.recognizers;\n var index = inArray(recognizers, recognizer);\n\n if (index !== -1) {\n recognizers.splice(index, 1);\n this.touchAction.update();\n }\n }\n\n return this;\n },\n\n /**\n * bind event\n * @param {String} events\n * @param {Function} handler\n * @returns {EventEmitter} this\n */\n on: function(events, handler) {\n if (events === undefined) {\n return;\n }\n if (handler === undefined) {\n return;\n }\n\n var handlers = this.handlers;\n each(splitStr(events), function(event) {\n handlers[event] = handlers[event] || [];\n handlers[event].push(handler);\n });\n return this;\n },\n\n /**\n * unbind event, leave emit blank to remove all handlers\n * @param {String} events\n * @param {Function} [handler]\n * @returns {EventEmitter} this\n */\n off: function(events, handler) {\n if (events === undefined) {\n return;\n }\n\n var handlers = this.handlers;\n each(splitStr(events), function(event) {\n if (!handler) {\n delete handlers[event];\n } else {\n handlers[event] && handlers[event].splice(inArray(handlers[event], handler), 1);\n }\n });\n return this;\n },\n\n /**\n * emit event to the listeners\n * @param {String} event\n * @param {Object} data\n */\n emit: function(event, data) {\n // we also want to trigger dom events\n if (this.options.domEvents) {\n triggerDomEvent(event, data);\n }\n\n // no handlers, so skip it all\n var handlers = this.handlers[event] && this.handlers[event].slice();\n if (!handlers || !handlers.length) {\n return;\n }\n\n data.type = event;\n data.preventDefault = function() {\n data.srcEvent.preventDefault();\n };\n\n var i = 0;\n while (i < handlers.length) {\n handlers[i](data);\n i++;\n }\n },\n\n /**\n * destroy the manager and unbinds all events\n * it doesn't unbind dom events, that is the user own responsibility\n */\n destroy: function() {\n this.element && toggleCssProps(this, false);\n\n this.handlers = {};\n this.session = {};\n this.input.destroy();\n this.element = null;\n }\n};\n\n/**\n * add/remove the css properties as defined in manager.options.cssProps\n * @param {Manager} manager\n * @param {Boolean} add\n */\nfunction toggleCssProps(manager, add) {\n var element = manager.element;\n if (!element.style) {\n return;\n }\n var prop;\n each(manager.options.cssProps, function(value, name) {\n prop = prefixed(element.style, name);\n if (add) {\n manager.oldCssProps[prop] = element.style[prop];\n element.style[prop] = value;\n } else {\n element.style[prop] = manager.oldCssProps[prop] || '';\n }\n });\n if (!add) {\n manager.oldCssProps = {};\n }\n}\n\n/**\n * trigger dom event\n * @param {String} event\n * @param {Object} data\n */\nfunction triggerDomEvent(event, data) {\n var gestureEvent = document.createEvent('Event');\n gestureEvent.initEvent(event, true, true);\n gestureEvent.gesture = data;\n data.target.dispatchEvent(gestureEvent);\n}\n\nassign(Hammer, {\n INPUT_START: INPUT_START,\n INPUT_MOVE: INPUT_MOVE,\n INPUT_END: INPUT_END,\n INPUT_CANCEL: INPUT_CANCEL,\n\n STATE_POSSIBLE: STATE_POSSIBLE,\n STATE_BEGAN: STATE_BEGAN,\n STATE_CHANGED: STATE_CHANGED,\n STATE_ENDED: STATE_ENDED,\n STATE_RECOGNIZED: STATE_RECOGNIZED,\n STATE_CANCELLED: STATE_CANCELLED,\n STATE_FAILED: STATE_FAILED,\n\n DIRECTION_NONE: DIRECTION_NONE,\n DIRECTION_LEFT: DIRECTION_LEFT,\n DIRECTION_RIGHT: DIRECTION_RIGHT,\n DIRECTION_UP: DIRECTION_UP,\n DIRECTION_DOWN: DIRECTION_DOWN,\n DIRECTION_HORIZONTAL: DIRECTION_HORIZONTAL,\n DIRECTION_VERTICAL: DIRECTION_VERTICAL,\n DIRECTION_ALL: DIRECTION_ALL,\n\n Manager: Manager,\n Input: Input,\n TouchAction: TouchAction,\n\n TouchInput: TouchInput,\n MouseInput: MouseInput,\n PointerEventInput: PointerEventInput,\n TouchMouseInput: TouchMouseInput,\n SingleTouchInput: SingleTouchInput,\n\n Recognizer: Recognizer,\n AttrRecognizer: AttrRecognizer,\n Tap: TapRecognizer,\n Pan: PanRecognizer,\n Swipe: SwipeRecognizer,\n Pinch: PinchRecognizer,\n Rotate: RotateRecognizer,\n Press: PressRecognizer,\n\n on: addEventListeners,\n off: removeEventListeners,\n each: each,\n merge: merge,\n extend: extend,\n assign: assign,\n inherit: inherit,\n bindFn: bindFn,\n prefixed: prefixed\n});\n\n// this prevents errors when Hammer is loaded in the presence of an AMD\n// style loader but by script tag, not by the loader.\nvar freeGlobal = (typeof window !== 'undefined' ? window : (typeof self !== 'undefined' ? self : {})); // jshint ignore:line\nfreeGlobal.Hammer = Hammer;\n\nif (typeof define === 'function' && define.amd) {\n define(function() {\n return Hammer;\n });\n} else if (typeof module != 'undefined' && module.exports) {\n module.exports = Hammer;\n} else {\n window[exportName] = Hammer;\n}\n\n})(window, document, 'Hammer');\n","export { default } from \"../shared/lib/image-external\";\nexport * from \"../shared/lib/image-external\";\n\n//# sourceMappingURL=image.js.map",null,"/*!\n * @kurkle/color v0.3.2\n * https://github.com/kurkle/color#readme\n * (c) 2023 Jukka Kurkela\n * Released under the MIT License\n */\nfunction round(v) {\n return v + 0.5 | 0;\n}\nconst lim = (v, l, h) => Math.max(Math.min(v, h), l);\nfunction p2b(v) {\n return lim(round(v * 2.55), 0, 255);\n}\nfunction b2p(v) {\n return lim(round(v / 2.55), 0, 100);\n}\nfunction n2b(v) {\n return lim(round(v * 255), 0, 255);\n}\nfunction b2n(v) {\n return lim(round(v / 2.55) / 100, 0, 1);\n}\nfunction n2p(v) {\n return lim(round(v * 100), 0, 100);\n}\n\nconst map$1 = {0: 0, 1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6, 7: 7, 8: 8, 9: 9, A: 10, B: 11, C: 12, D: 13, E: 14, F: 15, a: 10, b: 11, c: 12, d: 13, e: 14, f: 15};\nconst hex = [...'0123456789ABCDEF'];\nconst h1 = b => hex[b & 0xF];\nconst h2 = b => hex[(b & 0xF0) >> 4] + hex[b & 0xF];\nconst eq = b => ((b & 0xF0) >> 4) === (b & 0xF);\nconst isShort = v => eq(v.r) && eq(v.g) && eq(v.b) && eq(v.a);\nfunction hexParse(str) {\n var len = str.length;\n var ret;\n if (str[0] === '#') {\n if (len === 4 || len === 5) {\n ret = {\n r: 255 & map$1[str[1]] * 17,\n g: 255 & map$1[str[2]] * 17,\n b: 255 & map$1[str[3]] * 17,\n a: len === 5 ? map$1[str[4]] * 17 : 255\n };\n } else if (len === 7 || len === 9) {\n ret = {\n r: map$1[str[1]] << 4 | map$1[str[2]],\n g: map$1[str[3]] << 4 | map$1[str[4]],\n b: map$1[str[5]] << 4 | map$1[str[6]],\n a: len === 9 ? (map$1[str[7]] << 4 | map$1[str[8]]) : 255\n };\n }\n }\n return ret;\n}\nconst alpha = (a, f) => a < 255 ? f(a) : '';\nfunction hexString(v) {\n var f = isShort(v) ? h1 : h2;\n return v\n ? '#' + f(v.r) + f(v.g) + f(v.b) + alpha(v.a, f)\n : undefined;\n}\n\nconst HUE_RE = /^(hsla?|hwb|hsv)\\(\\s*([-+.e\\d]+)(?:deg)?[\\s,]+([-+.e\\d]+)%[\\s,]+([-+.e\\d]+)%(?:[\\s,]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction hsl2rgbn(h, s, l) {\n const a = s * Math.min(l, 1 - l);\n const f = (n, k = (n + h / 30) % 12) => l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);\n return [f(0), f(8), f(4)];\n}\nfunction hsv2rgbn(h, s, v) {\n const f = (n, k = (n + h / 60) % 6) => v - v * s * Math.max(Math.min(k, 4 - k, 1), 0);\n return [f(5), f(3), f(1)];\n}\nfunction hwb2rgbn(h, w, b) {\n const rgb = hsl2rgbn(h, 1, 0.5);\n let i;\n if (w + b > 1) {\n i = 1 / (w + b);\n w *= i;\n b *= i;\n }\n for (i = 0; i < 3; i++) {\n rgb[i] *= 1 - w - b;\n rgb[i] += w;\n }\n return rgb;\n}\nfunction hueValue(r, g, b, d, max) {\n if (r === max) {\n return ((g - b) / d) + (g < b ? 6 : 0);\n }\n if (g === max) {\n return (b - r) / d + 2;\n }\n return (r - g) / d + 4;\n}\nfunction rgb2hsl(v) {\n const range = 255;\n const r = v.r / range;\n const g = v.g / range;\n const b = v.b / range;\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n const l = (max + min) / 2;\n let h, s, d;\n if (max !== min) {\n d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n h = hueValue(r, g, b, d, max);\n h = h * 60 + 0.5;\n }\n return [h | 0, s || 0, l];\n}\nfunction calln(f, a, b, c) {\n return (\n Array.isArray(a)\n ? f(a[0], a[1], a[2])\n : f(a, b, c)\n ).map(n2b);\n}\nfunction hsl2rgb(h, s, l) {\n return calln(hsl2rgbn, h, s, l);\n}\nfunction hwb2rgb(h, w, b) {\n return calln(hwb2rgbn, h, w, b);\n}\nfunction hsv2rgb(h, s, v) {\n return calln(hsv2rgbn, h, s, v);\n}\nfunction hue(h) {\n return (h % 360 + 360) % 360;\n}\nfunction hueParse(str) {\n const m = HUE_RE.exec(str);\n let a = 255;\n let v;\n if (!m) {\n return;\n }\n if (m[5] !== v) {\n a = m[6] ? p2b(+m[5]) : n2b(+m[5]);\n }\n const h = hue(+m[2]);\n const p1 = +m[3] / 100;\n const p2 = +m[4] / 100;\n if (m[1] === 'hwb') {\n v = hwb2rgb(h, p1, p2);\n } else if (m[1] === 'hsv') {\n v = hsv2rgb(h, p1, p2);\n } else {\n v = hsl2rgb(h, p1, p2);\n }\n return {\n r: v[0],\n g: v[1],\n b: v[2],\n a: a\n };\n}\nfunction rotate(v, deg) {\n var h = rgb2hsl(v);\n h[0] = hue(h[0] + deg);\n h = hsl2rgb(h);\n v.r = h[0];\n v.g = h[1];\n v.b = h[2];\n}\nfunction hslString(v) {\n if (!v) {\n return;\n }\n const a = rgb2hsl(v);\n const h = a[0];\n const s = n2p(a[1]);\n const l = n2p(a[2]);\n return v.a < 255\n ? `hsla(${h}, ${s}%, ${l}%, ${b2n(v.a)})`\n : `hsl(${h}, ${s}%, ${l}%)`;\n}\n\nconst map = {\n x: 'dark',\n Z: 'light',\n Y: 're',\n X: 'blu',\n W: 'gr',\n V: 'medium',\n U: 'slate',\n A: 'ee',\n T: 'ol',\n S: 'or',\n B: 'ra',\n C: 'lateg',\n D: 'ights',\n R: 'in',\n Q: 'turquois',\n E: 'hi',\n P: 'ro',\n O: 'al',\n N: 'le',\n M: 'de',\n L: 'yello',\n F: 'en',\n K: 'ch',\n G: 'arks',\n H: 'ea',\n I: 'ightg',\n J: 'wh'\n};\nconst names$1 = {\n OiceXe: 'f0f8ff',\n antiquewEte: 'faebd7',\n aqua: 'ffff',\n aquamarRe: '7fffd4',\n azuY: 'f0ffff',\n beige: 'f5f5dc',\n bisque: 'ffe4c4',\n black: '0',\n blanKedOmond: 'ffebcd',\n Xe: 'ff',\n XeviTet: '8a2be2',\n bPwn: 'a52a2a',\n burlywood: 'deb887',\n caMtXe: '5f9ea0',\n KartYuse: '7fff00',\n KocTate: 'd2691e',\n cSO: 'ff7f50',\n cSnflowerXe: '6495ed',\n cSnsilk: 'fff8dc',\n crimson: 'dc143c',\n cyan: 'ffff',\n xXe: '8b',\n xcyan: '8b8b',\n xgTMnPd: 'b8860b',\n xWay: 'a9a9a9',\n xgYF: '6400',\n xgYy: 'a9a9a9',\n xkhaki: 'bdb76b',\n xmagFta: '8b008b',\n xTivegYF: '556b2f',\n xSange: 'ff8c00',\n xScEd: '9932cc',\n xYd: '8b0000',\n xsOmon: 'e9967a',\n xsHgYF: '8fbc8f',\n xUXe: '483d8b',\n xUWay: '2f4f4f',\n xUgYy: '2f4f4f',\n xQe: 'ced1',\n xviTet: '9400d3',\n dAppRk: 'ff1493',\n dApskyXe: 'bfff',\n dimWay: '696969',\n dimgYy: '696969',\n dodgerXe: '1e90ff',\n fiYbrick: 'b22222',\n flSOwEte: 'fffaf0',\n foYstWAn: '228b22',\n fuKsia: 'ff00ff',\n gaRsbSo: 'dcdcdc',\n ghostwEte: 'f8f8ff',\n gTd: 'ffd700',\n gTMnPd: 'daa520',\n Way: '808080',\n gYF: '8000',\n gYFLw: 'adff2f',\n gYy: '808080',\n honeyMw: 'f0fff0',\n hotpRk: 'ff69b4',\n RdianYd: 'cd5c5c',\n Rdigo: '4b0082',\n ivSy: 'fffff0',\n khaki: 'f0e68c',\n lavFMr: 'e6e6fa',\n lavFMrXsh: 'fff0f5',\n lawngYF: '7cfc00',\n NmoncEffon: 'fffacd',\n ZXe: 'add8e6',\n ZcSO: 'f08080',\n Zcyan: 'e0ffff',\n ZgTMnPdLw: 'fafad2',\n ZWay: 'd3d3d3',\n ZgYF: '90ee90',\n ZgYy: 'd3d3d3',\n ZpRk: 'ffb6c1',\n ZsOmon: 'ffa07a',\n ZsHgYF: '20b2aa',\n ZskyXe: '87cefa',\n ZUWay: '778899',\n ZUgYy: '778899',\n ZstAlXe: 'b0c4de',\n ZLw: 'ffffe0',\n lime: 'ff00',\n limegYF: '32cd32',\n lRF: 'faf0e6',\n magFta: 'ff00ff',\n maPon: '800000',\n VaquamarRe: '66cdaa',\n VXe: 'cd',\n VScEd: 'ba55d3',\n VpurpN: '9370db',\n VsHgYF: '3cb371',\n VUXe: '7b68ee',\n VsprRggYF: 'fa9a',\n VQe: '48d1cc',\n VviTetYd: 'c71585',\n midnightXe: '191970',\n mRtcYam: 'f5fffa',\n mistyPse: 'ffe4e1',\n moccasR: 'ffe4b5',\n navajowEte: 'ffdead',\n navy: '80',\n Tdlace: 'fdf5e6',\n Tive: '808000',\n TivedBb: '6b8e23',\n Sange: 'ffa500',\n SangeYd: 'ff4500',\n ScEd: 'da70d6',\n pOegTMnPd: 'eee8aa',\n pOegYF: '98fb98',\n pOeQe: 'afeeee',\n pOeviTetYd: 'db7093',\n papayawEp: 'ffefd5',\n pHKpuff: 'ffdab9',\n peru: 'cd853f',\n pRk: 'ffc0cb',\n plum: 'dda0dd',\n powMrXe: 'b0e0e6',\n purpN: '800080',\n YbeccapurpN: '663399',\n Yd: 'ff0000',\n Psybrown: 'bc8f8f',\n PyOXe: '4169e1',\n saddNbPwn: '8b4513',\n sOmon: 'fa8072',\n sandybPwn: 'f4a460',\n sHgYF: '2e8b57',\n sHshell: 'fff5ee',\n siFna: 'a0522d',\n silver: 'c0c0c0',\n skyXe: '87ceeb',\n UXe: '6a5acd',\n UWay: '708090',\n UgYy: '708090',\n snow: 'fffafa',\n sprRggYF: 'ff7f',\n stAlXe: '4682b4',\n tan: 'd2b48c',\n teO: '8080',\n tEstN: 'd8bfd8',\n tomato: 'ff6347',\n Qe: '40e0d0',\n viTet: 'ee82ee',\n JHt: 'f5deb3',\n wEte: 'ffffff',\n wEtesmoke: 'f5f5f5',\n Lw: 'ffff00',\n LwgYF: '9acd32'\n};\nfunction unpack() {\n const unpacked = {};\n const keys = Object.keys(names$1);\n const tkeys = Object.keys(map);\n let i, j, k, ok, nk;\n for (i = 0; i < keys.length; i++) {\n ok = nk = keys[i];\n for (j = 0; j < tkeys.length; j++) {\n k = tkeys[j];\n nk = nk.replace(k, map[k]);\n }\n k = parseInt(names$1[ok], 16);\n unpacked[nk] = [k >> 16 & 0xFF, k >> 8 & 0xFF, k & 0xFF];\n }\n return unpacked;\n}\n\nlet names;\nfunction nameParse(str) {\n if (!names) {\n names = unpack();\n names.transparent = [0, 0, 0, 0];\n }\n const a = names[str.toLowerCase()];\n return a && {\n r: a[0],\n g: a[1],\n b: a[2],\n a: a.length === 4 ? a[3] : 255\n };\n}\n\nconst RGB_RE = /^rgba?\\(\\s*([-+.\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?(?:[\\s,/]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction rgbParse(str) {\n const m = RGB_RE.exec(str);\n let a = 255;\n let r, g, b;\n if (!m) {\n return;\n }\n if (m[7] !== r) {\n const v = +m[7];\n a = m[8] ? p2b(v) : lim(v * 255, 0, 255);\n }\n r = +m[1];\n g = +m[3];\n b = +m[5];\n r = 255 & (m[2] ? p2b(r) : lim(r, 0, 255));\n g = 255 & (m[4] ? p2b(g) : lim(g, 0, 255));\n b = 255 & (m[6] ? p2b(b) : lim(b, 0, 255));\n return {\n r: r,\n g: g,\n b: b,\n a: a\n };\n}\nfunction rgbString(v) {\n return v && (\n v.a < 255\n ? `rgba(${v.r}, ${v.g}, ${v.b}, ${b2n(v.a)})`\n : `rgb(${v.r}, ${v.g}, ${v.b})`\n );\n}\n\nconst to = v => v <= 0.0031308 ? v * 12.92 : Math.pow(v, 1.0 / 2.4) * 1.055 - 0.055;\nconst from = v => v <= 0.04045 ? v / 12.92 : Math.pow((v + 0.055) / 1.055, 2.4);\nfunction interpolate(rgb1, rgb2, t) {\n const r = from(b2n(rgb1.r));\n const g = from(b2n(rgb1.g));\n const b = from(b2n(rgb1.b));\n return {\n r: n2b(to(r + t * (from(b2n(rgb2.r)) - r))),\n g: n2b(to(g + t * (from(b2n(rgb2.g)) - g))),\n b: n2b(to(b + t * (from(b2n(rgb2.b)) - b))),\n a: rgb1.a + t * (rgb2.a - rgb1.a)\n };\n}\n\nfunction modHSL(v, i, ratio) {\n if (v) {\n let tmp = rgb2hsl(v);\n tmp[i] = Math.max(0, Math.min(tmp[i] + tmp[i] * ratio, i === 0 ? 360 : 1));\n tmp = hsl2rgb(tmp);\n v.r = tmp[0];\n v.g = tmp[1];\n v.b = tmp[2];\n }\n}\nfunction clone(v, proto) {\n return v ? Object.assign(proto || {}, v) : v;\n}\nfunction fromObject(input) {\n var v = {r: 0, g: 0, b: 0, a: 255};\n if (Array.isArray(input)) {\n if (input.length >= 3) {\n v = {r: input[0], g: input[1], b: input[2], a: 255};\n if (input.length > 3) {\n v.a = n2b(input[3]);\n }\n }\n } else {\n v = clone(input, {r: 0, g: 0, b: 0, a: 1});\n v.a = n2b(v.a);\n }\n return v;\n}\nfunction functionParse(str) {\n if (str.charAt(0) === 'r') {\n return rgbParse(str);\n }\n return hueParse(str);\n}\nclass Color {\n constructor(input) {\n if (input instanceof Color) {\n return input;\n }\n const type = typeof input;\n let v;\n if (type === 'object') {\n v = fromObject(input);\n } else if (type === 'string') {\n v = hexParse(input) || nameParse(input) || functionParse(input);\n }\n this._rgb = v;\n this._valid = !!v;\n }\n get valid() {\n return this._valid;\n }\n get rgb() {\n var v = clone(this._rgb);\n if (v) {\n v.a = b2n(v.a);\n }\n return v;\n }\n set rgb(obj) {\n this._rgb = fromObject(obj);\n }\n rgbString() {\n return this._valid ? rgbString(this._rgb) : undefined;\n }\n hexString() {\n return this._valid ? hexString(this._rgb) : undefined;\n }\n hslString() {\n return this._valid ? hslString(this._rgb) : undefined;\n }\n mix(color, weight) {\n if (color) {\n const c1 = this.rgb;\n const c2 = color.rgb;\n let w2;\n const p = weight === w2 ? 0.5 : weight;\n const w = 2 * p - 1;\n const a = c1.a - c2.a;\n const w1 = ((w * a === -1 ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n w2 = 1 - w1;\n c1.r = 0xFF & w1 * c1.r + w2 * c2.r + 0.5;\n c1.g = 0xFF & w1 * c1.g + w2 * c2.g + 0.5;\n c1.b = 0xFF & w1 * c1.b + w2 * c2.b + 0.5;\n c1.a = p * c1.a + (1 - p) * c2.a;\n this.rgb = c1;\n }\n return this;\n }\n interpolate(color, t) {\n if (color) {\n this._rgb = interpolate(this._rgb, color._rgb, t);\n }\n return this;\n }\n clone() {\n return new Color(this.rgb);\n }\n alpha(a) {\n this._rgb.a = n2b(a);\n return this;\n }\n clearer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 - ratio;\n return this;\n }\n greyscale() {\n const rgb = this._rgb;\n const val = round(rgb.r * 0.3 + rgb.g * 0.59 + rgb.b * 0.11);\n rgb.r = rgb.g = rgb.b = val;\n return this;\n }\n opaquer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 + ratio;\n return this;\n }\n negate() {\n const v = this._rgb;\n v.r = 255 - v.r;\n v.g = 255 - v.g;\n v.b = 255 - v.b;\n return this;\n }\n lighten(ratio) {\n modHSL(this._rgb, 2, ratio);\n return this;\n }\n darken(ratio) {\n modHSL(this._rgb, 2, -ratio);\n return this;\n }\n saturate(ratio) {\n modHSL(this._rgb, 1, ratio);\n return this;\n }\n desaturate(ratio) {\n modHSL(this._rgb, 1, -ratio);\n return this;\n }\n rotate(deg) {\n rotate(this._rgb, deg);\n return this;\n }\n}\n\nfunction index_esm(input) {\n return new Color(input);\n}\n\nexport { Color, b2n, b2p, index_esm as default, hexParse, hexString, hsl2rgb, hslString, hsv2rgb, hueParse, hwb2rgb, lim, n2b, n2p, nameParse, p2b, rgb2hsl, rgbParse, rgbString, rotate, round };\n","/*!\n * Chart.js v4.4.3\n * https://www.chartjs.org\n * (c) 2024 Chart.js Contributors\n * Released under the MIT License\n */\nimport { Color } from '@kurkle/color';\n\n/**\n * @namespace Chart.helpers\n */ /**\n * An empty function that can be used, for example, for optional callback.\n */ function noop() {\n/* noop */ }\n/**\n * Returns a unique id, sequentially generated from a global variable.\n */ const uid = (()=>{\n let id = 0;\n return ()=>id++;\n})();\n/**\n * Returns true if `value` is neither null nor undefined, else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */ function isNullOrUndef(value) {\n return value === null || typeof value === 'undefined';\n}\n/**\n * Returns true if `value` is an array (including typed arrays), else returns false.\n * @param value - The value to test.\n * @function\n */ function isArray(value) {\n if (Array.isArray && Array.isArray(value)) {\n return true;\n }\n const type = Object.prototype.toString.call(value);\n if (type.slice(0, 7) === '[object' && type.slice(-6) === 'Array]') {\n return true;\n }\n return false;\n}\n/**\n * Returns true if `value` is an object (excluding null), else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */ function isObject(value) {\n return value !== null && Object.prototype.toString.call(value) === '[object Object]';\n}\n/**\n * Returns true if `value` is a finite number, else returns false\n * @param value - The value to test.\n */ function isNumberFinite(value) {\n return (typeof value === 'number' || value instanceof Number) && isFinite(+value);\n}\n/**\n * Returns `value` if finite, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is not finite.\n */ function finiteOrDefault(value, defaultValue) {\n return isNumberFinite(value) ? value : defaultValue;\n}\n/**\n * Returns `value` if defined, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is undefined.\n */ function valueOrDefault(value, defaultValue) {\n return typeof value === 'undefined' ? defaultValue : value;\n}\nconst toPercentage = (value, dimension)=>typeof value === 'string' && value.endsWith('%') ? parseFloat(value) / 100 : +value / dimension;\nconst toDimension = (value, dimension)=>typeof value === 'string' && value.endsWith('%') ? parseFloat(value) / 100 * dimension : +value;\n/**\n * Calls `fn` with the given `args` in the scope defined by `thisArg` and returns the\n * value returned by `fn`. If `fn` is not a function, this method returns undefined.\n * @param fn - The function to call.\n * @param args - The arguments with which `fn` should be called.\n * @param [thisArg] - The value of `this` provided for the call to `fn`.\n */ function callback(fn, args, thisArg) {\n if (fn && typeof fn.call === 'function') {\n return fn.apply(thisArg, args);\n }\n}\nfunction each(loopable, fn, thisArg, reverse) {\n let i, len, keys;\n if (isArray(loopable)) {\n len = loopable.length;\n if (reverse) {\n for(i = len - 1; i >= 0; i--){\n fn.call(thisArg, loopable[i], i);\n }\n } else {\n for(i = 0; i < len; i++){\n fn.call(thisArg, loopable[i], i);\n }\n }\n } else if (isObject(loopable)) {\n keys = Object.keys(loopable);\n len = keys.length;\n for(i = 0; i < len; i++){\n fn.call(thisArg, loopable[keys[i]], keys[i]);\n }\n }\n}\n/**\n * Returns true if the `a0` and `a1` arrays have the same content, else returns false.\n * @param a0 - The array to compare\n * @param a1 - The array to compare\n * @private\n */ function _elementsEqual(a0, a1) {\n let i, ilen, v0, v1;\n if (!a0 || !a1 || a0.length !== a1.length) {\n return false;\n }\n for(i = 0, ilen = a0.length; i < ilen; ++i){\n v0 = a0[i];\n v1 = a1[i];\n if (v0.datasetIndex !== v1.datasetIndex || v0.index !== v1.index) {\n return false;\n }\n }\n return true;\n}\n/**\n * Returns a deep copy of `source` without keeping references on objects and arrays.\n * @param source - The value to clone.\n */ function clone(source) {\n if (isArray(source)) {\n return source.map(clone);\n }\n if (isObject(source)) {\n const target = Object.create(null);\n const keys = Object.keys(source);\n const klen = keys.length;\n let k = 0;\n for(; k < klen; ++k){\n target[keys[k]] = clone(source[keys[k]]);\n }\n return target;\n }\n return source;\n}\nfunction isValidKey(key) {\n return [\n '__proto__',\n 'prototype',\n 'constructor'\n ].indexOf(key) === -1;\n}\n/**\n * The default merger when Chart.helpers.merge is called without merger option.\n * Note(SB): also used by mergeConfig and mergeScaleConfig as fallback.\n * @private\n */ function _merger(key, target, source, options) {\n if (!isValidKey(key)) {\n return;\n }\n const tval = target[key];\n const sval = source[key];\n if (isObject(tval) && isObject(sval)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n merge(tval, sval, options);\n } else {\n target[key] = clone(sval);\n }\n}\nfunction merge(target, source, options) {\n const sources = isArray(source) ? source : [\n source\n ];\n const ilen = sources.length;\n if (!isObject(target)) {\n return target;\n }\n options = options || {};\n const merger = options.merger || _merger;\n let current;\n for(let i = 0; i < ilen; ++i){\n current = sources[i];\n if (!isObject(current)) {\n continue;\n }\n const keys = Object.keys(current);\n for(let k = 0, klen = keys.length; k < klen; ++k){\n merger(keys[k], target, current, options);\n }\n }\n return target;\n}\nfunction mergeIf(target, source) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return merge(target, source, {\n merger: _mergerIf\n });\n}\n/**\n * Merges source[key] in target[key] only if target[key] is undefined.\n * @private\n */ function _mergerIf(key, target, source) {\n if (!isValidKey(key)) {\n return;\n }\n const tval = target[key];\n const sval = source[key];\n if (isObject(tval) && isObject(sval)) {\n mergeIf(tval, sval);\n } else if (!Object.prototype.hasOwnProperty.call(target, key)) {\n target[key] = clone(sval);\n }\n}\n/**\n * @private\n */ function _deprecated(scope, value, previous, current) {\n if (value !== undefined) {\n console.warn(scope + ': \"' + previous + '\" is deprecated. Please use \"' + current + '\" instead');\n }\n}\n// resolveObjectKey resolver cache\nconst keyResolvers = {\n // Chart.helpers.core resolveObjectKey should resolve empty key to root object\n '': (v)=>v,\n // default resolvers\n x: (o)=>o.x,\n y: (o)=>o.y\n};\n/**\n * @private\n */ function _splitKey(key) {\n const parts = key.split('.');\n const keys = [];\n let tmp = '';\n for (const part of parts){\n tmp += part;\n if (tmp.endsWith('\\\\')) {\n tmp = tmp.slice(0, -1) + '.';\n } else {\n keys.push(tmp);\n tmp = '';\n }\n }\n return keys;\n}\nfunction _getKeyResolver(key) {\n const keys = _splitKey(key);\n return (obj)=>{\n for (const k of keys){\n if (k === '') {\n break;\n }\n obj = obj && obj[k];\n }\n return obj;\n };\n}\nfunction resolveObjectKey(obj, key) {\n const resolver = keyResolvers[key] || (keyResolvers[key] = _getKeyResolver(key));\n return resolver(obj);\n}\n/**\n * @private\n */ function _capitalize(str) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\nconst defined = (value)=>typeof value !== 'undefined';\nconst isFunction = (value)=>typeof value === 'function';\n// Adapted from https://stackoverflow.com/questions/31128855/comparing-ecma6-sets-for-equality#31129384\nconst setsEqual = (a, b)=>{\n if (a.size !== b.size) {\n return false;\n }\n for (const item of a){\n if (!b.has(item)) {\n return false;\n }\n }\n return true;\n};\n/**\n * @param e - The event\n * @private\n */ function _isClickEvent(e) {\n return e.type === 'mouseup' || e.type === 'click' || e.type === 'contextmenu';\n}\n\n/**\n * @alias Chart.helpers.math\n * @namespace\n */ const PI = Math.PI;\nconst TAU = 2 * PI;\nconst PITAU = TAU + PI;\nconst INFINITY = Number.POSITIVE_INFINITY;\nconst RAD_PER_DEG = PI / 180;\nconst HALF_PI = PI / 2;\nconst QUARTER_PI = PI / 4;\nconst TWO_THIRDS_PI = PI * 2 / 3;\nconst log10 = Math.log10;\nconst sign = Math.sign;\nfunction almostEquals(x, y, epsilon) {\n return Math.abs(x - y) < epsilon;\n}\n/**\n * Implementation of the nice number algorithm used in determining where axis labels will go\n */ function niceNum(range) {\n const roundedRange = Math.round(range);\n range = almostEquals(range, roundedRange, range / 1000) ? roundedRange : range;\n const niceRange = Math.pow(10, Math.floor(log10(range)));\n const fraction = range / niceRange;\n const niceFraction = fraction <= 1 ? 1 : fraction <= 2 ? 2 : fraction <= 5 ? 5 : 10;\n return niceFraction * niceRange;\n}\n/**\n * Returns an array of factors sorted from 1 to sqrt(value)\n * @private\n */ function _factorize(value) {\n const result = [];\n const sqrt = Math.sqrt(value);\n let i;\n for(i = 1; i < sqrt; i++){\n if (value % i === 0) {\n result.push(i);\n result.push(value / i);\n }\n }\n if (sqrt === (sqrt | 0)) {\n result.push(sqrt);\n }\n result.sort((a, b)=>a - b).pop();\n return result;\n}\nfunction isNumber(n) {\n return !isNaN(parseFloat(n)) && isFinite(n);\n}\nfunction almostWhole(x, epsilon) {\n const rounded = Math.round(x);\n return rounded - epsilon <= x && rounded + epsilon >= x;\n}\n/**\n * @private\n */ function _setMinAndMaxByKey(array, target, property) {\n let i, ilen, value;\n for(i = 0, ilen = array.length; i < ilen; i++){\n value = array[i][property];\n if (!isNaN(value)) {\n target.min = Math.min(target.min, value);\n target.max = Math.max(target.max, value);\n }\n }\n}\nfunction toRadians(degrees) {\n return degrees * (PI / 180);\n}\nfunction toDegrees(radians) {\n return radians * (180 / PI);\n}\n/**\n * Returns the number of decimal places\n * i.e. the number of digits after the decimal point, of the value of this Number.\n * @param x - A number.\n * @returns The number of decimal places.\n * @private\n */ function _decimalPlaces(x) {\n if (!isNumberFinite(x)) {\n return;\n }\n let e = 1;\n let p = 0;\n while(Math.round(x * e) / e !== x){\n e *= 10;\n p++;\n }\n return p;\n}\n// Gets the angle from vertical upright to the point about a centre.\nfunction getAngleFromPoint(centrePoint, anglePoint) {\n const distanceFromXCenter = anglePoint.x - centrePoint.x;\n const distanceFromYCenter = anglePoint.y - centrePoint.y;\n const radialDistanceFromCenter = Math.sqrt(distanceFromXCenter * distanceFromXCenter + distanceFromYCenter * distanceFromYCenter);\n let angle = Math.atan2(distanceFromYCenter, distanceFromXCenter);\n if (angle < -0.5 * PI) {\n angle += TAU; // make sure the returned angle is in the range of (-PI/2, 3PI/2]\n }\n return {\n angle,\n distance: radialDistanceFromCenter\n };\n}\nfunction distanceBetweenPoints(pt1, pt2) {\n return Math.sqrt(Math.pow(pt2.x - pt1.x, 2) + Math.pow(pt2.y - pt1.y, 2));\n}\n/**\n * Shortest distance between angles, in either direction.\n * @private\n */ function _angleDiff(a, b) {\n return (a - b + PITAU) % TAU - PI;\n}\n/**\n * Normalize angle to be between 0 and 2*PI\n * @private\n */ function _normalizeAngle(a) {\n return (a % TAU + TAU) % TAU;\n}\n/**\n * @private\n */ function _angleBetween(angle, start, end, sameAngleIsFullCircle) {\n const a = _normalizeAngle(angle);\n const s = _normalizeAngle(start);\n const e = _normalizeAngle(end);\n const angleToStart = _normalizeAngle(s - a);\n const angleToEnd = _normalizeAngle(e - a);\n const startToAngle = _normalizeAngle(a - s);\n const endToAngle = _normalizeAngle(a - e);\n return a === s || a === e || sameAngleIsFullCircle && s === e || angleToStart > angleToEnd && startToAngle < endToAngle;\n}\n/**\n * Limit `value` between `min` and `max`\n * @param value\n * @param min\n * @param max\n * @private\n */ function _limitValue(value, min, max) {\n return Math.max(min, Math.min(max, value));\n}\n/**\n * @param {number} value\n * @private\n */ function _int16Range(value) {\n return _limitValue(value, -32768, 32767);\n}\n/**\n * @param value\n * @param start\n * @param end\n * @param [epsilon]\n * @private\n */ function _isBetween(value, start, end, epsilon = 1e-6) {\n return value >= Math.min(start, end) - epsilon && value <= Math.max(start, end) + epsilon;\n}\n\nfunction _lookup(table, value, cmp) {\n cmp = cmp || ((index)=>table[index] < value);\n let hi = table.length - 1;\n let lo = 0;\n let mid;\n while(hi - lo > 1){\n mid = lo + hi >> 1;\n if (cmp(mid)) {\n lo = mid;\n } else {\n hi = mid;\n }\n }\n return {\n lo,\n hi\n };\n}\n/**\n * Binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @param last - lookup last index\n * @private\n */ const _lookupByKey = (table, key, value, last)=>_lookup(table, value, last ? (index)=>{\n const ti = table[index][key];\n return ti < value || ti === value && table[index + 1][key] === value;\n } : (index)=>table[index][key] < value);\n/**\n * Reverse binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @private\n */ const _rlookupByKey = (table, key, value)=>_lookup(table, value, (index)=>table[index][key] >= value);\n/**\n * Return subset of `values` between `min` and `max` inclusive.\n * Values are assumed to be in sorted order.\n * @param values - sorted array of values\n * @param min - min value\n * @param max - max value\n */ function _filterBetween(values, min, max) {\n let start = 0;\n let end = values.length;\n while(start < end && values[start] < min){\n start++;\n }\n while(end > start && values[end - 1] > max){\n end--;\n }\n return start > 0 || end < values.length ? values.slice(start, end) : values;\n}\nconst arrayEvents = [\n 'push',\n 'pop',\n 'shift',\n 'splice',\n 'unshift'\n];\nfunction listenArrayEvents(array, listener) {\n if (array._chartjs) {\n array._chartjs.listeners.push(listener);\n return;\n }\n Object.defineProperty(array, '_chartjs', {\n configurable: true,\n enumerable: false,\n value: {\n listeners: [\n listener\n ]\n }\n });\n arrayEvents.forEach((key)=>{\n const method = '_onData' + _capitalize(key);\n const base = array[key];\n Object.defineProperty(array, key, {\n configurable: true,\n enumerable: false,\n value (...args) {\n const res = base.apply(this, args);\n array._chartjs.listeners.forEach((object)=>{\n if (typeof object[method] === 'function') {\n object[method](...args);\n }\n });\n return res;\n }\n });\n });\n}\nfunction unlistenArrayEvents(array, listener) {\n const stub = array._chartjs;\n if (!stub) {\n return;\n }\n const listeners = stub.listeners;\n const index = listeners.indexOf(listener);\n if (index !== -1) {\n listeners.splice(index, 1);\n }\n if (listeners.length > 0) {\n return;\n }\n arrayEvents.forEach((key)=>{\n delete array[key];\n });\n delete array._chartjs;\n}\n/**\n * @param items\n */ function _arrayUnique(items) {\n const set = new Set(items);\n if (set.size === items.length) {\n return items;\n }\n return Array.from(set);\n}\n\nfunction fontString(pixelSize, fontStyle, fontFamily) {\n return fontStyle + ' ' + pixelSize + 'px ' + fontFamily;\n}\n/**\n* Request animation polyfill\n*/ const requestAnimFrame = function() {\n if (typeof window === 'undefined') {\n return function(callback) {\n return callback();\n };\n }\n return window.requestAnimationFrame;\n}();\n/**\n * Throttles calling `fn` once per animation frame\n * Latest arguments are used on the actual call\n */ function throttled(fn, thisArg) {\n let argsToUse = [];\n let ticking = false;\n return function(...args) {\n // Save the args for use later\n argsToUse = args;\n if (!ticking) {\n ticking = true;\n requestAnimFrame.call(window, ()=>{\n ticking = false;\n fn.apply(thisArg, argsToUse);\n });\n }\n };\n}\n/**\n * Debounces calling `fn` for `delay` ms\n */ function debounce(fn, delay) {\n let timeout;\n return function(...args) {\n if (delay) {\n clearTimeout(timeout);\n timeout = setTimeout(fn, delay, args);\n } else {\n fn.apply(this, args);\n }\n return delay;\n };\n}\n/**\n * Converts 'start' to 'left', 'end' to 'right' and others to 'center'\n * @private\n */ const _toLeftRightCenter = (align)=>align === 'start' ? 'left' : align === 'end' ? 'right' : 'center';\n/**\n * Returns `start`, `end` or `(start + end) / 2` depending on `align`. Defaults to `center`\n * @private\n */ const _alignStartEnd = (align, start, end)=>align === 'start' ? start : align === 'end' ? end : (start + end) / 2;\n/**\n * Returns `left`, `right` or `(left + right) / 2` depending on `align`. Defaults to `left`\n * @private\n */ const _textX = (align, left, right, rtl)=>{\n const check = rtl ? 'left' : 'right';\n return align === check ? right : align === 'center' ? (left + right) / 2 : left;\n};\n/**\n * Return start and count of visible points.\n * @private\n */ function _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled) {\n const pointCount = points.length;\n let start = 0;\n let count = pointCount;\n if (meta._sorted) {\n const { iScale , _parsed } = meta;\n const axis = iScale.axis;\n const { min , max , minDefined , maxDefined } = iScale.getUserBounds();\n if (minDefined) {\n start = _limitValue(Math.min(// @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, axis, min).lo, // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? pointCount : _lookupByKey(points, axis, iScale.getPixelForValue(min)).lo), 0, pointCount - 1);\n }\n if (maxDefined) {\n count = _limitValue(Math.max(// @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, iScale.axis, max, true).hi + 1, // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? 0 : _lookupByKey(points, axis, iScale.getPixelForValue(max), true).hi + 1), start, pointCount) - start;\n } else {\n count = pointCount - start;\n }\n }\n return {\n start,\n count\n };\n}\n/**\n * Checks if the scale ranges have changed.\n * @param {object} meta - dataset meta.\n * @returns {boolean}\n * @private\n */ function _scaleRangesChanged(meta) {\n const { xScale , yScale , _scaleRanges } = meta;\n const newRanges = {\n xmin: xScale.min,\n xmax: xScale.max,\n ymin: yScale.min,\n ymax: yScale.max\n };\n if (!_scaleRanges) {\n meta._scaleRanges = newRanges;\n return true;\n }\n const changed = _scaleRanges.xmin !== xScale.min || _scaleRanges.xmax !== xScale.max || _scaleRanges.ymin !== yScale.min || _scaleRanges.ymax !== yScale.max;\n Object.assign(_scaleRanges, newRanges);\n return changed;\n}\n\nconst atEdge = (t)=>t === 0 || t === 1;\nconst elasticIn = (t, s, p)=>-(Math.pow(2, 10 * (t -= 1)) * Math.sin((t - s) * TAU / p));\nconst elasticOut = (t, s, p)=>Math.pow(2, -10 * t) * Math.sin((t - s) * TAU / p) + 1;\n/**\n * Easing functions adapted from Robert Penner's easing equations.\n * @namespace Chart.helpers.easing.effects\n * @see http://www.robertpenner.com/easing/\n */ const effects = {\n linear: (t)=>t,\n easeInQuad: (t)=>t * t,\n easeOutQuad: (t)=>-t * (t - 2),\n easeInOutQuad: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t : -0.5 * (--t * (t - 2) - 1),\n easeInCubic: (t)=>t * t * t,\n easeOutCubic: (t)=>(t -= 1) * t * t + 1,\n easeInOutCubic: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t * t : 0.5 * ((t -= 2) * t * t + 2),\n easeInQuart: (t)=>t * t * t * t,\n easeOutQuart: (t)=>-((t -= 1) * t * t * t - 1),\n easeInOutQuart: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t * t * t : -0.5 * ((t -= 2) * t * t * t - 2),\n easeInQuint: (t)=>t * t * t * t * t,\n easeOutQuint: (t)=>(t -= 1) * t * t * t * t + 1,\n easeInOutQuint: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t * t * t * t : 0.5 * ((t -= 2) * t * t * t * t + 2),\n easeInSine: (t)=>-Math.cos(t * HALF_PI) + 1,\n easeOutSine: (t)=>Math.sin(t * HALF_PI),\n easeInOutSine: (t)=>-0.5 * (Math.cos(PI * t) - 1),\n easeInExpo: (t)=>t === 0 ? 0 : Math.pow(2, 10 * (t - 1)),\n easeOutExpo: (t)=>t === 1 ? 1 : -Math.pow(2, -10 * t) + 1,\n easeInOutExpo: (t)=>atEdge(t) ? t : t < 0.5 ? 0.5 * Math.pow(2, 10 * (t * 2 - 1)) : 0.5 * (-Math.pow(2, -10 * (t * 2 - 1)) + 2),\n easeInCirc: (t)=>t >= 1 ? t : -(Math.sqrt(1 - t * t) - 1),\n easeOutCirc: (t)=>Math.sqrt(1 - (t -= 1) * t),\n easeInOutCirc: (t)=>(t /= 0.5) < 1 ? -0.5 * (Math.sqrt(1 - t * t) - 1) : 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1),\n easeInElastic: (t)=>atEdge(t) ? t : elasticIn(t, 0.075, 0.3),\n easeOutElastic: (t)=>atEdge(t) ? t : elasticOut(t, 0.075, 0.3),\n easeInOutElastic (t) {\n const s = 0.1125;\n const p = 0.45;\n return atEdge(t) ? t : t < 0.5 ? 0.5 * elasticIn(t * 2, s, p) : 0.5 + 0.5 * elasticOut(t * 2 - 1, s, p);\n },\n easeInBack (t) {\n const s = 1.70158;\n return t * t * ((s + 1) * t - s);\n },\n easeOutBack (t) {\n const s = 1.70158;\n return (t -= 1) * t * ((s + 1) * t + s) + 1;\n },\n easeInOutBack (t) {\n let s = 1.70158;\n if ((t /= 0.5) < 1) {\n return 0.5 * (t * t * (((s *= 1.525) + 1) * t - s));\n }\n return 0.5 * ((t -= 2) * t * (((s *= 1.525) + 1) * t + s) + 2);\n },\n easeInBounce: (t)=>1 - effects.easeOutBounce(1 - t),\n easeOutBounce (t) {\n const m = 7.5625;\n const d = 2.75;\n if (t < 1 / d) {\n return m * t * t;\n }\n if (t < 2 / d) {\n return m * (t -= 1.5 / d) * t + 0.75;\n }\n if (t < 2.5 / d) {\n return m * (t -= 2.25 / d) * t + 0.9375;\n }\n return m * (t -= 2.625 / d) * t + 0.984375;\n },\n easeInOutBounce: (t)=>t < 0.5 ? effects.easeInBounce(t * 2) * 0.5 : effects.easeOutBounce(t * 2 - 1) * 0.5 + 0.5\n};\n\nfunction isPatternOrGradient(value) {\n if (value && typeof value === 'object') {\n const type = value.toString();\n return type === '[object CanvasPattern]' || type === '[object CanvasGradient]';\n }\n return false;\n}\nfunction color(value) {\n return isPatternOrGradient(value) ? value : new Color(value);\n}\nfunction getHoverColor(value) {\n return isPatternOrGradient(value) ? value : new Color(value).saturate(0.5).darken(0.1).hexString();\n}\n\nconst numbers = [\n 'x',\n 'y',\n 'borderWidth',\n 'radius',\n 'tension'\n];\nconst colors = [\n 'color',\n 'borderColor',\n 'backgroundColor'\n];\nfunction applyAnimationsDefaults(defaults) {\n defaults.set('animation', {\n delay: undefined,\n duration: 1000,\n easing: 'easeOutQuart',\n fn: undefined,\n from: undefined,\n loop: undefined,\n to: undefined,\n type: undefined\n });\n defaults.describe('animation', {\n _fallback: false,\n _indexable: false,\n _scriptable: (name)=>name !== 'onProgress' && name !== 'onComplete' && name !== 'fn'\n });\n defaults.set('animations', {\n colors: {\n type: 'color',\n properties: colors\n },\n numbers: {\n type: 'number',\n properties: numbers\n }\n });\n defaults.describe('animations', {\n _fallback: 'animation'\n });\n defaults.set('transitions', {\n active: {\n animation: {\n duration: 400\n }\n },\n resize: {\n animation: {\n duration: 0\n }\n },\n show: {\n animations: {\n colors: {\n from: 'transparent'\n },\n visible: {\n type: 'boolean',\n duration: 0\n }\n }\n },\n hide: {\n animations: {\n colors: {\n to: 'transparent'\n },\n visible: {\n type: 'boolean',\n easing: 'linear',\n fn: (v)=>v | 0\n }\n }\n }\n });\n}\n\nfunction applyLayoutsDefaults(defaults) {\n defaults.set('layout', {\n autoPadding: true,\n padding: {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n }\n });\n}\n\nconst intlCache = new Map();\nfunction getNumberFormat(locale, options) {\n options = options || {};\n const cacheKey = locale + JSON.stringify(options);\n let formatter = intlCache.get(cacheKey);\n if (!formatter) {\n formatter = new Intl.NumberFormat(locale, options);\n intlCache.set(cacheKey, formatter);\n }\n return formatter;\n}\nfunction formatNumber(num, locale, options) {\n return getNumberFormat(locale, options).format(num);\n}\n\nconst formatters = {\n values (value) {\n return isArray(value) ? value : '' + value;\n },\n numeric (tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0';\n }\n const locale = this.chart.options.locale;\n let notation;\n let delta = tickValue;\n if (ticks.length > 1) {\n const maxTick = Math.max(Math.abs(ticks[0].value), Math.abs(ticks[ticks.length - 1].value));\n if (maxTick < 1e-4 || maxTick > 1e+15) {\n notation = 'scientific';\n }\n delta = calculateDelta(tickValue, ticks);\n }\n const logDelta = log10(Math.abs(delta));\n const numDecimal = isNaN(logDelta) ? 1 : Math.max(Math.min(-1 * Math.floor(logDelta), 20), 0);\n const options = {\n notation,\n minimumFractionDigits: numDecimal,\n maximumFractionDigits: numDecimal\n };\n Object.assign(options, this.options.ticks.format);\n return formatNumber(tickValue, locale, options);\n },\n logarithmic (tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0';\n }\n const remain = ticks[index].significand || tickValue / Math.pow(10, Math.floor(log10(tickValue)));\n if ([\n 1,\n 2,\n 3,\n 5,\n 10,\n 15\n ].includes(remain) || index > 0.8 * ticks.length) {\n return formatters.numeric.call(this, tickValue, index, ticks);\n }\n return '';\n }\n};\nfunction calculateDelta(tickValue, ticks) {\n let delta = ticks.length > 3 ? ticks[2].value - ticks[1].value : ticks[1].value - ticks[0].value;\n if (Math.abs(delta) >= 1 && tickValue !== Math.floor(tickValue)) {\n delta = tickValue - Math.floor(tickValue);\n }\n return delta;\n}\n var Ticks = {\n formatters\n};\n\nfunction applyScaleDefaults(defaults) {\n defaults.set('scale', {\n display: true,\n offset: false,\n reverse: false,\n beginAtZero: false,\n bounds: 'ticks',\n clip: true,\n grace: 0,\n grid: {\n display: true,\n lineWidth: 1,\n drawOnChartArea: true,\n drawTicks: true,\n tickLength: 8,\n tickWidth: (_ctx, options)=>options.lineWidth,\n tickColor: (_ctx, options)=>options.color,\n offset: false\n },\n border: {\n display: true,\n dash: [],\n dashOffset: 0.0,\n width: 1\n },\n title: {\n display: false,\n text: '',\n padding: {\n top: 4,\n bottom: 4\n }\n },\n ticks: {\n minRotation: 0,\n maxRotation: 50,\n mirror: false,\n textStrokeWidth: 0,\n textStrokeColor: '',\n padding: 3,\n display: true,\n autoSkip: true,\n autoSkipPadding: 3,\n labelOffset: 0,\n callback: Ticks.formatters.values,\n minor: {},\n major: {},\n align: 'center',\n crossAlign: 'near',\n showLabelBackdrop: false,\n backdropColor: 'rgba(255, 255, 255, 0.75)',\n backdropPadding: 2\n }\n });\n defaults.route('scale.ticks', 'color', '', 'color');\n defaults.route('scale.grid', 'color', '', 'borderColor');\n defaults.route('scale.border', 'color', '', 'borderColor');\n defaults.route('scale.title', 'color', '', 'color');\n defaults.describe('scale', {\n _fallback: false,\n _scriptable: (name)=>!name.startsWith('before') && !name.startsWith('after') && name !== 'callback' && name !== 'parser',\n _indexable: (name)=>name !== 'borderDash' && name !== 'tickBorderDash' && name !== 'dash'\n });\n defaults.describe('scales', {\n _fallback: 'scale'\n });\n defaults.describe('scale.ticks', {\n _scriptable: (name)=>name !== 'backdropPadding' && name !== 'callback',\n _indexable: (name)=>name !== 'backdropPadding'\n });\n}\n\nconst overrides = Object.create(null);\nconst descriptors = Object.create(null);\n function getScope$1(node, key) {\n if (!key) {\n return node;\n }\n const keys = key.split('.');\n for(let i = 0, n = keys.length; i < n; ++i){\n const k = keys[i];\n node = node[k] || (node[k] = Object.create(null));\n }\n return node;\n}\nfunction set(root, scope, values) {\n if (typeof scope === 'string') {\n return merge(getScope$1(root, scope), values);\n }\n return merge(getScope$1(root, ''), scope);\n}\n class Defaults {\n constructor(_descriptors, _appliers){\n this.animation = undefined;\n this.backgroundColor = 'rgba(0,0,0,0.1)';\n this.borderColor = 'rgba(0,0,0,0.1)';\n this.color = '#666';\n this.datasets = {};\n this.devicePixelRatio = (context)=>context.chart.platform.getDevicePixelRatio();\n this.elements = {};\n this.events = [\n 'mousemove',\n 'mouseout',\n 'click',\n 'touchstart',\n 'touchmove'\n ];\n this.font = {\n family: \"'Helvetica Neue', 'Helvetica', 'Arial', sans-serif\",\n size: 12,\n style: 'normal',\n lineHeight: 1.2,\n weight: null\n };\n this.hover = {};\n this.hoverBackgroundColor = (ctx, options)=>getHoverColor(options.backgroundColor);\n this.hoverBorderColor = (ctx, options)=>getHoverColor(options.borderColor);\n this.hoverColor = (ctx, options)=>getHoverColor(options.color);\n this.indexAxis = 'x';\n this.interaction = {\n mode: 'nearest',\n intersect: true,\n includeInvisible: false\n };\n this.maintainAspectRatio = true;\n this.onHover = null;\n this.onClick = null;\n this.parsing = true;\n this.plugins = {};\n this.responsive = true;\n this.scale = undefined;\n this.scales = {};\n this.showLine = true;\n this.drawActiveElementsOnTop = true;\n this.describe(_descriptors);\n this.apply(_appliers);\n }\n set(scope, values) {\n return set(this, scope, values);\n }\n get(scope) {\n return getScope$1(this, scope);\n }\n describe(scope, values) {\n return set(descriptors, scope, values);\n }\n override(scope, values) {\n return set(overrides, scope, values);\n }\n route(scope, name, targetScope, targetName) {\n const scopeObject = getScope$1(this, scope);\n const targetScopeObject = getScope$1(this, targetScope);\n const privateName = '_' + name;\n Object.defineProperties(scopeObject, {\n [privateName]: {\n value: scopeObject[name],\n writable: true\n },\n [name]: {\n enumerable: true,\n get () {\n const local = this[privateName];\n const target = targetScopeObject[targetName];\n if (isObject(local)) {\n return Object.assign({}, target, local);\n }\n return valueOrDefault(local, target);\n },\n set (value) {\n this[privateName] = value;\n }\n }\n });\n }\n apply(appliers) {\n appliers.forEach((apply)=>apply(this));\n }\n}\nvar defaults = /* #__PURE__ */ new Defaults({\n _scriptable: (name)=>!name.startsWith('on'),\n _indexable: (name)=>name !== 'events',\n hover: {\n _fallback: 'interaction'\n },\n interaction: {\n _scriptable: false,\n _indexable: false\n }\n}, [\n applyAnimationsDefaults,\n applyLayoutsDefaults,\n applyScaleDefaults\n]);\n\n/**\n * Converts the given font object into a CSS font string.\n * @param font - A font object.\n * @return The CSS font string. See https://developer.mozilla.org/en-US/docs/Web/CSS/font\n * @private\n */ function toFontString(font) {\n if (!font || isNullOrUndef(font.size) || isNullOrUndef(font.family)) {\n return null;\n }\n return (font.style ? font.style + ' ' : '') + (font.weight ? font.weight + ' ' : '') + font.size + 'px ' + font.family;\n}\n/**\n * @private\n */ function _measureText(ctx, data, gc, longest, string) {\n let textWidth = data[string];\n if (!textWidth) {\n textWidth = data[string] = ctx.measureText(string).width;\n gc.push(string);\n }\n if (textWidth > longest) {\n longest = textWidth;\n }\n return longest;\n}\n/**\n * @private\n */ // eslint-disable-next-line complexity\nfunction _longestText(ctx, font, arrayOfThings, cache) {\n cache = cache || {};\n let data = cache.data = cache.data || {};\n let gc = cache.garbageCollect = cache.garbageCollect || [];\n if (cache.font !== font) {\n data = cache.data = {};\n gc = cache.garbageCollect = [];\n cache.font = font;\n }\n ctx.save();\n ctx.font = font;\n let longest = 0;\n const ilen = arrayOfThings.length;\n let i, j, jlen, thing, nestedThing;\n for(i = 0; i < ilen; i++){\n thing = arrayOfThings[i];\n // Undefined strings and arrays should not be measured\n if (thing !== undefined && thing !== null && !isArray(thing)) {\n longest = _measureText(ctx, data, gc, longest, thing);\n } else if (isArray(thing)) {\n // if it is an array lets measure each element\n // to do maybe simplify this function a bit so we can do this more recursively?\n for(j = 0, jlen = thing.length; j < jlen; j++){\n nestedThing = thing[j];\n // Undefined strings and arrays should not be measured\n if (nestedThing !== undefined && nestedThing !== null && !isArray(nestedThing)) {\n longest = _measureText(ctx, data, gc, longest, nestedThing);\n }\n }\n }\n }\n ctx.restore();\n const gcLen = gc.length / 2;\n if (gcLen > arrayOfThings.length) {\n for(i = 0; i < gcLen; i++){\n delete data[gc[i]];\n }\n gc.splice(0, gcLen);\n }\n return longest;\n}\n/**\n * Returns the aligned pixel value to avoid anti-aliasing blur\n * @param chart - The chart instance.\n * @param pixel - A pixel value.\n * @param width - The width of the element.\n * @returns The aligned pixel value.\n * @private\n */ function _alignPixel(chart, pixel, width) {\n const devicePixelRatio = chart.currentDevicePixelRatio;\n const halfWidth = width !== 0 ? Math.max(width / 2, 0.5) : 0;\n return Math.round((pixel - halfWidth) * devicePixelRatio) / devicePixelRatio + halfWidth;\n}\n/**\n * Clears the entire canvas.\n */ function clearCanvas(canvas, ctx) {\n if (!ctx && !canvas) {\n return;\n }\n ctx = ctx || canvas.getContext('2d');\n ctx.save();\n // canvas.width and canvas.height do not consider the canvas transform,\n // while clearRect does\n ctx.resetTransform();\n ctx.clearRect(0, 0, canvas.width, canvas.height);\n ctx.restore();\n}\nfunction drawPoint(ctx, options, x, y) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n drawPointLegend(ctx, options, x, y, null);\n}\n// eslint-disable-next-line complexity\nfunction drawPointLegend(ctx, options, x, y, w) {\n let type, xOffset, yOffset, size, cornerRadius, width, xOffsetW, yOffsetW;\n const style = options.pointStyle;\n const rotation = options.rotation;\n const radius = options.radius;\n let rad = (rotation || 0) * RAD_PER_DEG;\n if (style && typeof style === 'object') {\n type = style.toString();\n if (type === '[object HTMLImageElement]' || type === '[object HTMLCanvasElement]') {\n ctx.save();\n ctx.translate(x, y);\n ctx.rotate(rad);\n ctx.drawImage(style, -style.width / 2, -style.height / 2, style.width, style.height);\n ctx.restore();\n return;\n }\n }\n if (isNaN(radius) || radius <= 0) {\n return;\n }\n ctx.beginPath();\n switch(style){\n // Default includes circle\n default:\n if (w) {\n ctx.ellipse(x, y, w / 2, radius, 0, 0, TAU);\n } else {\n ctx.arc(x, y, radius, 0, TAU);\n }\n ctx.closePath();\n break;\n case 'triangle':\n width = w ? w / 2 : radius;\n ctx.moveTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n ctx.closePath();\n break;\n case 'rectRounded':\n // NOTE: the rounded rect implementation changed to use `arc` instead of\n // `quadraticCurveTo` since it generates better results when rect is\n // almost a circle. 0.516 (instead of 0.5) produces results with visually\n // closer proportion to the previous impl and it is inscribed in the\n // circle with `radius`. For more details, see the following PRs:\n // https://github.com/chartjs/Chart.js/issues/5597\n // https://github.com/chartjs/Chart.js/issues/5858\n cornerRadius = radius * 0.516;\n size = radius - cornerRadius;\n xOffset = Math.cos(rad + QUARTER_PI) * size;\n xOffsetW = Math.cos(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n yOffset = Math.sin(rad + QUARTER_PI) * size;\n yOffsetW = Math.sin(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n ctx.arc(x - xOffsetW, y - yOffset, cornerRadius, rad - PI, rad - HALF_PI);\n ctx.arc(x + yOffsetW, y - xOffset, cornerRadius, rad - HALF_PI, rad);\n ctx.arc(x + xOffsetW, y + yOffset, cornerRadius, rad, rad + HALF_PI);\n ctx.arc(x - yOffsetW, y + xOffset, cornerRadius, rad + HALF_PI, rad + PI);\n ctx.closePath();\n break;\n case 'rect':\n if (!rotation) {\n size = Math.SQRT1_2 * radius;\n width = w ? w / 2 : size;\n ctx.rect(x - width, y - size, 2 * width, 2 * size);\n break;\n }\n rad += QUARTER_PI;\n /* falls through */ case 'rectRot':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n ctx.closePath();\n break;\n case 'crossRot':\n rad += QUARTER_PI;\n /* falls through */ case 'cross':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'star':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n rad += QUARTER_PI;\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'line':\n xOffset = w ? w / 2 : Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n ctx.moveTo(x - xOffset, y - yOffset);\n ctx.lineTo(x + xOffset, y + yOffset);\n break;\n case 'dash':\n ctx.moveTo(x, y);\n ctx.lineTo(x + Math.cos(rad) * (w ? w / 2 : radius), y + Math.sin(rad) * radius);\n break;\n case false:\n ctx.closePath();\n break;\n }\n ctx.fill();\n if (options.borderWidth > 0) {\n ctx.stroke();\n }\n}\n/**\n * Returns true if the point is inside the rectangle\n * @param point - The point to test\n * @param area - The rectangle\n * @param margin - allowed margin\n * @private\n */ function _isPointInArea(point, area, margin) {\n margin = margin || 0.5; // margin - default is to match rounded decimals\n return !area || point && point.x > area.left - margin && point.x < area.right + margin && point.y > area.top - margin && point.y < area.bottom + margin;\n}\nfunction clipArea(ctx, area) {\n ctx.save();\n ctx.beginPath();\n ctx.rect(area.left, area.top, area.right - area.left, area.bottom - area.top);\n ctx.clip();\n}\nfunction unclipArea(ctx) {\n ctx.restore();\n}\n/**\n * @private\n */ function _steppedLineTo(ctx, previous, target, flip, mode) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n if (mode === 'middle') {\n const midpoint = (previous.x + target.x) / 2.0;\n ctx.lineTo(midpoint, previous.y);\n ctx.lineTo(midpoint, target.y);\n } else if (mode === 'after' !== !!flip) {\n ctx.lineTo(previous.x, target.y);\n } else {\n ctx.lineTo(target.x, previous.y);\n }\n ctx.lineTo(target.x, target.y);\n}\n/**\n * @private\n */ function _bezierCurveTo(ctx, previous, target, flip) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n ctx.bezierCurveTo(flip ? previous.cp1x : previous.cp2x, flip ? previous.cp1y : previous.cp2y, flip ? target.cp2x : target.cp1x, flip ? target.cp2y : target.cp1y, target.x, target.y);\n}\nfunction setRenderOpts(ctx, opts) {\n if (opts.translation) {\n ctx.translate(opts.translation[0], opts.translation[1]);\n }\n if (!isNullOrUndef(opts.rotation)) {\n ctx.rotate(opts.rotation);\n }\n if (opts.color) {\n ctx.fillStyle = opts.color;\n }\n if (opts.textAlign) {\n ctx.textAlign = opts.textAlign;\n }\n if (opts.textBaseline) {\n ctx.textBaseline = opts.textBaseline;\n }\n}\nfunction decorateText(ctx, x, y, line, opts) {\n if (opts.strikethrough || opts.underline) {\n /**\n * Now that IE11 support has been dropped, we can use more\n * of the TextMetrics object. The actual bounding boxes\n * are unflagged in Chrome, Firefox, Edge, and Safari so they\n * can be safely used.\n * See https://developer.mozilla.org/en-US/docs/Web/API/TextMetrics#Browser_compatibility\n */ const metrics = ctx.measureText(line);\n const left = x - metrics.actualBoundingBoxLeft;\n const right = x + metrics.actualBoundingBoxRight;\n const top = y - metrics.actualBoundingBoxAscent;\n const bottom = y + metrics.actualBoundingBoxDescent;\n const yDecoration = opts.strikethrough ? (top + bottom) / 2 : bottom;\n ctx.strokeStyle = ctx.fillStyle;\n ctx.beginPath();\n ctx.lineWidth = opts.decorationWidth || 2;\n ctx.moveTo(left, yDecoration);\n ctx.lineTo(right, yDecoration);\n ctx.stroke();\n }\n}\nfunction drawBackdrop(ctx, opts) {\n const oldColor = ctx.fillStyle;\n ctx.fillStyle = opts.color;\n ctx.fillRect(opts.left, opts.top, opts.width, opts.height);\n ctx.fillStyle = oldColor;\n}\n/**\n * Render text onto the canvas\n */ function renderText(ctx, text, x, y, font, opts = {}) {\n const lines = isArray(text) ? text : [\n text\n ];\n const stroke = opts.strokeWidth > 0 && opts.strokeColor !== '';\n let i, line;\n ctx.save();\n ctx.font = font.string;\n setRenderOpts(ctx, opts);\n for(i = 0; i < lines.length; ++i){\n line = lines[i];\n if (opts.backdrop) {\n drawBackdrop(ctx, opts.backdrop);\n }\n if (stroke) {\n if (opts.strokeColor) {\n ctx.strokeStyle = opts.strokeColor;\n }\n if (!isNullOrUndef(opts.strokeWidth)) {\n ctx.lineWidth = opts.strokeWidth;\n }\n ctx.strokeText(line, x, y, opts.maxWidth);\n }\n ctx.fillText(line, x, y, opts.maxWidth);\n decorateText(ctx, x, y, line, opts);\n y += Number(font.lineHeight);\n }\n ctx.restore();\n}\n/**\n * Add a path of a rectangle with rounded corners to the current sub-path\n * @param ctx - Context\n * @param rect - Bounding rect\n */ function addRoundedRectPath(ctx, rect) {\n const { x , y , w , h , radius } = rect;\n // top left arc\n ctx.arc(x + radius.topLeft, y + radius.topLeft, radius.topLeft, 1.5 * PI, PI, true);\n // line from top left to bottom left\n ctx.lineTo(x, y + h - radius.bottomLeft);\n // bottom left arc\n ctx.arc(x + radius.bottomLeft, y + h - radius.bottomLeft, radius.bottomLeft, PI, HALF_PI, true);\n // line from bottom left to bottom right\n ctx.lineTo(x + w - radius.bottomRight, y + h);\n // bottom right arc\n ctx.arc(x + w - radius.bottomRight, y + h - radius.bottomRight, radius.bottomRight, HALF_PI, 0, true);\n // line from bottom right to top right\n ctx.lineTo(x + w, y + radius.topRight);\n // top right arc\n ctx.arc(x + w - radius.topRight, y + radius.topRight, radius.topRight, 0, -HALF_PI, true);\n // line from top right to top left\n ctx.lineTo(x + radius.topLeft, y);\n}\n\nconst LINE_HEIGHT = /^(normal|(\\d+(?:\\.\\d+)?)(px|em|%)?)$/;\nconst FONT_STYLE = /^(normal|italic|initial|inherit|unset|(oblique( -?[0-9]?[0-9]deg)?))$/;\n/**\n * @alias Chart.helpers.options\n * @namespace\n */ /**\n * Converts the given line height `value` in pixels for a specific font `size`.\n * @param value - The lineHeight to parse (eg. 1.6, '14px', '75%', '1.6em').\n * @param size - The font size (in pixels) used to resolve relative `value`.\n * @returns The effective line height in pixels (size * 1.2 if value is invalid).\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/line-height\n * @since 2.7.0\n */ function toLineHeight(value, size) {\n const matches = ('' + value).match(LINE_HEIGHT);\n if (!matches || matches[1] === 'normal') {\n return size * 1.2;\n }\n value = +matches[2];\n switch(matches[3]){\n case 'px':\n return value;\n case '%':\n value /= 100;\n break;\n }\n return size * value;\n}\nconst numberOrZero = (v)=>+v || 0;\nfunction _readValueToProps(value, props) {\n const ret = {};\n const objProps = isObject(props);\n const keys = objProps ? Object.keys(props) : props;\n const read = isObject(value) ? objProps ? (prop)=>valueOrDefault(value[prop], value[props[prop]]) : (prop)=>value[prop] : ()=>value;\n for (const prop of keys){\n ret[prop] = numberOrZero(read(prop));\n }\n return ret;\n}\n/**\n * Converts the given value into a TRBL object.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left)\n * @since 3.0.0\n */ function toTRBL(value) {\n return _readValueToProps(value, {\n top: 'y',\n right: 'x',\n bottom: 'y',\n left: 'x'\n });\n}\n/**\n * Converts the given value into a TRBL corners object (similar with css border-radius).\n * @param value - If a number, set the value to all TRBL corner components,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * @returns The TRBL corner values (topLeft, topRight, bottomLeft, bottomRight)\n * @since 3.0.0\n */ function toTRBLCorners(value) {\n return _readValueToProps(value, [\n 'topLeft',\n 'topRight',\n 'bottomLeft',\n 'bottomRight'\n ]);\n}\n/**\n * Converts the given value into a padding object with pre-computed width/height.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left, width, height)\n * @since 2.7.0\n */ function toPadding(value) {\n const obj = toTRBL(value);\n obj.width = obj.left + obj.right;\n obj.height = obj.top + obj.bottom;\n return obj;\n}\n/**\n * Parses font options and returns the font object.\n * @param options - A object that contains font options to be parsed.\n * @param fallback - A object that contains fallback font options.\n * @return The font object.\n * @private\n */ function toFont(options, fallback) {\n options = options || {};\n fallback = fallback || defaults.font;\n let size = valueOrDefault(options.size, fallback.size);\n if (typeof size === 'string') {\n size = parseInt(size, 10);\n }\n let style = valueOrDefault(options.style, fallback.style);\n if (style && !('' + style).match(FONT_STYLE)) {\n console.warn('Invalid font style specified: \"' + style + '\"');\n style = undefined;\n }\n const font = {\n family: valueOrDefault(options.family, fallback.family),\n lineHeight: toLineHeight(valueOrDefault(options.lineHeight, fallback.lineHeight), size),\n size,\n style,\n weight: valueOrDefault(options.weight, fallback.weight),\n string: ''\n };\n font.string = toFontString(font);\n return font;\n}\n/**\n * Evaluates the given `inputs` sequentially and returns the first defined value.\n * @param inputs - An array of values, falling back to the last value.\n * @param context - If defined and the current value is a function, the value\n * is called with `context` as first argument and the result becomes the new input.\n * @param index - If defined and the current value is an array, the value\n * at `index` become the new input.\n * @param info - object to return information about resolution in\n * @param info.cacheable - Will be set to `false` if option is not cacheable.\n * @since 2.7.0\n */ function resolve(inputs, context, index, info) {\n let cacheable = true;\n let i, ilen, value;\n for(i = 0, ilen = inputs.length; i < ilen; ++i){\n value = inputs[i];\n if (value === undefined) {\n continue;\n }\n if (context !== undefined && typeof value === 'function') {\n value = value(context);\n cacheable = false;\n }\n if (index !== undefined && isArray(value)) {\n value = value[index % value.length];\n cacheable = false;\n }\n if (value !== undefined) {\n if (info && !cacheable) {\n info.cacheable = false;\n }\n return value;\n }\n }\n}\n/**\n * @param minmax\n * @param grace\n * @param beginAtZero\n * @private\n */ function _addGrace(minmax, grace, beginAtZero) {\n const { min , max } = minmax;\n const change = toDimension(grace, (max - min) / 2);\n const keepZero = (value, add)=>beginAtZero && value === 0 ? 0 : value + add;\n return {\n min: keepZero(min, -Math.abs(change)),\n max: keepZero(max, change)\n };\n}\nfunction createContext(parentContext, context) {\n return Object.assign(Object.create(parentContext), context);\n}\n\n/**\n * Creates a Proxy for resolving raw values for options.\n * @param scopes - The option scopes to look for values, in resolution order\n * @param prefixes - The prefixes for values, in resolution order.\n * @param rootScopes - The root option scopes\n * @param fallback - Parent scopes fallback\n * @param getTarget - callback for getting the target for changed values\n * @returns Proxy\n * @private\n */ function _createResolver(scopes, prefixes = [\n ''\n], rootScopes, fallback, getTarget = ()=>scopes[0]) {\n const finalRootScopes = rootScopes || scopes;\n if (typeof fallback === 'undefined') {\n fallback = _resolve('_fallback', scopes);\n }\n const cache = {\n [Symbol.toStringTag]: 'Object',\n _cacheable: true,\n _scopes: scopes,\n _rootScopes: finalRootScopes,\n _fallback: fallback,\n _getTarget: getTarget,\n override: (scope)=>_createResolver([\n scope,\n ...scopes\n ], prefixes, finalRootScopes, fallback)\n };\n return new Proxy(cache, {\n /**\n * A trap for the delete operator.\n */ deleteProperty (target, prop) {\n delete target[prop]; // remove from cache\n delete target._keys; // remove cached keys\n delete scopes[0][prop]; // remove from top level scope\n return true;\n },\n /**\n * A trap for getting property values.\n */ get (target, prop) {\n return _cached(target, prop, ()=>_resolveWithPrefixes(prop, prefixes, scopes, target));\n },\n /**\n * A trap for Object.getOwnPropertyDescriptor.\n * Also used by Object.hasOwnProperty.\n */ getOwnPropertyDescriptor (target, prop) {\n return Reflect.getOwnPropertyDescriptor(target._scopes[0], prop);\n },\n /**\n * A trap for Object.getPrototypeOf.\n */ getPrototypeOf () {\n return Reflect.getPrototypeOf(scopes[0]);\n },\n /**\n * A trap for the in operator.\n */ has (target, prop) {\n return getKeysFromAllScopes(target).includes(prop);\n },\n /**\n * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n */ ownKeys (target) {\n return getKeysFromAllScopes(target);\n },\n /**\n * A trap for setting property values.\n */ set (target, prop, value) {\n const storage = target._storage || (target._storage = getTarget());\n target[prop] = storage[prop] = value; // set to top level scope + cache\n delete target._keys; // remove cached keys\n return true;\n }\n });\n}\n/**\n * Returns an Proxy for resolving option values with context.\n * @param proxy - The Proxy returned by `_createResolver`\n * @param context - Context object for scriptable/indexable options\n * @param subProxy - The proxy provided for scriptable options\n * @param descriptorDefaults - Defaults for descriptors\n * @private\n */ function _attachContext(proxy, context, subProxy, descriptorDefaults) {\n const cache = {\n _cacheable: false,\n _proxy: proxy,\n _context: context,\n _subProxy: subProxy,\n _stack: new Set(),\n _descriptors: _descriptors(proxy, descriptorDefaults),\n setContext: (ctx)=>_attachContext(proxy, ctx, subProxy, descriptorDefaults),\n override: (scope)=>_attachContext(proxy.override(scope), context, subProxy, descriptorDefaults)\n };\n return new Proxy(cache, {\n /**\n * A trap for the delete operator.\n */ deleteProperty (target, prop) {\n delete target[prop]; // remove from cache\n delete proxy[prop]; // remove from proxy\n return true;\n },\n /**\n * A trap for getting property values.\n */ get (target, prop, receiver) {\n return _cached(target, prop, ()=>_resolveWithContext(target, prop, receiver));\n },\n /**\n * A trap for Object.getOwnPropertyDescriptor.\n * Also used by Object.hasOwnProperty.\n */ getOwnPropertyDescriptor (target, prop) {\n return target._descriptors.allKeys ? Reflect.has(proxy, prop) ? {\n enumerable: true,\n configurable: true\n } : undefined : Reflect.getOwnPropertyDescriptor(proxy, prop);\n },\n /**\n * A trap for Object.getPrototypeOf.\n */ getPrototypeOf () {\n return Reflect.getPrototypeOf(proxy);\n },\n /**\n * A trap for the in operator.\n */ has (target, prop) {\n return Reflect.has(proxy, prop);\n },\n /**\n * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n */ ownKeys () {\n return Reflect.ownKeys(proxy);\n },\n /**\n * A trap for setting property values.\n */ set (target, prop, value) {\n proxy[prop] = value; // set to proxy\n delete target[prop]; // remove from cache\n return true;\n }\n });\n}\n/**\n * @private\n */ function _descriptors(proxy, defaults = {\n scriptable: true,\n indexable: true\n}) {\n const { _scriptable =defaults.scriptable , _indexable =defaults.indexable , _allKeys =defaults.allKeys } = proxy;\n return {\n allKeys: _allKeys,\n scriptable: _scriptable,\n indexable: _indexable,\n isScriptable: isFunction(_scriptable) ? _scriptable : ()=>_scriptable,\n isIndexable: isFunction(_indexable) ? _indexable : ()=>_indexable\n };\n}\nconst readKey = (prefix, name)=>prefix ? prefix + _capitalize(name) : name;\nconst needsSubResolver = (prop, value)=>isObject(value) && prop !== 'adapters' && (Object.getPrototypeOf(value) === null || value.constructor === Object);\nfunction _cached(target, prop, resolve) {\n if (Object.prototype.hasOwnProperty.call(target, prop) || prop === 'constructor') {\n return target[prop];\n }\n const value = resolve();\n // cache the resolved value\n target[prop] = value;\n return value;\n}\nfunction _resolveWithContext(target, prop, receiver) {\n const { _proxy , _context , _subProxy , _descriptors: descriptors } = target;\n let value = _proxy[prop]; // resolve from proxy\n // resolve with context\n if (isFunction(value) && descriptors.isScriptable(prop)) {\n value = _resolveScriptable(prop, value, target, receiver);\n }\n if (isArray(value) && value.length) {\n value = _resolveArray(prop, value, target, descriptors.isIndexable);\n }\n if (needsSubResolver(prop, value)) {\n // if the resolved value is an object, create a sub resolver for it\n value = _attachContext(value, _context, _subProxy && _subProxy[prop], descriptors);\n }\n return value;\n}\nfunction _resolveScriptable(prop, getValue, target, receiver) {\n const { _proxy , _context , _subProxy , _stack } = target;\n if (_stack.has(prop)) {\n throw new Error('Recursion detected: ' + Array.from(_stack).join('->') + '->' + prop);\n }\n _stack.add(prop);\n let value = getValue(_context, _subProxy || receiver);\n _stack.delete(prop);\n if (needsSubResolver(prop, value)) {\n // When scriptable option returns an object, create a resolver on that.\n value = createSubResolver(_proxy._scopes, _proxy, prop, value);\n }\n return value;\n}\nfunction _resolveArray(prop, value, target, isIndexable) {\n const { _proxy , _context , _subProxy , _descriptors: descriptors } = target;\n if (typeof _context.index !== 'undefined' && isIndexable(prop)) {\n return value[_context.index % value.length];\n } else if (isObject(value[0])) {\n // Array of objects, return array or resolvers\n const arr = value;\n const scopes = _proxy._scopes.filter((s)=>s !== arr);\n value = [];\n for (const item of arr){\n const resolver = createSubResolver(scopes, _proxy, prop, item);\n value.push(_attachContext(resolver, _context, _subProxy && _subProxy[prop], descriptors));\n }\n }\n return value;\n}\nfunction resolveFallback(fallback, prop, value) {\n return isFunction(fallback) ? fallback(prop, value) : fallback;\n}\nconst getScope = (key, parent)=>key === true ? parent : typeof key === 'string' ? resolveObjectKey(parent, key) : undefined;\nfunction addScopes(set, parentScopes, key, parentFallback, value) {\n for (const parent of parentScopes){\n const scope = getScope(key, parent);\n if (scope) {\n set.add(scope);\n const fallback = resolveFallback(scope._fallback, key, value);\n if (typeof fallback !== 'undefined' && fallback !== key && fallback !== parentFallback) {\n // When we reach the descriptor that defines a new _fallback, return that.\n // The fallback will resume to that new scope.\n return fallback;\n }\n } else if (scope === false && typeof parentFallback !== 'undefined' && key !== parentFallback) {\n // Fallback to `false` results to `false`, when falling back to different key.\n // For example `interaction` from `hover` or `plugins.tooltip` and `animation` from `animations`\n return null;\n }\n }\n return false;\n}\nfunction createSubResolver(parentScopes, resolver, prop, value) {\n const rootScopes = resolver._rootScopes;\n const fallback = resolveFallback(resolver._fallback, prop, value);\n const allScopes = [\n ...parentScopes,\n ...rootScopes\n ];\n const set = new Set();\n set.add(value);\n let key = addScopesFromKey(set, allScopes, prop, fallback || prop, value);\n if (key === null) {\n return false;\n }\n if (typeof fallback !== 'undefined' && fallback !== prop) {\n key = addScopesFromKey(set, allScopes, fallback, key, value);\n if (key === null) {\n return false;\n }\n }\n return _createResolver(Array.from(set), [\n ''\n ], rootScopes, fallback, ()=>subGetTarget(resolver, prop, value));\n}\nfunction addScopesFromKey(set, allScopes, key, fallback, item) {\n while(key){\n key = addScopes(set, allScopes, key, fallback, item);\n }\n return key;\n}\nfunction subGetTarget(resolver, prop, value) {\n const parent = resolver._getTarget();\n if (!(prop in parent)) {\n parent[prop] = {};\n }\n const target = parent[prop];\n if (isArray(target) && isObject(value)) {\n // For array of objects, the object is used to store updated values\n return value;\n }\n return target || {};\n}\nfunction _resolveWithPrefixes(prop, prefixes, scopes, proxy) {\n let value;\n for (const prefix of prefixes){\n value = _resolve(readKey(prefix, prop), scopes);\n if (typeof value !== 'undefined') {\n return needsSubResolver(prop, value) ? createSubResolver(scopes, proxy, prop, value) : value;\n }\n }\n}\nfunction _resolve(key, scopes) {\n for (const scope of scopes){\n if (!scope) {\n continue;\n }\n const value = scope[key];\n if (typeof value !== 'undefined') {\n return value;\n }\n }\n}\nfunction getKeysFromAllScopes(target) {\n let keys = target._keys;\n if (!keys) {\n keys = target._keys = resolveKeysFromAllScopes(target._scopes);\n }\n return keys;\n}\nfunction resolveKeysFromAllScopes(scopes) {\n const set = new Set();\n for (const scope of scopes){\n for (const key of Object.keys(scope).filter((k)=>!k.startsWith('_'))){\n set.add(key);\n }\n }\n return Array.from(set);\n}\nfunction _parseObjectDataRadialScale(meta, data, start, count) {\n const { iScale } = meta;\n const { key ='r' } = this._parsing;\n const parsed = new Array(count);\n let i, ilen, index, item;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n item = data[index];\n parsed[i] = {\n r: iScale.parse(resolveObjectKey(item, key), index)\n };\n }\n return parsed;\n}\n\nconst EPSILON = Number.EPSILON || 1e-14;\nconst getPoint = (points, i)=>i < points.length && !points[i].skip && points[i];\nconst getValueAxis = (indexAxis)=>indexAxis === 'x' ? 'y' : 'x';\nfunction splineCurve(firstPoint, middlePoint, afterPoint, t) {\n // Props to Rob Spencer at scaled innovation for his post on splining between points\n // http://scaledinnovation.com/analytics/splines/aboutSplines.html\n // This function must also respect \"skipped\" points\n const previous = firstPoint.skip ? middlePoint : firstPoint;\n const current = middlePoint;\n const next = afterPoint.skip ? middlePoint : afterPoint;\n const d01 = distanceBetweenPoints(current, previous);\n const d12 = distanceBetweenPoints(next, current);\n let s01 = d01 / (d01 + d12);\n let s12 = d12 / (d01 + d12);\n // If all points are the same, s01 & s02 will be inf\n s01 = isNaN(s01) ? 0 : s01;\n s12 = isNaN(s12) ? 0 : s12;\n const fa = t * s01; // scaling factor for triangle Ta\n const fb = t * s12;\n return {\n previous: {\n x: current.x - fa * (next.x - previous.x),\n y: current.y - fa * (next.y - previous.y)\n },\n next: {\n x: current.x + fb * (next.x - previous.x),\n y: current.y + fb * (next.y - previous.y)\n }\n };\n}\n/**\n * Adjust tangents to ensure monotonic properties\n */ function monotoneAdjust(points, deltaK, mK) {\n const pointsLen = points.length;\n let alphaK, betaK, tauK, squaredMagnitude, pointCurrent;\n let pointAfter = getPoint(points, 0);\n for(let i = 0; i < pointsLen - 1; ++i){\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent || !pointAfter) {\n continue;\n }\n if (almostEquals(deltaK[i], 0, EPSILON)) {\n mK[i] = mK[i + 1] = 0;\n continue;\n }\n alphaK = mK[i] / deltaK[i];\n betaK = mK[i + 1] / deltaK[i];\n squaredMagnitude = Math.pow(alphaK, 2) + Math.pow(betaK, 2);\n if (squaredMagnitude <= 9) {\n continue;\n }\n tauK = 3 / Math.sqrt(squaredMagnitude);\n mK[i] = alphaK * tauK * deltaK[i];\n mK[i + 1] = betaK * tauK * deltaK[i];\n }\n}\nfunction monotoneCompute(points, mK, indexAxis = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n let delta, pointBefore, pointCurrent;\n let pointAfter = getPoint(points, 0);\n for(let i = 0; i < pointsLen; ++i){\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n const iPixel = pointCurrent[indexAxis];\n const vPixel = pointCurrent[valueAxis];\n if (pointBefore) {\n delta = (iPixel - pointBefore[indexAxis]) / 3;\n pointCurrent[`cp1${indexAxis}`] = iPixel - delta;\n pointCurrent[`cp1${valueAxis}`] = vPixel - delta * mK[i];\n }\n if (pointAfter) {\n delta = (pointAfter[indexAxis] - iPixel) / 3;\n pointCurrent[`cp2${indexAxis}`] = iPixel + delta;\n pointCurrent[`cp2${valueAxis}`] = vPixel + delta * mK[i];\n }\n }\n}\n/**\n * This function calculates Bézier control points in a similar way than |splineCurve|,\n * but preserves monotonicity of the provided data and ensures no local extremums are added\n * between the dataset discrete points due to the interpolation.\n * See : https://en.wikipedia.org/wiki/Monotone_cubic_interpolation\n */ function splineCurveMonotone(points, indexAxis = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n const deltaK = Array(pointsLen).fill(0);\n const mK = Array(pointsLen);\n // Calculate slopes (deltaK) and initialize tangents (mK)\n let i, pointBefore, pointCurrent;\n let pointAfter = getPoint(points, 0);\n for(i = 0; i < pointsLen; ++i){\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n if (pointAfter) {\n const slopeDelta = pointAfter[indexAxis] - pointCurrent[indexAxis];\n // In the case of two points that appear at the same x pixel, slopeDeltaX is 0\n deltaK[i] = slopeDelta !== 0 ? (pointAfter[valueAxis] - pointCurrent[valueAxis]) / slopeDelta : 0;\n }\n mK[i] = !pointBefore ? deltaK[i] : !pointAfter ? deltaK[i - 1] : sign(deltaK[i - 1]) !== sign(deltaK[i]) ? 0 : (deltaK[i - 1] + deltaK[i]) / 2;\n }\n monotoneAdjust(points, deltaK, mK);\n monotoneCompute(points, mK, indexAxis);\n}\nfunction capControlPoint(pt, min, max) {\n return Math.max(Math.min(pt, max), min);\n}\nfunction capBezierPoints(points, area) {\n let i, ilen, point, inArea, inAreaPrev;\n let inAreaNext = _isPointInArea(points[0], area);\n for(i = 0, ilen = points.length; i < ilen; ++i){\n inAreaPrev = inArea;\n inArea = inAreaNext;\n inAreaNext = i < ilen - 1 && _isPointInArea(points[i + 1], area);\n if (!inArea) {\n continue;\n }\n point = points[i];\n if (inAreaPrev) {\n point.cp1x = capControlPoint(point.cp1x, area.left, area.right);\n point.cp1y = capControlPoint(point.cp1y, area.top, area.bottom);\n }\n if (inAreaNext) {\n point.cp2x = capControlPoint(point.cp2x, area.left, area.right);\n point.cp2y = capControlPoint(point.cp2y, area.top, area.bottom);\n }\n }\n}\n/**\n * @private\n */ function _updateBezierControlPoints(points, options, area, loop, indexAxis) {\n let i, ilen, point, controlPoints;\n // Only consider points that are drawn in case the spanGaps option is used\n if (options.spanGaps) {\n points = points.filter((pt)=>!pt.skip);\n }\n if (options.cubicInterpolationMode === 'monotone') {\n splineCurveMonotone(points, indexAxis);\n } else {\n let prev = loop ? points[points.length - 1] : points[0];\n for(i = 0, ilen = points.length; i < ilen; ++i){\n point = points[i];\n controlPoints = splineCurve(prev, point, points[Math.min(i + 1, ilen - (loop ? 0 : 1)) % ilen], options.tension);\n point.cp1x = controlPoints.previous.x;\n point.cp1y = controlPoints.previous.y;\n point.cp2x = controlPoints.next.x;\n point.cp2y = controlPoints.next.y;\n prev = point;\n }\n }\n if (options.capBezierPoints) {\n capBezierPoints(points, area);\n }\n}\n\n/**\n * Note: typedefs are auto-exported, so use a made-up `dom` namespace where\n * necessary to avoid duplicates with `export * from './helpers`; see\n * https://github.com/microsoft/TypeScript/issues/46011\n * @typedef { import('../core/core.controller.js').default } dom.Chart\n * @typedef { import('../../types').ChartEvent } ChartEvent\n */ /**\n * @private\n */ function _isDomSupported() {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n/**\n * @private\n */ function _getParentNode(domNode) {\n let parent = domNode.parentNode;\n if (parent && parent.toString() === '[object ShadowRoot]') {\n parent = parent.host;\n }\n return parent;\n}\n/**\n * convert max-width/max-height values that may be percentages into a number\n * @private\n */ function parseMaxStyle(styleValue, node, parentProperty) {\n let valueInPixels;\n if (typeof styleValue === 'string') {\n valueInPixels = parseInt(styleValue, 10);\n if (styleValue.indexOf('%') !== -1) {\n // percentage * size in dimension\n valueInPixels = valueInPixels / 100 * node.parentNode[parentProperty];\n }\n } else {\n valueInPixels = styleValue;\n }\n return valueInPixels;\n}\nconst getComputedStyle = (element)=>element.ownerDocument.defaultView.getComputedStyle(element, null);\nfunction getStyle(el, property) {\n return getComputedStyle(el).getPropertyValue(property);\n}\nconst positions = [\n 'top',\n 'right',\n 'bottom',\n 'left'\n];\nfunction getPositionedStyle(styles, style, suffix) {\n const result = {};\n suffix = suffix ? '-' + suffix : '';\n for(let i = 0; i < 4; i++){\n const pos = positions[i];\n result[pos] = parseFloat(styles[style + '-' + pos + suffix]) || 0;\n }\n result.width = result.left + result.right;\n result.height = result.top + result.bottom;\n return result;\n}\nconst useOffsetPos = (x, y, target)=>(x > 0 || y > 0) && (!target || !target.shadowRoot);\n/**\n * @param e\n * @param canvas\n * @returns Canvas position\n */ function getCanvasPosition(e, canvas) {\n const touches = e.touches;\n const source = touches && touches.length ? touches[0] : e;\n const { offsetX , offsetY } = source;\n let box = false;\n let x, y;\n if (useOffsetPos(offsetX, offsetY, e.target)) {\n x = offsetX;\n y = offsetY;\n } else {\n const rect = canvas.getBoundingClientRect();\n x = source.clientX - rect.left;\n y = source.clientY - rect.top;\n box = true;\n }\n return {\n x,\n y,\n box\n };\n}\n/**\n * Gets an event's x, y coordinates, relative to the chart area\n * @param event\n * @param chart\n * @returns x and y coordinates of the event\n */ function getRelativePosition(event, chart) {\n if ('native' in event) {\n return event;\n }\n const { canvas , currentDevicePixelRatio } = chart;\n const style = getComputedStyle(canvas);\n const borderBox = style.boxSizing === 'border-box';\n const paddings = getPositionedStyle(style, 'padding');\n const borders = getPositionedStyle(style, 'border', 'width');\n const { x , y , box } = getCanvasPosition(event, canvas);\n const xOffset = paddings.left + (box && borders.left);\n const yOffset = paddings.top + (box && borders.top);\n let { width , height } = chart;\n if (borderBox) {\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n return {\n x: Math.round((x - xOffset) / width * canvas.width / currentDevicePixelRatio),\n y: Math.round((y - yOffset) / height * canvas.height / currentDevicePixelRatio)\n };\n}\nfunction getContainerSize(canvas, width, height) {\n let maxWidth, maxHeight;\n if (width === undefined || height === undefined) {\n const container = canvas && _getParentNode(canvas);\n if (!container) {\n width = canvas.clientWidth;\n height = canvas.clientHeight;\n } else {\n const rect = container.getBoundingClientRect(); // this is the border box of the container\n const containerStyle = getComputedStyle(container);\n const containerBorder = getPositionedStyle(containerStyle, 'border', 'width');\n const containerPadding = getPositionedStyle(containerStyle, 'padding');\n width = rect.width - containerPadding.width - containerBorder.width;\n height = rect.height - containerPadding.height - containerBorder.height;\n maxWidth = parseMaxStyle(containerStyle.maxWidth, container, 'clientWidth');\n maxHeight = parseMaxStyle(containerStyle.maxHeight, container, 'clientHeight');\n }\n }\n return {\n width,\n height,\n maxWidth: maxWidth || INFINITY,\n maxHeight: maxHeight || INFINITY\n };\n}\nconst round1 = (v)=>Math.round(v * 10) / 10;\n// eslint-disable-next-line complexity\nfunction getMaximumSize(canvas, bbWidth, bbHeight, aspectRatio) {\n const style = getComputedStyle(canvas);\n const margins = getPositionedStyle(style, 'margin');\n const maxWidth = parseMaxStyle(style.maxWidth, canvas, 'clientWidth') || INFINITY;\n const maxHeight = parseMaxStyle(style.maxHeight, canvas, 'clientHeight') || INFINITY;\n const containerSize = getContainerSize(canvas, bbWidth, bbHeight);\n let { width , height } = containerSize;\n if (style.boxSizing === 'content-box') {\n const borders = getPositionedStyle(style, 'border', 'width');\n const paddings = getPositionedStyle(style, 'padding');\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n width = Math.max(0, width - margins.width);\n height = Math.max(0, aspectRatio ? width / aspectRatio : height - margins.height);\n width = round1(Math.min(width, maxWidth, containerSize.maxWidth));\n height = round1(Math.min(height, maxHeight, containerSize.maxHeight));\n if (width && !height) {\n // https://github.com/chartjs/Chart.js/issues/4659\n // If the canvas has width, but no height, default to aspectRatio of 2 (canvas default)\n height = round1(width / 2);\n }\n const maintainHeight = bbWidth !== undefined || bbHeight !== undefined;\n if (maintainHeight && aspectRatio && containerSize.height && height > containerSize.height) {\n height = containerSize.height;\n width = round1(Math.floor(height * aspectRatio));\n }\n return {\n width,\n height\n };\n}\n/**\n * @param chart\n * @param forceRatio\n * @param forceStyle\n * @returns True if the canvas context size or transformation has changed.\n */ function retinaScale(chart, forceRatio, forceStyle) {\n const pixelRatio = forceRatio || 1;\n const deviceHeight = Math.floor(chart.height * pixelRatio);\n const deviceWidth = Math.floor(chart.width * pixelRatio);\n chart.height = Math.floor(chart.height);\n chart.width = Math.floor(chart.width);\n const canvas = chart.canvas;\n // If no style has been set on the canvas, the render size is used as display size,\n // making the chart visually bigger, so let's enforce it to the \"correct\" values.\n // See https://github.com/chartjs/Chart.js/issues/3575\n if (canvas.style && (forceStyle || !canvas.style.height && !canvas.style.width)) {\n canvas.style.height = `${chart.height}px`;\n canvas.style.width = `${chart.width}px`;\n }\n if (chart.currentDevicePixelRatio !== pixelRatio || canvas.height !== deviceHeight || canvas.width !== deviceWidth) {\n chart.currentDevicePixelRatio = pixelRatio;\n canvas.height = deviceHeight;\n canvas.width = deviceWidth;\n chart.ctx.setTransform(pixelRatio, 0, 0, pixelRatio, 0, 0);\n return true;\n }\n return false;\n}\n/**\n * Detects support for options object argument in addEventListener.\n * https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#Safely_detecting_option_support\n * @private\n */ const supportsEventListenerOptions = function() {\n let passiveSupported = false;\n try {\n const options = {\n get passive () {\n passiveSupported = true;\n return false;\n }\n };\n if (_isDomSupported()) {\n window.addEventListener('test', null, options);\n window.removeEventListener('test', null, options);\n }\n } catch (e) {\n // continue regardless of error\n }\n return passiveSupported;\n}();\n/**\n * The \"used\" size is the final value of a dimension property after all calculations have\n * been performed. This method uses the computed style of `element` but returns undefined\n * if the computed style is not expressed in pixels. That can happen in some cases where\n * `element` has a size relative to its parent and this last one is not yet displayed,\n * for example because of `display: none` on a parent node.\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/used_value\n * @returns Size in pixels or undefined if unknown.\n */ function readUsedSize(element, property) {\n const value = getStyle(element, property);\n const matches = value && value.match(/^(\\d+)(\\.\\d+)?px$/);\n return matches ? +matches[1] : undefined;\n}\n\n/**\n * @private\n */ function _pointInLine(p1, p2, t, mode) {\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: p1.y + t * (p2.y - p1.y)\n };\n}\n/**\n * @private\n */ function _steppedInterpolation(p1, p2, t, mode) {\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: mode === 'middle' ? t < 0.5 ? p1.y : p2.y : mode === 'after' ? t < 1 ? p1.y : p2.y : t > 0 ? p2.y : p1.y\n };\n}\n/**\n * @private\n */ function _bezierInterpolation(p1, p2, t, mode) {\n const cp1 = {\n x: p1.cp2x,\n y: p1.cp2y\n };\n const cp2 = {\n x: p2.cp1x,\n y: p2.cp1y\n };\n const a = _pointInLine(p1, cp1, t);\n const b = _pointInLine(cp1, cp2, t);\n const c = _pointInLine(cp2, p2, t);\n const d = _pointInLine(a, b, t);\n const e = _pointInLine(b, c, t);\n return _pointInLine(d, e, t);\n}\n\nconst getRightToLeftAdapter = function(rectX, width) {\n return {\n x (x) {\n return rectX + rectX + width - x;\n },\n setWidth (w) {\n width = w;\n },\n textAlign (align) {\n if (align === 'center') {\n return align;\n }\n return align === 'right' ? 'left' : 'right';\n },\n xPlus (x, value) {\n return x - value;\n },\n leftForLtr (x, itemWidth) {\n return x - itemWidth;\n }\n };\n};\nconst getLeftToRightAdapter = function() {\n return {\n x (x) {\n return x;\n },\n setWidth (w) {},\n textAlign (align) {\n return align;\n },\n xPlus (x, value) {\n return x + value;\n },\n leftForLtr (x, _itemWidth) {\n return x;\n }\n };\n};\nfunction getRtlAdapter(rtl, rectX, width) {\n return rtl ? getRightToLeftAdapter(rectX, width) : getLeftToRightAdapter();\n}\nfunction overrideTextDirection(ctx, direction) {\n let style, original;\n if (direction === 'ltr' || direction === 'rtl') {\n style = ctx.canvas.style;\n original = [\n style.getPropertyValue('direction'),\n style.getPropertyPriority('direction')\n ];\n style.setProperty('direction', direction, 'important');\n ctx.prevTextDirection = original;\n }\n}\nfunction restoreTextDirection(ctx, original) {\n if (original !== undefined) {\n delete ctx.prevTextDirection;\n ctx.canvas.style.setProperty('direction', original[0], original[1]);\n }\n}\n\nfunction propertyFn(property) {\n if (property === 'angle') {\n return {\n between: _angleBetween,\n compare: _angleDiff,\n normalize: _normalizeAngle\n };\n }\n return {\n between: _isBetween,\n compare: (a, b)=>a - b,\n normalize: (x)=>x\n };\n}\nfunction normalizeSegment({ start , end , count , loop , style }) {\n return {\n start: start % count,\n end: end % count,\n loop: loop && (end - start + 1) % count === 0,\n style\n };\n}\nfunction getSegment(segment, points, bounds) {\n const { property , start: startBound , end: endBound } = bounds;\n const { between , normalize } = propertyFn(property);\n const count = points.length;\n let { start , end , loop } = segment;\n let i, ilen;\n if (loop) {\n start += count;\n end += count;\n for(i = 0, ilen = count; i < ilen; ++i){\n if (!between(normalize(points[start % count][property]), startBound, endBound)) {\n break;\n }\n start--;\n end--;\n }\n start %= count;\n end %= count;\n }\n if (end < start) {\n end += count;\n }\n return {\n start,\n end,\n loop,\n style: segment.style\n };\n}\n function _boundSegment(segment, points, bounds) {\n if (!bounds) {\n return [\n segment\n ];\n }\n const { property , start: startBound , end: endBound } = bounds;\n const count = points.length;\n const { compare , between , normalize } = propertyFn(property);\n const { start , end , loop , style } = getSegment(segment, points, bounds);\n const result = [];\n let inside = false;\n let subStart = null;\n let value, point, prevValue;\n const startIsBefore = ()=>between(startBound, prevValue, value) && compare(startBound, prevValue) !== 0;\n const endIsBefore = ()=>compare(endBound, value) === 0 || between(endBound, prevValue, value);\n const shouldStart = ()=>inside || startIsBefore();\n const shouldStop = ()=>!inside || endIsBefore();\n for(let i = start, prev = start; i <= end; ++i){\n point = points[i % count];\n if (point.skip) {\n continue;\n }\n value = normalize(point[property]);\n if (value === prevValue) {\n continue;\n }\n inside = between(value, startBound, endBound);\n if (subStart === null && shouldStart()) {\n subStart = compare(value, startBound) === 0 ? i : prev;\n }\n if (subStart !== null && shouldStop()) {\n result.push(normalizeSegment({\n start: subStart,\n end: i,\n loop,\n count,\n style\n }));\n subStart = null;\n }\n prev = i;\n prevValue = value;\n }\n if (subStart !== null) {\n result.push(normalizeSegment({\n start: subStart,\n end,\n loop,\n count,\n style\n }));\n }\n return result;\n}\n function _boundSegments(line, bounds) {\n const result = [];\n const segments = line.segments;\n for(let i = 0; i < segments.length; i++){\n const sub = _boundSegment(segments[i], line.points, bounds);\n if (sub.length) {\n result.push(...sub);\n }\n }\n return result;\n}\n function findStartAndEnd(points, count, loop, spanGaps) {\n let start = 0;\n let end = count - 1;\n if (loop && !spanGaps) {\n while(start < count && !points[start].skip){\n start++;\n }\n }\n while(start < count && points[start].skip){\n start++;\n }\n start %= count;\n if (loop) {\n end += start;\n }\n while(end > start && points[end % count].skip){\n end--;\n }\n end %= count;\n return {\n start,\n end\n };\n}\n function solidSegments(points, start, max, loop) {\n const count = points.length;\n const result = [];\n let last = start;\n let prev = points[start];\n let end;\n for(end = start + 1; end <= max; ++end){\n const cur = points[end % count];\n if (cur.skip || cur.stop) {\n if (!prev.skip) {\n loop = false;\n result.push({\n start: start % count,\n end: (end - 1) % count,\n loop\n });\n start = last = cur.stop ? end : null;\n }\n } else {\n last = end;\n if (prev.skip) {\n start = end;\n }\n }\n prev = cur;\n }\n if (last !== null) {\n result.push({\n start: start % count,\n end: last % count,\n loop\n });\n }\n return result;\n}\n function _computeSegments(line, segmentOptions) {\n const points = line.points;\n const spanGaps = line.options.spanGaps;\n const count = points.length;\n if (!count) {\n return [];\n }\n const loop = !!line._loop;\n const { start , end } = findStartAndEnd(points, count, loop, spanGaps);\n if (spanGaps === true) {\n return splitByStyles(line, [\n {\n start,\n end,\n loop\n }\n ], points, segmentOptions);\n }\n const max = end < start ? end + count : end;\n const completeLoop = !!line._fullLoop && start === 0 && end === count - 1;\n return splitByStyles(line, solidSegments(points, start, max, completeLoop), points, segmentOptions);\n}\n function splitByStyles(line, segments, points, segmentOptions) {\n if (!segmentOptions || !segmentOptions.setContext || !points) {\n return segments;\n }\n return doSplitByStyles(line, segments, points, segmentOptions);\n}\n function doSplitByStyles(line, segments, points, segmentOptions) {\n const chartContext = line._chart.getContext();\n const baseStyle = readStyle(line.options);\n const { _datasetIndex: datasetIndex , options: { spanGaps } } = line;\n const count = points.length;\n const result = [];\n let prevStyle = baseStyle;\n let start = segments[0].start;\n let i = start;\n function addStyle(s, e, l, st) {\n const dir = spanGaps ? -1 : 1;\n if (s === e) {\n return;\n }\n s += count;\n while(points[s % count].skip){\n s -= dir;\n }\n while(points[e % count].skip){\n e += dir;\n }\n if (s % count !== e % count) {\n result.push({\n start: s % count,\n end: e % count,\n loop: l,\n style: st\n });\n prevStyle = st;\n start = e % count;\n }\n }\n for (const segment of segments){\n start = spanGaps ? start : segment.start;\n let prev = points[start % count];\n let style;\n for(i = start + 1; i <= segment.end; i++){\n const pt = points[i % count];\n style = readStyle(segmentOptions.setContext(createContext(chartContext, {\n type: 'segment',\n p0: prev,\n p1: pt,\n p0DataIndex: (i - 1) % count,\n p1DataIndex: i % count,\n datasetIndex\n })));\n if (styleChanged(style, prevStyle)) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n prev = pt;\n prevStyle = style;\n }\n if (start < i - 1) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n }\n return result;\n}\nfunction readStyle(options) {\n return {\n backgroundColor: options.backgroundColor,\n borderCapStyle: options.borderCapStyle,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderJoinStyle: options.borderJoinStyle,\n borderWidth: options.borderWidth,\n borderColor: options.borderColor\n };\n}\nfunction styleChanged(style, prevStyle) {\n if (!prevStyle) {\n return false;\n }\n const cache = [];\n const replacer = function(key, value) {\n if (!isPatternOrGradient(value)) {\n return value;\n }\n if (!cache.includes(value)) {\n cache.push(value);\n }\n return cache.indexOf(value);\n };\n return JSON.stringify(style, replacer) !== JSON.stringify(prevStyle, replacer);\n}\n\nexport { unclipArea as $, _rlookupByKey as A, _lookupByKey as B, _isPointInArea as C, getAngleFromPoint as D, toPadding as E, each as F, getMaximumSize as G, HALF_PI as H, _getParentNode as I, readUsedSize as J, supportsEventListenerOptions as K, throttled as L, _isDomSupported as M, _factorize as N, finiteOrDefault as O, PI as P, callback as Q, _addGrace as R, _limitValue as S, TAU as T, toDegrees as U, _measureText as V, _int16Range as W, _alignPixel as X, clipArea as Y, renderText as Z, _arrayUnique as _, resolve as a, fontString as a$, toFont as a0, _toLeftRightCenter as a1, _alignStartEnd as a2, overrides as a3, merge as a4, _capitalize as a5, descriptors as a6, isFunction as a7, _attachContext as a8, _createResolver as a9, overrideTextDirection as aA, _textX as aB, restoreTextDirection as aC, drawPointLegend as aD, distanceBetweenPoints as aE, noop as aF, _setMinAndMaxByKey as aG, niceNum as aH, almostWhole as aI, almostEquals as aJ, _decimalPlaces as aK, Ticks as aL, log10 as aM, _longestText as aN, _filterBetween as aO, _lookup as aP, isPatternOrGradient as aQ, getHoverColor as aR, clone as aS, _merger as aT, _mergerIf as aU, _deprecated as aV, _splitKey as aW, toFontString as aX, splineCurve as aY, splineCurveMonotone as aZ, getStyle as a_, _descriptors as aa, mergeIf as ab, uid as ac, debounce as ad, retinaScale as ae, clearCanvas as af, setsEqual as ag, _elementsEqual as ah, _isClickEvent as ai, _isBetween as aj, _readValueToProps as ak, _updateBezierControlPoints as al, _computeSegments as am, _boundSegments as an, _steppedInterpolation as ao, _bezierInterpolation as ap, _pointInLine as aq, _steppedLineTo as ar, _bezierCurveTo as as, drawPoint as at, addRoundedRectPath as au, toTRBL as av, toTRBLCorners as aw, _boundSegment as ax, _normalizeAngle as ay, getRtlAdapter as az, isArray as b, toLineHeight as b0, PITAU as b1, INFINITY as b2, RAD_PER_DEG as b3, QUARTER_PI as b4, TWO_THIRDS_PI as b5, _angleDiff as b6, color as c, defaults as d, effects as e, resolveObjectKey as f, isNumberFinite as g, defined as h, isObject as i, createContext as j, isNullOrUndef as k, listenArrayEvents as l, toPercentage as m, toDimension as n, formatNumber as o, _angleBetween as p, _getStartAndCountOfVisiblePoints as q, requestAnimFrame as r, sign as s, toRadians as t, unlistenArrayEvents as u, valueOrDefault as v, _scaleRangesChanged as w, isNumber as x, _parseObjectDataRadialScale as y, getRelativePosition as z };\n//# sourceMappingURL=helpers.segment.js.map\n","import { getDefaultOptions as getInternalDefaultOptions } from \"./_lib/defaultOptions.mjs\";\n\n/**\n * @name getDefaultOptions\n * @category Common Helpers\n * @summary Get default options.\n * @pure false\n *\n * @description\n * Returns an object that contains defaults for\n * `options.locale`, `options.weekStartsOn` and `options.firstWeekContainsDate`\n * arguments for all functions.\n *\n * You can change these with [setDefaultOptions](https://date-fns.org/docs/setDefaultOptions).\n *\n * @returns The default options\n *\n * @example\n * const result = getDefaultOptions()\n * //=> {}\n *\n * @example\n * setDefaultOptions({ weekStarsOn: 1, firstWeekContainsDate: 4 })\n * const result = getDefaultOptions()\n * //=> { weekStarsOn: 1, firstWeekContainsDate: 4 }\n */\nexport function getDefaultOptions() {\n return Object.assign({}, getInternalDefaultOptions());\n}\n\n// Fallback for modularized imports:\nexport default getDefaultOptions;\n","import { constructFrom } from \"./constructFrom.mjs\";\n\n/**\n * @name transpose\n * @category Generic Helpers\n * @summary Transpose the date to the given constructor.\n *\n * @description\n * The function transposes the date to the given constructor. It helps you\n * to transpose the date in the system time zone to say `UTCDate` or any other\n * date extension.\n *\n * @typeParam DateInputType - The input `Date` type derived from the passed argument.\n * @typeParam DateOutputType - The output `Date` type derived from the passed constructor.\n *\n * @param fromDate - The date to use values from\n * @param constructor - The date constructor to use\n *\n * @returns Date transposed to the given constructor\n *\n * @example\n * // Create July 10, 2022 00:00 in locale time zone\n * const date = new Date(2022, 6, 10)\n * //=> 'Sun Jul 10 2022 00:00:00 GMT+0800 (Singapore Standard Time)'\n *\n * @example\n * // Transpose the date to July 10, 2022 00:00 in UTC\n * transpose(date, UTCDate)\n * //=> 'Sun Jul 10 2022 00:00:00 GMT+0000 (Coordinated Universal Time)'\n */\nexport function transpose(fromDate, constructor) {\n const date =\n constructor instanceof Date\n ? constructFrom(constructor, 0)\n : new constructor(0);\n date.setFullYear(\n fromDate.getFullYear(),\n fromDate.getMonth(),\n fromDate.getDate(),\n );\n date.setHours(\n fromDate.getHours(),\n fromDate.getMinutes(),\n fromDate.getSeconds(),\n fromDate.getMilliseconds(),\n );\n return date;\n}\n\n// Fallback for modularized imports:\nexport default transpose;\n","import { transpose } from \"../../transpose.mjs\";\nimport { constructFrom } from \"../../constructFrom.mjs\";\n\nconst TIMEZONE_UNIT_PRIORITY = 10;\n\nexport class Setter {\n subPriority = 0;\n\n validate(_utcDate, _options) {\n return true;\n }\n}\n\nexport class ValueSetter extends Setter {\n constructor(\n value,\n\n validateValue,\n\n setValue,\n\n priority,\n subPriority,\n ) {\n super();\n this.value = value;\n this.validateValue = validateValue;\n this.setValue = setValue;\n this.priority = priority;\n if (subPriority) {\n this.subPriority = subPriority;\n }\n }\n\n validate(date, options) {\n return this.validateValue(date, this.value, options);\n }\n\n set(date, flags, options) {\n return this.setValue(date, flags, this.value, options);\n }\n}\n\nexport class DateToSystemTimezoneSetter extends Setter {\n priority = TIMEZONE_UNIT_PRIORITY;\n subPriority = -1;\n set(date, flags) {\n if (flags.timestampIsSet) return date;\n return constructFrom(date, transpose(date, Date));\n }\n}\n","import { ValueSetter } from \"./Setter.mjs\";\n\nexport class Parser {\n run(dateString, token, match, options) {\n const result = this.parse(dateString, token, match, options);\n if (!result) {\n return null;\n }\n\n return {\n setter: new ValueSetter(\n result.value,\n this.validate,\n this.set,\n this.priority,\n this.subPriority,\n ),\n rest: result.rest,\n };\n }\n\n validate(_utcDate, _value, _options) {\n return true;\n }\n}\n","import { Parser } from \"../Parser.mjs\";\n\nexport class EraParser extends Parser {\n priority = 140;\n\n parse(dateString, token, match) {\n switch (token) {\n // AD, BC\n case \"G\":\n case \"GG\":\n case \"GGG\":\n return (\n match.era(dateString, { width: \"abbreviated\" }) ||\n match.era(dateString, { width: \"narrow\" })\n );\n\n // A, B\n case \"GGGGG\":\n return match.era(dateString, { width: \"narrow\" });\n // Anno Domini, Before Christ\n case \"GGGG\":\n default:\n return (\n match.era(dateString, { width: \"wide\" }) ||\n match.era(dateString, { width: \"abbreviated\" }) ||\n match.era(dateString, { width: \"narrow\" })\n );\n }\n }\n\n set(date, flags, value) {\n flags.era = value;\n date.setFullYear(value, 0, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"R\", \"u\", \"t\", \"T\"];\n}\n","export const numericPatterns = {\n month: /^(1[0-2]|0?\\d)/, // 0 to 12\n date: /^(3[0-1]|[0-2]?\\d)/, // 0 to 31\n dayOfYear: /^(36[0-6]|3[0-5]\\d|[0-2]?\\d?\\d)/, // 0 to 366\n week: /^(5[0-3]|[0-4]?\\d)/, // 0 to 53\n hour23h: /^(2[0-3]|[0-1]?\\d)/, // 0 to 23\n hour24h: /^(2[0-4]|[0-1]?\\d)/, // 0 to 24\n hour11h: /^(1[0-1]|0?\\d)/, // 0 to 11\n hour12h: /^(1[0-2]|0?\\d)/, // 0 to 12\n minute: /^[0-5]?\\d/, // 0 to 59\n second: /^[0-5]?\\d/, // 0 to 59\n\n singleDigit: /^\\d/, // 0 to 9\n twoDigits: /^\\d{1,2}/, // 0 to 99\n threeDigits: /^\\d{1,3}/, // 0 to 999\n fourDigits: /^\\d{1,4}/, // 0 to 9999\n\n anyDigitsSigned: /^-?\\d+/,\n singleDigitSigned: /^-?\\d/, // 0 to 9, -0 to -9\n twoDigitsSigned: /^-?\\d{1,2}/, // 0 to 99, -0 to -99\n threeDigitsSigned: /^-?\\d{1,3}/, // 0 to 999, -0 to -999\n fourDigitsSigned: /^-?\\d{1,4}/, // 0 to 9999, -0 to -9999\n};\n\nexport const timezonePatterns = {\n basicOptionalMinutes: /^([+-])(\\d{2})(\\d{2})?|Z/,\n basic: /^([+-])(\\d{2})(\\d{2})|Z/,\n basicOptionalSeconds: /^([+-])(\\d{2})(\\d{2})((\\d{2}))?|Z/,\n extended: /^([+-])(\\d{2}):(\\d{2})|Z/,\n extendedOptionalSeconds: /^([+-])(\\d{2}):(\\d{2})(:(\\d{2}))?|Z/,\n};\n","import {\n millisecondsInHour,\n millisecondsInMinute,\n millisecondsInSecond,\n} from \"../../constants.mjs\";\nimport { numericPatterns } from \"./constants.mjs\";\n\nexport function mapValue(parseFnResult, mapFn) {\n if (!parseFnResult) {\n return parseFnResult;\n }\n\n return {\n value: mapFn(parseFnResult.value),\n rest: parseFnResult.rest,\n };\n}\n\nexport function parseNumericPattern(pattern, dateString) {\n const matchResult = dateString.match(pattern);\n\n if (!matchResult) {\n return null;\n }\n\n return {\n value: parseInt(matchResult[0], 10),\n rest: dateString.slice(matchResult[0].length),\n };\n}\n\nexport function parseTimezonePattern(pattern, dateString) {\n const matchResult = dateString.match(pattern);\n\n if (!matchResult) {\n return null;\n }\n\n // Input is 'Z'\n if (matchResult[0] === \"Z\") {\n return {\n value: 0,\n rest: dateString.slice(1),\n };\n }\n\n const sign = matchResult[1] === \"+\" ? 1 : -1;\n const hours = matchResult[2] ? parseInt(matchResult[2], 10) : 0;\n const minutes = matchResult[3] ? parseInt(matchResult[3], 10) : 0;\n const seconds = matchResult[5] ? parseInt(matchResult[5], 10) : 0;\n\n return {\n value:\n sign *\n (hours * millisecondsInHour +\n minutes * millisecondsInMinute +\n seconds * millisecondsInSecond),\n rest: dateString.slice(matchResult[0].length),\n };\n}\n\nexport function parseAnyDigitsSigned(dateString) {\n return parseNumericPattern(numericPatterns.anyDigitsSigned, dateString);\n}\n\nexport function parseNDigits(n, dateString) {\n switch (n) {\n case 1:\n return parseNumericPattern(numericPatterns.singleDigit, dateString);\n case 2:\n return parseNumericPattern(numericPatterns.twoDigits, dateString);\n case 3:\n return parseNumericPattern(numericPatterns.threeDigits, dateString);\n case 4:\n return parseNumericPattern(numericPatterns.fourDigits, dateString);\n default:\n return parseNumericPattern(new RegExp(\"^\\\\d{1,\" + n + \"}\"), dateString);\n }\n}\n\nexport function parseNDigitsSigned(n, dateString) {\n switch (n) {\n case 1:\n return parseNumericPattern(numericPatterns.singleDigitSigned, dateString);\n case 2:\n return parseNumericPattern(numericPatterns.twoDigitsSigned, dateString);\n case 3:\n return parseNumericPattern(numericPatterns.threeDigitsSigned, dateString);\n case 4:\n return parseNumericPattern(numericPatterns.fourDigitsSigned, dateString);\n default:\n return parseNumericPattern(new RegExp(\"^-?\\\\d{1,\" + n + \"}\"), dateString);\n }\n}\n\nexport function dayPeriodEnumToHours(dayPeriod) {\n switch (dayPeriod) {\n case \"morning\":\n return 4;\n case \"evening\":\n return 17;\n case \"pm\":\n case \"noon\":\n case \"afternoon\":\n return 12;\n case \"am\":\n case \"midnight\":\n case \"night\":\n default:\n return 0;\n }\n}\n\nexport function normalizeTwoDigitYear(twoDigitYear, currentYear) {\n const isCommonEra = currentYear > 0;\n // Absolute number of the current year:\n // 1 -> 1 AC\n // 0 -> 1 BC\n // -1 -> 2 BC\n const absCurrentYear = isCommonEra ? currentYear : 1 - currentYear;\n\n let result;\n if (absCurrentYear <= 50) {\n result = twoDigitYear || 100;\n } else {\n const rangeEnd = absCurrentYear + 50;\n const rangeEndCentury = Math.trunc(rangeEnd / 100) * 100;\n const isPreviousCentury = twoDigitYear >= rangeEnd % 100;\n result = twoDigitYear + rangeEndCentury - (isPreviousCentury ? 100 : 0);\n }\n\n return isCommonEra ? result : 1 - result;\n}\n\nexport function isLeapYearIndex(year) {\n return year % 400 === 0 || (year % 4 === 0 && year % 100 !== 0);\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { mapValue, normalizeTwoDigitYear, parseNDigits } from \"../utils.mjs\";\n\n// From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_Patterns\n// | Year | y | yy | yyy | yyyy | yyyyy |\n// |----------|-------|----|-------|-------|-------|\n// | AD 1 | 1 | 01 | 001 | 0001 | 00001 |\n// | AD 12 | 12 | 12 | 012 | 0012 | 00012 |\n// | AD 123 | 123 | 23 | 123 | 0123 | 00123 |\n// | AD 1234 | 1234 | 34 | 1234 | 1234 | 01234 |\n// | AD 12345 | 12345 | 45 | 12345 | 12345 | 12345 |\nexport class YearParser extends Parser {\n priority = 130;\n incompatibleTokens = [\"Y\", \"R\", \"u\", \"w\", \"I\", \"i\", \"e\", \"c\", \"t\", \"T\"];\n\n parse(dateString, token, match) {\n const valueCallback = (year) => ({\n year,\n isTwoDigitYear: token === \"yy\",\n });\n\n switch (token) {\n case \"y\":\n return mapValue(parseNDigits(4, dateString), valueCallback);\n case \"yo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"year\",\n }),\n valueCallback,\n );\n default:\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n }\n }\n\n validate(_date, value) {\n return value.isTwoDigitYear || value.year > 0;\n }\n\n set(date, flags, value) {\n const currentYear = date.getFullYear();\n\n if (value.isTwoDigitYear) {\n const normalizedTwoDigitYear = normalizeTwoDigitYear(\n value.year,\n currentYear,\n );\n date.setFullYear(normalizedTwoDigitYear, 0, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n const year =\n !(\"era\" in flags) || flags.era === 1 ? value.year : 1 - value.year;\n date.setFullYear(year, 0, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n}\n","import { getWeekYear } from \"../../../getWeekYear.mjs\";\nimport { startOfWeek } from \"../../../startOfWeek.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, normalizeTwoDigitYear, parseNDigits } from \"../utils.mjs\";\n\n// Local week-numbering year\nexport class LocalWeekYearParser extends Parser {\n priority = 130;\n\n parse(dateString, token, match) {\n const valueCallback = (year) => ({\n year,\n isTwoDigitYear: token === \"YY\",\n });\n\n switch (token) {\n case \"Y\":\n return mapValue(parseNDigits(4, dateString), valueCallback);\n case \"Yo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"year\",\n }),\n valueCallback,\n );\n default:\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n }\n }\n\n validate(_date, value) {\n return value.isTwoDigitYear || value.year > 0;\n }\n\n set(date, flags, value, options) {\n const currentYear = getWeekYear(date, options);\n\n if (value.isTwoDigitYear) {\n const normalizedTwoDigitYear = normalizeTwoDigitYear(\n value.year,\n currentYear,\n );\n date.setFullYear(\n normalizedTwoDigitYear,\n 0,\n options.firstWeekContainsDate,\n );\n date.setHours(0, 0, 0, 0);\n return startOfWeek(date, options);\n }\n\n const year =\n !(\"era\" in flags) || flags.era === 1 ? value.year : 1 - value.year;\n date.setFullYear(year, 0, options.firstWeekContainsDate);\n date.setHours(0, 0, 0, 0);\n return startOfWeek(date, options);\n }\n\n incompatibleTokens = [\n \"y\",\n \"R\",\n \"u\",\n \"Q\",\n \"q\",\n \"M\",\n \"L\",\n \"I\",\n \"d\",\n \"D\",\n \"i\",\n \"t\",\n \"T\",\n ];\n}\n","import { startOfISOWeek } from \"../../../startOfISOWeek.mjs\";\nimport { constructFrom } from \"../../../constructFrom.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigitsSigned } from \"../utils.mjs\";\n\n// ISO week-numbering year\nexport class ISOWeekYearParser extends Parser {\n priority = 130;\n\n parse(dateString, token) {\n if (token === \"R\") {\n return parseNDigitsSigned(4, dateString);\n }\n\n return parseNDigitsSigned(token.length, dateString);\n }\n\n set(date, _flags, value) {\n const firstWeekOfYear = constructFrom(date, 0);\n firstWeekOfYear.setFullYear(value, 0, 4);\n firstWeekOfYear.setHours(0, 0, 0, 0);\n return startOfISOWeek(firstWeekOfYear);\n }\n\n incompatibleTokens = [\n \"G\",\n \"y\",\n \"Y\",\n \"u\",\n \"Q\",\n \"q\",\n \"M\",\n \"L\",\n \"w\",\n \"d\",\n \"D\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { parseNDigitsSigned } from \"../utils.mjs\";\n\nexport class ExtendedYearParser extends Parser {\n priority = 130;\n\n parse(dateString, token) {\n if (token === \"u\") {\n return parseNDigitsSigned(4, dateString);\n }\n\n return parseNDigitsSigned(token.length, dateString);\n }\n\n set(date, _flags, value) {\n date.setFullYear(value, 0, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"G\", \"y\", \"Y\", \"R\", \"w\", \"I\", \"i\", \"e\", \"c\", \"t\", \"T\"];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { parseNDigits } from \"../utils.mjs\";\n\nexport class QuarterParser extends Parser {\n priority = 120;\n\n parse(dateString, token, match) {\n switch (token) {\n // 1, 2, 3, 4\n case \"Q\":\n case \"QQ\": // 01, 02, 03, 04\n return parseNDigits(token.length, dateString);\n // 1st, 2nd, 3rd, 4th\n case \"Qo\":\n return match.ordinalNumber(dateString, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"QQQ\":\n return (\n match.quarter(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.quarter(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"QQQQQ\":\n return match.quarter(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"QQQQ\":\n default:\n return (\n match.quarter(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.quarter(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.quarter(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 4;\n }\n\n set(date, _flags, value) {\n date.setMonth((value - 1) * 3, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"M\",\n \"L\",\n \"w\",\n \"I\",\n \"d\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { parseNDigits } from \"../utils.mjs\";\n\nexport class StandAloneQuarterParser extends Parser {\n priority = 120;\n\n parse(dateString, token, match) {\n switch (token) {\n // 1, 2, 3, 4\n case \"q\":\n case \"qq\": // 01, 02, 03, 04\n return parseNDigits(token.length, dateString);\n // 1st, 2nd, 3rd, 4th\n case \"qo\":\n return match.ordinalNumber(dateString, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"qqq\":\n return (\n match.quarter(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.quarter(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n })\n );\n\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"qqqqq\":\n return match.quarter(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"qqqq\":\n default:\n return (\n match.quarter(dateString, {\n width: \"wide\",\n context: \"standalone\",\n }) ||\n match.quarter(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.quarter(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 4;\n }\n\n set(date, _flags, value) {\n date.setMonth((value - 1) * 3, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"Q\",\n \"M\",\n \"L\",\n \"w\",\n \"I\",\n \"d\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class MonthParser extends Parser {\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"Q\",\n \"L\",\n \"w\",\n \"I\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n\n priority = 110;\n\n parse(dateString, token, match) {\n const valueCallback = (value) => value - 1;\n\n switch (token) {\n // 1, 2, ..., 12\n case \"M\":\n return mapValue(\n parseNumericPattern(numericPatterns.month, dateString),\n valueCallback,\n );\n // 01, 02, ..., 12\n case \"MM\":\n return mapValue(parseNDigits(2, dateString), valueCallback);\n // 1st, 2nd, ..., 12th\n case \"Mo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"month\",\n }),\n valueCallback,\n );\n // Jan, Feb, ..., Dec\n case \"MMM\":\n return (\n match.month(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.month(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // J, F, ..., D\n case \"MMMMM\":\n return match.month(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // January, February, ..., December\n case \"MMMM\":\n default:\n return (\n match.month(dateString, { width: \"wide\", context: \"formatting\" }) ||\n match.month(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.month(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 11;\n }\n\n set(date, _flags, value) {\n date.setMonth(value, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class StandAloneMonthParser extends Parser {\n priority = 110;\n\n parse(dateString, token, match) {\n const valueCallback = (value) => value - 1;\n\n switch (token) {\n // 1, 2, ..., 12\n case \"L\":\n return mapValue(\n parseNumericPattern(numericPatterns.month, dateString),\n valueCallback,\n );\n // 01, 02, ..., 12\n case \"LL\":\n return mapValue(parseNDigits(2, dateString), valueCallback);\n // 1st, 2nd, ..., 12th\n case \"Lo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"month\",\n }),\n valueCallback,\n );\n // Jan, Feb, ..., Dec\n case \"LLL\":\n return (\n match.month(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.month(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n\n // J, F, ..., D\n case \"LLLLL\":\n return match.month(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // January, February, ..., December\n case \"LLLL\":\n default:\n return (\n match.month(dateString, { width: \"wide\", context: \"standalone\" }) ||\n match.month(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.month(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 11;\n }\n\n set(date, _flags, value) {\n date.setMonth(value, 1);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"Q\",\n \"M\",\n \"w\",\n \"I\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { getWeek } from \"./getWeek.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * The {@link setWeek} function options.\n */\n\n/**\n * @name setWeek\n * @category Week Helpers\n * @summary Set the local week to the given date.\n *\n * @description\n * Set the local week to the given date, saving the weekday number.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param week - The week of the new date\n * @param options - An object with options\n *\n * @returns The new date with the local week set\n *\n * @example\n * // Set the 1st week to 2 January 2005 with default options:\n * const result = setWeek(new Date(2005, 0, 2), 1)\n * //=> Sun Dec 26 2004 00:00:00\n *\n * @example\n * // Set the 1st week to 2 January 2005,\n * // if Monday is the first day of the week,\n * // and the first week of the year always contains 4 January:\n * const result = setWeek(new Date(2005, 0, 2), 1, {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> Sun Jan 4 2004 00:00:00\n */\nexport function setWeek(date, week, options) {\n const _date = toDate(date);\n const diff = getWeek(_date, options) - week;\n _date.setDate(_date.getDate() - diff * 7);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setWeek;\n","import { setWeek } from \"../../../setWeek.mjs\";\nimport { startOfWeek } from \"../../../startOfWeek.mjs\";\nimport { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\n// Local week of year\nexport class LocalWeekParser extends Parser {\n priority = 100;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"w\":\n return parseNumericPattern(numericPatterns.week, dateString);\n case \"wo\":\n return match.ordinalNumber(dateString, { unit: \"week\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 53;\n }\n\n set(date, _flags, value, options) {\n return startOfWeek(setWeek(date, value, options), options);\n }\n\n incompatibleTokens = [\n \"y\",\n \"R\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"I\",\n \"d\",\n \"D\",\n \"i\",\n \"t\",\n \"T\",\n ];\n}\n","import { getISOWeek } from \"./getISOWeek.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name setISOWeek\n * @category ISO Week Helpers\n * @summary Set the ISO week to the given date.\n *\n * @description\n * Set the ISO week to the given date, saving the weekday number.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param week - The ISO week of the new date\n *\n * @returns The new date with the ISO week set\n *\n * @example\n * // Set the 53rd ISO week to 7 August 2004:\n * const result = setISOWeek(new Date(2004, 7, 7), 53)\n * //=> Sat Jan 01 2005 00:00:00\n */\nexport function setISOWeek(date, week) {\n const _date = toDate(date);\n const diff = getISOWeek(_date) - week;\n _date.setDate(_date.getDate() - diff * 7);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default setISOWeek;\n","import { setISOWeek } from \"../../../setISOWeek.mjs\";\nimport { startOfISOWeek } from \"../../../startOfISOWeek.mjs\";\nimport { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\n// ISO week of year\nexport class ISOWeekParser extends Parser {\n priority = 100;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"I\":\n return parseNumericPattern(numericPatterns.week, dateString);\n case \"Io\":\n return match.ordinalNumber(dateString, { unit: \"week\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 53;\n }\n\n set(date, _flags, value) {\n return startOfISOWeek(setISOWeek(date, value));\n }\n\n incompatibleTokens = [\n \"y\",\n \"Y\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"w\",\n \"d\",\n \"D\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport {\n isLeapYearIndex,\n parseNDigits,\n parseNumericPattern,\n} from \"../utils.mjs\";\n\nconst DAYS_IN_MONTH = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\nconst DAYS_IN_MONTH_LEAP_YEAR = [\n 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31,\n];\n\n// Day of the month\nexport class DateParser extends Parser {\n priority = 90;\n subPriority = 1;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"d\":\n return parseNumericPattern(numericPatterns.date, dateString);\n case \"do\":\n return match.ordinalNumber(dateString, { unit: \"date\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(date, value) {\n const year = date.getFullYear();\n const isLeapYear = isLeapYearIndex(year);\n const month = date.getMonth();\n if (isLeapYear) {\n return value >= 1 && value <= DAYS_IN_MONTH_LEAP_YEAR[month];\n } else {\n return value >= 1 && value <= DAYS_IN_MONTH[month];\n }\n }\n\n set(date, _flags, value) {\n date.setDate(value);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"Q\",\n \"w\",\n \"I\",\n \"D\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport {\n isLeapYearIndex,\n parseNDigits,\n parseNumericPattern,\n} from \"../utils.mjs\";\n\nexport class DayOfYearParser extends Parser {\n priority = 90;\n\n subpriority = 1;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"D\":\n case \"DD\":\n return parseNumericPattern(numericPatterns.dayOfYear, dateString);\n case \"Do\":\n return match.ordinalNumber(dateString, { unit: \"date\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(date, value) {\n const year = date.getFullYear();\n const isLeapYear = isLeapYearIndex(year);\n if (isLeapYear) {\n return value >= 1 && value <= 366;\n } else {\n return value >= 1 && value <= 365;\n }\n }\n\n set(date, _flags, value) {\n date.setMonth(0, value);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"Y\",\n \"R\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"w\",\n \"I\",\n \"d\",\n \"E\",\n \"i\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { toDate } from \"./toDate.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\n\n/**\n * @name addDays\n * @category Day Helpers\n * @summary Add the specified number of days to the given date.\n *\n * @description\n * Add the specified number of days to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of days to be added.\n *\n * @returns The new date with the days added\n *\n * @example\n * // Add 10 days to 1 September 2014:\n * const result = addDays(new Date(2014, 8, 1), 10)\n * //=> Thu Sep 11 2014 00:00:00\n */\nexport function addDays(date, amount) {\n const _date = toDate(date);\n if (isNaN(amount)) return constructFrom(date, NaN);\n if (!amount) {\n // If 0 days, no-op to avoid changing times in the hour before end of DST\n return _date;\n }\n _date.setDate(_date.getDate() + amount);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default addDays;\n","import { addDays } from \"./addDays.mjs\";\nimport { toDate } from \"./toDate.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\n\n/**\n * The {@link setDay} function options.\n */\n\n/**\n * @name setDay\n * @category Weekday Helpers\n * @summary Set the day of the week to the given date.\n *\n * @description\n * Set the day of the week to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param day - The day of the week of the new date\n * @param options - An object with options.\n *\n * @returns The new date with the day of the week set\n *\n * @example\n * // Set week day to Sunday, with the default weekStartsOn of Sunday:\n * const result = setDay(new Date(2014, 8, 1), 0)\n * //=> Sun Aug 31 2014 00:00:00\n *\n * @example\n * // Set week day to Sunday, with a weekStartsOn of Monday:\n * const result = setDay(new Date(2014, 8, 1), 0, { weekStartsOn: 1 })\n * //=> Sun Sep 07 2014 00:00:00\n */\nexport function setDay(date, day, options) {\n const defaultOptions = getDefaultOptions();\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const _date = toDate(date);\n const currentDay = _date.getDay();\n\n const remainder = day % 7;\n const dayIndex = (remainder + 7) % 7;\n\n const delta = 7 - weekStartsOn;\n const diff =\n day < 0 || day > 6\n ? day - ((currentDay + delta) % 7)\n : ((dayIndex + delta) % 7) - ((currentDay + delta) % 7);\n return addDays(_date, diff);\n}\n\n// Fallback for modularized imports:\nexport default setDay;\n","import { setDay } from \"../../../setDay.mjs\";\nimport { Parser } from \"../Parser.mjs\";\n\n// Day of week\nexport class DayParser extends Parser {\n priority = 90;\n\n parse(dateString, token, match) {\n switch (token) {\n // Tue\n case \"E\":\n case \"EE\":\n case \"EEE\":\n return (\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // T\n case \"EEEEE\":\n return match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"EEEEEE\":\n return (\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // Tuesday\n case \"EEEE\":\n default:\n return (\n match.day(dateString, { width: \"wide\", context: \"formatting\" }) ||\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 6;\n }\n\n set(date, _flags, value, options) {\n date = setDay(date, value, options);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"D\", \"i\", \"e\", \"c\", \"t\", \"T\"];\n}\n","import { setDay } from \"../../../setDay.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits } from \"../utils.mjs\";\n\n// Local day of week\nexport class LocalDayParser extends Parser {\n priority = 90;\n parse(dateString, token, match, options) {\n const valueCallback = (value) => {\n // We want here floor instead of trunc, so we get -7 for value 0 instead of 0\n const wholeWeekDays = Math.floor((value - 1) / 7) * 7;\n return ((value + options.weekStartsOn + 6) % 7) + wholeWeekDays;\n };\n\n switch (token) {\n // 3\n case \"e\":\n case \"ee\": // 03\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n // 3rd\n case \"eo\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"day\",\n }),\n valueCallback,\n );\n // Tue\n case \"eee\":\n return (\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // T\n case \"eeeee\":\n return match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"eeeeee\":\n return (\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n\n // Tuesday\n case \"eeee\":\n default:\n return (\n match.day(dateString, { width: \"wide\", context: \"formatting\" }) ||\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"formatting\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"formatting\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 6;\n }\n\n set(date, _flags, value, options) {\n date = setDay(date, value, options);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"y\",\n \"R\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"I\",\n \"d\",\n \"D\",\n \"E\",\n \"i\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { setDay } from \"../../../setDay.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits } from \"../utils.mjs\";\n\n// Stand-alone local day of week\nexport class StandAloneLocalDayParser extends Parser {\n priority = 90;\n\n parse(dateString, token, match, options) {\n const valueCallback = (value) => {\n // We want here floor instead of trunc, so we get -7 for value 0 instead of 0\n const wholeWeekDays = Math.floor((value - 1) / 7) * 7;\n return ((value + options.weekStartsOn + 6) % 7) + wholeWeekDays;\n };\n\n switch (token) {\n // 3\n case \"c\":\n case \"cc\": // 03\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n // 3rd\n case \"co\":\n return mapValue(\n match.ordinalNumber(dateString, {\n unit: \"day\",\n }),\n valueCallback,\n );\n // Tue\n case \"ccc\":\n return (\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"standalone\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n\n // T\n case \"ccccc\":\n return match.day(dateString, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // Tu\n case \"cccccc\":\n return (\n match.day(dateString, { width: \"short\", context: \"standalone\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n\n // Tuesday\n case \"cccc\":\n default:\n return (\n match.day(dateString, { width: \"wide\", context: \"standalone\" }) ||\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"standalone\",\n }) ||\n match.day(dateString, { width: \"short\", context: \"standalone\" }) ||\n match.day(dateString, { width: \"narrow\", context: \"standalone\" })\n );\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 6;\n }\n\n set(date, _flags, value, options) {\n date = setDay(date, value, options);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"y\",\n \"R\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"I\",\n \"d\",\n \"D\",\n \"E\",\n \"i\",\n \"e\",\n \"t\",\n \"T\",\n ];\n}\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getISODay\n * @category Weekday Helpers\n * @summary Get the day of the ISO week of the given date.\n *\n * @description\n * Get the day of the ISO week of the given date,\n * which is 7 for Sunday, 1 for Monday etc.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The given date\n *\n * @returns The day of ISO week\n *\n * @example\n * // Which day of the ISO week is 26 February 2012?\n * const result = getISODay(new Date(2012, 1, 26))\n * //=> 7\n */\nexport function getISODay(date) {\n const _date = toDate(date);\n let day = _date.getDay();\n\n if (day === 0) {\n day = 7;\n }\n\n return day;\n}\n\n// Fallback for modularized imports:\nexport default getISODay;\n","import { addDays } from \"./addDays.mjs\";\nimport { getISODay } from \"./getISODay.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name setISODay\n * @category Weekday Helpers\n * @summary Set the day of the ISO week to the given date.\n *\n * @description\n * Set the day of the ISO week to the given date.\n * ISO week starts with Monday.\n * 7 is the index of Sunday, 1 is the index of Monday etc.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param day - The day of the ISO week of the new date\n *\n * @returns The new date with the day of the ISO week set\n *\n * @example\n * // Set Sunday to 1 September 2014:\n * const result = setISODay(new Date(2014, 8, 1), 7)\n * //=> Sun Sep 07 2014 00:00:00\n */\nexport function setISODay(date, day) {\n const _date = toDate(date);\n const currentDay = getISODay(_date);\n const diff = day - currentDay;\n return addDays(_date, diff);\n}\n\n// Fallback for modularized imports:\nexport default setISODay;\n","import { setISODay } from \"../../../setISODay.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits } from \"../utils.mjs\";\n\n// ISO day of week\nexport class ISODayParser extends Parser {\n priority = 90;\n\n parse(dateString, token, match) {\n const valueCallback = (value) => {\n if (value === 0) {\n return 7;\n }\n return value;\n };\n\n switch (token) {\n // 2\n case \"i\":\n case \"ii\": // 02\n return parseNDigits(token.length, dateString);\n // 2nd\n case \"io\":\n return match.ordinalNumber(dateString, { unit: \"day\" });\n // Tue\n case \"iii\":\n return mapValue(\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"short\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n }),\n valueCallback,\n );\n // T\n case \"iiiii\":\n return mapValue(\n match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n }),\n valueCallback,\n );\n // Tu\n case \"iiiiii\":\n return mapValue(\n match.day(dateString, {\n width: \"short\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n }),\n valueCallback,\n );\n // Tuesday\n case \"iiii\":\n default:\n return mapValue(\n match.day(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"short\",\n context: \"formatting\",\n }) ||\n match.day(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n }),\n valueCallback,\n );\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 7;\n }\n\n set(date, _flags, value) {\n date = setISODay(date, value);\n date.setHours(0, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\n \"y\",\n \"Y\",\n \"u\",\n \"q\",\n \"Q\",\n \"M\",\n \"L\",\n \"w\",\n \"d\",\n \"D\",\n \"E\",\n \"e\",\n \"c\",\n \"t\",\n \"T\",\n ];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { dayPeriodEnumToHours } from \"../utils.mjs\";\n\nexport class AMPMParser extends Parser {\n priority = 80;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"a\":\n case \"aa\":\n case \"aaa\":\n return (\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n\n case \"aaaaa\":\n return match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"aaaa\":\n default:\n return (\n match.dayPeriod(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n }\n }\n\n set(date, _flags, value) {\n date.setHours(dayPeriodEnumToHours(value), 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"b\", \"B\", \"H\", \"k\", \"t\", \"T\"];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { dayPeriodEnumToHours } from \"../utils.mjs\";\n\nexport class AMPMMidnightParser extends Parser {\n priority = 80;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"b\":\n case \"bb\":\n case \"bbb\":\n return (\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n\n case \"bbbbb\":\n return match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"bbbb\":\n default:\n return (\n match.dayPeriod(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n }\n }\n\n set(date, _flags, value) {\n date.setHours(dayPeriodEnumToHours(value), 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"a\", \"B\", \"H\", \"k\", \"t\", \"T\"];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { dayPeriodEnumToHours } from \"../utils.mjs\";\n\n// in the morning, in the afternoon, in the evening, at night\nexport class DayPeriodParser extends Parser {\n priority = 80;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"B\":\n case \"BB\":\n case \"BBB\":\n return (\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n\n case \"BBBBB\":\n return match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"BBBB\":\n default:\n return (\n match.dayPeriod(dateString, {\n width: \"wide\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"abbreviated\",\n context: \"formatting\",\n }) ||\n match.dayPeriod(dateString, {\n width: \"narrow\",\n context: \"formatting\",\n })\n );\n }\n }\n\n set(date, _flags, value) {\n date.setHours(dayPeriodEnumToHours(value), 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"a\", \"b\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class Hour1to12Parser extends Parser {\n priority = 70;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"h\":\n return parseNumericPattern(numericPatterns.hour12h, dateString);\n case \"ho\":\n return match.ordinalNumber(dateString, { unit: \"hour\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 12;\n }\n\n set(date, _flags, value) {\n const isPM = date.getHours() >= 12;\n if (isPM && value < 12) {\n date.setHours(value + 12, 0, 0, 0);\n } else if (!isPM && value === 12) {\n date.setHours(0, 0, 0, 0);\n } else {\n date.setHours(value, 0, 0, 0);\n }\n return date;\n }\n\n incompatibleTokens = [\"H\", \"K\", \"k\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class Hour0to23Parser extends Parser {\n priority = 70;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"H\":\n return parseNumericPattern(numericPatterns.hour23h, dateString);\n case \"Ho\":\n return match.ordinalNumber(dateString, { unit: \"hour\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 23;\n }\n\n set(date, _flags, value) {\n date.setHours(value, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"a\", \"b\", \"h\", \"K\", \"k\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class Hour0To11Parser extends Parser {\n priority = 70;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"K\":\n return parseNumericPattern(numericPatterns.hour11h, dateString);\n case \"Ko\":\n return match.ordinalNumber(dateString, { unit: \"hour\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 11;\n }\n\n set(date, _flags, value) {\n const isPM = date.getHours() >= 12;\n if (isPM && value < 12) {\n date.setHours(value + 12, 0, 0, 0);\n } else {\n date.setHours(value, 0, 0, 0);\n }\n return date;\n }\n\n incompatibleTokens = [\"h\", \"H\", \"k\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class Hour1To24Parser extends Parser {\n priority = 70;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"k\":\n return parseNumericPattern(numericPatterns.hour24h, dateString);\n case \"ko\":\n return match.ordinalNumber(dateString, { unit: \"hour\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 1 && value <= 24;\n }\n\n set(date, _flags, value) {\n const hours = value <= 24 ? value % 24 : value;\n date.setHours(hours, 0, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"a\", \"b\", \"h\", \"H\", \"K\", \"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class MinuteParser extends Parser {\n priority = 60;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"m\":\n return parseNumericPattern(numericPatterns.minute, dateString);\n case \"mo\":\n return match.ordinalNumber(dateString, { unit: \"minute\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 59;\n }\n\n set(date, _flags, value) {\n date.setMinutes(value, 0, 0);\n return date;\n }\n\n incompatibleTokens = [\"t\", \"T\"];\n}\n","import { numericPatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseNDigits, parseNumericPattern } from \"../utils.mjs\";\n\nexport class SecondParser extends Parser {\n priority = 50;\n\n parse(dateString, token, match) {\n switch (token) {\n case \"s\":\n return parseNumericPattern(numericPatterns.second, dateString);\n case \"so\":\n return match.ordinalNumber(dateString, { unit: \"second\" });\n default:\n return parseNDigits(token.length, dateString);\n }\n }\n\n validate(_date, value) {\n return value >= 0 && value <= 59;\n }\n\n set(date, _flags, value) {\n date.setSeconds(value, 0);\n return date;\n }\n\n incompatibleTokens = [\"t\", \"T\"];\n}\n","import { Parser } from \"../Parser.mjs\";\nimport { mapValue, parseNDigits } from \"../utils.mjs\";\n\nexport class FractionOfSecondParser extends Parser {\n priority = 30;\n\n parse(dateString, token) {\n const valueCallback = (value) =>\n Math.trunc(value * Math.pow(10, -token.length + 3));\n return mapValue(parseNDigits(token.length, dateString), valueCallback);\n }\n\n set(date, _flags, value) {\n date.setMilliseconds(value);\n return date;\n }\n\n incompatibleTokens = [\"t\", \"T\"];\n}\n","import { constructFrom } from \"../../../constructFrom.mjs\";\nimport { getTimezoneOffsetInMilliseconds } from \"../../../_lib/getTimezoneOffsetInMilliseconds.mjs\";\nimport { timezonePatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseTimezonePattern } from \"../utils.mjs\";\n\n// Timezone (ISO-8601. +00:00 is `'Z'`)\nexport class ISOTimezoneWithZParser extends Parser {\n priority = 10;\n\n parse(dateString, token) {\n switch (token) {\n case \"X\":\n return parseTimezonePattern(\n timezonePatterns.basicOptionalMinutes,\n dateString,\n );\n case \"XX\":\n return parseTimezonePattern(timezonePatterns.basic, dateString);\n case \"XXXX\":\n return parseTimezonePattern(\n timezonePatterns.basicOptionalSeconds,\n dateString,\n );\n case \"XXXXX\":\n return parseTimezonePattern(\n timezonePatterns.extendedOptionalSeconds,\n dateString,\n );\n case \"XXX\":\n default:\n return parseTimezonePattern(timezonePatterns.extended, dateString);\n }\n }\n\n set(date, flags, value) {\n if (flags.timestampIsSet) return date;\n return constructFrom(\n date,\n date.getTime() - getTimezoneOffsetInMilliseconds(date) - value,\n );\n }\n\n incompatibleTokens = [\"t\", \"T\", \"x\"];\n}\n","import { constructFrom } from \"../../../constructFrom.mjs\";\nimport { getTimezoneOffsetInMilliseconds } from \"../../../_lib/getTimezoneOffsetInMilliseconds.mjs\";\nimport { timezonePatterns } from \"../constants.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseTimezonePattern } from \"../utils.mjs\";\n\n// Timezone (ISO-8601)\nexport class ISOTimezoneParser extends Parser {\n priority = 10;\n\n parse(dateString, token) {\n switch (token) {\n case \"x\":\n return parseTimezonePattern(\n timezonePatterns.basicOptionalMinutes,\n dateString,\n );\n case \"xx\":\n return parseTimezonePattern(timezonePatterns.basic, dateString);\n case \"xxxx\":\n return parseTimezonePattern(\n timezonePatterns.basicOptionalSeconds,\n dateString,\n );\n case \"xxxxx\":\n return parseTimezonePattern(\n timezonePatterns.extendedOptionalSeconds,\n dateString,\n );\n case \"xxx\":\n default:\n return parseTimezonePattern(timezonePatterns.extended, dateString);\n }\n }\n\n set(date, flags, value) {\n if (flags.timestampIsSet) return date;\n return constructFrom(\n date,\n date.getTime() - getTimezoneOffsetInMilliseconds(date) - value,\n );\n }\n\n incompatibleTokens = [\"t\", \"T\", \"X\"];\n}\n","import { constructFrom } from \"../../../constructFrom.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseAnyDigitsSigned } from \"../utils.mjs\";\n\nexport class TimestampSecondsParser extends Parser {\n priority = 40;\n\n parse(dateString) {\n return parseAnyDigitsSigned(dateString);\n }\n\n set(date, _flags, value) {\n return [constructFrom(date, value * 1000), { timestampIsSet: true }];\n }\n\n incompatibleTokens = \"*\";\n}\n","import { constructFrom } from \"../../../constructFrom.mjs\";\nimport { Parser } from \"../Parser.mjs\";\nimport { parseAnyDigitsSigned } from \"../utils.mjs\";\n\nexport class TimestampMillisecondsParser extends Parser {\n priority = 20;\n\n parse(dateString) {\n return parseAnyDigitsSigned(dateString);\n }\n\n set(date, _flags, value) {\n return [constructFrom(date, value), { timestampIsSet: true }];\n }\n\n incompatibleTokens = \"*\";\n}\n","import { EraParser } from \"./parsers/EraParser.mjs\";\nimport { YearParser } from \"./parsers/YearParser.mjs\";\nimport { LocalWeekYearParser } from \"./parsers/LocalWeekYearParser.mjs\";\nimport { ISOWeekYearParser } from \"./parsers/ISOWeekYearParser.mjs\";\nimport { ExtendedYearParser } from \"./parsers/ExtendedYearParser.mjs\";\nimport { QuarterParser } from \"./parsers/QuarterParser.mjs\";\nimport { StandAloneQuarterParser } from \"./parsers/StandAloneQuarterParser.mjs\";\nimport { MonthParser } from \"./parsers/MonthParser.mjs\";\nimport { StandAloneMonthParser } from \"./parsers/StandAloneMonthParser.mjs\";\nimport { LocalWeekParser } from \"./parsers/LocalWeekParser.mjs\";\nimport { ISOWeekParser } from \"./parsers/ISOWeekParser.mjs\";\nimport { DateParser } from \"./parsers/DateParser.mjs\";\nimport { DayOfYearParser } from \"./parsers/DayOfYearParser.mjs\";\nimport { DayParser } from \"./parsers/DayParser.mjs\";\nimport { LocalDayParser } from \"./parsers/LocalDayParser.mjs\";\nimport { StandAloneLocalDayParser } from \"./parsers/StandAloneLocalDayParser.mjs\";\nimport { ISODayParser } from \"./parsers/ISODayParser.mjs\";\nimport { AMPMParser } from \"./parsers/AMPMParser.mjs\";\nimport { AMPMMidnightParser } from \"./parsers/AMPMMidnightParser.mjs\";\nimport { DayPeriodParser } from \"./parsers/DayPeriodParser.mjs\";\nimport { Hour1to12Parser } from \"./parsers/Hour1to12Parser.mjs\";\nimport { Hour0to23Parser } from \"./parsers/Hour0to23Parser.mjs\";\nimport { Hour0To11Parser } from \"./parsers/Hour0To11Parser.mjs\";\nimport { Hour1To24Parser } from \"./parsers/Hour1To24Parser.mjs\";\nimport { MinuteParser } from \"./parsers/MinuteParser.mjs\";\nimport { SecondParser } from \"./parsers/SecondParser.mjs\";\nimport { FractionOfSecondParser } from \"./parsers/FractionOfSecondParser.mjs\";\nimport { ISOTimezoneWithZParser } from \"./parsers/ISOTimezoneWithZParser.mjs\";\nimport { ISOTimezoneParser } from \"./parsers/ISOTimezoneParser.mjs\";\nimport { TimestampSecondsParser } from \"./parsers/TimestampSecondsParser.mjs\";\nimport { TimestampMillisecondsParser } from \"./parsers/TimestampMillisecondsParser.mjs\";\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | Milliseconds in day |\n * | b | AM, PM, noon, midnight | B | Flexible day period |\n * | c | Stand-alone local day of week | C* | Localized hour w/ day period |\n * | d | Day of month | D | Day of year |\n * | e | Local day of week | E | Day of week |\n * | f | | F* | Day of week in month |\n * | g* | Modified Julian day | G | Era |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | i! | ISO day of week | I! | ISO week of year |\n * | j* | Localized hour w/ day period | J* | Localized hour w/o day period |\n * | k | Hour [1-24] | K | Hour [0-11] |\n * | l* | (deprecated) | L | Stand-alone month |\n * | m | Minute | M | Month |\n * | n | | N | |\n * | o! | Ordinal number modifier | O* | Timezone (GMT) |\n * | p | | P | |\n * | q | Stand-alone quarter | Q | Quarter |\n * | r* | Related Gregorian year | R! | ISO week-numbering year |\n * | s | Second | S | Fraction of second |\n * | t! | Seconds timestamp | T! | Milliseconds timestamp |\n * | u | Extended year | U* | Cyclic year |\n * | v* | Timezone (generic non-locat.) | V* | Timezone (location) |\n * | w | Local week of year | W* | Week of month |\n * | x | Timezone (ISO-8601 w/o Z) | X | Timezone (ISO-8601) |\n * | y | Year (abs) | Y | Local week-numbering year |\n * | z* | Timezone (specific non-locat.) | Z* | Timezone (aliases) |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n *\n * Letters marked by ! are non-standard, but implemented by date-fns:\n * - `o` modifies the previous token to turn it into an ordinal (see `parse` docs)\n * - `i` is ISO day of week. For `i` and `ii` is returns numeric ISO week days,\n * i.e. 7 for Sunday, 1 for Monday, etc.\n * - `I` is ISO week of year, as opposed to `w` which is local week of year.\n * - `R` is ISO week-numbering year, as opposed to `Y` which is local week-numbering year.\n * `R` is supposed to be used in conjunction with `I` and `i`\n * for universal ISO week-numbering date, whereas\n * `Y` is supposed to be used in conjunction with `w` and `e`\n * for week-numbering date specific to the locale.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- It's ok, we want any here\nexport const parsers = {\n G: new EraParser(),\n y: new YearParser(),\n Y: new LocalWeekYearParser(),\n R: new ISOWeekYearParser(),\n u: new ExtendedYearParser(),\n Q: new QuarterParser(),\n q: new StandAloneQuarterParser(),\n M: new MonthParser(),\n L: new StandAloneMonthParser(),\n w: new LocalWeekParser(),\n I: new ISOWeekParser(),\n d: new DateParser(),\n D: new DayOfYearParser(),\n E: new DayParser(),\n e: new LocalDayParser(),\n c: new StandAloneLocalDayParser(),\n i: new ISODayParser(),\n a: new AMPMParser(),\n b: new AMPMMidnightParser(),\n B: new DayPeriodParser(),\n h: new Hour1to12Parser(),\n H: new Hour0to23Parser(),\n K: new Hour0To11Parser(),\n k: new Hour1To24Parser(),\n m: new MinuteParser(),\n s: new SecondParser(),\n S: new FractionOfSecondParser(),\n X: new ISOTimezoneWithZParser(),\n x: new ISOTimezoneParser(),\n t: new TimestampSecondsParser(),\n T: new TimestampMillisecondsParser(),\n};\n","import { constructFrom } from \"./constructFrom.mjs\";\nimport { getDefaultOptions } from \"./getDefaultOptions.mjs\";\nimport { defaultLocale } from \"./_lib/defaultLocale.mjs\";\nimport { toDate } from \"./toDate.mjs\";\nimport { longFormatters } from \"./_lib/format/longFormatters.mjs\";\nimport {\n isProtectedDayOfYearToken,\n isProtectedWeekYearToken,\n warnOrThrowProtectedError,\n} from \"./_lib/protectedTokens.mjs\";\nimport { parsers } from \"./parse/_lib/parsers.mjs\";\nimport { DateToSystemTimezoneSetter } from \"./parse/_lib/Setter.mjs\";\n\n// Rexports of internal for libraries to use.\n// See: https://github.com/date-fns/date-fns/issues/3638#issuecomment-1877082874\nexport { longFormatters, parsers };\n\n/**\n * The {@link parse} function options.\n */\n\n// This RegExp consists of three parts separated by `|`:\n// - [yYQqMLwIdDecihHKkms]o matches any available ordinal number token\n// (one of the certain letters followed by `o`)\n// - (\\w)\\1* matches any sequences of the same letter\n// - '' matches two quote characters in a row\n// - '(''|[^'])+('|$) matches anything surrounded by two quote characters ('),\n// except a single quote symbol, which ends the sequence.\n// Two quote characters do not end the sequence.\n// If there is no matching single quote\n// then the sequence will continue until the end of the string.\n// - . matches any single character unmatched by previous parts of the RegExps\nconst formattingTokensRegExp =\n /[yYQqMLwIdDecihHKkms]o|(\\w)\\1*|''|'(''|[^'])+('|$)|./g;\n\n// This RegExp catches symbols escaped by quotes, and also\n// sequences of symbols P, p, and the combinations like `PPPPPPPppppp`\nconst longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;\n\nconst escapedStringRegExp = /^'([^]*?)'?$/;\nconst doubleQuoteRegExp = /''/g;\n\nconst notWhitespaceRegExp = /\\S/;\nconst unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n\n/**\n * @name parse\n * @category Common Helpers\n * @summary Parse the date.\n *\n * @description\n * Return the date parsed from string using the given format string.\n *\n * > ⚠️ Please note that the `format` tokens differ from Moment.js and other libraries.\n * > See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * The characters in the format string wrapped between two single quotes characters (') are escaped.\n * Two single quotes in a row, whether inside or outside a quoted sequence, represent a 'real' single quote.\n *\n * Format of the format string is based on Unicode Technical Standard #35:\n * https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table\n * with a few additions (see note 5 below the table).\n *\n * Not all tokens are compatible. Combinations that don't make sense or could lead to bugs are prohibited\n * and will throw `RangeError`. For example usage of 24-hour format token with AM/PM token will throw an exception:\n *\n * ```javascript\n * parse('23 AM', 'HH a', new Date())\n * //=> RangeError: The format string mustn't contain `HH` and `a` at the same time\n * ```\n *\n * See the compatibility table: https://docs.google.com/spreadsheets/d/e/2PACX-1vQOPU3xUhplll6dyoMmVUXHKl_8CRDs6_ueLmex3SoqwhuolkuN3O05l4rqx5h1dKX8eb46Ul-CCSrq/pubhtml?gid=0&single=true\n *\n * Accepted format string patterns:\n * | Unit |Prior| Pattern | Result examples | Notes |\n * |---------------------------------|-----|---------|-----------------------------------|-------|\n * | Era | 140 | G..GGG | AD, BC | |\n * | | | GGGG | Anno Domini, Before Christ | 2 |\n * | | | GGGGG | A, B | |\n * | Calendar year | 130 | y | 44, 1, 1900, 2017, 9999 | 4 |\n * | | | yo | 44th, 1st, 1900th, 9999999th | 4,5 |\n * | | | yy | 44, 01, 00, 17 | 4 |\n * | | | yyy | 044, 001, 123, 999 | 4 |\n * | | | yyyy | 0044, 0001, 1900, 2017 | 4 |\n * | | | yyyyy | ... | 2,4 |\n * | Local week-numbering year | 130 | Y | 44, 1, 1900, 2017, 9000 | 4 |\n * | | | Yo | 44th, 1st, 1900th, 9999999th | 4,5 |\n * | | | YY | 44, 01, 00, 17 | 4,6 |\n * | | | YYY | 044, 001, 123, 999 | 4 |\n * | | | YYYY | 0044, 0001, 1900, 2017 | 4,6 |\n * | | | YYYYY | ... | 2,4 |\n * | ISO week-numbering year | 130 | R | -43, 1, 1900, 2017, 9999, -9999 | 4,5 |\n * | | | RR | -43, 01, 00, 17 | 4,5 |\n * | | | RRR | -043, 001, 123, 999, -999 | 4,5 |\n * | | | RRRR | -0043, 0001, 2017, 9999, -9999 | 4,5 |\n * | | | RRRRR | ... | 2,4,5 |\n * | Extended year | 130 | u | -43, 1, 1900, 2017, 9999, -999 | 4 |\n * | | | uu | -43, 01, 99, -99 | 4 |\n * | | | uuu | -043, 001, 123, 999, -999 | 4 |\n * | | | uuuu | -0043, 0001, 2017, 9999, -9999 | 4 |\n * | | | uuuuu | ... | 2,4 |\n * | Quarter (formatting) | 120 | Q | 1, 2, 3, 4 | |\n * | | | Qo | 1st, 2nd, 3rd, 4th | 5 |\n * | | | QQ | 01, 02, 03, 04 | |\n * | | | QQQ | Q1, Q2, Q3, Q4 | |\n * | | | QQQQ | 1st quarter, 2nd quarter, ... | 2 |\n * | | | QQQQQ | 1, 2, 3, 4 | 4 |\n * | Quarter (stand-alone) | 120 | q | 1, 2, 3, 4 | |\n * | | | qo | 1st, 2nd, 3rd, 4th | 5 |\n * | | | qq | 01, 02, 03, 04 | |\n * | | | qqq | Q1, Q2, Q3, Q4 | |\n * | | | qqqq | 1st quarter, 2nd quarter, ... | 2 |\n * | | | qqqqq | 1, 2, 3, 4 | 3 |\n * | Month (formatting) | 110 | M | 1, 2, ..., 12 | |\n * | | | Mo | 1st, 2nd, ..., 12th | 5 |\n * | | | MM | 01, 02, ..., 12 | |\n * | | | MMM | Jan, Feb, ..., Dec | |\n * | | | MMMM | January, February, ..., December | 2 |\n * | | | MMMMM | J, F, ..., D | |\n * | Month (stand-alone) | 110 | L | 1, 2, ..., 12 | |\n * | | | Lo | 1st, 2nd, ..., 12th | 5 |\n * | | | LL | 01, 02, ..., 12 | |\n * | | | LLL | Jan, Feb, ..., Dec | |\n * | | | LLLL | January, February, ..., December | 2 |\n * | | | LLLLL | J, F, ..., D | |\n * | Local week of year | 100 | w | 1, 2, ..., 53 | |\n * | | | wo | 1st, 2nd, ..., 53th | 5 |\n * | | | ww | 01, 02, ..., 53 | |\n * | ISO week of year | 100 | I | 1, 2, ..., 53 | 5 |\n * | | | Io | 1st, 2nd, ..., 53th | 5 |\n * | | | II | 01, 02, ..., 53 | 5 |\n * | Day of month | 90 | d | 1, 2, ..., 31 | |\n * | | | do | 1st, 2nd, ..., 31st | 5 |\n * | | | dd | 01, 02, ..., 31 | |\n * | Day of year | 90 | D | 1, 2, ..., 365, 366 | 7 |\n * | | | Do | 1st, 2nd, ..., 365th, 366th | 5 |\n * | | | DD | 01, 02, ..., 365, 366 | 7 |\n * | | | DDD | 001, 002, ..., 365, 366 | |\n * | | | DDDD | ... | 2 |\n * | Day of week (formatting) | 90 | E..EEE | Mon, Tue, Wed, ..., Sun | |\n * | | | EEEE | Monday, Tuesday, ..., Sunday | 2 |\n * | | | EEEEE | M, T, W, T, F, S, S | |\n * | | | EEEEEE | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | ISO day of week (formatting) | 90 | i | 1, 2, 3, ..., 7 | 5 |\n * | | | io | 1st, 2nd, ..., 7th | 5 |\n * | | | ii | 01, 02, ..., 07 | 5 |\n * | | | iii | Mon, Tue, Wed, ..., Sun | 5 |\n * | | | iiii | Monday, Tuesday, ..., Sunday | 2,5 |\n * | | | iiiii | M, T, W, T, F, S, S | 5 |\n * | | | iiiiii | Mo, Tu, We, Th, Fr, Sa, Su | 5 |\n * | Local day of week (formatting) | 90 | e | 2, 3, 4, ..., 1 | |\n * | | | eo | 2nd, 3rd, ..., 1st | 5 |\n * | | | ee | 02, 03, ..., 01 | |\n * | | | eee | Mon, Tue, Wed, ..., Sun | |\n * | | | eeee | Monday, Tuesday, ..., Sunday | 2 |\n * | | | eeeee | M, T, W, T, F, S, S | |\n * | | | eeeeee | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | Local day of week (stand-alone) | 90 | c | 2, 3, 4, ..., 1 | |\n * | | | co | 2nd, 3rd, ..., 1st | 5 |\n * | | | cc | 02, 03, ..., 01 | |\n * | | | ccc | Mon, Tue, Wed, ..., Sun | |\n * | | | cccc | Monday, Tuesday, ..., Sunday | 2 |\n * | | | ccccc | M, T, W, T, F, S, S | |\n * | | | cccccc | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | AM, PM | 80 | a..aaa | AM, PM | |\n * | | | aaaa | a.m., p.m. | 2 |\n * | | | aaaaa | a, p | |\n * | AM, PM, noon, midnight | 80 | b..bbb | AM, PM, noon, midnight | |\n * | | | bbbb | a.m., p.m., noon, midnight | 2 |\n * | | | bbbbb | a, p, n, mi | |\n * | Flexible day period | 80 | B..BBB | at night, in the morning, ... | |\n * | | | BBBB | at night, in the morning, ... | 2 |\n * | | | BBBBB | at night, in the morning, ... | |\n * | Hour [1-12] | 70 | h | 1, 2, ..., 11, 12 | |\n * | | | ho | 1st, 2nd, ..., 11th, 12th | 5 |\n * | | | hh | 01, 02, ..., 11, 12 | |\n * | Hour [0-23] | 70 | H | 0, 1, 2, ..., 23 | |\n * | | | Ho | 0th, 1st, 2nd, ..., 23rd | 5 |\n * | | | HH | 00, 01, 02, ..., 23 | |\n * | Hour [0-11] | 70 | K | 1, 2, ..., 11, 0 | |\n * | | | Ko | 1st, 2nd, ..., 11th, 0th | 5 |\n * | | | KK | 01, 02, ..., 11, 00 | |\n * | Hour [1-24] | 70 | k | 24, 1, 2, ..., 23 | |\n * | | | ko | 24th, 1st, 2nd, ..., 23rd | 5 |\n * | | | kk | 24, 01, 02, ..., 23 | |\n * | Minute | 60 | m | 0, 1, ..., 59 | |\n * | | | mo | 0th, 1st, ..., 59th | 5 |\n * | | | mm | 00, 01, ..., 59 | |\n * | Second | 50 | s | 0, 1, ..., 59 | |\n * | | | so | 0th, 1st, ..., 59th | 5 |\n * | | | ss | 00, 01, ..., 59 | |\n * | Seconds timestamp | 40 | t | 512969520 | |\n * | | | tt | ... | 2 |\n * | Fraction of second | 30 | S | 0, 1, ..., 9 | |\n * | | | SS | 00, 01, ..., 99 | |\n * | | | SSS | 000, 001, ..., 999 | |\n * | | | SSSS | ... | 2 |\n * | Milliseconds timestamp | 20 | T | 512969520900 | |\n * | | | TT | ... | 2 |\n * | Timezone (ISO-8601 w/ Z) | 10 | X | -08, +0530, Z | |\n * | | | XX | -0800, +0530, Z | |\n * | | | XXX | -08:00, +05:30, Z | |\n * | | | XXXX | -0800, +0530, Z, +123456 | 2 |\n * | | | XXXXX | -08:00, +05:30, Z, +12:34:56 | |\n * | Timezone (ISO-8601 w/o Z) | 10 | x | -08, +0530, +00 | |\n * | | | xx | -0800, +0530, +0000 | |\n * | | | xxx | -08:00, +05:30, +00:00 | 2 |\n * | | | xxxx | -0800, +0530, +0000, +123456 | |\n * | | | xxxxx | -08:00, +05:30, +00:00, +12:34:56 | |\n * | Long localized date | NA | P | 05/29/1453 | 5,8 |\n * | | | PP | May 29, 1453 | |\n * | | | PPP | May 29th, 1453 | |\n * | | | PPPP | Sunday, May 29th, 1453 | 2,5,8 |\n * | Long localized time | NA | p | 12:00 AM | 5,8 |\n * | | | pp | 12:00:00 AM | |\n * | Combination of date and time | NA | Pp | 05/29/1453, 12:00 AM | |\n * | | | PPpp | May 29, 1453, 12:00:00 AM | |\n * | | | PPPpp | May 29th, 1453 at ... | |\n * | | | PPPPpp | Sunday, May 29th, 1453 at ... | 2,5,8 |\n * Notes:\n * 1. \"Formatting\" units (e.g. formatting quarter) in the default en-US locale\n * are the same as \"stand-alone\" units, but are different in some languages.\n * \"Formatting\" units are declined according to the rules of the language\n * in the context of a date. \"Stand-alone\" units are always nominative singular.\n * In `format` function, they will produce different result:\n *\n * `format(new Date(2017, 10, 6), 'do LLLL', {locale: cs}) //=> '6. listopad'`\n *\n * `format(new Date(2017, 10, 6), 'do MMMM', {locale: cs}) //=> '6. listopadu'`\n *\n * `parse` will try to match both formatting and stand-alone units interchangably.\n *\n * 2. Any sequence of the identical letters is a pattern, unless it is escaped by\n * the single quote characters (see below).\n * If the sequence is longer than listed in table:\n * - for numerical units (`yyyyyyyy`) `parse` will try to match a number\n * as wide as the sequence\n * - for text units (`MMMMMMMM`) `parse` will try to match the widest variation of the unit.\n * These variations are marked with \"2\" in the last column of the table.\n *\n * 3. `QQQQQ` and `qqqqq` could be not strictly numerical in some locales.\n * These tokens represent the shortest form of the quarter.\n *\n * 4. The main difference between `y` and `u` patterns are B.C. years:\n *\n * | Year | `y` | `u` |\n * |------|-----|-----|\n * | AC 1 | 1 | 1 |\n * | BC 1 | 1 | 0 |\n * | BC 2 | 2 | -1 |\n *\n * Also `yy` will try to guess the century of two digit year by proximity with `referenceDate`:\n *\n * `parse('50', 'yy', new Date(2018, 0, 1)) //=> Sat Jan 01 2050 00:00:00`\n *\n * `parse('75', 'yy', new Date(2018, 0, 1)) //=> Wed Jan 01 1975 00:00:00`\n *\n * while `uu` will just assign the year as is:\n *\n * `parse('50', 'uu', new Date(2018, 0, 1)) //=> Sat Jan 01 0050 00:00:00`\n *\n * `parse('75', 'uu', new Date(2018, 0, 1)) //=> Tue Jan 01 0075 00:00:00`\n *\n * The same difference is true for local and ISO week-numbering years (`Y` and `R`),\n * except local week-numbering years are dependent on `options.weekStartsOn`\n * and `options.firstWeekContainsDate` (compare [setISOWeekYear](https://date-fns.org/docs/setISOWeekYear)\n * and [setWeekYear](https://date-fns.org/docs/setWeekYear)).\n *\n * 5. These patterns are not in the Unicode Technical Standard #35:\n * - `i`: ISO day of week\n * - `I`: ISO week of year\n * - `R`: ISO week-numbering year\n * - `o`: ordinal number modifier\n * - `P`: long localized date\n * - `p`: long localized time\n *\n * 6. `YY` and `YYYY` tokens represent week-numbering years but they are often confused with years.\n * You should enable `options.useAdditionalWeekYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * 7. `D` and `DD` tokens represent days of the year but they are ofthen confused with days of the month.\n * You should enable `options.useAdditionalDayOfYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * 8. `P+` tokens do not have a defined priority since they are merely aliases to other tokens based\n * on the given locale.\n *\n * using `en-US` locale: `P` => `MM/dd/yyyy`\n * using `en-US` locale: `p` => `hh:mm a`\n * using `pt-BR` locale: `P` => `dd/MM/yyyy`\n * using `pt-BR` locale: `p` => `HH:mm`\n *\n * Values will be assigned to the date in the descending order of its unit's priority.\n * Units of an equal priority overwrite each other in the order of appearance.\n *\n * If no values of higher priority are parsed (e.g. when parsing string 'January 1st' without a year),\n * the values will be taken from 3rd argument `referenceDate` which works as a context of parsing.\n *\n * `referenceDate` must be passed for correct work of the function.\n * If you're not sure which `referenceDate` to supply, create a new instance of Date:\n * `parse('02/11/2014', 'MM/dd/yyyy', new Date())`\n * In this case parsing will be done in the context of the current date.\n * If `referenceDate` is `Invalid Date` or a value not convertible to valid `Date`,\n * then `Invalid Date` will be returned.\n *\n * The result may vary by locale.\n *\n * If `formatString` matches with `dateString` but does not provides tokens, `referenceDate` will be returned.\n *\n * If parsing failed, `Invalid Date` will be returned.\n * Invalid Date is a Date, whose time value is NaN.\n * Time value of Date: http://es5.github.io/#x15.9.1.1\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param dateStr - The string to parse\n * @param formatStr - The string of tokens\n * @param referenceDate - defines values missing from the parsed dateString\n * @param options - An object with options.\n * see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * @returns The parsed date\n *\n * @throws `options.locale` must contain `match` property\n * @throws use `yyyy` instead of `YYYY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `yy` instead of `YY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `d` instead of `D` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `dd` instead of `DD` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws format string contains an unescaped latin alphabet character\n *\n * @example\n * // Parse 11 February 2014 from middle-endian format:\n * var result = parse('02/11/2014', 'MM/dd/yyyy', new Date())\n * //=> Tue Feb 11 2014 00:00:00\n *\n * @example\n * // Parse 28th of February in Esperanto locale in the context of 2010 year:\n * import eo from 'date-fns/locale/eo'\n * var result = parse('28-a de februaro', \"do 'de' MMMM\", new Date(2010, 0, 1), {\n * locale: eo\n * })\n * //=> Sun Feb 28 2010 00:00:00\n */\nexport function parse(dateStr, formatStr, referenceDate, options) {\n const defaultOptions = getDefaultOptions();\n const locale = options?.locale ?? defaultOptions.locale ?? defaultLocale;\n\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n if (formatStr === \"\") {\n if (dateStr === \"\") {\n return toDate(referenceDate);\n } else {\n return constructFrom(referenceDate, NaN);\n }\n }\n\n const subFnOptions = {\n firstWeekContainsDate,\n weekStartsOn,\n locale,\n };\n\n // If timezone isn't specified, it will be set to the system timezone\n const setters = [new DateToSystemTimezoneSetter()];\n\n const tokens = formatStr\n .match(longFormattingTokensRegExp)\n .map((substring) => {\n const firstCharacter = substring[0];\n if (firstCharacter in longFormatters) {\n const longFormatter = longFormatters[firstCharacter];\n return longFormatter(substring, locale.formatLong);\n }\n return substring;\n })\n .join(\"\")\n .match(formattingTokensRegExp);\n\n const usedTokens = [];\n\n for (let token of tokens) {\n if (\n !options?.useAdditionalWeekYearTokens &&\n isProtectedWeekYearToken(token)\n ) {\n warnOrThrowProtectedError(token, formatStr, dateStr);\n }\n if (\n !options?.useAdditionalDayOfYearTokens &&\n isProtectedDayOfYearToken(token)\n ) {\n warnOrThrowProtectedError(token, formatStr, dateStr);\n }\n\n const firstCharacter = token[0];\n const parser = parsers[firstCharacter];\n if (parser) {\n const { incompatibleTokens } = parser;\n if (Array.isArray(incompatibleTokens)) {\n const incompatibleToken = usedTokens.find(\n (usedToken) =>\n incompatibleTokens.includes(usedToken.token) ||\n usedToken.token === firstCharacter,\n );\n if (incompatibleToken) {\n throw new RangeError(\n `The format string mustn't contain \\`${incompatibleToken.fullToken}\\` and \\`${token}\\` at the same time`,\n );\n }\n } else if (parser.incompatibleTokens === \"*\" && usedTokens.length > 0) {\n throw new RangeError(\n `The format string mustn't contain \\`${token}\\` and any other token at the same time`,\n );\n }\n\n usedTokens.push({ token: firstCharacter, fullToken: token });\n\n const parseResult = parser.run(\n dateStr,\n token,\n locale.match,\n subFnOptions,\n );\n\n if (!parseResult) {\n return constructFrom(referenceDate, NaN);\n }\n\n setters.push(parseResult.setter);\n\n dateStr = parseResult.rest;\n } else {\n if (firstCharacter.match(unescapedLatinCharacterRegExp)) {\n throw new RangeError(\n \"Format string contains an unescaped latin alphabet character `\" +\n firstCharacter +\n \"`\",\n );\n }\n\n // Replace two single quote characters with one single quote character\n if (token === \"''\") {\n token = \"'\";\n } else if (firstCharacter === \"'\") {\n token = cleanEscapedString(token);\n }\n\n // Cut token from string, or, if string doesn't match the token, return Invalid Date\n if (dateStr.indexOf(token) === 0) {\n dateStr = dateStr.slice(token.length);\n } else {\n return constructFrom(referenceDate, NaN);\n }\n }\n }\n\n // Check if the remaining input contains something other than whitespace\n if (dateStr.length > 0 && notWhitespaceRegExp.test(dateStr)) {\n return constructFrom(referenceDate, NaN);\n }\n\n const uniquePrioritySetters = setters\n .map((setter) => setter.priority)\n .sort((a, b) => b - a)\n .filter((priority, index, array) => array.indexOf(priority) === index)\n .map((priority) =>\n setters\n .filter((setter) => setter.priority === priority)\n .sort((a, b) => b.subPriority - a.subPriority),\n )\n .map((setterArray) => setterArray[0]);\n\n let date = toDate(referenceDate);\n\n if (isNaN(date.getTime())) {\n return constructFrom(referenceDate, NaN);\n }\n\n const flags = {};\n for (const setter of uniquePrioritySetters) {\n if (!setter.validate(date, subFnOptions)) {\n return constructFrom(referenceDate, NaN);\n }\n\n const result = setter.set(date, flags, subFnOptions);\n // Result is tuple (date, flags)\n if (Array.isArray(result)) {\n date = result[0];\n Object.assign(flags, result[1]);\n // Result is date\n } else {\n date = result;\n }\n }\n\n return constructFrom(referenceDate, date);\n}\n\nfunction cleanEscapedString(input) {\n return input.match(escapedStringRegExp)[1].replace(doubleQuoteRegExp, \"'\");\n}\n\n// Fallback for modularized imports:\nexport default parse;\n","import { millisecondsInHour, millisecondsInMinute } from \"./constants.mjs\";\n\n/**\n * The {@link parseISO} function options.\n */\n\n/**\n * @name parseISO\n * @category Common Helpers\n * @summary Parse ISO string\n *\n * @description\n * Parse the given string in ISO 8601 format and return an instance of Date.\n *\n * Function accepts complete ISO 8601 formats as well as partial implementations.\n * ISO 8601: http://en.wikipedia.org/wiki/ISO_8601\n *\n * If the argument isn't a string, the function cannot parse the string or\n * the values are invalid, it returns Invalid Date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param argument - The value to convert\n * @param options - An object with options\n *\n * @returns The parsed date in the local time zone\n *\n * @example\n * // Convert string '2014-02-11T11:30:30' to date:\n * const result = parseISO('2014-02-11T11:30:30')\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert string '+02014101' to date,\n * // if the additional number of digits in the extended year format is 1:\n * const result = parseISO('+02014101', { additionalDigits: 1 })\n * //=> Fri Apr 11 2014 00:00:00\n */\nexport function parseISO(argument, options) {\n const additionalDigits = options?.additionalDigits ?? 2;\n const dateStrings = splitDateString(argument);\n\n let date;\n if (dateStrings.date) {\n const parseYearResult = parseYear(dateStrings.date, additionalDigits);\n date = parseDate(parseYearResult.restDateString, parseYearResult.year);\n }\n\n if (!date || isNaN(date.getTime())) {\n return new Date(NaN);\n }\n\n const timestamp = date.getTime();\n let time = 0;\n let offset;\n\n if (dateStrings.time) {\n time = parseTime(dateStrings.time);\n if (isNaN(time)) {\n return new Date(NaN);\n }\n }\n\n if (dateStrings.timezone) {\n offset = parseTimezone(dateStrings.timezone);\n if (isNaN(offset)) {\n return new Date(NaN);\n }\n } else {\n const dirtyDate = new Date(timestamp + time);\n // JS parsed string assuming it's in UTC timezone\n // but we need it to be parsed in our timezone\n // so we use utc values to build date in our timezone.\n // Year values from 0 to 99 map to the years 1900 to 1999\n // so set year explicitly with setFullYear.\n const result = new Date(0);\n result.setFullYear(\n dirtyDate.getUTCFullYear(),\n dirtyDate.getUTCMonth(),\n dirtyDate.getUTCDate(),\n );\n result.setHours(\n dirtyDate.getUTCHours(),\n dirtyDate.getUTCMinutes(),\n dirtyDate.getUTCSeconds(),\n dirtyDate.getUTCMilliseconds(),\n );\n return result;\n }\n\n return new Date(timestamp + time + offset);\n}\n\nconst patterns = {\n dateTimeDelimiter: /[T ]/,\n timeZoneDelimiter: /[Z ]/i,\n timezone: /([Z+-].*)$/,\n};\n\nconst dateRegex =\n /^-?(?:(\\d{3})|(\\d{2})(?:-?(\\d{2}))?|W(\\d{2})(?:-?(\\d{1}))?|)$/;\nconst timeRegex =\n /^(\\d{2}(?:[.,]\\d*)?)(?::?(\\d{2}(?:[.,]\\d*)?))?(?::?(\\d{2}(?:[.,]\\d*)?))?$/;\nconst timezoneRegex = /^([+-])(\\d{2})(?::?(\\d{2}))?$/;\n\nfunction splitDateString(dateString) {\n const dateStrings = {};\n const array = dateString.split(patterns.dateTimeDelimiter);\n let timeString;\n\n // The regex match should only return at maximum two array elements.\n // [date], [time], or [date, time].\n if (array.length > 2) {\n return dateStrings;\n }\n\n if (/:/.test(array[0])) {\n timeString = array[0];\n } else {\n dateStrings.date = array[0];\n timeString = array[1];\n if (patterns.timeZoneDelimiter.test(dateStrings.date)) {\n dateStrings.date = dateString.split(patterns.timeZoneDelimiter)[0];\n timeString = dateString.substr(\n dateStrings.date.length,\n dateString.length,\n );\n }\n }\n\n if (timeString) {\n const token = patterns.timezone.exec(timeString);\n if (token) {\n dateStrings.time = timeString.replace(token[1], \"\");\n dateStrings.timezone = token[1];\n } else {\n dateStrings.time = timeString;\n }\n }\n\n return dateStrings;\n}\n\nfunction parseYear(dateString, additionalDigits) {\n const regex = new RegExp(\n \"^(?:(\\\\d{4}|[+-]\\\\d{\" +\n (4 + additionalDigits) +\n \"})|(\\\\d{2}|[+-]\\\\d{\" +\n (2 + additionalDigits) +\n \"})$)\",\n );\n\n const captures = dateString.match(regex);\n // Invalid ISO-formatted year\n if (!captures) return { year: NaN, restDateString: \"\" };\n\n const year = captures[1] ? parseInt(captures[1]) : null;\n const century = captures[2] ? parseInt(captures[2]) : null;\n\n // either year or century is null, not both\n return {\n year: century === null ? year : century * 100,\n restDateString: dateString.slice((captures[1] || captures[2]).length),\n };\n}\n\nfunction parseDate(dateString, year) {\n // Invalid ISO-formatted year\n if (year === null) return new Date(NaN);\n\n const captures = dateString.match(dateRegex);\n // Invalid ISO-formatted string\n if (!captures) return new Date(NaN);\n\n const isWeekDate = !!captures[4];\n const dayOfYear = parseDateUnit(captures[1]);\n const month = parseDateUnit(captures[2]) - 1;\n const day = parseDateUnit(captures[3]);\n const week = parseDateUnit(captures[4]);\n const dayOfWeek = parseDateUnit(captures[5]) - 1;\n\n if (isWeekDate) {\n if (!validateWeekDate(year, week, dayOfWeek)) {\n return new Date(NaN);\n }\n return dayOfISOWeekYear(year, week, dayOfWeek);\n } else {\n const date = new Date(0);\n if (\n !validateDate(year, month, day) ||\n !validateDayOfYearDate(year, dayOfYear)\n ) {\n return new Date(NaN);\n }\n date.setUTCFullYear(year, month, Math.max(dayOfYear, day));\n return date;\n }\n}\n\nfunction parseDateUnit(value) {\n return value ? parseInt(value) : 1;\n}\n\nfunction parseTime(timeString) {\n const captures = timeString.match(timeRegex);\n if (!captures) return NaN; // Invalid ISO-formatted time\n\n const hours = parseTimeUnit(captures[1]);\n const minutes = parseTimeUnit(captures[2]);\n const seconds = parseTimeUnit(captures[3]);\n\n if (!validateTime(hours, minutes, seconds)) {\n return NaN;\n }\n\n return (\n hours * millisecondsInHour + minutes * millisecondsInMinute + seconds * 1000\n );\n}\n\nfunction parseTimeUnit(value) {\n return (value && parseFloat(value.replace(\",\", \".\"))) || 0;\n}\n\nfunction parseTimezone(timezoneString) {\n if (timezoneString === \"Z\") return 0;\n\n const captures = timezoneString.match(timezoneRegex);\n if (!captures) return 0;\n\n const sign = captures[1] === \"+\" ? -1 : 1;\n const hours = parseInt(captures[2]);\n const minutes = (captures[3] && parseInt(captures[3])) || 0;\n\n if (!validateTimezone(hours, minutes)) {\n return NaN;\n }\n\n return sign * (hours * millisecondsInHour + minutes * millisecondsInMinute);\n}\n\nfunction dayOfISOWeekYear(isoWeekYear, week, day) {\n const date = new Date(0);\n date.setUTCFullYear(isoWeekYear, 0, 4);\n const fourthOfJanuaryDay = date.getUTCDay() || 7;\n const diff = (week - 1) * 7 + day + 1 - fourthOfJanuaryDay;\n date.setUTCDate(date.getUTCDate() + diff);\n return date;\n}\n\n// Validation functions\n\n// February is null to handle the leap year (using ||)\nconst daysInMonths = [31, null, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\n\nfunction isLeapYearIndex(year) {\n return year % 400 === 0 || (year % 4 === 0 && year % 100 !== 0);\n}\n\nfunction validateDate(year, month, date) {\n return (\n month >= 0 &&\n month <= 11 &&\n date >= 1 &&\n date <= (daysInMonths[month] || (isLeapYearIndex(year) ? 29 : 28))\n );\n}\n\nfunction validateDayOfYearDate(year, dayOfYear) {\n return dayOfYear >= 1 && dayOfYear <= (isLeapYearIndex(year) ? 366 : 365);\n}\n\nfunction validateWeekDate(_year, week, day) {\n return week >= 1 && week <= 53 && day >= 0 && day <= 6;\n}\n\nfunction validateTime(hours, minutes, seconds) {\n if (hours === 24) {\n return minutes === 0 && seconds === 0;\n }\n\n return (\n seconds >= 0 &&\n seconds < 60 &&\n minutes >= 0 &&\n minutes < 60 &&\n hours >= 0 &&\n hours < 25\n );\n}\n\nfunction validateTimezone(_hours, minutes) {\n return minutes >= 0 && minutes <= 59;\n}\n\n// Fallback for modularized imports:\nexport default parseISO;\n","import { toDate } from \"./toDate.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\n\n/**\n * @name addMilliseconds\n * @category Millisecond Helpers\n * @summary Add the specified number of milliseconds to the given date.\n *\n * @description\n * Add the specified number of milliseconds to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of milliseconds to be added.\n *\n * @returns The new date with the milliseconds added\n *\n * @example\n * // Add 750 milliseconds to 10 July 2014 12:45:30.000:\n * const result = addMilliseconds(new Date(2014, 6, 10, 12, 45, 30, 0), 750)\n * //=> Thu Jul 10 2014 12:45:30.750\n */\nexport function addMilliseconds(date, amount) {\n const timestamp = +toDate(date);\n return constructFrom(date, timestamp + amount);\n}\n\n// Fallback for modularized imports:\nexport default addMilliseconds;\n","import { addMilliseconds } from \"./addMilliseconds.mjs\";\n\n/**\n * @name addSeconds\n * @category Second Helpers\n * @summary Add the specified number of seconds to the given date.\n *\n * @description\n * Add the specified number of seconds to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of seconds to be added.\n *\n * @returns The new date with the seconds added\n *\n * @example\n * // Add 30 seconds to 10 July 2014 12:45:00:\n * const result = addSeconds(new Date(2014, 6, 10, 12, 45, 0), 30)\n * //=> Thu Jul 10 2014 12:45:30\n */\nexport function addSeconds(date, amount) {\n return addMilliseconds(date, amount * 1000);\n}\n\n// Fallback for modularized imports:\nexport default addSeconds;\n","import { addMilliseconds } from \"./addMilliseconds.mjs\";\nimport { millisecondsInMinute } from \"./constants.mjs\";\n\n/**\n * @name addMinutes\n * @category Minute Helpers\n * @summary Add the specified number of minutes to the given date.\n *\n * @description\n * Add the specified number of minutes to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of minutes to be added.\n *\n * @returns The new date with the minutes added\n *\n * @example\n * // Add 30 minutes to 10 July 2014 12:00:00:\n * const result = addMinutes(new Date(2014, 6, 10, 12, 0), 30)\n * //=> Thu Jul 10 2014 12:30:00\n */\nexport function addMinutes(date, amount) {\n return addMilliseconds(date, amount * millisecondsInMinute);\n}\n\n// Fallback for modularized imports:\nexport default addMinutes;\n","import { addMilliseconds } from \"./addMilliseconds.mjs\";\nimport { millisecondsInHour } from \"./constants.mjs\";\n\n/**\n * @name addHours\n * @category Hour Helpers\n * @summary Add the specified number of hours to the given date.\n *\n * @description\n * Add the specified number of hours to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of hours to be added.\n *\n * @returns The new date with the hours added\n *\n * @example\n * // Add 2 hours to 10 July 2014 23:00:00:\n * const result = addHours(new Date(2014, 6, 10, 23, 0), 2)\n * //=> Fri Jul 11 2014 01:00:00\n */\nexport function addHours(date, amount) {\n return addMilliseconds(date, amount * millisecondsInHour);\n}\n\n// Fallback for modularized imports:\nexport default addHours;\n","import { addDays } from \"./addDays.mjs\";\n\n/**\n * @name addWeeks\n * @category Week Helpers\n * @summary Add the specified number of weeks to the given date.\n *\n * @description\n * Add the specified number of week to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of weeks to be added.\n *\n * @returns The new date with the weeks added\n *\n * @example\n * // Add 4 weeks to 1 September 2014:\n * const result = addWeeks(new Date(2014, 8, 1), 4)\n * //=> Mon Sep 29 2014 00:00:00\n */\nexport function addWeeks(date, amount) {\n const days = amount * 7;\n return addDays(date, days);\n}\n\n// Fallback for modularized imports:\nexport default addWeeks;\n","import { toDate } from \"./toDate.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\n\n/**\n * @name addMonths\n * @category Month Helpers\n * @summary Add the specified number of months to the given date.\n *\n * @description\n * Add the specified number of months to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of months to be added.\n *\n * @returns The new date with the months added\n *\n * @example\n * // Add 5 months to 1 September 2014:\n * const result = addMonths(new Date(2014, 8, 1), 5)\n * //=> Sun Feb 01 2015 00:00:00\n *\n * // Add one month to 30 January 2023:\n * const result = addMonths(new Date(2023, 0, 30), 1)\n * //=> Tue Feb 28 2023 00:00:00\n */\nexport function addMonths(date, amount) {\n const _date = toDate(date);\n if (isNaN(amount)) return constructFrom(date, NaN);\n if (!amount) {\n // If 0 months, no-op to avoid changing times in the hour before end of DST\n return _date;\n }\n const dayOfMonth = _date.getDate();\n\n // The JS Date object supports date math by accepting out-of-bounds values for\n // month, day, etc. For example, new Date(2020, 0, 0) returns 31 Dec 2019 and\n // new Date(2020, 13, 1) returns 1 Feb 2021. This is *almost* the behavior we\n // want except that dates will wrap around the end of a month, meaning that\n // new Date(2020, 13, 31) will return 3 Mar 2021 not 28 Feb 2021 as desired. So\n // we'll default to the end of the desired month by adding 1 to the desired\n // month and using a date of 0 to back up one day to the end of the desired\n // month.\n const endOfDesiredMonth = constructFrom(date, _date.getTime());\n endOfDesiredMonth.setMonth(_date.getMonth() + amount + 1, 0);\n const daysInMonth = endOfDesiredMonth.getDate();\n if (dayOfMonth >= daysInMonth) {\n // If we're already at the end of the month, then this is the correct date\n // and we're done.\n return endOfDesiredMonth;\n } else {\n // Otherwise, we now know that setting the original day-of-month value won't\n // cause an overflow, so set the desired day-of-month. Note that we can't\n // just set the date of `endOfDesiredMonth` because that object may have had\n // its time changed in the unusual case where where a DST transition was on\n // the last day of the month and its local time was in the hour skipped or\n // repeated next to a DST transition. So we use `date` instead which is\n // guaranteed to still have the original time.\n _date.setFullYear(\n endOfDesiredMonth.getFullYear(),\n endOfDesiredMonth.getMonth(),\n dayOfMonth,\n );\n return _date;\n }\n}\n\n// Fallback for modularized imports:\nexport default addMonths;\n","import { addMonths } from \"./addMonths.mjs\";\n\n/**\n * @name addQuarters\n * @category Quarter Helpers\n * @summary Add the specified number of year quarters to the given date.\n *\n * @description\n * Add the specified number of year quarters to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of quarters to be added.\n *\n * @returns The new date with the quarters added\n *\n * @example\n * // Add 1 quarter to 1 September 2014:\n * const result = addQuarters(new Date(2014, 8, 1), 1)\n * //=> Mon Dec 01 2014 00:00:00\n */\nexport function addQuarters(date, amount) {\n const months = amount * 3;\n return addMonths(date, months);\n}\n\n// Fallback for modularized imports:\nexport default addQuarters;\n","import { addMonths } from \"./addMonths.mjs\";\n\n/**\n * @name addYears\n * @category Year Helpers\n * @summary Add the specified number of years to the given date.\n *\n * @description\n * Add the specified number of years to the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of years to be added.\n *\n * @returns The new date with the years added\n *\n * @example\n * // Add 5 years to 1 September 2014:\n * const result = addYears(new Date(2014, 8, 1), 5)\n * //=> Sun Sep 01 2019 00:00:00\n */\nexport function addYears(date, amount) {\n return addMonths(date, amount * 12);\n}\n\n// Fallback for modularized imports:\nexport default addYears;\n","import { getRoundingMethod } from \"./_lib/getRoundingMethod.mjs\";\nimport { differenceInDays } from \"./differenceInDays.mjs\";\n\n/**\n * The {@link differenceInWeeks} function options.\n */\n\n/**\n * @name differenceInWeeks\n * @category Week Helpers\n * @summary Get the number of full weeks between the given dates.\n *\n * @description\n * Get the number of full weeks between two dates. Fractional weeks are\n * truncated towards zero by default.\n *\n * One \"full week\" is the distance between a local time in one day to the same\n * local time 7 days earlier or later. A full week can sometimes be less than\n * or more than 7*24 hours if a daylight savings change happens between two dates.\n *\n * To ignore DST and only measure exact 7*24-hour periods, use this instead:\n * `Math.trunc(differenceInHours(dateLeft, dateRight)/(7*24))|0`.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param dateLeft - The later date\n * @param dateRight - The earlier date\n * @param options - An object with options\n *\n * @returns The number of full weeks\n *\n * @example\n * // How many full weeks are between 5 July 2014 and 20 July 2014?\n * const result = differenceInWeeks(new Date(2014, 6, 20), new Date(2014, 6, 5))\n * //=> 2\n *\n * @example\n * // How many full weeks are between\n * // 1 March 2020 0:00 and 6 June 2020 0:00 ?\n * // Note: because local time is used, the\n * // result will always be 8 weeks (54 days),\n * // even if DST starts and the period has\n * // only 54*24-1 hours.\n * const result = differenceInWeeks(\n * new Date(2020, 5, 1),\n * new Date(2020, 2, 6)\n * )\n * //=> 8\n */\nexport function differenceInWeeks(dateLeft, dateRight, options) {\n const diff = differenceInDays(dateLeft, dateRight) / 7;\n return getRoundingMethod(options?.roundingMethod)(diff);\n}\n\n// Fallback for modularized imports:\nexport default differenceInWeeks;\n","import { getRoundingMethod } from \"./_lib/getRoundingMethod.mjs\";\nimport { differenceInMonths } from \"./differenceInMonths.mjs\";\n\n/**\n * The {@link differenceInQuarters} function options.\n */\n\n/**\n * @name differenceInQuarters\n * @category Quarter Helpers\n * @summary Get the number of quarters between the given dates.\n *\n * @description\n * Get the number of quarters between the given dates.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param dateLeft - The later date\n * @param dateRight - The earlier date\n * @param options - An object with options.\n *\n * @returns The number of full quarters\n *\n * @example\n * // How many full quarters are between 31 December 2013 and 2 July 2014?\n * const result = differenceInQuarters(new Date(2014, 6, 2), new Date(2013, 11, 31))\n * //=> 2\n */\nexport function differenceInQuarters(dateLeft, dateRight, options) {\n const diff = differenceInMonths(dateLeft, dateRight) / 3;\n return getRoundingMethod(options?.roundingMethod)(diff);\n}\n\n// Fallback for modularized imports:\nexport default differenceInQuarters;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name startOfSecond\n * @category Second Helpers\n * @summary Return the start of a second for the given date.\n *\n * @description\n * Return the start of a second for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The start of a second\n *\n * @example\n * // The start of a second for 1 December 2014 22:15:45.400:\n * const result = startOfSecond(new Date(2014, 11, 1, 22, 15, 45, 400))\n * //=> Mon Dec 01 2014 22:15:45.000\n */\nexport function startOfSecond(date) {\n const _date = toDate(date);\n _date.setMilliseconds(0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfSecond;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name startOfMinute\n * @category Minute Helpers\n * @summary Return the start of a minute for the given date.\n *\n * @description\n * Return the start of a minute for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The start of a minute\n *\n * @example\n * // The start of a minute for 1 December 2014 22:15:45.400:\n * const result = startOfMinute(new Date(2014, 11, 1, 22, 15, 45, 400))\n * //=> Mon Dec 01 2014 22:15:00\n */\nexport function startOfMinute(date) {\n const _date = toDate(date);\n _date.setSeconds(0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfMinute;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name startOfHour\n * @category Hour Helpers\n * @summary Return the start of an hour for the given date.\n *\n * @description\n * Return the start of an hour for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The start of an hour\n *\n * @example\n * // The start of an hour for 2 September 2014 11:55:00:\n * const result = startOfHour(new Date(2014, 8, 2, 11, 55))\n * //=> Tue Sep 02 2014 11:00:00\n */\nexport function startOfHour(date) {\n const _date = toDate(date);\n _date.setMinutes(0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfHour;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name startOfMonth\n * @category Month Helpers\n * @summary Return the start of a month for the given date.\n *\n * @description\n * Return the start of a month for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The start of a month\n *\n * @example\n * // The start of a month for 2 September 2014 11:55:00:\n * const result = startOfMonth(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfMonth(date) {\n const _date = toDate(date);\n _date.setDate(1);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfMonth;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name startOfQuarter\n * @category Quarter Helpers\n * @summary Return the start of a year quarter for the given date.\n *\n * @description\n * Return the start of a year quarter for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The start of a quarter\n *\n * @example\n * // The start of a quarter for 2 September 2014 11:55:00:\n * const result = startOfQuarter(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Tue Jul 01 2014 00:00:00\n */\nexport function startOfQuarter(date) {\n const _date = toDate(date);\n const currentMonth = _date.getMonth();\n const month = currentMonth - (currentMonth % 3);\n _date.setMonth(month, 1);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfQuarter;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name endOfSecond\n * @category Second Helpers\n * @summary Return the end of a second for the given date.\n *\n * @description\n * Return the end of a second for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The end of a second\n *\n * @example\n * // The end of a second for 1 December 2014 22:15:45.400:\n * const result = endOfSecond(new Date(2014, 11, 1, 22, 15, 45, 400))\n * //=> Mon Dec 01 2014 22:15:45.999\n */\nexport function endOfSecond(date) {\n const _date = toDate(date);\n _date.setMilliseconds(999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfSecond;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name endOfMinute\n * @category Minute Helpers\n * @summary Return the end of a minute for the given date.\n *\n * @description\n * Return the end of a minute for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The end of a minute\n *\n * @example\n * // The end of a minute for 1 December 2014 22:15:45.400:\n * const result = endOfMinute(new Date(2014, 11, 1, 22, 15, 45, 400))\n * //=> Mon Dec 01 2014 22:15:59.999\n */\nexport function endOfMinute(date) {\n const _date = toDate(date);\n _date.setSeconds(59, 999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfMinute;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name endOfHour\n * @category Hour Helpers\n * @summary Return the end of an hour for the given date.\n *\n * @description\n * Return the end of an hour for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The end of an hour\n *\n * @example\n * // The end of an hour for 2 September 2014 11:55:00:\n * const result = endOfHour(new Date(2014, 8, 2, 11, 55))\n * //=> Tue Sep 02 2014 11:59:59.999\n */\nexport function endOfHour(date) {\n const _date = toDate(date);\n _date.setMinutes(59, 59, 999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfHour;\n","import { toDate } from \"./toDate.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\n\n/**\n * The {@link endOfWeek} function options.\n */\n\n/**\n * @name endOfWeek\n * @category Week Helpers\n * @summary Return the end of a week for the given date.\n *\n * @description\n * Return the end of a week for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The end of a week\n *\n * @example\n * // The end of a week for 2 September 2014 11:55:00:\n * const result = endOfWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Sat Sep 06 2014 23:59:59.999\n *\n * @example\n * // If the week starts on Monday, the end of the week for 2 September 2014 11:55:00:\n * const result = endOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })\n * //=> Sun Sep 07 2014 23:59:59.999\n */\nexport function endOfWeek(date, options) {\n const defaultOptions = getDefaultOptions();\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const _date = toDate(date);\n const day = _date.getDay();\n const diff = (day < weekStartsOn ? -7 : 0) + 6 - (day - weekStartsOn);\n\n _date.setDate(_date.getDate() + diff);\n _date.setHours(23, 59, 59, 999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfWeek;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name endOfQuarter\n * @category Quarter Helpers\n * @summary Return the end of a year quarter for the given date.\n *\n * @description\n * Return the end of a year quarter for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The end of a quarter\n *\n * @example\n * // The end of a quarter for 2 September 2014 11:55:00:\n * const result = endOfQuarter(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Tue Sep 30 2014 23:59:59.999\n */\nexport function endOfQuarter(date) {\n const _date = toDate(date);\n const currentMonth = _date.getMonth();\n const month = currentMonth - (currentMonth % 3) + 3;\n _date.setMonth(month, 0);\n _date.setHours(23, 59, 59, 999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfQuarter;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name endOfYear\n * @category Year Helpers\n * @summary Return the end of a year for the given date.\n *\n * @description\n * Return the end of a year for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The end of a year\n *\n * @example\n * // The end of a year for 2 September 2014 11:55:00:\n * const result = endOfYear(new Date(2014, 8, 2, 11, 55, 00))\n * //=> Wed Dec 31 2014 23:59:59.999\n */\nexport function endOfYear(date) {\n const _date = toDate(date);\n const year = _date.getFullYear();\n _date.setFullYear(year + 1, 0, 0);\n _date.setHours(23, 59, 59, 999);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default endOfYear;\n","/*!\n * chartjs-adapter-date-fns v3.0.0\n * https://www.chartjs.org\n * (c) 2022 chartjs-adapter-date-fns Contributors\n * Released under the MIT license\n */\nimport { _adapters } from 'chart.js';\nimport { toDate, parse, parseISO, isValid, format, addYears, addQuarters, addMonths, addWeeks, addDays, addHours, addMinutes, addSeconds, addMilliseconds, differenceInYears, differenceInQuarters, differenceInMonths, differenceInWeeks, differenceInDays, differenceInHours, differenceInMinutes, differenceInSeconds, differenceInMilliseconds, startOfYear, startOfQuarter, startOfMonth, startOfWeek, startOfDay, startOfHour, startOfMinute, startOfSecond, endOfYear, endOfQuarter, endOfMonth, endOfWeek, endOfDay, endOfHour, endOfMinute, endOfSecond } from 'date-fns';\n\nconst FORMATS = {\n datetime: 'MMM d, yyyy, h:mm:ss aaaa',\n millisecond: 'h:mm:ss.SSS aaaa',\n second: 'h:mm:ss aaaa',\n minute: 'h:mm aaaa',\n hour: 'ha',\n day: 'MMM d',\n week: 'PP',\n month: 'MMM yyyy',\n quarter: 'qqq - yyyy',\n year: 'yyyy'\n};\n\n_adapters._date.override({\n _id: 'date-fns', // DEBUG\n\n formats: function() {\n return FORMATS;\n },\n\n parse: function(value, fmt) {\n if (value === null || typeof value === 'undefined') {\n return null;\n }\n const type = typeof value;\n if (type === 'number' || value instanceof Date) {\n value = toDate(value);\n } else if (type === 'string') {\n if (typeof fmt === 'string') {\n value = parse(value, fmt, new Date(), this.options);\n } else {\n value = parseISO(value, this.options);\n }\n }\n return isValid(value) ? value.getTime() : null;\n },\n\n format: function(time, fmt) {\n return format(time, fmt, this.options);\n },\n\n add: function(time, amount, unit) {\n switch (unit) {\n case 'millisecond': return addMilliseconds(time, amount);\n case 'second': return addSeconds(time, amount);\n case 'minute': return addMinutes(time, amount);\n case 'hour': return addHours(time, amount);\n case 'day': return addDays(time, amount);\n case 'week': return addWeeks(time, amount);\n case 'month': return addMonths(time, amount);\n case 'quarter': return addQuarters(time, amount);\n case 'year': return addYears(time, amount);\n default: return time;\n }\n },\n\n diff: function(max, min, unit) {\n switch (unit) {\n case 'millisecond': return differenceInMilliseconds(max, min);\n case 'second': return differenceInSeconds(max, min);\n case 'minute': return differenceInMinutes(max, min);\n case 'hour': return differenceInHours(max, min);\n case 'day': return differenceInDays(max, min);\n case 'week': return differenceInWeeks(max, min);\n case 'month': return differenceInMonths(max, min);\n case 'quarter': return differenceInQuarters(max, min);\n case 'year': return differenceInYears(max, min);\n default: return 0;\n }\n },\n\n startOf: function(time, unit, weekday) {\n switch (unit) {\n case 'second': return startOfSecond(time);\n case 'minute': return startOfMinute(time);\n case 'hour': return startOfHour(time);\n case 'day': return startOfDay(time);\n case 'week': return startOfWeek(time);\n case 'isoWeek': return startOfWeek(time, {weekStartsOn: +weekday});\n case 'month': return startOfMonth(time);\n case 'quarter': return startOfQuarter(time);\n case 'year': return startOfYear(time);\n default: return time;\n }\n },\n\n endOf: function(time, unit) {\n switch (unit) {\n case 'second': return endOfSecond(time);\n case 'minute': return endOfMinute(time);\n case 'hour': return endOfHour(time);\n case 'day': return endOfDay(time);\n case 'week': return endOfWeek(time);\n case 'month': return endOfMonth(time);\n case 'quarter': return endOfQuarter(time);\n case 'year': return endOfYear(time);\n default: return time;\n }\n }\n});\n","let defaultOptions = {};\n\nexport function getDefaultOptions() {\n return defaultOptions;\n}\n\nexport function setDefaultOptions(newOptions) {\n defaultOptions = newOptions;\n}\n","const dateLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"P\":\n return formatLong.date({ width: \"short\" });\n case \"PP\":\n return formatLong.date({ width: \"medium\" });\n case \"PPP\":\n return formatLong.date({ width: \"long\" });\n case \"PPPP\":\n default:\n return formatLong.date({ width: \"full\" });\n }\n};\n\nconst timeLongFormatter = (pattern, formatLong) => {\n switch (pattern) {\n case \"p\":\n return formatLong.time({ width: \"short\" });\n case \"pp\":\n return formatLong.time({ width: \"medium\" });\n case \"ppp\":\n return formatLong.time({ width: \"long\" });\n case \"pppp\":\n default:\n return formatLong.time({ width: \"full\" });\n }\n};\n\nconst dateTimeLongFormatter = (pattern, formatLong) => {\n const matchResult = pattern.match(/(P+)(p+)?/) || [];\n const datePattern = matchResult[1];\n const timePattern = matchResult[2];\n\n if (!timePattern) {\n return dateLongFormatter(pattern, formatLong);\n }\n\n let dateTimeFormat;\n\n switch (datePattern) {\n case \"P\":\n dateTimeFormat = formatLong.dateTime({ width: \"short\" });\n break;\n case \"PP\":\n dateTimeFormat = formatLong.dateTime({ width: \"medium\" });\n break;\n case \"PPP\":\n dateTimeFormat = formatLong.dateTime({ width: \"long\" });\n break;\n case \"PPPP\":\n default:\n dateTimeFormat = formatLong.dateTime({ width: \"full\" });\n break;\n }\n\n return dateTimeFormat\n .replace(\"{{date}}\", dateLongFormatter(datePattern, formatLong))\n .replace(\"{{time}}\", timeLongFormatter(timePattern, formatLong));\n};\n\nexport const longFormatters = {\n p: timeLongFormatter,\n P: dateTimeLongFormatter,\n};\n","const dayOfYearTokenRE = /^D+$/;\nconst weekYearTokenRE = /^Y+$/;\n\nconst throwTokens = [\"D\", \"DD\", \"YY\", \"YYYY\"];\n\nexport function isProtectedDayOfYearToken(token) {\n return dayOfYearTokenRE.test(token);\n}\n\nexport function isProtectedWeekYearToken(token) {\n return weekYearTokenRE.test(token);\n}\n\nexport function warnOrThrowProtectedError(token, format, input) {\n const _message = message(token, format, input);\n console.warn(_message);\n if (throwTokens.includes(token)) throw new RangeError(_message);\n}\n\nfunction message(token, format, input) {\n const subject = token[0] === \"Y\" ? \"years\" : \"days of the month\";\n return `Use \\`${token.toLowerCase()}\\` instead of \\`${token}\\` (in \\`${format}\\`) for formatting ${subject} to the input \\`${input}\\`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md`;\n}\n","/**\n * @name constructFrom\n * @category Generic Helpers\n * @summary Constructs a date using the reference date and the value\n *\n * @description\n * The function constructs a new date using the constructor from the reference\n * date and the given value. It helps to build generic functions that accept\n * date extensions.\n *\n * It defaults to `Date` if the passed reference date is a number or a string.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The reference date to take constructor from\n * @param value - The value to create the date\n *\n * @returns Date initialized using the given date and value\n *\n * @example\n * import { constructFrom } from 'date-fns'\n *\n * // A function that clones a date preserving the original type\n * function cloneDate 183\n */\nexport function getDayOfYear(date) {\n const _date = toDate(date);\n const diff = differenceInCalendarDays(_date, startOfYear(_date));\n const dayOfYear = diff + 1;\n return dayOfYear;\n}\n\n// Fallback for modularized imports:\nexport default getDayOfYear;\n","export function addLeadingZeros(number, targetLength) {\n const sign = number < 0 ? \"-\" : \"\";\n const output = Math.abs(number).toString().padStart(targetLength, \"0\");\n return sign + output;\n}\n","import { addLeadingZeros } from \"../addLeadingZeros.mjs\";\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | |\n * | d | Day of month | D | |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | m | Minute | M | Month |\n * | s | Second | S | Fraction of second |\n * | y | Year (abs) | Y | |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n */\n\nexport const lightFormatters = {\n // Year\n y(date, token) {\n // From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_tokens\n // | Year | y | yy | yyy | yyyy | yyyyy |\n // |----------|-------|----|-------|-------|-------|\n // | AD 1 | 1 | 01 | 001 | 0001 | 00001 |\n // | AD 12 | 12 | 12 | 012 | 0012 | 00012 |\n // | AD 123 | 123 | 23 | 123 | 0123 | 00123 |\n // | AD 1234 | 1234 | 34 | 1234 | 1234 | 01234 |\n // | AD 12345 | 12345 | 45 | 12345 | 12345 | 12345 |\n\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return addLeadingZeros(token === \"yy\" ? year % 100 : year, token.length);\n },\n\n // Month\n M(date, token) {\n const month = date.getMonth();\n return token === \"M\" ? String(month + 1) : addLeadingZeros(month + 1, 2);\n },\n\n // Day of the month\n d(date, token) {\n return addLeadingZeros(date.getDate(), token.length);\n },\n\n // AM or PM\n a(date, token) {\n const dayPeriodEnumValue = date.getHours() / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return dayPeriodEnumValue.toUpperCase();\n case \"aaa\":\n return dayPeriodEnumValue;\n case \"aaaaa\":\n return dayPeriodEnumValue[0];\n case \"aaaa\":\n default:\n return dayPeriodEnumValue === \"am\" ? \"a.m.\" : \"p.m.\";\n }\n },\n\n // Hour [1-12]\n h(date, token) {\n return addLeadingZeros(date.getHours() % 12 || 12, token.length);\n },\n\n // Hour [0-23]\n H(date, token) {\n return addLeadingZeros(date.getHours(), token.length);\n },\n\n // Minute\n m(date, token) {\n return addLeadingZeros(date.getMinutes(), token.length);\n },\n\n // Second\n s(date, token) {\n return addLeadingZeros(date.getSeconds(), token.length);\n },\n\n // Fraction of second\n S(date, token) {\n const numberOfDigits = token.length;\n const milliseconds = date.getMilliseconds();\n const fractionalSeconds = Math.trunc(\n milliseconds * Math.pow(10, numberOfDigits - 3),\n );\n return addLeadingZeros(fractionalSeconds, token.length);\n },\n};\n","import { getDayOfYear } from \"../../getDayOfYear.mjs\";\nimport { getISOWeek } from \"../../getISOWeek.mjs\";\nimport { getISOWeekYear } from \"../../getISOWeekYear.mjs\";\nimport { getWeek } from \"../../getWeek.mjs\";\nimport { getWeekYear } from \"../../getWeekYear.mjs\";\nimport { addLeadingZeros } from \"../addLeadingZeros.mjs\";\nimport { lightFormatters } from \"./lightFormatters.mjs\";\n\nconst dayPeriodEnum = {\n am: \"am\",\n pm: \"pm\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n};\n\n/*\n * | | Unit | | Unit |\n * |-----|--------------------------------|-----|--------------------------------|\n * | a | AM, PM | A* | Milliseconds in day |\n * | b | AM, PM, noon, midnight | B | Flexible day period |\n * | c | Stand-alone local day of week | C* | Localized hour w/ day period |\n * | d | Day of month | D | Day of year |\n * | e | Local day of week | E | Day of week |\n * | f | | F* | Day of week in month |\n * | g* | Modified Julian day | G | Era |\n * | h | Hour [1-12] | H | Hour [0-23] |\n * | i! | ISO day of week | I! | ISO week of year |\n * | j* | Localized hour w/ day period | J* | Localized hour w/o day period |\n * | k | Hour [1-24] | K | Hour [0-11] |\n * | l* | (deprecated) | L | Stand-alone month |\n * | m | Minute | M | Month |\n * | n | | N | |\n * | o! | Ordinal number modifier | O | Timezone (GMT) |\n * | p! | Long localized time | P! | Long localized date |\n * | q | Stand-alone quarter | Q | Quarter |\n * | r* | Related Gregorian year | R! | ISO week-numbering year |\n * | s | Second | S | Fraction of second |\n * | t! | Seconds timestamp | T! | Milliseconds timestamp |\n * | u | Extended year | U* | Cyclic year |\n * | v* | Timezone (generic non-locat.) | V* | Timezone (location) |\n * | w | Local week of year | W* | Week of month |\n * | x | Timezone (ISO-8601 w/o Z) | X | Timezone (ISO-8601) |\n * | y | Year (abs) | Y | Local week-numbering year |\n * | z | Timezone (specific non-locat.) | Z* | Timezone (aliases) |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n *\n * Letters marked by ! are non-standard, but implemented by date-fns:\n * - `o` modifies the previous token to turn it into an ordinal (see `format` docs)\n * - `i` is ISO day of week. For `i` and `ii` is returns numeric ISO week days,\n * i.e. 7 for Sunday, 1 for Monday, etc.\n * - `I` is ISO week of year, as opposed to `w` which is local week of year.\n * - `R` is ISO week-numbering year, as opposed to `Y` which is local week-numbering year.\n * `R` is supposed to be used in conjunction with `I` and `i`\n * for universal ISO week-numbering date, whereas\n * `Y` is supposed to be used in conjunction with `w` and `e`\n * for week-numbering date specific to the locale.\n * - `P` is long localized date format\n * - `p` is long localized time format\n */\n\nexport const formatters = {\n // Era\n G: function (date, token, localize) {\n const era = date.getFullYear() > 0 ? 1 : 0;\n switch (token) {\n // AD, BC\n case \"G\":\n case \"GG\":\n case \"GGG\":\n return localize.era(era, { width: \"abbreviated\" });\n // A, B\n case \"GGGGG\":\n return localize.era(era, { width: \"narrow\" });\n // Anno Domini, Before Christ\n case \"GGGG\":\n default:\n return localize.era(era, { width: \"wide\" });\n }\n },\n\n // Year\n y: function (date, token, localize) {\n // Ordinal number\n if (token === \"yo\") {\n const signedYear = date.getFullYear();\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const year = signedYear > 0 ? signedYear : 1 - signedYear;\n return localize.ordinalNumber(year, { unit: \"year\" });\n }\n\n return lightFormatters.y(date, token);\n },\n\n // Local week-numbering year\n Y: function (date, token, localize, options) {\n const signedWeekYear = getWeekYear(date, options);\n // Returns 1 for 1 BC (which is year 0 in JavaScript)\n const weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear;\n\n // Two digit year\n if (token === \"YY\") {\n const twoDigitYear = weekYear % 100;\n return addLeadingZeros(twoDigitYear, 2);\n }\n\n // Ordinal number\n if (token === \"Yo\") {\n return localize.ordinalNumber(weekYear, { unit: \"year\" });\n }\n\n // Padding\n return addLeadingZeros(weekYear, token.length);\n },\n\n // ISO week-numbering year\n R: function (date, token) {\n const isoWeekYear = getISOWeekYear(date);\n\n // Padding\n return addLeadingZeros(isoWeekYear, token.length);\n },\n\n // Extended year. This is a single number designating the year of this calendar system.\n // The main difference between `y` and `u` localizers are B.C. years:\n // | Year | `y` | `u` |\n // |------|-----|-----|\n // | AC 1 | 1 | 1 |\n // | BC 1 | 1 | 0 |\n // | BC 2 | 2 | -1 |\n // Also `yy` always returns the last two digits of a year,\n // while `uu` pads single digit years to 2 characters and returns other years unchanged.\n u: function (date, token) {\n const year = date.getFullYear();\n return addLeadingZeros(year, token.length);\n },\n\n // Quarter\n Q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"Q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"QQ\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"Qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"QQQ\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"QQQQQ\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"QQQQ\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone quarter\n q: function (date, token, localize) {\n const quarter = Math.ceil((date.getMonth() + 1) / 3);\n switch (token) {\n // 1, 2, 3, 4\n case \"q\":\n return String(quarter);\n // 01, 02, 03, 04\n case \"qq\":\n return addLeadingZeros(quarter, 2);\n // 1st, 2nd, 3rd, 4th\n case \"qo\":\n return localize.ordinalNumber(quarter, { unit: \"quarter\" });\n // Q1, Q2, Q3, Q4\n case \"qqq\":\n return localize.quarter(quarter, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n case \"qqqqq\":\n return localize.quarter(quarter, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // 1st quarter, 2nd quarter, ...\n case \"qqqq\":\n default:\n return localize.quarter(quarter, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // Month\n M: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n case \"M\":\n case \"MM\":\n return lightFormatters.M(date, token);\n // 1st, 2nd, ..., 12th\n case \"Mo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"MMM\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // J, F, ..., D\n case \"MMMMM\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // January, February, ..., December\n case \"MMMM\":\n default:\n return localize.month(month, { width: \"wide\", context: \"formatting\" });\n }\n },\n\n // Stand-alone month\n L: function (date, token, localize) {\n const month = date.getMonth();\n switch (token) {\n // 1, 2, ..., 12\n case \"L\":\n return String(month + 1);\n // 01, 02, ..., 12\n case \"LL\":\n return addLeadingZeros(month + 1, 2);\n // 1st, 2nd, ..., 12th\n case \"Lo\":\n return localize.ordinalNumber(month + 1, { unit: \"month\" });\n // Jan, Feb, ..., Dec\n case \"LLL\":\n return localize.month(month, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // J, F, ..., D\n case \"LLLLL\":\n return localize.month(month, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // January, February, ..., December\n case \"LLLL\":\n default:\n return localize.month(month, { width: \"wide\", context: \"standalone\" });\n }\n },\n\n // Local week of year\n w: function (date, token, localize, options) {\n const week = getWeek(date, options);\n\n if (token === \"wo\") {\n return localize.ordinalNumber(week, { unit: \"week\" });\n }\n\n return addLeadingZeros(week, token.length);\n },\n\n // ISO week of year\n I: function (date, token, localize) {\n const isoWeek = getISOWeek(date);\n\n if (token === \"Io\") {\n return localize.ordinalNumber(isoWeek, { unit: \"week\" });\n }\n\n return addLeadingZeros(isoWeek, token.length);\n },\n\n // Day of the month\n d: function (date, token, localize) {\n if (token === \"do\") {\n return localize.ordinalNumber(date.getDate(), { unit: \"date\" });\n }\n\n return lightFormatters.d(date, token);\n },\n\n // Day of year\n D: function (date, token, localize) {\n const dayOfYear = getDayOfYear(date);\n\n if (token === \"Do\") {\n return localize.ordinalNumber(dayOfYear, { unit: \"dayOfYear\" });\n }\n\n return addLeadingZeros(dayOfYear, token.length);\n },\n\n // Day of week\n E: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n switch (token) {\n // Tue\n case \"E\":\n case \"EE\":\n case \"EEE\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"EEEEE\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"EEEEEE\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"EEEE\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Local day of week\n e: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (Nth day of week with current locale or weekStartsOn)\n case \"e\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"ee\":\n return addLeadingZeros(localDayOfWeek, 2);\n // 1st, 2nd, ..., 7th\n case \"eo\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"eee\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"eeeee\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"eeeeee\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"eeee\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Stand-alone local day of week\n c: function (date, token, localize, options) {\n const dayOfWeek = date.getDay();\n const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n switch (token) {\n // Numerical value (same as in `e`)\n case \"c\":\n return String(localDayOfWeek);\n // Padded numerical value\n case \"cc\":\n return addLeadingZeros(localDayOfWeek, token.length);\n // 1st, 2nd, ..., 7th\n case \"co\":\n return localize.ordinalNumber(localDayOfWeek, { unit: \"day\" });\n case \"ccc\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"standalone\",\n });\n // T\n case \"ccccc\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"standalone\",\n });\n // Tu\n case \"cccccc\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"standalone\",\n });\n // Tuesday\n case \"cccc\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"standalone\",\n });\n }\n },\n\n // ISO day of week\n i: function (date, token, localize) {\n const dayOfWeek = date.getDay();\n const isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek;\n switch (token) {\n // 2\n case \"i\":\n return String(isoDayOfWeek);\n // 02\n case \"ii\":\n return addLeadingZeros(isoDayOfWeek, token.length);\n // 2nd\n case \"io\":\n return localize.ordinalNumber(isoDayOfWeek, { unit: \"day\" });\n // Tue\n case \"iii\":\n return localize.day(dayOfWeek, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n // T\n case \"iiiii\":\n return localize.day(dayOfWeek, {\n width: \"narrow\",\n context: \"formatting\",\n });\n // Tu\n case \"iiiiii\":\n return localize.day(dayOfWeek, {\n width: \"short\",\n context: \"formatting\",\n });\n // Tuesday\n case \"iiii\":\n default:\n return localize.day(dayOfWeek, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM or PM\n a: function (date, token, localize) {\n const hours = date.getHours();\n const dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n\n switch (token) {\n case \"a\":\n case \"aa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"aaa\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"aaaaa\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"aaaa\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // AM, PM, midnight, noon\n b: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours === 12) {\n dayPeriodEnumValue = dayPeriodEnum.noon;\n } else if (hours === 0) {\n dayPeriodEnumValue = dayPeriodEnum.midnight;\n } else {\n dayPeriodEnumValue = hours / 12 >= 1 ? \"pm\" : \"am\";\n }\n\n switch (token) {\n case \"b\":\n case \"bb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"bbb\":\n return localize\n .dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n })\n .toLowerCase();\n case \"bbbbb\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"bbbb\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // in the morning, in the afternoon, in the evening, at night\n B: function (date, token, localize) {\n const hours = date.getHours();\n let dayPeriodEnumValue;\n if (hours >= 17) {\n dayPeriodEnumValue = dayPeriodEnum.evening;\n } else if (hours >= 12) {\n dayPeriodEnumValue = dayPeriodEnum.afternoon;\n } else if (hours >= 4) {\n dayPeriodEnumValue = dayPeriodEnum.morning;\n } else {\n dayPeriodEnumValue = dayPeriodEnum.night;\n }\n\n switch (token) {\n case \"B\":\n case \"BB\":\n case \"BBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"abbreviated\",\n context: \"formatting\",\n });\n case \"BBBBB\":\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"narrow\",\n context: \"formatting\",\n });\n case \"BBBB\":\n default:\n return localize.dayPeriod(dayPeriodEnumValue, {\n width: \"wide\",\n context: \"formatting\",\n });\n }\n },\n\n // Hour [1-12]\n h: function (date, token, localize) {\n if (token === \"ho\") {\n let hours = date.getHours() % 12;\n if (hours === 0) hours = 12;\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return lightFormatters.h(date, token);\n },\n\n // Hour [0-23]\n H: function (date, token, localize) {\n if (token === \"Ho\") {\n return localize.ordinalNumber(date.getHours(), { unit: \"hour\" });\n }\n\n return lightFormatters.H(date, token);\n },\n\n // Hour [0-11]\n K: function (date, token, localize) {\n const hours = date.getHours() % 12;\n\n if (token === \"Ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Hour [1-24]\n k: function (date, token, localize) {\n let hours = date.getHours();\n if (hours === 0) hours = 24;\n\n if (token === \"ko\") {\n return localize.ordinalNumber(hours, { unit: \"hour\" });\n }\n\n return addLeadingZeros(hours, token.length);\n },\n\n // Minute\n m: function (date, token, localize) {\n if (token === \"mo\") {\n return localize.ordinalNumber(date.getMinutes(), { unit: \"minute\" });\n }\n\n return lightFormatters.m(date, token);\n },\n\n // Second\n s: function (date, token, localize) {\n if (token === \"so\") {\n return localize.ordinalNumber(date.getSeconds(), { unit: \"second\" });\n }\n\n return lightFormatters.s(date, token);\n },\n\n // Fraction of second\n S: function (date, token) {\n return lightFormatters.S(date, token);\n },\n\n // Timezone (ISO-8601. If offset is 0, output is always `'Z'`)\n X: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n if (timezoneOffset === 0) {\n return \"Z\";\n }\n\n switch (token) {\n // Hours and optional minutes\n case \"X\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XX`\n case \"XXXX\":\n case \"XX\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `XXX`\n case \"XXXXX\":\n case \"XXX\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent)\n x: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Hours and optional minutes\n case \"x\":\n return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n // Hours, minutes and optional seconds without `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xx`\n case \"xxxx\":\n case \"xx\": // Hours and minutes without `:` delimiter\n return formatTimezone(timezoneOffset);\n\n // Hours, minutes and optional seconds with `:` delimiter\n // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n // so this token always has the same output as `xxx`\n case \"xxxxx\":\n case \"xxx\": // Hours and minutes with `:` delimiter\n default:\n return formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (GMT)\n O: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"O\":\n case \"OO\":\n case \"OOO\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"OOOO\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Timezone (specific non-location)\n z: function (date, token, _localize) {\n const timezoneOffset = date.getTimezoneOffset();\n\n switch (token) {\n // Short\n case \"z\":\n case \"zz\":\n case \"zzz\":\n return \"GMT\" + formatTimezoneShort(timezoneOffset, \":\");\n // Long\n case \"zzzz\":\n default:\n return \"GMT\" + formatTimezone(timezoneOffset, \":\");\n }\n },\n\n // Seconds timestamp\n t: function (date, token, _localize) {\n const timestamp = Math.trunc(date.getTime() / 1000);\n return addLeadingZeros(timestamp, token.length);\n },\n\n // Milliseconds timestamp\n T: function (date, token, _localize) {\n const timestamp = date.getTime();\n return addLeadingZeros(timestamp, token.length);\n },\n};\n\nfunction formatTimezoneShort(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = Math.trunc(absOffset / 60);\n const minutes = absOffset % 60;\n if (minutes === 0) {\n return sign + String(hours);\n }\n return sign + String(hours) + delimiter + addLeadingZeros(minutes, 2);\n}\n\nfunction formatTimezoneWithOptionalMinutes(offset, delimiter) {\n if (offset % 60 === 0) {\n const sign = offset > 0 ? \"-\" : \"+\";\n return sign + addLeadingZeros(Math.abs(offset) / 60, 2);\n }\n return formatTimezone(offset, delimiter);\n}\n\nfunction formatTimezone(offset, delimiter = \"\") {\n const sign = offset > 0 ? \"-\" : \"+\";\n const absOffset = Math.abs(offset);\n const hours = addLeadingZeros(Math.trunc(absOffset / 60), 2);\n const minutes = addLeadingZeros(absOffset % 60, 2);\n return sign + hours + delimiter + minutes;\n}\n","import { defaultLocale } from \"./_lib/defaultLocale.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\nimport { formatters } from \"./_lib/format/formatters.mjs\";\nimport { longFormatters } from \"./_lib/format/longFormatters.mjs\";\nimport {\n isProtectedDayOfYearToken,\n isProtectedWeekYearToken,\n warnOrThrowProtectedError,\n} from \"./_lib/protectedTokens.mjs\";\nimport { isValid } from \"./isValid.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n// Rexports of internal for libraries to use.\n// See: https://github.com/date-fns/date-fns/issues/3638#issuecomment-1877082874\nexport { formatters, longFormatters };\n\n// This RegExp consists of three parts separated by `|`:\n// - [yYQqMLwIdDecihHKkms]o matches any available ordinal number token\n// (one of the certain letters followed by `o`)\n// - (\\w)\\1* matches any sequences of the same letter\n// - '' matches two quote characters in a row\n// - '(''|[^'])+('|$) matches anything surrounded by two quote characters ('),\n// except a single quote symbol, which ends the sequence.\n// Two quote characters do not end the sequence.\n// If there is no matching single quote\n// then the sequence will continue until the end of the string.\n// - . matches any single character unmatched by previous parts of the RegExps\nconst formattingTokensRegExp =\n /[yYQqMLwIdDecihHKkms]o|(\\w)\\1*|''|'(''|[^'])+('|$)|./g;\n\n// This RegExp catches symbols escaped by quotes, and also\n// sequences of symbols P, p, and the combinations like `PPPPPPPppppp`\nconst longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;\n\nconst escapedStringRegExp = /^'([^]*?)'?$/;\nconst doubleQuoteRegExp = /''/g;\nconst unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n\nexport { format as formatDate };\n\n/**\n * The {@link format} function options.\n */\n\n/**\n * @name format\n * @alias formatDate\n * @category Common Helpers\n * @summary Format the date.\n *\n * @description\n * Return the formatted date string in the given format. The result may vary by locale.\n *\n * > ⚠️ Please note that the `format` tokens differ from Moment.js and other libraries.\n * > See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * The characters wrapped between two single quotes characters (') are escaped.\n * Two single quotes in a row, whether inside or outside a quoted sequence, represent a 'real' single quote.\n * (see the last example)\n *\n * Format of the string is based on Unicode Technical Standard #35:\n * https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table\n * with a few additions (see note 7 below the table).\n *\n * Accepted patterns:\n * | Unit | Pattern | Result examples | Notes |\n * |---------------------------------|---------|-----------------------------------|-------|\n * | Era | G..GGG | AD, BC | |\n * | | GGGG | Anno Domini, Before Christ | 2 |\n * | | GGGGG | A, B | |\n * | Calendar year | y | 44, 1, 1900, 2017 | 5 |\n * | | yo | 44th, 1st, 0th, 17th | 5,7 |\n * | | yy | 44, 01, 00, 17 | 5 |\n * | | yyy | 044, 001, 1900, 2017 | 5 |\n * | | yyyy | 0044, 0001, 1900, 2017 | 5 |\n * | | yyyyy | ... | 3,5 |\n * | Local week-numbering year | Y | 44, 1, 1900, 2017 | 5 |\n * | | Yo | 44th, 1st, 1900th, 2017th | 5,7 |\n * | | YY | 44, 01, 00, 17 | 5,8 |\n * | | YYY | 044, 001, 1900, 2017 | 5 |\n * | | YYYY | 0044, 0001, 1900, 2017 | 5,8 |\n * | | YYYYY | ... | 3,5 |\n * | ISO week-numbering year | R | -43, 0, 1, 1900, 2017 | 5,7 |\n * | | RR | -43, 00, 01, 1900, 2017 | 5,7 |\n * | | RRR | -043, 000, 001, 1900, 2017 | 5,7 |\n * | | RRRR | -0043, 0000, 0001, 1900, 2017 | 5,7 |\n * | | RRRRR | ... | 3,5,7 |\n * | Extended year | u | -43, 0, 1, 1900, 2017 | 5 |\n * | | uu | -43, 01, 1900, 2017 | 5 |\n * | | uuu | -043, 001, 1900, 2017 | 5 |\n * | | uuuu | -0043, 0001, 1900, 2017 | 5 |\n * | | uuuuu | ... | 3,5 |\n * | Quarter (formatting) | Q | 1, 2, 3, 4 | |\n * | | Qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | QQ | 01, 02, 03, 04 | |\n * | | QQQ | Q1, Q2, Q3, Q4 | |\n * | | QQQQ | 1st quarter, 2nd quarter, ... | 2 |\n * | | QQQQQ | 1, 2, 3, 4 | 4 |\n * | Quarter (stand-alone) | q | 1, 2, 3, 4 | |\n * | | qo | 1st, 2nd, 3rd, 4th | 7 |\n * | | qq | 01, 02, 03, 04 | |\n * | | qqq | Q1, Q2, Q3, Q4 | |\n * | | qqqq | 1st quarter, 2nd quarter, ... | 2 |\n * | | qqqqq | 1, 2, 3, 4 | 4 |\n * | Month (formatting) | M | 1, 2, ..., 12 | |\n * | | Mo | 1st, 2nd, ..., 12th | 7 |\n * | | MM | 01, 02, ..., 12 | |\n * | | MMM | Jan, Feb, ..., Dec | |\n * | | MMMM | January, February, ..., December | 2 |\n * | | MMMMM | J, F, ..., D | |\n * | Month (stand-alone) | L | 1, 2, ..., 12 | |\n * | | Lo | 1st, 2nd, ..., 12th | 7 |\n * | | LL | 01, 02, ..., 12 | |\n * | | LLL | Jan, Feb, ..., Dec | |\n * | | LLLL | January, February, ..., December | 2 |\n * | | LLLLL | J, F, ..., D | |\n * | Local week of year | w | 1, 2, ..., 53 | |\n * | | wo | 1st, 2nd, ..., 53th | 7 |\n * | | ww | 01, 02, ..., 53 | |\n * | ISO week of year | I | 1, 2, ..., 53 | 7 |\n * | | Io | 1st, 2nd, ..., 53th | 7 |\n * | | II | 01, 02, ..., 53 | 7 |\n * | Day of month | d | 1, 2, ..., 31 | |\n * | | do | 1st, 2nd, ..., 31st | 7 |\n * | | dd | 01, 02, ..., 31 | |\n * | Day of year | D | 1, 2, ..., 365, 366 | 9 |\n * | | Do | 1st, 2nd, ..., 365th, 366th | 7 |\n * | | DD | 01, 02, ..., 365, 366 | 9 |\n * | | DDD | 001, 002, ..., 365, 366 | |\n * | | DDDD | ... | 3 |\n * | Day of week (formatting) | E..EEE | Mon, Tue, Wed, ..., Sun | |\n * | | EEEE | Monday, Tuesday, ..., Sunday | 2 |\n * | | EEEEE | M, T, W, T, F, S, S | |\n * | | EEEEEE | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | ISO day of week (formatting) | i | 1, 2, 3, ..., 7 | 7 |\n * | | io | 1st, 2nd, ..., 7th | 7 |\n * | | ii | 01, 02, ..., 07 | 7 |\n * | | iii | Mon, Tue, Wed, ..., Sun | 7 |\n * | | iiii | Monday, Tuesday, ..., Sunday | 2,7 |\n * | | iiiii | M, T, W, T, F, S, S | 7 |\n * | | iiiiii | Mo, Tu, We, Th, Fr, Sa, Su | 7 |\n * | Local day of week (formatting) | e | 2, 3, 4, ..., 1 | |\n * | | eo | 2nd, 3rd, ..., 1st | 7 |\n * | | ee | 02, 03, ..., 01 | |\n * | | eee | Mon, Tue, Wed, ..., Sun | |\n * | | eeee | Monday, Tuesday, ..., Sunday | 2 |\n * | | eeeee | M, T, W, T, F, S, S | |\n * | | eeeeee | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | Local day of week (stand-alone) | c | 2, 3, 4, ..., 1 | |\n * | | co | 2nd, 3rd, ..., 1st | 7 |\n * | | cc | 02, 03, ..., 01 | |\n * | | ccc | Mon, Tue, Wed, ..., Sun | |\n * | | cccc | Monday, Tuesday, ..., Sunday | 2 |\n * | | ccccc | M, T, W, T, F, S, S | |\n * | | cccccc | Mo, Tu, We, Th, Fr, Sa, Su | |\n * | AM, PM | a..aa | AM, PM | |\n * | | aaa | am, pm | |\n * | | aaaa | a.m., p.m. | 2 |\n * | | aaaaa | a, p | |\n * | AM, PM, noon, midnight | b..bb | AM, PM, noon, midnight | |\n * | | bbb | am, pm, noon, midnight | |\n * | | bbbb | a.m., p.m., noon, midnight | 2 |\n * | | bbbbb | a, p, n, mi | |\n * | Flexible day period | B..BBB | at night, in the morning, ... | |\n * | | BBBB | at night, in the morning, ... | 2 |\n * | | BBBBB | at night, in the morning, ... | |\n * | Hour [1-12] | h | 1, 2, ..., 11, 12 | |\n * | | ho | 1st, 2nd, ..., 11th, 12th | 7 |\n * | | hh | 01, 02, ..., 11, 12 | |\n * | Hour [0-23] | H | 0, 1, 2, ..., 23 | |\n * | | Ho | 0th, 1st, 2nd, ..., 23rd | 7 |\n * | | HH | 00, 01, 02, ..., 23 | |\n * | Hour [0-11] | K | 1, 2, ..., 11, 0 | |\n * | | Ko | 1st, 2nd, ..., 11th, 0th | 7 |\n * | | KK | 01, 02, ..., 11, 00 | |\n * | Hour [1-24] | k | 24, 1, 2, ..., 23 | |\n * | | ko | 24th, 1st, 2nd, ..., 23rd | 7 |\n * | | kk | 24, 01, 02, ..., 23 | |\n * | Minute | m | 0, 1, ..., 59 | |\n * | | mo | 0th, 1st, ..., 59th | 7 |\n * | | mm | 00, 01, ..., 59 | |\n * | Second | s | 0, 1, ..., 59 | |\n * | | so | 0th, 1st, ..., 59th | 7 |\n * | | ss | 00, 01, ..., 59 | |\n * | Fraction of second | S | 0, 1, ..., 9 | |\n * | | SS | 00, 01, ..., 99 | |\n * | | SSS | 000, 001, ..., 999 | |\n * | | SSSS | ... | 3 |\n * | Timezone (ISO-8601 w/ Z) | X | -08, +0530, Z | |\n * | | XX | -0800, +0530, Z | |\n * | | XXX | -08:00, +05:30, Z | |\n * | | XXXX | -0800, +0530, Z, +123456 | 2 |\n * | | XXXXX | -08:00, +05:30, Z, +12:34:56 | |\n * | Timezone (ISO-8601 w/o Z) | x | -08, +0530, +00 | |\n * | | xx | -0800, +0530, +0000 | |\n * | | xxx | -08:00, +05:30, +00:00 | 2 |\n * | | xxxx | -0800, +0530, +0000, +123456 | |\n * | | xxxxx | -08:00, +05:30, +00:00, +12:34:56 | |\n * | Timezone (GMT) | O...OOO | GMT-8, GMT+5:30, GMT+0 | |\n * | | OOOO | GMT-08:00, GMT+05:30, GMT+00:00 | 2 |\n * | Timezone (specific non-locat.) | z...zzz | GMT-8, GMT+5:30, GMT+0 | 6 |\n * | | zzzz | GMT-08:00, GMT+05:30, GMT+00:00 | 2,6 |\n * | Seconds timestamp | t | 512969520 | 7 |\n * | | tt | ... | 3,7 |\n * | Milliseconds timestamp | T | 512969520900 | 7 |\n * | | TT | ... | 3,7 |\n * | Long localized date | P | 04/29/1453 | 7 |\n * | | PP | Apr 29, 1453 | 7 |\n * | | PPP | April 29th, 1453 | 7 |\n * | | PPPP | Friday, April 29th, 1453 | 2,7 |\n * | Long localized time | p | 12:00 AM | 7 |\n * | | pp | 12:00:00 AM | 7 |\n * | | ppp | 12:00:00 AM GMT+2 | 7 |\n * | | pppp | 12:00:00 AM GMT+02:00 | 2,7 |\n * | Combination of date and time | Pp | 04/29/1453, 12:00 AM | 7 |\n * | | PPpp | Apr 29, 1453, 12:00:00 AM | 7 |\n * | | PPPppp | April 29th, 1453 at ... | 7 |\n * | | PPPPpppp| Friday, April 29th, 1453 at ... | 2,7 |\n * Notes:\n * 1. \"Formatting\" units (e.g. formatting quarter) in the default en-US locale\n * are the same as \"stand-alone\" units, but are different in some languages.\n * \"Formatting\" units are declined according to the rules of the language\n * in the context of a date. \"Stand-alone\" units are always nominative singular:\n *\n * `format(new Date(2017, 10, 6), 'do LLLL', {locale: cs}) //=> '6. listopad'`\n *\n * `format(new Date(2017, 10, 6), 'do MMMM', {locale: cs}) //=> '6. listopadu'`\n *\n * 2. Any sequence of the identical letters is a pattern, unless it is escaped by\n * the single quote characters (see below).\n * If the sequence is longer than listed in table (e.g. `EEEEEEEEEEE`)\n * the output will be the same as default pattern for this unit, usually\n * the longest one (in case of ISO weekdays, `EEEE`). Default patterns for units\n * are marked with \"2\" in the last column of the table.\n *\n * `format(new Date(2017, 10, 6), 'MMM') //=> 'Nov'`\n *\n * `format(new Date(2017, 10, 6), 'MMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMM') //=> 'N'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMM') //=> 'November'`\n *\n * `format(new Date(2017, 10, 6), 'MMMMMMM') //=> 'November'`\n *\n * 3. Some patterns could be unlimited length (such as `yyyyyyyy`).\n * The output will be padded with zeros to match the length of the pattern.\n *\n * `format(new Date(2017, 10, 6), 'yyyyyyyy') //=> '00002017'`\n *\n * 4. `QQQQQ` and `qqqqq` could be not strictly numerical in some locales.\n * These tokens represent the shortest form of the quarter.\n *\n * 5. The main difference between `y` and `u` patterns are B.C. years:\n *\n * | Year | `y` | `u` |\n * |------|-----|-----|\n * | AC 1 | 1 | 1 |\n * | BC 1 | 1 | 0 |\n * | BC 2 | 2 | -1 |\n *\n * Also `yy` always returns the last two digits of a year,\n * while `uu` pads single digit years to 2 characters and returns other years unchanged:\n *\n * | Year | `yy` | `uu` |\n * |------|------|------|\n * | 1 | 01 | 01 |\n * | 14 | 14 | 14 |\n * | 376 | 76 | 376 |\n * | 1453 | 53 | 1453 |\n *\n * The same difference is true for local and ISO week-numbering years (`Y` and `R`),\n * except local week-numbering years are dependent on `options.weekStartsOn`\n * and `options.firstWeekContainsDate` (compare [getISOWeekYear](https://date-fns.org/docs/getISOWeekYear)\n * and [getWeekYear](https://date-fns.org/docs/getWeekYear)).\n *\n * 6. Specific non-location timezones are currently unavailable in `date-fns`,\n * so right now these tokens fall back to GMT timezones.\n *\n * 7. These patterns are not in the Unicode Technical Standard #35:\n * - `i`: ISO day of week\n * - `I`: ISO week of year\n * - `R`: ISO week-numbering year\n * - `t`: seconds timestamp\n * - `T`: milliseconds timestamp\n * - `o`: ordinal number modifier\n * - `P`: long localized date\n * - `p`: long localized time\n *\n * 8. `YY` and `YYYY` tokens represent week-numbering years but they are often confused with years.\n * You should enable `options.useAdditionalWeekYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * 9. `D` and `DD` tokens represent days of the year but they are often confused with days of the month.\n * You should enable `options.useAdditionalDayOfYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n * @param format - The string of tokens\n * @param options - An object with options\n *\n * @returns The formatted date string\n *\n * @throws `date` must not be Invalid Date\n * @throws `options.locale` must contain `localize` property\n * @throws `options.locale` must contain `formatLong` property\n * @throws use `yyyy` instead of `YYYY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `yy` instead of `YY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `d` instead of `D` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws use `dd` instead of `DD` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws format string contains an unescaped latin alphabet character\n *\n * @example\n * // Represent 11 February 2014 in middle-endian format:\n * const result = format(new Date(2014, 1, 11), 'MM/dd/yyyy')\n * //=> '02/11/2014'\n *\n * @example\n * // Represent 2 July 2014 in Esperanto:\n * import { eoLocale } from 'date-fns/locale/eo'\n * const result = format(new Date(2014, 6, 2), \"do 'de' MMMM yyyy\", {\n * locale: eoLocale\n * })\n * //=> '2-a de julio 2014'\n *\n * @example\n * // Escape string by single quote characters:\n * const result = format(new Date(2014, 6, 2, 15), \"h 'o''clock'\")\n * //=> \"3 o'clock\"\n */\nexport function format(date, formatStr, options) {\n const defaultOptions = getDefaultOptions();\n const locale = options?.locale ?? defaultOptions.locale ?? defaultLocale;\n\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const originalDate = toDate(date);\n\n if (!isValid(originalDate)) {\n throw new RangeError(\"Invalid time value\");\n }\n\n let parts = formatStr\n .match(longFormattingTokensRegExp)\n .map((substring) => {\n const firstCharacter = substring[0];\n if (firstCharacter === \"p\" || firstCharacter === \"P\") {\n const longFormatter = longFormatters[firstCharacter];\n return longFormatter(substring, locale.formatLong);\n }\n return substring;\n })\n .join(\"\")\n .match(formattingTokensRegExp)\n .map((substring) => {\n // Replace two single quote characters with one single quote character\n if (substring === \"''\") {\n return { isToken: false, value: \"'\" };\n }\n\n const firstCharacter = substring[0];\n if (firstCharacter === \"'\") {\n return { isToken: false, value: cleanEscapedString(substring) };\n }\n\n if (formatters[firstCharacter]) {\n return { isToken: true, value: substring };\n }\n\n if (firstCharacter.match(unescapedLatinCharacterRegExp)) {\n throw new RangeError(\n \"Format string contains an unescaped latin alphabet character `\" +\n firstCharacter +\n \"`\",\n );\n }\n\n return { isToken: false, value: substring };\n });\n\n // invoke localize preprocessor (only for french locales at the moment)\n if (locale.localize.preprocessor) {\n parts = locale.localize.preprocessor(originalDate, parts);\n }\n\n const formatterOptions = {\n firstWeekContainsDate,\n weekStartsOn,\n locale,\n };\n\n return parts\n .map((part) => {\n if (!part.isToken) return part.value;\n\n const token = part.value;\n\n if (\n (!options?.useAdditionalWeekYearTokens &&\n isProtectedWeekYearToken(token)) ||\n (!options?.useAdditionalDayOfYearTokens &&\n isProtectedDayOfYearToken(token))\n ) {\n warnOrThrowProtectedError(token, formatStr, String(date));\n }\n\n const formatter = formatters[token[0]];\n return formatter(originalDate, token, locale.localize, formatterOptions);\n })\n .join(\"\");\n}\n\nfunction cleanEscapedString(input) {\n const matched = input.match(escapedStringRegExp);\n\n if (!matched) {\n return input;\n }\n\n return matched[1].replace(doubleQuoteRegExp, \"'\");\n}\n\n// Fallback for modularized imports:\nexport default format;\n","import { getISOWeekYear } from \"./getISOWeekYear.mjs\";\nimport { startOfISOWeek } from \"./startOfISOWeek.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\n\n/**\n * @name startOfISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Return the start of an ISO week-numbering year for the given date.\n *\n * @description\n * Return the start of an ISO week-numbering year,\n * which always starts 3 days before the year's first Thursday.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The start of an ISO week-numbering year\n *\n * @example\n * // The start of an ISO week-numbering year for 2 July 2005:\n * const result = startOfISOWeekYear(new Date(2005, 6, 2))\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfISOWeekYear(date) {\n const year = getISOWeekYear(date);\n const fourthOfJanuary = constructFrom(date, 0);\n fourthOfJanuary.setFullYear(year, 0, 4);\n fourthOfJanuary.setHours(0, 0, 0, 0);\n return startOfISOWeek(fourthOfJanuary);\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeekYear;\n","import { millisecondsInWeek } from \"./constants.mjs\";\nimport { startOfISOWeek } from \"./startOfISOWeek.mjs\";\nimport { startOfISOWeekYear } from \"./startOfISOWeekYear.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getISOWeek\n * @category ISO Week Helpers\n * @summary Get the ISO week of the given date.\n *\n * @description\n * Get the ISO week of the given date.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The given date\n *\n * @returns The ISO week\n *\n * @example\n * // Which week of the ISO-week numbering year is 2 January 2005?\n * const result = getISOWeek(new Date(2005, 0, 2))\n * //=> 53\n */\nexport function getISOWeek(date) {\n const _date = toDate(date);\n const diff = +startOfISOWeek(_date) - +startOfISOWeekYear(_date);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getISOWeek;\n","import { constructFrom } from \"./constructFrom.mjs\";\nimport { startOfISOWeek } from \"./startOfISOWeek.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name getISOWeekYear\n * @category ISO Week-Numbering Year Helpers\n * @summary Get the ISO week-numbering year of the given date.\n *\n * @description\n * Get the ISO week-numbering year of the given date,\n * which always starts 3 days before the year's first Thursday.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The given date\n *\n * @returns The ISO week-numbering year\n *\n * @example\n * // Which ISO-week numbering year is 2 January 2005?\n * const result = getISOWeekYear(new Date(2005, 0, 2))\n * //=> 2004\n */\nexport function getISOWeekYear(date) {\n const _date = toDate(date);\n const year = _date.getFullYear();\n\n const fourthOfJanuaryOfNextYear = constructFrom(date, 0);\n fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4);\n fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear);\n\n const fourthOfJanuaryOfThisYear = constructFrom(date, 0);\n fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4);\n fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfISOWeek(fourthOfJanuaryOfThisYear);\n\n if (_date.getTime() >= startOfNextYear.getTime()) {\n return year + 1;\n } else if (_date.getTime() >= startOfThisYear.getTime()) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getISOWeekYear;\n","import { constructFrom } from \"./constructFrom.mjs\";\nimport { getWeekYear } from \"./getWeekYear.mjs\";\nimport { startOfWeek } from \"./startOfWeek.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\n\n/**\n * The {@link startOfWeekYear} function options.\n */\n\n/**\n * @name startOfWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Return the start of a local week-numbering year for the given date.\n *\n * @description\n * Return the start of a local week-numbering year.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week-numbering year\n *\n * @example\n * // The start of an a week-numbering year for 2 July 2005 with default settings:\n * const result = startOfWeekYear(new Date(2005, 6, 2))\n * //=> Sun Dec 26 2004 00:00:00\n *\n * @example\n * // The start of a week-numbering year for 2 July 2005\n * // if Monday is the first day of week\n * // and 4 January is always in the first week of the year:\n * const result = startOfWeekYear(new Date(2005, 6, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> Mon Jan 03 2005 00:00:00\n */\nexport function startOfWeekYear(date, options) {\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const year = getWeekYear(date, options);\n const firstWeek = constructFrom(date, 0);\n firstWeek.setFullYear(year, 0, firstWeekContainsDate);\n firstWeek.setHours(0, 0, 0, 0);\n const _date = startOfWeek(firstWeek, options);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeekYear;\n","import { millisecondsInWeek } from \"./constants.mjs\";\nimport { startOfWeek } from \"./startOfWeek.mjs\";\nimport { startOfWeekYear } from \"./startOfWeekYear.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * The {@link getWeek} function options.\n */\n\n/**\n * @name getWeek\n * @category Week Helpers\n * @summary Get the local week index of the given date.\n *\n * @description\n * Get the local week index of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The given date\n * @param options - An object with options\n *\n * @returns The week\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005 with default options?\n * const result = getWeek(new Date(2005, 0, 2))\n * //=> 2\n *\n * @example\n * // Which week of the local week numbering year is 2 January 2005,\n * // if Monday is the first day of the week,\n * // and the first week of the year always contains 4 January?\n * const result = getWeek(new Date(2005, 0, 2), {\n * weekStartsOn: 1,\n * firstWeekContainsDate: 4\n * })\n * //=> 53\n */\n\nexport function getWeek(date, options) {\n const _date = toDate(date);\n const diff = +startOfWeek(_date, options) - +startOfWeekYear(_date, options);\n\n // Round the number of weeks to the nearest integer because the number of\n // milliseconds in a week is not constant (e.g. it's different in the week of\n // the daylight saving time clock shift).\n return Math.round(diff / millisecondsInWeek) + 1;\n}\n\n// Fallback for modularized imports:\nexport default getWeek;\n","import { constructFrom } from \"./constructFrom.mjs\";\nimport { startOfWeek } from \"./startOfWeek.mjs\";\nimport { toDate } from \"./toDate.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\n\n/**\n * The {@link getWeekYear} function options.\n */\n\n/**\n * @name getWeekYear\n * @category Week-Numbering Year Helpers\n * @summary Get the local week-numbering year of the given date.\n *\n * @description\n * Get the local week-numbering year of the given date.\n * The exact calculation depends on the values of\n * `options.weekStartsOn` (which is the index of the first day of the week)\n * and `options.firstWeekContainsDate` (which is the day of January, which is always in\n * the first week of the week-numbering year)\n *\n * Week numbering: https://en.wikipedia.org/wiki/Week#The_ISO_week_date_system\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The given date\n * @param options - An object with options.\n *\n * @returns The local week-numbering year\n *\n * @example\n * // Which week numbering year is 26 December 2004 with the default settings?\n * const result = getWeekYear(new Date(2004, 11, 26))\n * //=> 2005\n *\n * @example\n * // Which week numbering year is 26 December 2004 if week starts on Saturday?\n * const result = getWeekYear(new Date(2004, 11, 26), { weekStartsOn: 6 })\n * //=> 2004\n *\n * @example\n * // Which week numbering year is 26 December 2004 if the first week contains 4 January?\n * const result = getWeekYear(new Date(2004, 11, 26), { firstWeekContainsDate: 4 })\n * //=> 2004\n */\nexport function getWeekYear(date, options) {\n const _date = toDate(date);\n const year = _date.getFullYear();\n\n const defaultOptions = getDefaultOptions();\n const firstWeekContainsDate =\n options?.firstWeekContainsDate ??\n options?.locale?.options?.firstWeekContainsDate ??\n defaultOptions.firstWeekContainsDate ??\n defaultOptions.locale?.options?.firstWeekContainsDate ??\n 1;\n\n const firstWeekOfNextYear = constructFrom(date, 0);\n firstWeekOfNextYear.setFullYear(year + 1, 0, firstWeekContainsDate);\n firstWeekOfNextYear.setHours(0, 0, 0, 0);\n const startOfNextYear = startOfWeek(firstWeekOfNextYear, options);\n\n const firstWeekOfThisYear = constructFrom(date, 0);\n firstWeekOfThisYear.setFullYear(year, 0, firstWeekContainsDate);\n firstWeekOfThisYear.setHours(0, 0, 0, 0);\n const startOfThisYear = startOfWeek(firstWeekOfThisYear, options);\n\n if (_date.getTime() >= startOfNextYear.getTime()) {\n return year + 1;\n } else if (_date.getTime() >= startOfThisYear.getTime()) {\n return year;\n } else {\n return year - 1;\n }\n}\n\n// Fallback for modularized imports:\nexport default getWeekYear;\n","/**\n * @name isDate\n * @category Common Helpers\n * @summary Is the given value a date?\n *\n * @description\n * Returns true if the given value is an instance of Date. The function works for dates transferred across iframes.\n *\n * @param value - The value to check\n *\n * @returns True if the given value is a date\n *\n * @example\n * // For a valid date:\n * const result = isDate(new Date())\n * //=> true\n *\n * @example\n * // For an invalid date:\n * const result = isDate(new Date(NaN))\n * //=> true\n *\n * @example\n * // For some value:\n * const result = isDate('2014-02-31')\n * //=> false\n *\n * @example\n * // For an object:\n * const result = isDate({})\n * //=> false\n */\nexport function isDate(value) {\n return (\n value instanceof Date ||\n (typeof value === \"object\" &&\n Object.prototype.toString.call(value) === \"[object Date]\")\n );\n}\n\n// Fallback for modularized imports:\nexport default isDate;\n","import { isDate } from \"./isDate.mjs\";\nimport { toDate } from \"./toDate.mjs\";\n\n/**\n * @name isValid\n * @category Common Helpers\n * @summary Is the given date valid?\n *\n * @description\n * Returns false if argument is Invalid Date and true otherwise.\n * Argument is converted to Date using `toDate`. See [toDate](https://date-fns.org/docs/toDate)\n * Invalid Date is a Date, whose time value is NaN.\n *\n * Time value of Date: http://es5.github.io/#x15.9.1.1\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to check\n *\n * @returns The date is valid\n *\n * @example\n * // For the valid date:\n * const result = isValid(new Date(2014, 1, 31))\n * //=> true\n *\n * @example\n * // For the value, convertable into a date:\n * const result = isValid(1393804800000)\n * //=> true\n *\n * @example\n * // For the invalid date:\n * const result = isValid(new Date(''))\n * //=> false\n */\nexport function isValid(date) {\n if (!isDate(date) && typeof date !== \"number\") {\n return false;\n }\n const _date = toDate(date);\n return !isNaN(Number(_date));\n}\n\n// Fallback for modularized imports:\nexport default isValid;\n","const formatDistanceLocale = {\n lessThanXSeconds: {\n one: \"less than a second\",\n other: \"less than {{count}} seconds\",\n },\n\n xSeconds: {\n one: \"1 second\",\n other: \"{{count}} seconds\",\n },\n\n halfAMinute: \"half a minute\",\n\n lessThanXMinutes: {\n one: \"less than a minute\",\n other: \"less than {{count}} minutes\",\n },\n\n xMinutes: {\n one: \"1 minute\",\n other: \"{{count}} minutes\",\n },\n\n aboutXHours: {\n one: \"about 1 hour\",\n other: \"about {{count}} hours\",\n },\n\n xHours: {\n one: \"1 hour\",\n other: \"{{count}} hours\",\n },\n\n xDays: {\n one: \"1 day\",\n other: \"{{count}} days\",\n },\n\n aboutXWeeks: {\n one: \"about 1 week\",\n other: \"about {{count}} weeks\",\n },\n\n xWeeks: {\n one: \"1 week\",\n other: \"{{count}} weeks\",\n },\n\n aboutXMonths: {\n one: \"about 1 month\",\n other: \"about {{count}} months\",\n },\n\n xMonths: {\n one: \"1 month\",\n other: \"{{count}} months\",\n },\n\n aboutXYears: {\n one: \"about 1 year\",\n other: \"about {{count}} years\",\n },\n\n xYears: {\n one: \"1 year\",\n other: \"{{count}} years\",\n },\n\n overXYears: {\n one: \"over 1 year\",\n other: \"over {{count}} years\",\n },\n\n almostXYears: {\n one: \"almost 1 year\",\n other: \"almost {{count}} years\",\n },\n};\n\nexport const formatDistance = (token, count, options) => {\n let result;\n\n const tokenValue = formatDistanceLocale[token];\n if (typeof tokenValue === \"string\") {\n result = tokenValue;\n } else if (count === 1) {\n result = tokenValue.one;\n } else {\n result = tokenValue.other.replace(\"{{count}}\", count.toString());\n }\n\n if (options?.addSuffix) {\n if (options.comparison && options.comparison > 0) {\n return \"in \" + result;\n } else {\n return result + \" ago\";\n }\n }\n\n return result;\n};\n","export function buildFormatLongFn(args) {\n return (options = {}) => {\n // TODO: Remove String()\n const width = options.width ? String(options.width) : args.defaultWidth;\n const format = args.formats[width] || args.formats[args.defaultWidth];\n return format;\n };\n}\n","import { buildFormatLongFn } from \"../../_lib/buildFormatLongFn.mjs\";\n\nconst dateFormats = {\n full: \"EEEE, MMMM do, y\",\n long: \"MMMM do, y\",\n medium: \"MMM d, y\",\n short: \"MM/dd/yyyy\",\n};\n\nconst timeFormats = {\n full: \"h:mm:ss a zzzz\",\n long: \"h:mm:ss a z\",\n medium: \"h:mm:ss a\",\n short: \"h:mm a\",\n};\n\nconst dateTimeFormats = {\n full: \"{{date}} 'at' {{time}}\",\n long: \"{{date}} 'at' {{time}}\",\n medium: \"{{date}}, {{time}}\",\n short: \"{{date}}, {{time}}\",\n};\n\nexport const formatLong = {\n date: buildFormatLongFn({\n formats: dateFormats,\n defaultWidth: \"full\",\n }),\n\n time: buildFormatLongFn({\n formats: timeFormats,\n defaultWidth: \"full\",\n }),\n\n dateTime: buildFormatLongFn({\n formats: dateTimeFormats,\n defaultWidth: \"full\",\n }),\n};\n","const formatRelativeLocale = {\n lastWeek: \"'last' eeee 'at' p\",\n yesterday: \"'yesterday at' p\",\n today: \"'today at' p\",\n tomorrow: \"'tomorrow at' p\",\n nextWeek: \"eeee 'at' p\",\n other: \"P\",\n};\n\nexport const formatRelative = (token, _date, _baseDate, _options) =>\n formatRelativeLocale[token];\n","/* eslint-disable no-unused-vars */\n\n/**\n * The localize function argument callback which allows to convert raw value to\n * the actual type.\n *\n * @param value - The value to convert\n *\n * @returns The converted value\n */\n\n/**\n * The map of localized values for each width.\n */\n\n/**\n * The index type of the locale unit value. It types conversion of units of\n * values that don't start at 0 (i.e. quarters).\n */\n\n/**\n * Converts the unit value to the tuple of values.\n */\n\n/**\n * The tuple of localized era values. The first element represents BC,\n * the second element represents AD.\n */\n\n/**\n * The tuple of localized quarter values. The first element represents Q1.\n */\n\n/**\n * The tuple of localized day values. The first element represents Sunday.\n */\n\n/**\n * The tuple of localized month values. The first element represents January.\n */\n\nexport function buildLocalizeFn(args) {\n return (value, options) => {\n const context = options?.context ? String(options.context) : \"standalone\";\n\n let valuesArray;\n if (context === \"formatting\" && args.formattingValues) {\n const defaultWidth = args.defaultFormattingWidth || args.defaultWidth;\n const width = options?.width ? String(options.width) : defaultWidth;\n\n valuesArray =\n args.formattingValues[width] || args.formattingValues[defaultWidth];\n } else {\n const defaultWidth = args.defaultWidth;\n const width = options?.width ? String(options.width) : args.defaultWidth;\n\n valuesArray = args.values[width] || args.values[defaultWidth];\n }\n const index = args.argumentCallback ? args.argumentCallback(value) : value;\n\n // @ts-expect-error - For some reason TypeScript just don't want to match it, no matter how hard we try. I challenge you to try to remove it!\n return valuesArray[index];\n };\n}\n","import { buildLocalizeFn } from \"../../_lib/buildLocalizeFn.mjs\";\n\nconst eraValues = {\n narrow: [\"B\", \"A\"],\n abbreviated: [\"BC\", \"AD\"],\n wide: [\"Before Christ\", \"Anno Domini\"],\n};\n\nconst quarterValues = {\n narrow: [\"1\", \"2\", \"3\", \"4\"],\n abbreviated: [\"Q1\", \"Q2\", \"Q3\", \"Q4\"],\n wide: [\"1st quarter\", \"2nd quarter\", \"3rd quarter\", \"4th quarter\"],\n};\n\n// Note: in English, the names of days of the week and months are capitalized.\n// If you are making a new locale based on this one, check if the same is true for the language you're working on.\n// Generally, formatted dates should look like they are in the middle of a sentence,\n// e.g. in Spanish language the weekdays and months should be in the lowercase.\nconst monthValues = {\n narrow: [\"J\", \"F\", \"M\", \"A\", \"M\", \"J\", \"J\", \"A\", \"S\", \"O\", \"N\", \"D\"],\n abbreviated: [\n \"Jan\",\n \"Feb\",\n \"Mar\",\n \"Apr\",\n \"May\",\n \"Jun\",\n \"Jul\",\n \"Aug\",\n \"Sep\",\n \"Oct\",\n \"Nov\",\n \"Dec\",\n ],\n\n wide: [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\",\n ],\n};\n\nconst dayValues = {\n narrow: [\"S\", \"M\", \"T\", \"W\", \"T\", \"F\", \"S\"],\n short: [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"],\n abbreviated: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n wide: [\n \"Sunday\",\n \"Monday\",\n \"Tuesday\",\n \"Wednesday\",\n \"Thursday\",\n \"Friday\",\n \"Saturday\",\n ],\n};\n\nconst dayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"morning\",\n afternoon: \"afternoon\",\n evening: \"evening\",\n night: \"night\",\n },\n};\n\nconst formattingDayPeriodValues = {\n narrow: {\n am: \"a\",\n pm: \"p\",\n midnight: \"mi\",\n noon: \"n\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n abbreviated: {\n am: \"AM\",\n pm: \"PM\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n wide: {\n am: \"a.m.\",\n pm: \"p.m.\",\n midnight: \"midnight\",\n noon: \"noon\",\n morning: \"in the morning\",\n afternoon: \"in the afternoon\",\n evening: \"in the evening\",\n night: \"at night\",\n },\n};\n\nconst ordinalNumber = (dirtyNumber, _options) => {\n const number = Number(dirtyNumber);\n\n // If ordinal numbers depend on context, for example,\n // if they are different for different grammatical genders,\n // use `options.unit`.\n //\n // `unit` can be 'year', 'quarter', 'month', 'week', 'date', 'dayOfYear',\n // 'day', 'hour', 'minute', 'second'.\n\n const rem100 = number % 100;\n if (rem100 > 20 || rem100 < 10) {\n switch (rem100 % 10) {\n case 1:\n return number + \"st\";\n case 2:\n return number + \"nd\";\n case 3:\n return number + \"rd\";\n }\n }\n return number + \"th\";\n};\n\nexport const localize = {\n ordinalNumber,\n\n era: buildLocalizeFn({\n values: eraValues,\n defaultWidth: \"wide\",\n }),\n\n quarter: buildLocalizeFn({\n values: quarterValues,\n defaultWidth: \"wide\",\n argumentCallback: (quarter) => quarter - 1,\n }),\n\n month: buildLocalizeFn({\n values: monthValues,\n defaultWidth: \"wide\",\n }),\n\n day: buildLocalizeFn({\n values: dayValues,\n defaultWidth: \"wide\",\n }),\n\n dayPeriod: buildLocalizeFn({\n values: dayPeriodValues,\n defaultWidth: \"wide\",\n formattingValues: formattingDayPeriodValues,\n defaultFormattingWidth: \"wide\",\n }),\n};\n","export function buildMatchFn(args) {\n return (string, options = {}) => {\n const width = options.width;\n\n const matchPattern =\n (width && args.matchPatterns[width]) ||\n args.matchPatterns[args.defaultMatchWidth];\n const matchResult = string.match(matchPattern);\n\n if (!matchResult) {\n return null;\n }\n const matchedString = matchResult[0];\n\n const parsePatterns =\n (width && args.parsePatterns[width]) ||\n args.parsePatterns[args.defaultParseWidth];\n\n const key = Array.isArray(parsePatterns)\n ? findIndex(parsePatterns, (pattern) => pattern.test(matchedString))\n : // eslint-disable-next-line @typescript-eslint/no-explicit-any -- I challange you to fix the type\n findKey(parsePatterns, (pattern) => pattern.test(matchedString));\n\n let value;\n\n value = args.valueCallback ? args.valueCallback(key) : key;\n value = options.valueCallback\n ? // eslint-disable-next-line @typescript-eslint/no-explicit-any -- I challange you to fix the type\n options.valueCallback(value)\n : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n\nfunction findKey(object, predicate) {\n for (const key in object) {\n if (\n Object.prototype.hasOwnProperty.call(object, key) &&\n predicate(object[key])\n ) {\n return key;\n }\n }\n return undefined;\n}\n\nfunction findIndex(array, predicate) {\n for (let key = 0; key < array.length; key++) {\n if (predicate(array[key])) {\n return key;\n }\n }\n return undefined;\n}\n","export function buildMatchPatternFn(args) {\n return (string, options = {}) => {\n const matchResult = string.match(args.matchPattern);\n if (!matchResult) return null;\n const matchedString = matchResult[0];\n\n const parseResult = string.match(args.parsePattern);\n if (!parseResult) return null;\n let value = args.valueCallback\n ? args.valueCallback(parseResult[0])\n : parseResult[0];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- I challange you to fix the type\n value = options.valueCallback ? options.valueCallback(value) : value;\n\n const rest = string.slice(matchedString.length);\n\n return { value, rest };\n };\n}\n","import { buildMatchFn } from \"../../_lib/buildMatchFn.mjs\";\nimport { buildMatchPatternFn } from \"../../_lib/buildMatchPatternFn.mjs\";\n\nconst matchOrdinalNumberPattern = /^(\\d+)(th|st|nd|rd)?/i;\nconst parseOrdinalNumberPattern = /\\d+/i;\n\nconst matchEraPatterns = {\n narrow: /^(b|a)/i,\n abbreviated: /^(b\\.?\\s?c\\.?|b\\.?\\s?c\\.?\\s?e\\.?|a\\.?\\s?d\\.?|c\\.?\\s?e\\.?)/i,\n wide: /^(before christ|before common era|anno domini|common era)/i,\n};\nconst parseEraPatterns = {\n any: [/^b/i, /^(a|c)/i],\n};\n\nconst matchQuarterPatterns = {\n narrow: /^[1234]/i,\n abbreviated: /^q[1234]/i,\n wide: /^[1234](th|st|nd|rd)? quarter/i,\n};\nconst parseQuarterPatterns = {\n any: [/1/i, /2/i, /3/i, /4/i],\n};\n\nconst matchMonthPatterns = {\n narrow: /^[jfmasond]/i,\n abbreviated: /^(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)/i,\n wide: /^(january|february|march|april|may|june|july|august|september|october|november|december)/i,\n};\nconst parseMonthPatterns = {\n narrow: [\n /^j/i,\n /^f/i,\n /^m/i,\n /^a/i,\n /^m/i,\n /^j/i,\n /^j/i,\n /^a/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n\n any: [\n /^ja/i,\n /^f/i,\n /^mar/i,\n /^ap/i,\n /^may/i,\n /^jun/i,\n /^jul/i,\n /^au/i,\n /^s/i,\n /^o/i,\n /^n/i,\n /^d/i,\n ],\n};\n\nconst matchDayPatterns = {\n narrow: /^[smtwf]/i,\n short: /^(su|mo|tu|we|th|fr|sa)/i,\n abbreviated: /^(sun|mon|tue|wed|thu|fri|sat)/i,\n wide: /^(sunday|monday|tuesday|wednesday|thursday|friday|saturday)/i,\n};\nconst parseDayPatterns = {\n narrow: [/^s/i, /^m/i, /^t/i, /^w/i, /^t/i, /^f/i, /^s/i],\n any: [/^su/i, /^m/i, /^tu/i, /^w/i, /^th/i, /^f/i, /^sa/i],\n};\n\nconst matchDayPeriodPatterns = {\n narrow: /^(a|p|mi|n|(in the|at) (morning|afternoon|evening|night))/i,\n any: /^([ap]\\.?\\s?m\\.?|midnight|noon|(in the|at) (morning|afternoon|evening|night))/i,\n};\nconst parseDayPeriodPatterns = {\n any: {\n am: /^a/i,\n pm: /^p/i,\n midnight: /^mi/i,\n noon: /^no/i,\n morning: /morning/i,\n afternoon: /afternoon/i,\n evening: /evening/i,\n night: /night/i,\n },\n};\n\nexport const match = {\n ordinalNumber: buildMatchPatternFn({\n matchPattern: matchOrdinalNumberPattern,\n parsePattern: parseOrdinalNumberPattern,\n valueCallback: (value) => parseInt(value, 10),\n }),\n\n era: buildMatchFn({\n matchPatterns: matchEraPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseEraPatterns,\n defaultParseWidth: \"any\",\n }),\n\n quarter: buildMatchFn({\n matchPatterns: matchQuarterPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseQuarterPatterns,\n defaultParseWidth: \"any\",\n valueCallback: (index) => index + 1,\n }),\n\n month: buildMatchFn({\n matchPatterns: matchMonthPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseMonthPatterns,\n defaultParseWidth: \"any\",\n }),\n\n day: buildMatchFn({\n matchPatterns: matchDayPatterns,\n defaultMatchWidth: \"wide\",\n parsePatterns: parseDayPatterns,\n defaultParseWidth: \"any\",\n }),\n\n dayPeriod: buildMatchFn({\n matchPatterns: matchDayPeriodPatterns,\n defaultMatchWidth: \"any\",\n parsePatterns: parseDayPeriodPatterns,\n defaultParseWidth: \"any\",\n }),\n};\n","import { formatDistance } from \"./en-US/_lib/formatDistance.mjs\";\nimport { formatLong } from \"./en-US/_lib/formatLong.mjs\";\nimport { formatRelative } from \"./en-US/_lib/formatRelative.mjs\";\nimport { localize } from \"./en-US/_lib/localize.mjs\";\nimport { match } from \"./en-US/_lib/match.mjs\";\n\n/**\n * @category Locales\n * @summary English locale (United States).\n * @language English\n * @iso-639-2 eng\n * @author Sasha Koss [@kossnocorp](https://github.com/kossnocorp)\n * @author Lesha Koss [@leshakoss](https://github.com/leshakoss)\n */\nexport const enUS = {\n code: \"en-US\",\n formatDistance: formatDistance,\n formatLong: formatLong,\n formatRelative: formatRelative,\n localize: localize,\n match: match,\n options: {\n weekStartsOn: 0 /* Sunday */,\n firstWeekContainsDate: 1,\n },\n};\n\n// Fallback for modularized imports:\nexport default enUS;\n","import { startOfWeek } from \"./startOfWeek.mjs\";\n\n/**\n * @name startOfISOWeek\n * @category ISO Week Helpers\n * @summary Return the start of an ISO week for the given date.\n *\n * @description\n * Return the start of an ISO week for the given date.\n * The result will be in the local timezone.\n *\n * ISO week-numbering year: http://en.wikipedia.org/wiki/ISO_week_date\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The start of an ISO week\n *\n * @example\n * // The start of an ISO week for 2 September 2014 11:55:00:\n * const result = startOfISOWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfISOWeek(date) {\n return startOfWeek(date, { weekStartsOn: 1 });\n}\n\n// Fallback for modularized imports:\nexport default startOfISOWeek;\n","import { toDate } from \"./toDate.mjs\";\nimport { getDefaultOptions } from \"./_lib/defaultOptions.mjs\";\n\n/**\n * The {@link startOfWeek} function options.\n */\n\n/**\n * @name startOfWeek\n * @category Week Helpers\n * @summary Return the start of a week for the given date.\n *\n * @description\n * Return the start of a week for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n * @param options - An object with options\n *\n * @returns The start of a week\n *\n * @example\n * // The start of a week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0))\n * //=> Sun Aug 31 2014 00:00:00\n *\n * @example\n * // If the week starts on Monday, the start of the week for 2 September 2014 11:55:00:\n * const result = startOfWeek(new Date(2014, 8, 2, 11, 55, 0), { weekStartsOn: 1 })\n * //=> Mon Sep 01 2014 00:00:00\n */\nexport function startOfWeek(date, options) {\n const defaultOptions = getDefaultOptions();\n const weekStartsOn =\n options?.weekStartsOn ??\n options?.locale?.options?.weekStartsOn ??\n defaultOptions.weekStartsOn ??\n defaultOptions.locale?.options?.weekStartsOn ??\n 0;\n\n const _date = toDate(date);\n const day = _date.getDay();\n const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n\n _date.setDate(_date.getDate() - diff);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfWeek;\n","import { toDate } from \"./toDate.mjs\";\nimport { constructFrom } from \"./constructFrom.mjs\";\n\n/**\n * @name startOfYear\n * @category Year Helpers\n * @summary Return the start of a year for the given date.\n *\n * @description\n * Return the start of a year for the given date.\n * The result will be in the local timezone.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The original date\n *\n * @returns The start of a year\n *\n * @example\n * // The start of a year for 2 September 2014 11:55:00:\n * const result = startOfYear(new Date(2014, 8, 2, 11, 55, 00))\n * //=> Wed Jan 01 2014 00:00:00\n */\nexport function startOfYear(date) {\n const cleanDate = toDate(date);\n const _date = constructFrom(date, 0);\n _date.setFullYear(cleanDate.getFullYear(), 0, 1);\n _date.setHours(0, 0, 0, 0);\n return _date;\n}\n\n// Fallback for modularized imports:\nexport default startOfYear;\n"],"names":["getModifierKey","opts","enabled","modifierKey","keyPressed","key","event","keyNotPressed","directionEnabled","mode","dir","chart","undefined","indexOf","directionsEnabled","x","y","getEnabledScalesByPoint","options","point","scaleMode","overScaleMode","scale","getScaleUnderPoint","scales","scaleIds","Object","keys","i","length","top","bottom","left","right","scaleEnabled","overScaleEnabled","axis","enabledScales","chart_js_helpers__WEBPACK_IMPORTED_MODULE_1__","F","scaleItem","push","chartStates","WeakMap","getState","state","get","originalScaleLimits","updatedScaleLimits","handlers","panDelta","set","zoomDelta","zoom","center","range","max","min","newRange","centerPoint","isHorizontal","minPercent","Math","getValueForPixel","getLimit","scaleLimits","prop","fallback","limit","original","id","v","updateRange","limits","scaleOpts","minRange","minLimit","Infinity","maxLimit","offset","parse","integerChange","isNaN","round","OFFSETS","second","minute","hour","day","week","month","quarter","year","panNumericalScale","delta","canZoom","prevStart","prevEnd","time","newMin","getPixelForValue","newMax","panNonLinearScale","zoomFunctions","category","existCategoryFromMaxZoom","maxIndex","labels","getLabels","default","zoomRectFunctions","from","to","getRange","pixel0","pixel1","v0","v1","panFunctions","applied","lastLabelIndex","stepDelta","scaleLength","width","height","stepSize","abs","logarithmic","timeseries","removeMissingScales","opt","storeOriginalScaleLimits","shouldUpdateScaleLimits","previous","doZoom","amount","fn","type","Q","doZoomRect","transition","focalPoint","getCenter","ca","chartArea","zoomOptions","xEnabled","yEnabled","update","onZoom","zoomRect","p0","p1","panScale","storedDelta","s","pan","panOptions","onPan","getInitialScaleBounds","scaleBounds","scaleId","removeHandler","handler","target","removeEventListener","addHandler","oldHandler","addEventListener","mouseMove","dragStart","dragging","dragEnd","keyDown","zoomStart","onZoomStart","onZoomRejected","z","mouseDown","button","drag","canvas","window","document","computeDragRect","beginPointEvent","endPointEvent","chartWidth","chartHeight","beginPoint","endPoint","zoomX","zoomY","mouseUp","onZoomComplete","threshold","rect","distanceX","distanceY","distance","sqrt","setTimeout","wheel","wheelPreconditions","cancelable","preventDefault","deltaY","getBoundingClientRect","speed","clientX","clientY","handlePinch","e","pointers","zoomPercent","pinch","pinchAxes","pinchX","pinchY","p","handlePan","panning","deltaX","panScales","hammers","draw","caller","dragOptions","drawTime","ctx","save","beginPath","fillStyle","backgroundColor","fillRect","borderWidth","lineWidth","strokeStyle","borderColor","strokeRect","restore","plugin","version","defaults","start","_args","prototype","hasOwnProperty","call","console","warn","hammerjs__WEBPACK_IMPORTED_MODULE_0___default","startHammer","mc","Manager","add","Pinch","on","Pan","enable","recognizer","srcEvent","pointerType","onPanRejected","startPan","onPanStart","clearTimeout","panEndTimeout","onPanComplete","args","zoomScale","resetZoom","scaleOptions","getZoomLevel","origRange","getOriginalRange","level","isZoomedOrPanned","originalMin","originalMax","beforeEvent","beforeUpdate","addListeners","wheelOptions","addDebouncedHandler","name","delay","timeout","ownerDocument","beforeDatasetsDraw","afterDatasetsDraw","beforeDraw","afterDraw","stop","stopHammer","remove","destroy","delete","__WEBPACK_AMD_DEFINE_RESULT__","exportName","assign","VENDOR_PREFIXES","TEST_ELEMENT","createElement","now","Date","setTimeoutContext","context","bindFn","invokeArrayArg","arg","Array","isArray","each","obj","iterator","forEach","deprecate","method","message","deprecationMessage","stack","replace","log","apply","arguments","output","index","source","nextKey","extend","dest","src","merge","inherit","child","base","properties","childP","baseP","create","constructor","_super","boolOrFn","val","addEventListeners","types","splitStr","removeEventListeners","hasParent","node","parent","parentNode","inStr","str","find","trim","split","inArray","findByKey","toArray","slice","uniqueArray","sort","results","values","a","b","prefixed","property","prefix","camelProp","toUpperCase","_uniqueId","getWindowForElement","element","doc","defaultView","parentWindow","SUPPORT_TOUCH","SUPPORT_POINTER_EVENTS","SUPPORT_ONLY_TOUCH","MOBILE_REGEX","test","navigator","userAgent","INPUT_TYPE_TOUCH","INPUT_TYPE_MOUSE","PROPS_XY","PROPS_CLIENT_XY","Input","manager","callback","self","inputTarget","domHandler","ev","init","inputHandler","eventType","input","session","pointersLength","firstInput","firstMultiple","offsetCenter","prevDelta","prevInput","overallVelocity","pointersLen","changedPointersLen","changedPointers","isFirst","isFinal","simpleCloneInputData","timeStamp","deltaTime","angle","getAngle","getDistance","offsetDelta","offsetDirection","getDirection","getVelocity","overallVelocityX","overallVelocityY","end","rotation","maxPointers","computeIntervalInputData","velocity","velocityX","velocityY","direction","last","lastInterval","emit","recognize","p2","props","atan2","PI","evEl","evTarget","evWin","MOUSE_INPUT_MAP","mousedown","mousemove","mouseup","MouseInput","pressed","which","POINTER_INPUT_MAP","pointerdown","pointermove","pointerup","pointercancel","pointerout","IE10_POINTER_TYPE_ENUM","POINTER_ELEMENT_EVENTS","POINTER_WINDOW_EVENTS","PointerEventInput","store","pointerEvents","MSPointerEvent","PointerEvent","removePointer","toLowerCase","isTouch","storeIndex","pointerId","INPUT_END","splice","SINGLE_TOUCH_INPUT_MAP","touchstart","touchmove","touchend","touchcancel","SingleTouchInput","started","normalizeSingleTouches","all","touches","changed","changedTouches","concat","TOUCH_INPUT_MAP","TouchInput","targetIds","getTouches","allTouches","identifier","targetTouches","changedTargetTouches","filter","touch","TouchMouseInput","mouse","primaryTouch","lastTouches","recordTouches","eventData","setLastTouch","lastTouch","lts","isSyntheticEvent","t","dx","dy","inputEvent","inputData","isMouse","sourceCapabilities","firesTouchEvents","PREFIXED_TOUCH_ACTION","style","NATIVE_TOUCH_ACTION","TOUCH_ACTION_COMPUTE","TOUCH_ACTION_AUTO","TOUCH_ACTION_MANIPULATION","TOUCH_ACTION_NONE","TOUCH_ACTION_PAN_X","TOUCH_ACTION_PAN_Y","TOUCH_ACTION_MAP","getTouchActionProps","touchMap","cssSupports","CSS","supports","TouchAction","value","Recognizer","val1","simultaneous","requireFail","stateStr","directionStr","getRecognizerByNameIfManager","otherRecognizer","AttrRecognizer","PanRecognizer","pX","pY","PinchRecognizer","PressRecognizer","_timer","_input","RotateRecognizer","SwipeRecognizer","TapRecognizer","pTime","pCenter","count","Hammer","val2","recognizers","preset","inputClass","oldCssProps","touchAction","toggleCssProps","item","recognizeWith","requireFailure","cssProps","compute","actions","getTouchAction","cleanTouchActions","hasPanX","hasPanY","join","preventDefaults","prevented","hasNone","isTapPointer","isTapMovement","isTapTouchTime","preventSrc","dropRecognizeWith","dropRequireFailure","hasRequireFailures","canRecognizeWith","additionalEvent","tryEmit","canEmit","inputDataClone","reset","STATE_RECOGNIZED","process","STATE_BEGAN","attrTest","optionPointers","isRecognized","isValid","DIRECTION_HORIZONTAL","DIRECTION_LEFT","DIRECTION_UP","directionTest","hasMoved","inOut","validPointers","validMovement","validTime","taps","interval","posThreshold","validTouchTime","failTimeout","validInterval","validMultiTap","tapCount","VERSION","domEvents","userSelect","touchSelect","touchCallout","contentZooming","userDrag","tapHighlightColor","force","stopped","curRecognizer","existing","events","off","data","gestureEvent","createEvent","initEvent","gesture","dispatchEvent","INPUT_START","INPUT_MOVE","INPUT_CANCEL","STATE_POSSIBLE","STATE_CHANGED","STATE_ENDED","STATE_CANCELLED","STATE_FAILED","DIRECTION_NONE","DIRECTION_RIGHT","DIRECTION_DOWN","DIRECTION_VERTICAL","DIRECTION_ALL","Tap","Swipe","Rotate","Press","freeGlobal","exports","__webpack_require__","module","_default","getImageProps","imgProps","getImgProps","defaultLoader","imgConf","entries","Image","names","_attachContext","proxy","subProxy","descriptorDefaults","Proxy","_cacheable","_proxy","_context","_subProxy","_stack","Set","_descriptors","setContext","override","scope","deleteProperty","receiver","_cached","_resolveWithContext","descriptors","isFunction","isScriptable","_resolveScriptable","getValue","has","needsSubResolver","createSubResolver","_scopes","_resolveArray","isIndexable","isObject","arr","scopes","resolver","getOwnPropertyDescriptor","allKeys","Reflect","enumerable","configurable","getPrototypeOf","ownKeys","lim","l","h","p2b","n2b","b2n","n2p","map$1","A","B","C","D","E","c","d","f","hex","h1","h2","eq","isShort","r","g","alpha","HUE_RE","hsl2rgbn","n","k","hsv2rgbn","hwb2rgbn","w","rgb","rgb2hsl","calln","map","hue","Z","Y","X","W","V","U","T","S","R","P","O","N","M","L","K","G","H","I","J","names$1","OiceXe","antiquewEte","aqua","aquamarRe","azuY","beige","bisque","black","blanKedOmond","Xe","XeviTet","bPwn","burlywood","caMtXe","KartYuse","KocTate","cSO","cSnflowerXe","cSnsilk","crimson","cyan","xXe","xcyan","xgTMnPd","xWay","xgYF","xgYy","xkhaki","xmagFta","xTivegYF","xSange","xScEd","xYd","xsOmon","xsHgYF","xUXe","xUWay","xUgYy","xQe","xviTet","dAppRk","dApskyXe","dimWay","dimgYy","dodgerXe","fiYbrick","flSOwEte","foYstWAn","fuKsia","gaRsbSo","ghostwEte","gTd","gTMnPd","Way","gYF","gYFLw","gYy","honeyMw","hotpRk","RdianYd","Rdigo","ivSy","khaki","lavFMr","lavFMrXsh","lawngYF","NmoncEffon","ZXe","ZcSO","Zcyan","ZgTMnPdLw","ZWay","ZgYF","ZgYy","ZpRk","ZsOmon","ZsHgYF","ZskyXe","ZUWay","ZUgYy","ZstAlXe","ZLw","lime","limegYF","lRF","magFta","maPon","VaquamarRe","VXe","VScEd","VpurpN","VsHgYF","VUXe","VsprRggYF","VQe","VviTetYd","midnightXe","mRtcYam","mistyPse","moccasR","navajowEte","navy","Tdlace","Tive","TivedBb","Sange","SangeYd","ScEd","pOegTMnPd","pOegYF","pOeQe","pOeviTetYd","papayawEp","pHKpuff","peru","pRk","plum","powMrXe","purpN","YbeccapurpN","Yd","Psybrown","PyOXe","saddNbPwn","sOmon","sandybPwn","sHgYF","sHshell","siFna","silver","skyXe","UXe","UWay","UgYy","snow","sprRggYF","stAlXe","tan","teO","tEstN","tomato","Qe","viTet","JHt","wEte","wEtesmoke","Lw","LwgYF","RGB_RE","pow","modHSL","ratio","tmp","clone","proto","fromObject","Color","ret","len","hexParse","nameParse","unpack","j","ok","nk","unpacked","tkeys","parseInt","transparent","charAt","rgbParse","m","exec","hueParse","_rgb","_valid","valid","rgbString","hexString","hslString","mix","color","weight","w2","c1","c2","w1","interpolate","rgb1","rgb2","clearer","greyscale","opaquer","negate","lighten","darken","saturate","desaturate","rotate","deg","noop","uid","isNullOrUndef","toString","isNumberFinite","Number","isFinite","finiteOrDefault","defaultValue","valueOrDefault","toPercentage","dimension","endsWith","parseFloat","toDimension","thisArg","loopable","reverse","_elementsEqual","a0","a1","ilen","datasetIndex","helpers_segment_clone","klen","isValidKey","_merger","tval","sval","current","sources","merger","mergeIf","_mergerIf","keyResolvers","o","resolveObjectKey","_getKeyResolver","_splitKey","parts","part","_capitalize","defined","setsEqual","size","_isClickEvent","TAU","PITAU","INFINITY","POSITIVE_INFINITY","RAD_PER_DEG","HALF_PI","QUARTER_PI","TWO_THIRDS_PI","log10","sign","almostEquals","epsilon","niceNum","roundedRange","niceRange","floor","fraction","niceFraction","_factorize","result","pop","isNumber","almostWhole","rounded","_setMinAndMaxByKey","array","toRadians","degrees","toDegrees","radians","_decimalPlaces","getAngleFromPoint","centrePoint","anglePoint","distanceFromXCenter","distanceFromYCenter","distanceBetweenPoints","pt1","pt2","_angleDiff","_normalizeAngle","_angleBetween","sameAngleIsFullCircle","angleToStart","angleToEnd","startToAngle","endToAngle","_limitValue","_int16Range","_isBetween","_lookup","table","cmp","mid","hi","lo","_lookupByKey","ti","_rlookupByKey","_filterBetween","arrayEvents","listenArrayEvents","listener","_chartjs","listeners","defineProperty","res","object","unlistenArrayEvents","stub","_arrayUnique","items","requestAnimFrame","requestAnimationFrame","throttled","argsToUse","ticking","debounce","_toLeftRightCenter","align","_alignStartEnd","_textX","rtl","_getStartAndCountOfVisiblePoints","meta","points","animationsDisabled","pointCount","_sorted","iScale","_parsed","minDefined","maxDefined","getUserBounds","_scaleRangesChanged","xScale","yScale","_scaleRanges","newRanges","xmin","xmax","ymin","ymax","atEdge","elasticIn","sin","elasticOut","effects","linear","easeInQuad","easeOutQuad","easeInOutQuad","easeInCubic","easeOutCubic","easeInOutCubic","easeInQuart","easeOutQuart","easeInOutQuart","easeInQuint","easeOutQuint","easeInOutQuint","easeInSine","cos","easeOutSine","easeInOutSine","easeInExpo","easeOutExpo","easeInOutExpo","easeInCirc","easeOutCirc","easeInOutCirc","easeInElastic","easeOutElastic","easeInOutElastic","easeInBack","easeOutBack","easeInOutBack","easeInBounce","easeOutBounce","easeInOutBounce","isPatternOrGradient","getHoverColor","numbers","colors","intlCache","Map","formatNumber","num","locale","getNumberFormat","cacheKey","JSON","stringify","formatter","Intl","NumberFormat","format","formatters","numeric","tickValue","ticks","notation","maxTick","logDelta","numDecimal","minimumFractionDigits","maximumFractionDigits","includes","significand","Ticks","overrides","getScope$1","root","Defaults","_appliers","animation","datasets","devicePixelRatio","platform","getDevicePixelRatio","elements","font","family","lineHeight","hover","hoverBackgroundColor","hoverBorderColor","hoverColor","indexAxis","interaction","intersect","includeInvisible","maintainAspectRatio","onHover","onClick","parsing","plugins","responsive","showLine","drawActiveElementsOnTop","describe","route","targetScope","targetName","scopeObject","targetScopeObject","privateName","defineProperties","writable","local","appliers","_scriptable","startsWith","_indexable","_fallback","duration","easing","loop","active","resize","show","animations","visible","hide","autoPadding","padding","display","beginAtZero","bounds","clip","grace","grid","drawOnChartArea","drawTicks","tickLength","tickWidth","_ctx","tickColor","border","dash","dashOffset","title","text","minRotation","maxRotation","mirror","textStrokeWidth","textStrokeColor","autoSkip","autoSkipPadding","labelOffset","minor","major","crossAlign","showLabelBackdrop","backdropColor","backdropPadding","_measureText","gc","longest","string","textWidth","measureText","_longestText","arrayOfThings","cache","jlen","thing","nestedThing","garbageCollect","gcLen","_alignPixel","pixel","currentDevicePixelRatio","halfWidth","clearCanvas","getContext","resetTransform","clearRect","drawPoint","drawPointLegend","xOffset","yOffset","cornerRadius","xOffsetW","yOffsetW","pointStyle","radius","rad","translate","drawImage","ellipse","arc","closePath","moveTo","lineTo","SQRT1_2","fill","stroke","_isPointInArea","area","margin","clipArea","unclipArea","_steppedLineTo","flip","midpoint","_bezierCurveTo","bezierCurveTo","cp1x","cp2x","cp1y","cp2y","renderText","line","lines","strokeWidth","strokeColor","translation","textAlign","textBaseline","backdrop","drawBackdrop","oldColor","strokeText","maxWidth","fillText","decorateText","strikethrough","underline","metrics","actualBoundingBoxLeft","actualBoundingBoxRight","actualBoundingBoxAscent","actualBoundingBoxDescent","yDecoration","decorationWidth","addRoundedRectPath","topLeft","bottomLeft","bottomRight","topRight","LINE_HEIGHT","FONT_STYLE","numberOrZero","_readValueToProps","objProps","read","toTRBL","toTRBLCorners","toPadding","toFont","match","toLineHeight","matches","resolve","inputs","info","cacheable","_addGrace","minmax","change","keepZero","createContext","parentContext","_createResolver","prefixes","rootScopes","getTarget","finalRootScopes","_resolve","Symbol","toStringTag","_rootScopes","_getTarget","_keys","_resolveWithPrefixes","readKey","getKeysFromAllScopes","storage","_storage","scriptable","indexable","_allKeys","getScope","parentScopes","allScopes","addScopesFromKey","subGetTarget","addScopes","parentFallback","resolveKeysFromAllScopes","_parseObjectDataRadialScale","_parsing","parsed","EPSILON","getPoint","skip","getValueAxis","capControlPoint","pt","_updateBezierControlPoints","controlPoints","spanGaps","cubicInterpolationMode","splineCurveMonotone","pointBefore","pointCurrent","valueAxis","pointsLen","deltaK","mK","pointAfter","slopeDelta","monotoneAdjust","alphaK","betaK","tauK","squaredMagnitude","monotoneCompute","iPixel","vPixel","prev","splineCurve","firstPoint","middlePoint","afterPoint","next","d01","d12","s01","s12","fa","fb","tension","capBezierPoints","inArea","inAreaPrev","inAreaNext","_isDomSupported","_getParentNode","domNode","host","parseMaxStyle","styleValue","parentProperty","valueInPixels","getComputedStyle","positions","getPositionedStyle","styles","suffix","pos","useOffsetPos","shadowRoot","getRelativePosition","borderBox","boxSizing","paddings","borders","box","getCanvasPosition","offsetX","offsetY","round1","getMaximumSize","bbWidth","bbHeight","aspectRatio","margins","maxHeight","containerSize","getContainerSize","container","containerStyle","containerBorder","containerPadding","clientWidth","clientHeight","retinaScale","forceRatio","forceStyle","pixelRatio","deviceHeight","deviceWidth","setTransform","supportsEventListenerOptions","passiveSupported","passive","readUsedSize","getPropertyValue","_pointInLine","_steppedInterpolation","_bezierInterpolation","cp1","cp2","getRtlAdapter","rectX","setWidth","xPlus","leftForLtr","itemWidth","_itemWidth","overrideTextDirection","getPropertyPriority","setProperty","prevTextDirection","restoreTextDirection","propertyFn","between","compare","normalize","normalizeSegment","_boundSegment","segment","prevValue","startBound","endBound","getSegment","inside","subStart","startIsBefore","endIsBefore","shouldStart","shouldStop","_boundSegments","segments","sub","_computeSegments","segmentOptions","_loop","findStartAndEnd","splitByStyles","completeLoop","_fullLoop","solidSegments","cur","doSplitByStyles","chartContext","_chart","baseStyle","readStyle","_datasetIndex","prevStyle","addStyle","st","styleChanged","replacer","p0DataIndex","p1DataIndex","borderCapStyle","borderDash","borderDashOffset","borderJoinStyle","Setter","validate","_utcDate","_options","subPriority","ValueSetter","date","validateValue","flags","setValue","priority","DateToSystemTimezoneSetter","timestampIsSet","constructFrom","transpose","fromDate","setFullYear","getFullYear","getMonth","getDate","setHours","getHours","getMinutes","getSeconds","getMilliseconds","Parser","run","dateString","token","setter","rest","_value","EraParser","era","incompatibleTokens","numericPatterns","dayOfYear","hour23h","hour24h","hour11h","hour12h","singleDigit","twoDigits","threeDigits","fourDigits","anyDigitsSigned","singleDigitSigned","twoDigitsSigned","threeDigitsSigned","fourDigitsSigned","timezonePatterns","basicOptionalMinutes","basic","basicOptionalSeconds","extended","extendedOptionalSeconds","mapValue","parseFnResult","mapFn","parseNumericPattern","pattern","matchResult","parseTimezonePattern","hours","minutes","seconds","millisecondsInHour","millisecondsInMinute","millisecondsInSecond","parseAnyDigitsSigned","parseNDigits","parseNDigitsSigned","dayPeriodEnumToHours","dayPeriod","normalizeTwoDigitYear","twoDigitYear","currentYear","isCommonEra","absCurrentYear","rangeEnd","trunc","isPreviousCentury","isLeapYearIndex","YearParser","valueCallback","isTwoDigitYear","ordinalNumber","unit","_date","normalizedTwoDigitYear","LocalWeekYearParser","getWeekYear","firstWeekContainsDate","startOfWeek","ISOWeekYearParser","_flags","firstWeekOfYear","startOfISOWeek","ExtendedYearParser","QuarterParser","setMonth","StandAloneQuarterParser","MonthParser","StandAloneMonthParser","LocalWeekParser","setWeek","toDate","diff","getWeek","setDate","ISOWeekParser","setISOWeek","getISOWeek","DAYS_IN_MONTH","DAYS_IN_MONTH_LEAP_YEAR","DateParser","isLeapYear","DayOfYearParser","subpriority","addDays","NaN","setDay","defaultOptions","getDefaultOptions","weekStartsOn","currentDay","getDay","dayIndex","remainder","DayParser","LocalDayParser","StandAloneLocalDayParser","ISODayParser","setISODay","AMPMParser","AMPMMidnightParser","DayPeriodParser","Hour1to12Parser","isPM","Hour0to23Parser","Hour0To11Parser","Hour1To24Parser","MinuteParser","setMinutes","SecondParser","setSeconds","FractionOfSecondParser","setMilliseconds","ISOTimezoneWithZParser","getTime","getTimezoneOffsetInMilliseconds","ISOTimezoneParser","TimestampSecondsParser","TimestampMillisecondsParser","parsers","u","q","formattingTokensRegExp","longFormattingTokensRegExp","escapedStringRegExp","doubleQuoteRegExp","notWhitespaceRegExp","unescapedLatinCharacterRegExp","patterns","dateTimeDelimiter","timeZoneDelimiter","timezone","dateRegex","timeRegex","timezoneRegex","parseDateUnit","parseTimeUnit","daysInMonths","addMilliseconds","timestamp","addMonths","dayOfMonth","endOfDesiredMonth","FORMATS","datetime","millisecond","IQ","_id","formats","fmt","dateStr","formatStr","referenceDate","getInternalDefaultOptions","defaultLocale","subFnOptions","setters","tokens","firstCharacter","substring","longFormatters","longFormatter","formatLong","usedTokens","useAdditionalWeekYearTokens","isProtectedWeekYearToken","warnOrThrowProtectedError","useAdditionalDayOfYearTokens","isProtectedDayOfYearToken","parser","incompatibleToken","usedToken","fullToken","parseResult","uniquePrioritySetters","setterArray","parseISO","argument","additionalDigits","dateStrings","splitDateString","timeString","substr","parseYearResult","parseYear","regex","captures","restDateString","century","parseDate","isWeekDate","dayOfWeek","dayOfISOWeekYear","isoWeekYear","setUTCFullYear","fourthOfJanuaryDay","getUTCDay","setUTCDate","getUTCDate","parseTime","parseTimezone","timezoneString","dirtyDate","getUTCFullYear","getUTCMonth","getUTCHours","getUTCMinutes","getUTCSeconds","getUTCMilliseconds","WU","differenceInMilliseconds","_","differenceInSeconds","differenceInMinutes","differenceInHours","differenceInDays","differenceInWeeks","dateLeft","dateRight","getRoundingMethod","differenceInMonths","differenceInQuarters","differenceInYears","startOf","weekday","startOfSecond","startOfMinute","startOfHour","startOfDay","startOfMonth","startOfQuarter","currentMonth","startOfYear","endOf","endOfSecond","endOfMinute","endOfHour","endOfDay","endOfWeek","endOfMonth","endOfQuarter","endOfYear","dateLongFormatter","timeLongFormatter","dateTimeFormat","datePattern","timePattern","dateTime","dayOfYearTokenRE","weekYearTokenRE","throwTokens","_message","subject","addLeadingZeros","number","targetLength","padStart","lightFormatters","signedYear","String","dayPeriodEnumValue","numberOfDigits","milliseconds","dayPeriodEnum","midnight","noon","morning","afternoon","evening","night","localize","signedWeekYear","weekYear","getISOWeekYear","ceil","isoWeek","getDayOfYear","differenceInCalendarDays","localDayOfWeek","isoDayOfWeek","_localize","timezoneOffset","getTimezoneOffset","formatTimezoneWithOptionalMinutes","formatTimezone","formatTimezoneShort","delimiter","absOffset","originalDate","isToken","cleanEscapedString","matched","preprocessor","formatterOptions","startOfISOWeekYear","fourthOfJanuary","millisecondsInWeek","fourthOfJanuaryOfNextYear","startOfNextYear","fourthOfJanuaryOfThisYear","startOfThisYear","startOfWeekYear","firstWeek","firstWeekOfNextYear","firstWeekOfThisYear","formatDistanceLocale","lessThanXSeconds","one","other","xSeconds","halfAMinute","lessThanXMinutes","xMinutes","aboutXHours","xHours","xDays","aboutXWeeks","xWeeks","aboutXMonths","xMonths","aboutXYears","xYears","overXYears","almostXYears","buildFormatLongFn","defaultWidth","full","long","medium","short","formatRelativeLocale","lastWeek","yesterday","today","tomorrow","nextWeek","buildLocalizeFn","valuesArray","formattingValues","defaultFormattingWidth","argumentCallback","buildMatchFn","matchPattern","matchPatterns","defaultMatchWidth","matchedString","parsePatterns","defaultParseWidth","findIndex","predicate","findKey","enUS","code","formatDistance","tokenValue","addSuffix","comparison","formatRelative","_baseDate","dirtyNumber","rem100","narrow","abbreviated","wide","am","pm","parsePattern","any","cleanDate"],"sourceRoot":""}