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,308 @@
1
+ ////
2
+ ///
3
+ /// Scale Keyframes Mixins Module
4
+ /// ===========================================================================
5
+ ///
6
+ /// Defines keyframes for scale animations including expand, shrink, scale
7
+ /// in/out effects. These keyframes provide size-based animations for
8
+ /// emphasis, feedback, and transition effects.
9
+ ///
10
+ /// @group Keyframes
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
+ @use "../_base" as *;
25
+
26
+
27
+ // ============================================================================
28
+ // Basic Scale Keyframes
29
+ // ============================================================================
30
+
31
+ ///
32
+ /// Standard scale animation.
33
+ ///
34
+ /// @param {Number} $scale_start [1] - Starting scale
35
+ /// @param {Number} $scale_end [1.2] - Ending/midpoint scale
36
+ ///
37
+ @mixin keyframes_scale($scale_start: 1, $scale_end: $animate_scale_pop) {
38
+ @include keyframes(animate_scale) {
39
+ 0%, 100% {
40
+ transform: scale($scale_start);
41
+ }
42
+ 50% {
43
+ transform: scale($scale_end);
44
+ }
45
+ }
46
+ }
47
+
48
+ ///
49
+ /// Scale with CSS custom property support.
50
+ ///
51
+ @mixin keyframes_animate_scale($scale: $animate_scale_pop) {
52
+ @include keyframes(animate_scale) {
53
+ 0%, 100% {
54
+ transform: scale(var(--animate-scale-base, #{$animate_scale_base}));
55
+ }
56
+ 50% {
57
+ transform: scale(var(--animate-scale-end, #{$scale}));
58
+ }
59
+ }
60
+ }
61
+
62
+
63
+ // ============================================================================
64
+ // Expand Keyframes
65
+ // ============================================================================
66
+
67
+ ///
68
+ /// Expand animation.
69
+ ///
70
+ /// @param {Number} $scale_start [1] - Starting scale
71
+ /// @param {Number} $scale_end [1.2] - Maximum scale
72
+ ///
73
+ @mixin keyframes_scale_expand($scale_start: 1, $scale_end: $animate_scale_pop) {
74
+ @include keyframes(animate_scale_expand) {
75
+ 0%, 100% {
76
+ transform: scale($scale_start);
77
+ }
78
+ 50% {
79
+ transform: scale($scale_end);
80
+ }
81
+ }
82
+ }
83
+
84
+
85
+ // ============================================================================
86
+ // Shrink Keyframes
87
+ // ============================================================================
88
+
89
+ ///
90
+ /// Shrink animation.
91
+ ///
92
+ /// @param {Number} $scale_min [0.8] - Minimum scale
93
+ /// @param {Number} $scale_max [1.2] - Maximum scale
94
+ ///
95
+ @mixin keyframes_scale_shrink($scale_min: $animate_scale_shrink_min, $scale_max: $animate_scale_pop) {
96
+ @include keyframes(animate_scale_shrink) {
97
+ 0% {
98
+ transform: scale($scale_max);
99
+ }
100
+ 50% {
101
+ transform: scale($scale_min);
102
+ }
103
+ 100% {
104
+ transform: scale($scale_max);
105
+ }
106
+ }
107
+ }
108
+
109
+
110
+ // ============================================================================
111
+ // Scale In Keyframes
112
+ // ============================================================================
113
+
114
+ ///
115
+ /// Scale in from small.
116
+ ///
117
+ /// @param {Number} $start_scale [0] - Starting scale
118
+ ///
119
+ @mixin keyframes_scale_in($start_scale: 0) {
120
+ @include keyframes(animate_scale_in) {
121
+ from {
122
+ transform: scale($start_scale);
123
+ opacity: 0;
124
+ }
125
+ to {
126
+ transform: scale(1);
127
+ opacity: 1;
128
+ }
129
+ }
130
+ }
131
+
132
+ ///
133
+ /// Scale in from center.
134
+ ///
135
+ /// @param {Number} $start_scale [0.5] - Starting scale
136
+ ///
137
+ @mixin keyframes_scale_in_center($start_scale: $animate_scale_in_center) {
138
+ @include keyframes(animate_scale_in_center) {
139
+ from {
140
+ transform: scale($start_scale);
141
+ opacity: 0;
142
+ }
143
+ to {
144
+ transform: scale(1);
145
+ opacity: 1;
146
+ }
147
+ }
148
+ }
149
+
150
+ ///
151
+ /// Scale in with overshoot (pop effect).
152
+ ///
153
+ /// @param {Number} $start_scale [0] - Starting scale
154
+ /// @param {Number} $overshoot [1.1] - Overshoot scale
155
+ ///
156
+ @mixin keyframes_scale_in_pop($start_scale: 0, $overshoot: $animate_scale_overshoot) {
157
+ @include keyframes(animate_scale_in_pop) {
158
+ 0% {
159
+ transform: scale($start_scale);
160
+ opacity: 0;
161
+ }
162
+ 70% {
163
+ transform: scale($overshoot);
164
+ opacity: 1;
165
+ }
166
+ 100% {
167
+ transform: scale(1);
168
+ }
169
+ }
170
+ }
171
+
172
+
173
+ // ============================================================================
174
+ // Scale Out Keyframes
175
+ // ============================================================================
176
+
177
+ ///
178
+ /// Scale out to nothing.
179
+ ///
180
+ /// @param {Number} $end_scale [0] - Ending scale
181
+ ///
182
+ @mixin keyframes_scale_out($end_scale: 0) {
183
+ @include keyframes(animate_scale_out) {
184
+ from {
185
+ transform: scale(1);
186
+ opacity: 1;
187
+ }
188
+ to {
189
+ transform: scale($end_scale);
190
+ opacity: 0;
191
+ }
192
+ }
193
+ }
194
+
195
+ ///
196
+ /// Scale out from center.
197
+ ///
198
+ /// @param {Number} $end_scale [0.5] - Ending scale
199
+ ///
200
+ @mixin keyframes_scale_out_center($end_scale: $animate_scale_in_center) {
201
+ @include keyframes(animate_scale_out_center) {
202
+ from {
203
+ transform: scale(1);
204
+ opacity: 1;
205
+ }
206
+ to {
207
+ transform: scale($end_scale);
208
+ opacity: 0;
209
+ }
210
+ }
211
+ }
212
+
213
+
214
+ // ============================================================================
215
+ // Bounce Scale Keyframes
216
+ // ============================================================================
217
+
218
+ ///
219
+ /// Scale with bounce effect.
220
+ ///
221
+ /// @param {Number} $scale [1.2] - Target scale
222
+ ///
223
+ @mixin keyframes_scale_bounce($scale: $animate_scale_pop) {
224
+ @include keyframes(animate_scale_bounce) {
225
+ 0%, 100% {
226
+ transform: scale(1);
227
+ }
228
+ 30% {
229
+ transform: scale($scale);
230
+ }
231
+ 50% {
232
+ transform: scale($scale * 0.9);
233
+ }
234
+ 70% {
235
+ transform: scale($scale * 0.95);
236
+ }
237
+ }
238
+ }
239
+
240
+
241
+ // ============================================================================
242
+ // Scale X/Y Keyframes
243
+ // ============================================================================
244
+
245
+ ///
246
+ /// Scale on X-axis only.
247
+ ///
248
+ /// @param {Number} $scale_x [1.2] - X-axis scale
249
+ ///
250
+ @mixin keyframes_scale_x($scale_x: $animate_scale_pop) {
251
+ @include keyframes(animate_scale_x) {
252
+ 0%, 100% {
253
+ transform: scaleX(1);
254
+ }
255
+ 50% {
256
+ transform: scaleX($scale_x);
257
+ }
258
+ }
259
+ }
260
+
261
+ ///
262
+ /// Scale on Y-axis only.
263
+ ///
264
+ /// @param {Number} $scale_y [1.2] - Y-axis scale
265
+ ///
266
+ @mixin keyframes_scale_y($scale_y: $animate_scale_pop) {
267
+ @include keyframes(animate_scale_y) {
268
+ 0%, 100% {
269
+ transform: scaleY(1);
270
+ }
271
+ 50% {
272
+ transform: scaleY($scale_y);
273
+ }
274
+ }
275
+ }
276
+
277
+
278
+ // ============================================================================
279
+ // Scale Transition Classes (CSS utility classes)
280
+ // ============================================================================
281
+
282
+ ///
283
+ /// Keyframes for scale-in transition class.
284
+ ///
285
+ @mixin keyframes_scale_transition_in() {
286
+ @include keyframes(scale_transition_in) {
287
+ from {
288
+ transform: scale(0);
289
+ }
290
+ to {
291
+ transform: scale(1);
292
+ }
293
+ }
294
+ }
295
+
296
+ ///
297
+ /// Keyframes for scale-out transition class.
298
+ ///
299
+ @mixin keyframes_scale_transition_out() {
300
+ @include keyframes(scale_transition_out) {
301
+ from {
302
+ transform: scale(1);
303
+ }
304
+ to {
305
+ transform: scale(0);
306
+ }
307
+ }
308
+ }
@@ -0,0 +1,270 @@
1
+ ////
2
+ ///
3
+ /// Shake Keyframes Mixins Module
4
+ /// ===========================================================================
5
+ ///
6
+ /// Defines keyframes for shake animations including rotational shake,
7
+ /// horizontal/vertical shake, and intense shake variations. These keyframes
8
+ /// create attention-grabbing oscillating effects.
9
+ ///
10
+ /// @group Keyframes
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
+ @use "../_base" as *;
25
+
26
+
27
+ // ============================================================================
28
+ // Basic Shake Keyframes
29
+ // ============================================================================
30
+
31
+ ///
32
+ /// Standard rotational shake.
33
+ ///
34
+ /// @param {Angle} $amplitude [$animate_angle_shake] - Maximum rotation angle
35
+ ///
36
+ @mixin keyframes_shake($amplitude: $animate_angle_shake) {
37
+ @include keyframes(animate_shake) {
38
+ 0% {
39
+ transform: rotate(-$amplitude);
40
+ }
41
+ 4% {
42
+ transform: rotate($amplitude);
43
+ }
44
+ 8%, 24% {
45
+ transform: rotate(-$amplitude * 1.2);
46
+ }
47
+ 12%, 28% {
48
+ transform: rotate($amplitude * 1.2);
49
+ }
50
+ 16% {
51
+ transform: rotate(-$amplitude * 1.4);
52
+ }
53
+ 20% {
54
+ transform: rotate($amplitude * 1.4);
55
+ }
56
+ 32% {
57
+ transform: rotate(-$amplitude * 0.8);
58
+ }
59
+ 36% {
60
+ transform: rotate($amplitude * 0.8);
61
+ }
62
+ 40%, 100% {
63
+ transform: rotate(0deg);
64
+ }
65
+ }
66
+ }
67
+
68
+ ///
69
+ /// Shake with CSS custom property support.
70
+ ///
71
+ @mixin keyframes_animate_shake($amplitude: $animate_angle_shake) {
72
+ @include keyframes(animate_shake) {
73
+ 0%, 100% {
74
+ transform: rotate(0deg);
75
+ }
76
+ 10%, 30%, 50%, 70%, 90% {
77
+ transform: rotate(calc(-1 * var(--animate-shake-angle, #{$amplitude})));
78
+ }
79
+ 20%, 40%, 60%, 80% {
80
+ transform: rotate(var(--animate-shake-angle, #{$amplitude}));
81
+ }
82
+ }
83
+ }
84
+
85
+
86
+ // ============================================================================
87
+ // Slow Shake Keyframes
88
+ // ============================================================================
89
+
90
+ ///
91
+ /// Gentler, slower shake.
92
+ ///
93
+ /// @param {Angle} $amplitude [$animate_angle_gentle] - Maximum rotation angle
94
+ ///
95
+ @mixin keyframes_shake_slow($amplitude: $animate_angle_gentle) {
96
+ @include keyframes(animate_shake_slow) {
97
+ 0%, 100% {
98
+ transform: rotate(0deg);
99
+ }
100
+ 10%, 30%, 50%, 70%, 90% {
101
+ transform: rotate(-$amplitude);
102
+ }
103
+ 20%, 40%, 60%, 80% {
104
+ transform: rotate($amplitude);
105
+ }
106
+ }
107
+ }
108
+
109
+
110
+ // ============================================================================
111
+ // Horizontal Shake Keyframes
112
+ // ============================================================================
113
+
114
+ ///
115
+ /// Horizontal shake (translateX).
116
+ ///
117
+ /// @param {Length} $distance [$animate_translate_shake] - Horizontal distance
118
+ ///
119
+ @mixin keyframes_shake_horizontal($distance: $animate_translate_shake) {
120
+ @include keyframes(animate_shake_horizontal) {
121
+ 0%, 100% {
122
+ transform: translateX(0);
123
+ }
124
+ 10%, 30%, 50%, 70%, 90% {
125
+ transform: translateX(-$distance);
126
+ }
127
+ 20%, 40%, 60%, 80% {
128
+ transform: translateX($distance);
129
+ }
130
+ }
131
+ }
132
+
133
+
134
+ // ============================================================================
135
+ // Vertical Shake Keyframes
136
+ // ============================================================================
137
+
138
+ ///
139
+ /// Vertical shake (translateY).
140
+ ///
141
+ /// @param {Length} $distance [$animate_translate_shake] - Vertical distance
142
+ ///
143
+ @mixin keyframes_shake_vertical($distance: $animate_translate_shake) {
144
+ @include keyframes(animate_shake_vertical) {
145
+ 0%, 100% {
146
+ transform: translateY(0);
147
+ }
148
+ 10%, 30%, 50%, 70%, 90% {
149
+ transform: translateY(-$distance);
150
+ }
151
+ 20%, 40%, 60%, 80% {
152
+ transform: translateY($distance);
153
+ }
154
+ }
155
+ }
156
+
157
+
158
+ // ============================================================================
159
+ // Intense Shake Keyframes
160
+ // ============================================================================
161
+
162
+ ///
163
+ /// Intense shake with rotation and translation.
164
+ ///
165
+ /// @param {Angle} $amplitude [$animate_angle_rapid] - Maximum rotation angle
166
+ /// @param {Length} $distance [5px] - Translation distance
167
+ ///
168
+ @mixin keyframes_shake_intense($amplitude: $animate_angle_rapid, $distance: 5px) {
169
+ @include keyframes(animate_shake_intense) {
170
+ 0%, 100% {
171
+ transform: translateX(0) rotate(0);
172
+ }
173
+ 10% {
174
+ transform: translateX(-$distance) rotate(-$amplitude);
175
+ }
176
+ 20% {
177
+ transform: translateX($distance) rotate($amplitude);
178
+ }
179
+ 30% {
180
+ transform: translateX(-$distance * 0.8) rotate(-$amplitude * 0.8);
181
+ }
182
+ 40% {
183
+ transform: translateX($distance * 0.8) rotate($amplitude * 0.8);
184
+ }
185
+ 50% {
186
+ transform: translateX(-$distance * 0.6) rotate(-$amplitude * 0.6);
187
+ }
188
+ 60% {
189
+ transform: translateX($distance * 0.6) rotate($amplitude * 0.6);
190
+ }
191
+ 70% {
192
+ transform: translateX(-$distance * 0.4) rotate(-$amplitude * 0.4);
193
+ }
194
+ 80% {
195
+ transform: translateX($distance * 0.4) rotate($amplitude * 0.4);
196
+ }
197
+ 90% {
198
+ transform: translateX(-$distance * 0.2) rotate(-$amplitude * 0.2);
199
+ }
200
+ }
201
+ }
202
+
203
+
204
+ // ============================================================================
205
+ // Jitter Shake Keyframes
206
+ // ============================================================================
207
+
208
+ ///
209
+ /// Random-like jitter shake.
210
+ ///
211
+ /// @param {Length} $distance [2px] - Maximum jitter distance
212
+ ///
213
+ @mixin keyframes_shake_jitter($distance: 2px) {
214
+ @include keyframes(animate_shake_jitter) {
215
+ 0%, 100% {
216
+ transform: translate(0, 0);
217
+ }
218
+ 10% {
219
+ transform: translate(-$distance, $distance);
220
+ }
221
+ 20% {
222
+ transform: translate($distance, -$distance);
223
+ }
224
+ 30% {
225
+ transform: translate(-$distance * 0.5, -$distance);
226
+ }
227
+ 40% {
228
+ transform: translate($distance, $distance * 0.5);
229
+ }
230
+ 50% {
231
+ transform: translate(-$distance, $distance * 0.5);
232
+ }
233
+ 60% {
234
+ transform: translate($distance * 0.5, -$distance);
235
+ }
236
+ 70% {
237
+ transform: translate(-$distance * 0.5, $distance);
238
+ }
239
+ 80% {
240
+ transform: translate($distance, -$distance * 0.5);
241
+ }
242
+ 90% {
243
+ transform: translate(-$distance, -$distance * 0.5);
244
+ }
245
+ }
246
+ }
247
+
248
+
249
+ // ============================================================================
250
+ // Nod Shake Keyframes
251
+ // ============================================================================
252
+
253
+ ///
254
+ /// Nodding shake (up and down motion).
255
+ ///
256
+ /// @param {Angle} $angle [5deg] - Rotation angle
257
+ ///
258
+ @mixin keyframes_shake_nod($angle: 5deg) {
259
+ @include keyframes(animate_shake_nod) {
260
+ 0%, 100% {
261
+ transform: rotateX(0deg);
262
+ }
263
+ 25% {
264
+ transform: rotateX($angle);
265
+ }
266
+ 75% {
267
+ transform: rotateX(-$angle);
268
+ }
269
+ }
270
+ }