motion 10.18.0 → 11.11.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +32 -0
- package/{LICENSE → LICENSE.md} +2 -2
- package/README.md +99 -7
- package/dist/cjs/index.js +6117 -0
- package/dist/cjs/react-client.js +10003 -0
- package/dist/cjs/react-m.js +1852 -0
- package/dist/es/framer-motion/dist/es/animation/GroupPlaybackControls.mjs +78 -0
- package/dist/es/framer-motion/dist/es/animation/animate/index.mjs +34 -0
- package/dist/es/framer-motion/dist/es/animation/animate/resolve-subjects.mjs +19 -0
- package/dist/es/framer-motion/dist/es/animation/animate/sequence.mjs +14 -0
- package/dist/es/framer-motion/dist/es/animation/animate/single-value.mjs +11 -0
- package/dist/es/framer-motion/dist/es/animation/animate/subject.mjs +52 -0
- package/dist/es/framer-motion/dist/es/animation/animators/AcceleratedAnimation.mjs +318 -0
- package/dist/es/framer-motion/dist/es/animation/animators/BaseAnimation.mjs +113 -0
- package/dist/es/framer-motion/dist/es/animation/animators/MainThreadAnimation.mjs +384 -0
- package/dist/es/framer-motion/dist/es/animation/animators/drivers/driver-frameloop.mjs +17 -0
- package/dist/es/framer-motion/dist/es/animation/animators/utils/accelerated-values.mjs +14 -0
- package/dist/es/framer-motion/dist/es/animation/animators/utils/can-animate.mjs +42 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/NativeAnimation.mjs +169 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/animate-elements.mjs +36 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/animate-style.mjs +12 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/easing.mjs +44 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/index.mjs +23 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/attach-timeline.mjs +6 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/get-final-keyframe.mjs +12 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/linear.mjs +15 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/memo-supports.mjs +9 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/style.mjs +8 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/supports-flags.mjs +9 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/supports-linear-easing.mjs +15 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/supports-partial-keyframes.mjs +13 -0
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/supports-waapi.mjs +5 -0
- package/dist/es/framer-motion/dist/es/animation/generators/inertia.mjs +87 -0
- package/dist/es/framer-motion/dist/es/animation/generators/keyframes.mjs +51 -0
- package/dist/es/framer-motion/dist/es/animation/generators/spring/find.mjs +89 -0
- package/dist/es/framer-motion/dist/es/animation/generators/spring/index.mjs +129 -0
- package/dist/es/framer-motion/dist/es/animation/generators/utils/calc-duration.mjs +17 -0
- package/dist/es/framer-motion/dist/es/animation/generators/utils/is-generator.mjs +5 -0
- package/dist/es/framer-motion/dist/es/animation/generators/utils/velocity.mjs +9 -0
- package/dist/es/framer-motion/dist/es/animation/hooks/animation-controls.mjs +80 -0
- package/dist/es/framer-motion/dist/es/animation/hooks/use-animate-style.mjs +17 -0
- package/dist/es/framer-motion/dist/es/animation/hooks/use-animate.mjs +17 -0
- package/dist/es/framer-motion/dist/es/animation/hooks/use-animated-state.mjs +64 -0
- package/dist/es/framer-motion/dist/es/animation/hooks/use-animation.mjs +41 -0
- package/dist/es/framer-motion/dist/es/animation/interfaces/motion-value.mjs +113 -0
- package/dist/es/framer-motion/dist/es/animation/interfaces/visual-element-target.mjs +75 -0
- package/dist/es/framer-motion/dist/es/animation/interfaces/visual-element-variant.mjs +66 -0
- package/dist/es/framer-motion/dist/es/animation/interfaces/visual-element.mjs +26 -0
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/data-id.mjs +6 -0
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/get-appear-id.mjs +7 -0
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/handoff.mjs +40 -0
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/start.mjs +173 -0
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/store-id.mjs +8 -0
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/store.mjs +4 -0
- package/dist/es/framer-motion/dist/es/animation/sequence/create.mjs +230 -0
- package/dist/es/framer-motion/dist/es/animation/sequence/utils/calc-time.mjs +21 -0
- package/dist/es/framer-motion/dist/es/animation/sequence/utils/edit.mjs +31 -0
- package/dist/es/framer-motion/dist/es/animation/sequence/utils/sort.mjs +14 -0
- package/dist/es/framer-motion/dist/es/animation/utils/create-visual-element.mjs +44 -0
- package/dist/es/framer-motion/dist/es/animation/utils/default-transitions.mjs +40 -0
- package/dist/es/framer-motion/dist/es/animation/utils/get-value-transition.mjs +9 -0
- package/dist/es/framer-motion/dist/es/animation/utils/is-animatable.mjs +30 -0
- package/dist/es/framer-motion/dist/es/animation/utils/is-animation-controls.mjs +7 -0
- package/dist/es/framer-motion/dist/es/animation/utils/is-dom-keyframes.mjs +5 -0
- package/dist/es/framer-motion/dist/es/animation/utils/is-keyframes-target.mjs +5 -0
- package/dist/es/framer-motion/dist/es/animation/utils/is-none.mjs +15 -0
- package/dist/es/framer-motion/dist/es/animation/utils/is-transition-defined.mjs +10 -0
- package/dist/es/framer-motion/dist/es/animation/utils/stagger.mjs +26 -0
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/PopChild.mjs +77 -0
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/PresenceChild.mjs +61 -0
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/index.mjs +163 -0
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/use-presence.mjs +66 -0
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/utils.mjs +14 -0
- package/dist/es/framer-motion/dist/es/components/AnimateSharedLayout.mjs +15 -0
- package/dist/es/framer-motion/dist/es/components/LayoutGroup/index.mjs +32 -0
- package/dist/es/framer-motion/dist/es/components/LazyMotion/index.mjs +68 -0
- package/dist/es/framer-motion/dist/es/components/MotionConfig/index.mjs +48 -0
- package/dist/es/framer-motion/dist/es/components/Reorder/Group.mjs +53 -0
- package/dist/es/framer-motion/dist/es/components/Reorder/Item.mjs +34 -0
- package/dist/es/framer-motion/dist/es/components/Reorder/namespace.mjs +2 -0
- package/dist/es/framer-motion/dist/es/components/Reorder/utils/check-reorder.mjs +24 -0
- package/dist/es/framer-motion/dist/es/context/DeprecatedLayoutGroupContext.mjs +10 -0
- package/dist/es/framer-motion/dist/es/context/LayoutGroupContext.mjs +6 -0
- package/dist/es/framer-motion/dist/es/context/LazyContext.mjs +6 -0
- package/dist/es/framer-motion/dist/es/context/MotionConfigContext.mjs +13 -0
- package/dist/es/framer-motion/dist/es/context/MotionContext/create.mjs +13 -0
- package/dist/es/framer-motion/dist/es/context/MotionContext/index.mjs +6 -0
- package/dist/es/framer-motion/dist/es/context/MotionContext/utils.mjs +17 -0
- package/dist/es/framer-motion/dist/es/context/PresenceContext.mjs +9 -0
- package/dist/es/framer-motion/dist/es/context/ReorderContext.mjs +6 -0
- package/dist/es/framer-motion/dist/es/context/SwitchLayoutGroupContext.mjs +9 -0
- package/dist/es/framer-motion/dist/es/easing/anticipate.mjs +5 -0
- package/dist/es/framer-motion/dist/es/easing/back.mjs +9 -0
- package/dist/es/framer-motion/dist/es/easing/circ.mjs +8 -0
- package/dist/es/framer-motion/dist/es/easing/cubic-bezier.mjs +51 -0
- package/dist/es/framer-motion/dist/es/easing/ease.mjs +7 -0
- package/dist/es/framer-motion/dist/es/easing/modifiers/mirror.mjs +5 -0
- package/dist/es/framer-motion/dist/es/easing/modifiers/reverse.mjs +5 -0
- package/dist/es/framer-motion/dist/es/easing/steps.mjs +15 -0
- package/dist/es/framer-motion/dist/es/easing/utils/create-generator-easing.mjs +17 -0
- package/dist/es/framer-motion/dist/es/easing/utils/get-easing-for-segment.mjs +8 -0
- package/dist/es/framer-motion/dist/es/easing/utils/is-bezier-definition.mjs +3 -0
- package/dist/es/framer-motion/dist/es/easing/utils/is-easing-array.mjs +5 -0
- package/dist/es/framer-motion/dist/es/easing/utils/map.mjs +38 -0
- package/dist/es/framer-motion/dist/es/events/add-dom-event.mjs +6 -0
- package/dist/es/framer-motion/dist/es/events/add-pointer-event.mjs +8 -0
- package/dist/es/framer-motion/dist/es/events/event-info.mjs +15 -0
- package/dist/es/framer-motion/dist/es/events/use-dom-event.mjs +34 -0
- package/dist/es/framer-motion/dist/es/events/utils/is-primary-pointer.mjs +18 -0
- package/dist/es/framer-motion/dist/es/frameloop/batcher.mjs +74 -0
- package/dist/es/framer-motion/dist/es/frameloop/frame.mjs +6 -0
- package/dist/es/framer-motion/dist/es/frameloop/index-legacy.mjs +20 -0
- package/dist/es/framer-motion/dist/es/frameloop/microtask.mjs +5 -0
- package/dist/es/framer-motion/dist/es/frameloop/render-step.mjs +80 -0
- package/dist/es/framer-motion/dist/es/frameloop/sync-time.mjs +31 -0
- package/dist/es/framer-motion/dist/es/gestures/drag/VisualElementDragControls.mjs +487 -0
- package/dist/es/framer-motion/dist/es/gestures/drag/index.mjs +27 -0
- package/dist/es/framer-motion/dist/es/gestures/drag/use-drag-controls.mjs +88 -0
- package/dist/es/framer-motion/dist/es/gestures/drag/utils/constraints.mjs +129 -0
- package/dist/es/framer-motion/dist/es/gestures/drag/utils/lock.mjs +53 -0
- package/dist/es/framer-motion/dist/es/gestures/focus.mjs +41 -0
- package/dist/es/framer-motion/dist/es/gestures/hover.mjs +33 -0
- package/dist/es/framer-motion/dist/es/gestures/pan/PanSession.mjs +156 -0
- package/dist/es/framer-motion/dist/es/gestures/pan/index.mjs +50 -0
- package/dist/es/framer-motion/dist/es/gestures/press.mjs +130 -0
- package/dist/es/framer-motion/dist/es/gestures/utils/is-node-or-child.mjs +20 -0
- package/dist/es/framer-motion/dist/es/motion/features/Feature.mjs +9 -0
- package/dist/es/framer-motion/dist/es/motion/features/animation/exit.mjs +31 -0
- package/dist/es/framer-motion/dist/es/motion/features/animation/index.mjs +41 -0
- package/dist/es/framer-motion/dist/es/motion/features/animations.mjs +13 -0
- package/dist/es/framer-motion/dist/es/motion/features/definitions.mjs +28 -0
- package/dist/es/framer-motion/dist/es/motion/features/drag.mjs +17 -0
- package/dist/es/framer-motion/dist/es/motion/features/gestures.mjs +21 -0
- package/dist/es/framer-motion/dist/es/motion/features/layout/MeasureLayout.mjs +134 -0
- package/dist/es/framer-motion/dist/es/motion/features/layout.mjs +11 -0
- package/dist/es/framer-motion/dist/es/motion/features/load-features.mjs +12 -0
- package/dist/es/framer-motion/dist/es/motion/features/viewport/index.mjs +72 -0
- package/dist/es/framer-motion/dist/es/motion/features/viewport/observers.mjs +49 -0
- package/dist/es/framer-motion/dist/es/motion/index.mjs +98 -0
- package/dist/es/framer-motion/dist/es/motion/utils/is-forced-motion-value.mjs +11 -0
- package/dist/es/framer-motion/dist/es/motion/utils/is-motion-component.mjs +12 -0
- package/dist/es/framer-motion/dist/es/motion/utils/symbol.mjs +3 -0
- package/dist/es/framer-motion/dist/es/motion/utils/unwrap-motion-component.mjs +17 -0
- package/dist/es/framer-motion/dist/es/motion/utils/use-motion-ref.mjs +36 -0
- package/dist/es/framer-motion/dist/es/motion/utils/use-visual-element.mjs +134 -0
- package/dist/es/framer-motion/dist/es/motion/utils/use-visual-state.mjs +82 -0
- package/dist/es/framer-motion/dist/es/motion/utils/valid-prop.mjs +57 -0
- package/dist/es/framer-motion/dist/es/projection/animation/mix-values.mjs +93 -0
- package/dist/es/framer-motion/dist/es/projection/geometry/conversion.mjs +33 -0
- package/dist/es/framer-motion/dist/es/projection/geometry/copy.mjs +31 -0
- package/dist/es/framer-motion/dist/es/projection/geometry/delta-apply.mjs +119 -0
- package/dist/es/framer-motion/dist/es/projection/geometry/delta-calc.mjs +52 -0
- package/dist/es/framer-motion/dist/es/projection/geometry/delta-remove.mjs +54 -0
- package/dist/es/framer-motion/dist/es/projection/geometry/models.mjs +17 -0
- package/dist/es/framer-motion/dist/es/projection/geometry/utils.mjs +31 -0
- package/dist/es/framer-motion/dist/es/projection/node/DocumentProjectionNode.mjs +13 -0
- package/dist/es/framer-motion/dist/es/projection/node/HTMLProjectionNode.mjs +27 -0
- package/dist/es/framer-motion/dist/es/projection/node/create-projection-node.mjs +1583 -0
- package/dist/es/framer-motion/dist/es/projection/node/group.mjs +24 -0
- package/dist/es/framer-motion/dist/es/projection/node/state.mjs +19 -0
- package/dist/es/framer-motion/dist/es/projection/shared/stack.mjs +112 -0
- package/dist/es/framer-motion/dist/es/projection/styles/scale-border-radius.mjs +41 -0
- package/dist/es/framer-motion/dist/es/projection/styles/scale-box-shadow.mjs +35 -0
- package/dist/es/framer-motion/dist/es/projection/styles/scale-correction.mjs +6 -0
- package/dist/es/framer-motion/dist/es/projection/styles/transform.mjs +49 -0
- package/dist/es/framer-motion/dist/es/projection/use-instant-layout-transition.mjs +14 -0
- package/dist/es/framer-motion/dist/es/projection/use-reset-projection.mjs +14 -0
- package/dist/es/framer-motion/dist/es/projection/utils/each-axis.mjs +5 -0
- package/dist/es/framer-motion/dist/es/projection/utils/has-transform.mjs +26 -0
- package/dist/es/framer-motion/dist/es/projection/utils/measure.mjs +17 -0
- package/dist/es/framer-motion/dist/es/render/VisualElement.mjs +477 -0
- package/dist/es/framer-motion/dist/es/render/components/create-factory.mjs +23 -0
- package/dist/es/framer-motion/dist/es/render/components/create-proxy.mjs +38 -0
- package/dist/es/framer-motion/dist/es/render/components/m/create.mjs +6 -0
- package/dist/es/framer-motion/dist/es/render/components/m/elements.mjs +227 -0
- package/dist/es/framer-motion/dist/es/render/components/m/proxy.mjs +6 -0
- package/dist/es/framer-motion/dist/es/render/components/motion/create.mjs +15 -0
- package/dist/es/framer-motion/dist/es/render/components/motion/elements.mjs +194 -0
- package/dist/es/framer-motion/dist/es/render/components/motion/proxy.mjs +6 -0
- package/dist/es/framer-motion/dist/es/render/dom/DOMKeyframesResolver.mjs +130 -0
- package/dist/es/framer-motion/dist/es/render/dom/DOMVisualElement.mjs +28 -0
- package/dist/es/framer-motion/dist/es/render/dom/create-visual-element.mjs +14 -0
- package/dist/es/framer-motion/dist/es/render/dom/features-animation.mjs +14 -0
- package/dist/es/framer-motion/dist/es/render/dom/features-max.mjs +14 -0
- package/dist/es/framer-motion/dist/es/render/dom/features-min.mjs +12 -0
- package/dist/es/framer-motion/dist/es/render/dom/resize/handle-element.mjs +64 -0
- package/dist/es/framer-motion/dist/es/render/dom/resize/handle-window.mjs +30 -0
- package/dist/es/framer-motion/dist/es/render/dom/resize/index.mjs +8 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/index.mjs +80 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/info.mjs +56 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/observe.mjs +18 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/edge.mjs +45 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/index.mjs +59 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/inset.mjs +45 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/offset.mjs +35 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/presets.mjs +20 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/on-scroll-handler.mjs +48 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/supports.mjs +5 -0
- package/dist/es/framer-motion/dist/es/render/dom/scroll/track.mjs +84 -0
- package/dist/es/framer-motion/dist/es/render/dom/use-render.mjs +33 -0
- package/dist/es/framer-motion/dist/es/render/dom/utils/camel-to-dash.mjs +6 -0
- package/dist/es/framer-motion/dist/es/render/dom/utils/css-variables-conversion.mjs +42 -0
- package/dist/es/framer-motion/dist/es/render/dom/utils/filter-props.mjs +59 -0
- package/dist/es/framer-motion/dist/es/render/dom/utils/is-css-variable.mjs +15 -0
- package/dist/es/framer-motion/dist/es/render/dom/utils/is-svg-component.mjs +30 -0
- package/dist/es/framer-motion/dist/es/render/dom/utils/is-svg-element.mjs +5 -0
- package/dist/es/framer-motion/dist/es/render/dom/utils/resolve-element.mjs +28 -0
- package/dist/es/framer-motion/dist/es/render/dom/utils/unit-conversion.mjs +65 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/animatable-none.mjs +15 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/defaults.mjs +30 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/dimensions.mjs +15 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/find.mjs +15 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/get-as-type.mjs +10 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/number-browser.mjs +41 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/number.mjs +18 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/test.mjs +6 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/transform.mjs +31 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/type-auto.mjs +9 -0
- package/dist/es/framer-motion/dist/es/render/dom/value-types/type-int.mjs +8 -0
- package/dist/es/framer-motion/dist/es/render/dom/viewport/index.mjs +43 -0
- package/dist/es/framer-motion/dist/es/render/html/HTMLVisualElement.mjs +57 -0
- package/dist/es/framer-motion/dist/es/render/html/config-motion.mjs +12 -0
- package/dist/es/framer-motion/dist/es/render/html/use-props.mjs +57 -0
- package/dist/es/framer-motion/dist/es/render/html/utils/build-styles.mjs +65 -0
- package/dist/es/framer-motion/dist/es/render/html/utils/build-transform.mjs +62 -0
- package/dist/es/framer-motion/dist/es/render/html/utils/create-render-state.mjs +8 -0
- package/dist/es/framer-motion/dist/es/render/html/utils/make-none-animatable.mjs +30 -0
- package/dist/es/framer-motion/dist/es/render/html/utils/render.mjs +9 -0
- package/dist/es/framer-motion/dist/es/render/html/utils/scrape-motion-values.mjs +20 -0
- package/dist/es/framer-motion/dist/es/render/html/utils/transform.mjs +28 -0
- package/dist/es/framer-motion/dist/es/render/object/ObjectVisualElement.mjs +41 -0
- package/dist/es/framer-motion/dist/es/render/store.mjs +3 -0
- package/dist/es/framer-motion/dist/es/render/svg/SVGVisualElement.mjs +45 -0
- package/dist/es/framer-motion/dist/es/render/svg/config-motion.mjs +40 -0
- package/dist/es/framer-motion/dist/es/render/svg/lowercase-elements.mjs +33 -0
- package/dist/es/framer-motion/dist/es/render/svg/use-props.mjs +24 -0
- package/dist/es/framer-motion/dist/es/render/svg/utils/build-attrs.mjs +52 -0
- package/dist/es/framer-motion/dist/es/render/svg/utils/camel-case-attrs.mjs +30 -0
- package/dist/es/framer-motion/dist/es/render/svg/utils/create-render-state.mjs +8 -0
- package/dist/es/framer-motion/dist/es/render/svg/utils/is-svg-tag.mjs +3 -0
- package/dist/es/framer-motion/dist/es/render/svg/utils/path.mjs +32 -0
- package/dist/es/framer-motion/dist/es/render/svg/utils/render.mjs +12 -0
- package/dist/es/framer-motion/dist/es/render/svg/utils/scrape-motion-values.mjs +19 -0
- package/dist/es/framer-motion/dist/es/render/svg/utils/transform-origin.mjs +18 -0
- package/dist/es/framer-motion/dist/es/render/utils/KeyframesResolver.mjs +164 -0
- package/dist/es/framer-motion/dist/es/render/utils/animation-state.mjs +332 -0
- package/dist/es/framer-motion/dist/es/render/utils/compare-by-depth.mjs +3 -0
- package/dist/es/framer-motion/dist/es/render/utils/flat-tree.mjs +24 -0
- package/dist/es/framer-motion/dist/es/render/utils/get-variant-context.mjs +28 -0
- package/dist/es/framer-motion/dist/es/render/utils/is-controlling-variants.mjs +13 -0
- package/dist/es/framer-motion/dist/es/render/utils/is-variant-label.mjs +8 -0
- package/dist/es/framer-motion/dist/es/render/utils/motion-values.mjs +59 -0
- package/dist/es/framer-motion/dist/es/render/utils/resolve-dynamic-variants.mjs +8 -0
- package/dist/es/framer-motion/dist/es/render/utils/resolve-variants.mjs +36 -0
- package/dist/es/framer-motion/dist/es/render/utils/setters.mjs +27 -0
- package/dist/es/framer-motion/dist/es/render/utils/variant-props.mjs +12 -0
- package/dist/es/framer-motion/dist/es/utils/GlobalConfig.mjs +6 -0
- package/dist/es/framer-motion/dist/es/utils/array.mjs +21 -0
- package/dist/es/framer-motion/dist/es/utils/clamp.mjs +9 -0
- package/dist/es/framer-motion/dist/es/utils/delay.mjs +24 -0
- package/dist/es/framer-motion/dist/es/utils/distance.mjs +9 -0
- package/dist/es/framer-motion/dist/es/utils/errors.mjs +18 -0
- package/dist/es/framer-motion/dist/es/utils/get-context-window.mjs +6 -0
- package/dist/es/framer-motion/dist/es/utils/hsla-to-rgba.mjs +42 -0
- package/dist/es/framer-motion/dist/es/utils/interpolate.mjs +75 -0
- package/dist/es/framer-motion/dist/es/utils/is-browser.mjs +3 -0
- package/dist/es/framer-motion/dist/es/utils/is-numerical-string.mjs +6 -0
- package/dist/es/framer-motion/dist/es/utils/is-ref-object.mjs +7 -0
- package/dist/es/framer-motion/dist/es/utils/is-zero-value-string.mjs +6 -0
- package/dist/es/framer-motion/dist/es/utils/memo.mjs +10 -0
- package/dist/es/framer-motion/dist/es/utils/mix/color.mjs +47 -0
- package/dist/es/framer-motion/dist/es/utils/mix/complex.mjs +94 -0
- package/dist/es/framer-motion/dist/es/utils/mix/immediate.mjs +5 -0
- package/dist/es/framer-motion/dist/es/utils/mix/index.mjs +14 -0
- package/dist/es/framer-motion/dist/es/utils/mix/number.mjs +26 -0
- package/dist/es/framer-motion/dist/es/utils/mix/visibility.mjs +16 -0
- package/dist/es/framer-motion/dist/es/utils/noop.mjs +3 -0
- package/dist/es/framer-motion/dist/es/utils/offsets/default.mjs +9 -0
- package/dist/es/framer-motion/dist/es/utils/offsets/fill.mjs +12 -0
- package/dist/es/framer-motion/dist/es/utils/offsets/time.mjs +5 -0
- package/dist/es/framer-motion/dist/es/utils/pipe.mjs +11 -0
- package/dist/es/framer-motion/dist/es/utils/progress.mjs +18 -0
- package/dist/es/framer-motion/dist/es/utils/reduced-motion/index.mjs +19 -0
- package/dist/es/framer-motion/dist/es/utils/reduced-motion/state.mjs +5 -0
- package/dist/es/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion-config.mjs +19 -0
- package/dist/es/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.mjs +47 -0
- package/dist/es/framer-motion/dist/es/utils/resolve-value.mjs +11 -0
- package/dist/es/framer-motion/dist/es/utils/shallow-compare.mjs +14 -0
- package/dist/es/framer-motion/dist/es/utils/subscription-manager.mjs +40 -0
- package/dist/es/framer-motion/dist/es/utils/time-conversion.mjs +10 -0
- package/dist/es/framer-motion/dist/es/utils/transform.mjs +21 -0
- package/dist/es/framer-motion/dist/es/utils/use-animation-frame.mjs +21 -0
- package/dist/es/framer-motion/dist/es/utils/use-constant.mjs +18 -0
- package/dist/es/framer-motion/dist/es/utils/use-cycle.mjs +47 -0
- package/dist/es/framer-motion/dist/es/utils/use-force-update.mjs +19 -0
- package/dist/es/framer-motion/dist/es/utils/use-in-view.mjs +23 -0
- package/dist/es/framer-motion/dist/es/utils/use-instant-transition-state.mjs +5 -0
- package/dist/es/framer-motion/dist/es/utils/use-instant-transition.mjs +41 -0
- package/dist/es/framer-motion/dist/es/utils/use-is-mounted.mjs +15 -0
- package/dist/es/framer-motion/dist/es/utils/use-isomorphic-effect.mjs +6 -0
- package/dist/es/framer-motion/dist/es/utils/use-motion-value-event.mjs +13 -0
- package/dist/es/framer-motion/dist/es/utils/use-unmount-effect.mjs +7 -0
- package/dist/es/framer-motion/dist/es/utils/velocity-per-second.mjs +11 -0
- package/dist/es/framer-motion/dist/es/utils/warn-once.mjs +11 -0
- package/dist/es/framer-motion/dist/es/utils/wrap.mjs +6 -0
- package/dist/es/framer-motion/dist/es/value/index.mjs +319 -0
- package/dist/es/framer-motion/dist/es/value/scroll/use-element-scroll.mjs +14 -0
- package/dist/es/framer-motion/dist/es/value/scroll/use-viewport-scroll.mjs +14 -0
- package/dist/es/framer-motion/dist/es/value/types/color/hex.mjs +40 -0
- package/dist/es/framer-motion/dist/es/value/types/color/hsla.mjs +22 -0
- package/dist/es/framer-motion/dist/es/value/types/color/index.mjs +27 -0
- package/dist/es/framer-motion/dist/es/value/types/color/rgba.mjs +25 -0
- package/dist/es/framer-motion/dist/es/value/types/color/utils.mjs +29 -0
- package/dist/es/framer-motion/dist/es/value/types/complex/filter.mjs +30 -0
- package/dist/es/framer-motion/dist/es/value/types/complex/index.mjs +92 -0
- package/dist/es/framer-motion/dist/es/value/types/numbers/index.mjs +17 -0
- package/dist/es/framer-motion/dist/es/value/types/numbers/units.mjs +17 -0
- package/dist/es/framer-motion/dist/es/value/types/utils/color-regex.mjs +3 -0
- package/dist/es/framer-motion/dist/es/value/types/utils/float-regex.mjs +3 -0
- package/dist/es/framer-motion/dist/es/value/types/utils/is-nullish.mjs +5 -0
- package/dist/es/framer-motion/dist/es/value/types/utils/sanitize.mjs +5 -0
- package/dist/es/framer-motion/dist/es/value/types/utils/single-color-regex.mjs +3 -0
- package/dist/es/framer-motion/dist/es/value/use-combine-values.mjs +37 -0
- package/dist/es/framer-motion/dist/es/value/use-computed.mjs +19 -0
- package/dist/es/framer-motion/dist/es/value/use-inverted-scale.mjs +52 -0
- package/dist/es/framer-motion/dist/es/value/use-motion-template.mjs +45 -0
- package/dist/es/framer-motion/dist/es/value/use-motion-value.mjs +38 -0
- package/dist/es/framer-motion/dist/es/value/use-scroll.mjs +39 -0
- package/dist/es/framer-motion/dist/es/value/use-spring.mjs +85 -0
- package/dist/es/framer-motion/dist/es/value/use-time.mjs +10 -0
- package/dist/es/framer-motion/dist/es/value/use-transform.mjs +29 -0
- package/dist/es/framer-motion/dist/es/value/use-velocity.mjs +35 -0
- package/dist/es/framer-motion/dist/es/value/use-will-change/WillChangeMotionValue.mjs +22 -0
- package/dist/es/framer-motion/dist/es/value/use-will-change/add-will-change.mjs +14 -0
- package/dist/es/framer-motion/dist/es/value/use-will-change/get-will-change-name.mjs +14 -0
- package/dist/es/framer-motion/dist/es/value/use-will-change/index.mjs +8 -0
- package/dist/es/framer-motion/dist/es/value/use-will-change/is.mjs +7 -0
- package/dist/es/framer-motion/dist/es/value/utils/is-motion-value.mjs +3 -0
- package/dist/es/framer-motion/dist/es/value/utils/resolve-motion-value.mjs +16 -0
- package/dist/es/motion/lib/index.mjs +30 -0
- package/dist/es/motion/lib/react-client.mjs +3 -0
- package/dist/es/motion/lib/react-m.mjs +3 -0
- package/dist/es/motion/lib/react.mjs +110 -0
- package/dist/index.d.ts +1 -0
- package/dist/motion.dev.js +6121 -0
- package/dist/motion.js +1 -0
- package/dist/react-client.d.ts +1 -0
- package/dist/react-m.d.ts +1 -0
- package/dist/react.d.ts +1 -0
- package/lib/index.js +1 -3
- package/lib/index.js.map +1 -1
- package/lib/react-client.js +3 -0
- package/lib/react-client.js.map +1 -0
- package/lib/react-m.js +3 -0
- package/lib/react-m.js.map +1 -0
- package/lib/react.js +3 -0
- package/lib/react.js.map +1 -0
- package/package.json +79 -29
- package/react/package.json +6 -0
- package/react-client/package.json +6 -0
- package/react-m/package.json +6 -0
- package/rollup.config.mjs +184 -0
- package/src/index.ts +1 -0
- package/src/react-client.ts +3 -0
- package/src/react-m.ts +3 -0
- package/src/react.ts +3 -0
- package/tsconfig.json +25 -0
- package/types/index.d.ts +1 -4
- package/types/react-client.d.ts +1 -0
- package/types/react-m.d.ts +1 -0
- package/types/react.d.ts +1 -0
- package/CHANGELOG.md +0 -378
- package/dist/animate.cjs.js +0 -22
- package/dist/animate.es.js +0 -19
- package/dist/main.cjs.js +0 -21
- package/dist/main.es.js +0 -3
- package/dist/motion.min.js +0 -1
- package/dist/motion.umd.js +0 -2364
- package/dist/size-index.js +0 -1
- package/lib/animate.js +0 -17
- package/lib/animate.js.map +0 -1
- package/types/animate.d.ts +0 -6
- package/types/animate.d.ts.map +0 -1
- package/types/index.d.ts.map +0 -1
|
@@ -0,0 +1,477 @@
|
|
|
1
|
+
import { initPrefersReducedMotion } from '../utils/reduced-motion/index.mjs';
|
|
2
|
+
import { hasReducedMotionListener, prefersReducedMotion } from '../utils/reduced-motion/state.mjs';
|
|
3
|
+
import { SubscriptionManager } from '../utils/subscription-manager.mjs';
|
|
4
|
+
import { motionValue } from '../value/index.mjs';
|
|
5
|
+
import { isMotionValue } from '../value/utils/is-motion-value.mjs';
|
|
6
|
+
import { transformProps } from './html/utils/transform.mjs';
|
|
7
|
+
import { isControllingVariants, isVariantNode } from './utils/is-controlling-variants.mjs';
|
|
8
|
+
import { updateMotionValuesFromProps } from './utils/motion-values.mjs';
|
|
9
|
+
import { resolveVariantFromProps } from './utils/resolve-variants.mjs';
|
|
10
|
+
import { warnOnce } from '../utils/warn-once.mjs';
|
|
11
|
+
import { featureDefinitions } from '../motion/features/definitions.mjs';
|
|
12
|
+
import { visualElementStore } from './store.mjs';
|
|
13
|
+
import { KeyframeResolver } from './utils/KeyframesResolver.mjs';
|
|
14
|
+
import { isNumericalString } from '../utils/is-numerical-string.mjs';
|
|
15
|
+
import { isZeroValueString } from '../utils/is-zero-value-string.mjs';
|
|
16
|
+
import { findValueType } from './dom/value-types/find.mjs';
|
|
17
|
+
import { complex } from '../value/types/complex/index.mjs';
|
|
18
|
+
import { getAnimatableNone } from './dom/value-types/animatable-none.mjs';
|
|
19
|
+
import { createBox } from '../projection/geometry/models.mjs';
|
|
20
|
+
import { time } from '../frameloop/sync-time.mjs';
|
|
21
|
+
import { frame, cancelFrame } from '../frameloop/frame.mjs';
|
|
22
|
+
|
|
23
|
+
const propEventHandlers = [
|
|
24
|
+
"AnimationStart",
|
|
25
|
+
"AnimationComplete",
|
|
26
|
+
"Update",
|
|
27
|
+
"BeforeLayoutMeasure",
|
|
28
|
+
"LayoutMeasure",
|
|
29
|
+
"LayoutAnimationStart",
|
|
30
|
+
"LayoutAnimationComplete",
|
|
31
|
+
];
|
|
32
|
+
/**
|
|
33
|
+
* A VisualElement is an imperative abstraction around UI elements such as
|
|
34
|
+
* HTMLElement, SVGElement, Three.Object3D etc.
|
|
35
|
+
*/
|
|
36
|
+
class VisualElement {
|
|
37
|
+
/**
|
|
38
|
+
* This method takes React props and returns found MotionValues. For example, HTML
|
|
39
|
+
* MotionValues will be found within the style prop, whereas for Three.js within attribute arrays.
|
|
40
|
+
*
|
|
41
|
+
* This isn't an abstract method as it needs calling in the constructor, but it is
|
|
42
|
+
* intended to be one.
|
|
43
|
+
*/
|
|
44
|
+
scrapeMotionValuesFromProps(_props, _prevProps, _visualElement) {
|
|
45
|
+
return {};
|
|
46
|
+
}
|
|
47
|
+
constructor({ parent, props, presenceContext, reducedMotionConfig, blockInitialAnimation, visualState, }, options = {}) {
|
|
48
|
+
/**
|
|
49
|
+
* A reference to the current underlying Instance, e.g. a HTMLElement
|
|
50
|
+
* or Three.Mesh etc.
|
|
51
|
+
*/
|
|
52
|
+
this.current = null;
|
|
53
|
+
/**
|
|
54
|
+
* A set containing references to this VisualElement's children.
|
|
55
|
+
*/
|
|
56
|
+
this.children = new Set();
|
|
57
|
+
/**
|
|
58
|
+
* Determine what role this visual element should take in the variant tree.
|
|
59
|
+
*/
|
|
60
|
+
this.isVariantNode = false;
|
|
61
|
+
this.isControllingVariants = false;
|
|
62
|
+
/**
|
|
63
|
+
* Decides whether this VisualElement should animate in reduced motion
|
|
64
|
+
* mode.
|
|
65
|
+
*
|
|
66
|
+
* TODO: This is currently set on every individual VisualElement but feels
|
|
67
|
+
* like it could be set globally.
|
|
68
|
+
*/
|
|
69
|
+
this.shouldReduceMotion = null;
|
|
70
|
+
/**
|
|
71
|
+
* A map of all motion values attached to this visual element. Motion
|
|
72
|
+
* values are source of truth for any given animated value. A motion
|
|
73
|
+
* value might be provided externally by the component via props.
|
|
74
|
+
*/
|
|
75
|
+
this.values = new Map();
|
|
76
|
+
this.KeyframeResolver = KeyframeResolver;
|
|
77
|
+
/**
|
|
78
|
+
* Cleanup functions for active features (hover/tap/exit etc)
|
|
79
|
+
*/
|
|
80
|
+
this.features = {};
|
|
81
|
+
/**
|
|
82
|
+
* A map of every subscription that binds the provided or generated
|
|
83
|
+
* motion values onChange listeners to this visual element.
|
|
84
|
+
*/
|
|
85
|
+
this.valueSubscriptions = new Map();
|
|
86
|
+
/**
|
|
87
|
+
* A reference to the previously-provided motion values as returned
|
|
88
|
+
* from scrapeMotionValuesFromProps. We use the keys in here to determine
|
|
89
|
+
* if any motion values need to be removed after props are updated.
|
|
90
|
+
*/
|
|
91
|
+
this.prevMotionValues = {};
|
|
92
|
+
/**
|
|
93
|
+
* An object containing a SubscriptionManager for each active event.
|
|
94
|
+
*/
|
|
95
|
+
this.events = {};
|
|
96
|
+
/**
|
|
97
|
+
* An object containing an unsubscribe function for each prop event subscription.
|
|
98
|
+
* For example, every "Update" event can have multiple subscribers via
|
|
99
|
+
* VisualElement.on(), but only one of those can be defined via the onUpdate prop.
|
|
100
|
+
*/
|
|
101
|
+
this.propEventSubscriptions = {};
|
|
102
|
+
this.notifyUpdate = () => this.notify("Update", this.latestValues);
|
|
103
|
+
this.render = () => {
|
|
104
|
+
if (!this.current)
|
|
105
|
+
return;
|
|
106
|
+
this.triggerBuild();
|
|
107
|
+
this.renderInstance(this.current, this.renderState, this.props.style, this.projection);
|
|
108
|
+
};
|
|
109
|
+
this.renderScheduledAt = 0.0;
|
|
110
|
+
this.scheduleRender = () => {
|
|
111
|
+
const now = time.now();
|
|
112
|
+
if (this.renderScheduledAt < now) {
|
|
113
|
+
this.renderScheduledAt = now;
|
|
114
|
+
frame.render(this.render, false, true);
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
const { latestValues, renderState } = visualState;
|
|
118
|
+
this.latestValues = latestValues;
|
|
119
|
+
this.baseTarget = { ...latestValues };
|
|
120
|
+
this.initialValues = props.initial ? { ...latestValues } : {};
|
|
121
|
+
this.renderState = renderState;
|
|
122
|
+
this.parent = parent;
|
|
123
|
+
this.props = props;
|
|
124
|
+
this.presenceContext = presenceContext;
|
|
125
|
+
this.depth = parent ? parent.depth + 1 : 0;
|
|
126
|
+
this.reducedMotionConfig = reducedMotionConfig;
|
|
127
|
+
this.options = options;
|
|
128
|
+
this.blockInitialAnimation = Boolean(blockInitialAnimation);
|
|
129
|
+
this.isControllingVariants = isControllingVariants(props);
|
|
130
|
+
this.isVariantNode = isVariantNode(props);
|
|
131
|
+
if (this.isVariantNode) {
|
|
132
|
+
this.variantChildren = new Set();
|
|
133
|
+
}
|
|
134
|
+
this.manuallyAnimateOnMount = Boolean(parent && parent.current);
|
|
135
|
+
/**
|
|
136
|
+
* Any motion values that are provided to the element when created
|
|
137
|
+
* aren't yet bound to the element, as this would technically be impure.
|
|
138
|
+
* However, we iterate through the motion values and set them to the
|
|
139
|
+
* initial values for this component.
|
|
140
|
+
*
|
|
141
|
+
* TODO: This is impure and we should look at changing this to run on mount.
|
|
142
|
+
* Doing so will break some tests but this isn't necessarily a breaking change,
|
|
143
|
+
* more a reflection of the test.
|
|
144
|
+
*/
|
|
145
|
+
const { willChange, ...initialMotionValues } = this.scrapeMotionValuesFromProps(props, {}, this);
|
|
146
|
+
for (const key in initialMotionValues) {
|
|
147
|
+
const value = initialMotionValues[key];
|
|
148
|
+
if (latestValues[key] !== undefined && isMotionValue(value)) {
|
|
149
|
+
value.set(latestValues[key], false);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
mount(instance) {
|
|
154
|
+
this.current = instance;
|
|
155
|
+
visualElementStore.set(instance, this);
|
|
156
|
+
if (this.projection && !this.projection.instance) {
|
|
157
|
+
this.projection.mount(instance);
|
|
158
|
+
}
|
|
159
|
+
if (this.parent && this.isVariantNode && !this.isControllingVariants) {
|
|
160
|
+
this.removeFromVariantTree = this.parent.addVariantChild(this);
|
|
161
|
+
}
|
|
162
|
+
this.values.forEach((value, key) => this.bindToMotionValue(key, value));
|
|
163
|
+
if (!hasReducedMotionListener.current) {
|
|
164
|
+
initPrefersReducedMotion();
|
|
165
|
+
}
|
|
166
|
+
this.shouldReduceMotion =
|
|
167
|
+
this.reducedMotionConfig === "never"
|
|
168
|
+
? false
|
|
169
|
+
: this.reducedMotionConfig === "always"
|
|
170
|
+
? true
|
|
171
|
+
: prefersReducedMotion.current;
|
|
172
|
+
if (process.env.NODE_ENV !== "production") {
|
|
173
|
+
warnOnce(this.shouldReduceMotion !== true, "You have Reduced Motion enabled on your device. Animations may not appear as expected.");
|
|
174
|
+
}
|
|
175
|
+
if (this.parent)
|
|
176
|
+
this.parent.children.add(this);
|
|
177
|
+
this.update(this.props, this.presenceContext);
|
|
178
|
+
}
|
|
179
|
+
unmount() {
|
|
180
|
+
visualElementStore.delete(this.current);
|
|
181
|
+
this.projection && this.projection.unmount();
|
|
182
|
+
cancelFrame(this.notifyUpdate);
|
|
183
|
+
cancelFrame(this.render);
|
|
184
|
+
this.valueSubscriptions.forEach((remove) => remove());
|
|
185
|
+
this.valueSubscriptions.clear();
|
|
186
|
+
this.removeFromVariantTree && this.removeFromVariantTree();
|
|
187
|
+
this.parent && this.parent.children.delete(this);
|
|
188
|
+
for (const key in this.events) {
|
|
189
|
+
this.events[key].clear();
|
|
190
|
+
}
|
|
191
|
+
for (const key in this.features) {
|
|
192
|
+
const feature = this.features[key];
|
|
193
|
+
if (feature) {
|
|
194
|
+
feature.unmount();
|
|
195
|
+
feature.isMounted = false;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
this.current = null;
|
|
199
|
+
}
|
|
200
|
+
bindToMotionValue(key, value) {
|
|
201
|
+
if (this.valueSubscriptions.has(key)) {
|
|
202
|
+
this.valueSubscriptions.get(key)();
|
|
203
|
+
}
|
|
204
|
+
const valueIsTransform = transformProps.has(key);
|
|
205
|
+
const removeOnChange = value.on("change", (latestValue) => {
|
|
206
|
+
this.latestValues[key] = latestValue;
|
|
207
|
+
this.props.onUpdate && frame.preRender(this.notifyUpdate);
|
|
208
|
+
if (valueIsTransform && this.projection) {
|
|
209
|
+
this.projection.isTransformDirty = true;
|
|
210
|
+
}
|
|
211
|
+
});
|
|
212
|
+
const removeOnRenderRequest = value.on("renderRequest", this.scheduleRender);
|
|
213
|
+
let removeSyncCheck;
|
|
214
|
+
if (window.MotionCheckAppearSync) {
|
|
215
|
+
removeSyncCheck = window.MotionCheckAppearSync(this, key, value);
|
|
216
|
+
}
|
|
217
|
+
this.valueSubscriptions.set(key, () => {
|
|
218
|
+
removeOnChange();
|
|
219
|
+
removeOnRenderRequest();
|
|
220
|
+
if (removeSyncCheck)
|
|
221
|
+
removeSyncCheck();
|
|
222
|
+
if (value.owner)
|
|
223
|
+
value.stop();
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
sortNodePosition(other) {
|
|
227
|
+
/**
|
|
228
|
+
* If these nodes aren't even of the same type we can't compare their depth.
|
|
229
|
+
*/
|
|
230
|
+
if (!this.current ||
|
|
231
|
+
!this.sortInstanceNodePosition ||
|
|
232
|
+
this.type !== other.type) {
|
|
233
|
+
return 0;
|
|
234
|
+
}
|
|
235
|
+
return this.sortInstanceNodePosition(this.current, other.current);
|
|
236
|
+
}
|
|
237
|
+
updateFeatures() {
|
|
238
|
+
let key = "animation";
|
|
239
|
+
for (key in featureDefinitions) {
|
|
240
|
+
const featureDefinition = featureDefinitions[key];
|
|
241
|
+
if (!featureDefinition)
|
|
242
|
+
continue;
|
|
243
|
+
const { isEnabled, Feature: FeatureConstructor } = featureDefinition;
|
|
244
|
+
/**
|
|
245
|
+
* If this feature is enabled but not active, make a new instance.
|
|
246
|
+
*/
|
|
247
|
+
if (!this.features[key] &&
|
|
248
|
+
FeatureConstructor &&
|
|
249
|
+
isEnabled(this.props)) {
|
|
250
|
+
this.features[key] = new FeatureConstructor(this);
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* If we have a feature, mount or update it.
|
|
254
|
+
*/
|
|
255
|
+
if (this.features[key]) {
|
|
256
|
+
const feature = this.features[key];
|
|
257
|
+
if (feature.isMounted) {
|
|
258
|
+
feature.update();
|
|
259
|
+
}
|
|
260
|
+
else {
|
|
261
|
+
feature.mount();
|
|
262
|
+
feature.isMounted = true;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
triggerBuild() {
|
|
268
|
+
this.build(this.renderState, this.latestValues, this.props);
|
|
269
|
+
}
|
|
270
|
+
/**
|
|
271
|
+
* Measure the current viewport box with or without transforms.
|
|
272
|
+
* Only measures axis-aligned boxes, rotate and skew must be manually
|
|
273
|
+
* removed with a re-render to work.
|
|
274
|
+
*/
|
|
275
|
+
measureViewportBox() {
|
|
276
|
+
return this.current
|
|
277
|
+
? this.measureInstanceViewportBox(this.current, this.props)
|
|
278
|
+
: createBox();
|
|
279
|
+
}
|
|
280
|
+
getStaticValue(key) {
|
|
281
|
+
return this.latestValues[key];
|
|
282
|
+
}
|
|
283
|
+
setStaticValue(key, value) {
|
|
284
|
+
this.latestValues[key] = value;
|
|
285
|
+
}
|
|
286
|
+
/**
|
|
287
|
+
* Update the provided props. Ensure any newly-added motion values are
|
|
288
|
+
* added to our map, old ones removed, and listeners updated.
|
|
289
|
+
*/
|
|
290
|
+
update(props, presenceContext) {
|
|
291
|
+
if (props.transformTemplate || this.props.transformTemplate) {
|
|
292
|
+
this.scheduleRender();
|
|
293
|
+
}
|
|
294
|
+
this.prevProps = this.props;
|
|
295
|
+
this.props = props;
|
|
296
|
+
this.prevPresenceContext = this.presenceContext;
|
|
297
|
+
this.presenceContext = presenceContext;
|
|
298
|
+
/**
|
|
299
|
+
* Update prop event handlers ie onAnimationStart, onAnimationComplete
|
|
300
|
+
*/
|
|
301
|
+
for (let i = 0; i < propEventHandlers.length; i++) {
|
|
302
|
+
const key = propEventHandlers[i];
|
|
303
|
+
if (this.propEventSubscriptions[key]) {
|
|
304
|
+
this.propEventSubscriptions[key]();
|
|
305
|
+
delete this.propEventSubscriptions[key];
|
|
306
|
+
}
|
|
307
|
+
const listenerName = ("on" + key);
|
|
308
|
+
const listener = props[listenerName];
|
|
309
|
+
if (listener) {
|
|
310
|
+
this.propEventSubscriptions[key] = this.on(key, listener);
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
this.prevMotionValues = updateMotionValuesFromProps(this, this.scrapeMotionValuesFromProps(props, this.prevProps, this), this.prevMotionValues);
|
|
314
|
+
if (this.handleChildMotionValue) {
|
|
315
|
+
this.handleChildMotionValue();
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
getProps() {
|
|
319
|
+
return this.props;
|
|
320
|
+
}
|
|
321
|
+
/**
|
|
322
|
+
* Returns the variant definition with a given name.
|
|
323
|
+
*/
|
|
324
|
+
getVariant(name) {
|
|
325
|
+
return this.props.variants ? this.props.variants[name] : undefined;
|
|
326
|
+
}
|
|
327
|
+
/**
|
|
328
|
+
* Returns the defined default transition on this component.
|
|
329
|
+
*/
|
|
330
|
+
getDefaultTransition() {
|
|
331
|
+
return this.props.transition;
|
|
332
|
+
}
|
|
333
|
+
getTransformPagePoint() {
|
|
334
|
+
return this.props.transformPagePoint;
|
|
335
|
+
}
|
|
336
|
+
getClosestVariantNode() {
|
|
337
|
+
return this.isVariantNode
|
|
338
|
+
? this
|
|
339
|
+
: this.parent
|
|
340
|
+
? this.parent.getClosestVariantNode()
|
|
341
|
+
: undefined;
|
|
342
|
+
}
|
|
343
|
+
/**
|
|
344
|
+
* Add a child visual element to our set of children.
|
|
345
|
+
*/
|
|
346
|
+
addVariantChild(child) {
|
|
347
|
+
const closestVariantNode = this.getClosestVariantNode();
|
|
348
|
+
if (closestVariantNode) {
|
|
349
|
+
closestVariantNode.variantChildren &&
|
|
350
|
+
closestVariantNode.variantChildren.add(child);
|
|
351
|
+
return () => closestVariantNode.variantChildren.delete(child);
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
/**
|
|
355
|
+
* Add a motion value and bind it to this visual element.
|
|
356
|
+
*/
|
|
357
|
+
addValue(key, value) {
|
|
358
|
+
// Remove existing value if it exists
|
|
359
|
+
const existingValue = this.values.get(key);
|
|
360
|
+
if (value !== existingValue) {
|
|
361
|
+
if (existingValue)
|
|
362
|
+
this.removeValue(key);
|
|
363
|
+
this.bindToMotionValue(key, value);
|
|
364
|
+
this.values.set(key, value);
|
|
365
|
+
this.latestValues[key] = value.get();
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
/**
|
|
369
|
+
* Remove a motion value and unbind any active subscriptions.
|
|
370
|
+
*/
|
|
371
|
+
removeValue(key) {
|
|
372
|
+
this.values.delete(key);
|
|
373
|
+
const unsubscribe = this.valueSubscriptions.get(key);
|
|
374
|
+
if (unsubscribe) {
|
|
375
|
+
unsubscribe();
|
|
376
|
+
this.valueSubscriptions.delete(key);
|
|
377
|
+
}
|
|
378
|
+
delete this.latestValues[key];
|
|
379
|
+
this.removeValueFromRenderState(key, this.renderState);
|
|
380
|
+
}
|
|
381
|
+
/**
|
|
382
|
+
* Check whether we have a motion value for this key
|
|
383
|
+
*/
|
|
384
|
+
hasValue(key) {
|
|
385
|
+
return this.values.has(key);
|
|
386
|
+
}
|
|
387
|
+
getValue(key, defaultValue) {
|
|
388
|
+
if (this.props.values && this.props.values[key]) {
|
|
389
|
+
return this.props.values[key];
|
|
390
|
+
}
|
|
391
|
+
let value = this.values.get(key);
|
|
392
|
+
if (value === undefined && defaultValue !== undefined) {
|
|
393
|
+
value = motionValue(defaultValue === null ? undefined : defaultValue, { owner: this });
|
|
394
|
+
this.addValue(key, value);
|
|
395
|
+
}
|
|
396
|
+
return value;
|
|
397
|
+
}
|
|
398
|
+
/**
|
|
399
|
+
* If we're trying to animate to a previously unencountered value,
|
|
400
|
+
* we need to check for it in our state and as a last resort read it
|
|
401
|
+
* directly from the instance (which might have performance implications).
|
|
402
|
+
*/
|
|
403
|
+
readValue(key, target) {
|
|
404
|
+
var _a;
|
|
405
|
+
let value = this.latestValues[key] !== undefined || !this.current
|
|
406
|
+
? this.latestValues[key]
|
|
407
|
+
: (_a = this.getBaseTargetFromProps(this.props, key)) !== null && _a !== void 0 ? _a : this.readValueFromInstance(this.current, key, this.options);
|
|
408
|
+
if (value !== undefined && value !== null) {
|
|
409
|
+
if (typeof value === "string" &&
|
|
410
|
+
(isNumericalString(value) || isZeroValueString(value))) {
|
|
411
|
+
// If this is a number read as a string, ie "0" or "200", convert it to a number
|
|
412
|
+
value = parseFloat(value);
|
|
413
|
+
}
|
|
414
|
+
else if (!findValueType(value) && complex.test(target)) {
|
|
415
|
+
value = getAnimatableNone(key, target);
|
|
416
|
+
}
|
|
417
|
+
this.setBaseTarget(key, isMotionValue(value) ? value.get() : value);
|
|
418
|
+
}
|
|
419
|
+
return isMotionValue(value) ? value.get() : value;
|
|
420
|
+
}
|
|
421
|
+
/**
|
|
422
|
+
* Set the base target to later animate back to. This is currently
|
|
423
|
+
* only hydrated on creation and when we first read a value.
|
|
424
|
+
*/
|
|
425
|
+
setBaseTarget(key, value) {
|
|
426
|
+
this.baseTarget[key] = value;
|
|
427
|
+
}
|
|
428
|
+
/**
|
|
429
|
+
* Find the base target for a value thats been removed from all animation
|
|
430
|
+
* props.
|
|
431
|
+
*/
|
|
432
|
+
getBaseTarget(key) {
|
|
433
|
+
var _a;
|
|
434
|
+
const { initial } = this.props;
|
|
435
|
+
let valueFromInitial;
|
|
436
|
+
if (typeof initial === "string" || typeof initial === "object") {
|
|
437
|
+
const variant = resolveVariantFromProps(this.props, initial, (_a = this.presenceContext) === null || _a === void 0 ? void 0 : _a.custom);
|
|
438
|
+
if (variant) {
|
|
439
|
+
valueFromInitial = variant[key];
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
/**
|
|
443
|
+
* If this value still exists in the current initial variant, read that.
|
|
444
|
+
*/
|
|
445
|
+
if (initial && valueFromInitial !== undefined) {
|
|
446
|
+
return valueFromInitial;
|
|
447
|
+
}
|
|
448
|
+
/**
|
|
449
|
+
* Alternatively, if this VisualElement config has defined a getBaseTarget
|
|
450
|
+
* so we can read the value from an alternative source, try that.
|
|
451
|
+
*/
|
|
452
|
+
const target = this.getBaseTargetFromProps(this.props, key);
|
|
453
|
+
if (target !== undefined && !isMotionValue(target))
|
|
454
|
+
return target;
|
|
455
|
+
/**
|
|
456
|
+
* If the value was initially defined on initial, but it doesn't any more,
|
|
457
|
+
* return undefined. Otherwise return the value as initially read from the DOM.
|
|
458
|
+
*/
|
|
459
|
+
return this.initialValues[key] !== undefined &&
|
|
460
|
+
valueFromInitial === undefined
|
|
461
|
+
? undefined
|
|
462
|
+
: this.baseTarget[key];
|
|
463
|
+
}
|
|
464
|
+
on(eventName, callback) {
|
|
465
|
+
if (!this.events[eventName]) {
|
|
466
|
+
this.events[eventName] = new SubscriptionManager();
|
|
467
|
+
}
|
|
468
|
+
return this.events[eventName].add(callback);
|
|
469
|
+
}
|
|
470
|
+
notify(eventName, ...args) {
|
|
471
|
+
if (this.events[eventName]) {
|
|
472
|
+
this.events[eventName].notify(...args);
|
|
473
|
+
}
|
|
474
|
+
}
|
|
475
|
+
}
|
|
476
|
+
|
|
477
|
+
export { VisualElement };
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { createRendererMotionComponent } from '../../motion/index.mjs';
|
|
2
|
+
import { isSVGComponent } from '../dom/utils/is-svg-component.mjs';
|
|
3
|
+
import { svgMotionConfig } from '../svg/config-motion.mjs';
|
|
4
|
+
import { htmlMotionConfig } from '../html/config-motion.mjs';
|
|
5
|
+
import { createUseRender } from '../dom/use-render.mjs';
|
|
6
|
+
|
|
7
|
+
function createMotionComponentFactory(preloadedFeatures, createVisualElement) {
|
|
8
|
+
return function createMotionComponent(Component, { forwardMotionProps } = { forwardMotionProps: false }) {
|
|
9
|
+
const baseConfig = isSVGComponent(Component)
|
|
10
|
+
? svgMotionConfig
|
|
11
|
+
: htmlMotionConfig;
|
|
12
|
+
const config = {
|
|
13
|
+
...baseConfig,
|
|
14
|
+
preloadedFeatures,
|
|
15
|
+
useRender: createUseRender(forwardMotionProps),
|
|
16
|
+
createVisualElement,
|
|
17
|
+
Component,
|
|
18
|
+
};
|
|
19
|
+
return createRendererMotionComponent(config);
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export { createMotionComponentFactory };
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { warnOnce } from '../../utils/warn-once.mjs';
|
|
2
|
+
|
|
3
|
+
function createDOMMotionComponentProxy(componentFactory) {
|
|
4
|
+
if (typeof Proxy === "undefined") {
|
|
5
|
+
return componentFactory;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* A cache of generated `motion` components, e.g `motion.div`, `motion.input` etc.
|
|
9
|
+
* Rather than generating them anew every render.
|
|
10
|
+
*/
|
|
11
|
+
const componentCache = new Map();
|
|
12
|
+
const deprecatedFactoryFunction = (...args) => {
|
|
13
|
+
if (process.env.NODE_ENV !== "production") {
|
|
14
|
+
warnOnce(false, "motion() is deprecated. Use motion.create() instead.");
|
|
15
|
+
}
|
|
16
|
+
return componentFactory(...args);
|
|
17
|
+
};
|
|
18
|
+
return new Proxy(deprecatedFactoryFunction, {
|
|
19
|
+
/**
|
|
20
|
+
* Called when `motion` is referenced with a prop: `motion.div`, `motion.input` etc.
|
|
21
|
+
* The prop name is passed through as `key` and we can use that to generate a `motion`
|
|
22
|
+
* DOM component with that name.
|
|
23
|
+
*/
|
|
24
|
+
get: (_target, key) => {
|
|
25
|
+
if (key === "create")
|
|
26
|
+
return componentFactory;
|
|
27
|
+
/**
|
|
28
|
+
* If this element doesn't exist in the component cache, create it and cache.
|
|
29
|
+
*/
|
|
30
|
+
if (!componentCache.has(key)) {
|
|
31
|
+
componentCache.set(key, componentFactory(key));
|
|
32
|
+
}
|
|
33
|
+
return componentCache.get(key);
|
|
34
|
+
},
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export { createDOMMotionComponentProxy };
|