motion 12.18.0 → 12.18.2

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.
Files changed (409) hide show
  1. package/dist/cjs/mini.js +7 -1063
  2. package/dist/es/debug.mjs +1 -0
  3. package/dist/es/index.mjs +1 -0
  4. package/dist/es/mini.mjs +1 -0
  5. package/dist/es/react-client.mjs +2 -0
  6. package/dist/es/react-m.mjs +2 -0
  7. package/dist/es/react-mini.mjs +2 -0
  8. package/dist/es/react.mjs +2 -0
  9. package/dist/motion.js +1 -1
  10. package/mini/package.json +1 -1
  11. package/package.json +11 -11
  12. package/react/package.json +1 -1
  13. package/react-client/package.json +1 -1
  14. package/react-m/package.json +1 -1
  15. package/dist/es/framer-motion/dist/es/animation/animate/index.mjs +0 -34
  16. package/dist/es/framer-motion/dist/es/animation/animate/resolve-subjects.mjs +0 -19
  17. package/dist/es/framer-motion/dist/es/animation/animate/sequence.mjs +0 -14
  18. package/dist/es/framer-motion/dist/es/animation/animate/single-value.mjs +0 -11
  19. package/dist/es/framer-motion/dist/es/animation/animate/subject.mjs +0 -52
  20. package/dist/es/framer-motion/dist/es/animation/animators/waapi/animate-elements.mjs +0 -112
  21. package/dist/es/framer-motion/dist/es/animation/animators/waapi/animate-sequence.mjs +0 -13
  22. package/dist/es/framer-motion/dist/es/animation/animators/waapi/animate-style.mjs +0 -12
  23. package/dist/es/framer-motion/dist/es/animation/animators/waapi/utils/get-final-keyframe.mjs +0 -12
  24. package/dist/es/framer-motion/dist/es/animation/hooks/animation-controls.mjs +0 -80
  25. package/dist/es/framer-motion/dist/es/animation/hooks/use-animate-style.mjs +0 -17
  26. package/dist/es/framer-motion/dist/es/animation/hooks/use-animate.mjs +0 -17
  27. package/dist/es/framer-motion/dist/es/animation/hooks/use-animated-state.mjs +0 -64
  28. package/dist/es/framer-motion/dist/es/animation/hooks/use-animation.mjs +0 -41
  29. package/dist/es/framer-motion/dist/es/animation/interfaces/motion-value.mjs +0 -102
  30. package/dist/es/framer-motion/dist/es/animation/interfaces/visual-element-target.mjs +0 -85
  31. package/dist/es/framer-motion/dist/es/animation/interfaces/visual-element-variant.mjs +0 -65
  32. package/dist/es/framer-motion/dist/es/animation/interfaces/visual-element.mjs +0 -26
  33. package/dist/es/framer-motion/dist/es/animation/optimized-appear/data-id.mjs +0 -6
  34. package/dist/es/framer-motion/dist/es/animation/optimized-appear/get-appear-id.mjs +0 -7
  35. package/dist/es/framer-motion/dist/es/animation/optimized-appear/handoff.mjs +0 -38
  36. package/dist/es/framer-motion/dist/es/animation/optimized-appear/start.mjs +0 -171
  37. package/dist/es/framer-motion/dist/es/animation/optimized-appear/store-id.mjs +0 -8
  38. package/dist/es/framer-motion/dist/es/animation/optimized-appear/store.mjs +0 -4
  39. package/dist/es/framer-motion/dist/es/animation/sequence/create.mjs +0 -256
  40. package/dist/es/framer-motion/dist/es/animation/sequence/utils/calc-repeat-duration.mjs +0 -5
  41. package/dist/es/framer-motion/dist/es/animation/sequence/utils/calc-time.mjs +0 -23
  42. package/dist/es/framer-motion/dist/es/animation/sequence/utils/edit.mjs +0 -31
  43. package/dist/es/framer-motion/dist/es/animation/sequence/utils/normalize-times.mjs +0 -13
  44. package/dist/es/framer-motion/dist/es/animation/sequence/utils/sort.mjs +0 -14
  45. package/dist/es/framer-motion/dist/es/animation/utils/create-visual-element.mjs +0 -45
  46. package/dist/es/framer-motion/dist/es/animation/utils/default-transitions.mjs +0 -40
  47. package/dist/es/framer-motion/dist/es/animation/utils/is-animation-controls.mjs +0 -7
  48. package/dist/es/framer-motion/dist/es/animation/utils/is-dom-keyframes.mjs +0 -5
  49. package/dist/es/framer-motion/dist/es/animation/utils/is-keyframes-target.mjs +0 -5
  50. package/dist/es/framer-motion/dist/es/animation/utils/is-transition-defined.mjs +0 -10
  51. package/dist/es/framer-motion/dist/es/animation/utils/stagger.mjs +0 -26
  52. package/dist/es/framer-motion/dist/es/components/AnimatePresence/PopChild.mjs +0 -87
  53. package/dist/es/framer-motion/dist/es/components/AnimatePresence/PresenceChild.mjs +0 -64
  54. package/dist/es/framer-motion/dist/es/components/AnimatePresence/index.mjs +0 -166
  55. package/dist/es/framer-motion/dist/es/components/AnimatePresence/use-presence-data.mjs +0 -9
  56. package/dist/es/framer-motion/dist/es/components/AnimatePresence/use-presence.mjs +0 -70
  57. package/dist/es/framer-motion/dist/es/components/AnimatePresence/utils.mjs +0 -14
  58. package/dist/es/framer-motion/dist/es/components/AnimateSharedLayout.mjs +0 -15
  59. package/dist/es/framer-motion/dist/es/components/LayoutGroup/index.mjs +0 -32
  60. package/dist/es/framer-motion/dist/es/components/LazyMotion/index.mjs +0 -68
  61. package/dist/es/framer-motion/dist/es/components/MotionConfig/index.mjs +0 -48
  62. package/dist/es/framer-motion/dist/es/components/Reorder/Group.mjs +0 -53
  63. package/dist/es/framer-motion/dist/es/components/Reorder/Item.mjs +0 -34
  64. package/dist/es/framer-motion/dist/es/components/Reorder/namespace.mjs +0 -2
  65. package/dist/es/framer-motion/dist/es/components/Reorder/utils/check-reorder.mjs +0 -24
  66. package/dist/es/framer-motion/dist/es/context/DeprecatedLayoutGroupContext.mjs +0 -10
  67. package/dist/es/framer-motion/dist/es/context/LayoutGroupContext.mjs +0 -6
  68. package/dist/es/framer-motion/dist/es/context/LazyContext.mjs +0 -6
  69. package/dist/es/framer-motion/dist/es/context/MotionConfigContext.mjs +0 -13
  70. package/dist/es/framer-motion/dist/es/context/MotionContext/create.mjs +0 -13
  71. package/dist/es/framer-motion/dist/es/context/MotionContext/index.mjs +0 -6
  72. package/dist/es/framer-motion/dist/es/context/MotionContext/utils.mjs +0 -17
  73. package/dist/es/framer-motion/dist/es/context/PresenceContext.mjs +0 -10
  74. package/dist/es/framer-motion/dist/es/context/ReorderContext.mjs +0 -6
  75. package/dist/es/framer-motion/dist/es/context/SwitchLayoutGroupContext.mjs +0 -9
  76. package/dist/es/framer-motion/dist/es/events/add-dom-event.mjs +0 -6
  77. package/dist/es/framer-motion/dist/es/events/add-pointer-event.mjs +0 -8
  78. package/dist/es/framer-motion/dist/es/events/event-info.mjs +0 -15
  79. package/dist/es/framer-motion/dist/es/events/use-dom-event.mjs +0 -34
  80. package/dist/es/framer-motion/dist/es/gestures/drag/VisualElementDragControls.mjs +0 -479
  81. package/dist/es/framer-motion/dist/es/gestures/drag/index.mjs +0 -27
  82. package/dist/es/framer-motion/dist/es/gestures/drag/use-drag-controls.mjs +0 -88
  83. package/dist/es/framer-motion/dist/es/gestures/drag/utils/constraints.mjs +0 -129
  84. package/dist/es/framer-motion/dist/es/gestures/focus.mjs +0 -41
  85. package/dist/es/framer-motion/dist/es/gestures/hover.mjs +0 -30
  86. package/dist/es/framer-motion/dist/es/gestures/pan/PanSession.mjs +0 -156
  87. package/dist/es/framer-motion/dist/es/gestures/pan/index.mjs +0 -50
  88. package/dist/es/framer-motion/dist/es/gestures/press.mjs +0 -33
  89. package/dist/es/framer-motion/dist/es/motion/features/Feature.mjs +0 -9
  90. package/dist/es/framer-motion/dist/es/motion/features/animation/exit.mjs +0 -36
  91. package/dist/es/framer-motion/dist/es/motion/features/animation/index.mjs +0 -40
  92. package/dist/es/framer-motion/dist/es/motion/features/animations.mjs +0 -13
  93. package/dist/es/framer-motion/dist/es/motion/features/definitions.mjs +0 -28
  94. package/dist/es/framer-motion/dist/es/motion/features/drag.mjs +0 -17
  95. package/dist/es/framer-motion/dist/es/motion/features/gestures.mjs +0 -21
  96. package/dist/es/framer-motion/dist/es/motion/features/layout/MeasureLayout.mjs +0 -135
  97. package/dist/es/framer-motion/dist/es/motion/features/layout.mjs +0 -11
  98. package/dist/es/framer-motion/dist/es/motion/features/load-features.mjs +0 -12
  99. package/dist/es/framer-motion/dist/es/motion/features/viewport/index.mjs +0 -72
  100. package/dist/es/framer-motion/dist/es/motion/features/viewport/observers.mjs +0 -49
  101. package/dist/es/framer-motion/dist/es/motion/index.mjs +0 -101
  102. package/dist/es/framer-motion/dist/es/motion/utils/is-forced-motion-value.mjs +0 -11
  103. package/dist/es/framer-motion/dist/es/motion/utils/is-motion-component.mjs +0 -12
  104. package/dist/es/framer-motion/dist/es/motion/utils/symbol.mjs +0 -3
  105. package/dist/es/framer-motion/dist/es/motion/utils/unwrap-motion-component.mjs +0 -17
  106. package/dist/es/framer-motion/dist/es/motion/utils/use-motion-ref.mjs +0 -38
  107. package/dist/es/framer-motion/dist/es/motion/utils/use-visual-element.mjs +0 -133
  108. package/dist/es/framer-motion/dist/es/motion/utils/use-visual-state.mjs +0 -79
  109. package/dist/es/framer-motion/dist/es/motion/utils/valid-prop.mjs +0 -57
  110. package/dist/es/framer-motion/dist/es/projection/animation/mix-values.mjs +0 -91
  111. package/dist/es/framer-motion/dist/es/projection/geometry/conversion.mjs +0 -33
  112. package/dist/es/framer-motion/dist/es/projection/geometry/copy.mjs +0 -31
  113. package/dist/es/framer-motion/dist/es/projection/geometry/delta-apply.mjs +0 -119
  114. package/dist/es/framer-motion/dist/es/projection/geometry/delta-calc.mjs +0 -52
  115. package/dist/es/framer-motion/dist/es/projection/geometry/delta-remove.mjs +0 -54
  116. package/dist/es/framer-motion/dist/es/projection/geometry/models.mjs +0 -17
  117. package/dist/es/framer-motion/dist/es/projection/geometry/utils.mjs +0 -31
  118. package/dist/es/framer-motion/dist/es/projection/node/DocumentProjectionNode.mjs +0 -13
  119. package/dist/es/framer-motion/dist/es/projection/node/HTMLProjectionNode.mjs +0 -27
  120. package/dist/es/framer-motion/dist/es/projection/node/create-projection-node.mjs +0 -1605
  121. package/dist/es/framer-motion/dist/es/projection/node/group.mjs +0 -24
  122. package/dist/es/framer-motion/dist/es/projection/node/state.mjs +0 -19
  123. package/dist/es/framer-motion/dist/es/projection/shared/stack.mjs +0 -112
  124. package/dist/es/framer-motion/dist/es/projection/styles/scale-border-radius.mjs +0 -41
  125. package/dist/es/framer-motion/dist/es/projection/styles/scale-box-shadow.mjs +0 -35
  126. package/dist/es/framer-motion/dist/es/projection/styles/scale-correction.mjs +0 -13
  127. package/dist/es/framer-motion/dist/es/projection/styles/transform.mjs +0 -49
  128. package/dist/es/framer-motion/dist/es/projection/use-instant-layout-transition.mjs +0 -14
  129. package/dist/es/framer-motion/dist/es/projection/use-reset-projection.mjs +0 -14
  130. package/dist/es/framer-motion/dist/es/projection/utils/each-axis.mjs +0 -5
  131. package/dist/es/framer-motion/dist/es/projection/utils/has-transform.mjs +0 -26
  132. package/dist/es/framer-motion/dist/es/projection/utils/measure.mjs +0 -17
  133. package/dist/es/framer-motion/dist/es/render/VisualElement.mjs +0 -478
  134. package/dist/es/framer-motion/dist/es/render/components/create-factory.mjs +0 -23
  135. package/dist/es/framer-motion/dist/es/render/components/create-proxy.mjs +0 -38
  136. package/dist/es/framer-motion/dist/es/render/components/m/create.mjs +0 -6
  137. package/dist/es/framer-motion/dist/es/render/components/m/elements.mjs +0 -227
  138. package/dist/es/framer-motion/dist/es/render/components/m/proxy.mjs +0 -6
  139. package/dist/es/framer-motion/dist/es/render/components/motion/create.mjs +0 -15
  140. package/dist/es/framer-motion/dist/es/render/components/motion/elements.mjs +0 -194
  141. package/dist/es/framer-motion/dist/es/render/components/motion/proxy.mjs +0 -6
  142. package/dist/es/framer-motion/dist/es/render/dom/DOMVisualElement.mjs +0 -43
  143. package/dist/es/framer-motion/dist/es/render/dom/create-visual-element.mjs +0 -14
  144. package/dist/es/framer-motion/dist/es/render/dom/features-animation.mjs +0 -14
  145. package/dist/es/framer-motion/dist/es/render/dom/features-max.mjs +0 -14
  146. package/dist/es/framer-motion/dist/es/render/dom/features-min.mjs +0 -12
  147. package/dist/es/framer-motion/dist/es/render/dom/scroll/attach-animation.mjs +0 -17
  148. package/dist/es/framer-motion/dist/es/render/dom/scroll/attach-function.mjs +0 -23
  149. package/dist/es/framer-motion/dist/es/render/dom/scroll/index.mjs +0 -14
  150. package/dist/es/framer-motion/dist/es/render/dom/scroll/info.mjs +0 -56
  151. package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/edge.mjs +0 -45
  152. package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/index.mjs +0 -60
  153. package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/inset.mjs +0 -47
  154. package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/offset.mjs +0 -35
  155. package/dist/es/framer-motion/dist/es/render/dom/scroll/offsets/presets.mjs +0 -20
  156. package/dist/es/framer-motion/dist/es/render/dom/scroll/on-scroll-handler.mjs +0 -48
  157. package/dist/es/framer-motion/dist/es/render/dom/scroll/track.mjs +0 -81
  158. package/dist/es/framer-motion/dist/es/render/dom/scroll/utils/get-timeline.mjs +0 -30
  159. package/dist/es/framer-motion/dist/es/render/dom/use-render.mjs +0 -33
  160. package/dist/es/framer-motion/dist/es/render/dom/utils/camel-to-dash.mjs +0 -6
  161. package/dist/es/framer-motion/dist/es/render/dom/utils/filter-props.mjs +0 -59
  162. package/dist/es/framer-motion/dist/es/render/dom/utils/is-svg-component.mjs +0 -30
  163. package/dist/es/framer-motion/dist/es/render/dom/viewport/index.mjs +0 -43
  164. package/dist/es/framer-motion/dist/es/render/html/HTMLVisualElement.mjs +0 -44
  165. package/dist/es/framer-motion/dist/es/render/html/config-motion.mjs +0 -12
  166. package/dist/es/framer-motion/dist/es/render/html/use-props.mjs +0 -57
  167. package/dist/es/framer-motion/dist/es/render/html/utils/build-styles.mjs +0 -65
  168. package/dist/es/framer-motion/dist/es/render/html/utils/build-transform.mjs +0 -62
  169. package/dist/es/framer-motion/dist/es/render/html/utils/create-render-state.mjs +0 -8
  170. package/dist/es/framer-motion/dist/es/render/html/utils/render.mjs +0 -9
  171. package/dist/es/framer-motion/dist/es/render/html/utils/scrape-motion-values.mjs +0 -19
  172. package/dist/es/framer-motion/dist/es/render/object/ObjectVisualElement.mjs +0 -41
  173. package/dist/es/framer-motion/dist/es/render/store.mjs +0 -3
  174. package/dist/es/framer-motion/dist/es/render/svg/SVGVisualElement.mjs +0 -45
  175. package/dist/es/framer-motion/dist/es/render/svg/config-motion.mjs +0 -12
  176. package/dist/es/framer-motion/dist/es/render/svg/lowercase-elements.mjs +0 -33
  177. package/dist/es/framer-motion/dist/es/render/svg/use-props.mjs +0 -24
  178. package/dist/es/framer-motion/dist/es/render/svg/utils/build-attrs.mjs +0 -57
  179. package/dist/es/framer-motion/dist/es/render/svg/utils/camel-case-attrs.mjs +0 -30
  180. package/dist/es/framer-motion/dist/es/render/svg/utils/create-render-state.mjs +0 -8
  181. package/dist/es/framer-motion/dist/es/render/svg/utils/is-svg-tag.mjs +0 -3
  182. package/dist/es/framer-motion/dist/es/render/svg/utils/path.mjs +0 -32
  183. package/dist/es/framer-motion/dist/es/render/svg/utils/render.mjs +0 -12
  184. package/dist/es/framer-motion/dist/es/render/svg/utils/scrape-motion-values.mjs +0 -19
  185. package/dist/es/framer-motion/dist/es/render/utils/animation-state.mjs +0 -342
  186. package/dist/es/framer-motion/dist/es/render/utils/compare-by-depth.mjs +0 -3
  187. package/dist/es/framer-motion/dist/es/render/utils/flat-tree.mjs +0 -24
  188. package/dist/es/framer-motion/dist/es/render/utils/get-variant-context.mjs +0 -28
  189. package/dist/es/framer-motion/dist/es/render/utils/is-controlling-variants.mjs +0 -13
  190. package/dist/es/framer-motion/dist/es/render/utils/is-variant-label.mjs +0 -8
  191. package/dist/es/framer-motion/dist/es/render/utils/motion-values.mjs +0 -51
  192. package/dist/es/framer-motion/dist/es/render/utils/resolve-dynamic-variants.mjs +0 -8
  193. package/dist/es/framer-motion/dist/es/render/utils/resolve-variants.mjs +0 -36
  194. package/dist/es/framer-motion/dist/es/render/utils/setters.mjs +0 -31
  195. package/dist/es/framer-motion/dist/es/render/utils/variant-props.mjs +0 -12
  196. package/dist/es/framer-motion/dist/es/utils/delay.mjs +0 -24
  197. package/dist/es/framer-motion/dist/es/utils/distance.mjs +0 -9
  198. package/dist/es/framer-motion/dist/es/utils/get-context-window.mjs +0 -6
  199. package/dist/es/framer-motion/dist/es/utils/is-browser.mjs +0 -3
  200. package/dist/es/framer-motion/dist/es/utils/is-ref-object.mjs +0 -7
  201. package/dist/es/framer-motion/dist/es/utils/reduced-motion/index.mjs +0 -19
  202. package/dist/es/framer-motion/dist/es/utils/reduced-motion/state.mjs +0 -5
  203. package/dist/es/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion-config.mjs +0 -19
  204. package/dist/es/framer-motion/dist/es/utils/reduced-motion/use-reduced-motion.mjs +0 -47
  205. package/dist/es/framer-motion/dist/es/utils/shallow-compare.mjs +0 -14
  206. package/dist/es/framer-motion/dist/es/utils/use-animation-frame.mjs +0 -21
  207. package/dist/es/framer-motion/dist/es/utils/use-constant.mjs +0 -18
  208. package/dist/es/framer-motion/dist/es/utils/use-cycle.mjs +0 -47
  209. package/dist/es/framer-motion/dist/es/utils/use-force-update.mjs +0 -19
  210. package/dist/es/framer-motion/dist/es/utils/use-in-view.mjs +0 -23
  211. package/dist/es/framer-motion/dist/es/utils/use-instant-transition.mjs +0 -41
  212. package/dist/es/framer-motion/dist/es/utils/use-is-mounted.mjs +0 -15
  213. package/dist/es/framer-motion/dist/es/utils/use-isomorphic-effect.mjs +0 -6
  214. package/dist/es/framer-motion/dist/es/utils/use-motion-value-event.mjs +0 -13
  215. package/dist/es/framer-motion/dist/es/utils/use-unmount-effect.mjs +0 -7
  216. package/dist/es/framer-motion/dist/es/value/scroll/use-element-scroll.mjs +0 -14
  217. package/dist/es/framer-motion/dist/es/value/scroll/use-viewport-scroll.mjs +0 -14
  218. package/dist/es/framer-motion/dist/es/value/use-combine-values.mjs +0 -37
  219. package/dist/es/framer-motion/dist/es/value/use-computed.mjs +0 -19
  220. package/dist/es/framer-motion/dist/es/value/use-inverted-scale.mjs +0 -52
  221. package/dist/es/framer-motion/dist/es/value/use-motion-template.mjs +0 -45
  222. package/dist/es/framer-motion/dist/es/value/use-motion-value.mjs +0 -38
  223. package/dist/es/framer-motion/dist/es/value/use-scroll.mjs +0 -39
  224. package/dist/es/framer-motion/dist/es/value/use-spring.mjs +0 -22
  225. package/dist/es/framer-motion/dist/es/value/use-time.mjs +0 -10
  226. package/dist/es/framer-motion/dist/es/value/use-transform.mjs +0 -29
  227. package/dist/es/framer-motion/dist/es/value/use-velocity.mjs +0 -35
  228. package/dist/es/framer-motion/dist/es/value/use-will-change/WillChangeMotionValue.mjs +0 -21
  229. package/dist/es/framer-motion/dist/es/value/use-will-change/add-will-change.mjs +0 -20
  230. package/dist/es/framer-motion/dist/es/value/use-will-change/index.mjs +0 -8
  231. package/dist/es/framer-motion/dist/es/value/use-will-change/is.mjs +0 -7
  232. package/dist/es/framer-motion/dist/es/value/utils/resolve-motion-value.mjs +0 -12
  233. package/dist/es/motion/lib/debug.mjs +0 -1
  234. package/dist/es/motion/lib/index.mjs +0 -131
  235. package/dist/es/motion/lib/mini.mjs +0 -2
  236. package/dist/es/motion/lib/react-client.mjs +0 -3
  237. package/dist/es/motion/lib/react-m.mjs +0 -3
  238. package/dist/es/motion/lib/react-mini.mjs +0 -2
  239. package/dist/es/motion/lib/react.mjs +0 -204
  240. package/dist/es/motion-dom/dist/es/animation/AsyncMotionValueAnimation.mjs +0 -175
  241. package/dist/es/motion-dom/dist/es/animation/GroupAnimation.mjs +0 -72
  242. package/dist/es/motion-dom/dist/es/animation/GroupAnimationWithThen.mjs +0 -9
  243. package/dist/es/motion-dom/dist/es/animation/JSAnimation.mjs +0 -348
  244. package/dist/es/motion-dom/dist/es/animation/NativeAnimation.mjs +0 -158
  245. package/dist/es/motion-dom/dist/es/animation/NativeAnimationExtended.mjs +0 -65
  246. package/dist/es/motion-dom/dist/es/animation/NativeAnimationWrapper.mjs +0 -14
  247. package/dist/es/motion-dom/dist/es/animation/drivers/frame.mjs +0 -17
  248. package/dist/es/motion-dom/dist/es/animation/generators/inertia.mjs +0 -87
  249. package/dist/es/motion-dom/dist/es/animation/generators/keyframes.mjs +0 -51
  250. package/dist/es/motion-dom/dist/es/animation/generators/spring/defaults.mjs +0 -27
  251. package/dist/es/motion-dom/dist/es/animation/generators/spring/find.mjs +0 -86
  252. package/dist/es/motion-dom/dist/es/animation/generators/spring/index.mjs +0 -176
  253. package/dist/es/motion-dom/dist/es/animation/generators/utils/calc-duration.mjs +0 -17
  254. package/dist/es/motion-dom/dist/es/animation/generators/utils/create-generator-easing.mjs +0 -19
  255. package/dist/es/motion-dom/dist/es/animation/generators/utils/is-generator.mjs +0 -5
  256. package/dist/es/motion-dom/dist/es/animation/generators/utils/velocity.mjs +0 -9
  257. package/dist/es/motion-dom/dist/es/animation/keyframes/DOMKeyframesResolver.mjs +0 -131
  258. package/dist/es/motion-dom/dist/es/animation/keyframes/KeyframesResolver.mjs +0 -147
  259. package/dist/es/motion-dom/dist/es/animation/keyframes/get-final.mjs +0 -11
  260. package/dist/es/motion-dom/dist/es/animation/keyframes/offsets/default.mjs +0 -9
  261. package/dist/es/motion-dom/dist/es/animation/keyframes/offsets/fill.mjs +0 -12
  262. package/dist/es/motion-dom/dist/es/animation/keyframes/offsets/time.mjs +0 -5
  263. package/dist/es/motion-dom/dist/es/animation/keyframes/utils/apply-px-defaults.mjs +0 -11
  264. package/dist/es/motion-dom/dist/es/animation/keyframes/utils/fill-wildcards.mjs +0 -7
  265. package/dist/es/motion-dom/dist/es/animation/keyframes/utils/is-none.mjs +0 -15
  266. package/dist/es/motion-dom/dist/es/animation/keyframes/utils/make-none-animatable.mjs +0 -30
  267. package/dist/es/motion-dom/dist/es/animation/keyframes/utils/unit-conversion.mjs +0 -36
  268. package/dist/es/motion-dom/dist/es/animation/utils/WithPromise.mjs +0 -26
  269. package/dist/es/motion-dom/dist/es/animation/utils/active-animations.mjs +0 -9
  270. package/dist/es/motion-dom/dist/es/animation/utils/can-animate.mjs +0 -42
  271. package/dist/es/motion-dom/dist/es/animation/utils/css-variables-conversion.mjs +0 -42
  272. package/dist/es/motion-dom/dist/es/animation/utils/get-value-transition.mjs +0 -7
  273. package/dist/es/motion-dom/dist/es/animation/utils/is-animatable.mjs +0 -30
  274. package/dist/es/motion-dom/dist/es/animation/utils/is-css-variable.mjs +0 -15
  275. package/dist/es/motion-dom/dist/es/animation/utils/replace-transition-type.mjs +0 -18
  276. package/dist/es/motion-dom/dist/es/animation/waapi/easing/cubic-bezier.mjs +0 -3
  277. package/dist/es/motion-dom/dist/es/animation/waapi/easing/is-supported.mjs +0 -14
  278. package/dist/es/motion-dom/dist/es/animation/waapi/easing/map-easing.mjs +0 -28
  279. package/dist/es/motion-dom/dist/es/animation/waapi/easing/supported.mjs +0 -15
  280. package/dist/es/motion-dom/dist/es/animation/waapi/start-waapi-animation.mjs +0 -39
  281. package/dist/es/motion-dom/dist/es/animation/waapi/supports/partial-keyframes.mjs +0 -13
  282. package/dist/es/motion-dom/dist/es/animation/waapi/supports/waapi.mjs +0 -37
  283. package/dist/es/motion-dom/dist/es/animation/waapi/utils/accelerated-values.mjs +0 -14
  284. package/dist/es/motion-dom/dist/es/animation/waapi/utils/apply-generator.mjs +0 -15
  285. package/dist/es/motion-dom/dist/es/animation/waapi/utils/linear.mjs +0 -12
  286. package/dist/es/motion-dom/dist/es/animation/waapi/utils/px-values.mjs +0 -39
  287. package/dist/es/motion-dom/dist/es/animation/waapi/utils/unsupported-easing.mjs +0 -20
  288. package/dist/es/motion-dom/dist/es/effects/MotionValueState.mjs +0 -47
  289. package/dist/es/motion-dom/dist/es/effects/attr/index.mjs +0 -41
  290. package/dist/es/motion-dom/dist/es/effects/prop/index.mjs +0 -9
  291. package/dist/es/motion-dom/dist/es/effects/style/index.mjs +0 -52
  292. package/dist/es/motion-dom/dist/es/effects/style/transform.mjs +0 -38
  293. package/dist/es/motion-dom/dist/es/effects/svg/index.mjs +0 -41
  294. package/dist/es/motion-dom/dist/es/effects/utils/create-dom-effect.mjs +0 -18
  295. package/dist/es/motion-dom/dist/es/effects/utils/create-effect.mjs +0 -21
  296. package/dist/es/motion-dom/dist/es/frameloop/batcher.mjs +0 -71
  297. package/dist/es/motion-dom/dist/es/frameloop/frame.mjs +0 -6
  298. package/dist/es/motion-dom/dist/es/frameloop/index-legacy.mjs +0 -20
  299. package/dist/es/motion-dom/dist/es/frameloop/microtask.mjs +0 -6
  300. package/dist/es/motion-dom/dist/es/frameloop/order.mjs +0 -12
  301. package/dist/es/motion-dom/dist/es/frameloop/render-step.mjs +0 -92
  302. package/dist/es/motion-dom/dist/es/frameloop/sync-time.mjs +0 -31
  303. package/dist/es/motion-dom/dist/es/gestures/drag/state/is-active.mjs +0 -9
  304. package/dist/es/motion-dom/dist/es/gestures/drag/state/set-active.mjs +0 -28
  305. package/dist/es/motion-dom/dist/es/gestures/hover.mjs +0 -37
  306. package/dist/es/motion-dom/dist/es/gestures/press/index.mjs +0 -83
  307. package/dist/es/motion-dom/dist/es/gestures/press/utils/is-keyboard-accessible.mjs +0 -13
  308. package/dist/es/motion-dom/dist/es/gestures/press/utils/keyboard.mjs +0 -38
  309. package/dist/es/motion-dom/dist/es/gestures/press/utils/state.mjs +0 -3
  310. package/dist/es/motion-dom/dist/es/gestures/utils/is-node-or-child.mjs +0 -20
  311. package/dist/es/motion-dom/dist/es/gestures/utils/is-primary-pointer.mjs +0 -18
  312. package/dist/es/motion-dom/dist/es/gestures/utils/setup.mjs +0 -15
  313. package/dist/es/motion-dom/dist/es/render/dom/is-css-var.mjs +0 -3
  314. package/dist/es/motion-dom/dist/es/render/dom/parse-transform.mjs +0 -83
  315. package/dist/es/motion-dom/dist/es/render/dom/style-computed.mjs +0 -10
  316. package/dist/es/motion-dom/dist/es/render/dom/style-set.mjs +0 -9
  317. package/dist/es/motion-dom/dist/es/render/dom/utils/camel-to-dash.mjs +0 -5
  318. package/dist/es/motion-dom/dist/es/render/utils/keys-position.mjs +0 -13
  319. package/dist/es/motion-dom/dist/es/render/utils/keys-transform.mjs +0 -28
  320. package/dist/es/motion-dom/dist/es/resize/handle-element.mjs +0 -63
  321. package/dist/es/motion-dom/dist/es/resize/handle-window.mjs +0 -31
  322. package/dist/es/motion-dom/dist/es/resize/index.mjs +0 -8
  323. package/dist/es/motion-dom/dist/es/scroll/observe.mjs +0 -18
  324. package/dist/es/motion-dom/dist/es/stats/animation-count.mjs +0 -7
  325. package/dist/es/motion-dom/dist/es/stats/buffer.mjs +0 -6
  326. package/dist/es/motion-dom/dist/es/stats/index.mjs +0 -117
  327. package/dist/es/motion-dom/dist/es/utils/interpolate.mjs +0 -79
  328. package/dist/es/motion-dom/dist/es/utils/is-html-element.mjs +0 -11
  329. package/dist/es/motion-dom/dist/es/utils/is-svg-element.mjs +0 -11
  330. package/dist/es/motion-dom/dist/es/utils/is-svg-svg-element.mjs +0 -11
  331. package/dist/es/motion-dom/dist/es/utils/mix/color.mjs +0 -47
  332. package/dist/es/motion-dom/dist/es/utils/mix/complex.mjs +0 -93
  333. package/dist/es/motion-dom/dist/es/utils/mix/immediate.mjs +0 -5
  334. package/dist/es/motion-dom/dist/es/utils/mix/index.mjs +0 -14
  335. package/dist/es/motion-dom/dist/es/utils/mix/number.mjs +0 -26
  336. package/dist/es/motion-dom/dist/es/utils/mix/visibility.mjs +0 -16
  337. package/dist/es/motion-dom/dist/es/utils/resolve-elements.mjs +0 -17
  338. package/dist/es/motion-dom/dist/es/utils/supports/flags.mjs +0 -7
  339. package/dist/es/motion-dom/dist/es/utils/supports/linear-easing.mjs +0 -15
  340. package/dist/es/motion-dom/dist/es/utils/supports/memo.mjs +0 -9
  341. package/dist/es/motion-dom/dist/es/utils/supports/scroll-timeline.mjs +0 -5
  342. package/dist/es/motion-dom/dist/es/utils/transform.mjs +0 -14
  343. package/dist/es/motion-dom/dist/es/value/index.mjs +0 -329
  344. package/dist/es/motion-dom/dist/es/value/map-value.mjs +0 -46
  345. package/dist/es/motion-dom/dist/es/value/spring-value.mjs +0 -72
  346. package/dist/es/motion-dom/dist/es/value/subscribe-value.mjs +0 -13
  347. package/dist/es/motion-dom/dist/es/value/transform-value.mjs +0 -35
  348. package/dist/es/motion-dom/dist/es/value/types/auto.mjs +0 -9
  349. package/dist/es/motion-dom/dist/es/value/types/color/hex.mjs +0 -40
  350. package/dist/es/motion-dom/dist/es/value/types/color/hsla-to-rgba.mjs +0 -42
  351. package/dist/es/motion-dom/dist/es/value/types/color/hsla.mjs +0 -22
  352. package/dist/es/motion-dom/dist/es/value/types/color/index.mjs +0 -32
  353. package/dist/es/motion-dom/dist/es/value/types/color/rgba.mjs +0 -25
  354. package/dist/es/motion-dom/dist/es/value/types/color/utils.mjs +0 -29
  355. package/dist/es/motion-dom/dist/es/value/types/complex/filter.mjs +0 -30
  356. package/dist/es/motion-dom/dist/es/value/types/complex/index.mjs +0 -91
  357. package/dist/es/motion-dom/dist/es/value/types/dimensions.mjs +0 -15
  358. package/dist/es/motion-dom/dist/es/value/types/int.mjs +0 -8
  359. package/dist/es/motion-dom/dist/es/value/types/maps/defaults.mjs +0 -30
  360. package/dist/es/motion-dom/dist/es/value/types/maps/number.mjs +0 -50
  361. package/dist/es/motion-dom/dist/es/value/types/maps/transform.mjs +0 -31
  362. package/dist/es/motion-dom/dist/es/value/types/numbers/index.mjs +0 -17
  363. package/dist/es/motion-dom/dist/es/value/types/numbers/units.mjs +0 -18
  364. package/dist/es/motion-dom/dist/es/value/types/test.mjs +0 -6
  365. package/dist/es/motion-dom/dist/es/value/types/utils/animatable-none.mjs +0 -15
  366. package/dist/es/motion-dom/dist/es/value/types/utils/color-regex.mjs +0 -3
  367. package/dist/es/motion-dom/dist/es/value/types/utils/find.mjs +0 -15
  368. package/dist/es/motion-dom/dist/es/value/types/utils/float-regex.mjs +0 -3
  369. package/dist/es/motion-dom/dist/es/value/types/utils/get-as-type.mjs +0 -10
  370. package/dist/es/motion-dom/dist/es/value/types/utils/is-nullish.mjs +0 -5
  371. package/dist/es/motion-dom/dist/es/value/types/utils/sanitize.mjs +0 -5
  372. package/dist/es/motion-dom/dist/es/value/types/utils/single-color-regex.mjs +0 -3
  373. package/dist/es/motion-dom/dist/es/value/utils/is-motion-value.mjs +0 -3
  374. package/dist/es/motion-dom/dist/es/view/index.mjs +0 -64
  375. package/dist/es/motion-dom/dist/es/view/queue.mjs +0 -52
  376. package/dist/es/motion-dom/dist/es/view/start.mjs +0 -155
  377. package/dist/es/motion-dom/dist/es/view/utils/choose-layer-type.mjs +0 -11
  378. package/dist/es/motion-dom/dist/es/view/utils/css.mjs +0 -32
  379. package/dist/es/motion-dom/dist/es/view/utils/get-layer-name.mjs +0 -8
  380. package/dist/es/motion-dom/dist/es/view/utils/get-view-animations.mjs +0 -12
  381. package/dist/es/motion-dom/dist/es/view/utils/has-target.mjs +0 -5
  382. package/dist/es/motion-utils/dist/es/array.mjs +0 -21
  383. package/dist/es/motion-utils/dist/es/clamp.mjs +0 -9
  384. package/dist/es/motion-utils/dist/es/easing/anticipate.mjs +0 -5
  385. package/dist/es/motion-utils/dist/es/easing/back.mjs +0 -9
  386. package/dist/es/motion-utils/dist/es/easing/circ.mjs +0 -8
  387. package/dist/es/motion-utils/dist/es/easing/cubic-bezier.mjs +0 -51
  388. package/dist/es/motion-utils/dist/es/easing/ease.mjs +0 -7
  389. package/dist/es/motion-utils/dist/es/easing/modifiers/mirror.mjs +0 -5
  390. package/dist/es/motion-utils/dist/es/easing/modifiers/reverse.mjs +0 -5
  391. package/dist/es/motion-utils/dist/es/easing/steps.mjs +0 -15
  392. package/dist/es/motion-utils/dist/es/easing/utils/get-easing-for-segment.mjs +0 -8
  393. package/dist/es/motion-utils/dist/es/easing/utils/is-bezier-definition.mjs +0 -3
  394. package/dist/es/motion-utils/dist/es/easing/utils/is-easing-array.mjs +0 -5
  395. package/dist/es/motion-utils/dist/es/easing/utils/map.mjs +0 -41
  396. package/dist/es/motion-utils/dist/es/errors.mjs +0 -16
  397. package/dist/es/motion-utils/dist/es/global-config.mjs +0 -3
  398. package/dist/es/motion-utils/dist/es/is-numerical-string.mjs +0 -6
  399. package/dist/es/motion-utils/dist/es/is-object.mjs +0 -5
  400. package/dist/es/motion-utils/dist/es/is-zero-value-string.mjs +0 -6
  401. package/dist/es/motion-utils/dist/es/memo.mjs +0 -11
  402. package/dist/es/motion-utils/dist/es/noop.mjs +0 -4
  403. package/dist/es/motion-utils/dist/es/pipe.mjs +0 -11
  404. package/dist/es/motion-utils/dist/es/progress.mjs +0 -19
  405. package/dist/es/motion-utils/dist/es/subscription-manager.mjs +0 -40
  406. package/dist/es/motion-utils/dist/es/time-conversion.mjs +0 -12
  407. package/dist/es/motion-utils/dist/es/velocity-per-second.mjs +0 -11
  408. package/dist/es/motion-utils/dist/es/warn-once.mjs +0 -14
  409. 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,8 +0,0 @@
1
- const createHtmlRenderState = () => ({
2
- style: {},
3
- transform: {},
4
- transformOrigin: {},
5
- vars: {},
6
- });
7
-
8
- export { createHtmlRenderState };
@@ -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,3 +0,0 @@
1
- const visualElementStore = new WeakMap();
2
-
3
- export { visualElementStore };
@@ -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,8 +0,0 @@
1
- import { createHtmlRenderState } from '../../html/utils/create-render-state.mjs';
2
-
3
- const createSvgRenderState = () => ({
4
- ...createHtmlRenderState(),
5
- attrs: {},
6
- });
7
-
8
- export { createSvgRenderState };
@@ -1,3 +0,0 @@
1
- const isSVGTag = (tag) => typeof tag === "string" && tag.toLowerCase() === "svg";
2
-
3
- export { isSVGTag };
@@ -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 };