@maas/vue-equipment 0.40.0 → 1.0.0-beta.10

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 (349) hide show
  1. package/README.md +6 -16
  2. package/dist/composables/index.d.ts +7 -18
  3. package/dist/composables/index.js +79 -132
  4. package/dist/composables/index.js.map +1 -1
  5. package/dist/nuxt/module.json +1 -1
  6. package/dist/nuxt/module.mjs +35 -42
  7. package/dist/plugins/.turbo/turbo-build.log +0 -0
  8. package/dist/plugins/.turbo/turbo-lint.log +5 -0
  9. package/dist/plugins/.turbo/turbo-release.log +7 -0
  10. package/dist/plugins/MagicAccordion/demo/data/footer.json +117 -0
  11. package/dist/plugins/MagicAccordion/index.d.ts +2 -0
  12. package/dist/plugins/MagicAccordion/src/components/MagicAccordionContent.vue +103 -70
  13. package/dist/plugins/MagicAccordion/src/components/MagicAccordionContent.vue.d.ts +39 -13
  14. package/dist/plugins/MagicAccordion/src/components/MagicAccordionProvider.vue +36 -30
  15. package/dist/plugins/MagicAccordion/src/components/MagicAccordionProvider.vue.d.ts +12 -12
  16. package/dist/plugins/MagicAccordion/src/components/MagicAccordionTrigger.vue +73 -71
  17. package/dist/plugins/MagicAccordion/src/components/MagicAccordionTrigger.vue.d.ts +24 -55
  18. package/dist/plugins/MagicAccordion/src/components/MagicAccordionView.vue +52 -50
  19. package/dist/plugins/MagicAccordion/src/components/MagicAccordionView.vue.d.ts +18 -14
  20. package/dist/plugins/MagicAccordion/src/composables/private/useAccordionCallback.d.ts +6 -6
  21. package/dist/plugins/MagicAccordion/src/composables/private/useAccordionCallback.mjs +6 -6
  22. package/dist/plugins/MagicAccordion/src/composables/private/useAccordionState.mjs +10 -10
  23. package/dist/plugins/MagicAccordion/src/composables/private/useAccordionTrigger.d.ts +1 -1
  24. package/dist/plugins/MagicAccordion/src/composables/private/useAccordionView.mjs +11 -10
  25. package/dist/plugins/MagicAccordion/src/symbols/index.d.ts +2 -2
  26. package/dist/plugins/MagicAccordion/src/types/index.d.ts +4 -0
  27. package/dist/plugins/MagicAccordion/src/utils/defaultOptions.d.ts +2 -2
  28. package/dist/plugins/MagicAccordion/src/utils/defaultOptions.mjs +7 -2
  29. package/dist/plugins/MagicCommand/demo/data/about.json +3 -0
  30. package/dist/plugins/MagicCommand/demo/data/search.json +594 -0
  31. package/dist/plugins/MagicCommand/index.d.ts +2 -0
  32. package/dist/plugins/MagicCommand/index.mjs +9 -11
  33. package/dist/plugins/MagicCommand/src/components/MagicCommandContent.vue +199 -0
  34. package/dist/plugins/MagicCommand/src/components/MagicCommandContent.vue.d.ts +32 -0
  35. package/dist/plugins/MagicCommand/src/components/MagicCommandDrawer.vue +60 -53
  36. package/dist/plugins/MagicCommand/src/components/MagicCommandDrawer.vue.d.ts +14 -14
  37. package/dist/plugins/MagicCommand/src/components/MagicCommandItem.vue +105 -80
  38. package/dist/plugins/MagicCommand/src/components/MagicCommandItem.vue.d.ts +32 -22
  39. package/dist/plugins/MagicCommand/src/components/MagicCommandModal.vue +55 -53
  40. package/dist/plugins/MagicCommand/src/components/MagicCommandModal.vue.d.ts +12 -12
  41. package/dist/plugins/MagicCommand/src/components/MagicCommandProvider.vue +92 -62
  42. package/dist/plugins/MagicCommand/src/components/MagicCommandProvider.vue.d.ts +15 -16
  43. package/dist/plugins/MagicCommand/src/components/MagicCommandRenderer.vue +63 -0
  44. package/dist/plugins/MagicCommand/src/components/MagicCommandRenderer.vue.d.ts +2 -0
  45. package/dist/plugins/MagicCommand/src/components/MagicCommandTrigger.vue +111 -0
  46. package/dist/plugins/MagicCommand/src/components/MagicCommandTrigger.vue.d.ts +40 -0
  47. package/dist/plugins/MagicCommand/src/components/MagicCommandView.vue +56 -73
  48. package/dist/plugins/MagicCommand/src/components/MagicCommandView.vue.d.ts +16 -16
  49. package/dist/plugins/MagicCommand/src/composables/private/useCommandCallback.d.ts +14 -0
  50. package/dist/plugins/MagicCommand/src/composables/private/useCommandCallback.mjs +32 -0
  51. package/dist/plugins/MagicCommand/src/composables/private/useCommandItem.d.ts +15 -6
  52. package/dist/plugins/MagicCommand/src/composables/private/useCommandItem.mjs +77 -44
  53. package/dist/plugins/MagicCommand/src/composables/private/useCommandScroll.d.ts +24 -6
  54. package/dist/plugins/MagicCommand/src/composables/private/useCommandScroll.mjs +45 -28
  55. package/dist/plugins/MagicCommand/src/composables/private/useCommandState.d.ts +7 -0
  56. package/dist/plugins/MagicCommand/src/composables/private/useCommandState.mjs +49 -0
  57. package/dist/plugins/MagicCommand/src/composables/private/useCommandTrigger.d.ts +18 -0
  58. package/dist/plugins/MagicCommand/src/composables/private/useCommandTrigger.mjs +76 -0
  59. package/dist/plugins/MagicCommand/src/composables/private/useCommandView.d.ts +21 -5
  60. package/dist/plugins/MagicCommand/src/composables/private/useCommandView.mjs +193 -18
  61. package/dist/plugins/MagicCommand/src/composables/useMagicCommand.d.ts +14 -5
  62. package/dist/plugins/MagicCommand/src/composables/useMagicCommand.mjs +43 -13
  63. package/dist/plugins/MagicCommand/src/symbols/index.d.ts +9 -2
  64. package/dist/plugins/MagicCommand/src/symbols/index.mjs +18 -1
  65. package/dist/plugins/MagicCommand/src/types/index.d.ts +73 -13
  66. package/dist/plugins/MagicCommand/src/utils/defaultOptions.d.ts +3 -5
  67. package/dist/plugins/MagicCommand/src/utils/defaultOptions.mjs +8 -3
  68. package/dist/plugins/MagicCookie/index.d.ts +5 -3
  69. package/dist/plugins/MagicCookie/index.mjs +7 -3
  70. package/dist/plugins/MagicCookie/nuxt.mjs +5 -9
  71. package/dist/plugins/MagicCookie/src/components/MagicCookieItem.vue +56 -0
  72. package/dist/plugins/MagicCookie/src/components/MagicCookieItem.vue.d.ts +24 -0
  73. package/dist/plugins/MagicCookie/src/components/MagicCookieProvider.vue +43 -0
  74. package/dist/plugins/MagicCookie/src/components/MagicCookieProvider.vue.d.ts +20 -0
  75. package/dist/plugins/MagicCookie/src/components/MagicCookieView.vue +96 -0
  76. package/dist/plugins/MagicCookie/src/components/MagicCookieView.vue.d.ts +30 -0
  77. package/dist/plugins/MagicCookie/src/composables/private/useCookieCallback.d.ts +9 -0
  78. package/dist/plugins/MagicCookie/src/composables/private/useCookieCallback.mjs +31 -0
  79. package/dist/plugins/MagicCookie/src/composables/private/useCookieItem.d.ts +16 -0
  80. package/dist/plugins/MagicCookie/src/composables/private/useCookieItem.mjs +87 -0
  81. package/dist/plugins/MagicCookie/src/composables/private/useCookieState.d.ts +7 -0
  82. package/dist/plugins/MagicCookie/src/composables/private/useCookieState.mjs +43 -0
  83. package/dist/plugins/MagicCookie/src/composables/useMagicCookie.d.ts +15 -15
  84. package/dist/plugins/MagicCookie/src/composables/useMagicCookie.mjs +59 -60
  85. package/dist/plugins/MagicCookie/src/symbols/index.d.ts +5 -0
  86. package/dist/plugins/MagicCookie/src/symbols/index.mjs +4 -0
  87. package/dist/plugins/MagicCookie/src/types/index.d.ts +31 -13
  88. package/dist/plugins/MagicCookie/src/utils/defaultOptions.d.ts +4 -0
  89. package/dist/plugins/MagicCookie/src/utils/defaultOptions.mjs +10 -0
  90. package/dist/plugins/MagicDraggable/src/components/MagicDraggable.vue +136 -97
  91. package/dist/plugins/MagicDraggable/src/components/MagicDraggable.vue.d.ts +95 -18
  92. package/dist/plugins/MagicDraggable/src/composables/private/useDraggableDrag.d.ts +8 -8
  93. package/dist/plugins/MagicDraggable/src/composables/private/useDraggableDrag.mjs +12 -6
  94. package/dist/plugins/MagicDraggable/src/composables/private/useDraggableScrollLock.mjs +34 -14
  95. package/dist/plugins/MagicDraggable/src/composables/private/useDraggableSnap.d.ts +9 -8
  96. package/dist/plugins/MagicDraggable/src/composables/private/useDraggableSnap.mjs +46 -8
  97. package/dist/plugins/MagicDraggable/src/composables/private/useDraggableState.d.ts +2 -1
  98. package/dist/plugins/MagicDraggable/src/composables/private/useDraggableState.mjs +10 -10
  99. package/dist/plugins/MagicDraggable/src/types/index.d.ts +11 -6
  100. package/dist/plugins/MagicDraggable/src/utils/defaultOptions.d.ts +3 -8
  101. package/dist/plugins/MagicDraggable/src/utils/defaultOptions.mjs +6 -6
  102. package/dist/plugins/MagicDrawer/nuxt.mjs +1 -1
  103. package/dist/plugins/MagicDrawer/src/components/MagicDrawer.vue +501 -337
  104. package/dist/plugins/MagicDrawer/src/components/MagicDrawer.vue.d.ts +166 -19
  105. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerCallback.d.ts +6 -6
  106. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerCallback.mjs +6 -6
  107. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerDOM.mjs +34 -14
  108. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerDrag.d.ts +9 -11
  109. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerDrag.mjs +29 -19
  110. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerGuards.d.ts +3 -4
  111. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerGuards.mjs +28 -10
  112. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerProgress.d.ts +4 -4
  113. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerProgress.mjs +4 -2
  114. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerSnap.d.ts +8 -9
  115. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerSnap.mjs +45 -26
  116. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerState.d.ts +1 -1
  117. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerState.mjs +8 -8
  118. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerWheel.d.ts +3 -3
  119. package/dist/plugins/MagicDrawer/src/composables/private/useDrawerWheel.mjs +23 -19
  120. package/dist/plugins/MagicDrawer/src/composables/useMagicDrawer.mjs +4 -3
  121. package/dist/plugins/MagicDrawer/src/types/index.d.ts +10 -3
  122. package/dist/plugins/MagicDrawer/src/utils/defaultOptions.d.ts +3 -11
  123. package/dist/plugins/MagicDrawer/src/utils/defaultOptions.mjs +1 -3
  124. package/dist/plugins/MagicEmitter/src/composables/useMagicEmitter.d.ts +190 -46
  125. package/dist/plugins/MagicEmitter/src/types/index.d.ts +1 -1
  126. package/dist/plugins/MagicMarquee/index.d.ts +4 -2
  127. package/dist/plugins/MagicMarquee/index.mjs +2 -1
  128. package/dist/plugins/MagicMarquee/src/components/MagicMarquee.vue +121 -50
  129. package/dist/plugins/MagicMarquee/src/components/MagicMarquee.vue.d.ts +18 -25
  130. package/dist/plugins/MagicMarquee/src/composables/private/useMarqueeApi.d.ts +4 -8
  131. package/dist/plugins/MagicMarquee/src/composables/private/useMarqueeApi.mjs +57 -43
  132. package/dist/plugins/MagicMarquee/src/composables/private/useMarqueeState.d.ts +7 -0
  133. package/dist/plugins/MagicMarquee/src/composables/private/useMarqueeState.mjs +42 -0
  134. package/dist/plugins/MagicMarquee/src/composables/useMagicMarquee.d.ts +11 -0
  135. package/dist/plugins/MagicMarquee/src/composables/useMagicMarquee.mjs +45 -0
  136. package/dist/plugins/MagicMarquee/src/types/index.d.ts +9 -0
  137. package/dist/plugins/MagicMarquee/src/types/index.mjs +0 -0
  138. package/dist/plugins/MagicMarquee/src/utils/defaultOptions.d.ts +4 -0
  139. package/dist/plugins/MagicMarquee/src/utils/defaultOptions.mjs +5 -0
  140. package/dist/plugins/MagicMenu/index.d.ts +2 -0
  141. package/dist/plugins/MagicMenu/nuxt.mjs +1 -1
  142. package/dist/plugins/MagicMenu/src/components/MagicMenuChannel.vue +78 -69
  143. package/dist/plugins/MagicMenu/src/components/MagicMenuChannel.vue.d.ts +17 -11
  144. package/dist/plugins/MagicMenu/src/components/MagicMenuContent.vue +245 -216
  145. package/dist/plugins/MagicMenu/src/components/MagicMenuContent.vue.d.ts +42 -14
  146. package/dist/plugins/MagicMenu/src/components/MagicMenuFloat.vue +234 -212
  147. package/dist/plugins/MagicMenu/src/components/MagicMenuFloat.vue.d.ts +42 -17
  148. package/dist/plugins/MagicMenu/src/components/MagicMenuItem.vue +115 -124
  149. package/dist/plugins/MagicMenu/src/components/MagicMenuItem.vue.d.ts +28 -16
  150. package/dist/plugins/MagicMenu/src/components/MagicMenuProvider.vue +105 -96
  151. package/dist/plugins/MagicMenu/src/components/MagicMenuProvider.vue.d.ts +14 -15
  152. package/dist/plugins/MagicMenu/src/components/MagicMenuRemote.vue +88 -87
  153. package/dist/plugins/MagicMenu/src/components/MagicMenuRemote.vue.d.ts +19 -14
  154. package/dist/plugins/MagicMenu/src/components/MagicMenuTrigger.vue +121 -112
  155. package/dist/plugins/MagicMenu/src/components/MagicMenuTrigger.vue.d.ts +27 -51
  156. package/dist/plugins/MagicMenu/src/components/MagicMenuView.vue +67 -70
  157. package/dist/plugins/MagicMenu/src/components/MagicMenuView.vue.d.ts +15 -11
  158. package/dist/plugins/MagicMenu/src/composables/private/useMenuCallback.d.ts +6 -6
  159. package/dist/plugins/MagicMenu/src/composables/private/useMenuCallback.mjs +9 -9
  160. package/dist/plugins/MagicMenu/src/composables/private/useMenuChannel.mjs +44 -25
  161. package/dist/plugins/MagicMenu/src/composables/private/useMenuCursor.d.ts +3 -3
  162. package/dist/plugins/MagicMenu/src/composables/private/useMenuCursor.mjs +16 -10
  163. package/dist/plugins/MagicMenu/src/composables/private/useMenuDOM.mjs +35 -15
  164. package/dist/plugins/MagicMenu/src/composables/private/useMenuItem.d.ts +1 -1
  165. package/dist/plugins/MagicMenu/src/composables/private/useMenuItem.mjs +20 -14
  166. package/dist/plugins/MagicMenu/src/composables/private/useMenuKeyListener.mjs +20 -13
  167. package/dist/plugins/MagicMenu/src/composables/private/useMenuState.mjs +10 -10
  168. package/dist/plugins/MagicMenu/src/composables/private/useMenuTrigger.d.ts +1 -1
  169. package/dist/plugins/MagicMenu/src/composables/private/useMenuTrigger.mjs +6 -3
  170. package/dist/plugins/MagicMenu/src/composables/private/useMenuView.d.ts +3 -3
  171. package/dist/plugins/MagicMenu/src/composables/private/useMenuView.mjs +111 -75
  172. package/dist/plugins/MagicMenu/src/symbols/index.d.ts +4 -4
  173. package/dist/plugins/MagicMenu/src/types/index.d.ts +1 -2
  174. package/dist/plugins/MagicMenu/src/utils/modeDelayDefaults.d.ts +2 -2
  175. package/dist/plugins/MagicMenu/src/utils/modeDelayDefaults.mjs +2 -2
  176. package/dist/plugins/MagicModal/src/components/MagicModal.vue +266 -166
  177. package/dist/plugins/MagicModal/src/components/MagicModal.vue.d.ts +45 -17
  178. package/dist/plugins/MagicModal/src/composables/private/useModalCallback.d.ts +6 -6
  179. package/dist/plugins/MagicModal/src/composables/private/useModalCallback.mjs +6 -6
  180. package/dist/plugins/MagicModal/src/composables/private/useModalDOM.mjs +34 -14
  181. package/dist/plugins/MagicModal/src/composables/private/useModalStore.mjs +1 -1
  182. package/dist/plugins/MagicModal/src/types/index.d.ts +2 -2
  183. package/dist/plugins/MagicModal/src/utils/defaultOptions.mjs +2 -2
  184. package/dist/plugins/MagicNoise/index.d.ts +3 -1
  185. package/dist/plugins/MagicNoise/src/components/MagicNoise.vue +120 -63
  186. package/dist/plugins/MagicNoise/src/components/MagicNoise.vue.d.ts +2 -4
  187. package/dist/plugins/MagicNoise/src/composables/private/useNoiseApi.d.ts +3 -3
  188. package/dist/plugins/MagicNoise/src/composables/private/useNoiseApi.mjs +4 -4
  189. package/dist/plugins/MagicPie/index.d.ts +7 -0
  190. package/dist/plugins/MagicPie/index.mjs +8 -0
  191. package/dist/plugins/MagicPie/nuxt.mjs +23 -0
  192. package/dist/plugins/MagicPie/src/components/MagicPie.vue +202 -0
  193. package/dist/plugins/MagicPie/src/components/MagicPie.vue.d.ts +7 -0
  194. package/dist/plugins/MagicPie/src/composables/private/usePieState.d.ts +6 -0
  195. package/dist/plugins/MagicPie/src/composables/private/usePieState.mjs +33 -0
  196. package/dist/plugins/MagicPie/src/composables/useMagicPie.d.ts +13 -0
  197. package/dist/plugins/MagicPie/src/composables/useMagicPie.mjs +43 -0
  198. package/dist/plugins/MagicPie/src/types/index.d.ts +9 -0
  199. package/dist/plugins/MagicPie/src/types/index.mjs +0 -0
  200. package/dist/plugins/MagicPlayer/index.d.ts +4 -9
  201. package/dist/plugins/MagicPlayer/index.mjs +11 -17
  202. package/dist/plugins/MagicPlayer/src/components/MagicPlayerAudio.vue +84 -0
  203. package/dist/plugins/MagicPlayer/src/components/MagicPlayerAudio.vue.d.ts +2 -0
  204. package/dist/plugins/MagicPlayer/src/components/MagicPlayerAudioControls.vue +128 -0
  205. package/dist/plugins/MagicPlayer/src/components/MagicPlayerAudioControls.vue.d.ts +34 -0
  206. package/dist/plugins/MagicPlayer/src/components/MagicPlayerDisplayTime.vue +45 -41
  207. package/dist/plugins/MagicPlayer/src/components/MagicPlayerDisplayTime.vue.d.ts +2 -5
  208. package/dist/plugins/MagicPlayer/src/components/MagicPlayerMuxPopover.vue +127 -114
  209. package/dist/plugins/MagicPlayer/src/components/MagicPlayerMuxPopover.vue.d.ts +4 -5
  210. package/dist/plugins/MagicPlayer/src/components/MagicPlayerOverlay.vue +111 -58
  211. package/dist/plugins/MagicPlayer/src/components/MagicPlayerOverlay.vue.d.ts +30 -18
  212. package/dist/plugins/MagicPlayer/src/components/MagicPlayerPoster.vue +42 -23
  213. package/dist/plugins/MagicPlayer/src/components/MagicPlayerPoster.vue.d.ts +14 -15
  214. package/dist/plugins/MagicPlayer/src/components/MagicPlayerProvider.vue +82 -0
  215. package/dist/plugins/MagicPlayer/src/components/MagicPlayerProvider.vue.d.ts +34 -0
  216. package/dist/plugins/MagicPlayer/src/components/MagicPlayerTimeline.vue +111 -65
  217. package/dist/plugins/MagicPlayer/src/components/MagicPlayerTimeline.vue.d.ts +1 -4
  218. package/dist/plugins/MagicPlayer/src/components/MagicPlayerVideo.vue +93 -0
  219. package/dist/plugins/MagicPlayer/src/components/MagicPlayerVideo.vue.d.ts +2 -0
  220. package/dist/plugins/MagicPlayer/src/components/MagicPlayerVideoControls.vue +221 -0
  221. package/dist/plugins/MagicPlayer/src/components/MagicPlayerVideoControls.vue.d.ts +73 -0
  222. package/dist/plugins/MagicPlayer/src/components/icons/FullscreenEnter.vue.d.ts +1 -1
  223. package/dist/plugins/MagicPlayer/src/components/icons/FullscreenExit.vue.d.ts +1 -1
  224. package/dist/plugins/MagicPlayer/src/components/icons/Pause.vue.d.ts +1 -1
  225. package/dist/plugins/MagicPlayer/src/components/icons/Play.vue.d.ts +1 -1
  226. package/dist/plugins/MagicPlayer/src/components/icons/VolumeOff.vue.d.ts +1 -1
  227. package/dist/plugins/MagicPlayer/src/components/icons/VolumeOn.vue.d.ts +1 -1
  228. package/dist/plugins/MagicPlayer/src/components/icons/Waiting.vue +23 -1
  229. package/dist/plugins/MagicPlayer/src/components/icons/Waiting.vue.d.ts +1 -1
  230. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerAudioApi.d.ts +2 -2
  231. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerAudioApi.mjs +8 -9
  232. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerControlsApi.d.ts +10 -10
  233. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerControlsApi.mjs +33 -31
  234. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerMediaApi.d.ts +13 -13
  235. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerMediaApi.mjs +31 -24
  236. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerRuntime.d.ts +5 -5
  237. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerRuntime.mjs +7 -7
  238. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerVideoApi.d.ts +6 -6
  239. package/dist/plugins/MagicPlayer/src/composables/private/usePlayerVideoApi.mjs +10 -12
  240. package/dist/plugins/MagicPlayer/src/composables/useMagicPlayer.d.ts +22 -26
  241. package/dist/plugins/MagicPlayer/src/composables/useMagicPlayer.mjs +5 -5
  242. package/dist/plugins/MagicPlayer/src/css/magic-player-audio-controls.css +95 -0
  243. package/dist/plugins/MagicPlayer/src/css/magic-player-display-time.css +10 -0
  244. package/dist/plugins/MagicPlayer/src/css/magic-player-timeline.css +89 -0
  245. package/dist/plugins/MagicPlayer/src/css/magic-player-video-controls.css +115 -0
  246. package/dist/plugins/MagicPlayer/src/symbols/index.d.ts +5 -0
  247. package/dist/plugins/MagicPlayer/src/symbols/index.mjs +3 -0
  248. package/dist/plugins/MagicPlayer/src/types/index.d.ts +11 -1
  249. package/dist/plugins/MagicPlayer/src/utils/defaultOptions.d.ts +3 -0
  250. package/dist/plugins/MagicPlayer/src/utils/defaultOptions.mjs +12 -0
  251. package/dist/plugins/MagicScroll/index.d.ts +4 -10
  252. package/dist/plugins/MagicScroll/index.mjs +2 -11
  253. package/dist/plugins/MagicScroll/src/components/MagicScrollCollision.vue +76 -31
  254. package/dist/plugins/MagicScroll/src/components/MagicScrollCollision.vue.d.ts +13 -17
  255. package/dist/plugins/MagicScroll/src/components/MagicScrollMotion.vue +78 -64
  256. package/dist/plugins/MagicScroll/src/components/MagicScrollMotion.vue.d.ts +13 -20
  257. package/dist/plugins/MagicScroll/src/components/MagicScrollProvider.vue +39 -39
  258. package/dist/plugins/MagicScroll/src/components/MagicScrollProvider.vue.d.ts +48 -34
  259. package/dist/plugins/MagicScroll/src/components/MagicScrollScene.vue +84 -73
  260. package/dist/plugins/MagicScroll/src/components/MagicScrollScene.vue.d.ts +16 -21
  261. package/dist/plugins/MagicScroll/src/composables/private/useCollisionDetection.d.ts +13 -0
  262. package/dist/plugins/MagicScroll/src/composables/private/useCollisionDetection.mjs +130 -0
  263. package/dist/plugins/MagicScroll/src/composables/private/useScrollApi.d.ts +3 -3
  264. package/dist/plugins/MagicScroll/src/composables/private/useScrollApi.mjs +19 -7
  265. package/dist/plugins/MagicScroll/src/symbols/index.d.ts +2 -2
  266. package/dist/plugins/MagicScroll/src/symbols/index.mjs +2 -2
  267. package/dist/plugins/MagicScroll/src/types/index.d.ts +12 -22
  268. package/dist/plugins/MagicToast/index.d.ts +3 -2
  269. package/dist/plugins/MagicToast/index.mjs +3 -3
  270. package/dist/plugins/MagicToast/nuxt.mjs +2 -2
  271. package/dist/plugins/MagicToast/src/components/MagicToastProvider.vue +290 -0
  272. package/dist/plugins/MagicToast/src/components/{MagicToast.vue.d.ts → MagicToastProvider.vue.d.ts} +4 -4
  273. package/dist/plugins/MagicToast/src/components/MagicToastView.vue +152 -0
  274. package/dist/plugins/MagicToast/src/components/MagicToastView.vue.d.ts +34 -0
  275. package/dist/plugins/MagicToast/src/composables/private/useToastCallback.d.ts +8 -31
  276. package/dist/plugins/MagicToast/src/composables/private/useToastCallback.mjs +33 -28
  277. package/dist/plugins/MagicToast/src/composables/private/useToastDrag.d.ts +12 -0
  278. package/dist/plugins/MagicToast/src/composables/private/useToastDrag.mjs +312 -0
  279. package/dist/plugins/MagicToast/src/composables/private/useToastListener.d.ts +6 -0
  280. package/dist/plugins/MagicToast/src/composables/private/useToastListener.mjs +25 -0
  281. package/dist/plugins/MagicToast/src/composables/private/useToastScrollLock.d.ts +6 -0
  282. package/dist/plugins/MagicToast/src/composables/private/useToastScrollLock.mjs +59 -0
  283. package/dist/plugins/MagicToast/src/composables/private/useToastState.d.ts +7 -0
  284. package/dist/plugins/MagicToast/src/composables/private/useToastState.mjs +45 -0
  285. package/dist/plugins/MagicToast/src/composables/private/useToastView.d.ts +12 -0
  286. package/dist/plugins/MagicToast/src/composables/private/useToastView.mjs +51 -0
  287. package/dist/plugins/MagicToast/src/composables/useMagicToast.d.ts +14 -8
  288. package/dist/plugins/MagicToast/src/composables/useMagicToast.mjs +34 -23
  289. package/dist/plugins/MagicToast/src/types/index.d.ts +58 -17
  290. package/dist/plugins/MagicToast/src/utils/defaultOptions.d.ts +2 -3
  291. package/dist/plugins/MagicToast/src/utils/defaultOptions.mjs +21 -4
  292. package/dist/plugins/MagicToast/symbols/index.d.ts +3 -0
  293. package/dist/plugins/MagicToast/symbols/index.mjs +2 -0
  294. package/dist/plugins/index.d.ts +1 -1
  295. package/dist/plugins/index.mjs +1 -1
  296. package/dist/utils/css/animations/auto-size-out.css +12 -0
  297. package/dist/utils/css/animations/squash-y.css +5 -0
  298. package/dist/utils/css/animations.css +2 -1
  299. package/dist/utils/index.d.ts +10 -6
  300. package/dist/utils/index.js +41 -56
  301. package/dist/utils/index.js.map +1 -1
  302. package/package.json +62 -58
  303. package/dist/composables/index.d.mts +0 -108
  304. package/dist/composables/index.mjs +0 -383
  305. package/dist/composables/index.mjs.map +0 -1
  306. package/dist/plugins/MagicAutoSize/index.d.ts +0 -4
  307. package/dist/plugins/MagicAutoSize/index.mjs +0 -7
  308. package/dist/plugins/MagicAutoSize/nuxt.mjs +0 -14
  309. package/dist/plugins/MagicAutoSize/src/components/MagicAutoSize.vue +0 -152
  310. package/dist/plugins/MagicAutoSize/src/components/MagicAutoSize.vue.d.ts +0 -29
  311. package/dist/plugins/MagicCommand/src/components/MagicCommandBody.vue +0 -91
  312. package/dist/plugins/MagicCommand/src/components/MagicCommandBody.vue.d.ts +0 -19
  313. package/dist/plugins/MagicCommand/src/components/MagicCommandFooter.vue +0 -5
  314. package/dist/plugins/MagicCommand/src/components/MagicCommandFooter.vue.d.ts +0 -17
  315. package/dist/plugins/MagicCommand/src/components/MagicCommandGroup.vue +0 -5
  316. package/dist/plugins/MagicCommand/src/components/MagicCommandGroup.vue.d.ts +0 -17
  317. package/dist/plugins/MagicCommand/src/components/MagicCommandHead.vue +0 -5
  318. package/dist/plugins/MagicCommand/src/components/MagicCommandHead.vue.d.ts +0 -17
  319. package/dist/plugins/MagicCommand/src/composables/private/useCommandStore.d.ts +0 -35
  320. package/dist/plugins/MagicCommand/src/composables/private/useCommandStore.mjs +0 -67
  321. package/dist/plugins/MagicCookie/src/components/MagicCookie.vue +0 -117
  322. package/dist/plugins/MagicCookie/src/components/MagicCookie.vue.d.ts +0 -27
  323. package/dist/plugins/MagicCookie/src/composables/private/useCookieApi.d.ts +0 -29
  324. package/dist/plugins/MagicCookie/src/composables/private/useCookieApi.mjs +0 -22
  325. package/dist/plugins/MagicPlayer/src/components/MagicAudioPlayer.vue +0 -89
  326. package/dist/plugins/MagicPlayer/src/components/MagicAudioPlayer.vue.d.ts +0 -28
  327. package/dist/plugins/MagicPlayer/src/components/MagicAudioPlayerControls.vue +0 -95
  328. package/dist/plugins/MagicPlayer/src/components/MagicAudioPlayerControls.vue.d.ts +0 -24
  329. package/dist/plugins/MagicPlayer/src/components/MagicPlayer.vue +0 -125
  330. package/dist/plugins/MagicPlayer/src/components/MagicPlayer.vue.d.ts +0 -35
  331. package/dist/plugins/MagicPlayer/src/components/MagicPlayerControls.vue +0 -152
  332. package/dist/plugins/MagicPlayer/src/components/MagicPlayerControls.vue.d.ts +0 -38
  333. package/dist/plugins/MagicScroll/src/components/MagicScrollTransform.vue +0 -42
  334. package/dist/plugins/MagicScroll/src/components/MagicScrollTransform.vue.d.ts +0 -36
  335. package/dist/plugins/MagicScroll/src/composables/private/useCollisionDetect.d.ts +0 -56
  336. package/dist/plugins/MagicScroll/src/composables/private/useCollisionDetect.mjs +0 -140
  337. package/dist/plugins/MagicToast/src/components/MagicToast.vue +0 -141
  338. package/dist/plugins/MagicToast/src/components/MagicToastComponent.vue +0 -64
  339. package/dist/plugins/MagicToast/src/components/MagicToastComponent.vue.d.ts +0 -30
  340. package/dist/plugins/MagicToast/src/composables/private/useToastApi.d.ts +0 -5
  341. package/dist/plugins/MagicToast/src/composables/private/useToastApi.mjs +0 -22
  342. package/dist/plugins/MagicToast/src/composables/private/useToastInternalApi.d.ts +0 -4
  343. package/dist/plugins/MagicToast/src/composables/private/useToastInternalApi.mjs +0 -28
  344. package/dist/plugins/MagicToast/src/composables/private/useToastStore.d.ts +0 -27
  345. package/dist/plugins/MagicToast/src/composables/private/useToastStore.mjs +0 -41
  346. package/dist/utils/index.d.mts +0 -80
  347. package/dist/utils/index.mjs +0 -200
  348. package/dist/utils/index.mjs.map +0 -1
  349. /package/dist/plugins/{MagicAutoSize → MagicPie}/nuxt.d.ts +0 -0
