@shohojdhara/atomix 0.3.3 → 0.3.4

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 (398) hide show
  1. package/README.md +46 -28
  2. package/dist/atomix.css +13 -6
  3. package/dist/atomix.min.css +1 -1
  4. package/dist/index.d.ts +912 -505
  5. package/dist/index.esm.js +2924 -2133
  6. package/dist/index.esm.js.map +1 -1
  7. package/dist/index.js +2719 -1916
  8. package/dist/index.js.map +1 -1
  9. package/dist/index.min.js +1 -1
  10. package/dist/index.min.js.map +1 -1
  11. package/package.json +11 -62
  12. package/scripts/atomix-cli.js +338 -2
  13. package/scripts/cli/interactive-init.js +36 -44
  14. package/scripts/cli/theme-bridge.js +129 -0
  15. package/scripts/sync-theme-config.js +22 -22
  16. package/src/components/Button/Button.tsx +36 -1
  17. package/src/lib/config/index.ts +275 -0
  18. package/src/lib/config/loader.ts +105 -0
  19. package/src/lib/index.ts +1 -0
  20. package/src/lib/theme/composeTheme.ts +0 -5
  21. package/src/lib/theme/config/index.ts +1 -1
  22. package/src/lib/theme/config/loader.ts +75 -41
  23. package/src/lib/theme/config/types.ts +21 -7
  24. package/src/lib/theme/config/validator.ts +1 -1
  25. package/src/lib/theme/constants.ts +12 -2
  26. package/src/lib/theme/createTheme.ts +0 -1
  27. package/src/lib/theme/createThemeFromConfig.ts +132 -0
  28. package/src/lib/theme/devtools/CLI.ts +161 -76
  29. package/src/lib/theme/devtools/Comparator.tsx +343 -0
  30. package/src/lib/theme/devtools/IMPROVEMENTS.md +429 -0
  31. package/src/lib/theme/devtools/Inspector.tsx +21 -6
  32. package/src/lib/theme/devtools/LiveEditor.tsx +393 -0
  33. package/src/lib/theme/devtools/README.md +433 -0
  34. package/src/lib/theme/devtools/index.ts +12 -11
  35. package/src/lib/theme/generateCSSVariables.ts +79 -38
  36. package/src/lib/theme/index.ts +18 -2
  37. package/src/lib/theme/runtime/ThemeManager.test.ts +17 -1
  38. package/src/lib/theme/runtime/ThemeManager.ts +7 -7
  39. package/src/lib/theme/types.ts +42 -43
  40. package/src/lib/theme-tools.ts +7 -67
  41. package/src/lib/types/components.ts +69 -75
  42. package/src/styles/01-settings/_settings.navbar.scss +1 -1
  43. package/src/styles/03-generic/_generated-root.css +5 -0
  44. package/src/styles/06-components/_components.navbar.scss +12 -5
  45. package/src/themes/README.md +1 -2
  46. package/src/themes/themes.config.js +10 -194
  47. package/dist/themes/applemix.css +0 -16576
  48. package/dist/themes/applemix.css.map +0 -1
  49. package/dist/themes/applemix.min.css +0 -73
  50. package/dist/themes/boomdevs.css +0 -16007
  51. package/dist/themes/boomdevs.css.map +0 -1
  52. package/dist/themes/boomdevs.min.css +0 -406
  53. package/dist/themes/esrar.css +0 -18424
  54. package/dist/themes/esrar.css.map +0 -1
  55. package/dist/themes/esrar.min.css +0 -221
  56. package/dist/themes/flashtrade.css +0 -17596
  57. package/dist/themes/flashtrade.css.map +0 -1
  58. package/dist/themes/flashtrade.min.css +0 -196
  59. package/dist/themes/mashroom.css +0 -31082
  60. package/dist/themes/mashroom.css.map +0 -1
  61. package/dist/themes/mashroom.min.css +0 -450
  62. package/dist/themes/shaj-default.css +0 -17200
  63. package/dist/themes/shaj-default.css.map +0 -1
  64. package/dist/themes/shaj-default.min.css +0 -502
  65. package/src/lib/theme/__tests__/ThemeBuilder.test.ts +0 -223
  66. package/src/lib/theme/builders/ThemeBuilder.ts +0 -372
  67. package/src/lib/theme/errors.test.ts +0 -207
  68. package/src/lib/theme/generators/CSSGenerator.ts +0 -311
  69. package/src/lib/theme/generators/ConfigGenerator.ts +0 -287
  70. package/src/lib/theme/generators/TypeGenerator.ts +0 -228
  71. package/src/lib/theme/generators/index.ts +0 -21
  72. package/src/lib/theme/monitoring/ThemeAnalytics.ts +0 -409
  73. package/src/lib/theme/monitoring/index.ts +0 -17
  74. package/src/lib/theme/overrides/ComponentOverrides.ts +0 -243
  75. package/src/lib/theme/overrides/index.ts +0 -15
  76. package/src/lib/theme/whitelabel/WhiteLabelManager.ts +0 -364
  77. package/src/lib/theme/whitelabel/index.ts +0 -13
  78. package/src/themes/THEME_CHECKLIST.md +0 -74
  79. package/src/themes/applemix/01-settings/_index.scss +0 -24
  80. package/src/themes/applemix/01-settings/_settings.animations.scss +0 -0
  81. package/src/themes/applemix/01-settings/_settings.background.scss +0 -6
  82. package/src/themes/applemix/01-settings/_settings.colors.scss +0 -75
  83. package/src/themes/applemix/01-settings/_settings.config.scss +0 -15
  84. package/src/themes/applemix/01-settings/_settings.typography.scss +0 -30
  85. package/src/themes/applemix/02-tools/_index.scss +0 -4
  86. package/src/themes/applemix/03-generic/_index.scss +0 -7
  87. package/src/themes/applemix/04-elements/_index.scss +0 -7
  88. package/src/themes/applemix/05-objects/_index.scss +0 -7
  89. package/src/themes/applemix/06-components/_index.scss +0 -15
  90. package/src/themes/applemix/99-utilities/_index.scss +0 -7
  91. package/src/themes/applemix/README.md +0 -378
  92. package/src/themes/applemix/index.scss +0 -33
  93. package/src/themes/boomdevs/01-settings/_index.scss +0 -38
  94. package/src/themes/boomdevs/01-settings/_settings.accordion.scss +0 -12
  95. package/src/themes/boomdevs/01-settings/_settings.animations.scss +0 -11
  96. package/src/themes/boomdevs/01-settings/_settings.avatar.scss +0 -9
  97. package/src/themes/boomdevs/01-settings/_settings.badge.scss +0 -11
  98. package/src/themes/boomdevs/01-settings/_settings.border-radius.scss +0 -16
  99. package/src/themes/boomdevs/01-settings/_settings.border.scss +0 -10
  100. package/src/themes/boomdevs/01-settings/_settings.box-shadow.scss +0 -14
  101. package/src/themes/boomdevs/01-settings/_settings.breadcrumb.scss +0 -13
  102. package/src/themes/boomdevs/01-settings/_settings.breakpoints.scss +0 -15
  103. package/src/themes/boomdevs/01-settings/_settings.button.scss +0 -9
  104. package/src/themes/boomdevs/01-settings/_settings.callout.scss +0 -9
  105. package/src/themes/boomdevs/01-settings/_settings.card.scss +0 -11
  106. package/src/themes/boomdevs/01-settings/_settings.checkbox.scss +0 -9
  107. package/src/themes/boomdevs/01-settings/_settings.colors.scss +0 -145
  108. package/src/themes/boomdevs/01-settings/_settings.dropdown.scss +0 -11
  109. package/src/themes/boomdevs/01-settings/_settings.grid.scss +0 -16
  110. package/src/themes/boomdevs/01-settings/_settings.input.scss +0 -14
  111. package/src/themes/boomdevs/01-settings/_settings.link.scss +0 -11
  112. package/src/themes/boomdevs/01-settings/_settings.list.scss +0 -10
  113. package/src/themes/boomdevs/01-settings/_settings.modal.scss +0 -16
  114. package/src/themes/boomdevs/01-settings/_settings.navbar.scss +0 -16
  115. package/src/themes/boomdevs/01-settings/_settings.pagination.scss +0 -13
  116. package/src/themes/boomdevs/01-settings/_settings.progress.scss +0 -11
  117. package/src/themes/boomdevs/01-settings/_settings.rating.scss +0 -10
  118. package/src/themes/boomdevs/01-settings/_settings.spacing.scss +0 -33
  119. package/src/themes/boomdevs/01-settings/_settings.spinner.scss +0 -11
  120. package/src/themes/boomdevs/01-settings/_settings.steps.scss +0 -12
  121. package/src/themes/boomdevs/01-settings/_settings.tabs.scss +0 -12
  122. package/src/themes/boomdevs/01-settings/_settings.todo.scss +0 -15
  123. package/src/themes/boomdevs/01-settings/_settings.toggle.scss +0 -14
  124. package/src/themes/boomdevs/01-settings/_settings.tooltip.scss +0 -13
  125. package/src/themes/boomdevs/01-settings/_settings.typography.scss +0 -58
  126. package/src/themes/boomdevs/01-settings/_settings.video-player.scss +0 -12
  127. package/src/themes/boomdevs/02-tools/_index.scss +0 -7
  128. package/src/themes/boomdevs/03-generic/_index.scss +0 -7
  129. package/src/themes/boomdevs/04-elements/_index.scss +0 -7
  130. package/src/themes/boomdevs/05-objects/_index.scss +0 -7
  131. package/src/themes/boomdevs/06-components/_components.button.scss +0 -11
  132. package/src/themes/boomdevs/06-components/_index.scss +0 -11
  133. package/src/themes/boomdevs/99-utilities/_index.scss +0 -7
  134. package/src/themes/boomdevs/index.scss +0 -26
  135. package/src/themes/esrar/01-settings/_index.scss +0 -15
  136. package/src/themes/esrar/01-settings/_settings.colors.scss +0 -91
  137. package/src/themes/esrar/02-tools/_index.scss +0 -8
  138. package/src/themes/esrar/02-tools/_tools.animations.scss +0 -342
  139. package/src/themes/esrar/06-components/_components.accordion.scss +0 -49
  140. package/src/themes/esrar/06-components/_components.avatar-group.scss +0 -14
  141. package/src/themes/esrar/06-components/_components.avatar.scss +0 -61
  142. package/src/themes/esrar/06-components/_components.badge.scss +0 -117
  143. package/src/themes/esrar/06-components/_components.breadcrumb.scss +0 -65
  144. package/src/themes/esrar/06-components/_components.btn-group.scss +0 -19
  145. package/src/themes/esrar/06-components/_components.button.scss +0 -224
  146. package/src/themes/esrar/06-components/_components.callout.scss +0 -51
  147. package/src/themes/esrar/06-components/_components.card.scss +0 -134
  148. package/src/themes/esrar/06-components/_components.chart.scss +0 -24
  149. package/src/themes/esrar/06-components/_components.checkbox-group.scss +0 -26
  150. package/src/themes/esrar/06-components/_components.checkbox.scss +0 -71
  151. package/src/themes/esrar/06-components/_components.color-mode-toggle.scss +0 -29
  152. package/src/themes/esrar/06-components/_components.countdown.scss +0 -67
  153. package/src/themes/esrar/06-components/_components.data-table.scss +0 -22
  154. package/src/themes/esrar/06-components/_components.datepicker.scss +0 -20
  155. package/src/themes/esrar/06-components/_components.dropdown.scss +0 -272
  156. package/src/themes/esrar/06-components/_components.edge-panel.scss +0 -10
  157. package/src/themes/esrar/06-components/_components.form-group.scss +0 -15
  158. package/src/themes/esrar/06-components/_components.form.scss +0 -66
  159. package/src/themes/esrar/06-components/_components.hero.scss +0 -251
  160. package/src/themes/esrar/06-components/_components.icon.scss +0 -33
  161. package/src/themes/esrar/06-components/_components.image-gallery.scss +0 -29
  162. package/src/themes/esrar/06-components/_components.input.scss +0 -91
  163. package/src/themes/esrar/06-components/_components.list-group.scss +0 -26
  164. package/src/themes/esrar/06-components/_components.modal.scss +0 -148
  165. package/src/themes/esrar/06-components/_components.notification.scss +0 -80
  166. package/src/themes/esrar/06-components/_components.pagination.scss +0 -84
  167. package/src/themes/esrar/06-components/_components.popover.scss +0 -10
  168. package/src/themes/esrar/06-components/_components.progress.scss +0 -64
  169. package/src/themes/esrar/06-components/_components.rating.scss +0 -26
  170. package/src/themes/esrar/06-components/_components.skeleton.scss +0 -15
  171. package/src/themes/esrar/06-components/_components.slider.scss +0 -90
  172. package/src/themes/esrar/06-components/_components.spinner.scss +0 -71
  173. package/src/themes/esrar/06-components/_components.steps.scss +0 -76
  174. package/src/themes/esrar/06-components/_components.tab.scss +0 -58
  175. package/src/themes/esrar/06-components/_components.tag.scss +0 -21
  176. package/src/themes/esrar/06-components/_components.timeline.scss +0 -19
  177. package/src/themes/esrar/06-components/_components.toast.scss +0 -91
  178. package/src/themes/esrar/06-components/_components.toggle.scss +0 -74
  179. package/src/themes/esrar/06-components/_components.tooltip.scss +0 -45
  180. package/src/themes/esrar/06-components/_components.upload.scss +0 -102
  181. package/src/themes/esrar/06-components/_index.scss +0 -42
  182. package/src/themes/esrar/index.scss +0 -30
  183. package/src/themes/flashtrade/01-settings/_index.scss +0 -19
  184. package/src/themes/flashtrade/01-settings/_settings.animations.scss +0 -11
  185. package/src/themes/flashtrade/01-settings/_settings.background.scss +0 -9
  186. package/src/themes/flashtrade/01-settings/_settings.colors.scss +0 -79
  187. package/src/themes/flashtrade/01-settings/_settings.config.scss +0 -16
  188. package/src/themes/flashtrade/01-settings/_settings.typography.scss +0 -35
  189. package/src/themes/flashtrade/02-tools/_index.scss +0 -8
  190. package/src/themes/flashtrade/03-generic/_index.scss +0 -8
  191. package/src/themes/flashtrade/04-elements/_index.scss +0 -12
  192. package/src/themes/flashtrade/05-objects/_index.scss +0 -8
  193. package/src/themes/flashtrade/06-components/_components.badge.scss +0 -156
  194. package/src/themes/flashtrade/06-components/_components.button.scss +0 -135
  195. package/src/themes/flashtrade/06-components/_components.card.scss +0 -214
  196. package/src/themes/flashtrade/06-components/_components.navbar.scss +0 -227
  197. package/src/themes/flashtrade/06-components/_index.scss +0 -13
  198. package/src/themes/flashtrade/99-utilities/_index.scss +0 -9
  199. package/src/themes/flashtrade/99-utilities/_utilities.trading.scss +0 -187
  200. package/src/themes/flashtrade/README.md +0 -386
  201. package/src/themes/flashtrade/demo.html +0 -272
  202. package/src/themes/flashtrade/index.scss +0 -36
  203. package/src/themes/mashroom/01-settings/_index.scss +0 -69
  204. package/src/themes/mashroom/01-settings/_settings.accordion.scss +0 -32
  205. package/src/themes/mashroom/01-settings/_settings.animations.scss +0 -26
  206. package/src/themes/mashroom/01-settings/_settings.avatar-group.scss +0 -22
  207. package/src/themes/mashroom/01-settings/_settings.avatar.scss +0 -57
  208. package/src/themes/mashroom/01-settings/_settings.badge.scss +0 -19
  209. package/src/themes/mashroom/01-settings/_settings.border-radius.scss +0 -24
  210. package/src/themes/mashroom/01-settings/_settings.border.scss +0 -14
  211. package/src/themes/mashroom/01-settings/_settings.box-shadow.scss +0 -40
  212. package/src/themes/mashroom/01-settings/_settings.breadcrumb.scss +0 -0
  213. package/src/themes/mashroom/01-settings/_settings.breakpoints.scss +0 -17
  214. package/src/themes/mashroom/01-settings/_settings.btn-group.scss +0 -5
  215. package/src/themes/mashroom/01-settings/_settings.button.scss +0 -50
  216. package/src/themes/mashroom/01-settings/_settings.callout.scss +0 -81
  217. package/src/themes/mashroom/01-settings/_settings.card.scss +0 -52
  218. package/src/themes/mashroom/01-settings/_settings.checkbox-group.scss +0 -5
  219. package/src/themes/mashroom/01-settings/_settings.checkbox.scss +0 -23
  220. package/src/themes/mashroom/01-settings/_settings.color-mode.scss +0 -7
  221. package/src/themes/mashroom/01-settings/_settings.colors.scss +0 -180
  222. package/src/themes/mashroom/01-settings/_settings.config.scss +0 -4
  223. package/src/themes/mashroom/01-settings/_settings.countdown.scss +0 -20
  224. package/src/themes/mashroom/01-settings/_settings.data-table.scss +0 -56
  225. package/src/themes/mashroom/01-settings/_settings.datepicker.scss +0 -45
  226. package/src/themes/mashroom/01-settings/_settings.design-tokens.scss +0 -3
  227. package/src/themes/mashroom/01-settings/_settings.dropdown.scss +0 -45
  228. package/src/themes/mashroom/01-settings/_settings.edge-panel.scss +0 -24
  229. package/src/themes/mashroom/01-settings/_settings.fonts.scss +0 -8
  230. package/src/themes/mashroom/01-settings/_settings.form-group.scss +0 -14
  231. package/src/themes/mashroom/01-settings/_settings.form.scss +0 -6
  232. package/src/themes/mashroom/01-settings/_settings.grid.scss +0 -23
  233. package/src/themes/mashroom/01-settings/_settings.hero.scss +0 -41
  234. package/src/themes/mashroom/01-settings/_settings.input.scss +0 -51
  235. package/src/themes/mashroom/01-settings/_settings.link.scss +0 -13
  236. package/src/themes/mashroom/01-settings/_settings.list-group.scss +0 -16
  237. package/src/themes/mashroom/01-settings/_settings.list.scss +0 -13
  238. package/src/themes/mashroom/01-settings/_settings.masonry-grid.scss +0 -23
  239. package/src/themes/mashroom/01-settings/_settings.menu.scss +0 -50
  240. package/src/themes/mashroom/01-settings/_settings.messages.scss +0 -98
  241. package/src/themes/mashroom/01-settings/_settings.modal.scss +0 -41
  242. package/src/themes/mashroom/01-settings/_settings.nav.scss +0 -20
  243. package/src/themes/mashroom/01-settings/_settings.navbar.scss +0 -54
  244. package/src/themes/mashroom/01-settings/_settings.pagination.scss +0 -30
  245. package/src/themes/mashroom/01-settings/_settings.photoviewer.scss +0 -45
  246. package/src/themes/mashroom/01-settings/_settings.popover.scss +0 -20
  247. package/src/themes/mashroom/01-settings/_settings.position.scss +0 -9
  248. package/src/themes/mashroom/01-settings/_settings.progress.scss +0 -17
  249. package/src/themes/mashroom/01-settings/_settings.rating.scss +0 -11
  250. package/src/themes/mashroom/01-settings/_settings.river.scss +0 -50
  251. package/src/themes/mashroom/01-settings/_settings.sectionintro.scss +0 -31
  252. package/src/themes/mashroom/01-settings/_settings.select.scss +0 -47
  253. package/src/themes/mashroom/01-settings/_settings.side-menu.scss +0 -79
  254. package/src/themes/mashroom/01-settings/_settings.skeleton.scss +0 -24
  255. package/src/themes/mashroom/01-settings/_settings.spacing.scss +0 -66
  256. package/src/themes/mashroom/01-settings/_settings.spinner.scss +0 -34
  257. package/src/themes/mashroom/01-settings/_settings.steps.scss +0 -33
  258. package/src/themes/mashroom/01-settings/_settings.tabs.scss +0 -33
  259. package/src/themes/mashroom/01-settings/_settings.testimonials.scss +0 -24
  260. package/src/themes/mashroom/01-settings/_settings.todo.scss +0 -52
  261. package/src/themes/mashroom/01-settings/_settings.toggle.scss +0 -49
  262. package/src/themes/mashroom/01-settings/_settings.tooltip.scss +0 -20
  263. package/src/themes/mashroom/01-settings/_settings.typography.scss +0 -95
  264. package/src/themes/mashroom/01-settings/_settings.upload.scss +0 -96
  265. package/src/themes/mashroom/01-settings/_settings.z-layers.scss +0 -19
  266. package/src/themes/mashroom/02-tools/_index.scss +0 -8
  267. package/src/themes/mashroom/02-tools/_tools.psychedelic-gradients.scss +0 -78
  268. package/src/themes/mashroom/02-tools/_tools.trippy-effects.scss +0 -114
  269. package/src/themes/mashroom/03-generic/_index.scss +0 -6
  270. package/src/themes/mashroom/04-elements/_index.scss +0 -6
  271. package/src/themes/mashroom/05-objects/_index.scss +0 -6
  272. package/src/themes/mashroom/06-components/_components.accordion.scss +0 -187
  273. package/src/themes/mashroom/06-components/_components.avatar-group.scss +0 -276
  274. package/src/themes/mashroom/06-components/_components.avatar.scss +0 -114
  275. package/src/themes/mashroom/06-components/_components.badge.scss +0 -152
  276. package/src/themes/mashroom/06-components/_components.breadcrumb.scss +0 -162
  277. package/src/themes/mashroom/06-components/_components.btn-group.scss +0 -404
  278. package/src/themes/mashroom/06-components/_components.button.scss +0 -160
  279. package/src/themes/mashroom/06-components/_components.callout.scss +0 -140
  280. package/src/themes/mashroom/06-components/_components.card.scss +0 -225
  281. package/src/themes/mashroom/06-components/_components.checkbox.scss +0 -186
  282. package/src/themes/mashroom/06-components/_components.color-mode-toggle.scss +0 -308
  283. package/src/themes/mashroom/06-components/_components.countdown.scss +0 -402
  284. package/src/themes/mashroom/06-components/_components.data-table.scss +0 -354
  285. package/src/themes/mashroom/06-components/_components.datepicker.scss +0 -349
  286. package/src/themes/mashroom/06-components/_components.dropdown.scss +0 -334
  287. package/src/themes/mashroom/06-components/_components.edge-panel.scss +0 -413
  288. package/src/themes/mashroom/06-components/_components.form-group.scss +0 -433
  289. package/src/themes/mashroom/06-components/_components.form.scss +0 -358
  290. package/src/themes/mashroom/06-components/_components.hero.scss +0 -151
  291. package/src/themes/mashroom/06-components/_components.input.scss +0 -147
  292. package/src/themes/mashroom/06-components/_components.list-group.scss +0 -456
  293. package/src/themes/mashroom/06-components/_components.list.scss +0 -145
  294. package/src/themes/mashroom/06-components/_components.menu.scss +0 -497
  295. package/src/themes/mashroom/06-components/_components.messages.scss +0 -277
  296. package/src/themes/mashroom/06-components/_components.modal.scss +0 -264
  297. package/src/themes/mashroom/06-components/_components.nav.scss +0 -181
  298. package/src/themes/mashroom/06-components/_components.navbar.scss +0 -538
  299. package/src/themes/mashroom/06-components/_components.pagination.scss +0 -400
  300. package/src/themes/mashroom/06-components/_components.photoviewer.scss +0 -498
  301. package/src/themes/mashroom/06-components/_components.popover.scss +0 -383
  302. package/src/themes/mashroom/06-components/_components.product-review.scss +0 -408
  303. package/src/themes/mashroom/06-components/_components.progress.scss +0 -249
  304. package/src/themes/mashroom/06-components/_components.rating.scss +0 -300
  305. package/src/themes/mashroom/06-components/_components.river.scss +0 -570
  306. package/src/themes/mashroom/06-components/_components.sectionintro.scss +0 -546
  307. package/src/themes/mashroom/06-components/_components.select.scss +0 -455
  308. package/src/themes/mashroom/06-components/_components.side-menu.scss +0 -635
  309. package/src/themes/mashroom/06-components/_components.skeleton.scss +0 -447
  310. package/src/themes/mashroom/06-components/_components.slider.scss +0 -414
  311. package/src/themes/mashroom/06-components/_components.spinner.scss +0 -198
  312. package/src/themes/mashroom/06-components/_components.steps.scss +0 -350
  313. package/src/themes/mashroom/06-components/_components.tabs.scss +0 -269
  314. package/src/themes/mashroom/06-components/_components.testimonials.scss +0 -561
  315. package/src/themes/mashroom/06-components/_components.toggle.scss +0 -231
  316. package/src/themes/mashroom/06-components/_components.tooltip.scss +0 -167
  317. package/src/themes/mashroom/06-components/_components.upload.scss +0 -537
  318. package/src/themes/mashroom/06-components/_components.video-player.scss +0 -560
  319. package/src/themes/mashroom/06-components/_index.scss +0 -55
  320. package/src/themes/mashroom/99-utilities/_index.scss +0 -6
  321. package/src/themes/mashroom/index.scss +0 -26
  322. package/src/themes/shaj-default/01-settings/_index.scss +0 -69
  323. package/src/themes/shaj-default/01-settings/_settings.accordion.scss +0 -38
  324. package/src/themes/shaj-default/01-settings/_settings.animations.scss +0 -32
  325. package/src/themes/shaj-default/01-settings/_settings.avatar-group.scss +0 -28
  326. package/src/themes/shaj-default/01-settings/_settings.avatar.scss +0 -63
  327. package/src/themes/shaj-default/01-settings/_settings.badge.scss +0 -25
  328. package/src/themes/shaj-default/01-settings/_settings.border-radius.scss +0 -24
  329. package/src/themes/shaj-default/01-settings/_settings.border.scss +0 -20
  330. package/src/themes/shaj-default/01-settings/_settings.box-shadow.scss +0 -46
  331. package/src/themes/shaj-default/01-settings/_settings.breadcrumb.scss +0 -0
  332. package/src/themes/shaj-default/01-settings/_settings.breakpoints.scss +0 -23
  333. package/src/themes/shaj-default/01-settings/_settings.btn-group.scss +0 -11
  334. package/src/themes/shaj-default/01-settings/_settings.button.scss +0 -56
  335. package/src/themes/shaj-default/01-settings/_settings.callout.scss +0 -87
  336. package/src/themes/shaj-default/01-settings/_settings.card.scss +0 -52
  337. package/src/themes/shaj-default/01-settings/_settings.checkbox-group.scss +0 -11
  338. package/src/themes/shaj-default/01-settings/_settings.checkbox.scss +0 -29
  339. package/src/themes/shaj-default/01-settings/_settings.color-mode.scss +0 -13
  340. package/src/themes/shaj-default/01-settings/_settings.colors.scss +0 -91
  341. package/src/themes/shaj-default/01-settings/_settings.config.scss +0 -4
  342. package/src/themes/shaj-default/01-settings/_settings.countdown.scss +0 -26
  343. package/src/themes/shaj-default/01-settings/_settings.data-table.scss +0 -62
  344. package/src/themes/shaj-default/01-settings/_settings.datepicker.scss +0 -51
  345. package/src/themes/shaj-default/01-settings/_settings.design-tokens.scss +0 -9
  346. package/src/themes/shaj-default/01-settings/_settings.dropdown.scss +0 -51
  347. package/src/themes/shaj-default/01-settings/_settings.edge-panel.scss +0 -30
  348. package/src/themes/shaj-default/01-settings/_settings.fonts.scss +0 -13
  349. package/src/themes/shaj-default/01-settings/_settings.form-group.scss +0 -20
  350. package/src/themes/shaj-default/01-settings/_settings.form.scss +0 -12
  351. package/src/themes/shaj-default/01-settings/_settings.grid.scss +0 -29
  352. package/src/themes/shaj-default/01-settings/_settings.hero.scss +0 -47
  353. package/src/themes/shaj-default/01-settings/_settings.input.scss +0 -57
  354. package/src/themes/shaj-default/01-settings/_settings.link.scss +0 -19
  355. package/src/themes/shaj-default/01-settings/_settings.list-group.scss +0 -22
  356. package/src/themes/shaj-default/01-settings/_settings.list.scss +0 -19
  357. package/src/themes/shaj-default/01-settings/_settings.masonry-grid.scss +0 -29
  358. package/src/themes/shaj-default/01-settings/_settings.menu.scss +0 -56
  359. package/src/themes/shaj-default/01-settings/_settings.messages.scss +0 -104
  360. package/src/themes/shaj-default/01-settings/_settings.modal.scss +0 -47
  361. package/src/themes/shaj-default/01-settings/_settings.nav.scss +0 -26
  362. package/src/themes/shaj-default/01-settings/_settings.navbar.scss +0 -60
  363. package/src/themes/shaj-default/01-settings/_settings.pagination.scss +0 -36
  364. package/src/themes/shaj-default/01-settings/_settings.photoviewer.scss +0 -51
  365. package/src/themes/shaj-default/01-settings/_settings.popover.scss +0 -26
  366. package/src/themes/shaj-default/01-settings/_settings.position.scss +0 -15
  367. package/src/themes/shaj-default/01-settings/_settings.progress.scss +0 -23
  368. package/src/themes/shaj-default/01-settings/_settings.rating.scss +0 -17
  369. package/src/themes/shaj-default/01-settings/_settings.river.scss +0 -56
  370. package/src/themes/shaj-default/01-settings/_settings.sectionintro.scss +0 -37
  371. package/src/themes/shaj-default/01-settings/_settings.select.scss +0 -53
  372. package/src/themes/shaj-default/01-settings/_settings.side-menu.scss +0 -85
  373. package/src/themes/shaj-default/01-settings/_settings.skeleton.scss +0 -30
  374. package/src/themes/shaj-default/01-settings/_settings.spacing.scss +0 -72
  375. package/src/themes/shaj-default/01-settings/_settings.spinner.scss +0 -24
  376. package/src/themes/shaj-default/01-settings/_settings.steps.scss +0 -39
  377. package/src/themes/shaj-default/01-settings/_settings.tabs.scss +0 -39
  378. package/src/themes/shaj-default/01-settings/_settings.testimonials.scss +0 -30
  379. package/src/themes/shaj-default/01-settings/_settings.todo.scss +0 -58
  380. package/src/themes/shaj-default/01-settings/_settings.toggle.scss +0 -55
  381. package/src/themes/shaj-default/01-settings/_settings.tooltip.scss +0 -26
  382. package/src/themes/shaj-default/01-settings/_settings.typography.scss +0 -101
  383. package/src/themes/shaj-default/01-settings/_settings.upload.scss +0 -102
  384. package/src/themes/shaj-default/01-settings/_settings.z-layers.scss +0 -25
  385. package/src/themes/shaj-default/02-tools/_index.scss +0 -0
  386. package/src/themes/shaj-default/03-generic/_generic.root.scss +0 -0
  387. package/src/themes/shaj-default/03-generic/_index.scss +0 -2
  388. package/src/themes/shaj-default/04-elements/_index.scss +0 -0
  389. package/src/themes/shaj-default/05-objects/_index.scss +0 -0
  390. package/src/themes/shaj-default/06-components/_components.button.scss +0 -55
  391. package/src/themes/shaj-default/06-components/_components.card.scss +0 -57
  392. package/src/themes/shaj-default/06-components/_components.input.scss +0 -58
  393. package/src/themes/shaj-default/06-components/_components.navbar.scss +0 -99
  394. package/src/themes/shaj-default/06-components/_components.tooltip.scss +0 -0
  395. package/src/themes/shaj-default/06-components/_index.scss +0 -13
  396. package/src/themes/shaj-default/99-utilities/_index.scss +0 -0
  397. package/src/themes/shaj-default/index.scss +0 -25
  398. package/theme.config.ts +0 -360
