move.gl 0.0.1 → 0.0.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 (463) hide show
  1. package/README.md +185 -11
  2. package/dist/LICENSE +21 -0
  3. package/dist/README.md +212 -0
  4. package/dist/css/move.gl.css +43859 -0
  5. package/dist/css/move.gl.min.css +19 -0
  6. package/dist/js/index.cjs +1171 -0
  7. package/dist/js/index.cjs.map +1 -0
  8. package/dist/js/index.d.cts +184 -0
  9. package/dist/js/index.d.ts +184 -0
  10. package/dist/js/index.mjs +1135 -0
  11. package/dist/js/index.mjs.map +1 -0
  12. package/dist/package.json +68 -0
  13. package/{scss → dist/scss}/classes/_animations.scss +33 -14
  14. package/dist/scss/classes/_controls.scss +314 -0
  15. package/dist/scss/classes/_effects.scss +283 -0
  16. package/dist/scss/classes/_index.scss +28 -0
  17. package/dist/scss/classes/_loaders.scss +779 -0
  18. package/dist/scss/classes/_transforms.scss +138 -0
  19. package/dist/scss/classes/_transitions.scss +264 -0
  20. package/{scss → dist/scss}/dev/_deprecation.scss +6 -3
  21. package/{scss → dist/scss}/dev/_modules.scss +5 -6
  22. package/dist/scss/docs.scss +2344 -0
  23. package/dist/scss/docs.scss.bak +3133 -0
  24. package/dist/scss/functions/_index.scss +22 -0
  25. package/dist/scss/functions/scenes/_bubble.scss +32 -0
  26. package/dist/scss/functions/scenes/_index.scss +21 -0
  27. package/dist/scss/index.scss +17 -0
  28. package/dist/scss/maps/_controls.scss +85 -0
  29. package/dist/scss/maps/_index.scss +22 -0
  30. package/{scss → dist/scss}/mixins/_accessibility.scss +24 -3
  31. package/{scss → dist/scss}/mixins/_boot.scss +4 -4
  32. package/dist/scss/mixins/_index.scss +41 -0
  33. package/dist/scss/mixins/_screensaver.scss +228 -0
  34. package/dist/scss/mixins/_shape.scss +315 -0
  35. package/dist/scss/mixins/animations/_base.scss +403 -0
  36. package/dist/scss/mixins/animations/_beat.scss +137 -0
  37. package/{scss → dist/scss}/mixins/animations/_blink.scss +60 -52
  38. package/dist/scss/mixins/animations/_bounce.scss +306 -0
  39. package/{scss → dist/scss}/mixins/animations/_elastic.scss +26 -22
  40. package/dist/scss/mixins/animations/_fade.scss +393 -0
  41. package/{scss → dist/scss}/mixins/animations/_flash.scss +53 -61
  42. package/dist/scss/mixins/animations/_flip.scss +251 -0
  43. package/{scss → dist/scss}/mixins/animations/_float.scss +47 -32
  44. package/{scss → dist/scss}/mixins/animations/_glow.scss +69 -58
  45. package/dist/scss/mixins/animations/_heartbeat.scss +195 -0
  46. package/dist/scss/mixins/animations/_hinge.scss +118 -0
  47. package/dist/scss/mixins/animations/_index.scss +97 -0
  48. package/dist/scss/mixins/animations/_jello.scss +123 -0
  49. package/dist/scss/mixins/animations/_jiggle.scss +162 -0
  50. package/dist/scss/mixins/animations/_lightspeed.scss +135 -0
  51. package/{scss → dist/scss}/mixins/animations/_nod.scss +57 -65
  52. package/dist/scss/mixins/animations/_pop.scss +153 -0
  53. package/dist/scss/mixins/animations/_pulse.scss +275 -0
  54. package/{scss → dist/scss}/mixins/animations/_ripple.scss +47 -55
  55. package/dist/scss/mixins/animations/_roll.scss +217 -0
  56. package/dist/scss/mixins/animations/_rotate.scss +728 -0
  57. package/dist/scss/mixins/animations/_rubber.scss +115 -0
  58. package/dist/scss/mixins/animations/_scale.scss +382 -0
  59. package/dist/scss/mixins/animations/_shake.scss +233 -0
  60. package/dist/scss/mixins/animations/_slide.scss +501 -0
  61. package/dist/scss/mixins/animations/_spin.scss +322 -0
  62. package/{scss → dist/scss}/mixins/animations/_sway.scss +32 -49
  63. package/{scss → dist/scss}/mixins/animations/_swing.scss +47 -49
  64. package/{scss → dist/scss}/mixins/animations/_tada.scss +44 -42
  65. package/{scss → dist/scss}/mixins/animations/_twist.scss +40 -55
  66. package/{scss → dist/scss}/mixins/animations/_wave.scss +36 -53
  67. package/dist/scss/mixins/animations/_wobble.scss +283 -0
  68. package/dist/scss/mixins/animations/_zoom.scss +394 -0
  69. package/{scss/mixins/mouse → dist/scss/mixins/controls}/_cursor.scss +60 -39
  70. package/dist/scss/mixins/controls/_hover.scss +625 -0
  71. package/dist/scss/mixins/controls/_index.scss +30 -0
  72. package/dist/scss/mixins/controls/_keyboard.scss +300 -0
  73. package/{scss/mixins/mouse → dist/scss/mixins/controls}/_pointer.scss +81 -72
  74. package/dist/scss/mixins/controls/_scroll.scss +460 -0
  75. package/{scss/mixins/scroll → dist/scss/mixins/controls}/_scrollbar.scss +50 -16
  76. package/dist/scss/mixins/controls/_selection.scss +208 -0
  77. package/dist/scss/mixins/controls/_touch.scss +401 -0
  78. package/dist/scss/mixins/effects/_blend.scss +128 -0
  79. package/dist/scss/mixins/effects/_filter.scss +470 -0
  80. package/dist/scss/mixins/effects/_focus.scss +83 -0
  81. package/dist/scss/mixins/effects/_gradient.scss +130 -0
  82. package/dist/scss/mixins/effects/_index.scss +28 -0
  83. package/dist/scss/mixins/effects/_mask.scss +76 -0
  84. package/dist/scss/mixins/effects/_opacity.scss +376 -0
  85. package/dist/scss/mixins/effects/_shadow.scss +429 -0
  86. package/dist/scss/mixins/keyframes/_base.scss +199 -0
  87. package/dist/scss/mixins/keyframes/_index.scss +24 -0
  88. package/dist/scss/mixins/keyframes/animations/_beat.scss +280 -0
  89. package/dist/scss/mixins/keyframes/animations/_blink.scss +82 -0
  90. package/dist/scss/mixins/keyframes/animations/_bounce.scss +292 -0
  91. package/dist/scss/mixins/keyframes/animations/_fade.scss +311 -0
  92. package/dist/scss/mixins/keyframes/animations/_flash.scss +165 -0
  93. package/dist/scss/mixins/keyframes/animations/_flip.scss +266 -0
  94. package/{scss/mixins → dist/scss/mixins/keyframes}/animations/_index.scss +19 -10
  95. package/dist/scss/mixins/keyframes/animations/_jiggle.scss +85 -0
  96. package/dist/scss/mixins/keyframes/animations/_lightspeed.scss +73 -0
  97. package/dist/scss/mixins/keyframes/animations/_nod.scss +79 -0
  98. package/dist/scss/mixins/keyframes/animations/_pop.scss +78 -0
  99. package/dist/scss/mixins/keyframes/animations/_pulse.scss +225 -0
  100. package/dist/scss/mixins/keyframes/animations/_ripple.scss +94 -0
  101. package/dist/scss/mixins/keyframes/animations/_roll.scss +124 -0
  102. package/dist/scss/mixins/keyframes/animations/_rotate.scss +360 -0
  103. package/dist/scss/mixins/keyframes/animations/_rubber.scss +81 -0
  104. package/dist/scss/mixins/keyframes/animations/_scale.scss +308 -0
  105. package/dist/scss/mixins/keyframes/animations/_shake.scss +270 -0
  106. package/dist/scss/mixins/keyframes/animations/_slide.scss +345 -0
  107. package/dist/scss/mixins/keyframes/animations/_spin.scss +270 -0
  108. package/dist/scss/mixins/keyframes/animations/_sway.scss +83 -0
  109. package/dist/scss/mixins/keyframes/animations/_twist.scss +89 -0
  110. package/dist/scss/mixins/keyframes/animations/_wave.scss +90 -0
  111. package/dist/scss/mixins/keyframes/animations/_wobble.scss +293 -0
  112. package/dist/scss/mixins/keyframes/animations/_zoom.scss +345 -0
  113. package/dist/scss/mixins/loaders/_bars.scss +128 -0
  114. package/dist/scss/mixins/loaders/_base.scss +39 -0
  115. package/dist/scss/mixins/loaders/_bubble.scss +395 -0
  116. package/dist/scss/mixins/loaders/_circle.scss +456 -0
  117. package/dist/scss/mixins/loaders/_dots.scss +248 -0
  118. package/dist/scss/mixins/loaders/_graph.scss +542 -0
  119. package/dist/scss/mixins/loaders/_index.scss +77 -0
  120. package/dist/scss/mixins/loaders/_line.scss +471 -0
  121. package/dist/scss/mixins/loaders/_objects.scss +563 -0
  122. package/dist/scss/mixins/loaders/_progress.scss +477 -0
  123. package/dist/scss/mixins/loaders/_rect.scss +480 -0
  124. package/dist/scss/mixins/loaders/_rings.scss +377 -0
  125. package/dist/scss/mixins/loaders/_skeleton.scss +461 -0
  126. package/dist/scss/mixins/loaders/_special.scss +611 -0
  127. package/dist/scss/mixins/loaders/_spinner.scss +175 -0
  128. package/dist/scss/mixins/loaders/_text.scss +446 -0
  129. package/{scss → dist/scss}/mixins/transforms/_flip.scss +16 -18
  130. package/dist/scss/mixins/transforms/_index.scss +28 -0
  131. package/dist/scss/mixins/transforms/_matrix.scss +18 -0
  132. package/{scss → dist/scss}/mixins/transforms/_perspective.scss +18 -1
  133. package/{scss → dist/scss}/mixins/transforms/_rotate.scss +9 -14
  134. package/{scss → dist/scss}/mixins/transforms/_scale.scss +16 -1
  135. package/{scss → dist/scss}/mixins/transforms/_skew.scss +16 -2
  136. package/{scss → dist/scss}/mixins/transforms/_translate.scss +16 -2
  137. package/dist/scss/mixins/transitions/_index.scss +22 -0
  138. package/dist/scss/mixins/transitions/_transition.scss +43 -0
  139. package/dist/scss/variables/_animations.scss +300 -0
  140. package/dist/scss/variables/_controls.scss +178 -0
  141. package/dist/scss/variables/_effects.scss +87 -0
  142. package/dist/scss/variables/_index.scss +27 -0
  143. package/dist/scss/variables/_keyframes.scss +28 -0
  144. package/dist/scss/variables/_loaders.scss +75 -0
  145. package/dist/scss/variables/_transforms.scss +85 -0
  146. package/dist/scss/variables/_transitions.scss +80 -0
  147. package/dist/ts/Draggable.ts +143 -0
  148. package/dist/ts/Gesture.ts +226 -0
  149. package/dist/ts/Keyboard.ts +195 -0
  150. package/dist/ts/LoaderManager.ts +662 -0
  151. package/dist/ts/Screensaver.ts +192 -0
  152. package/dist/ts/VideoOverlay.ts +205 -0
  153. package/dist/ts/demo.ts +1108 -0
  154. package/dist/ts/index.ts +58 -0
  155. package/package.json +90 -53
  156. package/src/html/_base.html +138 -0
  157. package/src/html/base.html +147 -0
  158. package/src/html/core-concepts.html +282 -0
  159. package/src/html/demo_base.html +171 -0
  160. package/src/html/demo_draggable.html +250 -0
  161. package/src/html/demo_gesture.html +264 -0
  162. package/src/html/demo_keyboard.html +224 -0
  163. package/src/html/demo_screensaver.html +258 -0
  164. package/src/html/demo_video_overlay.html +291 -0
  165. package/src/html/getting-started.html +242 -0
  166. package/src/html/index.html +400 -0
  167. package/src/html/keyboard.html +14 -0
  168. package/src/html/partials/_demo_links.html +21 -0
  169. package/src/html/partials/_footer.html +18 -0
  170. package/src/html/partials/_head.html +21 -0
  171. package/src/html/partials/_nav.html +84 -0
  172. package/src/html/partials/_theme_toggle.html +11 -0
  173. package/src/html/screensaver.html +20 -0
  174. package/src/html/test_animations.html +813 -0
  175. package/src/html/test_attention.html +281 -0
  176. package/src/html/test_bounce.html +201 -0
  177. package/src/html/test_effects.html +1348 -0
  178. package/src/html/test_fade.html +213 -0
  179. package/src/html/test_flip.html +208 -0
  180. package/src/html/test_keyframes.html +415 -0
  181. package/src/html/test_loaders.html +1489 -0
  182. package/src/html/test_mouse.html +516 -0
  183. package/src/html/test_overview.html +1444 -0
  184. package/src/html/test_pulse.html +212 -0
  185. package/src/html/test_scale.html +204 -0
  186. package/src/html/test_shake.html +232 -0
  187. package/src/html/test_slide.html +212 -0
  188. package/src/html/test_special.html +257 -0
  189. package/src/html/test_spin.html +216 -0
  190. package/src/html/test_transforms.html +332 -0
  191. package/src/html/test_transitions.html +245 -0
  192. package/src/html/test_zoom.html +188 -0
  193. package/src/html/video_overlay.html +27 -0
  194. package/src/jinja/_base.html.jinja +50 -0
  195. package/src/jinja/base.html.jinja +48 -0
  196. package/src/jinja/core-concepts.html.jinja +148 -0
  197. package/src/jinja/demo_draggable.html.jinja +114 -0
  198. package/src/jinja/demo_gesture.html.jinja +128 -0
  199. package/src/jinja/demo_keyboard.html.jinja +88 -0
  200. package/src/jinja/demo_screensaver.html.jinja +122 -0
  201. package/src/jinja/demo_video_overlay.html.jinja +155 -0
  202. package/src/jinja/getting-started.html.jinja +108 -0
  203. package/src/jinja/index.html.jinja +268 -0
  204. package/src/jinja/index.json +5 -0
  205. package/src/jinja/move.gl.css +7741 -0
  206. package/src/jinja/partials/_code_block.html.jinja +17 -0
  207. package/src/jinja/partials/_demo_links.html.jinja +41 -0
  208. package/src/jinja/partials/_feature_card.html.jinja +20 -0
  209. package/src/jinja/partials/_footer.html.jinja +22 -0
  210. package/src/jinja/partials/_head.html.jinja +27 -0
  211. package/src/jinja/partials/_nav.html.jinja +79 -0
  212. package/src/jinja/partials/_theme_toggle.html.jinja +15 -0
  213. package/src/jinja/test_animations.html.jinja +679 -0
  214. package/src/jinja/test_attention.html.jinja +147 -0
  215. package/src/jinja/test_bounce.html.jinja +67 -0
  216. package/src/jinja/test_effects.html.jinja +1218 -0
  217. package/src/jinja/test_fade.html.jinja +79 -0
  218. package/src/jinja/test_flip.html.jinja +74 -0
  219. package/src/jinja/test_keyframes.html.jinja +281 -0
  220. package/src/jinja/test_loaders.html.jinja +1358 -0
  221. package/src/jinja/test_mouse.html.jinja +382 -0
  222. package/src/jinja/test_overview.html.jinja +1313 -0
  223. package/src/jinja/test_pulse.html.jinja +78 -0
  224. package/src/jinja/test_scale.html.jinja +70 -0
  225. package/src/jinja/test_shake.html.jinja +98 -0
  226. package/src/jinja/test_slide.html.jinja +78 -0
  227. package/src/jinja/test_special.html.jinja +123 -0
  228. package/src/jinja/test_spin.html.jinja +82 -0
  229. package/src/jinja/test_transforms.html.jinja +198 -0
  230. package/src/jinja/test_transitions.html.jinja +111 -0
  231. package/src/jinja/test_zoom.html.jinja +54 -0
  232. package/src/scss/classes/_animations.scss +595 -0
  233. package/src/scss/classes/_controls.scss +314 -0
  234. package/src/scss/classes/_effects.scss +283 -0
  235. package/src/scss/classes/_index.scss +28 -0
  236. package/src/scss/classes/_loaders.scss +779 -0
  237. package/src/scss/classes/_transforms.scss +138 -0
  238. package/src/scss/classes/_transitions.scss +264 -0
  239. package/src/scss/dev/_banner.scss +36 -0
  240. package/src/scss/dev/_debug.scss +18 -0
  241. package/src/scss/dev/_deprecation.scss +13 -0
  242. package/src/scss/dev/_index.scss +8 -0
  243. package/src/scss/dev/_modules.scss +23 -0
  244. package/src/scss/docs.scss +2344 -0
  245. package/src/scss/docs.scss.bak +3133 -0
  246. package/src/scss/functions/_index.scss +22 -0
  247. package/src/scss/functions/scenes/_bubble.scss +32 -0
  248. package/src/scss/functions/scenes/_index.scss +21 -0
  249. package/src/scss/index.scss +17 -0
  250. package/src/scss/maps/_controls.scss +85 -0
  251. package/src/scss/maps/_index.scss +22 -0
  252. package/src/scss/mixins/_accessibility.scss +91 -0
  253. package/src/scss/mixins/_boot.scss +51 -0
  254. package/src/scss/mixins/_index.scss +41 -0
  255. package/src/scss/mixins/_screensaver.scss +228 -0
  256. package/src/scss/mixins/_shape.scss +315 -0
  257. package/src/scss/mixins/animations/_base.scss +403 -0
  258. package/src/scss/mixins/animations/_beat.scss +137 -0
  259. package/src/scss/mixins/animations/_blink.scss +159 -0
  260. package/src/scss/mixins/animations/_bounce.scss +306 -0
  261. package/src/scss/mixins/animations/_elastic.scss +69 -0
  262. package/src/scss/mixins/animations/_fade.scss +393 -0
  263. package/src/scss/mixins/animations/_flash.scss +169 -0
  264. package/src/scss/mixins/animations/_flip.scss +251 -0
  265. package/src/scss/mixins/animations/_float.scss +141 -0
  266. package/src/scss/mixins/animations/_glow.scss +190 -0
  267. package/src/scss/mixins/animations/_heartbeat.scss +195 -0
  268. package/src/scss/mixins/animations/_hinge.scss +118 -0
  269. package/src/scss/mixins/animations/_index.scss +97 -0
  270. package/src/scss/mixins/animations/_jello.scss +123 -0
  271. package/src/scss/mixins/animations/_jiggle.scss +162 -0
  272. package/src/scss/mixins/animations/_lightspeed.scss +135 -0
  273. package/src/scss/mixins/animations/_nod.scss +153 -0
  274. package/src/scss/mixins/animations/_pop.scss +153 -0
  275. package/src/scss/mixins/animations/_pulse.scss +275 -0
  276. package/src/scss/mixins/animations/_ripple.scss +161 -0
  277. package/src/scss/mixins/animations/_roll.scss +217 -0
  278. package/src/scss/mixins/animations/_rotate.scss +728 -0
  279. package/src/scss/mixins/animations/_rubber.scss +115 -0
  280. package/src/scss/mixins/animations/_scale.scss +382 -0
  281. package/src/scss/mixins/animations/_shake.scss +233 -0
  282. package/src/scss/mixins/animations/_slide.scss +501 -0
  283. package/src/scss/mixins/animations/_spin.scss +322 -0
  284. package/src/scss/mixins/animations/_sway.scss +150 -0
  285. package/src/scss/mixins/animations/_swing.scss +245 -0
  286. package/src/scss/mixins/animations/_tada.scss +235 -0
  287. package/src/scss/mixins/animations/_twist.scss +162 -0
  288. package/src/scss/mixins/animations/_wave.scss +149 -0
  289. package/src/scss/mixins/animations/_wobble.scss +283 -0
  290. package/src/scss/mixins/animations/_zoom.scss +394 -0
  291. package/src/scss/mixins/controls/_cursor.scss +203 -0
  292. package/src/scss/mixins/controls/_hover.scss +625 -0
  293. package/src/scss/mixins/controls/_index.scss +30 -0
  294. package/src/scss/mixins/controls/_keyboard.scss +300 -0
  295. package/src/scss/mixins/controls/_pointer.scss +267 -0
  296. package/src/scss/mixins/controls/_scroll.scss +460 -0
  297. package/src/scss/mixins/controls/_scrollbar.scss +283 -0
  298. package/src/scss/mixins/controls/_selection.scss +208 -0
  299. package/src/scss/mixins/controls/_touch.scss +401 -0
  300. package/src/scss/mixins/effects/_blend.scss +128 -0
  301. package/src/scss/mixins/effects/_filter.scss +470 -0
  302. package/src/scss/mixins/effects/_focus.scss +83 -0
  303. package/src/scss/mixins/effects/_gradient.scss +130 -0
  304. package/src/scss/mixins/effects/_index.scss +28 -0
  305. package/src/scss/mixins/effects/_mask.scss +76 -0
  306. package/src/scss/mixins/effects/_opacity.scss +376 -0
  307. package/src/scss/mixins/effects/_shadow.scss +429 -0
  308. package/src/scss/mixins/keyframes/_base.scss +199 -0
  309. package/src/scss/mixins/keyframes/_index.scss +24 -0
  310. package/src/scss/mixins/keyframes/animations/_beat.scss +280 -0
  311. package/src/scss/mixins/keyframes/animations/_blink.scss +82 -0
  312. package/src/scss/mixins/keyframes/animations/_bounce.scss +292 -0
  313. package/src/scss/mixins/keyframes/animations/_fade.scss +311 -0
  314. package/src/scss/mixins/keyframes/animations/_flash.scss +165 -0
  315. package/src/scss/mixins/keyframes/animations/_flip.scss +266 -0
  316. package/src/scss/mixins/keyframes/animations/_index.scss +46 -0
  317. package/src/scss/mixins/keyframes/animations/_jiggle.scss +85 -0
  318. package/src/scss/mixins/keyframes/animations/_lightspeed.scss +73 -0
  319. package/src/scss/mixins/keyframes/animations/_nod.scss +79 -0
  320. package/src/scss/mixins/keyframes/animations/_pop.scss +78 -0
  321. package/src/scss/mixins/keyframes/animations/_pulse.scss +225 -0
  322. package/src/scss/mixins/keyframes/animations/_ripple.scss +94 -0
  323. package/src/scss/mixins/keyframes/animations/_roll.scss +124 -0
  324. package/src/scss/mixins/keyframes/animations/_rotate.scss +360 -0
  325. package/src/scss/mixins/keyframes/animations/_rubber.scss +81 -0
  326. package/src/scss/mixins/keyframes/animations/_scale.scss +308 -0
  327. package/src/scss/mixins/keyframes/animations/_shake.scss +270 -0
  328. package/src/scss/mixins/keyframes/animations/_slide.scss +345 -0
  329. package/src/scss/mixins/keyframes/animations/_spin.scss +270 -0
  330. package/src/scss/mixins/keyframes/animations/_sway.scss +83 -0
  331. package/src/scss/mixins/keyframes/animations/_twist.scss +89 -0
  332. package/src/scss/mixins/keyframes/animations/_wave.scss +90 -0
  333. package/src/scss/mixins/keyframes/animations/_wobble.scss +293 -0
  334. package/src/scss/mixins/keyframes/animations/_zoom.scss +345 -0
  335. package/src/scss/mixins/loaders/_bars.scss +128 -0
  336. package/src/scss/mixins/loaders/_base.scss +39 -0
  337. package/src/scss/mixins/loaders/_bubble.scss +395 -0
  338. package/src/scss/mixins/loaders/_circle.scss +456 -0
  339. package/src/scss/mixins/loaders/_dots.scss +248 -0
  340. package/src/scss/mixins/loaders/_graph.scss +542 -0
  341. package/src/scss/mixins/loaders/_index.scss +77 -0
  342. package/src/scss/mixins/loaders/_line.scss +471 -0
  343. package/src/scss/mixins/loaders/_objects.scss +563 -0
  344. package/src/scss/mixins/loaders/_progress.scss +477 -0
  345. package/src/scss/mixins/loaders/_rect.scss +480 -0
  346. package/src/scss/mixins/loaders/_rings.scss +377 -0
  347. package/src/scss/mixins/loaders/_skeleton.scss +461 -0
  348. package/src/scss/mixins/loaders/_special.scss +611 -0
  349. package/src/scss/mixins/loaders/_spinner.scss +175 -0
  350. package/src/scss/mixins/loaders/_text.scss +446 -0
  351. package/src/scss/mixins/transforms/_flip.scss +74 -0
  352. package/src/scss/mixins/transforms/_index.scss +28 -0
  353. package/src/scss/mixins/transforms/_matrix.scss +18 -0
  354. package/src/scss/mixins/transforms/_perspective.scss +28 -0
  355. package/src/scss/mixins/transforms/_rotate.scss +96 -0
  356. package/src/scss/mixins/transforms/_scale.scss +26 -0
  357. package/src/scss/mixins/transforms/_skew.scss +27 -0
  358. package/src/scss/mixins/transforms/_translate.scss +27 -0
  359. package/src/scss/mixins/transitions/_index.scss +22 -0
  360. package/src/scss/mixins/transitions/_transition.scss +43 -0
  361. package/src/scss/variables/_animations.scss +300 -0
  362. package/src/scss/variables/_controls.scss +178 -0
  363. package/src/scss/variables/_effects.scss +87 -0
  364. package/src/scss/variables/_index.scss +27 -0
  365. package/src/scss/variables/_keyframes.scss +28 -0
  366. package/src/scss/variables/_loaders.scss +75 -0
  367. package/src/scss/variables/_transforms.scss +85 -0
  368. package/src/scss/variables/_transitions.scss +80 -0
  369. package/src/ts/Draggable.ts +143 -0
  370. package/src/ts/Gesture.ts +226 -0
  371. package/src/ts/Keyboard.ts +195 -0
  372. package/src/ts/LoaderManager.ts +662 -0
  373. package/src/ts/Screensaver.ts +192 -0
  374. package/src/ts/VideoOverlay.ts +205 -0
  375. package/src/ts/demo.ts +1108 -0
  376. package/src/ts/index.ts +58 -0
  377. package/css/move.gl.css +0 -2
  378. package/css/move.gl.min.css +0 -2
  379. package/scss/classes/_transforms.scss +0 -124
  380. package/scss/classes/keyboard.scss +0 -18
  381. package/scss/classes/screensaver.scss +0 -15
  382. package/scss/effects/_filter.scss +0 -176
  383. package/scss/effects/_index.scss +0 -23
  384. package/scss/effects/_opacity.scss +0 -62
  385. package/scss/effects/_shadow.scss +0 -175
  386. package/scss/functions/scenes/_bubble.scss +0 -19
  387. package/scss/functions/scenes/_index.scss +0 -20
  388. package/scss/index.scss +0 -0
  389. package/scss/keyframes/_beat.scss +0 -26
  390. package/scss/keyframes/_index.scss +0 -0
  391. package/scss/maps/_index.scss +0 -0
  392. package/scss/maps/_mouse.scss +0 -96
  393. package/scss/mixins/_hover.scss +0 -51
  394. package/scss/mixins/_index.scss +0 -0
  395. package/scss/mixins/_selection.scss +0 -321
  396. package/scss/mixins/_shape.scss +0 -44
  397. package/scss/mixins/_touch.scss +0 -95
  398. package/scss/mixins/animations/--hover.scss +0 -107
  399. package/scss/mixins/animations/_base.scss +0 -337
  400. package/scss/mixins/animations/_beat.scss +0 -119
  401. package/scss/mixins/animations/_bounce.scss +0 -192
  402. package/scss/mixins/animations/_fade.scss +0 -154
  403. package/scss/mixins/animations/_flip.scss +0 -72
  404. package/scss/mixins/animations/_heartbeat.scss +0 -175
  405. package/scss/mixins/animations/_hinge.scss +0 -119
  406. package/scss/mixins/animations/_jello.scss +0 -129
  407. package/scss/mixins/animations/_jiggle.scss +0 -163
  408. package/scss/mixins/animations/_lightspeed.scss +0 -130
  409. package/scss/mixins/animations/_pop.scss +0 -150
  410. package/scss/mixins/animations/_pulse.scss +0 -213
  411. package/scss/mixins/animations/_roll.scss +0 -261
  412. package/scss/mixins/animations/_rotate.scss +0 -428
  413. package/scss/mixins/animations/_rubber.scss +0 -116
  414. package/scss/mixins/animations/_scale.scss +0 -113
  415. package/scss/mixins/animations/_shake.scss +0 -182
  416. package/scss/mixins/animations/_slide.scss +0 -294
  417. package/scss/mixins/animations/_spin.scss +0 -219
  418. package/scss/mixins/animations/_wobble.scss +0 -254
  419. package/scss/mixins/animations/_zoom.scss +0 -166
  420. package/scss/mixins/effects/_filter.scss +0 -148
  421. package/scss/mixins/effects/_index.scss +0 -0
  422. package/scss/mixins/effects/_shadow.scss +0 -21
  423. package/scss/mixins/loaders/_index.scss +0 -0
  424. package/scss/mixins/loaders/_progress.scss +0 -174
  425. package/scss/mixins/loaders/_spinner.scss +0 -101
  426. package/scss/mixins/loaders/circle_01.scss +0 -22
  427. package/scss/mixins/loaders/circle_02.scss +0 -19
  428. package/scss/mixins/loaders/circle_03.scss +0 -29
  429. package/scss/mixins/loaders/circle_inner_01.scss +0 -33
  430. package/scss/mixins/loaders/circle_inner_02.scss +0 -33
  431. package/scss/mixins/loaders/circle_inner_03.scss +0 -34
  432. package/scss/mixins/mouse/_index.scss +0 -0
  433. package/scss/mixins/scroll/_index.scss +0 -0
  434. package/scss/mixins/scroll/_scroll.scss +0 -104
  435. package/scss/mixins/transforms/_index.scss +0 -23
  436. package/scss/mixins/transforms/_matrix.scss +0 -1
  437. package/scss/mixins/transitions/_index.scss +0 -0
  438. package/scss/mixins/transitions/_transition.scss +0 -13
  439. package/scss/variables/_animation.scss +0 -91
  440. package/scss/variables/_index.scss +0 -0
  441. package/ts/ARContent.ts +0 -27
  442. package/ts/ARInteraction.ts +0 -34
  443. package/ts/AdaptiveUI.ts +0 -25
  444. package/ts/ContentStreaming.ts +0 -20
  445. package/ts/Draggable.ts +0 -71
  446. package/ts/DynamicEnvironment.ts +0 -60
  447. package/ts/Gesture.ts +0 -168
  448. package/ts/ImmersiveAudio.ts +0 -40
  449. package/ts/InteractiveCanvas.ts +0 -177
  450. package/ts/InteractiveVideo.ts +0 -29
  451. package/ts/Keyboard.ts +0 -162
  452. package/ts/RealTimeCollaboration.ts +0 -25
  453. package/ts/Screensaver.ts +0 -140
  454. package/ts/SpatialNavigation.ts +0 -38
  455. package/ts/UserProfile.ts +0 -27
  456. package/ts/VRExperience.ts +0 -58
  457. package/ts/VideoOverlay.ts +0 -116
  458. package/ts/index.ts +0 -0
  459. /package/{scss → dist/scss}/dev/_banner.scss +0 -0
  460. /package/{scss → dist/scss}/dev/_debug.scss +0 -0
  461. /package/{scss → dist/scss}/dev/_index.scss +0 -0
  462. /package/{scss/classes/_index.scss → src/html/partials/_code_block.html} +0 -0
  463. /package/{scss/functions/_index.scss → src/html/partials/_feature_card.html} +0 -0
