@shohojdhara/atomix 0.1.16 → 0.1.18

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 (525) hide show
  1. package/CONTRIBUTING.md +151 -0
  2. package/NEXTJS_INTEGRATION.md +358 -0
  3. package/README.md +168 -119
  4. package/babel.config.js +58 -0
  5. package/css.d.ts +10 -0
  6. package/dist/css/atomix.css +1 -2
  7. package/dist/js/194.js +1 -2
  8. package/dist/js/244.js +1 -0
  9. package/dist/js/atomix.react.cjs.js +1 -0
  10. package/dist/js/atomix.react.esm.js +1 -2
  11. package/dist/js/atomix.react.umd.js +1 -2
  12. package/dist/js/chunks/cjs/202.9d3b1ef1eaa0d5c8a309.js +1 -0
  13. package/dist/js/chunks/cjs/308.6ea9685ea38ead4120d0.js +1 -0
  14. package/dist/js/chunks/cjs/54.73db6922594e421ba6b1.js +1 -0
  15. package/dist/js/chunks/cjs/619.51feecaadcab819780d4.js +1 -0
  16. package/dist/js/chunks/cjs/690.90f6d11164081cbcbc4d.js +1 -0
  17. package/dist/js/chunks/cjs/894.24877561df336a8dfd14.js +1 -0
  18. package/dist/js/chunks/cjs/897.6c2a71fae95338890de7.js +1 -0
  19. package/dist/js/chunks/esm/{202.ff48d27672233280e021.js → 202.82aa7b3244e53c9edb72.js} +1 -2
  20. package/dist/js/chunks/esm/{308.f873332126eba90e5c62.js → 308.27e1e4005705ae320432.js} +1 -2
  21. package/dist/js/chunks/esm/{54.4db919e5e4e5cc6d7c72.js → 54.ece1fd6964f98d4d994f.js} +1 -2
  22. package/dist/js/chunks/esm/{619.afc5a718eff77fa423b5.js → 619.ebeb0298432a066ac05c.js} +1 -2
  23. package/dist/js/chunks/esm/{690.a9e968c7497d61e56cdc.js → 690.c5f412cc979b55740359.js} +1 -2
  24. package/dist/js/chunks/esm/{894.f1091a4a8758c26d29e4.js → 894.3604ddc9367d75191198.js} +1 -2
  25. package/dist/js/chunks/esm/{897.561a50f7d043d42169da.js → 897.a4aab2fad9401693eb12.js} +1 -2
  26. package/dist/js/chunks/umd/{202.dac7605cc555b6bda542.js → 202.5017dd0403d696bf1644.js} +1 -2
  27. package/dist/js/chunks/umd/{308.6709979849dcbdb90c9b.js → 308.4bc14b9d7b16b6ee0ab8.js} +1 -2
  28. package/dist/js/chunks/umd/{54.403470e1f7d0ef4424a7.js → 54.7fdfb4a031989470a70d.js} +1 -2
  29. package/dist/js/chunks/umd/{619.fa05ea98c10270eb64c5.js → 619.84a0c35ecee695250085.js} +1 -2
  30. package/dist/js/chunks/umd/{690.aa7054d1c53e5402c2d6.js → 690.d7041094a34a4a434be2.js} +1 -2
  31. package/dist/js/chunks/umd/{894.3e1eaf0a2aadf4434390.js → 894.c127ee4e9513c22ee97d.js} +1 -2
  32. package/dist/js/chunks/umd/{897.554ea37be4453698c167.js → 897.26932ac837a39fc91907.js} +1 -2
  33. package/dist/types/components/Badge/index.d.ts +3 -3
  34. package/dist/types/components/{Navbar → Navigation/Menu}/MegaMenu.d.ts +1 -1
  35. package/dist/types/components/{Navbar → Navigation/Menu}/Menu.d.ts +1 -1
  36. package/dist/types/components/Navigation/Nav/Nav.d.ts +20 -0
  37. package/dist/types/components/{Navbar → Navigation/Nav}/NavDropdown.d.ts +1 -1
  38. package/dist/types/components/Navigation/Nav/NavItem.d.ts +33 -0
  39. package/dist/types/components/Navigation/Navbar/Navbar.d.ts +19 -0
  40. package/dist/types/components/Navigation/SideMenu/SideMenu.d.ts +20 -0
  41. package/dist/types/components/Navigation/SideMenu/SideMenuItem.d.ts +30 -0
  42. package/dist/types/components/Navigation/SideMenu/SideMenuList.d.ts +17 -0
  43. package/dist/types/components/Navigation/index.d.ts +10 -0
  44. package/dist/types/components/PhotoViewer/PhotoViewer.d.ts +2 -2
  45. package/dist/types/components/PhotoViewer/PhotoViewerHeader.d.ts +2 -2
  46. package/dist/types/components/Tab/index.d.ts +2 -2
  47. package/dist/types/components/Toggle/index.d.ts +2 -2
  48. package/dist/types/components/Tooltip/index.d.ts +3 -3
  49. package/dist/types/components/index.d.ts +1 -1
  50. package/dist/types/lib/composables/index.d.ts +1 -0
  51. package/dist/types/lib/composables/useDatePicker.d.ts +1 -1
  52. package/dist/types/lib/composables/useDropdown.d.ts +1 -1
  53. package/dist/types/lib/composables/useModal.d.ts +1 -1
  54. package/dist/types/lib/composables/usePhotoViewer.d.ts +1 -1
  55. package/dist/types/lib/composables/useRating.d.ts +1 -1
  56. package/dist/types/lib/composables/useSideMenu.d.ts +28 -0
  57. package/dist/types/lib/constants/components.d.ts +72 -0
  58. package/dist/types/lib/types/components.d.ts +103 -0
  59. package/examples/nextjs-example.tsx +271 -0
  60. package/implementation-guide.md +505 -0
  61. package/next.config.js +69 -0
  62. package/package.json +80 -42
  63. package/postcss.config.js +28 -0
  64. package/src/Introduction.mdx +3 -5
  65. package/src/assets/fonts/HelveticaNeue/stylesheet.css +140 -127
  66. package/src/components/Accordion/Accordion.stories.tsx +58 -45
  67. package/src/components/Accordion/Accordion.tsx +14 -4
  68. package/src/components/Accordion/scripts/accordionInteractions.ts +9 -9
  69. package/src/components/Accordion/scripts/bundle.ts +1 -1
  70. package/src/components/Accordion/scripts/index.ts +3 -3
  71. package/src/components/AtomixLogo.tsx +13 -19
  72. package/src/components/Avatar/Avatar.stories.tsx +24 -21
  73. package/src/components/Avatar/Avatar.tsx +5 -8
  74. package/src/components/Avatar/AvatarGroup.tsx +11 -11
  75. package/src/components/Avatar/index.ts +1 -1
  76. package/src/components/Avatar/scripts/index.ts +66 -71
  77. package/src/components/Badge/Badge.stories.tsx +51 -21
  78. package/src/components/Badge/Badge.tsx +14 -12
  79. package/src/components/Badge/index.ts +3 -3
  80. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +40 -40
  81. package/src/components/Breadcrumb/Breadcrumb.tsx +19 -26
  82. package/src/components/Breadcrumb/index.ts +1 -1
  83. package/src/components/Breadcrumb/scripts/breadcrumb.ts +36 -34
  84. package/src/components/Breadcrumb/scripts/index.ts +1 -1
  85. package/src/components/Breadcrumb/scripts/types.ts +9 -9
  86. package/src/components/Button/Button.stories.tsx +36 -12
  87. package/src/components/Button/Button.tsx +52 -39
  88. package/src/components/Button/index.ts +1 -1
  89. package/src/components/Button/scripts/buttonInteractions.ts +9 -9
  90. package/src/components/Button/scripts/index.ts +1 -1
  91. package/src/components/Callout/Callout.stories.tsx +207 -114
  92. package/src/components/Callout/Callout.tsx +12 -12
  93. package/src/components/Callout/index.ts +1 -1
  94. package/src/components/Callout/scripts/CalloutInteractions.ts +58 -48
  95. package/src/components/Callout/scripts/bundle.ts +2 -2
  96. package/src/components/Callout/scripts/index.ts +19 -15
  97. package/src/components/Card/Card.stories.tsx +2 -2
  98. package/src/components/Card/Card.tsx +49 -72
  99. package/src/components/Card/ElevationCard.tsx +4 -8
  100. package/src/components/Card/index.ts +1 -1
  101. package/src/components/Card/scripts/bundle.ts +7 -7
  102. package/src/components/Card/scripts/cardInteractions.ts +24 -24
  103. package/src/components/Card/scripts/index.ts +25 -26
  104. package/src/components/ColorModeToggle/ColorModeToggle.stories.tsx +6 -3
  105. package/src/components/ColorModeToggle/ColorModeToggle.tsx +12 -15
  106. package/src/components/ColorModeToggle/index.ts +1 -1
  107. package/src/components/Countdown/Countdown.stories.tsx +6 -2
  108. package/src/components/Countdown/Countdown.tsx +56 -48
  109. package/src/components/Countdown/index.ts +1 -1
  110. package/src/components/Countdown/scripts/index.ts +33 -28
  111. package/src/components/DataTable/DataTable.stories.tsx +23 -18
  112. package/src/components/DataTable/DataTable.tsx +39 -39
  113. package/src/components/DataTable/index.ts +1 -1
  114. package/src/components/DataTable/scripts/bundle.ts +8 -3
  115. package/src/components/DataTable/scripts/index.ts +182 -164
  116. package/src/components/DatePicker/DatePicker.stories.tsx +136 -148
  117. package/src/components/DatePicker/DatePicker.tsx +461 -420
  118. package/src/components/DatePicker/scripts/bundle.ts +12 -7
  119. package/src/components/DatePicker/scripts/componentInteractions.ts +76 -46
  120. package/src/components/DatePicker/scripts/index.ts +176 -156
  121. package/src/components/DatePicker/types.ts +32 -32
  122. package/src/components/DatePicker/utils.ts +41 -30
  123. package/src/components/Dropdown/Dropdown.stories.tsx +85 -55
  124. package/src/components/Dropdown/Dropdown.tsx +97 -88
  125. package/src/components/Dropdown/index.ts +5 -10
  126. package/src/components/Dropdown/scripts/bundle.ts +10 -10
  127. package/src/components/Dropdown/scripts/componentInteractions.ts +10 -2
  128. package/src/components/Dropdown/scripts/index.ts +122 -117
  129. package/src/components/EdgePanel/EdgePanel.stories.tsx +142 -58
  130. package/src/components/EdgePanel/EdgePanel.tsx +7 -13
  131. package/src/components/EdgePanel/index.ts +1 -1
  132. package/src/components/EdgePanel/scripts/bundle.ts +5 -5
  133. package/src/components/EdgePanel/scripts/edgePanelInteractions.ts +26 -26
  134. package/src/components/EdgePanel/scripts/index.ts +53 -53
  135. package/src/components/Form/Checkbox.stories.tsx +2 -2
  136. package/src/components/Form/Checkbox.tsx +13 -7
  137. package/src/components/Form/Form.stories.tsx +144 -218
  138. package/src/components/Form/Form.tsx +6 -6
  139. package/src/components/Form/FormGroup.stories.tsx +21 -38
  140. package/src/components/Form/FormGroup.tsx +18 -20
  141. package/src/components/Form/Input.stories.tsx +1 -1
  142. package/src/components/Form/Input.tsx +18 -8
  143. package/src/components/Form/Radio.stories.tsx +12 -25
  144. package/src/components/Form/Radio.tsx +11 -6
  145. package/src/components/Form/Select.stories.tsx +6 -6
  146. package/src/components/Form/Select.tsx +31 -33
  147. package/src/components/Form/Textarea.stories.tsx +7 -2
  148. package/src/components/Form/Textarea.tsx +17 -8
  149. package/src/components/Form/index.ts +1 -1
  150. package/src/components/Hero/Hero.stories.tsx +44 -42
  151. package/src/components/Hero/Hero.tsx +28 -38
  152. package/src/components/Hero/index.ts +1 -1
  153. package/src/components/Hero/scripts/bundle.ts +6 -6
  154. package/src/components/Hero/scripts/heroInteractions.ts +24 -29
  155. package/src/components/Hero/scripts/index.ts +16 -17
  156. package/src/components/Icon/Icon.tsx +16 -18
  157. package/src/components/Icon/index.ts +1 -1
  158. package/src/components/List/List.stories.tsx +1 -3
  159. package/src/components/List/List.tsx +6 -10
  160. package/src/components/List/ListGroup.tsx +1 -1
  161. package/src/components/List/index.ts +1 -1
  162. package/src/components/Messages/Messages.stories.tsx +30 -29
  163. package/src/components/Messages/Messages.tsx +60 -55
  164. package/src/components/Messages/index.ts +1 -1
  165. package/src/components/Messages/scripts/bundle.ts +1 -6
  166. package/src/components/Messages/scripts/componentInteractions.ts +32 -37
  167. package/src/components/Messages/scripts/index.ts +61 -55
  168. package/src/components/Modal/Modal.stories.tsx +77 -53
  169. package/src/components/Modal/Modal.tsx +63 -62
  170. package/src/components/Modal/index.ts +1 -1
  171. package/src/components/Modal/scripts/bundle.ts +3 -3
  172. package/src/components/Modal/scripts/index.ts +96 -84
  173. package/src/components/Modal/scripts/modalInteractions.ts +16 -14
  174. package/src/components/{Navbar → Navigation/Menu}/MegaMenu.tsx +50 -59
  175. package/src/components/Navigation/Menu/Menu.stories.tsx +340 -0
  176. package/src/components/Navigation/Menu/Menu.tsx +110 -0
  177. package/src/components/Navigation/Nav/Nav.stories.tsx +458 -0
  178. package/src/components/Navigation/Nav/Nav.tsx +50 -0
  179. package/src/components/Navigation/Nav/NavDropdown.tsx +105 -0
  180. package/src/components/Navigation/Nav/NavItem.tsx +159 -0
  181. package/src/components/{Navbar → Navigation/Navbar}/Navbar.stories.tsx +198 -104
  182. package/src/components/Navigation/Navbar/Navbar.tsx +150 -0
  183. package/src/components/Navigation/README.md +314 -0
  184. package/src/components/Navigation/SideMenu/SideMenu.README.md +494 -0
  185. package/src/components/Navigation/SideMenu/SideMenu.stories.tsx +618 -0
  186. package/src/components/Navigation/SideMenu/SideMenu.tsx +101 -0
  187. package/src/components/Navigation/SideMenu/SideMenuItem.tsx +95 -0
  188. package/src/components/Navigation/SideMenu/SideMenuList.tsx +41 -0
  189. package/src/components/Navigation/index.ts +23 -0
  190. package/src/components/Navigation/scripts/NavbarInteractions.ts +171 -0
  191. package/src/components/Navigation/scripts/SideMenu.ts +319 -0
  192. package/src/components/Navigation/scripts/SideMenuBundle.ts +69 -0
  193. package/src/components/Navigation/scripts/SideMenuInteractions.ts +250 -0
  194. package/src/components/Navigation/scripts/bundle.ts +58 -0
  195. package/src/components/Navigation/scripts/index.ts +248 -0
  196. package/src/components/Pagination/Pagination.stories.tsx +34 -33
  197. package/src/components/Pagination/Pagination.tsx +25 -35
  198. package/src/components/Pagination/index.ts +1 -1
  199. package/src/components/Pagination/scripts/index.ts +42 -37
  200. package/src/components/PhotoViewer/PhotoViewer.stories.tsx +48 -48
  201. package/src/components/PhotoViewer/PhotoViewer.tsx +29 -46
  202. package/src/components/PhotoViewer/PhotoViewerHeader.tsx +20 -26
  203. package/src/components/PhotoViewer/PhotoViewerImage.tsx +19 -17
  204. package/src/components/PhotoViewer/PhotoViewerInfo.tsx +13 -5
  205. package/src/components/PhotoViewer/PhotoViewerNavigation.tsx +5 -5
  206. package/src/components/PhotoViewer/PhotoViewerThumbnails.tsx +31 -30
  207. package/src/components/PhotoViewer/examples/ImageGallery.tsx +27 -37
  208. package/src/components/PhotoViewer/examples/SimpleGallery.tsx +19 -13
  209. package/src/components/PhotoViewer/examples/index.ts +1 -1
  210. package/src/components/PhotoViewer/index.ts +1 -1
  211. package/src/components/PhotoViewer/scripts/PhotoViewerInteractions.ts +43 -33
  212. package/src/components/PhotoViewer/scripts/bundle.ts +14 -14
  213. package/src/components/PhotoViewer/scripts/index.ts +173 -129
  214. package/src/components/Popover/Popover.stories.tsx +11 -12
  215. package/src/components/Popover/Popover.tsx +36 -36
  216. package/src/components/Popover/index.ts +1 -1
  217. package/src/components/Popover/scripts/bundle.ts +1 -1
  218. package/src/components/Popover/scripts/componentInteractions.ts +34 -46
  219. package/src/components/Popover/scripts/index.ts +64 -53
  220. package/src/components/ProductReview/ProductReview.stories.tsx +10 -8
  221. package/src/components/ProductReview/ProductReview.tsx +28 -32
  222. package/src/components/ProductReview/scripts/componentInteractions.ts +20 -20
  223. package/src/components/Progress/Progress.tsx +36 -34
  224. package/src/components/Progress/scripts/bundle.ts +7 -2
  225. package/src/components/Progress/scripts/componentInteractions.ts +29 -23
  226. package/src/components/Progress/scripts/index.ts +45 -39
  227. package/src/components/Rating/Rating.stories.tsx +3 -16
  228. package/src/components/Rating/Rating.tsx +250 -231
  229. package/src/components/Rating/scripts/bundle.ts +11 -6
  230. package/src/components/Rating/scripts/index.ts +85 -80
  231. package/src/components/Rating/scripts/ratingInteractions.ts +27 -24
  232. package/src/components/River/River.stories.tsx +70 -24
  233. package/src/components/River/River.tsx +28 -38
  234. package/src/components/River/index.ts +1 -1
  235. package/src/components/River/scripts/index.ts +11 -12
  236. package/src/components/SectionIntro/SectionIntro.stories.tsx +12 -9
  237. package/src/components/SectionIntro/SectionIntro.tsx +25 -31
  238. package/src/components/SectionIntro/scripts/componentInteractions.ts +1 -1
  239. package/src/components/SectionIntro/scripts/index.ts +30 -16
  240. package/src/components/Spinner/Spinner.stories.tsx +5 -7
  241. package/src/components/Spinner/Spinner.tsx +11 -6
  242. package/src/components/Spinner/index.ts +2 -2
  243. package/src/components/Steps/Steps.stories.tsx +44 -48
  244. package/src/components/Steps/Steps.tsx +20 -20
  245. package/src/components/Steps/index.ts +1 -1
  246. package/src/components/Steps/scripts/index.ts +9 -9
  247. package/src/components/Tab/Tab.stories.tsx +14 -6
  248. package/src/components/Tab/Tab.tsx +16 -18
  249. package/src/components/Tab/index.ts +2 -2
  250. package/src/components/Tab/scripts/index.ts +13 -13
  251. package/src/components/Testimonial/Testimonial.stories.tsx +54 -51
  252. package/src/components/Testimonial/Testimonial.tsx +18 -19
  253. package/src/components/Testimonial/index.ts +1 -1
  254. package/src/components/Testimonial/scripts/index.ts +19 -8
  255. package/src/components/Todo/Todo.stories.tsx +7 -24
  256. package/src/components/Todo/Todo.tsx +35 -46
  257. package/src/components/Todo/index.ts +1 -1
  258. package/src/components/Todo/scripts/bundle.ts +1 -1
  259. package/src/components/Todo/scripts/index.ts +99 -81
  260. package/src/components/Todo/scripts/todoInteractions.ts +12 -12
  261. package/src/components/Todo/scripts/types.ts +3 -3
  262. package/src/components/Toggle/Toggle.stories.tsx +2 -2
  263. package/src/components/Toggle/Toggle.tsx +18 -18
  264. package/src/components/Toggle/index.ts +2 -2
  265. package/src/components/Toggle/scripts/bundle.ts +7 -2
  266. package/src/components/Toggle/scripts/index.ts +14 -10
  267. package/src/components/Toggle/scripts/toggleInteractions.ts +11 -14
  268. package/src/components/Tooltip/Tooltip.stories.tsx +13 -6
  269. package/src/components/Tooltip/Tooltip.tsx +25 -15
  270. package/src/components/Tooltip/index.ts +3 -3
  271. package/src/components/Tooltip/scripts/bundle.ts +0 -1
  272. package/src/components/Tooltip/scripts/index.ts +44 -41
  273. package/src/components/Tooltip/scripts/tooltipInteractions.ts +22 -22
  274. package/src/components/Upload/Upload.stories.tsx +28 -34
  275. package/src/components/Upload/Upload.tsx +86 -71
  276. package/src/components/Upload/index.ts +1 -1
  277. package/src/components/Upload/scripts/index.ts +58 -43
  278. package/src/components/index.ts +5 -6
  279. package/src/design-tokens/BoxShadow/BoxShadow.stories.tsx +13 -10
  280. package/src/design-tokens/Colors/colors.scss +10 -7
  281. package/src/design-tokens/Colors/colors.stories.tsx +46 -59
  282. package/src/design-tokens/Spacing/Spacing.scss +7 -5
  283. package/src/design-tokens/Spacing/Spacing.stories.tsx +19 -18
  284. package/src/design-tokens/Typography/Typography.scss +88 -25
  285. package/src/design-tokens/Typography/Typography.stories.tsx +22 -25
  286. package/src/docs/implementation-guide.mdx +2 -2
  287. package/src/htmlComponentsEntry.ts +23 -23
  288. package/src/index.ts +1 -1
  289. package/src/layouts/Grid/Container.tsx +6 -10
  290. package/src/layouts/Grid/Grid.stories.tsx +72 -34
  291. package/src/layouts/Grid/Grid.tsx +6 -13
  292. package/src/layouts/Grid/GridCol.tsx +29 -26
  293. package/src/layouts/Grid/Row.tsx +6 -13
  294. package/src/layouts/MasonryGrid/MasonryGrid.stories.tsx +79 -72
  295. package/src/layouts/MasonryGrid/MasonryGrid.tsx +23 -25
  296. package/src/layouts/MasonryGrid/MasonryGridItem.tsx +4 -12
  297. package/src/layouts/index.ts +3 -4
  298. package/src/lib/composables/index.ts +3 -3
  299. package/src/lib/composables/useAccordion.ts +15 -6
  300. package/src/lib/composables/useBadge.ts +3 -3
  301. package/src/lib/composables/useBreadcrumb.ts +6 -12
  302. package/src/lib/composables/useButton.ts +3 -3
  303. package/src/lib/composables/useCallout.ts +3 -3
  304. package/src/lib/composables/useCard.ts +50 -28
  305. package/src/lib/composables/useCheckbox.ts +7 -7
  306. package/src/lib/composables/useDataTable.ts +61 -57
  307. package/src/lib/composables/useDatePicker.ts +255 -231
  308. package/src/lib/composables/useDropdown.ts +90 -75
  309. package/src/lib/composables/useEdgePanel.ts +50 -47
  310. package/src/lib/composables/useForm.ts +4 -7
  311. package/src/lib/composables/useFormGroup.ts +11 -12
  312. package/src/lib/composables/useHero.ts +36 -38
  313. package/src/lib/composables/useInput.ts +9 -10
  314. package/src/lib/composables/useMessages.ts +12 -14
  315. package/src/lib/composables/useModal.ts +37 -34
  316. package/src/lib/composables/useNavbar.ts +33 -22
  317. package/src/lib/composables/usePagination.ts +3 -10
  318. package/src/lib/composables/usePhotoViewer.ts +625 -578
  319. package/src/lib/composables/usePopover.ts +68 -62
  320. package/src/lib/composables/useProgress.ts +9 -12
  321. package/src/lib/composables/useRadio.ts +4 -4
  322. package/src/lib/composables/useRating.ts +82 -70
  323. package/src/lib/composables/useRiver.ts +28 -31
  324. package/src/lib/composables/useSelect.ts +7 -8
  325. package/src/lib/composables/useSideMenu.ts +197 -0
  326. package/src/lib/composables/useSpinner.ts +3 -3
  327. package/src/lib/composables/useTextarea.ts +8 -9
  328. package/src/lib/composables/useTodo.ts +14 -18
  329. package/src/lib/constants/components.ts +191 -118
  330. package/src/lib/constants/index.ts +1 -1
  331. package/src/lib/types/components.ts +454 -324
  332. package/src/lib/utils/dom.ts +2 -6
  333. package/src/lib/utils/icons.ts +20 -12
  334. package/src/lib/utils/index.ts +2 -2
  335. package/src/lib/utils/useForkRef.ts +1 -2
  336. package/src/styles/01-settings/_index.scss +59 -59
  337. package/src/styles/01-settings/_settings.accordion.scss +21 -21
  338. package/src/styles/01-settings/_settings.animations.scss +2 -2
  339. package/src/styles/01-settings/_settings.avatar-group.scss +14 -14
  340. package/src/styles/01-settings/_settings.avatar.scss +31 -31
  341. package/src/styles/01-settings/_settings.badge.scss +11 -11
  342. package/src/styles/01-settings/_settings.border-radius.scss +10 -9
  343. package/src/styles/01-settings/_settings.border.scss +7 -7
  344. package/src/styles/01-settings/_settings.box-shadow.scss +24 -12
  345. package/src/styles/01-settings/_settings.breadcrumb.scss +18 -18
  346. package/src/styles/01-settings/_settings.btn-group.scss +1 -1
  347. package/src/styles/01-settings/_settings.button.scss +63 -49
  348. package/src/styles/01-settings/_settings.callout.scss +27 -7
  349. package/src/styles/01-settings/_settings.card.scss +27 -30
  350. package/src/styles/01-settings/_settings.checkbox-group.scss +2 -3
  351. package/src/styles/01-settings/_settings.checkbox.scss +17 -18
  352. package/src/styles/01-settings/_settings.color-mode.scss +1 -1
  353. package/src/styles/01-settings/_settings.colors.scss +197 -214
  354. package/src/styles/01-settings/_settings.config.scss +1 -3
  355. package/src/styles/01-settings/_settings.countdown.scss +14 -14
  356. package/src/styles/01-settings/_settings.data-table.scss +6 -6
  357. package/src/styles/01-settings/_settings.datepicker.scss +40 -42
  358. package/src/styles/01-settings/_settings.dropdown.scss +30 -30
  359. package/src/styles/01-settings/_settings.edge-panel.scss +16 -16
  360. package/src/styles/01-settings/_settings.fonts.scss +14 -12
  361. package/src/styles/01-settings/_settings.form-group.scss +10 -10
  362. package/src/styles/01-settings/_settings.form.scss +3 -3
  363. package/src/styles/01-settings/_settings.grid.scss +1 -1
  364. package/src/styles/01-settings/_settings.hero.scss +23 -23
  365. package/src/styles/01-settings/_settings.input.scss +32 -32
  366. package/src/styles/01-settings/_settings.link.scss +6 -6
  367. package/src/styles/01-settings/_settings.list-group.scss +12 -12
  368. package/src/styles/01-settings/_settings.list.scss +2 -2
  369. package/src/styles/01-settings/_settings.maps.scss +183 -188
  370. package/src/styles/01-settings/_settings.masonry-grid.scss +2 -2
  371. package/src/styles/01-settings/_settings.menu.scss +35 -38
  372. package/src/styles/01-settings/_settings.messages.scss +71 -77
  373. package/src/styles/01-settings/_settings.modal.scss +24 -24
  374. package/src/styles/01-settings/_settings.nav.scss +15 -15
  375. package/src/styles/01-settings/_settings.navbar.scss +39 -12
  376. package/src/styles/01-settings/_settings.pagination.scss +21 -21
  377. package/src/styles/01-settings/_settings.photoviewer.scss +1 -1
  378. package/src/styles/01-settings/_settings.popover.scss +3 -3
  379. package/src/styles/01-settings/_settings.position.scss +2 -2
  380. package/src/styles/01-settings/_settings.progress.scss +15 -18
  381. package/src/styles/01-settings/_settings.rating.scss +7 -7
  382. package/src/styles/01-settings/_settings.river.scss +25 -25
  383. package/src/styles/01-settings/_settings.sectionintro.scss +15 -16
  384. package/src/styles/01-settings/_settings.select.scss +31 -31
  385. package/src/styles/01-settings/_settings.side-menu.scss +64 -16
  386. package/src/styles/01-settings/_settings.skeleton.scss +12 -12
  387. package/src/styles/01-settings/_settings.spacing.scss +62 -33
  388. package/src/styles/01-settings/_settings.spinner.scss +10 -10
  389. package/src/styles/01-settings/_settings.steps.scss +22 -22
  390. package/src/styles/01-settings/_settings.tabs.scss +25 -25
  391. package/src/styles/01-settings/_settings.testimonials.scss +17 -19
  392. package/src/styles/01-settings/_settings.todo.scss +1 -1
  393. package/src/styles/01-settings/_settings.toggle.scss +26 -26
  394. package/src/styles/01-settings/_settings.tooltip.scss +15 -15
  395. package/src/styles/01-settings/_settings.typography.scss +65 -48
  396. package/src/styles/01-settings/_settings.upload.scss +70 -77
  397. package/src/styles/01-settings/_settings.z-layers.scss +1 -1
  398. package/src/styles/02-tools/_index.scss +19 -19
  399. package/src/styles/02-tools/_tools.animations.scss +4 -4
  400. package/src/styles/02-tools/_tools.border-radius.scss +4 -5
  401. package/src/styles/02-tools/_tools.breakpoints.scss +33 -34
  402. package/src/styles/02-tools/_tools.button.scss +49 -25
  403. package/src/styles/02-tools/_tools.color-mode.scss +11 -11
  404. package/src/styles/02-tools/_tools.event.scss +1 -1
  405. package/src/styles/02-tools/_tools.hidden-visually.scss +1 -1
  406. package/src/styles/02-tools/_tools.hidden.scss +1 -1
  407. package/src/styles/02-tools/_tools.map-loop.scss +9 -9
  408. package/src/styles/02-tools/_tools.media-queries.scss +5 -3
  409. package/src/styles/02-tools/_tools.object-fit.scss +3 -3
  410. package/src/styles/02-tools/_tools.placeholder.scss +0 -1
  411. package/src/styles/02-tools/_tools.rem.scss +1 -1
  412. package/src/styles/02-tools/_tools.spacing.scss +8 -34
  413. package/src/styles/02-tools/_tools.to-rgb.scss +3 -3
  414. package/src/styles/02-tools/_tools.transition.scss +1 -1
  415. package/src/styles/02-tools/_tools.utility-api.scss +29 -14
  416. package/src/styles/03-generic/_generic.fonts.scss +0 -1
  417. package/src/styles/03-generic/_generic.reset.scss +13 -8
  418. package/src/styles/03-generic/_generic.root.scss +5 -5
  419. package/src/styles/03-generic/_index.scss +4 -4
  420. package/src/styles/04-elements/_elements.all.scss +2 -2
  421. package/src/styles/04-elements/_elements.body.scss +1 -2
  422. package/src/styles/04-elements/_elements.heading.scss +37 -21
  423. package/src/styles/04-elements/_elements.links.scss +0 -1
  424. package/src/styles/04-elements/_index.scss +5 -5
  425. package/src/styles/05-objects/_index.scss +3 -3
  426. package/src/styles/05-objects/_objects.container.scss +5 -4
  427. package/src/styles/05-objects/_objects.grid.scss +12 -12
  428. package/src/styles/05-objects/_objects.masonry-grid.scss +80 -74
  429. package/src/styles/06-components/_components.accordion.scss +12 -6
  430. package/src/styles/06-components/_components.avatar-group.scss +9 -8
  431. package/src/styles/06-components/_components.avatar.scss +78 -77
  432. package/src/styles/06-components/_components.badge.scss +48 -48
  433. package/src/styles/06-components/_components.breadcrumb.scss +57 -58
  434. package/src/styles/06-components/_components.btn-group.scss +22 -22
  435. package/src/styles/06-components/_components.button.scss +118 -110
  436. package/src/styles/06-components/_components.callout.scss +21 -15
  437. package/src/styles/06-components/_components.card.scss +6 -10
  438. package/src/styles/06-components/_components.checkbox-group.scss +9 -10
  439. package/src/styles/06-components/_components.checkbox.scss +10 -17
  440. package/src/styles/06-components/_components.color-mode-toggle.scss +6 -6
  441. package/src/styles/06-components/_components.countdown.scss +53 -54
  442. package/src/styles/06-components/_components.data-table.scss +40 -36
  443. package/src/styles/06-components/_components.datepicker.scss +95 -73
  444. package/src/styles/06-components/_components.dropdown.scss +15 -9
  445. package/src/styles/06-components/_components.edge-panel.scss +87 -46
  446. package/src/styles/06-components/_components.form-group.scss +5 -4
  447. package/src/styles/06-components/_components.hero.scss +128 -132
  448. package/src/styles/06-components/_components.icon.scss +16 -16
  449. package/src/styles/06-components/_components.image-gallery.scss +9 -7
  450. package/src/styles/06-components/_components.input.scss +18 -16
  451. package/src/styles/06-components/_components.list-group.scss +52 -51
  452. package/src/styles/06-components/_components.list.scss +15 -15
  453. package/src/styles/06-components/_components.menu.scss +225 -220
  454. package/src/styles/06-components/_components.messages.scss +45 -32
  455. package/src/styles/06-components/_components.modal.scss +0 -1
  456. package/src/styles/06-components/_components.nav.scss +56 -11
  457. package/src/styles/06-components/_components.navbar.scss +278 -202
  458. package/src/styles/06-components/_components.pagination.scss +7 -6
  459. package/src/styles/06-components/_components.photoviewer.scss +121 -116
  460. package/src/styles/06-components/_components.popover.scss +10 -10
  461. package/src/styles/06-components/_components.product-review.scss +3 -3
  462. package/src/styles/06-components/_components.progress.scss +32 -35
  463. package/src/styles/06-components/_components.rating.scss +9 -8
  464. package/src/styles/06-components/_components.river.scss +4 -2
  465. package/src/styles/06-components/_components.sectionintro.scss +19 -26
  466. package/src/styles/06-components/_components.select.scss +7 -8
  467. package/src/styles/06-components/_components.side-menu.scss +154 -28
  468. package/src/styles/06-components/_components.skeleton.scss +0 -1
  469. package/src/styles/06-components/_components.spinner.scss +2 -4
  470. package/src/styles/06-components/_components.steps.scss +76 -77
  471. package/src/styles/06-components/_components.tabs.scss +17 -12
  472. package/src/styles/06-components/_components.testimonials.scss +49 -52
  473. package/src/styles/06-components/_components.todo.scss +26 -26
  474. package/src/styles/06-components/_components.tooltip.scss +114 -115
  475. package/src/styles/06-components/_components.upload.scss +8 -18
  476. package/src/styles/06-components/_index.scss +48 -48
  477. package/src/styles/99-utilities/_index.scss +18 -18
  478. package/src/styles/99-utilities/_utilities.background.scss +13 -13
  479. package/src/styles/99-utilities/_utilities.border.scss +30 -30
  480. package/src/styles/99-utilities/_utilities.clearfix.scss +1 -1
  481. package/src/styles/99-utilities/_utilities.display.scss +5 -4
  482. package/src/styles/99-utilities/_utilities.flex.scss +19 -19
  483. package/src/styles/99-utilities/_utilities.link.scss +52 -35
  484. package/src/styles/99-utilities/_utilities.object-fit.scss +3 -3
  485. package/src/styles/99-utilities/_utilities.opacity.scss +6 -6
  486. package/src/styles/99-utilities/_utilities.overflow.scss +4 -4
  487. package/src/styles/99-utilities/_utilities.position.scss +8 -8
  488. package/src/styles/99-utilities/_utilities.shadow.scss +13 -13
  489. package/src/styles/99-utilities/_utilities.sizes.scss +17 -17
  490. package/src/styles/99-utilities/_utilities.spacing.scss +72 -37
  491. package/src/styles/99-utilities/_utilities.text.scss +15 -15
  492. package/src/styles/99-utilities/_utilities.visibility.scss +8 -8
  493. package/src/styles/99-utilities/_utilities.visually-hidden.scss +1 -1
  494. package/src/styles/99-utilities/_utilities.z-index.scss +2 -2
  495. package/tsconfig.json +74 -0
  496. package/webpack.config.js +463 -0
  497. package/NPM_PUBLISHING.md +0 -221
  498. package/dist/css/atomix.css.map +0 -1
  499. package/dist/js/194.js.map +0 -1
  500. package/dist/js/atomix.react.esm.js.map +0 -1
  501. package/dist/js/atomix.react.umd.js.map +0 -1
  502. package/dist/js/chunks/esm/202.ff48d27672233280e021.js.map +0 -1
  503. package/dist/js/chunks/esm/308.f873332126eba90e5c62.js.map +0 -1
  504. package/dist/js/chunks/esm/54.4db919e5e4e5cc6d7c72.js.map +0 -1
  505. package/dist/js/chunks/esm/619.afc5a718eff77fa423b5.js.map +0 -1
  506. package/dist/js/chunks/esm/690.a9e968c7497d61e56cdc.js.map +0 -1
  507. package/dist/js/chunks/esm/894.f1091a4a8758c26d29e4.js.map +0 -1
  508. package/dist/js/chunks/esm/897.561a50f7d043d42169da.js.map +0 -1
  509. package/dist/js/chunks/umd/202.dac7605cc555b6bda542.js.map +0 -1
  510. package/dist/js/chunks/umd/308.6709979849dcbdb90c9b.js.map +0 -1
  511. package/dist/js/chunks/umd/54.403470e1f7d0ef4424a7.js.map +0 -1
  512. package/dist/js/chunks/umd/619.fa05ea98c10270eb64c5.js.map +0 -1
  513. package/dist/js/chunks/umd/690.aa7054d1c53e5402c2d6.js.map +0 -1
  514. package/dist/js/chunks/umd/894.3e1eaf0a2aadf4434390.js.map +0 -1
  515. package/dist/js/chunks/umd/897.554ea37be4453698c167.js.map +0 -1
  516. package/dist/types/components/Navbar/Nav.d.ts +0 -5
  517. package/dist/types/components/Navbar/NavItem.d.ts +0 -5
  518. package/dist/types/components/Navbar/Navbar.d.ts +0 -5
  519. package/dist/types/components/Navbar/index.d.ts +0 -6
  520. package/src/components/Navbar/Menu.tsx +0 -122
  521. package/src/components/Navbar/Nav.tsx +0 -35
  522. package/src/components/Navbar/NavDropdown.tsx +0 -108
  523. package/src/components/Navbar/NavItem.tsx +0 -128
  524. package/src/components/Navbar/Navbar.tsx +0 -124
  525. package/src/components/Navbar/index.ts +0 -6
