@shohojdhara/atomix 0.3.3 → 0.3.5

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 (489) hide show
  1. package/README.md +46 -28
  2. package/dist/atomix.css +15 -9
  3. package/dist/atomix.css.map +1 -0
  4. package/dist/atomix.min.css +15108 -11
  5. package/dist/atomix.min.css.map +1 -0
  6. package/dist/charts.d.ts +1929 -0
  7. package/dist/charts.js +6482 -0
  8. package/dist/charts.js.map +1 -0
  9. package/dist/core.d.ts +1289 -0
  10. package/dist/core.js +3357 -0
  11. package/dist/core.js.map +1 -0
  12. package/dist/forms.d.ts +1085 -0
  13. package/dist/forms.js +2450 -0
  14. package/dist/forms.js.map +1 -0
  15. package/dist/heavy.d.ts +636 -0
  16. package/dist/heavy.js +4550 -0
  17. package/dist/heavy.js.map +1 -0
  18. package/dist/index.d.ts +5196 -4618
  19. package/dist/index.esm.js +4240 -2776
  20. package/dist/index.esm.js.map +1 -1
  21. package/dist/index.js +4057 -2571
  22. package/dist/index.js.map +1 -1
  23. package/dist/index.min.js +1 -1
  24. package/dist/index.min.js.map +1 -1
  25. package/dist/layout.d.ts +300 -0
  26. package/dist/layout.js +336 -0
  27. package/dist/layout.js.map +1 -0
  28. package/dist/theme.d.ts +1992 -0
  29. package/dist/theme.js +5348 -0
  30. package/dist/theme.js.map +1 -0
  31. package/package.json +63 -68
  32. package/scripts/atomix-cli.js +879 -15
  33. package/scripts/cli/__tests__/cli-commands.test.js +204 -0
  34. package/scripts/cli/__tests__/utils.test.js +201 -0
  35. package/scripts/cli/__tests__/vitest.config.js +26 -0
  36. package/scripts/cli/interactive-init.js +37 -45
  37. package/scripts/cli/theme-bridge.js +129 -0
  38. package/scripts/cli/token-manager.js +32 -7
  39. package/scripts/cli/utils.js +347 -0
  40. package/scripts/sync-theme-config.js +22 -22
  41. package/src/components/Accordion/Accordion.tsx +5 -54
  42. package/src/components/Accordion/index.ts +1 -1
  43. package/src/components/Avatar/Avatar.tsx +3 -3
  44. package/src/components/Badge/Badge.tsx +3 -3
  45. package/src/components/Breadcrumb/Breadcrumb.tsx +3 -3
  46. package/src/components/Button/Button.tsx +36 -1
  47. package/src/components/Card/ElevationCard.tsx +1 -1
  48. package/src/components/Chart/AnimatedChart.tsx +19 -17
  49. package/src/components/Chart/AreaChart.tsx +5 -1
  50. package/src/components/Chart/BarChart.tsx +1 -0
  51. package/src/components/Chart/BubbleChart.tsx +6 -5
  52. package/src/components/Chart/ChartToolbar.tsx +1 -0
  53. package/src/components/Chart/FunnelChart.tsx +1 -1
  54. package/src/components/Chart/RadarChart.tsx +19 -12
  55. package/src/components/Chart/ScatterChart.tsx +3 -3
  56. package/src/components/Chart/TreemapChart.tsx +2 -1
  57. package/src/components/Chart/WaterfallChart.tsx +0 -1
  58. package/src/components/Chart/types.ts +12 -2
  59. package/src/components/Chart/utils.ts +4 -3
  60. package/src/components/DataTable/DataTable.tsx +3 -3
  61. package/src/components/Dropdown/Dropdown.tsx +12 -9
  62. package/src/components/Footer/FooterSection.tsx +3 -3
  63. package/src/components/Form/Checkbox.tsx +3 -3
  64. package/src/components/Form/Input.tsx +4 -2
  65. package/src/components/Form/Radio.tsx +3 -3
  66. package/src/components/Form/Select.tsx +3 -3
  67. package/src/components/Form/Textarea.tsx +4 -2
  68. package/src/components/List/List.stories.tsx +3 -3
  69. package/src/components/List/List.tsx +3 -3
  70. package/src/components/List/ListGroup.tsx +3 -1
  71. package/src/components/Modal/Modal.tsx +3 -3
  72. package/src/components/Navigation/Menu/MegaMenu.tsx +9 -3
  73. package/src/components/Navigation/Menu/Menu.tsx +9 -3
  74. package/src/components/Pagination/Pagination.tsx +6 -5
  75. package/src/components/PhotoViewer/PhotoViewerImage.tsx +2 -2
  76. package/src/components/Popover/Popover.tsx +4 -4
  77. package/src/components/Progress/Progress.tsx +6 -2
  78. package/src/components/Rating/Rating.tsx +5 -2
  79. package/src/components/Slider/Slider.tsx +10 -9
  80. package/src/components/Spinner/Spinner.tsx +3 -3
  81. package/src/components/Tabs/Tabs.tsx +3 -3
  82. package/src/components/Tooltip/Tooltip.tsx +3 -3
  83. package/src/components/index.ts +5 -2
  84. package/src/layouts/MasonryGrid/MasonryGrid.tsx +2 -2
  85. package/src/lib/composables/useChartPerformance.ts +102 -78
  86. package/src/lib/composables/useChartScale.ts +10 -0
  87. package/src/lib/composables/useHero.ts +9 -2
  88. package/src/lib/composables/useHeroBackgroundSlider.ts +5 -3
  89. package/src/lib/composables/useSideMenu.ts +1 -0
  90. package/src/lib/composables/useVideoPlayer.ts +3 -2
  91. package/src/lib/config/index.ts +275 -0
  92. package/src/lib/config/loader.ts +147 -0
  93. package/src/lib/hooks/index.ts +0 -1
  94. package/src/lib/hooks/useComponentCustomization.ts +10 -14
  95. package/src/lib/hooks/usePerformanceMonitor.ts +149 -0
  96. package/src/lib/index.ts +1 -0
  97. package/src/lib/patterns/index.ts +2 -2
  98. package/src/lib/patterns/slots.tsx +2 -2
  99. package/src/lib/theme/composeTheme.ts +1 -6
  100. package/src/lib/theme/config/index.ts +1 -1
  101. package/src/lib/theme/config/loader.ts +75 -41
  102. package/src/lib/theme/config/types.ts +21 -7
  103. package/src/lib/theme/config/validator.ts +1 -1
  104. package/src/lib/theme/constants.ts +12 -2
  105. package/src/lib/theme/core/ThemeEngine.ts +8 -0
  106. package/src/lib/theme/core/ThemeValidator.ts +5 -2
  107. package/src/lib/theme/createTheme.ts +0 -1
  108. package/src/lib/theme/createThemeFromConfig.ts +132 -0
  109. package/src/lib/theme/devtools/CLI.ts +161 -76
  110. package/src/lib/theme/devtools/Comparator.tsx +343 -0
  111. package/src/lib/theme/devtools/IMPROVEMENTS.md +429 -0
  112. package/src/lib/theme/devtools/Inspector.tsx +22 -7
  113. package/src/lib/theme/devtools/LiveEditor.tsx +399 -0
  114. package/src/lib/theme/devtools/README.md +433 -0
  115. package/src/lib/theme/devtools/index.ts +12 -11
  116. package/src/lib/theme/generateCSSVariables.ts +80 -39
  117. package/src/lib/theme/i18n/rtl.ts +2 -1
  118. package/src/lib/theme/index.ts +18 -2
  119. package/src/lib/theme/runtime/ThemeApplicator.ts +28 -11
  120. package/src/lib/theme/runtime/ThemeErrorBoundary.tsx +3 -3
  121. package/src/lib/theme/runtime/ThemeManager.test.ts +17 -1
  122. package/src/lib/theme/runtime/ThemeManager.ts +11 -7
  123. package/src/lib/theme/types.ts +42 -43
  124. package/src/lib/theme-tools.ts +8 -68
  125. package/src/lib/types/components.ts +252 -109
  126. package/src/lib/types/partProps.ts +0 -16
  127. package/src/lib/utils/fontPreloader.ts +148 -0
  128. package/src/lib/utils/index.ts +11 -0
  129. package/src/lib/utils/memoryMonitor.ts +189 -0
  130. package/src/styles/01-settings/_settings.fonts.scss +2 -5
  131. package/src/styles/01-settings/_settings.navbar.scss +1 -1
  132. package/src/styles/03-generic/_generated-root.css +26 -0
  133. package/src/styles/06-components/_components.navbar.scss +6 -5
  134. package/src/themes/README.md +1 -2
  135. package/src/themes/themes.config.js +30 -181
  136. package/dist/themes/applemix.css +0 -16576
  137. package/dist/themes/applemix.css.map +0 -1
  138. package/dist/themes/applemix.min.css +0 -73
  139. package/dist/themes/boomdevs.css +0 -16007
  140. package/dist/themes/boomdevs.css.map +0 -1
  141. package/dist/themes/boomdevs.min.css +0 -406
  142. package/dist/themes/esrar.css +0 -18424
  143. package/dist/themes/esrar.css.map +0 -1
  144. package/dist/themes/esrar.min.css +0 -221
  145. package/dist/themes/flashtrade.css +0 -17596
  146. package/dist/themes/flashtrade.css.map +0 -1
  147. package/dist/themes/flashtrade.min.css +0 -196
  148. package/dist/themes/mashroom.css +0 -31082
  149. package/dist/themes/mashroom.css.map +0 -1
  150. package/dist/themes/mashroom.min.css +0 -450
  151. package/dist/themes/shaj-default.css +0 -17200
  152. package/dist/themes/shaj-default.css.map +0 -1
  153. package/dist/themes/shaj-default.min.css +0 -502
  154. package/scripts/build-themes.js +0 -208
  155. package/src/components/AtomixGlass/atomixGLass.old.tsx +0 -1263
  156. package/src/lib/theme/__tests__/ThemeBuilder.test.ts +0 -223
  157. package/src/lib/theme/builders/ThemeBuilder.ts +0 -372
  158. package/src/lib/theme/errors.test.ts +0 -207
  159. package/src/lib/theme/generators/CSSGenerator.ts +0 -311
  160. package/src/lib/theme/generators/ConfigGenerator.ts +0 -287
  161. package/src/lib/theme/generators/TypeGenerator.ts +0 -228
  162. package/src/lib/theme/generators/index.ts +0 -21
  163. package/src/lib/theme/monitoring/ThemeAnalytics.ts +0 -409
  164. package/src/lib/theme/monitoring/index.ts +0 -17
  165. package/src/lib/theme/overrides/ComponentOverrides.ts +0 -243
  166. package/src/lib/theme/overrides/index.ts +0 -15
  167. package/src/lib/theme/whitelabel/WhiteLabelManager.ts +0 -364
  168. package/src/lib/theme/whitelabel/index.ts +0 -13
  169. package/src/themes/THEME_CHECKLIST.md +0 -74
  170. package/src/themes/applemix/01-settings/_index.scss +0 -24
  171. package/src/themes/applemix/01-settings/_settings.animations.scss +0 -0
  172. package/src/themes/applemix/01-settings/_settings.background.scss +0 -6
  173. package/src/themes/applemix/01-settings/_settings.colors.scss +0 -75
  174. package/src/themes/applemix/01-settings/_settings.config.scss +0 -15
  175. package/src/themes/applemix/01-settings/_settings.typography.scss +0 -30
  176. package/src/themes/applemix/02-tools/_index.scss +0 -4
  177. package/src/themes/applemix/03-generic/_index.scss +0 -7
  178. package/src/themes/applemix/04-elements/_index.scss +0 -7
  179. package/src/themes/applemix/05-objects/_index.scss +0 -7
  180. package/src/themes/applemix/06-components/_index.scss +0 -15
  181. package/src/themes/applemix/99-utilities/_index.scss +0 -7
  182. package/src/themes/applemix/README.md +0 -378
  183. package/src/themes/applemix/index.scss +0 -33
  184. package/src/themes/boomdevs/01-settings/_index.scss +0 -38
  185. package/src/themes/boomdevs/01-settings/_settings.accordion.scss +0 -12
  186. package/src/themes/boomdevs/01-settings/_settings.animations.scss +0 -11
  187. package/src/themes/boomdevs/01-settings/_settings.avatar.scss +0 -9
  188. package/src/themes/boomdevs/01-settings/_settings.badge.scss +0 -11
  189. package/src/themes/boomdevs/01-settings/_settings.border-radius.scss +0 -16
  190. package/src/themes/boomdevs/01-settings/_settings.border.scss +0 -10
  191. package/src/themes/boomdevs/01-settings/_settings.box-shadow.scss +0 -14
  192. package/src/themes/boomdevs/01-settings/_settings.breadcrumb.scss +0 -13
  193. package/src/themes/boomdevs/01-settings/_settings.breakpoints.scss +0 -15
  194. package/src/themes/boomdevs/01-settings/_settings.button.scss +0 -9
  195. package/src/themes/boomdevs/01-settings/_settings.callout.scss +0 -9
  196. package/src/themes/boomdevs/01-settings/_settings.card.scss +0 -11
  197. package/src/themes/boomdevs/01-settings/_settings.checkbox.scss +0 -9
  198. package/src/themes/boomdevs/01-settings/_settings.colors.scss +0 -145
  199. package/src/themes/boomdevs/01-settings/_settings.dropdown.scss +0 -11
  200. package/src/themes/boomdevs/01-settings/_settings.grid.scss +0 -16
  201. package/src/themes/boomdevs/01-settings/_settings.input.scss +0 -14
  202. package/src/themes/boomdevs/01-settings/_settings.link.scss +0 -11
  203. package/src/themes/boomdevs/01-settings/_settings.list.scss +0 -10
  204. package/src/themes/boomdevs/01-settings/_settings.modal.scss +0 -16
  205. package/src/themes/boomdevs/01-settings/_settings.navbar.scss +0 -16
  206. package/src/themes/boomdevs/01-settings/_settings.pagination.scss +0 -13
  207. package/src/themes/boomdevs/01-settings/_settings.progress.scss +0 -11
  208. package/src/themes/boomdevs/01-settings/_settings.rating.scss +0 -10
  209. package/src/themes/boomdevs/01-settings/_settings.spacing.scss +0 -33
  210. package/src/themes/boomdevs/01-settings/_settings.spinner.scss +0 -11
  211. package/src/themes/boomdevs/01-settings/_settings.steps.scss +0 -12
  212. package/src/themes/boomdevs/01-settings/_settings.tabs.scss +0 -12
  213. package/src/themes/boomdevs/01-settings/_settings.todo.scss +0 -15
  214. package/src/themes/boomdevs/01-settings/_settings.toggle.scss +0 -14
  215. package/src/themes/boomdevs/01-settings/_settings.tooltip.scss +0 -13
  216. package/src/themes/boomdevs/01-settings/_settings.typography.scss +0 -58
  217. package/src/themes/boomdevs/01-settings/_settings.video-player.scss +0 -12
  218. package/src/themes/boomdevs/02-tools/_index.scss +0 -7
  219. package/src/themes/boomdevs/03-generic/_index.scss +0 -7
  220. package/src/themes/boomdevs/04-elements/_index.scss +0 -7
  221. package/src/themes/boomdevs/05-objects/_index.scss +0 -7
  222. package/src/themes/boomdevs/06-components/_components.button.scss +0 -11
  223. package/src/themes/boomdevs/06-components/_index.scss +0 -11
  224. package/src/themes/boomdevs/99-utilities/_index.scss +0 -7
  225. package/src/themes/boomdevs/index.scss +0 -26
  226. package/src/themes/esrar/01-settings/_index.scss +0 -15
  227. package/src/themes/esrar/01-settings/_settings.colors.scss +0 -91
  228. package/src/themes/esrar/02-tools/_index.scss +0 -8
  229. package/src/themes/esrar/02-tools/_tools.animations.scss +0 -342
  230. package/src/themes/esrar/06-components/_components.accordion.scss +0 -49
  231. package/src/themes/esrar/06-components/_components.avatar-group.scss +0 -14
  232. package/src/themes/esrar/06-components/_components.avatar.scss +0 -61
  233. package/src/themes/esrar/06-components/_components.badge.scss +0 -117
  234. package/src/themes/esrar/06-components/_components.breadcrumb.scss +0 -65
  235. package/src/themes/esrar/06-components/_components.btn-group.scss +0 -19
  236. package/src/themes/esrar/06-components/_components.button.scss +0 -224
  237. package/src/themes/esrar/06-components/_components.callout.scss +0 -51
  238. package/src/themes/esrar/06-components/_components.card.scss +0 -134
  239. package/src/themes/esrar/06-components/_components.chart.scss +0 -24
  240. package/src/themes/esrar/06-components/_components.checkbox-group.scss +0 -26
  241. package/src/themes/esrar/06-components/_components.checkbox.scss +0 -71
  242. package/src/themes/esrar/06-components/_components.color-mode-toggle.scss +0 -29
  243. package/src/themes/esrar/06-components/_components.countdown.scss +0 -67
  244. package/src/themes/esrar/06-components/_components.data-table.scss +0 -22
  245. package/src/themes/esrar/06-components/_components.datepicker.scss +0 -20
  246. package/src/themes/esrar/06-components/_components.dropdown.scss +0 -272
  247. package/src/themes/esrar/06-components/_components.edge-panel.scss +0 -10
  248. package/src/themes/esrar/06-components/_components.form-group.scss +0 -15
  249. package/src/themes/esrar/06-components/_components.form.scss +0 -66
  250. package/src/themes/esrar/06-components/_components.hero.scss +0 -251
  251. package/src/themes/esrar/06-components/_components.icon.scss +0 -33
  252. package/src/themes/esrar/06-components/_components.image-gallery.scss +0 -29
  253. package/src/themes/esrar/06-components/_components.input.scss +0 -91
  254. package/src/themes/esrar/06-components/_components.list-group.scss +0 -26
  255. package/src/themes/esrar/06-components/_components.modal.scss +0 -148
  256. package/src/themes/esrar/06-components/_components.notification.scss +0 -80
  257. package/src/themes/esrar/06-components/_components.pagination.scss +0 -84
  258. package/src/themes/esrar/06-components/_components.popover.scss +0 -10
  259. package/src/themes/esrar/06-components/_components.progress.scss +0 -64
  260. package/src/themes/esrar/06-components/_components.rating.scss +0 -26
  261. package/src/themes/esrar/06-components/_components.skeleton.scss +0 -15
  262. package/src/themes/esrar/06-components/_components.slider.scss +0 -90
  263. package/src/themes/esrar/06-components/_components.spinner.scss +0 -71
  264. package/src/themes/esrar/06-components/_components.steps.scss +0 -76
  265. package/src/themes/esrar/06-components/_components.tab.scss +0 -58
  266. package/src/themes/esrar/06-components/_components.tag.scss +0 -21
  267. package/src/themes/esrar/06-components/_components.timeline.scss +0 -19
  268. package/src/themes/esrar/06-components/_components.toast.scss +0 -91
  269. package/src/themes/esrar/06-components/_components.toggle.scss +0 -74
  270. package/src/themes/esrar/06-components/_components.tooltip.scss +0 -45
  271. package/src/themes/esrar/06-components/_components.upload.scss +0 -102
  272. package/src/themes/esrar/06-components/_index.scss +0 -42
  273. package/src/themes/esrar/index.scss +0 -30
  274. package/src/themes/flashtrade/01-settings/_index.scss +0 -19
  275. package/src/themes/flashtrade/01-settings/_settings.animations.scss +0 -11
  276. package/src/themes/flashtrade/01-settings/_settings.background.scss +0 -9
  277. package/src/themes/flashtrade/01-settings/_settings.colors.scss +0 -79
  278. package/src/themes/flashtrade/01-settings/_settings.config.scss +0 -16
  279. package/src/themes/flashtrade/01-settings/_settings.typography.scss +0 -35
  280. package/src/themes/flashtrade/02-tools/_index.scss +0 -8
  281. package/src/themes/flashtrade/03-generic/_index.scss +0 -8
  282. package/src/themes/flashtrade/04-elements/_index.scss +0 -12
  283. package/src/themes/flashtrade/05-objects/_index.scss +0 -8
  284. package/src/themes/flashtrade/06-components/_components.badge.scss +0 -156
  285. package/src/themes/flashtrade/06-components/_components.button.scss +0 -135
  286. package/src/themes/flashtrade/06-components/_components.card.scss +0 -214
  287. package/src/themes/flashtrade/06-components/_components.navbar.scss +0 -227
  288. package/src/themes/flashtrade/06-components/_index.scss +0 -13
  289. package/src/themes/flashtrade/99-utilities/_index.scss +0 -9
  290. package/src/themes/flashtrade/99-utilities/_utilities.trading.scss +0 -187
  291. package/src/themes/flashtrade/README.md +0 -386
  292. package/src/themes/flashtrade/demo.html +0 -272
  293. package/src/themes/flashtrade/index.scss +0 -36
  294. package/src/themes/mashroom/01-settings/_index.scss +0 -69
  295. package/src/themes/mashroom/01-settings/_settings.accordion.scss +0 -32
  296. package/src/themes/mashroom/01-settings/_settings.animations.scss +0 -26
  297. package/src/themes/mashroom/01-settings/_settings.avatar-group.scss +0 -22
  298. package/src/themes/mashroom/01-settings/_settings.avatar.scss +0 -57
  299. package/src/themes/mashroom/01-settings/_settings.badge.scss +0 -19
  300. package/src/themes/mashroom/01-settings/_settings.border-radius.scss +0 -24
  301. package/src/themes/mashroom/01-settings/_settings.border.scss +0 -14
  302. package/src/themes/mashroom/01-settings/_settings.box-shadow.scss +0 -40
  303. package/src/themes/mashroom/01-settings/_settings.breadcrumb.scss +0 -0
  304. package/src/themes/mashroom/01-settings/_settings.breakpoints.scss +0 -17
  305. package/src/themes/mashroom/01-settings/_settings.btn-group.scss +0 -5
  306. package/src/themes/mashroom/01-settings/_settings.button.scss +0 -50
  307. package/src/themes/mashroom/01-settings/_settings.callout.scss +0 -81
  308. package/src/themes/mashroom/01-settings/_settings.card.scss +0 -52
  309. package/src/themes/mashroom/01-settings/_settings.checkbox-group.scss +0 -5
  310. package/src/themes/mashroom/01-settings/_settings.checkbox.scss +0 -23
  311. package/src/themes/mashroom/01-settings/_settings.color-mode.scss +0 -7
  312. package/src/themes/mashroom/01-settings/_settings.colors.scss +0 -180
  313. package/src/themes/mashroom/01-settings/_settings.config.scss +0 -4
  314. package/src/themes/mashroom/01-settings/_settings.countdown.scss +0 -20
  315. package/src/themes/mashroom/01-settings/_settings.data-table.scss +0 -56
  316. package/src/themes/mashroom/01-settings/_settings.datepicker.scss +0 -45
  317. package/src/themes/mashroom/01-settings/_settings.design-tokens.scss +0 -3
  318. package/src/themes/mashroom/01-settings/_settings.dropdown.scss +0 -45
  319. package/src/themes/mashroom/01-settings/_settings.edge-panel.scss +0 -24
  320. package/src/themes/mashroom/01-settings/_settings.fonts.scss +0 -8
  321. package/src/themes/mashroom/01-settings/_settings.form-group.scss +0 -14
  322. package/src/themes/mashroom/01-settings/_settings.form.scss +0 -6
  323. package/src/themes/mashroom/01-settings/_settings.grid.scss +0 -23
  324. package/src/themes/mashroom/01-settings/_settings.hero.scss +0 -41
  325. package/src/themes/mashroom/01-settings/_settings.input.scss +0 -51
  326. package/src/themes/mashroom/01-settings/_settings.link.scss +0 -13
  327. package/src/themes/mashroom/01-settings/_settings.list-group.scss +0 -16
  328. package/src/themes/mashroom/01-settings/_settings.list.scss +0 -13
  329. package/src/themes/mashroom/01-settings/_settings.masonry-grid.scss +0 -23
  330. package/src/themes/mashroom/01-settings/_settings.menu.scss +0 -50
  331. package/src/themes/mashroom/01-settings/_settings.messages.scss +0 -98
  332. package/src/themes/mashroom/01-settings/_settings.modal.scss +0 -41
  333. package/src/themes/mashroom/01-settings/_settings.nav.scss +0 -20
  334. package/src/themes/mashroom/01-settings/_settings.navbar.scss +0 -54
  335. package/src/themes/mashroom/01-settings/_settings.pagination.scss +0 -30
  336. package/src/themes/mashroom/01-settings/_settings.photoviewer.scss +0 -45
  337. package/src/themes/mashroom/01-settings/_settings.popover.scss +0 -20
  338. package/src/themes/mashroom/01-settings/_settings.position.scss +0 -9
  339. package/src/themes/mashroom/01-settings/_settings.progress.scss +0 -17
  340. package/src/themes/mashroom/01-settings/_settings.rating.scss +0 -11
  341. package/src/themes/mashroom/01-settings/_settings.river.scss +0 -50
  342. package/src/themes/mashroom/01-settings/_settings.sectionintro.scss +0 -31
  343. package/src/themes/mashroom/01-settings/_settings.select.scss +0 -47
  344. package/src/themes/mashroom/01-settings/_settings.side-menu.scss +0 -79
  345. package/src/themes/mashroom/01-settings/_settings.skeleton.scss +0 -24
  346. package/src/themes/mashroom/01-settings/_settings.spacing.scss +0 -66
  347. package/src/themes/mashroom/01-settings/_settings.spinner.scss +0 -34
  348. package/src/themes/mashroom/01-settings/_settings.steps.scss +0 -33
  349. package/src/themes/mashroom/01-settings/_settings.tabs.scss +0 -33
  350. package/src/themes/mashroom/01-settings/_settings.testimonials.scss +0 -24
  351. package/src/themes/mashroom/01-settings/_settings.todo.scss +0 -52
  352. package/src/themes/mashroom/01-settings/_settings.toggle.scss +0 -49
  353. package/src/themes/mashroom/01-settings/_settings.tooltip.scss +0 -20
  354. package/src/themes/mashroom/01-settings/_settings.typography.scss +0 -95
  355. package/src/themes/mashroom/01-settings/_settings.upload.scss +0 -96
  356. package/src/themes/mashroom/01-settings/_settings.z-layers.scss +0 -19
  357. package/src/themes/mashroom/02-tools/_index.scss +0 -8
  358. package/src/themes/mashroom/02-tools/_tools.psychedelic-gradients.scss +0 -78
  359. package/src/themes/mashroom/02-tools/_tools.trippy-effects.scss +0 -114
  360. package/src/themes/mashroom/03-generic/_index.scss +0 -6
  361. package/src/themes/mashroom/04-elements/_index.scss +0 -6
  362. package/src/themes/mashroom/05-objects/_index.scss +0 -6
  363. package/src/themes/mashroom/06-components/_components.accordion.scss +0 -187
  364. package/src/themes/mashroom/06-components/_components.avatar-group.scss +0 -276
  365. package/src/themes/mashroom/06-components/_components.avatar.scss +0 -114
  366. package/src/themes/mashroom/06-components/_components.badge.scss +0 -152
  367. package/src/themes/mashroom/06-components/_components.breadcrumb.scss +0 -162
  368. package/src/themes/mashroom/06-components/_components.btn-group.scss +0 -404
  369. package/src/themes/mashroom/06-components/_components.button.scss +0 -160
  370. package/src/themes/mashroom/06-components/_components.callout.scss +0 -140
  371. package/src/themes/mashroom/06-components/_components.card.scss +0 -225
  372. package/src/themes/mashroom/06-components/_components.checkbox.scss +0 -186
  373. package/src/themes/mashroom/06-components/_components.color-mode-toggle.scss +0 -308
  374. package/src/themes/mashroom/06-components/_components.countdown.scss +0 -402
  375. package/src/themes/mashroom/06-components/_components.data-table.scss +0 -354
  376. package/src/themes/mashroom/06-components/_components.datepicker.scss +0 -349
  377. package/src/themes/mashroom/06-components/_components.dropdown.scss +0 -334
  378. package/src/themes/mashroom/06-components/_components.edge-panel.scss +0 -413
  379. package/src/themes/mashroom/06-components/_components.form-group.scss +0 -433
  380. package/src/themes/mashroom/06-components/_components.form.scss +0 -358
  381. package/src/themes/mashroom/06-components/_components.hero.scss +0 -151
  382. package/src/themes/mashroom/06-components/_components.input.scss +0 -147
  383. package/src/themes/mashroom/06-components/_components.list-group.scss +0 -456
  384. package/src/themes/mashroom/06-components/_components.list.scss +0 -145
  385. package/src/themes/mashroom/06-components/_components.menu.scss +0 -497
  386. package/src/themes/mashroom/06-components/_components.messages.scss +0 -277
  387. package/src/themes/mashroom/06-components/_components.modal.scss +0 -264
  388. package/src/themes/mashroom/06-components/_components.nav.scss +0 -181
  389. package/src/themes/mashroom/06-components/_components.navbar.scss +0 -538
  390. package/src/themes/mashroom/06-components/_components.pagination.scss +0 -400
  391. package/src/themes/mashroom/06-components/_components.photoviewer.scss +0 -498
  392. package/src/themes/mashroom/06-components/_components.popover.scss +0 -383
  393. package/src/themes/mashroom/06-components/_components.product-review.scss +0 -408
  394. package/src/themes/mashroom/06-components/_components.progress.scss +0 -249
  395. package/src/themes/mashroom/06-components/_components.rating.scss +0 -300
  396. package/src/themes/mashroom/06-components/_components.river.scss +0 -570
  397. package/src/themes/mashroom/06-components/_components.sectionintro.scss +0 -546
  398. package/src/themes/mashroom/06-components/_components.select.scss +0 -455
  399. package/src/themes/mashroom/06-components/_components.side-menu.scss +0 -635
  400. package/src/themes/mashroom/06-components/_components.skeleton.scss +0 -447
  401. package/src/themes/mashroom/06-components/_components.slider.scss +0 -414
  402. package/src/themes/mashroom/06-components/_components.spinner.scss +0 -198
  403. package/src/themes/mashroom/06-components/_components.steps.scss +0 -350
  404. package/src/themes/mashroom/06-components/_components.tabs.scss +0 -269
  405. package/src/themes/mashroom/06-components/_components.testimonials.scss +0 -561
  406. package/src/themes/mashroom/06-components/_components.toggle.scss +0 -231
  407. package/src/themes/mashroom/06-components/_components.tooltip.scss +0 -167
  408. package/src/themes/mashroom/06-components/_components.upload.scss +0 -537
  409. package/src/themes/mashroom/06-components/_components.video-player.scss +0 -560
  410. package/src/themes/mashroom/06-components/_index.scss +0 -55
  411. package/src/themes/mashroom/99-utilities/_index.scss +0 -6
  412. package/src/themes/mashroom/index.scss +0 -26
  413. package/src/themes/shaj-default/01-settings/_index.scss +0 -69
  414. package/src/themes/shaj-default/01-settings/_settings.accordion.scss +0 -38
  415. package/src/themes/shaj-default/01-settings/_settings.animations.scss +0 -32
  416. package/src/themes/shaj-default/01-settings/_settings.avatar-group.scss +0 -28
  417. package/src/themes/shaj-default/01-settings/_settings.avatar.scss +0 -63
  418. package/src/themes/shaj-default/01-settings/_settings.badge.scss +0 -25
  419. package/src/themes/shaj-default/01-settings/_settings.border-radius.scss +0 -24
  420. package/src/themes/shaj-default/01-settings/_settings.border.scss +0 -20
  421. package/src/themes/shaj-default/01-settings/_settings.box-shadow.scss +0 -46
  422. package/src/themes/shaj-default/01-settings/_settings.breadcrumb.scss +0 -0
  423. package/src/themes/shaj-default/01-settings/_settings.breakpoints.scss +0 -23
  424. package/src/themes/shaj-default/01-settings/_settings.btn-group.scss +0 -11
  425. package/src/themes/shaj-default/01-settings/_settings.button.scss +0 -56
  426. package/src/themes/shaj-default/01-settings/_settings.callout.scss +0 -87
  427. package/src/themes/shaj-default/01-settings/_settings.card.scss +0 -52
  428. package/src/themes/shaj-default/01-settings/_settings.checkbox-group.scss +0 -11
  429. package/src/themes/shaj-default/01-settings/_settings.checkbox.scss +0 -29
  430. package/src/themes/shaj-default/01-settings/_settings.color-mode.scss +0 -13
  431. package/src/themes/shaj-default/01-settings/_settings.colors.scss +0 -91
  432. package/src/themes/shaj-default/01-settings/_settings.config.scss +0 -4
  433. package/src/themes/shaj-default/01-settings/_settings.countdown.scss +0 -26
  434. package/src/themes/shaj-default/01-settings/_settings.data-table.scss +0 -62
  435. package/src/themes/shaj-default/01-settings/_settings.datepicker.scss +0 -51
  436. package/src/themes/shaj-default/01-settings/_settings.design-tokens.scss +0 -9
  437. package/src/themes/shaj-default/01-settings/_settings.dropdown.scss +0 -51
  438. package/src/themes/shaj-default/01-settings/_settings.edge-panel.scss +0 -30
  439. package/src/themes/shaj-default/01-settings/_settings.fonts.scss +0 -13
  440. package/src/themes/shaj-default/01-settings/_settings.form-group.scss +0 -20
  441. package/src/themes/shaj-default/01-settings/_settings.form.scss +0 -12
  442. package/src/themes/shaj-default/01-settings/_settings.grid.scss +0 -29
  443. package/src/themes/shaj-default/01-settings/_settings.hero.scss +0 -47
  444. package/src/themes/shaj-default/01-settings/_settings.input.scss +0 -57
  445. package/src/themes/shaj-default/01-settings/_settings.link.scss +0 -19
  446. package/src/themes/shaj-default/01-settings/_settings.list-group.scss +0 -22
  447. package/src/themes/shaj-default/01-settings/_settings.list.scss +0 -19
  448. package/src/themes/shaj-default/01-settings/_settings.masonry-grid.scss +0 -29
  449. package/src/themes/shaj-default/01-settings/_settings.menu.scss +0 -56
  450. package/src/themes/shaj-default/01-settings/_settings.messages.scss +0 -104
  451. package/src/themes/shaj-default/01-settings/_settings.modal.scss +0 -47
  452. package/src/themes/shaj-default/01-settings/_settings.nav.scss +0 -26
  453. package/src/themes/shaj-default/01-settings/_settings.navbar.scss +0 -60
  454. package/src/themes/shaj-default/01-settings/_settings.pagination.scss +0 -36
  455. package/src/themes/shaj-default/01-settings/_settings.photoviewer.scss +0 -51
  456. package/src/themes/shaj-default/01-settings/_settings.popover.scss +0 -26
  457. package/src/themes/shaj-default/01-settings/_settings.position.scss +0 -15
  458. package/src/themes/shaj-default/01-settings/_settings.progress.scss +0 -23
  459. package/src/themes/shaj-default/01-settings/_settings.rating.scss +0 -17
  460. package/src/themes/shaj-default/01-settings/_settings.river.scss +0 -56
  461. package/src/themes/shaj-default/01-settings/_settings.sectionintro.scss +0 -37
  462. package/src/themes/shaj-default/01-settings/_settings.select.scss +0 -53
  463. package/src/themes/shaj-default/01-settings/_settings.side-menu.scss +0 -85
  464. package/src/themes/shaj-default/01-settings/_settings.skeleton.scss +0 -30
  465. package/src/themes/shaj-default/01-settings/_settings.spacing.scss +0 -72
  466. package/src/themes/shaj-default/01-settings/_settings.spinner.scss +0 -24
  467. package/src/themes/shaj-default/01-settings/_settings.steps.scss +0 -39
  468. package/src/themes/shaj-default/01-settings/_settings.tabs.scss +0 -39
  469. package/src/themes/shaj-default/01-settings/_settings.testimonials.scss +0 -30
  470. package/src/themes/shaj-default/01-settings/_settings.todo.scss +0 -58
  471. package/src/themes/shaj-default/01-settings/_settings.toggle.scss +0 -55
  472. package/src/themes/shaj-default/01-settings/_settings.tooltip.scss +0 -26
  473. package/src/themes/shaj-default/01-settings/_settings.typography.scss +0 -101
  474. package/src/themes/shaj-default/01-settings/_settings.upload.scss +0 -102
  475. package/src/themes/shaj-default/01-settings/_settings.z-layers.scss +0 -25
  476. package/src/themes/shaj-default/02-tools/_index.scss +0 -0
  477. package/src/themes/shaj-default/03-generic/_generic.root.scss +0 -0
  478. package/src/themes/shaj-default/03-generic/_index.scss +0 -2
  479. package/src/themes/shaj-default/04-elements/_index.scss +0 -0
  480. package/src/themes/shaj-default/05-objects/_index.scss +0 -0
  481. package/src/themes/shaj-default/06-components/_components.button.scss +0 -55
  482. package/src/themes/shaj-default/06-components/_components.card.scss +0 -57
  483. package/src/themes/shaj-default/06-components/_components.input.scss +0 -58
  484. package/src/themes/shaj-default/06-components/_components.navbar.scss +0 -99
  485. package/src/themes/shaj-default/06-components/_components.tooltip.scss +0 -0
  486. package/src/themes/shaj-default/06-components/_index.scss +0 -13
  487. package/src/themes/shaj-default/99-utilities/_index.scss +0 -0
  488. package/src/themes/shaj-default/index.scss +0 -25
  489. package/theme.config.ts +0 -360