@@ -0,0 +1,10 @@
1
+ .magic-player-display-time {
2
+ height: 100%;
3
+ width: 4rem;
4
+ font-size: 0.875rem;
5
+ color: inherit;
6
+ display: flex;
7
+ align-items: center;
8
+ justify-content: center;
9
+ font-variant-numeric: tabular-nums;
10
+ }
@@ -0,0 +1,89 @@
1
+ :root {
2
+ --magic-player-timeline-track-height: 0.25rem;
3
+ }
4
+
5
+ .magic-player-timeline {
6
+ position: relative;
7
+ width: 100%;
8
+ height: var(--magic-player-timeline-track-height);
9
+ display: flex;
10
+ align-items: center;
11
+ }
12
+
13
+ .magic-player-timeline__target {
14
+ position: relative;
15
+ width: 100%;
16
+ height: 3.5rem;
17
+ display: flex;
18
+ align-items: center;
19
+ cursor: pointer;
20
+ }
21
+
22
+ .magic-player-timeline__track {
23
+ position: relative;
24
+ width: 100%;
25
+ height: var(--magic-player-timeline-track-height);
26
+ background: rgba(250, 250, 250, 0.15);
27
+ border-radius: 50rem;
28
+ }
29
+
30
+ .magic-player-timeline__inner-track {
31
+ position: relative;
32
+ border-radius: 50rem;
33
+ overflow: hidden;
34
+ width: 100%;
35
+ height: 100%;
36
+ top: 0;
37
+ left: 0;
38
+ z-index: 1;
39
+ }
40
+
41
+ .magic-player-timeline__thumb {
42
+ position: absolute;
43
+ width: var(--magic-player-timeline-track-height);
44
+ height: var(--magic-player-timeline-track-height);
45
+ z-index: 10;
46
+ }
47
+
48
+ .magic-player-timeline__thumb-handle {
49
+ position: absolute;
50
+ width: 1rem;
51
+ height: 1rem;
52
+ top: 50%;
53
+ left: 50%;
54
+ transform: translate(-50%, -50%) scale(0);
55
+ transition: transform 300ms ease;
56
+ z-index: 10;
57
+ background-color: rgba(250, 250, 250, 1);
58
+ border-radius: 50rem;
59
+ }
60
+
61
+ .magic-player-timeline__scrubbed,
62
+ .magic-player-timeline__seeked,
63
+ .magic-player-timeline__buffered {
64
+ position: absolute;
65
+ left: 0;
66
+ width: 100%;
67
+ height: 100%;
68
+ margin-left: calc(-100% + var(--magic-player-timeline-track-height));
69
+ background: currentColor;
70
+ border-radius: 50rem;
71
+ }
72
+
73
+ .magic-player-timeline__scrubbed {
74
+ z-index: 1;
75
+ min-width: var(--magic-player-timeline-track-height);
76
+ display: flex;
77
+ }
78
+
79
+ .magic-player-timeline__seeked {
80
+ opacity: 0.25;
81
+ }
82
+
83
+ .magic-player-timeline__buffered {
84
+ opacity: 0.15;
85
+ }
86
+
87
+ .magic-player-timeline:hover .magic-player-timeline__thumb-handle {
88
+ transform: translate3d(-50%, -50%, 0) scale(1);
89
+ }
@@ -0,0 +1,115 @@
1
+ @import './magic-player-timeline.css';
2
+ @import './magic-player-display-time.css';
3
+
4
+ :root {
5
+ --magic-player-video-controls-left: 1.5rem;
6
+ --magic-player-video-controls-height: 3rem;
7
+ }
8
+
9
+ @media (max-width: 640px) {
10
+ :root {
11
+ --magic-player-video-controls-height: 2.5rem;
12
+ --magic-player-video-controls-left: 0.75rem;
13
+ }
14
+ }
15
+
16
+ .magic-player-video-controls {
17
+ position: absolute;
18
+ inset: 0;
19
+ width: 100%;
20
+ pointer-events: none;
21
+ }
22
+
23
+ .magic-player-video-controls-enter-active {
24
+ animation: fade-up-in 150ms ease;
25
+ }
26
+
27
+ .magic-player-video-controls-leave-active {
28
+ animation: fade-up-out 150ms ease;
29
+ }
30
+
31
+ .magic-player-video-controls__bar {
32
+ position: absolute;
33
+ width: calc(100% - (var(--magic-player-video-controls-left) * 2));
34
+ bottom: 1.5rem;
35
+ left: var(--magic-player-video-controls-left);
36
+ margin: 0 auto;
37
+ display: flex;
38
+ flex-direction: column;
39
+ align-items: flex-start;
40
+ gap: 1rem;
41
+ pointer-events: auto;
42
+ }
43
+
44
+ .magic-player-video-controls__bar--inner {
45
+ width: 100%;
46
+ box-sizing: border-box;
47
+ height: var(--magic-player-video-controls-height);
48
+ padding: 0 0.75rem;
49
+ background-color: rgba(32, 32, 32, 0.8);
50
+ backdrop-filter: blur(80px);
51
+ color: rgba(255, 255, 255, 1);
52
+ border-radius: 50rem;
53
+ display: flex;
54
+ align-items: center;
55
+ }
56
+
57
+ .magic-player-video-controls__item {
58
+ display: inline-flex;
59
+ align-items: center;
60
+ user-select: none;
61
+ }
62
+
63
+ .magic-player-video-controls__item.-shrink-0 {
64
+ flex-shrink: 0;
65
+ }
66
+
67
+ .magic-player-video-controls__item.-grow {
68
+ flex-grow: 1;
69
+ }
70
+
71
+ .magic-player-video-controls__item button {
72
+ background-color: transparent;
73
+ color: inherit;
74
+ border: 0;
75
+ outline: none;
76
+ appearance: none;
77
+ padding: 0;
78
+ border-radius: 0;
79
+ cursor: pointer;
80
+ width: 3rem;
81
+ height: var(--magic-player-video-controls-height);
82
+ display: flex;
83
+ align-items: center;
84
+ justify-content: center;
85
+ }
86
+
87
+ .magic-player-video-controls__item button svg {
88
+ display: block;
89
+ width: 1.25rem;
90
+ height: auto;
91
+ }
92
+
93
+ .magic-player-video-controls__timeline {
94
+ width: 100%;
95
+ }
96
+
97
+ .magic-player-video-controls[data-standalone='true'] {
98
+ position: relative;
99
+ inset: unset;
100
+ width: 100%;
101
+ --magic-player-video-controls-left: 0;
102
+ & .magic-player-video-controls__bar--inner {
103
+ background-color: transparent;
104
+ backdrop-filter: none;
105
+ }
106
+
107
+ & .magic-player-video-controls__bar {
108
+ position: relative;
109
+ bottom: 0;
110
+ padding: 0;
111
+ background-color: transparent;
112
+ border-radius: unset;
113
+ backdrop-filter: none;
114
+ }
115
+ }
@@ -0,0 +1,5 @@
1
+ import type { InjectionKey, MaybeRef } from 'vue';
2
+ import type { MagicPlayerOptions } from '../types/index.js';
3
+ declare const MagicPlayerInstanceId: InjectionKey<MaybeRef<string>>;
4
+ declare const MagicPlayerOptionsKey: InjectionKey<MagicPlayerOptions>;
5
+ export { MagicPlayerInstanceId, MagicPlayerOptionsKey };
@@ -0,0 +1,3 @@
1
+ const MagicPlayerInstanceId = Symbol();
2
+ const MagicPlayerOptionsKey = Symbol();
3
+ export { MagicPlayerInstanceId, MagicPlayerOptionsKey };
@@ -1,4 +1,14 @@
1
- export type MagicPlayerSourceType = 'native' | 'hls';
1
+ export interface MagicPlayerOptions {
2
+ src: string;
3
+ mode?: 'audio' | 'video';
4
+ srcType?: 'native' | 'hls';
5
+ preload?: 'auto' | 'metadata' | 'none';
6
+ autoplay?: boolean;
7
+ loop?: boolean;
8
+ transition?: {
9
+ videoControls: string;
10
+ };
11
+ }
2
12
  type API = 'media' | 'player' | 'controls' | 'runtime' | 'player';
