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,230 @@
|
|
|
1
|
+
import { createGeneratorEasing } from '../../easing/utils/create-generator-easing.mjs';
|
|
2
|
+
import { defaultOffset } from '../../utils/offsets/default.mjs';
|
|
3
|
+
import { fillOffset } from '../../utils/offsets/fill.mjs';
|
|
4
|
+
import { progress } from '../../utils/progress.mjs';
|
|
5
|
+
import { secondsToMilliseconds } from '../../utils/time-conversion.mjs';
|
|
6
|
+
import { isMotionValue } from '../../value/utils/is-motion-value.mjs';
|
|
7
|
+
import { resolveSubjects } from '../animate/resolve-subjects.mjs';
|
|
8
|
+
import { isGenerator } from '../generators/utils/is-generator.mjs';
|
|
9
|
+
import { calcNextTime } from './utils/calc-time.mjs';
|
|
10
|
+
import { addKeyframes } from './utils/edit.mjs';
|
|
11
|
+
import { compareByTime } from './utils/sort.mjs';
|
|
12
|
+
|
|
13
|
+
const defaultSegmentEasing = "easeInOut";
|
|
14
|
+
function createAnimationsFromSequence(sequence, { defaultTransition = {}, ...sequenceTransition } = {}, scope, generators) {
|
|
15
|
+
const defaultDuration = defaultTransition.duration || 0.3;
|
|
16
|
+
const animationDefinitions = new Map();
|
|
17
|
+
const sequences = new Map();
|
|
18
|
+
const elementCache = {};
|
|
19
|
+
const timeLabels = new Map();
|
|
20
|
+
let prevTime = 0;
|
|
21
|
+
let currentTime = 0;
|
|
22
|
+
let totalDuration = 0;
|
|
23
|
+
/**
|
|
24
|
+
* Build the timeline by mapping over the sequence array and converting
|
|
25
|
+
* the definitions into keyframes and offsets with absolute time values.
|
|
26
|
+
* These will later get converted into relative offsets in a second pass.
|
|
27
|
+
*/
|
|
28
|
+
for (let i = 0; i < sequence.length; i++) {
|
|
29
|
+
const segment = sequence[i];
|
|
30
|
+
/**
|
|
31
|
+
* If this is a timeline label, mark it and skip the rest of this iteration.
|
|
32
|
+
*/
|
|
33
|
+
if (typeof segment === "string") {
|
|
34
|
+
timeLabels.set(segment, currentTime);
|
|
35
|
+
continue;
|
|
36
|
+
}
|
|
37
|
+
else if (!Array.isArray(segment)) {
|
|
38
|
+
timeLabels.set(segment.name, calcNextTime(currentTime, segment.at, prevTime, timeLabels));
|
|
39
|
+
continue;
|
|
40
|
+
}
|
|
41
|
+
let [subject, keyframes, transition = {}] = segment;
|
|
42
|
+
/**
|
|
43
|
+
* If a relative or absolute time value has been specified we need to resolve
|
|
44
|
+
* it in relation to the currentTime.
|
|
45
|
+
*/
|
|
46
|
+
if (transition.at !== undefined) {
|
|
47
|
+
currentTime = calcNextTime(currentTime, transition.at, prevTime, timeLabels);
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Keep track of the maximum duration in this definition. This will be
|
|
51
|
+
* applied to currentTime once the definition has been parsed.
|
|
52
|
+
*/
|
|
53
|
+
let maxDuration = 0;
|
|
54
|
+
const resolveValueSequence = (valueKeyframes, valueTransition, valueSequence, elementIndex = 0, numSubjects = 0) => {
|
|
55
|
+
const valueKeyframesAsList = keyframesAsList(valueKeyframes);
|
|
56
|
+
const { delay = 0, times = defaultOffset(valueKeyframesAsList), type = "keyframes", ...remainingTransition } = valueTransition;
|
|
57
|
+
let { ease = defaultTransition.ease || "easeOut", duration } = valueTransition;
|
|
58
|
+
/**
|
|
59
|
+
* Resolve stagger() if defined.
|
|
60
|
+
*/
|
|
61
|
+
const calculatedDelay = typeof delay === "function"
|
|
62
|
+
? delay(elementIndex, numSubjects)
|
|
63
|
+
: delay;
|
|
64
|
+
/**
|
|
65
|
+
* If this animation should and can use a spring, generate a spring easing function.
|
|
66
|
+
*/
|
|
67
|
+
const numKeyframes = valueKeyframesAsList.length;
|
|
68
|
+
const createGenerator = isGenerator(type)
|
|
69
|
+
? type
|
|
70
|
+
: generators === null || generators === void 0 ? void 0 : generators[type];
|
|
71
|
+
if (numKeyframes <= 2 && createGenerator) {
|
|
72
|
+
/**
|
|
73
|
+
* As we're creating an easing function from a spring,
|
|
74
|
+
* ideally we want to generate it using the real distance
|
|
75
|
+
* between the two keyframes. However this isn't always
|
|
76
|
+
* possible - in these situations we use 0-100.
|
|
77
|
+
*/
|
|
78
|
+
let absoluteDelta = 100;
|
|
79
|
+
if (numKeyframes === 2 &&
|
|
80
|
+
isNumberKeyframesArray(valueKeyframesAsList)) {
|
|
81
|
+
const delta = valueKeyframesAsList[1] - valueKeyframesAsList[0];
|
|
82
|
+
absoluteDelta = Math.abs(delta);
|
|
83
|
+
}
|
|
84
|
+
const springTransition = { ...remainingTransition };
|
|
85
|
+
if (duration !== undefined) {
|
|
86
|
+
springTransition.duration = secondsToMilliseconds(duration);
|
|
87
|
+
}
|
|
88
|
+
const springEasing = createGeneratorEasing(springTransition, absoluteDelta, createGenerator);
|
|
89
|
+
ease = springEasing.ease;
|
|
90
|
+
duration = springEasing.duration;
|
|
91
|
+
}
|
|
92
|
+
duration !== null && duration !== void 0 ? duration : (duration = defaultDuration);
|
|
93
|
+
const startTime = currentTime + calculatedDelay;
|
|
94
|
+
const targetTime = startTime + duration;
|
|
95
|
+
/**
|
|
96
|
+
* If there's only one time offset of 0, fill in a second with length 1
|
|
97
|
+
*/
|
|
98
|
+
if (times.length === 1 && times[0] === 0) {
|
|
99
|
+
times[1] = 1;
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Fill out if offset if fewer offsets than keyframes
|
|
103
|
+
*/
|
|
104
|
+
const remainder = times.length - valueKeyframesAsList.length;
|
|
105
|
+
remainder > 0 && fillOffset(times, remainder);
|
|
106
|
+
/**
|
|
107
|
+
* If only one value has been set, ie [1], push a null to the start of
|
|
108
|
+
* the keyframe array. This will let us mark a keyframe at this point
|
|
109
|
+
* that will later be hydrated with the previous value.
|
|
110
|
+
*/
|
|
111
|
+
valueKeyframesAsList.length === 1 &&
|
|
112
|
+
valueKeyframesAsList.unshift(null);
|
|
113
|
+
/**
|
|
114
|
+
* Add keyframes, mapping offsets to absolute time.
|
|
115
|
+
*/
|
|
116
|
+
addKeyframes(valueSequence, valueKeyframesAsList, ease, times, startTime, targetTime);
|
|
117
|
+
maxDuration = Math.max(calculatedDelay + duration, maxDuration);
|
|
118
|
+
totalDuration = Math.max(targetTime, totalDuration);
|
|
119
|
+
};
|
|
120
|
+
if (isMotionValue(subject)) {
|
|
121
|
+
const subjectSequence = getSubjectSequence(subject, sequences);
|
|
122
|
+
resolveValueSequence(keyframes, transition, getValueSequence("default", subjectSequence));
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
const subjects = resolveSubjects(subject, keyframes, scope, elementCache);
|
|
126
|
+
const numSubjects = subjects.length;
|
|
127
|
+
/**
|
|
128
|
+
* For every element in this segment, process the defined values.
|
|
129
|
+
*/
|
|
130
|
+
for (let subjectIndex = 0; subjectIndex < numSubjects; subjectIndex++) {
|
|
131
|
+
/**
|
|
132
|
+
* Cast necessary, but we know these are of this type
|
|
133
|
+
*/
|
|
134
|
+
keyframes = keyframes;
|
|
135
|
+
transition = transition;
|
|
136
|
+
const thisSubject = subjects[subjectIndex];
|
|
137
|
+
const subjectSequence = getSubjectSequence(thisSubject, sequences);
|
|
138
|
+
for (const key in keyframes) {
|
|
139
|
+
resolveValueSequence(keyframes[key], getValueTransition(transition, key), getValueSequence(key, subjectSequence), subjectIndex, numSubjects);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
prevTime = currentTime;
|
|
144
|
+
currentTime += maxDuration;
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* For every element and value combination create a new animation.
|
|
148
|
+
*/
|
|
149
|
+
sequences.forEach((valueSequences, element) => {
|
|
150
|
+
for (const key in valueSequences) {
|
|
151
|
+
const valueSequence = valueSequences[key];
|
|
152
|
+
/**
|
|
153
|
+
* Arrange all the keyframes in ascending time order.
|
|
154
|
+
*/
|
|
155
|
+
valueSequence.sort(compareByTime);
|
|
156
|
+
const keyframes = [];
|
|
157
|
+
const valueOffset = [];
|
|
158
|
+
const valueEasing = [];
|
|
159
|
+
/**
|
|
160
|
+
* For each keyframe, translate absolute times into
|
|
161
|
+
* relative offsets based on the total duration of the timeline.
|
|
162
|
+
*/
|
|
163
|
+
for (let i = 0; i < valueSequence.length; i++) {
|
|
164
|
+
const { at, value, easing } = valueSequence[i];
|
|
165
|
+
keyframes.push(value);
|
|
166
|
+
valueOffset.push(progress(0, totalDuration, at));
|
|
167
|
+
valueEasing.push(easing || "easeOut");
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* If the first keyframe doesn't land on offset: 0
|
|
171
|
+
* provide one by duplicating the initial keyframe. This ensures
|
|
172
|
+
* it snaps to the first keyframe when the animation starts.
|
|
173
|
+
*/
|
|
174
|
+
if (valueOffset[0] !== 0) {
|
|
175
|
+
valueOffset.unshift(0);
|
|
176
|
+
keyframes.unshift(keyframes[0]);
|
|
177
|
+
valueEasing.unshift(defaultSegmentEasing);
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* If the last keyframe doesn't land on offset: 1
|
|
181
|
+
* provide one with a null wildcard value. This will ensure it
|
|
182
|
+
* stays static until the end of the animation.
|
|
183
|
+
*/
|
|
184
|
+
if (valueOffset[valueOffset.length - 1] !== 1) {
|
|
185
|
+
valueOffset.push(1);
|
|
186
|
+
keyframes.push(null);
|
|
187
|
+
}
|
|
188
|
+
if (!animationDefinitions.has(element)) {
|
|
189
|
+
animationDefinitions.set(element, {
|
|
190
|
+
keyframes: {},
|
|
191
|
+
transition: {},
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
const definition = animationDefinitions.get(element);
|
|
195
|
+
definition.keyframes[key] = keyframes;
|
|
196
|
+
definition.transition[key] = {
|
|
197
|
+
...defaultTransition,
|
|
198
|
+
duration: totalDuration,
|
|
199
|
+
ease: valueEasing,
|
|
200
|
+
times: valueOffset,
|
|
201
|
+
...sequenceTransition,
|
|
202
|
+
};
|
|
203
|
+
}
|
|
204
|
+
});
|
|
205
|
+
return animationDefinitions;
|
|
206
|
+
}
|
|
207
|
+
function getSubjectSequence(subject, sequences) {
|
|
208
|
+
!sequences.has(subject) && sequences.set(subject, {});
|
|
209
|
+
return sequences.get(subject);
|
|
210
|
+
}
|
|
211
|
+
function getValueSequence(name, sequences) {
|
|
212
|
+
if (!sequences[name])
|
|
213
|
+
sequences[name] = [];
|
|
214
|
+
return sequences[name];
|
|
215
|
+
}
|
|
216
|
+
function keyframesAsList(keyframes) {
|
|
217
|
+
return Array.isArray(keyframes) ? keyframes : [keyframes];
|
|
218
|
+
}
|
|
219
|
+
function getValueTransition(transition, key) {
|
|
220
|
+
return transition && transition[key]
|
|
221
|
+
? {
|
|
222
|
+
...transition,
|
|
223
|
+
...transition[key],
|
|
224
|
+
}
|
|
225
|
+
: { ...transition };
|
|
226
|
+
}
|
|
227
|
+
const isNumber = (keyframe) => typeof keyframe === "number";
|
|
228
|
+
const isNumberKeyframesArray = (keyframes) => keyframes.every(isNumber);
|
|
229
|
+
|
|
230
|
+
export { createAnimationsFromSequence, getValueTransition };
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Given a absolute or relative time definition and current/prev time state of the sequence,
|
|
3
|
+
* calculate an absolute time for the next keyframes.
|
|
4
|
+
*/
|
|
5
|
+
function calcNextTime(current, next, prev, labels) {
|
|
6
|
+
var _a;
|
|
7
|
+
if (typeof next === "number") {
|
|
8
|
+
return next;
|
|
9
|
+
}
|
|
10
|
+
else if (next.startsWith("-") || next.startsWith("+")) {
|
|
11
|
+
return Math.max(0, current + parseFloat(next));
|
|
12
|
+
}
|
|
13
|
+
else if (next === "<") {
|
|
14
|
+
return prev;
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
return (_a = labels.get(next)) !== null && _a !== void 0 ? _a : current;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export { calcNextTime };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { getEasingForSegment } from '../../../easing/utils/get-easing-for-segment.mjs';
|
|
2
|
+
import { removeItem } from '../../../utils/array.mjs';
|
|
3
|
+
import { mixNumber } from '../../../utils/mix/number.mjs';
|
|
4
|
+
|
|
5
|
+
function eraseKeyframes(sequence, startTime, endTime) {
|
|
6
|
+
for (let i = 0; i < sequence.length; i++) {
|
|
7
|
+
const keyframe = sequence[i];
|
|
8
|
+
if (keyframe.at > startTime && keyframe.at < endTime) {
|
|
9
|
+
removeItem(sequence, keyframe);
|
|
10
|
+
// If we remove this item we have to push the pointer back one
|
|
11
|
+
i--;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
function addKeyframes(sequence, keyframes, easing, offset, startTime, endTime) {
|
|
16
|
+
/**
|
|
17
|
+
* Erase every existing value between currentTime and targetTime,
|
|
18
|
+
* this will essentially splice this timeline into any currently
|
|
19
|
+
* defined ones.
|
|
20
|
+
*/
|
|
21
|
+
eraseKeyframes(sequence, startTime, endTime);
|
|
22
|
+
for (let i = 0; i < keyframes.length; i++) {
|
|
23
|
+
sequence.push({
|
|
24
|
+
value: keyframes[i],
|
|
25
|
+
at: mixNumber(startTime, endTime, offset[i]),
|
|
26
|
+
easing: getEasingForSegment(easing, i),
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export { addKeyframes, eraseKeyframes };
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { isSVGElement } from '../../render/dom/utils/is-svg-element.mjs';
|
|
2
|
+
import { SVGVisualElement } from '../../render/svg/SVGVisualElement.mjs';
|
|
3
|
+
import { HTMLVisualElement } from '../../render/html/HTMLVisualElement.mjs';
|
|
4
|
+
import { visualElementStore } from '../../render/store.mjs';
|
|
5
|
+
import { ObjectVisualElement } from '../../render/object/ObjectVisualElement.mjs';
|
|
6
|
+
|
|
7
|
+
function createDOMVisualElement(element) {
|
|
8
|
+
const options = {
|
|
9
|
+
presenceContext: null,
|
|
10
|
+
props: {},
|
|
11
|
+
visualState: {
|
|
12
|
+
renderState: {
|
|
13
|
+
transform: {},
|
|
14
|
+
transformOrigin: {},
|
|
15
|
+
style: {},
|
|
16
|
+
vars: {},
|
|
17
|
+
attrs: {},
|
|
18
|
+
},
|
|
19
|
+
latestValues: {},
|
|
20
|
+
},
|
|
21
|
+
};
|
|
22
|
+
const node = isSVGElement(element)
|
|
23
|
+
? new SVGVisualElement(options)
|
|
24
|
+
: new HTMLVisualElement(options);
|
|
25
|
+
node.mount(element);
|
|
26
|
+
visualElementStore.set(element, node);
|
|
27
|
+
}
|
|
28
|
+
function createObjectVisualElement(subject) {
|
|
29
|
+
const options = {
|
|
30
|
+
presenceContext: null,
|
|
31
|
+
props: {},
|
|
32
|
+
visualState: {
|
|
33
|
+
renderState: {
|
|
34
|
+
output: {},
|
|
35
|
+
},
|
|
36
|
+
latestValues: {},
|
|
37
|
+
},
|
|
38
|
+
};
|
|
39
|
+
const node = new ObjectVisualElement(options);
|
|
40
|
+
node.mount(subject);
|
|
41
|
+
visualElementStore.set(subject, node);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export { createDOMVisualElement, createObjectVisualElement };
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { transformProps } from '../../render/html/utils/transform.mjs';
|
|
2
|
+
|
|
3
|
+
const underDampedSpring = {
|
|
4
|
+
type: "spring",
|
|
5
|
+
stiffness: 500,
|
|
6
|
+
damping: 25,
|
|
7
|
+
restSpeed: 10,
|
|
8
|
+
};
|
|
9
|
+
const criticallyDampedSpring = (target) => ({
|
|
10
|
+
type: "spring",
|
|
11
|
+
stiffness: 550,
|
|
12
|
+
damping: target === 0 ? 2 * Math.sqrt(550) : 30,
|
|
13
|
+
restSpeed: 10,
|
|
14
|
+
});
|
|
15
|
+
const keyframesTransition = {
|
|
16
|
+
type: "keyframes",
|
|
17
|
+
duration: 0.8,
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* Default easing curve is a slightly shallower version of
|
|
21
|
+
* the default browser easing curve.
|
|
22
|
+
*/
|
|
23
|
+
const ease = {
|
|
24
|
+
type: "keyframes",
|
|
25
|
+
ease: [0.25, 0.1, 0.35, 1],
|
|
26
|
+
duration: 0.3,
|
|
27
|
+
};
|
|
28
|
+
const getDefaultTransition = (valueKey, { keyframes }) => {
|
|
29
|
+
if (keyframes.length > 2) {
|
|
30
|
+
return keyframesTransition;
|
|
31
|
+
}
|
|
32
|
+
else if (transformProps.has(valueKey)) {
|
|
33
|
+
return valueKey.startsWith("scale")
|
|
34
|
+
? criticallyDampedSpring(keyframes[1])
|
|
35
|
+
: underDampedSpring;
|
|
36
|
+
}
|
|
37
|
+
return ease;
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export { getDefaultTransition };
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { complex } from '../../value/types/complex/index.mjs';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Check if a value is animatable. Examples:
|
|
5
|
+
*
|
|
6
|
+
* ✅: 100, "100px", "#fff"
|
|
7
|
+
* ❌: "block", "url(2.jpg)"
|
|
8
|
+
* @param value
|
|
9
|
+
*
|
|
10
|
+
* @internal
|
|
11
|
+
*/
|
|
12
|
+
const isAnimatable = (value, name) => {
|
|
13
|
+
// If the list of keys tat might be non-animatable grows, replace with Set
|
|
14
|
+
if (name === "zIndex")
|
|
15
|
+
return false;
|
|
16
|
+
// If it's a number or a keyframes array, we can animate it. We might at some point
|
|
17
|
+
// need to do a deep isAnimatable check of keyframes, or let Popmotion handle this,
|
|
18
|
+
// but for now lets leave it like this for performance reasons
|
|
19
|
+
if (typeof value === "number" || Array.isArray(value))
|
|
20
|
+
return true;
|
|
21
|
+
if (typeof value === "string" && // It's animatable if we have a string
|
|
22
|
+
(complex.test(value) || value === "0") && // And it contains numbers and/or colors
|
|
23
|
+
!value.startsWith("url(") // Unless it starts with "url("
|
|
24
|
+
) {
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
return false;
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
export { isAnimatable };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { isZeroValueString } from '../../utils/is-zero-value-string.mjs';
|
|
2
|
+
|
|
3
|
+
function isNone(value) {
|
|
4
|
+
if (typeof value === "number") {
|
|
5
|
+
return value === 0;
|
|
6
|
+
}
|
|
7
|
+
else if (value !== null) {
|
|
8
|
+
return value === "none" || value === "0" || isZeroValueString(value);
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
return true;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export { isNone };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Decide whether a transition is defined on a given Transition.
|
|
3
|
+
* This filters out orchestration options and returns true
|
|
4
|
+
* if any options are left.
|
|
5
|
+
*/
|
|
6
|
+
function isTransitionDefined({ when, delay: _delay, delayChildren, staggerChildren, staggerDirection, repeat, repeatType, repeatDelay, from, elapsed, ...transition }) {
|
|
7
|
+
return !!Object.keys(transition).length;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export { isTransitionDefined };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { easingDefinitionToFunction } from '../../easing/utils/map.mjs';
|
|
2
|
+
|
|
3
|
+
function getOriginIndex(from, total) {
|
|
4
|
+
if (from === "first") {
|
|
5
|
+
return 0;
|
|
6
|
+
}
|
|
7
|
+
else {
|
|
8
|
+
const lastIndex = total - 1;
|
|
9
|
+
return from === "last" ? lastIndex : lastIndex / 2;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
function stagger(duration = 0.1, { startDelay = 0, from = 0, ease } = {}) {
|
|
13
|
+
return (i, total) => {
|
|
14
|
+
const fromIndex = typeof from === "number" ? from : getOriginIndex(from, total);
|
|
15
|
+
const distance = Math.abs(fromIndex - i);
|
|
16
|
+
let delay = duration * distance;
|
|
17
|
+
if (ease) {
|
|
18
|
+
const maxDelay = total * duration;
|
|
19
|
+
const easingFunction = easingDefinitionToFunction(ease);
|
|
20
|
+
delay = easingFunction(delay / maxDelay) * maxDelay;
|
|
21
|
+
}
|
|
22
|
+
return startDelay + delay;
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export { getOriginIndex, stagger };
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import { useId, useRef, useContext, useInsertionEffect } from 'react';
|
|
5
|
+
import { MotionConfigContext } from '../../context/MotionConfigContext.mjs';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Measurement functionality has to be within a separate component
|
|
9
|
+
* to leverage snapshot lifecycle.
|
|
10
|
+
*/
|
|
11
|
+
class PopChildMeasure extends React.Component {
|
|
12
|
+
getSnapshotBeforeUpdate(prevProps) {
|
|
13
|
+
const element = this.props.childRef.current;
|
|
14
|
+
if (element && prevProps.isPresent && !this.props.isPresent) {
|
|
15
|
+
const size = this.props.sizeRef.current;
|
|
16
|
+
size.height = element.offsetHeight || 0;
|
|
17
|
+
size.width = element.offsetWidth || 0;
|
|
18
|
+
size.top = element.offsetTop;
|
|
19
|
+
size.left = element.offsetLeft;
|
|
20
|
+
}
|
|
21
|
+
return null;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Required with getSnapshotBeforeUpdate to stop React complaining.
|
|
25
|
+
*/
|
|
26
|
+
componentDidUpdate() { }
|
|
27
|
+
render() {
|
|
28
|
+
return this.props.children;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
function PopChild({ children, isPresent }) {
|
|
32
|
+
const id = useId();
|
|
33
|
+
const ref = useRef(null);
|
|
34
|
+
const size = useRef({
|
|
35
|
+
width: 0,
|
|
36
|
+
height: 0,
|
|
37
|
+
top: 0,
|
|
38
|
+
left: 0,
|
|
39
|
+
});
|
|
40
|
+
const { nonce } = useContext(MotionConfigContext);
|
|
41
|
+
/**
|
|
42
|
+
* We create and inject a style block so we can apply this explicit
|
|
43
|
+
* sizing in a non-destructive manner by just deleting the style block.
|
|
44
|
+
*
|
|
45
|
+
* We can't apply size via render as the measurement happens
|
|
46
|
+
* in getSnapshotBeforeUpdate (post-render), likewise if we apply the
|
|
47
|
+
* styles directly on the DOM node, we might be overwriting
|
|
48
|
+
* styles set via the style prop.
|
|
49
|
+
*/
|
|
50
|
+
useInsertionEffect(() => {
|
|
51
|
+
const { width, height, top, left } = size.current;
|
|
52
|
+
if (isPresent || !ref.current || !width || !height)
|
|
53
|
+
return;
|
|
54
|
+
ref.current.dataset.motionPopId = id;
|
|
55
|
+
const style = document.createElement("style");
|
|
56
|
+
if (nonce)
|
|
57
|
+
style.nonce = nonce;
|
|
58
|
+
document.head.appendChild(style);
|
|
59
|
+
if (style.sheet) {
|
|
60
|
+
style.sheet.insertRule(`
|
|
61
|
+
[data-motion-pop-id="${id}"] {
|
|
62
|
+
position: absolute !important;
|
|
63
|
+
width: ${width}px !important;
|
|
64
|
+
height: ${height}px !important;
|
|
65
|
+
top: ${top}px !important;
|
|
66
|
+
left: ${left}px !important;
|
|
67
|
+
}
|
|
68
|
+
`);
|
|
69
|
+
}
|
|
70
|
+
return () => {
|
|
71
|
+
document.head.removeChild(style);
|
|
72
|
+
};
|
|
73
|
+
}, [isPresent]);
|
|
74
|
+
return (jsx(PopChildMeasure, { isPresent: isPresent, childRef: ref, sizeRef: size, children: React.cloneElement(children, { ref }) }));
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
export { PopChild };
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import { useId, useCallback, useMemo } from 'react';
|
|
5
|
+
import { PresenceContext } from '../../context/PresenceContext.mjs';
|
|
6
|
+
import { useConstant } from '../../utils/use-constant.mjs';
|
|
7
|
+
import { PopChild } from './PopChild.mjs';
|
|
8
|
+
|
|
9
|
+
const PresenceChild = ({ children, initial, isPresent, onExitComplete, custom, presenceAffectsLayout, mode, }) => {
|
|
10
|
+
const presenceChildren = useConstant(newChildrenMap);
|
|
11
|
+
const id = useId();
|
|
12
|
+
const memoizedOnExitComplete = useCallback((childId) => {
|
|
13
|
+
presenceChildren.set(childId, true);
|
|
14
|
+
for (const isComplete of presenceChildren.values()) {
|
|
15
|
+
if (!isComplete)
|
|
16
|
+
return; // can stop searching when any is incomplete
|
|
17
|
+
}
|
|
18
|
+
onExitComplete && onExitComplete();
|
|
19
|
+
}, [presenceChildren, onExitComplete]);
|
|
20
|
+
const context = useMemo(() => ({
|
|
21
|
+
id,
|
|
22
|
+
initial,
|
|
23
|
+
isPresent,
|
|
24
|
+
custom,
|
|
25
|
+
onExitComplete: memoizedOnExitComplete,
|
|
26
|
+
register: (childId) => {
|
|
27
|
+
presenceChildren.set(childId, false);
|
|
28
|
+
return () => presenceChildren.delete(childId);
|
|
29
|
+
},
|
|
30
|
+
}),
|
|
31
|
+
/**
|
|
32
|
+
* If the presence of a child affects the layout of the components around it,
|
|
33
|
+
* we want to make a new context value to ensure they get re-rendered
|
|
34
|
+
* so they can detect that layout change.
|
|
35
|
+
*/
|
|
36
|
+
presenceAffectsLayout
|
|
37
|
+
? [Math.random(), memoizedOnExitComplete]
|
|
38
|
+
: [isPresent, memoizedOnExitComplete]);
|
|
39
|
+
useMemo(() => {
|
|
40
|
+
presenceChildren.forEach((_, key) => presenceChildren.set(key, false));
|
|
41
|
+
}, [isPresent]);
|
|
42
|
+
/**
|
|
43
|
+
* If there's no `motion` components to fire exit animations, we want to remove this
|
|
44
|
+
* component immediately.
|
|
45
|
+
*/
|
|
46
|
+
React.useEffect(() => {
|
|
47
|
+
!isPresent &&
|
|
48
|
+
!presenceChildren.size &&
|
|
49
|
+
onExitComplete &&
|
|
50
|
+
onExitComplete();
|
|
51
|
+
}, [isPresent]);
|
|
52
|
+
if (mode === "popLayout") {
|
|
53
|
+
children = jsx(PopChild, { isPresent: isPresent, children: children });
|
|
54
|
+
}
|
|
55
|
+
return (jsx(PresenceContext.Provider, { value: context, children: children }));
|
|
56
|
+
};
|
|
57
|
+
function newChildrenMap() {
|
|
58
|
+
return new Map();
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export { PresenceChild };
|