{"version":3,"file":"static/chunks/7870-ddb6833676d6f473.js","mappings":"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","sources":["webpack://_N_E/./node_modules/next/image.js","webpack://_N_E/./node_modules/next/dist/client/image.js","webpack://_N_E/./node_modules/next/dist/shared/lib/image-blur-svg.js","webpack://_N_E/./node_modules/next/dist/shared/lib/image-loader.js","webpack://_N_E/./node_modules/framer-motion/dist/es/context/MotionConfigContext.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/context/MotionContext/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/context/PresenceContext.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/is-browser.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/use-isomorphic-effect.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/context/LazyContext.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/utils/camel-to-dash.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/optimized-appear/data-id.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/GlobalConfig.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/frameloop/batcher.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/frameloop/render-step.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/frameloop/microtask.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/is-ref-object.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/context/SwitchLayoutGroupContext.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/utils/use-visual-element.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/utils/use-motion-ref.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/is-variant-label.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/utils/is-animation-controls.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/variant-props.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/is-controlling-variants.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/context/MotionContext/create.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/context/MotionContext/utils.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/definitions.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/context/LayoutGroupContext.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/utils/symbol.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/load-features.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/motion-proxy.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/lowercase-elements.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/utils/is-svg-component.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/styles/scale-correction.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/utils/transform.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/utils/is-forced-motion-value.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/utils/is-motion-value.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/value-types/get-as-type.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/clamp.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/numbers/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/utils.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/numbers/units.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/value-types/type-int.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/value-types/number.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/utils/build-transform.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/utils/is-css-variable.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/utils/build-styles.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/utils/create-render-state.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/use-props.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/utils/valid-prop.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/utils/filter-props.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/utils/transform-origin.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/utils/path.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/utils/build-attrs.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/utils/create-render-state.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/utils/is-svg-tag.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/use-props.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/use-render.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/utils/render.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/utils/camel-case-attrs.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/utils/render.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/utils/scrape-motion-values.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/utils/scrape-motion-values.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/resolve-variants.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/utils/is-keyframes-target.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/utils/resolve-motion-value.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/resolve-value.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/animators/utils/accelerated-values.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/use-will-change/get-will-change-name.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/array.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/utils/use-visual-state.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/use-constant.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/noop.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/frameloop/frame.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/config-motion.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/config-motion.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/events/add-dom-event.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/events/utils/is-primary-pointer.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/events/event-info.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/events/add-pointer-event.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/pipe.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/drag/utils/lock.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/Feature.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/hover.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/utils/is-node-or-child.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/press.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/viewport/observers.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/viewport/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/gestures.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/focus.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/shallow-compare.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/resolve-dynamic-variants.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/time-conversion.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/utils/default-transitions.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/utils/transitions.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/use-instant-transition-state.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/animators/waapi/utils/get-final-keyframe.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/is-zero-value-string.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/errors.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/is-numerical-string.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/utils/css-variables-conversion.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/utils/unit-conversion.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/value-types/test.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/value-types/dimensions.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/value-types/type-auto.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/KeyframesResolver.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/color/utils.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/color/rgba.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/color/hex.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/color/hsla.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/color/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/complex/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/types/complex/filter.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/value-types/defaults.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/value-types/animatable-none.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/utils/make-none-animatable.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/DOMKeyframesResolver.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/utils/is-none.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/memo.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/frameloop/sync-time.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/utils/is-animatable.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/animators/BaseAnimation.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/animators/utils/can-animate.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/velocity-per-second.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/generators/utils/velocity.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/generators/spring/find.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/generators/spring/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/generators/inertia.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/cubic-bezier.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/ease.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/modifiers/mirror.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/modifiers/reverse.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/circ.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/back.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/utils/map.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/anticipate.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/progress.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/mix/number.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/hsla-to-rgba.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/mix/immediate.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/mix/color.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/mix/visibility.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/mix/complex.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/mix/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/interpolate.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/offsets/default.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/offsets/fill.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/generators/keyframes.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/utils/is-easing-array.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/offsets/time.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/animators/drivers/driver-frameloop.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/animators/MainThreadAnimation.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/generators/utils/calc-duration.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/easing/utils/is-bezier-definition.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/animators/waapi/easing.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/animators/AcceleratedAnimation.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/animators/waapi/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/scroll/supports.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/GroupPlaybackControls.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/scroll/observe.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/interfaces/motion-value.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/subscription-manager.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/setters.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/optimized-appear/get-appear-id.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/use-will-change/WillChangeMotionValue.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/use-will-change/add-will-change.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/value/use-will-change/is.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/interfaces/visual-element-target.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/interfaces/visual-element-variant.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/animation-state.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/interfaces/visual-element.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/animation/exit.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/animations.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/animation/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/distance.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/pan/PanSession.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/geometry/delta-calc.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/drag/utils/constraints.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/geometry/models.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/utils/each-axis.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/geometry/conversion.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/utils/has-transform.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/geometry/delta-apply.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/utils/measure.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/get-context-window.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/drag/VisualElementDragControls.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/pan/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/node/state.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/styles/scale-border-radius.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/styles/scale-box-shadow.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/layout/MeasureLayout.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/components/AnimatePresence/use-presence.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/animation/mix-values.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/geometry/copy.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/geometry/delta-remove.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/geometry/utils.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/shared/stack.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/compare-by-depth.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/flat-tree.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/node/create-projection-node.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/utils/is-svg-element.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/delay.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/animation/interfaces/single-value.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/styles/transform.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/node/DocumentProjectionNode.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/projection/node/HTMLProjectionNode.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/drag.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/gestures/drag/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/reduced-motion/state.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/store.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/value-types/find.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/VisualElement.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/DOMVisualElement.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/utils/reduced-motion/index.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/utils/motion-values.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/html/HTMLVisualElement.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/svg/SVGVisualElement.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/create-visual-element.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/motion.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/motion/features/layout.mjs","webpack://_N_E/./node_modules/framer-motion/dist/es/render/dom/utils/create-config.mjs"],"sourcesContent":["module.exports = require('./dist/client/image')\n","\"use client\";\n\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = Image;\nvar _extends = require(\"@swc/helpers/lib/_extends.js\").default;\nvar _interop_require_default = require(\"@swc/helpers/lib/_interop_require_default.js\").default;\nvar _interop_require_wildcard = require(\"@swc/helpers/lib/_interop_require_wildcard.js\").default;\nvar _object_without_properties_loose = require(\"@swc/helpers/lib/_object_without_properties_loose.js\").default;\nvar _react = _interop_require_wildcard(require(\"react\"));\nvar _head = _interop_require_default(require(\"../shared/lib/head\"));\nvar _imageBlurSvg = require(\"../shared/lib/image-blur-svg\");\nvar _imageConfig = require(\"../shared/lib/image-config\");\nvar _imageConfigContext = require(\"../shared/lib/image-config-context\");\nvar _warnOnce = require(\"../shared/lib/utils/warn-once\");\nvar _imageLoader = _interop_require_default(require(\"next/dist/shared/lib/image-loader\"));\nfunction Image(_param) {\n var { src , sizes , unoptimized =false , priority =false , loading , className , quality , width , height , fill , style , onLoad , onLoadingComplete , placeholder ='empty' , blurDataURL , layout , objectFit , objectPosition , lazyBoundary , lazyRoot } = _param, all = _object_without_properties_loose(_param, [\n \"src\",\n \"sizes\",\n \"unoptimized\",\n \"priority\",\n \"loading\",\n \"className\",\n \"quality\",\n \"width\",\n \"height\",\n \"fill\",\n \"style\",\n \"onLoad\",\n \"onLoadingComplete\",\n \"placeholder\",\n \"blurDataURL\",\n \"layout\",\n \"objectFit\",\n \"objectPosition\",\n \"lazyBoundary\",\n \"lazyRoot\"\n ]);\n const configContext = (0, _react).useContext(_imageConfigContext.ImageConfigContext);\n const config = (0, _react).useMemo(()=>{\n const c = configEnv || configContext || _imageConfig.imageConfigDefault;\n const allSizes = [\n ...c.deviceSizes,\n ...c.imageSizes\n ].sort((a, b)=>a - b);\n const deviceSizes = c.deviceSizes.sort((a, b)=>a - b);\n return _extends({}, c, {\n allSizes,\n deviceSizes\n });\n }, [\n configContext\n ]);\n let rest = all;\n let loader = rest.loader || _imageLoader.default;\n // Remove property so it's not spread on element\n delete rest.loader;\n if ('__next_img_default' in loader) {\n // This special value indicates that the user\n // didn't define a \"loader\" prop or config.\n if (config.loader === 'custom') {\n throw new Error(`Image with src \"${src}\" is missing \"loader\" prop.` + `\\nRead more: https://nextjs.org/docs/messages/next-image-missing-loader`);\n }\n } else {\n // The user defined a \"loader\" prop or config.\n // Since the config object is internal only, we\n // must not pass it to the user-defined \"loader\".\n const customImageLoader = loader;\n var _tmp;\n _tmp = (obj)=>{\n const { config: _ } = obj, opts = _object_without_properties_loose(obj, [\n \"config\"\n ]);\n return customImageLoader(opts);\n }, loader = _tmp, _tmp;\n }\n if (layout) {\n if (layout === 'fill') {\n fill = true;\n }\n const layoutToStyle = {\n intrinsic: {\n maxWidth: '100%',\n height: 'auto'\n },\n responsive: {\n width: '100%',\n height: 'auto'\n }\n };\n const layoutToSizes = {\n responsive: '100vw',\n fill: '100vw'\n };\n const layoutStyle = layoutToStyle[layout];\n if (layoutStyle) {\n style = _extends({}, style, layoutStyle);\n }\n const layoutSizes = layoutToSizes[layout];\n if (layoutSizes && !sizes) {\n sizes = layoutSizes;\n }\n }\n let staticSrc = '';\n let widthInt = getInt(width);\n let heightInt = getInt(height);\n let blurWidth;\n let blurHeight;\n if (isStaticImport(src)) {\n const staticImageData = isStaticRequire(src) ? src.default : src;\n if (!staticImageData.src) {\n throw new Error(`An object should only be passed to the image component src parameter if it comes from a static image import. It must include src. Received ${JSON.stringify(staticImageData)}`);\n }\n if (!staticImageData.height || !staticImageData.width) {\n throw new Error(`An object should only be passed to the image component src parameter if it comes from a static image import. It must include height and width. Received ${JSON.stringify(staticImageData)}`);\n }\n blurWidth = staticImageData.blurWidth;\n blurHeight = staticImageData.blurHeight;\n blurDataURL = blurDataURL || staticImageData.blurDataURL;\n staticSrc = staticImageData.src;\n if (!fill) {\n if (!widthInt && !heightInt) {\n widthInt = staticImageData.width;\n heightInt = staticImageData.height;\n } else if (widthInt && !heightInt) {\n const ratio = widthInt / staticImageData.width;\n heightInt = Math.round(staticImageData.height * ratio);\n } else if (!widthInt && heightInt) {\n const ratio = heightInt / staticImageData.height;\n widthInt = Math.round(staticImageData.width * ratio);\n }\n }\n }\n src = typeof src === 'string' ? src : staticSrc;\n let isLazy = !priority && (loading === 'lazy' || typeof loading === 'undefined');\n if (src.startsWith('data:') || src.startsWith('blob:')) {\n // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs\n unoptimized = true;\n isLazy = false;\n }\n if (config.unoptimized) {\n unoptimized = true;\n }\n const [blurComplete, setBlurComplete] = (0, _react).useState(false);\n const [showAltText, setShowAltText] = (0, _react).useState(false);\n const qualityInt = getInt(quality);\n if (process.env.NODE_ENV !== 'production') {\n if (!src) {\n // React doesn't show the stack trace and there's\n // no `src` to help identify which image, so we\n // instead console.error(ref) during mount.\n unoptimized = true;\n } else {\n if (fill) {\n if (width) {\n throw new Error(`Image with src \"${src}\" has both \"width\" and \"fill\" properties. Only one should be used.`);\n }\n if (height) {\n throw new Error(`Image with src \"${src}\" has both \"height\" and \"fill\" properties. Only one should be used.`);\n }\n if ((style == null ? void 0 : style.position) && style.position !== 'absolute') {\n throw new Error(`Image with src \"${src}\" has both \"fill\" and \"style.position\" properties. Images with \"fill\" always use position absolute - it cannot be modified.`);\n }\n if ((style == null ? void 0 : style.width) && style.width !== '100%') {\n throw new Error(`Image with src \"${src}\" has both \"fill\" and \"style.width\" properties. Images with \"fill\" always use width 100% - it cannot be modified.`);\n }\n if ((style == null ? void 0 : style.height) && style.height !== '100%') {\n throw new Error(`Image with src \"${src}\" has both \"fill\" and \"style.height\" properties. Images with \"fill\" always use height 100% - it cannot be modified.`);\n }\n } else {\n if (typeof widthInt === 'undefined') {\n throw new Error(`Image with src \"${src}\" is missing required \"width\" property.`);\n } else if (isNaN(widthInt)) {\n throw new Error(`Image with src \"${src}\" has invalid \"width\" property. Expected a numeric value in pixels but received \"${width}\".`);\n }\n if (typeof heightInt === 'undefined') {\n throw new Error(`Image with src \"${src}\" is missing required \"height\" property.`);\n } else if (isNaN(heightInt)) {\n throw new Error(`Image with src \"${src}\" has invalid \"height\" property. Expected a numeric value in pixels but received \"${height}\".`);\n }\n }\n }\n if (!VALID_LOADING_VALUES.includes(loading)) {\n throw new Error(`Image with src \"${src}\" has invalid \"loading\" property. Provided \"${loading}\" should be one of ${VALID_LOADING_VALUES.map(String).join(',')}.`);\n }\n if (priority && loading === 'lazy') {\n throw new Error(`Image with src \"${src}\" has both \"priority\" and \"loading='lazy'\" properties. Only one should be used.`);\n }\n if (placeholder === 'blur') {\n if (widthInt && heightInt && widthInt * heightInt < 1600) {\n (0, _warnOnce).warnOnce(`Image with src \"${src}\" is smaller than 40x40. Consider removing the \"placeholder='blur'\" property to improve performance.`);\n }\n if (!blurDataURL) {\n const VALID_BLUR_EXT = [\n 'jpeg',\n 'png',\n 'webp',\n 'avif'\n ] // should match next-image-loader\n ;\n throw new Error(`Image with src \"${src}\" has \"placeholder='blur'\" property but is missing the \"blurDataURL\" property.\n Possible solutions:\n - Add a \"blurDataURL\" property, the contents should be a small Data URL to represent the image\n - Change the \"src\" property to a static import with one of the supported file types: ${VALID_BLUR_EXT.join(',')}\n - Remove the \"placeholder\" property, effectively no blur effect\n Read more: https://nextjs.org/docs/messages/placeholder-blur-data-url`);\n }\n }\n if ('ref' in rest) {\n (0, _warnOnce).warnOnce(`Image with src \"${src}\" is using unsupported \"ref\" property. Consider using the \"onLoadingComplete\" property instead.`);\n }\n if (!unoptimized && loader !== _imageLoader.default) {\n const urlStr = loader({\n config,\n src,\n width: widthInt || 400,\n quality: qualityInt || 75\n });\n let url;\n try {\n url = new URL(urlStr);\n } catch (err) {}\n if (urlStr === src || url && url.pathname === src && !url.search) {\n (0, _warnOnce).warnOnce(`Image with src \"${src}\" has a \"loader\" property that does not implement width. Please implement it or use the \"unoptimized\" property instead.` + `\\nRead more: https://nextjs.org/docs/messages/next-image-missing-loader-width`);\n }\n }\n for (const [legacyKey, legacyValue] of Object.entries({\n layout,\n objectFit,\n objectPosition,\n lazyBoundary,\n lazyRoot\n })){\n if (legacyValue) {\n (0, _warnOnce).warnOnce(`Image with src \"${src}\" has legacy prop \"${legacyKey}\". Did you forget to run the codemod?` + `\\nRead more: https://nextjs.org/docs/messages/next-image-upgrade-to-13`);\n }\n }\n if (typeof window !== 'undefined' && !perfObserver && window.PerformanceObserver) {\n perfObserver = new PerformanceObserver((entryList)=>{\n for (const entry of entryList.getEntries()){\n var ref;\n // @ts-ignore - missing \"LargestContentfulPaint\" class with \"element\" prop\n const imgSrc = (entry == null ? void 0 : (ref = entry.element) == null ? void 0 : ref.src) || '';\n const lcpImage = allImgs.get(imgSrc);\n if (lcpImage && !lcpImage.priority && lcpImage.placeholder !== 'blur' && !lcpImage.src.startsWith('data:') && !lcpImage.src.startsWith('blob:')) {\n // https://web.dev/lcp/#measure-lcp-in-javascript\n (0, _warnOnce).warnOnce(`Image with src \"${lcpImage.src}\" was detected as the Largest Contentful Paint (LCP). Please add the \"priority\" property if this image is above the fold.` + `\\nRead more: https://nextjs.org/docs/api-reference/next/image#priority`);\n }\n }\n });\n try {\n perfObserver.observe({\n type: 'largest-contentful-paint',\n buffered: true\n });\n } catch (err) {\n // Log error but don't crash the app\n console.error(err);\n }\n }\n }\n const imgStyle = Object.assign(fill ? {\n position: 'absolute',\n height: '100%',\n width: '100%',\n left: 0,\n top: 0,\n right: 0,\n bottom: 0,\n objectFit,\n objectPosition\n } : {}, showAltText ? {} : {\n color: 'transparent'\n }, style);\n const blurStyle = placeholder === 'blur' && blurDataURL && !blurComplete ? {\n backgroundSize: imgStyle.objectFit || 'cover',\n backgroundPosition: imgStyle.objectPosition || '50% 50%',\n backgroundRepeat: 'no-repeat',\n backgroundImage: `url(\"data:image/svg+xml;charset=utf-8,${(0, _imageBlurSvg).getImageBlurSvg({\n widthInt,\n heightInt,\n blurWidth,\n blurHeight,\n blurDataURL\n })}\")`\n } : {};\n if (process.env.NODE_ENV === 'development') {\n if (blurStyle.backgroundImage && (blurDataURL == null ? void 0 : blurDataURL.startsWith('/'))) {\n // During `next dev`, we don't want to generate blur placeholders with webpack\n // because it can delay starting the dev server. Instead, `next-image-loader.js`\n // will inline a special url to lazily generate the blur placeholder at request time.\n blurStyle.backgroundImage = `url(\"${blurDataURL}\")`;\n }\n }\n const imgAttributes = generateImgAttrs({\n config,\n src,\n unoptimized,\n width: widthInt,\n quality: qualityInt,\n sizes,\n loader\n });\n let srcString = src;\n if (process.env.NODE_ENV !== 'production') {\n if (typeof window !== 'undefined') {\n let fullUrl;\n try {\n fullUrl = new URL(imgAttributes.src);\n } catch (e) {\n fullUrl = new URL(imgAttributes.src, window.location.href);\n }\n allImgs.set(fullUrl.href, {\n src,\n priority,\n placeholder\n });\n }\n }\n const linkProps = {\n // @ts-expect-error upgrade react types to react 18\n imageSrcSet: imgAttributes.srcSet,\n imageSizes: imgAttributes.sizes,\n crossOrigin: rest.crossOrigin\n };\n const onLoadRef = (0, _react).useRef(onLoad);\n (0, _react).useEffect(()=>{\n onLoadRef.current = onLoad;\n }, [\n onLoad\n ]);\n const onLoadingCompleteRef = (0, _react).useRef(onLoadingComplete);\n (0, _react).useEffect(()=>{\n onLoadingCompleteRef.current = onLoadingComplete;\n }, [\n onLoadingComplete\n ]);\n const imgElementArgs = _extends({\n isLazy,\n imgAttributes,\n heightInt,\n widthInt,\n qualityInt,\n className,\n imgStyle,\n blurStyle,\n loading,\n config,\n fill,\n unoptimized,\n placeholder,\n loader,\n srcString,\n onLoadRef,\n onLoadingCompleteRef,\n setBlurComplete,\n setShowAltText\n }, rest);\n return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(ImageElement, Object.assign({}, imgElementArgs)), priority ? // Note how we omit the `href` attribute, as it would only be relevant\n // for browsers that do not support `imagesrcset`, and in those cases\n // it would likely cause the incorrect image to be preloaded.\n //\n // https://html.spec.whatwg.org/multipage/semantics.html#attr-link-imagesrcset\n /*#__PURE__*/ _react.default.createElement(_head.default, null, /*#__PURE__*/ _react.default.createElement(\"link\", Object.assign({\n key: '__nimg-' + imgAttributes.src + imgAttributes.srcSet + imgAttributes.sizes,\n rel: \"preload\",\n as: \"image\",\n href: imgAttributes.srcSet ? undefined : imgAttributes.src\n }, linkProps))) : null);\n}\n'use client';\nconst configEnv = process.env.__NEXT_IMAGE_OPTS;\nconst allImgs = new Map();\nlet perfObserver;\nif (typeof window === 'undefined') {\n globalThis.__NEXT_IMAGE_IMPORTED = true;\n}\nconst VALID_LOADING_VALUES = [\n 'lazy',\n 'eager',\n undefined\n];\nfunction isStaticRequire(src) {\n return src.default !== undefined;\n}\nfunction isStaticImageData(src) {\n return src.src !== undefined;\n}\nfunction isStaticImport(src) {\n return typeof src === 'object' && (isStaticRequire(src) || isStaticImageData(src));\n}\nfunction getWidths({ deviceSizes , allSizes }, width, sizes) {\n if (sizes) {\n // Find all the \"vw\" percent sizes used in the sizes prop\n const viewportWidthRe = /(^|\\s)(1?\\d?\\d)vw/g;\n const percentSizes = [];\n for(let match; match = viewportWidthRe.exec(sizes); match){\n percentSizes.push(parseInt(match[2]));\n }\n if (percentSizes.length) {\n const smallestRatio = Math.min(...percentSizes) * 0.01;\n return {\n widths: allSizes.filter((s)=>s >= deviceSizes[0] * smallestRatio),\n kind: 'w'\n };\n }\n return {\n widths: allSizes,\n kind: 'w'\n };\n }\n if (typeof width !== 'number') {\n return {\n widths: deviceSizes,\n kind: 'w'\n };\n }\n const widths = [\n ...new Set(// > This means that most OLED screens that say they are 3x resolution,\n // > are actually 3x in the green color, but only 1.5x in the red and\n // > blue colors. Showing a 3x resolution image in the app vs a 2x\n // > resolution image will be visually the same, though the 3x image\n // > takes significantly more data. Even true 3x resolution screens are\n // > wasteful as the human eye cannot see that level of detail without\n // > something like a magnifying glass.\n // https://blog.twitter.com/engineering/en_us/topics/infrastructure/2019/capping-image-fidelity-on-ultra-high-resolution-devices.html\n [\n width,\n width * 2 /*, width * 3*/ \n ].map((w)=>allSizes.find((p)=>p >= w) || allSizes[allSizes.length - 1])), \n ];\n return {\n widths,\n kind: 'x'\n };\n}\nfunction generateImgAttrs({ config , src , unoptimized , width , quality , sizes , loader }) {\n if (unoptimized) {\n return {\n src,\n srcSet: undefined,\n sizes: undefined\n };\n }\n const { widths , kind } = getWidths(config, width, sizes);\n const last = widths.length - 1;\n return {\n sizes: !sizes && kind === 'w' ? '100vw' : sizes,\n srcSet: widths.map((w, i)=>`${loader({\n config,\n src,\n quality,\n width: w\n })} ${kind === 'w' ? w : i + 1}${kind}`).join(', '),\n // It's intended to keep `src` the last attribute because React updates\n // attributes in order. If we keep `src` the first one, Safari will\n // immediately start to fetch `src`, before `sizes` and `srcSet` are even\n // updated by React. That causes multiple unnecessary requests if `srcSet`\n // and `sizes` are defined.\n // This bug cannot be reproduced in Chrome or Firefox.\n src: loader({\n config,\n src,\n quality,\n width: widths[last]\n })\n };\n}\nfunction getInt(x) {\n if (typeof x === 'number' || typeof x === 'undefined') {\n return x;\n }\n if (typeof x === 'string' && /^[0-9]+$/.test(x)) {\n return parseInt(x, 10);\n }\n return NaN;\n}\n// See https://stackoverflow.com/q/39777833/266535 for why we use this ref\n// handler instead of the img's onLoad attribute.\nfunction handleLoading(img, src, placeholder, onLoadRef, onLoadingCompleteRef, setBlurComplete, unoptimized) {\n if (!img || img['data-loaded-src'] === src) {\n return;\n }\n img['data-loaded-src'] = src;\n const p = 'decode' in img ? img.decode() : Promise.resolve();\n p.catch(()=>{}).then(()=>{\n if (!img.parentNode) {\n // Exit early in case of race condition:\n // - onload() is called\n // - decode() is called but incomplete\n // - unmount is called\n // - decode() completes\n return;\n }\n if (placeholder === 'blur') {\n setBlurComplete(true);\n }\n if (onLoadRef == null ? void 0 : onLoadRef.current) {\n // Since we don't have the SyntheticEvent here,\n // we must create one with the same shape.\n // See https://reactjs.org/docs/events.html\n const event = new Event('load');\n Object.defineProperty(event, 'target', {\n writable: false,\n value: img\n });\n let prevented = false;\n let stopped = false;\n onLoadRef.current(_extends({}, event, {\n nativeEvent: event,\n currentTarget: img,\n target: img,\n isDefaultPrevented: ()=>prevented,\n isPropagationStopped: ()=>stopped,\n persist: ()=>{},\n preventDefault: ()=>{\n prevented = true;\n event.preventDefault();\n },\n stopPropagation: ()=>{\n stopped = true;\n event.stopPropagation();\n }\n }));\n }\n if (onLoadingCompleteRef == null ? void 0 : onLoadingCompleteRef.current) {\n onLoadingCompleteRef.current(img);\n }\n if (process.env.NODE_ENV !== 'production') {\n if (img.getAttribute('data-nimg') === 'fill') {\n if (!unoptimized && (!img.getAttribute('sizes') || img.getAttribute('sizes') === '100vw')) {\n let widthViewportRatio = img.getBoundingClientRect().width / window.innerWidth;\n if (widthViewportRatio < 0.6) {\n (0, _warnOnce).warnOnce(`Image with src \"${src}\" has \"fill\" but is missing \"sizes\" prop. Please add it to improve page performance. Read more: https://nextjs.org/docs/api-reference/next/image#sizes`);\n }\n }\n if (img.parentElement) {\n const { position } = window.getComputedStyle(img.parentElement);\n const valid = [\n 'absolute',\n 'fixed',\n 'relative'\n ];\n if (!valid.includes(position)) {\n (0, _warnOnce).warnOnce(`Image with src \"${src}\" has \"fill\" and parent element with invalid \"position\". Provided \"${position}\" should be one of ${valid.map(String).join(',')}.`);\n }\n }\n if (img.height === 0) {\n (0, _warnOnce).warnOnce(`Image with src \"${src}\" has \"fill\" and a height value of 0. This is likely because the parent element of the image has not been styled to have a set height.`);\n }\n }\n const heightModified = img.height.toString() !== img.getAttribute('height');\n const widthModified = img.width.toString() !== img.getAttribute('width');\n if (heightModified && !widthModified || !heightModified && widthModified) {\n (0, _warnOnce).warnOnce(`Image with src \"${src}\" has either width or height modified, but not the other. If you use CSS to change the size of your image, also include the styles 'width: \"auto\"' or 'height: \"auto\"' to maintain the aspect ratio.`);\n }\n }\n });\n}\nconst ImageElement = (_param)=>{\n var { imgAttributes , heightInt , widthInt , qualityInt , className , imgStyle , blurStyle , isLazy , fill , placeholder , loading , srcString , config , unoptimized , loader , onLoadRef , onLoadingCompleteRef , setBlurComplete , setShowAltText , onLoad , onError } = _param, rest = _object_without_properties_loose(_param, [\n \"imgAttributes\",\n \"heightInt\",\n \"widthInt\",\n \"qualityInt\",\n \"className\",\n \"imgStyle\",\n \"blurStyle\",\n \"isLazy\",\n \"fill\",\n \"placeholder\",\n \"loading\",\n \"srcString\",\n \"config\",\n \"unoptimized\",\n \"loader\",\n \"onLoadRef\",\n \"onLoadingCompleteRef\",\n \"setBlurComplete\",\n \"setShowAltText\",\n \"onLoad\",\n \"onError\"\n ]);\n loading = isLazy ? 'lazy' : loading;\n return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(\"img\", Object.assign({}, rest, imgAttributes, {\n width: widthInt,\n height: heightInt,\n decoding: \"async\",\n \"data-nimg\": fill ? 'fill' : '1',\n className: className,\n // @ts-ignore - TODO: upgrade to `@types/react@17`\n loading: loading,\n style: _extends({}, imgStyle, blurStyle),\n ref: (0, _react).useCallback((img)=>{\n if (!img) {\n return;\n }\n if (onError) {\n // If the image has an error before react hydrates, then the error is lost.\n // The workaround is to wait until the image is mounted which is after hydration,\n // then we set the src again to trigger the error handler (if there was an error).\n // eslint-disable-next-line no-self-assign\n img.src = img.src;\n }\n if (process.env.NODE_ENV !== 'production') {\n if (!srcString) {\n console.error(`Image is missing required \"src\" property:`, img);\n }\n if (img.getAttribute('alt') === null) {\n console.error(`Image is missing required \"alt\" property. Please add Alternative Text to describe the image for screen readers and search engines.`);\n }\n }\n if (img.complete) {\n handleLoading(img, srcString, placeholder, onLoadRef, onLoadingCompleteRef, setBlurComplete, unoptimized);\n }\n }, [\n srcString,\n placeholder,\n onLoadRef,\n onLoadingCompleteRef,\n setBlurComplete,\n onError,\n unoptimized, \n ]),\n onLoad: (event)=>{\n const img = event.currentTarget;\n handleLoading(img, srcString, placeholder, onLoadRef, onLoadingCompleteRef, setBlurComplete, unoptimized);\n },\n onError: (event)=>{\n // if the real image fails to load, this will ensure \"alt\" is visible\n setShowAltText(true);\n if (placeholder === 'blur') {\n // If the real image fails to load, this will still remove the placeholder.\n setBlurComplete(true);\n }\n if (onError) {\n onError(event);\n }\n }\n })));\n};\n\nif ((typeof exports.default === 'function' || (typeof exports.default === 'object' && exports.default !== null)) && typeof exports.default.__esModule === 'undefined') {\n Object.defineProperty(exports.default, '__esModule', { value: true });\n Object.assign(exports.default, exports);\n module.exports = exports.default;\n}\n\n//# sourceMappingURL=image.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getImageBlurSvg = getImageBlurSvg;\nfunction getImageBlurSvg({ widthInt , heightInt , blurWidth , blurHeight , blurDataURL }) {\n const std = blurWidth && blurHeight ? '1' : '20';\n const svgWidth = blurWidth || widthInt;\n const svgHeight = blurHeight || heightInt;\n const feComponentTransfer = blurDataURL.startsWith('data:image/jpeg') ? `%3CfeComponentTransfer%3E%3CfeFuncA type='discrete' tableValues='1 1'/%3E%3C/feComponentTransfer%3E%` : '';\n if (svgWidth && svgHeight) {\n return `%3Csvg xmlns='http%3A//www.w3.org/2000/svg' viewBox='0 0 ${svgWidth} ${svgHeight}'%3E%3Cfilter id='b' color-interpolation-filters='sRGB'%3E%3CfeGaussianBlur stdDeviation='${std}'/%3E${feComponentTransfer}%3C/filter%3E%3Cimage preserveAspectRatio='none' filter='url(%23b)' x='0' y='0' height='100%25' width='100%25' href='${blurDataURL}'/%3E%3C/svg%3E`;\n }\n return `%3Csvg xmlns='http%3A//www.w3.org/2000/svg'%3E%3Cimage style='filter:blur(20px)' x='0' y='0' height='100%25' width='100%25' href='${blurDataURL}'/%3E%3C/svg%3E`;\n}\n\n//# sourceMappingURL=image-blur-svg.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nfunction defaultLoader({ config , src , width , quality }) {\n if (process.env.NODE_ENV !== 'production') {\n const missingValues = [];\n // these should always be provided but make sure they are\n if (!src) missingValues.push('src');\n if (!width) missingValues.push('width');\n if (missingValues.length > 0) {\n throw new Error(`Next Image Optimization requires ${missingValues.join(', ')} to be provided. Make sure you pass them as props to the \\`next/image\\` component. Received: ${JSON.stringify({\n src,\n width,\n quality\n })}`);\n }\n if (src.startsWith('//')) {\n throw new Error(`Failed to parse src \"${src}\" on \\`next/image\\`, protocol-relative URL (//) must be changed to an absolute URL (http:// or https://)`);\n }\n if (!src.startsWith('/') && (config.domains || config.remotePatterns)) {\n let parsedSrc;\n try {\n parsedSrc = new URL(src);\n } catch (err) {\n console.error(err);\n throw new Error(`Failed to parse src \"${src}\" on \\`next/image\\`, if using relative image it must start with a leading slash \"/\" or be an absolute URL (http:// or https://)`);\n }\n if (process.env.NODE_ENV !== 'test') {\n // We use dynamic require because this should only error in development\n const { hasMatch } = require('./match-remote-pattern');\n if (!hasMatch(config.domains, config.remotePatterns, parsedSrc)) {\n throw new Error(`Invalid src prop (${src}) on \\`next/image\\`, hostname \"${parsedSrc.hostname}\" is not configured under images in your \\`next.config.js\\`\\n` + `See more info: https://nextjs.org/docs/messages/next-image-unconfigured-host`);\n }\n }\n }\n }\n if (src.endsWith('.svg') && !config.dangerouslyAllowSVG) {\n // Special case to make svg serve as-is to avoid proxying\n // through the built-in Image Optimization API.\n return src;\n }\n return `${config.path}?url=${encodeURIComponent(src)}&w=${width}&q=${quality || 75}`;\n}\n// We use this to determine if the import is the default loader\n// or a custom loader defined by the user in next.config.js\ndefaultLoader.__next_img_default = true;\nvar _default = defaultLoader;\nexports.default = _default;\n\n//# sourceMappingURL=image-loader.js.map","import { createContext } from 'react';\n\n/**\n * @public\n */\nconst MotionConfigContext = createContext({\n transformPagePoint: (p) => p,\n isStatic: false,\n reducedMotion: \"never\",\n});\n\nexport { MotionConfigContext };\n","import { createContext } from 'react';\n\nconst MotionContext = createContext({});\n\nexport { MotionContext };\n","import { createContext } from 'react';\n\n/**\n * @public\n */\nconst PresenceContext = createContext(null);\n\nexport { PresenceContext };\n","const isBrowser = typeof window !== \"undefined\";\n\nexport { isBrowser };\n","import { useLayoutEffect, useEffect } from 'react';\nimport { isBrowser } from './is-browser.mjs';\n\nconst useIsomorphicLayoutEffect = isBrowser ? useLayoutEffect : useEffect;\n\nexport { useIsomorphicLayoutEffect };\n","import { createContext } from 'react';\n\nconst LazyContext = createContext({ strict: false });\n\nexport { LazyContext };\n","/**\n * Convert camelCase to dash-case properties.\n */\nconst camelToDash = (str) => str.replace(/([a-z])([A-Z])/gu, \"$1-$2\").toLowerCase();\n\nexport { camelToDash };\n","import { camelToDash } from '../../render/dom/utils/camel-to-dash.mjs';\n\nconst optimizedAppearDataId = \"framerAppearId\";\nconst optimizedAppearDataAttribute = \"data-\" + camelToDash(optimizedAppearDataId);\n\nexport { optimizedAppearDataAttribute, optimizedAppearDataId };\n","const MotionGlobalConfig = {\n skipAnimations: false,\n useManualTiming: false,\n};\n\nexport { MotionGlobalConfig };\n","import { MotionGlobalConfig } from '../utils/GlobalConfig.mjs';\nimport { createRenderStep } from './render-step.mjs';\n\nconst stepsOrder = [\n \"read\", // Read\n \"resolveKeyframes\", // Write/Read/Write/Read\n \"update\", // Compute\n \"preRender\", // Compute\n \"render\", // Write\n \"postRender\", // Compute\n];\nconst maxElapsed = 40;\nfunction createRenderBatcher(scheduleNextBatch, allowKeepAlive) {\n let runNextFrame = false;\n let useDefaultElapsed = true;\n const state = {\n delta: 0.0,\n timestamp: 0.0,\n isProcessing: false,\n };\n const flagRunNextFrame = () => (runNextFrame = true);\n const steps = stepsOrder.reduce((acc, key) => {\n acc[key] = createRenderStep(flagRunNextFrame);\n return acc;\n }, {});\n const { read, resolveKeyframes, update, preRender, render, postRender } = steps;\n const processBatch = () => {\n const timestamp = MotionGlobalConfig.useManualTiming\n ? state.timestamp\n : performance.now();\n runNextFrame = false;\n state.delta = useDefaultElapsed\n ? 1000 / 60\n : Math.max(Math.min(timestamp - state.timestamp, maxElapsed), 1);\n state.timestamp = timestamp;\n state.isProcessing = true;\n // Unrolled render loop for better per-frame performance\n read.process(state);\n resolveKeyframes.process(state);\n update.process(state);\n preRender.process(state);\n render.process(state);\n postRender.process(state);\n state.isProcessing = false;\n if (runNextFrame && allowKeepAlive) {\n useDefaultElapsed = false;\n scheduleNextBatch(processBatch);\n }\n };\n const wake = () => {\n runNextFrame = true;\n useDefaultElapsed = true;\n if (!state.isProcessing) {\n scheduleNextBatch(processBatch);\n }\n };\n const schedule = stepsOrder.reduce((acc, key) => {\n const step = steps[key];\n acc[key] = (process, keepAlive = false, immediate = false) => {\n if (!runNextFrame)\n wake();\n return step.schedule(process, keepAlive, immediate);\n };\n return acc;\n }, {});\n const cancel = (process) => {\n for (let i = 0; i < stepsOrder.length; i++) {\n steps[stepsOrder[i]].cancel(process);\n }\n };\n return { schedule, cancel, state, steps };\n}\n\nexport { createRenderBatcher, stepsOrder };\n","function createRenderStep(runNextFrame) {\n /**\n * We create and reuse two queues, one to queue jobs for the current frame\n * and one for the next. We reuse to avoid triggering GC after x frames.\n */\n let thisFrame = new Set();\n let nextFrame = new Set();\n /**\n * Track whether we're currently processing jobs in this step. This way\n * we can decide whether to schedule new jobs for this frame or next.\n */\n let isProcessing = false;\n let flushNextFrame = false;\n /**\n * A set of processes which were marked keepAlive when scheduled.\n */\n const toKeepAlive = new WeakSet();\n let latestFrameData = {\n delta: 0.0,\n timestamp: 0.0,\n isProcessing: false,\n };\n function triggerCallback(callback) {\n if (toKeepAlive.has(callback)) {\n step.schedule(callback);\n runNextFrame();\n }\n callback(latestFrameData);\n }\n const step = {\n /**\n * Schedule a process to run on the next frame.\n */\n schedule: (callback, keepAlive = false, immediate = false) => {\n const addToCurrentFrame = immediate && isProcessing;\n const queue = addToCurrentFrame ? thisFrame : nextFrame;\n if (keepAlive)\n toKeepAlive.add(callback);\n if (!queue.has(callback))\n queue.add(callback);\n return callback;\n },\n /**\n * Cancel the provided callback from running on the next frame.\n */\n cancel: (callback) => {\n nextFrame.delete(callback);\n toKeepAlive.delete(callback);\n },\n /**\n * Execute all schedule callbacks.\n */\n process: (frameData) => {\n latestFrameData = frameData;\n /**\n * If we're already processing we've probably been triggered by a flushSync\n * inside an existing process. Instead of executing, mark flushNextFrame\n * as true and ensure we flush the following frame at the end of this one.\n */\n if (isProcessing) {\n flushNextFrame = true;\n return;\n }\n isProcessing = true;\n [thisFrame, nextFrame] = [nextFrame, thisFrame];\n // Clear the next frame queue\n nextFrame.clear();\n // Execute this frame\n thisFrame.forEach(triggerCallback);\n isProcessing = false;\n if (flushNextFrame) {\n flushNextFrame = false;\n step.process(frameData);\n }\n },\n };\n return step;\n}\n\nexport { createRenderStep };\n","import { createRenderBatcher } from './batcher.mjs';\n\nconst { schedule: microtask, cancel: cancelMicrotask } = createRenderBatcher(queueMicrotask, false);\n\nexport { cancelMicrotask, microtask };\n","function isRefObject(ref) {\n return (ref &&\n typeof ref === \"object\" &&\n Object.prototype.hasOwnProperty.call(ref, \"current\"));\n}\n\nexport { isRefObject };\n","import { createContext } from 'react';\n\n/**\n * Internal, exported only for usage in Framer\n */\nconst SwitchLayoutGroupContext = createContext({});\n\nexport { SwitchLayoutGroupContext };\n","import { useContext, useRef, useInsertionEffect, useEffect } from 'react';\nimport { PresenceContext } from '../../context/PresenceContext.mjs';\nimport { MotionContext } from '../../context/MotionContext/index.mjs';\nimport { useIsomorphicLayoutEffect } from '../../utils/use-isomorphic-effect.mjs';\nimport { LazyContext } from '../../context/LazyContext.mjs';\nimport { MotionConfigContext } from '../../context/MotionConfigContext.mjs';\nimport { optimizedAppearDataAttribute } from '../../animation/optimized-appear/data-id.mjs';\nimport { microtask } from '../../frameloop/microtask.mjs';\nimport { isRefObject } from '../../utils/is-ref-object.mjs';\nimport { SwitchLayoutGroupContext } from '../../context/SwitchLayoutGroupContext.mjs';\n\nlet scheduleHandoffComplete = false;\nfunction useVisualElement(Component, visualState, props, createVisualElement, ProjectionNodeConstructor) {\n var _a;\n const { visualElement: parent } = useContext(MotionContext);\n const lazyContext = useContext(LazyContext);\n const presenceContext = useContext(PresenceContext);\n const reducedMotionConfig = useContext(MotionConfigContext).reducedMotion;\n const visualElementRef = useRef();\n /**\n * If we haven't preloaded a renderer, check to see if we have one lazy-loaded\n */\n createVisualElement = createVisualElement || lazyContext.renderer;\n if (!visualElementRef.current && createVisualElement) {\n visualElementRef.current = createVisualElement(Component, {\n visualState,\n parent,\n props,\n presenceContext,\n blockInitialAnimation: presenceContext\n ? presenceContext.initial === false\n : false,\n reducedMotionConfig,\n });\n }\n const visualElement = visualElementRef.current;\n /**\n * Load Motion gesture and animation features. These are rendered as renderless\n * components so each feature can optionally make use of React lifecycle methods.\n */\n const initialLayoutGroupConfig = useContext(SwitchLayoutGroupContext);\n if (visualElement &&\n !visualElement.projection &&\n ProjectionNodeConstructor &&\n (visualElement.type === \"html\" || visualElement.type === \"svg\")) {\n createProjectionNode(visualElementRef.current, props, ProjectionNodeConstructor, initialLayoutGroupConfig);\n }\n useInsertionEffect(() => {\n visualElement && visualElement.update(props, presenceContext);\n });\n /**\n * Cache this value as we want to know whether HandoffAppearAnimations\n * was present on initial render - it will be deleted after this.\n */\n const optimisedAppearId = props[optimizedAppearDataAttribute];\n const wantsHandoff = useRef(Boolean(optimisedAppearId) &&\n !window.MotionHandoffIsComplete &&\n ((_a = window.MotionHasOptimisedAnimation) === null || _a === void 0 ? void 0 : _a.call(window, optimisedAppearId)));\n useIsomorphicLayoutEffect(() => {\n if (!visualElement)\n return;\n visualElement.updateFeatures();\n microtask.render(visualElement.render);\n /**\n * Ideally this function would always run in a useEffect.\n *\n * However, if we have optimised appear animations to handoff from,\n * it needs to happen synchronously to ensure there's no flash of\n * incorrect styles in the event of a hydration error.\n *\n * So if we detect a situtation where optimised appear animations\n * are running, we use useLayoutEffect to trigger animations.\n */\n if (wantsHandoff.current && visualElement.animationState) {\n visualElement.animationState.animateChanges();\n }\n });\n useEffect(() => {\n if (!visualElement)\n return;\n if (!wantsHandoff.current && visualElement.animationState) {\n visualElement.animationState.animateChanges();\n }\n wantsHandoff.current = false;\n // This ensures all future calls to animateChanges() will run in useEffect\n if (!scheduleHandoffComplete) {\n scheduleHandoffComplete = true;\n queueMicrotask(completeHandoff);\n }\n });\n return visualElement;\n}\nfunction completeHandoff() {\n window.MotionHandoffIsComplete = true;\n}\nfunction createProjectionNode(visualElement, props, ProjectionNodeConstructor, initialPromotionConfig) {\n const { layoutId, layout, drag, dragConstraints, layoutScroll, layoutRoot, } = props;\n visualElement.projection = new ProjectionNodeConstructor(visualElement.latestValues, props[\"data-framer-portal-id\"]\n ? undefined\n : getClosestProjectingNode(visualElement.parent));\n visualElement.projection.setOptions({\n layoutId,\n layout,\n alwaysMeasureLayout: Boolean(drag) || (dragConstraints && isRefObject(dragConstraints)),\n visualElement,\n /**\n * TODO: Update options in an effect. This could be tricky as it'll be too late\n * to update by the time layout animations run.\n * We also need to fix this safeToRemove by linking it up to the one returned by usePresence,\n * ensuring it gets called if there's no potential layout animations.\n *\n */\n animationType: typeof layout === \"string\" ? layout : \"both\",\n initialPromotionConfig,\n layoutScroll,\n layoutRoot,\n });\n}\nfunction getClosestProjectingNode(visualElement) {\n if (!visualElement)\n return undefined;\n return visualElement.options.allowProjection !== false\n ? visualElement.projection\n : getClosestProjectingNode(visualElement.parent);\n}\n\nexport { useVisualElement };\n","import { useCallback } from 'react';\nimport { isRefObject } from '../../utils/is-ref-object.mjs';\n\n/**\n * Creates a ref function that, when called, hydrates the provided\n * external ref and VisualElement.\n */\nfunction useMotionRef(visualState, visualElement, externalRef) {\n return useCallback((instance) => {\n instance && visualState.mount && visualState.mount(instance);\n if (visualElement) {\n if (instance) {\n visualElement.mount(instance);\n }\n else {\n visualElement.unmount();\n }\n }\n if (externalRef) {\n if (typeof externalRef === \"function\") {\n externalRef(instance);\n }\n else if (isRefObject(externalRef)) {\n externalRef.current = instance;\n }\n }\n }, \n /**\n * Only pass a new ref callback to React if we've received a visual element\n * factory. Otherwise we'll be mounting/remounting every time externalRef\n * or other dependencies change.\n */\n [visualElement]);\n}\n\nexport { useMotionRef };\n","/**\n * Decides if the supplied variable is variant label\n */\nfunction isVariantLabel(v) {\n return typeof v === \"string\" || Array.isArray(v);\n}\n\nexport { isVariantLabel };\n","function isAnimationControls(v) {\n return (v !== null &&\n typeof v === \"object\" &&\n typeof v.start === \"function\");\n}\n\nexport { isAnimationControls };\n","const variantPriorityOrder = [\n \"animate\",\n \"whileInView\",\n \"whileFocus\",\n \"whileHover\",\n \"whileTap\",\n \"whileDrag\",\n \"exit\",\n];\nconst variantProps = [\"initial\", ...variantPriorityOrder];\n\nexport { variantPriorityOrder, variantProps };\n","import { isAnimationControls } from '../../animation/utils/is-animation-controls.mjs';\nimport { isVariantLabel } from './is-variant-label.mjs';\nimport { variantProps } from './variant-props.mjs';\n\nfunction isControllingVariants(props) {\n return (isAnimationControls(props.animate) ||\n variantProps.some((name) => isVariantLabel(props[name])));\n}\nfunction isVariantNode(props) {\n return Boolean(isControllingVariants(props) || props.variants);\n}\n\nexport { isControllingVariants, isVariantNode };\n","import { useContext, useMemo } from 'react';\nimport { MotionContext } from './index.mjs';\nimport { getCurrentTreeVariants } from './utils.mjs';\n\nfunction useCreateMotionContext(props) {\n const { initial, animate } = getCurrentTreeVariants(props, useContext(MotionContext));\n return useMemo(() => ({ initial, animate }), [variantLabelsAsDependency(initial), variantLabelsAsDependency(animate)]);\n}\nfunction variantLabelsAsDependency(prop) {\n return Array.isArray(prop) ? prop.join(\" \") : prop;\n}\n\nexport { useCreateMotionContext };\n","import { isVariantLabel } from '../../render/utils/is-variant-label.mjs';\nimport { isControllingVariants } from '../../render/utils/is-controlling-variants.mjs';\n\nfunction getCurrentTreeVariants(props, context) {\n if (isControllingVariants(props)) {\n const { initial, animate } = props;\n return {\n initial: initial === false || isVariantLabel(initial)\n ? initial\n : undefined,\n animate: isVariantLabel(animate) ? animate : undefined,\n };\n }\n return props.inherit !== false ? context : {};\n}\n\nexport { getCurrentTreeVariants };\n","const featureProps = {\n animation: [\n \"animate\",\n \"variants\",\n \"whileHover\",\n \"whileTap\",\n \"exit\",\n \"whileInView\",\n \"whileFocus\",\n \"whileDrag\",\n ],\n exit: [\"exit\"],\n drag: [\"drag\", \"dragControls\"],\n focus: [\"whileFocus\"],\n hover: [\"whileHover\", \"onHoverStart\", \"onHoverEnd\"],\n tap: [\"whileTap\", \"onTap\", \"onTapStart\", \"onTapCancel\"],\n pan: [\"onPan\", \"onPanStart\", \"onPanSessionStart\", \"onPanEnd\"],\n inView: [\"whileInView\", \"onViewportEnter\", \"onViewportLeave\"],\n layout: [\"layout\", \"layoutId\"],\n};\nconst featureDefinitions = {};\nfor (const key in featureProps) {\n featureDefinitions[key] = {\n isEnabled: (props) => featureProps[key].some((name) => !!props[name]),\n };\n}\n\nexport { featureDefinitions };\n","import { createContext } from 'react';\n\nconst LayoutGroupContext = createContext({});\n\nexport { LayoutGroupContext };\n","const motionComponentSymbol = Symbol.for(\"motionComponentSymbol\");\n\nexport { motionComponentSymbol };\n","import { jsxs, jsx } from 'react/jsx-runtime';\nimport { forwardRef, useContext } from 'react';\nimport { MotionConfigContext } from '../context/MotionConfigContext.mjs';\nimport { MotionContext } from '../context/MotionContext/index.mjs';\nimport { useVisualElement } from './utils/use-visual-element.mjs';\nimport { useMotionRef } from './utils/use-motion-ref.mjs';\nimport { useCreateMotionContext } from '../context/MotionContext/create.mjs';\nimport { loadFeatures } from './features/load-features.mjs';\nimport { isBrowser } from '../utils/is-browser.mjs';\nimport { LayoutGroupContext } from '../context/LayoutGroupContext.mjs';\nimport { LazyContext } from '../context/LazyContext.mjs';\nimport { motionComponentSymbol } from './utils/symbol.mjs';\nimport { warning, invariant } from '../utils/errors.mjs';\nimport { featureDefinitions } from './features/definitions.mjs';\n\n/**\n * Create a `motion` component.\n *\n * This function accepts a Component argument, which can be either a string (ie \"div\"\n * for `motion.div`), or an actual React component.\n *\n * Alongside this is a config option which provides a way of rendering the provided\n * component \"offline\", or outside the React render cycle.\n */\nfunction createMotionComponent({ preloadedFeatures, createVisualElement, useRender, useVisualState, Component, }) {\n preloadedFeatures && loadFeatures(preloadedFeatures);\n function MotionComponent(props, externalRef) {\n /**\n * If we need to measure the element we load this functionality in a\n * separate class component in order to gain access to getSnapshotBeforeUpdate.\n */\n let MeasureLayout;\n const configAndProps = {\n ...useContext(MotionConfigContext),\n ...props,\n layoutId: useLayoutId(props),\n };\n const { isStatic } = configAndProps;\n const context = useCreateMotionContext(props);\n const visualState = useVisualState(props, isStatic);\n if (!isStatic && isBrowser) {\n useStrictMode(configAndProps, preloadedFeatures);\n const layoutProjection = getProjectionFunctionality(configAndProps);\n MeasureLayout = layoutProjection.MeasureLayout;\n /**\n * Create a VisualElement for this component. A VisualElement provides a common\n * interface to renderer-specific APIs (ie DOM/Three.js etc) as well as\n * providing a way of rendering to these APIs outside of the React render loop\n * for more performant animations and interactions\n */\n context.visualElement = useVisualElement(Component, visualState, configAndProps, createVisualElement, layoutProjection.ProjectionNode);\n }\n /**\n * The mount order and hierarchy is specific to ensure our element ref\n * is hydrated by the time features fire their effects.\n */\n return (jsxs(MotionContext.Provider, { value: context, children: [MeasureLayout && context.visualElement ? (jsx(MeasureLayout, { visualElement: context.visualElement, ...configAndProps })) : null, useRender(Component, props, useMotionRef(visualState, context.visualElement, externalRef), visualState, isStatic, context.visualElement)] }));\n }\n const ForwardRefComponent = forwardRef(MotionComponent);\n ForwardRefComponent[motionComponentSymbol] = Component;\n return ForwardRefComponent;\n}\nfunction useLayoutId({ layoutId }) {\n const layoutGroupId = useContext(LayoutGroupContext).id;\n return layoutGroupId && layoutId !== undefined\n ? layoutGroupId + \"-\" + layoutId\n : layoutId;\n}\nfunction useStrictMode(configAndProps, preloadedFeatures) {\n const isStrict = useContext(LazyContext).strict;\n /**\n * If we're in development mode, check to make sure we're not rendering a motion component\n * as a child of LazyMotion, as this will break the file-size benefits of using it.\n */\n if (process.env.NODE_ENV !== \"production\" &&\n preloadedFeatures &&\n isStrict) {\n const strictMessage = \"You have rendered a `motion` component within a `LazyMotion` component. This will break tree shaking. Import and render a `m` component instead.\";\n configAndProps.ignoreStrict\n ? warning(false, strictMessage)\n : invariant(false, strictMessage);\n }\n}\nfunction getProjectionFunctionality(props) {\n const { drag, layout } = featureDefinitions;\n if (!drag && !layout)\n return {};\n const combined = { ...drag, ...layout };\n return {\n MeasureLayout: (drag === null || drag === void 0 ? void 0 : drag.isEnabled(props)) || (layout === null || layout === void 0 ? void 0 : layout.isEnabled(props))\n ? combined.MeasureLayout\n : undefined,\n ProjectionNode: combined.ProjectionNode,\n };\n}\n\nexport { createMotionComponent };\n","import { featureDefinitions } from './definitions.mjs';\n\nfunction loadFeatures(features) {\n for (const key in features) {\n featureDefinitions[key] = {\n ...featureDefinitions[key],\n ...features[key],\n };\n }\n}\n\nexport { loadFeatures };\n","import { createMotionComponent } from '../../motion/index.mjs';\n\n/**\n * Convert any React component into a `motion` component. The provided component\n * **must** use `React.forwardRef` to the underlying DOM component you want to animate.\n *\n * ```jsx\n * const Component = React.forwardRef((props, ref) => {\n * return
\n * })\n *\n * const MotionComponent = motion(Component)\n * ```\n *\n * @public\n */\nfunction createMotionProxy(createConfig) {\n function custom(Component, customMotionComponentConfig = {}) {\n return createMotionComponent(createConfig(Component, customMotionComponentConfig));\n }\n if (typeof Proxy === \"undefined\") {\n return custom;\n }\n /**\n * A cache of generated `motion` components, e.g `motion.div`, `motion.input` etc.\n * Rather than generating them anew every render.\n */\n const componentCache = new Map();\n return new Proxy(custom, {\n /**\n * Called when `motion` is referenced with a prop: `motion.div`, `motion.input` etc.\n * The prop name is passed through as `key` and we can use that to generate a `motion`\n * DOM component with that name.\n */\n get: (_target, key) => {\n /**\n * If this element doesn't exist in the component cache, create it and cache.\n */\n if (!componentCache.has(key)) {\n componentCache.set(key, custom(key));\n }\n return componentCache.get(key);\n },\n });\n}\n\nexport { createMotionProxy };\n","/**\n * We keep these listed separately as we use the lowercase tag names as part\n * of the runtime bundle to detect SVG components\n */\nconst lowercaseSVGElements = [\n \"animate\",\n \"circle\",\n \"defs\",\n \"desc\",\n \"ellipse\",\n \"g\",\n \"image\",\n \"line\",\n \"filter\",\n \"marker\",\n \"mask\",\n \"metadata\",\n \"path\",\n \"pattern\",\n \"polygon\",\n \"polyline\",\n \"rect\",\n \"stop\",\n \"switch\",\n \"symbol\",\n \"svg\",\n \"text\",\n \"tspan\",\n \"use\",\n \"view\",\n];\n\nexport { lowercaseSVGElements };\n","import { lowercaseSVGElements } from '../../svg/lowercase-elements.mjs';\n\nfunction isSVGComponent(Component) {\n if (\n /**\n * If it's not a string, it's a custom React component. Currently we only support\n * HTML custom React components.\n */\n typeof Component !== \"string\" ||\n /**\n * If it contains a dash, the element is a custom HTML webcomponent.\n */\n Component.includes(\"-\")) {\n return false;\n }\n else if (\n /**\n * If it's in our list of lowercase SVG tags, it's an SVG component\n */\n lowercaseSVGElements.indexOf(Component) > -1 ||\n /**\n * If it contains a capital letter, it's an SVG component\n */\n /[A-Z]/u.test(Component)) {\n return true;\n }\n return false;\n}\n\nexport { isSVGComponent };\n","const scaleCorrectors = {};\nfunction addScaleCorrector(correctors) {\n Object.assign(scaleCorrectors, correctors);\n}\n\nexport { addScaleCorrector, scaleCorrectors };\n","/**\n * Generate a list of every possible transform key.\n */\nconst transformPropOrder = [\n \"transformPerspective\",\n \"x\",\n \"y\",\n \"z\",\n \"translateX\",\n \"translateY\",\n \"translateZ\",\n \"scale\",\n \"scaleX\",\n \"scaleY\",\n \"rotate\",\n \"rotateX\",\n \"rotateY\",\n \"rotateZ\",\n \"skew\",\n \"skewX\",\n \"skewY\",\n];\n/**\n * A quick lookup for transform props.\n */\nconst transformProps = new Set(transformPropOrder);\n\nexport { transformPropOrder, transformProps };\n","import { scaleCorrectors } from '../../projection/styles/scale-correction.mjs';\nimport { transformProps } from '../../render/html/utils/transform.mjs';\n\nfunction isForcedMotionValue(key, { layout, layoutId }) {\n return (transformProps.has(key) ||\n key.startsWith(\"origin\") ||\n ((layout || layoutId !== undefined) &&\n (!!scaleCorrectors[key] || key === \"opacity\")));\n}\n\nexport { isForcedMotionValue };\n","const isMotionValue = (value) => Boolean(value && value.getVelocity);\n\nexport { isMotionValue };\n","/**\n * Provided a value and a ValueType, returns the value as that value type.\n */\nconst getValueAsType = (value, type) => {\n return type && typeof value === \"number\"\n ? type.transform(value)\n : value;\n};\n\nexport { getValueAsType };\n","const clamp = (min, max, v) => {\n if (v > max)\n return max;\n if (v < min)\n return min;\n return v;\n};\n\nexport { clamp };\n","import { clamp } from '../../../utils/clamp.mjs';\n\nconst number = {\n test: (v) => typeof v === \"number\",\n parse: parseFloat,\n transform: (v) => v,\n};\nconst alpha = {\n ...number,\n transform: (v) => clamp(0, 1, v),\n};\nconst scale = {\n ...number,\n default: 1,\n};\n\nexport { alpha, number, scale };\n","/**\n * TODO: When we move from string as a source of truth to data models\n * everything in this folder should probably be referred to as models vs types\n */\n// If this number is a decimal, make it just five decimal places\n// to avoid exponents\nconst sanitize = (v) => Math.round(v * 100000) / 100000;\nconst floatRegex = /-?(?:\\d+(?:\\.\\d+)?|\\.\\d+)/gu;\nconst colorRegex = /(?:#[\\da-f]{3,8}|(?:rgb|hsl)a?\\((?:-?[\\d.]+%?[,\\s]+){2}-?[\\d.]+%?\\s*(?:[,/]\\s*)?(?:\\b\\d+(?:\\.\\d+)?|\\.\\d+)?%?\\))/giu;\nconst singleColorRegex = /^(?:#[\\da-f]{3,8}|(?:rgb|hsl)a?\\((?:-?[\\d.]+%?[,\\s]+){2}-?[\\d.]+%?\\s*(?:[,/]\\s*)?(?:\\b\\d+(?:\\.\\d+)?|\\.\\d+)?%?\\))$/iu;\nfunction isString(v) {\n return typeof v === \"string\";\n}\nfunction isNullish(v) {\n return v == null;\n}\n\nexport { colorRegex, floatRegex, isNullish, isString, sanitize, singleColorRegex };\n","import { isString } from '../utils.mjs';\n\nconst createUnitType = (unit) => ({\n test: (v) => isString(v) && v.endsWith(unit) && v.split(\" \").length === 1,\n parse: parseFloat,\n transform: (v) => `${v}${unit}`,\n});\nconst degrees = createUnitType(\"deg\");\nconst percent = createUnitType(\"%\");\nconst px = createUnitType(\"px\");\nconst vh = createUnitType(\"vh\");\nconst vw = createUnitType(\"vw\");\nconst progressPercentage = {\n ...percent,\n parse: (v) => percent.parse(v) / 100,\n transform: (v) => percent.transform(v * 100),\n};\n\nexport { degrees, percent, progressPercentage, px, vh, vw };\n","import { number } from '../../../value/types/numbers/index.mjs';\n\nconst int = {\n ...number,\n transform: Math.round,\n};\n\nexport { int };\n","import { scale, alpha } from '../../../value/types/numbers/index.mjs';\nimport { px, degrees, progressPercentage } from '../../../value/types/numbers/units.mjs';\nimport { int } from './type-int.mjs';\n\nconst numberValueTypes = {\n // Border props\n borderWidth: px,\n borderTopWidth: px,\n borderRightWidth: px,\n borderBottomWidth: px,\n borderLeftWidth: px,\n borderRadius: px,\n radius: px,\n borderTopLeftRadius: px,\n borderTopRightRadius: px,\n borderBottomRightRadius: px,\n borderBottomLeftRadius: px,\n // Positioning props\n width: px,\n maxWidth: px,\n height: px,\n maxHeight: px,\n size: px,\n top: px,\n right: px,\n bottom: px,\n left: px,\n // Spacing props\n padding: px,\n paddingTop: px,\n paddingRight: px,\n paddingBottom: px,\n paddingLeft: px,\n margin: px,\n marginTop: px,\n marginRight: px,\n marginBottom: px,\n marginLeft: px,\n // Transform props\n rotate: degrees,\n rotateX: degrees,\n rotateY: degrees,\n rotateZ: degrees,\n scale,\n scaleX: scale,\n scaleY: scale,\n scaleZ: scale,\n skew: degrees,\n skewX: degrees,\n skewY: degrees,\n distance: px,\n translateX: px,\n translateY: px,\n translateZ: px,\n x: px,\n y: px,\n z: px,\n perspective: px,\n transformPerspective: px,\n opacity: alpha,\n originX: progressPercentage,\n originY: progressPercentage,\n originZ: px,\n // Misc\n zIndex: int,\n backgroundPositionX: px,\n backgroundPositionY: px,\n // SVG\n fillOpacity: alpha,\n strokeOpacity: alpha,\n numOctaves: int,\n};\n\nexport { numberValueTypes };\n","import { transformPropOrder } from './transform.mjs';\nimport { getValueAsType } from '../../dom/value-types/get-as-type.mjs';\nimport { numberValueTypes } from '../../dom/value-types/number.mjs';\n\nconst translateAlias = {\n x: \"translateX\",\n y: \"translateY\",\n z: \"translateZ\",\n transformPerspective: \"perspective\",\n};\nconst numTransforms = transformPropOrder.length;\n/**\n * Build a CSS transform style from individual x/y/scale etc properties.\n *\n * This outputs with a default order of transforms/scales/rotations, this can be customised by\n * providing a transformTemplate function.\n */\nfunction buildTransform(latestValues, transform, transformTemplate) {\n // The transform string we're going to build into.\n let transformString = \"\";\n let transformIsDefault = true;\n /**\n * Loop over all possible transforms in order, adding the ones that\n * are present to the transform string.\n */\n for (let i = 0; i < numTransforms; i++) {\n const key = transformPropOrder[i];\n const value = latestValues[key];\n if (value === undefined)\n continue;\n let valueIsDefault = true;\n if (typeof value === \"number\") {\n valueIsDefault = value === (key.startsWith(\"scale\") ? 1 : 0);\n }\n else {\n valueIsDefault = parseFloat(value) === 0;\n }\n if (!valueIsDefault || transformTemplate) {\n const valueAsType = getValueAsType(value, numberValueTypes[key]);\n if (!valueIsDefault) {\n transformIsDefault = false;\n const transformName = translateAlias[key] || key;\n transformString += `${transformName}(${valueAsType}) `;\n }\n if (transformTemplate) {\n transform[key] = valueAsType;\n }\n }\n }\n transformString = transformString.trim();\n // If we have a custom `transform` template, pass our transform values and\n // generated transformString to that before returning\n if (transformTemplate) {\n transformString = transformTemplate(transform, transformIsDefault ? \"\" : transformString);\n }\n else if (transformIsDefault) {\n transformString = \"none\";\n }\n return transformString;\n}\n\nexport { buildTransform };\n","const checkStringStartsWith = (token) => (key) => typeof key === \"string\" && key.startsWith(token);\nconst isCSSVariableName = checkStringStartsWith(\"--\");\nconst startsAsVariableToken = checkStringStartsWith(\"var(--\");\nconst isCSSVariableToken = (value) => {\n const startsWithToken = startsAsVariableToken(value);\n if (!startsWithToken)\n return false;\n // Ensure any comments are stripped from the value as this can harm performance of the regex.\n return singleCssVariableRegex.test(value.split(\"/*\")[0].trim());\n};\nconst singleCssVariableRegex = /var\\(--(?:[\\w-]+\\s*|[\\w-]+\\s*,(?:\\s*[^)(\\s]|\\s*\\((?:[^)(]|\\([^)(]*\\))*\\))+\\s*)\\)$/iu;\n\nexport { isCSSVariableName, isCSSVariableToken };\n","import { buildTransform } from './build-transform.mjs';\nimport { isCSSVariableName } from '../../dom/utils/is-css-variable.mjs';\nimport { transformProps } from './transform.mjs';\nimport { getValueAsType } from '../../dom/value-types/get-as-type.mjs';\nimport { numberValueTypes } from '../../dom/value-types/number.mjs';\n\nfunction buildHTMLStyles(state, latestValues, transformTemplate) {\n const { style, vars, transformOrigin } = state;\n // Track whether we encounter any transform or transformOrigin values.\n let hasTransform = false;\n let hasTransformOrigin = false;\n /**\n * Loop over all our latest animated values and decide whether to handle them\n * as a style or CSS variable.\n *\n * Transforms and transform origins are kept separately for further processing.\n */\n for (const key in latestValues) {\n const value = latestValues[key];\n if (transformProps.has(key)) {\n // If this is a transform, flag to enable further transform processing\n hasTransform = true;\n continue;\n }\n else if (isCSSVariableName(key)) {\n vars[key] = value;\n continue;\n }\n else {\n // Convert the value to its default value type, ie 0 -> \"0px\"\n const valueAsType = getValueAsType(value, numberValueTypes[key]);\n if (key.startsWith(\"origin\")) {\n // If this is a transform origin, flag and enable further transform-origin processing\n hasTransformOrigin = true;\n transformOrigin[key] =\n valueAsType;\n }\n else {\n style[key] = valueAsType;\n }\n }\n }\n if (!latestValues.transform) {\n if (hasTransform || transformTemplate) {\n style.transform = buildTransform(latestValues, state.transform, transformTemplate);\n }\n else if (style.transform) {\n /**\n * If we have previously created a transform but currently don't have any,\n * reset transform style to none.\n */\n style.transform = \"none\";\n }\n }\n /**\n * Build a transformOrigin style. Uses the same defaults as the browser for\n * undefined origins.\n */\n if (hasTransformOrigin) {\n const { originX = \"50%\", originY = \"50%\", originZ = 0, } = transformOrigin;\n style.transformOrigin = `${originX} ${originY} ${originZ}`;\n }\n}\n\nexport { buildHTMLStyles };\n","const createHtmlRenderState = () => ({\n style: {},\n transform: {},\n transformOrigin: {},\n vars: {},\n});\n\nexport { createHtmlRenderState };\n","import { useMemo } from 'react';\nimport { isForcedMotionValue } from '../../motion/utils/is-forced-motion-value.mjs';\nimport { isMotionValue } from '../../value/utils/is-motion-value.mjs';\nimport { buildHTMLStyles } from './utils/build-styles.mjs';\nimport { createHtmlRenderState } from './utils/create-render-state.mjs';\n\nfunction copyRawValuesOnly(target, source, props) {\n for (const key in source) {\n if (!isMotionValue(source[key]) && !isForcedMotionValue(key, props)) {\n target[key] = source[key];\n }\n }\n}\nfunction useInitialMotionValues({ transformTemplate }, visualState) {\n return useMemo(() => {\n const state = createHtmlRenderState();\n buildHTMLStyles(state, visualState, transformTemplate);\n return Object.assign({}, state.vars, state.style);\n }, [visualState]);\n}\nfunction useStyle(props, visualState) {\n const styleProp = props.style || {};\n const style = {};\n /**\n * Copy non-Motion Values straight into style\n */\n copyRawValuesOnly(style, styleProp, props);\n Object.assign(style, useInitialMotionValues(props, visualState));\n return style;\n}\nfunction useHTMLProps(props, visualState) {\n // The `any` isn't ideal but it is the type of createElement props argument\n const htmlProps = {};\n const style = useStyle(props, visualState);\n if (props.drag && props.dragListener !== false) {\n // Disable the ghost element when a user drags\n htmlProps.draggable = false;\n // Disable text selection\n style.userSelect =\n style.WebkitUserSelect =\n style.WebkitTouchCallout =\n \"none\";\n // Disable scrolling on the draggable direction\n style.touchAction =\n props.drag === true\n ? \"none\"\n : `pan-${props.drag === \"x\" ? \"y\" : \"x\"}`;\n }\n if (props.tabIndex === undefined &&\n (props.onTap || props.onTapStart || props.whileTap)) {\n htmlProps.tabIndex = 0;\n }\n htmlProps.style = style;\n return htmlProps;\n}\n\nexport { copyRawValuesOnly, useHTMLProps };\n","/**\n * A list of all valid MotionProps.\n *\n * @privateRemarks\n * This doesn't throw if a `MotionProp` name is missing - it should.\n */\nconst validMotionProps = new Set([\n \"animate\",\n \"exit\",\n \"variants\",\n \"initial\",\n \"style\",\n \"values\",\n \"variants\",\n \"transition\",\n \"transformTemplate\",\n \"custom\",\n \"inherit\",\n \"onBeforeLayoutMeasure\",\n \"onAnimationStart\",\n \"onAnimationComplete\",\n \"onUpdate\",\n \"onDragStart\",\n \"onDrag\",\n \"onDragEnd\",\n \"onMeasureDragConstraints\",\n \"onDirectionLock\",\n \"onDragTransitionEnd\",\n \"_dragX\",\n \"_dragY\",\n \"onHoverStart\",\n \"onHoverEnd\",\n \"onViewportEnter\",\n \"onViewportLeave\",\n \"globalTapTarget\",\n \"ignoreStrict\",\n \"viewport\",\n]);\n/**\n * Check whether a prop name is a valid `MotionProp` key.\n *\n * @param key - Name of the property to check\n * @returns `true` is key is a valid `MotionProp`.\n *\n * @public\n */\nfunction isValidMotionProp(key) {\n return (key.startsWith(\"while\") ||\n (key.startsWith(\"drag\") && key !== \"draggable\") ||\n key.startsWith(\"layout\") ||\n key.startsWith(\"onTap\") ||\n key.startsWith(\"onPan\") ||\n key.startsWith(\"onLayout\") ||\n validMotionProps.has(key));\n}\n\nexport { isValidMotionProp };\n","import { isValidMotionProp } from '../../../motion/utils/valid-prop.mjs';\n\nlet shouldForward = (key) => !isValidMotionProp(key);\nfunction loadExternalIsValidProp(isValidProp) {\n if (!isValidProp)\n return;\n // Explicitly filter our events\n shouldForward = (key) => key.startsWith(\"on\") ? !isValidMotionProp(key) : isValidProp(key);\n}\n/**\n * Emotion and Styled Components both allow users to pass through arbitrary props to their components\n * to dynamically generate CSS. They both use the `@emotion/is-prop-valid` package to determine which\n * of these should be passed to the underlying DOM node.\n *\n * However, when styling a Motion component `styled(motion.div)`, both packages pass through *all* props\n * as it's seen as an arbitrary component rather than a DOM node. Motion only allows arbitrary props\n * passed through the `custom` prop so it doesn't *need* the payload or computational overhead of\n * `@emotion/is-prop-valid`, however to fix this problem we need to use it.\n *\n * By making it an optionalDependency we can offer this functionality only in the situations where it's\n * actually required.\n */\ntry {\n /**\n * We attempt to import this package but require won't be defined in esm environments, in that case\n * isPropValid will have to be provided via `MotionContext`. In a 6.0.0 this should probably be removed\n * in favour of explicit injection.\n */\n loadExternalIsValidProp(require(\"@emotion/is-prop-valid\").default);\n}\ncatch (_a) {\n // We don't need to actually do anything here - the fallback is the existing `isPropValid`.\n}\nfunction filterProps(props, isDom, forwardMotionProps) {\n const filteredProps = {};\n for (const key in props) {\n /**\n * values is considered a valid prop by Emotion, so if it's present\n * this will be rendered out to the DOM unless explicitly filtered.\n *\n * We check the type as it could be used with the `feColorMatrix`\n * element, which we support.\n */\n if (key === \"values\" && typeof props.values === \"object\")\n continue;\n if (shouldForward(key) ||\n (forwardMotionProps === true && isValidMotionProp(key)) ||\n (!isDom && !isValidMotionProp(key)) ||\n // If trying to use native HTML drag events, forward drag listeners\n (props[\"draggable\"] &&\n key.startsWith(\"onDrag\"))) {\n filteredProps[key] =\n props[key];\n }\n }\n return filteredProps;\n}\n\nexport { filterProps, loadExternalIsValidProp };\n","import { px } from '../../../value/types/numbers/units.mjs';\n\nfunction calcOrigin(origin, offset, size) {\n return typeof origin === \"string\"\n ? origin\n : px.transform(offset + size * origin);\n}\n/**\n * The SVG transform origin defaults are different to CSS and is less intuitive,\n * so we use the measured dimensions of the SVG to reconcile these.\n */\nfunction calcSVGTransformOrigin(dimensions, originX, originY) {\n const pxOriginX = calcOrigin(originX, dimensions.x, dimensions.width);\n const pxOriginY = calcOrigin(originY, dimensions.y, dimensions.height);\n return `${pxOriginX} ${pxOriginY}`;\n}\n\nexport { calcSVGTransformOrigin };\n","import { px } from '../../../value/types/numbers/units.mjs';\n\nconst dashKeys = {\n offset: \"stroke-dashoffset\",\n array: \"stroke-dasharray\",\n};\nconst camelKeys = {\n offset: \"strokeDashoffset\",\n array: \"strokeDasharray\",\n};\n/**\n * Build SVG path properties. Uses the path's measured length to convert\n * our custom pathLength, pathSpacing and pathOffset into stroke-dashoffset\n * and stroke-dasharray attributes.\n *\n * This function is mutative to reduce per-frame GC.\n */\nfunction buildSVGPath(attrs, length, spacing = 1, offset = 0, useDashCase = true) {\n // Normalise path length by setting SVG attribute pathLength to 1\n attrs.pathLength = 1;\n // We use dash case when setting attributes directly to the DOM node and camel case\n // when defining props on a React component.\n const keys = useDashCase ? dashKeys : camelKeys;\n // Build the dash offset\n attrs[keys.offset] = px.transform(-offset);\n // Build the dash array\n const pathLength = px.transform(length);\n const pathSpacing = px.transform(spacing);\n attrs[keys.array] = `${pathLength} ${pathSpacing}`;\n}\n\nexport { buildSVGPath };\n","import { buildHTMLStyles } from '../../html/utils/build-styles.mjs';\nimport { calcSVGTransformOrigin } from './transform-origin.mjs';\nimport { buildSVGPath } from './path.mjs';\n\n/**\n * Build SVG visual attrbutes, like cx and style.transform\n */\nfunction buildSVGAttrs(state, { attrX, attrY, attrScale, originX, originY, pathLength, pathSpacing = 1, pathOffset = 0, \n// This is object creation, which we try to avoid per-frame.\n...latest }, isSVGTag, transformTemplate) {\n buildHTMLStyles(state, latest, transformTemplate);\n /**\n * For svg tags we just want to make sure viewBox is animatable and treat all the styles\n * as normal HTML tags.\n */\n if (isSVGTag) {\n if (state.style.viewBox) {\n state.attrs.viewBox = state.style.viewBox;\n }\n return;\n }\n state.attrs = state.style;\n state.style = {};\n const { attrs, style, dimensions } = state;\n /**\n * However, we apply transforms as CSS transforms. So if we detect a transform we take it from attrs\n * and copy it into style.\n */\n if (attrs.transform) {\n if (dimensions)\n style.transform = attrs.transform;\n delete attrs.transform;\n }\n // Parse transformOrigin\n if (dimensions &&\n (originX !== undefined || originY !== undefined || style.transform)) {\n style.transformOrigin = calcSVGTransformOrigin(dimensions, originX !== undefined ? originX : 0.5, originY !== undefined ? originY : 0.5);\n }\n // Render attrX/attrY/attrScale as attributes\n if (attrX !== undefined)\n attrs.x = attrX;\n if (attrY !== undefined)\n attrs.y = attrY;\n if (attrScale !== undefined)\n attrs.scale = attrScale;\n // Build SVG path if one has been defined\n if (pathLength !== undefined) {\n buildSVGPath(attrs, pathLength, pathSpacing, pathOffset, false);\n }\n}\n\nexport { buildSVGAttrs };\n","import { createHtmlRenderState } from '../../html/utils/create-render-state.mjs';\n\nconst createSvgRenderState = () => ({\n ...createHtmlRenderState(),\n attrs: {},\n});\n\nexport { createSvgRenderState };\n","const isSVGTag = (tag) => typeof tag === \"string\" && tag.toLowerCase() === \"svg\";\n\nexport { isSVGTag };\n","import { useMemo } from 'react';\nimport { copyRawValuesOnly } from '../html/use-props.mjs';\nimport { buildSVGAttrs } from './utils/build-attrs.mjs';\nimport { createSvgRenderState } from './utils/create-render-state.mjs';\nimport { isSVGTag } from './utils/is-svg-tag.mjs';\n\nfunction useSVGProps(props, visualState, _isStatic, Component) {\n const visualProps = useMemo(() => {\n const state = createSvgRenderState();\n buildSVGAttrs(state, visualState, isSVGTag(Component), props.transformTemplate);\n return {\n ...state.attrs,\n style: { ...state.style },\n };\n }, [visualState]);\n if (props.style) {\n const rawStyles = {};\n copyRawValuesOnly(rawStyles, props.style, props);\n visualProps.style = { ...rawStyles, ...visualProps.style };\n }\n return visualProps;\n}\n\nexport { useSVGProps };\n","import { Fragment, useMemo, createElement } from 'react';\nimport { useHTMLProps } from '../html/use-props.mjs';\nimport { filterProps } from './utils/filter-props.mjs';\nimport { isSVGComponent } from './utils/is-svg-component.mjs';\nimport { useSVGProps } from '../svg/use-props.mjs';\nimport { isMotionValue } from '../../value/utils/is-motion-value.mjs';\n\nfunction createUseRender(forwardMotionProps = false) {\n const useRender = (Component, props, ref, { latestValues }, isStatic) => {\n const useVisualProps = isSVGComponent(Component)\n ? useSVGProps\n : useHTMLProps;\n const visualProps = useVisualProps(props, latestValues, isStatic, Component);\n const filteredProps = filterProps(props, typeof Component === \"string\", forwardMotionProps);\n const elementProps = Component !== Fragment\n ? { ...filteredProps, ...visualProps, ref }\n : {};\n /**\n * If component has been handed a motion value as its child,\n * memoise its initial value and render that. Subsequent updates\n * will be handled by the onChange handler\n */\n const { children } = props;\n const renderedChildren = useMemo(() => (isMotionValue(children) ? children.get() : children), [children]);\n return createElement(Component, {\n ...elementProps,\n children: renderedChildren,\n });\n };\n return useRender;\n}\n\nexport { createUseRender };\n","function renderHTML(element, { style, vars }, styleProp, projection) {\n Object.assign(element.style, style, projection && projection.getProjectionStyles(styleProp));\n // Loop over any CSS variables and assign those.\n for (const key in vars) {\n element.style.setProperty(key, vars[key]);\n }\n}\n\nexport { renderHTML };\n","/**\n * A set of attribute names that are always read/written as camel case.\n */\nconst camelCaseAttributes = new Set([\n \"baseFrequency\",\n \"diffuseConstant\",\n \"kernelMatrix\",\n \"kernelUnitLength\",\n \"keySplines\",\n \"keyTimes\",\n \"limitingConeAngle\",\n \"markerHeight\",\n \"markerWidth\",\n \"numOctaves\",\n \"targetX\",\n \"targetY\",\n \"surfaceScale\",\n \"specularConstant\",\n \"specularExponent\",\n \"stdDeviation\",\n \"tableValues\",\n \"viewBox\",\n \"gradientTransform\",\n \"pathLength\",\n \"startOffset\",\n \"textLength\",\n \"lengthAdjust\",\n]);\n\nexport { camelCaseAttributes };\n","import { camelToDash } from '../../dom/utils/camel-to-dash.mjs';\nimport { renderHTML } from '../../html/utils/render.mjs';\nimport { camelCaseAttributes } from './camel-case-attrs.mjs';\n\nfunction renderSVG(element, renderState, _styleProp, projection) {\n renderHTML(element, renderState, undefined, projection);\n for (const key in renderState.attrs) {\n element.setAttribute(!camelCaseAttributes.has(key) ? camelToDash(key) : key, renderState.attrs[key]);\n }\n}\n\nexport { renderSVG };\n","import { isForcedMotionValue } from '../../../motion/utils/is-forced-motion-value.mjs';\nimport { isMotionValue } from '../../../value/utils/is-motion-value.mjs';\n\nfunction scrapeMotionValuesFromProps(props, prevProps, visualElement) {\n var _a;\n const { style } = props;\n const newValues = {};\n for (const key in style) {\n if (isMotionValue(style[key]) ||\n (prevProps.style &&\n isMotionValue(prevProps.style[key])) ||\n isForcedMotionValue(key, props) ||\n ((_a = visualElement === null || visualElement === void 0 ? void 0 : visualElement.getValue(key)) === null || _a === void 0 ? void 0 : _a.liveStyle) !== undefined) {\n newValues[key] = style[key];\n }\n }\n /**\n * If the willChange style has been manually set as a string, set\n * applyWillChange to false to prevent it from automatically being applied.\n */\n if (visualElement && style && typeof style.willChange === \"string\") {\n visualElement.applyWillChange = false;\n }\n return newValues;\n}\n\nexport { scrapeMotionValuesFromProps };\n","import { isMotionValue } from '../../../value/utils/is-motion-value.mjs';\nimport { scrapeMotionValuesFromProps as scrapeMotionValuesFromProps$1 } from '../../html/utils/scrape-motion-values.mjs';\nimport { transformPropOrder } from '../../html/utils/transform.mjs';\n\nfunction scrapeMotionValuesFromProps(props, prevProps, visualElement) {\n const newValues = scrapeMotionValuesFromProps$1(props, prevProps, visualElement);\n for (const key in props) {\n if (isMotionValue(props[key]) ||\n isMotionValue(prevProps[key])) {\n const targetKey = transformPropOrder.indexOf(key) !== -1\n ? \"attr\" + key.charAt(0).toUpperCase() + key.substring(1)\n : key;\n newValues[targetKey] = props[key];\n }\n }\n return newValues;\n}\n\nexport { scrapeMotionValuesFromProps };\n","function getValueState(visualElement) {\n const state = [{}, {}];\n visualElement === null || visualElement === void 0 ? void 0 : visualElement.values.forEach((value, key) => {\n state[0][key] = value.get();\n state[1][key] = value.getVelocity();\n });\n return state;\n}\nfunction resolveVariantFromProps(props, definition, custom, visualElement) {\n /**\n * If the variant definition is a function, resolve.\n */\n if (typeof definition === \"function\") {\n const [current, velocity] = getValueState(visualElement);\n definition = definition(custom !== undefined ? custom : props.custom, current, velocity);\n }\n /**\n * If the variant definition is a variant label, or\n * the function returned a variant label, resolve.\n */\n if (typeof definition === \"string\") {\n definition = props.variants && props.variants[definition];\n }\n /**\n * At this point we've resolved both functions and variant labels,\n * but the resolved variant label might itself have been a function.\n * If so, resolve. This can only have returned a valid target object.\n */\n if (typeof definition === \"function\") {\n const [current, velocity] = getValueState(visualElement);\n definition = definition(custom !== undefined ? custom : props.custom, current, velocity);\n }\n return definition;\n}\n\nexport { resolveVariantFromProps };\n","const isKeyframesTarget = (v) => {\n return Array.isArray(v);\n};\n\nexport { isKeyframesTarget };\n","import { isCustomValue } from '../../utils/resolve-value.mjs';\nimport { isMotionValue } from './is-motion-value.mjs';\n\n/**\n * If the provided value is a MotionValue, this returns the actual value, otherwise just the value itself\n *\n * TODO: Remove and move to library\n */\nfunction resolveMotionValue(value) {\n const unwrappedValue = isMotionValue(value) ? value.get() : value;\n return isCustomValue(unwrappedValue)\n ? unwrappedValue.toValue()\n : unwrappedValue;\n}\n\nexport { resolveMotionValue };\n","import { isKeyframesTarget } from '../animation/utils/is-keyframes-target.mjs';\n\nconst isCustomValue = (v) => {\n return Boolean(v && typeof v === \"object\" && v.mix && v.toValue);\n};\nconst resolveFinalValueInKeyframes = (v) => {\n // TODO maybe throw if v.length - 1 is placeholder token?\n return isKeyframesTarget(v) ? v[v.length - 1] || 0 : v;\n};\n\nexport { isCustomValue, resolveFinalValueInKeyframes };\n","/**\n * A list of values that can be hardware-accelerated.\n */\nconst acceleratedValues = new Set([\n \"opacity\",\n \"clipPath\",\n \"filter\",\n \"transform\",\n // TODO: Can be accelerated but currently disabled until https://issues.chromium.org/issues/41491098 is resolved\n // or until we implement support for linear() easing.\n // \"background-color\"\n]);\n\nexport { acceleratedValues };\n","import { acceleratedValues } from '../../animation/animators/utils/accelerated-values.mjs';\nimport { camelToDash } from '../../render/dom/utils/camel-to-dash.mjs';\nimport { transformProps } from '../../render/html/utils/transform.mjs';\n\nfunction getWillChangeName(name) {\n if (transformProps.has(name)) {\n return \"transform\";\n }\n else if (acceleratedValues.has(name)) {\n return camelToDash(name);\n }\n}\n\nexport { getWillChangeName };\n","function addUniqueItem(arr, item) {\n if (arr.indexOf(item) === -1)\n arr.push(item);\n}\nfunction removeItem(arr, item) {\n const index = arr.indexOf(item);\n if (index > -1)\n arr.splice(index, 1);\n}\n// Adapted from array-move\nfunction moveItem([...arr], fromIndex, toIndex) {\n const startIndex = fromIndex < 0 ? arr.length + fromIndex : fromIndex;\n if (startIndex >= 0 && startIndex < arr.length) {\n const endIndex = toIndex < 0 ? arr.length + toIndex : toIndex;\n const [item] = arr.splice(fromIndex, 1);\n arr.splice(endIndex, 0, item);\n }\n return arr;\n}\n\nexport { addUniqueItem, moveItem, removeItem };\n","import { useContext } from 'react';\nimport { isAnimationControls } from '../../animation/utils/is-animation-controls.mjs';\nimport { PresenceContext } from '../../context/PresenceContext.mjs';\nimport { resolveVariantFromProps } from '../../render/utils/resolve-variants.mjs';\nimport { useConstant } from '../../utils/use-constant.mjs';\nimport { resolveMotionValue } from '../../value/utils/resolve-motion-value.mjs';\nimport { MotionContext } from '../../context/MotionContext/index.mjs';\nimport { isControllingVariants, isVariantNode } from '../../render/utils/is-controlling-variants.mjs';\nimport { getWillChangeName } from '../../value/use-will-change/get-will-change-name.mjs';\nimport { addUniqueItem } from '../../utils/array.mjs';\n\nfunction makeState({ applyWillChange = false, scrapeMotionValuesFromProps, createRenderState, onMount, }, props, context, presenceContext, isStatic) {\n const state = {\n latestValues: makeLatestValues(props, context, presenceContext, isStatic ? false : applyWillChange, scrapeMotionValuesFromProps),\n renderState: createRenderState(),\n };\n if (onMount) {\n state.mount = (instance) => onMount(props, instance, state);\n }\n return state;\n}\nconst makeUseVisualState = (config) => (props, isStatic) => {\n const context = useContext(MotionContext);\n const presenceContext = useContext(PresenceContext);\n const make = () => makeState(config, props, context, presenceContext, isStatic);\n return isStatic ? make() : useConstant(make);\n};\nfunction addWillChange(willChange, name) {\n const memberName = getWillChangeName(name);\n if (memberName) {\n addUniqueItem(willChange, memberName);\n }\n}\nfunction forEachDefinition(props, definition, callback) {\n const list = Array.isArray(definition) ? definition : [definition];\n for (let i = 0; i < list.length; i++) {\n const resolved = resolveVariantFromProps(props, list[i]);\n if (resolved) {\n const { transitionEnd, transition, ...target } = resolved;\n callback(target, transitionEnd);\n }\n }\n}\nfunction makeLatestValues(props, context, presenceContext, shouldApplyWillChange, scrapeMotionValues) {\n var _a;\n const values = {};\n const willChange = [];\n const applyWillChange = shouldApplyWillChange && ((_a = props.style) === null || _a === void 0 ? void 0 : _a.willChange) === undefined;\n const motionValues = scrapeMotionValues(props, {});\n for (const key in motionValues) {\n values[key] = resolveMotionValue(motionValues[key]);\n }\n let { initial, animate } = props;\n const isControllingVariants$1 = isControllingVariants(props);\n const isVariantNode$1 = isVariantNode(props);\n if (context &&\n isVariantNode$1 &&\n !isControllingVariants$1 &&\n props.inherit !== false) {\n if (initial === undefined)\n initial = context.initial;\n if (animate === undefined)\n animate = context.animate;\n }\n let isInitialAnimationBlocked = presenceContext\n ? presenceContext.initial === false\n : false;\n isInitialAnimationBlocked = isInitialAnimationBlocked || initial === false;\n const variantToSet = isInitialAnimationBlocked ? animate : initial;\n if (variantToSet &&\n typeof variantToSet !== \"boolean\" &&\n !isAnimationControls(variantToSet)) {\n forEachDefinition(props, variantToSet, (target, transitionEnd) => {\n for (const key in target) {\n let valueTarget = target[key];\n if (Array.isArray(valueTarget)) {\n /**\n * Take final keyframe if the initial animation is blocked because\n * we want to initialise at the end of that blocked animation.\n */\n const index = isInitialAnimationBlocked\n ? valueTarget.length - 1\n : 0;\n valueTarget = valueTarget[index];\n }\n if (valueTarget !== null) {\n values[key] = valueTarget;\n }\n }\n for (const key in transitionEnd) {\n values[key] = transitionEnd[key];\n }\n });\n }\n // Add animating values to will-change\n if (applyWillChange) {\n if (animate && initial !== false && !isAnimationControls(animate)) {\n forEachDefinition(props, animate, (target) => {\n for (const key in target) {\n addWillChange(willChange, key);\n }\n });\n }\n if (willChange.length) {\n values.willChange = willChange.join(\",\");\n }\n }\n return values;\n}\n\nexport { makeUseVisualState };\n","import { useRef } from 'react';\n\n/**\n * Creates a constant value over the lifecycle of a component.\n *\n * Even if `useMemo` is provided an empty array as its final argument, it doesn't offer\n * a guarantee that it won't re-run for performance reasons later on. By using `useConstant`\n * you can ensure that initialisers don't execute twice or more.\n */\nfunction useConstant(init) {\n const ref = useRef(null);\n if (ref.current === null) {\n ref.current = init();\n }\n return ref.current;\n}\n\nexport { useConstant };\n","const noop = (any) => any;\n\nexport { noop };\n","import { noop } from '../utils/noop.mjs';\nimport { createRenderBatcher } from './batcher.mjs';\n\nconst { schedule: frame, cancel: cancelFrame, state: frameData, steps, } = createRenderBatcher(typeof requestAnimationFrame !== \"undefined\" ? requestAnimationFrame : noop, true);\n\nexport { cancelFrame, frame, frameData, steps };\n","import { renderSVG } from './utils/render.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\nimport { makeUseVisualState } from '../../motion/utils/use-visual-state.mjs';\nimport { createSvgRenderState } from './utils/create-render-state.mjs';\nimport { buildSVGAttrs } from './utils/build-attrs.mjs';\nimport { isSVGTag } from './utils/is-svg-tag.mjs';\nimport { frame } from '../../frameloop/frame.mjs';\n\nconst svgMotionConfig = {\n useVisualState: makeUseVisualState({\n scrapeMotionValuesFromProps: scrapeMotionValuesFromProps,\n createRenderState: createSvgRenderState,\n onMount: (props, instance, { renderState, latestValues }) => {\n frame.read(() => {\n try {\n renderState.dimensions =\n typeof instance.getBBox ===\n \"function\"\n ? instance.getBBox()\n : instance.getBoundingClientRect();\n }\n catch (e) {\n // Most likely trying to measure an unrendered element under Firefox\n renderState.dimensions = {\n x: 0,\n y: 0,\n width: 0,\n height: 0,\n };\n }\n });\n frame.render(() => {\n buildSVGAttrs(renderState, latestValues, isSVGTag(instance.tagName), props.transformTemplate);\n renderSVG(instance, renderState);\n });\n },\n }),\n};\n\nexport { svgMotionConfig };\n","import { makeUseVisualState } from '../../motion/utils/use-visual-state.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\nimport { createHtmlRenderState } from './utils/create-render-state.mjs';\n\nconst htmlMotionConfig = {\n useVisualState: makeUseVisualState({\n applyWillChange: true,\n scrapeMotionValuesFromProps,\n createRenderState: createHtmlRenderState,\n }),\n};\n\nexport { htmlMotionConfig };\n","function addDomEvent(target, eventName, handler, options = { passive: true }) {\n target.addEventListener(eventName, handler, options);\n return () => target.removeEventListener(eventName, handler);\n}\n\nexport { addDomEvent };\n","const isPrimaryPointer = (event) => {\n if (event.pointerType === \"mouse\") {\n return typeof event.button !== \"number\" || event.button <= 0;\n }\n else {\n /**\n * isPrimary is true for all mice buttons, whereas every touch point\n * is regarded as its own input. So subsequent concurrent touch points\n * will be false.\n *\n * Specifically match against false here as incomplete versions of\n * PointerEvents in very old browser might have it set as undefined.\n */\n return event.isPrimary !== false;\n }\n};\n\nexport { isPrimaryPointer };\n","import { isPrimaryPointer } from './utils/is-primary-pointer.mjs';\n\nfunction extractEventInfo(event, pointType = \"page\") {\n return {\n point: {\n x: event[`${pointType}X`],\n y: event[`${pointType}Y`],\n },\n };\n}\nconst addPointerInfo = (handler) => {\n return (event) => isPrimaryPointer(event) && handler(event, extractEventInfo(event));\n};\n\nexport { addPointerInfo, extractEventInfo };\n","import { addDomEvent } from './add-dom-event.mjs';\nimport { addPointerInfo } from './event-info.mjs';\n\nfunction addPointerEvent(target, eventName, handler, options) {\n return addDomEvent(target, eventName, addPointerInfo(handler), options);\n}\n\nexport { addPointerEvent };\n","/**\n * Pipe\n * Compose other transformers to run linearily\n * pipe(min(20), max(40))\n * @param {...functions} transformers\n * @return {function}\n */\nconst combineFunctions = (a, b) => (v) => b(a(v));\nconst pipe = (...transformers) => transformers.reduce(combineFunctions);\n\nexport { pipe };\n","function createLock(name) {\n let lock = null;\n return () => {\n const openLock = () => {\n lock = null;\n };\n if (lock === null) {\n lock = name;\n return openLock;\n }\n return false;\n };\n}\nconst globalHorizontalLock = createLock(\"dragHorizontal\");\nconst globalVerticalLock = createLock(\"dragVertical\");\nfunction getGlobalLock(drag) {\n let lock = false;\n if (drag === \"y\") {\n lock = globalVerticalLock();\n }\n else if (drag === \"x\") {\n lock = globalHorizontalLock();\n }\n else {\n const openHorizontal = globalHorizontalLock();\n const openVertical = globalVerticalLock();\n if (openHorizontal && openVertical) {\n lock = () => {\n openHorizontal();\n openVertical();\n };\n }\n else {\n // Release the locks because we don't use them\n if (openHorizontal)\n openHorizontal();\n if (openVertical)\n openVertical();\n }\n }\n return lock;\n}\nfunction isDragActive() {\n // Check the gesture lock - if we get it, it means no drag gesture is active\n // and we can safely fire the tap gesture.\n const openGestureLock = getGlobalLock(true);\n if (!openGestureLock)\n return true;\n openGestureLock();\n return false;\n}\n\nexport { createLock, getGlobalLock, isDragActive };\n","class Feature {\n constructor(node) {\n this.isMounted = false;\n this.node = node;\n }\n update() { }\n}\n\nexport { Feature };\n","import { addPointerEvent } from '../events/add-pointer-event.mjs';\nimport { pipe } from '../utils/pipe.mjs';\nimport { isDragActive } from './drag/utils/lock.mjs';\nimport { Feature } from '../motion/features/Feature.mjs';\nimport { frame } from '../frameloop/frame.mjs';\n\nfunction addHoverEvent(node, isActive) {\n const eventName = isActive ? \"pointerenter\" : \"pointerleave\";\n const callbackName = isActive ? \"onHoverStart\" : \"onHoverEnd\";\n const handleEvent = (event, info) => {\n if (event.pointerType === \"touch\" || isDragActive())\n return;\n const props = node.getProps();\n if (node.animationState && props.whileHover) {\n node.animationState.setActive(\"whileHover\", isActive);\n }\n const callback = props[callbackName];\n if (callback) {\n frame.postRender(() => callback(event, info));\n }\n };\n return addPointerEvent(node.current, eventName, handleEvent, {\n passive: !node.getProps()[callbackName],\n });\n}\nclass HoverGesture extends Feature {\n mount() {\n this.unmount = pipe(addHoverEvent(this.node, true), addHoverEvent(this.node, false));\n }\n unmount() { }\n}\n\nexport { HoverGesture };\n","/**\n * Recursively traverse up the tree to check whether the provided child node\n * is the parent or a descendant of it.\n *\n * @param parent - Element to find\n * @param child - Element to test against parent\n */\nconst isNodeOrChild = (parent, child) => {\n if (!child) {\n return false;\n }\n else if (parent === child) {\n return true;\n }\n else {\n return isNodeOrChild(parent, child.parentElement);\n }\n};\n\nexport { isNodeOrChild };\n","import { extractEventInfo } from '../events/event-info.mjs';\nimport { addDomEvent } from '../events/add-dom-event.mjs';\nimport { addPointerEvent } from '../events/add-pointer-event.mjs';\nimport { Feature } from '../motion/features/Feature.mjs';\nimport { pipe } from '../utils/pipe.mjs';\nimport { isDragActive } from './drag/utils/lock.mjs';\nimport { isNodeOrChild } from './utils/is-node-or-child.mjs';\nimport { noop } from '../utils/noop.mjs';\nimport { frame } from '../frameloop/frame.mjs';\n\nfunction fireSyntheticPointerEvent(name, handler) {\n if (!handler)\n return;\n const syntheticPointerEvent = new PointerEvent(\"pointer\" + name);\n handler(syntheticPointerEvent, extractEventInfo(syntheticPointerEvent));\n}\nclass PressGesture extends Feature {\n constructor() {\n super(...arguments);\n this.removeStartListeners = noop;\n this.removeEndListeners = noop;\n this.removeAccessibleListeners = noop;\n this.startPointerPress = (startEvent, startInfo) => {\n if (this.isPressing)\n return;\n this.removeEndListeners();\n const props = this.node.getProps();\n const endPointerPress = (endEvent, endInfo) => {\n if (!this.checkPressEnd())\n return;\n const { onTap, onTapCancel, globalTapTarget } = this.node.getProps();\n /**\n * We only count this as a tap gesture if the event.target is the same\n * as, or a child of, this component's element\n */\n const handler = !globalTapTarget &&\n !isNodeOrChild(this.node.current, endEvent.target)\n ? onTapCancel\n : onTap;\n if (handler) {\n frame.update(() => handler(endEvent, endInfo));\n }\n };\n const removePointerUpListener = addPointerEvent(window, \"pointerup\", endPointerPress, {\n passive: !(props.onTap || props[\"onPointerUp\"]),\n });\n const removePointerCancelListener = addPointerEvent(window, \"pointercancel\", (cancelEvent, cancelInfo) => this.cancelPress(cancelEvent, cancelInfo), {\n passive: !(props.onTapCancel ||\n props[\"onPointerCancel\"]),\n });\n this.removeEndListeners = pipe(removePointerUpListener, removePointerCancelListener);\n this.startPress(startEvent, startInfo);\n };\n this.startAccessiblePress = () => {\n const handleKeydown = (keydownEvent) => {\n if (keydownEvent.key !== \"Enter\" || this.isPressing)\n return;\n const handleKeyup = (keyupEvent) => {\n if (keyupEvent.key !== \"Enter\" || !this.checkPressEnd())\n return;\n fireSyntheticPointerEvent(\"up\", (event, info) => {\n const { onTap } = this.node.getProps();\n if (onTap) {\n frame.postRender(() => onTap(event, info));\n }\n });\n };\n this.removeEndListeners();\n this.removeEndListeners = addDomEvent(this.node.current, \"keyup\", handleKeyup);\n fireSyntheticPointerEvent(\"down\", (event, info) => {\n this.startPress(event, info);\n });\n };\n const removeKeydownListener = addDomEvent(this.node.current, \"keydown\", handleKeydown);\n const handleBlur = () => {\n if (!this.isPressing)\n return;\n fireSyntheticPointerEvent(\"cancel\", (cancelEvent, cancelInfo) => this.cancelPress(cancelEvent, cancelInfo));\n };\n const removeBlurListener = addDomEvent(this.node.current, \"blur\", handleBlur);\n this.removeAccessibleListeners = pipe(removeKeydownListener, removeBlurListener);\n };\n }\n startPress(event, info) {\n this.isPressing = true;\n const { onTapStart, whileTap } = this.node.getProps();\n /**\n * Ensure we trigger animations before firing event callback\n */\n if (whileTap && this.node.animationState) {\n this.node.animationState.setActive(\"whileTap\", true);\n }\n if (onTapStart) {\n frame.postRender(() => onTapStart(event, info));\n }\n }\n checkPressEnd() {\n this.removeEndListeners();\n this.isPressing = false;\n const props = this.node.getProps();\n if (props.whileTap && this.node.animationState) {\n this.node.animationState.setActive(\"whileTap\", false);\n }\n return !isDragActive();\n }\n cancelPress(event, info) {\n if (!this.checkPressEnd())\n return;\n const { onTapCancel } = this.node.getProps();\n if (onTapCancel) {\n frame.postRender(() => onTapCancel(event, info));\n }\n }\n mount() {\n const props = this.node.getProps();\n const removePointerListener = addPointerEvent(props.globalTapTarget ? window : this.node.current, \"pointerdown\", this.startPointerPress, {\n passive: !(props.onTapStart ||\n props[\"onPointerStart\"]),\n });\n const removeFocusListener = addDomEvent(this.node.current, \"focus\", this.startAccessiblePress);\n this.removeStartListeners = pipe(removePointerListener, removeFocusListener);\n }\n unmount() {\n this.removeStartListeners();\n this.removeEndListeners();\n this.removeAccessibleListeners();\n }\n}\n\nexport { PressGesture };\n","/**\n * Map an IntersectionHandler callback to an element. We only ever make one handler for one\n * element, so even though these handlers might all be triggered by different\n * observers, we can keep them in the same map.\n */\nconst observerCallbacks = new WeakMap();\n/**\n * Multiple observers can be created for multiple element/document roots. Each with\n * different settings. So here we store dictionaries of observers to each root,\n * using serialised settings (threshold/margin) as lookup keys.\n */\nconst observers = new WeakMap();\nconst fireObserverCallback = (entry) => {\n const callback = observerCallbacks.get(entry.target);\n callback && callback(entry);\n};\nconst fireAllObserverCallbacks = (entries) => {\n entries.forEach(fireObserverCallback);\n};\nfunction initIntersectionObserver({ root, ...options }) {\n const lookupRoot = root || document;\n /**\n * If we don't have an observer lookup map for this root, create one.\n */\n if (!observers.has(lookupRoot)) {\n observers.set(lookupRoot, {});\n }\n const rootObservers = observers.get(lookupRoot);\n const key = JSON.stringify(options);\n /**\n * If we don't have an observer for this combination of root and settings,\n * create one.\n */\n if (!rootObservers[key]) {\n rootObservers[key] = new IntersectionObserver(fireAllObserverCallbacks, { root, ...options });\n }\n return rootObservers[key];\n}\nfunction observeIntersection(element, options, callback) {\n const rootInteresectionObserver = initIntersectionObserver(options);\n observerCallbacks.set(element, callback);\n rootInteresectionObserver.observe(element);\n return () => {\n observerCallbacks.delete(element);\n rootInteresectionObserver.unobserve(element);\n };\n}\n\nexport { observeIntersection };\n","import { Feature } from '../Feature.mjs';\nimport { observeIntersection } from './observers.mjs';\n\nconst thresholdNames = {\n some: 0,\n all: 1,\n};\nclass InViewFeature extends Feature {\n constructor() {\n super(...arguments);\n this.hasEnteredView = false;\n this.isInView = false;\n }\n startObserver() {\n this.unmount();\n const { viewport = {} } = this.node.getProps();\n const { root, margin: rootMargin, amount = \"some\", once } = viewport;\n const options = {\n root: root ? root.current : undefined,\n rootMargin,\n threshold: typeof amount === \"number\" ? amount : thresholdNames[amount],\n };\n const onIntersectionUpdate = (entry) => {\n const { isIntersecting } = entry;\n /**\n * If there's been no change in the viewport state, early return.\n */\n if (this.isInView === isIntersecting)\n return;\n this.isInView = isIntersecting;\n /**\n * Handle hasEnteredView. If this is only meant to run once, and\n * element isn't visible, early return. Otherwise set hasEnteredView to true.\n */\n if (once && !isIntersecting && this.hasEnteredView) {\n return;\n }\n else if (isIntersecting) {\n this.hasEnteredView = true;\n }\n if (this.node.animationState) {\n this.node.animationState.setActive(\"whileInView\", isIntersecting);\n }\n /**\n * Use the latest committed props rather than the ones in scope\n * when this observer is created\n */\n const { onViewportEnter, onViewportLeave } = this.node.getProps();\n const callback = isIntersecting ? onViewportEnter : onViewportLeave;\n callback && callback(entry);\n };\n return observeIntersection(this.node.current, options, onIntersectionUpdate);\n }\n mount() {\n this.startObserver();\n }\n update() {\n if (typeof IntersectionObserver === \"undefined\")\n return;\n const { props, prevProps } = this.node;\n const hasOptionsChanged = [\"amount\", \"margin\", \"root\"].some(hasViewportOptionChanged(props, prevProps));\n if (hasOptionsChanged) {\n this.startObserver();\n }\n }\n unmount() { }\n}\nfunction hasViewportOptionChanged({ viewport = {} }, { viewport: prevViewport = {} } = {}) {\n return (name) => viewport[name] !== prevViewport[name];\n}\n\nexport { InViewFeature };\n","import { HoverGesture } from '../../gestures/hover.mjs';\nimport { FocusGesture } from '../../gestures/focus.mjs';\nimport { PressGesture } from '../../gestures/press.mjs';\nimport { InViewFeature } from './viewport/index.mjs';\n\nconst gestureAnimations = {\n inView: {\n Feature: InViewFeature,\n },\n tap: {\n Feature: PressGesture,\n },\n focus: {\n Feature: FocusGesture,\n },\n hover: {\n Feature: HoverGesture,\n },\n};\n\nexport { gestureAnimations };\n","import { addDomEvent } from '../events/add-dom-event.mjs';\nimport { Feature } from '../motion/features/Feature.mjs';\nimport { pipe } from '../utils/pipe.mjs';\n\nclass FocusGesture extends Feature {\n constructor() {\n super(...arguments);\n this.isActive = false;\n }\n onFocus() {\n let isFocusVisible = false;\n /**\n * If this element doesn't match focus-visible then don't\n * apply whileHover. But, if matches throws that focus-visible\n * is not a valid selector then in that browser outline styles will be applied\n * to the element by default and we want to match that behaviour with whileFocus.\n */\n try {\n isFocusVisible = this.node.current.matches(\":focus-visible\");\n }\n catch (e) {\n isFocusVisible = true;\n }\n if (!isFocusVisible || !this.node.animationState)\n return;\n this.node.animationState.setActive(\"whileFocus\", true);\n this.isActive = true;\n }\n onBlur() {\n if (!this.isActive || !this.node.animationState)\n return;\n this.node.animationState.setActive(\"whileFocus\", false);\n this.isActive = false;\n }\n mount() {\n this.unmount = pipe(addDomEvent(this.node.current, \"focus\", () => this.onFocus()), addDomEvent(this.node.current, \"blur\", () => this.onBlur()));\n }\n unmount() { }\n}\n\nexport { FocusGesture };\n","function shallowCompare(next, prev) {\n if (!Array.isArray(prev))\n return false;\n const prevLength = prev.length;\n if (prevLength !== next.length)\n return false;\n for (let i = 0; i < prevLength; i++) {\n if (prev[i] !== next[i])\n return false;\n }\n return true;\n}\n\nexport { shallowCompare };\n","import { resolveVariantFromProps } from './resolve-variants.mjs';\n\nfunction resolveVariant(visualElement, definition, custom) {\n const props = visualElement.getProps();\n return resolveVariantFromProps(props, definition, custom !== undefined ? custom : props.custom, visualElement);\n}\n\nexport { resolveVariant };\n","/**\n * Converts seconds to milliseconds\n *\n * @param seconds - Time in seconds.\n * @return milliseconds - Converted time in milliseconds.\n */\nconst secondsToMilliseconds = (seconds) => seconds * 1000;\nconst millisecondsToSeconds = (milliseconds) => milliseconds / 1000;\n\nexport { millisecondsToSeconds, secondsToMilliseconds };\n","import { transformProps } from '../../render/html/utils/transform.mjs';\n\nconst underDampedSpring = {\n type: \"spring\",\n stiffness: 500,\n damping: 25,\n restSpeed: 10,\n};\nconst criticallyDampedSpring = (target) => ({\n type: \"spring\",\n stiffness: 550,\n damping: target === 0 ? 2 * Math.sqrt(550) : 30,\n restSpeed: 10,\n});\nconst keyframesTransition = {\n type: \"keyframes\",\n duration: 0.8,\n};\n/**\n * Default easing curve is a slightly shallower version of\n * the default browser easing curve.\n */\nconst ease = {\n type: \"keyframes\",\n ease: [0.25, 0.1, 0.35, 1],\n duration: 0.3,\n};\nconst getDefaultTransition = (valueKey, { keyframes }) => {\n if (keyframes.length > 2) {\n return keyframesTransition;\n }\n else if (transformProps.has(valueKey)) {\n return valueKey.startsWith(\"scale\")\n ? criticallyDampedSpring(keyframes[1])\n : underDampedSpring;\n }\n return ease;\n};\n\nexport { getDefaultTransition };\n","/**\n * Decide whether a transition is defined on a given Transition.\n * This filters out orchestration options and returns true\n * if any options are left.\n */\nfunction isTransitionDefined({ when, delay: _delay, delayChildren, staggerChildren, staggerDirection, repeat, repeatType, repeatDelay, from, elapsed, ...transition }) {\n return !!Object.keys(transition).length;\n}\nfunction getValueTransition(transition, key) {\n return (transition[key] ||\n transition[\"default\"] ||\n transition);\n}\n\nexport { getValueTransition, isTransitionDefined };\n","const instantAnimationState = {\n current: false,\n};\n\nexport { instantAnimationState };\n","const isNotNull = (value) => value !== null;\nfunction getFinalKeyframe(keyframes, { repeat, repeatType = \"loop\" }, finalKeyframe) {\n const resolvedKeyframes = keyframes.filter(isNotNull);\n const index = repeat && repeatType !== \"loop\" && repeat % 2 === 1\n ? 0\n : resolvedKeyframes.length - 1;\n return !index || finalKeyframe === undefined\n ? resolvedKeyframes[index]\n : finalKeyframe;\n}\n\nexport { getFinalKeyframe };\n","/**\n * Check if the value is a zero value string like \"0px\" or \"0%\"\n */\nconst isZeroValueString = (v) => /^0[^.\\s]+$/u.test(v);\n\nexport { isZeroValueString };\n","import { noop } from './noop.mjs';\n\nlet warning = noop;\nlet invariant = noop;\nif (process.env.NODE_ENV !== \"production\") {\n warning = (check, message) => {\n if (!check && typeof console !== \"undefined\") {\n console.warn(message);\n }\n };\n invariant = (check, message) => {\n if (!check) {\n throw new Error(message);\n }\n };\n}\n\nexport { invariant, warning };\n","/**\n * Check if value is a numerical string, ie a string that is purely a number eg \"100\" or \"-100.1\"\n */\nconst isNumericalString = (v) => /^-?(?:\\d+(?:\\.\\d+)?|\\.\\d+)$/u.test(v);\n\nexport { isNumericalString };\n","import { invariant } from '../../../utils/errors.mjs';\nimport { isNumericalString } from '../../../utils/is-numerical-string.mjs';\nimport { isCSSVariableToken } from './is-css-variable.mjs';\n\n/**\n * Parse Framer's special CSS variable format into a CSS token and a fallback.\n *\n * ```\n * `var(--foo, #fff)` => [`--foo`, '#fff']\n * ```\n *\n * @param current\n */\nconst splitCSSVariableRegex = \n// eslint-disable-next-line redos-detector/no-unsafe-regex -- false positive, as it can match a lot of words\n/^var\\(--(?:([\\w-]+)|([\\w-]+), ?([a-zA-Z\\d ()%#.,-]+))\\)/u;\nfunction parseCSSVariable(current) {\n const match = splitCSSVariableRegex.exec(current);\n if (!match)\n return [,];\n const [, token1, token2, fallback] = match;\n return [`--${token1 !== null && token1 !== void 0 ? token1 : token2}`, fallback];\n}\nconst maxDepth = 4;\nfunction getVariableValue(current, element, depth = 1) {\n invariant(depth <= maxDepth, `Max CSS variable fallback depth detected in property \"${current}\". This may indicate a circular fallback dependency.`);\n const [token, fallback] = parseCSSVariable(current);\n // No CSS variable detected\n if (!token)\n return;\n // Attempt to read this CSS variable off the element\n const resolved = window.getComputedStyle(element).getPropertyValue(token);\n if (resolved) {\n const trimmed = resolved.trim();\n return isNumericalString(trimmed) ? parseFloat(trimmed) : trimmed;\n }\n return isCSSVariableToken(fallback)\n ? getVariableValue(fallback, element, depth + 1)\n : fallback;\n}\n\nexport { getVariableValue, parseCSSVariable };\n","import { transformPropOrder } from '../../html/utils/transform.mjs';\nimport { number } from '../../../value/types/numbers/index.mjs';\nimport { px } from '../../../value/types/numbers/units.mjs';\n\nconst positionalKeys = new Set([\n \"width\",\n \"height\",\n \"top\",\n \"left\",\n \"right\",\n \"bottom\",\n \"x\",\n \"y\",\n \"translateX\",\n \"translateY\",\n]);\nconst isNumOrPxType = (v) => v === number || v === px;\nconst getPosFromMatrix = (matrix, pos) => parseFloat(matrix.split(\", \")[pos]);\nconst getTranslateFromMatrix = (pos2, pos3) => (_bbox, { transform }) => {\n if (transform === \"none\" || !transform)\n return 0;\n const matrix3d = transform.match(/^matrix3d\\((.+)\\)$/u);\n if (matrix3d) {\n return getPosFromMatrix(matrix3d[1], pos3);\n }\n else {\n const matrix = transform.match(/^matrix\\((.+)\\)$/u);\n if (matrix) {\n return getPosFromMatrix(matrix[1], pos2);\n }\n else {\n return 0;\n }\n }\n};\nconst transformKeys = new Set([\"x\", \"y\", \"z\"]);\nconst nonTranslationalTransformKeys = transformPropOrder.filter((key) => !transformKeys.has(key));\nfunction removeNonTranslationalTransform(visualElement) {\n const removedTransforms = [];\n nonTranslationalTransformKeys.forEach((key) => {\n const value = visualElement.getValue(key);\n if (value !== undefined) {\n removedTransforms.push([key, value.get()]);\n value.set(key.startsWith(\"scale\") ? 1 : 0);\n }\n });\n return removedTransforms;\n}\nconst positionalValues = {\n // Dimensions\n width: ({ x }, { paddingLeft = \"0\", paddingRight = \"0\" }) => x.max - x.min - parseFloat(paddingLeft) - parseFloat(paddingRight),\n height: ({ y }, { paddingTop = \"0\", paddingBottom = \"0\" }) => y.max - y.min - parseFloat(paddingTop) - parseFloat(paddingBottom),\n top: (_bbox, { top }) => parseFloat(top),\n left: (_bbox, { left }) => parseFloat(left),\n bottom: ({ y }, { top }) => parseFloat(top) + (y.max - y.min),\n right: ({ x }, { left }) => parseFloat(left) + (x.max - x.min),\n // Transform\n x: getTranslateFromMatrix(4, 13),\n y: getTranslateFromMatrix(5, 14),\n};\n// Alias translate longform names\npositionalValues.translateX = positionalValues.x;\npositionalValues.translateY = positionalValues.y;\n\nexport { isNumOrPxType, positionalKeys, positionalValues, removeNonTranslationalTransform };\n","/**\n * Tests a provided value against a ValueType\n */\nconst testValueType = (v) => (type) => type.test(v);\n\nexport { testValueType };\n","import { number } from '../../../value/types/numbers/index.mjs';\nimport { px, percent, degrees, vw, vh } from '../../../value/types/numbers/units.mjs';\nimport { testValueType } from './test.mjs';\nimport { auto } from './type-auto.mjs';\n\n/**\n * A list of value types commonly used for dimensions\n */\nconst dimensionValueTypes = [number, px, percent, degrees, vw, vh, auto];\n/**\n * Tests a dimensional value against the list of dimension ValueTypes\n */\nconst findDimensionValueType = (v) => dimensionValueTypes.find(testValueType(v));\n\nexport { dimensionValueTypes, findDimensionValueType };\n","/**\n * ValueType for \"auto\"\n */\nconst auto = {\n test: (v) => v === \"auto\",\n parse: (v) => v,\n};\n\nexport { auto };\n","import { removeNonTranslationalTransform } from '../dom/utils/unit-conversion.mjs';\nimport { frame } from '../../frameloop/frame.mjs';\n\nconst toResolve = new Set();\nlet isScheduled = false;\nlet anyNeedsMeasurement = false;\nfunction measureAllKeyframes() {\n if (anyNeedsMeasurement) {\n const resolversToMeasure = Array.from(toResolve).filter((resolver) => resolver.needsMeasurement);\n const elementsToMeasure = new Set(resolversToMeasure.map((resolver) => resolver.element));\n const transformsToRestore = new Map();\n /**\n * Write pass\n * If we're measuring elements we want to remove bounding box-changing transforms.\n */\n elementsToMeasure.forEach((element) => {\n const removedTransforms = removeNonTranslationalTransform(element);\n if (!removedTransforms.length)\n return;\n transformsToRestore.set(element, removedTransforms);\n element.render();\n });\n // Read\n resolversToMeasure.forEach((resolver) => resolver.measureInitialState());\n // Write\n elementsToMeasure.forEach((element) => {\n element.render();\n const restore = transformsToRestore.get(element);\n if (restore) {\n restore.forEach(([key, value]) => {\n var _a;\n (_a = element.getValue(key)) === null || _a === void 0 ? void 0 : _a.set(value);\n });\n }\n });\n // Read\n resolversToMeasure.forEach((resolver) => resolver.measureEndState());\n // Write\n resolversToMeasure.forEach((resolver) => {\n if (resolver.suspendedScrollY !== undefined) {\n window.scrollTo(0, resolver.suspendedScrollY);\n }\n });\n }\n anyNeedsMeasurement = false;\n isScheduled = false;\n toResolve.forEach((resolver) => resolver.complete());\n toResolve.clear();\n}\nfunction readAllKeyframes() {\n toResolve.forEach((resolver) => {\n resolver.readKeyframes();\n if (resolver.needsMeasurement) {\n anyNeedsMeasurement = true;\n }\n });\n}\nfunction flushKeyframeResolvers() {\n readAllKeyframes();\n measureAllKeyframes();\n}\nclass KeyframeResolver {\n constructor(unresolvedKeyframes, onComplete, name, motionValue, element, isAsync = false) {\n /**\n * Track whether this resolver has completed. Once complete, it never\n * needs to attempt keyframe resolution again.\n */\n this.isComplete = false;\n /**\n * Track whether this resolver is async. If it is, it'll be added to the\n * resolver queue and flushed in the next frame. Resolvers that aren't going\n * to trigger read/write thrashing don't need to be async.\n */\n this.isAsync = false;\n /**\n * Track whether this resolver needs to perform a measurement\n * to resolve its keyframes.\n */\n this.needsMeasurement = false;\n /**\n * Track whether this resolver is currently scheduled to resolve\n * to allow it to be cancelled and resumed externally.\n */\n this.isScheduled = false;\n this.unresolvedKeyframes = [...unresolvedKeyframes];\n this.onComplete = onComplete;\n this.name = name;\n this.motionValue = motionValue;\n this.element = element;\n this.isAsync = isAsync;\n }\n scheduleResolve() {\n this.isScheduled = true;\n if (this.isAsync) {\n toResolve.add(this);\n if (!isScheduled) {\n isScheduled = true;\n frame.read(readAllKeyframes);\n frame.resolveKeyframes(measureAllKeyframes);\n }\n }\n else {\n this.readKeyframes();\n this.complete();\n }\n }\n readKeyframes() {\n const { unresolvedKeyframes, name, element, motionValue } = this;\n /**\n * If a keyframe is null, we hydrate it either by reading it from\n * the instance, or propagating from previous keyframes.\n */\n for (let i = 0; i < unresolvedKeyframes.length; i++) {\n if (unresolvedKeyframes[i] === null) {\n /**\n * If the first keyframe is null, we need to find its value by sampling the element\n */\n if (i === 0) {\n const currentValue = motionValue === null || motionValue === void 0 ? void 0 : motionValue.get();\n const finalKeyframe = unresolvedKeyframes[unresolvedKeyframes.length - 1];\n if (currentValue !== undefined) {\n unresolvedKeyframes[0] = currentValue;\n }\n else if (element && name) {\n const valueAsRead = element.readValue(name, finalKeyframe);\n if (valueAsRead !== undefined && valueAsRead !== null) {\n unresolvedKeyframes[0] = valueAsRead;\n }\n }\n if (unresolvedKeyframes[0] === undefined) {\n unresolvedKeyframes[0] = finalKeyframe;\n }\n if (motionValue && currentValue === undefined) {\n motionValue.set(unresolvedKeyframes[0]);\n }\n }\n else {\n unresolvedKeyframes[i] = unresolvedKeyframes[i - 1];\n }\n }\n }\n }\n setFinalKeyframe() { }\n measureInitialState() { }\n renderEndStyles() { }\n measureEndState() { }\n complete() {\n this.isComplete = true;\n this.onComplete(this.unresolvedKeyframes, this.finalKeyframe);\n toResolve.delete(this);\n }\n cancel() {\n if (!this.isComplete) {\n this.isScheduled = false;\n toResolve.delete(this);\n }\n }\n resume() {\n if (!this.isComplete)\n this.scheduleResolve();\n }\n}\n\nexport { KeyframeResolver, flushKeyframeResolvers };\n","import { isString, singleColorRegex, isNullish, floatRegex } from '../utils.mjs';\n\n/**\n * Returns true if the provided string is a color, ie rgba(0,0,0,0) or #000,\n * but false if a number or multiple colors\n */\nconst isColorString = (type, testProp) => (v) => {\n return Boolean((isString(v) && singleColorRegex.test(v) && v.startsWith(type)) ||\n (testProp &&\n !isNullish(v) &&\n Object.prototype.hasOwnProperty.call(v, testProp)));\n};\nconst splitColor = (aName, bName, cName) => (v) => {\n if (!isString(v))\n return v;\n const [a, b, c, alpha] = v.match(floatRegex);\n return {\n [aName]: parseFloat(a),\n [bName]: parseFloat(b),\n [cName]: parseFloat(c),\n alpha: alpha !== undefined ? parseFloat(alpha) : 1,\n };\n};\n\nexport { isColorString, splitColor };\n","import { clamp } from '../../../utils/clamp.mjs';\nimport { alpha, number } from '../numbers/index.mjs';\nimport { sanitize } from '../utils.mjs';\nimport { isColorString, splitColor } from './utils.mjs';\n\nconst clampRgbUnit = (v) => clamp(0, 255, v);\nconst rgbUnit = {\n ...number,\n transform: (v) => Math.round(clampRgbUnit(v)),\n};\nconst rgba = {\n test: isColorString(\"rgb\", \"red\"),\n parse: splitColor(\"red\", \"green\", \"blue\"),\n transform: ({ red, green, blue, alpha: alpha$1 = 1 }) => \"rgba(\" +\n rgbUnit.transform(red) +\n \", \" +\n rgbUnit.transform(green) +\n \", \" +\n rgbUnit.transform(blue) +\n \", \" +\n sanitize(alpha.transform(alpha$1)) +\n \")\",\n};\n\nexport { rgbUnit, rgba };\n","import { rgba } from './rgba.mjs';\nimport { isColorString } from './utils.mjs';\n\nfunction parseHex(v) {\n let r = \"\";\n let g = \"\";\n let b = \"\";\n let a = \"\";\n // If we have 6 characters, ie #FF0000\n if (v.length > 5) {\n r = v.substring(1, 3);\n g = v.substring(3, 5);\n b = v.substring(5, 7);\n a = v.substring(7, 9);\n // Or we have 3 characters, ie #F00\n }\n else {\n r = v.substring(1, 2);\n g = v.substring(2, 3);\n b = v.substring(3, 4);\n a = v.substring(4, 5);\n r += r;\n g += g;\n b += b;\n a += a;\n }\n return {\n red: parseInt(r, 16),\n green: parseInt(g, 16),\n blue: parseInt(b, 16),\n alpha: a ? parseInt(a, 16) / 255 : 1,\n };\n}\nconst hex = {\n test: isColorString(\"#\"),\n parse: parseHex,\n transform: rgba.transform,\n};\n\nexport { hex };\n","import { alpha } from '../numbers/index.mjs';\nimport { percent } from '../numbers/units.mjs';\nimport { sanitize } from '../utils.mjs';\nimport { isColorString, splitColor } from './utils.mjs';\n\nconst hsla = {\n test: isColorString(\"hsl\", \"hue\"),\n parse: splitColor(\"hue\", \"saturation\", \"lightness\"),\n transform: ({ hue, saturation, lightness, alpha: alpha$1 = 1 }) => {\n return (\"hsla(\" +\n Math.round(hue) +\n \", \" +\n percent.transform(sanitize(saturation)) +\n \", \" +\n percent.transform(sanitize(lightness)) +\n \", \" +\n sanitize(alpha.transform(alpha$1)) +\n \")\");\n },\n};\n\nexport { hsla };\n","import { isString } from '../utils.mjs';\nimport { hex } from './hex.mjs';\nimport { hsla } from './hsla.mjs';\nimport { rgba } from './rgba.mjs';\n\nconst color = {\n test: (v) => rgba.test(v) || hex.test(v) || hsla.test(v),\n parse: (v) => {\n if (rgba.test(v)) {\n return rgba.parse(v);\n }\n else if (hsla.test(v)) {\n return hsla.parse(v);\n }\n else {\n return hex.parse(v);\n }\n },\n transform: (v) => {\n return isString(v)\n ? v\n : v.hasOwnProperty(\"red\")\n ? rgba.transform(v)\n : hsla.transform(v);\n },\n};\n\nexport { color };\n","import { color } from '../color/index.mjs';\nimport { isString, floatRegex, colorRegex, sanitize } from '../utils.mjs';\n\nfunction test(v) {\n var _a, _b;\n return (isNaN(v) &&\n isString(v) &&\n (((_a = v.match(floatRegex)) === null || _a === void 0 ? void 0 : _a.length) || 0) +\n (((_b = v.match(colorRegex)) === null || _b === void 0 ? void 0 : _b.length) || 0) >\n 0);\n}\nconst NUMBER_TOKEN = \"number\";\nconst COLOR_TOKEN = \"color\";\nconst VAR_TOKEN = \"var\";\nconst VAR_FUNCTION_TOKEN = \"var(\";\nconst SPLIT_TOKEN = \"${}\";\n// this regex consists of the `singleCssVariableRegex|rgbHSLValueRegex|digitRegex`\nconst complexRegex = /var\\s*\\(\\s*--(?:[\\w-]+\\s*|[\\w-]+\\s*,(?:\\s*[^)(\\s]|\\s*\\((?:[^)(]|\\([^)(]*\\))*\\))+\\s*)\\)|#[\\da-f]{3,8}|(?:rgb|hsl)a?\\((?:-?[\\d.]+%?[,\\s]+){2}-?[\\d.]+%?\\s*(?:[,/]\\s*)?(?:\\b\\d+(?:\\.\\d+)?|\\.\\d+)?%?\\)|-?(?:\\d+(?:\\.\\d+)?|\\.\\d+)/giu;\nfunction analyseComplexValue(value) {\n const originalValue = value.toString();\n const values = [];\n const indexes = {\n color: [],\n number: [],\n var: [],\n };\n const types = [];\n let i = 0;\n const tokenised = originalValue.replace(complexRegex, (parsedValue) => {\n if (color.test(parsedValue)) {\n indexes.color.push(i);\n types.push(COLOR_TOKEN);\n values.push(color.parse(parsedValue));\n }\n else if (parsedValue.startsWith(VAR_FUNCTION_TOKEN)) {\n indexes.var.push(i);\n types.push(VAR_TOKEN);\n values.push(parsedValue);\n }\n else {\n indexes.number.push(i);\n types.push(NUMBER_TOKEN);\n values.push(parseFloat(parsedValue));\n }\n ++i;\n return SPLIT_TOKEN;\n });\n const split = tokenised.split(SPLIT_TOKEN);\n return { values, split, indexes, types };\n}\nfunction parseComplexValue(v) {\n return analyseComplexValue(v).values;\n}\nfunction createTransformer(source) {\n const { split, types } = analyseComplexValue(source);\n const numSections = split.length;\n return (v) => {\n let output = \"\";\n for (let i = 0; i < numSections; i++) {\n output += split[i];\n if (v[i] !== undefined) {\n const type = types[i];\n if (type === NUMBER_TOKEN) {\n output += sanitize(v[i]);\n }\n else if (type === COLOR_TOKEN) {\n output += color.transform(v[i]);\n }\n else {\n output += v[i];\n }\n }\n }\n return output;\n };\n}\nconst convertNumbersToZero = (v) => typeof v === \"number\" ? 0 : v;\nfunction getAnimatableNone(v) {\n const parsed = parseComplexValue(v);\n const transformer = createTransformer(v);\n return transformer(parsed.map(convertNumbersToZero));\n}\nconst complex = {\n test,\n parse: parseComplexValue,\n createTransformer,\n getAnimatableNone,\n};\n\nexport { analyseComplexValue, complex };\n","import { complex } from './index.mjs';\nimport { floatRegex } from '../utils.mjs';\n\n/**\n * Properties that should default to 1 or 100%\n */\nconst maxDefaults = new Set([\"brightness\", \"contrast\", \"saturate\", \"opacity\"]);\nfunction applyDefaultFilter(v) {\n const [name, value] = v.slice(0, -1).split(\"(\");\n if (name === \"drop-shadow\")\n return v;\n const [number] = value.match(floatRegex) || [];\n if (!number)\n return v;\n const unit = value.replace(number, \"\");\n let defaultValue = maxDefaults.has(name) ? 1 : 0;\n if (number !== value)\n defaultValue *= 100;\n return name + \"(\" + defaultValue + unit + \")\";\n}\nconst functionRegex = /\\b([a-z-]*)\\(.*?\\)/gu;\nconst filter = {\n ...complex,\n getAnimatableNone: (v) => {\n const functions = v.match(functionRegex);\n return functions ? functions.map(applyDefaultFilter).join(\" \") : v;\n },\n};\n\nexport { filter };\n","import { color } from '../../../value/types/color/index.mjs';\nimport { filter } from '../../../value/types/complex/filter.mjs';\nimport { numberValueTypes } from './number.mjs';\n\n/**\n * A map of default value types for common values\n */\nconst defaultValueTypes = {\n ...numberValueTypes,\n // Color props\n color,\n backgroundColor: color,\n outlineColor: color,\n fill: color,\n stroke: color,\n // Border props\n borderColor: color,\n borderTopColor: color,\n borderRightColor: color,\n borderBottomColor: color,\n borderLeftColor: color,\n filter,\n WebkitFilter: filter,\n};\n/**\n * Gets the default ValueType for the provided value key\n */\nconst getDefaultValueType = (key) => defaultValueTypes[key];\n\nexport { defaultValueTypes, getDefaultValueType };\n","import { complex } from '../../../value/types/complex/index.mjs';\nimport { filter } from '../../../value/types/complex/filter.mjs';\nimport { getDefaultValueType } from './defaults.mjs';\n\nfunction getAnimatableNone(key, value) {\n let defaultValueType = getDefaultValueType(key);\n if (defaultValueType !== filter)\n defaultValueType = complex;\n // If value is not recognised as animatable, ie \"none\", create an animatable version origin based on the target\n return defaultValueType.getAnimatableNone\n ? defaultValueType.getAnimatableNone(value)\n : undefined;\n}\n\nexport { getAnimatableNone };\n","import { analyseComplexValue } from '../../../value/types/complex/index.mjs';\nimport { getAnimatableNone } from '../../dom/value-types/animatable-none.mjs';\n\n/**\n * If we encounter keyframes like \"none\" or \"0\" and we also have keyframes like\n * \"#fff\" or \"200px 200px\" we want to find a keyframe to serve as a template for\n * the \"none\" keyframes. In this case \"#fff\" or \"200px 200px\" - then these get turned into\n * zero equivalents, i.e. \"#fff0\" or \"0px 0px\".\n */\nconst invalidTemplates = new Set([\"auto\", \"none\", \"0\"]);\nfunction makeNoneKeyframesAnimatable(unresolvedKeyframes, noneKeyframeIndexes, name) {\n let i = 0;\n let animatableTemplate = undefined;\n while (i < unresolvedKeyframes.length && !animatableTemplate) {\n const keyframe = unresolvedKeyframes[i];\n if (typeof keyframe === \"string\" &&\n !invalidTemplates.has(keyframe) &&\n analyseComplexValue(keyframe).values.length) {\n animatableTemplate = unresolvedKeyframes[i];\n }\n i++;\n }\n if (animatableTemplate && name) {\n for (const noneIndex of noneKeyframeIndexes) {\n unresolvedKeyframes[noneIndex] = getAnimatableNone(name, animatableTemplate);\n }\n }\n}\n\nexport { makeNoneKeyframesAnimatable };\n","import { isNone } from '../../animation/utils/is-none.mjs';\nimport { getVariableValue } from './utils/css-variables-conversion.mjs';\nimport { isCSSVariableToken } from './utils/is-css-variable.mjs';\nimport { positionalKeys, isNumOrPxType, positionalValues } from './utils/unit-conversion.mjs';\nimport { findDimensionValueType } from './value-types/dimensions.mjs';\nimport { KeyframeResolver } from '../utils/KeyframesResolver.mjs';\nimport { makeNoneKeyframesAnimatable } from '../html/utils/make-none-animatable.mjs';\n\nclass DOMKeyframesResolver extends KeyframeResolver {\n constructor(unresolvedKeyframes, onComplete, name, motionValue, element) {\n super(unresolvedKeyframes, onComplete, name, motionValue, element, true);\n }\n readKeyframes() {\n const { unresolvedKeyframes, element, name } = this;\n if (!element || !element.current)\n return;\n super.readKeyframes();\n /**\n * If any keyframe is a CSS variable, we need to find its value by sampling the element\n */\n for (let i = 0; i < unresolvedKeyframes.length; i++) {\n let keyframe = unresolvedKeyframes[i];\n if (typeof keyframe === \"string\") {\n keyframe = keyframe.trim();\n if (isCSSVariableToken(keyframe)) {\n const resolved = getVariableValue(keyframe, element.current);\n if (resolved !== undefined) {\n unresolvedKeyframes[i] = resolved;\n }\n if (i === unresolvedKeyframes.length - 1) {\n this.finalKeyframe = keyframe;\n }\n }\n }\n }\n /**\n * Resolve \"none\" values. We do this potentially twice - once before and once after measuring keyframes.\n * This could be seen as inefficient but it's a trade-off to avoid measurements in more situations, which\n * have a far bigger performance impact.\n */\n this.resolveNoneKeyframes();\n /**\n * Check to see if unit type has changed. If so schedule jobs that will\n * temporarily set styles to the destination keyframes.\n * Skip if we have more than two keyframes or this isn't a positional value.\n * TODO: We can throw if there are multiple keyframes and the value type changes.\n */\n if (!positionalKeys.has(name) || unresolvedKeyframes.length !== 2) {\n return;\n }\n const [origin, target] = unresolvedKeyframes;\n const originType = findDimensionValueType(origin);\n const targetType = findDimensionValueType(target);\n /**\n * Either we don't recognise these value types or we can animate between them.\n */\n if (originType === targetType)\n return;\n /**\n * If both values are numbers or pixels, we can animate between them by\n * converting them to numbers.\n */\n if (isNumOrPxType(originType) && isNumOrPxType(targetType)) {\n for (let i = 0; i < unresolvedKeyframes.length; i++) {\n const value = unresolvedKeyframes[i];\n if (typeof value === \"string\") {\n unresolvedKeyframes[i] = parseFloat(value);\n }\n }\n }\n else {\n /**\n * Else, the only way to resolve this is by measuring the element.\n */\n this.needsMeasurement = true;\n }\n }\n resolveNoneKeyframes() {\n const { unresolvedKeyframes, name } = this;\n const noneKeyframeIndexes = [];\n for (let i = 0; i < unresolvedKeyframes.length; i++) {\n if (isNone(unresolvedKeyframes[i])) {\n noneKeyframeIndexes.push(i);\n }\n }\n if (noneKeyframeIndexes.length) {\n makeNoneKeyframesAnimatable(unresolvedKeyframes, noneKeyframeIndexes, name);\n }\n }\n measureInitialState() {\n const { element, unresolvedKeyframes, name } = this;\n if (!element || !element.current)\n return;\n if (name === \"height\") {\n this.suspendedScrollY = window.pageYOffset;\n }\n this.measuredOrigin = positionalValues[name](element.measureViewportBox(), window.getComputedStyle(element.current));\n unresolvedKeyframes[0] = this.measuredOrigin;\n // Set final key frame to measure after next render\n const measureKeyframe = unresolvedKeyframes[unresolvedKeyframes.length - 1];\n if (measureKeyframe !== undefined) {\n element.getValue(name, measureKeyframe).jump(measureKeyframe, false);\n }\n }\n measureEndState() {\n var _a;\n const { element, name, unresolvedKeyframes } = this;\n if (!element || !element.current)\n return;\n const value = element.getValue(name);\n value && value.jump(this.measuredOrigin, false);\n const finalKeyframeIndex = unresolvedKeyframes.length - 1;\n const finalKeyframe = unresolvedKeyframes[finalKeyframeIndex];\n unresolvedKeyframes[finalKeyframeIndex] = positionalValues[name](element.measureViewportBox(), window.getComputedStyle(element.current));\n if (finalKeyframe !== null && this.finalKeyframe === undefined) {\n this.finalKeyframe = finalKeyframe;\n }\n // If we removed transform values, reapply them before the next render\n if ((_a = this.removedTransforms) === null || _a === void 0 ? void 0 : _a.length) {\n this.removedTransforms.forEach(([unsetTransformName, unsetTransformValue]) => {\n element\n .getValue(unsetTransformName)\n .set(unsetTransformValue);\n });\n }\n this.resolveNoneKeyframes();\n }\n}\n\nexport { DOMKeyframesResolver };\n","import { isZeroValueString } from '../../utils/is-zero-value-string.mjs';\n\nfunction isNone(value) {\n if (typeof value === \"number\") {\n return value === 0;\n }\n else if (value !== null) {\n return value === \"none\" || value === \"0\" || isZeroValueString(value);\n }\n else {\n return true;\n }\n}\n\nexport { isNone };\n","function memo(callback) {\n let result;\n return () => {\n if (result === undefined)\n result = callback();\n return result;\n };\n}\n\nexport { memo };\n","import { MotionGlobalConfig } from '../utils/GlobalConfig.mjs';\nimport { frameData } from './frame.mjs';\n\nlet now;\nfunction clearTime() {\n now = undefined;\n}\n/**\n * An eventloop-synchronous alternative to performance.now().\n *\n * Ensures that time measurements remain consistent within a synchronous context.\n * Usually calling performance.now() twice within the same synchronous context\n * will return different values which isn't useful for animations when we're usually\n * trying to sync animations to the same frame.\n */\nconst time = {\n now: () => {\n if (now === undefined) {\n time.set(frameData.isProcessing || MotionGlobalConfig.useManualTiming\n ? frameData.timestamp\n : performance.now());\n }\n return now;\n },\n set: (newTime) => {\n now = newTime;\n queueMicrotask(clearTime);\n },\n};\n\nexport { time };\n","import { complex } from '../../value/types/complex/index.mjs';\n\n/**\n * Check if a value is animatable. Examples:\n *\n * ✅: 100, \"100px\", \"#fff\"\n * ❌: \"block\", \"url(2.jpg)\"\n * @param value\n *\n * @internal\n */\nconst isAnimatable = (value, name) => {\n // If the list of keys tat might be non-animatable grows, replace with Set\n if (name === \"zIndex\")\n return false;\n // If it's a number or a keyframes array, we can animate it. We might at some point\n // need to do a deep isAnimatable check of keyframes, or let Popmotion handle this,\n // but for now lets leave it like this for performance reasons\n if (typeof value === \"number\" || Array.isArray(value))\n return true;\n if (typeof value === \"string\" && // It's animatable if we have a string\n (complex.test(value) || value === \"0\") && // And it contains numbers and/or colors\n !value.startsWith(\"url(\") // Unless it starts with \"url(\"\n ) {\n return true;\n }\n return false;\n};\n\nexport { isAnimatable };\n","import { time } from '../../frameloop/sync-time.mjs';\nimport { flushKeyframeResolvers } from '../../render/utils/KeyframesResolver.mjs';\nimport { instantAnimationState } from '../../utils/use-instant-transition-state.mjs';\nimport { canAnimate } from './utils/can-animate.mjs';\nimport { getFinalKeyframe } from './waapi/utils/get-final-keyframe.mjs';\n\n/**\n * Maximum time allowed between an animation being created and it being\n * resolved for us to use the latter as the start time.\n *\n * This is to ensure that while we prefer to \"start\" an animation as soon\n * as it's triggered, we also want to avoid a visual jump if there's a big delay\n * between these two moments.\n */\nconst MAX_RESOLVE_DELAY = 40;\nclass BaseAnimation {\n constructor({ autoplay = true, delay = 0, type = \"keyframes\", repeat = 0, repeatDelay = 0, repeatType = \"loop\", ...options }) {\n // Track whether the animation has been stopped. Stopped animations won't restart.\n this.isStopped = false;\n this.hasAttemptedResolve = false;\n this.createdAt = time.now();\n this.options = {\n autoplay,\n delay,\n type,\n repeat,\n repeatDelay,\n repeatType,\n ...options,\n };\n this.updateFinishedPromise();\n }\n /**\n * This method uses the createdAt and resolvedAt to calculate the\n * animation startTime. *Ideally*, we would use the createdAt time as t=0\n * as the following frame would then be the first frame of the animation in\n * progress, which would feel snappier.\n *\n * However, if there's a delay (main thread work) between the creation of\n * the animation and the first commited frame, we prefer to use resolvedAt\n * to avoid a sudden jump into the animation.\n */\n calcStartTime() {\n if (!this.resolvedAt)\n return this.createdAt;\n return this.resolvedAt - this.createdAt > MAX_RESOLVE_DELAY\n ? this.resolvedAt\n : this.createdAt;\n }\n /**\n * A getter for resolved data. If keyframes are not yet resolved, accessing\n * this.resolved will synchronously flush all pending keyframe resolvers.\n * This is a deoptimisation, but at its worst still batches read/writes.\n */\n get resolved() {\n if (!this._resolved && !this.hasAttemptedResolve) {\n flushKeyframeResolvers();\n }\n return this._resolved;\n }\n /**\n * A method to be called when the keyframes resolver completes. This method\n * will check if its possible to run the animation and, if not, skip it.\n * Otherwise, it will call initPlayback on the implementing class.\n */\n onKeyframesResolved(keyframes, finalKeyframe) {\n this.resolvedAt = time.now();\n this.hasAttemptedResolve = true;\n const { name, type, velocity, delay, onComplete, onUpdate, isGenerator, } = this.options;\n /**\n * If we can't animate this value with the resolved keyframes\n * then we should complete it immediately.\n */\n if (!isGenerator && !canAnimate(keyframes, name, type, velocity)) {\n // Finish immediately\n if (instantAnimationState.current || !delay) {\n onUpdate === null || onUpdate === void 0 ? void 0 : onUpdate(getFinalKeyframe(keyframes, this.options, finalKeyframe));\n onComplete === null || onComplete === void 0 ? void 0 : onComplete();\n this.resolveFinishedPromise();\n return;\n }\n // Finish after a delay\n else {\n this.options.duration = 0;\n }\n }\n const resolvedAnimation = this.initPlayback(keyframes, finalKeyframe);\n if (resolvedAnimation === false)\n return;\n this._resolved = {\n keyframes,\n finalKeyframe,\n ...resolvedAnimation,\n };\n this.onPostResolved();\n }\n onPostResolved() { }\n /**\n * Allows the returned animation to be awaited or promise-chained. Currently\n * resolves when the animation finishes at all but in a future update could/should\n * reject if its cancels.\n */\n then(resolve, reject) {\n return this.currentFinishedPromise.then(resolve, reject);\n }\n updateFinishedPromise() {\n this.currentFinishedPromise = new Promise((resolve) => {\n this.resolveFinishedPromise = resolve;\n });\n }\n}\n\nexport { BaseAnimation };\n","import { warning } from '../../../utils/errors.mjs';\nimport { isAnimatable } from '../../utils/is-animatable.mjs';\n\nfunction hasKeyframesChanged(keyframes) {\n const current = keyframes[0];\n if (keyframes.length === 1)\n return true;\n for (let i = 0; i < keyframes.length; i++) {\n if (keyframes[i] !== current)\n return true;\n }\n}\nfunction canAnimate(keyframes, name, type, velocity) {\n /**\n * Check if we're able to animate between the start and end keyframes,\n * and throw a warning if we're attempting to animate between one that's\n * animatable and another that isn't.\n */\n const originKeyframe = keyframes[0];\n if (originKeyframe === null)\n return false;\n /**\n * These aren't traditionally animatable but we do support them.\n * In future we could look into making this more generic or replacing\n * this function with mix() === mixImmediate\n */\n if (name === \"display\" || name === \"visibility\")\n return true;\n const targetKeyframe = keyframes[keyframes.length - 1];\n const isOriginAnimatable = isAnimatable(originKeyframe, name);\n const isTargetAnimatable = isAnimatable(targetKeyframe, name);\n warning(isOriginAnimatable === isTargetAnimatable, `You are trying to animate ${name} from \"${originKeyframe}\" to \"${targetKeyframe}\". ${originKeyframe} is not an animatable value - to enable this animation set ${originKeyframe} to a value animatable to ${targetKeyframe} via the \\`style\\` property.`);\n // Always skip if any of these are true\n if (!isOriginAnimatable || !isTargetAnimatable) {\n return false;\n }\n return hasKeyframesChanged(keyframes) || (type === \"spring\" && velocity);\n}\n\nexport { canAnimate };\n","/*\n Convert velocity into velocity per second\n\n @param [number]: Unit per frame\n @param [number]: Frame duration in ms\n*/\nfunction velocityPerSecond(velocity, frameDuration) {\n return frameDuration ? velocity * (1000 / frameDuration) : 0;\n}\n\nexport { velocityPerSecond };\n","import { velocityPerSecond } from '../../../utils/velocity-per-second.mjs';\n\nconst velocitySampleDuration = 5; // ms\nfunction calcGeneratorVelocity(resolveValue, t, current) {\n const prevT = Math.max(t - velocitySampleDuration, 0);\n return velocityPerSecond(current - resolveValue(prevT), t - prevT);\n}\n\nexport { calcGeneratorVelocity };\n","import { warning } from '../../../utils/errors.mjs';\nimport { clamp } from '../../../utils/clamp.mjs';\nimport { secondsToMilliseconds, millisecondsToSeconds } from '../../../utils/time-conversion.mjs';\n\nconst safeMin = 0.001;\nconst minDuration = 0.01;\nconst maxDuration = 10.0;\nconst minDamping = 0.05;\nconst maxDamping = 1;\nfunction findSpring({ duration = 800, bounce = 0.25, velocity = 0, mass = 1, }) {\n let envelope;\n let derivative;\n warning(duration <= secondsToMilliseconds(maxDuration), \"Spring duration must be 10 seconds or less\");\n let dampingRatio = 1 - bounce;\n /**\n * Restrict dampingRatio and duration to within acceptable ranges.\n */\n dampingRatio = clamp(minDamping, maxDamping, dampingRatio);\n duration = clamp(minDuration, maxDuration, millisecondsToSeconds(duration));\n if (dampingRatio < 1) {\n /**\n * Underdamped spring\n */\n envelope = (undampedFreq) => {\n const exponentialDecay = undampedFreq * dampingRatio;\n const delta = exponentialDecay * duration;\n const a = exponentialDecay - velocity;\n const b = calcAngularFreq(undampedFreq, dampingRatio);\n const c = Math.exp(-delta);\n return safeMin - (a / b) * c;\n };\n derivative = (undampedFreq) => {\n const exponentialDecay = undampedFreq * dampingRatio;\n const delta = exponentialDecay * duration;\n const d = delta * velocity + velocity;\n const e = Math.pow(dampingRatio, 2) * Math.pow(undampedFreq, 2) * duration;\n const f = Math.exp(-delta);\n const g = calcAngularFreq(Math.pow(undampedFreq, 2), dampingRatio);\n const factor = -envelope(undampedFreq) + safeMin > 0 ? -1 : 1;\n return (factor * ((d - e) * f)) / g;\n };\n }\n else {\n /**\n * Critically-damped spring\n */\n envelope = (undampedFreq) => {\n const a = Math.exp(-undampedFreq * duration);\n const b = (undampedFreq - velocity) * duration + 1;\n return -safeMin + a * b;\n };\n derivative = (undampedFreq) => {\n const a = Math.exp(-undampedFreq * duration);\n const b = (velocity - undampedFreq) * (duration * duration);\n return a * b;\n };\n }\n const initialGuess = 5 / duration;\n const undampedFreq = approximateRoot(envelope, derivative, initialGuess);\n duration = secondsToMilliseconds(duration);\n if (isNaN(undampedFreq)) {\n return {\n stiffness: 100,\n damping: 10,\n duration,\n };\n }\n else {\n const stiffness = Math.pow(undampedFreq, 2) * mass;\n return {\n stiffness,\n damping: dampingRatio * 2 * Math.sqrt(mass * stiffness),\n duration,\n };\n }\n}\nconst rootIterations = 12;\nfunction approximateRoot(envelope, derivative, initialGuess) {\n let result = initialGuess;\n for (let i = 1; i < rootIterations; i++) {\n result = result - envelope(result) / derivative(result);\n }\n return result;\n}\nfunction calcAngularFreq(undampedFreq, dampingRatio) {\n return undampedFreq * Math.sqrt(1 - dampingRatio * dampingRatio);\n}\n\nexport { calcAngularFreq, findSpring, maxDamping, maxDuration, minDamping, minDuration };\n","import { millisecondsToSeconds, secondsToMilliseconds } from '../../../utils/time-conversion.mjs';\nimport { calcGeneratorVelocity } from '../utils/velocity.mjs';\nimport { findSpring, calcAngularFreq } from './find.mjs';\n\nconst durationKeys = [\"duration\", \"bounce\"];\nconst physicsKeys = [\"stiffness\", \"damping\", \"mass\"];\nfunction isSpringType(options, keys) {\n return keys.some((key) => options[key] !== undefined);\n}\nfunction getSpringOptions(options) {\n let springOptions = {\n velocity: 0.0,\n stiffness: 100,\n damping: 10,\n mass: 1.0,\n isResolvedFromDuration: false,\n ...options,\n };\n // stiffness/damping/mass overrides duration/bounce\n if (!isSpringType(options, physicsKeys) &&\n isSpringType(options, durationKeys)) {\n const derived = findSpring(options);\n springOptions = {\n ...springOptions,\n ...derived,\n mass: 1.0,\n };\n springOptions.isResolvedFromDuration = true;\n }\n return springOptions;\n}\nfunction spring({ keyframes, restDelta, restSpeed, ...options }) {\n const origin = keyframes[0];\n const target = keyframes[keyframes.length - 1];\n /**\n * This is the Iterator-spec return value. We ensure it's mutable rather than using a generator\n * to reduce GC during animation.\n */\n const state = { done: false, value: origin };\n const { stiffness, damping, mass, duration, velocity, isResolvedFromDuration, } = getSpringOptions({\n ...options,\n velocity: -millisecondsToSeconds(options.velocity || 0),\n });\n const initialVelocity = velocity || 0.0;\n const dampingRatio = damping / (2 * Math.sqrt(stiffness * mass));\n const initialDelta = target - origin;\n const undampedAngularFreq = millisecondsToSeconds(Math.sqrt(stiffness / mass));\n /**\n * If we're working on a granular scale, use smaller defaults for determining\n * when the spring is finished.\n *\n * These defaults have been selected emprically based on what strikes a good\n * ratio between feeling good and finishing as soon as changes are imperceptible.\n */\n const isGranularScale = Math.abs(initialDelta) < 5;\n restSpeed || (restSpeed = isGranularScale ? 0.01 : 2);\n restDelta || (restDelta = isGranularScale ? 0.005 : 0.5);\n let resolveSpring;\n if (dampingRatio < 1) {\n const angularFreq = calcAngularFreq(undampedAngularFreq, dampingRatio);\n // Underdamped spring\n resolveSpring = (t) => {\n const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n return (target -\n envelope *\n (((initialVelocity +\n dampingRatio * undampedAngularFreq * initialDelta) /\n angularFreq) *\n Math.sin(angularFreq * t) +\n initialDelta * Math.cos(angularFreq * t)));\n };\n }\n else if (dampingRatio === 1) {\n // Critically damped spring\n resolveSpring = (t) => target -\n Math.exp(-undampedAngularFreq * t) *\n (initialDelta +\n (initialVelocity + undampedAngularFreq * initialDelta) * t);\n }\n else {\n // Overdamped spring\n const dampedAngularFreq = undampedAngularFreq * Math.sqrt(dampingRatio * dampingRatio - 1);\n resolveSpring = (t) => {\n const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n // When performing sinh or cosh values can hit Infinity so we cap them here\n const freqForT = Math.min(dampedAngularFreq * t, 300);\n return (target -\n (envelope *\n ((initialVelocity +\n dampingRatio * undampedAngularFreq * initialDelta) *\n Math.sinh(freqForT) +\n dampedAngularFreq *\n initialDelta *\n Math.cosh(freqForT))) /\n dampedAngularFreq);\n };\n }\n return {\n calculatedDuration: isResolvedFromDuration ? duration || null : null,\n next: (t) => {\n const current = resolveSpring(t);\n if (!isResolvedFromDuration) {\n let currentVelocity = 0.0;\n /**\n * We only need to calculate velocity for under-damped springs\n * as over- and critically-damped springs can't overshoot, so\n * checking only for displacement is enough.\n */\n if (dampingRatio < 1) {\n currentVelocity =\n t === 0\n ? secondsToMilliseconds(initialVelocity)\n : calcGeneratorVelocity(resolveSpring, t, current);\n }\n const isBelowVelocityThreshold = Math.abs(currentVelocity) <= restSpeed;\n const isBelowDisplacementThreshold = Math.abs(target - current) <= restDelta;\n state.done =\n isBelowVelocityThreshold && isBelowDisplacementThreshold;\n }\n else {\n state.done = t >= duration;\n }\n state.value = state.done ? target : current;\n return state;\n },\n };\n}\n\nexport { spring };\n","import { spring } from './spring/index.mjs';\nimport { calcGeneratorVelocity } from './utils/velocity.mjs';\n\nfunction inertia({ keyframes, velocity = 0.0, power = 0.8, timeConstant = 325, bounceDamping = 10, bounceStiffness = 500, modifyTarget, min, max, restDelta = 0.5, restSpeed, }) {\n const origin = keyframes[0];\n const state = {\n done: false,\n value: origin,\n };\n const isOutOfBounds = (v) => (min !== undefined && v < min) || (max !== undefined && v > max);\n const nearestBoundary = (v) => {\n if (min === undefined)\n return max;\n if (max === undefined)\n return min;\n return Math.abs(min - v) < Math.abs(max - v) ? min : max;\n };\n let amplitude = power * velocity;\n const ideal = origin + amplitude;\n const target = modifyTarget === undefined ? ideal : modifyTarget(ideal);\n /**\n * If the target has changed we need to re-calculate the amplitude, otherwise\n * the animation will start from the wrong position.\n */\n if (target !== ideal)\n amplitude = target - origin;\n const calcDelta = (t) => -amplitude * Math.exp(-t / timeConstant);\n const calcLatest = (t) => target + calcDelta(t);\n const applyFriction = (t) => {\n const delta = calcDelta(t);\n const latest = calcLatest(t);\n state.done = Math.abs(delta) <= restDelta;\n state.value = state.done ? target : latest;\n };\n /**\n * Ideally this would resolve for t in a stateless way, we could\n * do that by always precalculating the animation but as we know\n * this will be done anyway we can assume that spring will\n * be discovered during that.\n */\n let timeReachedBoundary;\n let spring$1;\n const checkCatchBoundary = (t) => {\n if (!isOutOfBounds(state.value))\n return;\n timeReachedBoundary = t;\n spring$1 = spring({\n keyframes: [state.value, nearestBoundary(state.value)],\n velocity: calcGeneratorVelocity(calcLatest, t, state.value), // TODO: This should be passing * 1000\n damping: bounceDamping,\n stiffness: bounceStiffness,\n restDelta,\n restSpeed,\n });\n };\n checkCatchBoundary(0);\n return {\n calculatedDuration: null,\n next: (t) => {\n /**\n * We need to resolve the friction to figure out if we need a\n * spring but we don't want to do this twice per frame. So here\n * we flag if we updated for this frame and later if we did\n * we can skip doing it again.\n */\n let hasUpdatedFrame = false;\n if (!spring$1 && timeReachedBoundary === undefined) {\n hasUpdatedFrame = true;\n applyFriction(t);\n checkCatchBoundary(t);\n }\n /**\n * If we have a spring and the provided t is beyond the moment the friction\n * animation crossed the min/max boundary, use the spring.\n */\n if (timeReachedBoundary !== undefined && t >= timeReachedBoundary) {\n return spring$1.next(t - timeReachedBoundary);\n }\n else {\n !hasUpdatedFrame && applyFriction(t);\n return state;\n }\n },\n };\n}\n\nexport { inertia };\n","import { noop } from '../utils/noop.mjs';\n\n/*\n Bezier function generator\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 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 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) *\n 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 noop;\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 { cubicBezier } from './cubic-bezier.mjs';\n\nconst easeIn = cubicBezier(0.42, 0, 1, 1);\nconst easeOut = cubicBezier(0, 0, 0.58, 1);\nconst easeInOut = cubicBezier(0.42, 0, 0.58, 1);\n\nexport { easeIn, easeInOut, easeOut };\n","// Accepts an easing function and returns a new one that outputs mirrored values for\n// the second half of the animation. Turns easeIn into easeInOut.\nconst mirrorEasing = (easing) => (p) => p <= 0.5 ? easing(2 * p) / 2 : (2 - easing(2 * (1 - p))) / 2;\n\nexport { mirrorEasing };\n","// Accepts an easing function and returns a new one that outputs reversed values.\n// Turns easeIn into easeOut.\nconst reverseEasing = (easing) => (p) => 1 - easing(1 - p);\n\nexport { reverseEasing };\n","import { mirrorEasing } from './modifiers/mirror.mjs';\nimport { reverseEasing } from './modifiers/reverse.mjs';\n\nconst circIn = (p) => 1 - Math.sin(Math.acos(p));\nconst circOut = reverseEasing(circIn);\nconst circInOut = mirrorEasing(circIn);\n\nexport { circIn, circInOut, circOut };\n","import { cubicBezier } from './cubic-bezier.mjs';\nimport { mirrorEasing } from './modifiers/mirror.mjs';\nimport { reverseEasing } from './modifiers/reverse.mjs';\n\nconst backOut = cubicBezier(0.33, 1.53, 0.69, 0.99);\nconst backIn = reverseEasing(backOut);\nconst backInOut = mirrorEasing(backIn);\n\nexport { backIn, backInOut, backOut };\n","import { invariant } from '../../utils/errors.mjs';\nimport { cubicBezier } from '../cubic-bezier.mjs';\nimport { noop } from '../../utils/noop.mjs';\nimport { easeIn, easeInOut, easeOut } from '../ease.mjs';\nimport { circIn, circInOut, circOut } from '../circ.mjs';\nimport { backIn, backInOut, backOut } from '../back.mjs';\nimport { anticipate } from '../anticipate.mjs';\n\nconst easingLookup = {\n linear: noop,\n easeIn,\n easeInOut,\n easeOut,\n circIn,\n circInOut,\n circOut,\n backIn,\n backInOut,\n backOut,\n anticipate,\n};\nconst easingDefinitionToFunction = (definition) => {\n if (Array.isArray(definition)) {\n // If cubic bezier definition, create bezier curve\n invariant(definition.length === 4, `Cubic bezier arrays must contain four numerical values.`);\n const [x1, y1, x2, y2] = definition;\n return cubicBezier(x1, y1, x2, y2);\n }\n else if (typeof definition === \"string\") {\n // Else lookup from table\n invariant(easingLookup[definition] !== undefined, `Invalid easing type '${definition}'`);\n return easingLookup[definition];\n }\n return definition;\n};\n\nexport { easingDefinitionToFunction };\n","import { backIn } from './back.mjs';\n\nconst anticipate = (p) => (p *= 2) < 1 ? 0.5 * backIn(p) : 0.5 * (2 - Math.pow(2, -10 * (p - 1)));\n\nexport { anticipate };\n","/*\n Progress within given range\n\n Given a lower limit and an upper limit, we return the progress\n (expressed as a number 0-1) represented by the given value, and\n limit that progress to within 0-1.\n\n @param [number]: Lower limit\n @param [number]: Upper limit\n @param [number]: Value to find progress within given range\n @return [number]: Progress of value within range as expressed 0-1\n*/\nconst progress = (from, to, value) => {\n const toFromDifference = to - from;\n return toFromDifference === 0 ? 1 : (value - from) / toFromDifference;\n};\n\nexport { progress };\n","/*\n Value in range from progress\n\n Given a lower limit and an upper limit, we return the value within\n that range as expressed by progress (usually a number from 0 to 1)\n\n So progress = 0.5 would change\n\n from -------- to\n\n to\n\n from ---- to\n\n E.g. from = 10, to = 20, progress = 0.5 => 15\n\n @param [number]: Lower limit of range\n @param [number]: Upper limit of range\n @param [number]: The progress between lower and upper limits expressed 0-1\n @return [number]: Value as calculated from progress within range (not limited within range)\n*/\nconst mixNumber = (from, to, progress) => {\n return from + (to - from) * progress;\n};\n\nexport { mixNumber };\n","// Adapted from https://gist.github.com/mjackson/5311256\nfunction hueToRgb(p, q, t) {\n if (t < 0)\n t += 1;\n if (t > 1)\n t -= 1;\n if (t < 1 / 6)\n return p + (q - p) * 6 * t;\n if (t < 1 / 2)\n return q;\n if (t < 2 / 3)\n return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n}\nfunction hslaToRgba({ hue, saturation, lightness, alpha }) {\n hue /= 360;\n saturation /= 100;\n lightness /= 100;\n let red = 0;\n let green = 0;\n let blue = 0;\n if (!saturation) {\n red = green = blue = lightness;\n }\n else {\n const q = lightness < 0.5\n ? lightness * (1 + saturation)\n : lightness + saturation - lightness * saturation;\n const p = 2 * lightness - q;\n red = hueToRgb(p, q, hue + 1 / 3);\n green = hueToRgb(p, q, hue);\n blue = hueToRgb(p, q, hue - 1 / 3);\n }\n return {\n red: Math.round(red * 255),\n green: Math.round(green * 255),\n blue: Math.round(blue * 255),\n alpha,\n };\n}\n\nexport { hslaToRgba };\n","function mixImmediate(a, b) {\n return (p) => (p > 0 ? b : a);\n}\n\nexport { mixImmediate };\n","import { mixNumber } from './number.mjs';\nimport { warning } from '../errors.mjs';\nimport { hslaToRgba } from '../hsla-to-rgba.mjs';\nimport { hex } from '../../value/types/color/hex.mjs';\nimport { rgba } from '../../value/types/color/rgba.mjs';\nimport { hsla } from '../../value/types/color/hsla.mjs';\nimport { mixImmediate } from './immediate.mjs';\n\n// Linear color space blending\n// Explained https://www.youtube.com/watch?v=LKnqECcg6Gw\n// Demonstrated http://codepen.io/osublake/pen/xGVVaN\nconst mixLinearColor = (from, to, v) => {\n const fromExpo = from * from;\n const expo = v * (to * to - fromExpo) + fromExpo;\n return expo < 0 ? 0 : Math.sqrt(expo);\n};\nconst colorTypes = [hex, rgba, hsla];\nconst getColorType = (v) => colorTypes.find((type) => type.test(v));\nfunction asRGBA(color) {\n const type = getColorType(color);\n warning(Boolean(type), `'${color}' is not an animatable color. Use the equivalent color code instead.`);\n if (!Boolean(type))\n return false;\n let model = type.parse(color);\n if (type === hsla) {\n // TODO Remove this cast - needed since Framer Motion's stricter typing\n model = hslaToRgba(model);\n }\n return model;\n}\nconst mixColor = (from, to) => {\n const fromRGBA = asRGBA(from);\n const toRGBA = asRGBA(to);\n if (!fromRGBA || !toRGBA) {\n return mixImmediate(from, to);\n }\n const blended = { ...fromRGBA };\n return (v) => {\n blended.red = mixLinearColor(fromRGBA.red, toRGBA.red, v);\n blended.green = mixLinearColor(fromRGBA.green, toRGBA.green, v);\n blended.blue = mixLinearColor(fromRGBA.blue, toRGBA.blue, v);\n blended.alpha = mixNumber(fromRGBA.alpha, toRGBA.alpha, v);\n return rgba.transform(blended);\n };\n};\n\nexport { mixColor, mixLinearColor };\n","const invisibleValues = new Set([\"none\", \"hidden\"]);\n/**\n * Returns a function that, when provided a progress value between 0 and 1,\n * will return the \"none\" or \"hidden\" string only when the progress is that of\n * the origin or target.\n */\nfunction mixVisibility(origin, target) {\n if (invisibleValues.has(origin)) {\n return (p) => (p <= 0 ? origin : target);\n }\n else {\n return (p) => (p >= 1 ? target : origin);\n }\n}\n\nexport { invisibleValues, mixVisibility };\n","import { mixNumber as mixNumber$1 } from './number.mjs';\nimport { mixColor } from './color.mjs';\nimport { pipe } from '../pipe.mjs';\nimport { warning } from '../errors.mjs';\nimport { color } from '../../value/types/color/index.mjs';\nimport { complex, analyseComplexValue } from '../../value/types/complex/index.mjs';\nimport { isCSSVariableToken } from '../../render/dom/utils/is-css-variable.mjs';\nimport { invisibleValues, mixVisibility } from './visibility.mjs';\nimport { mixImmediate } from './immediate.mjs';\n\nfunction mixNumber(a, b) {\n return (p) => mixNumber$1(a, b, p);\n}\nfunction getMixer(a) {\n if (typeof a === \"number\") {\n return mixNumber;\n }\n else if (typeof a === \"string\") {\n return isCSSVariableToken(a)\n ? mixImmediate\n : color.test(a)\n ? mixColor\n : mixComplex;\n }\n else if (Array.isArray(a)) {\n return mixArray;\n }\n else if (typeof a === \"object\") {\n return color.test(a) ? mixColor : mixObject;\n }\n return mixImmediate;\n}\nfunction mixArray(a, b) {\n const output = [...a];\n const numValues = output.length;\n const blendValue = a.map((v, i) => getMixer(v)(v, b[i]));\n return (p) => {\n for (let i = 0; i < numValues; i++) {\n output[i] = blendValue[i](p);\n }\n return output;\n };\n}\nfunction mixObject(a, b) {\n const output = { ...a, ...b };\n const blendValue = {};\n for (const key in output) {\n if (a[key] !== undefined && b[key] !== undefined) {\n blendValue[key] = getMixer(a[key])(a[key], b[key]);\n }\n }\n return (v) => {\n for (const key in blendValue) {\n output[key] = blendValue[key](v);\n }\n return output;\n };\n}\nfunction matchOrder(origin, target) {\n var _a;\n const orderedOrigin = [];\n const pointers = { color: 0, var: 0, number: 0 };\n for (let i = 0; i < target.values.length; i++) {\n const type = target.types[i];\n const originIndex = origin.indexes[type][pointers[type]];\n const originValue = (_a = origin.values[originIndex]) !== null && _a !== void 0 ? _a : 0;\n orderedOrigin[i] = originValue;\n pointers[type]++;\n }\n return orderedOrigin;\n}\nconst mixComplex = (origin, target) => {\n const template = complex.createTransformer(target);\n const originStats = analyseComplexValue(origin);\n const targetStats = analyseComplexValue(target);\n const canInterpolate = originStats.indexes.var.length === targetStats.indexes.var.length &&\n originStats.indexes.color.length === targetStats.indexes.color.length &&\n originStats.indexes.number.length >= targetStats.indexes.number.length;\n if (canInterpolate) {\n if ((invisibleValues.has(origin) &&\n !targetStats.values.length) ||\n (invisibleValues.has(target) &&\n !originStats.values.length)) {\n return mixVisibility(origin, target);\n }\n return pipe(mixArray(matchOrder(originStats, targetStats), targetStats.values), template);\n }\n else {\n warning(true, `Complex values '${origin}' and '${target}' too different to mix. Ensure all colors are of the same type, and that each contains the same quantity of number and color values. Falling back to instant transition.`);\n return mixImmediate(origin, target);\n }\n};\n\nexport { getMixer, mixArray, mixComplex, mixObject };\n","import { getMixer } from './complex.mjs';\nimport { mixNumber } from './number.mjs';\n\nfunction mix(from, to, p) {\n if (typeof from === \"number\" &&\n typeof to === \"number\" &&\n typeof p === \"number\") {\n return mixNumber(from, to, p);\n }\n const mixer = getMixer(from);\n return mixer(from, to);\n}\n\nexport { mix };\n","import { invariant } from './errors.mjs';\nimport { clamp } from './clamp.mjs';\nimport { pipe } from './pipe.mjs';\nimport { progress } from './progress.mjs';\nimport { noop } from './noop.mjs';\nimport { mix } from './mix/index.mjs';\n\nfunction createMixers(output, ease, customMixer) {\n const mixers = [];\n const mixerFactory = customMixer || mix;\n const numMixers = output.length - 1;\n for (let i = 0; i < numMixers; i++) {\n let mixer = mixerFactory(output[i], output[i + 1]);\n if (ease) {\n const easingFunction = Array.isArray(ease) ? ease[i] || noop : ease;\n mixer = pipe(easingFunction, mixer);\n }\n mixers.push(mixer);\n }\n return mixers;\n}\n/**\n * Create a function that maps from a numerical input array to a generic output array.\n *\n * Accepts:\n * - Numbers\n * - Colors (hex, hsl, hsla, rgb, rgba)\n * - Complex (combinations of one or more numbers or strings)\n *\n * ```jsx\n * const mixColor = interpolate([0, 1], ['#fff', '#000'])\n *\n * mixColor(0.5) // 'rgba(128, 128, 128, 1)'\n * ```\n *\n * TODO Revist this approach once we've moved to data models for values,\n * probably not needed to pregenerate mixer functions.\n *\n * @public\n */\nfunction interpolate(input, output, { clamp: isClamp = true, ease, mixer } = {}) {\n const inputLength = input.length;\n invariant(inputLength === output.length, \"Both input and output ranges must be the same length\");\n /**\n * If we're only provided a single input, we can just make a function\n * that returns the output.\n */\n if (inputLength === 1)\n return () => output[0];\n if (inputLength === 2 && input[0] === input[1])\n return () => output[1];\n // If input runs highest -> lowest, reverse both arrays\n if (input[0] > input[inputLength - 1]) {\n input = [...input].reverse();\n output = [...output].reverse();\n }\n const mixers = createMixers(output, ease, mixer);\n const numMixers = mixers.length;\n const interpolator = (v) => {\n let i = 0;\n if (numMixers > 1) {\n for (; i < input.length - 2; i++) {\n if (v < input[i + 1])\n break;\n }\n }\n const progressInRange = progress(input[i], input[i + 1], v);\n return mixers[i](progressInRange);\n };\n return isClamp\n ? (v) => interpolator(clamp(input[0], input[inputLength - 1], v))\n : interpolator;\n}\n\nexport { interpolate };\n","import { fillOffset } from './fill.mjs';\n\nfunction defaultOffset(arr) {\n const offset = [0];\n fillOffset(offset, arr.length - 1);\n return offset;\n}\n\nexport { defaultOffset };\n","import { mixNumber } from '../mix/number.mjs';\nimport { progress } from '../progress.mjs';\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(mixNumber(min, 1, offsetProgress));\n }\n}\n\nexport { fillOffset };\n","import { easeInOut } from '../../easing/ease.mjs';\nimport { isEasingArray } from '../../easing/utils/is-easing-array.mjs';\nimport { easingDefinitionToFunction } from '../../easing/utils/map.mjs';\nimport { interpolate } from '../../utils/interpolate.mjs';\nimport { defaultOffset } from '../../utils/offsets/default.mjs';\nimport { convertOffsetToTimes } from '../../utils/offsets/time.mjs';\n\nfunction defaultEasing(values, easing) {\n return values.map(() => easing || easeInOut).splice(0, values.length - 1);\n}\nfunction keyframes({ duration = 300, keyframes: keyframeValues, times, ease = \"easeInOut\", }) {\n /**\n * Easing functions can be externally defined as strings. Here we convert them\n * into actual functions.\n */\n const easingFunctions = isEasingArray(ease)\n ? ease.map(easingDefinitionToFunction)\n : easingDefinitionToFunction(ease);\n /**\n * This is the Iterator-spec return value. We ensure it's mutable rather than using a generator\n * to reduce GC during animation.\n */\n const state = {\n done: false,\n value: keyframeValues[0],\n };\n /**\n * Create a times array based on the provided 0-1 offsets\n */\n const absoluteTimes = convertOffsetToTimes(\n // Only use the provided offsets if they're the correct length\n // TODO Maybe we should warn here if there's a length mismatch\n times && times.length === keyframeValues.length\n ? times\n : defaultOffset(keyframeValues), duration);\n const mapTimeToKeyframe = interpolate(absoluteTimes, keyframeValues, {\n ease: Array.isArray(easingFunctions)\n ? easingFunctions\n : defaultEasing(keyframeValues, easingFunctions),\n });\n return {\n calculatedDuration: duration,\n next: (t) => {\n state.value = mapTimeToKeyframe(t);\n state.done = t >= duration;\n return state;\n },\n };\n}\n\nexport { defaultEasing, keyframes };\n","const isEasingArray = (ease) => {\n return Array.isArray(ease) && typeof ease[0] !== \"number\";\n};\n\nexport { isEasingArray };\n","function convertOffsetToTimes(offset, duration) {\n return offset.map((o) => o * duration);\n}\n\nexport { convertOffsetToTimes };\n","import { time } from '../../../frameloop/sync-time.mjs';\nimport { frame, cancelFrame, frameData } from '../../../frameloop/frame.mjs';\n\nconst frameloopDriver = (update) => {\n const passTimestamp = ({ timestamp }) => update(timestamp);\n return {\n start: () => frame.update(passTimestamp, true),\n stop: () => cancelFrame(passTimestamp),\n /**\n * If we're processing this frame we can use the\n * framelocked timestamp to keep things in sync.\n */\n now: () => (frameData.isProcessing ? frameData.timestamp : time.now()),\n };\n};\n\nexport { frameloopDriver };\n","import { KeyframeResolver } from '../../render/utils/KeyframesResolver.mjs';\nimport { spring } from '../generators/spring/index.mjs';\nimport { inertia } from '../generators/inertia.mjs';\nimport { keyframes } from '../generators/keyframes.mjs';\nimport { BaseAnimation } from './BaseAnimation.mjs';\nimport { pipe } from '../../utils/pipe.mjs';\nimport { mix } from '../../utils/mix/index.mjs';\nimport { calcGeneratorDuration } from '../generators/utils/calc-duration.mjs';\nimport { millisecondsToSeconds, secondsToMilliseconds } from '../../utils/time-conversion.mjs';\nimport { clamp } from '../../utils/clamp.mjs';\nimport { invariant } from '../../utils/errors.mjs';\nimport { frameloopDriver } from './drivers/driver-frameloop.mjs';\nimport { getFinalKeyframe } from './waapi/utils/get-final-keyframe.mjs';\n\nconst generators = {\n decay: inertia,\n inertia,\n tween: keyframes,\n keyframes: keyframes,\n spring,\n};\nconst percentToProgress = (percent) => percent / 100;\n/**\n * Animation that runs on the main thread. Designed to be WAAPI-spec in the subset of\n * features we expose publically. Mostly the compatibility is to ensure visual identity\n * between both WAAPI and main thread animations.\n */\nclass MainThreadAnimation extends BaseAnimation {\n constructor(options) {\n super(options);\n /**\n * The time at which the animation was paused.\n */\n this.holdTime = null;\n /**\n * The time at which the animation was cancelled.\n */\n this.cancelTime = null;\n /**\n * The current time of the animation.\n */\n this.currentTime = 0;\n /**\n * Playback speed as a factor. 0 would be stopped, -1 reverse and 2 double speed.\n */\n this.playbackSpeed = 1;\n /**\n * The state of the animation to apply when the animation is resolved. This\n * allows calls to the public API to control the animation before it is resolved,\n * without us having to resolve it first.\n */\n this.pendingPlayState = \"running\";\n /**\n * The time at which the animation was started.\n */\n this.startTime = null;\n this.state = \"idle\";\n /**\n * This method is bound to the instance to fix a pattern where\n * animation.stop is returned as a reference from a useEffect.\n */\n this.stop = () => {\n this.resolver.cancel();\n this.isStopped = true;\n if (this.state === \"idle\")\n return;\n this.teardown();\n const { onStop } = this.options;\n onStop && onStop();\n };\n const { name, motionValue, element, keyframes } = this.options;\n const KeyframeResolver$1 = (element === null || element === void 0 ? void 0 : element.KeyframeResolver) || KeyframeResolver;\n const onResolved = (resolvedKeyframes, finalKeyframe) => this.onKeyframesResolved(resolvedKeyframes, finalKeyframe);\n this.resolver = new KeyframeResolver$1(keyframes, onResolved, name, motionValue, element);\n this.resolver.scheduleResolve();\n }\n initPlayback(keyframes$1) {\n const { type = \"keyframes\", repeat = 0, repeatDelay = 0, repeatType, velocity = 0, } = this.options;\n const generatorFactory = generators[type] || keyframes;\n /**\n * If our generator doesn't support mixing numbers, we need to replace keyframes with\n * [0, 100] and then make a function that maps that to the actual keyframes.\n *\n * 100 is chosen instead of 1 as it works nicer with spring animations.\n */\n let mapPercentToKeyframes;\n let mirroredGenerator;\n if (generatorFactory !== keyframes &&\n typeof keyframes$1[0] !== \"number\") {\n if (process.env.NODE_ENV !== \"production\") {\n invariant(keyframes$1.length === 2, `Only two keyframes currently supported with spring and inertia animations. Trying to animate ${keyframes$1}`);\n }\n mapPercentToKeyframes = pipe(percentToProgress, mix(keyframes$1[0], keyframes$1[1]));\n keyframes$1 = [0, 100];\n }\n const generator = generatorFactory({ ...this.options, keyframes: keyframes$1 });\n /**\n * If we have a mirror repeat type we need to create a second generator that outputs the\n * mirrored (not reversed) animation and later ping pong between the two generators.\n */\n if (repeatType === \"mirror\") {\n mirroredGenerator = generatorFactory({\n ...this.options,\n keyframes: [...keyframes$1].reverse(),\n velocity: -velocity,\n });\n }\n /**\n * If duration is undefined and we have repeat options,\n * we need to calculate a duration from the generator.\n *\n * We set it to the generator itself to cache the duration.\n * Any timeline resolver will need to have already precalculated\n * the duration by this step.\n */\n if (generator.calculatedDuration === null) {\n generator.calculatedDuration = calcGeneratorDuration(generator);\n }\n const { calculatedDuration } = generator;\n const resolvedDuration = calculatedDuration + repeatDelay;\n const totalDuration = resolvedDuration * (repeat + 1) - repeatDelay;\n return {\n generator,\n mirroredGenerator,\n mapPercentToKeyframes,\n calculatedDuration,\n resolvedDuration,\n totalDuration,\n };\n }\n onPostResolved() {\n const { autoplay = true } = this.options;\n this.play();\n if (this.pendingPlayState === \"paused\" || !autoplay) {\n this.pause();\n }\n else {\n this.state = this.pendingPlayState;\n }\n }\n tick(timestamp, sample = false) {\n const { resolved } = this;\n // If the animations has failed to resolve, return the final keyframe.\n if (!resolved) {\n const { keyframes } = this.options;\n return { done: true, value: keyframes[keyframes.length - 1] };\n }\n const { finalKeyframe, generator, mirroredGenerator, mapPercentToKeyframes, keyframes, calculatedDuration, totalDuration, resolvedDuration, } = resolved;\n if (this.startTime === null)\n return generator.next(0);\n const { delay, repeat, repeatType, repeatDelay, onUpdate } = this.options;\n /**\n * requestAnimationFrame timestamps can come through as lower than\n * the startTime as set by performance.now(). Here we prevent this,\n * though in the future it could be possible to make setting startTime\n * a pending operation that gets resolved here.\n */\n if (this.speed > 0) {\n this.startTime = Math.min(this.startTime, timestamp);\n }\n else if (this.speed < 0) {\n this.startTime = Math.min(timestamp - totalDuration / this.speed, this.startTime);\n }\n // Update currentTime\n if (sample) {\n this.currentTime = timestamp;\n }\n else if (this.holdTime !== null) {\n this.currentTime = this.holdTime;\n }\n else {\n // Rounding the time because floating point arithmetic is not always accurate, e.g. 3000.367 - 1000.367 =\n // 2000.0000000000002. This is a problem when we are comparing the currentTime with the duration, for\n // example.\n this.currentTime =\n Math.round(timestamp - this.startTime) * this.speed;\n }\n // Rebase on delay\n const timeWithoutDelay = this.currentTime - delay * (this.speed >= 0 ? 1 : -1);\n const isInDelayPhase = this.speed >= 0\n ? timeWithoutDelay < 0\n : timeWithoutDelay > totalDuration;\n this.currentTime = Math.max(timeWithoutDelay, 0);\n // If this animation has finished, set the current time to the total duration.\n if (this.state === \"finished\" && this.holdTime === null) {\n this.currentTime = totalDuration;\n }\n let elapsed = this.currentTime;\n let frameGenerator = generator;\n if (repeat) {\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 = Math.min(this.currentTime, totalDuration) / resolvedDuration;\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 /**\n * If iteration progress is 1 we count that as the end\n * of the previous iteration.\n */\n if (!iterationProgress && progress >= 1) {\n iterationProgress = 1;\n }\n iterationProgress === 1 && currentIteration--;\n currentIteration = Math.min(currentIteration, repeat + 1);\n /**\n * Reverse progress if we're not running in \"normal\" direction\n */\n const isOddIteration = Boolean(currentIteration % 2);\n if (isOddIteration) {\n if (repeatType === \"reverse\") {\n iterationProgress = 1 - iterationProgress;\n if (repeatDelay) {\n iterationProgress -= repeatDelay / resolvedDuration;\n }\n }\n else if (repeatType === \"mirror\") {\n frameGenerator = mirroredGenerator;\n }\n }\n elapsed = clamp(0, 1, iterationProgress) * resolvedDuration;\n }\n /**\n * If we're in negative time, set state as the initial keyframe.\n * This prevents delay: x, duration: 0 animations from finishing\n * instantly.\n */\n const state = isInDelayPhase\n ? { done: false, value: keyframes[0] }\n : frameGenerator.next(elapsed);\n if (mapPercentToKeyframes) {\n state.value = mapPercentToKeyframes(state.value);\n }\n let { done } = state;\n if (!isInDelayPhase && calculatedDuration !== null) {\n done =\n this.speed >= 0\n ? this.currentTime >= totalDuration\n : this.currentTime <= 0;\n }\n const isAnimationFinished = this.holdTime === null &&\n (this.state === \"finished\" || (this.state === \"running\" && done));\n if (isAnimationFinished && finalKeyframe !== undefined) {\n state.value = getFinalKeyframe(keyframes, this.options, finalKeyframe);\n }\n if (onUpdate) {\n onUpdate(state.value);\n }\n if (isAnimationFinished) {\n this.finish();\n }\n return state;\n }\n get duration() {\n const { resolved } = this;\n return resolved ? millisecondsToSeconds(resolved.calculatedDuration) : 0;\n }\n get time() {\n return millisecondsToSeconds(this.currentTime);\n }\n set time(newTime) {\n newTime = secondsToMilliseconds(newTime);\n this.currentTime = newTime;\n if (this.holdTime !== null || this.speed === 0) {\n this.holdTime = newTime;\n }\n else if (this.driver) {\n this.startTime = this.driver.now() - newTime / this.speed;\n }\n }\n get speed() {\n return this.playbackSpeed;\n }\n set speed(newSpeed) {\n const hasChanged = this.playbackSpeed !== newSpeed;\n this.playbackSpeed = newSpeed;\n if (hasChanged) {\n this.time = millisecondsToSeconds(this.currentTime);\n }\n }\n play() {\n if (!this.resolver.isScheduled) {\n this.resolver.resume();\n }\n if (!this._resolved) {\n this.pendingPlayState = \"running\";\n return;\n }\n if (this.isStopped)\n return;\n const { driver = frameloopDriver, onPlay, startTime } = this.options;\n if (!this.driver) {\n this.driver = driver((timestamp) => this.tick(timestamp));\n }\n onPlay && onPlay();\n const now = this.driver.now();\n if (this.holdTime !== null) {\n this.startTime = now - this.holdTime;\n }\n else if (!this.startTime) {\n this.startTime = startTime !== null && startTime !== void 0 ? startTime : this.calcStartTime();\n }\n else if (this.state === \"finished\") {\n this.startTime = now;\n }\n if (this.state === \"finished\") {\n this.updateFinishedPromise();\n }\n this.cancelTime = this.startTime;\n this.holdTime = null;\n /**\n * Set playState to running only after we've used it in\n * the previous logic.\n */\n this.state = \"running\";\n this.driver.start();\n }\n pause() {\n var _a;\n if (!this._resolved) {\n this.pendingPlayState = \"paused\";\n return;\n }\n this.state = \"paused\";\n this.holdTime = (_a = this.currentTime) !== null && _a !== void 0 ? _a : 0;\n }\n complete() {\n if (this.state !== \"running\") {\n this.play();\n }\n this.pendingPlayState = this.state = \"finished\";\n this.holdTime = null;\n }\n finish() {\n this.teardown();\n this.state = \"finished\";\n const { onComplete } = this.options;\n onComplete && onComplete();\n }\n cancel() {\n if (this.cancelTime !== null) {\n this.tick(this.cancelTime);\n }\n this.teardown();\n this.updateFinishedPromise();\n }\n teardown() {\n this.state = \"idle\";\n this.stopDriver();\n this.resolveFinishedPromise();\n this.updateFinishedPromise();\n this.startTime = this.cancelTime = null;\n this.resolver.cancel();\n }\n stopDriver() {\n if (!this.driver)\n return;\n this.driver.stop();\n this.driver = undefined;\n }\n sample(time) {\n this.startTime = 0;\n return this.tick(time, true);\n }\n}\n// Legacy interface\nfunction animateValue(options) {\n return new MainThreadAnimation(options);\n}\n\nexport { MainThreadAnimation, animateValue };\n","/**\n * Implement a practical max duration for keyframe generation\n * to prevent infinite loops\n */\nconst maxGeneratorDuration = 20000;\nfunction calcGeneratorDuration(generator) {\n let duration = 0;\n const timeStep = 50;\n let state = generator.next(duration);\n while (!state.done && duration < maxGeneratorDuration) {\n duration += timeStep;\n state = generator.next(duration);\n }\n return duration >= maxGeneratorDuration ? Infinity : duration;\n}\n\nexport { calcGeneratorDuration, maxGeneratorDuration };\n","const isBezierDefinition = (easing) => Array.isArray(easing) && typeof easing[0] === \"number\";\n\nexport { isBezierDefinition };\n","import { isBezierDefinition } from '../../../easing/utils/is-bezier-definition.mjs';\n\nfunction isWaapiSupportedEasing(easing) {\n return Boolean(!easing ||\n (typeof easing === \"string\" && easing in supportedWaapiEasing) ||\n isBezierDefinition(easing) ||\n (Array.isArray(easing) && easing.every(isWaapiSupportedEasing)));\n}\nconst cubicBezierAsString = ([a, b, c, d]) => `cubic-bezier(${a}, ${b}, ${c}, ${d})`;\nconst supportedWaapiEasing = {\n linear: \"linear\",\n ease: \"ease\",\n easeIn: \"ease-in\",\n easeOut: \"ease-out\",\n easeInOut: \"ease-in-out\",\n circIn: cubicBezierAsString([0, 0.65, 0.55, 1]),\n circOut: cubicBezierAsString([0.55, 0, 1, 0.45]),\n backIn: cubicBezierAsString([0.31, 0.01, 0.66, -0.59]),\n backOut: cubicBezierAsString([0.33, 1.53, 0.69, 0.99]),\n};\nfunction mapEasingToNativeEasingWithDefault(easing) {\n return (mapEasingToNativeEasing(easing) ||\n supportedWaapiEasing.easeOut);\n}\nfunction mapEasingToNativeEasing(easing) {\n if (!easing) {\n return undefined;\n }\n else if (isBezierDefinition(easing)) {\n return cubicBezierAsString(easing);\n }\n else if (Array.isArray(easing)) {\n return easing.map(mapEasingToNativeEasingWithDefault);\n }\n else {\n return supportedWaapiEasing[easing];\n }\n}\n\nexport { cubicBezierAsString, isWaapiSupportedEasing, mapEasingToNativeEasing, supportedWaapiEasing };\n","import { DOMKeyframesResolver } from '../../render/dom/DOMKeyframesResolver.mjs';\nimport { memo } from '../../utils/memo.mjs';\nimport { noop } from '../../utils/noop.mjs';\nimport { millisecondsToSeconds, secondsToMilliseconds } from '../../utils/time-conversion.mjs';\nimport { BaseAnimation } from './BaseAnimation.mjs';\nimport { MainThreadAnimation } from './MainThreadAnimation.mjs';\nimport { acceleratedValues } from './utils/accelerated-values.mjs';\nimport { animateStyle } from './waapi/index.mjs';\nimport { isWaapiSupportedEasing } from './waapi/easing.mjs';\nimport { getFinalKeyframe } from './waapi/utils/get-final-keyframe.mjs';\n\nconst supportsWaapi = memo(() => Object.hasOwnProperty.call(Element.prototype, \"animate\"));\n/**\n * 10ms is chosen here as it strikes a balance between smooth\n * results (more than one keyframe per frame at 60fps) and\n * keyframe quantity.\n */\nconst sampleDelta = 10; //ms\n/**\n * Implement a practical max duration for keyframe generation\n * to prevent infinite loops\n */\nconst maxDuration = 20000;\n/**\n * Check if an animation can run natively via WAAPI or requires pregenerated keyframes.\n * WAAPI doesn't support spring or function easings so we run these as JS animation before\n * handing off.\n */\nfunction requiresPregeneratedKeyframes(options) {\n return options.type === \"spring\" || !isWaapiSupportedEasing(options.ease);\n}\nfunction pregenerateKeyframes(keyframes, options) {\n /**\n * Create a main-thread animation to pregenerate keyframes.\n * We sample this at regular intervals to generate keyframes that we then\n * linearly interpolate between.\n */\n const sampleAnimation = new MainThreadAnimation({\n ...options,\n keyframes,\n repeat: 0,\n delay: 0,\n isGenerator: true,\n });\n let state = { done: false, value: keyframes[0] };\n const pregeneratedKeyframes = [];\n /**\n * Bail after 20 seconds of pre-generated keyframes as it's likely\n * we're heading for an infinite loop.\n */\n let t = 0;\n while (!state.done && t < maxDuration) {\n state = sampleAnimation.sample(t);\n pregeneratedKeyframes.push(state.value);\n t += sampleDelta;\n }\n return {\n times: undefined,\n keyframes: pregeneratedKeyframes,\n duration: t - sampleDelta,\n ease: \"linear\",\n };\n}\nclass AcceleratedAnimation extends BaseAnimation {\n constructor(options) {\n super(options);\n const { name, motionValue, element, keyframes } = this.options;\n this.resolver = new DOMKeyframesResolver(keyframes, (resolvedKeyframes, finalKeyframe) => this.onKeyframesResolved(resolvedKeyframes, finalKeyframe), name, motionValue, element);\n this.resolver.scheduleResolve();\n }\n initPlayback(keyframes, finalKeyframe) {\n var _a;\n let { duration = 300, times, ease, type, motionValue, name, startTime, } = this.options;\n /**\n * If element has since been unmounted, return false to indicate\n * the animation failed to initialised.\n */\n if (!((_a = motionValue.owner) === null || _a === void 0 ? void 0 : _a.current)) {\n return false;\n }\n /**\n * If this animation needs pre-generated keyframes then generate.\n */\n if (requiresPregeneratedKeyframes(this.options)) {\n const { onComplete, onUpdate, motionValue, element, ...options } = this.options;\n const pregeneratedAnimation = pregenerateKeyframes(keyframes, options);\n keyframes = pregeneratedAnimation.keyframes;\n // If this is a very short animation, ensure we have\n // at least two keyframes to animate between as older browsers\n // can't animate between a single keyframe.\n if (keyframes.length === 1) {\n keyframes[1] = keyframes[0];\n }\n duration = pregeneratedAnimation.duration;\n times = pregeneratedAnimation.times;\n ease = pregeneratedAnimation.ease;\n type = \"keyframes\";\n }\n const animation = animateStyle(motionValue.owner.current, name, keyframes, { ...this.options, duration, times, ease });\n // Override the browser calculated startTime with one synchronised to other JS\n // and WAAPI animations starting this event loop.\n animation.startTime = startTime !== null && startTime !== void 0 ? startTime : this.calcStartTime();\n if (this.pendingTimeline) {\n animation.timeline = this.pendingTimeline;\n this.pendingTimeline = undefined;\n }\n else {\n /**\n * Prefer the `onfinish` prop as it's more widely supported than\n * the `finished` promise.\n *\n * Here, we synchronously set the provided MotionValue to the end\n * keyframe. If we didn't, when the WAAPI animation is finished it would\n * be removed from the element which would then revert to its old styles.\n */\n animation.onfinish = () => {\n const { onComplete } = this.options;\n motionValue.set(getFinalKeyframe(keyframes, this.options, finalKeyframe));\n onComplete && onComplete();\n this.cancel();\n this.resolveFinishedPromise();\n };\n }\n return {\n animation,\n duration,\n times,\n type,\n ease,\n keyframes: keyframes,\n };\n }\n get duration() {\n const { resolved } = this;\n if (!resolved)\n return 0;\n const { duration } = resolved;\n return millisecondsToSeconds(duration);\n }\n get time() {\n const { resolved } = this;\n if (!resolved)\n return 0;\n const { animation } = resolved;\n return millisecondsToSeconds(animation.currentTime || 0);\n }\n set time(newTime) {\n const { resolved } = this;\n if (!resolved)\n return;\n const { animation } = resolved;\n animation.currentTime = secondsToMilliseconds(newTime);\n }\n get speed() {\n const { resolved } = this;\n if (!resolved)\n return 1;\n const { animation } = resolved;\n return animation.playbackRate;\n }\n set speed(newSpeed) {\n const { resolved } = this;\n if (!resolved)\n return;\n const { animation } = resolved;\n animation.playbackRate = newSpeed;\n }\n get state() {\n const { resolved } = this;\n if (!resolved)\n return \"idle\";\n const { animation } = resolved;\n return animation.playState;\n }\n get startTime() {\n const { resolved } = this;\n if (!resolved)\n return null;\n const { animation } = resolved;\n // Coerce to number as TypeScript incorrectly types this\n // as CSSNumberish\n return animation.startTime;\n }\n /**\n * Replace the default DocumentTimeline with another AnimationTimeline.\n * Currently used for scroll animations.\n */\n attachTimeline(timeline) {\n if (!this._resolved) {\n this.pendingTimeline = timeline;\n }\n else {\n const { resolved } = this;\n if (!resolved)\n return noop;\n const { animation } = resolved;\n animation.timeline = timeline;\n animation.onfinish = null;\n }\n return noop;\n }\n play() {\n if (this.isStopped)\n return;\n const { resolved } = this;\n if (!resolved)\n return;\n const { animation } = resolved;\n if (animation.playState === \"finished\") {\n this.updateFinishedPromise();\n }\n animation.play();\n }\n pause() {\n const { resolved } = this;\n if (!resolved)\n return;\n const { animation } = resolved;\n animation.pause();\n }\n stop() {\n this.resolver.cancel();\n this.isStopped = true;\n if (this.state === \"idle\")\n return;\n this.resolveFinishedPromise();\n this.updateFinishedPromise();\n const { resolved } = this;\n if (!resolved)\n return;\n const { animation, keyframes, duration, type, ease, times } = resolved;\n if (animation.playState === \"idle\" ||\n animation.playState === \"finished\") {\n return;\n }\n /**\n * WAAPI doesn't natively have any interruption capabilities.\n *\n * Rather than read commited styles back out of the DOM, we can\n * create a renderless JS animation and sample it twice to calculate\n * its current value, \"previous\" value, and therefore allow\n * Motion to calculate velocity for any subsequent animation.\n */\n if (this.time) {\n const { motionValue, onUpdate, onComplete, element, ...options } = this.options;\n const sampleAnimation = new MainThreadAnimation({\n ...options,\n keyframes,\n duration,\n type,\n ease,\n times,\n isGenerator: true,\n });\n const sampleTime = secondsToMilliseconds(this.time);\n motionValue.setWithVelocity(sampleAnimation.sample(sampleTime - sampleDelta).value, sampleAnimation.sample(sampleTime).value, sampleDelta);\n }\n const { onStop } = this.options;\n onStop && onStop();\n this.cancel();\n }\n complete() {\n const { resolved } = this;\n if (!resolved)\n return;\n resolved.animation.finish();\n }\n cancel() {\n const { resolved } = this;\n if (!resolved)\n return;\n resolved.animation.cancel();\n }\n static supports(options) {\n const { motionValue, name, repeatDelay, repeatType, damping, type } = options;\n return (supportsWaapi() &&\n name &&\n acceleratedValues.has(name) &&\n motionValue &&\n motionValue.owner &&\n motionValue.owner.current instanceof HTMLElement &&\n /**\n * If we're outputting values to onUpdate then we can't use WAAPI as there's\n * no way to read the value from WAAPI every frame.\n */\n !motionValue.owner.getProps().onUpdate &&\n !repeatDelay &&\n repeatType !== \"mirror\" &&\n damping !== 0 &&\n type !== \"inertia\");\n }\n}\n\nexport { AcceleratedAnimation };\n","import { mapEasingToNativeEasing } from './easing.mjs';\n\nfunction animateStyle(element, valueName, keyframes, { delay = 0, duration = 300, repeat = 0, repeatType = \"loop\", ease, times, } = {}) {\n const keyframeOptions = { [valueName]: keyframes };\n if (times)\n keyframeOptions.offset = times;\n const easing = mapEasingToNativeEasing(ease);\n /**\n * If this is an easing array, apply to keyframes, not animation as a whole\n */\n if (Array.isArray(easing))\n keyframeOptions.easing = easing;\n return element.animate(keyframeOptions, {\n delay,\n duration,\n easing: !Array.isArray(easing) ? easing : \"linear\",\n fill: \"both\",\n iterations: repeat + 1,\n direction: repeatType === \"reverse\" ? \"alternate\" : \"normal\",\n });\n}\n\nexport { animateStyle };\n","import { memo } from '../../../utils/memo.mjs';\n\nconst supportsScrollTimeline = memo(() => window.ScrollTimeline !== undefined);\n\nexport { supportsScrollTimeline };\n","import { observeTimeline } from '../render/dom/scroll/observe.mjs';\nimport { supportsScrollTimeline } from '../render/dom/scroll/supports.mjs';\n\nclass GroupPlaybackControls {\n constructor(animations) {\n // Bound to accomodate common `return animation.stop` pattern\n this.stop = () => this.runAll(\"stop\");\n this.animations = animations.filter(Boolean);\n }\n then(onResolve, onReject) {\n return Promise.all(this.animations).then(onResolve).catch(onReject);\n }\n /**\n * TODO: Filter out cancelled or stopped animations before returning\n */\n getAll(propName) {\n return this.animations[0][propName];\n }\n setAll(propName, newValue) {\n for (let i = 0; i < this.animations.length; i++) {\n this.animations[i][propName] = newValue;\n }\n }\n attachTimeline(timeline) {\n const cancelAll = this.animations.map((animation) => {\n if (supportsScrollTimeline() && animation.attachTimeline) {\n animation.attachTimeline(timeline);\n }\n else {\n animation.pause();\n return observeTimeline((progress) => {\n animation.time = animation.duration * progress;\n }, timeline);\n }\n });\n return () => {\n cancelAll.forEach((cancelTimeline, i) => {\n if (cancelTimeline)\n cancelTimeline();\n this.animations[i].stop();\n });\n };\n }\n get time() {\n return this.getAll(\"time\");\n }\n set time(time) {\n this.setAll(\"time\", time);\n }\n get speed() {\n return this.getAll(\"speed\");\n }\n set speed(speed) {\n this.setAll(\"speed\", speed);\n }\n get startTime() {\n return this.getAll(\"startTime\");\n }\n get duration() {\n let max = 0;\n for (let i = 0; i < this.animations.length; i++) {\n max = Math.max(max, this.animations[i].duration);\n }\n return max;\n }\n runAll(methodName) {\n this.animations.forEach((controls) => controls[methodName]());\n }\n play() {\n this.runAll(\"play\");\n }\n pause() {\n this.runAll(\"pause\");\n }\n cancel() {\n this.runAll(\"cancel\");\n }\n complete() {\n this.runAll(\"complete\");\n }\n}\n\nexport { GroupPlaybackControls };\n","import { frame, cancelFrame } from '../../../frameloop/frame.mjs';\n\nfunction observeTimeline(update, timeline) {\n let prevProgress;\n const onFrame = () => {\n const { currentTime } = timeline;\n const percentage = currentTime === null ? 0 : currentTime.value;\n const progress = percentage / 100;\n if (prevProgress !== progress) {\n update(progress);\n }\n prevProgress = progress;\n };\n frame.update(onFrame, true);\n return () => cancelFrame(onFrame);\n}\n\nexport { observeTimeline };\n","import { secondsToMilliseconds } from '../../utils/time-conversion.mjs';\nimport { getDefaultTransition } from '../utils/default-transitions.mjs';\nimport { getValueTransition, isTransitionDefined } from '../utils/transitions.mjs';\nimport { MotionGlobalConfig } from '../../utils/GlobalConfig.mjs';\nimport { instantAnimationState } from '../../utils/use-instant-transition-state.mjs';\nimport { getFinalKeyframe } from '../animators/waapi/utils/get-final-keyframe.mjs';\nimport { frame } from '../../frameloop/frame.mjs';\nimport { AcceleratedAnimation } from '../animators/AcceleratedAnimation.mjs';\nimport { MainThreadAnimation } from '../animators/MainThreadAnimation.mjs';\nimport { GroupPlaybackControls } from '../GroupPlaybackControls.mjs';\n\nconst animateMotionValue = (name, value, target, transition = {}, element, isHandoff, \n/**\n * Currently used to remove values from will-change when an animation ends.\n * Preferably this would be handled by event listeners on the MotionValue\n * but these aren't consistent enough yet when considering the different ways\n * an animation can be cancelled.\n */\nonEnd) => (onComplete) => {\n const valueTransition = getValueTransition(transition, name) || {};\n /**\n * Most transition values are currently completely overwritten by value-specific\n * transitions. In the future it'd be nicer to blend these transitions. But for now\n * delay actually does inherit from the root transition if not value-specific.\n */\n const delay = valueTransition.delay || transition.delay || 0;\n /**\n * Elapsed isn't a public transition option but can be passed through from\n * optimized appear effects in milliseconds.\n */\n let { elapsed = 0 } = transition;\n elapsed = elapsed - secondsToMilliseconds(delay);\n let options = {\n keyframes: Array.isArray(target) ? target : [null, target],\n ease: \"easeOut\",\n velocity: value.getVelocity(),\n ...valueTransition,\n delay: -elapsed,\n onUpdate: (v) => {\n value.set(v);\n valueTransition.onUpdate && valueTransition.onUpdate(v);\n },\n onComplete: () => {\n onComplete();\n valueTransition.onComplete && valueTransition.onComplete();\n onEnd && onEnd();\n },\n onStop: onEnd,\n name,\n motionValue: value,\n element: isHandoff ? undefined : element,\n };\n /**\n * If there's no transition defined for this value, we can generate\n * unqiue transition settings for this value.\n */\n if (!isTransitionDefined(valueTransition)) {\n options = {\n ...options,\n ...getDefaultTransition(name, options),\n };\n }\n /**\n * Both WAAPI and our internal animation functions use durations\n * as defined by milliseconds, while our external API defines them\n * as seconds.\n */\n if (options.duration) {\n options.duration = secondsToMilliseconds(options.duration);\n }\n if (options.repeatDelay) {\n options.repeatDelay = secondsToMilliseconds(options.repeatDelay);\n }\n if (options.from !== undefined) {\n options.keyframes[0] = options.from;\n }\n let shouldSkip = false;\n if (options.type === false ||\n (options.duration === 0 && !options.repeatDelay)) {\n options.duration = 0;\n if (options.delay === 0) {\n shouldSkip = true;\n }\n }\n if (instantAnimationState.current ||\n MotionGlobalConfig.skipAnimations) {\n shouldSkip = true;\n options.duration = 0;\n options.delay = 0;\n }\n /**\n * If we can or must skip creating the animation, and apply only\n * the final keyframe, do so. We also check once keyframes are resolved but\n * this early check prevents the need to create an animation at all.\n */\n if (shouldSkip && !isHandoff && value.get() !== undefined) {\n const finalKeyframe = getFinalKeyframe(options.keyframes, valueTransition);\n if (finalKeyframe !== undefined) {\n frame.update(() => {\n options.onUpdate(finalKeyframe);\n options.onComplete();\n });\n // We still want to return some animation controls here rather\n // than returning undefined\n return new GroupPlaybackControls([]);\n }\n }\n /**\n * Animate via WAAPI if possible. If this is a handoff animation, the optimised animation will be running via\n * WAAPI. Therefore, this animation must be JS to ensure it runs \"under\" the\n * optimised animation.\n */\n if (!isHandoff && AcceleratedAnimation.supports(options)) {\n return new AcceleratedAnimation(options);\n }\n else {\n return new MainThreadAnimation(options);\n }\n};\n\nexport { animateMotionValue };\n","import { addUniqueItem, removeItem } from './array.mjs';\n\nclass SubscriptionManager {\n constructor() {\n this.subscriptions = [];\n }\n add(handler) {\n addUniqueItem(this.subscriptions, handler);\n return () => removeItem(this.subscriptions, handler);\n }\n notify(a, b, c) {\n const numSubscriptions = this.subscriptions.length;\n if (!numSubscriptions)\n return;\n if (numSubscriptions === 1) {\n /**\n * If there's only a single handler we can just call it without invoking a loop.\n */\n this.subscriptions[0](a, b, c);\n }\n else {\n for (let i = 0; i < numSubscriptions; i++) {\n /**\n * Check whether the handler exists before firing as it's possible\n * the subscriptions were modified during this loop running.\n */\n const handler = this.subscriptions[i];\n handler && handler(a, b, c);\n }\n }\n }\n getSize() {\n return this.subscriptions.length;\n }\n clear() {\n this.subscriptions.length = 0;\n }\n}\n\nexport { SubscriptionManager };\n","import { SubscriptionManager } from '../utils/subscription-manager.mjs';\nimport { velocityPerSecond } from '../utils/velocity-per-second.mjs';\nimport { warnOnce } from '../utils/warn-once.mjs';\nimport { time } from '../frameloop/sync-time.mjs';\nimport { frame } from '../frameloop/frame.mjs';\n\n/**\n * Maximum time between the value of two frames, beyond which we\n * assume the velocity has since been 0.\n */\nconst MAX_VELOCITY_DELTA = 30;\nconst isFloat = (value) => {\n return !isNaN(parseFloat(value));\n};\nconst collectMotionValues = {\n current: undefined,\n};\n/**\n * `MotionValue` is used to track the state and velocity of motion values.\n *\n * @public\n */\nclass MotionValue {\n /**\n * @param init - The initiating value\n * @param config - Optional configuration options\n *\n * - `transformer`: A function to transform incoming values with.\n *\n * @internal\n */\n constructor(init, options = {}) {\n /**\n * This will be replaced by the build step with the latest version number.\n * When MotionValues are provided to motion components, warn if versions are mixed.\n */\n this.version = \"11.3.29\";\n /**\n * Tracks whether this value can output a velocity. Currently this is only true\n * if the value is numerical, but we might be able to widen the scope here and support\n * other value types.\n *\n * @internal\n */\n this.canTrackVelocity = null;\n /**\n * An object containing a SubscriptionManager for each active event.\n */\n this.events = {};\n this.updateAndNotify = (v, render = true) => {\n const currentTime = time.now();\n /**\n * If we're updating the value during another frame or eventloop\n * than the previous frame, then the we set the previous frame value\n * to current.\n */\n if (this.updatedAt !== currentTime) {\n this.setPrevFrameValue();\n }\n this.prev = this.current;\n this.setCurrent(v);\n // Update update subscribers\n if (this.current !== this.prev && this.events.change) {\n this.events.change.notify(this.current);\n }\n // Update render subscribers\n if (render && this.events.renderRequest) {\n this.events.renderRequest.notify(this.current);\n }\n };\n this.hasAnimated = false;\n this.setCurrent(init);\n this.owner = options.owner;\n }\n setCurrent(current) {\n this.current = current;\n this.updatedAt = time.now();\n if (this.canTrackVelocity === null && current !== undefined) {\n this.canTrackVelocity = isFloat(this.current);\n }\n }\n setPrevFrameValue(prevFrameValue = this.current) {\n this.prevFrameValue = prevFrameValue;\n this.prevUpdatedAt = this.updatedAt;\n }\n /**\n * Adds a function that will be notified when the `MotionValue` is updated.\n *\n * It returns a function that, when called, will cancel the subscription.\n *\n * When calling `onChange` inside a React component, it should be wrapped with the\n * `useEffect` hook. As it returns an unsubscribe function, this should be returned\n * from the `useEffect` function to ensure you don't add duplicate subscribers..\n *\n * ```jsx\n * export const MyComponent = () => {\n * const x = useMotionValue(0)\n * const y = useMotionValue(0)\n * const opacity = useMotionValue(1)\n *\n * useEffect(() => {\n * function updateOpacity() {\n * const maxXY = Math.max(x.get(), y.get())\n * const newOpacity = transform(maxXY, [0, 100], [1, 0])\n * opacity.set(newOpacity)\n * }\n *\n * const unsubscribeX = x.on(\"change\", updateOpacity)\n * const unsubscribeY = y.on(\"change\", updateOpacity)\n *\n * return () => {\n * unsubscribeX()\n * unsubscribeY()\n * }\n * }, [])\n *\n * return \n * }\n * ```\n *\n * @param subscriber - A function that receives the latest value.\n * @returns A function that, when called, will cancel this subscription.\n *\n * @deprecated\n */\n onChange(subscription) {\n if (process.env.NODE_ENV !== \"production\") {\n warnOnce(false, `value.onChange(callback) is deprecated. Switch to value.on(\"change\", callback).`);\n }\n return this.on(\"change\", subscription);\n }\n on(eventName, callback) {\n if (!this.events[eventName]) {\n this.events[eventName] = new SubscriptionManager();\n }\n const unsubscribe = this.events[eventName].add(callback);\n if (eventName === \"change\") {\n return () => {\n unsubscribe();\n /**\n * If we have no more change listeners by the start\n * of the next frame, stop active animations.\n */\n frame.read(() => {\n if (!this.events.change.getSize()) {\n this.stop();\n }\n });\n };\n }\n return unsubscribe;\n }\n clearListeners() {\n for (const eventManagers in this.events) {\n this.events[eventManagers].clear();\n }\n }\n /**\n * Attaches a passive effect to the `MotionValue`.\n *\n * @internal\n */\n attach(passiveEffect, stopPassiveEffect) {\n this.passiveEffect = passiveEffect;\n this.stopPassiveEffect = stopPassiveEffect;\n }\n /**\n * Sets the state of the `MotionValue`.\n *\n * @remarks\n *\n * ```jsx\n * const x = useMotionValue(0)\n * x.set(10)\n * ```\n *\n * @param latest - Latest value to set.\n * @param render - Whether to notify render subscribers. Defaults to `true`\n *\n * @public\n */\n set(v, render = true) {\n if (!render || !this.passiveEffect) {\n this.updateAndNotify(v, render);\n }\n else {\n this.passiveEffect(v, this.updateAndNotify);\n }\n }\n setWithVelocity(prev, current, delta) {\n this.set(current);\n this.prev = undefined;\n this.prevFrameValue = prev;\n this.prevUpdatedAt = this.updatedAt - delta;\n }\n /**\n * Set the state of the `MotionValue`, stopping any active animations,\n * effects, and resets velocity to `0`.\n */\n jump(v, endAnimation = true) {\n this.updateAndNotify(v);\n this.prev = v;\n this.prevUpdatedAt = this.prevFrameValue = undefined;\n endAnimation && this.stop();\n if (this.stopPassiveEffect)\n this.stopPassiveEffect();\n }\n /**\n * Returns the latest state of `MotionValue`\n *\n * @returns - The latest state of `MotionValue`\n *\n * @public\n */\n get() {\n if (collectMotionValues.current) {\n collectMotionValues.current.push(this);\n }\n return this.current;\n }\n /**\n * @public\n */\n getPrevious() {\n return this.prev;\n }\n /**\n * Returns the latest velocity of `MotionValue`\n *\n * @returns - The latest velocity of `MotionValue`. Returns `0` if the state is non-numerical.\n *\n * @public\n */\n getVelocity() {\n const currentTime = time.now();\n if (!this.canTrackVelocity ||\n this.prevFrameValue === undefined ||\n currentTime - this.updatedAt > MAX_VELOCITY_DELTA) {\n return 0;\n }\n const delta = Math.min(this.updatedAt - this.prevUpdatedAt, MAX_VELOCITY_DELTA);\n // Casts because of parseFloat's poor typing\n return velocityPerSecond(parseFloat(this.current) -\n parseFloat(this.prevFrameValue), delta);\n }\n /**\n * Registers a new animation to control this `MotionValue`. Only one\n * animation can drive a `MotionValue` at one time.\n *\n * ```jsx\n * value.start()\n * ```\n *\n * @param animation - A function that starts the provided animation\n *\n * @internal\n */\n start(startAnimation) {\n this.stop();\n return new Promise((resolve) => {\n this.hasAnimated = true;\n this.animation = startAnimation(resolve);\n if (this.events.animationStart) {\n this.events.animationStart.notify();\n }\n }).then(() => {\n if (this.events.animationComplete) {\n this.events.animationComplete.notify();\n }\n this.clearAnimation();\n });\n }\n /**\n * Stop the currently active animation.\n *\n * @public\n */\n stop() {\n if (this.animation) {\n this.animation.stop();\n if (this.events.animationCancel) {\n this.events.animationCancel.notify();\n }\n }\n this.clearAnimation();\n }\n /**\n * Returns `true` if this value is currently animating.\n *\n * @public\n */\n isAnimating() {\n return !!this.animation;\n }\n clearAnimation() {\n delete this.animation;\n }\n /**\n * Destroy and clean up subscribers to this `MotionValue`.\n *\n * The `MotionValue` hooks like `useMotionValue` and `useTransform` automatically\n * handle the lifecycle of the returned `MotionValue`, so this method is only necessary if you've manually\n * created a `MotionValue` via the `motionValue` function.\n *\n * @public\n */\n destroy() {\n this.clearListeners();\n this.stop();\n if (this.stopPassiveEffect) {\n this.stopPassiveEffect();\n }\n }\n}\nfunction motionValue(init, options) {\n return new MotionValue(init, options);\n}\n\nexport { MotionValue, collectMotionValues, motionValue };\n","import { resolveFinalValueInKeyframes } from '../../utils/resolve-value.mjs';\nimport { motionValue } from '../../value/index.mjs';\nimport { resolveVariant } from './resolve-dynamic-variants.mjs';\n\n/**\n * Set VisualElement's MotionValue, creating a new MotionValue for it if\n * it doesn't exist.\n */\nfunction setMotionValue(visualElement, key, value) {\n if (visualElement.hasValue(key)) {\n visualElement.getValue(key).set(value);\n }\n else {\n visualElement.addValue(key, motionValue(value));\n }\n}\nfunction setTarget(visualElement, definition) {\n const resolved = resolveVariant(visualElement, definition);\n let { transitionEnd = {}, transition = {}, ...target } = resolved || {};\n target = { ...target, ...transitionEnd };\n for (const key in target) {\n const value = resolveFinalValueInKeyframes(target[key]);\n setMotionValue(visualElement, key, value);\n }\n}\n\nexport { setTarget };\n","import { optimizedAppearDataAttribute } from './data-id.mjs';\n\nfunction getOptimisedAppearId(visualElement) {\n return visualElement.getProps()[optimizedAppearDataAttribute];\n}\n\nexport { getOptimisedAppearId };\n","import { MotionValue } from '../index.mjs';\nimport { getWillChangeName } from './get-will-change-name.mjs';\nimport { removeItem } from '../../utils/array.mjs';\n\nclass WillChangeMotionValue extends MotionValue {\n constructor() {\n super(...arguments);\n this.output = [];\n this.counts = new Map();\n }\n add(name) {\n const styleName = getWillChangeName(name);\n if (!styleName)\n return;\n /**\n * Update counter. Each value has an indepdent counter\n * as multiple sources could be requesting the same value\n * gets added to will-change.\n */\n const prevCount = this.counts.get(styleName) || 0;\n this.counts.set(styleName, prevCount + 1);\n if (prevCount === 0) {\n this.output.push(styleName);\n this.update();\n }\n /**\n * Prevents the remove function from being called multiple times.\n */\n let hasRemoved = false;\n return () => {\n if (hasRemoved)\n return;\n hasRemoved = true;\n const newCount = this.counts.get(styleName) - 1;\n this.counts.set(styleName, newCount);\n if (newCount === 0) {\n removeItem(this.output, styleName);\n this.update();\n }\n };\n }\n update() {\n this.set(this.output.length ? this.output.join(\", \") : \"auto\");\n }\n}\n\nexport { WillChangeMotionValue };\n","import { WillChangeMotionValue } from './WillChangeMotionValue.mjs';\nimport { isWillChangeMotionValue } from './is.mjs';\n\nfunction addValueToWillChange(visualElement, key) {\n var _a;\n if (!visualElement.applyWillChange)\n return;\n let willChange = visualElement.getValue(\"willChange\");\n /**\n * If we haven't created a willChange MotionValue, and the we haven't been\n * manually provided one, create one.\n */\n if (!willChange && !((_a = visualElement.props.style) === null || _a === void 0 ? void 0 : _a.willChange)) {\n willChange = new WillChangeMotionValue(\"auto\");\n visualElement.addValue(\"willChange\", willChange);\n }\n /**\n * It could be that a user has set willChange to a regular MotionValue,\n * in which case we can't add the value to it.\n */\n if (isWillChangeMotionValue(willChange)) {\n return willChange.add(key);\n }\n}\n\nexport { addValueToWillChange };\n","import { isMotionValue } from '../utils/is-motion-value.mjs';\n\nfunction isWillChangeMotionValue(value) {\n return Boolean(isMotionValue(value) && value.add);\n}\n\nexport { isWillChangeMotionValue };\n","import { transformProps } from '../../render/html/utils/transform.mjs';\nimport { animateMotionValue } from './motion-value.mjs';\nimport { setTarget } from '../../render/utils/setters.mjs';\nimport { getValueTransition } from '../utils/transitions.mjs';\nimport { getOptimisedAppearId } from '../optimized-appear/get-appear-id.mjs';\nimport { addValueToWillChange } from '../../value/use-will-change/add-will-change.mjs';\nimport { frame } from '../../frameloop/frame.mjs';\n\n/**\n * Decide whether we should block this animation. Previously, we achieved this\n * just by checking whether the key was listed in protectedKeys, but this\n * posed problems if an animation was triggered by afterChildren and protectedKeys\n * had been set to true in the meantime.\n */\nfunction shouldBlockAnimation({ protectedKeys, needsAnimating }, key) {\n const shouldBlock = protectedKeys.hasOwnProperty(key) && needsAnimating[key] !== true;\n needsAnimating[key] = false;\n return shouldBlock;\n}\nfunction animateTarget(visualElement, targetAndTransition, { delay = 0, transitionOverride, type } = {}) {\n var _a;\n let { transition = visualElement.getDefaultTransition(), transitionEnd, ...target } = targetAndTransition;\n if (transitionOverride)\n transition = transitionOverride;\n const animations = [];\n const animationTypeState = type &&\n visualElement.animationState &&\n visualElement.animationState.getState()[type];\n for (const key in target) {\n const value = visualElement.getValue(key, (_a = visualElement.latestValues[key]) !== null && _a !== void 0 ? _a : null);\n const valueTarget = target[key];\n if (valueTarget === undefined ||\n (animationTypeState &&\n shouldBlockAnimation(animationTypeState, key))) {\n continue;\n }\n const valueTransition = {\n delay,\n ...getValueTransition(transition || {}, key),\n };\n /**\n * If this is the first time a value is being animated, check\n * to see if we're handling off from an existing animation.\n */\n let isHandoff = false;\n if (window.MotionHandoffAnimation) {\n const appearId = getOptimisedAppearId(visualElement);\n if (appearId) {\n const startTime = window.MotionHandoffAnimation(appearId, key, frame);\n if (startTime !== null) {\n valueTransition.startTime = startTime;\n isHandoff = true;\n }\n }\n }\n value.start(animateMotionValue(key, value, valueTarget, visualElement.shouldReduceMotion && transformProps.has(key)\n ? { type: false }\n : valueTransition, visualElement, isHandoff, addValueToWillChange(visualElement, key)));\n const animation = value.animation;\n if (animation) {\n animations.push(animation);\n }\n }\n if (transitionEnd) {\n Promise.all(animations).then(() => {\n frame.update(() => {\n transitionEnd && setTarget(visualElement, transitionEnd);\n });\n });\n }\n return animations;\n}\n\nexport { animateTarget };\n","import { resolveVariant } from '../../render/utils/resolve-dynamic-variants.mjs';\nimport { animateTarget } from './visual-element-target.mjs';\n\nfunction animateVariant(visualElement, variant, options = {}) {\n var _a;\n const resolved = resolveVariant(visualElement, variant, options.type === \"exit\"\n ? (_a = visualElement.presenceContext) === null || _a === void 0 ? void 0 : _a.custom\n : undefined);\n let { transition = visualElement.getDefaultTransition() || {} } = resolved || {};\n if (options.transitionOverride) {\n transition = options.transitionOverride;\n }\n /**\n * If we have a variant, create a callback that runs it as an animation.\n * Otherwise, we resolve a Promise immediately for a composable no-op.\n */\n const getAnimation = resolved\n ? () => Promise.all(animateTarget(visualElement, resolved, options))\n : () => Promise.resolve();\n /**\n * If we have children, create a callback that runs all their animations.\n * Otherwise, we resolve a Promise immediately for a composable no-op.\n */\n const getChildAnimations = visualElement.variantChildren && visualElement.variantChildren.size\n ? (forwardDelay = 0) => {\n const { delayChildren = 0, staggerChildren, staggerDirection, } = transition;\n return animateChildren(visualElement, variant, delayChildren + forwardDelay, staggerChildren, staggerDirection, options);\n }\n : () => Promise.resolve();\n /**\n * If the transition explicitly defines a \"when\" option, we need to resolve either\n * this animation or all children animations before playing the other.\n */\n const { when } = transition;\n if (when) {\n const [first, last] = when === \"beforeChildren\"\n ? [getAnimation, getChildAnimations]\n : [getChildAnimations, getAnimation];\n return first().then(() => last());\n }\n else {\n return Promise.all([getAnimation(), getChildAnimations(options.delay)]);\n }\n}\nfunction animateChildren(visualElement, variant, delayChildren = 0, staggerChildren = 0, staggerDirection = 1, options) {\n const animations = [];\n const maxStaggerDuration = (visualElement.variantChildren.size - 1) * staggerChildren;\n const generateStaggerDuration = staggerDirection === 1\n ? (i = 0) => i * staggerChildren\n : (i = 0) => maxStaggerDuration - i * staggerChildren;\n Array.from(visualElement.variantChildren)\n .sort(sortByTreeOrder)\n .forEach((child, i) => {\n child.notify(\"AnimationStart\", variant);\n animations.push(animateVariant(child, variant, {\n ...options,\n delay: delayChildren + generateStaggerDuration(i),\n }).then(() => child.notify(\"AnimationComplete\", variant)));\n });\n return Promise.all(animations);\n}\nfunction sortByTreeOrder(a, b) {\n return a.sortNodePosition(b);\n}\n\nexport { animateVariant, sortByTreeOrder };\n","import { isAnimationControls } from '../../animation/utils/is-animation-controls.mjs';\nimport { isKeyframesTarget } from '../../animation/utils/is-keyframes-target.mjs';\nimport { shallowCompare } from '../../utils/shallow-compare.mjs';\nimport { isVariantLabel } from './is-variant-label.mjs';\nimport { resolveVariant } from './resolve-dynamic-variants.mjs';\nimport { variantPriorityOrder } from './variant-props.mjs';\nimport { animateVisualElement } from '../../animation/interfaces/visual-element.mjs';\n\nconst reversePriorityOrder = [...variantPriorityOrder].reverse();\nconst numAnimationTypes = variantPriorityOrder.length;\nfunction animateList(visualElement) {\n return (animations) => Promise.all(animations.map(({ animation, options }) => animateVisualElement(visualElement, animation, options)));\n}\nfunction createAnimationState(visualElement) {\n let animate = animateList(visualElement);\n let state = createState();\n let isInitialRender = true;\n /**\n * This function will be used to reduce the animation definitions for\n * each active animation type into an object of resolved values for it.\n */\n const buildResolvedTypeValues = (type) => (acc, definition) => {\n var _a;\n const resolved = resolveVariant(visualElement, definition, type === \"exit\"\n ? (_a = visualElement.presenceContext) === null || _a === void 0 ? void 0 : _a.custom\n : undefined);\n if (resolved) {\n const { transition, transitionEnd, ...target } = resolved;\n acc = { ...acc, ...target, ...transitionEnd };\n }\n return acc;\n };\n /**\n * This just allows us to inject mocked animation functions\n * @internal\n */\n function setAnimateFunction(makeAnimator) {\n animate = makeAnimator(visualElement);\n }\n /**\n * When we receive new props, we need to:\n * 1. Create a list of protected keys for each type. This is a directory of\n * value keys that are currently being \"handled\" by types of a higher priority\n * so that whenever an animation is played of a given type, these values are\n * protected from being animated.\n * 2. Determine if an animation type needs animating.\n * 3. Determine if any values have been removed from a type and figure out\n * what to animate those to.\n */\n function animateChanges(changedActiveType) {\n const props = visualElement.getProps();\n const context = visualElement.getVariantContext(true) || {};\n /**\n * A list of animations that we'll build into as we iterate through the animation\n * types. This will get executed at the end of the function.\n */\n const animations = [];\n /**\n * Keep track of which values have been removed. Then, as we hit lower priority\n * animation types, we can check if they contain removed values and animate to that.\n */\n const removedKeys = new Set();\n /**\n * A dictionary of all encountered keys. This is an object to let us build into and\n * copy it without iteration. Each time we hit an animation type we set its protected\n * keys - the keys its not allowed to animate - to the latest version of this object.\n */\n let encounteredKeys = {};\n /**\n * If a variant has been removed at a given index, and this component is controlling\n * variant animations, we want to ensure lower-priority variants are forced to animate.\n */\n let removedVariantIndex = Infinity;\n /**\n * Iterate through all animation types in reverse priority order. For each, we want to\n * detect which values it's handling and whether or not they've changed (and therefore\n * need to be animated). If any values have been removed, we want to detect those in\n * lower priority props and flag for animation.\n */\n for (let i = 0; i < numAnimationTypes; i++) {\n const type = reversePriorityOrder[i];\n const typeState = state[type];\n const prop = props[type] !== undefined\n ? props[type]\n : context[type];\n const propIsVariant = isVariantLabel(prop);\n /**\n * If this type has *just* changed isActive status, set activeDelta\n * to that status. Otherwise set to null.\n */\n const activeDelta = type === changedActiveType ? typeState.isActive : null;\n if (activeDelta === false)\n removedVariantIndex = i;\n /**\n * If this prop is an inherited variant, rather than been set directly on the\n * component itself, we want to make sure we allow the parent to trigger animations.\n *\n * TODO: Can probably change this to a !isControllingVariants check\n */\n let isInherited = prop === context[type] &&\n prop !== props[type] &&\n propIsVariant;\n /**\n *\n */\n if (isInherited &&\n isInitialRender &&\n visualElement.manuallyAnimateOnMount) {\n isInherited = false;\n }\n /**\n * Set all encountered keys so far as the protected keys for this type. This will\n * be any key that has been animated or otherwise handled by active, higher-priortiy types.\n */\n typeState.protectedKeys = { ...encounteredKeys };\n // Check if we can skip analysing this prop early\n if (\n // If it isn't active and hasn't *just* been set as inactive\n (!typeState.isActive && activeDelta === null) ||\n // If we didn't and don't have any defined prop for this animation type\n (!prop && !typeState.prevProp) ||\n // Or if the prop doesn't define an animation\n isAnimationControls(prop) ||\n typeof prop === \"boolean\") {\n continue;\n }\n /**\n * As we go look through the values defined on this type, if we detect\n * a changed value or a value that was removed in a higher priority, we set\n * this to true and add this prop to the animation list.\n */\n const variantDidChange = checkVariantsDidChange(typeState.prevProp, prop);\n let shouldAnimateType = variantDidChange ||\n // If we're making this variant active, we want to always make it active\n (type === changedActiveType &&\n typeState.isActive &&\n !isInherited &&\n propIsVariant) ||\n // If we removed a higher-priority variant (i is in reverse order)\n (i > removedVariantIndex && propIsVariant);\n let handledRemovedValues = false;\n /**\n * As animations can be set as variant lists, variants or target objects, we\n * coerce everything to an array if it isn't one already\n */\n const definitionList = Array.isArray(prop) ? prop : [prop];\n /**\n * Build an object of all the resolved values. We'll use this in the subsequent\n * animateChanges calls to determine whether a value has changed.\n */\n let resolvedValues = definitionList.reduce(buildResolvedTypeValues(type), {});\n if (activeDelta === false)\n resolvedValues = {};\n /**\n * Now we need to loop through all the keys in the prev prop and this prop,\n * and decide:\n * 1. If the value has changed, and needs animating\n * 2. If it has been removed, and needs adding to the removedKeys set\n * 3. If it has been removed in a higher priority type and needs animating\n * 4. If it hasn't been removed in a higher priority but hasn't changed, and\n * needs adding to the type's protectedKeys list.\n */\n const { prevResolvedValues = {} } = typeState;\n const allKeys = {\n ...prevResolvedValues,\n ...resolvedValues,\n };\n const markToAnimate = (key) => {\n shouldAnimateType = true;\n if (removedKeys.has(key)) {\n handledRemovedValues = true;\n removedKeys.delete(key);\n }\n typeState.needsAnimating[key] = true;\n const motionValue = visualElement.getValue(key);\n if (motionValue)\n motionValue.liveStyle = false;\n };\n for (const key in allKeys) {\n const next = resolvedValues[key];\n const prev = prevResolvedValues[key];\n // If we've already handled this we can just skip ahead\n if (encounteredKeys.hasOwnProperty(key))\n continue;\n /**\n * If the value has changed, we probably want to animate it.\n */\n let valueHasChanged = false;\n if (isKeyframesTarget(next) && isKeyframesTarget(prev)) {\n valueHasChanged = !shallowCompare(next, prev);\n }\n else {\n valueHasChanged = next !== prev;\n }\n if (valueHasChanged) {\n if (next !== undefined && next !== null) {\n // If next is defined and doesn't equal prev, it needs animating\n markToAnimate(key);\n }\n else {\n // If it's undefined, it's been removed.\n removedKeys.add(key);\n }\n }\n else if (next !== undefined && removedKeys.has(key)) {\n /**\n * If next hasn't changed and it isn't undefined, we want to check if it's\n * been removed by a higher priority\n */\n markToAnimate(key);\n }\n else {\n /**\n * If it hasn't changed, we add it to the list of protected values\n * to ensure it doesn't get animated.\n */\n typeState.protectedKeys[key] = true;\n }\n }\n /**\n * Update the typeState so next time animateChanges is called we can compare the\n * latest prop and resolvedValues to these.\n */\n typeState.prevProp = prop;\n typeState.prevResolvedValues = resolvedValues;\n /**\n *\n */\n if (typeState.isActive) {\n encounteredKeys = { ...encounteredKeys, ...resolvedValues };\n }\n if (isInitialRender && visualElement.blockInitialAnimation) {\n shouldAnimateType = false;\n }\n /**\n * If this is an inherited prop we want to hard-block animations\n */\n if (shouldAnimateType && (!isInherited || handledRemovedValues)) {\n animations.push(...definitionList.map((animation) => ({\n animation: animation,\n options: { type },\n })));\n }\n }\n /**\n * If there are some removed value that haven't been dealt with,\n * we need to create a new animation that falls back either to the value\n * defined in the style prop, or the last read value.\n */\n if (removedKeys.size) {\n const fallbackAnimation = {};\n removedKeys.forEach((key) => {\n const fallbackTarget = visualElement.getBaseTarget(key);\n const motionValue = visualElement.getValue(key);\n if (motionValue)\n motionValue.liveStyle = true;\n // @ts-expect-error - @mattgperry to figure if we should do something here\n fallbackAnimation[key] = fallbackTarget !== null && fallbackTarget !== void 0 ? fallbackTarget : null;\n });\n animations.push({ animation: fallbackAnimation });\n }\n let shouldAnimate = Boolean(animations.length);\n if (isInitialRender &&\n (props.initial === false || props.initial === props.animate) &&\n !visualElement.manuallyAnimateOnMount) {\n shouldAnimate = false;\n }\n isInitialRender = false;\n return shouldAnimate ? animate(animations) : Promise.resolve();\n }\n /**\n * Change whether a certain animation type is active.\n */\n function setActive(type, isActive) {\n var _a;\n // If the active state hasn't changed, we can safely do nothing here\n if (state[type].isActive === isActive)\n return Promise.resolve();\n // Propagate active change to children\n (_a = visualElement.variantChildren) === null || _a === void 0 ? void 0 : _a.forEach((child) => { var _a; return (_a = child.animationState) === null || _a === void 0 ? void 0 : _a.setActive(type, isActive); });\n state[type].isActive = isActive;\n const animations = animateChanges(type);\n for (const key in state) {\n state[key].protectedKeys = {};\n }\n return animations;\n }\n return {\n animateChanges,\n setActive,\n setAnimateFunction,\n getState: () => state,\n reset: () => {\n state = createState();\n isInitialRender = true;\n },\n };\n}\nfunction checkVariantsDidChange(prev, next) {\n if (typeof next === \"string\") {\n return next !== prev;\n }\n else if (Array.isArray(next)) {\n return !shallowCompare(next, prev);\n }\n return false;\n}\nfunction createTypeState(isActive = false) {\n return {\n isActive,\n protectedKeys: {},\n needsAnimating: {},\n prevResolvedValues: {},\n };\n}\nfunction createState() {\n return {\n animate: createTypeState(true),\n whileInView: createTypeState(),\n whileHover: createTypeState(),\n whileTap: createTypeState(),\n whileDrag: createTypeState(),\n whileFocus: createTypeState(),\n exit: createTypeState(),\n };\n}\n\nexport { checkVariantsDidChange, createAnimationState };\n","import { resolveVariant } from '../../render/utils/resolve-dynamic-variants.mjs';\nimport { animateTarget } from './visual-element-target.mjs';\nimport { animateVariant } from './visual-element-variant.mjs';\n\nfunction animateVisualElement(visualElement, definition, options = {}) {\n visualElement.notify(\"AnimationStart\", definition);\n let animation;\n if (Array.isArray(definition)) {\n const animations = definition.map((variant) => animateVariant(visualElement, variant, options));\n animation = Promise.all(animations);\n }\n else if (typeof definition === \"string\") {\n animation = animateVariant(visualElement, definition, options);\n }\n else {\n const resolvedDefinition = typeof definition === \"function\"\n ? resolveVariant(visualElement, definition, options.custom)\n : definition;\n animation = Promise.all(animateTarget(visualElement, resolvedDefinition, options));\n }\n return animation.then(() => {\n visualElement.notify(\"AnimationComplete\", definition);\n });\n}\n\nexport { animateVisualElement };\n","import { Feature } from '../Feature.mjs';\n\nlet id = 0;\nclass ExitAnimationFeature extends Feature {\n constructor() {\n super(...arguments);\n this.id = id++;\n }\n update() {\n if (!this.node.presenceContext)\n return;\n const { isPresent, onExitComplete } = this.node.presenceContext;\n const { isPresent: prevIsPresent } = this.node.prevPresenceContext || {};\n if (!this.node.animationState || isPresent === prevIsPresent) {\n return;\n }\n const exitAnimation = this.node.animationState.setActive(\"exit\", !isPresent);\n if (onExitComplete && !isPresent) {\n exitAnimation.then(() => onExitComplete(this.id));\n }\n }\n mount() {\n const { register } = this.node.presenceContext || {};\n if (register) {\n this.unmount = register(this.id);\n }\n }\n unmount() { }\n}\n\nexport { ExitAnimationFeature };\n","import { AnimationFeature } from './animation/index.mjs';\nimport { ExitAnimationFeature } from './animation/exit.mjs';\n\nconst animations = {\n animation: {\n Feature: AnimationFeature,\n },\n exit: {\n Feature: ExitAnimationFeature,\n },\n};\n\nexport { animations };\n","import { isAnimationControls } from '../../../animation/utils/is-animation-controls.mjs';\nimport { createAnimationState } from '../../../render/utils/animation-state.mjs';\nimport { Feature } from '../Feature.mjs';\n\nclass AnimationFeature extends Feature {\n /**\n * We dynamically generate the AnimationState manager as it contains a reference\n * to the underlying animation library. We only want to load that if we load this,\n * so people can optionally code split it out using the `m` component.\n */\n constructor(node) {\n super(node);\n node.animationState || (node.animationState = createAnimationState(node));\n }\n updateAnimationControlsSubscription() {\n const { animate } = this.node.getProps();\n if (isAnimationControls(animate)) {\n this.unmountControls = animate.subscribe(this.node);\n }\n }\n /**\n * Subscribe any provided AnimationControls to the component's VisualElement\n */\n mount() {\n this.updateAnimationControlsSubscription();\n }\n update() {\n const { animate } = this.node.getProps();\n const { animate: prevAnimate } = this.node.prevProps || {};\n if (animate !== prevAnimate) {\n this.updateAnimationControlsSubscription();\n }\n }\n unmount() {\n var _a;\n this.node.animationState.reset();\n (_a = this.unmountControls) === null || _a === void 0 ? void 0 : _a.call(this);\n }\n}\n\nexport { AnimationFeature };\n","const distance = (a, b) => Math.abs(a - b);\nfunction distance2D(a, b) {\n // Multi-dimensional\n const xDelta = distance(a.x, b.x);\n const yDelta = distance(a.y, b.y);\n return Math.sqrt(xDelta ** 2 + yDelta ** 2);\n}\n\nexport { distance, distance2D };\n","import { extractEventInfo } from '../../events/event-info.mjs';\nimport { secondsToMilliseconds, millisecondsToSeconds } from '../../utils/time-conversion.mjs';\nimport { addPointerEvent } from '../../events/add-pointer-event.mjs';\nimport { pipe } from '../../utils/pipe.mjs';\nimport { distance2D } from '../../utils/distance.mjs';\nimport { isPrimaryPointer } from '../../events/utils/is-primary-pointer.mjs';\nimport { frame, cancelFrame, frameData } from '../../frameloop/frame.mjs';\n\n/**\n * @internal\n */\nclass PanSession {\n constructor(event, handlers, { transformPagePoint, contextWindow, dragSnapToOrigin = false } = {}) {\n /**\n * @internal\n */\n this.startEvent = null;\n /**\n * @internal\n */\n this.lastMoveEvent = null;\n /**\n * @internal\n */\n this.lastMoveEventInfo = null;\n /**\n * @internal\n */\n this.handlers = {};\n /**\n * @internal\n */\n this.contextWindow = window;\n this.updatePoint = () => {\n if (!(this.lastMoveEvent && this.lastMoveEventInfo))\n return;\n const info = getPanInfo(this.lastMoveEventInfo, this.history);\n const isPanStarted = this.startEvent !== null;\n // Only start panning if the offset is larger than 3 pixels. If we make it\n // any larger than this we'll want to reset the pointer history\n // on the first update to avoid visual snapping to the cursoe.\n const isDistancePastThreshold = distance2D(info.offset, { x: 0, y: 0 }) >= 3;\n if (!isPanStarted && !isDistancePastThreshold)\n return;\n const { point } = info;\n const { timestamp } = frameData;\n this.history.push({ ...point, timestamp });\n const { onStart, onMove } = this.handlers;\n if (!isPanStarted) {\n onStart && onStart(this.lastMoveEvent, info);\n this.startEvent = this.lastMoveEvent;\n }\n onMove && onMove(this.lastMoveEvent, info);\n };\n this.handlePointerMove = (event, info) => {\n this.lastMoveEvent = event;\n this.lastMoveEventInfo = transformPoint(info, this.transformPagePoint);\n // Throttle mouse move event to once per frame\n frame.update(this.updatePoint, true);\n };\n this.handlePointerUp = (event, info) => {\n this.end();\n const { onEnd, onSessionEnd, resumeAnimation } = this.handlers;\n if (this.dragSnapToOrigin)\n resumeAnimation && resumeAnimation();\n if (!(this.lastMoveEvent && this.lastMoveEventInfo))\n return;\n const panInfo = getPanInfo(event.type === \"pointercancel\"\n ? this.lastMoveEventInfo\n : transformPoint(info, this.transformPagePoint), this.history);\n if (this.startEvent && onEnd) {\n onEnd(event, panInfo);\n }\n onSessionEnd && onSessionEnd(event, panInfo);\n };\n // If we have more than one touch, don't start detecting this gesture\n if (!isPrimaryPointer(event))\n return;\n this.dragSnapToOrigin = dragSnapToOrigin;\n this.handlers = handlers;\n this.transformPagePoint = transformPagePoint;\n this.contextWindow = contextWindow || window;\n const info = extractEventInfo(event);\n const initialInfo = transformPoint(info, this.transformPagePoint);\n const { point } = initialInfo;\n const { timestamp } = frameData;\n this.history = [{ ...point, timestamp }];\n const { onSessionStart } = handlers;\n onSessionStart &&\n onSessionStart(event, getPanInfo(initialInfo, this.history));\n this.removeListeners = pipe(addPointerEvent(this.contextWindow, \"pointermove\", this.handlePointerMove), addPointerEvent(this.contextWindow, \"pointerup\", this.handlePointerUp), addPointerEvent(this.contextWindow, \"pointercancel\", this.handlePointerUp));\n }\n updateHandlers(handlers) {\n this.handlers = handlers;\n }\n end() {\n this.removeListeners && this.removeListeners();\n cancelFrame(this.updatePoint);\n }\n}\nfunction transformPoint(info, transformPagePoint) {\n return transformPagePoint ? { point: transformPagePoint(info.point) } : info;\n}\nfunction subtractPoint(a, b) {\n return { x: a.x - b.x, y: a.y - b.y };\n}\nfunction getPanInfo({ point }, history) {\n return {\n point,\n delta: subtractPoint(point, lastDevicePoint(history)),\n offset: subtractPoint(point, startDevicePoint(history)),\n velocity: getVelocity(history, 0.1),\n };\n}\nfunction startDevicePoint(history) {\n return history[0];\n}\nfunction lastDevicePoint(history) {\n return history[history.length - 1];\n}\nfunction getVelocity(history, timeDelta) {\n if (history.length < 2) {\n return { x: 0, y: 0 };\n }\n let i = history.length - 1;\n let timestampedPoint = null;\n const lastPoint = lastDevicePoint(history);\n while (i >= 0) {\n timestampedPoint = history[i];\n if (lastPoint.timestamp - timestampedPoint.timestamp >\n secondsToMilliseconds(timeDelta)) {\n break;\n }\n i--;\n }\n if (!timestampedPoint) {\n return { x: 0, y: 0 };\n }\n const time = millisecondsToSeconds(lastPoint.timestamp - timestampedPoint.timestamp);\n if (time === 0) {\n return { x: 0, y: 0 };\n }\n const currentVelocity = {\n x: (lastPoint.x - timestampedPoint.x) / time,\n y: (lastPoint.y - timestampedPoint.y) / time,\n };\n if (currentVelocity.x === Infinity) {\n currentVelocity.x = 0;\n }\n if (currentVelocity.y === Infinity) {\n currentVelocity.y = 0;\n }\n return currentVelocity;\n}\n\nexport { PanSession };\n","import { mixNumber } from '../../utils/mix/number.mjs';\n\nconst SCALE_PRECISION = 0.0001;\nconst SCALE_MIN = 1 - SCALE_PRECISION;\nconst SCALE_MAX = 1 + SCALE_PRECISION;\nconst TRANSLATE_PRECISION = 0.01;\nconst TRANSLATE_MIN = 0 - TRANSLATE_PRECISION;\nconst TRANSLATE_MAX = 0 + TRANSLATE_PRECISION;\nfunction calcLength(axis) {\n return axis.max - axis.min;\n}\nfunction isNear(value, target, maxDistance) {\n return Math.abs(value - target) <= maxDistance;\n}\nfunction calcAxisDelta(delta, source, target, origin = 0.5) {\n delta.origin = origin;\n delta.originPoint = mixNumber(source.min, source.max, delta.origin);\n delta.scale = calcLength(target) / calcLength(source);\n delta.translate =\n mixNumber(target.min, target.max, delta.origin) - delta.originPoint;\n if ((delta.scale >= SCALE_MIN && delta.scale <= SCALE_MAX) ||\n isNaN(delta.scale)) {\n delta.scale = 1.0;\n }\n if ((delta.translate >= TRANSLATE_MIN &&\n delta.translate <= TRANSLATE_MAX) ||\n isNaN(delta.translate)) {\n delta.translate = 0.0;\n }\n}\nfunction calcBoxDelta(delta, source, target, origin) {\n calcAxisDelta(delta.x, source.x, target.x, origin ? origin.originX : undefined);\n calcAxisDelta(delta.y, source.y, target.y, origin ? origin.originY : undefined);\n}\nfunction calcRelativeAxis(target, relative, parent) {\n target.min = parent.min + relative.min;\n target.max = target.min + calcLength(relative);\n}\nfunction calcRelativeBox(target, relative, parent) {\n calcRelativeAxis(target.x, relative.x, parent.x);\n calcRelativeAxis(target.y, relative.y, parent.y);\n}\nfunction calcRelativeAxisPosition(target, layout, parent) {\n target.min = layout.min - parent.min;\n target.max = target.min + calcLength(layout);\n}\nfunction calcRelativePosition(target, layout, parent) {\n calcRelativeAxisPosition(target.x, layout.x, parent.x);\n calcRelativeAxisPosition(target.y, layout.y, parent.y);\n}\n\nexport { calcAxisDelta, calcBoxDelta, calcLength, calcRelativeAxis, calcRelativeAxisPosition, calcRelativeBox, calcRelativePosition, isNear };\n","import { progress } from '../../../utils/progress.mjs';\nimport { calcLength } from '../../../projection/geometry/delta-calc.mjs';\nimport { clamp } from '../../../utils/clamp.mjs';\nimport { mixNumber } from '../../../utils/mix/number.mjs';\n\n/**\n * Apply constraints to a point. These constraints are both physical along an\n * axis, and an elastic factor that determines how much to constrain the point\n * by if it does lie outside the defined parameters.\n */\nfunction applyConstraints(point, { min, max }, elastic) {\n if (min !== undefined && point < min) {\n // If we have a min point defined, and this is outside of that, constrain\n point = elastic\n ? mixNumber(min, point, elastic.min)\n : Math.max(point, min);\n }\n else if (max !== undefined && point > max) {\n // If we have a max point defined, and this is outside of that, constrain\n point = elastic\n ? mixNumber(max, point, elastic.max)\n : Math.min(point, max);\n }\n return point;\n}\n/**\n * Calculate constraints in terms of the viewport when defined relatively to the\n * measured axis. This is measured from the nearest edge, so a max constraint of 200\n * on an axis with a max value of 300 would return a constraint of 500 - axis length\n */\nfunction calcRelativeAxisConstraints(axis, min, max) {\n return {\n min: min !== undefined ? axis.min + min : undefined,\n max: max !== undefined\n ? axis.max + max - (axis.max - axis.min)\n : undefined,\n };\n}\n/**\n * Calculate constraints in terms of the viewport when\n * defined relatively to the measured bounding box.\n */\nfunction calcRelativeConstraints(layoutBox, { top, left, bottom, right }) {\n return {\n x: calcRelativeAxisConstraints(layoutBox.x, left, right),\n y: calcRelativeAxisConstraints(layoutBox.y, top, bottom),\n };\n}\n/**\n * Calculate viewport constraints when defined as another viewport-relative axis\n */\nfunction calcViewportAxisConstraints(layoutAxis, constraintsAxis) {\n let min = constraintsAxis.min - layoutAxis.min;\n let max = constraintsAxis.max - layoutAxis.max;\n // If the constraints axis is actually smaller than the layout axis then we can\n // flip the constraints\n if (constraintsAxis.max - constraintsAxis.min <\n layoutAxis.max - layoutAxis.min) {\n [min, max] = [max, min];\n }\n return { min, max };\n}\n/**\n * Calculate viewport constraints when defined as another viewport-relative box\n */\nfunction calcViewportConstraints(layoutBox, constraintsBox) {\n return {\n x: calcViewportAxisConstraints(layoutBox.x, constraintsBox.x),\n y: calcViewportAxisConstraints(layoutBox.y, constraintsBox.y),\n };\n}\n/**\n * Calculate a transform origin relative to the source axis, between 0-1, that results\n * in an asthetically pleasing scale/transform needed to project from source to target.\n */\nfunction calcOrigin(source, target) {\n let origin = 0.5;\n const sourceLength = calcLength(source);\n const targetLength = calcLength(target);\n if (targetLength > sourceLength) {\n origin = progress(target.min, target.max - sourceLength, source.min);\n }\n else if (sourceLength > targetLength) {\n origin = progress(source.min, source.max - targetLength, target.min);\n }\n return clamp(0, 1, origin);\n}\n/**\n * Rebase the calculated viewport constraints relative to the layout.min point.\n */\nfunction rebaseAxisConstraints(layout, constraints) {\n const relativeConstraints = {};\n if (constraints.min !== undefined) {\n relativeConstraints.min = constraints.min - layout.min;\n }\n if (constraints.max !== undefined) {\n relativeConstraints.max = constraints.max - layout.min;\n }\n return relativeConstraints;\n}\nconst defaultElastic = 0.35;\n/**\n * Accepts a dragElastic prop and returns resolved elastic values for each axis.\n */\nfunction resolveDragElastic(dragElastic = defaultElastic) {\n if (dragElastic === false) {\n dragElastic = 0;\n }\n else if (dragElastic === true) {\n dragElastic = defaultElastic;\n }\n return {\n x: resolveAxisElastic(dragElastic, \"left\", \"right\"),\n y: resolveAxisElastic(dragElastic, \"top\", \"bottom\"),\n };\n}\nfunction resolveAxisElastic(dragElastic, minLabel, maxLabel) {\n return {\n min: resolvePointElastic(dragElastic, minLabel),\n max: resolvePointElastic(dragElastic, maxLabel),\n };\n}\nfunction resolvePointElastic(dragElastic, label) {\n return typeof dragElastic === \"number\"\n ? dragElastic\n : dragElastic[label] || 0;\n}\n\nexport { applyConstraints, calcOrigin, calcRelativeAxisConstraints, calcRelativeConstraints, calcViewportAxisConstraints, calcViewportConstraints, defaultElastic, rebaseAxisConstraints, resolveAxisElastic, resolveDragElastic, resolvePointElastic };\n","const createAxisDelta = () => ({\n translate: 0,\n scale: 1,\n origin: 0,\n originPoint: 0,\n});\nconst createDelta = () => ({\n x: createAxisDelta(),\n y: createAxisDelta(),\n});\nconst createAxis = () => ({ min: 0, max: 0 });\nconst createBox = () => ({\n x: createAxis(),\n y: createAxis(),\n});\n\nexport { createAxis, createAxisDelta, createBox, createDelta };\n","function eachAxis(callback) {\n return [callback(\"x\"), callback(\"y\")];\n}\n\nexport { eachAxis };\n","/**\n * Bounding boxes tend to be defined as top, left, right, bottom. For various operations\n * it's easier to consider each axis individually. This function returns a bounding box\n * as a map of single-axis min/max values.\n */\nfunction convertBoundingBoxToBox({ top, left, right, bottom, }) {\n return {\n x: { min: left, max: right },\n y: { min: top, max: bottom },\n };\n}\nfunction convertBoxToBoundingBox({ x, y }) {\n return { top: y.min, right: x.max, bottom: y.max, left: x.min };\n}\n/**\n * Applies a TransformPoint function to a bounding box. TransformPoint is usually a function\n * provided by Framer to allow measured points to be corrected for device scaling. This is used\n * when measuring DOM elements and DOM event points.\n */\nfunction transformBoxPoints(point, transformPoint) {\n if (!transformPoint)\n return point;\n const topLeft = transformPoint({ x: point.left, y: point.top });\n const bottomRight = transformPoint({ x: point.right, y: point.bottom });\n return {\n top: topLeft.y,\n left: topLeft.x,\n bottom: bottomRight.y,\n right: bottomRight.x,\n };\n}\n\nexport { convertBoundingBoxToBox, convertBoxToBoundingBox, transformBoxPoints };\n","function isIdentityScale(scale) {\n return scale === undefined || scale === 1;\n}\nfunction hasScale({ scale, scaleX, scaleY }) {\n return (!isIdentityScale(scale) ||\n !isIdentityScale(scaleX) ||\n !isIdentityScale(scaleY));\n}\nfunction hasTransform(values) {\n return (hasScale(values) ||\n has2DTranslate(values) ||\n values.z ||\n values.rotate ||\n values.rotateX ||\n values.rotateY ||\n values.skewX ||\n values.skewY);\n}\nfunction has2DTranslate(values) {\n return is2DTranslate(values.x) || is2DTranslate(values.y);\n}\nfunction is2DTranslate(value) {\n return value && value !== \"0%\";\n}\n\nexport { has2DTranslate, hasScale, hasTransform };\n","import { mixNumber } from '../../utils/mix/number.mjs';\nimport { hasTransform } from '../utils/has-transform.mjs';\n\n/**\n * Scales a point based on a factor and an originPoint\n */\nfunction scalePoint(point, scale, originPoint) {\n const distanceFromOrigin = point - originPoint;\n const scaled = scale * distanceFromOrigin;\n return originPoint + scaled;\n}\n/**\n * Applies a translate/scale delta to a point\n */\nfunction applyPointDelta(point, translate, scale, originPoint, boxScale) {\n if (boxScale !== undefined) {\n point = scalePoint(point, boxScale, originPoint);\n }\n return scalePoint(point, scale, originPoint) + translate;\n}\n/**\n * Applies a translate/scale delta to an axis\n */\nfunction applyAxisDelta(axis, translate = 0, scale = 1, originPoint, boxScale) {\n axis.min = applyPointDelta(axis.min, translate, scale, originPoint, boxScale);\n axis.max = applyPointDelta(axis.max, translate, scale, originPoint, boxScale);\n}\n/**\n * Applies a translate/scale delta to a box\n */\nfunction applyBoxDelta(box, { x, y }) {\n applyAxisDelta(box.x, x.translate, x.scale, x.originPoint);\n applyAxisDelta(box.y, y.translate, y.scale, y.originPoint);\n}\nconst TREE_SCALE_SNAP_MIN = 0.999999999999;\nconst TREE_SCALE_SNAP_MAX = 1.0000000000001;\n/**\n * Apply a tree of deltas to a box. We do this to calculate the effect of all the transforms\n * in a tree upon our box before then calculating how to project it into our desired viewport-relative box\n *\n * This is the final nested loop within updateLayoutDelta for future refactoring\n */\nfunction applyTreeDeltas(box, treeScale, treePath, isSharedTransition = false) {\n const treeLength = treePath.length;\n if (!treeLength)\n return;\n // Reset the treeScale\n treeScale.x = treeScale.y = 1;\n let node;\n let delta;\n for (let i = 0; i < treeLength; i++) {\n node = treePath[i];\n delta = node.projectionDelta;\n /**\n * TODO: Prefer to remove this, but currently we have motion components with\n * display: contents in Framer.\n */\n const { visualElement } = node.options;\n if (visualElement &&\n visualElement.props.style &&\n visualElement.props.style.display === \"contents\") {\n continue;\n }\n if (isSharedTransition &&\n node.options.layoutScroll &&\n node.scroll &&\n node !== node.root) {\n transformBox(box, {\n x: -node.scroll.offset.x,\n y: -node.scroll.offset.y,\n });\n }\n if (delta) {\n // Incoporate each ancestor's scale into a culmulative treeScale for this component\n treeScale.x *= delta.x.scale;\n treeScale.y *= delta.y.scale;\n // Apply each ancestor's calculated delta into this component's recorded layout box\n applyBoxDelta(box, delta);\n }\n if (isSharedTransition && hasTransform(node.latestValues)) {\n transformBox(box, node.latestValues);\n }\n }\n /**\n * Snap tree scale back to 1 if it's within a non-perceivable threshold.\n * This will help reduce useless scales getting rendered.\n */\n if (treeScale.x < TREE_SCALE_SNAP_MAX &&\n treeScale.x > TREE_SCALE_SNAP_MIN) {\n treeScale.x = 1.0;\n }\n if (treeScale.y < TREE_SCALE_SNAP_MAX &&\n treeScale.y > TREE_SCALE_SNAP_MIN) {\n treeScale.y = 1.0;\n }\n}\nfunction translateAxis(axis, distance) {\n axis.min = axis.min + distance;\n axis.max = axis.max + distance;\n}\n/**\n * Apply a transform to an axis from the latest resolved motion values.\n * This function basically acts as a bridge between a flat motion value map\n * and applyAxisDelta\n */\nfunction transformAxis(axis, axisTranslate, axisScale, boxScale, axisOrigin = 0.5) {\n const originPoint = mixNumber(axis.min, axis.max, axisOrigin);\n // Apply the axis delta to the final axis\n applyAxisDelta(axis, axisTranslate, axisScale, originPoint, boxScale);\n}\n/**\n * Apply a transform to a box from the latest resolved motion values.\n */\nfunction transformBox(box, transform) {\n transformAxis(box.x, transform.x, transform.scaleX, transform.scale, transform.originX);\n transformAxis(box.y, transform.y, transform.scaleY, transform.scale, transform.originY);\n}\n\nexport { applyAxisDelta, applyBoxDelta, applyPointDelta, applyTreeDeltas, scalePoint, transformAxis, transformBox, translateAxis };\n","import { convertBoundingBoxToBox, transformBoxPoints } from '../geometry/conversion.mjs';\nimport { translateAxis } from '../geometry/delta-apply.mjs';\n\nfunction measureViewportBox(instance, transformPoint) {\n return convertBoundingBoxToBox(transformBoxPoints(instance.getBoundingClientRect(), transformPoint));\n}\nfunction measurePageBox(element, rootProjectionNode, transformPagePoint) {\n const viewportBox = measureViewportBox(element, transformPagePoint);\n const { scroll } = rootProjectionNode;\n if (scroll) {\n translateAxis(viewportBox.x, scroll.offset.x);\n translateAxis(viewportBox.y, scroll.offset.y);\n }\n return viewportBox;\n}\n\nexport { measurePageBox, measureViewportBox };\n","// Fixes https://github.com/framer/motion/issues/2270\nconst getContextWindow = ({ current }) => {\n return current ? current.ownerDocument.defaultView : null;\n};\n\nexport { getContextWindow };\n","import { invariant } from '../../utils/errors.mjs';\nimport { PanSession } from '../pan/PanSession.mjs';\nimport { getGlobalLock } from './utils/lock.mjs';\nimport { isRefObject } from '../../utils/is-ref-object.mjs';\nimport { addPointerEvent } from '../../events/add-pointer-event.mjs';\nimport { applyConstraints, calcRelativeConstraints, resolveDragElastic, rebaseAxisConstraints, calcViewportConstraints, calcOrigin, defaultElastic } from './utils/constraints.mjs';\nimport { createBox } from '../../projection/geometry/models.mjs';\nimport { eachAxis } from '../../projection/utils/each-axis.mjs';\nimport { measurePageBox } from '../../projection/utils/measure.mjs';\nimport { extractEventInfo } from '../../events/event-info.mjs';\nimport { convertBoxToBoundingBox, convertBoundingBoxToBox } from '../../projection/geometry/conversion.mjs';\nimport { addDomEvent } from '../../events/add-dom-event.mjs';\nimport { calcLength } from '../../projection/geometry/delta-calc.mjs';\nimport { mixNumber } from '../../utils/mix/number.mjs';\nimport { percent } from '../../value/types/numbers/units.mjs';\nimport { animateMotionValue } from '../../animation/interfaces/motion-value.mjs';\nimport { getContextWindow } from '../../utils/get-context-window.mjs';\nimport { addValueToWillChange } from '../../value/use-will-change/add-will-change.mjs';\nimport { frame } from '../../frameloop/frame.mjs';\n\nconst elementDragControls = new WeakMap();\n/**\n *\n */\n// let latestPointerEvent: PointerEvent\nclass VisualElementDragControls {\n constructor(visualElement) {\n // This is a reference to the global drag gesture lock, ensuring only one component\n // can \"capture\" the drag of one or both axes.\n // TODO: Look into moving this into pansession?\n this.openGlobalLock = null;\n this.isDragging = false;\n this.currentDirection = null;\n this.originPoint = { x: 0, y: 0 };\n /**\n * The permitted boundaries of travel, in pixels.\n */\n this.constraints = false;\n this.hasMutatedConstraints = false;\n /**\n * The per-axis resolved elastic values.\n */\n this.elastic = createBox();\n this.visualElement = visualElement;\n }\n start(originEvent, { snapToCursor = false } = {}) {\n /**\n * Don't start dragging if this component is exiting\n */\n const { presenceContext } = this.visualElement;\n if (presenceContext && presenceContext.isPresent === false)\n return;\n const onSessionStart = (event) => {\n const { dragSnapToOrigin } = this.getProps();\n // Stop or pause any animations on both axis values immediately. This allows the user to throw and catch\n // the component.\n dragSnapToOrigin ? this.pauseAnimation() : this.stopAnimation();\n if (snapToCursor) {\n this.snapToCursor(extractEventInfo(event, \"page\").point);\n }\n };\n const onStart = (event, info) => {\n var _a;\n // Attempt to grab the global drag gesture lock - maybe make this part of PanSession\n const { drag, dragPropagation, onDragStart } = this.getProps();\n if (drag && !dragPropagation) {\n if (this.openGlobalLock)\n this.openGlobalLock();\n this.openGlobalLock = getGlobalLock(drag);\n // If we don 't have the lock, don't start dragging\n if (!this.openGlobalLock)\n return;\n }\n this.isDragging = true;\n this.currentDirection = null;\n this.resolveConstraints();\n if (this.visualElement.projection) {\n this.visualElement.projection.isAnimationBlocked = true;\n this.visualElement.projection.target = undefined;\n }\n /**\n * Record gesture origin\n */\n eachAxis((axis) => {\n let current = this.getAxisMotionValue(axis).get() || 0;\n /**\n * If the MotionValue is a percentage value convert to px\n */\n if (percent.test(current)) {\n const { projection } = this.visualElement;\n if (projection && projection.layout) {\n const measuredAxis = projection.layout.layoutBox[axis];\n if (measuredAxis) {\n const length = calcLength(measuredAxis);\n current = length * (parseFloat(current) / 100);\n }\n }\n }\n this.originPoint[axis] = current;\n });\n // Fire onDragStart event\n if (onDragStart) {\n frame.postRender(() => onDragStart(event, info));\n }\n (_a = this.removeWillChange) === null || _a === void 0 ? void 0 : _a.call(this);\n this.removeWillChange = addValueToWillChange(this.visualElement, \"transform\");\n const { animationState } = this.visualElement;\n animationState && animationState.setActive(\"whileDrag\", true);\n };\n const onMove = (event, info) => {\n // latestPointerEvent = event\n const { dragPropagation, dragDirectionLock, onDirectionLock, onDrag, } = this.getProps();\n // If we didn't successfully receive the gesture lock, early return.\n if (!dragPropagation && !this.openGlobalLock)\n return;\n const { offset } = info;\n // Attempt to detect drag direction if directionLock is true\n if (dragDirectionLock && this.currentDirection === null) {\n this.currentDirection = getCurrentDirection(offset);\n // If we've successfully set a direction, notify listener\n if (this.currentDirection !== null) {\n onDirectionLock && onDirectionLock(this.currentDirection);\n }\n return;\n }\n // Update each point with the latest position\n this.updateAxis(\"x\", info.point, offset);\n this.updateAxis(\"y\", info.point, offset);\n /**\n * Ideally we would leave the renderer to fire naturally at the end of\n * this frame but if the element is about to change layout as the result\n * of a re-render we want to ensure the browser can read the latest\n * bounding box to ensure the pointer and element don't fall out of sync.\n */\n this.visualElement.render();\n /**\n * This must fire after the render call as it might trigger a state\n * change which itself might trigger a layout update.\n */\n onDrag && onDrag(event, info);\n };\n const onSessionEnd = (event, info) => this.stop(event, info);\n const resumeAnimation = () => eachAxis((axis) => {\n var _a;\n return this.getAnimationState(axis) === \"paused\" &&\n ((_a = this.getAxisMotionValue(axis).animation) === null || _a === void 0 ? void 0 : _a.play());\n });\n const { dragSnapToOrigin } = this.getProps();\n this.panSession = new PanSession(originEvent, {\n onSessionStart,\n onStart,\n onMove,\n onSessionEnd,\n resumeAnimation,\n }, {\n transformPagePoint: this.visualElement.getTransformPagePoint(),\n dragSnapToOrigin,\n contextWindow: getContextWindow(this.visualElement),\n });\n }\n stop(event, info) {\n var _a;\n (_a = this.removeWillChange) === null || _a === void 0 ? void 0 : _a.call(this);\n const isDragging = this.isDragging;\n this.cancel();\n if (!isDragging)\n return;\n const { velocity } = info;\n this.startAnimation(velocity);\n const { onDragEnd } = this.getProps();\n if (onDragEnd) {\n frame.postRender(() => onDragEnd(event, info));\n }\n }\n cancel() {\n this.isDragging = false;\n const { projection, animationState } = this.visualElement;\n if (projection) {\n projection.isAnimationBlocked = false;\n }\n this.panSession && this.panSession.end();\n this.panSession = undefined;\n const { dragPropagation } = this.getProps();\n if (!dragPropagation && this.openGlobalLock) {\n this.openGlobalLock();\n this.openGlobalLock = null;\n }\n animationState && animationState.setActive(\"whileDrag\", false);\n }\n updateAxis(axis, _point, offset) {\n const { drag } = this.getProps();\n // If we're not dragging this axis, do an early return.\n if (!offset || !shouldDrag(axis, drag, this.currentDirection))\n return;\n const axisValue = this.getAxisMotionValue(axis);\n let next = this.originPoint[axis] + offset[axis];\n // Apply constraints\n if (this.constraints && this.constraints[axis]) {\n next = applyConstraints(next, this.constraints[axis], this.elastic[axis]);\n }\n axisValue.set(next);\n }\n resolveConstraints() {\n var _a;\n const { dragConstraints, dragElastic } = this.getProps();\n const layout = this.visualElement.projection &&\n !this.visualElement.projection.layout\n ? this.visualElement.projection.measure(false)\n : (_a = this.visualElement.projection) === null || _a === void 0 ? void 0 : _a.layout;\n const prevConstraints = this.constraints;\n if (dragConstraints && isRefObject(dragConstraints)) {\n if (!this.constraints) {\n this.constraints = this.resolveRefConstraints();\n }\n }\n else {\n if (dragConstraints && layout) {\n this.constraints = calcRelativeConstraints(layout.layoutBox, dragConstraints);\n }\n else {\n this.constraints = false;\n }\n }\n this.elastic = resolveDragElastic(dragElastic);\n /**\n * If we're outputting to external MotionValues, we want to rebase the measured constraints\n * from viewport-relative to component-relative.\n */\n if (prevConstraints !== this.constraints &&\n layout &&\n this.constraints &&\n !this.hasMutatedConstraints) {\n eachAxis((axis) => {\n if (this.constraints !== false &&\n this.getAxisMotionValue(axis)) {\n this.constraints[axis] = rebaseAxisConstraints(layout.layoutBox[axis], this.constraints[axis]);\n }\n });\n }\n }\n resolveRefConstraints() {\n const { dragConstraints: constraints, onMeasureDragConstraints } = this.getProps();\n if (!constraints || !isRefObject(constraints))\n return false;\n const constraintsElement = constraints.current;\n invariant(constraintsElement !== null, \"If `dragConstraints` is set as a React ref, that ref must be passed to another component's `ref` prop.\");\n const { projection } = this.visualElement;\n // TODO\n if (!projection || !projection.layout)\n return false;\n const constraintsBox = measurePageBox(constraintsElement, projection.root, this.visualElement.getTransformPagePoint());\n let measuredConstraints = calcViewportConstraints(projection.layout.layoutBox, constraintsBox);\n /**\n * If there's an onMeasureDragConstraints listener we call it and\n * if different constraints are returned, set constraints to that\n */\n if (onMeasureDragConstraints) {\n const userConstraints = onMeasureDragConstraints(convertBoxToBoundingBox(measuredConstraints));\n this.hasMutatedConstraints = !!userConstraints;\n if (userConstraints) {\n measuredConstraints = convertBoundingBoxToBox(userConstraints);\n }\n }\n return measuredConstraints;\n }\n startAnimation(velocity) {\n const { drag, dragMomentum, dragElastic, dragTransition, dragSnapToOrigin, onDragTransitionEnd, } = this.getProps();\n const constraints = this.constraints || {};\n const momentumAnimations = eachAxis((axis) => {\n if (!shouldDrag(axis, drag, this.currentDirection)) {\n return;\n }\n let transition = (constraints && constraints[axis]) || {};\n if (dragSnapToOrigin)\n transition = { min: 0, max: 0 };\n /**\n * Overdamp the boundary spring if `dragElastic` is disabled. There's still a frame\n * of spring animations so we should look into adding a disable spring option to `inertia`.\n * We could do something here where we affect the `bounceStiffness` and `bounceDamping`\n * using the value of `dragElastic`.\n */\n const bounceStiffness = dragElastic ? 200 : 1000000;\n const bounceDamping = dragElastic ? 40 : 10000000;\n const inertia = {\n type: \"inertia\",\n velocity: dragMomentum ? velocity[axis] : 0,\n bounceStiffness,\n bounceDamping,\n timeConstant: 750,\n restDelta: 1,\n restSpeed: 10,\n ...dragTransition,\n ...transition,\n };\n // If we're not animating on an externally-provided `MotionValue` we can use the\n // component's animation controls which will handle interactions with whileHover (etc),\n // otherwise we just have to animate the `MotionValue` itself.\n return this.startAxisValueAnimation(axis, inertia);\n });\n // Run all animations and then resolve the new drag constraints.\n return Promise.all(momentumAnimations).then(onDragTransitionEnd);\n }\n startAxisValueAnimation(axis, transition) {\n const axisValue = this.getAxisMotionValue(axis);\n return axisValue.start(animateMotionValue(axis, axisValue, 0, transition, this.visualElement, false, addValueToWillChange(this.visualElement, axis)));\n }\n stopAnimation() {\n eachAxis((axis) => this.getAxisMotionValue(axis).stop());\n }\n pauseAnimation() {\n eachAxis((axis) => { var _a; return (_a = this.getAxisMotionValue(axis).animation) === null || _a === void 0 ? void 0 : _a.pause(); });\n }\n getAnimationState(axis) {\n var _a;\n return (_a = this.getAxisMotionValue(axis).animation) === null || _a === void 0 ? void 0 : _a.state;\n }\n /**\n * Drag works differently depending on which props are provided.\n *\n * - If _dragX and _dragY are provided, we output the gesture delta directly to those motion values.\n * - Otherwise, we apply the delta to the x/y motion values.\n */\n getAxisMotionValue(axis) {\n const dragKey = `_drag${axis.toUpperCase()}`;\n const props = this.visualElement.getProps();\n const externalMotionValue = props[dragKey];\n return externalMotionValue\n ? externalMotionValue\n : this.visualElement.getValue(axis, (props.initial\n ? props.initial[axis]\n : undefined) || 0);\n }\n snapToCursor(point) {\n eachAxis((axis) => {\n const { drag } = this.getProps();\n // If we're not dragging this axis, do an early return.\n if (!shouldDrag(axis, drag, this.currentDirection))\n return;\n const { projection } = this.visualElement;\n const axisValue = this.getAxisMotionValue(axis);\n if (projection && projection.layout) {\n const { min, max } = projection.layout.layoutBox[axis];\n axisValue.set(point[axis] - mixNumber(min, max, 0.5));\n }\n });\n }\n /**\n * When the viewport resizes we want to check if the measured constraints\n * have changed and, if so, reposition the element within those new constraints\n * relative to where it was before the resize.\n */\n scalePositionWithinConstraints() {\n if (!this.visualElement.current)\n return;\n const { drag, dragConstraints } = this.getProps();\n const { projection } = this.visualElement;\n if (!isRefObject(dragConstraints) || !projection || !this.constraints)\n return;\n /**\n * Stop current animations as there can be visual glitching if we try to do\n * this mid-animation\n */\n this.stopAnimation();\n /**\n * Record the relative position of the dragged element relative to the\n * constraints box and save as a progress value.\n */\n const boxProgress = { x: 0, y: 0 };\n eachAxis((axis) => {\n const axisValue = this.getAxisMotionValue(axis);\n if (axisValue && this.constraints !== false) {\n const latest = axisValue.get();\n boxProgress[axis] = calcOrigin({ min: latest, max: latest }, this.constraints[axis]);\n }\n });\n /**\n * Update the layout of this element and resolve the latest drag constraints\n */\n const { transformTemplate } = this.visualElement.getProps();\n this.visualElement.current.style.transform = transformTemplate\n ? transformTemplate({}, \"\")\n : \"none\";\n projection.root && projection.root.updateScroll();\n projection.updateLayout();\n this.resolveConstraints();\n /**\n * For each axis, calculate the current progress of the layout axis\n * within the new constraints.\n */\n eachAxis((axis) => {\n if (!shouldDrag(axis, drag, null))\n return;\n /**\n * Calculate a new transform based on the previous box progress\n */\n const axisValue = this.getAxisMotionValue(axis);\n const { min, max } = this.constraints[axis];\n axisValue.set(mixNumber(min, max, boxProgress[axis]));\n });\n }\n addListeners() {\n if (!this.visualElement.current)\n return;\n elementDragControls.set(this.visualElement, this);\n const element = this.visualElement.current;\n /**\n * Attach a pointerdown event listener on this DOM element to initiate drag tracking.\n */\n const stopPointerListener = addPointerEvent(element, \"pointerdown\", (event) => {\n const { drag, dragListener = true } = this.getProps();\n drag && dragListener && this.start(event);\n });\n const measureDragConstraints = () => {\n const { dragConstraints } = this.getProps();\n if (isRefObject(dragConstraints) && dragConstraints.current) {\n this.constraints = this.resolveRefConstraints();\n }\n };\n const { projection } = this.visualElement;\n const stopMeasureLayoutListener = projection.addEventListener(\"measure\", measureDragConstraints);\n if (projection && !projection.layout) {\n projection.root && projection.root.updateScroll();\n projection.updateLayout();\n }\n frame.read(measureDragConstraints);\n /**\n * Attach a window resize listener to scale the draggable target within its defined\n * constraints as the window resizes.\n */\n const stopResizeListener = addDomEvent(window, \"resize\", () => this.scalePositionWithinConstraints());\n /**\n * If the element's layout changes, calculate the delta and apply that to\n * the drag gesture's origin point.\n */\n const stopLayoutUpdateListener = projection.addEventListener(\"didUpdate\", (({ delta, hasLayoutChanged }) => {\n if (this.isDragging && hasLayoutChanged) {\n eachAxis((axis) => {\n const motionValue = this.getAxisMotionValue(axis);\n if (!motionValue)\n return;\n this.originPoint[axis] += delta[axis].translate;\n motionValue.set(motionValue.get() + delta[axis].translate);\n });\n this.visualElement.render();\n }\n }));\n return () => {\n stopResizeListener();\n stopPointerListener();\n stopMeasureLayoutListener();\n stopLayoutUpdateListener && stopLayoutUpdateListener();\n };\n }\n getProps() {\n const props = this.visualElement.getProps();\n const { drag = false, dragDirectionLock = false, dragPropagation = false, dragConstraints = false, dragElastic = defaultElastic, dragMomentum = true, } = props;\n return {\n ...props,\n drag,\n dragDirectionLock,\n dragPropagation,\n dragConstraints,\n dragElastic,\n dragMomentum,\n };\n }\n}\nfunction shouldDrag(direction, drag, currentDirection) {\n return ((drag === true || drag === direction) &&\n (currentDirection === null || currentDirection === direction));\n}\n/**\n * Based on an x/y offset determine the current drag direction. If both axis' offsets are lower\n * than the provided threshold, return `null`.\n *\n * @param offset - The x/y offset from origin.\n * @param lockThreshold - (Optional) - the minimum absolute offset before we can determine a drag direction.\n */\nfunction getCurrentDirection(offset, lockThreshold = 10) {\n let direction = null;\n if (Math.abs(offset.y) > lockThreshold) {\n direction = \"y\";\n }\n else if (Math.abs(offset.x) > lockThreshold) {\n direction = \"x\";\n }\n return direction;\n}\n\nexport { VisualElementDragControls, elementDragControls };\n","import { PanSession } from './PanSession.mjs';\nimport { addPointerEvent } from '../../events/add-pointer-event.mjs';\nimport { Feature } from '../../motion/features/Feature.mjs';\nimport { noop } from '../../utils/noop.mjs';\nimport { getContextWindow } from '../../utils/get-context-window.mjs';\nimport { frame } from '../../frameloop/frame.mjs';\n\nconst asyncHandler = (handler) => (event, info) => {\n if (handler) {\n frame.postRender(() => handler(event, info));\n }\n};\nclass PanGesture extends Feature {\n constructor() {\n super(...arguments);\n this.removePointerDownListener = noop;\n }\n onPointerDown(pointerDownEvent) {\n this.session = new PanSession(pointerDownEvent, this.createPanHandlers(), {\n transformPagePoint: this.node.getTransformPagePoint(),\n contextWindow: getContextWindow(this.node),\n });\n }\n createPanHandlers() {\n const { onPanSessionStart, onPanStart, onPan, onPanEnd } = this.node.getProps();\n return {\n onSessionStart: asyncHandler(onPanSessionStart),\n onStart: asyncHandler(onPanStart),\n onMove: onPan,\n onEnd: (event, info) => {\n delete this.session;\n if (onPanEnd) {\n frame.postRender(() => onPanEnd(event, info));\n }\n },\n };\n }\n mount() {\n this.removePointerDownListener = addPointerEvent(this.node.current, \"pointerdown\", (event) => this.onPointerDown(event));\n }\n update() {\n this.session && this.session.updateHandlers(this.createPanHandlers());\n }\n unmount() {\n this.removePointerDownListener();\n this.session && this.session.end();\n }\n}\n\nexport { PanGesture };\n","/**\n * This should only ever be modified on the client otherwise it'll\n * persist through server requests. If we need instanced states we\n * could lazy-init via root.\n */\nconst globalProjectionState = {\n /**\n * Global flag as to whether the tree has animated since the last time\n * we resized the window\n */\n hasAnimatedSinceResize: true,\n /**\n * We set this to true once, on the first update. Any nodes added to the tree beyond that\n * update will be given a `data-projection-id` attribute.\n */\n hasEverUpdated: false,\n};\n\nexport { globalProjectionState };\n","import { px } from '../../value/types/numbers/units.mjs';\n\nfunction pixelsToPercent(pixels, axis) {\n if (axis.max === axis.min)\n return 0;\n return (pixels / (axis.max - axis.min)) * 100;\n}\n/**\n * We always correct borderRadius as a percentage rather than pixels to reduce paints.\n * For example, if you are projecting a box that is 100px wide with a 10px borderRadius\n * into a box that is 200px wide with a 20px borderRadius, that is actually a 10%\n * borderRadius in both states. If we animate between the two in pixels that will trigger\n * a paint each time. If we animate between the two in percentage we'll avoid a paint.\n */\nconst correctBorderRadius = {\n correct: (latest, node) => {\n if (!node.target)\n return latest;\n /**\n * If latest is a string, if it's a percentage we can return immediately as it's\n * going to be stretched appropriately. Otherwise, if it's a pixel, convert it to a number.\n */\n if (typeof latest === \"string\") {\n if (px.test(latest)) {\n latest = parseFloat(latest);\n }\n else {\n return latest;\n }\n }\n /**\n * If latest is a number, it's a pixel value. We use the current viewportBox to calculate that\n * pixel value as a percentage of each axis\n */\n const x = pixelsToPercent(latest, node.target.x);\n const y = pixelsToPercent(latest, node.target.y);\n return `${x}% ${y}%`;\n },\n};\n\nexport { correctBorderRadius, pixelsToPercent };\n","import { mixNumber } from '../../utils/mix/number.mjs';\nimport { complex } from '../../value/types/complex/index.mjs';\n\nconst correctBoxShadow = {\n correct: (latest, { treeScale, projectionDelta }) => {\n const original = latest;\n const shadow = complex.parse(latest);\n // TODO: Doesn't support multiple shadows\n if (shadow.length > 5)\n return original;\n const template = complex.createTransformer(latest);\n const offset = typeof shadow[0] !== \"number\" ? 1 : 0;\n // Calculate the overall context scale\n const xScale = projectionDelta.x.scale * treeScale.x;\n const yScale = projectionDelta.y.scale * treeScale.y;\n shadow[0 + offset] /= xScale;\n shadow[1 + offset] /= yScale;\n /**\n * Ideally we'd correct x and y scales individually, but because blur and\n * spread apply to both we have to take a scale average and apply that instead.\n * We could potentially improve the outcome of this by incorporating the ratio between\n * the two scales.\n */\n const averageScale = mixNumber(xScale, yScale, 0.5);\n // Blur\n if (typeof shadow[2 + offset] === \"number\")\n shadow[2 + offset] /= averageScale;\n // Spread\n if (typeof shadow[3 + offset] === \"number\")\n shadow[3 + offset] /= averageScale;\n return template(shadow);\n },\n};\n\nexport { correctBoxShadow };\n","import { jsx } from 'react/jsx-runtime';\nimport { useContext, Component } from 'react';\nimport { usePresence } from '../../../components/AnimatePresence/use-presence.mjs';\nimport { LayoutGroupContext } from '../../../context/LayoutGroupContext.mjs';\nimport { SwitchLayoutGroupContext } from '../../../context/SwitchLayoutGroupContext.mjs';\nimport { globalProjectionState } from '../../../projection/node/state.mjs';\nimport { correctBorderRadius } from '../../../projection/styles/scale-border-radius.mjs';\nimport { correctBoxShadow } from '../../../projection/styles/scale-box-shadow.mjs';\nimport { addScaleCorrector } from '../../../projection/styles/scale-correction.mjs';\nimport { microtask } from '../../../frameloop/microtask.mjs';\nimport { frame } from '../../../frameloop/frame.mjs';\n\nclass MeasureLayoutWithContext extends Component {\n /**\n * This only mounts projection nodes for components that\n * need measuring, we might want to do it for all components\n * in order to incorporate transforms\n */\n componentDidMount() {\n const { visualElement, layoutGroup, switchLayoutGroup, layoutId } = this.props;\n const { projection } = visualElement;\n addScaleCorrector(defaultScaleCorrectors);\n if (projection) {\n if (layoutGroup.group)\n layoutGroup.group.add(projection);\n if (switchLayoutGroup && switchLayoutGroup.register && layoutId) {\n switchLayoutGroup.register(projection);\n }\n projection.root.didUpdate();\n projection.addEventListener(\"animationComplete\", () => {\n this.safeToRemove();\n });\n projection.setOptions({\n ...projection.options,\n onExitComplete: () => this.safeToRemove(),\n });\n }\n globalProjectionState.hasEverUpdated = true;\n }\n getSnapshotBeforeUpdate(prevProps) {\n const { layoutDependency, visualElement, drag, isPresent } = this.props;\n const projection = visualElement.projection;\n if (!projection)\n return null;\n /**\n * TODO: We use this data in relegate to determine whether to\n * promote a previous element. There's no guarantee its presence data\n * will have updated by this point - if a bug like this arises it will\n * have to be that we markForRelegation and then find a new lead some other way,\n * perhaps in didUpdate\n */\n projection.isPresent = isPresent;\n if (drag ||\n prevProps.layoutDependency !== layoutDependency ||\n layoutDependency === undefined) {\n projection.willUpdate();\n }\n else {\n this.safeToRemove();\n }\n if (prevProps.isPresent !== isPresent) {\n if (isPresent) {\n projection.promote();\n }\n else if (!projection.relegate()) {\n /**\n * If there's another stack member taking over from this one,\n * it's in charge of the exit animation and therefore should\n * be in charge of the safe to remove. Otherwise we call it here.\n */\n frame.postRender(() => {\n const stack = projection.getStack();\n if (!stack || !stack.members.length) {\n this.safeToRemove();\n }\n });\n }\n }\n return null;\n }\n componentDidUpdate() {\n const { projection } = this.props.visualElement;\n if (projection) {\n projection.root.didUpdate();\n microtask.postRender(() => {\n if (!projection.currentAnimation && projection.isLead()) {\n this.safeToRemove();\n }\n });\n }\n }\n componentWillUnmount() {\n const { visualElement, layoutGroup, switchLayoutGroup: promoteContext, } = this.props;\n const { projection } = visualElement;\n if (projection) {\n projection.scheduleCheckAfterUnmount();\n if (layoutGroup && layoutGroup.group)\n layoutGroup.group.remove(projection);\n if (promoteContext && promoteContext.deregister)\n promoteContext.deregister(projection);\n }\n }\n safeToRemove() {\n const { safeToRemove } = this.props;\n safeToRemove && safeToRemove();\n }\n render() {\n return null;\n }\n}\nfunction MeasureLayout(props) {\n const [isPresent, safeToRemove] = usePresence();\n const layoutGroup = useContext(LayoutGroupContext);\n return (jsx(MeasureLayoutWithContext, { ...props, layoutGroup: layoutGroup, switchLayoutGroup: useContext(SwitchLayoutGroupContext), isPresent: isPresent, safeToRemove: safeToRemove }));\n}\nconst defaultScaleCorrectors = {\n borderRadius: {\n ...correctBorderRadius,\n applyTo: [\n \"borderTopLeftRadius\",\n \"borderTopRightRadius\",\n \"borderBottomLeftRadius\",\n \"borderBottomRightRadius\",\n ],\n },\n borderTopLeftRadius: correctBorderRadius,\n borderTopRightRadius: correctBorderRadius,\n borderBottomLeftRadius: correctBorderRadius,\n borderBottomRightRadius: correctBorderRadius,\n boxShadow: correctBoxShadow,\n};\n\nexport { MeasureLayout };\n","import { useContext, useId, useEffect, useCallback } from 'react';\nimport { PresenceContext } from '../../context/PresenceContext.mjs';\n\n/**\n * When a component is the child of `AnimatePresence`, it can use `usePresence`\n * to access information about whether it's still present in the React tree.\n *\n * ```jsx\n * import { usePresence } from \"framer-motion\"\n *\n * export const Component = () => {\n * const [isPresent, safeToRemove] = usePresence()\n *\n * useEffect(() => {\n * !isPresent && setTimeout(safeToRemove, 1000)\n * }, [isPresent])\n *\n * return
\n * }\n * ```\n *\n * If `isPresent` is `false`, it means that a component has been removed the tree, but\n * `AnimatePresence` won't really remove it until `safeToRemove` has been called.\n *\n * @public\n */\nfunction usePresence() {\n const context = useContext(PresenceContext);\n if (context === null)\n return [true, null];\n const { isPresent, onExitComplete, register } = context;\n // It's safe to call the following hooks conditionally (after an early return) because the context will always\n // either be null or non-null for the lifespan of the component.\n const id = useId();\n useEffect(() => register(id), []);\n const safeToRemove = useCallback(() => onExitComplete && onExitComplete(id), [id, onExitComplete]);\n return !isPresent && onExitComplete ? [false, safeToRemove] : [true];\n}\n/**\n * Similar to `usePresence`, except `useIsPresent` simply returns whether or not the component is present.\n * There is no `safeToRemove` function.\n *\n * ```jsx\n * import { useIsPresent } from \"framer-motion\"\n *\n * export const Component = () => {\n * const isPresent = useIsPresent()\n *\n * useEffect(() => {\n * !isPresent && console.log(\"I've been removed!\")\n * }, [isPresent])\n *\n * return
\n * }\n * ```\n *\n * @public\n */\nfunction useIsPresent() {\n return isPresent(useContext(PresenceContext));\n}\nfunction isPresent(context) {\n return context === null ? true : context.isPresent;\n}\n\nexport { isPresent, useIsPresent, usePresence };\n","import { circOut } from '../../easing/circ.mjs';\nimport { progress } from '../../utils/progress.mjs';\nimport { mixNumber } from '../../utils/mix/number.mjs';\nimport { noop } from '../../utils/noop.mjs';\nimport { percent, px } from '../../value/types/numbers/units.mjs';\n\nconst borders = [\"TopLeft\", \"TopRight\", \"BottomLeft\", \"BottomRight\"];\nconst numBorders = borders.length;\nconst asNumber = (value) => typeof value === \"string\" ? parseFloat(value) : value;\nconst isPx = (value) => typeof value === \"number\" || px.test(value);\nfunction mixValues(target, follow, lead, progress, shouldCrossfadeOpacity, isOnlyMember) {\n if (shouldCrossfadeOpacity) {\n target.opacity = mixNumber(0, \n // TODO Reinstate this if only child\n lead.opacity !== undefined ? lead.opacity : 1, easeCrossfadeIn(progress));\n target.opacityExit = mixNumber(follow.opacity !== undefined ? follow.opacity : 1, 0, easeCrossfadeOut(progress));\n }\n else if (isOnlyMember) {\n target.opacity = mixNumber(follow.opacity !== undefined ? follow.opacity : 1, lead.opacity !== undefined ? lead.opacity : 1, progress);\n }\n /**\n * Mix border radius\n */\n for (let i = 0; i < numBorders; i++) {\n const borderLabel = `border${borders[i]}Radius`;\n let followRadius = getRadius(follow, borderLabel);\n let leadRadius = getRadius(lead, borderLabel);\n if (followRadius === undefined && leadRadius === undefined)\n continue;\n followRadius || (followRadius = 0);\n leadRadius || (leadRadius = 0);\n const canMix = followRadius === 0 ||\n leadRadius === 0 ||\n isPx(followRadius) === isPx(leadRadius);\n if (canMix) {\n target[borderLabel] = Math.max(mixNumber(asNumber(followRadius), asNumber(leadRadius), progress), 0);\n if (percent.test(leadRadius) || percent.test(followRadius)) {\n target[borderLabel] += \"%\";\n }\n }\n else {\n target[borderLabel] = leadRadius;\n }\n }\n /**\n * Mix rotation\n */\n if (follow.rotate || lead.rotate) {\n target.rotate = mixNumber(follow.rotate || 0, lead.rotate || 0, progress);\n }\n}\nfunction getRadius(values, radiusName) {\n return values[radiusName] !== undefined\n ? values[radiusName]\n : values.borderRadius;\n}\n// /**\n// * We only want to mix the background color if there's a follow element\n// * that we're not crossfading opacity between. For instance with switch\n// * AnimateSharedLayout animations, this helps the illusion of a continuous\n// * element being animated but also cuts down on the number of paints triggered\n// * for elements where opacity is doing that work for us.\n// */\n// if (\n// !hasFollowElement &&\n// latestLeadValues.backgroundColor &&\n// latestFollowValues.backgroundColor\n// ) {\n// /**\n// * This isn't ideal performance-wise as mixColor is creating a new function every frame.\n// * We could probably create a mixer that runs at the start of the animation but\n// * the idea behind the crossfader is that it runs dynamically between two potentially\n// * changing targets (ie opacity or borderRadius may be animating independently via variants)\n// */\n// leadState.backgroundColor = followState.backgroundColor = mixColor(\n// latestFollowValues.backgroundColor as string,\n// latestLeadValues.backgroundColor as string\n// )(p)\n// }\nconst easeCrossfadeIn = compress(0, 0.5, circOut);\nconst easeCrossfadeOut = compress(0.5, 0.95, noop);\nfunction compress(min, max, easing) {\n return (p) => {\n // Could replace ifs with clamp\n if (p < min)\n return 0;\n if (p > max)\n return 1;\n return easing(progress(min, max, p));\n };\n}\n\nexport { mixValues };\n","/**\n * Reset an axis to the provided origin box.\n *\n * This is a mutative operation.\n */\nfunction copyAxisInto(axis, originAxis) {\n axis.min = originAxis.min;\n axis.max = originAxis.max;\n}\n/**\n * Reset a box to the provided origin box.\n *\n * This is a mutative operation.\n */\nfunction copyBoxInto(box, originBox) {\n copyAxisInto(box.x, originBox.x);\n copyAxisInto(box.y, originBox.y);\n}\n/**\n * Reset a delta to the provided origin box.\n *\n * This is a mutative operation.\n */\nfunction copyAxisDeltaInto(delta, originDelta) {\n delta.translate = originDelta.translate;\n delta.scale = originDelta.scale;\n delta.originPoint = originDelta.originPoint;\n delta.origin = originDelta.origin;\n}\n\nexport { copyAxisDeltaInto, copyAxisInto, copyBoxInto };\n","import { mixNumber } from '../../utils/mix/number.mjs';\nimport { percent } from '../../value/types/numbers/units.mjs';\nimport { scalePoint } from './delta-apply.mjs';\n\n/**\n * Remove a delta from a point. This is essentially the steps of applyPointDelta in reverse\n */\nfunction removePointDelta(point, translate, scale, originPoint, boxScale) {\n point -= translate;\n point = scalePoint(point, 1 / scale, originPoint);\n if (boxScale !== undefined) {\n point = scalePoint(point, 1 / boxScale, originPoint);\n }\n return point;\n}\n/**\n * Remove a delta from an axis. This is essentially the steps of applyAxisDelta in reverse\n */\nfunction removeAxisDelta(axis, translate = 0, scale = 1, origin = 0.5, boxScale, originAxis = axis, sourceAxis = axis) {\n if (percent.test(translate)) {\n translate = parseFloat(translate);\n const relativeProgress = mixNumber(sourceAxis.min, sourceAxis.max, translate / 100);\n translate = relativeProgress - sourceAxis.min;\n }\n if (typeof translate !== \"number\")\n return;\n let originPoint = mixNumber(originAxis.min, originAxis.max, origin);\n if (axis === originAxis)\n originPoint -= translate;\n axis.min = removePointDelta(axis.min, translate, scale, originPoint, boxScale);\n axis.max = removePointDelta(axis.max, translate, scale, originPoint, boxScale);\n}\n/**\n * Remove a transforms from an axis. This is essentially the steps of applyAxisTransforms in reverse\n * and acts as a bridge between motion values and removeAxisDelta\n */\nfunction removeAxisTransforms(axis, transforms, [key, scaleKey, originKey], origin, sourceAxis) {\n removeAxisDelta(axis, transforms[key], transforms[scaleKey], transforms[originKey], transforms.scale, origin, sourceAxis);\n}\n/**\n * The names of the motion values we want to apply as translation, scale and origin.\n */\nconst xKeys = [\"x\", \"scaleX\", \"originX\"];\nconst yKeys = [\"y\", \"scaleY\", \"originY\"];\n/**\n * Remove a transforms from an box. This is essentially the steps of applyAxisBox in reverse\n * and acts as a bridge between motion values and removeAxisDelta\n */\nfunction removeBoxTransforms(box, transforms, originBox, sourceBox) {\n removeAxisTransforms(box.x, transforms, xKeys, originBox ? originBox.x : undefined, sourceBox ? sourceBox.x : undefined);\n removeAxisTransforms(box.y, transforms, yKeys, originBox ? originBox.y : undefined, sourceBox ? sourceBox.y : undefined);\n}\n\nexport { removeAxisDelta, removeAxisTransforms, removeBoxTransforms, removePointDelta };\n","import { calcLength } from './delta-calc.mjs';\n\nfunction isAxisDeltaZero(delta) {\n return delta.translate === 0 && delta.scale === 1;\n}\nfunction isDeltaZero(delta) {\n return isAxisDeltaZero(delta.x) && isAxisDeltaZero(delta.y);\n}\nfunction axisEquals(a, b) {\n return a.min === b.min && a.max === b.max;\n}\nfunction boxEquals(a, b) {\n return axisEquals(a.x, b.x) && axisEquals(a.y, b.y);\n}\nfunction axisEqualsRounded(a, b) {\n return (Math.round(a.min) === Math.round(b.min) &&\n Math.round(a.max) === Math.round(b.max));\n}\nfunction boxEqualsRounded(a, b) {\n return axisEqualsRounded(a.x, b.x) && axisEqualsRounded(a.y, b.y);\n}\nfunction aspectRatio(box) {\n return calcLength(box.x) / calcLength(box.y);\n}\nfunction axisDeltaEquals(a, b) {\n return (a.translate === b.translate &&\n a.scale === b.scale &&\n a.originPoint === b.originPoint);\n}\n\nexport { aspectRatio, axisDeltaEquals, axisEquals, axisEqualsRounded, boxEquals, boxEqualsRounded, isDeltaZero };\n","import { addUniqueItem, removeItem } from '../../utils/array.mjs';\n\nclass NodeStack {\n constructor() {\n this.members = [];\n }\n add(node) {\n addUniqueItem(this.members, node);\n node.scheduleRender();\n }\n remove(node) {\n removeItem(this.members, node);\n if (node === this.prevLead) {\n this.prevLead = undefined;\n }\n if (node === this.lead) {\n const prevLead = this.members[this.members.length - 1];\n if (prevLead) {\n this.promote(prevLead);\n }\n }\n }\n relegate(node) {\n const indexOfNode = this.members.findIndex((member) => node === member);\n if (indexOfNode === 0)\n return false;\n /**\n * Find the next projection node that is present\n */\n let prevLead;\n for (let i = indexOfNode; i >= 0; i--) {\n const member = this.members[i];\n if (member.isPresent !== false) {\n prevLead = member;\n break;\n }\n }\n if (prevLead) {\n this.promote(prevLead);\n return true;\n }\n else {\n return false;\n }\n }\n promote(node, preserveFollowOpacity) {\n const prevLead = this.lead;\n if (node === prevLead)\n return;\n this.prevLead = prevLead;\n this.lead = node;\n node.show();\n if (prevLead) {\n prevLead.instance && prevLead.scheduleRender();\n node.scheduleRender();\n node.resumeFrom = prevLead;\n if (preserveFollowOpacity) {\n node.resumeFrom.preserveOpacity = true;\n }\n if (prevLead.snapshot) {\n node.snapshot = prevLead.snapshot;\n node.snapshot.latestValues =\n prevLead.animationValues || prevLead.latestValues;\n }\n if (node.root && node.root.isUpdating) {\n node.isLayoutDirty = true;\n }\n const { crossfade } = node.options;\n if (crossfade === false) {\n prevLead.hide();\n }\n /**\n * TODO:\n * - Test border radius when previous node was deleted\n * - boxShadow mixing\n * - Shared between element A in scrolled container and element B (scroll stays the same or changes)\n * - Shared between element A in transformed container and element B (transform stays the same or changes)\n * - Shared between element A in scrolled page and element B (scroll stays the same or changes)\n * ---\n * - Crossfade opacity of root nodes\n * - layoutId changes after animation\n * - layoutId changes mid animation\n */\n }\n }\n exitAnimationComplete() {\n this.members.forEach((node) => {\n const { options, resumingFrom } = node;\n options.onExitComplete && options.onExitComplete();\n if (resumingFrom) {\n resumingFrom.options.onExitComplete &&\n resumingFrom.options.onExitComplete();\n }\n });\n }\n scheduleRender() {\n this.members.forEach((node) => {\n node.instance && node.scheduleRender(false);\n });\n }\n /**\n * Clear any leads that have been removed this render to prevent them from being\n * used in future animations and to prevent memory leaks\n */\n removeLeadSnapshot() {\n if (this.lead && this.lead.snapshot) {\n this.lead.snapshot = undefined;\n }\n }\n}\n\nexport { NodeStack };\n","const compareByDepth = (a, b) => a.depth - b.depth;\n\nexport { compareByDepth };\n","import { addUniqueItem, removeItem } from '../../utils/array.mjs';\nimport { compareByDepth } from './compare-by-depth.mjs';\n\nclass FlatTree {\n constructor() {\n this.children = [];\n this.isDirty = false;\n }\n add(child) {\n addUniqueItem(this.children, child);\n this.isDirty = true;\n }\n remove(child) {\n removeItem(this.children, child);\n this.isDirty = true;\n }\n forEach(callback) {\n this.isDirty && this.children.sort(compareByDepth);\n this.isDirty = false;\n this.children.forEach(callback);\n }\n}\n\nexport { FlatTree };\n","import { SubscriptionManager } from '../../utils/subscription-manager.mjs';\nimport { mixValues } from '../animation/mix-values.mjs';\nimport { copyBoxInto, copyAxisDeltaInto } from '../geometry/copy.mjs';\nimport { translateAxis, transformBox, applyBoxDelta, applyTreeDeltas } from '../geometry/delta-apply.mjs';\nimport { calcRelativePosition, calcRelativeBox, calcBoxDelta, calcLength, isNear } from '../geometry/delta-calc.mjs';\nimport { removeBoxTransforms } from '../geometry/delta-remove.mjs';\nimport { getValueTransition } from '../../animation/utils/transitions.mjs';\nimport { boxEqualsRounded, isDeltaZero, axisDeltaEquals, aspectRatio, boxEquals } from '../geometry/utils.mjs';\nimport { NodeStack } from '../shared/stack.mjs';\nimport { scaleCorrectors } from '../styles/scale-correction.mjs';\nimport { buildProjectionTransform } from '../styles/transform.mjs';\nimport { eachAxis } from '../utils/each-axis.mjs';\nimport { hasTransform, hasScale, has2DTranslate } from '../utils/has-transform.mjs';\nimport { FlatTree } from '../../render/utils/flat-tree.mjs';\nimport { resolveMotionValue } from '../../value/utils/resolve-motion-value.mjs';\nimport { globalProjectionState } from './state.mjs';\nimport { delay } from '../../utils/delay.mjs';\nimport { mixNumber } from '../../utils/mix/number.mjs';\nimport { isSVGElement } from '../../render/dom/utils/is-svg-element.mjs';\nimport { animateSingleValue } from '../../animation/interfaces/single-value.mjs';\nimport { clamp } from '../../utils/clamp.mjs';\nimport { cancelFrame, frameData, steps, frame } from '../../frameloop/frame.mjs';\nimport { noop } from '../../utils/noop.mjs';\nimport { time } from '../../frameloop/sync-time.mjs';\nimport { microtask } from '../../frameloop/microtask.mjs';\nimport { getOptimisedAppearId } from '../../animation/optimized-appear/get-appear-id.mjs';\nimport { createBox, createDelta } from '../geometry/models.mjs';\n\nconst metrics = {\n type: \"projectionFrame\",\n totalNodes: 0,\n resolvedTargetDeltas: 0,\n recalculatedProjection: 0,\n};\nconst isDebug = typeof window !== \"undefined\" && window.MotionDebug !== undefined;\nconst transformAxes = [\"\", \"X\", \"Y\", \"Z\"];\nconst hiddenVisibility = { visibility: \"hidden\" };\n/**\n * We use 1000 as the animation target as 0-1000 maps better to pixels than 0-1\n * which has a noticeable difference in spring animations\n */\nconst animationTarget = 1000;\nlet id = 0;\nfunction resetDistortingTransform(key, visualElement, values, sharedAnimationValues) {\n const { latestValues } = visualElement;\n // Record the distorting transform and then temporarily set it to 0\n if (latestValues[key]) {\n values[key] = latestValues[key];\n visualElement.setStaticValue(key, 0);\n if (sharedAnimationValues) {\n sharedAnimationValues[key] = 0;\n }\n }\n}\nfunction cancelTreeOptimisedTransformAnimations(projectionNode) {\n projectionNode.hasCheckedOptimisedAppear = true;\n if (projectionNode.root === projectionNode)\n return;\n const { visualElement } = projectionNode.options;\n if (!visualElement)\n return;\n const appearId = getOptimisedAppearId(visualElement);\n if (window.MotionHasOptimisedTransformAnimation(appearId)) {\n window.MotionCancelOptimisedTransform(appearId);\n }\n const { parent } = projectionNode;\n if (parent && !parent.hasCheckedOptimisedAppear) {\n cancelTreeOptimisedTransformAnimations(parent);\n }\n}\nfunction createProjectionNode({ attachResizeListener, defaultParent, measureScroll, checkIsScrollRoot, resetTransform, }) {\n return class ProjectionNode {\n constructor(latestValues = {}, parent = defaultParent === null || defaultParent === void 0 ? void 0 : defaultParent()) {\n /**\n * A unique ID generated for every projection node.\n */\n this.id = id++;\n /**\n * An id that represents a unique session instigated by startUpdate.\n */\n this.animationId = 0;\n /**\n * A Set containing all this component's children. This is used to iterate\n * through the children.\n *\n * TODO: This could be faster to iterate as a flat array stored on the root node.\n */\n this.children = new Set();\n /**\n * Options for the node. We use this to configure what kind of layout animations\n * we should perform (if any).\n */\n this.options = {};\n /**\n * We use this to detect when its safe to shut down part of a projection tree.\n * We have to keep projecting children for scale correction and relative projection\n * until all their parents stop performing layout animations.\n */\n this.isTreeAnimating = false;\n this.isAnimationBlocked = false;\n /**\n * Flag to true if we think this layout has been changed. We can't always know this,\n * currently we set it to true every time a component renders, or if it has a layoutDependency\n * if that has changed between renders. Additionally, components can be grouped by LayoutGroup\n * and if one node is dirtied, they all are.\n */\n this.isLayoutDirty = false;\n /**\n * Flag to true if we think the projection calculations for this node needs\n * recalculating as a result of an updated transform or layout animation.\n */\n this.isProjectionDirty = false;\n /**\n * Flag to true if the layout *or* transform has changed. This then gets propagated\n * throughout the projection tree, forcing any element below to recalculate on the next frame.\n */\n this.isSharedProjectionDirty = false;\n /**\n * Flag transform dirty. This gets propagated throughout the whole tree but is only\n * respected by shared nodes.\n */\n this.isTransformDirty = false;\n /**\n * Block layout updates for instant layout transitions throughout the tree.\n */\n this.updateManuallyBlocked = false;\n this.updateBlockedByResize = false;\n /**\n * Set to true between the start of the first `willUpdate` call and the end of the `didUpdate`\n * call.\n */\n this.isUpdating = false;\n /**\n * If this is an SVG element we currently disable projection transforms\n */\n this.isSVG = false;\n /**\n * Flag to true (during promotion) if a node doing an instant layout transition needs to reset\n * its projection styles.\n */\n this.needsReset = false;\n /**\n * Flags whether this node should have its transform reset prior to measuring.\n */\n this.shouldResetTransform = false;\n /**\n * Store whether this node has been checked for optimised appear animations. As\n * effects fire bottom-up, and we want to look up the tree for appear animations,\n * this makes sure we only check each path once, stopping at nodes that\n * have already been checked.\n */\n this.hasCheckedOptimisedAppear = false;\n /**\n * An object representing the calculated contextual/accumulated/tree scale.\n * This will be used to scale calculcated projection transforms, as these are\n * calculated in screen-space but need to be scaled for elements to layoutly\n * make it to their calculated destinations.\n *\n * TODO: Lazy-init\n */\n this.treeScale = { x: 1, y: 1 };\n /**\n *\n */\n this.eventHandlers = new Map();\n this.hasTreeAnimated = false;\n // Note: Currently only running on root node\n this.updateScheduled = false;\n this.scheduleUpdate = () => this.update();\n this.projectionUpdateScheduled = false;\n this.checkUpdateFailed = () => {\n if (this.isUpdating) {\n this.isUpdating = false;\n this.clearAllSnapshots();\n }\n };\n /**\n * This is a multi-step process as shared nodes might be of different depths. Nodes\n * are sorted by depth order, so we need to resolve the entire tree before moving to\n * the next step.\n */\n this.updateProjection = () => {\n this.projectionUpdateScheduled = false;\n /**\n * Reset debug counts. Manually resetting rather than creating a new\n * object each frame.\n */\n if (isDebug) {\n metrics.totalNodes =\n metrics.resolvedTargetDeltas =\n metrics.recalculatedProjection =\n 0;\n }\n this.nodes.forEach(propagateDirtyNodes);\n this.nodes.forEach(resolveTargetDelta);\n this.nodes.forEach(calcProjection);\n this.nodes.forEach(cleanDirtyNodes);\n if (isDebug) {\n window.MotionDebug.record(metrics);\n }\n };\n /**\n * Frame calculations\n */\n this.resolvedRelativeTargetAt = 0.0;\n this.hasProjected = false;\n this.isVisible = true;\n this.animationProgress = 0;\n /**\n * Shared layout\n */\n // TODO Only running on root node\n this.sharedNodes = new Map();\n this.latestValues = latestValues;\n this.root = parent ? parent.root || parent : this;\n this.path = parent ? [...parent.path, parent] : [];\n this.parent = parent;\n this.depth = parent ? parent.depth + 1 : 0;\n for (let i = 0; i < this.path.length; i++) {\n this.path[i].shouldResetTransform = true;\n }\n if (this.root === this)\n this.nodes = new FlatTree();\n }\n addEventListener(name, handler) {\n if (!this.eventHandlers.has(name)) {\n this.eventHandlers.set(name, new SubscriptionManager());\n }\n return this.eventHandlers.get(name).add(handler);\n }\n notifyListeners(name, ...args) {\n const subscriptionManager = this.eventHandlers.get(name);\n subscriptionManager && subscriptionManager.notify(...args);\n }\n hasListeners(name) {\n return this.eventHandlers.has(name);\n }\n /**\n * Lifecycles\n */\n mount(instance, isLayoutDirty = this.root.hasTreeAnimated) {\n if (this.instance)\n return;\n this.isSVG = isSVGElement(instance);\n this.instance = instance;\n const { layoutId, layout, visualElement } = this.options;\n if (visualElement && !visualElement.current) {\n visualElement.mount(instance);\n }\n this.root.nodes.add(this);\n this.parent && this.parent.children.add(this);\n if (isLayoutDirty && (layout || layoutId)) {\n this.isLayoutDirty = true;\n }\n if (attachResizeListener) {\n let cancelDelay;\n const resizeUnblockUpdate = () => (this.root.updateBlockedByResize = false);\n attachResizeListener(instance, () => {\n this.root.updateBlockedByResize = true;\n cancelDelay && cancelDelay();\n cancelDelay = delay(resizeUnblockUpdate, 250);\n if (globalProjectionState.hasAnimatedSinceResize) {\n globalProjectionState.hasAnimatedSinceResize = false;\n this.nodes.forEach(finishAnimation);\n }\n });\n }\n if (layoutId) {\n this.root.registerSharedNode(layoutId, this);\n }\n // Only register the handler if it requires layout animation\n if (this.options.animate !== false &&\n visualElement &&\n (layoutId || layout)) {\n this.addEventListener(\"didUpdate\", ({ delta, hasLayoutChanged, hasRelativeTargetChanged, layout: newLayout, }) => {\n if (this.isTreeAnimationBlocked()) {\n this.target = undefined;\n this.relativeTarget = undefined;\n return;\n }\n // TODO: Check here if an animation exists\n const layoutTransition = this.options.transition ||\n visualElement.getDefaultTransition() ||\n defaultLayoutTransition;\n const { onLayoutAnimationStart, onLayoutAnimationComplete, } = visualElement.getProps();\n /**\n * The target layout of the element might stay the same,\n * but its position relative to its parent has changed.\n */\n const targetChanged = !this.targetLayout ||\n !boxEqualsRounded(this.targetLayout, newLayout) ||\n hasRelativeTargetChanged;\n /**\n * If the layout hasn't seemed to have changed, it might be that the\n * element is visually in the same place in the document but its position\n * relative to its parent has indeed changed. So here we check for that.\n */\n const hasOnlyRelativeTargetChanged = !hasLayoutChanged && hasRelativeTargetChanged;\n if (this.options.layoutRoot ||\n (this.resumeFrom && this.resumeFrom.instance) ||\n hasOnlyRelativeTargetChanged ||\n (hasLayoutChanged &&\n (targetChanged || !this.currentAnimation))) {\n if (this.resumeFrom) {\n this.resumingFrom = this.resumeFrom;\n this.resumingFrom.resumingFrom = undefined;\n }\n this.setAnimationOrigin(delta, hasOnlyRelativeTargetChanged);\n const animationOptions = {\n ...getValueTransition(layoutTransition, \"layout\"),\n onPlay: onLayoutAnimationStart,\n onComplete: onLayoutAnimationComplete,\n };\n if (visualElement.shouldReduceMotion ||\n this.options.layoutRoot) {\n animationOptions.delay = 0;\n animationOptions.type = false;\n }\n this.startAnimation(animationOptions);\n }\n else {\n /**\n * If the layout hasn't changed and we have an animation that hasn't started yet,\n * finish it immediately. Otherwise it will be animating from a location\n * that was probably never commited to screen and look like a jumpy box.\n */\n if (!hasLayoutChanged) {\n finishAnimation(this);\n }\n if (this.isLead() && this.options.onExitComplete) {\n this.options.onExitComplete();\n }\n }\n this.targetLayout = newLayout;\n });\n }\n }\n unmount() {\n this.options.layoutId && this.willUpdate();\n this.root.nodes.remove(this);\n const stack = this.getStack();\n stack && stack.remove(this);\n this.parent && this.parent.children.delete(this);\n this.instance = undefined;\n cancelFrame(this.updateProjection);\n }\n // only on the root\n blockUpdate() {\n this.updateManuallyBlocked = true;\n }\n unblockUpdate() {\n this.updateManuallyBlocked = false;\n }\n isUpdateBlocked() {\n return this.updateManuallyBlocked || this.updateBlockedByResize;\n }\n isTreeAnimationBlocked() {\n return (this.isAnimationBlocked ||\n (this.parent && this.parent.isTreeAnimationBlocked()) ||\n false);\n }\n // Note: currently only running on root node\n startUpdate() {\n if (this.isUpdateBlocked())\n return;\n this.isUpdating = true;\n this.nodes && this.nodes.forEach(resetSkewAndRotation);\n this.animationId++;\n }\n getTransformTemplate() {\n const { visualElement } = this.options;\n return visualElement && visualElement.getProps().transformTemplate;\n }\n willUpdate(shouldNotifyListeners = true) {\n this.root.hasTreeAnimated = true;\n if (this.root.isUpdateBlocked()) {\n this.options.onExitComplete && this.options.onExitComplete();\n return;\n }\n /**\n * If we're running optimised appear animations then these must be\n * cancelled before measuring the DOM. This is so we can measure\n * the true layout of the element rather than the WAAPI animation\n * which will be unaffected by the resetSkewAndRotate step.\n *\n * Note: This is a DOM write. Worst case scenario is this is sandwiched\n * between other snapshot reads which will cause unnecessary style recalculations.\n * This has to happen here though, as we don't yet know which nodes will need\n * snapshots in startUpdate(), but we only want to cancel optimised animations\n * if a layout animation measurement is actually going to be affected by them.\n */\n if (window.MotionCancelOptimisedTransform &&\n !this.hasCheckedOptimisedAppear) {\n cancelTreeOptimisedTransformAnimations(this);\n }\n !this.root.isUpdating && this.root.startUpdate();\n if (this.isLayoutDirty)\n return;\n this.isLayoutDirty = true;\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n node.shouldResetTransform = true;\n node.updateScroll(\"snapshot\");\n if (node.options.layoutRoot) {\n node.willUpdate(false);\n }\n }\n const { layoutId, layout } = this.options;\n if (layoutId === undefined && !layout)\n return;\n const transformTemplate = this.getTransformTemplate();\n this.prevTransformTemplateValue = transformTemplate\n ? transformTemplate(this.latestValues, \"\")\n : undefined;\n this.updateSnapshot();\n shouldNotifyListeners && this.notifyListeners(\"willUpdate\");\n }\n update() {\n this.updateScheduled = false;\n const updateWasBlocked = this.isUpdateBlocked();\n // When doing an instant transition, we skip the layout update,\n // but should still clean up the measurements so that the next\n // snapshot could be taken correctly.\n if (updateWasBlocked) {\n this.unblockUpdate();\n this.clearAllSnapshots();\n this.nodes.forEach(clearMeasurements);\n return;\n }\n if (!this.isUpdating) {\n this.nodes.forEach(clearIsLayoutDirty);\n }\n this.isUpdating = false;\n /**\n * Write\n */\n this.nodes.forEach(resetTransformStyle);\n /**\n * Read ==================\n */\n // Update layout measurements of updated children\n this.nodes.forEach(updateLayout);\n /**\n * Write\n */\n // Notify listeners that the layout is updated\n this.nodes.forEach(notifyLayoutUpdate);\n this.clearAllSnapshots();\n /**\n * Manually flush any pending updates. Ideally\n * we could leave this to the following requestAnimationFrame but this seems\n * to leave a flash of incorrectly styled content.\n */\n const now = time.now();\n frameData.delta = clamp(0, 1000 / 60, now - frameData.timestamp);\n frameData.timestamp = now;\n frameData.isProcessing = true;\n steps.update.process(frameData);\n steps.preRender.process(frameData);\n steps.render.process(frameData);\n frameData.isProcessing = false;\n }\n didUpdate() {\n if (!this.updateScheduled) {\n this.updateScheduled = true;\n microtask.read(this.scheduleUpdate);\n }\n }\n clearAllSnapshots() {\n this.nodes.forEach(clearSnapshot);\n this.sharedNodes.forEach(removeLeadSnapshots);\n }\n scheduleUpdateProjection() {\n if (!this.projectionUpdateScheduled) {\n this.projectionUpdateScheduled = true;\n frame.preRender(this.updateProjection, false, true);\n }\n }\n scheduleCheckAfterUnmount() {\n /**\n * If the unmounting node is in a layoutGroup and did trigger a willUpdate,\n * we manually call didUpdate to give a chance to the siblings to animate.\n * Otherwise, cleanup all snapshots to prevents future nodes from reusing them.\n */\n frame.postRender(() => {\n if (this.isLayoutDirty) {\n this.root.didUpdate();\n }\n else {\n this.root.checkUpdateFailed();\n }\n });\n }\n /**\n * Update measurements\n */\n updateSnapshot() {\n if (this.snapshot || !this.instance)\n return;\n this.snapshot = this.measure();\n }\n updateLayout() {\n if (!this.instance)\n return;\n // TODO: Incorporate into a forwarded scroll offset\n this.updateScroll();\n if (!(this.options.alwaysMeasureLayout && this.isLead()) &&\n !this.isLayoutDirty) {\n return;\n }\n /**\n * When a node is mounted, it simply resumes from the prevLead's\n * snapshot instead of taking a new one, but the ancestors scroll\n * might have updated while the prevLead is unmounted. We need to\n * update the scroll again to make sure the layout we measure is\n * up to date.\n */\n if (this.resumeFrom && !this.resumeFrom.instance) {\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n node.updateScroll();\n }\n }\n const prevLayout = this.layout;\n this.layout = this.measure(false);\n this.layoutCorrected = createBox();\n this.isLayoutDirty = false;\n this.projectionDelta = undefined;\n this.notifyListeners(\"measure\", this.layout.layoutBox);\n const { visualElement } = this.options;\n visualElement &&\n visualElement.notify(\"LayoutMeasure\", this.layout.layoutBox, prevLayout ? prevLayout.layoutBox : undefined);\n }\n updateScroll(phase = \"measure\") {\n let needsMeasurement = Boolean(this.options.layoutScroll && this.instance);\n if (this.scroll &&\n this.scroll.animationId === this.root.animationId &&\n this.scroll.phase === phase) {\n needsMeasurement = false;\n }\n if (needsMeasurement) {\n const isRoot = checkIsScrollRoot(this.instance);\n this.scroll = {\n animationId: this.root.animationId,\n phase,\n isRoot,\n offset: measureScroll(this.instance),\n wasRoot: this.scroll ? this.scroll.isRoot : isRoot,\n };\n }\n }\n resetTransform() {\n if (!resetTransform)\n return;\n const isResetRequested = this.isLayoutDirty ||\n this.shouldResetTransform ||\n this.options.alwaysMeasureLayout;\n const hasProjection = this.projectionDelta && !isDeltaZero(this.projectionDelta);\n const transformTemplate = this.getTransformTemplate();\n const transformTemplateValue = transformTemplate\n ? transformTemplate(this.latestValues, \"\")\n : undefined;\n const transformTemplateHasChanged = transformTemplateValue !== this.prevTransformTemplateValue;\n if (isResetRequested &&\n (hasProjection ||\n hasTransform(this.latestValues) ||\n transformTemplateHasChanged)) {\n resetTransform(this.instance, transformTemplateValue);\n this.shouldResetTransform = false;\n this.scheduleRender();\n }\n }\n measure(removeTransform = true) {\n const pageBox = this.measurePageBox();\n let layoutBox = this.removeElementScroll(pageBox);\n /**\n * Measurements taken during the pre-render stage\n * still have transforms applied so we remove them\n * via calculation.\n */\n if (removeTransform) {\n layoutBox = this.removeTransform(layoutBox);\n }\n roundBox(layoutBox);\n return {\n animationId: this.root.animationId,\n measuredBox: pageBox,\n layoutBox,\n latestValues: {},\n source: this.id,\n };\n }\n measurePageBox() {\n var _a;\n const { visualElement } = this.options;\n if (!visualElement)\n return createBox();\n const box = visualElement.measureViewportBox();\n const wasInScrollRoot = ((_a = this.scroll) === null || _a === void 0 ? void 0 : _a.wasRoot) || this.path.some(checkNodeWasScrollRoot);\n if (!wasInScrollRoot) {\n // Remove viewport scroll to give page-relative coordinates\n const { scroll } = this.root;\n if (scroll) {\n translateAxis(box.x, scroll.offset.x);\n translateAxis(box.y, scroll.offset.y);\n }\n }\n return box;\n }\n removeElementScroll(box) {\n var _a;\n const boxWithoutScroll = createBox();\n copyBoxInto(boxWithoutScroll, box);\n if ((_a = this.scroll) === null || _a === void 0 ? void 0 : _a.wasRoot) {\n return boxWithoutScroll;\n }\n /**\n * Performance TODO: Keep a cumulative scroll offset down the tree\n * rather than loop back up the path.\n */\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n const { scroll, options } = node;\n if (node !== this.root && scroll && options.layoutScroll) {\n /**\n * If this is a new scroll root, we want to remove all previous scrolls\n * from the viewport box.\n */\n if (scroll.wasRoot) {\n copyBoxInto(boxWithoutScroll, box);\n }\n translateAxis(boxWithoutScroll.x, scroll.offset.x);\n translateAxis(boxWithoutScroll.y, scroll.offset.y);\n }\n }\n return boxWithoutScroll;\n }\n applyTransform(box, transformOnly = false) {\n const withTransforms = createBox();\n copyBoxInto(withTransforms, box);\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n if (!transformOnly &&\n node.options.layoutScroll &&\n node.scroll &&\n node !== node.root) {\n transformBox(withTransforms, {\n x: -node.scroll.offset.x,\n y: -node.scroll.offset.y,\n });\n }\n if (!hasTransform(node.latestValues))\n continue;\n transformBox(withTransforms, node.latestValues);\n }\n if (hasTransform(this.latestValues)) {\n transformBox(withTransforms, this.latestValues);\n }\n return withTransforms;\n }\n removeTransform(box) {\n const boxWithoutTransform = createBox();\n copyBoxInto(boxWithoutTransform, box);\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n if (!node.instance)\n continue;\n if (!hasTransform(node.latestValues))\n continue;\n hasScale(node.latestValues) && node.updateSnapshot();\n const sourceBox = createBox();\n const nodeBox = node.measurePageBox();\n copyBoxInto(sourceBox, nodeBox);\n removeBoxTransforms(boxWithoutTransform, node.latestValues, node.snapshot ? node.snapshot.layoutBox : undefined, sourceBox);\n }\n if (hasTransform(this.latestValues)) {\n removeBoxTransforms(boxWithoutTransform, this.latestValues);\n }\n return boxWithoutTransform;\n }\n setTargetDelta(delta) {\n this.targetDelta = delta;\n this.root.scheduleUpdateProjection();\n this.isProjectionDirty = true;\n }\n setOptions(options) {\n this.options = {\n ...this.options,\n ...options,\n crossfade: options.crossfade !== undefined ? options.crossfade : true,\n };\n }\n clearMeasurements() {\n this.scroll = undefined;\n this.layout = undefined;\n this.snapshot = undefined;\n this.prevTransformTemplateValue = undefined;\n this.targetDelta = undefined;\n this.target = undefined;\n this.isLayoutDirty = false;\n }\n forceRelativeParentToResolveTarget() {\n if (!this.relativeParent)\n return;\n /**\n * If the parent target isn't up-to-date, force it to update.\n * This is an unfortunate de-optimisation as it means any updating relative\n * projection will cause all the relative parents to recalculate back\n * up the tree.\n */\n if (this.relativeParent.resolvedRelativeTargetAt !==\n frameData.timestamp) {\n this.relativeParent.resolveTargetDelta(true);\n }\n }\n resolveTargetDelta(forceRecalculation = false) {\n var _a;\n /**\n * Once the dirty status of nodes has been spread through the tree, we also\n * need to check if we have a shared node of a different depth that has itself\n * been dirtied.\n */\n const lead = this.getLead();\n this.isProjectionDirty || (this.isProjectionDirty = lead.isProjectionDirty);\n this.isTransformDirty || (this.isTransformDirty = lead.isTransformDirty);\n this.isSharedProjectionDirty || (this.isSharedProjectionDirty = lead.isSharedProjectionDirty);\n const isShared = Boolean(this.resumingFrom) || this !== lead;\n /**\n * We don't use transform for this step of processing so we don't\n * need to check whether any nodes have changed transform.\n */\n const canSkip = !(forceRecalculation ||\n (isShared && this.isSharedProjectionDirty) ||\n this.isProjectionDirty ||\n ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.isProjectionDirty) ||\n this.attemptToResolveRelativeTarget ||\n this.root.updateBlockedByResize);\n if (canSkip)\n return;\n const { layout, layoutId } = this.options;\n /**\n * If we have no layout, we can't perform projection, so early return\n */\n if (!this.layout || !(layout || layoutId))\n return;\n this.resolvedRelativeTargetAt = frameData.timestamp;\n /**\n * If we don't have a targetDelta but do have a layout, we can attempt to resolve\n * a relativeParent. This will allow a component to perform scale correction\n * even if no animation has started.\n */\n if (!this.targetDelta && !this.relativeTarget) {\n const relativeParent = this.getClosestProjectingParent();\n if (relativeParent &&\n relativeParent.layout &&\n this.animationProgress !== 1) {\n this.relativeParent = relativeParent;\n this.forceRelativeParentToResolveTarget();\n this.relativeTarget = createBox();\n this.relativeTargetOrigin = createBox();\n calcRelativePosition(this.relativeTargetOrigin, this.layout.layoutBox, relativeParent.layout.layoutBox);\n copyBoxInto(this.relativeTarget, this.relativeTargetOrigin);\n }\n else {\n this.relativeParent = this.relativeTarget = undefined;\n }\n }\n /**\n * If we have no relative target or no target delta our target isn't valid\n * for this frame.\n */\n if (!this.relativeTarget && !this.targetDelta)\n return;\n /**\n * Lazy-init target data structure\n */\n if (!this.target) {\n this.target = createBox();\n this.targetWithTransforms = createBox();\n }\n /**\n * If we've got a relative box for this component, resolve it into a target relative to the parent.\n */\n if (this.relativeTarget &&\n this.relativeTargetOrigin &&\n this.relativeParent &&\n this.relativeParent.target) {\n this.forceRelativeParentToResolveTarget();\n calcRelativeBox(this.target, this.relativeTarget, this.relativeParent.target);\n /**\n * If we've only got a targetDelta, resolve it into a target\n */\n }\n else if (this.targetDelta) {\n if (Boolean(this.resumingFrom)) {\n // TODO: This is creating a new object every frame\n this.target = this.applyTransform(this.layout.layoutBox);\n }\n else {\n copyBoxInto(this.target, this.layout.layoutBox);\n }\n applyBoxDelta(this.target, this.targetDelta);\n }\n else {\n /**\n * If no target, use own layout as target\n */\n copyBoxInto(this.target, this.layout.layoutBox);\n }\n /**\n * If we've been told to attempt to resolve a relative target, do so.\n */\n if (this.attemptToResolveRelativeTarget) {\n this.attemptToResolveRelativeTarget = false;\n const relativeParent = this.getClosestProjectingParent();\n if (relativeParent &&\n Boolean(relativeParent.resumingFrom) ===\n Boolean(this.resumingFrom) &&\n !relativeParent.options.layoutScroll &&\n relativeParent.target &&\n this.animationProgress !== 1) {\n this.relativeParent = relativeParent;\n this.forceRelativeParentToResolveTarget();\n this.relativeTarget = createBox();\n this.relativeTargetOrigin = createBox();\n calcRelativePosition(this.relativeTargetOrigin, this.target, relativeParent.target);\n copyBoxInto(this.relativeTarget, this.relativeTargetOrigin);\n }\n else {\n this.relativeParent = this.relativeTarget = undefined;\n }\n }\n /**\n * Increase debug counter for resolved target deltas\n */\n if (isDebug) {\n metrics.resolvedTargetDeltas++;\n }\n }\n getClosestProjectingParent() {\n if (!this.parent ||\n hasScale(this.parent.latestValues) ||\n has2DTranslate(this.parent.latestValues)) {\n return undefined;\n }\n if (this.parent.isProjecting()) {\n return this.parent;\n }\n else {\n return this.parent.getClosestProjectingParent();\n }\n }\n isProjecting() {\n return Boolean((this.relativeTarget ||\n this.targetDelta ||\n this.options.layoutRoot) &&\n this.layout);\n }\n calcProjection() {\n var _a;\n const lead = this.getLead();\n const isShared = Boolean(this.resumingFrom) || this !== lead;\n let canSkip = true;\n /**\n * If this is a normal layout animation and neither this node nor its nearest projecting\n * is dirty then we can't skip.\n */\n if (this.isProjectionDirty || ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.isProjectionDirty)) {\n canSkip = false;\n }\n /**\n * If this is a shared layout animation and this node's shared projection is dirty then\n * we can't skip.\n */\n if (isShared &&\n (this.isSharedProjectionDirty || this.isTransformDirty)) {\n canSkip = false;\n }\n /**\n * If we have resolved the target this frame we must recalculate the\n * projection to ensure it visually represents the internal calculations.\n */\n if (this.resolvedRelativeTargetAt === frameData.timestamp) {\n canSkip = false;\n }\n if (canSkip)\n return;\n const { layout, layoutId } = this.options;\n /**\n * If this section of the tree isn't animating we can\n * delete our target sources for the following frame.\n */\n this.isTreeAnimating = Boolean((this.parent && this.parent.isTreeAnimating) ||\n this.currentAnimation ||\n this.pendingAnimation);\n if (!this.isTreeAnimating) {\n this.targetDelta = this.relativeTarget = undefined;\n }\n if (!this.layout || !(layout || layoutId))\n return;\n /**\n * Reset the corrected box with the latest values from box, as we're then going\n * to perform mutative operations on it.\n */\n copyBoxInto(this.layoutCorrected, this.layout.layoutBox);\n /**\n * Record previous tree scales before updating.\n */\n const prevTreeScaleX = this.treeScale.x;\n const prevTreeScaleY = this.treeScale.y;\n /**\n * Apply all the parent deltas to this box to produce the corrected box. This\n * is the layout box, as it will appear on screen as a result of the transforms of its parents.\n */\n applyTreeDeltas(this.layoutCorrected, this.treeScale, this.path, isShared);\n /**\n * If this layer needs to perform scale correction but doesn't have a target,\n * use the layout as the target.\n */\n if (lead.layout &&\n !lead.target &&\n (this.treeScale.x !== 1 || this.treeScale.y !== 1)) {\n lead.target = lead.layout.layoutBox;\n lead.targetWithTransforms = createBox();\n }\n const { target } = lead;\n if (!target) {\n /**\n * If we don't have a target to project into, but we were previously\n * projecting, we want to remove the stored transform and schedule\n * a render to ensure the elements reflect the removed transform.\n */\n if (this.prevProjectionDelta) {\n this.createProjectionDeltas();\n this.scheduleRender();\n }\n return;\n }\n if (!this.projectionDelta || !this.prevProjectionDelta) {\n this.createProjectionDeltas();\n }\n else {\n copyAxisDeltaInto(this.prevProjectionDelta.x, this.projectionDelta.x);\n copyAxisDeltaInto(this.prevProjectionDelta.y, this.projectionDelta.y);\n }\n /**\n * Update the delta between the corrected box and the target box before user-set transforms were applied.\n * This will allow us to calculate the corrected borderRadius and boxShadow to compensate\n * for our layout reprojection, but still allow them to be scaled correctly by the user.\n * It might be that to simplify this we may want to accept that user-set scale is also corrected\n * and we wouldn't have to keep and calc both deltas, OR we could support a user setting\n * to allow people to choose whether these styles are corrected based on just the\n * layout reprojection or the final bounding box.\n */\n calcBoxDelta(this.projectionDelta, this.layoutCorrected, target, this.latestValues);\n if (this.treeScale.x !== prevTreeScaleX ||\n this.treeScale.y !== prevTreeScaleY ||\n !axisDeltaEquals(this.projectionDelta.x, this.prevProjectionDelta.x) ||\n !axisDeltaEquals(this.projectionDelta.y, this.prevProjectionDelta.y)) {\n this.hasProjected = true;\n this.scheduleRender();\n this.notifyListeners(\"projectionUpdate\", target);\n }\n /**\n * Increase debug counter for recalculated projections\n */\n if (isDebug) {\n metrics.recalculatedProjection++;\n }\n }\n hide() {\n this.isVisible = false;\n // TODO: Schedule render\n }\n show() {\n this.isVisible = true;\n // TODO: Schedule render\n }\n scheduleRender(notifyAll = true) {\n var _a;\n (_a = this.options.visualElement) === null || _a === void 0 ? void 0 : _a.scheduleRender();\n if (notifyAll) {\n const stack = this.getStack();\n stack && stack.scheduleRender();\n }\n if (this.resumingFrom && !this.resumingFrom.instance) {\n this.resumingFrom = undefined;\n }\n }\n createProjectionDeltas() {\n this.prevProjectionDelta = createDelta();\n this.projectionDelta = createDelta();\n this.projectionDeltaWithTransform = createDelta();\n }\n setAnimationOrigin(delta, hasOnlyRelativeTargetChanged = false) {\n const snapshot = this.snapshot;\n const snapshotLatestValues = snapshot\n ? snapshot.latestValues\n : {};\n const mixedValues = { ...this.latestValues };\n const targetDelta = createDelta();\n if (!this.relativeParent ||\n !this.relativeParent.options.layoutRoot) {\n this.relativeTarget = this.relativeTargetOrigin = undefined;\n }\n this.attemptToResolveRelativeTarget = !hasOnlyRelativeTargetChanged;\n const relativeLayout = createBox();\n const snapshotSource = snapshot ? snapshot.source : undefined;\n const layoutSource = this.layout ? this.layout.source : undefined;\n const isSharedLayoutAnimation = snapshotSource !== layoutSource;\n const stack = this.getStack();\n const isOnlyMember = !stack || stack.members.length <= 1;\n const shouldCrossfadeOpacity = Boolean(isSharedLayoutAnimation &&\n !isOnlyMember &&\n this.options.crossfade === true &&\n !this.path.some(hasOpacityCrossfade));\n this.animationProgress = 0;\n let prevRelativeTarget;\n this.mixTargetDelta = (latest) => {\n const progress = latest / 1000;\n mixAxisDelta(targetDelta.x, delta.x, progress);\n mixAxisDelta(targetDelta.y, delta.y, progress);\n this.setTargetDelta(targetDelta);\n if (this.relativeTarget &&\n this.relativeTargetOrigin &&\n this.layout &&\n this.relativeParent &&\n this.relativeParent.layout) {\n calcRelativePosition(relativeLayout, this.layout.layoutBox, this.relativeParent.layout.layoutBox);\n mixBox(this.relativeTarget, this.relativeTargetOrigin, relativeLayout, progress);\n /**\n * If this is an unchanged relative target we can consider the\n * projection not dirty.\n */\n if (prevRelativeTarget &&\n boxEquals(this.relativeTarget, prevRelativeTarget)) {\n this.isProjectionDirty = false;\n }\n if (!prevRelativeTarget)\n prevRelativeTarget = createBox();\n copyBoxInto(prevRelativeTarget, this.relativeTarget);\n }\n if (isSharedLayoutAnimation) {\n this.animationValues = mixedValues;\n mixValues(mixedValues, snapshotLatestValues, this.latestValues, progress, shouldCrossfadeOpacity, isOnlyMember);\n }\n this.root.scheduleUpdateProjection();\n this.scheduleRender();\n this.animationProgress = progress;\n };\n this.mixTargetDelta(this.options.layoutRoot ? 1000 : 0);\n }\n startAnimation(options) {\n this.notifyListeners(\"animationStart\");\n this.currentAnimation && this.currentAnimation.stop();\n if (this.resumingFrom && this.resumingFrom.currentAnimation) {\n this.resumingFrom.currentAnimation.stop();\n }\n if (this.pendingAnimation) {\n cancelFrame(this.pendingAnimation);\n this.pendingAnimation = undefined;\n }\n /**\n * Start the animation in the next frame to have a frame with progress 0,\n * where the target is the same as when the animation started, so we can\n * calculate the relative positions correctly for instant transitions.\n */\n this.pendingAnimation = frame.update(() => {\n globalProjectionState.hasAnimatedSinceResize = true;\n this.currentAnimation = animateSingleValue(0, animationTarget, {\n ...options,\n onUpdate: (latest) => {\n this.mixTargetDelta(latest);\n options.onUpdate && options.onUpdate(latest);\n },\n onComplete: () => {\n options.onComplete && options.onComplete();\n this.completeAnimation();\n },\n });\n if (this.resumingFrom) {\n this.resumingFrom.currentAnimation = this.currentAnimation;\n }\n this.pendingAnimation = undefined;\n });\n }\n completeAnimation() {\n if (this.resumingFrom) {\n this.resumingFrom.currentAnimation = undefined;\n this.resumingFrom.preserveOpacity = undefined;\n }\n const stack = this.getStack();\n stack && stack.exitAnimationComplete();\n this.resumingFrom =\n this.currentAnimation =\n this.animationValues =\n undefined;\n this.notifyListeners(\"animationComplete\");\n }\n finishAnimation() {\n if (this.currentAnimation) {\n this.mixTargetDelta && this.mixTargetDelta(animationTarget);\n this.currentAnimation.stop();\n }\n this.completeAnimation();\n }\n applyTransformsToTarget() {\n const lead = this.getLead();\n let { targetWithTransforms, target, layout, latestValues } = lead;\n if (!targetWithTransforms || !target || !layout)\n return;\n /**\n * If we're only animating position, and this element isn't the lead element,\n * then instead of projecting into the lead box we instead want to calculate\n * a new target that aligns the two boxes but maintains the layout shape.\n */\n if (this !== lead &&\n this.layout &&\n layout &&\n shouldAnimatePositionOnly(this.options.animationType, this.layout.layoutBox, layout.layoutBox)) {\n target = this.target || createBox();\n const xLength = calcLength(this.layout.layoutBox.x);\n target.x.min = lead.target.x.min;\n target.x.max = target.x.min + xLength;\n const yLength = calcLength(this.layout.layoutBox.y);\n target.y.min = lead.target.y.min;\n target.y.max = target.y.min + yLength;\n }\n copyBoxInto(targetWithTransforms, target);\n /**\n * Apply the latest user-set transforms to the targetBox to produce the targetBoxFinal.\n * This is the final box that we will then project into by calculating a transform delta and\n * applying it to the corrected box.\n */\n transformBox(targetWithTransforms, latestValues);\n /**\n * Update the delta between the corrected box and the final target box, after\n * user-set transforms are applied to it. This will be used by the renderer to\n * create a transform style that will reproject the element from its layout layout\n * into the desired bounding box.\n */\n calcBoxDelta(this.projectionDeltaWithTransform, this.layoutCorrected, targetWithTransforms, latestValues);\n }\n registerSharedNode(layoutId, node) {\n if (!this.sharedNodes.has(layoutId)) {\n this.sharedNodes.set(layoutId, new NodeStack());\n }\n const stack = this.sharedNodes.get(layoutId);\n stack.add(node);\n const config = node.options.initialPromotionConfig;\n node.promote({\n transition: config ? config.transition : undefined,\n preserveFollowOpacity: config && config.shouldPreserveFollowOpacity\n ? config.shouldPreserveFollowOpacity(node)\n : undefined,\n });\n }\n isLead() {\n const stack = this.getStack();\n return stack ? stack.lead === this : true;\n }\n getLead() {\n var _a;\n const { layoutId } = this.options;\n return layoutId ? ((_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.lead) || this : this;\n }\n getPrevLead() {\n var _a;\n const { layoutId } = this.options;\n return layoutId ? (_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.prevLead : undefined;\n }\n getStack() {\n const { layoutId } = this.options;\n if (layoutId)\n return this.root.sharedNodes.get(layoutId);\n }\n promote({ needsReset, transition, preserveFollowOpacity, } = {}) {\n const stack = this.getStack();\n if (stack)\n stack.promote(this, preserveFollowOpacity);\n if (needsReset) {\n this.projectionDelta = undefined;\n this.needsReset = true;\n }\n if (transition)\n this.setOptions({ transition });\n }\n relegate() {\n const stack = this.getStack();\n if (stack) {\n return stack.relegate(this);\n }\n else {\n return false;\n }\n }\n resetSkewAndRotation() {\n const { visualElement } = this.options;\n if (!visualElement)\n return;\n // If there's no detected skew or rotation values, we can early return without a forced render.\n let hasDistortingTransform = false;\n /**\n * An unrolled check for rotation values. Most elements don't have any rotation and\n * skipping the nested loop and new object creation is 50% faster.\n */\n const { latestValues } = visualElement;\n if (latestValues.z ||\n latestValues.rotate ||\n latestValues.rotateX ||\n latestValues.rotateY ||\n latestValues.rotateZ ||\n latestValues.skewX ||\n latestValues.skewY) {\n hasDistortingTransform = true;\n }\n // If there's no distorting values, we don't need to do any more.\n if (!hasDistortingTransform)\n return;\n const resetValues = {};\n if (latestValues.z) {\n resetDistortingTransform(\"z\", visualElement, resetValues, this.animationValues);\n }\n // Check the skew and rotate value of all axes and reset to 0\n for (let i = 0; i < transformAxes.length; i++) {\n resetDistortingTransform(`rotate${transformAxes[i]}`, visualElement, resetValues, this.animationValues);\n resetDistortingTransform(`skew${transformAxes[i]}`, visualElement, resetValues, this.animationValues);\n }\n // Force a render of this element to apply the transform with all skews and rotations\n // set to 0.\n visualElement.render();\n // Put back all the values we reset\n for (const key in resetValues) {\n visualElement.setStaticValue(key, resetValues[key]);\n if (this.animationValues) {\n this.animationValues[key] = resetValues[key];\n }\n }\n // Schedule a render for the next frame. This ensures we won't visually\n // see the element with the reset rotate value applied.\n visualElement.scheduleRender();\n }\n getProjectionStyles(styleProp) {\n var _a, _b;\n if (!this.instance || this.isSVG)\n return undefined;\n if (!this.isVisible) {\n return hiddenVisibility;\n }\n const styles = {\n visibility: \"\",\n };\n const transformTemplate = this.getTransformTemplate();\n if (this.needsReset) {\n this.needsReset = false;\n styles.opacity = \"\";\n styles.pointerEvents =\n resolveMotionValue(styleProp === null || styleProp === void 0 ? void 0 : styleProp.pointerEvents) || \"\";\n styles.transform = transformTemplate\n ? transformTemplate(this.latestValues, \"\")\n : \"none\";\n return styles;\n }\n const lead = this.getLead();\n if (!this.projectionDelta || !this.layout || !lead.target) {\n const emptyStyles = {};\n if (this.options.layoutId) {\n emptyStyles.opacity =\n this.latestValues.opacity !== undefined\n ? this.latestValues.opacity\n : 1;\n emptyStyles.pointerEvents =\n resolveMotionValue(styleProp === null || styleProp === void 0 ? void 0 : styleProp.pointerEvents) || \"\";\n }\n if (this.hasProjected && !hasTransform(this.latestValues)) {\n emptyStyles.transform = transformTemplate\n ? transformTemplate({}, \"\")\n : \"none\";\n this.hasProjected = false;\n }\n return emptyStyles;\n }\n const valuesToRender = lead.animationValues || lead.latestValues;\n this.applyTransformsToTarget();\n styles.transform = buildProjectionTransform(this.projectionDeltaWithTransform, this.treeScale, valuesToRender);\n if (transformTemplate) {\n styles.transform = transformTemplate(valuesToRender, styles.transform);\n }\n const { x, y } = this.projectionDelta;\n styles.transformOrigin = `${x.origin * 100}% ${y.origin * 100}% 0`;\n if (lead.animationValues) {\n /**\n * If the lead component is animating, assign this either the entering/leaving\n * opacity\n */\n styles.opacity =\n lead === this\n ? (_b = (_a = valuesToRender.opacity) !== null && _a !== void 0 ? _a : this.latestValues.opacity) !== null && _b !== void 0 ? _b : 1\n : this.preserveOpacity\n ? this.latestValues.opacity\n : valuesToRender.opacityExit;\n }\n else {\n /**\n * Or we're not animating at all, set the lead component to its layout\n * opacity and other components to hidden.\n */\n styles.opacity =\n lead === this\n ? valuesToRender.opacity !== undefined\n ? valuesToRender.opacity\n : \"\"\n : valuesToRender.opacityExit !== undefined\n ? valuesToRender.opacityExit\n : 0;\n }\n /**\n * Apply scale correction\n */\n for (const key in scaleCorrectors) {\n if (valuesToRender[key] === undefined)\n continue;\n const { correct, applyTo } = scaleCorrectors[key];\n /**\n * Only apply scale correction to the value if we have an\n * active projection transform. Otherwise these values become\n * vulnerable to distortion if the element changes size without\n * a corresponding layout animation.\n */\n const corrected = styles.transform === \"none\"\n ? valuesToRender[key]\n : correct(valuesToRender[key], lead);\n if (applyTo) {\n const num = applyTo.length;\n for (let i = 0; i < num; i++) {\n styles[applyTo[i]] = corrected;\n }\n }\n else {\n styles[key] = corrected;\n }\n }\n /**\n * Disable pointer events on follow components. This is to ensure\n * that if a follow component covers a lead component it doesn't block\n * pointer events on the lead.\n */\n if (this.options.layoutId) {\n styles.pointerEvents =\n lead === this\n ? resolveMotionValue(styleProp === null || styleProp === void 0 ? void 0 : styleProp.pointerEvents) || \"\"\n : \"none\";\n }\n return styles;\n }\n clearSnapshot() {\n this.resumeFrom = this.snapshot = undefined;\n }\n // Only run on root\n resetTree() {\n this.root.nodes.forEach((node) => { var _a; return (_a = node.currentAnimation) === null || _a === void 0 ? void 0 : _a.stop(); });\n this.root.nodes.forEach(clearMeasurements);\n this.root.sharedNodes.clear();\n }\n };\n}\nfunction updateLayout(node) {\n node.updateLayout();\n}\nfunction notifyLayoutUpdate(node) {\n var _a;\n const snapshot = ((_a = node.resumeFrom) === null || _a === void 0 ? void 0 : _a.snapshot) || node.snapshot;\n if (node.isLead() &&\n node.layout &&\n snapshot &&\n node.hasListeners(\"didUpdate\")) {\n const { layoutBox: layout, measuredBox: measuredLayout } = node.layout;\n const { animationType } = node.options;\n const isShared = snapshot.source !== node.layout.source;\n // TODO Maybe we want to also resize the layout snapshot so we don't trigger\n // animations for instance if layout=\"size\" and an element has only changed position\n if (animationType === \"size\") {\n eachAxis((axis) => {\n const axisSnapshot = isShared\n ? snapshot.measuredBox[axis]\n : snapshot.layoutBox[axis];\n const length = calcLength(axisSnapshot);\n axisSnapshot.min = layout[axis].min;\n axisSnapshot.max = axisSnapshot.min + length;\n });\n }\n else if (shouldAnimatePositionOnly(animationType, snapshot.layoutBox, layout)) {\n eachAxis((axis) => {\n const axisSnapshot = isShared\n ? snapshot.measuredBox[axis]\n : snapshot.layoutBox[axis];\n const length = calcLength(layout[axis]);\n axisSnapshot.max = axisSnapshot.min + length;\n /**\n * Ensure relative target gets resized and rerendererd\n */\n if (node.relativeTarget && !node.currentAnimation) {\n node.isProjectionDirty = true;\n node.relativeTarget[axis].max =\n node.relativeTarget[axis].min + length;\n }\n });\n }\n const layoutDelta = createDelta();\n calcBoxDelta(layoutDelta, layout, snapshot.layoutBox);\n const visualDelta = createDelta();\n if (isShared) {\n calcBoxDelta(visualDelta, node.applyTransform(measuredLayout, true), snapshot.measuredBox);\n }\n else {\n calcBoxDelta(visualDelta, layout, snapshot.layoutBox);\n }\n const hasLayoutChanged = !isDeltaZero(layoutDelta);\n let hasRelativeTargetChanged = false;\n if (!node.resumeFrom) {\n const relativeParent = node.getClosestProjectingParent();\n /**\n * If the relativeParent is itself resuming from a different element then\n * the relative snapshot is not relavent\n */\n if (relativeParent && !relativeParent.resumeFrom) {\n const { snapshot: parentSnapshot, layout: parentLayout } = relativeParent;\n if (parentSnapshot && parentLayout) {\n const relativeSnapshot = createBox();\n calcRelativePosition(relativeSnapshot, snapshot.layoutBox, parentSnapshot.layoutBox);\n const relativeLayout = createBox();\n calcRelativePosition(relativeLayout, layout, parentLayout.layoutBox);\n if (!boxEqualsRounded(relativeSnapshot, relativeLayout)) {\n hasRelativeTargetChanged = true;\n }\n if (relativeParent.options.layoutRoot) {\n node.relativeTarget = relativeLayout;\n node.relativeTargetOrigin = relativeSnapshot;\n node.relativeParent = relativeParent;\n }\n }\n }\n }\n node.notifyListeners(\"didUpdate\", {\n layout,\n snapshot,\n delta: visualDelta,\n layoutDelta,\n hasLayoutChanged,\n hasRelativeTargetChanged,\n });\n }\n else if (node.isLead()) {\n const { onExitComplete } = node.options;\n onExitComplete && onExitComplete();\n }\n /**\n * Clearing transition\n * TODO: Investigate why this transition is being passed in as {type: false } from Framer\n * and why we need it at all\n */\n node.options.transition = undefined;\n}\nfunction propagateDirtyNodes(node) {\n /**\n * Increase debug counter for nodes encountered this frame\n */\n if (isDebug) {\n metrics.totalNodes++;\n }\n if (!node.parent)\n return;\n /**\n * If this node isn't projecting, propagate isProjectionDirty. It will have\n * no performance impact but it will allow the next child that *is* projecting\n * but *isn't* dirty to just check its parent to see if *any* ancestor needs\n * correcting.\n */\n if (!node.isProjecting()) {\n node.isProjectionDirty = node.parent.isProjectionDirty;\n }\n /**\n * Propagate isSharedProjectionDirty and isTransformDirty\n * throughout the whole tree. A future revision can take another look at\n * this but for safety we still recalcualte shared nodes.\n */\n node.isSharedProjectionDirty || (node.isSharedProjectionDirty = Boolean(node.isProjectionDirty ||\n node.parent.isProjectionDirty ||\n node.parent.isSharedProjectionDirty));\n node.isTransformDirty || (node.isTransformDirty = node.parent.isTransformDirty);\n}\nfunction cleanDirtyNodes(node) {\n node.isProjectionDirty =\n node.isSharedProjectionDirty =\n node.isTransformDirty =\n false;\n}\nfunction clearSnapshot(node) {\n node.clearSnapshot();\n}\nfunction clearMeasurements(node) {\n node.clearMeasurements();\n}\nfunction clearIsLayoutDirty(node) {\n node.isLayoutDirty = false;\n}\nfunction resetTransformStyle(node) {\n const { visualElement } = node.options;\n if (visualElement && visualElement.getProps().onBeforeLayoutMeasure) {\n visualElement.notify(\"BeforeLayoutMeasure\");\n }\n node.resetTransform();\n}\nfunction finishAnimation(node) {\n node.finishAnimation();\n node.targetDelta = node.relativeTarget = node.target = undefined;\n node.isProjectionDirty = true;\n}\nfunction resolveTargetDelta(node) {\n node.resolveTargetDelta();\n}\nfunction calcProjection(node) {\n node.calcProjection();\n}\nfunction resetSkewAndRotation(node) {\n node.resetSkewAndRotation();\n}\nfunction removeLeadSnapshots(stack) {\n stack.removeLeadSnapshot();\n}\nfunction mixAxisDelta(output, delta, p) {\n output.translate = mixNumber(delta.translate, 0, p);\n output.scale = mixNumber(delta.scale, 1, p);\n output.origin = delta.origin;\n output.originPoint = delta.originPoint;\n}\nfunction mixAxis(output, from, to, p) {\n output.min = mixNumber(from.min, to.min, p);\n output.max = mixNumber(from.max, to.max, p);\n}\nfunction mixBox(output, from, to, p) {\n mixAxis(output.x, from.x, to.x, p);\n mixAxis(output.y, from.y, to.y, p);\n}\nfunction hasOpacityCrossfade(node) {\n return (node.animationValues && node.animationValues.opacityExit !== undefined);\n}\nconst defaultLayoutTransition = {\n duration: 0.45,\n ease: [0.4, 0, 0.1, 1],\n};\nconst userAgentContains = (string) => typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().includes(string);\n/**\n * Measured bounding boxes must be rounded in Safari and\n * left untouched in Chrome, otherwise non-integer layouts within scaled-up elements\n * can appear to jump.\n */\nconst roundPoint = userAgentContains(\"applewebkit/\") && !userAgentContains(\"chrome/\")\n ? Math.round\n : noop;\nfunction roundAxis(axis) {\n // Round to the nearest .5 pixels to support subpixel layouts\n axis.min = roundPoint(axis.min);\n axis.max = roundPoint(axis.max);\n}\nfunction roundBox(box) {\n roundAxis(box.x);\n roundAxis(box.y);\n}\nfunction shouldAnimatePositionOnly(animationType, snapshot, layout) {\n return (animationType === \"position\" ||\n (animationType === \"preserve-aspect\" &&\n !isNear(aspectRatio(snapshot), aspectRatio(layout), 0.2)));\n}\nfunction checkNodeWasScrollRoot(node) {\n var _a;\n return node !== node.root && ((_a = node.scroll) === null || _a === void 0 ? void 0 : _a.wasRoot);\n}\n\nexport { cleanDirtyNodes, createProjectionNode, mixAxis, mixAxisDelta, mixBox, propagateDirtyNodes };\n","function isSVGElement(element) {\n return element instanceof SVGElement && element.tagName !== \"svg\";\n}\n\nexport { isSVGElement };\n","import { time } from '../frameloop/sync-time.mjs';\nimport { frame, cancelFrame } from '../frameloop/frame.mjs';\n\n/**\n * Timeout defined in ms\n */\nfunction delay(callback, timeout) {\n const start = time.now();\n const checkElapsed = ({ timestamp }) => {\n const elapsed = timestamp - start;\n if (elapsed >= timeout) {\n cancelFrame(checkElapsed);\n callback(elapsed - timeout);\n }\n };\n frame.read(checkElapsed, true);\n return () => cancelFrame(checkElapsed);\n}\n\nexport { delay };\n","import { animateMotionValue } from './motion-value.mjs';\nimport { motionValue } from '../../value/index.mjs';\nimport { isMotionValue } from '../../value/utils/is-motion-value.mjs';\n\nfunction animateSingleValue(value, keyframes, options) {\n const motionValue$1 = isMotionValue(value) ? value : motionValue(value);\n motionValue$1.start(animateMotionValue(\"\", motionValue$1, keyframes, options));\n return motionValue$1.animation;\n}\n\nexport { animateSingleValue };\n","function buildProjectionTransform(delta, treeScale, latestTransform) {\n let transform = \"\";\n /**\n * The translations we use to calculate are always relative to the viewport coordinate space.\n * But when we apply scales, we also scale the coordinate space of an element and its children.\n * For instance if we have a treeScale (the culmination of all parent scales) of 0.5 and we need\n * to move an element 100 pixels, we actually need to move it 200 in within that scaled space.\n */\n const xTranslate = delta.x.translate / treeScale.x;\n const yTranslate = delta.y.translate / treeScale.y;\n const zTranslate = (latestTransform === null || latestTransform === void 0 ? void 0 : latestTransform.z) || 0;\n if (xTranslate || yTranslate || zTranslate) {\n transform = `translate3d(${xTranslate}px, ${yTranslate}px, ${zTranslate}px) `;\n }\n /**\n * Apply scale correction for the tree transform.\n * This will apply scale to the screen-orientated axes.\n */\n if (treeScale.x !== 1 || treeScale.y !== 1) {\n transform += `scale(${1 / treeScale.x}, ${1 / treeScale.y}) `;\n }\n if (latestTransform) {\n const { transformPerspective, rotate, rotateX, rotateY, skewX, skewY } = latestTransform;\n if (transformPerspective)\n transform = `perspective(${transformPerspective}px) ${transform}`;\n if (rotate)\n transform += `rotate(${rotate}deg) `;\n if (rotateX)\n transform += `rotateX(${rotateX}deg) `;\n if (rotateY)\n transform += `rotateY(${rotateY}deg) `;\n if (skewX)\n transform += `skewX(${skewX}deg) `;\n if (skewY)\n transform += `skewY(${skewY}deg) `;\n }\n /**\n * Apply scale to match the size of the element to the size we want it.\n * This will apply scale to the element-orientated axes.\n */\n const elementScaleX = delta.x.scale * treeScale.x;\n const elementScaleY = delta.y.scale * treeScale.y;\n if (elementScaleX !== 1 || elementScaleY !== 1) {\n transform += `scale(${elementScaleX}, ${elementScaleY})`;\n }\n return transform || \"none\";\n}\n\nexport { buildProjectionTransform };\n","import { createProjectionNode } from './create-projection-node.mjs';\nimport { addDomEvent } from '../../events/add-dom-event.mjs';\n\nconst DocumentProjectionNode = createProjectionNode({\n attachResizeListener: (ref, notify) => addDomEvent(ref, \"resize\", notify),\n measureScroll: () => ({\n x: document.documentElement.scrollLeft || document.body.scrollLeft,\n y: document.documentElement.scrollTop || document.body.scrollTop,\n }),\n checkIsScrollRoot: () => true,\n});\n\nexport { DocumentProjectionNode };\n","import { createProjectionNode } from './create-projection-node.mjs';\nimport { DocumentProjectionNode } from './DocumentProjectionNode.mjs';\n\nconst rootProjectionNode = {\n current: undefined,\n};\nconst HTMLProjectionNode = createProjectionNode({\n measureScroll: (instance) => ({\n x: instance.scrollLeft,\n y: instance.scrollTop,\n }),\n defaultParent: () => {\n if (!rootProjectionNode.current) {\n const documentNode = new DocumentProjectionNode({});\n documentNode.mount(window);\n documentNode.setOptions({ layoutScroll: true });\n rootProjectionNode.current = documentNode;\n }\n return rootProjectionNode.current;\n },\n resetTransform: (instance, value) => {\n instance.style.transform = value !== undefined ? value : \"none\";\n },\n checkIsScrollRoot: (instance) => Boolean(window.getComputedStyle(instance).position === \"fixed\"),\n});\n\nexport { HTMLProjectionNode, rootProjectionNode };\n","import { DragGesture } from '../../gestures/drag/index.mjs';\nimport { PanGesture } from '../../gestures/pan/index.mjs';\nimport { MeasureLayout } from './layout/MeasureLayout.mjs';\nimport { HTMLProjectionNode } from '../../projection/node/HTMLProjectionNode.mjs';\n\nconst drag = {\n pan: {\n Feature: PanGesture,\n },\n drag: {\n Feature: DragGesture,\n ProjectionNode: HTMLProjectionNode,\n MeasureLayout,\n },\n};\n\nexport { drag };\n","import { Feature } from '../../motion/features/Feature.mjs';\nimport { noop } from '../../utils/noop.mjs';\nimport { VisualElementDragControls } from './VisualElementDragControls.mjs';\n\nclass DragGesture extends Feature {\n constructor(node) {\n super(node);\n this.removeGroupControls = noop;\n this.removeListeners = noop;\n this.controls = new VisualElementDragControls(node);\n }\n mount() {\n // If we've been provided a DragControls for manual control over the drag gesture,\n // subscribe this component to it on mount.\n const { dragControls } = this.node.getProps();\n if (dragControls) {\n this.removeGroupControls = dragControls.subscribe(this.controls);\n }\n this.removeListeners = this.controls.addListeners() || noop;\n }\n unmount() {\n this.removeGroupControls();\n this.removeListeners();\n }\n}\n\nexport { DragGesture };\n","// Does this device prefer reduced motion? Returns `null` server-side.\nconst prefersReducedMotion = { current: null };\nconst hasReducedMotionListener = { current: false };\n\nexport { hasReducedMotionListener, prefersReducedMotion };\n","const visualElementStore = new WeakMap();\n\nexport { visualElementStore };\n","import { color } from '../../../value/types/color/index.mjs';\nimport { complex } from '../../../value/types/complex/index.mjs';\nimport { dimensionValueTypes } from './dimensions.mjs';\nimport { testValueType } from './test.mjs';\n\n/**\n * A list of all ValueTypes\n */\nconst valueTypes = [...dimensionValueTypes, color, complex];\n/**\n * Tests a value against the list of ValueTypes\n */\nconst findValueType = (v) => valueTypes.find(testValueType(v));\n\nexport { findValueType };\n","import { initPrefersReducedMotion } from '../utils/reduced-motion/index.mjs';\nimport { hasReducedMotionListener, prefersReducedMotion } from '../utils/reduced-motion/state.mjs';\nimport { SubscriptionManager } from '../utils/subscription-manager.mjs';\nimport { motionValue } from '../value/index.mjs';\nimport { isMotionValue } from '../value/utils/is-motion-value.mjs';\nimport { transformProps } from './html/utils/transform.mjs';\nimport { isControllingVariants, isVariantNode } from './utils/is-controlling-variants.mjs';\nimport { isVariantLabel } from './utils/is-variant-label.mjs';\nimport { updateMotionValuesFromProps } from './utils/motion-values.mjs';\nimport { resolveVariantFromProps } from './utils/resolve-variants.mjs';\nimport { warnOnce } from '../utils/warn-once.mjs';\nimport { featureDefinitions } from '../motion/features/definitions.mjs';\nimport { variantProps } from './utils/variant-props.mjs';\nimport { visualElementStore } from './store.mjs';\nimport { KeyframeResolver } from './utils/KeyframesResolver.mjs';\nimport { isNumericalString } from '../utils/is-numerical-string.mjs';\nimport { isZeroValueString } from '../utils/is-zero-value-string.mjs';\nimport { findValueType } from './dom/value-types/find.mjs';\nimport { complex } from '../value/types/complex/index.mjs';\nimport { getAnimatableNone } from './dom/value-types/animatable-none.mjs';\nimport { createBox } from '../projection/geometry/models.mjs';\nimport { frame, cancelFrame } from '../frameloop/frame.mjs';\n\nconst propEventHandlers = [\n \"AnimationStart\",\n \"AnimationComplete\",\n \"Update\",\n \"BeforeLayoutMeasure\",\n \"LayoutMeasure\",\n \"LayoutAnimationStart\",\n \"LayoutAnimationComplete\",\n];\nconst numVariantProps = variantProps.length;\n/**\n * A VisualElement is an imperative abstraction around UI elements such as\n * HTMLElement, SVGElement, Three.Object3D etc.\n */\nclass VisualElement {\n /**\n * This method takes React props and returns found MotionValues. For example, HTML\n * MotionValues will be found within the style prop, whereas for Three.js within attribute arrays.\n *\n * This isn't an abstract method as it needs calling in the constructor, but it is\n * intended to be one.\n */\n scrapeMotionValuesFromProps(_props, _prevProps, _visualElement) {\n return {};\n }\n constructor({ parent, props, presenceContext, reducedMotionConfig, blockInitialAnimation, visualState, }, options = {}) {\n /**\n * If true, will-change will be applied to the element. Only HTMLVisualElements\n * currently support this.\n */\n this.applyWillChange = false;\n /**\n * A reference to the current underlying Instance, e.g. a HTMLElement\n * or Three.Mesh etc.\n */\n this.current = null;\n /**\n * A set containing references to this VisualElement's children.\n */\n this.children = new Set();\n /**\n * Determine what role this visual element should take in the variant tree.\n */\n this.isVariantNode = false;\n this.isControllingVariants = false;\n /**\n * Decides whether this VisualElement should animate in reduced motion\n * mode.\n *\n * TODO: This is currently set on every individual VisualElement but feels\n * like it could be set globally.\n */\n this.shouldReduceMotion = null;\n /**\n * A map of all motion values attached to this visual element. Motion\n * values are source of truth for any given animated value. A motion\n * value might be provided externally by the component via props.\n */\n this.values = new Map();\n this.KeyframeResolver = KeyframeResolver;\n /**\n * Cleanup functions for active features (hover/tap/exit etc)\n */\n this.features = {};\n /**\n * A map of every subscription that binds the provided or generated\n * motion values onChange listeners to this visual element.\n */\n this.valueSubscriptions = new Map();\n /**\n * A reference to the previously-provided motion values as returned\n * from scrapeMotionValuesFromProps. We use the keys in here to determine\n * if any motion values need to be removed after props are updated.\n */\n this.prevMotionValues = {};\n /**\n * An object containing a SubscriptionManager for each active event.\n */\n this.events = {};\n /**\n * An object containing an unsubscribe function for each prop event subscription.\n * For example, every \"Update\" event can have multiple subscribers via\n * VisualElement.on(), but only one of those can be defined via the onUpdate prop.\n */\n this.propEventSubscriptions = {};\n this.notifyUpdate = () => this.notify(\"Update\", this.latestValues);\n this.render = () => {\n this.isRenderScheduled = false;\n if (!this.current)\n return;\n this.triggerBuild();\n this.renderInstance(this.current, this.renderState, this.props.style, this.projection);\n };\n this.isRenderScheduled = false;\n this.scheduleRender = () => {\n if (!this.isRenderScheduled) {\n this.isRenderScheduled = true;\n frame.render(this.render, false, true);\n }\n };\n const { latestValues, renderState } = visualState;\n this.latestValues = latestValues;\n this.baseTarget = { ...latestValues };\n this.initialValues = props.initial ? { ...latestValues } : {};\n this.renderState = renderState;\n this.parent = parent;\n this.props = props;\n this.presenceContext = presenceContext;\n this.depth = parent ? parent.depth + 1 : 0;\n this.reducedMotionConfig = reducedMotionConfig;\n this.options = options;\n this.blockInitialAnimation = Boolean(blockInitialAnimation);\n this.isControllingVariants = isControllingVariants(props);\n this.isVariantNode = isVariantNode(props);\n if (this.isVariantNode) {\n this.variantChildren = new Set();\n }\n this.manuallyAnimateOnMount = Boolean(parent && parent.current);\n /**\n * Any motion values that are provided to the element when created\n * aren't yet bound to the element, as this would technically be impure.\n * However, we iterate through the motion values and set them to the\n * initial values for this component.\n *\n * TODO: This is impure and we should look at changing this to run on mount.\n * Doing so will break some tests but this isn't necessarily a breaking change,\n * more a reflection of the test.\n */\n const { willChange, ...initialMotionValues } = this.scrapeMotionValuesFromProps(props, {}, this);\n for (const key in initialMotionValues) {\n const value = initialMotionValues[key];\n if (latestValues[key] !== undefined && isMotionValue(value)) {\n value.set(latestValues[key], false);\n }\n }\n }\n mount(instance) {\n this.current = instance;\n visualElementStore.set(instance, this);\n if (this.projection && !this.projection.instance) {\n this.projection.mount(instance);\n }\n if (this.parent && this.isVariantNode && !this.isControllingVariants) {\n this.removeFromVariantTree = this.parent.addVariantChild(this);\n }\n this.values.forEach((value, key) => this.bindToMotionValue(key, value));\n if (!hasReducedMotionListener.current) {\n initPrefersReducedMotion();\n }\n this.shouldReduceMotion =\n this.reducedMotionConfig === \"never\"\n ? false\n : this.reducedMotionConfig === \"always\"\n ? true\n : prefersReducedMotion.current;\n if (process.env.NODE_ENV !== \"production\") {\n warnOnce(this.shouldReduceMotion !== true, \"You have Reduced Motion enabled on your device. Animations may not appear as expected.\");\n }\n if (this.parent)\n this.parent.children.add(this);\n this.update(this.props, this.presenceContext);\n }\n unmount() {\n visualElementStore.delete(this.current);\n this.projection && this.projection.unmount();\n cancelFrame(this.notifyUpdate);\n cancelFrame(this.render);\n this.valueSubscriptions.forEach((remove) => remove());\n this.removeFromVariantTree && this.removeFromVariantTree();\n this.parent && this.parent.children.delete(this);\n for (const key in this.events) {\n this.events[key].clear();\n }\n for (const key in this.features) {\n const feature = this.features[key];\n if (feature) {\n feature.unmount();\n feature.isMounted = false;\n }\n }\n this.current = null;\n }\n bindToMotionValue(key, value) {\n const valueIsTransform = transformProps.has(key);\n const removeOnChange = value.on(\"change\", (latestValue) => {\n this.latestValues[key] = latestValue;\n this.props.onUpdate && frame.preRender(this.notifyUpdate);\n if (valueIsTransform && this.projection) {\n this.projection.isTransformDirty = true;\n }\n });\n const removeOnRenderRequest = value.on(\"renderRequest\", this.scheduleRender);\n this.valueSubscriptions.set(key, () => {\n removeOnChange();\n removeOnRenderRequest();\n if (value.owner)\n value.stop();\n });\n }\n sortNodePosition(other) {\n /**\n * If these nodes aren't even of the same type we can't compare their depth.\n */\n if (!this.current ||\n !this.sortInstanceNodePosition ||\n this.type !== other.type) {\n return 0;\n }\n return this.sortInstanceNodePosition(this.current, other.current);\n }\n updateFeatures() {\n let key = \"animation\";\n for (key in featureDefinitions) {\n const featureDefinition = featureDefinitions[key];\n if (!featureDefinition)\n continue;\n const { isEnabled, Feature: FeatureConstructor } = featureDefinition;\n /**\n * If this feature is enabled but not active, make a new instance.\n */\n if (!this.features[key] &&\n FeatureConstructor &&\n isEnabled(this.props)) {\n this.features[key] = new FeatureConstructor(this);\n }\n /**\n * If we have a feature, mount or update it.\n */\n if (this.features[key]) {\n const feature = this.features[key];\n if (feature.isMounted) {\n feature.update();\n }\n else {\n feature.mount();\n feature.isMounted = true;\n }\n }\n }\n }\n triggerBuild() {\n this.build(this.renderState, this.latestValues, this.props);\n }\n /**\n * Measure the current viewport box with or without transforms.\n * Only measures axis-aligned boxes, rotate and skew must be manually\n * removed with a re-render to work.\n */\n measureViewportBox() {\n return this.current\n ? this.measureInstanceViewportBox(this.current, this.props)\n : createBox();\n }\n getStaticValue(key) {\n return this.latestValues[key];\n }\n setStaticValue(key, value) {\n this.latestValues[key] = value;\n }\n /**\n * Update the provided props. Ensure any newly-added motion values are\n * added to our map, old ones removed, and listeners updated.\n */\n update(props, presenceContext) {\n if (props.transformTemplate || this.props.transformTemplate) {\n this.scheduleRender();\n }\n this.prevProps = this.props;\n this.props = props;\n this.prevPresenceContext = this.presenceContext;\n this.presenceContext = presenceContext;\n /**\n * Update prop event handlers ie onAnimationStart, onAnimationComplete\n */\n for (let i = 0; i < propEventHandlers.length; i++) {\n const key = propEventHandlers[i];\n if (this.propEventSubscriptions[key]) {\n this.propEventSubscriptions[key]();\n delete this.propEventSubscriptions[key];\n }\n const listenerName = (\"on\" + key);\n const listener = props[listenerName];\n if (listener) {\n this.propEventSubscriptions[key] = this.on(key, listener);\n }\n }\n this.prevMotionValues = updateMotionValuesFromProps(this, this.scrapeMotionValuesFromProps(props, this.prevProps, this), this.prevMotionValues);\n if (this.handleChildMotionValue) {\n this.handleChildMotionValue();\n }\n }\n getProps() {\n return this.props;\n }\n /**\n * Returns the variant definition with a given name.\n */\n getVariant(name) {\n return this.props.variants ? this.props.variants[name] : undefined;\n }\n /**\n * Returns the defined default transition on this component.\n */\n getDefaultTransition() {\n return this.props.transition;\n }\n getTransformPagePoint() {\n return this.props.transformPagePoint;\n }\n getClosestVariantNode() {\n return this.isVariantNode\n ? this\n : this.parent\n ? this.parent.getClosestVariantNode()\n : undefined;\n }\n getVariantContext(startAtParent = false) {\n if (startAtParent) {\n return this.parent ? this.parent.getVariantContext() : undefined;\n }\n if (!this.isControllingVariants) {\n const context = this.parent\n ? this.parent.getVariantContext() || {}\n : {};\n if (this.props.initial !== undefined) {\n context.initial = this.props.initial;\n }\n return context;\n }\n const context = {};\n for (let i = 0; i < numVariantProps; i++) {\n const name = variantProps[i];\n const prop = this.props[name];\n if (isVariantLabel(prop) || prop === false) {\n context[name] = prop;\n }\n }\n return context;\n }\n /**\n * Add a child visual element to our set of children.\n */\n addVariantChild(child) {\n const closestVariantNode = this.getClosestVariantNode();\n if (closestVariantNode) {\n closestVariantNode.variantChildren &&\n closestVariantNode.variantChildren.add(child);\n return () => closestVariantNode.variantChildren.delete(child);\n }\n }\n /**\n * Add a motion value and bind it to this visual element.\n */\n addValue(key, value) {\n // Remove existing value if it exists\n const existingValue = this.values.get(key);\n if (value !== existingValue) {\n if (existingValue)\n this.removeValue(key);\n this.bindToMotionValue(key, value);\n this.values.set(key, value);\n this.latestValues[key] = value.get();\n }\n }\n /**\n * Remove a motion value and unbind any active subscriptions.\n */\n removeValue(key) {\n this.values.delete(key);\n const unsubscribe = this.valueSubscriptions.get(key);\n if (unsubscribe) {\n unsubscribe();\n this.valueSubscriptions.delete(key);\n }\n delete this.latestValues[key];\n this.removeValueFromRenderState(key, this.renderState);\n }\n /**\n * Check whether we have a motion value for this key\n */\n hasValue(key) {\n return this.values.has(key);\n }\n getValue(key, defaultValue) {\n if (this.props.values && this.props.values[key]) {\n return this.props.values[key];\n }\n let value = this.values.get(key);\n if (value === undefined && defaultValue !== undefined) {\n value = motionValue(defaultValue === null ? undefined : defaultValue, { owner: this });\n this.addValue(key, value);\n }\n return value;\n }\n /**\n * If we're trying to animate to a previously unencountered value,\n * we need to check for it in our state and as a last resort read it\n * directly from the instance (which might have performance implications).\n */\n readValue(key, target) {\n var _a;\n let value = this.latestValues[key] !== undefined || !this.current\n ? this.latestValues[key]\n : (_a = this.getBaseTargetFromProps(this.props, key)) !== null && _a !== void 0 ? _a : this.readValueFromInstance(this.current, key, this.options);\n if (value !== undefined && value !== null) {\n if (typeof value === \"string\" &&\n (isNumericalString(value) || isZeroValueString(value))) {\n // If this is a number read as a string, ie \"0\" or \"200\", convert it to a number\n value = parseFloat(value);\n }\n else if (!findValueType(value) && complex.test(target)) {\n value = getAnimatableNone(key, target);\n }\n this.setBaseTarget(key, isMotionValue(value) ? value.get() : value);\n }\n return isMotionValue(value) ? value.get() : value;\n }\n /**\n * Set the base target to later animate back to. This is currently\n * only hydrated on creation and when we first read a value.\n */\n setBaseTarget(key, value) {\n this.baseTarget[key] = value;\n }\n /**\n * Find the base target for a value thats been removed from all animation\n * props.\n */\n getBaseTarget(key) {\n var _a;\n const { initial } = this.props;\n let valueFromInitial;\n if (typeof initial === \"string\" || typeof initial === \"object\") {\n const variant = resolveVariantFromProps(this.props, initial, (_a = this.presenceContext) === null || _a === void 0 ? void 0 : _a.custom);\n if (variant) {\n valueFromInitial = variant[key];\n }\n }\n /**\n * If this value still exists in the current initial variant, read that.\n */\n if (initial && valueFromInitial !== undefined) {\n return valueFromInitial;\n }\n /**\n * Alternatively, if this VisualElement config has defined a getBaseTarget\n * so we can read the value from an alternative source, try that.\n */\n const target = this.getBaseTargetFromProps(this.props, key);\n if (target !== undefined && !isMotionValue(target))\n return target;\n /**\n * If the value was initially defined on initial, but it doesn't any more,\n * return undefined. Otherwise return the value as initially read from the DOM.\n */\n return this.initialValues[key] !== undefined &&\n valueFromInitial === undefined\n ? undefined\n : this.baseTarget[key];\n }\n on(eventName, callback) {\n if (!this.events[eventName]) {\n this.events[eventName] = new SubscriptionManager();\n }\n return this.events[eventName].add(callback);\n }\n notify(eventName, ...args) {\n if (this.events[eventName]) {\n this.events[eventName].notify(...args);\n }\n }\n}\n\nexport { VisualElement };\n","import { VisualElement } from '../VisualElement.mjs';\nimport { DOMKeyframesResolver } from './DOMKeyframesResolver.mjs';\n\nclass DOMVisualElement extends VisualElement {\n constructor() {\n super(...arguments);\n this.KeyframeResolver = DOMKeyframesResolver;\n }\n sortInstanceNodePosition(a, b) {\n /**\n * compareDocumentPosition returns a bitmask, by using the bitwise &\n * we're returning true if 2 in that bitmask is set to true. 2 is set\n * to true if b preceeds a.\n */\n return a.compareDocumentPosition(b) & 2 ? 1 : -1;\n }\n getBaseTargetFromProps(props, key) {\n return props.style\n ? props.style[key]\n : undefined;\n }\n removeValueFromRenderState(key, { vars, style }) {\n delete vars[key];\n delete style[key];\n }\n}\n\nexport { DOMVisualElement };\n","import { isBrowser } from '../is-browser.mjs';\nimport { hasReducedMotionListener, prefersReducedMotion } from './state.mjs';\n\nfunction initPrefersReducedMotion() {\n hasReducedMotionListener.current = true;\n if (!isBrowser)\n return;\n if (window.matchMedia) {\n const motionMediaQuery = window.matchMedia(\"(prefers-reduced-motion)\");\n const setReducedMotionPreferences = () => (prefersReducedMotion.current = motionMediaQuery.matches);\n motionMediaQuery.addListener(setReducedMotionPreferences);\n setReducedMotionPreferences();\n }\n else {\n prefersReducedMotion.current = false;\n }\n}\n\nexport { initPrefersReducedMotion };\n","import { warnOnce } from '../../utils/warn-once.mjs';\nimport { motionValue } from '../../value/index.mjs';\nimport { isMotionValue } from '../../value/utils/is-motion-value.mjs';\n\nfunction updateMotionValuesFromProps(element, next, prev) {\n for (const key in next) {\n const nextValue = next[key];\n const prevValue = prev[key];\n if (isMotionValue(nextValue)) {\n /**\n * If this is a motion value found in props or style, we want to add it\n * to our visual element's motion value map.\n */\n element.addValue(key, nextValue);\n /**\n * Check the version of the incoming motion value with this version\n * and warn against mismatches.\n */\n if (process.env.NODE_ENV === \"development\") {\n warnOnce(nextValue.version === \"11.3.29\", `Attempting to mix Framer Motion versions ${nextValue.version} with 11.3.29 may not work as expected.`);\n }\n }\n else if (isMotionValue(prevValue)) {\n /**\n * If we're swapping from a motion value to a static value,\n * create a new motion value from that\n */\n element.addValue(key, motionValue(nextValue, { owner: element }));\n }\n else if (prevValue !== nextValue) {\n /**\n * If this is a flat value that has changed, update the motion value\n * or create one if it doesn't exist. We only want to do this if we're\n * not handling the value with our animation state.\n */\n if (element.hasValue(key)) {\n const existingValue = element.getValue(key);\n if (existingValue.liveStyle === true) {\n existingValue.jump(nextValue);\n }\n else if (!existingValue.hasAnimated) {\n existingValue.set(nextValue);\n }\n }\n else {\n const latestValue = element.getStaticValue(key);\n element.addValue(key, motionValue(latestValue !== undefined ? latestValue : nextValue, { owner: element }));\n }\n }\n }\n // Handle removed values\n for (const key in prev) {\n if (next[key] === undefined)\n element.removeValue(key);\n }\n return next;\n}\n\nexport { updateMotionValuesFromProps };\n","import { buildHTMLStyles } from './utils/build-styles.mjs';\nimport { isCSSVariableName } from '../dom/utils/is-css-variable.mjs';\nimport { transformProps } from './utils/transform.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\nimport { renderHTML } from './utils/render.mjs';\nimport { getDefaultValueType } from '../dom/value-types/defaults.mjs';\nimport { measureViewportBox } from '../../projection/utils/measure.mjs';\nimport { DOMVisualElement } from '../dom/DOMVisualElement.mjs';\nimport { isMotionValue } from '../../value/utils/is-motion-value.mjs';\n\nfunction getComputedStyle(element) {\n return window.getComputedStyle(element);\n}\nclass HTMLVisualElement extends DOMVisualElement {\n constructor() {\n super(...arguments);\n this.type = \"html\";\n this.applyWillChange = true;\n this.renderInstance = renderHTML;\n }\n readValueFromInstance(instance, key) {\n if (transformProps.has(key)) {\n const defaultType = getDefaultValueType(key);\n return defaultType ? defaultType.default || 0 : 0;\n }\n else {\n const computedStyle = getComputedStyle(instance);\n const value = (isCSSVariableName(key)\n ? computedStyle.getPropertyValue(key)\n : computedStyle[key]) || 0;\n return typeof value === \"string\" ? value.trim() : value;\n }\n }\n measureInstanceViewportBox(instance, { transformPagePoint }) {\n return measureViewportBox(instance, transformPagePoint);\n }\n build(renderState, latestValues, props) {\n buildHTMLStyles(renderState, latestValues, props.transformTemplate);\n }\n scrapeMotionValuesFromProps(props, prevProps, visualElement) {\n return scrapeMotionValuesFromProps(props, prevProps, visualElement);\n }\n handleChildMotionValue() {\n if (this.childSubscription) {\n this.childSubscription();\n delete this.childSubscription;\n }\n const { children } = this.props;\n if (isMotionValue(children)) {\n this.childSubscription = children.on(\"change\", (latest) => {\n if (this.current)\n this.current.textContent = `${latest}`;\n });\n }\n }\n}\n\nexport { HTMLVisualElement, getComputedStyle };\n","import { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\nimport { DOMVisualElement } from '../dom/DOMVisualElement.mjs';\nimport { buildSVGAttrs } from './utils/build-attrs.mjs';\nimport { camelToDash } from '../dom/utils/camel-to-dash.mjs';\nimport { camelCaseAttributes } from './utils/camel-case-attrs.mjs';\nimport { transformProps } from '../html/utils/transform.mjs';\nimport { renderSVG } from './utils/render.mjs';\nimport { getDefaultValueType } from '../dom/value-types/defaults.mjs';\nimport { createBox } from '../../projection/geometry/models.mjs';\nimport { isSVGTag } from './utils/is-svg-tag.mjs';\n\nclass SVGVisualElement extends DOMVisualElement {\n constructor() {\n super(...arguments);\n this.type = \"svg\";\n this.isSVGTag = false;\n this.measureInstanceViewportBox = createBox;\n }\n getBaseTargetFromProps(props, key) {\n return props[key];\n }\n readValueFromInstance(instance, key) {\n if (transformProps.has(key)) {\n const defaultType = getDefaultValueType(key);\n return defaultType ? defaultType.default || 0 : 0;\n }\n key = !camelCaseAttributes.has(key) ? camelToDash(key) : key;\n return instance.getAttribute(key);\n }\n scrapeMotionValuesFromProps(props, prevProps, visualElement) {\n return scrapeMotionValuesFromProps(props, prevProps, visualElement);\n }\n build(renderState, latestValues, props) {\n buildSVGAttrs(renderState, latestValues, this.isSVGTag, props.transformTemplate);\n }\n renderInstance(instance, renderState, styleProp, projection) {\n renderSVG(instance, renderState, styleProp, projection);\n }\n mount(instance) {\n this.isSVGTag = isSVGTag(instance.tagName);\n super.mount(instance);\n }\n}\n\nexport { SVGVisualElement };\n","import { Fragment } from 'react';\nimport { HTMLVisualElement } from '../html/HTMLVisualElement.mjs';\nimport { SVGVisualElement } from '../svg/SVGVisualElement.mjs';\nimport { isSVGComponent } from './utils/is-svg-component.mjs';\n\nconst createDomVisualElement = (Component, options) => {\n return isSVGComponent(Component)\n ? new SVGVisualElement(options)\n : new HTMLVisualElement(options, {\n allowProjection: Component !== Fragment,\n });\n};\n\nexport { createDomVisualElement };\n","import { createMotionComponent } from '../../motion/index.mjs';\nimport { createMotionProxy } from './motion-proxy.mjs';\nimport { createDomMotionConfig } from './utils/create-config.mjs';\nimport { gestureAnimations } from '../../motion/features/gestures.mjs';\nimport { animations } from '../../motion/features/animations.mjs';\nimport { drag } from '../../motion/features/drag.mjs';\nimport { createDomVisualElement } from './create-visual-element.mjs';\nimport { layout } from '../../motion/features/layout.mjs';\n\nconst preloadedFeatures = {\n ...animations,\n ...gestureAnimations,\n ...drag,\n ...layout,\n};\n/**\n * HTML & SVG components, optimised for use with gestures and animation. These can be used as\n * drop-in replacements for any HTML & SVG component, all CSS & SVG properties are supported.\n *\n * @public\n */\nconst motion = /*@__PURE__*/ createMotionProxy((Component, config) => createDomMotionConfig(Component, config, preloadedFeatures, createDomVisualElement));\n/**\n * Create a DOM `motion` component with the provided string. This is primarily intended\n * as a full alternative to `motion` for consumers who have to support environments that don't\n * support `Proxy`.\n *\n * ```javascript\n * import { createDomMotionComponent } from \"framer-motion\"\n *\n * const motion = {\n * div: createDomMotionComponent('div')\n * }\n * ```\n *\n * @public\n */\nfunction createDomMotionComponent(key) {\n return createMotionComponent(createDomMotionConfig(key, { forwardMotionProps: false }, preloadedFeatures, createDomVisualElement));\n}\n\nexport { createDomMotionComponent, motion };\n","import { HTMLProjectionNode } from '../../projection/node/HTMLProjectionNode.mjs';\nimport { MeasureLayout } from './layout/MeasureLayout.mjs';\n\nconst layout = {\n layout: {\n ProjectionNode: HTMLProjectionNode,\n MeasureLayout,\n },\n};\n\nexport { layout };\n","import { isSVGComponent } from './is-svg-component.mjs';\nimport { createUseRender } from '../use-render.mjs';\nimport { svgMotionConfig } from '../../svg/config-motion.mjs';\nimport { htmlMotionConfig } from '../../html/config-motion.mjs';\n\nfunction createDomMotionConfig(Component, { forwardMotionProps = false }, preloadedFeatures, createVisualElement) {\n const baseConfig = isSVGComponent(Component)\n ? svgMotionConfig\n : htmlMotionConfig;\n return {\n ...baseConfig,\n preloadedFeatures,\n useRender: createUseRender(forwardMotionProps),\n createVisualElement,\n Component,\n };\n}\n\nexport { createDomMotionConfig };\n"],"names":["module","exports","Object","defineProperty","value","_param","src","sizes","unoptimized","priority","loading","className","quality","width","height","fill","style","onLoad","onLoadingComplete","placeholder","blurDataURL","layout","objectFit","objectPosition","lazyBoundary","lazyRoot","all","_object_without_properties_loose","configContext","_react","useContext","_imageConfigContext","ImageConfigContext","config","useMemo","c","configEnv","_imageConfig","imageConfigDefault","allSizes","deviceSizes","imageSizes","sort","a","b","_extends","rest","loader","_imageLoader","default","Error","customImageLoader","obj","_","opts","layoutToSizes","responsive","layoutStyle","intrinsic","maxWidth","layoutSizes","blurWidth","blurHeight","staticSrc","widthInt","getInt","heightInt","isStaticRequire","undefined","isStaticImageData","isStaticImport","staticImageData","JSON","stringify","ratio","Math","round","isLazy","startsWith","blurComplete","setBlurComplete","useState","showAltText","setShowAltText","qualityInt","process","imgStyle","assign","position","left","top","right","bottom","color","blurStyle","backgroundSize","backgroundPosition","backgroundRepeat","backgroundImage","_imageBlurSvg","getImageBlurSvg","imgAttributes","srcSet","widths","kind","viewportWidthRe","percentSizes","match","exec","push","parseInt","length","smallestRatio","min","filter","s","Set","map","w","find","p","getWidths","last","i","join","generateImgAttrs","srcString","linkProps","imageSrcSet","crossOrigin","onLoadRef","useRef","useEffect","current","onLoadingCompleteRef","imgElementArgs","createElement","Fragment","ImageElement","_head","key","rel","as","href","require","_interop_require_default","_interop_require_wildcard","Map","x","test","NaN","handleLoading","img","decode","Promise","resolve","catch","then","parentNode","event","Event","writable","prevented","stopped","nativeEvent","currentTarget","target","isDefaultPrevented","isPropagationStopped","persist","preventDefault","stopPropagation","onError","decoding","ref","useCallback","complete","__esModule","std","svgWidth","svgHeight","feComponentTransfer","defaultLoader","endsWith","dangerouslyAllowSVG","encodeURIComponent","path","__next_img_default","_default","MotionConfigContext","createContext","transformPagePoint","isStatic","reducedMotion","MotionContext","isBrowser","window","useIsomorphicLayoutEffect","useLayoutEffect","LazyContext","strict","camelToDash","str","replace","toLowerCase","optimizedAppearDataAttribute","MotionGlobalConfig","stepsOrder","createRenderBatcher","scheduleNextBatch","allowKeepAlive","runNextFrame","useDefaultElapsed","state","delta","timestamp","isProcessing","flagRunNextFrame","steps","reduce","acc","thisFrame","nextFrame","flushNextFrame","toKeepAlive","WeakSet","latestFrameData","triggerCallback","callback","has","step","schedule","keepAlive","immediate","queue","add","cancel","delete","frameData","clear","forEach","createRenderStep","read","resolveKeyframes","update","preRender","render","postRender","processBatch","performance","now","max","microtask","cancelMicrotask","queueMicrotask","isRefObject","prototype","hasOwnProperty","call","SwitchLayoutGroupContext","scheduleHandoffComplete","useVisualElement","Component","visualState","props","createVisualElement","ProjectionNodeConstructor","_a","visualElement","parent","lazyContext","presenceContext","reducedMotionConfig","visualElementRef","renderer","blockInitialAnimation","initial","initialLayoutGroupConfig","projection","type","initialPromotionConfig","layoutId","drag","dragConstraints","layoutScroll","layoutRoot","latestValues","getClosestProjectingNode","setOptions","alwaysMeasureLayout","Boolean","animationType","createProjectionNode","useInsertionEffect","optimisedAppearId","wantsHandoff","MotionHandoffIsComplete","MotionHasOptimisedAnimation","updateFeatures","animationState","animateChanges","completeHandoff","options","allowProjection","useMotionRef","externalRef","instance","mount","unmount","isVariantLabel","v","Array","isArray","isAnimationControls","start","variantPriorityOrder","variantProps","isControllingVariants","animate","some","name","isVariantNode","variants","useCreateMotionContext","context","inherit","getCurrentTreeVariants","variantLabelsAsDependency","prop","featureProps","animation","exit","focus","hover","tap","pan","inView","featureDefinitions","isEnabled","LayoutGroupContext","motionComponentSymbol","Symbol","for","preloadedFeatures","useRender","useVisualState","features","loadFeatures","ForwardRefComponent","forwardRef","MeasureLayout","configAndProps","useLayoutId","useStrictMode","layoutProjection","combined","ProjectionNode","getProjectionFunctionality","jsxs","Provider","children","jsx","layoutGroupId","id","createMotionProxy","createConfig","custom","customMotionComponentConfig","Proxy","componentCache","get","_target","set","lowercaseSVGElements","isSVGComponent","includes","indexOf","scaleCorrectors","transformPropOrder","transformProps","isForcedMotionValue","isMotionValue","getVelocity","getValueAsType","transform","clamp","number","parse","parseFloat","alpha","scale","sanitize","floatRegex","colorRegex","singleColorRegex","isString","createUnitType","unit","split","degrees","percent","px","vh","vw","progressPercentage","numberValueTypes","borderWidth","borderTopWidth","borderRightWidth","borderBottomWidth","borderLeftWidth","borderRadius","radius","borderTopLeftRadius","borderTopRightRadius","borderBottomRightRadius","borderBottomLeftRadius","maxHeight","size","padding","paddingTop","paddingRight","paddingBottom","paddingLeft","margin","marginTop","marginRight","marginBottom","marginLeft","rotate","rotateX","rotateY","rotateZ","scaleX","scaleY","scaleZ","skew","skewX","skewY","distance","translateX","translateY","translateZ","y","z","perspective","transformPerspective","opacity","originX","originY","originZ","zIndex","backgroundPositionX","backgroundPositionY","fillOpacity","strokeOpacity","numOctaves","translateAlias","numTransforms","checkStringStartsWith","token","isCSSVariableName","startsAsVariableToken","isCSSVariableToken","singleCssVariableRegex","trim","buildHTMLStyles","transformTemplate","vars","transformOrigin","hasTransform","hasTransformOrigin","valueAsType","transformString","transformIsDefault","valueIsDefault","buildTransform","createHtmlRenderState","copyRawValuesOnly","source","useStyle","useInitialMotionValues","useHTMLProps","htmlProps","dragListener","draggable","userSelect","WebkitUserSelect","WebkitTouchCallout","touchAction","tabIndex","onTap","onTapStart","whileTap","validMotionProps","isValidMotionProp","shouldForward","isValidProp","calcOrigin","origin","offset","dashKeys","array","camelKeys","buildSVGAttrs","attrX","attrY","attrScale","pathLength","pathSpacing","pathOffset","latest","isSVGTag","viewBox","attrs","dimensions","calcSVGTransformOrigin","spacing","useDashCase","keys","buildSVGPath","createSvgRenderState","tag","useSVGProps","_isStatic","visualProps","rawStyles","createUseRender","forwardMotionProps","filteredProps","isDom","values","filterProps","elementProps","renderedChildren","renderHTML","element","styleProp","getProjectionStyles","setProperty","camelCaseAttributes","renderSVG","renderState","_styleProp","setAttribute","scrapeMotionValuesFromProps","prevProps","newValues","getValue","liveStyle","willChange","applyWillChange","charAt","toUpperCase","substring","getValueState","resolveVariantFromProps","definition","velocity","isKeyframesTarget","resolveMotionValue","unwrappedValue","mix","toValue","acceleratedValues","getWillChangeName","addUniqueItem","arr","item","removeItem","index","splice","makeUseVisualState","make","createRenderState","onMount","makeLatestValues","makeState","init","useConstant","addWillChange","memberName","forEachDefinition","list","resolved","transitionEnd","transition","shouldApplyWillChange","scrapeMotionValues","motionValues","isControllingVariants$1","isVariantNode$1","isInitialAnimationBlocked","variantToSet","valueTarget","noop","any","cancelFrame","requestAnimationFrame","svgMotionConfig","getBBox","getBoundingClientRect","e","tagName","htmlMotionConfig","addDomEvent","eventName","handler","passive","addEventListener","removeEventListener","isPrimaryPointer","pointerType","button","isPrimary","extractEventInfo","pointType","point","addPointerEvent","addPointerInfo","combineFunctions","pipe","transformers","createLock","lock","openLock","globalHorizontalLock","globalVerticalLock","getGlobalLock","openHorizontal","openVertical","isDragActive","openGestureLock","Feature","constructor","node","this","isMounted","addHoverEvent","isActive","callbackName","info","getProps","whileHover","setActive","isNodeOrChild","child","parentElement","fireSyntheticPointerEvent","syntheticPointerEvent","PointerEvent","observerCallbacks","WeakMap","observers","fireObserverCallback","entry","fireAllObserverCallbacks","entries","observeIntersection","rootInteresectionObserver","root","lookupRoot","document","rootObservers","IntersectionObserver","initIntersectionObserver","observe","unobserve","thresholdNames","gestureAnimations","super","arguments","hasEnteredView","isInView","startObserver","viewport","rootMargin","amount","once","threshold","isIntersecting","onViewportEnter","onViewportLeave","prevViewport","hasViewportOptionChanged","removeStartListeners","removeEndListeners","removeAccessibleListeners","startPointerPress","startEvent","startInfo","isPressing","removePointerUpListener","endEvent","endInfo","checkPressEnd","onTapCancel","globalTapTarget","removePointerCancelListener","cancelEvent","cancelInfo","cancelPress","startPress","startAccessiblePress","removeKeydownListener","keydownEvent","keyupEvent","removeBlurListener","removePointerListener","removeFocusListener","onFocus","isFocusVisible","matches","onBlur","shallowCompare","next","prev","prevLength","resolveVariant","secondsToMilliseconds","seconds","millisecondsToSeconds","milliseconds","underDampedSpring","stiffness","damping","restSpeed","keyframesTransition","duration","ease","getDefaultTransition","valueKey","keyframes","sqrt","getValueTransition","instantAnimationState","isNotNull","getFinalKeyframe","repeat","repeatType","finalKeyframe","resolvedKeyframes","isZeroValueString","warning","invariant","isNumericalString","splitCSSVariableRegex","getVariableValue","depth","fallback","token1","token2","parseCSSVariable","getComputedStyle","getPropertyValue","trimmed","positionalKeys","isNumOrPxType","getPosFromMatrix","matrix","pos","getTranslateFromMatrix","pos2","pos3","_bbox","matrix3d","transformKeys","nonTranslationalTransformKeys","positionalValues","testValueType","dimensionValueTypes","findDimensionValueType","toResolve","isScheduled","anyNeedsMeasurement","measureAllKeyframes","resolversToMeasure","from","resolver","needsMeasurement","elementsToMeasure","transformsToRestore","removedTransforms","removeNonTranslationalTransform","measureInitialState","restore","measureEndState","suspendedScrollY","scrollTo","readAllKeyframes","readKeyframes","KeyframeResolver","unresolvedKeyframes","onComplete","motionValue","isAsync","isComplete","scheduleResolve","currentValue","valueAsRead","readValue","setFinalKeyframe","renderEndStyles","resume","isColorString","testProp","isNullish","splitColor","aName","bName","cName","rgbUnit","clampRgbUnit","rgba","red","green","blue","alpha$1","hex","r","g","hsla","hue","saturation","lightness","NUMBER_TOKEN","COLOR_TOKEN","complexRegex","analyseComplexValue","originalValue","toString","indexes","var","types","parsedValue","parseComplexValue","createTransformer","numSections","output","convertNumbersToZero","complex","_b","isNaN","getAnimatableNone","parsed","transformer","maxDefaults","applyDefaultFilter","slice","defaultValue","functionRegex","functions","defaultValueTypes","backgroundColor","outlineColor","stroke","borderColor","borderTopColor","borderRightColor","borderBottomColor","borderLeftColor","WebkitFilter","getDefaultValueType","defaultValueType","invalidTemplates","DOMKeyframesResolver","keyframe","resolveNoneKeyframes","originType","targetType","noneKeyframeIndexes","animatableTemplate","noneIndex","makeNoneKeyframesAnimatable","pageYOffset","measuredOrigin","measureViewportBox","measureKeyframe","jump","finalKeyframeIndex","unsetTransformName","unsetTransformValue","memo","result","clearTime","time","newTime","isAnimatable","BaseAnimation","autoplay","delay","repeatDelay","isStopped","hasAttemptedResolve","createdAt","updateFinishedPromise","calcStartTime","resolvedAt","_resolved","onKeyframesResolved","onUpdate","isGenerator","originKeyframe","targetKeyframe","isOriginAnimatable","isTargetAnimatable","hasKeyframesChanged","canAnimate","resolveFinishedPromise","resolvedAnimation","initPlayback","onPostResolved","reject","currentFinishedPromise","velocityPerSecond","frameDuration","calcGeneratorVelocity","resolveValue","t","prevT","safeMin","findSpring","bounce","mass","envelope","derivative","dampingRatio","undampedFreq","exponentialDecay","calcAngularFreq","exp","d","pow","f","initialGuess","approximateRoot","durationKeys","physicsKeys","isSpringType","spring","restDelta","done","isResolvedFromDuration","springOptions","derived","getSpringOptions","initialVelocity","initialDelta","undampedAngularFreq","isGranularScale","abs","resolveSpring","angularFreq","sin","cos","dampedAngularFreq","freqForT","sinh","cosh","calculatedDuration","currentVelocity","isBelowVelocityThreshold","isBelowDisplacementThreshold","inertia","power","timeConstant","bounceDamping","bounceStiffness","modifyTarget","nearestBoundary","amplitude","ideal","calcDelta","calcLatest","applyFriction","timeReachedBoundary","spring$1","checkCatchBoundary","hasUpdatedFrame","calcBezier","a1","a2","cubicBezier","mX1","mY1","mX2","mY2","getTForX","aX","lowerBound","upperBound","currentX","currentT","binarySubdivide","easeIn","easeOut","easeInOut","mirrorEasing","easing","reverseEasing","circIn","acos","circOut","circInOut","backOut","backIn","backInOut","easingLookup","linear","anticipate","easingDefinitionToFunction","x1","y1","x2","y2","progress","to","toFromDifference","mixNumber","hueToRgb","q","mixImmediate","mixLinearColor","fromExpo","expo","colorTypes","asRGBA","model","hslaToRgba","mixColor","fromRGBA","toRGBA","blended","invisibleValues","getMixer","mixComplex","mixArray","mixObject","numValues","blendValue","template","originStats","targetStats","mixVisibility","orderedOrigin","pointers","originIndex","originValue","matchOrder","mixer","interpolate","input","isClamp","inputLength","reverse","mixers","customMixer","mixerFactory","numMixers","easingFunction","createMixers","interpolator","progressInRange","defaultOffset","remaining","offsetProgress","fillOffset","keyframeValues","times","easingFunctions","isEasingArray","absoluteTimes","o","convertOffsetToTimes","mapTimeToKeyframe","frameloopDriver","passTimestamp","stop","generators","decay","tween","percentToProgress","MainThreadAnimation","holdTime","cancelTime","currentTime","playbackSpeed","pendingPlayState","startTime","teardown","onStop","KeyframeResolver$1","keyframes$1","generatorFactory","mapPercentToKeyframes","mirroredGenerator","generator","Infinity","calcGeneratorDuration","resolvedDuration","totalDuration","play","pause","tick","sample","speed","timeWithoutDelay","isInDelayPhase","elapsed","frameGenerator","currentIteration","floor","iterationProgress","isAnimationFinished","finish","driver","newSpeed","hasChanged","onPlay","stopDriver","isBezierDefinition","isWaapiSupportedEasing","supportedWaapiEasing","every","cubicBezierAsString","mapEasingToNativeEasingWithDefault","mapEasingToNativeEasing","supportsWaapi","Element","AcceleratedAnimation","owner","pregeneratedAnimation","sampleAnimation","pregeneratedKeyframes","pregenerateKeyframes","valueName","keyframeOptions","iterations","direction","animateStyle","pendingTimeline","timeline","onfinish","playbackRate","playState","attachTimeline","sampleTime","setWithVelocity","static","HTMLElement","supportsScrollTimeline","ScrollTimeline","GroupPlaybackControls","animations","runAll","onResolve","onReject","getAll","propName","setAll","newValue","cancelAll","prevProgress","onFrame","observeTimeline","cancelTimeline","methodName","controls","animateMotionValue","isHandoff","onEnd","valueTransition","when","_delay","delayChildren","staggerChildren","staggerDirection","isTransitionDefined","shouldSkip","supports","SubscriptionManager","subscriptions","notify","numSubscriptions","getSize","collectMotionValues","MotionValue","version","canTrackVelocity","events","updateAndNotify","updatedAt","setPrevFrameValue","setCurrent","change","renderRequest","hasAnimated","prevFrameValue","prevUpdatedAt","onChange","subscription","on","unsubscribe","clearListeners","eventManagers","attach","passiveEffect","stopPassiveEffect","endAnimation","getPrevious","startAnimation","animationStart","animationComplete","clearAnimation","animationCancel","isAnimating","destroy","setMotionValue","hasValue","addValue","getOptimisedAppearId","WillChangeMotionValue","counts","styleName","prevCount","hasRemoved","newCount","addValueToWillChange","shouldBlockAnimation","protectedKeys","needsAnimating","shouldBlock","animateTarget","targetAndTransition","transitionOverride","animationTypeState","getState","MotionHandoffAnimation","appearId","shouldReduceMotion","setTarget","animateVariant","variant","getAnimation","getChildAnimations","variantChildren","forwardDelay","maxStaggerDuration","generateStaggerDuration","sortByTreeOrder","animateChildren","first","sortNodePosition","reversePriorityOrder","numAnimationTypes","animateList","resolvedDefinition","animateVisualElement","checkVariantsDidChange","createTypeState","prevResolvedValues","createState","whileInView","whileDrag","whileFocus","isInitialRender","buildResolvedTypeValues","changedActiveType","getVariantContext","removedKeys","encounteredKeys","removedVariantIndex","typeState","propIsVariant","activeDelta","isInherited","manuallyAnimateOnMount","prevProp","shouldAnimateType","handledRemovedValues","definitionList","resolvedValues","allKeys","markToAnimate","valueHasChanged","fallbackAnimation","fallbackTarget","getBaseTarget","shouldAnimate","setAnimateFunction","makeAnimator","reset","createAnimationState","updateAnimationControlsSubscription","unmountControls","subscribe","prevAnimate","isPresent","onExitComplete","prevIsPresent","prevPresenceContext","exitAnimation","register","PanSession","handlers","contextWindow","dragSnapToOrigin","lastMoveEvent","lastMoveEventInfo","updatePoint","getPanInfo","history","isPanStarted","isDistancePastThreshold","xDelta","yDelta","distance2D","onStart","onMove","handlePointerMove","transformPoint","handlePointerUp","end","onSessionEnd","resumeAnimation","panInfo","initialInfo","onSessionStart","removeListeners","updateHandlers","subtractPoint","lastDevicePoint","startDevicePoint","timeDelta","timestampedPoint","lastPoint","calcLength","axis","calcAxisDelta","originPoint","translate","calcBoxDelta","calcRelativeAxis","relative","calcRelativeAxisPosition","calcRelativePosition","calcRelativeAxisConstraints","calcViewportAxisConstraints","layoutAxis","constraintsAxis","defaultElastic","resolveAxisElastic","dragElastic","minLabel","maxLabel","resolvePointElastic","label","createBox","eachAxis","convertBoundingBoxToBox","isIdentityScale","hasScale","has2DTranslate","is2DTranslate","scalePoint","applyPointDelta","boxScale","applyAxisDelta","applyBoxDelta","box","TREE_SCALE_SNAP_MIN","TREE_SCALE_SNAP_MAX","translateAxis","transformAxis","axisTranslate","axisScale","axisOrigin","transformBox","topLeft","bottomRight","transformBoxPoints","getContextWindow","ownerDocument","defaultView","elementDragControls","VisualElementDragControls","openGlobalLock","isDragging","currentDirection","constraints","hasMutatedConstraints","elastic","originEvent","snapToCursor","panSession","pauseAnimation","stopAnimation","dragPropagation","onDragStart","resolveConstraints","isAnimationBlocked","getAxisMotionValue","measuredAxis","layoutBox","removeWillChange","dragDirectionLock","onDirectionLock","onDrag","lockThreshold","getCurrentDirection","updateAxis","getAnimationState","getTransformPagePoint","onDragEnd","_point","shouldDrag","axisValue","applyConstraints","measure","prevConstraints","resolveRefConstraints","calcRelativeConstraints","resolveDragElastic","relativeConstraints","rebaseAxisConstraints","onMeasureDragConstraints","constraintsElement","constraintsBox","rootProjectionNode","viewportBox","scroll","measurePageBox","measuredConstraints","calcViewportConstraints","userConstraints","convertBoxToBoundingBox","dragMomentum","dragTransition","onDragTransitionEnd","momentumAnimations","startAxisValueAnimation","dragKey","externalMotionValue","scalePositionWithinConstraints","boxProgress","sourceLength","targetLength","updateScroll","updateLayout","addListeners","stopPointerListener","measureDragConstraints","stopMeasureLayoutListener","stopResizeListener","stopLayoutUpdateListener","hasLayoutChanged","asyncHandler","globalProjectionState","hasAnimatedSinceResize","hasEverUpdated","pixelsToPercent","pixels","correctBorderRadius","correct","correctBoxShadow","treeScale","projectionDelta","original","shadow","xScale","yScale","averageScale","MeasureLayoutWithContext","componentDidMount","layoutGroup","switchLayoutGroup","correctors","defaultScaleCorrectors","group","didUpdate","safeToRemove","getSnapshotBeforeUpdate","layoutDependency","willUpdate","promote","relegate","stack","getStack","members","componentDidUpdate","currentAnimation","isLead","componentWillUnmount","promoteContext","scheduleCheckAfterUnmount","remove","deregister","useId","usePresence","applyTo","boxShadow","borders","numBorders","asNumber","isPx","getRadius","radiusName","easeCrossfadeIn","compress","easeCrossfadeOut","copyAxisInto","originAxis","copyBoxInto","originBox","copyAxisDeltaInto","originDelta","removePointDelta","removeAxisTransforms","transforms","scaleKey","originKey","sourceAxis","removeAxisDelta","xKeys","yKeys","removeBoxTransforms","sourceBox","isAxisDeltaZero","isDeltaZero","axisEquals","axisEqualsRounded","boxEqualsRounded","aspectRatio","axisDeltaEquals","NodeStack","scheduleRender","prevLead","lead","indexOfNode","findIndex","member","preserveFollowOpacity","show","resumeFrom","preserveOpacity","snapshot","animationValues","isUpdating","isLayoutDirty","crossfade","hide","exitAnimationComplete","resumingFrom","removeLeadSnapshot","compareByDepth","FlatTree","isDirty","metrics","totalNodes","resolvedTargetDeltas","recalculatedProjection","isDebug","MotionDebug","transformAxes","hiddenVisibility","visibility","resetDistortingTransform","sharedAnimationValues","setStaticValue","cancelTreeOptimisedTransformAnimations","projectionNode","hasCheckedOptimisedAppear","MotionHasOptimisedTransformAnimation","MotionCancelOptimisedTransform","attachResizeListener","defaultParent","measureScroll","checkIsScrollRoot","resetTransform","animationId","isTreeAnimating","isProjectionDirty","isSharedProjectionDirty","isTransformDirty","updateManuallyBlocked","updateBlockedByResize","isSVG","needsReset","shouldResetTransform","eventHandlers","hasTreeAnimated","updateScheduled","scheduleUpdate","projectionUpdateScheduled","checkUpdateFailed","clearAllSnapshots","updateProjection","nodes","propagateDirtyNodes","resolveTargetDelta","calcProjection","cleanDirtyNodes","record","resolvedRelativeTargetAt","hasProjected","isVisible","animationProgress","sharedNodes","notifyListeners","args","subscriptionManager","hasListeners","SVGElement","cancelDelay","resizeUnblockUpdate","timeout","checkElapsed","finishAnimation","registerSharedNode","hasRelativeTargetChanged","newLayout","isTreeAnimationBlocked","relativeTarget","layoutTransition","defaultLayoutTransition","onLayoutAnimationStart","onLayoutAnimationComplete","targetChanged","targetLayout","hasOnlyRelativeTargetChanged","setAnimationOrigin","animationOptions","blockUpdate","unblockUpdate","isUpdateBlocked","startUpdate","resetSkewAndRotation","getTransformTemplate","shouldNotifyListeners","prevTransformTemplateValue","updateSnapshot","clearMeasurements","clearIsLayoutDirty","resetTransformStyle","notifyLayoutUpdate","clearSnapshot","removeLeadSnapshots","scheduleUpdateProjection","prevLayout","layoutCorrected","phase","isRoot","wasRoot","isResetRequested","hasProjection","transformTemplateValue","transformTemplateHasChanged","removeTransform","pageBox","removeElementScroll","roundAxis","measuredBox","checkNodeWasScrollRoot","boxWithoutScroll","applyTransform","transformOnly","withTransforms","boxWithoutTransform","setTargetDelta","targetDelta","forceRelativeParentToResolveTarget","relativeParent","forceRecalculation","getLead","isShared","attemptToResolveRelativeTarget","getClosestProjectingParent","relativeTargetOrigin","targetWithTransforms","isProjecting","canSkip","pendingAnimation","prevTreeScaleX","prevTreeScaleY","treePath","isSharedTransition","treeLength","display","applyTreeDeltas","prevProjectionDelta","createProjectionDeltas","notifyAll","projectionDeltaWithTransform","snapshotLatestValues","mixedValues","relativeLayout","isSharedLayoutAnimation","isOnlyMember","shouldCrossfadeOpacity","hasOpacityCrossfade","prevRelativeTarget","mixTargetDelta","mixAxisDelta","mixAxis","follow","opacityExit","borderLabel","followRadius","leadRadius","mixValues","motionValue$1","animateSingleValue","completeAnimation","applyTransformsToTarget","shouldAnimatePositionOnly","xLength","yLength","shouldPreserveFollowOpacity","getPrevLead","hasDistortingTransform","resetValues","styles","pointerEvents","emptyStyles","valuesToRender","latestTransform","xTranslate","yTranslate","zTranslate","elementScaleX","elementScaleY","buildProjectionTransform","corrected","num","resetTree","measuredLayout","axisSnapshot","layoutDelta","visualDelta","parentSnapshot","parentLayout","relativeSnapshot","onBeforeLayoutMeasure","userAgentContains","string","navigator","userAgent","roundPoint","maxDistance","DocumentProjectionNode","documentElement","scrollLeft","body","scrollTop","HTMLProjectionNode","documentNode","removePointerDownListener","onPointerDown","pointerDownEvent","session","createPanHandlers","onPanSessionStart","onPanStart","onPan","onPanEnd","removeGroupControls","dragControls","prefersReducedMotion","hasReducedMotionListener","visualElementStore","valueTypes","propEventHandlers","numVariantProps","DOMVisualElement","_props","_prevProps","_visualElement","valueSubscriptions","prevMotionValues","propEventSubscriptions","notifyUpdate","isRenderScheduled","triggerBuild","renderInstance","baseTarget","initialValues","initialMotionValues","removeFromVariantTree","addVariantChild","bindToMotionValue","matchMedia","motionMediaQuery","setReducedMotionPreferences","addListener","initPrefersReducedMotion","feature","valueIsTransform","removeOnChange","latestValue","removeOnRenderRequest","other","sortInstanceNodePosition","featureDefinition","FeatureConstructor","build","measureInstanceViewportBox","getStaticValue","listener","nextValue","prevValue","existingValue","removeValue","updateMotionValuesFromProps","handleChildMotionValue","getVariant","getClosestVariantNode","startAtParent","closestVariantNode","removeValueFromRenderState","getBaseTargetFromProps","readValueFromInstance","setBaseTarget","valueFromInitial","compareDocumentPosition","HTMLVisualElement","defaultType","computedStyle","childSubscription","textContent","SVGVisualElement","getAttribute","motion"],"sourceRoot":""}