{"version":3,"sources":["webpack://@verndale/toolkit/./node_modules/@motionone/animation/dist/Animation.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/easing/dist/cubic-bezier.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/easing/dist/steps.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/animation/dist/utils/easing.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/types/dist/MotionValue.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/data.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/transforms.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/css-var.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/feature-detection.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/easing.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/get-style-name.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/style.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/get-unit.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/animate-style.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/controls.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/keyframes.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/options.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/animate/utils/stop-animation.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/utils/resolve-elements.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/dom/dist/utils/stagger.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/array.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/clamp.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/defaults.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/wrap.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/easing.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/interpolate.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/is-cubic-bezier.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/is-easing-generator.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/is-easing-list.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/is-function.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/is-number.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/is-string.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/mix.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/noop.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/offset.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/progress.es.js","webpack://@verndale/toolkit/./node_modules/@motionone/utils/dist/time.es.js","webpack://@verndale/toolkit/./node_modules/hey-listen/dist/hey-listen.es.js"],"names":["Animation","output","keyframes","easing","initialDuration","delay","endDelay","repeat","offset","direction","resolve","reject","custom","interpolate$1","timestamp","_a","t","progress","currentIteration","iterationProgress","iterationIsOdd","p","latest","now","duration","rate","calcBezier","a1","a2","subdivisionPrecision","subdivisionMaxIterations","binarySubdivide","x","lowerBound","upperBound","mX1","mX2","currentX","currentT","i","cubicBezier","mY1","mY2","getTForX","aX","steps","expanded","rounded","namedEasings","functionArgsRegex","getEasingFunction","definition","args","argsArray","MotionValue","animation","data","getAnimationData","element","getMotionValue","motionValues","name","axes","order","transformAlias","rotation","v","baseTransformProperties","transformDefinitions","asTransformCssVar","transforms","axis","compareTransformOrder","a","b","transformLookup","isTransform","addTransformToElement","buildTransformTemplate","transformListToString","template","isCssVar","registeredProperties","registerCssVariable","syntax","initialValue","testAnimation","options","featureTests","results","supports","key","resolution","generateLinearEasingPoints","points","numPoints","convertEasing","cubicBezierAsString","c","d","getStyleName","style","value","getUnitConverter","toUnit","finalKeyframe","unit","getDevToolsRecord","animateStyle","keyframesDefinition","AnimationPolyfill","record","isRecording","persist","allowWebkitAcceleration","valueIsTransform","canAnimateNatively","motionValue","readInitialValue","_b","animationOptions","thisEasing","target","createAnimation","factory","withControls","animationFactory","controls","getActiveAnimation","state","activeAnimation","selectFinished","callback","hydrateKeyframes","keyframesList","getOptions","stopAnimation","needsCommit","resolveElements","elements","selectorCache","stagger","start","from","total","fromIndex","getFromIndex","distance","maxDelay","lastIndex","resolveOption","option","addUniqueItem","array","item","removeItem","arr","index","clamp","min","max","defaults","wrap","rangeSize","getEasingForSegment","interpolate","input","length","remainder","progressInRange","isCubicBezier","isEasingGenerator","isEasingList","isFunction","isNumber","isString","mix","noop","noopReturn","fillOffset","remaining","offsetProgress","defaultOffset","time","seconds","milliseconds","warning","invariant"],"mappings":"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","file":"scripts/8707.4177a1488e9330b4bd57.js","sourcesContent":["import { noopReturn, defaults, isEasingGenerator, isEasingList, interpolate } from '@motionone/utils';\nimport { getEasingFunction } from './utils/easing.es.js';\n\nclass Animation {\n    constructor(output, keyframes = [0, 1], { easing, duration: initialDuration = defaults.duration, delay = defaults.delay, endDelay = defaults.endDelay, repeat = defaults.repeat, offset, direction = \"normal\", } = {}) {\n        this.startTime = null;\n        this.rate = 1;\n        this.t = 0;\n        this.cancelTimestamp = null;\n        this.easing = noopReturn;\n        this.duration = 0;\n        this.totalDuration = 0;\n        this.repeat = 0;\n        this.playState = \"idle\";\n        this.finished = new Promise((resolve, reject) => {\n            this.resolve = resolve;\n            this.reject = reject;\n        });\n        easing = easing || defaults.easing;\n        if (isEasingGenerator(easing)) {\n            const custom = easing.createAnimation(keyframes);\n            easing = custom.easing;\n            keyframes = custom.keyframes || keyframes;\n            initialDuration = custom.duration || initialDuration;\n        }\n        this.repeat = repeat;\n        this.easing = isEasingList(easing) ? noopReturn : getEasingFunction(easing);\n        this.updateDuration(initialDuration);\n        const interpolate$1 = interpolate(keyframes, offset, isEasingList(easing) ? easing.map(getEasingFunction) : noopReturn);\n        this.tick = (timestamp) => {\n            var _a;\n            // TODO: Temporary fix for OptionsResolver typing\n            delay = delay;\n            let t = 0;\n            if (this.pauseTime !== undefined) {\n                t = this.pauseTime;\n            }\n            else {\n                t = (timestamp - this.startTime) * this.rate;\n            }\n            this.t = t;\n            // Convert to seconds\n            t /= 1000;\n            // Rebase on delay\n            t = Math.max(t - delay, 0);\n            /**\n             * If this animation has finished, set the current time\n             * to the total duration.\n             */\n            if (this.playState === \"finished\" && this.pauseTime === undefined) {\n                t = this.totalDuration;\n            }\n            /**\n             * Get the current progress (0-1) of the animation. If t is >\n             * than duration we'll get values like 2.5 (midway through the\n             * third iteration)\n             */\n            const progress = t / this.duration;\n            // TODO progress += iterationStart\n            /**\n             * Get the current iteration (0 indexed). For instance the floor of\n             * 2.5 is 2.\n             */\n            let currentIteration = Math.floor(progress);\n            /**\n             * Get the current progress of the iteration by taking the remainder\n             * so 2.5 is 0.5 through iteration 2\n             */\n            let iterationProgress = progress % 1.0;\n            if (!iterationProgress && progress >= 1) {\n                iterationProgress = 1;\n            }\n            /**\n             * If iteration progress is 1 we count that as the end\n             * of the previous iteration.\n             */\n            iterationProgress === 1 && currentIteration--;\n            /**\n             * Reverse progress if we're not running in \"normal\" direction\n             */\n            const iterationIsOdd = currentIteration % 2;\n            if (direction === \"reverse\" ||\n                (direction === \"alternate\" && iterationIsOdd) ||\n                (direction === \"alternate-reverse\" && !iterationIsOdd)) {\n                iterationProgress = 1 - iterationProgress;\n            }\n            const p = t >= this.totalDuration ? 1 : Math.min(iterationProgress, 1);\n            const latest = interpolate$1(this.easing(p));\n            output(latest);\n            const isAnimationFinished = this.pauseTime === undefined &&\n                (this.playState === \"finished\" || t >= this.totalDuration + endDelay);\n            if (isAnimationFinished) {\n                this.playState = \"finished\";\n                (_a = this.resolve) === null || _a === void 0 ? void 0 : _a.call(this, latest);\n            }\n            else if (this.playState !== \"idle\") {\n                this.frameRequestId = requestAnimationFrame(this.tick);\n            }\n        };\n        this.play();\n    }\n    play() {\n        const now = performance.now();\n        this.playState = \"running\";\n        if (this.pauseTime !== undefined) {\n            this.startTime = now - this.pauseTime;\n        }\n        else if (!this.startTime) {\n            this.startTime = now;\n        }\n        this.cancelTimestamp = this.startTime;\n        this.pauseTime = undefined;\n        this.frameRequestId = requestAnimationFrame(this.tick);\n    }\n    pause() {\n        this.playState = \"paused\";\n        this.pauseTime = this.t;\n    }\n    finish() {\n        this.playState = \"finished\";\n        this.tick(0);\n    }\n    stop() {\n        var _a;\n        this.playState = \"idle\";\n        if (this.frameRequestId !== undefined) {\n            cancelAnimationFrame(this.frameRequestId);\n        }\n        (_a = this.reject) === null || _a === void 0 ? void 0 : _a.call(this, false);\n    }\n    cancel() {\n        this.stop();\n        this.tick(this.cancelTimestamp);\n    }\n    reverse() {\n        this.rate *= -1;\n    }\n    commitStyles() { }\n    updateDuration(duration) {\n        this.duration = duration;\n        this.totalDuration = duration * (this.repeat + 1);\n    }\n    get currentTime() {\n        return this.t;\n    }\n    set currentTime(t) {\n        if (this.pauseTime !== undefined || this.rate === 0) {\n            this.pauseTime = t;\n        }\n        else {\n            this.startTime = performance.now() - t / this.rate;\n        }\n    }\n    get playbackRate() {\n        return this.rate;\n    }\n    set playbackRate(rate) {\n        this.rate = rate;\n    }\n}\n\nexport { Animation };\n","import { noopReturn } from '@motionone/utils';\n\n/*\n  Bezier function generator\n\n  This has been modified from Gaëtan Renaudeau's BezierEasing\n  https://github.com/gre/bezier-easing/blob/master/src/index.js\n  https://github.com/gre/bezier-easing/blob/master/LICENSE\n  \n  I've removed the newtonRaphsonIterate algo because in benchmarking it\n  wasn't noticiably faster than binarySubdivision, indeed removing it\n  usually improved times, depending on the curve.\n\n  I also removed the lookup table, as for the added bundle size and loop we're\n  only cutting ~4 or so subdivision iterations. I bumped the max iterations up\n  to 12 to compensate and this still tended to be faster for no perceivable\n  loss in accuracy.\n\n  Usage\n    const easeOut = cubicBezier(.17,.67,.83,.67);\n    const x = easeOut(0.5); // returns 0.627...\n*/\n// Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2.\nconst calcBezier = (t, a1, a2) => (((1.0 - 3.0 * a2 + 3.0 * a1) * t + (3.0 * a2 - 6.0 * a1)) * t + 3.0 * a1) * t;\nconst subdivisionPrecision = 0.0000001;\nconst subdivisionMaxIterations = 12;\nfunction binarySubdivide(x, lowerBound, upperBound, mX1, mX2) {\n    let currentX;\n    let currentT;\n    let i = 0;\n    do {\n        currentT = lowerBound + (upperBound - lowerBound) / 2.0;\n        currentX = calcBezier(currentT, mX1, mX2) - x;\n        if (currentX > 0.0) {\n            upperBound = currentT;\n        }\n        else {\n            lowerBound = currentT;\n        }\n    } while (Math.abs(currentX) > subdivisionPrecision &&\n        ++i < subdivisionMaxIterations);\n    return currentT;\n}\nfunction cubicBezier(mX1, mY1, mX2, mY2) {\n    // If this is a linear gradient, return linear easing\n    if (mX1 === mY1 && mX2 === mY2)\n        return noopReturn;\n    const getTForX = (aX) => binarySubdivide(aX, 0, 1, mX1, mX2);\n    // If animation is at start/end, return t without easing\n    return (t) => t === 0 || t === 1 ? t : calcBezier(getTForX(t), mY1, mY2);\n}\n\nexport { cubicBezier };\n","import { clamp } from '@motionone/utils';\n\nconst steps = (steps, direction = \"end\") => (progress) => {\n    progress =\n        direction === \"end\"\n            ? Math.min(progress, 0.999)\n            : Math.max(progress, 0.001);\n    const expanded = progress * steps;\n    const rounded = direction === \"end\" ? Math.floor(expanded) : Math.ceil(expanded);\n    return clamp(0, 1, rounded / steps);\n};\n\nexport { steps };\n","import { cubicBezier, steps } from '@motionone/easing';\nimport { isFunction, isCubicBezier, noopReturn } from '@motionone/utils';\n\nconst namedEasings = {\n    ease: cubicBezier(0.25, 0.1, 0.25, 1.0),\n    \"ease-in\": cubicBezier(0.42, 0.0, 1.0, 1.0),\n    \"ease-in-out\": cubicBezier(0.42, 0.0, 0.58, 1.0),\n    \"ease-out\": cubicBezier(0.0, 0.0, 0.58, 1.0),\n};\nconst functionArgsRegex = /\\((.*?)\\)/;\nfunction getEasingFunction(definition) {\n    // If already an easing function, return\n    if (isFunction(definition))\n        return definition;\n    // If an easing curve definition, return bezier function\n    if (isCubicBezier(definition))\n        return cubicBezier(...definition);\n    // If we have a predefined easing function, return\n    if (namedEasings[definition])\n        return namedEasings[definition];\n    // If this is a steps function, attempt to create easing curve\n    if (definition.startsWith(\"steps\")) {\n        const args = functionArgsRegex.exec(definition);\n        if (args) {\n            const argsArray = args[1].split(\",\");\n            return steps(parseFloat(argsArray[0]), argsArray[1].trim());\n        }\n    }\n    return noopReturn;\n}\n\nexport { getEasingFunction };\n","/**\n * The MotionValue tracks the state of a single animatable\n * value. Currently, updatedAt and current are unused. The\n * long term idea is to use this to minimise the number\n * of DOM reads, and to abstract the DOM interactions here.\n */\nclass MotionValue {\n    setAnimation(animation) {\n        this.animation = animation;\n        animation === null || animation === void 0 ? void 0 : animation.finished.then(() => this.clearAnimation()).catch(() => { });\n    }\n    clearAnimation() {\n        this.animation = this.generator = undefined;\n    }\n}\n\nexport { MotionValue };\n","import { MotionValue } from '@motionone/types';\n\nconst data = new WeakMap();\nfunction getAnimationData(element) {\n    if (!data.has(element)) {\n        data.set(element, {\n            transforms: [],\n            values: new Map(),\n        });\n    }\n    return data.get(element);\n}\nfunction getMotionValue(motionValues, name) {\n    if (!motionValues.has(name)) {\n        motionValues.set(name, new MotionValue());\n    }\n    return motionValues.get(name);\n}\n\nexport { getAnimationData, getMotionValue };\n","import { noopReturn, addUniqueItem } from '@motionone/utils';\nimport { getAnimationData } from '../data.es.js';\n\n/**\n * A list of all transformable axes. We'll use this list to generated a version\n * of each axes for each transform.\n */\nconst axes = [\"\", \"X\", \"Y\", \"Z\"];\n/**\n * An ordered array of each transformable value. By default, transform values\n * will be sorted to this order.\n */\nconst order = [\"translate\", \"scale\", \"rotate\", \"skew\"];\nconst transformAlias = {\n    x: \"translateX\",\n    y: \"translateY\",\n    z: \"translateZ\",\n};\nconst rotation = {\n    syntax: \"<angle>\",\n    initialValue: \"0deg\",\n    toDefaultUnit: (v) => v + \"deg\",\n};\nconst baseTransformProperties = {\n    translate: {\n        syntax: \"<length-percentage>\",\n        initialValue: \"0px\",\n        toDefaultUnit: (v) => v + \"px\",\n    },\n    rotate: rotation,\n    scale: {\n        syntax: \"<number>\",\n        initialValue: 1,\n        toDefaultUnit: noopReturn,\n    },\n    skew: rotation,\n};\nconst transformDefinitions = new Map();\nconst asTransformCssVar = (name) => `--motion-${name}`;\n/**\n * Generate a list of every possible transform key\n */\nconst transforms = [\"x\", \"y\", \"z\"];\norder.forEach((name) => {\n    axes.forEach((axis) => {\n        transforms.push(name + axis);\n        transformDefinitions.set(asTransformCssVar(name + axis), baseTransformProperties[name]);\n    });\n});\n/**\n * A function to use with Array.sort to sort transform keys by their default order.\n */\nconst compareTransformOrder = (a, b) => transforms.indexOf(a) - transforms.indexOf(b);\n/**\n * Provide a quick way to check if a string is the name of a transform\n */\nconst transformLookup = new Set(transforms);\nconst isTransform = (name) => transformLookup.has(name);\nconst addTransformToElement = (element, name) => {\n    // Map x to translateX etc\n    if (transformAlias[name])\n        name = transformAlias[name];\n    const { transforms } = getAnimationData(element);\n    addUniqueItem(transforms, name);\n    /**\n     * TODO: An optimisation here could be to cache the transform in element data\n     * and only update if this has changed.\n     */\n    element.style.transform = buildTransformTemplate(transforms);\n};\nconst buildTransformTemplate = (transforms) => transforms\n    .sort(compareTransformOrder)\n    .reduce(transformListToString, \"\")\n    .trim();\nconst transformListToString = (template, name) => `${template} ${name}(var(${asTransformCssVar(name)}))`;\n\nexport { addTransformToElement, asTransformCssVar, axes, buildTransformTemplate, compareTransformOrder, isTransform, transformAlias, transformDefinitions };\n","import { transformDefinitions } from './transforms.es.js';\n\nconst isCssVar = (name) => name.startsWith(\"--\");\nconst registeredProperties = new Set();\nfunction registerCssVariable(name) {\n    if (registeredProperties.has(name))\n        return;\n    registeredProperties.add(name);\n    try {\n        const { syntax, initialValue } = transformDefinitions.has(name)\n            ? transformDefinitions.get(name)\n            : {};\n        CSS.registerProperty({\n            name,\n            inherits: false,\n            syntax,\n            initialValue,\n        });\n    }\n    catch (e) { }\n}\n\nexport { isCssVar, registerCssVariable, registeredProperties };\n","const testAnimation = (keyframes, options) => document.createElement(\"div\").animate(keyframes, options);\nconst featureTests = {\n    cssRegisterProperty: () => typeof CSS !== \"undefined\" &&\n        Object.hasOwnProperty.call(CSS, \"registerProperty\"),\n    waapi: () => Object.hasOwnProperty.call(Element.prototype, \"animate\"),\n    partialKeyframes: () => {\n        try {\n            testAnimation({ opacity: [1] });\n        }\n        catch (e) {\n            return false;\n        }\n        return true;\n    },\n    finished: () => Boolean(testAnimation({ opacity: [0, 1] }, { duration: 0.001 }).finished),\n    linearEasing: () => {\n        try {\n            testAnimation({ opacity: 0 }, { easing: \"linear(0, 1)\" });\n        }\n        catch (e) {\n            return false;\n        }\n        return true;\n    },\n};\nconst results = {};\nconst supports = {};\nfor (const key in featureTests) {\n    supports[key] = () => {\n        if (results[key] === undefined)\n            results[key] = featureTests[key]();\n        return results[key];\n    };\n}\n\nexport { supports };\n","import { isFunction, defaults, isCubicBezier, progress } from '@motionone/utils';\nimport { supports } from './feature-detection.es.js';\n\n// Create a linear easing point for every x second\nconst resolution = 0.015;\nconst generateLinearEasingPoints = (easing, duration) => {\n    let points = \"\";\n    const numPoints = Math.round(duration / resolution);\n    for (let i = 0; i < numPoints; i++) {\n        points += easing(progress(0, numPoints - 1, i)) + \", \";\n    }\n    return points.substring(0, points.length - 2);\n};\nconst convertEasing = (easing, duration) => {\n    if (isFunction(easing)) {\n        return supports.linearEasing()\n            ? `linear(${generateLinearEasingPoints(easing, duration)})`\n            : defaults.easing;\n    }\n    else {\n        return isCubicBezier(easing) ? cubicBezierAsString(easing) : easing;\n    }\n};\nconst cubicBezierAsString = ([a, b, c, d]) => `cubic-bezier(${a}, ${b}, ${c}, ${d})`;\n\nexport { convertEasing, cubicBezierAsString, generateLinearEasingPoints };\n","import { isTransform, asTransformCssVar, transformAlias } from './transforms.es.js';\n\nfunction getStyleName(key) {\n    if (transformAlias[key])\n        key = transformAlias[key];\n    return isTransform(key) ? asTransformCssVar(key) : key;\n}\n\nexport { getStyleName };\n","import { isCssVar } from './utils/css-var.es.js';\nimport { getStyleName } from './utils/get-style-name.es.js';\nimport { transformDefinitions } from './utils/transforms.es.js';\n\nconst style = {\n    get: (element, name) => {\n        name = getStyleName(name);\n        let value = isCssVar(name)\n            ? element.style.getPropertyValue(name)\n            : getComputedStyle(element)[name];\n        if (!value && value !== 0) {\n            const definition = transformDefinitions.get(name);\n            if (definition)\n                value = definition.initialValue;\n        }\n        return value;\n    },\n    set: (element, name, value) => {\n        name = getStyleName(name);\n        if (isCssVar(name)) {\n            element.style.setProperty(name, value);\n        }\n        else {\n            element.style[name] = value;\n        }\n    },\n};\n\nexport { style };\n","import { noopReturn, isString } from '@motionone/utils';\n\nfunction getUnitConverter(keyframes, definition) {\n    var _a;\n    let toUnit = (definition === null || definition === void 0 ? void 0 : definition.toDefaultUnit) || noopReturn;\n    const finalKeyframe = keyframes[keyframes.length - 1];\n    if (isString(finalKeyframe)) {\n        const unit = ((_a = finalKeyframe.match(/(-?[\\d.]+)([a-z%]*)/)) === null || _a === void 0 ? void 0 : _a[2]) || \"\";\n        if (unit)\n            toUnit = (value) => value + unit;\n    }\n    return toUnit;\n}\n\nexport { getUnitConverter };\n","import { getAnimationData, getMotionValue } from './data.es.js';\nimport { isCssVar, registerCssVariable } from './utils/css-var.es.js';\nimport { defaults, isEasingGenerator, isFunction, isEasingList, isNumber, time, noop } from '@motionone/utils';\nimport { isTransform, addTransformToElement, transformDefinitions } from './utils/transforms.es.js';\nimport { convertEasing } from './utils/easing.es.js';\nimport { supports } from './utils/feature-detection.es.js';\nimport { hydrateKeyframes, keyframesList } from './utils/keyframes.es.js';\nimport { style } from './style.es.js';\nimport { getStyleName } from './utils/get-style-name.es.js';\nimport { stopAnimation } from './utils/stop-animation.es.js';\nimport { getUnitConverter } from './utils/get-unit.es.js';\n\nfunction getDevToolsRecord() {\n    return window.__MOTION_DEV_TOOLS_RECORD;\n}\nfunction animateStyle(element, key, keyframesDefinition, options = {}, AnimationPolyfill) {\n    const record = getDevToolsRecord();\n    const isRecording = options.record !== false && record;\n    let animation;\n    let { duration = defaults.duration, delay = defaults.delay, endDelay = defaults.endDelay, repeat = defaults.repeat, easing = defaults.easing, persist = false, direction, offset, allowWebkitAcceleration = false, } = options;\n    const data = getAnimationData(element);\n    const valueIsTransform = isTransform(key);\n    let canAnimateNatively = supports.waapi();\n    /**\n     * If this is an individual transform, we need to map its\n     * key to a CSS variable and update the element's transform style\n     */\n    valueIsTransform && addTransformToElement(element, key);\n    const name = getStyleName(key);\n    const motionValue = getMotionValue(data.values, name);\n    /**\n     * Get definition of value, this will be used to convert numerical\n     * keyframes into the default value type.\n     */\n    const definition = transformDefinitions.get(name);\n    /**\n     * Stop the current animation, if any. Because this will trigger\n     * commitStyles (DOM writes) and we might later trigger DOM reads,\n     * this is fired now and we return a factory function to create\n     * the actual animation that can get called in batch,\n     */\n    stopAnimation(motionValue.animation, !(isEasingGenerator(easing) && motionValue.generator) &&\n        options.record !== false);\n    /**\n     * Batchable factory function containing all DOM reads.\n     */\n    return () => {\n        const readInitialValue = () => { var _a, _b; return (_b = (_a = style.get(element, name)) !== null && _a !== void 0 ? _a : definition === null || definition === void 0 ? void 0 : definition.initialValue) !== null && _b !== void 0 ? _b : 0; };\n        /**\n         * Replace null values with the previous keyframe value, or read\n         * it from the DOM if it's the first keyframe.\n         */\n        let keyframes = hydrateKeyframes(keyframesList(keyframesDefinition), readInitialValue);\n        /**\n         * Detect unit type of keyframes.\n         */\n        const toUnit = getUnitConverter(keyframes, definition);\n        if (isEasingGenerator(easing)) {\n            const custom = easing.createAnimation(keyframes, key !== \"opacity\", readInitialValue, name, motionValue);\n            easing = custom.easing;\n            keyframes = custom.keyframes || keyframes;\n            duration = custom.duration || duration;\n        }\n        /**\n         * If this is a CSS variable we need to register it with the browser\n         * before it can be animated natively. We also set it with setProperty\n         * rather than directly onto the element.style object.\n         */\n        if (isCssVar(name)) {\n            if (supports.cssRegisterProperty()) {\n                registerCssVariable(name);\n            }\n            else {\n                canAnimateNatively = false;\n            }\n        }\n        /**\n         * If we've been passed a custom easing function, and this browser\n         * does **not** support linear() easing, and the value is a transform\n         * (and thus a pure number) we can still support the custom easing\n         * by falling back to the animation polyfill.\n         */\n        if (valueIsTransform &&\n            !supports.linearEasing() &&\n            (isFunction(easing) || (isEasingList(easing) && easing.some(isFunction)))) {\n            canAnimateNatively = false;\n        }\n        /**\n         * If we can animate this value with WAAPI, do so.\n         */\n        if (canAnimateNatively) {\n            /**\n             * Convert numbers to default value types. Currently this only supports\n             * transforms but it could also support other value types.\n             */\n            if (definition) {\n                keyframes = keyframes.map((value) => isNumber(value) ? definition.toDefaultUnit(value) : value);\n            }\n            /**\n             * If this browser doesn't support partial/implicit keyframes we need to\n             * explicitly provide one.\n             */\n            if (keyframes.length === 1 &&\n                (!supports.partialKeyframes() || isRecording)) {\n                keyframes.unshift(readInitialValue());\n            }\n            const animationOptions = {\n                delay: time.ms(delay),\n                duration: time.ms(duration),\n                endDelay: time.ms(endDelay),\n                easing: !isEasingList(easing)\n                    ? convertEasing(easing, duration)\n                    : undefined,\n                direction,\n                iterations: repeat + 1,\n                fill: \"both\",\n            };\n            animation = element.animate({\n                [name]: keyframes,\n                offset,\n                easing: isEasingList(easing)\n                    ? easing.map((thisEasing) => convertEasing(thisEasing, duration))\n                    : undefined,\n            }, animationOptions);\n            /**\n             * Polyfill finished Promise in browsers that don't support it\n             */\n            if (!animation.finished) {\n                animation.finished = new Promise((resolve, reject) => {\n                    animation.onfinish = resolve;\n                    animation.oncancel = reject;\n                });\n            }\n            const target = keyframes[keyframes.length - 1];\n            animation.finished\n                .then(() => {\n                if (persist)\n                    return;\n                // Apply styles to target\n                style.set(element, name, target);\n                // Ensure fill modes don't persist\n                animation.cancel();\n            })\n                .catch(noop);\n            /**\n             * This forces Webkit to run animations on the main thread by exploiting\n             * this condition:\n             * https://trac.webkit.org/browser/webkit/trunk/Source/WebCore/platform/graphics/ca/GraphicsLayerCA.cpp?rev=281238#L1099\n             *\n             * This fixes Webkit's timing bugs, like accelerated animations falling\n             * out of sync with main thread animations and massive delays in starting\n             * accelerated animations in WKWebView.\n             */\n            if (!allowWebkitAcceleration)\n                animation.playbackRate = 1.000001;\n            /**\n             * If we can't animate the value natively then we can fallback to the numbers-only\n             * polyfill for transforms.\n             */\n        }\n        else if (AnimationPolyfill && valueIsTransform) {\n            /**\n             * If any keyframe is a string (because we measured it from the DOM), we need to convert\n             * it into a number before passing to the Animation polyfill.\n             */\n            keyframes = keyframes.map((value) => typeof value === \"string\" ? parseFloat(value) : value);\n            /**\n             * If we only have a single keyframe, we need to create an initial keyframe by reading\n             * the current value from the DOM.\n             */\n            if (keyframes.length === 1) {\n                keyframes.unshift(parseFloat(readInitialValue()));\n            }\n            animation = new AnimationPolyfill((latest) => {\n                style.set(element, name, toUnit ? toUnit(latest) : latest);\n            }, keyframes, Object.assign(Object.assign({}, options), { duration,\n                easing }));\n        }\n        else {\n            const target = keyframes[keyframes.length - 1];\n            style.set(element, name, definition && isNumber(target)\n                ? definition.toDefaultUnit(target)\n                : target);\n        }\n        if (isRecording) {\n            record(element, key, keyframes, {\n                duration,\n                delay: delay,\n                easing,\n                repeat,\n                offset,\n            }, \"motion-one\");\n        }\n        motionValue.setAnimation(animation);\n        return animation;\n    };\n}\n\nexport { animateStyle };\n","import { defaults, noop, time } from '@motionone/utils';\nimport { stopAnimation } from './stop-animation.es.js';\n\nconst createAnimation = (factory) => factory();\nconst withControls = (animationFactory, options, duration = defaults.duration) => {\n    return new Proxy({\n        animations: animationFactory.map(createAnimation).filter(Boolean),\n        duration,\n        options,\n    }, controls);\n};\n/**\n * TODO:\n * Currently this returns the first animation, ideally it would return\n * the first active animation.\n */\nconst getActiveAnimation = (state) => state.animations[0];\nconst controls = {\n    get: (target, key) => {\n        const activeAnimation = getActiveAnimation(target);\n        switch (key) {\n            case \"duration\":\n                return target.duration;\n            case \"currentTime\":\n                return time.s((activeAnimation === null || activeAnimation === void 0 ? void 0 : activeAnimation[key]) || 0);\n            case \"playbackRate\":\n            case \"playState\":\n                return activeAnimation === null || activeAnimation === void 0 ? void 0 : activeAnimation[key];\n            case \"finished\":\n                if (!target.finished) {\n                    target.finished = Promise.all(target.animations.map(selectFinished)).catch(noop);\n                }\n                return target.finished;\n            case \"stop\":\n                return () => {\n                    target.animations.forEach((animation) => stopAnimation(animation));\n                };\n            case \"forEachNative\":\n                /**\n                 * This is for internal use only, fire a callback for each\n                 * underlying animation.\n                 */\n                return (callback) => {\n                    target.animations.forEach((animation) => callback(animation, target));\n                };\n            default:\n                return typeof (activeAnimation === null || activeAnimation === void 0 ? void 0 : activeAnimation[key]) === \"undefined\"\n                    ? undefined\n                    : () => target.animations.forEach((animation) => animation[key]());\n        }\n    },\n    set: (target, key, value) => {\n        switch (key) {\n            case \"currentTime\":\n                value = time.ms(value);\n            case \"currentTime\":\n            case \"playbackRate\":\n                for (let i = 0; i < target.animations.length; i++) {\n                    target.animations[i][key] = value;\n                }\n                return true;\n        }\n        return false;\n    },\n};\nconst selectFinished = (animation) => animation.finished;\n\nexport { controls, withControls };\n","function hydrateKeyframes(keyframes, readInitialValue) {\n    for (let i = 0; i < keyframes.length; i++) {\n        if (keyframes[i] === null) {\n            keyframes[i] = i ? keyframes[i - 1] : readInitialValue();\n        }\n    }\n    return keyframes;\n}\nconst keyframesList = (keyframes) => Array.isArray(keyframes) ? keyframes : [keyframes];\n\nexport { hydrateKeyframes, keyframesList };\n","const getOptions = (options, key) => \n/**\n * TODO: Make test for this\n * Always return a new object otherwise delay is overwritten by results of stagger\n * and this results in no stagger\n */\noptions[key] ? Object.assign(Object.assign({}, options), options[key]) : Object.assign({}, options);\n\nexport { getOptions };\n","function stopAnimation(animation, needsCommit = true) {\n    if (!animation || animation.playState === \"finished\")\n        return;\n    // Suppress error thrown by WAAPI\n    try {\n        if (animation.stop) {\n            animation.stop();\n        }\n        else {\n            needsCommit && animation.commitStyles();\n            animation.cancel();\n        }\n    }\n    catch (e) { }\n}\n\nexport { stopAnimation };\n","function resolveElements(elements, selectorCache) {\n    var _a;\n    if (typeof elements === \"string\") {\n        if (selectorCache) {\n            (_a = selectorCache[elements]) !== null && _a !== void 0 ? _a : (selectorCache[elements] = document.querySelectorAll(elements));\n            elements = selectorCache[elements];\n        }\n        else {\n            elements = document.querySelectorAll(elements);\n        }\n    }\n    else if (elements instanceof Element) {\n        elements = [elements];\n    }\n    /**\n     * Return an empty array\n     */\n    return Array.from(elements || []);\n}\n\nexport { resolveElements };\n","import { isNumber, isFunction } from '@motionone/utils';\nimport { getEasingFunction } from '@motionone/animation';\n\nfunction stagger(duration = 0.1, { start = 0, from = 0, easing } = {}) {\n    return (i, total) => {\n        const fromIndex = isNumber(from) ? from : getFromIndex(from, total);\n        const distance = Math.abs(fromIndex - i);\n        let delay = duration * distance;\n        if (easing) {\n            const maxDelay = total * duration;\n            const easingFunction = getEasingFunction(easing);\n            delay = easingFunction(delay / maxDelay) * maxDelay;\n        }\n        return start + delay;\n    };\n}\nfunction getFromIndex(from, total) {\n    if (from === \"first\") {\n        return 0;\n    }\n    else {\n        const lastIndex = total - 1;\n        return from === \"last\" ? lastIndex : lastIndex / 2;\n    }\n}\nfunction resolveOption(option, i, total) {\n    return isFunction(option) ? option(i, total) : option;\n}\n\nexport { getFromIndex, resolveOption, stagger };\n","function addUniqueItem(array, item) {\n    array.indexOf(item) === -1 && array.push(item);\n}\nfunction removeItem(arr, item) {\n    const index = arr.indexOf(item);\n    index > -1 && arr.splice(index, 1);\n}\n\nexport { addUniqueItem, removeItem };\n","const clamp = (min, max, v) => Math.min(Math.max(v, min), max);\n\nexport { clamp };\n","const defaults = {\n    duration: 0.3,\n    delay: 0,\n    endDelay: 0,\n    repeat: 0,\n    easing: \"ease\",\n};\n\nexport { defaults };\n","const wrap = (min, max, v) => {\n    const rangeSize = max - min;\n    return ((((v - min) % rangeSize) + rangeSize) % rangeSize) + min;\n};\n\nexport { wrap };\n","import { isEasingList } from './is-easing-list.es.js';\nimport { wrap } from './wrap.es.js';\n\nfunction getEasingForSegment(easing, i) {\n    return isEasingList(easing)\n        ? easing[wrap(0, easing.length, i)]\n        : easing;\n}\n\nexport { getEasingForSegment };\n","import { mix } from './mix.es.js';\nimport { noopReturn } from './noop.es.js';\nimport { fillOffset, defaultOffset } from './offset.es.js';\nimport { progress } from './progress.es.js';\nimport { getEasingForSegment } from './easing.es.js';\nimport { clamp } from './clamp.es.js';\n\nfunction interpolate(output, input = defaultOffset(output.length), easing = noopReturn) {\n    const length = output.length;\n    /**\n     * If the input length is lower than the output we\n     * fill the input to match. This currently assumes the input\n     * is an animation progress value so is a good candidate for\n     * moving outside the function.\n     */\n    const remainder = length - input.length;\n    remainder > 0 && fillOffset(input, remainder);\n    return (t) => {\n        let i = 0;\n        for (; i < length - 2; i++) {\n            if (t < input[i + 1])\n                break;\n        }\n        let progressInRange = clamp(0, 1, progress(input[i], input[i + 1], t));\n        const segmentEasing = getEasingForSegment(easing, i);\n        progressInRange = segmentEasing(progressInRange);\n        return mix(output[i], output[i + 1], progressInRange);\n    };\n}\n\nexport { interpolate };\n","import { isNumber } from './is-number.es.js';\n\nconst isCubicBezier = (easing) => Array.isArray(easing) && isNumber(easing[0]);\n\nexport { isCubicBezier };\n","const isEasingGenerator = (easing) => typeof easing === \"object\" &&\n    Boolean(easing.createAnimation);\n\nexport { isEasingGenerator };\n","import { isNumber } from './is-number.es.js';\n\nconst isEasingList = (easing) => Array.isArray(easing) && !isNumber(easing[0]);\n\nexport { isEasingList };\n","const isFunction = (value) => typeof value === \"function\";\n\nexport { isFunction };\n","const isNumber = (value) => typeof value === \"number\";\n\nexport { isNumber };\n","const isString = (value) => typeof value === \"string\";\n\nexport { isString };\n","const mix = (min, max, progress) => -progress * min + progress * max + min;\n\nexport { mix };\n","const noop = () => { };\nconst noopReturn = (v) => v;\n\nexport { noop, noopReturn };\n","import { mix } from './mix.es.js';\nimport { progress } from './progress.es.js';\n\nfunction fillOffset(offset, remaining) {\n    const min = offset[offset.length - 1];\n    for (let i = 1; i <= remaining; i++) {\n        const offsetProgress = progress(0, remaining, i);\n        offset.push(mix(min, 1, offsetProgress));\n    }\n}\nfunction defaultOffset(length) {\n    const offset = [0];\n    fillOffset(offset, length - 1);\n    return offset;\n}\n\nexport { defaultOffset, fillOffset };\n","const progress = (min, max, value) => max - min === 0 ? 1 : (value - min) / (max - min);\n\nexport { progress };\n","const time = {\n    ms: (seconds) => seconds * 1000,\n    s: (milliseconds) => milliseconds / 1000,\n};\n\nexport { time };\n","var warning = function () { };\r\nvar invariant = function () { };\r\nif (process.env.NODE_ENV !== 'production') {\r\n    warning = function (check, message) {\r\n        if (!check && typeof console !== 'undefined') {\r\n            console.warn(message);\r\n        }\r\n    };\r\n    invariant = function (check, message) {\r\n        if (!check) {\r\n            throw new Error(message);\r\n        }\r\n    };\r\n}\n\nexport { invariant, warning };\n"],"sourceRoot":""}