@@ -10,7 +10,7 @@ $utilities-text: (
10
10
  rfs: true,
11
11
  property: font-size,
12
12
  class: u-fs,
13
- values: $font-sizes
13
+ values: $font-sizes,
14
14
  ),
15
15
  'font-style': (
16
16
  property: font-style,
@@ -18,7 +18,7 @@ $utilities-text: (
18
18
  values: (
19
19
  italic: italic,
20
20
  normal: normal,
21
- )
21
+ ),
22
22
  ),
23
23
  'font-weight': (
24
24
  property: font-weight,
@@ -30,8 +30,8 @@ $utilities-text: (
30
30
  semibold: $font-weight-semibold,
31
31
  bold: $font-weight-bold,
32
32
  heavy: $font-weight-heavy,
33
- black: $font-weight-black
34
- )
33
+ black: $font-weight-black,
34
+ ),
35
35
  ),
36
36
  'line-height': (
37
37
  property: line-height,
@@ -40,8 +40,8 @@ $utilities-text: (
40
40
  1: 1,
41
41
  sm: $line-height-sm,
42
42
  base: $line-height-base,
43
- lg: $line-height-lg
44
- )
43
+ lg: $line-height-lg,
44
+ ),
45
45
  ),
46
46
  'text-align': (
47
47
  responsive: true,
@@ -50,38 +50,38 @@ $utilities-text: (
50
50
  values: (
51
51
  start: left,
52
52
  end: right,
53
- center: center
54
- )
53
+ center: center,
54
+ ),
55
55
  ),
