@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,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
- }