@@ -0,0 +1,460 @@
1
+ ////
2
+ ///
3
+ /// Scroll Controls Mixin Module
4
+ /// =========================================================================
5
+ ///
6
+ /// Provides comprehensive mixins for scroll behavior, scroll snapping,
7
+ /// scroll animations, and scroll-driven effects. Enhances user
8
+ /// interaction and navigation within scrollable elements.
9
+ ///
10
+ /// @group Controls
11
+ /// @author Scape Agency
12
+ /// @link https://move.gl
13
+ /// @since 0.1.0 initial release
14
+ /// @access public
15
+ ///
16
+ ////
17
+
18
+
19
+ // ============================================================================
20
+ // Use
21
+ // ============================================================================
22
+
23
+ @use "../../variables" as *;
24
+
25
+
26
+ // ============================================================================
27
+ // Scroll Behavior Mixins
28
+ // ============================================================================
29
+
30
+ ///
31
+ /// Enable smooth scrolling for a container.
32
+ ///
33
+ /// @param {Boolean} $enable [true] - Enables smooth scrolling.
34
+ /// @param {Boolean} $touch [true] - Enables WebKit touch scrolling.
35
+ ///
36
+ @mixin scroll_smooth($enable: true, $touch: true) {
37
+ @if $enable {
38
+ scroll-behavior: smooth;
39
+ } @else {
40
+ scroll-behavior: auto;
41
+ }
42
+
43
+ @if $touch {
44
+ -webkit-overflow-scrolling: touch;
45
+ }
46
+ }
47
+
48
+ ///
49
+ /// Set scroll behavior to auto (instant).
50
+ ///
51
+ @mixin scroll_instant {
52
+ scroll-behavior: auto;
53
+ }
54
+
55
+ ///
56
+ /// Scroll padding for fixed headers.
57
+ ///
58
+ /// @param {Length} $top [0] - Top padding.
59
+ /// @param {Length} $right [0] - Right padding.
60
+ /// @param {Length} $bottom [0] - Bottom padding.
61
+ /// @param {Length} $left [0] - Left padding.
62
+ ///
63
+ @mixin scroll_padding($top: 0, $right: 0, $bottom: 0, $left: 0) {
64
+ scroll-padding: $top $right $bottom $left;
65
+ }
66
+
67
+ ///
68
+ /// Scroll padding for fixed header navigation.
69
+ ///
70
+ /// @param {Length} $header-height [60px] - Height of fixed header.
71
+ /// @param {Length} $extra [20px] - Extra padding.
72
+ ///
73
+ @mixin scroll_padding_header($header-height: 60px, $extra: 20px) {
74
+ scroll-padding-top: calc(#{$header-height} + #{$extra});
75
+ }
76
+
77
+
78
+ // ============================================================================
79
+ // Scroll Snap Mixins
80
+ // ============================================================================
81
+
82
+ ///
83
+ /// Set up scroll snapping for a container.
84
+ ///
85
+ /// @param {String} $type [y mandatory] - Snap type: x/y + mandatory/proximity.
86
+ /// @param {String} $align [start] - Snap alignment: start, center, end.
87
+ /// @param {String} $stop [normal] - Snap stop: normal, always.
88
+ ///
89
+ @mixin scroll_snap($type: y mandatory, $align: start, $stop: normal) {
90
+ scroll-snap-type: $type;
91
+
92
+ > * {
93
+ scroll-snap-align: $align;
94
+ scroll-snap-stop: $stop;
95
+ }
96
+ }
97
+
98
+ ///
99
+ /// Horizontal scroll snap container.
100
+ ///
101
+ /// @param {String} $align [center] - Snap alignment.
102
+ /// @param {Boolean} $mandatory [true] - Whether snapping is mandatory.
103
+ ///
104
+ @mixin scroll_snap_x($align: center, $mandatory: true) {
105
+ overflow-x: auto;
106
+ overflow-y: hidden;
107
+ @if $mandatory {
108
+ scroll-snap-type: x mandatory;
109
+ } @else {
110
+ scroll-snap-type: x proximity;
111
+ }
112
+
113
+ > * {
114
+ scroll-snap-align: $align;
115
+ }
116
+ }
117
+
118
+ ///
119
+ /// Vertical scroll snap container.
120
+ ///
121
+ /// @param {String} $align [start] - Snap alignment.
122
+ /// @param {Boolean} $mandatory [true] - Whether snapping is mandatory.
123
+ ///
124
+ @mixin scroll_snap_y($align: start, $mandatory: true) {
125
+ overflow-x: hidden;
126
+ overflow-y: auto;
127
+ @if $mandatory {
128
+ scroll-snap-type: y mandatory;
129
+ } @else {
130
+ scroll-snap-type: y proximity;
131
+ }
132
+
133
+ > * {
134
+ scroll-snap-align: $align;
135
+ }
136
+ }
137
+
138
+ ///
139
+ /// Scroll snap child/item styles.
140
+ ///
141
+ /// @param {String} $align [start] - Alignment within parent.
142
+ /// @param {String} $stop [normal] - Stop behavior.
143
+ ///
144
+ @mixin scroll_snap_item($align: start, $stop: normal) {
145
+ scroll-snap-align: $align;
146
+ scroll-snap-stop: $stop;
147
+ }
148
+
149
+ ///
150
+ /// Full-page scroll snap sections.
151
+ ///
152
+ @mixin scroll_snap_fullpage {
153
+ height: 100vh;
154
+ overflow-y: auto;
155
+ scroll-snap-type: y mandatory;
156
+
157
+ > * {
158
+ height: 100vh;
159
+ scroll-snap-align: start;
160
+ }
161
+ }
162
+
163
+ ///
164
+ /// Carousel-style horizontal scroll snap.
165
+ ///
166
+ /// @param {Length} $item-width [300px] - Width of each item.
167
+ /// @param {Length} $gap [20px] - Gap between items.
168
+ ///
169
+ @mixin scroll_snap_carousel($item-width: 300px, $gap: 20px) {
170
+ display: flex;
171
+ gap: $gap;
172
+ overflow-x: auto;
173
+ scroll-snap-type: x mandatory;
174
+ scroll-padding: 0 $gap;
175
+ -webkit-overflow-scrolling: touch;
176
+
177
+ > * {
178
+ flex: 0 0 $item-width;
179
+ scroll-snap-align: center;
180
+ }
181
+ }
182
+
183
+
184
+ // ============================================================================
185
+ // Overflow & Scroll Container Mixins
186
+ // ============================================================================
187
+
188
+ ///
189
+ /// Scrollable container with auto overflow.
190
+ ///
191
+ /// @param {String} $direction [both] - Scroll direction: x, y, or both.
192
+ ///
193
+ @mixin scrollable($direction: both) {
194
+ @if $direction == x {
195
+ overflow-x: auto;
196
+ overflow-y: hidden;
197
+ } @else if $direction == y {
198
+ overflow-x: hidden;
199
+ overflow-y: auto;
200
+ } @else {
201
+ overflow: auto;
202
+ }
203
+
204
+ -webkit-overflow-scrolling: touch;
205
+ }
206
+
207
+ ///
208
+ /// Hide overflow.
209
+ ///
210
+ /// @param {String} $direction [both] - Direction: x, y, or both.
211
+ ///
212
+ @mixin overflow_hidden($direction: both) {
213
+ @if $direction == x {
214
+ overflow-x: hidden;
215
+ } @else if $direction == y {
216
+ overflow-y: hidden;
217
+ } @else {
218
+ overflow: hidden;
219
+ }
220
+ }
221
+
222
+ ///
223
+ /// Clip overflow (modern alternative to hidden).
224
+ ///
225
+ @mixin overflow_clip {
226
+ overflow: clip;
227
+ }
228
+
229
+ ///
230
+ /// Scroll container with max height.
231
+ ///
232
+ /// @param {Length} $max-height [400px] - Maximum height.
233
+ ///
234
+ @mixin scroll_container($max-height: 400px) {
235
+ max-height: $max-height;
236
+ overflow-y: auto;
237
+ -webkit-overflow-scrolling: touch;
238
+ }
239
+
240
+
241
+ // ============================================================================
242
+ // Scroll Indicator Mixins
243
+ // ============================================================================
244
+
245
+ ///
246
+ /// Fade edges to indicate more content (scroll shadows).
247
+ ///
248
+ /// @param {String} $direction [y] - Direction: x or y.
249
+ /// @param {Length} $size [30px] - Fade size.
250
+ ///
251
+ @mixin scroll_fade_edges($direction: y, $size: 30px) {
252
+ position: relative;
253
+
254
+ &::before,
255
+ &::after {
256
+ content: '';
257
+ position: absolute;
258
+ pointer-events: none;
259
+ z-index: 1;
260
+
261
+ @if $direction == y {
262
+ left: 0;
263
+ right: 0;
264
+ height: $size;
265
+ } @else {
266
+ top: 0;
267
+ bottom: 0;
268
+ width: $size;
269
+ }
270
+ }
271
+
272
+ &::before {
273
+ @if $direction == y {
274
+ top: 0;
275
+ background: linear-gradient(to bottom, var(--scroll-fade-color, white), transparent);
276
+ } @else {
277
+ left: 0;
278
+ background: linear-gradient(to right, var(--scroll-fade-color, white), transparent);
279
+ }
280
+ }
281
+
282
+ &::after {
283
+ @if $direction == y {
284
+ bottom: 0;
285
+ background: linear-gradient(to top, var(--scroll-fade-color, white), transparent);
286
+ } @else {
287
+ right: 0;
288
+ background: linear-gradient(to left, var(--scroll-fade-color, white), transparent);
289
+ }
290
+ }
291
+ }
292
+
293
+
294
+ // ============================================================================
295
+ // Scroll Animation Mixins
296
+ // ============================================================================
297
+
298
+ ///
299
+ /// Scroll-driven animation using scroll-timeline.
300
+ ///
301
+ /// @param {String} $timeline-name - Name for the scroll timeline.
302
+ /// @param {String} $axis [block] - Scroll axis: block, inline, x, y.
303
+ ///
304
+ @mixin scroll_timeline($timeline-name, $axis: block) {
305
+ scroll-timeline-name: $timeline-name;
306
+ scroll-timeline-axis: $axis;
307
+ }
308
+
309
+ ///
310
+ /// View timeline for scroll-triggered animations.
311
+ ///
312
+ /// @param {String} $timeline-name - Name for the view timeline.
313
+ /// @param {String} $axis [block] - Axis: block, inline, x, y.
314
+ ///
315
+ @mixin view_timeline($timeline-name, $axis: block) {
316
+ view-timeline-name: $timeline-name;
317
+ view-timeline-axis: $axis;
318
+ }
319
+
320
+ ///
321
+ /// Animation linked to scroll position.
322
+ ///
323
+ /// @param {String} $animation-name - Keyframe animation name.
324
+ /// @param {String} $timeline - Scroll/view timeline to use.
325
+ ///
326
+ @mixin scroll_animation($animation-name, $timeline) {
327
+ animation: $animation-name linear;
328
+ animation-timeline: $timeline;
329
+ }
330
+
331
+ ///
332
+ /// Fade in on scroll into view.
333
+ ///
334
+ @mixin scroll_fade_in {
335
+ animation: scroll-fade-in linear both;
336
+ animation-timeline: view();
337
+ animation-range: entry 0% entry 100%;
338
+ }
339
+
340
+ ///
341
+ /// Parallax scrolling effect.
342
+ ///
343
+ /// @param {Number} $speed [0.5] - Parallax speed (0-1).
344
+ ///
345
+ @mixin scroll_parallax($speed: 0.5) {
346
+ will-change: transform;
347
+
348
+ @supports (animation-timeline: scroll()) {
349
+ animation: parallax-move linear;
350
+ animation-timeline: scroll();
351
+ }
352
+ }
353
+
354
+
355
+ // ============================================================================
356
+ // Scroll Lock Mixins
357
+ // ============================================================================
358
+
359
+ ///
360
+ /// Lock body scroll (for modals).
361
+ ///
362
+ @mixin scroll_lock {
363
+ overflow: hidden;
364
+ position: fixed;
365
+ width: 100%;
366
+ height: 100%;
367
+ }
368
+
369
+ ///
370
+ /// Prevent scroll chaining (overscroll).
371
+ ///
372
+ /// @param {String} $behavior [none] - none, contain, or auto.
373
+ ///
374
+ @mixin overscroll($behavior: none) {
375
+ overscroll-behavior: $behavior;
376
+ }
377
+
378
+ ///
379
+ /// Prevent overscroll on specific axis.
380
+ ///
381
+ /// @param {String} $axis [y] - Axis: x or y.
382
+ ///
383
+ @mixin overscroll_contain($axis: y) {
384
+ @if $axis == y {
385
+ overscroll-behavior-y: contain;
386
+ } @else {
387
+ overscroll-behavior-x: contain;
388
+ }
389
+ }
390
+
391
+
392
+ // ============================================================================
393
+ // Scroll Margin Mixins
394
+ // ============================================================================
395
+
396
+ ///
397
+ /// Scroll margin for anchor links.
398
+ ///
399
+ /// @param {Length} $margin [80px] - Scroll margin.
400
+ ///
401
+ @mixin scroll_margin($margin: 80px) {
402
+ scroll-margin-top: $margin;
403
+ }
404
+
405
+ ///
406
+ /// Scroll margin for fixed header anchors.
407
+ ///
408
+ /// @param {Length} $header-height [60px] - Header height.
409
+ /// @param {Length} $extra [20px] - Extra spacing.
410
+ ///
411
+ @mixin scroll_margin_header($header-height: 60px, $extra: 20px) {
412
+ scroll-margin-top: calc(#{$header-height} + #{$extra});
413
+ }
414
+
415
+
416
+ // ============================================================================
417
+ // Perspective Container
418
+ // ============================================================================
419
+
420
+ ///
421
+ /// Perspective container for 3D transforms.
422
+ /// Creates a container with 3D perspective for child elements.
423
+ ///
424
+ /// @param {Length} $perspective [500px] - Perspective distance.
425
+ ///
426
+ @mixin perspective_container($perspective: 500px) {
427
+ perspective: $perspective;
428
+ transform-style: preserve-3d;
429
+ }
430
+
431
+
432
+ // ============================================================================
433
+ // Utility Class Generators
434
+ // ============================================================================
435
+
436
+ ///
437
+ /// Generate scroll utility classes.
438
+ ///
439
+ @mixin generate_scroll_utilities {
440
+ .scroll-smooth { scroll-behavior: smooth; }
441
+ .scroll-auto { scroll-behavior: auto; }
442
+
443
+ .overflow-auto { overflow: auto; }
444
+ .overflow-hidden { overflow: hidden; }
445
+ .overflow-scroll { overflow: scroll; }
446
+ .overflow-x-auto { overflow-x: auto; }
447
+ .overflow-y-auto { overflow-y: auto; }
448
+ .overflow-x-hidden { overflow-x: hidden; }
449
+ .overflow-y-hidden { overflow-y: hidden; }
450
+
451
+ .overscroll-auto { overscroll-behavior: auto; }
452
+ .overscroll-contain { overscroll-behavior: contain; }
453
+ .overscroll-none { overscroll-behavior: none; }
454
+
455
+ .snap-x { scroll-snap-type: x mandatory; }
456
+ .snap-y { scroll-snap-type: y mandatory; }
457
+ .snap-start { scroll-snap-align: start; }
458
+ .snap-center { scroll-snap-align: center; }
459
+ .snap-end { scroll-snap-align: end; }
460
+ }