{"version":3,"file":"1322-365d05d93b2f8cc78b1f.js","mappings":"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","sources":["webpack://react-app/./node_modules/.pnpm/react@19.0.0/node_modules/react/cjs/react-jsx-runtime.production.js","webpack://react-app/./node_modules/.pnpm/react@19.0.0/node_modules/react/jsx-runtime.js","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/components/AnimatePresence/use-presence.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/context/LayoutGroupContext.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/context/MotionConfigContext.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/context/PresenceContext.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/components/create-proxy.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/utils/is-animation-controls.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/resolve-variants.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/resolve-dynamic-variants.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/animation/utils/get-value-transition.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/utils/keys-transform.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/utils/keys-position.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/utils/is-keyframes-target.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/resolve-value.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/GlobalConfig.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-utils/dist/es/noop.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/frameloop/order.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/stats/buffer.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/frameloop/batcher.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/frameloop/render-step.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/frameloop/frame.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/frameloop/sync-time.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/array.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/subscription-manager.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/velocity-per-second.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/setters.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/utils/is-motion-value.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/use-will-change/add-will-change.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/use-will-change/is.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/utils/camel-to-dash.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/optimized-appear/data-id.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/optimized-appear/get-appear-id.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-utils/dist/es/memo.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/utils/supports/scroll-timeline.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/animation/controls/BaseGroup.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/animation/controls/Group.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-utils/dist/es/time-conversion.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/use-instant-transition-state.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/animation/generators/utils/is-generator.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/animation/waapi/utils/attach-timeline.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/utils/is-bezier-definition.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/utils/supports/flags.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/utils/supports/memo.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/utils/supports/linear-easing.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-utils/dist/es/progress.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/animation/waapi/utils/linear.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/animation/waapi/utils/easing.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/easing/cubic-bezier.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/easing/modifiers/mirror.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/easing/modifiers/reverse.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/easing/back.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/easing/anticipate.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/easing/circ.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/is-zero-value-string.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/clamp.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/numbers/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/utils/sanitize.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/utils/float-regex.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/utils/single-color-regex.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/color/utils.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/utils/is-nullish.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/color/rgba.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/color/hex.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/numbers/units.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/color/hsla.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/color/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/utils/color-regex.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/complex/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/types/complex/filter.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/number-browser.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/transform.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/type-int.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/number.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/defaults.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/animatable-none.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/utils/make-none-animatable.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/utils/unit-conversion.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/KeyframesResolver.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-utils/dist/es/errors.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/is-numerical-string.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/utils/is-css-variable.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/utils/css-variables-conversion.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/test.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/dimensions.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/type-auto.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/DOMKeyframesResolver.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/utils/is-none.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/utils/is-animatable.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animators/utils/can-animate.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/get-final-keyframe.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animators/BaseAnimation.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/animation/generators/utils/calc-duration.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/stats/animation-count.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/mix/number.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/hsla-to-rgba.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/mix/immediate.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/mix/color.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/pipe.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/mix/visibility.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/mix/complex.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/mix/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/generators/utils/velocity.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/generators/spring/defaults.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/generators/spring/find.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/generators/spring/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/generators/inertia.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/easing/ease.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/easing/utils/map.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/interpolate.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/offsets/default.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/offsets/fill.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/generators/keyframes.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/easing/utils/is-easing-array.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/offsets/time.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animators/drivers/driver-frameloop.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animators/MainThreadAnimation.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animators/utils/accelerated-values.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animators/waapi/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/supports-waapi.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animators/AcceleratedAnimation.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/utils/default-transitions.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/interfaces/motion-value.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/utils/is-transition-defined.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/interfaces/visual-element-target.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/interfaces/visual-element-variant.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/shallow-compare.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/is-variant-label.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/variant-props.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/get-variant-context.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/animation-state.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/interfaces/visual-element.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/Feature.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/animation/exit.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/animations.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/animation/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/drag/state/is-active.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/utils/is-primary-pointer.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/events/add-dom-event.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/events/event-info.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/events/add-pointer-event.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/distance.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/gestures/pan/PanSession.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/is-ref-object.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/geometry/delta-calc.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/gestures/drag/utils/constraints.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/geometry/models.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/utils/each-axis.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/geometry/conversion.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/utils/has-transform.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/geometry/delta-apply.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/utils/measure.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/get-context-window.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/gestures/drag/VisualElementDragControls.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/drag/state/set-active.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/gestures/pan/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/context/SwitchLayoutGroupContext.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/node/state.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/styles/scale-border-radius.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/styles/scale-box-shadow.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/styles/scale-correction.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/frameloop/microtask.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/layout/MeasureLayout.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/compare-by-depth.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/flat-tree.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/delay.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/value/utils/resolve-motion-value.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/animation/mix-values.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/geometry/copy.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/geometry/delta-remove.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/geometry/utils.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/shared/stack.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/node/create-projection-node.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/utils/is-svg-element.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/animation/animate/single-value.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/styles/transform.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/node/DocumentProjectionNode.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/projection/node/HTMLProjectionNode.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/drag.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/gestures/drag/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/utils/setup.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/hover.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/gestures/hover.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/utils/is-node-or-child.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/press/utils/is-keyboard-accessible.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/press/utils/state.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/press/utils/keyboard.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/gestures/press/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/gestures/press.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/viewport/observers.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/viewport/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/gestures.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/gestures/focus.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/layout.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/context/LazyContext.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/context/MotionContext/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/is-controlling-variants.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/context/MotionContext/create.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/context/MotionContext/utils.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/definitions.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/utils/symbol.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/utils/use-motion-ref.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/utils/use-visual-element.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/features/load-features.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/utils/is-forced-motion-value.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/get-as-type.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/utils/build-transform.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/utils/build-styles.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/utils/create-render-state.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/use-props.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/utils/valid-prop.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/utils/filter-props.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/lowercase-elements.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/utils/is-svg-component.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/utils/path.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/utils/transform-origin.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/utils/build-attrs.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/utils/create-render-state.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/utils/is-svg-tag.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/use-props.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/use-render.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/motion/utils/use-visual-state.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/utils/scrape-motion-values.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/config-motion.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/utils/measure.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/utils/render.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/utils/camel-case-attrs.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/utils/render.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/utils/scrape-motion-values.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/config-motion.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/components/create-factory.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/value-types/find.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/store.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/VisualElement.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/utils/motion-values.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/DOMVisualElement.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/html/HTMLVisualElement.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/svg/SVGVisualElement.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/dom/create-visual-element.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/components/motion/proxy.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/render/components/motion/create.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/is-browser.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/reduced-motion/index.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/reduced-motion/state.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/use-constant.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/framer-motion/dist/es/utils/use-isomorphic-effect.mjs","webpack://react-app/./node_modules/.pnpm/motion@12.4.3_react-dom@19.0.0_react@19.0.0/node_modules/motion/dist/es/motion-dom/dist/es/utils/resolve-elements.mjs"],"sourcesContent":["/**\n * @license React\n * react-jsx-runtime.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\");\nfunction jsxProd(type, config, maybeKey) {\n var key = null;\n void 0 !== maybeKey && (key = \"\" + maybeKey);\n void 0 !== config.key && (key = \"\" + config.key);\n if (\"key\" in config) {\n maybeKey = {};\n for (var propName in config)\n \"key\" !== propName && (maybeKey[propName] = config[propName]);\n } else maybeKey = config;\n config = maybeKey.ref;\n return {\n $$typeof: REACT_ELEMENT_TYPE,\n type: type,\n key: key,\n ref: void 0 !== config ? config : null,\n props: maybeKey\n };\n}\nexports.Fragment = REACT_FRAGMENT_TYPE;\nexports.jsx = jsxProd;\nexports.jsxs = jsxProd;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-jsx-runtime.production.js');\n} else {\n module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\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(subscribe = true) {\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(() => {\n if (subscribe)\n register(id);\n }, [subscribe]);\n const safeToRemove = useCallback(() => subscribe && onExitComplete && onExitComplete(id), [id, onExitComplete, subscribe]);\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","\"use client\";\nimport { createContext } from 'react';\n\nconst LayoutGroupContext = createContext({});\n\nexport { LayoutGroupContext };\n","\"use client\";\nimport { 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","\"use client\";\nimport { createContext } from 'react';\n\n/**\n * @public\n */\nconst PresenceContext = \n/* @__PURE__ */ createContext(null);\n\nexport { PresenceContext };\n","import { warnOnce } from '../../utils/warn-once.mjs';\n\nfunction createDOMMotionComponentProxy(componentFactory) {\n if (typeof Proxy === \"undefined\") {\n return componentFactory;\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 const deprecatedFactoryFunction = (...args) => {\n if (process.env.NODE_ENV !== \"production\") {\n warnOnce(false, \"motion() is deprecated. Use motion.create() instead.\");\n }\n return componentFactory(...args);\n };\n return new Proxy(deprecatedFactoryFunction, {\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 if (key === \"create\")\n return componentFactory;\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, componentFactory(key));\n }\n return componentCache.get(key);\n },\n });\n}\n\nexport { createDOMMotionComponentProxy };\n","function isAnimationControls(v) {\n return (v !== null &&\n typeof v === \"object\" &&\n typeof v.start === \"function\");\n}\n\nexport { isAnimationControls };\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","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","function getValueTransition(transition, key) {\n return transition\n ? transition[key] ||\n transition[\"default\"] ||\n transition\n : undefined;\n}\n\nexport { getValueTransition };\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 { transformPropOrder } from './keys-transform.mjs';\n\nconst positionalKeys = new Set([\n \"width\",\n \"height\",\n \"top\",\n \"left\",\n \"right\",\n \"bottom\",\n ...transformPropOrder,\n]);\n\nexport { positionalKeys };\n","const isKeyframesTarget = (v) => {\n return Array.isArray(v);\n};\n\nexport { isKeyframesTarget };\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","const MotionGlobalConfig = {\n skipAnimations: false,\n useManualTiming: false,\n};\n\nexport { MotionGlobalConfig };\n","/*#__NO_SIDE_EFFECTS__*/\nconst noop = (any) => any;\n\nexport { noop };\n","const stepsOrder = [\n \"read\", // Read\n \"resolveKeyframes\", // Write/Read/Write/Read\n \"update\", // Compute\n \"preRender\", // Compute\n \"render\", // Write\n \"postRender\", // Compute\n];\n\nexport { stepsOrder };\n","const statsBuffer = {\n value: null,\n addProjectionMetrics: null,\n};\n\nexport { statsBuffer };\n","import { MotionGlobalConfig } from '../utils/GlobalConfig.mjs';\nimport { stepsOrder } from './order.mjs';\nimport { createRenderStep } from './render-step.mjs';\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, allowKeepAlive ? key : undefined);\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 if (!MotionGlobalConfig.useManualTiming) {\n state.delta = useDefaultElapsed\n ? 1000 / 60\n : Math.max(Math.min(timestamp - state.timestamp, maxElapsed), 1);\n }\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 };\n","import { statsBuffer } from '../stats/buffer.mjs';\n\nfunction createRenderStep(runNextFrame, stepName) {\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 let numCalls = 0;\n function triggerCallback(callback) {\n if (toKeepAlive.has(callback)) {\n step.schedule(callback);\n runNextFrame();\n }\n numCalls++;\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 // Execute this frame\n thisFrame.forEach(triggerCallback);\n /**\n * If we're recording stats then\n */\n if (stepName && statsBuffer.value) {\n statsBuffer.value.frameloop[stepName].push(numCalls);\n }\n numCalls = 0;\n // Clear the frame so no callbacks remain. This is to avoid\n // memory leaks should this render step not run for a while.\n thisFrame.clear();\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 '../../../../motion-utils/dist/es/errors.mjs';\nimport { noop } from '../../../../motion-utils/dist/es/noop.mjs';\nimport { createRenderBatcher } from './batcher.mjs';\n\nconst { schedule: frame, cancel: cancelFrame, state: frameData, steps: frameSteps, } = createRenderBatcher(typeof requestAnimationFrame !== \"undefined\" ? requestAnimationFrame : noop, true);\n\nexport { cancelFrame, frame, frameData, frameSteps };\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","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 { 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","/*\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 { time } from '../frameloop/sync-time.mjs';\nimport { SubscriptionManager } from '../utils/subscription-manager.mjs';\nimport { velocityPerSecond } from '../utils/velocity-per-second.mjs';\nimport { warnOnce } from '../utils/warn-once.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 = \"12.4.3\";\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","const isMotionValue = (value) => Boolean(value && value.getVelocity);\n\nexport { isMotionValue };\n","import { isWillChangeMotionValue } from './is.mjs';\n\nfunction addValueToWillChange(visualElement, key) {\n const willChange = visualElement.getValue(\"willChange\");\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","/**\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","import { optimizedAppearDataAttribute } from './data-id.mjs';\n\nfunction getOptimisedAppearId(visualElement) {\n return visualElement.props[optimizedAppearDataAttribute];\n}\n\nexport { getOptimisedAppearId };\n","/*#__NO_SIDE_EFFECTS__*/\nfunction memo(callback) {\n let result;\n return () => {\n if (result === undefined)\n result = callback();\n return result;\n };\n}\n\nexport { memo };\n","import '../../../../../motion-utils/dist/es/errors.mjs';\nimport { memo } from '../../../../../motion-utils/dist/es/memo.mjs';\n\nconst supportsScrollTimeline = memo(() => window.ScrollTimeline !== undefined);\n\nexport { supportsScrollTimeline };\n","import { supportsScrollTimeline } from '../../utils/supports/scroll-timeline.mjs';\n\nclass BaseGroupPlaybackControls {\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 get finished() {\n // Support for new finished Promise and legacy thennable API\n return Promise.all(this.animations.map((animation) => \"finished\" in animation ? animation.finished : animation));\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, fallback) {\n const subscriptions = this.animations.map((animation) => {\n if (supportsScrollTimeline() && animation.attachTimeline) {\n return animation.attachTimeline(timeline);\n }\n else if (typeof fallback === \"function\") {\n return fallback(animation);\n }\n });\n return () => {\n subscriptions.forEach((cancel, i) => {\n cancel && cancel();\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 flatten() {\n this.runAll(\"flatten\");\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 { BaseGroupPlaybackControls };\n","import { BaseGroupPlaybackControls } from './BaseGroup.mjs';\n\n/**\n * TODO: This is a temporary class to support the legacy\n * thennable API\n */\nclass GroupPlaybackControls extends BaseGroupPlaybackControls {\n then(onResolve, onReject) {\n return Promise.all(this.animations).then(onResolve).catch(onReject);\n }\n}\n\nexport { GroupPlaybackControls };\n","/**\n * Converts seconds to milliseconds\n *\n * @param seconds - Time in seconds.\n * @return milliseconds - Converted time in milliseconds.\n */\n/*#__NO_SIDE_EFFECTS__*/\nconst secondsToMilliseconds = (seconds) => seconds * 1000;\n/*#__NO_SIDE_EFFECTS__*/\nconst millisecondsToSeconds = (milliseconds) => milliseconds / 1000;\n\nexport { millisecondsToSeconds, secondsToMilliseconds };\n","const instantAnimationState = {\n current: false,\n};\n\nexport { instantAnimationState };\n","function isGenerator(type) {\n return typeof type === \"function\";\n}\n\nexport { isGenerator };\n","function attachTimeline(animation, timeline) {\n animation.timeline = timeline;\n animation.onfinish = null;\n}\n\nexport { attachTimeline };\n","const isBezierDefinition = (easing) => Array.isArray(easing) && typeof easing[0] === \"number\";\n\nexport { isBezierDefinition };\n","/**\n * Add the ability for test suites to manually set support flags\n * to better test more environments.\n */\nconst supportsFlags = {\n linearEasing: undefined,\n};\n\nexport { supportsFlags };\n","import '../../../../../motion-utils/dist/es/errors.mjs';\nimport { memo } from '../../../../../motion-utils/dist/es/memo.mjs';\nimport { supportsFlags } from './flags.mjs';\n\nfunction memoSupports(callback, supportsFlag) {\n const memoized = memo(callback);\n return () => { var _a; return (_a = supportsFlags[supportsFlag]) !== null && _a !== void 0 ? _a : memoized(); };\n}\n\nexport { memoSupports };\n","import { memoSupports } from './memo.mjs';\n\nconst supportsLinearEasing = /*@__PURE__*/ memoSupports(() => {\n try {\n document\n .createElement(\"div\")\n .animate({ opacity: 0 }, { easing: \"linear(0, 1)\" });\n }\n catch (e) {\n return false;\n }\n return true;\n}, \"linearEasing\");\n\nexport { supportsLinearEasing };\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*/\n/*#__NO_SIDE_EFFECTS__*/\nconst progress = (from, to, value) => {\n const toFromDifference = to - from;\n return toFromDifference === 0 ? 1 : (value - from) / toFromDifference;\n};\n\nexport { progress };\n","import '../../../../../../motion-utils/dist/es/errors.mjs';\nimport { progress } from '../../../../../../motion-utils/dist/es/progress.mjs';\n\nconst generateLinearEasing = (easing, duration, // as milliseconds\nresolution = 10 // as milliseconds\n) => {\n let points = \"\";\n const numPoints = Math.max(Math.round(duration / resolution), 2);\n for (let i = 0; i < numPoints; i++) {\n points += easing(progress(0, numPoints - 1, i)) + \", \";\n }\n return `linear(${points.substring(0, points.length - 2)})`;\n};\n\nexport { generateLinearEasing };\n","import { isBezierDefinition } from '../../../utils/is-bezier-definition.mjs';\nimport { supportsLinearEasing } from '../../../utils/supports/linear-easing.mjs';\nimport { generateLinearEasing } from './linear.mjs';\n\nfunction isWaapiSupportedEasing(easing) {\n return Boolean((typeof easing === \"function\" && supportsLinearEasing()) ||\n !easing ||\n (typeof easing === \"string\" &&\n (easing in supportedWaapiEasing || supportsLinearEasing())) ||\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: /*@__PURE__*/ cubicBezierAsString([0, 0.65, 0.55, 1]),\n circOut: /*@__PURE__*/ cubicBezierAsString([0.55, 0, 1, 0.45]),\n backIn: /*@__PURE__*/ cubicBezierAsString([0.31, 0.01, 0.66, -0.59]),\n backOut: /*@__PURE__*/ cubicBezierAsString([0.33, 1.53, 0.69, 0.99]),\n};\nfunction mapEasingToNativeEasing(easing, duration) {\n if (!easing) {\n return undefined;\n }\n else if (typeof easing === \"function\" && supportsLinearEasing()) {\n return generateLinearEasing(easing, duration);\n }\n else if (isBezierDefinition(easing)) {\n return cubicBezierAsString(easing);\n }\n else if (Array.isArray(easing)) {\n return easing.map((segmentEasing) => mapEasingToNativeEasing(segmentEasing, duration) ||\n supportedWaapiEasing.easeOut);\n }\n else {\n return supportedWaapiEasing[easing];\n }\n}\n\nexport { cubicBezierAsString, isWaapiSupportedEasing, mapEasingToNativeEasing, supportedWaapiEasing };\n","import '../../../../motion-utils/dist/es/errors.mjs';\nimport { noop } from '../../../../motion-utils/dist/es/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","// 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 { cubicBezier } from './cubic-bezier.mjs';\nimport { mirrorEasing } from './modifiers/mirror.mjs';\nimport { reverseEasing } from './modifiers/reverse.mjs';\n\nconst backOut = /*@__PURE__*/ cubicBezier(0.33, 1.53, 0.69, 0.99);\nconst backIn = /*@__PURE__*/ reverseEasing(backOut);\nconst backInOut = /*@__PURE__*/ mirrorEasing(backIn);\n\nexport { backIn, backInOut, backOut };\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","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","/**\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","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","// If this number is a decimal, make it just five decimal places\n// to avoid exponents\nconst sanitize = (v) => Math.round(v * 100000) / 100000;\n\nexport { sanitize };\n","const floatRegex = /-?(?:\\d+(?:\\.\\d+)?|\\.\\d+)/gu;\n\nexport { floatRegex };\n","const singleColorRegex = /^(?:#[\\da-f]{3,8}|(?:rgb|hsl)a?\\((?:-?[\\d.]+%?[,\\s]+){2}-?[\\d.]+%?\\s*(?:[,/]\\s*)?(?:\\b\\d+(?:\\.\\d+)?|\\.\\d+)?%?\\))$/iu;\n\nexport { singleColorRegex };\n","import { floatRegex } from '../utils/float-regex.mjs';\nimport { isNullish } from '../utils/is-nullish.mjs';\nimport { singleColorRegex } from '../utils/single-color-regex.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((typeof v === \"string\" &&\n singleColorRegex.test(v) &&\n v.startsWith(type)) ||\n (testProp &&\n !isNullish(v) &&\n Object.prototype.hasOwnProperty.call(v, testProp)));\n};\nconst splitColor = (aName, bName, cName) => (v) => {\n if (typeof v !== \"string\")\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","function isNullish(v) {\n return v == null;\n}\n\nexport { isNullish };\n","import { clamp } from '../../../utils/clamp.mjs';\nimport { alpha, number } from '../numbers/index.mjs';\nimport { sanitize } from '../utils/sanitize.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: /*@__PURE__*/ isColorString(\"rgb\", \"red\"),\n parse: /*@__PURE__*/ 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: /*@__PURE__*/ isColorString(\"#\"),\n parse: parseHex,\n transform: rgba.transform,\n};\n\nexport { hex };\n","const createUnitType = (unit) => ({\n test: (v) => typeof v === \"string\" && v.endsWith(unit) && v.split(\" \").length === 1,\n parse: parseFloat,\n transform: (v) => `${v}${unit}`,\n});\nconst degrees = /*@__PURE__*/ createUnitType(\"deg\");\nconst percent = /*@__PURE__*/ createUnitType(\"%\");\nconst px = /*@__PURE__*/ createUnitType(\"px\");\nconst vh = /*@__PURE__*/ createUnitType(\"vh\");\nconst vw = /*@__PURE__*/ 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 { alpha } from '../numbers/index.mjs';\nimport { percent } from '../numbers/units.mjs';\nimport { sanitize } from '../utils/sanitize.mjs';\nimport { isColorString, splitColor } from './utils.mjs';\n\nconst hsla = {\n test: /*@__PURE__*/ isColorString(\"hsl\", \"hue\"),\n parse: /*@__PURE__*/ 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 { 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 typeof v === \"string\"\n ? v\n : v.hasOwnProperty(\"red\")\n ? rgba.transform(v)\n : hsla.transform(v);\n },\n};\n\nexport { color };\n","const colorRegex = /(?:#[\\da-f]{3,8}|(?:rgb|hsl)a?\\((?:-?[\\d.]+%?[,\\s]+){2}-?[\\d.]+%?\\s*(?:[,/]\\s*)?(?:\\b\\d+(?:\\.\\d+)?|\\.\\d+)?%?\\))/giu;\n\nexport { colorRegex };\n","import { color } from '../color/index.mjs';\nimport { colorRegex } from '../utils/color-regex.mjs';\nimport { floatRegex } from '../utils/float-regex.mjs';\nimport { sanitize } from '../utils/sanitize.mjs';\n\nfunction test(v) {\n var _a, _b;\n return (isNaN(v) &&\n typeof v === \"string\" &&\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/float-regex.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 { px } from '../../../value/types/numbers/units.mjs';\n\nconst browserNumberValueTypes = {\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 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 // Misc\n backgroundPositionX: px,\n backgroundPositionY: px,\n};\n\nexport { browserNumberValueTypes };\n","import { scale, alpha } from '../../../value/types/numbers/index.mjs';\nimport { degrees, px, progressPercentage } from '../../../value/types/numbers/units.mjs';\n\nconst transformValueTypes = {\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};\n\nexport { transformValueTypes };\n","import { number } from '../../../value/types/numbers/index.mjs';\n\nconst int = {\n ...number,\n transform: Math.round,\n};\n\nexport { int };\n","import { alpha } from '../../../value/types/numbers/index.mjs';\nimport { px } from '../../../value/types/numbers/units.mjs';\nimport { browserNumberValueTypes } from './number-browser.mjs';\nimport { transformValueTypes } from './transform.mjs';\nimport { int } from './type-int.mjs';\n\nconst numberValueTypes = {\n ...browserNumberValueTypes,\n ...transformValueTypes,\n zIndex: int,\n size: px,\n // SVG\n fillOpacity: alpha,\n strokeOpacity: alpha,\n numOctaves: int,\n};\n\nexport { numberValueTypes };\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 { number } from '../../../value/types/numbers/index.mjs';\nimport { px } from '../../../value/types/numbers/units.mjs';\nimport { transformPropOrder } from '../../html/utils/keys-transform.mjs';\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, positionalValues, removeNonTranslationalTransform };\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 { 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","const checkStringStartsWith = (token) => (key) => typeof key === \"string\" && key.startsWith(token);\nconst isCSSVariableName = \n/*@__PURE__*/ checkStringStartsWith(\"--\");\nconst startsAsVariableToken = \n/*@__PURE__*/ 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 { invariant } from '../../../../../../motion-utils/dist/es/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","/**\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 { isNone } from '../../animation/utils/is-none.mjs';\nimport { positionalKeys } from '../html/utils/keys-position.mjs';\nimport { makeNoneKeyframesAnimatable } from '../html/utils/make-none-animatable.mjs';\nimport { KeyframeResolver } from '../utils/KeyframesResolver.mjs';\nimport { getVariableValue } from './utils/css-variables-conversion.mjs';\nimport { isCSSVariableToken } from './utils/is-css-variable.mjs';\nimport { isNumOrPxType, positionalValues } from './utils/unit-conversion.mjs';\nimport { findDimensionValueType } from './value-types/dimensions.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","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 { warning } from '../../../../../../motion-utils/dist/es/errors.mjs';\nimport { isGenerator } from '../../../../../../motion-dom/dist/es/animation/generators/utils/is-generator.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) ||\n ((type === \"spring\" || isGenerator(type)) && velocity));\n}\n\nexport { canAnimate };\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","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 &&\n onUpdate(getFinalKeyframe(keyframes, this.options, finalKeyframe));\n onComplete && 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 flatten() {\n this.options.type = \"keyframes\";\n this.options.ease = \"linear\";\n }\n updateFinishedPromise() {\n this.currentFinishedPromise = new Promise((resolve) => {\n this.resolveFinishedPromise = resolve;\n });\n }\n}\n\nexport { BaseAnimation };\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 activeAnimations = {\n layout: 0,\n mainThread: 0,\n waapi: 0,\n};\n\nexport { activeAnimations };\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 '../../../../../motion-utils/dist/es/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 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","/**\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","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 '../../../../../motion-utils/dist/es/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 { 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","const springDefaults = {\n // Default spring physics\n stiffness: 100,\n damping: 10,\n mass: 1.0,\n velocity: 0.0,\n // Default duration/bounce-based options\n duration: 800, // in ms\n bounce: 0.3,\n visualDuration: 0.3, // in seconds\n // Rest thresholds\n restSpeed: {\n granular: 0.01,\n default: 2,\n },\n restDelta: {\n granular: 0.005,\n default: 0.5,\n },\n // Limits\n minDuration: 0.01, // in seconds\n maxDuration: 10.0, // in seconds\n minDamping: 0.05,\n maxDamping: 1,\n};\n\nexport { springDefaults };\n","import { warning } from '../../../../../../motion-utils/dist/es/errors.mjs';\nimport { secondsToMilliseconds, millisecondsToSeconds } from '../../../../../../motion-utils/dist/es/time-conversion.mjs';\nimport { clamp } from '../../../utils/clamp.mjs';\nimport { springDefaults } from './defaults.mjs';\n\nconst safeMin = 0.001;\nfunction findSpring({ duration = springDefaults.duration, bounce = springDefaults.bounce, velocity = springDefaults.velocity, mass = springDefaults.mass, }) {\n let envelope;\n let derivative;\n warning(duration <= secondsToMilliseconds(springDefaults.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(springDefaults.minDamping, springDefaults.maxDamping, dampingRatio);\n duration = clamp(springDefaults.minDuration, springDefaults.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: springDefaults.stiffness,\n damping: springDefaults.damping,\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 };\n","import '../../../../../../motion-utils/dist/es/errors.mjs';\nimport { millisecondsToSeconds, secondsToMilliseconds } from '../../../../../../motion-utils/dist/es/time-conversion.mjs';\nimport { calcGeneratorDuration, maxGeneratorDuration } from '../../../../../../motion-dom/dist/es/animation/generators/utils/calc-duration.mjs';\nimport { generateLinearEasing } from '../../../../../../motion-dom/dist/es/animation/waapi/utils/linear.mjs';\nimport { clamp } from '../../../utils/clamp.mjs';\nimport { calcGeneratorVelocity } from '../utils/velocity.mjs';\nimport { springDefaults } from './defaults.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: springDefaults.velocity,\n stiffness: springDefaults.stiffness,\n damping: springDefaults.damping,\n mass: springDefaults.mass,\n isResolvedFromDuration: false,\n ...options,\n };\n // stiffness/damping/mass overrides duration/bounce\n if (!isSpringType(options, physicsKeys) &&\n isSpringType(options, durationKeys)) {\n if (options.visualDuration) {\n const visualDuration = options.visualDuration;\n const root = (2 * Math.PI) / (visualDuration * 1.2);\n const stiffness = root * root;\n const damping = 2 *\n clamp(0.05, 1, 1 - (options.bounce || 0)) *\n Math.sqrt(stiffness);\n springOptions = {\n ...springOptions,\n mass: springDefaults.mass,\n stiffness,\n damping,\n };\n }\n else {\n const derived = findSpring(options);\n springOptions = {\n ...springOptions,\n ...derived,\n mass: springDefaults.mass,\n };\n springOptions.isResolvedFromDuration = true;\n }\n }\n return springOptions;\n}\nfunction spring(optionsOrVisualDuration = springDefaults.visualDuration, bounce = springDefaults.bounce) {\n const options = typeof optionsOrVisualDuration !== \"object\"\n ? {\n visualDuration: optionsOrVisualDuration,\n keyframes: [0, 1],\n bounce,\n }\n : optionsOrVisualDuration;\n let { restSpeed, restDelta } = options;\n const origin = options.keyframes[0];\n const target = options.keyframes[options.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\n ? springDefaults.restSpeed.granular\n : springDefaults.restSpeed.default);\n restDelta || (restDelta = isGranularScale\n ? springDefaults.restDelta.granular\n : springDefaults.restDelta.default);\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 const generator = {\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 toString: () => {\n const calculatedDuration = Math.min(calcGeneratorDuration(generator), maxGeneratorDuration);\n const easing = generateLinearEasing((progress) => generator.next(calculatedDuration * progress).value, calculatedDuration, 30);\n return calculatedDuration + \"ms \" + easing;\n },\n };\n return generator;\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 { cubicBezier } from './cubic-bezier.mjs';\n\nconst easeIn = /*@__PURE__*/ cubicBezier(0.42, 0, 1, 1);\nconst easeOut = /*@__PURE__*/ cubicBezier(0, 0, 0.58, 1);\nconst easeInOut = /*@__PURE__*/ cubicBezier(0.42, 0, 0.58, 1);\n\nexport { easeIn, easeInOut, easeOut };\n","import { invariant } from '../../../../../motion-utils/dist/es/errors.mjs';\nimport { noop } from '../../../../../motion-utils/dist/es/noop.mjs';\nimport { isBezierDefinition } from '../../../../../motion-dom/dist/es/utils/is-bezier-definition.mjs';\nimport { anticipate } from '../anticipate.mjs';\nimport { backIn, backInOut, backOut } from '../back.mjs';\nimport { circIn, circInOut, circOut } from '../circ.mjs';\nimport { cubicBezier } from '../cubic-bezier.mjs';\nimport { easeIn, easeInOut, easeOut } from '../ease.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 (isBezierDefinition(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 { invariant } from '../../../../motion-utils/dist/es/errors.mjs';\nimport { noop } from '../../../../motion-utils/dist/es/noop.mjs';\nimport { progress } from '../../../../motion-utils/dist/es/progress.mjs';\nimport { clamp } from './clamp.mjs';\nimport { mix } from './mix/index.mjs';\nimport { pipe } from './pipe.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 && output[0] === output[1])\n return () => output[1];\n const isZeroDeltaRange = input[0] === input[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 if (isZeroDeltaRange && v < input[0])\n return output[0];\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 '../../../../../motion-utils/dist/es/errors.mjs';\nimport { progress } from '../../../../../motion-utils/dist/es/progress.mjs';\nimport { mixNumber } from '../mix/number.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 { invariant } from '../../../../../motion-utils/dist/es/errors.mjs';\nimport { millisecondsToSeconds, secondsToMilliseconds } from '../../../../../motion-utils/dist/es/time-conversion.mjs';\nimport { calcGeneratorDuration } from '../../../../../motion-dom/dist/es/animation/generators/utils/calc-duration.mjs';\nimport { isGenerator } from '../../../../../motion-dom/dist/es/animation/generators/utils/is-generator.mjs';\nimport { KeyframeResolver } from '../../render/utils/KeyframesResolver.mjs';\nimport { activeAnimations } from '../../stats/animation-count.mjs';\nimport { clamp } from '../../utils/clamp.mjs';\nimport { mix } from '../../utils/mix/index.mjs';\nimport { pipe } from '../../utils/pipe.mjs';\nimport { inertia } from '../generators/inertia.mjs';\nimport { keyframes } from '../generators/keyframes.mjs';\nimport { spring } from '../generators/spring/index.mjs';\nimport { BaseAnimation } from './BaseAnimation.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 flatten() {\n super.flatten();\n // If we've already resolved the animation, re-initialise it\n if (this._resolved) {\n Object.assign(this._resolved, this.initPlayback(this._resolved.keyframes));\n }\n }\n initPlayback(keyframes$1) {\n const { type = \"keyframes\", repeat = 0, repeatDelay = 0, repeatType, velocity = 0, } = this.options;\n const generatorFactory = isGenerator(type)\n ? type\n : 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 (process.env.NODE_ENV !== \"production\" &&\n generatorFactory !== keyframes) {\n invariant(keyframes$1.length <= 2, `Only two keyframes currently supported with spring and inertia animations. Trying to animate ${keyframes$1}`);\n }\n if (generatorFactory !== keyframes &&\n typeof keyframes$1[0] !== \"number\") {\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 activeAnimations.mainThread++;\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 activeAnimations.mainThread--;\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 * 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 '../../../../../../motion-utils/dist/es/errors.mjs';\nimport { mapEasingToNativeEasing } from '../../../../../../motion-dom/dist/es/animation/waapi/utils/easing.mjs';\nimport { activeAnimations } from '../../../stats/animation-count.mjs';\nimport { statsBuffer } from '../../../stats/buffer.mjs';\n\nfunction startWaapiAnimation(element, valueName, keyframes, { delay = 0, duration = 300, repeat = 0, repeatType = \"loop\", ease = \"easeInOut\", times, } = {}) {\n const keyframeOptions = { [valueName]: keyframes };\n if (times)\n keyframeOptions.offset = times;\n const easing = mapEasingToNativeEasing(ease, duration);\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 if (statsBuffer.value) {\n activeAnimations.waapi++;\n }\n const animation = 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 if (statsBuffer.value) {\n animation.finished.finally(() => {\n activeAnimations.waapi--;\n });\n }\n return animation;\n}\n\nexport { startWaapiAnimation };\n","import '../../../../../../../motion-utils/dist/es/errors.mjs';\nimport { memo } from '../../../../../../../motion-utils/dist/es/memo.mjs';\n\nconst supportsWaapi = /*@__PURE__*/ memo(() => Object.hasOwnProperty.call(Element.prototype, \"animate\"));\n\nexport { supportsWaapi };\n","import '../../../../../motion-utils/dist/es/errors.mjs';\nimport { noop } from '../../../../../motion-utils/dist/es/noop.mjs';\nimport { millisecondsToSeconds, secondsToMilliseconds } from '../../../../../motion-utils/dist/es/time-conversion.mjs';\nimport { isGenerator } from '../../../../../motion-dom/dist/es/animation/generators/utils/is-generator.mjs';\nimport { attachTimeline } from '../../../../../motion-dom/dist/es/animation/waapi/utils/attach-timeline.mjs';\nimport { isWaapiSupportedEasing } from '../../../../../motion-dom/dist/es/animation/waapi/utils/easing.mjs';\nimport { supportsLinearEasing } from '../../../../../motion-dom/dist/es/utils/supports/linear-easing.mjs';\nimport { anticipate } from '../../easing/anticipate.mjs';\nimport { backInOut } from '../../easing/back.mjs';\nimport { circInOut } from '../../easing/circ.mjs';\nimport { DOMKeyframesResolver } from '../../render/dom/DOMKeyframesResolver.mjs';\nimport { BaseAnimation } from './BaseAnimation.mjs';\nimport { MainThreadAnimation } from './MainThreadAnimation.mjs';\nimport { acceleratedValues } from './utils/accelerated-values.mjs';\nimport { startWaapiAnimation } from './waapi/index.mjs';\nimport { getFinalKeyframe } from './waapi/utils/get-final-keyframe.mjs';\nimport { supportsWaapi } from './waapi/utils/supports-waapi.mjs';\n\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 (isGenerator(options.type) ||\n options.type === \"spring\" ||\n !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}\nconst unsupportedEasingFunctions = {\n anticipate,\n backInOut,\n circInOut,\n};\nfunction isUnsupportedEase(key) {\n return key in unsupportedEasingFunctions;\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 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 (!motionValue.owner || !motionValue.owner.current) {\n return false;\n }\n /**\n * If the user has provided an easing function name that isn't supported\n * by WAAPI (like \"anticipate\"), we need to provide the corressponding\n * function. This will later get converted to a linear() easing function.\n */\n if (typeof ease === \"string\" &&\n supportsLinearEasing() &&\n isUnsupportedEase(ease)) {\n ease = unsupportedEasingFunctions[ease];\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 = startWaapiAnimation(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 attachTimeline(animation, 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 attachTimeline(animation, timeline);\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 if (!motionValue ||\n !motionValue.owner ||\n !(motionValue.owner.current instanceof HTMLElement)) {\n return false;\n }\n const { onUpdate, transformTemplate } = motionValue.owner.getProps();\n return (supportsWaapi() &&\n name &&\n acceleratedValues.has(name) &&\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 !onUpdate &&\n !transformTemplate &&\n !repeatDelay &&\n repeatType !== \"mirror\" &&\n damping !== 0 &&\n type !== \"inertia\");\n }\n}\n\nexport { AcceleratedAnimation };\n","import { transformProps } from '../../render/html/utils/keys-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","import { GroupPlaybackControls } from '../../../../../motion-dom/dist/es/animation/controls/Group.mjs';\nimport { getValueTransition } from '../../../../../motion-dom/dist/es/animation/utils/get-value-transition.mjs';\nimport '../../../../../motion-utils/dist/es/errors.mjs';\nimport { secondsToMilliseconds } from '../../../../../motion-utils/dist/es/time-conversion.mjs';\nimport { frame } from '../../frameloop/frame.mjs';\nimport { MotionGlobalConfig } from '../../utils/GlobalConfig.mjs';\nimport { instantAnimationState } from '../../utils/use-instant-transition-state.mjs';\nimport { AcceleratedAnimation } from '../animators/AcceleratedAnimation.mjs';\nimport { MainThreadAnimation } from '../animators/MainThreadAnimation.mjs';\nimport { getFinalKeyframe } from '../animators/waapi/utils/get-final-keyframe.mjs';\nimport { getDefaultTransition } from '../utils/default-transitions.mjs';\nimport { isTransitionDefined } from '../utils/is-transition-defined.mjs';\n\nconst animateMotionValue = (name, value, target, transition = {}, element, isHandoff) => (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 },\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","/**\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}\n\nexport { isTransitionDefined };\n","import '../../../../../motion-utils/dist/es/errors.mjs';\nimport { getValueTransition } from '../../../../../motion-dom/dist/es/animation/utils/get-value-transition.mjs';\nimport { positionalKeys } from '../../render/html/utils/keys-position.mjs';\nimport { setTarget } from '../../render/utils/setters.mjs';\nimport { addValueToWillChange } from '../../value/use-will-change/add-will-change.mjs';\nimport { getOptimisedAppearId } from '../optimized-appear/get-appear-id.mjs';\nimport { animateMotionValue } from './motion-value.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 addValueToWillChange(visualElement, key);\n value.start(animateMotionValue(key, value, valueTarget, visualElement.shouldReduceMotion && positionalKeys.has(key)\n ? { type: false }\n : valueTransition, visualElement, isHandoff));\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","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","/**\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","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 { isVariantLabel } from './is-variant-label.mjs';\nimport { variantProps } from './variant-props.mjs';\n\nconst numVariantProps = variantProps.length;\nfunction getVariantContext(visualElement) {\n if (!visualElement)\n return undefined;\n if (!visualElement.isControllingVariants) {\n const context = visualElement.parent\n ? getVariantContext(visualElement.parent) || {}\n : {};\n if (visualElement.props.initial !== undefined) {\n context.initial = visualElement.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 = visualElement.props[name];\n if (isVariantLabel(prop) || prop === false) {\n context[name] = prop;\n }\n }\n return context;\n}\n\nexport { getVariantContext };\n","import { animateVisualElement } from '../../animation/interfaces/visual-element.mjs';\nimport { 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 { getVariantContext } from './get-variant-context.mjs';\nimport { isVariantLabel } from './is-variant-label.mjs';\nimport { resolveVariant } from './resolve-dynamic-variants.mjs';\nimport { variantPriorityOrder } from './variant-props.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;\n const context = getVariantContext(visualElement.parent) || {};\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 skip this animation\n * unless the inherited variants haven't changed on this render.\n */\n const willAnimateViaParent = isInherited && variantDidChange;\n const needsAnimating = !willAnimateViaParent || handledRemovedValues;\n if (shouldAnimateType && needsAnimating) {\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 /**\n * If the initial prop contains a transition we can use that, otherwise\n * allow the animation function to use the visual element's default.\n */\n if (typeof props.initial !== \"boolean\") {\n const initialTransition = resolveVariant(visualElement, Array.isArray(props.initial)\n ? props.initial[0]\n : props.initial);\n if (initialTransition && initialTransition.transition) {\n fallbackAnimation.transition = initialTransition.transition;\n }\n }\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","class Feature {\n constructor(node) {\n this.isMounted = false;\n this.node = node;\n }\n update() { }\n}\n\nexport { Feature };\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(() => {\n onExitComplete(this.id);\n });\n }\n }\n mount() {\n const { register, onExitComplete } = this.node.presenceContext || {};\n if (onExitComplete) {\n onExitComplete(this.id);\n }\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 isDragging = {\n x: false,\n y: false,\n};\nfunction isDragActive() {\n return isDragging.x || isDragging.y;\n}\n\nexport { isDragActive, isDragging };\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","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","import '../../../../motion-utils/dist/es/errors.mjs';\nimport { isPrimaryPointer } from '../../../../motion-dom/dist/es/gestures/utils/is-primary-pointer.mjs';\n\nfunction extractEventInfo(event) {\n return {\n point: {\n x: event.pageX,\n y: event.pageY,\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","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 '../../../../../motion-utils/dist/es/errors.mjs';\nimport { secondsToMilliseconds, millisecondsToSeconds } from '../../../../../motion-utils/dist/es/time-conversion.mjs';\nimport { isPrimaryPointer } from '../../../../../motion-dom/dist/es/gestures/utils/is-primary-pointer.mjs';\nimport { addPointerEvent } from '../../events/add-pointer-event.mjs';\nimport { extractEventInfo } from '../../events/event-info.mjs';\nimport { distance2D } from '../../utils/distance.mjs';\nimport { pipe } from '../../utils/pipe.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","function isRefObject(ref) {\n return (ref &&\n typeof ref === \"object\" &&\n Object.prototype.hasOwnProperty.call(ref, \"current\"));\n}\n\nexport { isRefObject };\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 '../../../../../../motion-utils/dist/es/errors.mjs';\nimport { progress } from '../../../../../../motion-utils/dist/es/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/motiondivision/motion/issues/2270\nconst getContextWindow = ({ current }) => {\n return current ? current.ownerDocument.defaultView : null;\n};\n\nexport { getContextWindow };\n","import { invariant } from '../../../../../motion-utils/dist/es/errors.mjs';\nimport { setDragLock } from '../../../../../motion-dom/dist/es/gestures/drag/state/set-active.mjs';\nimport { PanSession } from '../pan/PanSession.mjs';\nimport { isRefObject } from '../../utils/is-ref-object.mjs';\nimport { addPointerEvent } from '../../events/add-pointer-event.mjs';\nimport { applyConstraints, calcRelativeConstraints, resolveDragElastic, calcViewportConstraints, rebaseAxisConstraints, 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.openDragLock = 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).point);\n }\n };\n const onStart = (event, info) => {\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.openDragLock)\n this.openDragLock();\n this.openDragLock = setDragLock(drag);\n // If we don 't have the lock, don't start dragging\n if (!this.openDragLock)\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 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.openDragLock)\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 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.openDragLock) {\n this.openDragLock();\n this.openDragLock = 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 addValueToWillChange(this.visualElement, axis);\n return axisValue.start(animateMotionValue(axis, axisValue, 0, transition, this.visualElement, false));\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 { isDragging } from './is-active.mjs';\n\nfunction setDragLock(axis) {\n if (axis === \"x\" || axis === \"y\") {\n if (isDragging[axis]) {\n return null;\n }\n else {\n isDragging[axis] = true;\n return () => {\n isDragging[axis] = false;\n };\n }\n }\n else {\n if (isDragging.x || isDragging.y) {\n return null;\n }\n else {\n isDragging.x = isDragging.y = true;\n return () => {\n isDragging.x = isDragging.y = false;\n };\n }\n }\n}\n\nexport { setDragLock };\n","import { PanSession } from './PanSession.mjs';\nimport { addPointerEvent } from '../../events/add-pointer-event.mjs';\nimport { Feature } from '../../motion/features/Feature.mjs';\nimport '../../../../../motion-utils/dist/es/errors.mjs';\nimport { noop } from '../../../../../motion-utils/dist/es/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","\"use client\";\nimport { createContext } from 'react';\n\n/**\n * Internal, exported only for usage in Framer\n */\nconst SwitchLayoutGroupContext = createContext({});\n\nexport { SwitchLayoutGroupContext };\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 { isCSSVariableName } from '../../render/dom/utils/is-css-variable.mjs';\n\nconst scaleCorrectors = {};\nfunction addScaleCorrector(correctors) {\n for (const key in correctors) {\n scaleCorrectors[key] = correctors[key];\n if (isCSSVariableName(key)) {\n scaleCorrectors[key].isCSSVariable = true;\n }\n }\n}\n\nexport { addScaleCorrector, scaleCorrectors };\n","import { createRenderBatcher } from './batcher.mjs';\n\nconst { schedule: microtask, cancel: cancelMicrotask } = createRenderBatcher(queueMicrotask, false);\n\nexport { cancelMicrotask, microtask };\n","\"use client\";\nimport { 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","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 '../../../../motion-utils/dist/es/errors.mjs';\nimport { secondsToMilliseconds } from '../../../../motion-utils/dist/es/time-conversion.mjs';\nimport { 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}\nfunction delayInSeconds(callback, timeout) {\n return delay(callback, secondsToMilliseconds(timeout));\n}\n\nexport { delay, delayInSeconds };\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 '../../../../../motion-utils/dist/es/errors.mjs';\nimport { noop } from '../../../../../motion-utils/dist/es/noop.mjs';\nimport { progress } from '../../../../../motion-utils/dist/es/progress.mjs';\nimport { circOut } from '../../easing/circ.mjs';\nimport { mixNumber } from '../../utils/mix/number.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 = /*@__PURE__*/ compress(0, 0.5, circOut);\nconst easeCrossfadeOut = /*@__PURE__*/ 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","import '../../../../../motion-utils/dist/es/errors.mjs';\nimport { noop } from '../../../../../motion-utils/dist/es/noop.mjs';\nimport { getValueTransition } from '../../../../../motion-dom/dist/es/animation/utils/get-value-transition.mjs';\nimport { animateSingleValue } from '../../animation/animate/single-value.mjs';\nimport { getOptimisedAppearId } from '../../animation/optimized-appear/get-appear-id.mjs';\nimport { cancelFrame, frameData, frameSteps, frame } from '../../frameloop/frame.mjs';\nimport { microtask } from '../../frameloop/microtask.mjs';\nimport { time } from '../../frameloop/sync-time.mjs';\nimport { isSVGElement } from '../../render/dom/utils/is-svg-element.mjs';\nimport { FlatTree } from '../../render/utils/flat-tree.mjs';\nimport { activeAnimations } from '../../stats/animation-count.mjs';\nimport { statsBuffer } from '../../stats/buffer.mjs';\nimport { clamp } from '../../utils/clamp.mjs';\nimport { delay } from '../../utils/delay.mjs';\nimport { mixNumber } from '../../utils/mix/number.mjs';\nimport { SubscriptionManager } from '../../utils/subscription-manager.mjs';\nimport { resolveMotionValue } from '../../value/utils/resolve-motion-value.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 { calcLength, calcRelativePosition, calcRelativeBox, calcBoxDelta, isNear } from '../geometry/delta-calc.mjs';\nimport { removeBoxTransforms } from '../geometry/delta-remove.mjs';\nimport { createBox, createDelta } from '../geometry/models.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 { globalProjectionState } from './state.mjs';\n\nconst metrics = {\n nodes: 0,\n calculatedTargetDeltas: 0,\n calculatedProjections: 0,\n};\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.MotionHasOptimisedAnimation(appearId, \"transform\")) {\n const { layout, layoutId } = projectionNode.options;\n window.MotionCancelOptimisedAnimation(appearId, \"transform\", frame, !(layout || layoutId));\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 (statsBuffer.value) {\n metrics.nodes =\n metrics.calculatedTargetDeltas =\n metrics.calculatedProjections =\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 (statsBuffer.addProjectionMetrics) {\n statsBuffer.addProjectionMetrics(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, hasRelativeLayoutChanged, 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 hasTargetChanged = !this.targetLayout ||\n !boxEqualsRounded(this.targetLayout, newLayout);\n /*\n * Note: Disabled to fix relative animations always triggering new\n * layout animations. If this causes further issues, we can try\n * a different approach to detecting relative target changes.\n */\n // || hasRelativeLayoutChanged\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 && hasRelativeLayoutChanged;\n if (this.options.layoutRoot ||\n this.resumeFrom ||\n hasOnlyRelativeTargetChanged ||\n (hasLayoutChanged &&\n (hasTargetChanged || !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.MotionCancelOptimisedAnimation &&\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 frameSteps.update.process(frameData);\n frameSteps.preRender.process(frameData);\n frameSteps.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 if (this.snapshot &&\n !calcLength(this.snapshot.measuredBox.x) &&\n !calcLength(this.snapshot.measuredBox.y)) {\n this.snapshot = undefined;\n }\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 (statsBuffer.value) {\n metrics.calculatedTargetDeltas++;\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 (statsBuffer.value) {\n metrics.calculatedProjections++;\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 activeAnimations.layout++;\n this.currentAnimation = animateSingleValue(0, animationTarget, {\n ...options,\n onUpdate: (latest) => {\n this.mixTargetDelta(latest);\n options.onUpdate && options.onUpdate(latest);\n },\n onStop: () => {\n activeAnimations.layout--;\n },\n onComplete: () => {\n activeAnimations.layout--;\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, isCSSVariable } = 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 // If this is a CSS variable, set it directly on the instance.\n // Replacing this function from creating styles to setting them\n // would be a good place to remove per frame object creation\n if (isCSSVariable) {\n this.options.visualElement.renderState.vars[key] = corrected;\n }\n else {\n styles[key] = corrected;\n }\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 hasRelativeLayoutChanged = 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 hasRelativeLayoutChanged = 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 hasRelativeLayoutChanged,\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 (statsBuffer.value) {\n metrics.nodes++;\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 { motionValue } from '../../value/index.mjs';\nimport { isMotionValue } from '../../value/utils/is-motion-value.mjs';\nimport { animateMotionValue } from '../interfaces/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 '../../../../../motion-utils/dist/es/errors.mjs';\nimport { noop } from '../../../../../motion-utils/dist/es/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","import { resolveElements } from '../../utils/resolve-elements.mjs';\n\nfunction setupGesture(elementOrSelector, options) {\n const elements = resolveElements(elementOrSelector);\n const gestureAbortController = new AbortController();\n const eventOptions = {\n passive: true,\n ...options,\n signal: gestureAbortController.signal,\n };\n const cancel = () => gestureAbortController.abort();\n return [elements, eventOptions, cancel];\n}\n\nexport { setupGesture };\n","import { isDragActive } from './drag/state/is-active.mjs';\nimport { setupGesture } from './utils/setup.mjs';\n\nfunction isValidHover(event) {\n return !(event.pointerType === \"touch\" || isDragActive());\n}\n/**\n * Create a hover gesture. hover() is different to .addEventListener(\"pointerenter\")\n * in that it has an easier syntax, filters out polyfilled touch events, interoperates\n * with drag gestures, and automatically removes the \"pointerennd\" event listener when the hover ends.\n *\n * @public\n */\nfunction hover(elementOrSelector, onHoverStart, options = {}) {\n const [elements, eventOptions, cancel] = setupGesture(elementOrSelector, options);\n const onPointerEnter = (enterEvent) => {\n if (!isValidHover(enterEvent))\n return;\n const { target } = enterEvent;\n const onHoverEnd = onHoverStart(target, enterEvent);\n if (typeof onHoverEnd !== \"function\" || !target)\n return;\n const onPointerLeave = (leaveEvent) => {\n if (!isValidHover(leaveEvent))\n return;\n onHoverEnd(leaveEvent);\n target.removeEventListener(\"pointerleave\", onPointerLeave);\n };\n target.addEventListener(\"pointerleave\", onPointerLeave, eventOptions);\n };\n elements.forEach((element) => {\n element.addEventListener(\"pointerenter\", onPointerEnter, eventOptions);\n });\n return cancel;\n}\n\nexport { hover };\n","import '../../../../motion-utils/dist/es/errors.mjs';\nimport { hover } from '../../../../motion-dom/dist/es/gestures/hover.mjs';\nimport { extractEventInfo } from '../events/event-info.mjs';\nimport { Feature } from '../motion/features/Feature.mjs';\nimport { frame } from '../frameloop/frame.mjs';\n\nfunction handleHoverEvent(node, event, lifecycle) {\n const { props } = node;\n if (node.animationState && props.whileHover) {\n node.animationState.setActive(\"whileHover\", lifecycle === \"Start\");\n }\n const eventName = (\"onHover\" + lifecycle);\n const callback = props[eventName];\n if (callback) {\n frame.postRender(() => callback(event, extractEventInfo(event)));\n }\n}\nclass HoverGesture extends Feature {\n mount() {\n const { current } = this.node;\n if (!current)\n return;\n this.unmount = hover(current, (_element, startEvent) => {\n handleHoverEvent(this.node, startEvent, \"Start\");\n return (endEvent) => handleHoverEvent(this.node, endEvent, \"End\");\n });\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","const focusableElements = new Set([\n \"BUTTON\",\n \"INPUT\",\n \"SELECT\",\n \"TEXTAREA\",\n \"A\",\n]);\nfunction isElementKeyboardAccessible(element) {\n return (focusableElements.has(element.tagName) ||\n element.tabIndex !== -1);\n}\n\nexport { isElementKeyboardAccessible };\n","const isPressing = new WeakSet();\n\nexport { isPressing };\n","import { isPressing } from './state.mjs';\n\n/**\n * Filter out events that are not \"Enter\" keys.\n */\nfunction filterEvents(callback) {\n return (event) => {\n if (event.key !== \"Enter\")\n return;\n callback(event);\n };\n}\nfunction firePointerEvent(target, type) {\n target.dispatchEvent(new PointerEvent(\"pointer\" + type, { isPrimary: true, bubbles: true }));\n}\nconst enableKeyboardPress = (focusEvent, eventOptions) => {\n const element = focusEvent.currentTarget;\n if (!element)\n return;\n const handleKeydown = filterEvents(() => {\n if (isPressing.has(element))\n return;\n firePointerEvent(element, \"down\");\n const handleKeyup = filterEvents(() => {\n firePointerEvent(element, \"up\");\n });\n const handleBlur = () => firePointerEvent(element, \"cancel\");\n element.addEventListener(\"keyup\", handleKeyup, eventOptions);\n element.addEventListener(\"blur\", handleBlur, eventOptions);\n });\n element.addEventListener(\"keydown\", handleKeydown, eventOptions);\n /**\n * Add an event listener that fires on blur to remove the keydown events.\n */\n element.addEventListener(\"blur\", () => element.removeEventListener(\"keydown\", handleKeydown), eventOptions);\n};\n\nexport { enableKeyboardPress };\n","import { isDragActive } from '../drag/state/is-active.mjs';\nimport { isNodeOrChild } from '../utils/is-node-or-child.mjs';\nimport { isPrimaryPointer } from '../utils/is-primary-pointer.mjs';\nimport { setupGesture } from '../utils/setup.mjs';\nimport { isElementKeyboardAccessible } from './utils/is-keyboard-accessible.mjs';\nimport { enableKeyboardPress } from './utils/keyboard.mjs';\nimport { isPressing } from './utils/state.mjs';\n\n/**\n * Filter out events that are not primary pointer events, or are triggering\n * while a Motion gesture is active.\n */\nfunction isValidPressEvent(event) {\n return isPrimaryPointer(event) && !isDragActive();\n}\n/**\n * Create a press gesture.\n *\n * Press is different to `\"pointerdown\"`, `\"pointerup\"` in that it\n * automatically filters out secondary pointer events like right\n * click and multitouch.\n *\n * It also adds accessibility support for keyboards, where\n * an element with a press gesture will receive focus and\n * trigger on Enter `\"keydown\"` and `\"keyup\"` events.\n *\n * This is different to a browser's `\"click\"` event, which does\n * respond to keyboards but only for the `\"click\"` itself, rather\n * than the press start and end/cancel. The element also needs\n * to be focusable for this to work, whereas a press gesture will\n * make an element focusable by default.\n *\n * @public\n */\nfunction press(elementOrSelector, onPressStart, options = {}) {\n const [elements, eventOptions, cancelEvents] = setupGesture(elementOrSelector, options);\n const startPress = (startEvent) => {\n const element = startEvent.currentTarget;\n if (!isValidPressEvent(startEvent) || isPressing.has(element))\n return;\n isPressing.add(element);\n const onPressEnd = onPressStart(element, startEvent);\n const onPointerEnd = (endEvent, success) => {\n window.removeEventListener(\"pointerup\", onPointerUp);\n window.removeEventListener(\"pointercancel\", onPointerCancel);\n if (!isValidPressEvent(endEvent) || !isPressing.has(element)) {\n return;\n }\n isPressing.delete(element);\n if (typeof onPressEnd === \"function\") {\n onPressEnd(endEvent, { success });\n }\n };\n const onPointerUp = (upEvent) => {\n onPointerEnd(upEvent, options.useGlobalTarget ||\n isNodeOrChild(element, upEvent.target));\n };\n const onPointerCancel = (cancelEvent) => {\n onPointerEnd(cancelEvent, false);\n };\n window.addEventListener(\"pointerup\", onPointerUp, eventOptions);\n window.addEventListener(\"pointercancel\", onPointerCancel, eventOptions);\n };\n elements.forEach((element) => {\n if (!isElementKeyboardAccessible(element) &&\n element.getAttribute(\"tabindex\") === null) {\n element.tabIndex = 0;\n }\n const target = options.useGlobalTarget ? window : element;\n target.addEventListener(\"pointerdown\", startPress, eventOptions);\n element.addEventListener(\"focus\", (event) => enableKeyboardPress(event, eventOptions), eventOptions);\n });\n return cancelEvents;\n}\n\nexport { press };\n","import '../../../../motion-utils/dist/es/errors.mjs';\nimport { press } from '../../../../motion-dom/dist/es/gestures/press/index.mjs';\nimport { extractEventInfo } from '../events/event-info.mjs';\nimport { Feature } from '../motion/features/Feature.mjs';\nimport { frame } from '../frameloop/frame.mjs';\n\nfunction handlePressEvent(node, event, lifecycle) {\n const { props } = node;\n if (node.current instanceof HTMLButtonElement && node.current.disabled) {\n return;\n }\n if (node.animationState && props.whileTap) {\n node.animationState.setActive(\"whileTap\", lifecycle === \"Start\");\n }\n const eventName = (\"onTap\" + (lifecycle === \"End\" ? \"\" : lifecycle));\n const callback = props[eventName];\n if (callback) {\n frame.postRender(() => callback(event, extractEventInfo(event)));\n }\n}\nclass PressGesture extends Feature {\n mount() {\n const { current } = this.node;\n if (!current)\n return;\n this.unmount = press(current, (_element, startEvent) => {\n handlePressEvent(this.node, startEvent, \"Start\");\n return (endEvent, { success }) => handlePressEvent(this.node, endEvent, success ? \"End\" : \"Cancel\");\n }, { useGlobalTarget: this.node.props.globalTapTarget });\n }\n unmount() { }\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","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","\"use client\";\nimport { createContext } from 'react';\n\nconst LazyContext = createContext({ strict: false });\n\nexport { LazyContext };\n","\"use client\";\nimport { createContext } from 'react';\n\nconst MotionContext = /* @__PURE__ */ createContext({});\n\nexport { MotionContext };\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 { isControllingVariants } from '../../render/utils/is-controlling-variants.mjs';\nimport { isVariantLabel } from '../../render/utils/is-variant-label.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","const motionComponentSymbol = Symbol.for(\"motionComponentSymbol\");\n\nexport { motionComponentSymbol };\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 if (instance) {\n visualState.onMount && visualState.onMount(instance);\n }\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","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\nfunction useVisualElement(Component, visualState, props, createVisualElement, ProjectionNodeConstructor) {\n var _a, _b;\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(null);\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 const isMounted = useRef(false);\n useInsertionEffect(() => {\n /**\n * Check the component has already mounted before calling\n * `update` unnecessarily. This ensures we skip the initial update.\n */\n if (visualElement && isMounted.current) {\n visualElement.update(props, presenceContext);\n }\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 !((_a = window.MotionHandoffIsComplete) === null || _a === void 0 ? void 0 : _a.call(window, optimisedAppearId)) &&\n ((_b = window.MotionHasOptimisedAnimation) === null || _b === void 0 ? void 0 : _b.call(window, optimisedAppearId)));\n useIsomorphicLayoutEffect(() => {\n if (!visualElement)\n return;\n isMounted.current = true;\n window.MotionIsMounted = true;\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 if (wantsHandoff.current) {\n // This ensures all future calls to animateChanges() in this component will run in useEffect\n queueMicrotask(() => {\n var _a;\n (_a = window.MotionHandoffMarkAsComplete) === null || _a === void 0 ? void 0 : _a.call(window, optimisedAppearId);\n });\n wantsHandoff.current = false;\n }\n });\n return visualElement;\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","\"use client\";\nimport { jsxs, jsx } from 'react/jsx-runtime';\nimport { warning, invariant } from '../../../../motion-utils/dist/es/errors.mjs';\nimport { forwardRef, useContext } from 'react';\nimport { LayoutGroupContext } from '../context/LayoutGroupContext.mjs';\nimport { LazyContext } from '../context/LazyContext.mjs';\nimport { MotionConfigContext } from '../context/MotionConfigContext.mjs';\nimport { MotionContext } from '../context/MotionContext/index.mjs';\nimport { useCreateMotionContext } from '../context/MotionContext/create.mjs';\nimport { isBrowser } from '../utils/is-browser.mjs';\nimport { featureDefinitions } from './features/definitions.mjs';\nimport { loadFeatures } from './features/load-features.mjs';\nimport { motionComponentSymbol } from './utils/symbol.mjs';\nimport { useMotionRef } from './utils/use-motion-ref.mjs';\nimport { useVisualElement } from './utils/use-visual-element.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 createRendererMotionComponent({ preloadedFeatures, createVisualElement, useRender, useVisualState, Component, }) {\n var _a, _b;\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 MotionComponent.displayName = `motion.${typeof Component === \"string\"\n ? Component\n : `create(${(_b = (_a = Component.displayName) !== null && _a !== void 0 ? _a : Component.name) !== null && _b !== void 0 ? _b : \"\"})`}`;\n const ForwardRefMotionComponent = forwardRef(MotionComponent);\n ForwardRefMotionComponent[motionComponentSymbol] = Component;\n return ForwardRefMotionComponent;\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 { createRendererMotionComponent };\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 { scaleCorrectors } from '../../projection/styles/scale-correction.mjs';\nimport { transformProps } from '../../render/html/utils/keys-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","/**\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","import { getValueAsType } from '../../dom/value-types/get-as-type.mjs';\nimport { numberValueTypes } from '../../dom/value-types/number.mjs';\nimport { transformPropOrder } from './keys-transform.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","import { isCSSVariableName } from '../../dom/utils/is-css-variable.mjs';\nimport { getValueAsType } from '../../dom/value-types/get-as-type.mjs';\nimport { numberValueTypes } from '../../dom/value-types/number.mjs';\nimport { buildTransform } from './build-transform.mjs';\nimport { transformProps } from './keys-transform.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","/**\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","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 { 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 { buildHTMLStyles } from '../../html/utils/build-styles.mjs';\nimport { buildSVGPath } from './path.mjs';\nimport { calcSVGTransformOrigin } from './transform-origin.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","import { useContext } from 'react';\nimport { isAnimationControls } from '../../animation/utils/is-animation-controls.mjs';\nimport { MotionContext } from '../../context/MotionContext/index.mjs';\nimport { PresenceContext } from '../../context/PresenceContext.mjs';\nimport { isControllingVariants, isVariantNode } from '../../render/utils/is-controlling-variants.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';\n\nfunction makeState({ scrapeMotionValuesFromProps, createRenderState, onUpdate, }, props, context, presenceContext) {\n const state = {\n latestValues: makeLatestValues(props, context, presenceContext, scrapeMotionValuesFromProps),\n renderState: createRenderState(),\n };\n if (onUpdate) {\n /**\n * onMount works without the VisualElement because it could be\n * called before the VisualElement payload has been hydrated.\n * (e.g. if someone is using m components )\n */\n state.onMount = (instance) => onUpdate({ props, current: instance, ...state });\n state.onUpdate = (visualElement) => onUpdate(visualElement);\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);\n return isStatic ? make() : useConstant(make);\n};\nfunction makeLatestValues(props, context, presenceContext, scrapeMotionValues) {\n const values = {};\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 const list = Array.isArray(variantToSet) ? variantToSet : [variantToSet];\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 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 }\n return values;\n}\n\nexport { makeUseVisualState };\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 return newValues;\n}\n\nexport { scrapeMotionValuesFromProps };\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 scrapeMotionValuesFromProps,\n createRenderState: createHtmlRenderState,\n }),\n};\n\nexport { htmlMotionConfig };\n","function updateSVGDimensions(instance, renderState) {\n try {\n renderState.dimensions =\n typeof instance.getBBox === \"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\nexport { updateSVGDimensions };\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 { isMotionValue } from '../../../value/utils/is-motion-value.mjs';\nimport { transformPropOrder } from '../../html/utils/keys-transform.mjs';\nimport { scrapeMotionValuesFromProps as scrapeMotionValuesFromProps$1 } from '../../html/utils/scrape-motion-values.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","import { frame } from '../../frameloop/frame.mjs';\nimport { makeUseVisualState } from '../../motion/utils/use-visual-state.mjs';\nimport { transformProps } from '../html/utils/keys-transform.mjs';\nimport { buildSVGAttrs } from './utils/build-attrs.mjs';\nimport { createSvgRenderState } from './utils/create-render-state.mjs';\nimport { isSVGTag } from './utils/is-svg-tag.mjs';\nimport { updateSVGDimensions } from './utils/measure.mjs';\nimport { renderSVG } from './utils/render.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\n\nconst layoutProps = [\"x\", \"y\", \"width\", \"height\", \"cx\", \"cy\", \"r\"];\nconst svgMotionConfig = {\n useVisualState: makeUseVisualState({\n scrapeMotionValuesFromProps: scrapeMotionValuesFromProps,\n createRenderState: createSvgRenderState,\n onUpdate: ({ props, prevProps, current, renderState, latestValues, }) => {\n if (!current)\n return;\n let hasTransform = !!props.drag;\n if (!hasTransform) {\n for (const key in latestValues) {\n if (transformProps.has(key)) {\n hasTransform = true;\n break;\n }\n }\n }\n if (!hasTransform)\n return;\n let needsMeasure = !prevProps;\n if (prevProps) {\n /**\n * Check the layout props for changes, if any are found we need to\n * measure the element again.\n */\n for (let i = 0; i < layoutProps.length; i++) {\n const key = layoutProps[i];\n if (props[key] !==\n prevProps[key]) {\n needsMeasure = true;\n }\n }\n }\n if (!needsMeasure)\n return;\n frame.read(() => {\n updateSVGDimensions(current, renderState);\n frame.render(() => {\n buildSVGAttrs(renderState, latestValues, isSVGTag(current.tagName), props.transformTemplate);\n renderSVG(current, renderState);\n });\n });\n },\n }),\n};\n\nexport { svgMotionConfig };\n","import { createRendererMotionComponent } from '../../motion/index.mjs';\nimport { createUseRender } from '../dom/use-render.mjs';\nimport { isSVGComponent } from '../dom/utils/is-svg-component.mjs';\nimport { htmlMotionConfig } from '../html/config-motion.mjs';\nimport { svgMotionConfig } from '../svg/config-motion.mjs';\n\nfunction createMotionComponentFactory(preloadedFeatures, createVisualElement) {\n return function createMotionComponent(Component, { forwardMotionProps } = { forwardMotionProps: false }) {\n const baseConfig = isSVGComponent(Component)\n ? svgMotionConfig\n : htmlMotionConfig;\n const config = {\n ...baseConfig,\n preloadedFeatures,\n useRender: createUseRender(forwardMotionProps),\n createVisualElement,\n Component,\n };\n return createRendererMotionComponent(config);\n };\n}\n\nexport { createMotionComponentFactory };\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","const visualElementStore = new WeakMap();\n\nexport { visualElementStore };\n","import { time } from '../frameloop/sync-time.mjs';\nimport { featureDefinitions } from '../motion/features/definitions.mjs';\nimport { createBox } from '../projection/geometry/models.mjs';\nimport { isNumericalString } from '../utils/is-numerical-string.mjs';\nimport { isZeroValueString } from '../utils/is-zero-value-string.mjs';\nimport { initPrefersReducedMotion } from '../utils/reduced-motion/index.mjs';\nimport { hasReducedMotionListener, prefersReducedMotion } from '../utils/reduced-motion/state.mjs';\nimport { SubscriptionManager } from '../utils/subscription-manager.mjs';\nimport { warnOnce } from '../utils/warn-once.mjs';\nimport { motionValue } from '../value/index.mjs';\nimport { complex } from '../value/types/complex/index.mjs';\nimport { isMotionValue } from '../value/utils/is-motion-value.mjs';\nimport { getAnimatableNone } from './dom/value-types/animatable-none.mjs';\nimport { findValueType } from './dom/value-types/find.mjs';\nimport { transformProps } from './html/utils/keys-transform.mjs';\nimport { visualElementStore } from './store.mjs';\nimport { isControllingVariants, isVariantNode } from './utils/is-controlling-variants.mjs';\nimport { KeyframeResolver } from './utils/KeyframesResolver.mjs';\nimport { updateMotionValuesFromProps } from './utils/motion-values.mjs';\nimport { resolveVariantFromProps } from './utils/resolve-variants.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];\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 * 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 if (!this.current)\n return;\n this.triggerBuild();\n this.renderInstance(this.current, this.renderState, this.props.style, this.projection);\n };\n this.renderScheduledAt = 0.0;\n this.scheduleRender = () => {\n const now = time.now();\n if (this.renderScheduledAt < now) {\n this.renderScheduledAt = now;\n frame.render(this.render, false, true);\n }\n };\n const { latestValues, renderState, onUpdate } = visualState;\n this.onUpdate = onUpdate;\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 this.projection && this.projection.unmount();\n cancelFrame(this.notifyUpdate);\n cancelFrame(this.render);\n this.valueSubscriptions.forEach((remove) => remove());\n this.valueSubscriptions.clear();\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 if (this.valueSubscriptions.has(key)) {\n this.valueSubscriptions.get(key)();\n }\n const valueIsTransform = transformProps.has(key);\n if (valueIsTransform && this.onBindTransform) {\n this.onBindTransform();\n }\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 let removeSyncCheck;\n if (window.MotionCheckAppearSync) {\n removeSyncCheck = window.MotionCheckAppearSync(this, key, value);\n }\n this.valueSubscriptions.set(key, () => {\n removeOnChange();\n removeOnRenderRequest();\n if (removeSyncCheck)\n removeSyncCheck();\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 this.onUpdate && this.onUpdate(this);\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 /**\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 { 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 === \"12.4.3\", `Attempting to mix Motion versions ${nextValue.version} with 12.4.3 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 { VisualElement } from '../VisualElement.mjs';\nimport { DOMKeyframesResolver } from './DOMKeyframesResolver.mjs';\nimport { isMotionValue } from '../../value/utils/is-motion-value.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 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}\n\nexport { DOMVisualElement };\n","import { measureViewportBox } from '../../projection/utils/measure.mjs';\nimport { DOMVisualElement } from '../dom/DOMVisualElement.mjs';\nimport { isCSSVariableName } from '../dom/utils/is-css-variable.mjs';\nimport { getDefaultValueType } from '../dom/value-types/defaults.mjs';\nimport { buildHTMLStyles } from './utils/build-styles.mjs';\nimport { transformProps } from './utils/keys-transform.mjs';\nimport { renderHTML } from './utils/render.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.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.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}\n\nexport { HTMLVisualElement, getComputedStyle };\n","import { frame } from '../../frameloop/frame.mjs';\nimport { createBox } from '../../projection/geometry/models.mjs';\nimport { DOMVisualElement } from '../dom/DOMVisualElement.mjs';\nimport { camelToDash } from '../dom/utils/camel-to-dash.mjs';\nimport { getDefaultValueType } from '../dom/value-types/defaults.mjs';\nimport { transformProps } from '../html/utils/keys-transform.mjs';\nimport { buildSVGAttrs } from './utils/build-attrs.mjs';\nimport { camelCaseAttributes } from './utils/camel-case-attrs.mjs';\nimport { isSVGTag } from './utils/is-svg-tag.mjs';\nimport { updateSVGDimensions } from './utils/measure.mjs';\nimport { renderSVG } from './utils/render.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\n\nclass SVGVisualElement extends DOMVisualElement {\n constructor() {\n super(...arguments);\n this.type = \"svg\";\n this.isSVGTag = false;\n this.measureInstanceViewportBox = createBox;\n this.updateDimensions = () => {\n if (this.current && !this.renderState.dimensions) {\n updateSVGDimensions(this.current, this.renderState);\n }\n };\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 onBindTransform() {\n if (this.current && !this.renderState.dimensions) {\n frame.postRender(this.updateDimensions);\n }\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 { createDOMMotionComponentProxy } from '../create-proxy.mjs';\nimport { createMotionComponent } from './create.mjs';\n\nconst motion = /*@__PURE__*/ createDOMMotionComponentProxy(createMotionComponent);\n\nexport { motion };\n","import { animations } from '../../../motion/features/animations.mjs';\nimport { drag } from '../../../motion/features/drag.mjs';\nimport { gestureAnimations } from '../../../motion/features/gestures.mjs';\nimport { layout } from '../../../motion/features/layout.mjs';\nimport { createMotionComponentFactory } from '../create-factory.mjs';\nimport { createDomVisualElement } from '../../dom/create-visual-element.mjs';\n\nconst createMotionComponent = /*@__PURE__*/ createMotionComponentFactory({\n ...animations,\n ...gestureAnimations,\n ...drag,\n ...layout,\n}, createDomVisualElement);\n\nexport { createMotionComponent };\n","const isBrowser = typeof window !== \"undefined\";\n\nexport { isBrowser };\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","// Does this device prefer reduced motion? Returns `null` server-side.\nconst prefersReducedMotion = { current: null };\nconst hasReducedMotionListener = { current: false };\n\nexport { hasReducedMotionListener, prefersReducedMotion };\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","import { useLayoutEffect, useEffect } from 'react';\nimport { isBrowser } from './is-browser.mjs';\n\nconst useIsomorphicLayoutEffect = isBrowser ? useLayoutEffect : useEffect;\n\nexport { useIsomorphicLayoutEffect };\n","function resolveElements(elementOrSelector, scope, selectorCache) {\n var _a;\n if (elementOrSelector instanceof Element) {\n return [elementOrSelector];\n }\n else if (typeof elementOrSelector === \"string\") {\n let root = document;\n if (scope) {\n // TODO: Refactor to utils package\n // invariant(\n // Boolean(scope.current),\n // \"Scope provided, but no element detected.\"\n // )\n root = scope.current;\n }\n const elements = (_a = selectorCache === null || selectorCache === void 0 ? void 0 : selectorCache[elementOrSelector]) !== null && _a !== void 0 ? _a : root.querySelectorAll(elementOrSelector);\n return elements ? Array.from(elements) : [];\n }\n return Array.from(elementOrSelector);\n}\n\nexport { resolveElements };\n"],"names":["REACT_ELEMENT_TYPE","Symbol","for","REACT_FRAGMENT_TYPE","jsxProd","type","config","maybeKey","key","propName","ref","$$typeof","props","exports","Fragment","jsx","jsxs","module","usePresence","subscribe","context","useContext","isPresent","onExitComplete","register","id","useId","useEffect","safeToRemove","useCallback","LayoutGroupContext","createContext","MotionConfigContext","transformPagePoint","p","isStatic","reducedMotion","PresenceContext","createDOMMotionComponentProxy","componentFactory","Proxy","componentCache","Map","args","get","_target","has","set","isAnimationControls","v","start","getValueState","visualElement","state","values","forEach","value","getVelocity","resolveVariantFromProps","definition","custom","current","velocity","undefined","variants","resolveVariant","getProps","getValueTransition","transition","transformPropOrder","transformProps","Set","positionalKeys","isKeyframesTarget","Array","isArray","isCustomValue","Boolean","mix","toValue","resolveFinalValueInKeyframes","length","MotionGlobalConfig","noop","any","stepsOrder","statsBuffer","addProjectionMetrics","createRenderBatcher","scheduleNextBatch","allowKeepAlive","runNextFrame","useDefaultElapsed","delta","timestamp","isProcessing","flagRunNextFrame","steps","reduce","acc","stepName","thisFrame","nextFrame","flushNextFrame","toKeepAlive","WeakSet","latestFrameData","numCalls","triggerCallback","callback","step","schedule","keepAlive","immediate","queue","add","cancel","delete","process","frameData","frameloop","push","clear","createRenderStep","read","resolveKeyframes","update","preRender","render","postRender","processBatch","performance","now","Math","max","min","i","cancelFrame","frameSteps","requestAnimationFrame","clearTime","time","newTime","queueMicrotask","addUniqueItem","arr","item","indexOf","removeItem","index","splice","SubscriptionManager","constructor","this","subscriptions","handler","notify","a","b","c","numSubscriptions","getSize","velocityPerSecond","frameDuration","collectMotionValues","MotionValue","init","options","version","canTrackVelocity","events","updateAndNotify","currentTime","updatedAt","setPrevFrameValue","prev","setCurrent","change","renderRequest","hasAnimated","owner","isNaN","parseFloat","prevFrameValue","prevUpdatedAt","onChange","subscription","on","eventName","unsubscribe","stop","clearListeners","eventManagers","attach","passiveEffect","stopPassiveEffect","setWithVelocity","jump","endAnimation","getPrevious","startAnimation","Promise","resolve","animation","animationStart","then","animationComplete","clearAnimation","animationCancel","isAnimating","destroy","motionValue","setMotionValue","hasValue","getValue","addValue","isMotionValue","addValueToWillChange","willChange","camelToDash","str","replace","toLowerCase","optimizedAppearDataAttribute","getOptimisedAppearId","memo","result","supportsScrollTimeline","window","ScrollTimeline","BaseGroupPlaybackControls","animations","runAll","filter","finished","all","map","getAll","setAll","newValue","attachTimeline","timeline","fallback","speed","startTime","duration","methodName","controls","flatten","play","pause","complete","GroupPlaybackControls","onResolve","onReject","catch","seconds","millisecondsToSeconds","milliseconds","instantAnimationState","isGenerator","onfinish","isBezierDefinition","easing","supportsFlags","linearEasing","memoSupports","supportsFlag","memoized","_a","supportsLinearEasing","document","createElement","animate","opacity","e","progress","from","to","toFromDifference","generateLinearEasing","resolution","points","numPoints","round","substring","isWaapiSupportedEasing","supportedWaapiEasing","every","cubicBezierAsString","d","linear","ease","easeIn","easeOut","easeInOut","circIn","circOut","backIn","backOut","mapEasingToNativeEasing","segmentEasing","calcBezier","t","a1","a2","subdivisionPrecision","subdivisionMaxIterations","cubicBezier","mX1","mY1","mX2","mY2","getTForX","aX","x","lowerBound","upperBound","currentX","currentT","abs","binarySubdivide","mirrorEasing","reverseEasing","backInOut","anticipate","pow","sin","acos","circInOut","isZeroValueString","test","clamp","number","parse","transform","alpha","scale","default","sanitize","floatRegex","singleColorRegex","isColorString","testProp","startsWith","isNullish","Object","prototype","hasOwnProperty","call","splitColor","aName","bName","cName","match","rgbUnit","clampRgbUnit","rgba","red","green","blue","alpha$1","hex","r","g","parseInt","createUnitType","unit","endsWith","split","degrees","percent","px","vh","vw","progressPercentage","hsla","hue","saturation","lightness","color","colorRegex","NUMBER_TOKEN","COLOR_TOKEN","VAR_TOKEN","VAR_FUNCTION_TOKEN","SPLIT_TOKEN","complexRegex","analyseComplexValue","originalValue","toString","indexes","var","types","parsedValue","parseComplexValue","createTransformer","source","numSections","output","convertNumbersToZero","complex","_b","getAnimatableNone","parsed","transformer","maxDefaults","applyDefaultFilter","name","slice","defaultValue","functionRegex","functions","join","browserNumberValueTypes","borderWidth","borderTopWidth","borderRightWidth","borderBottomWidth","borderLeftWidth","borderRadius","radius","borderTopLeftRadius","borderTopRightRadius","borderBottomRightRadius","borderBottomLeftRadius","width","maxWidth","height","maxHeight","top","right","bottom","left","padding","paddingTop","paddingRight","paddingBottom","paddingLeft","margin","marginTop","marginRight","marginBottom","marginLeft","backgroundPositionX","backgroundPositionY","transformValueTypes","rotate","rotateX","rotateY","rotateZ","scaleX","scaleY","scaleZ","skew","skewX","skewY","distance","translateX","translateY","translateZ","y","z","perspective","transformPerspective","originX","originY","originZ","numberValueTypes","zIndex","size","fillOpacity","strokeOpacity","numOctaves","defaultValueTypes","backgroundColor","outlineColor","fill","stroke","borderColor","borderTopColor","borderRightColor","borderBottomColor","borderLeftColor","WebkitFilter","getDefaultValueType","defaultValueType","invalidTemplates","isNumOrPxType","getPosFromMatrix","matrix","pos","getTranslateFromMatrix","pos2","pos3","_bbox","matrix3d","transformKeys","nonTranslationalTransformKeys","positionalValues","toResolve","isScheduled","anyNeedsMeasurement","measureAllKeyframes","resolversToMeasure","resolver","needsMeasurement","elementsToMeasure","element","transformsToRestore","removedTransforms","removeNonTranslationalTransform","measureInitialState","restore","measureEndState","suspendedScrollY","scrollTo","readAllKeyframes","readKeyframes","KeyframeResolver","unresolvedKeyframes","onComplete","isAsync","isComplete","scheduleResolve","currentValue","finalKeyframe","valueAsRead","readValue","setFinalKeyframe","renderEndStyles","resume","warning","invariant","isNumericalString","checkStringStartsWith","token","isCSSVariableName","startsAsVariableToken","isCSSVariableToken","singleCssVariableRegex","trim","splitCSSVariableRegex","getVariableValue","depth","exec","token1","token2","parseCSSVariable","resolved","getComputedStyle","getPropertyValue","trimmed","testValueType","dimensionValueTypes","findDimensionValueType","find","DOMKeyframesResolver","super","keyframe","resolveNoneKeyframes","origin","target","originType","targetType","noneKeyframeIndexes","animatableTemplate","noneIndex","makeNoneKeyframesAnimatable","pageYOffset","measuredOrigin","measureViewportBox","measureKeyframe","finalKeyframeIndex","unsetTransformName","unsetTransformValue","isAnimatable","canAnimate","keyframes","originKeyframe","targetKeyframe","isOriginAnimatable","isTargetAnimatable","hasKeyframesChanged","isNotNull","getFinalKeyframe","repeat","repeatType","resolvedKeyframes","BaseAnimation","autoplay","delay","repeatDelay","isStopped","hasAttemptedResolve","createdAt","updateFinishedPromise","calcStartTime","resolvedAt","_resolved","onKeyframesResolved","onUpdate","resolveFinishedPromise","resolvedAnimation","initPlayback","onPostResolved","reject","currentFinishedPromise","maxGeneratorDuration","calcGeneratorDuration","generator","next","done","Infinity","activeAnimations","layout","mainThread","waapi","mixNumber","hueToRgb","q","mixImmediate","mixLinearColor","fromExpo","expo","sqrt","colorTypes","asRGBA","model","hslaToRgba","mixColor","fromRGBA","toRGBA","blended","combineFunctions","pipe","transformers","invisibleValues","getMixer","mixComplex","mixArray","mixObject","numValues","blendValue","template","originStats","targetStats","mixVisibility","orderedOrigin","pointers","originIndex","originValue","matchOrder","mixer","velocitySampleDuration","calcGeneratorVelocity","resolveValue","prevT","springDefaults","stiffness","damping","mass","bounce","visualDuration","restSpeed","granular","restDelta","minDuration","maxDuration","minDamping","maxDamping","safeMin","findSpring","envelope","derivative","dampingRatio","undampedFreq","exponentialDecay","calcAngularFreq","exp","f","initialGuess","rootIterations","approximateRoot","durationKeys","physicsKeys","isSpringType","keys","some","spring","optionsOrVisualDuration","isResolvedFromDuration","springOptions","root","PI","derived","getSpringOptions","initialVelocity","initialDelta","undampedAngularFreq","isGranularScale","resolveSpring","angularFreq","cos","dampedAngularFreq","freqForT","sinh","cosh","calculatedDuration","currentVelocity","isBelowVelocityThreshold","isBelowDisplacementThreshold","inertia","power","timeConstant","bounceDamping","bounceStiffness","modifyTarget","nearestBoundary","amplitude","ideal","calcDelta","calcLatest","applyFriction","latest","timeReachedBoundary","spring$1","checkCatchBoundary","hasUpdatedFrame","easingLookup","easingDefinitionToFunction","x1","y1","x2","y2","interpolate","input","isClamp","inputLength","isZeroDeltaRange","reverse","mixers","customMixer","mixerFactory","numMixers","easingFunction","createMixers","interpolator","progressInRange","defaultOffset","offset","remaining","offsetProgress","fillOffset","keyframeValues","times","easingFunctions","isEasingArray","absoluteTimes","o","convertOffsetToTimes","mapTimeToKeyframe","frameloopDriver","passTimestamp","generators","decay","tween","percentToProgress","MainThreadAnimation","holdTime","cancelTime","playbackSpeed","pendingPlayState","teardown","onStop","KeyframeResolver$1","assign","keyframes$1","generatorFactory","mapPercentToKeyframes","mirroredGenerator","resolvedDuration","totalDuration","tick","sample","timeWithoutDelay","isInDelayPhase","elapsed","frameGenerator","currentIteration","floor","iterationProgress","isAnimationFinished","finish","driver","newSpeed","hasChanged","onPlay","stopDriver","acceleratedValues","startWaapiAnimation","valueName","keyframeOptions","iterations","direction","finally","supportsWaapi","Element","unsupportedEasingFunctions","AcceleratedAnimation","pregeneratedAnimation","sampleAnimation","pregeneratedKeyframes","pregenerateKeyframes","pendingTimeline","playbackRate","playState","sampleTime","supports","HTMLElement","transformTemplate","underDampedSpring","keyframesTransition","getDefaultTransition","valueKey","animateMotionValue","isHandoff","valueTransition","when","_delay","delayChildren","staggerChildren","staggerDirection","isTransitionDefined","shouldSkip","shouldBlockAnimation","protectedKeys","needsAnimating","shouldBlock","animateTarget","targetAndTransition","transitionOverride","transitionEnd","animationTypeState","animationState","getState","latestValues","valueTarget","MotionHandoffAnimation","appearId","shouldReduceMotion","setTarget","animateVariant","variant","presenceContext","getAnimation","getChildAnimations","variantChildren","forwardDelay","maxStaggerDuration","generateStaggerDuration","sort","sortByTreeOrder","child","animateChildren","first","last","sortNodePosition","shallowCompare","prevLength","isVariantLabel","variantPriorityOrder","variantProps","numVariantProps","getVariantContext","isControllingVariants","parent","initial","prop","reversePriorityOrder","numAnimationTypes","animateList","resolvedDefinition","animateVisualElement","createAnimationState","createState","isInitialRender","buildResolvedTypeValues","animateChanges","changedActiveType","removedKeys","encounteredKeys","removedVariantIndex","typeState","propIsVariant","activeDelta","isActive","isInherited","manuallyAnimateOnMount","prevProp","variantDidChange","checkVariantsDidChange","shouldAnimateType","handledRemovedValues","definitionList","resolvedValues","prevResolvedValues","allKeys","markToAnimate","liveStyle","valueHasChanged","blockInitialAnimation","fallbackAnimation","initialTransition","fallbackTarget","getBaseTarget","shouldAnimate","setActive","setAnimateFunction","makeAnimator","reset","createTypeState","whileInView","whileHover","whileTap","whileDrag","whileFocus","exit","Feature","node","isMounted","updateAnimationControlsSubscription","unmountControls","mount","prevAnimate","prevProps","unmount","arguments","prevIsPresent","prevPresenceContext","exitAnimation","isDragging","isDragActive","isPrimaryPointer","event","pointerType","button","isPrimary","addDomEvent","passive","addEventListener","removeEventListener","extractEventInfo","point","pageX","pageY","addPointerEvent","addPointerInfo","PanSession","handlers","contextWindow","dragSnapToOrigin","startEvent","lastMoveEvent","lastMoveEventInfo","updatePoint","info","getPanInfo","history","isPanStarted","isDistancePastThreshold","xDelta","yDelta","distance2D","onStart","onMove","handlePointerMove","transformPoint","handlePointerUp","end","onEnd","onSessionEnd","resumeAnimation","panInfo","initialInfo","onSessionStart","removeListeners","updateHandlers","subtractPoint","lastDevicePoint","startDevicePoint","timeDelta","timestampedPoint","lastPoint","isRefObject","SCALE_MIN","SCALE_MAX","TRANSLATE_MIN","TRANSLATE_MAX","calcLength","axis","calcAxisDelta","originPoint","translate","calcBoxDelta","calcRelativeAxis","relative","calcRelativeAxisPosition","calcRelativePosition","calcRelativeAxisConstraints","calcViewportAxisConstraints","layoutAxis","constraintsAxis","defaultElastic","resolveAxisElastic","dragElastic","minLabel","maxLabel","resolvePointElastic","label","createDelta","createBox","eachAxis","convertBoundingBoxToBox","isIdentityScale","hasScale","hasTransform","has2DTranslate","is2DTranslate","scalePoint","applyPointDelta","boxScale","applyAxisDelta","applyBoxDelta","box","TREE_SCALE_SNAP_MIN","TREE_SCALE_SNAP_MAX","translateAxis","transformAxis","axisTranslate","axisScale","axisOrigin","transformBox","instance","topLeft","bottomRight","transformBoxPoints","getBoundingClientRect","getContextWindow","ownerDocument","defaultView","elementDragControls","WeakMap","VisualElementDragControls","openDragLock","currentDirection","constraints","hasMutatedConstraints","elastic","originEvent","snapToCursor","panSession","pauseAnimation","stopAnimation","drag","dragPropagation","onDragStart","resolveConstraints","projection","isAnimationBlocked","getAxisMotionValue","measuredAxis","layoutBox","dragDirectionLock","onDirectionLock","onDrag","lockThreshold","getCurrentDirection","updateAxis","getAnimationState","getTransformPagePoint","onDragEnd","_point","shouldDrag","axisValue","applyConstraints","dragConstraints","measure","prevConstraints","resolveRefConstraints","calcRelativeConstraints","resolveDragElastic","relativeConstraints","rebaseAxisConstraints","onMeasureDragConstraints","constraintsElement","constraintsBox","rootProjectionNode","viewportBox","scroll","measurePageBox","measuredConstraints","calcViewportConstraints","userConstraints","convertBoxToBoundingBox","dragMomentum","dragTransition","onDragTransitionEnd","momentumAnimations","startAxisValueAnimation","dragKey","toUpperCase","externalMotionValue","scalePositionWithinConstraints","boxProgress","sourceLength","targetLength","calcOrigin","style","updateScroll","updateLayout","addListeners","stopPointerListener","dragListener","measureDragConstraints","stopMeasureLayoutListener","stopResizeListener","stopLayoutUpdateListener","hasLayoutChanged","asyncHandler","SwitchLayoutGroupContext","globalProjectionState","hasAnimatedSinceResize","hasEverUpdated","pixelsToPercent","pixels","correctBorderRadius","correct","correctBoxShadow","treeScale","projectionDelta","original","shadow","xScale","yScale","averageScale","scaleCorrectors","microtask","cancelMicrotask","MeasureLayoutWithContext","Component","componentDidMount","layoutGroup","switchLayoutGroup","layoutId","correctors","isCSSVariable","addScaleCorrector","defaultScaleCorrectors","group","didUpdate","setOptions","getSnapshotBeforeUpdate","layoutDependency","willUpdate","promote","relegate","stack","getStack","members","componentDidUpdate","currentAnimation","isLead","componentWillUnmount","promoteContext","scheduleCheckAfterUnmount","remove","deregister","MeasureLayout","L","applyTo","boxShadow","compareByDepth","FlatTree","children","isDirty","timeout","checkElapsed","resolveMotionValue","unwrappedValue","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","metrics","nodes","calculatedTargetDeltas","calculatedProjections","transformAxes","hiddenVisibility","visibility","resetDistortingTransform","sharedAnimationValues","setStaticValue","cancelTreeOptimisedTransformAnimations","projectionNode","hasCheckedOptimisedAppear","MotionHasOptimisedAnimation","MotionCancelOptimisedAnimation","createProjectionNode","attachResizeListener","defaultParent","measureScroll","checkIsScrollRoot","resetTransform","animationId","isTreeAnimating","isProjectionDirty","isSharedProjectionDirty","isTransformDirty","updateManuallyBlocked","updateBlockedByResize","isSVG","needsReset","shouldResetTransform","eventHandlers","hasTreeAnimated","updateScheduled","scheduleUpdate","projectionUpdateScheduled","checkUpdateFailed","clearAllSnapshots","updateProjection","propagateDirtyNodes","resolveTargetDelta","calcProjection","cleanDirtyNodes","resolvedRelativeTargetAt","hasProjected","isVisible","animationProgress","sharedNodes","path","notifyListeners","subscriptionManager","hasListeners","SVGElement","tagName","cancelDelay","resizeUnblockUpdate","finishAnimation","registerSharedNode","hasRelativeLayoutChanged","newLayout","isTreeAnimationBlocked","relativeTarget","layoutTransition","defaultLayoutTransition","onLayoutAnimationStart","onLayoutAnimationComplete","hasTargetChanged","targetLayout","hasOnlyRelativeTargetChanged","layoutRoot","setAnimationOrigin","animationOptions","blockUpdate","unblockUpdate","isUpdateBlocked","startUpdate","resetSkewAndRotation","getTransformTemplate","shouldNotifyListeners","prevTransformTemplateValue","updateSnapshot","clearMeasurements","clearIsLayoutDirty","resetTransformStyle","notifyLayoutUpdate","clearSnapshot","removeLeadSnapshots","scheduleUpdateProjection","measuredBox","alwaysMeasureLayout","prevLayout","layoutCorrected","phase","layoutScroll","isRoot","wasRoot","isResetRequested","hasProjection","transformTemplateValue","transformTemplateHasChanged","removeTransform","pageBox","removeElementScroll","roundAxis","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","animationType","xLength","yLength","initialPromotionConfig","shouldPreserveFollowOpacity","getPrevLead","hasDistortingTransform","resetValues","getProjectionStyles","styleProp","styles","pointerEvents","emptyStyles","valuesToRender","latestTransform","xTranslate","yTranslate","zTranslate","elementScaleX","elementScaleY","buildProjectionTransform","transformOrigin","corrected","num","renderState","vars","resetTree","measuredLayout","axisSnapshot","layoutDelta","visualDelta","parentSnapshot","parentLayout","relativeSnapshot","onBeforeLayoutMeasure","userAgentContains","string","navigator","userAgent","includes","roundPoint","maxDistance","DocumentProjectionNode","documentElement","scrollLeft","body","scrollTop","HTMLProjectionNode","documentNode","position","pan","removePointerDownListener","onPointerDown","pointerDownEvent","session","createPanHandlers","onPanSessionStart","onPanStart","onPan","onPanEnd","removeGroupControls","dragControls","ProjectionNode","setupGesture","elementOrSelector","elements","gestureAbortController","AbortController","signal","abort","isValidHover","handleHoverEvent","lifecycle","isNodeOrChild","parentElement","focusableElements","isPressing","filterEvents","firePointerEvent","dispatchEvent","PointerEvent","bubbles","isValidPressEvent","press","onPressStart","eventOptions","cancelEvents","startPress","currentTarget","onPressEnd","onPointerEnd","endEvent","success","onPointerUp","onPointerCancel","upEvent","useGlobalTarget","cancelEvent","tabIndex","isElementKeyboardAccessible","getAttribute","focusEvent","handleKeydown","handleKeyup","enableKeyboardPress","handlePressEvent","HTMLButtonElement","disabled","observerCallbacks","observers","fireObserverCallback","entry","fireAllObserverCallbacks","entries","observeIntersection","rootInteresectionObserver","lookupRoot","rootObservers","JSON","stringify","IntersectionObserver","initIntersectionObserver","observe","unobserve","thresholdNames","gestureAnimations","inView","hasEnteredView","isInView","startObserver","viewport","rootMargin","amount","once","threshold","isIntersecting","onViewportEnter","onViewportLeave","prevViewport","hasViewportOptionChanged","tap","_element","globalTapTarget","focus","onFocus","isFocusVisible","matches","onBlur","hover","onHoverStart","onPointerEnter","enterEvent","onHoverEnd","onPointerLeave","leaveEvent","LazyContext","strict","MotionContext","isVariantNode","useCreateMotionContext","inherit","getCurrentTreeVariants","useMemo","variantLabelsAsDependency","featureProps","featureDefinitions","isEnabled","motionComponentSymbol","useMotionRef","visualState","externalRef","onMount","useVisualElement","createVisualElement","ProjectionNodeConstructor","lazyContext","reducedMotionConfig","visualElementRef","useRef","renderer","initialLayoutGroupConfig","getClosestProjectingNode","useInsertionEffect","optimisedAppearId","wantsHandoff","MotionHandoffIsComplete","MotionIsMounted","updateFeatures","MotionHandoffMarkAsComplete","allowProjection","createRendererMotionComponent","preloadedFeatures","useRender","useVisualState","MotionComponent","configAndProps","useLayoutId","useStrictMode","layoutProjection","combined","getProjectionFunctionality","Provider","features","loadFeatures","displayName","ForwardRefMotionComponent","forwardRef","layoutGroupId","isForcedMotionValue","getValueAsType","translateAlias","numTransforms","buildHTMLStyles","hasTransformOrigin","valueAsType","transformString","transformIsDefault","valueIsDefault","buildTransform","createHtmlRenderState","copyRawValuesOnly","useStyle","useInitialMotionValues","useHTMLProps","htmlProps","draggable","userSelect","WebkitUserSelect","WebkitTouchCallout","touchAction","onTap","onTapStart","validMotionProps","isValidMotionProp","shouldForward","isValidProp","require","lowercaseSVGElements","isSVGComponent","dashKeys","array","camelKeys","buildSVGAttrs","attrX","attrY","attrScale","pathLength","pathSpacing","pathOffset","isSVGTag","viewBox","attrs","dimensions","calcSVGTransformOrigin","spacing","useDashCase","buildSVGPath","createSvgRenderState","tag","useSVGProps","_isStatic","visualProps","rawStyles","createUseRender","forwardMotionProps","filteredProps","isDom","filterProps","elementProps","renderedChildren","makeUseVisualState","make","scrapeMotionValuesFromProps","createRenderState","makeLatestValues","makeState","scrapeMotionValues","motionValues","isControllingVariants$1","isVariantNode$1","isInitialAnimationBlocked","variantToSet","list","newValues","htmlMotionConfig","updateSVGDimensions","getBBox","renderHTML","setProperty","camelCaseAttributes","renderSVG","_styleProp","setAttribute","charAt","layoutProps","svgMotionConfig","needsMeasure","createMotionComponentFactory","valueTypes","visualElementStore","propEventHandlers","VisualElement","_props","_prevProps","_visualElement","valueSubscriptions","prevMotionValues","propEventSubscriptions","notifyUpdate","triggerBuild","renderInstance","renderScheduledAt","baseTarget","initialValues","initialMotionValues","removeFromVariantTree","addVariantChild","bindToMotionValue","feature","valueIsTransform","onBindTransform","removeOnChange","latestValue","removeOnRenderRequest","removeSyncCheck","MotionCheckAppearSync","other","sortInstanceNodePosition","featureDefinition","FeatureConstructor","build","measureInstanceViewportBox","getStaticValue","listener","nextValue","prevValue","existingValue","removeValue","updateMotionValuesFromProps","handleChildMotionValue","getVariant","getClosestVariantNode","closestVariantNode","removeValueFromRenderState","getBaseTargetFromProps","readValueFromInstance","setBaseTarget","valueFromInitial","DOMVisualElement","compareDocumentPosition","childSubscription","textContent","HTMLVisualElement","defaultType","computedStyle","SVGVisualElement","updateDimensions","motion","isBrowser","initPrefersReducedMotion","matchMedia","motionMediaQuery","setReducedMotionPreferences","addListener","prefersReducedMotion","hasReducedMotionListener","useConstant","useIsomorphicLayoutEffect","useLayoutEffect","resolveElements","scope","selectorCache","querySelectorAll"],"sourceRoot":""}