56
56
  'text-decoration': (
57
57
  class: u-td,
58
58
  property: text-decoration,
59
- values: none underline line-through
59
+ values: none underline line-through,
60
60
  ),
61
61
  'text-transform': (
62
62
  property: text-transform,
63
63
  class: u-text,
64
- values: lowercase uppercase capitalize
64
+ values: lowercase uppercase capitalize,
65
65
  ),
66
66
  'white-space': (
67
67
  property: white-space,
68
68
  class: u-text,
69
69
  values: (
70
70
  wrap: normal,
71
- nowrap: nowrap
72
- )
71
+ nowrap: nowrap,
72
+ ),
73
73
  ),
74
74
  'word-wrap': (
75
75
  property: word-wrap word-break,
76
76
  class: u-text,
77
77
  values: (
78
- break: break-word
78
+ break: break-word,
79
79
  ),
80
- rtl: false
80
+ rtl: false,
81
81
  ),
82
82
  'color': (
83
83
  property: color,
84
84
  class: u-text,
85
- values: color-maps.$utilities-text-colors
85
+ values: color-maps.$utilities-text-colors,
86
86
  ),
87
87
  );
@@ -2,12 +2,12 @@
2
2
 
3
3
  // Define utilities for visibility
4
4
  $utilities-visibility: (
5
- "visibility": (
6
- property: visibility,
7
- class: null,
8
- values: (
9
- u-visible: visible,
10
- u-invisible: hidden,
11
- )
5
+ 'visibility': (
6
+ property: visibility,
7
+ class: null,
8
+ values: (
9
+ u-visible: visible,
10
+ u-invisible: hidden,
12
11
  ),
13
- );
12
+ ),
13
+ );
@@ -2,4 +2,4 @@
2
2
 
