motion 12.18.1 → 12.19.0
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/dist/cjs/mini.js +7 -1063
- package/dist/es/debug.mjs +1 -0
- package/dist/es/index.mjs +1 -0
- package/dist/es/mini.mjs +1 -0
- package/dist/es/react-client.mjs +2 -0
- package/dist/es/react-m.mjs +2 -0
- package/dist/es/react-mini.mjs +2 -0
- package/dist/es/react.mjs +2 -0
- package/dist/motion.dev.js +2 -2
- package/dist/motion.js +1 -1
- package/mini/package.json +1 -1
- package/package.json +11 -11
- package/react/package.json +1 -1
- package/react-client/package.json +1 -1
- package/react-m/package.json +1 -1
- package/dist/es/framer-motion/dist/es/animation/animate/index.mjs +0 -34
- package/dist/es/framer-motion/dist/es/animation/animate/resolve-subjects.mjs +0 -19
- package/dist/es/framer-motion/dist/es/animation/animate/sequence.mjs +0 -14
- package/dist/es/framer-motion/dist/es/animation/animate/single-value.mjs +0 -11
- package/dist/es/framer-motion/dist/es/animation/animate/subject.mjs +0 -52
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/animate-elements.mjs +0 -112
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/animate-sequence.mjs +0 -13
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/animate-style.mjs +0 -12
- package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/get-final-keyframe.mjs +0 -12
- package/dist/es/framer-motion/dist/es/animation/hooks/animation-controls.mjs +0 -80
- package/dist/es/framer-motion/dist/es/animation/hooks/use-animate-style.mjs +0 -17
- package/dist/es/framer-motion/dist/es/animation/hooks/use-animate.mjs +0 -17
- package/dist/es/framer-motion/dist/es/animation/hooks/use-animated-state.mjs +0 -64
- package/dist/es/framer-motion/dist/es/animation/hooks/use-animation.mjs +0 -41
- package/dist/es/framer-motion/dist/es/animation/interfaces/motion-value.mjs +0 -102
- package/dist/es/framer-motion/dist/es/animation/interfaces/visual-element-target.mjs +0 -85
- package/dist/es/framer-motion/dist/es/animation/interfaces/visual-element-variant.mjs +0 -65
- package/dist/es/framer-motion/dist/es/animation/interfaces/visual-element.mjs +0 -26
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/data-id.mjs +0 -6
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/get-appear-id.mjs +0 -7
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/handoff.mjs +0 -38
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/start.mjs +0 -171
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/store-id.mjs +0 -8
- package/dist/es/framer-motion/dist/es/animation/optimized-appear/store.mjs +0 -4
- package/dist/es/framer-motion/dist/es/animation/sequence/create.mjs +0 -256
- package/dist/es/framer-motion/dist/es/animation/sequence/utils/calc-repeat-duration.mjs +0 -5
- package/dist/es/framer-motion/dist/es/animation/sequence/utils/calc-time.mjs +0 -23
- package/dist/es/framer-motion/dist/es/animation/sequence/utils/edit.mjs +0 -31
- package/dist/es/framer-motion/dist/es/animation/sequence/utils/normalize-times.mjs +0 -13
- package/dist/es/framer-motion/dist/es/animation/sequence/utils/sort.mjs +0 -14
- package/dist/es/framer-motion/dist/es/animation/utils/create-visual-element.mjs +0 -45
- package/dist/es/framer-motion/dist/es/animation/utils/default-transitions.mjs +0 -40
- package/dist/es/framer-motion/dist/es/animation/utils/is-animation-controls.mjs +0 -7
- package/dist/es/framer-motion/dist/es/animation/utils/is-dom-keyframes.mjs +0 -5
- package/dist/es/framer-motion/dist/es/animation/utils/is-keyframes-target.mjs +0 -5
- package/dist/es/framer-motion/dist/es/animation/utils/is-transition-defined.mjs +0 -10
- package/dist/es/framer-motion/dist/es/animation/utils/stagger.mjs +0 -26
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/PopChild.mjs +0 -87
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/PresenceChild.mjs +0 -64
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/index.mjs +0 -166
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/use-presence-data.mjs +0 -9
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/use-presence.mjs +0 -70
- package/dist/es/framer-motion/dist/es/components/AnimatePresence/utils.mjs +0 -14
- package/dist/es/framer-motion/dist/es/components/AnimateSharedLayout.mjs +0 -15
- package/dist/es/framer-motion/dist/es/components/LayoutGroup/index.mjs +0 -32
- package/dist/es/framer-motion/dist/es/components/LazyMotion/index.mjs +0 -68
- package/dist/es/framer-motion/dist/es/components/MotionConfig/index.mjs +0 -48
- package/dist/es/framer-motion/dist/es/components/Reorder/Group.mjs +0 -53
- package/dist/es/framer-motion/dist/es/components/Reorder/Item.mjs +0 -34
- package/dist/es/framer-motion/dist/es/components/Reorder/namespace.mjs +0 -2
- package/dist/es/framer-motion/dist/es/components/Reorder/utils/check-reorder.mjs +0 -24
- package/dist/es/framer-motion/dist/es/context/DeprecatedLayoutGroupContext.mjs +0 -10
- package/dist/es/framer-motion/dist/es/context/LayoutGroupContext.mjs +0 -6
- package/dist/es/framer-motion/dist/es/context/LazyContext.mjs +0 -6
- package/dist/es/framer-motion/dist/es/context/MotionConfigContext.mjs +0 -13
- package/dist/es/framer-motion/dist/es/context/MotionContext/create.mjs +0 -13
- package/dist/es/framer-motion/dist/es/context/MotionContext/index.mjs +0 -6
- package/dist/es/framer-motion/dist/es/context/MotionContext/utils.mjs +0 -17
- package/dist/es/framer-motion/dist/es/context/PresenceContext.mjs +0 -10
- package/dist/es/framer-motion/dist/es/context/ReorderContext.mjs +0 -6
- package/dist/es/framer-motion/dist/es/context/SwitchLayoutGroupContext.mjs +0 -9
- package/dist/es/framer-motion/dist/es/events/add-dom-event.mjs +0 -6
- package/dist/es/framer-motion/dist/es/events/add-pointer-event.mjs +0 -8
- package/dist/es/framer-motion/dist/es/events/event-info.mjs +0 -15
- package/dist/es/framer-motion/dist/es/events/use-dom-event.mjs +0 -34
- package/dist/es/framer-motion/dist/es/gestures/drag/VisualElementDragControls.mjs +0 -479
- package/dist/es/framer-motion/dist/es/gestures/drag/index.mjs +0 -27
- package/dist/es/framer-motion/dist/es/gestures/drag/use-drag-controls.mjs +0 -88
- package/dist/es/framer-motion/dist/es/gestures/drag/utils/constraints.mjs +0 -129
- package/dist/es/framer-motion/dist/es/gestures/focus.mjs +0 -41
- package/dist/es/framer-motion/dist/es/gestures/hover.mjs +0 -30
- package/dist/es/framer-motion/dist/es/gestures/pan/PanSession.mjs +0 -156
- package/dist/es/framer-motion/dist/es/gestures/pan/index.mjs +0 -50
- package/dist/es/framer-motion/dist/es/gestures/press.mjs +0 -33
- package/dist/es/framer-motion/dist/es/motion/features/Feature.mjs +0 -9
- package/dist/es/framer-motion/dist/es/motion/features/animation/exit.mjs +0 -36
- package/dist/es/framer-motion/dist/es/motion/features/animation/index.mjs +0 -40
- package/dist/es/framer-motion/dist/es/motion/features/animations.mjs +0 -13
- package/dist/es/framer-motion/dist/es/motion/features/definitions.mjs +0 -28
- package/dist/es/framer-motion/dist/es/motion/features/drag.mjs +0 -17
- package/dist/es/framer-motion/dist/es/motion/features/gestures.mjs +0 -21
- package/dist/es/framer-motion/dist/es/motion/features/layout/MeasureLayout.mjs +0 -135
- package/dist/es/framer-motion/dist/es/motion/features/layout.mjs +0 -11
- package/dist/es/framer-motion/dist/es/motion/features/load-features.mjs +0 -12
- package/dist/es/framer-motion/dist/es/motion/features/viewport/index.mjs +0 -72
- package/dist/es/framer-motion/dist/es/motion/features/viewport/observers.mjs +0 -49
- package/dist/es/framer-motion/dist/es/motion/index.mjs +0 -101
- package/dist/es/framer-motion/dist/es/motion/utils/is-forced-motion-value.mjs +0 -11
- package/dist/es/framer-motion/dist/es/motion/utils/is-motion-component.mjs +0 -12
- package/dist/es/framer-motion/dist/es/motion/utils/symbol.mjs +0 -3
- package/dist/es/framer-motion/dist/es/motion/utils/unwrap-motion-component.mjs +0 -17
- package/dist/es/framer-motion/dist/es/motion/utils/use-motion-ref.mjs +0 -38
- package/dist/es/framer-motion/dist/es/motion/utils/use-visual-element.mjs +0 -133
- package/dist/es/framer-motion/dist/es/motion/utils/use-visual-state.mjs +0 -79
- package/dist/es/framer-motion/dist/es/motion/utils/valid-prop.mjs +0 -57
- package/dist/es/framer-motion/dist/es/projection/animation/mix-values.mjs +0 -91
- package/dist/es/framer-motion/dist/es/projection/geometry/conversion.mjs +0 -33
- package/dist/es/framer-motion/dist/es/projection/geometry/copy.mjs +0 -31
- package/dist/es/framer-motion/dist/es/projection/geometry/delta-apply.mjs +0 -119
- package/dist/es/framer-motion/dist/es/projection/geometry/delta-calc.mjs +0 -52
- package/dist/es/framer-motion/dist/es/projection/geometry/delta-remove.mjs +0 -54
- package/dist/es/framer-motion/dist/es/projection/geometry/models.mjs +0 -17
- package/dist/es/framer-motion/dist/es/projection/geometry/utils.mjs +0 -31
- package/dist/es/framer-motion/dist/es/projection/node/DocumentProjectionNode.mjs +0 -13
- package/dist/es/framer-motion/dist/es/projection/node/HTMLProjectionNode.mjs +0 -27
- package/dist/es/framer-motion/dist/es/projection/node/create-projection-node.mjs +0 -1605
- package/dist/es/framer-motion/dist/es/projection/node/group.mjs +0 -24
- package/dist/es/framer-motion/dist/es/projection/node/state.mjs +0 -19
- package/dist/es/framer-motion/dist/es/projection/shared/stack.mjs +0 -112
- package/dist/es/framer-motion/dist/es/projection/styles/scale-border-radius.mjs +0 -41
- package/dist/es/framer-motion/dist/es/projection/styles/scale-box-shadow.mjs +0 -35
- package/dist/es/framer-motion/dist/es/projection/styles/scale-correction.mjs +0 -13
- package/dist/es/framer-motion/dist/es/projection/styles/transform.mjs +0 -49
- package/dist/es/framer-motion/dist/es/projection/use-instant-layout-transition.mjs +0 -14
- package/dist/es/framer-motion/dist/es/projection/use-reset-projection.mjs +0 -14
- package/dist/es/framer-motion/dist/es/projection/utils/each-axis.mjs +0 -5
- package/dist/es/framer-motion/dist/es/projection/utils/has-transform.mjs +0 -26
- package/dist/es/framer-motion/dist/es/projection/utils/measure.mjs +0 -17
- package/dist/es/framer-motion/dist/es/render/VisualElement.mjs +0 -478
- package/dist/es/framer-motion/dist/es/render/components/create-factory.mjs +0 -23
- package/dist/es/framer-motion/dist/es/render/components/create-proxy.mjs +0 -38
- package/dist/es/framer-motion/dist/es/render/components/m/create.mjs +0 -6
- package/dist/es/framer-motion/dist/es/render/components/m/elements.mjs +0 -227
- package/dist/es/framer-motion/dist/es/render/components/m/proxy.mjs +0 -6
- package/dist/es/framer-motion/dist/es/render/components/motion/create.mjs +0 -15
- package/dist/es/framer-motion/dist/es/render/components/motion/elements.mjs +0 -194
- package/dist/es/framer-motion/dist/es/render/components/motion/proxy.mjs +0 -6
- package/dist/es/framer-motion/dist/es/render/dom/DOMVisualElement.mjs +0 -43
- package/dist/es/framer-motion/dist/es/render/dom/create-visual-element.mjs +0 -14
- package/dist/es/framer-motion/dist/es/render/dom/features-animation.mjs +0 -14
- package/dist/es/framer-motion/dist/es/render/dom/features-max.mjs +0 -14
- package/dist/es/framer-motion/dist/es/render/dom/features-min.mjs +0 -12
- package/dist/es/framer-motion/dist/es/render/dom/scroll/attach-animation.mjs +0 -17
- package/dist/es/framer-motion/dist/es/render/dom/scroll/attach-function.mjs +0 -23
- package/dist/es/framer-motion/dist/es/render/dom/scroll/index.mjs +0 -14
- package/dist/es/framer-motion/dist/es/render/dom/scroll/info.mjs +0 -56
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/edge.mjs +0 -45
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/index.mjs +0 -60
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/inset.mjs +0 -47
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/offset.mjs +0 -35
- package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/presets.mjs +0 -20
- package/dist/es/framer-motion/dist/es/render/dom/scroll/on-scroll-handler.mjs +0 -48
- package/dist/es/framer-motion/dist/es/render/dom/scroll/track.mjs +0 -81
- package/dist/es/framer-motion/dist/es/render/dom/scroll/utils/get-timeline.mjs +0 -30
- package/dist/es/framer-motion/dist/es/render/dom/use-render.mjs +0 -33
- package/dist/es/framer-motion/dist/es/render/dom/utils/camel-to-dash.mjs +0 -6
- package/dist/es/framer-motion/dist/es/render/dom/utils/filter-props.mjs +0 -59
- package/dist/es/framer-motion/dist/es/render/dom/utils/is-svg-component.mjs +0 -30
- package/dist/es/framer-motion/dist/es/render/dom/viewport/index.mjs +0 -43
- package/dist/es/framer-motion/dist/es/render/html/HTMLVisualElement.mjs +0 -44
- package/dist/es/framer-motion/dist/es/render/html/config-motion.mjs +0 -12
- package/dist/es/framer-motion/dist/es/render/html/use-props.mjs +0 -57
- package/dist/es/framer-motion/dist/es/render/html/utils/build-styles.mjs +0 -65
- package/dist/es/framer-motion/dist/es/render/html/utils/build-transform.mjs +0 -62
- package/dist/es/framer-motion/dist/es/render/html/utils/create-render-state.mjs +0 -8
- package/dist/es/framer-motion/dist/es/render/html/utils/render.mjs +0 -9
- package/dist/es/framer-motion/dist/es/render/html/utils/scrape-motion-values.mjs +0 -19
- package/dist/es/framer-motion/dist/es/render/object/ObjectVisualElement.mjs +0 -41
- package/dist/es/framer-motion/dist/es/render/store.mjs +0 -3
- package/dist/es/framer-motion/dist/es/render/svg/SVGVisualElement.mjs +0 -45
- package/dist/es/framer-motion/dist/es/render/svg/config-motion.mjs +0 -12
- package/dist/es/framer-motion/dist/es/render/svg/lowercase-elements.mjs +0 -33
- package/dist/es/framer-motion/dist/es/render/svg/use-props.mjs +0 -24
- package/dist/es/framer-motion/dist/es/render/svg/utils/build-attrs.mjs +0 -57
- package/dist/es/framer-motion/dist/es/render/svg/utils/camel-case-attrs.mjs +0 -30
- package/dist/es/framer-motion/dist/es/render/svg/utils/create-render-state.mjs +0 -8
- package/dist/es/framer-motion/dist/es/render/svg/utils/is-svg-tag.mjs +0 -3
- package/dist/es/framer-motion/dist/es/render/svg/utils/path.mjs +0 -32
- package/dist/es/framer-motion/dist/es/render/svg/utils/render.mjs +0 -12
- package/dist/es/framer-motion/dist/es/render/svg/utils/scrape-motion-values.mjs +0 -19
- package/dist/es/framer-motion/dist/es/render/utils/animation-state.mjs +0 -342
- package/dist/es/framer-motion/dist/es/render/utils/compare-by-depth.mjs +0 -3
- package/dist/es/framer-motion/dist/es/render/utils/flat-tree.mjs +0 -24
- package/dist/es/framer-motion/dist/es/render/utils/get-variant-context.mjs +0 -28
- package/dist/es/framer-motion/dist/es/render/utils/is-controlling-variants.mjs +0 -13
- package/dist/es/framer-motion/dist/es/render/utils/is-variant-label.mjs +0 -8
- package/dist/es/framer-motion/dist/es/render/utils/motion-values.mjs +0 -51
- package/dist/es/framer-motion/dist/es/render/utils/resolve-dynamic-variants.mjs +0 -8
- package/dist/es/framer-motion/dist/es/render/utils/resolve-variants.mjs +0 -36
- package/dist/es/framer-motion/dist/es/render/utils/setters.mjs +0 -31
- package/dist/es/framer-motion/dist/es/render/utils/variant-props.mjs +0 -12
- package/dist/es/framer-motion/dist/es/utils/delay.mjs +0 -24
- package/dist/es/framer-motion/dist/es/utils/distance.mjs +0 -9
- package/dist/es/framer-motion/dist/es/utils/get-context-window.mjs +0 -6
- package/dist/es/framer-motion/dist/es/utils/is-browser.mjs +0 -3
- package/dist/es/framer-motion/dist/es/utils/is-ref-object.mjs +0 -7
- package/dist/es/framer-motion/dist/es/utils/reduced-motion/index.mjs +0 -19
- package/dist/es/framer-motion/dist/es/utils/reduced-motion/state.mjs +0 -5
- package/dist/es/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion-config.mjs +0 -19
- package/dist/es/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.mjs +0 -47
- package/dist/es/framer-motion/dist/es/utils/shallow-compare.mjs +0 -14
- package/dist/es/framer-motion/dist/es/utils/use-animation-frame.mjs +0 -21
- package/dist/es/framer-motion/dist/es/utils/use-constant.mjs +0 -18
- package/dist/es/framer-motion/dist/es/utils/use-cycle.mjs +0 -47
- package/dist/es/framer-motion/dist/es/utils/use-force-update.mjs +0 -19
- package/dist/es/framer-motion/dist/es/utils/use-in-view.mjs +0 -23
- package/dist/es/framer-motion/dist/es/utils/use-instant-transition.mjs +0 -41
- package/dist/es/framer-motion/dist/es/utils/use-is-mounted.mjs +0 -15
- package/dist/es/framer-motion/dist/es/utils/use-isomorphic-effect.mjs +0 -6
- package/dist/es/framer-motion/dist/es/utils/use-motion-value-event.mjs +0 -13
- package/dist/es/framer-motion/dist/es/utils/use-unmount-effect.mjs +0 -7
- package/dist/es/framer-motion/dist/es/value/scroll/use-element-scroll.mjs +0 -14
- package/dist/es/framer-motion/dist/es/value/scroll/use-viewport-scroll.mjs +0 -14
- package/dist/es/framer-motion/dist/es/value/use-combine-values.mjs +0 -37
- package/dist/es/framer-motion/dist/es/value/use-computed.mjs +0 -19
- package/dist/es/framer-motion/dist/es/value/use-inverted-scale.mjs +0 -52
- package/dist/es/framer-motion/dist/es/value/use-motion-template.mjs +0 -45
- package/dist/es/framer-motion/dist/es/value/use-motion-value.mjs +0 -38
- package/dist/es/framer-motion/dist/es/value/use-scroll.mjs +0 -39
- package/dist/es/framer-motion/dist/es/value/use-spring.mjs +0 -22
- package/dist/es/framer-motion/dist/es/value/use-time.mjs +0 -10
- package/dist/es/framer-motion/dist/es/value/use-transform.mjs +0 -29
- package/dist/es/framer-motion/dist/es/value/use-velocity.mjs +0 -35
- package/dist/es/framer-motion/dist/es/value/use-will-change/WillChangeMotionValue.mjs +0 -21
- package/dist/es/framer-motion/dist/es/value/use-will-change/add-will-change.mjs +0 -20
- package/dist/es/framer-motion/dist/es/value/use-will-change/index.mjs +0 -8
- package/dist/es/framer-motion/dist/es/value/use-will-change/is.mjs +0 -7
- package/dist/es/framer-motion/dist/es/value/utils/resolve-motion-value.mjs +0 -12
- package/dist/es/motion/lib/debug.mjs +0 -1
- package/dist/es/motion/lib/index.mjs +0 -131
- package/dist/es/motion/lib/mini.mjs +0 -2
- package/dist/es/motion/lib/react-client.mjs +0 -3
- package/dist/es/motion/lib/react-m.mjs +0 -3
- package/dist/es/motion/lib/react-mini.mjs +0 -2
- package/dist/es/motion/lib/react.mjs +0 -204
- package/dist/es/motion-dom/dist/es/animation/AsyncMotionValueAnimation.mjs +0 -175
- package/dist/es/motion-dom/dist/es/animation/GroupAnimation.mjs +0 -72
- package/dist/es/motion-dom/dist/es/animation/GroupAnimationWithThen.mjs +0 -9
- package/dist/es/motion-dom/dist/es/animation/JSAnimation.mjs +0 -348
- package/dist/es/motion-dom/dist/es/animation/NativeAnimation.mjs +0 -158
- package/dist/es/motion-dom/dist/es/animation/NativeAnimationExtended.mjs +0 -65
- package/dist/es/motion-dom/dist/es/animation/NativeAnimationWrapper.mjs +0 -14
- package/dist/es/motion-dom/dist/es/animation/drivers/frame.mjs +0 -17
- package/dist/es/motion-dom/dist/es/animation/generators/inertia.mjs +0 -87
- package/dist/es/motion-dom/dist/es/animation/generators/keyframes.mjs +0 -51
- package/dist/es/motion-dom/dist/es/animation/generators/spring/defaults.mjs +0 -27
- package/dist/es/motion-dom/dist/es/animation/generators/spring/find.mjs +0 -86
- package/dist/es/motion-dom/dist/es/animation/generators/spring/index.mjs +0 -176
- package/dist/es/motion-dom/dist/es/animation/generators/utils/calc-duration.mjs +0 -17
- package/dist/es/motion-dom/dist/es/animation/generators/utils/create-generator-easing.mjs +0 -19
- package/dist/es/motion-dom/dist/es/animation/generators/utils/is-generator.mjs +0 -5
- package/dist/es/motion-dom/dist/es/animation/generators/utils/velocity.mjs +0 -9
- package/dist/es/motion-dom/dist/es/animation/keyframes/DOMKeyframesResolver.mjs +0 -131
- package/dist/es/motion-dom/dist/es/animation/keyframes/KeyframesResolver.mjs +0 -147
- package/dist/es/motion-dom/dist/es/animation/keyframes/get-final.mjs +0 -11
- package/dist/es/motion-dom/dist/es/animation/keyframes/offsets/default.mjs +0 -9
- package/dist/es/motion-dom/dist/es/animation/keyframes/offsets/fill.mjs +0 -12
- package/dist/es/motion-dom/dist/es/animation/keyframes/offsets/time.mjs +0 -5
- package/dist/es/motion-dom/dist/es/animation/keyframes/utils/apply-px-defaults.mjs +0 -11
- package/dist/es/motion-dom/dist/es/animation/keyframes/utils/fill-wildcards.mjs +0 -7
- package/dist/es/motion-dom/dist/es/animation/keyframes/utils/is-none.mjs +0 -15
- package/dist/es/motion-dom/dist/es/animation/keyframes/utils/make-none-animatable.mjs +0 -30
- package/dist/es/motion-dom/dist/es/animation/keyframes/utils/unit-conversion.mjs +0 -36
- package/dist/es/motion-dom/dist/es/animation/utils/WithPromise.mjs +0 -26
- package/dist/es/motion-dom/dist/es/animation/utils/active-animations.mjs +0 -9
- package/dist/es/motion-dom/dist/es/animation/utils/can-animate.mjs +0 -42
- package/dist/es/motion-dom/dist/es/animation/utils/css-variables-conversion.mjs +0 -42
- package/dist/es/motion-dom/dist/es/animation/utils/get-value-transition.mjs +0 -7
- package/dist/es/motion-dom/dist/es/animation/utils/is-animatable.mjs +0 -30
- package/dist/es/motion-dom/dist/es/animation/utils/is-css-variable.mjs +0 -15
- package/dist/es/motion-dom/dist/es/animation/utils/replace-transition-type.mjs +0 -18
- package/dist/es/motion-dom/dist/es/animation/waapi/easing/cubic-bezier.mjs +0 -3
- package/dist/es/motion-dom/dist/es/animation/waapi/easing/is-supported.mjs +0 -14
- package/dist/es/motion-dom/dist/es/animation/waapi/easing/map-easing.mjs +0 -28
- package/dist/es/motion-dom/dist/es/animation/waapi/easing/supported.mjs +0 -15
- package/dist/es/motion-dom/dist/es/animation/waapi/start-waapi-animation.mjs +0 -39
- package/dist/es/motion-dom/dist/es/animation/waapi/supports/partial-keyframes.mjs +0 -13
- package/dist/es/motion-dom/dist/es/animation/waapi/supports/waapi.mjs +0 -37
- package/dist/es/motion-dom/dist/es/animation/waapi/utils/accelerated-values.mjs +0 -14
- package/dist/es/motion-dom/dist/es/animation/waapi/utils/apply-generator.mjs +0 -15
- package/dist/es/motion-dom/dist/es/animation/waapi/utils/linear.mjs +0 -12
- package/dist/es/motion-dom/dist/es/animation/waapi/utils/px-values.mjs +0 -39
- package/dist/es/motion-dom/dist/es/animation/waapi/utils/unsupported-easing.mjs +0 -20
- package/dist/es/motion-dom/dist/es/effects/MotionValueState.mjs +0 -47
- package/dist/es/motion-dom/dist/es/effects/attr/index.mjs +0 -41
- package/dist/es/motion-dom/dist/es/effects/prop/index.mjs +0 -9
- package/dist/es/motion-dom/dist/es/effects/style/index.mjs +0 -52
- package/dist/es/motion-dom/dist/es/effects/style/transform.mjs +0 -38
- package/dist/es/motion-dom/dist/es/effects/svg/index.mjs +0 -41
- package/dist/es/motion-dom/dist/es/effects/utils/create-dom-effect.mjs +0 -18
- package/dist/es/motion-dom/dist/es/effects/utils/create-effect.mjs +0 -21
- package/dist/es/motion-dom/dist/es/frameloop/batcher.mjs +0 -71
- package/dist/es/motion-dom/dist/es/frameloop/frame.mjs +0 -6
- package/dist/es/motion-dom/dist/es/frameloop/index-legacy.mjs +0 -20
- package/dist/es/motion-dom/dist/es/frameloop/microtask.mjs +0 -6
- package/dist/es/motion-dom/dist/es/frameloop/order.mjs +0 -12
- package/dist/es/motion-dom/dist/es/frameloop/render-step.mjs +0 -92
- package/dist/es/motion-dom/dist/es/frameloop/sync-time.mjs +0 -31
- package/dist/es/motion-dom/dist/es/gestures/drag/state/is-active.mjs +0 -9
- package/dist/es/motion-dom/dist/es/gestures/drag/state/set-active.mjs +0 -28
- package/dist/es/motion-dom/dist/es/gestures/hover.mjs +0 -37
- package/dist/es/motion-dom/dist/es/gestures/press/index.mjs +0 -83
- package/dist/es/motion-dom/dist/es/gestures/press/utils/is-keyboard-accessible.mjs +0 -13
- package/dist/es/motion-dom/dist/es/gestures/press/utils/keyboard.mjs +0 -38
- package/dist/es/motion-dom/dist/es/gestures/press/utils/state.mjs +0 -3
- package/dist/es/motion-dom/dist/es/gestures/utils/is-node-or-child.mjs +0 -20
- package/dist/es/motion-dom/dist/es/gestures/utils/is-primary-pointer.mjs +0 -18
- package/dist/es/motion-dom/dist/es/gestures/utils/setup.mjs +0 -15
- package/dist/es/motion-dom/dist/es/render/dom/is-css-var.mjs +0 -3
- package/dist/es/motion-dom/dist/es/render/dom/parse-transform.mjs +0 -83
- package/dist/es/motion-dom/dist/es/render/dom/style-computed.mjs +0 -10
- package/dist/es/motion-dom/dist/es/render/dom/style-set.mjs +0 -9
- package/dist/es/motion-dom/dist/es/render/dom/utils/camel-to-dash.mjs +0 -5
- package/dist/es/motion-dom/dist/es/render/utils/keys-position.mjs +0 -13
- package/dist/es/motion-dom/dist/es/render/utils/keys-transform.mjs +0 -28
- package/dist/es/motion-dom/dist/es/resize/handle-element.mjs +0 -63
- package/dist/es/motion-dom/dist/es/resize/handle-window.mjs +0 -31
- package/dist/es/motion-dom/dist/es/resize/index.mjs +0 -8
- package/dist/es/motion-dom/dist/es/scroll/observe.mjs +0 -18
- package/dist/es/motion-dom/dist/es/stats/animation-count.mjs +0 -7
- package/dist/es/motion-dom/dist/es/stats/buffer.mjs +0 -6
- package/dist/es/motion-dom/dist/es/stats/index.mjs +0 -117
- package/dist/es/motion-dom/dist/es/utils/interpolate.mjs +0 -79
- package/dist/es/motion-dom/dist/es/utils/is-html-element.mjs +0 -11
- package/dist/es/motion-dom/dist/es/utils/is-svg-element.mjs +0 -11
- package/dist/es/motion-dom/dist/es/utils/is-svg-svg-element.mjs +0 -11
- package/dist/es/motion-dom/dist/es/utils/mix/color.mjs +0 -47
- package/dist/es/motion-dom/dist/es/utils/mix/complex.mjs +0 -93
- package/dist/es/motion-dom/dist/es/utils/mix/immediate.mjs +0 -5
- package/dist/es/motion-dom/dist/es/utils/mix/index.mjs +0 -14
- package/dist/es/motion-dom/dist/es/utils/mix/number.mjs +0 -26
- package/dist/es/motion-dom/dist/es/utils/mix/visibility.mjs +0 -16
- package/dist/es/motion-dom/dist/es/utils/resolve-elements.mjs +0 -17
- package/dist/es/motion-dom/dist/es/utils/supports/flags.mjs +0 -7
- package/dist/es/motion-dom/dist/es/utils/supports/linear-easing.mjs +0 -15
- package/dist/es/motion-dom/dist/es/utils/supports/memo.mjs +0 -9
- package/dist/es/motion-dom/dist/es/utils/supports/scroll-timeline.mjs +0 -5
- package/dist/es/motion-dom/dist/es/utils/transform.mjs +0 -14
- package/dist/es/motion-dom/dist/es/value/index.mjs +0 -329
- package/dist/es/motion-dom/dist/es/value/map-value.mjs +0 -46
- package/dist/es/motion-dom/dist/es/value/spring-value.mjs +0 -72
- package/dist/es/motion-dom/dist/es/value/subscribe-value.mjs +0 -13
- package/dist/es/motion-dom/dist/es/value/transform-value.mjs +0 -35
- package/dist/es/motion-dom/dist/es/value/types/auto.mjs +0 -9
- package/dist/es/motion-dom/dist/es/value/types/color/hex.mjs +0 -40
- package/dist/es/motion-dom/dist/es/value/types/color/hsla-to-rgba.mjs +0 -42
- package/dist/es/motion-dom/dist/es/value/types/color/hsla.mjs +0 -22
- package/dist/es/motion-dom/dist/es/value/types/color/index.mjs +0 -32
- package/dist/es/motion-dom/dist/es/value/types/color/rgba.mjs +0 -25
- package/dist/es/motion-dom/dist/es/value/types/color/utils.mjs +0 -29
- package/dist/es/motion-dom/dist/es/value/types/complex/filter.mjs +0 -30
- package/dist/es/motion-dom/dist/es/value/types/complex/index.mjs +0 -91
- package/dist/es/motion-dom/dist/es/value/types/dimensions.mjs +0 -15
- package/dist/es/motion-dom/dist/es/value/types/int.mjs +0 -8
- package/dist/es/motion-dom/dist/es/value/types/maps/defaults.mjs +0 -30
- package/dist/es/motion-dom/dist/es/value/types/maps/number.mjs +0 -50
- package/dist/es/motion-dom/dist/es/value/types/maps/transform.mjs +0 -31
- package/dist/es/motion-dom/dist/es/value/types/numbers/index.mjs +0 -17
- package/dist/es/motion-dom/dist/es/value/types/numbers/units.mjs +0 -18
- package/dist/es/motion-dom/dist/es/value/types/test.mjs +0 -6
- package/dist/es/motion-dom/dist/es/value/types/utils/animatable-none.mjs +0 -15
- package/dist/es/motion-dom/dist/es/value/types/utils/color-regex.mjs +0 -3
- package/dist/es/motion-dom/dist/es/value/types/utils/find.mjs +0 -15
- package/dist/es/motion-dom/dist/es/value/types/utils/float-regex.mjs +0 -3
- package/dist/es/motion-dom/dist/es/value/types/utils/get-as-type.mjs +0 -10
- package/dist/es/motion-dom/dist/es/value/types/utils/is-nullish.mjs +0 -5
- package/dist/es/motion-dom/dist/es/value/types/utils/sanitize.mjs +0 -5
- package/dist/es/motion-dom/dist/es/value/types/utils/single-color-regex.mjs +0 -3
- package/dist/es/motion-dom/dist/es/value/utils/is-motion-value.mjs +0 -3
- package/dist/es/motion-dom/dist/es/view/index.mjs +0 -64
- package/dist/es/motion-dom/dist/es/view/queue.mjs +0 -52
- package/dist/es/motion-dom/dist/es/view/start.mjs +0 -155
- package/dist/es/motion-dom/dist/es/view/utils/choose-layer-type.mjs +0 -11
- package/dist/es/motion-dom/dist/es/view/utils/css.mjs +0 -32
- package/dist/es/motion-dom/dist/es/view/utils/get-layer-name.mjs +0 -8
- package/dist/es/motion-dom/dist/es/view/utils/get-view-animations.mjs +0 -12
- package/dist/es/motion-dom/dist/es/view/utils/has-target.mjs +0 -5
- package/dist/es/motion-utils/dist/es/array.mjs +0 -21
- package/dist/es/motion-utils/dist/es/clamp.mjs +0 -9
- package/dist/es/motion-utils/dist/es/easing/anticipate.mjs +0 -5
- package/dist/es/motion-utils/dist/es/easing/back.mjs +0 -9
- package/dist/es/motion-utils/dist/es/easing/circ.mjs +0 -8
- package/dist/es/motion-utils/dist/es/easing/cubic-bezier.mjs +0 -51
- package/dist/es/motion-utils/dist/es/easing/ease.mjs +0 -7
- package/dist/es/motion-utils/dist/es/easing/modifiers/mirror.mjs +0 -5
- package/dist/es/motion-utils/dist/es/easing/modifiers/reverse.mjs +0 -5
- package/dist/es/motion-utils/dist/es/easing/steps.mjs +0 -15
- package/dist/es/motion-utils/dist/es/easing/utils/get-easing-for-segment.mjs +0 -8
- package/dist/es/motion-utils/dist/es/easing/utils/is-bezier-definition.mjs +0 -3
- package/dist/es/motion-utils/dist/es/easing/utils/is-easing-array.mjs +0 -5
- package/dist/es/motion-utils/dist/es/easing/utils/map.mjs +0 -41
- package/dist/es/motion-utils/dist/es/errors.mjs +0 -16
- package/dist/es/motion-utils/dist/es/global-config.mjs +0 -3
- package/dist/es/motion-utils/dist/es/is-numerical-string.mjs +0 -6
- package/dist/es/motion-utils/dist/es/is-object.mjs +0 -5
- package/dist/es/motion-utils/dist/es/is-zero-value-string.mjs +0 -6
- package/dist/es/motion-utils/dist/es/memo.mjs +0 -11
- package/dist/es/motion-utils/dist/es/noop.mjs +0 -4
- package/dist/es/motion-utils/dist/es/pipe.mjs +0 -11
- package/dist/es/motion-utils/dist/es/progress.mjs +0 -19
- package/dist/es/motion-utils/dist/es/subscription-manager.mjs +0 -40
- package/dist/es/motion-utils/dist/es/time-conversion.mjs +0 -12
- package/dist/es/motion-utils/dist/es/velocity-per-second.mjs +0 -11
- package/dist/es/motion-utils/dist/es/warn-once.mjs +0 -14
- package/dist/es/motion-utils/dist/es/wrap.mjs +0 -6
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { useMemo } from 'react';
|
|
2
|
-
import { isForcedMotionValue } from '../../motion/utils/is-forced-motion-value.mjs';
|
|
3
|
-
import { buildHTMLStyles } from './utils/build-styles.mjs';
|
|
4
|
-
import { createHtmlRenderState } from './utils/create-render-state.mjs';
|
|
5
|
-
import { isMotionValue } from '../../../../../motion-dom/dist/es/value/utils/is-motion-value.mjs';
|
|
6
|
-
|
|
7
|
-
function copyRawValuesOnly(target, source, props) {
|
|
8
|
-
for (const key in source) {
|
|
9
|
-
if (!isMotionValue(source[key]) && !isForcedMotionValue(key, props)) {
|
|
10
|
-
target[key] = source[key];
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
function useInitialMotionValues({ transformTemplate }, visualState) {
|
|
15
|
-
return useMemo(() => {
|
|
16
|
-
const state = createHtmlRenderState();
|
|
17
|
-
buildHTMLStyles(state, visualState, transformTemplate);
|
|
18
|
-
return Object.assign({}, state.vars, state.style);
|
|
19
|
-
}, [visualState]);
|
|
20
|
-
}
|
|
21
|
-
function useStyle(props, visualState) {
|
|
22
|
-
const styleProp = props.style || {};
|
|
23
|
-
const style = {};
|
|
24
|
-
/**
|
|
25
|
-
* Copy non-Motion Values straight into style
|
|
26
|
-
*/
|
|
27
|
-
copyRawValuesOnly(style, styleProp, props);
|
|
28
|
-
Object.assign(style, useInitialMotionValues(props, visualState));
|
|
29
|
-
return style;
|
|
30
|
-
}
|
|
31
|
-
function useHTMLProps(props, visualState) {
|
|
32
|
-
// The `any` isn't ideal but it is the type of createElement props argument
|
|
33
|
-
const htmlProps = {};
|
|
34
|
-
const style = useStyle(props, visualState);
|
|
35
|
-
if (props.drag && props.dragListener !== false) {
|
|
36
|
-
// Disable the ghost element when a user drags
|
|
37
|
-
htmlProps.draggable = false;
|
|
38
|
-
// Disable text selection
|
|
39
|
-
style.userSelect =
|
|
40
|
-
style.WebkitUserSelect =
|
|
41
|
-
style.WebkitTouchCallout =
|
|
42
|
-
"none";
|
|
43
|
-
// Disable scrolling on the draggable direction
|
|
44
|
-
style.touchAction =
|
|
45
|
-
props.drag === true
|
|
46
|
-
? "none"
|
|
47
|
-
: `pan-${props.drag === "x" ? "y" : "x"}`;
|
|
48
|
-
}
|
|
49
|
-
if (props.tabIndex === undefined &&
|
|
50
|
-
(props.onTap || props.onTapStart || props.whileTap)) {
|
|
51
|
-
htmlProps.tabIndex = 0;
|
|
52
|
-
}
|
|
53
|
-
htmlProps.style = style;
|
|
54
|
-
return htmlProps;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
export { copyRawValuesOnly, useHTMLProps };
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import { buildTransform } from './build-transform.mjs';
|
|
2
|
-
import { transformProps } from '../../../../../../motion-dom/dist/es/render/utils/keys-transform.mjs';
|
|
3
|
-
import { isCSSVariableName } from '../../../../../../motion-dom/dist/es/animation/utils/is-css-variable.mjs';
|
|
4
|
-
import { getValueAsType } from '../../../../../../motion-dom/dist/es/value/types/utils/get-as-type.mjs';
|
|
5
|
-
import { numberValueTypes } from '../../../../../../motion-dom/dist/es/value/types/maps/number.mjs';
|
|
6
|
-
|
|
7
|
-
function buildHTMLStyles(state, latestValues, transformTemplate) {
|
|
8
|
-
const { style, vars, transformOrigin } = state;
|
|
9
|
-
// Track whether we encounter any transform or transformOrigin values.
|
|
10
|
-
let hasTransform = false;
|
|
11
|
-
let hasTransformOrigin = false;
|
|
12
|
-
/**
|
|
13
|
-
* Loop over all our latest animated values and decide whether to handle them
|
|
14
|
-
* as a style or CSS variable.
|
|
15
|
-
*
|
|
16
|
-
* Transforms and transform origins are kept separately for further processing.
|
|
17
|
-
*/
|
|
18
|
-
for (const key in latestValues) {
|
|
19
|
-
const value = latestValues[key];
|
|
20
|
-
if (transformProps.has(key)) {
|
|
21
|
-
// If this is a transform, flag to enable further transform processing
|
|
22
|
-
hasTransform = true;
|
|
23
|
-
continue;
|
|
24
|
-
}
|
|
25
|
-
else if (isCSSVariableName(key)) {
|
|
26
|
-
vars[key] = value;
|
|
27
|
-
continue;
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
// Convert the value to its default value type, ie 0 -> "0px"
|
|
31
|
-
const valueAsType = getValueAsType(value, numberValueTypes[key]);
|
|
32
|
-
if (key.startsWith("origin")) {
|
|
33
|
-
// If this is a transform origin, flag and enable further transform-origin processing
|
|
34
|
-
hasTransformOrigin = true;
|
|
35
|
-
transformOrigin[key] =
|
|
36
|
-
valueAsType;
|
|
37
|
-
}
|
|
38
|
-
else {
|
|
39
|
-
style[key] = valueAsType;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
if (!latestValues.transform) {
|
|
44
|
-
if (hasTransform || transformTemplate) {
|
|
45
|
-
style.transform = buildTransform(latestValues, state.transform, transformTemplate);
|
|
46
|
-
}
|
|
47
|
-
else if (style.transform) {
|
|
48
|
-
/**
|
|
49
|
-
* If we have previously created a transform but currently don't have any,
|
|
50
|
-
* reset transform style to none.
|
|
51
|
-
*/
|
|
52
|
-
style.transform = "none";
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Build a transformOrigin style. Uses the same defaults as the browser for
|
|
57
|
-
* undefined origins.
|
|
58
|
-
*/
|
|
59
|
-
if (hasTransformOrigin) {
|
|
60
|
-
const { originX = "50%", originY = "50%", originZ = 0, } = transformOrigin;
|
|
61
|
-
style.transformOrigin = `${originX} ${originY} ${originZ}`;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
export { buildHTMLStyles };
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import { transformPropOrder } from '../../../../../../motion-dom/dist/es/render/utils/keys-transform.mjs';
|
|
2
|
-
import { getValueAsType } from '../../../../../../motion-dom/dist/es/value/types/utils/get-as-type.mjs';
|
|
3
|
-
import { numberValueTypes } from '../../../../../../motion-dom/dist/es/value/types/maps/number.mjs';
|
|
4
|
-
|
|
5
|
-
const translateAlias = {
|
|
6
|
-
x: "translateX",
|
|
7
|
-
y: "translateY",
|
|
8
|
-
z: "translateZ",
|
|
9
|
-
transformPerspective: "perspective",
|
|
10
|
-
};
|
|
11
|
-
const numTransforms = transformPropOrder.length;
|
|
12
|
-
/**
|
|
13
|
-
* Build a CSS transform style from individual x/y/scale etc properties.
|
|
14
|
-
*
|
|
15
|
-
* This outputs with a default order of transforms/scales/rotations, this can be customised by
|
|
16
|
-
* providing a transformTemplate function.
|
|
17
|
-
*/
|
|
18
|
-
function buildTransform(latestValues, transform, transformTemplate) {
|
|
19
|
-
// The transform string we're going to build into.
|
|
20
|
-
let transformString = "";
|
|
21
|
-
let transformIsDefault = true;
|
|
22
|
-
/**
|
|
23
|
-
* Loop over all possible transforms in order, adding the ones that
|
|
24
|
-
* are present to the transform string.
|
|
25
|
-
*/
|
|
26
|
-
for (let i = 0; i < numTransforms; i++) {
|
|
27
|
-
const key = transformPropOrder[i];
|
|
28
|
-
const value = latestValues[key];
|
|
29
|
-
if (value === undefined)
|
|
30
|
-
continue;
|
|
31
|
-
let valueIsDefault = true;
|
|
32
|
-
if (typeof value === "number") {
|
|
33
|
-
valueIsDefault = value === (key.startsWith("scale") ? 1 : 0);
|
|
34
|
-
}
|
|
35
|
-
else {
|
|
36
|
-
valueIsDefault = parseFloat(value) === 0;
|
|
37
|
-
}
|
|
38
|
-
if (!valueIsDefault || transformTemplate) {
|
|
39
|
-
const valueAsType = getValueAsType(value, numberValueTypes[key]);
|
|
40
|
-
if (!valueIsDefault) {
|
|
41
|
-
transformIsDefault = false;
|
|
42
|
-
const transformName = translateAlias[key] || key;
|
|
43
|
-
transformString += `${transformName}(${valueAsType}) `;
|
|
44
|
-
}
|
|
45
|
-
if (transformTemplate) {
|
|
46
|
-
transform[key] = valueAsType;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
transformString = transformString.trim();
|
|
51
|
-
// If we have a custom `transform` template, pass our transform values and
|
|
52
|
-
// generated transformString to that before returning
|
|
53
|
-
if (transformTemplate) {
|
|
54
|
-
transformString = transformTemplate(transform, transformIsDefault ? "" : transformString);
|
|
55
|
-
}
|
|
56
|
-
else if (transformIsDefault) {
|
|
57
|
-
transformString = "none";
|
|
58
|
-
}
|
|
59
|
-
return transformString;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
export { buildTransform };
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
function renderHTML(element, { style, vars }, styleProp, projection) {
|
|
2
|
-
Object.assign(element.style, style, projection && projection.getProjectionStyles(styleProp));
|
|
3
|
-
// Loop over any CSS variables and assign those.
|
|
4
|
-
for (const key in vars) {
|
|
5
|
-
element.style.setProperty(key, vars[key]);
|
|
6
|
-
}
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export { renderHTML };
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { isForcedMotionValue } from '../../../motion/utils/is-forced-motion-value.mjs';
|
|
2
|
-
import { isMotionValue } from '../../../../../../motion-dom/dist/es/value/utils/is-motion-value.mjs';
|
|
3
|
-
|
|
4
|
-
function scrapeMotionValuesFromProps(props, prevProps, visualElement) {
|
|
5
|
-
const { style } = props;
|
|
6
|
-
const newValues = {};
|
|
7
|
-
for (const key in style) {
|
|
8
|
-
if (isMotionValue(style[key]) ||
|
|
9
|
-
(prevProps.style &&
|
|
10
|
-
isMotionValue(prevProps.style[key])) ||
|
|
11
|
-
isForcedMotionValue(key, props) ||
|
|
12
|
-
visualElement?.getValue(key)?.liveStyle !== undefined) {
|
|
13
|
-
newValues[key] = style[key];
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
return newValues;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export { scrapeMotionValuesFromProps };
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { createBox } from '../../projection/geometry/models.mjs';
|
|
2
|
-
import { VisualElement } from '../VisualElement.mjs';
|
|
3
|
-
|
|
4
|
-
function isObjectKey(key, object) {
|
|
5
|
-
return key in object;
|
|
6
|
-
}
|
|
7
|
-
class ObjectVisualElement extends VisualElement {
|
|
8
|
-
constructor() {
|
|
9
|
-
super(...arguments);
|
|
10
|
-
this.type = "object";
|
|
11
|
-
}
|
|
12
|
-
readValueFromInstance(instance, key) {
|
|
13
|
-
if (isObjectKey(key, instance)) {
|
|
14
|
-
const value = instance[key];
|
|
15
|
-
if (typeof value === "string" || typeof value === "number") {
|
|
16
|
-
return value;
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
return undefined;
|
|
20
|
-
}
|
|
21
|
-
getBaseTargetFromProps() {
|
|
22
|
-
return undefined;
|
|
23
|
-
}
|
|
24
|
-
removeValueFromRenderState(key, renderState) {
|
|
25
|
-
delete renderState.output[key];
|
|
26
|
-
}
|
|
27
|
-
measureInstanceViewportBox() {
|
|
28
|
-
return createBox();
|
|
29
|
-
}
|
|
30
|
-
build(renderState, latestValues) {
|
|
31
|
-
Object.assign(renderState.output, latestValues);
|
|
32
|
-
}
|
|
33
|
-
renderInstance(instance, { output }) {
|
|
34
|
-
Object.assign(instance, output);
|
|
35
|
-
}
|
|
36
|
-
sortInstanceNodePosition() {
|
|
37
|
-
return 0;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
export { ObjectVisualElement };
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import { createBox } from '../../projection/geometry/models.mjs';
|
|
2
|
-
import { DOMVisualElement } from '../dom/DOMVisualElement.mjs';
|
|
3
|
-
import { camelToDash } from '../dom/utils/camel-to-dash.mjs';
|
|
4
|
-
import { buildSVGAttrs } from './utils/build-attrs.mjs';
|
|
5
|
-
import { camelCaseAttributes } from './utils/camel-case-attrs.mjs';
|
|
6
|
-
import { isSVGTag } from './utils/is-svg-tag.mjs';
|
|
7
|
-
import { renderSVG } from './utils/render.mjs';
|
|
8
|
-
import { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';
|
|
9
|
-
import { transformProps } from '../../../../../motion-dom/dist/es/render/utils/keys-transform.mjs';
|
|
10
|
-
import { getDefaultValueType } from '../../../../../motion-dom/dist/es/value/types/maps/defaults.mjs';
|
|
11
|
-
|
|
12
|
-
class SVGVisualElement extends DOMVisualElement {
|
|
13
|
-
constructor() {
|
|
14
|
-
super(...arguments);
|
|
15
|
-
this.type = "svg";
|
|
16
|
-
this.isSVGTag = false;
|
|
17
|
-
this.measureInstanceViewportBox = createBox;
|
|
18
|
-
}
|
|
19
|
-
getBaseTargetFromProps(props, key) {
|
|
20
|
-
return props[key];
|
|
21
|
-
}
|
|
22
|
-
readValueFromInstance(instance, key) {
|
|
23
|
-
if (transformProps.has(key)) {
|
|
24
|
-
const defaultType = getDefaultValueType(key);
|
|
25
|
-
return defaultType ? defaultType.default || 0 : 0;
|
|
26
|
-
}
|
|
27
|
-
key = !camelCaseAttributes.has(key) ? camelToDash(key) : key;
|
|
28
|
-
return instance.getAttribute(key);
|
|
29
|
-
}
|
|
30
|
-
scrapeMotionValuesFromProps(props, prevProps, visualElement) {
|
|
31
|
-
return scrapeMotionValuesFromProps(props, prevProps, visualElement);
|
|
32
|
-
}
|
|
33
|
-
build(renderState, latestValues, props) {
|
|
34
|
-
buildSVGAttrs(renderState, latestValues, this.isSVGTag, props.transformTemplate, props.style);
|
|
35
|
-
}
|
|
36
|
-
renderInstance(instance, renderState, styleProp, projection) {
|
|
37
|
-
renderSVG(instance, renderState, styleProp, projection);
|
|
38
|
-
}
|
|
39
|
-
mount(instance) {
|
|
40
|
-
this.isSVGTag = isSVGTag(instance.tagName);
|
|
41
|
-
super.mount(instance);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
export { SVGVisualElement };
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { makeUseVisualState } from '../../motion/utils/use-visual-state.mjs';
|
|
2
|
-
import { createSvgRenderState } from './utils/create-render-state.mjs';
|
|
3
|
-
import { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';
|
|
4
|
-
|
|
5
|
-
const svgMotionConfig = {
|
|
6
|
-
useVisualState: makeUseVisualState({
|
|
7
|
-
scrapeMotionValuesFromProps: scrapeMotionValuesFromProps,
|
|
8
|
-
createRenderState: createSvgRenderState,
|
|
9
|
-
}),
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
export { svgMotionConfig };
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* We keep these listed separately as we use the lowercase tag names as part
|
|
3
|
-
* of the runtime bundle to detect SVG components
|
|
4
|
-
*/
|
|
5
|
-
const lowercaseSVGElements = [
|
|
6
|
-
"animate",
|
|
7
|
-
"circle",
|
|
8
|
-
"defs",
|
|
9
|
-
"desc",
|
|
10
|
-
"ellipse",
|
|
11
|
-
"g",
|
|
12
|
-
"image",
|
|
13
|
-
"line",
|
|
14
|
-
"filter",
|
|
15
|
-
"marker",
|
|
16
|
-
"mask",
|
|
17
|
-
"metadata",
|
|
18
|
-
"path",
|
|
19
|
-
"pattern",
|
|
20
|
-
"polygon",
|
|
21
|
-
"polyline",
|
|
22
|
-
"rect",
|
|
23
|
-
"stop",
|
|
24
|
-
"switch",
|
|
25
|
-
"symbol",
|
|
26
|
-
"svg",
|
|
27
|
-
"text",
|
|
28
|
-
"tspan",
|
|
29
|
-
"use",
|
|
30
|
-
"view",
|
|
31
|
-
];
|
|
32
|
-
|
|
33
|
-
export { lowercaseSVGElements };
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { useMemo } from 'react';
|
|
2
|
-
import { copyRawValuesOnly } from '../html/use-props.mjs';
|
|
3
|
-
import { buildSVGAttrs } from './utils/build-attrs.mjs';
|
|
4
|
-
import { createSvgRenderState } from './utils/create-render-state.mjs';
|
|
5
|
-
import { isSVGTag } from './utils/is-svg-tag.mjs';
|
|
6
|
-
|
|
7
|
-
function useSVGProps(props, visualState, _isStatic, Component) {
|
|
8
|
-
const visualProps = useMemo(() => {
|
|
9
|
-
const state = createSvgRenderState();
|
|
10
|
-
buildSVGAttrs(state, visualState, isSVGTag(Component), props.transformTemplate, props.style);
|
|
11
|
-
return {
|
|
12
|
-
...state.attrs,
|
|
13
|
-
style: { ...state.style },
|
|
14
|
-
};
|
|
15
|
-
}, [visualState]);
|
|
16
|
-
if (props.style) {
|
|
17
|
-
const rawStyles = {};
|
|
18
|
-
copyRawValuesOnly(rawStyles, props.style, props);
|
|
19
|
-
visualProps.style = { ...rawStyles, ...visualProps.style };
|
|
20
|
-
}
|
|
21
|
-
return visualProps;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export { useSVGProps };
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { buildHTMLStyles } from '../../html/utils/build-styles.mjs';
|
|
2
|
-
import { buildSVGPath } from './path.mjs';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Build SVG visual attrbutes, like cx and style.transform
|
|
6
|
-
*/
|
|
7
|
-
function buildSVGAttrs(state, { attrX, attrY, attrScale, pathLength, pathSpacing = 1, pathOffset = 0,
|
|
8
|
-
// This is object creation, which we try to avoid per-frame.
|
|
9
|
-
...latest }, isSVGTag, transformTemplate, styleProp) {
|
|
10
|
-
buildHTMLStyles(state, latest, transformTemplate);
|
|
11
|
-
/**
|
|
12
|
-
* For svg tags we just want to make sure viewBox is animatable and treat all the styles
|
|
13
|
-
* as normal HTML tags.
|
|
14
|
-
*/
|
|
15
|
-
if (isSVGTag) {
|
|
16
|
-
if (state.style.viewBox) {
|
|
17
|
-
state.attrs.viewBox = state.style.viewBox;
|
|
18
|
-
}
|
|
19
|
-
return;
|
|
20
|
-
}
|
|
21
|
-
state.attrs = state.style;
|
|
22
|
-
state.style = {};
|
|
23
|
-
const { attrs, style } = state;
|
|
24
|
-
/**
|
|
25
|
-
* However, we apply transforms as CSS transforms.
|
|
26
|
-
* So if we detect a transform, transformOrigin we take it from attrs and copy it into style.
|
|
27
|
-
*/
|
|
28
|
-
if (attrs.transform) {
|
|
29
|
-
style.transform = attrs.transform;
|
|
30
|
-
delete attrs.transform;
|
|
31
|
-
}
|
|
32
|
-
if (style.transform || attrs.transformOrigin) {
|
|
33
|
-
style.transformOrigin = attrs.transformOrigin ?? "50% 50%";
|
|
34
|
-
delete attrs.transformOrigin;
|
|
35
|
-
}
|
|
36
|
-
if (style.transform) {
|
|
37
|
-
/**
|
|
38
|
-
* SVG's element transform-origin uses its own median as a reference.
|
|
39
|
-
* Therefore, transformBox becomes a fill-box
|
|
40
|
-
*/
|
|
41
|
-
style.transformBox = styleProp?.transformBox ?? "fill-box";
|
|
42
|
-
delete attrs.transformBox;
|
|
43
|
-
}
|
|
44
|
-
// Render attrX/attrY/attrScale as attributes
|
|
45
|
-
if (attrX !== undefined)
|
|
46
|
-
attrs.x = attrX;
|
|
47
|
-
if (attrY !== undefined)
|
|
48
|
-
attrs.y = attrY;
|
|
49
|
-
if (attrScale !== undefined)
|
|
50
|
-
attrs.scale = attrScale;
|
|
51
|
-
// Build SVG path if one has been defined
|
|
52
|
-
if (pathLength !== undefined) {
|
|
53
|
-
buildSVGPath(attrs, pathLength, pathSpacing, pathOffset, false);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
export { buildSVGAttrs };
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* A set of attribute names that are always read/written as camel case.
|
|
3
|
-
*/
|
|
4
|
-
const camelCaseAttributes = new Set([
|
|
5
|
-
"baseFrequency",
|
|
6
|
-
"diffuseConstant",
|
|
7
|
-
"kernelMatrix",
|
|
8
|
-
"kernelUnitLength",
|
|
9
|
-
"keySplines",
|
|
10
|
-
"keyTimes",
|
|
11
|
-
"limitingConeAngle",
|
|
12
|
-
"markerHeight",
|
|
13
|
-
"markerWidth",
|
|
14
|
-
"numOctaves",
|
|
15
|
-
"targetX",
|
|
16
|
-
"targetY",
|
|
17
|
-
"surfaceScale",
|
|
18
|
-
"specularConstant",
|
|
19
|
-
"specularExponent",
|
|
20
|
-
"stdDeviation",
|
|
21
|
-
"tableValues",
|
|
22
|
-
"viewBox",
|
|
23
|
-
"gradientTransform",
|
|
24
|
-
"pathLength",
|
|
25
|
-
"startOffset",
|
|
26
|
-
"textLength",
|
|
27
|
-
"lengthAdjust",
|
|
28
|
-
]);
|
|
29
|
-
|
|
30
|
-
export { camelCaseAttributes };
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import { px } from '../../../../../../motion-dom/dist/es/value/types/numbers/units.mjs';
|
|
2
|
-
|
|
3
|
-
const dashKeys = {
|
|
4
|
-
offset: "stroke-dashoffset",
|
|
5
|
-
array: "stroke-dasharray",
|
|
6
|
-
};
|
|
7
|
-
const camelKeys = {
|
|
8
|
-
offset: "strokeDashoffset",
|
|
9
|
-
array: "strokeDasharray",
|
|
10
|
-
};
|
|
11
|
-
/**
|
|
12
|
-
* Build SVG path properties. Uses the path's measured length to convert
|
|
13
|
-
* our custom pathLength, pathSpacing and pathOffset into stroke-dashoffset
|
|
14
|
-
* and stroke-dasharray attributes.
|
|
15
|
-
*
|
|
16
|
-
* This function is mutative to reduce per-frame GC.
|
|
17
|
-
*/
|
|
18
|
-
function buildSVGPath(attrs, length, spacing = 1, offset = 0, useDashCase = true) {
|
|
19
|
-
// Normalise path length by setting SVG attribute pathLength to 1
|
|
20
|
-
attrs.pathLength = 1;
|
|
21
|
-
// We use dash case when setting attributes directly to the DOM node and camel case
|
|
22
|
-
// when defining props on a React component.
|
|
23
|
-
const keys = useDashCase ? dashKeys : camelKeys;
|
|
24
|
-
// Build the dash offset
|
|
25
|
-
attrs[keys.offset] = px.transform(-offset);
|
|
26
|
-
// Build the dash array
|
|
27
|
-
const pathLength = px.transform(length);
|
|
28
|
-
const pathSpacing = px.transform(spacing);
|
|
29
|
-
attrs[keys.array] = `${pathLength} ${pathSpacing}`;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export { buildSVGPath };
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { camelToDash } from '../../dom/utils/camel-to-dash.mjs';
|
|
2
|
-
import { renderHTML } from '../../html/utils/render.mjs';
|
|
3
|
-
import { camelCaseAttributes } from './camel-case-attrs.mjs';
|
|
4
|
-
|
|
5
|
-
function renderSVG(element, renderState, _styleProp, projection) {
|
|
6
|
-
renderHTML(element, renderState, undefined, projection);
|
|
7
|
-
for (const key in renderState.attrs) {
|
|
8
|
-
element.setAttribute(!camelCaseAttributes.has(key) ? camelToDash(key) : key, renderState.attrs[key]);
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export { renderSVG };
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { scrapeMotionValuesFromProps as scrapeMotionValuesFromProps$1 } from '../../html/utils/scrape-motion-values.mjs';
|
|
2
|
-
import { isMotionValue } from '../../../../../../motion-dom/dist/es/value/utils/is-motion-value.mjs';
|
|
3
|
-
import { transformPropOrder } from '../../../../../../motion-dom/dist/es/render/utils/keys-transform.mjs';
|
|
4
|
-
|
|
5
|
-
function scrapeMotionValuesFromProps(props, prevProps, visualElement) {
|
|
6
|
-
const newValues = scrapeMotionValuesFromProps$1(props, prevProps, visualElement);
|
|
7
|
-
for (const key in props) {
|
|
8
|
-
if (isMotionValue(props[key]) ||
|
|
9
|
-
isMotionValue(prevProps[key])) {
|
|
10
|
-
const targetKey = transformPropOrder.indexOf(key) !== -1
|
|
11
|
-
? "attr" + key.charAt(0).toUpperCase() + key.substring(1)
|
|
12
|
-
: key;
|
|
13
|
-
newValues[targetKey] = props[key];
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
return newValues;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export { scrapeMotionValuesFromProps };
|