@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
@@ -8,326 +8,364 @@ import { Icon } from '../Icon/Icon';
8
8
  * DatePicker component for selecting dates from a calendar interface.
9
9
  * Supports various display modes, date ranges, and customization options.
10
10
  */
11
- export const DatePicker = forwardRef<DatePickerRef, DatePickerProps>(({
12
- value,
13
- onChange,
14
- selectionMode = 'single',
15
- startDate,
16
- endDate,
17
- onRangeChange,
18
- format = 'MM/dd/yyyy',
19
- minDate,
20
- maxDate,
21
- placeholder = 'Select date...',
22
- disabled = false,
23
- readOnly = false,
24
- clearable = true,
25
- showTodayButton = true,
26
- showWeekNumbers = false,
27
- inline = false,
28
- id,
29
- name,
30
- className = '',
31
- placement = 'bottom-start',
32
- inputClassName = '',
33
- size = 'md',
34
- ...props
35
- }, ref) => {
36
- const {
37
- // State
38
- isOpen,
39
- inputValue,
40
- rangeInputValue,
41
- viewMode,
42
- currentMonth,
43
- currentYear,
44
- selectionMode: activeSelectionMode,
45
- rangeSelectionState,
46
-
47
- // Refs
48
- datePickerRef,
49
- inputRef,
50
-
51
- // Range state
52
- startDate: rangeStartDate,
53
- endDate: rangeEndDate,
54
-
55
- // Action handlers
56
- setIsOpen,
57
- handleDateSelect,
58
- handlePrevMonth,
59
- handleNextMonth,
60
- handlePrevYear,
61
- handleNextYear,
62
- handleTodayClick,
63
- handleClear,
64
- handleInputChange,
65
- handleInputFocus,
66
-
67
- // View mode handlers
68
- switchToMonthView,
69
- switchToYearView,
70
- selectMonth,
71
- selectYear,
72
-
73
- // Data generators
74
- generateDays,
75
- generateMonths,
76
- generateYears,
77
-
78
- // State checkers
79
- isDateSelectable,
80
- isDateSelected,
81
- isDateInSelectedRange,
82
- isToday,
83
- getWeekNumber,
84
- } = useDatePicker({
85
- value,
86
- onChange,
87
- selectionMode,
88
- startDate,
89
- endDate,
90
- onRangeChange,
91
- format,
92
- minDate,
93
- maxDate,
94
- inline
95
- });
96
-
97
- // Expose the ref API
98
- useImperativeHandle(ref, () => ({
99
- open: () => setIsOpen(true),
100
- close: () => setIsOpen(false),
101
- clear: handleClear,
102
- focus: () => inputRef.current?.focus()
103
- }));
104
-
105
- // Prepare class names
106
- const datepickerClassName = `c-datepicker ${className} ${inline ? 'c-datepicker--inline' : ''}`.trim();
107
- const inputClasses = `c-datepicker__input c-input c-input--${size} ${inputClassName}`.trim();
108
-
109
- // Create unique ID for accessibility
110
- const datepickerId = id || `datepicker-${Math.random().toString(36).substring(2, 9)}`;
111
- const calendarId = `${datepickerId}-calendar`;
112
-
113
- // Get the appropriate input value based on selection mode
114
- const displayValue = selectionMode === 'single' ? inputValue : rangeInputValue;
115
-
116
- // Helper function to get placeholder based on selection mode
117
- const getPlaceholder = () => {
118
- if (selectionMode === 'single') {
119
- return placeholder;
120
- } else {
121
- return rangeSelectionState === 'start'
122
- ? 'Select start date...'
123
- : (rangeStartDate ? `${formatDate(rangeStartDate, format)} - Select end date...` : 'Select date range...');
124
- }
125
- };
126
-
127
- return (
128
- <div className={datepickerClassName} ref={datePickerRef} {...props}>
129
- {!inline && (
130
- <div className="c-datepicker__input-wrapper">
131
- <input
132
- id={datepickerId}
133
- name={name}
134
- ref={inputRef}
135
- type="text"
136
- className={inputClasses}
137
- placeholder={getPlaceholder()}
138
- value={displayValue}
139
- onChange={handleInputChange}
140
- onFocus={handleInputFocus}
141
- disabled={disabled}
142
- readOnly={readOnly}
143
- aria-haspopup="dialog"
144
- aria-expanded={isOpen}
145
- aria-controls={calendarId}
146
- />
147
- {clearable && displayValue && (
148
- <button
149
- type="button"
150
- className="c-datepicker__clear-button"
151
- onClick={handleClear}
152
- aria-label="Clear date"
153
- >
154
- <Icon name="X" size="sm" />
155
- </button>
156
- )}
157
- <span className="c-datepicker__calendar-icon" aria-hidden="true">
158
- <Icon name="Calendar" size="sm" color="var(--atomix-secondary-text-emphasis)" />
159
- </span>
160
- </div>
161
- )}
162
-
163
- {(isOpen || inline) && (
164
- <div
165
- id={calendarId}
166
- className={`c-datepicker__calendar c-datepicker__calendar--${placement}`}
167
- role="dialog"
168
- aria-modal={!inline ? "true" : undefined}
169
- aria-label="Date picker"
170
- >
171
-
172
-
173
- <div className="c-datepicker__header">
174
- {viewMode === 'days' && (
175
- <>
176
- <button
177
- type="button"
178
- className="c-datepicker__nav-button c-datepicker__nav-button--prev-year"
179
- onClick={handlePrevYear}
180
- aria-label="Previous year"
181
- >
182
- <Icon name="CaretDoubleLeft" size="sm" />
183
- </button>
184
- <button
185
- type="button"
186
- className="c-datepicker__nav-button c-datepicker__nav-button--prev-month"
187
- onClick={handlePrevMonth}
188
- aria-label="Previous month"
189
- >
190
- <Icon name="CaretLeft" size="sm" />
191
- </button>
192
- <button
193
- type="button"
194
- className="c-datepicker__view-switch"
195
- onClick={switchToMonthView}
196
- aria-label="Switch to month view"
197
- >
198
- {`${currentMonth + 1}/${currentYear}`}
199
- </button>
200
- <button
201
- type="button"
202
- className="c-datepicker__nav-button c-datepicker__nav-button--next-month"
203
- onClick={handleNextMonth}
204
- aria-label="Next month"
205
- >
206
- <Icon name="CaretRight" size="sm" />
207
- </button>
208
- <button
209
- type="button"
210
- className="c-datepicker__nav-button c-datepicker__nav-button--next-year"
211
- onClick={handleNextYear}
212
- aria-label="Next year"
213
- >
214
- <Icon name="CaretDoubleRight" size="sm" />
215
- </button>
216
- </>
217
- )}
218
-
219
- {viewMode === 'months' && (
220
- <>
221
- <button
222
- type="button"
223
- className="c-datepicker__nav-button c-datepicker__nav-button--prev-year"
224
- onClick={handlePrevYear}
225
- aria-label="Previous year"
226
- >
227
- <Icon name="CaretLeft" size="sm" />
228
- </button>
229
- <button
230
- type="button"
231
- className="c-datepicker__view-switch"
232
- onClick={switchToYearView}
233
- aria-label="Switch to year view"
234
- >
235
- {currentYear}
236
- </button>
237
- <button
238
- type="button"
239
- className="c-datepicker__nav-button c-datepicker__nav-button--next-year"
240
- onClick={handleNextYear}
241
- aria-label="Next year"
242
- >
243
- <Icon name="CaretRight" size="sm" />
244
- </button>
245
- </>
246
- )}
247
-
248
- {viewMode === 'years' && (
249
- <>
250
- <button
251
- type="button"
252
- className="c-datepicker__nav-button c-datepicker__nav-button--prev-year"
253
- onClick={() => handlePrevYear()}
254
- aria-label="Previous year range"
255
- >
256
- <Icon name="CaretLeft" size="sm" />
257
- </button>
258
- <button
259
- type="button"
260
- className="c-datepicker__view-switch"
261
- aria-label="Current year range"
262
- >
263
- {currentYear - 6} - {currentYear + 5}
264
- </button>
265
- <button
266
- type="button"
267
- className="c-datepicker__nav-button c-datepicker__nav-button--next-year"
268
- onClick={() => handleNextYear()}
269
- aria-label="Next year range"
270
- >
271
- <Icon name="CaretRight" size="sm" />
272
- </button>
273
- </>
11
+ export const DatePicker = forwardRef<DatePickerRef, DatePickerProps>(
12
+ (
13
+ {
14
+ value,
15
+ onChange,
16
+ selectionMode = 'single',
17
+ startDate,
18
+ endDate,
19
+ onRangeChange,
20
+ format = 'MM/dd/yyyy',
21
+ minDate,
22
+ maxDate,
23
+ placeholder = 'Select date...',
24
+ disabled = false,
25
+ readOnly = false,
26
+ clearable = true,
27
+ showTodayButton = true,
28
+ showWeekNumbers = false,
29
+ inline = false,
30
+ id,
31
+ name,
32
+ className = '',
33
+ placement = 'bottom-start',
34
+ inputClassName = '',
35
+ size = 'md',
36
+ ...props
37
+ },
38
+ ref
39
+ ) => {
40
+ const {
41
+ // State
42
+ isOpen,
43
+ inputValue,
44
+ rangeInputValue,
45
+ viewMode,
46
+ currentMonth,
47
+ currentYear,
48
+ selectionMode: activeSelectionMode,
49
+ rangeSelectionState,
50
+
51
+ // Refs
52
+ datePickerRef,
53
+ inputRef,
54
+
55
+ // Range state
56
+ startDate: rangeStartDate,
57
+ endDate: rangeEndDate,
58
+
59
+ // Action handlers
60
+ setIsOpen,
61
+ handleDateSelect,
62
+ handlePrevMonth,
63
+ handleNextMonth,
64
+ handlePrevYear,
65
+ handleNextYear,
66
+ handleTodayClick,
67
+ handleClear,
68
+ handleInputChange,
69
+ handleInputFocus,
70
+
71
+ // View mode handlers
72
+ switchToMonthView,
73
+ switchToYearView,
74
+ selectMonth,
75
+ selectYear,
76
+
77
+ // Data generators
78
+ generateDays,
79
+ generateMonths,
80
+ generateYears,
81
+
82
+ // State checkers
83
+ isDateSelectable,
84
+ isDateSelected,
85
+ isDateInSelectedRange,
86
+ isToday,
87
+ getWeekNumber,
88
+ } = useDatePicker({
89
+ value,
90
+ onChange,
91
+ selectionMode,
92
+ startDate,
93
+ endDate,
94
+ onRangeChange,
95
+ format,
96
+ minDate,
97
+ maxDate,
98
+ inline,
99
+ });
100
+
101
+ // Expose the ref API
102
+ useImperativeHandle(ref, () => ({
103
+ open: () => setIsOpen(true),
104
+ close: () => setIsOpen(false),
105
+ clear: handleClear,
106
+ focus: () => inputRef.current?.focus(),
107
+ }));
108
+
109
+ // Prepare class names
110
+ const datepickerClassName =
111
+ `c-datepicker ${className} ${inline ? 'c-datepicker--inline' : ''}`.trim();
112
+ const inputClasses = `c-datepicker__input c-input c-input--${size} ${inputClassName}`.trim();
113
+
114
+ // Create unique ID for accessibility
115
+ const datepickerId = id || `datepicker-${Math.random().toString(36).substring(2, 9)}`;
116
+ const calendarId = `${datepickerId}-calendar`;
117
+
118
+ // Get the appropriate input value based on selection mode
119
+ const displayValue = selectionMode === 'single' ? inputValue : rangeInputValue;
120
+
121
+ // Helper function to get placeholder based on selection mode
122
+ const getPlaceholder = () => {
123
+ if (selectionMode === 'single') {
124
+ return placeholder;
125
+ } else {
126
+ return rangeSelectionState === 'start'
127
+ ? 'Select start date...'
128
+ : rangeStartDate
129
+ ? `${formatDate(rangeStartDate, format)} - Select end date...`
130
+ : 'Select date range...';
131
+ }
132
+ };
133
+
134
+ return (
135
+ <div className={datepickerClassName} ref={datePickerRef} {...props}>
136
+ {!inline && (
137
+ <div className="c-datepicker__input-wrapper">
138
+ <input
139
+ id={datepickerId}
140
+ name={name}
141
+ ref={inputRef}
142
+ type="text"
143
+ className={inputClasses}
144
+ placeholder={getPlaceholder()}
145
+ value={displayValue}
146
+ onChange={handleInputChange}
147
+ onFocus={handleInputFocus}
148
+ disabled={disabled}
149
+ readOnly={readOnly}
150
+ aria-haspopup="dialog"
151
+ aria-expanded={isOpen}
152
+ aria-controls={calendarId}
153
+ />
154
+ {clearable && displayValue && (
155
+ <button
156
+ type="button"
157
+ className="c-datepicker__clear-button"
158
+ onClick={handleClear}
159
+ aria-label="Clear date"
160
+ >
161
+ <Icon name="X" size="sm" />
162
+ </button>
274
163
  )}
164
+ <span className="c-datepicker__calendar-icon" aria-hidden="true">
165
+ <Icon name="Calendar" size="sm" color="var(--atomix-secondary-text-emphasis)" />
166
+ </span>
275
167
  </div>
276
-
277
- <div className="c-datepicker__body">
278
- {viewMode === 'days' && (
279
- <>
280
- <div className="c-datepicker__weekdays" role="row">
281
- {showWeekNumbers && <div className="c-datepicker__weekday c-datepicker__weeknumber" role="columnheader">#</div>}
282
- <div className="c-datepicker__weekday" role="columnheader">Su</div>
283
- <div className="c-datepicker__weekday" role="columnheader">Mo</div>
284
- <div className="c-datepicker__weekday" role="columnheader">Tu</div>
285
- <div className="c-datepicker__weekday" role="columnheader">We</div>
286
- <div className="c-datepicker__weekday" role="columnheader">Th</div>
287
- <div className="c-datepicker__weekday" role="columnheader">Fr</div>
288
- <div className="c-datepicker__weekday" role="columnheader">Sa</div>
289
- </div>
290
-
291
- <div
292
- className="c-datepicker__days"
293
- role="grid"
294
- aria-labelledby={`${datepickerId}-month-year`}
295
- >
296
- {generateDays().map((dateObj, index) => {
297
- const isSelectable = isDateSelectable(dateObj.year, dateObj.month, dateObj.day);
298
- const isSelected = isDateSelected(dateObj.year, dateObj.month, dateObj.day);
299
- const isTodayDate = isToday(dateObj.year, dateObj.month, dateObj.day);
300
- const dateValue = new Date(dateObj.year, dateObj.month, dateObj.day);
301
-
302
- // Check if date is in range (for range selection)
303
- const isInRange = isDateInSelectedRange(dateObj.year, dateObj.month, dateObj.day);
304
-
305
- // Determine if the day is start or end of range
306
- const isStartOfRange = selectionMode === 'range' && startDate &&
307
- dateObj.day === startDate.getDate() &&
308
- dateObj.month === startDate.getMonth() &&
309
- dateObj.year === startDate.getFullYear();
310
-
311
- const isEndOfRange = selectionMode === 'range' && endDate &&
312
- dateObj.day === endDate.getDate() &&
313
- dateObj.month === endDate.getMonth() &&
314
- dateObj.year === endDate.getFullYear();
315
-
316
- // Add week number if enabled
317
- if (showWeekNumbers && index % 7 === 0) {
318
- const weekNum = getWeekNumber(dateValue);
319
-
320
- return (
321
- <React.Fragment key={`week-${index}`}>
322
- <div
323
- className="c-datepicker__weeknumber"
324
- aria-label={`Week ${weekNum}`}
325
- >
326
- {weekNum}
327
- </div>
328
- <button
329
- type="button"
330
- className={`c-datepicker__day
168
+ )}
169
+
170
+ {(isOpen || inline) && (
171
+ <div
172
+ id={calendarId}
173
+ className={`c-datepicker__calendar c-datepicker__calendar--${placement}`}
174
+ role="dialog"
175
+ aria-modal={!inline ? 'true' : undefined}
176
+ aria-label="Date picker"
177
+ >
178
+ <div className="c-datepicker__header">
179
+ {viewMode === 'days' && (
180
+ <>
181
+ <button
182
+ type="button"
183
+ className="c-datepicker__nav-button c-datepicker__nav-button--prev-year"
184
+ onClick={handlePrevYear}
185
+ aria-label="Previous year"
186
+ >
187
+ <Icon name="CaretDoubleLeft" size="sm" />
188
+ </button>
189
+ <button
190
+ type="button"
191
+ className="c-datepicker__nav-button c-datepicker__nav-button--prev-month"
192
+ onClick={handlePrevMonth}
193
+ aria-label="Previous month"
194
+ >
195
+ <Icon name="CaretLeft" size="sm" />
196
+ </button>
197
+ <button
198
+ type="button"
199
+ className="c-datepicker__view-switch"
200
+ onClick={switchToMonthView}
201
+ aria-label="Switch to month view"
202
+ >
203
+ {`${currentMonth + 1}/${currentYear}`}
204
+ </button>
205
+ <button
206
+ type="button"
207
+ className="c-datepicker__nav-button c-datepicker__nav-button--next-month"
208
+ onClick={handleNextMonth}
209
+ aria-label="Next month"
210
+ >
211
+ <Icon name="CaretRight" size="sm" />
212
+ </button>
213
+ <button
214
+ type="button"
215
+ className="c-datepicker__nav-button c-datepicker__nav-button--next-year"
216
+ onClick={handleNextYear}
217
+ aria-label="Next year"
218
+ >
219
+ <Icon name="CaretDoubleRight" size="sm" />
220
+ </button>
221
+ </>
222
+ )}
223
+
224
+ {viewMode === 'months' && (
225
+ <>
226
+ <button
227
+ type="button"
228
+ className="c-datepicker__nav-button c-datepicker__nav-button--prev-year"
229
+ onClick={handlePrevYear}
230
+ aria-label="Previous year"
231
+ >
232
+ <Icon name="CaretLeft" size="sm" />
233
+ </button>
234
+ <button
235
+ type="button"
236
+ className="c-datepicker__view-switch"
237
+ onClick={switchToYearView}
238
+ aria-label="Switch to year view"
239
+ >
240
+ {currentYear}
241
+ </button>
242
+ <button
243
+ type="button"
244
+ className="c-datepicker__nav-button c-datepicker__nav-button--next-year"
245
+ onClick={handleNextYear}
246
+ aria-label="Next year"
247
+ >
248
+ <Icon name="CaretRight" size="sm" />
249
+ </button>
250
+ </>
251
+ )}
252
+
253
+ {viewMode === 'years' && (
254
+ <>
255
+ <button
256
+ type="button"
257
+ className="c-datepicker__nav-button c-datepicker__nav-button--prev-year"
258
+ onClick={() => handlePrevYear()}
259
+ aria-label="Previous year range"
260
+ >
261
+ <Icon name="CaretLeft" size="sm" />
262
+ </button>
263
+ <button
264
+ type="button"
265
+ className="c-datepicker__view-switch"
266
+ aria-label="Current year range"
267
+ >
268
+ {currentYear - 6} - {currentYear + 5}
269
+ </button>
270
+ <button
271
+ type="button"
272
+ className="c-datepicker__nav-button c-datepicker__nav-button--next-year"
273
+ onClick={() => handleNextYear()}
274
+ aria-label="Next year range"
275
+ >
276
+ <Icon name="CaretRight" size="sm" />
277
+ </button>
278
+ </>
279
+ )}
280
+ </div>
281
+
282
+ <div className="c-datepicker__body">
283
+ {viewMode === 'days' && (
284
+ <>
285
+ <div className="c-datepicker__weekdays" role="row">
286
+ {showWeekNumbers && (
287
+ <div
288
+ className="c-datepicker__weekday c-datepicker__weeknumber"
289
+ role="columnheader"
290
+ >
291
+ #
292
+ </div>
293
+ )}
294
+ <div className="c-datepicker__weekday" role="columnheader">
295
+ Su
296
+ </div>
297
+ <div className="c-datepicker__weekday" role="columnheader">
298
+ Mo
299
+ </div>
300
+ <div className="c-datepicker__weekday" role="columnheader">
301
+ Tu
302
+ </div>
303
+ <div className="c-datepicker__weekday" role="columnheader">
304
+ We
305
+ </div>
306
+ <div className="c-datepicker__weekday" role="columnheader">
307
+ Th
308
+ </div>
309
+ <div className="c-datepicker__weekday" role="columnheader">
310
+ Fr
311
+ </div>
312
+ <div className="c-datepicker__weekday" role="columnheader">
313
+ Sa
314
+ </div>
315
+ </div>
316
+
317
+ <div
318
+ className="c-datepicker__days"
319
+ role="grid"
320
+ aria-labelledby={`${datepickerId}-month-year`}
321
+ >
322
+ {generateDays().map((dateObj, index) => {
323
+ const isSelectable = isDateSelectable(
324
+ dateObj.year,
325
+ dateObj.month,
326
+ dateObj.day
327
+ );
328
+ const isSelected = isDateSelected(dateObj.year, dateObj.month, dateObj.day);
329
+ const isTodayDate = isToday(dateObj.year, dateObj.month, dateObj.day);
330
+ const dateValue = new Date(dateObj.year, dateObj.month, dateObj.day);
331
+
332
+ // Check if date is in range (for range selection)
333
+ const isInRange = isDateInSelectedRange(
334
+ dateObj.year,
335
+ dateObj.month,
336
+ dateObj.day
337
+ );
338
+
339
+ // Determine if the day is start or end of range
340
+ const isStartOfRange =
341
+ selectionMode === 'range' &&
342
+ startDate &&
343
+ dateObj.day === startDate.getDate() &&
344
+ dateObj.month === startDate.getMonth() &&
345
+ dateObj.year === startDate.getFullYear();
346
+
347
+ const isEndOfRange =
348
+ selectionMode === 'range' &&
349
+ endDate &&
350
+ dateObj.day === endDate.getDate() &&
351
+ dateObj.month === endDate.getMonth() &&
352
+ dateObj.year === endDate.getFullYear();
353
+
354
+ // Add week number if enabled
355
+ if (showWeekNumbers && index % 7 === 0) {
356
+ const weekNum = getWeekNumber(dateValue);
357
+
358
+ return (
359
+ <React.Fragment key={`week-${index}`}>
360
+ <div
361
+ className="c-datepicker__weeknumber"
362
+ aria-label={`Week ${weekNum}`}
363
+ >
364
+ {weekNum}
365
+ </div>
366
+ <button
367
+ type="button"
368
+ className={`c-datepicker__day
331
369
  ${!dateObj.isCurrentMonth ? 'c-datepicker__day--outside' : ''}
332
370
  ${isSelected ? 'c-datepicker__day--selected' : ''}
333
371
  ${isStartOfRange ? 'c-datepicker__day--start-range' : ''}
@@ -335,24 +373,24 @@ export const DatePicker = forwardRef<DatePickerRef, DatePickerProps>(({
335
373
  ${isInRange ? 'c-datepicker__day--in-range' : ''}
336
374
  ${isTodayDate ? 'c-datepicker__day--today' : ''}
337
375
  ${!isSelectable ? 'c-datepicker__day--disabled' : ''}`}
338
- onClick={() => isSelectable && handleDateSelect(dateObj.day)}
339
- disabled={!isSelectable}
340
- tabIndex={dateObj.isCurrentMonth ? 0 : -1}
341
- aria-label={dateValue.toLocaleDateString()}
342
- aria-selected={isSelected ? 'true' : 'false'}
343
- role="gridcell"
344
- >
345
- {dateObj.day}
346
- </button>
347
- </React.Fragment>
348
- );
349
- }
350
-
351
- return (
352
- <button
353
- key={`day-${index}`}
354
- type="button"
355
- className={`c-datepicker__day
376
+ onClick={() => isSelectable && handleDateSelect(dateObj.day)}
377
+ disabled={!isSelectable}
378
+ tabIndex={dateObj.isCurrentMonth ? 0 : -1}
379
+ aria-label={dateValue.toLocaleDateString()}
380
+ aria-selected={isSelected ? 'true' : 'false'}
381
+ role="gridcell"
382
+ >
383
+ {dateObj.day}
384
+ </button>
385
+ </React.Fragment>
386
+ );
387
+ }
388
+
389
+ return (
390
+ <button
391
+ key={`day-${index}`}
392
+ type="button"
393
+ className={`c-datepicker__day
356
394
  ${!dateObj.isCurrentMonth ? 'c-datepicker__day--outside' : ''}
357
395
  ${isSelected ? 'c-datepicker__day--selected' : ''}
358
396
  ${isStartOfRange ? 'c-datepicker__day--start-range' : ''}
@@ -360,103 +398,106 @@ export const DatePicker = forwardRef<DatePickerRef, DatePickerProps>(({
360
398
  ${isInRange ? 'c-datepicker__day--in-range' : ''}
361
399
  ${isTodayDate ? 'c-datepicker__day--today' : ''}
362
400
  ${!isSelectable ? 'c-datepicker__day--disabled' : ''}`}
363
- onClick={() => isSelectable && handleDateSelect(dateObj.day)}
364
- disabled={!isSelectable}
365
- tabIndex={dateObj.isCurrentMonth ? 0 : -1}
366
- aria-label={dateValue.toLocaleDateString()}
401
+ onClick={() => isSelectable && handleDateSelect(dateObj.day)}
402
+ disabled={!isSelectable}
403
+ tabIndex={dateObj.isCurrentMonth ? 0 : -1}
404
+ aria-label={dateValue.toLocaleDateString()}
405
+ aria-selected={isSelected ? 'true' : 'false'}
406
+ role="gridcell"
407
+ >
408
+ {dateObj.day}
409
+ </button>
410
+ );
411
+ })}
412
+ </div>
413
+ </>
414
+ )}
415
+
416
+ {viewMode === 'months' && (
417
+ <div className="c-datepicker__months" role="grid">
418
+ {generateMonths().map((monthObj, index) => {
419
+ const isSelected =
420
+ value &&
421
+ value.getMonth() === monthObj.month &&
422
+ value.getFullYear() === currentYear;
423
+
424
+ return (
425
+ <button
426
+ key={`month-${index}`}
427
+ type="button"
428
+ className={`c-datepicker__month ${isSelected ? 'c-datepicker__month--selected' : ''}`}
429
+ onClick={() => selectMonth(monthObj.month)}
367
430
  aria-selected={isSelected ? 'true' : 'false'}
368
431
  role="gridcell"
369
432
  >
370
- {dateObj.day}
433
+ {monthObj.name.substring(0, 3)}
371
434
  </button>
372
435
  );
373
436
  })}
374
437
  </div>
375
- </>
376
- )}
377
-
378
- {viewMode === 'months' && (
379
- <div className="c-datepicker__months" role="grid">
380
- {generateMonths().map((monthObj, index) => {
381
- const isSelected = value && value.getMonth() === monthObj.month && value.getFullYear() === currentYear;
382
-
383
- return (
384
- <button
385
- key={`month-${index}`}
386
- type="button"
387
- className={`c-datepicker__month ${isSelected ? 'c-datepicker__month--selected' : ''}`}
388
- onClick={() => selectMonth(monthObj.month)}
389
- aria-selected={isSelected ? 'true' : 'false'}
390
- role="gridcell"
391
- >
392
- {monthObj.name.substring(0, 3)}
393
- </button>
394
- );
395
- })}
396
- </div>
397
- )}
398
-
399
- {viewMode === 'years' && (
400
- <div className="c-datepicker__years" role="grid">
401
- {generateYears().map((year, index) => {
402
- const isSelected = value && value.getFullYear() === year;
403
-
404
- return (
405
- <button
406
- key={`year-${index}`}
407
- type="button"
408
- className={`c-datepicker__year ${isSelected ? 'c-datepicker__year--selected' : ''}`}
409
- onClick={() => selectYear(year)}
410
- aria-selected={isSelected ? 'true' : 'false'}
411
- role="gridcell"
412
- >
413
- {year}
414
- </button>
415
- );
416
- })}
417
- </div>
418
- )}
419
- </div>
420
-
421
- {viewMode === 'days' && (
422
- <div className="c-datepicker__footer">
423
- {selectionMode === 'range' && (
424
- <div className="c-datepicker__range-status c-badge c-badge--sm c-badge--info u-w-100">
425
- Selecting {rangeSelectionState === 'start' ? 'start' : 'end'} date
426
- </div>
427
438
  )}
428
439
 
429
- {showTodayButton && (
430
- <button
431
- type="button"
432
- className="c-datepicker__today-button c-btn c-btn--sm c-btn--outline-primary"
433
- onClick={handleTodayClick}
434
- aria-label="Go to today"
435
- >
436
- Today
437
- </button>
438
- )}
439
-
440
- {!inline && (
441
- <button
442
- type="button"
443
- className="c-datepicker__close-button c-btn c-btn--sm c-btn--outline-error"
444
- onClick={() => setIsOpen(false)}
445
- aria-label="Close calendar"
446
- >
447
- Close
448
- </button>
440
+ {viewMode === 'years' && (
441
+ <div className="c-datepicker__years" role="grid">
442
+ {generateYears().map((year, index) => {
443
+ const isSelected = value && value.getFullYear() === year;
444
+
445
+ return (
446
+ <button
447
+ key={`year-${index}`}
448
+ type="button"
449
+ className={`c-datepicker__year ${isSelected ? 'c-datepicker__year--selected' : ''}`}
450
+ onClick={() => selectYear(year)}
451
+ aria-selected={isSelected ? 'true' : 'false'}
452
+ role="gridcell"
453
+ >
454
+ {year}
455
+ </button>
456
+ );
457
+ })}
458
+ </div>
449
459
  )}
450
460
  </div>
451
- )}
452
- </div>
453
- )}
454
- </div>
455
- );
456
- });
457
461
 
458
- DatePicker.displayName = 'DatePicker';
462
+ {viewMode === 'days' && (
463
+ <div className="c-datepicker__footer">
464
+ {selectionMode === 'range' && (
465
+ <div className="c-datepicker__range-status c-badge c-badge--sm c-badge--info u-w-100">
466
+ Selecting {rangeSelectionState === 'start' ? 'start' : 'end'} date
467
+ </div>
468
+ )}
459
469
 
470
+ {showTodayButton && (
471
+ <button
472
+ type="button"
473
+ className="c-datepicker__today-button c-btn c-btn--sm c-btn--outline-primary"
474
+ onClick={handleTodayClick}
475
+ aria-label="Go to today"
476
+ >
477
+ Today
478
+ </button>
479
+ )}
480
+
481
+ {!inline && (
482
+ <button
483
+ type="button"
484
+ className="c-datepicker__close-button c-btn c-btn--sm c-btn--outline-error"
485
+ onClick={() => setIsOpen(false)}
486
+ aria-label="Close calendar"
487
+ >
488
+ Close
489
+ </button>
490
+ )}
491
+ </div>
492
+ )}
493
+ </div>
494
+ )}
495
+ </div>
496
+ );
497
+ }
498
+ );
499
+
500
+ DatePicker.displayName = 'DatePicker';
460
501
 
461
502
  export type { DatePickerProps, DatePickerRef };
462
503