3
3
  .u-visually-hidden {
4
4
  @include visually-hidden;
5
- }
5
+ }
@@ -6,6 +6,6 @@ $utilities-z-index: (
6
6
  'z-index': (
7
7
  property: z-index,
8
8
  class: u-z,
9
- values: $z-layers
10
- )
9
+ values: $z-layers,
10
+ ),
11
11
  );
package/tsconfig.json ADDED
@@ -0,0 +1,74 @@
1
+ {
2
+ "compilerOptions": {
3
+ // Target and Module Configuration
4
+ "target": "ES2020",
5
+ "module": "ESNext",
6
+ "lib": ["DOM", "DOM.Iterable", "ESNext"],
7
+ "moduleResolution": "node",
8
+ "isolatedModules": true,
9
+ "baseUrl": ".",
10
+ "paths": {
11
+ "@shohojdhara/atomix": ["./src/index.ts"],
12
+ "@/*": ["./src/*"]
13
+ },
14
+
15
+ // Strict Type Checking
16
+ "strict": true,
17
+ "noImplicitAny": true,
18
+ "strictNullChecks": false, // Temporarily disabled to fix build
19
+ "strictFunctionTypes": true,
20
+ "strictBindCallApply": true,
21
+ "strictPropertyInitialization": false, // Temporarily disabled to fix build
22
+ "noImplicitThis": true,
23
+ "useUnknownInCatchVariables": true,
24
+ "alwaysStrict": true,
25
+
26
+ // Additional Checks
27
+ "noUnusedLocals": false, // Temporarily disabled to fix build
28
+ "noUnusedParameters": false, // Temporarily disabled to fix build
29
+ "noImplicitReturns": true,
30
+ "noFallthroughCasesInSwitch": true,
31
+ "noUncheckedIndexedAccess": false, // Temporarily disabled to fix build
32
+
33
+ // Module Resolution and Imports
34
+ "esModuleInterop": true,
35
+ "allowSyntheticDefaultImports": true,
36
+ "resolveJsonModule": true,
37
+ "forceConsistentCasingInFileNames": true,
38
+ "skipLibCheck": true,
39
+
40
+ // JSX and React
41
+ "jsx": "react-jsx",
42
+
43
+ // Output Configuration
44
+ "declaration": true,
45
+ "declarationDir": "./dist/types",
46
+ "emitDeclarationOnly": true,
47
+ "sourceMap": true,
48
+ "outDir": "./dist",
49
+
50
+ // Type Definitions
51
+ "typeRoots": [
52
+ "./node_modules/@types",
53
+ "./src/types"
54
+ ]
55
+ },
56
+ "include": [
57
+ "src/components/**/*.tsx",
58
+ "src/components/**/index.ts",
59
+ "src/layouts/**/*.tsx",
60
+ "src/layouts/**/index.ts",
61
+ "src/lib/**/*.ts",
62
+ "src/index.ts"
63
+ ],
64
+ "exclude": [
65
+ "node_modules",
66
+ "dist",
67
+ "**/*.stories.tsx",
68
+ "**/*.stories.ts",
69
+ "**/*.test.ts",
70
+ "**/*.test.tsx",
71
+ "**/scripts/**",
72
+ "src/htmlComponentsEntry.ts"
73
+ ]
74
+ }
@@ -0,0 +1,463 @@
1
+ const path = require('path');
2
+ const MiniCssExtractPlugin = require('mini-css-extract-plugin');
3
+ const TerserPlugin = require('terser-webpack-plugin');
4
+ const CssMinimizerPlugin = require('css-minimizer-webpack-plugin');
5
+ const nodeExternals = require('webpack-node-externals');
6
+ const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer');
7
+ const { CleanWebpackPlugin } = require('clean-webpack-plugin');
8
+
9
+ // Version for output filenames
10
+ const version = require('./package.json').version;
11
+
12
+ // Shared rules for all builds
13
+ const sharedRules = [
14
+ {
15
+ test: /\.(ts|tsx)$/,
16
+ exclude: [/node_modules/, /\.d\.ts$/],
17
+ use: {
18
+ loader: 'babel-loader',
19
+ options: {
20
+ cacheDirectory: true, // Enable caching for faster builds
21
+ presets: [
22
+ ['@babel/preset-env', {
23
+ modules: false, // Let webpack handle modules
24
+ targets: '> 0.25%, not dead',
25
+ bugfixes: true, // Apply bugfixes for smaller output
26
+ useBuiltIns: 'usage', // Only include polyfills that are used
27
+ corejs: 3 // Use core-js v3
28
+ }],
29
+ ['@babel/preset-react', {
30
+ runtime: 'automatic' // Use new JSX transform
31
+ }],
32
+ ['@babel/preset-typescript', {
33
+ isTSX: true, // Handle TSX files
34
+ allExtensions: true, // Process all extensions
35
+ allowDeclareFields: true // Allow declare fields
36
+ }]
37
+ ],
38
+ },
39
+ },
40
+ },
41
+ {
42
+ test: /\.(woff|woff2|eot|ttf|otf)$/i,
43
+ type: 'asset',
44
+ parser: {
45
+ dataUrlCondition: {
46
+ maxSize: 8 * 1024 // 8kb - inline if smaller than this
47
+ }
48
+ },
49
+ generator: {
50
+ filename: 'fonts/[name].[contenthash][ext]'
51
+ }
52
+ },
53
+ {
54
+ test: /\.(png|jpg|jpeg|gif)$/i,
55
+ type: 'asset',
56
+ parser: {
57
+ dataUrlCondition: {
58
+ maxSize: 4 * 1024 // 4kb - inline if smaller than this
59
+ }
60
+ },
61
+ generator: {
62
+ filename: 'images/[name].[contenthash][ext]'
63
+ }
64
+ },
65
+ {
66
+ test: /\.svg$/i,
67
+ type: 'asset',
68
+ parser: {
69
+ dataUrlCondition: {
70
+ maxSize: 4 * 1024 // 4kb - inline if smaller than this
71
+ }
72
+ },
73
+ generator: {
74
+ filename: 'images/[name].[contenthash][ext]'
75
+ }
76
+ }
77
+ ];
78
+
79
+ // Base webpack configuration
80
+ const baseConfig = {
81
+ mode: 'production',
82
+ devtool: false, // Disable source maps for production builds
83
+ module: {
84
+ rules: sharedRules,
85
+ },
86
+ resolve: {
87
+ symlinks: true,
88
+ extensions: ['.ts', '.tsx', '.js', '.jsx', '.json'],
89
+ alias: {
90
+ '@': path.resolve(__dirname, 'src'),
91
+ },
92
+ // Prefer ESM modules when available
93
+ mainFields: ['module', 'main'],
94
+ },
95
+ optimization: {
96
+ minimize: true,
97
+ minimizer: [
98
+ new TerserPlugin({
99
+ extractComments: false,
100
+ parallel: true, // Use multi-process parallel running
101
+ terserOptions: {
102
+ ecma: 2020, // Use ES2020 syntax
103
+ format: {
104
+ comments: false,
105
+ },
106
+ compress: {
107
+ drop_console: true,
108
+ pure_getters: true,
109
+ unsafe: true,
110
+ unsafe_comps: true,
111
+ passes: 2, // Run optimization passes twice
112
+ warnings: false,
113
+ },
114
+ mangle: {
115
+ safari10: true,
116
+ },
117
+ },
118
+ }),
119
+ new CssMinimizerPlugin({
120
+ minimizerOptions: {
121
+ preset: [
122
+ 'default',
123
+ {
124
+ discardComments: { removeAll: true },
125
+ normalizeWhitespace: true,
126
+ },
127
+ ],
128
+ },
129
+ parallel: true, // Use multi-process parallel running
130
+ }),
131
+ ],
132
+ // Enable better tree shaking
133
+ usedExports: true,
134
+ sideEffects: false,
135
+ // Split chunks for better caching
136
+ splitChunks: {
137
+ chunks: 'all',
138
+ maxInitialRequests: Infinity,
139
+ minSize: 0,
140
+ cacheGroups: {
141
+ vendors: {
142
+ test: /[\\]node_modules[\\]/,
143
+ name(module) {
144
+ // Get the name of the npm package
145
+ const packageName = module.context.match(/[\\]node_modules[\\](.+?)([\\]|$)/)[1];
146
+ return `npm.${packageName.replace('@', '')}`;
147
+ },
148
+ },
149
+ },
150
+ },
151
+ },
152
+ performance: {
153
+ hints: 'warning',
154
+ maxAssetSize: 100000, // 100kb
155
+ maxEntrypointSize: 250000, // 250kb
156
+ },
157
+ stats: {
158
+ assets: true,
159
+ colors: true,
160
+ errors: true,
161
+ errorDetails: true,
162
+ modules: false,
163
+ performance: true,
164
+ hash: false,
165
+ },
166
+ };
167
+
168
+ // Create configuration based on environment variables
169
+ module.exports = (env = {}) => {
170
+ const target = env.target || 'components';
171
+ const format = env.format || 'all';
172
+ const analyze = env.analyze === 'true' || env.analyze === true;
173
+
174
+ // CSS/Styles build configuration
175
+ if (target === 'styles') {
176
+ return {
177
+ ...baseConfig,
178
+ name: 'styles',
179
+ entry: {
180
+ 'main': './src/styles/index.scss',
181
+ 'minified': './src/styles/index.scss',
182
+ },
183
+ output: {
184
+ path: path.resolve(__dirname, 'dist'),
185
+ filename: 'js/[name].js', // Not used but required
186
+ assetModuleFilename: 'assets/[name].[contenthash][ext]',
187
+ clean: true, // Clean dist folder
188
+ chunkFormat: 'array-push', // Specify chunk format to fix the error
189
+ },
190
+ module: {
191
+ rules: [
192
+ {
193
+ test: /\.(scss|css)$/,
194
+ use: [
195
+ MiniCssExtractPlugin.loader,
196
+ {
197
+ loader: 'css-loader',
198
+ options: {
199
+ sourceMap: false, // Disable source maps for production
200
+ importLoaders: 2,
201
+ modules: {
202
+ auto: true, // Enable CSS modules for .module.scss files
203
+ localIdentName: '[local]--[hash:base64:5]', // Format for CSS module class names
204
+ },
205
+ },
206
+ },
207
+ {
208
+ loader: 'postcss-loader',
209
+ options: {
210
+ sourceMap: false, // Disable source maps for production
211
+ postcssOptions: {
212
+ plugins: [
213
+ 'autoprefixer',
214
+ ['cssnano', {
215
+ preset: ['default', { discardComments: { removeAll: true } }]
216
+ }],
217
+ ],
218
+ },
219
+ },
220
+ },
221
+ {
222
+ loader: 'sass-loader',
223
+ options: {
224
+ sourceMap: false, // Disable source maps for production
225
+ implementation: require('sass-embedded'),
226
+ sassOptions: {
227
+ outputStyle: 'expanded', // Let cssnano handle minification
228
+ precision: 8, // Precision for calculations
229
+ },
230
+ },
231
+ },
232
+ ],
233
+ },
234
+ ...sharedRules,
235
+ ],
236
+ },
237
+ plugins: [
238
+ new CleanWebpackPlugin(),
239
+ new MiniCssExtractPlugin({
240
+ filename: (pathData) => {
241
+ return pathData.chunk.name === 'minified'
242
+ ? `css/atomix.min.css`
243
+ : `css/atomix.css`;
244
+ },
245
+ }),
246
+ ...(analyze ? [new BundleAnalyzerPlugin({
247
+ analyzerMode: 'static',
248
+ reportFilename: 'reports/styles.html',
249
+ openAnalyzer: false,
250
+ })] : []),
251
+ ],
252
+ };
253
+ }
254
+
255
+ // Component builds (React only)
256
+ const configs = [];
257
+
258
+ // ESM build - Modern bundlers and tree-shaking
259
+ if (format === 'all' || format === 'esm') {
260
+ configs.push({
261
+ ...baseConfig,
262
+ name: 'react-esm',
263
+ entry: {
264
+ 'atomix.react.esm': './src/index.ts'
265
+ },
266
+ output: {
267
+ path: path.resolve(__dirname, 'dist'),
268
+ filename: `js/[name].js`,
269
+ library: {
270
+ type: 'module',
271
+ },
272
+ environment: {
273
+ module: true,
274
+ arrowFunction: true,
275
+ const: true,
276
+ destructuring: true,
277
+ dynamicImport: true, // Support dynamic imports
278
+ },
279
+ assetModuleFilename: 'assets/[name].[contenthash][ext]',
280
+ clean: false, // Don't clean on individual builds
281
+ chunkFilename: 'js/chunks/esm/[name].[contenthash].js', // Named chunks for better caching with unique path
282
+ },
283
+ experiments: {
284
+ outputModule: true,
285
+ },
286
+ externals: [
287
+ // More specific externals for better control
288
+ {
289
+ 'react': 'react',
290
+ 'react-dom': 'react-dom',
291
+ 'react-router-dom': 'react-router-dom',
292
+ 'classnames': 'classnames',
293
+ 'phosphor-react': 'phosphor-react',
294
+ 'prism-react-renderer': 'prism-react-renderer',
295
+ // Next.js specific externals
296
+ 'next': 'next',
297
+ 'next/router': 'next/router',
298
+ 'next/head': 'next/head',
299
+ 'next/image': 'next/image',
300
+ 'next/link': 'next/link',
301
+ },
302
+ // Exclude CSS/SCSS/TypeScript declaration files
303
+ /\.(scss|css|d\.ts)$/,
304
+ ],
305
+ plugins: [
306
+ // Clean the dist directory only on the first build, but preserve CSS files
307
+ format === 'all' ? new CleanWebpackPlugin({
308
+ cleanOnceBeforeBuildPatterns: ['**/*', '!css/**', '!fonts/**']
309
+ }) : null,
310
+ ...(analyze ? [new BundleAnalyzerPlugin({
311
+ analyzerMode: 'static',
312
+ reportFilename: 'reports/react-esm.html',
313
+ openAnalyzer: false,
314
+ })] : []),
315
+ ].filter(Boolean), // Filter out null values
316
+ });
317
+ }
318
+
319
+ // CommonJS build - Node.js compatibility
320
+ if (format === 'all' || format === 'cjs') {
321
+ configs.push({
322
+ ...baseConfig,
323
+ name: 'react-cjs',
324
+ entry: {
325
+ 'atomix.react.cjs': './src/index.ts'
326
+ },
327
+ output: {
328
+ path: path.resolve(__dirname, 'dist'),
329
+ filename: `js/[name].js`,
330
+ library: {
331
+ type: 'commonjs2',
332
+ },
333
+ assetModuleFilename: 'assets/[name].[contenthash][ext]',
334
+ clean: false,
335
+ chunkFilename: 'js/chunks/cjs/[name].[contenthash].js', // Named chunks for better caching with unique path
336
+ },
337
+ externals: [
338
+ {
339
+ 'react': 'react',
340
+ 'react-dom': 'react-dom',
341
+ 'react-router-dom': 'react-router-dom',
342
+ 'classnames': 'classnames',
343
+ 'phosphor-react': 'phosphor-react',
344
+ 'prism-react-renderer': 'prism-react-renderer',
345
+ // Next.js specific externals
346
+ 'next': 'next',
347
+ 'next/router': 'next/router',
348
+ 'next/head': 'next/head',
349
+ 'next/image': 'next/image',
350
+ 'next/link': 'next/link',
351
+ },
352
+ /\.(scss|css|d\.ts)$/,
353
+ ],
354
+ plugins: analyze ? [new BundleAnalyzerPlugin({
355
+ analyzerMode: 'static',
356
+ reportFilename: 'reports/react-cjs.html',
357
+ openAnalyzer: false,
358
+ })] : [],
359
+ // Optimize for Node.js environment
360
+ target: 'node',
361
+ node: {
362
+ __dirname: false,
363
+ __filename: false,
364
+ },
365
+ });
366
+ }
367
+
368
+ // UMD build - Browser compatibility
369
+ if (format === 'all' || format === 'umd') {
370
+ configs.push({
371
+ ...baseConfig,
372
+ name: 'react-umd',
373
+ entry: {
374
+ 'atomix.react.umd': './src/index.ts'
375
+ },
376
+ output: {
377
+ path: path.resolve(__dirname, 'dist'),
378
+ filename: `js/[name].js`,
379
+ library: {
380
+ name: 'Atomix',
381
+ type: 'umd',
382
+ umdNamedDefine: true,
383
+ },
384
+ globalObject: 'this',
385
+ assetModuleFilename: 'assets/[name].[contenthash][ext]',
386
+ clean: false,
387
+ chunkFilename: 'js/chunks/umd/[name].[contenthash].js', // Named chunks for better caching with unique path
388
+ },
389
+ // Optimize for browser environment
390
+ target: 'web',
391
+ externals: {
392
+ react: {
393
+ root: 'React',
394
+ commonjs2: 'react',
395
+ commonjs: 'react',
396
+ amd: 'react',
397
+ },
398
+ 'react-dom': {
399
+ root: 'ReactDOM',
400
+ commonjs2: 'react-dom',
401
+ commonjs: 'react-dom',
402
+ amd: 'react-dom',
403
+ },
404
+ 'react-router-dom': {
405
+ root: 'ReactRouterDOM',
406
+ commonjs2: 'react-router-dom',
407
+ commonjs: 'react-router-dom',
408
+ amd: 'react-router-dom',
409
+ },
410
+ 'classnames': {
411
+ root: 'classNames',
412
+ commonjs2: 'classnames',
413
+ commonjs: 'classnames',
414
+ amd: 'classnames',
415
+ },
416
+ 'phosphor-react': {
417
+ root: 'PhosphorReact',
418
+ commonjs2: 'phosphor-react',
419
+ commonjs: 'phosphor-react',
420
+ amd: 'phosphor-react',
421
+ },
422
+ // Next.js externals for UMD build
423
+ 'next': {
424
+ root: 'Next',
425
+ commonjs2: 'next',
426
+ commonjs: 'next',
427
+ amd: 'next',
428
+ },
429
+ 'next/router': {
430
+ root: 'NextRouter',
431
+ commonjs2: 'next/router',
432
+ commonjs: 'next/router',
433
+ amd: 'next/router',
434
+ },
435
+ 'next/head': {
436
+ root: 'NextHead',
437
+ commonjs2: 'next/head',
438
+ commonjs: 'next/head',
439
+ amd: 'next/head',
440
+ },
441
+ 'next/image': {
442
+ root: 'NextImage',
443
+ commonjs2: 'next/image',
444
+ commonjs: 'next/image',
445
+ amd: 'next/image',
446
+ },
447
+ 'next/link': {
448
+ root: 'NextLink',
449
+ commonjs2: 'next/link',
450
+ commonjs: 'next/link',
451
+ amd: 'next/link',
452
+ },
453
+ },
454
+ plugins: analyze ? [new BundleAnalyzerPlugin({
455
+ analyzerMode: 'static',
456
+ reportFilename: 'reports/react-umd.html',
457
+ openAnalyzer: false,
458
+ })] : [],
459
+ });
460
+ }
461
+
462
+ return configs.length === 1 ? configs[0] : configs;
463
+ };