3
13
  export type Buffered = [number, number][];
4
14
  export type PlayerPrivateEvents = {
@@ -0,0 +1,3 @@
1
+ import type { MagicPlayerOptions } from '../types/index.js';
2
+ declare const defaultOptions: MagicPlayerOptions;
3
+ export { defaultOptions };
@@ -0,0 +1,12 @@
1
+ const defaultOptions = {
2
+ mode: "video",
3
+ src: "",
4
+ srcType: "native",
5
+ preload: "metadata",
6
+ autoplay: false,
7
+ loop: false,
8
+ transition: {
9
+ videoControls: "magic-player-video-controls"
10
+ }
11
+ };
12
+ export { defaultOptions };
@@ -1,12 +1,6 @@
1
- import MagicScrollProvider from './src/components/MagicScrollProvider.vue.js';
2
- import MagicScrollScene from './src/components/MagicScrollScene.vue.js';
3
- import MagicScrollTransform from './src/components/MagicScrollTransform.vue.js';
4
- import MagicScrollMotion from './src/components/MagicScrollMotion.vue.js';
5
- import MagicScrollCollision from './src/components/MagicScrollCollision.vue.js';
6
- import { useCollisionDetect } from './src/composables/private/useCollisionDetect.js';
7
- import { MagicScrollParent, MagicScrollProgress, MagicScrollReturn } from './src/symbols/index.js';
8
- import type { MagicScrollCollisionEntry } from './src/types/index.js';
1
+ import { MagicScrollTarget, MagicScrollProgress, MagicScrollReturn } from './src/symbols/index.js';
9
2
  import type { Plugin } from 'vue';
3
+ import type { MagicScrollSequence } from './src/types/index.js';
10
4
  declare const MagicScrollPlugin: Plugin;
11
- export { MagicScrollPlugin, MagicScrollProvider, MagicScrollScene, MagicScrollTransform, MagicScrollMotion, MagicScrollCollision, useCollisionDetect, MagicScrollParent, MagicScrollProgress, MagicScrollReturn, };
12
- export type { MagicScrollCollisionEntry };
5
+ export { MagicScrollPlugin, MagicScrollTarget, MagicScrollProgress, MagicScrollReturn, };
6
+ export type { MagicScrollSequence };
@@ -1,11 +1,9 @@
1
1
  import MagicScrollProvider from "./src/components/MagicScrollProvider.vue";
2
2
  import MagicScrollScene from "./src/components/MagicScrollScene.vue";
3
- import MagicScrollTransform from "./src/components/MagicScrollTransform.vue";
4
3
  import MagicScrollMotion from "./src/components/MagicScrollMotion.vue";
5
4
  import MagicScrollCollision from "./src/components/MagicScrollCollision.vue";
6
- import { useCollisionDetect } from "./src/composables/private/useCollisionDetect.mjs";
7
5
  import {
8
- MagicScrollParent,
6
+ MagicScrollTarget,
9
7
  MagicScrollProgress,
10
8
  MagicScrollReturn
11
9
  } from "./src/symbols/index.mjs";
@@ -13,20 +11,13 @@ const MagicScrollPlugin = {
13
11
  install: (app) => {
14
12
  app.component("MagicScrollProvider", MagicScrollProvider);
15
13
  app.component("MagicScrollScene", MagicScrollScene);
16
- app.component("MagicScrollTransform", MagicScrollTransform);
17
14
  app.component("MagicScrollMotion", MagicScrollMotion);
18
15
  app.component("MagicScrollCollision", MagicScrollCollision);
19
16
  }
20
17
  };
21
18
  export {
22
19
  MagicScrollPlugin,
23
- MagicScrollProvider,
24
- MagicScrollScene,
25
- MagicScrollTransform,
26
- MagicScrollMotion,
27
- MagicScrollCollision,
28
- useCollisionDetect,
29
- MagicScrollParent,
20
+ MagicScrollTarget,
30
21
  MagicScrollProgress,
31
22
  MagicScrollReturn
32
23
  };
@@ -1,32 +1,77 @@
1
- <template>
2
- <div ref="elRef" :style="{ display: 'contents' }">
3
- <slot />
4
- </div>
5
- </template>
6
-
7
- <script setup lang="ts">
8
- import { ref, inject, computed, onMounted } from 'vue'
9
- import { toValue } from '@vueuse/core'
10
- import { useCollisionDetect } from '../composables/private/useCollisionDetect'
11
- import { MagicScrollReturn } from '../symbols'
12
-
13
- import type { MagicScrollCollisionEntry } from '../types'
14
-
15
- interface Props {
16
- entries: MagicScrollCollisionEntry[]
17
- }
18
-
19
- const props = defineProps<Props>()
20
- const elRef = ref<HTMLElement | undefined>(undefined)
21
-
22
- const scrollReturn = inject(MagicScrollReturn, undefined)
23
- const scrollY = computed(() => toValue(scrollReturn?.y) || 0)
24
-
25
- onMounted(() => {
26
- useCollisionDetect({
27
- scrollY,
28
- entries: props.entries,
29
- parent: toValue(elRef),
30
- })
31
- })
1
+ <script>
2
+ import { defineComponent as _defineComponent } from "vue";
3
+ import { renderSlot as _renderSlot, openBlock as _openBlock, createElementBlock as _createElementBlock } from "vue";
4
+ const _hoisted_1 = {
5
+ ref: "el",
6
+ class: "magic-scroll-collision"
7
+ };
8
+ import {
9
+ shallowRef,
10
+ inject,
11
+ computed,
12
+ toValue,
13
+ watch,
14
+ useId,
15
+ onMounted,
16
+ useTemplateRef
17
+ } from "vue";
18
+ import { useCollisionDetection } from "../composables/private/useCollisionDetection";
19
+ import { MagicScrollReturn, MagicScrollTarget } from "../symbols";
20
+ import { useIntersectionObserver } from "@vueuse/core";
21
+ export default /* @__PURE__ */ _defineComponent({
22
+ __name: "MagicScrollCollision",
23
+ props: {
24
+ id: { type: String, required: false },
25
+ offset: { type: Object, required: false }
26
+ },
27
+ setup(__props) {
28
+ const scrollReturn = inject(MagicScrollReturn, void 0);
29
+ const scrollTarget = inject(MagicScrollTarget);
30
+ if (!scrollTarget) {
31
+ console.error(
32
+ "MagicScrollCollision must be used within a MagicScrollProvider"
33
+ );
34
+ }
35
+ const intersecting = shallowRef(false);
36
+ const elRef = useTemplateRef("el");
37
+ const scrollY = computed(() => toValue(scrollReturn?.y) || 0);
38
+ const mappedId = computed(() => __props.id ?? `magic-scroll-collision-${useId()}`);
39
+ const { observe } = useCollisionDetection({
40
+ id: mappedId.value,
41
+ child: elRef,
42
+ parent: scrollTarget,
43
+ scrollY,
44
+ offset: __props.offset
45
+ });
46
+ watch(
47
+ () => scrollY.value,
48
+ () => {
49
+ if (intersecting.value) {
50
+ observe();
51
+ }
52
+ }
53
+ );
54
+ useIntersectionObserver(
55
+ elRef,
56
+ ([{ isIntersecting }]) => {
57
+ intersecting.value = isIntersecting;
58
+ },
59
+ { rootMargin: "150% 0px 150% 0px", immediate: true }
60
+ );
61
+ onMounted(() => {
62
+ observe();
63
+ });
64
+ return (_ctx, _cache) => {
65
+ return _openBlock(), _createElementBlock(
66
+ "div",
67
+ _hoisted_1,
68
+ [
69
+ _renderSlot(_ctx.$slots, "default")
70
+ ],
71
+ 512
72
+ /* NEED_PATCH */
73
+ );
74
+ };
75
+ }
76
+ });
32
77
  </script>
@@ -1,22 +1,18 @@
1
- import type { MagicScrollCollisionEntry } from '../types';
2
- interface Props {
3
- entries: MagicScrollCollisionEntry[];
1
+ import type { CollisionOffset } from '../types/index.js';
2
+ interface MagicScrollCollisionProps {
3
+ id?: string;
4
+ offset?: CollisionOffset;
4
5
  }
5
- declare function __VLS_template(): {
6
- attrs: Partial<{}>;
7
- slots: {
8
- default?(_: {}): any;
9
- };
10
- refs: {
11
- elRef: HTMLDivElement;
12
- };
13
- rootEl: HTMLDivElement;
14
- };
15
- type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
16
- declare const __VLS_component: import("vue").DefineComponent<Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<Props> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, HTMLDivElement>;
17
- declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
6
+ declare const __VLS_ctx: InstanceType<__VLS_PickNotAny<typeof __VLS_self, new () => {}>>;
7
+ declare var __VLS_1: {};
8
+ type __VLS_Slots = __VLS_PrettifyGlobal<__VLS_OmitStringIndex<typeof __VLS_ctx.$slots> & {
9
+ default?: (props: typeof __VLS_1) => any;
10
+ }>;
11
+ declare const __VLS_self: import("vue").DefineComponent<MagicScrollCollisionProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<MagicScrollCollisionProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
12
+ declare const __VLS_component: import("vue").DefineComponent<MagicScrollCollisionProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<MagicScrollCollisionProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
13
+ declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
18
14
  export default _default;
19
- type __VLS_WithTemplateSlots<T, S> = T & {
15
+ type __VLS_WithSlots<T, S> = T & {
20
16
  new (): {
21
17
  $slots: S;
22
18
  };
@@ -1,67 +1,81 @@
1
- <template>
2
- <div ref="elRef" class="magic-scroll-motion">
3
- <slot />
4
- </div>
5
- </template>
6
-
7
- <script setup lang="ts">
8
- import { ref, inject, computed, onMounted, watch } from 'vue'
9
- import { unrefElement } from '@vueuse/core'
1
+ <script>
2
+ import { defineComponent as _defineComponent } from "vue";
3
+ import { renderSlot as _renderSlot, openBlock as _openBlock, createElementBlock as _createElementBlock } from "vue";
4
+ const _hoisted_1 = {
5
+ ref: "el",
6
+ class: "magic-scroll-motion"
7
+ };
8
+ import { ref, inject, computed, onMounted, watch, useTemplateRef } from "vue";
9
+ import { unrefElement } from "@vueuse/core";
10
+ import defu from "defu";
10
11
  import {
11
- animate,
12
- type MotionKeyframesDefinition,
13
- type AnimationControls,
14
- type Easing,
15
- } from 'motion'
16
- import { MagicScrollProgress } from '../symbols'
17
-
18
- interface MagicScrollMotionProps {
19
- keyframes?: MotionKeyframesDefinition
20
- offset?: number[]
21
- easing?: Easing
22
- progress?: number
23
- }
24
-
25
- const props = withDefaults(defineProps<MagicScrollMotionProps>(), {
26
- easing: 'linear',
27
- })
28
-
29
- const animation = ref<AnimationControls | undefined>(undefined)
30
- const elRef = ref<HTMLElement | undefined>(undefined)
31
-
32
- const progress = inject(
33
- MagicScrollProgress,
34
- computed(() => 0)
35
- )
36
-
37
- const mappedProgress = computed(() => {
38
- return props.progress || progress.value || 0
39
- })
40
-
41
- function createAnimation() {
42
- if (!props.keyframes) return
43
- animation.value = animate(unrefElement(elRef)!, props.keyframes, {
44
- duration: 1,
45
- easing: props.easing || 'linear',
46
- offset: props.offset,
47
- })
48
- animation.value.stop()
49
- animation.value.currentTime = mappedProgress.value
50
- }
51
-
52
- onMounted(() => {
53
- createAnimation()
54
- })
55
-
56
- watch(mappedProgress, (value) => {
57
- if ((!value && value !== 0) || !animation.value || !props.keyframes) return
58
- animation.value.currentTime = value
59
- })
60
-
61
- watch(
62
- () => props.keyframes,
63
- () => {
64
- createAnimation()
12
+ animate
13
+ } from "motion";
14
+ import { MagicScrollProgress } from "../symbols";
15
+ export default /* @__PURE__ */ _defineComponent({
16
+ __name: "MagicScrollMotion",
17
+ props: {
18
+ sequence: { type: Array, required: true },
19
+ sequenceOptions: { type: Object, required: false },
20
+ progress: { type: Number, required: false }
21
+ },
22
+ setup(__props) {
23
+ const animation = ref(void 0);
24
+ const elRef = useTemplateRef("el");
25
+ const injectedProgress = inject(
26
+ MagicScrollProgress,
27
+ computed(() => 0)
28
+ );
29
+ const mappedProgress = computed(() => {
30
+ return __props.progress || injectedProgress.value || 0;
31
+ });
32
+ const defaultSequenceOptions = {
33
+ duration: 1,
34
+ delay: 0
35
+ };
36
+ const mappedSequenceOptions = defu(__props.sequenceOptions, defaultSequenceOptions);
37
+ function createAnimation() {
38
+ const el = unrefElement(elRef);
39
+ if (!__props.sequence || !__props.sequence.length || !el) {
40
+ return;
41
+ }
42
+ const mappedSequence = __props.sequence.map((item) => {
43
+ const [animation2 = [], options = {}] = item;
44
+ return [el, animation2, options];
45
+ });
46
+ animation.value = animate(mappedSequence, mappedSequenceOptions);
47
+ animation.value.pause();
48
+ animation.value.time = mappedProgress.value;
49
+ }
50
+ watch(mappedProgress, (value) => {
51
+ if (!value && value !== 0 || !animation.value) {
52
+ return;
53
+ }
54
+ animation.value.time = value;
55
+ });
56
+ watch(
57
+ () => __props.sequence,
58
+ () => {
59
+ createAnimation();
60
+ },
61
+ {
62
+ deep: true
63
+ }
64
+ );
65
+ onMounted(() => {
66
+ createAnimation();
67
+ });
68
+ return (_ctx, _cache) => {
69
+ return _openBlock(), _createElementBlock(
70
+ "div",
71
+ _hoisted_1,
72
+ [
73
+ _renderSlot(_ctx.$slots, "default")
74
+ ],
75
+ 512
76
+ /* NEED_PATCH */
77
+ );
78
+ };
65
79
  }
66
- )
80
+ });
67
81
  </script>
@@ -1,27 +1,20 @@
1
- import { type MotionKeyframesDefinition, type Easing } from 'motion';
1
+ import { type SequenceOptions } from 'motion';
2
+ import { type MagicScrollSequence } from '../types/index.js';
2
3
  interface MagicScrollMotionProps {
3
- keyframes?: MotionKeyframesDefinition;
4
- offset?: number[];
5
- easing?: Easing;
4
+ sequence: MagicScrollSequence;
5
+ sequenceOptions?: SequenceOptions;
6
6
  progress?: number;
7
7
  }
8
- declare function __VLS_template(): {
9
- attrs: Partial<{}>;
10
- slots: {
11
- default?(_: {}): any;
12
- };
13
- refs: {
14
- elRef: HTMLDivElement;
15
- };
16
- rootEl: HTMLDivElement;
17
- };
18
- type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
19
- declare const __VLS_component: import("vue").DefineComponent<MagicScrollMotionProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<MagicScrollMotionProps> & Readonly<{}>, {
20
- easing: Easing;
21
- }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, HTMLDivElement>;
22
- declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
8
+ declare const __VLS_ctx: InstanceType<__VLS_PickNotAny<typeof __VLS_self, new () => {}>>;
9
+ declare var __VLS_1: {};
10
+ type __VLS_Slots = __VLS_PrettifyGlobal<__VLS_OmitStringIndex<typeof __VLS_ctx.$slots> & {
11
+ default?: (props: typeof __VLS_1) => any;
12
+ }>;
13
+ declare const __VLS_self: import("vue").DefineComponent<MagicScrollMotionProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<MagicScrollMotionProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
14
+ declare const __VLS_component: import("vue").DefineComponent<MagicScrollMotionProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<MagicScrollMotionProps> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
15
+ declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
23
16
  export default _default;
24
- type __VLS_WithTemplateSlots<T, S> = T & {
17
+ type __VLS_WithSlots<T, S> = T & {
25
18
  new (): {
26
19
  $slots: S;
27
20
  };