@@ -1,414 +0,0 @@
1
- /*!
2
- * Mashroom Theme Slider Component
3
- * Mushroom-shaped handles and trippy track effects
4
- */
5
-
6
- // Import required tools and settings
7
- @use '../02-tools/tools.trippy-effects' as trippy;
8
- @use '../02-tools/tools.psychedelic-gradients' as gradients;
9
- @use '../01-settings/settings.colors' as *;
10
-
11
- .c-slider {
12
- $root: &;
13
-
14
- // Base slider container
15
- position: relative;
16
- width: 100%;
17
- margin: 2rem 0;
18
-
19
- // Track styling
20
- &__track {
21
- position: relative;
22
- height: 8px;
23
- background: linear-gradient(
24
- 90deg,
25
- rgba(157, 0, 255, 0.3),
26
- rgba(255, 187, 0, 0.3),
27
- rgba(255, 32, 133, 0.3),
28
- rgba(0, 255, 136, 0.3)
29
- );
30
- border-radius: 4px;
31
- overflow: hidden;
32
- @include trippy.trippy-glow(rgba(157, 0, 255, 0.2), 5px);
33
-
34
- // Animated background
35
- &::before {
36
- content: '';
37
- position: absolute;
38
- top: 0;
39
- left: 0;
40
- right: 0;
41
- bottom: 0;
42
- background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
43
- animation: trackShimmer 3s ease-in-out infinite;
44
- }
45
-
46
- @keyframes trackShimmer {
47
- 0% {
48
- transform: translateX(-100%);
49
- }
50
- 100% {
51
- transform: translateX(100%);
52
- }
53
- }
54
- }
55
-
56
- // Fill styling
57
- &__fill {
58
- position: absolute;
59
- top: 0;
60
- left: 0;
61
- height: 100%;
62
- background: linear-gradient(90deg, $purple-4, $yellow-4, $red-4, $green-4);
63
- background-size: 200% 100%;
64
- border-radius: 4px;
65
- animation: fillGradient 4s ease-in-out infinite;
66
- @include trippy.trippy-glow($purple-4, 8px);
67
- }
68
-
69
- @keyframes fillGradient {
70
- 0% {
71
- background-position: 0% 50%;
72
- }
73
- 50% {
74
- background-position: 100% 50%;
75
- }
76
- 100% {
77
- background-position: 0% 50%;
78
- }
79
- }
80
-
81
- // Handle styling (mushroom-shaped)
82
- &__handle {
83
- position: absolute;
84
- top: 50%;
85
- width: 24px;
86
- height: 24px;
87
- background: linear-gradient(135deg, $purple-4, $yellow-4);
88
- border-radius: 50% 50% 20% 20%;
89
- transform: translate(-50%, -50%);
90
- cursor: grab;
91
- @include trippy.trippy-glow($purple-4, 10px);
92
- transition: all 0.3s ease;
93
-
94
- // Mushroom cap shape
95
- border-radius: 50% 50% 30% 30%;
96
-
97
- // Stem effect
98
- &::before {
99
- content: '';
100
- position: absolute;
101
- top: 60%;
102
- left: 50%;
103
- width: 8px;
104
- height: 12px;
105
- background: linear-gradient(180deg, rgba(255, 255, 255, 0.3), transparent);
106
- border-radius: 0 0 50% 50%;
107
- transform: translateX(-50%);
108
- }
109
-
110
- // Dot patterns
111
- &::after {
112
- content: '';
113
- position: absolute;
114
- top: 20%;
115
- left: 30%;
116
- width: 3px;
117
- height: 3px;
118
- background: rgba(255, 255, 255, 0.6);
119
- border-radius: 50%;
120
- box-shadow:
121
- 6px 2px 0 rgba(255, 255, 255, 0.4),
122
- 3px 6px 0 rgba(255, 255, 255, 0.4);
123
- }
124
-
125
- &:hover {
126
- transform: translate(-50%, -50%) scale(1.2);
127
- @include trippy.trippy-glow($yellow-4, 15px);
128
- }
129
-
130
- &:active {
131
- cursor: grabbing;
132
- transform: translate(-50%, -50%) scale(1.1);
133
- }
134
-
135
- // Focus state
136
- &:focus {
137
- outline: none;
138
- @include trippy.trippy-glow($yellow-4, 20px);
139
- }
140
- }
141
-
142
- // Tick marks
143
- &__ticks {
144
- position: absolute;
145
- top: 100%;
146
- left: 0;
147
- right: 0;
148
- display: flex;
149
- justify-content: space-between;
150
- margin-top: 0.5rem;
151
- }
152
-
153
- &__tick {
154
- position: relative;
155
- font-size: 0.75rem;
156
- color: rgba(255, 255, 255, 0.6);
157
-
158
- // Tick line
159
- &::before {
160
- content: '';
161
- position: absolute;
162
- top: -8px;
163
- left: 50%;
164
- width: 1px;
165
- height: 4px;
166
- background: rgba(255, 255, 255, 0.3);
167
- transform: translateX(-50%);
168
- }
169
- }
170
-
171
- // Labels
172
- &__label {
173
- font-size: 0.875rem;
174
- color: rgba(255, 255, 255, 0.7);
175
- margin-bottom: 0.5rem;
176
-
177
- &--min,
178
- &--max {
179
- position: absolute;
180
- top: 100%;
181
- font-size: 0.75rem;
182
- color: rgba(255, 255, 255, 0.5);
183
- }
184
-
185
- &--min {
186
- left: 0;
187
- }
188
-
189
- &--max {
190
- right: 0;
191
- }
192
- }
193
-
194
- // Value display
195
- &__value {
196
- position: absolute;
197
- top: -40px;
198
- left: 50%;
199
- transform: translateX(-50%);
200
- background: rgba(0, 0, 0, 0.8);
201
- color: $white;
202
- padding: 0.25rem 0.75rem;
203
- border-radius: 1rem;
204
- font-size: 0.875rem;
205
- font-weight: 600;
206
- @include trippy.trippy-glow(rgba(157, 0, 255, 0.3), 5px);
207
- opacity: 0;
208
- transition: opacity 0.3s ease;
209
-
210
- #{$root}__handle:hover + &,
211
- #{$root}__handle:focus + & {
212
- opacity: 1;
213
- }
214
- }
215
-
216
- // Range slider (dual handles)
217
- &--range {
218
- #{$root}__handle {
219
- &--min {
220
- background: linear-gradient(135deg, $green-4, $yellow-4);
221
- @include trippy.trippy-glow($green-4, 8px);
222
- }
223
-
224
- &--max {
225
- background: linear-gradient(135deg, $red-4, $yellow-4);
226
- @include trippy.trippy-glow($red-4, 8px);
227
- }
228
- }
229
- }
230
-
231
- // Vertical slider
232
- &--vertical {
233
- height: 200px;
234
- width: 8px;
235
-
236
- #{$root}__track {
237
- height: 100%;
238
- width: 8px;
239
- background: linear-gradient(
240
- 180deg,
241
- rgba(157, 0, 255, 0.3),
242
- rgba(255, 187, 0, 0.3),
243
- rgba(255, 32, 133, 0.3),
244
- rgba(0, 255, 136, 0.3)
245
- );
246
- }
247
-
248
- #{$root}__fill {
249
- width: 100%;
250
- height: auto;
251
- top: auto;
252
- bottom: 0;
253
- background: linear-gradient(180deg, $purple-4, $yellow-4, $red-4, $green-4);
254
- background-size: 100% 200%;
255
- }
256
-
257
- #{$root}__handle {
258
- left: 50%;
259
- transform: translate(-50%, 50%);
260
- }
261
-
262
- #{$root}__ticks {
263
- flex-direction: column;
264
- top: 0;
265
- bottom: 0;
266
- right: -40px;
267
- left: auto;
268
- width: 30px;
269
- }
270
-
271
- #{$root}__label--min,
272
- #{$root}__label--max {
273
- top: auto;
274
- bottom: auto;
275
- left: 100%;
276
- margin-left: 10px;
277
- }
278
-
279
- #{$root}__label--min {
280
- bottom: 0;
281
- }
282
-
283
- #{$root}__label--max {
284
- top: 0;
285
- }
286
- }
287
-
288
- // Size variants
289
- &--sm {
290
- #{$root}__track {
291
- height: 4px;
292
- }
293
-
294
- #{$root}__handle {
295
- width: 16px;
296
- height: 16px;
297
-
298
- &::before {
299
- width: 6px;
300
- height: 8px;
301
- }
302
- }
303
- }
304
-
305
- &--lg {
306
- #{$root}__track {
307
- height: 12px;
308
- }
309
-
310
- #{$root}__handle {
311
- width: 32px;
312
- height: 32px;
313
-
314
- &::before {
315
- width: 10px;
316
- height: 16px;
317
- }
318
- }
319
- }
320
-
321
- // Psychedelic variant
322
- &--psychedelic {
323
- #{$root}__track {
324
- background: linear-gradient(
325
- 90deg,
326
- rgba(157, 0, 255, 0.2),
327
- rgba(255, 32, 133, 0.2),
328
- rgba(0, 255, 136, 0.2),
329
- rgba(255, 187, 0, 0.2),
330
- rgba(157, 0, 255, 0.2)
331
- );
332
- background-size: 400% 100%;
333
- animation: psychedelicTrack 6s ease-in-out infinite;
334
- }
335
-
336
- #{$root}__fill {
337
- animation: psychedelicFill 3s ease-in-out infinite;
338
- }
339
-
340
- #{$root}__handle {
341
- animation: psychedelicHandle 2s ease-in-out infinite;
342
- }
343
- }
344
-
345
- @keyframes psychedelicTrack {
346
- 0% {
347
- background-position: 0% 50%;
348
- }
349
- 50% {
350
- background-position: 100% 50%;
351
- }
352
- 100% {
353
- background-position: 0% 50%;
354
- }
355
- }
356
-
357
- @keyframes psychedelicFill {
358
- 0% {
359
- filter: hue-rotate(0deg);
360
- }
361
- 100% {
362
- filter: hue-rotate(360deg);
363
- }
364
- }
365
-
366
- @keyframes psychedelicHandle {
367
- 0% {
368
- filter: hue-rotate(0deg) brightness(1);
369
- }
370
- 50% {
371
- filter: hue-rotate(180deg) brightness(1.2);
372
- }
373
- 100% {
374
- filter: hue-rotate(360deg) brightness(1);
375
- }
376
- }
377
-
378
- // Glow variant
379
- &--glow {
380
- #{$root}__track {
381
- @include trippy.trippy-glow(rgba(157, 0, 255, 0.4), 10px);
382
- }
383
-
384
- #{$root}__fill {
385
- @include trippy.trippy-glow($yellow-4, 15px);
386
- }
387
-
388
- #{$root}__handle {
389
- @include trippy.trippy-glow($purple-4, 20px);
390
- }
391
- }
392
-
393
- // Disabled state
394
- &--disabled {
395
- opacity: 0.5;
396
- pointer-events: none;
397
-
398
- #{$root}__handle {
399
- cursor: not-allowed;
400
- }
401
- }
402
-
403
- // Responsive adjustments
404
- @media (max-width: 768px) {
405
- #{$root}__ticks {
406
- font-size: 0.625rem;
407
- }
408
-
409
- #{$root}__label--min,
410
- #{$root}__label--max {
411
- font-size: 0.625rem;
412
- }
413
- }
414
- }
@@ -1,198 +0,0 @@
1
- @use '../02-tools/tools.trippy-effects' as trippy;
2
- @use '../02-tools/tools.psychedelic-gradients' as gradients;
3
- @use '../01-settings/settings.colors' as colors;
4
- @use '../01-settings/settings.config' as config;
5
- @use '../01-settings/settings.spinner' as spinner;
6
- @use '../01-settings/settings.design-tokens' as maps;
7
- @use 'sass:map';
8
-
9
- // Psychedelic spinner animations
10
- @keyframes spinner {
11
- to {
12
- transform: rotate(360deg) #{'/* rtl:ignore */'};
13
- }
14
- }
15
-
16
- @keyframes psychedelic-spinner {
17
- 0% {
18
- transform: rotate(0deg) scale(1);
19
- filter: hue-rotate(0deg);
20
- }
21
- 25% {
22
- transform: rotate(90deg) scale(1.1);
23
- filter: hue-rotate(90deg);
24
- }
25
- 50% {
26
- transform: rotate(180deg) scale(1);
27
- filter: hue-rotate(180deg);
28
- }
29
- 75% {
30
- transform: rotate(270deg) scale(0.9);
31
- filter: hue-rotate(270deg);
32
- }
33
- 100% {
34
- transform: rotate(360deg) scale(1);
35
- filter: hue-rotate(360deg);
36
- }
37
- }
38
-
39
- @keyframes spinner-glow {
40
- 0%,
41
- 100% {
42
- box-shadow: 0 0 10px colors.$primary-6;
43
- }
44
- 25% {
45
- box-shadow:
46
- 0 0 20px colors.$blue-6,
47
- 0 0 30px colors.$blue-6;
48
- }
49
- 50% {
50
- box-shadow: 0 0 10px colors.$green-6;
51
- }
52
- 75% {
53
- box-shadow:
54
- 0 0 20px colors.$red-6,
55
- 0 0 30px colors.$red-6;
56
- }
57
- }
58
-
59
- @keyframes spinner-float {
60
- 0%,
61
- 100% {
62
- transform: translateY(0px);
63
- }
64
- 50% {
65
- transform: translateY(-5px);
66
- }
67
- }
68
-
69
- @keyframes rainbow-spinner {
70
- 0% {
71
- background-position: 0% 50%;
72
- }
73
- 100% {
74
- background-position: 100% 50%;
75
- }
76
- }
77
-
78
- .c-spinner {
79
- --#{config.$prefix}spinner-size: #{map.get(spinner.$spinner-sizes, md)};
80
- --#{config.$prefix}spinner-background-color: #{spinner.$spinner-background-color};
81
- --#{config.$prefix}spinner-color: #{spinner.$spinner-color};
82
- --#{config.$prefix}spinner-border-width: #{spinner.$spinner-border-width};
83
- --#{config.$prefix}spinner-animation-speed: #{spinner.$spinner-animation-speed};
84
-
85
- color: var(--#{config.$prefix}spinner-background-color);
86
- position: relative;
87
-
88
- // Use a psychedelic gradient for the spinner
89
- background: conic-gradient(
90
- colors.$primary-6,
91
- colors.$blue-6,
92
- colors.$green-6,
93
- colors.$yellow-6,
94
- colors.$red-6,
95
- colors.$primary-6
96
- );
97
- border-radius: 50%;
98
- animation:
99
- psychedelic-spinner var(--#{config.$prefix}spinner-animation-speed) ease-in-out infinite,
100
- spinner-glow var(--#{config.$prefix}spinner-animation-speed) ease infinite;
101
-
102
- // Add a glow effect
103
- @include trippy.trippy-glow(colors.$primary-6, 10px);
104
-
105
- // Add floating animation
106
- @include trippy.float-animation();
107
- animation-duration: 4s;
108
-
109
- // Add a central "hole" to make it look like a ring
110
- &::before {
111
- content: '';
112
- position: absolute;
113
- top: 10%;
114
- left: 10%;
115
- right: 10%;
116
- bottom: 10%;
117
- background-color: colors.$black;
118
- border-radius: 50%;
119
- }
120
-
121
- // Size variants
122
- @each $size, $value in spinner.$spinner-sizes {
123
- &--#{$size} {
124
- --#{config.$prefix}spinner-size: #{$value};
125
- }
126
- }
127
-
128
- // Color variants
129
- @each $color, $value in maps.$theme-colors {
130
- &--#{$color} {
131
- @if ($color == 'secondary') {
132
- --#{config.$prefix}spinner-background-color: var(--#{config.$prefix}body-bg);
133
- }
134
-
135
- --#{config.$prefix}spinner-color: var(--#{config.$prefix}#{$color});
136
-
137
- // Apply color-specific effects
138
- @if ($color == 'primary') {
139
- animation:
140
- psychedelic-spinner var(--#{config.$prefix}spinner-animation-speed) ease-in-out infinite,
141
- spinner-glow var(--#{config.$prefix}spinner-animation-speed) ease infinite;
142
- } @else {
143
- // For other colors, use a simpler animation
144
- animation: spinner var(--#{config.$prefix}spinner-animation-speed) linear infinite;
145
- }
146
- }
147
- }
148
-
149
- // Growing variant
150
- &--growing {
151
- animation:
152
- spinner var(--#{config.$prefix}spinner-animation-speed) linear infinite,
153
- spinner-grow 1s linear infinite;
154
-
155
- @keyframes spinner-grow {
156
- 0%,
157
- 100% {
158
- transform: scale(1);
159
- }
160
- 50% {
161
- transform: scale(1.2);
162
- }
163
- }
164
- }
165
-
166
- // Psychedelic variant
167
- &--psychedelic {
168
- @include gradients.rainbow-gradient();
169
- background-size: 300% 300%;
170
- animation:
171
- rainbow-spinner 2s linear infinite,
172
- spinner-glow 1s ease infinite,
173
- spinner-float 3s ease-in-out infinite;
174
- border-radius: 50%;
175
-
176
- &::before {
177
- background-color: rgba(colors.$black, 0.7);
178
- }
179
- }
180
-
181
- // Glowing variant
182
- &--glow {
183
- @include trippy.trippy-glow(colors.$purple-4, 20px);
184
- animation:
185
- spinner-glow 0.5s ease infinite,
186
- spinner-float 2s ease-in-out infinite;
187
-
188
- &::before {
189
- background-color: rgba(colors.$black, 0.5);
190
- }
191
- }
192
-
193
- // Floating variant
194
- &--floating {
195
- @include trippy.float-animation();
196
- animation-duration: 2s;
197
- }
198
- }