@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,223 +0,0 @@
1
- import { describe, it, expect } from 'vitest';
2
- import { ThemeBuilder, createThemeBuilder, createTheme } from '../builders/ThemeBuilder';
3
-
4
- describe('ThemeBuilder', () => {
5
- describe('Basic Builder Operations', () => {
6
- it('should create a theme with name', () => {
7
- const theme = new ThemeBuilder()
8
- .setName('test-theme')
9
- .build();
10
-
11
- expect(theme.name).toBe('test-theme');
12
- });
13
-
14
- it('should set CSS variables', () => {
15
- const theme = new ThemeBuilder()
16
- .setCSSVars({
17
- '--color-primary': '#FF0000',
18
- '--spacing-base': '16px',
19
- })
20
- .build();
21
-
22
- expect(theme.cssVars).toEqual({
23
- '--color-primary': '#FF0000',
24
- '--spacing-base': '16px',
25
- });
26
- });
27
-
28
- it('should add individual CSS variable', () => {
29
- const theme = new ThemeBuilder()
30
- .addCSSVar('--color-primary', '#FF0000')
31
- .addCSSVar('--spacing-base', '16px')
32
- .build();
33
-
34
- expect(theme.cssVars).toEqual({
35
- '--color-primary': '#FF0000',
36
- '--spacing-base': '16px',
37
- });
38
- });
39
- });
40
-
41
- describe('Typography', () => {
42
- it('should set typography', () => {
43
- const typography = {
44
- fontFamily: 'Inter, sans-serif',
45
- fontSize: {
46
- sm: '0.875rem',
47
- md: '1rem',
48
- lg: '1.125rem',
49
- },
50
- fontWeight: {
51
- normal: 400,
52
- medium: 500,
53
- bold: 700,
54
- },
55
- };
56
-
57
- const theme = new ThemeBuilder()
58
- .setTypography(typography)
59
- .build();
60
-
61
- expect(theme.typography).toEqual(typography);
62
- });
63
- });
64
-
65
- describe('Palette', () => {
66
- it('should set color palette', () => {
67
- const palette = {
68
- primary: {
69
- 500: '#7AFFD7',
70
- 600: '#00E6C3',
71
- },
72
- secondary: {
73
- 500: '#FF4785',
74
- },
75
- };
76
-
77
- const theme = new ThemeBuilder()
78
- .setPalette(palette)
79
- .build();
80
-
81
- expect(theme.palette).toEqual(palette);
82
- });
83
- });
84
-
85
- describe('Component Overrides', () => {
86
- it('should override component with CSS variables', () => {
87
- const theme = new ThemeBuilder()
88
- .overrideComponent('Button', {
89
- cssVars: {
90
- '--atomix-button-bg': '#FF0000',
91
- '--atomix-button-border-radius': '20px',
92
- },
93
- })
94
- .build();
95
-
96
- expect(theme.components?.Button?.cssVars).toEqual({
97
- '--atomix-button-bg': '#FF0000',
98
- '--atomix-button-border-radius': '20px',
99
- });
100
- });
101
-
102
- it('should set component CSS variables directly', () => {
103
- const theme = new ThemeBuilder()
104
- .setComponentCSSVars('Button', {
105
- '--atomix-button-bg': '#FF0000',
106
- })
107
- .build();
108
-
109
- expect(theme.components?.Button?.cssVars).toEqual({
110
- '--atomix-button-bg': '#FF0000',
111
- });
112
- });
113
-
114
- it('should set component part configuration', () => {
115
- const theme = new ThemeBuilder()
116
- .setComponentPart('Button', 'icon', {
117
- cssVars: { '--atomix-button-icon-size': '20px' },
118
- className: 'custom-icon',
119
- })
120
- .build();
121
-
122
- expect(theme.components?.Button?.parts?.icon).toEqual({
123
- cssVars: { '--atomix-button-icon-size': '20px' },
124
- className: 'custom-icon',
125
- });
126
- });
127
-
128
- it('should override multiple components', () => {
129
- const theme = new ThemeBuilder()
130
- .overrideComponent('Button', {
131
- cssVars: { '--atomix-button-bg': '#FF0000' },
132
- })
133
- .overrideComponent('Card', {
134
- cssVars: { '--atomix-card-bg': '#FFFFFF' },
135
- })
136
- .build();
137
-
138
- expect(theme.components?.Button?.cssVars).toEqual({
139
- '--atomix-button-bg': '#FF0000',
140
- });
141
- expect(theme.components?.Card?.cssVars).toEqual({
142
- '--atomix-card-bg': '#FFFFFF',
143
- });
144
- });
145
- });
146
-
147
- describe('Builder Methods', () => {
148
- it('should build partial theme', () => {
149
- const builder = new ThemeBuilder()
150
- .setName('test-theme')
151
- .setCSSVars({ '--color-primary': '#FF0000' });
152
-
153
- const partial = builder.buildPartial();
154
-
155
- expect(partial.name).toBe('test-theme');
156
- expect(partial.cssVars).toEqual({ '--color-primary': '#FF0000' });
157
- });
158
-
159
- it('should reset builder', () => {
160
- const builder = new ThemeBuilder()
161
- .setName('test-theme')
162
- .setCSSVars({ '--color-primary': '#FF0000' })
163
- .reset();
164
-
165
- const theme = builder.build();
166
-
167
- expect(theme.name).toBeUndefined();
168
- expect(theme.cssVars).toBeUndefined();
169
- });
170
-
171
- it('should get current theme state', () => {
172
- const builder = new ThemeBuilder()
173
- .setName('test-theme')
174
- .setCSSVars({ '--color-primary': '#FF0000' });
175
-
176
- const state = builder.getTheme();
177
-
178
- expect(state.name).toBe('test-theme');
179
- expect(state.cssVars).toEqual({ '--color-primary': '#FF0000' });
180
- });
181
- });
182
-
183
- describe('Factory Functions', () => {
184
- it('should create theme builder', () => {
185
- const builder = createThemeBuilder();
186
- expect(builder).toBeInstanceOf(ThemeBuilder);
187
- });
188
-
189
- it('should create theme with config', () => {
190
- const theme = createTheme({
191
- name: 'test-theme',
192
- cssVars: { '--color-primary': '#FF0000' },
193
- palette: {
194
- primary: { 500: '#7AFFD7' },
195
- },
196
- });
197
-
198
- expect(theme.name).toBe('test-theme');
199
- expect(theme.cssVars).toEqual({ '--color-primary': '#FF0000' });
200
- expect(theme.palette).toEqual({
201
- primary: { 500: '#7AFFD7' },
202
- });
203
- });
204
- });
205
-
206
- describe('Method Chaining', () => {
207
- it('should support fluent API', () => {
208
- const theme = new ThemeBuilder()
209
- .setName('test-theme')
210
- .setCSSVars({ '--color-primary': '#FF0000' })
211
- .setPalette({ primary: { 500: '#7AFFD7' } })
212
- .overrideComponent('Button', {
213
- cssVars: { '--atomix-button-bg': '#FF0000' },
214
- })
215
- .build();
216
-
217
- expect(theme.name).toBe('test-theme');
218
- expect(theme.cssVars).toBeDefined();
219
- expect(theme.palette).toBeDefined();
220
- expect(theme.components?.Button).toBeDefined();
221
- });
222
- });
223
- });
@@ -1,372 +0,0 @@
1
- /**
2
- * Theme Builder
3
- *
4
- * Fluent API for building theme configurations with type safety and validation.
5
- */
6
-
7
- import type { Theme, ThemeComponentOverrides, ComponentThemeOverride } from '../types';
8
-
9
- /**
10
- * Theme builder class with fluent API
11
- */
12
- export class ThemeBuilder {
13
- private theme: Partial<Theme> = {};
14
-
15
- /**
16
- * Set theme name
17
- */
18
- setName(name: string): this {
19
- this.theme.name = name;
20
- return this;
21
- }
22
-
23
- /**
24
- * Set global CSS variables
25
- */
26
- setCSSVars(vars: Record<string, string | number>): this {
27
- this.theme.cssVars = { ...this.theme.cssVars, ...vars };
28
- return this;
29
- }
30
-
31
- /**
32
- * Add a single CSS variable
33
- */
34
- addCSSVar(key: string, value: string | number): this {
35
- if (!this.theme.cssVars) {
36
- this.theme.cssVars = {};
37
- }
38
- this.theme.cssVars[key] = value;
39
- return this;
40
- }
41
-
42
- /**
43
- * Set typography configuration
44
- */
45
- setTypography(typography: Theme['typography']): this {
46
- this.theme.typography = typography;
47
- return this;
48
- }
49
-
50
- /**
51
- * Set font family
52
- */
53
- setFontFamily(fontFamily: string): this {
54
- if (!this.theme.typography) {
55
- this.theme.typography = {};
56
- }
57
- this.theme.typography.fontFamily = fontFamily;
58
- return this;
59
- }
60
-
61
- /**
62
- * Set font sizes
63
- */
64
- setFontSizes(fontSize: Record<string, string>): this {
65
- if (!this.theme.typography) {
66
- this.theme.typography = {};
67
- }
68
- this.theme.typography.fontSize = fontSize;
69
- return this;
70
- }
71
-
72
- /**
73
- * Set font weights
74
- */
75
- setFontWeights(fontWeight: Record<string, number>): this {
76
- if (!this.theme.typography) {
77
- this.theme.typography = {};
78
- }
79
- this.theme.typography.fontWeight = fontWeight;
80
- return this;
81
- }
82
-
83
- /**
84
- * Set line heights
85
- */
86
- setLineHeights(lineHeight: Record<string, number>): this {
87
- if (!this.theme.typography) {
88
- this.theme.typography = {};
89
- }
90
- this.theme.typography.lineHeight = lineHeight;
91
- return this;
92
- }
93
-
94
- /**
95
- * Set spacing system
96
- */
97
- setSpacing(spacing: Record<string, string | number>): this {
98
- this.theme.spacing = spacing;
99
- return this;
100
- }
101
-
102
- /**
103
- * Set color palette
104
- */
105
- setPalette(palette: Theme['palette']): this {
106
- this.theme.palette = palette;
107
- return this;
108
- }
109
-
110
- /**
111
- * Set a specific color scale
112
- */
113
- setColorScale(
114
- colorName: keyof NonNullable<Theme['palette']>,
115
- scale: NonNullable<Theme['palette']>[typeof colorName]
116
- ): this {
117
- if (!this.theme.palette) {
118
- this.theme.palette = {};
119
- }
120
- this.theme.palette[colorName] = scale;
121
- return this;
122
- }
123
-
124
- /**
125
- * Override a component's configuration
126
- */
127
- overrideComponent<C extends keyof ThemeComponentOverrides>(
128
- component: C,
129
- override: ThemeComponentOverrides[C]
130
- ): this {
131
- if (!this.theme.components) {
132
- this.theme.components = {};
133
- }
134
- this.theme.components[component] = override;
135
- return this;
136
- }
137
-
138
- /**
139
- * Set component CSS variables
140
- */
141
- setComponentCSSVars<C extends keyof ThemeComponentOverrides>(
142
- component: C,
143
- vars: Record<string, string | number>
144
- ): this {
145
- if (!this.theme.components) {
146
- this.theme.components = {};
147
- }
148
- if (!this.theme.components[component]) {
149
- this.theme.components[component] = {} as any;
150
- }
151
- const componentOverride = this.theme.components[component] as ComponentThemeOverride;
152
- componentOverride.cssVars = { ...componentOverride.cssVars, ...vars };
153
- return this;
154
- }
155
-
156
- /**
157
- * Set component default props
158
- */
159
- setComponentDefaultProps<C extends keyof ThemeComponentOverrides>(
160
- component: C,
161
- defaultProps: Record<string, any>
162
- ): this {
163
- if (!this.theme.components) {
164
- this.theme.components = {};
165
- }
166
- if (!this.theme.components[component]) {
167
- this.theme.components[component] = {} as any;
168
- }
169
- const componentOverride = this.theme.components[component] as ComponentThemeOverride;
170
- componentOverride.defaultProps = { ...componentOverride.defaultProps, ...defaultProps };
171
- return this;
172
- }
173
-
174
- /**
175
- * Set component part styles
176
- */
177
- setComponentPart<C extends keyof ThemeComponentOverrides>(
178
- component: C,
179
- partName: string,
180
- partConfig: {
181
- cssVars?: Record<string, string | number>;
182
- className?: string;
183
- }
184
- ): this {
185
- if (!this.theme.components) {
186
- this.theme.components = {};
187
- }
188
- if (!this.theme.components[component]) {
189
- this.theme.components[component] = {} as any;
190
- }
191
- const componentOverride = this.theme.components[component] as ComponentThemeOverride;
192
- if (!componentOverride.parts) {
193
- componentOverride.parts = {};
194
- }
195
- componentOverride.parts[partName] = partConfig;
196
- return this;
197
- }
198
-
199
- /**
200
- * Set component variant styles
201
- */
202
- setComponentVariant<C extends keyof ThemeComponentOverrides>(
203
- component: C,
204
- variantName: string,
205
- variantConfig: {
206
- cssVars?: Record<string, string | number>;
207
- className?: string;
208
- }
209
- ): this {
210
- if (!this.theme.components) {
211
- this.theme.components = {};
212
- }
213
- if (!this.theme.components[component]) {
214
- this.theme.components[component] = {} as any;
215
- }
216
- const componentOverride = this.theme.components[component] as ComponentThemeOverride;
217
- if (!componentOverride.variants) {
218
- componentOverride.variants = {};
219
- }
220
- componentOverride.variants[variantName] = variantConfig;
221
- return this;
222
- }
223
-
224
- /**
225
- * Merge with another theme
226
- */
227
- merge(otherTheme: Partial<Theme>): this {
228
- // Deep merge logic
229
- if (otherTheme.name) this.theme.name = otherTheme.name;
230
-
231
- if (otherTheme.cssVars) {
232
- this.theme.cssVars = { ...this.theme.cssVars, ...otherTheme.cssVars };
233
- }
234
-
235
- if (otherTheme.typography) {
236
- this.theme.typography = {
237
- ...this.theme.typography,
238
- ...otherTheme.typography,
239
- fontSize: {
240
- ...this.theme.typography?.fontSize,
241
- ...otherTheme.typography.fontSize,
242
- },
243
- fontWeight: {
244
- ...this.theme.typography?.fontWeight,
245
- ...otherTheme.typography.fontWeight,
246
- },
247
- lineHeight: {
248
- ...this.theme.typography?.lineHeight,
249
- ...otherTheme.typography.lineHeight,
250
- },
251
- };
252
- }
253
-
254
- if (otherTheme.spacing) {
255
- this.theme.spacing = { ...this.theme.spacing, ...otherTheme.spacing };
256
- }
257
-
258
- if (otherTheme.palette) {
259
- this.theme.palette = {
260
- ...this.theme.palette,
261
- ...otherTheme.palette,
262
- };
263
- }
264
-
265
- if (otherTheme.components) {
266
- this.theme.components = {
267
- ...this.theme.components,
268
- ...otherTheme.components,
269
- };
270
- }
271
-
272
- return this;
273
- }
274
-
275
- /**
276
- * Clone the current builder
277
- */
278
- clone(): ThemeBuilder {
279
- const newBuilder = new ThemeBuilder();
280
- newBuilder.theme = JSON.parse(JSON.stringify(this.theme));
281
- return newBuilder;
282
- }
283
-
284
- /**
285
- * Build and return the theme
286
- */
287
- build(): Theme {
288
- if (!this.theme.name) {
289
- throw new Error('Theme name is required. Use setName() to set it.');
290
- }
291
-
292
- return this.theme as Theme;
293
- }
294
-
295
- /**
296
- * Build without validation (returns partial theme)
297
- */
298
- buildPartial(): Partial<Theme> {
299
- return { ...this.theme };
300
- }
301
-
302
- /**
303
- * Reset the builder
304
- */
305
- reset(): this {
306
- this.theme = {};
307
- return this;
308
- }
309
-
310
- /**
311
- * Get current theme state
312
- */
313
- getTheme(): Partial<Theme> {
314
- return { ...this.theme };
315
- }
316
- }
317
-
318
- /**
319
- * Create a new theme builder
320
- */
321
- export function createThemeBuilder(): ThemeBuilder {
322
- return new ThemeBuilder();
323
- }
324
-
325
- /**
326
- * Create a theme from a base theme
327
- */
328
- export function extendTheme(baseTheme: Theme): ThemeBuilder {
329
- const builder = new ThemeBuilder();
330
- builder.merge(baseTheme);
331
- return builder;
332
- }
333
-
334
- /**
335
- * Quick theme creation helper
336
- */
337
- export function createTheme(config: {
338
- name: string;
339
- cssVars?: Record<string, string | number>;
340
- typography?: Theme['typography'];
341
- spacing?: Record<string, string | number>;
342
- palette?: Theme['palette'];
343
- components?: ThemeComponentOverrides;
344
- }): Theme {
345
- const builder = new ThemeBuilder();
346
-
347
- builder.setName(config.name);
348
-
349
- if (config.cssVars) {
350
- builder.setCSSVars(config.cssVars);
351
- }
352
-
353
- if (config.typography) {
354
- builder.setTypography(config.typography);
355
- }
356
-
357
- if (config.spacing) {
358
- builder.setSpacing(config.spacing);
359
- }
360
-
361
- if (config.palette) {
362
- builder.setPalette(config.palette);
363
- }
364
-
365
- if (config.components) {
366
- Object.entries(config.components).forEach(([component, override]) => {
367
- builder.overrideComponent(component as any, override as any);
368
- });
369
- }
370
-
371
- return builder.build();
372
- }