@@ -1,207 +0,0 @@
1
- /**
2
- * Theme Error Handling Tests
3
- *
4
- * Tests for ThemeError class and ThemeLogger
5
- */
6
-
7
- import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
8
- import {
9
- ThemeError,
10
- ThemeErrorCode,
11
- ThemeLogger,
12
- LogLevel,
13
- getLogger,
14
- setLogger,
15
- createLogger,
16
- } from './errors';
17
-
18
- describe('ThemeError', () => {
19
- it('should create an error with message', () => {
20
- const error = new ThemeError('Test error');
21
- expect(error.message).toBe('Test error');
22
- expect(error.name).toBe('ThemeError');
23
- expect(error.code).toBe(ThemeErrorCode.UNKNOWN_ERROR);
24
- });
25
-
26
- it('should create an error with code', () => {
27
- const error = new ThemeError(
28
- 'Theme not found',
29
- ThemeErrorCode.THEME_NOT_FOUND
30
- );
31
- expect(error.code).toBe(ThemeErrorCode.THEME_NOT_FOUND);
32
- });
33
-
34
- it('should create an error with context', () => {
35
- const context = { themeId: 'test-theme', reason: 'not found' };
36
- const error = new ThemeError('Error', ThemeErrorCode.THEME_NOT_FOUND, context);
37
- expect(error.context).toEqual(context);
38
- });
39
-
40
- it('should have a timestamp', () => {
41
- const before = Date.now();
42
- const error = new ThemeError('Test');
43
- const after = Date.now();
44
- expect(error.timestamp).toBeGreaterThanOrEqual(before);
45
- expect(error.timestamp).toBeLessThanOrEqual(after);
46
- });
47
-
48
- it('should convert to JSON', () => {
49
- const context = { themeId: 'test' };
50
- const error = new ThemeError('Test', ThemeErrorCode.THEME_NOT_FOUND, context);
51
- const json = error.toJSON();
52
- expect(json).toHaveProperty('name', 'ThemeError');
53
- expect(json).toHaveProperty('message', 'Test');
54
- expect(json).toHaveProperty('code', ThemeErrorCode.THEME_NOT_FOUND);
55
- expect(json).toHaveProperty('context', context);
56
- expect(json).toHaveProperty('timestamp');
57
- expect(json).toHaveProperty('stack');
58
- });
59
-
60
- it('should be an instance of Error', () => {
61
- const error = new ThemeError('Test');
62
- expect(error).toBeInstanceOf(Error);
63
- expect(error).toBeInstanceOf(ThemeError);
64
- });
65
- });
66
-
67
- describe('ThemeLogger', () => {
68
- let logger: ThemeLogger;
69
- let consoleErrorSpy: ReturnType<typeof vi.spyOn>;
70
- let consoleWarnSpy: ReturnType<typeof vi.spyOn>;
71
- let consoleInfoSpy: ReturnType<typeof vi.spyOn>;
72
- let consoleDebugSpy: ReturnType<typeof vi.spyOn>;
73
-
74
- beforeEach(() => {
75
- consoleErrorSpy = vi.spyOn(console, 'error').mockImplementation(() => {});
76
- consoleWarnSpy = vi.spyOn(console, 'warn').mockImplementation(() => {});
77
- consoleInfoSpy = vi.spyOn(console, 'info').mockImplementation(() => {});
78
- consoleDebugSpy = vi.spyOn(console, 'debug').mockImplementation(() => {});
79
- });
80
-
81
- afterEach(() => {
82
- vi.restoreAllMocks();
83
- });
84
-
85
- describe('error', () => {
86
- it('should log errors at ERROR level', () => {
87
- logger = new ThemeLogger({ level: LogLevel.ERROR });
88
- const error = new Error('Test error');
89
- logger.error('Test message', error);
90
- expect(consoleErrorSpy).toHaveBeenCalledTimes(1);
91
- });
92
-
93
- it('should not log errors below ERROR level', () => {
94
- logger = new ThemeLogger({ level: LogLevel.WARN });
95
- const error = new Error('Test error');
96
- logger.error('Test message', error);
97
- expect(consoleErrorSpy).not.toHaveBeenCalled();
98
- });
99
-
100
- it('should include context in error logs', () => {
101
- logger = new ThemeLogger({ level: LogLevel.ERROR });
102
- const error = new Error('Test');
103
- const context = { themeId: 'test' };
104
- logger.error('Test', error, context);
105
- expect(consoleErrorSpy).toHaveBeenCalledWith(
106
- expect.stringContaining('[ThemeError]'),
107
- expect.objectContaining({
108
- error,
109
- context: expect.objectContaining(context),
110
- })
111
- );
112
- });
113
-
114
- it('should call custom error handler', () => {
115
- const onError = vi.fn();
116
- logger = new ThemeLogger({ level: LogLevel.ERROR, onError });
117
- const error = new Error('Test');
118
- logger.error('Test', error);
119
- expect(onError).toHaveBeenCalledWith(
120
- expect.any(ThemeError),
121
- undefined
122
- );
123
- });
124
- });
125
-
126
- describe('warn', () => {
127
- it('should log warnings at WARN level', () => {
128
- logger = new ThemeLogger({ level: LogLevel.WARN });
129
- logger.warn('Warning message');
130
- expect(consoleWarnSpy).toHaveBeenCalledTimes(1);
131
- });
132
-
133
- it('should not log warnings below WARN level', () => {
134
- logger = new ThemeLogger({ level: LogLevel.ERROR });
135
- logger.warn('Warning message');
136
- expect(consoleWarnSpy).not.toHaveBeenCalled();
137
- });
138
-
139
- it('should call custom warn handler', () => {
140
- const onWarn = vi.fn();
141
- logger = new ThemeLogger({ level: LogLevel.WARN, onWarn });
142
- logger.warn('Warning', { context: 'data' });
143
- expect(onWarn).toHaveBeenCalledWith('Warning', { context: 'data' });
144
- });
145
- });
146
-
147
- describe('info', () => {
148
- it('should log info at INFO level', () => {
149
- logger = new ThemeLogger({ level: LogLevel.INFO });
150
- logger.info('Info message');
151
- expect(consoleInfoSpy).toHaveBeenCalledTimes(1);
152
- });
153
-
154
- it('should not log info below INFO level', () => {
155
- logger = new ThemeLogger({ level: LogLevel.WARN });
156
- logger.info('Info message');
157
- expect(consoleInfoSpy).not.toHaveBeenCalled();
158
- });
159
- });
160
-
161
- describe('debug', () => {
162
- it('should log debug at DEBUG level', () => {
163
- logger = new ThemeLogger({ level: LogLevel.DEBUG });
164
- logger.debug('Debug message');
165
- expect(consoleDebugSpy).toHaveBeenCalledTimes(1);
166
- });
167
-
168
- it('should not log debug below DEBUG level', () => {
169
- logger = new ThemeLogger({ level: LogLevel.INFO });
170
- logger.debug('Debug message');
171
- expect(consoleDebugSpy).not.toHaveBeenCalled();
172
- });
173
- });
174
-
175
- describe('console control', () => {
176
- it('should not log to console when disabled', () => {
177
- logger = new ThemeLogger({ level: LogLevel.DEBUG, enableConsole: false });
178
- logger.error('Error');
179
- logger.warn('Warning');
180
- logger.info('Info');
181
- logger.debug('Debug');
182
- expect(consoleErrorSpy).not.toHaveBeenCalled();
183
- expect(consoleWarnSpy).not.toHaveBeenCalled();
184
- expect(consoleInfoSpy).not.toHaveBeenCalled();
185
- expect(consoleDebugSpy).not.toHaveBeenCalled();
186
- });
187
- });
188
- });
189
-
190
- describe('Logger utilities', () => {
191
- it('should get default logger', () => {
192
- const logger = getLogger();
193
- expect(logger).toBeInstanceOf(ThemeLogger);
194
- });
195
-
196
- it('should set custom logger', () => {
197
- const customLogger = new ThemeLogger({ level: LogLevel.DEBUG });
198
- setLogger(customLogger);
199
- const retrieved = getLogger();
200
- expect(retrieved).toBe(customLogger);
201
- });
202
-
203
- it('should create logger with config', () => {
204
- const logger = createLogger({ level: LogLevel.WARN });
205
- expect(logger).toBeInstanceOf(ThemeLogger);
206
- });
207
- });
@@ -1,311 +0,0 @@
1
- /**
2
- * CSS Generator
3
- *
4
- * Optimized CSS variable generation from theme objects
5
- */
6
-
7
- import type { Theme } from '../types';
8
-
9
- /**
10
- * CSS generation options
11
- */
12
- export interface CSSGeneratorOptions {
13
- /** CSS selector (default: ':root') */
14
- selector?: string;
15
- /** CSS variable prefix (default: 'atomix') */
16
- prefix?: string;
17
- /** Include comments */
18
- includeComments?: boolean;
19
- /** Minify output */
20
- minify?: boolean;
21
- /** Custom property formatter */
22
- formatProperty?: (path: string[], value: any) => string;
23
- }
24
-
25
- /**
26
- * CSS Generator
27
- *
28
- * Generates optimized CSS custom properties from theme objects
29
- */
30
- export class CSSGenerator {
31
- private options: Required<Omit<CSSGeneratorOptions, 'formatProperty'>> & {
32
- formatProperty?: CSSGeneratorOptions['formatProperty'];
33
- };
34
-
35
- constructor(options: CSSGeneratorOptions = {}) {
36
- this.options = {
37
- selector: options.selector || ':root',
38
- prefix: options.prefix || 'atomix',
39
- includeComments: options.includeComments ?? true,
40
- minify: options.minify ?? false,
41
- formatProperty: options.formatProperty,
42
- };
43
- }
44
-
45
- /**
46
- * Generate CSS from theme
47
- */
48
- generate(theme: Theme): string {
49
- const variables = this.extractVariables(theme);
50
- return this.formatCSS(variables);
51
- }
52
-
53
- /**
54
- * Extract CSS variables from theme
55
- */
56
- private extractVariables(theme: Theme): Map<string, string> {
57
- const variables = new Map<string, string>();
58
-
59
- // Palette
60
- this.extractPalette(theme.palette, variables);
61
-
62
- // Typography
63
- this.extractTypography(theme.typography, variables);
64
-
65
- // Spacing (generate common values)
66
- this.extractSpacing(theme.spacing, variables);
67
-
68
- // Breakpoints
69
- this.extractBreakpoints(theme.breakpoints, variables);
70
-
71
- // Shadows
72
- this.extractShadows(theme.shadows, variables);
73
-
74
- // Transitions
75
- this.extractTransitions(theme.transitions, variables);
76
-
77
- // Z-index
78
- this.extractZIndex(theme.zIndex, variables);
79
-
80
- // Border radius
81
- this.extractBorderRadius(theme.borderRadius, variables);
82
-
83
- // Custom properties
84
- this.extractCustom(theme.custom, variables);
85
-
86
- return variables;
87
- }
88
-
89
- /**
90
- * Extract palette variables
91
- */
92
- private extractPalette(palette: Theme['palette'], variables: Map<string, string>): void {
93
- const colors = ['primary', 'secondary', 'error', 'warning', 'info', 'success'] as const;
94
-
95
- for (const color of colors) {
96
- const colorObj = palette[color];
97
- if (colorObj) {
98
- variables.set(`palette-${color}-main`, colorObj.main);
99
- if (colorObj.light) variables.set(`palette-${color}-light`, colorObj.light);
100
- if (colorObj.dark) variables.set(`palette-${color}-dark`, colorObj.dark);
101
- if (colorObj.contrastText) variables.set(`palette-${color}-contrast-text`, colorObj.contrastText);
102
- }
103
- }
104
-
105
- // Background
106
- if (palette.background) {
107
- variables.set('background-default', palette.background.default);
108
- variables.set('background-paper', palette.background.paper);
109
- variables.set('background-subtle', palette.background.subtle);
110
- }
111
-
112
- // Text
113
- if (palette.text) {
114
- variables.set('text-primary', palette.text.primary);
115
- variables.set('text-secondary', palette.text.secondary);
116
- variables.set('text-disabled', palette.text.disabled);
117
- }
118
- }
119
-
120
- /**
121
- * Extract typography variables
122
- */
123
- private extractTypography(typography: Theme['typography'], variables: Map<string, string>): void {
124
- variables.set('font-family', typography.fontFamily);
125
- variables.set('font-size', `${typography.fontSize}px`);
126
-
127
- // Font weights
128
- if (typography.fontWeightLight) variables.set('font-weight-light', String(typography.fontWeightLight));
129
- if (typography.fontWeightRegular) variables.set('font-weight-regular', String(typography.fontWeightRegular));
130
- if (typography.fontWeightMedium) variables.set('font-weight-medium', String(typography.fontWeightMedium));
131
- if (typography.fontWeightSemiBold) variables.set('font-weight-semibold', String(typography.fontWeightSemiBold));
132
- if (typography.fontWeightBold) variables.set('font-weight-bold', String(typography.fontWeightBold));
133
-
134
- // Headings
135
- const headings = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'] as const;
136
- for (const heading of headings) {
137
- const h = typography[heading];
138
- if (h) {
139
- if (h.fontSize) variables.set(`typography-${heading}-font-size`, String(h.fontSize));
140
- if (h.fontWeight) variables.set(`typography-${heading}-font-weight`, String(h.fontWeight));
141
- if (h.lineHeight) variables.set(`typography-${heading}-line-height`, String(h.lineHeight));
142
- }
143
- }
144
-
145
- // Body
146
- if (typography.body1) {
147
- if (typography.body1.fontSize) variables.set('typography-body1-font-size', String(typography.body1.fontSize));
148
- if (typography.body1.fontWeight) variables.set('typography-body1-font-weight', String(typography.body1.fontWeight));
149
- if (typography.body1.lineHeight) variables.set('typography-body1-line-height', String(typography.body1.lineHeight));
150
- }
151
-
152
- if (typography.body2) {
153
- if (typography.body2.fontSize) variables.set('typography-body2-font-size', String(typography.body2.fontSize));
154
- if (typography.body2.fontWeight) variables.set('typography-body2-font-weight', String(typography.body2.fontWeight));
155
- if (typography.body2.lineHeight) variables.set('typography-body2-line-height', String(typography.body2.lineHeight));
156
- }
157
- }
158
-
159
- /**
160
- * Extract spacing variables
161
- */
162
- private extractSpacing(spacing: Theme['spacing'], variables: Map<string, string>): void {
163
- // Generate common spacing values
164
- for (let i = 0; i <= 12; i++) {
165
- try {
166
- const value = spacing(i);
167
- variables.set(`spacing-${i}`, value);
168
- } catch {
169
- // Ignore errors
170
- }
171
- }
172
- }
173
-
174
- /**
175
- * Extract breakpoint variables
176
- */
177
- private extractBreakpoints(breakpoints: Theme['breakpoints'], variables: Map<string, string>): void {
178
- const keys = ['xs', 'sm', 'md', 'lg', 'xl'] as const;
179
- for (const key of keys) {
180
- const value = breakpoints.values[key];
181
- if (value !== undefined) {
182
- variables.set(`breakpoint-${key}`, `${value}px`);
183
- }
184
- }
185
- }
186
-
187
- /**
188
- * Extract shadow variables
189
- */
190
- private extractShadows(shadows: Theme['shadows'], variables: Map<string, string>): void {
191
- const keys = ['xs', 'sm', 'md', 'lg', 'xl'] as const;
192
- for (const key of keys) {
193
- const shadow = shadows[key];
194
- if (shadow) {
195
- variables.set(`shadow-${key}`, shadow);
196
- }
197
- }
198
- }
199
-
200
- /**
201
- * Extract transition variables
202
- */
203
- private extractTransitions(transitions: Theme['transitions'], variables: Map<string, string>): void {
204
- if (transitions.duration) {
205
- const durations = ['shortest', 'shorter', 'short', 'standard', 'complex'] as const;
206
- for (const key of durations) {
207
- const value = transitions.duration[key];
208
- if (value !== undefined) {
209
- variables.set(`transition-duration-${key}`, `${value}ms`);
210
- }
211
- }
212
- }
213
-
214
- if (transitions.easing) {
215
- const easings = ['easeInOut', 'easeOut', 'easeIn', 'sharp'] as const;
216
- for (const key of easings) {
217
- const value = transitions.easing[key];
218
- if (value) {
219
- variables.set(`transition-easing-${key}`, value);
220
- }
221
- }
222
- }
223
- }
224
-
225
- /**
226
- * Extract z-index variables
227
- */
228
- private extractZIndex(zIndex: Theme['zIndex'], variables: Map<string, string>): void {
229
- const keys = ['mobileStepper', 'speedDial', 'appBar', 'drawer', 'modal', 'snackbar', 'tooltip'] as const;
230
- for (const key of keys) {
231
- const value = zIndex[key];
232
- if (value !== undefined) {
233
- variables.set(`z-index-${key}`, String(value));
234
- }
235
- }
236
- }
237
-
238
- /**
239
- * Extract border radius variables
240
- */
241
- private extractBorderRadius(borderRadius: Theme['borderRadius'], variables: Map<string, string>): void {
242
- const keys = ['base', 'sm', 'md', 'lg', 'xl', 'xxl', '3xl', '4xl', 'pill'] as const;
243
- for (const key of keys) {
244
- const value = borderRadius[key];
245
- if (value !== undefined) {
246
- variables.set(`border-radius-${key}`, String(value));
247
- }
248
- }
249
- }
250
-
251
- /**
252
- * Extract custom properties
253
- */
254
- private extractCustom(custom: Theme['custom'], variables: Map<string, string>): void {
255
- for (const [key, value] of Object.entries(custom)) {
256
- if (value !== undefined && value !== null) {
257
- variables.set(`custom-${key}`, String(value));
258
- }
259
- }
260
- }
261
-
262
- /**
263
- * Format CSS from variables
264
- */
265
- private formatCSS(variables: Map<string, string>): string {
266
- const { selector, prefix, includeComments, minify } = this.options;
267
- const indent = minify ? '' : ' ';
268
- const newline = minify ? '' : '\n';
269
- const space = minify ? '' : ' ';
270
-
271
- let css = '';
272
-
273
- if (includeComments && !minify) {
274
- css += `/* Atomix Theme CSS Variables */${newline}`;
275
- css += `/* Generated from theme configuration */${newline}${newline}`;
276
- }
277
-
278
- css += `${selector}${space}{${newline}`;
279
-
280
- for (const [key, value] of variables.entries()) {
281
- const property = this.formatPropertyName(key);
282
- css += `${indent}--${prefix}-${property}:${space}${value};${newline}`;
283
- }
284
-
285
- css += `}${newline}`;
286
-
287
- return css;
288
- }
289
-
290
- /**
291
- * Format property name
292
- */
293
- private formatPropertyName(key: string): string {
294
- if (this.options.formatProperty) {
295
- return this.options.formatProperty(key.split('-'), key);
296
- }
297
- return key;
298
- }
299
- }
300
-
301
- /**
302
- * Generate CSS variables from theme
303
- *
304
- * @param theme - Theme object
305
- * @param options - Generation options
306
- * @returns CSS string
307
- */
308
- export function generateCSS(theme: Theme, options: CSSGeneratorOptions = {}): string {
309
- const generator = new CSSGenerator(options);
310
- return generator.generate(theme);
311
- }