@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
@@ -21,7 +21,9 @@
21
21
  opacity: 0;
22
22
  visibility: hidden;
23
23
  pointer-events: none;
24
- transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
24
+ transition:
25
+ opacity 0.3s ease-in-out,
26
+ visibility 0.3s ease-in-out;
25
27
  z-index: 1000;
26
28
 
27
29
  &__content {
@@ -33,10 +35,8 @@
33
35
  position: relative;
34
36
  display: flex;
35
37
  flex-direction: column;
36
- gap: var(--#{$prefix}popover-inner-gap-y)
37
- var(--#{$prefix}popover-inner-gap-x);
38
- padding: var(--#{$prefix}popover-padding-y)
39
- var(--#{$prefix}popover-padding-x);
38
+ gap: var(--#{$prefix}popover-inner-gap-y) var(--#{$prefix}popover-inner-gap-x);
39
+ padding: var(--#{$prefix}popover-padding-y) var(--#{$prefix}popover-padding-x);
40
40
  background: var(--#{$prefix}popover-bg);
41
41
  border-radius: var(--#{$prefix}popover-border-radius);
42
42
  box-shadow: var(--#{$prefix}popover-box-shadow);
@@ -57,7 +57,7 @@
57
57
  visibility: visible;
58
58
  pointer-events: auto;
59
59
  }
60
-
60
+
61
61
  // Position variants
62
62
  &--top {
63
63
  .c-popover__arrow {
@@ -66,7 +66,7 @@
66
66
  transform: translateX(-50%) rotate(45deg);
67
67
  }
68
68
  }
69
-
69
+
70
70
  &--bottom {
71
71
  .c-popover__arrow {
72
72
  top: calc(var(--#{$prefix}popover-arrow-offset) * -1);
@@ -74,7 +74,7 @@
74
74
  transform: translateX(-50%) rotate(45deg);
75
75
  }
76
76
  }
77
-
77
+
78
78
  &--left {
79
79
  .c-popover__arrow {
80
80
  top: 50%;
@@ -82,7 +82,7 @@
82
82
  transform: translateY(-50%) rotate(45deg);
83
83
  }
84
84
  }
85
-
85
+
86
86
  &--right {
87
87
  .c-popover__arrow {
88
88
  top: 50%;
@@ -90,7 +90,7 @@
90
90
  transform: translateY(-50%) rotate(45deg);
91
91
  }
92
92
  }
93
-
93
+
94
94
  // Auto position automatically selects the best position
95
95
  // and will dynamically apply one of the position classes above
96
96
  &--auto {
@@ -93,7 +93,7 @@
93
93
  color: var(--#{config.$prefix}body-color);
94
94
  font-family: inherit;
95
95
  resize: vertical;
96
-
96
+
97
97
  &:focus {
98
98
  outline: none;
99
99
  border-color: var(--#{config.$prefix}primary);
@@ -109,12 +109,12 @@
109
109
  &__success {
110
110
  text-align: center;
111
111
  padding: var(--#{config.$prefix}product-review-spacing) 0;
112
-
112
+
113
113
  h3 {
114
114
  margin-top: 0;
115
115
  margin-bottom: rem.rem(8px);
116
116
  }
117
-
117
+
118
118
  p {
119
119
  margin-bottom: var(--#{config.$prefix}product-review-spacing);
120
120
  color: var(--#{config.$prefix}text-muted);
@@ -4,43 +4,40 @@
4
4
  @use '../01-settings/settings.progress' as progress;
5
5
  @use '../02-tools/tools.rem' as rem;
6
6
 
7
- .c-progress{
8
-
9
- --#{config.$prefix}progress-width: #{progress.$progress-width};
10
- --#{config.$prefix}progress-percentage: 0%;
11
- --#{config.$prefix}progress-height: #{rem.rem(progress.$progress-height)};
12
- --#{config.$prefix}progress-font-size: #{progress.$progress-font-size};
13
- --#{config.$prefix}progress-bg: #{progress.$progress-bg};
14
- --#{config.$prefix}progress-border-radius: #{progress.$progress-border-radius};
15
- --#{config.$prefix}progress-bar-width: var(--#{config.$prefix}progress-percentage);
16
- --#{config.$prefix}progress-bar-height: #{progress.$progress-bar-height};
17
- --#{config.$prefix}progress-bar-color: #{progress.$progress-bar-color};
18
- --#{config.$prefix}progress-bar-bg: #{progress.$progress-bar-bg};
19
- --#{config.$prefix}progress-bar-transition: #{progress.$progress-bar-transition};
20
- --#{config.$prefix}progress-bar-easing: #{progress.$progress-bar-easing};
21
-
22
- width: 100%;
23
- max-width: var(--#{config.$prefix}progress-width);
7
+ .c-progress {
8
+ --#{config.$prefix}progress-width: #{progress.$progress-width};
9
+ --#{config.$prefix}progress-percentage: 0%;
10
+ --#{config.$prefix}progress-height: #{rem.rem(progress.$progress-height)};
11
+ --#{config.$prefix}progress-font-size: #{progress.$progress-font-size};
12
+ --#{config.$prefix}progress-bg: #{progress.$progress-bg};
13
+ --#{config.$prefix}progress-border-radius: #{progress.$progress-border-radius};
14
+ --#{config.$prefix}progress-bar-width: var(--#{config.$prefix}progress-percentage);
15
+ --#{config.$prefix}progress-bar-height: #{progress.$progress-bar-height};
16
+ --#{config.$prefix}progress-bar-color: #{progress.$progress-bar-color};
17
+ --#{config.$prefix}progress-bar-bg: #{progress.$progress-bar-bg};
18
+ --#{config.$prefix}progress-bar-transition: #{progress.$progress-bar-transition};
19
+ --#{config.$prefix}progress-bar-easing: #{progress.$progress-bar-easing};
20
+
21
+ width: 100%;
22
+ max-width: var(--#{config.$prefix}progress-width);
23
+ height: var(--#{config.$prefix}progress-bar-height);
24
+ background-color: var(--#{config.$prefix}progress-bg);
25
+ border-radius: var(--#{config.$prefix}progress-border-radius);
26
+ overflow: hidden;
27
+
28
+ &__bar {
29
+ width: var(--#{config.$prefix}progress-bar-width);
24
30
  height: var(--#{config.$prefix}progress-bar-height);
25
- background-color: var(--#{config.$prefix}progress-bg);
31
+ color: var(--#{config.$prefix}progress-bar-color);
32
+ background-color: var(--#{config.$prefix}progress-bar-bg);
26
33
  border-radius: var(--#{config.$prefix}progress-border-radius);
27
- overflow: hidden;
28
-
29
- &__bar{
30
- width: var(--#{config.$prefix}progress-bar-width);
31
- height: var(--#{config.$prefix}progress-bar-height);
32
- color: var(--#{config.$prefix}progress-bar-color);
33
- background-color: var(--#{config.$prefix}progress-bar-bg);
34
- border-radius: var(--#{config.$prefix}progress-border-radius);
35
- transition: var(--#{config.$prefix}progress-bar-transition) var(--#{config.$prefix}progress-bar-easing);
36
- }
34
+ transition: var(--#{config.$prefix}progress-bar-transition)
35
+ var(--#{config.$prefix}progress-bar-easing);
36
+ }
37
37
 
38
- @each $color, $value in maps.$theme-colors {
39
- &--#{$color} {
40
- --#{config.$prefix}progress-bar-bg: var(--#{config.$prefix}#{$color});
41
- }
38
+ @each $color, $value in maps.$theme-colors {
39
+ &--#{$color} {
40
+ --#{config.$prefix}progress-bar-bg: var(--#{config.$prefix}#{$color});
42
41
  }
42
+ }
43
43
  }
44
-
45
-
46
-
@@ -30,16 +30,17 @@
30
30
  align-items: center;
31
31
  position: relative;
32
32
 
33
- &[data-readonly="false"] {
33
+ &[data-readonly='false'] {
34
34
  cursor: pointer;
35
35
 
36
36
  #{$root}__star {
37
37
  transition: var(--#{config.$prefix}rating-star-transition);
38
38
 
39
- &:hover, &:focus {
39
+ &:hover,
40
+ &:focus {
40
41
  transform: scale(var(--#{config.$prefix}rating-star-hover-scale));
41
42
  }
42
-
43
+
43
44
  &:focus-visible {
44
45
  outline: 2px solid var(--#{config.$prefix}primary);
45
46
  outline-offset: 2px;
@@ -77,7 +78,7 @@
77
78
  --#{config.$prefix}rating-star-bg: #{$value};
78
79
  }
79
80
  }
80
-
81
+
81
82
  // Focused state
82
83
  &--focused {
83
84
  outline: 2px solid var(--#{config.$prefix}primary);
@@ -92,22 +93,22 @@
92
93
  fill: var(--#{config.$prefix}rating-star-empty-color);
93
94
  stroke-width: 1px;
94
95
  }
95
-
96
+
96
97
  // Full star styles
97
98
  &__star-full {
98
99
  fill: var(--#{config.$prefix}rating-star-bg);
99
100
  display: none;
100
-
101
+
101
102
  #{$root}__star--full & {
102
103
  display: block;
103
104
  }
104
105
  }
105
-
106
+
106
107
  // Half-star styles
107
108
  &__star-half {
108
109
  fill: var(--#{config.$prefix}rating-star-bg);
109
110
  display: none;
110
-
111
+
111
112
  #{$root}__star--half & {
112
113
  display: block;
113
114
  }
@@ -6,7 +6,6 @@
6
6
  @use '../02-tools/tools.breakpoints' as *;
7
7
  @use '../02-tools/tools.grid' as grid;
8
8
 
9
-
10
9
  .c-river {
11
10
  $root: &;
12
11
 
@@ -32,7 +31,10 @@
32
31
  --#{config.$prefix}river-content-max-width: #{rem($river-content-max-width)};
33
32
  --#{config.$prefix}river-breakout-title-width: #{rem($river-breakout-title-width)};
34
33
  --#{config.$prefix}river-breakout-text-width: #{rem($river-breakout-text-width)};
35
- --#{config.$prefix}river-content-width: var(--river-content-width, #{rem($river-content-max-width)});
34
+ --#{config.$prefix}river-content-width: var(
35
+ --river-content-width,
36
+ #{rem($river-content-max-width)}
37
+ );
36
38
 
37
39
  position: relative;
38
40
  width: 100%;
@@ -15,16 +15,10 @@
15
15
  --#{$prefix}sectionintro-text-color: #{$sectionintro-text-color};
16
16
  --#{$prefix}sectionintro-title-font-weight: #{$sectionintro-title-font-weight};
17
17
  --#{$prefix}sectionintro-text-font-weight: #{$sectionintro-text-font-weight};
18
- --#{$prefix}sectionintro-label-margin-bottom: #{rem(
19
- $sectionintro-label-margin-bottom
20
- )};
18
+ --#{$prefix}sectionintro-label-margin-bottom: #{rem($sectionintro-label-margin-bottom)};
21
19
  --#{$prefix}sectionintro-text-margin-top: #{rem($sectionintro-text-margin-top)};
22
- --#{$prefix}sectionintro-actions-margin-top: #{rem(
23
- $sectionintro-actions-margin-top
24
- )};
25
- --#{$prefix}sectionintro-actions-inner-gap: #{rem(
26
- $sectionintro-actions-inner-gap
27
- )};
20
+ --#{$prefix}sectionintro-actions-margin-top: #{rem($sectionintro-actions-margin-top)};
21
+ --#{$prefix}sectionintro-actions-inner-gap: #{rem($sectionintro-actions-inner-gap)};
28
22
  --#{$prefix}sectionintro-width: #{rem($sectionintro-width)};
29
23
  --#{$prefix}sectionintro-image-margin-top: #{rem(24px)};
30
24
  --#{$prefix}sectionintro-image-max-width: 100%;
@@ -36,8 +30,7 @@
36
30
 
37
31
  width: 100%;
38
32
  max-width: var(--#{$prefix}sectionintro-width);
39
- padding: var(--#{$prefix}sectionintro-padding-y)
40
- var(--#{$prefix}sectionintro-padding-x);
33
+ padding: var(--#{$prefix}sectionintro-padding-y) var(--#{$prefix}sectionintro-padding-x);
41
34
  position: relative;
42
35
  overflow: hidden;
43
36
 
@@ -78,29 +71,29 @@
78
71
  &--right {
79
72
  margin-left: auto;
80
73
  text-align: right;
81
-
74
+
82
75
  #{$root}__actions {
83
76
  justify-content: flex-end;
84
77
  }
85
78
  }
86
-
79
+
87
80
  &__container {
88
81
  position: relative;
89
82
  z-index: 1;
90
83
  }
91
-
84
+
92
85
  &__image-wrapper {
93
86
  margin-top: var(--#{$prefix}sectionintro-image-margin-top);
94
87
  display: flex;
95
88
  justify-content: center;
96
89
  }
97
-
90
+
98
91
  &__image {
99
92
  max-width: var(--#{$prefix}sectionintro-image-max-width);
100
93
  height: auto;
101
94
  border-radius: var(--#{$prefix}border-radius);
102
95
  }
103
-
96
+
104
97
  &__bg {
105
98
  position: absolute;
106
99
  top: 0;
@@ -110,13 +103,13 @@
110
103
  z-index: var(--#{$prefix}sectionintro-bg-z-index);
111
104
  overflow: hidden;
112
105
  }
113
-
106
+
114
107
  &__bg-image {
115
108
  width: 100%;
116
109
  height: 100%;
117
110
  object-fit: cover;
118
111
  }
119
-
112
+
120
113
  &__overlay {
121
114
  position: absolute;
122
115
  top: 0;
@@ -126,43 +119,43 @@
126
119
  background-color: var(--#{$prefix}sectionintro-overlay-bg-color);
127
120
  opacity: var(--#{$prefix}sectionintro-overlay-opacity);
128
121
  }
129
-
122
+
130
123
  &--has-bg {
131
124
  color: var(--#{$prefix}color-white);
132
-
125
+
133
126
  #{$root}__title,
134
127
  #{$root}__text,
135
128
  #{$root}__label {
136
129
  color: var(--#{$prefix}color-white);
137
130
  }
138
131
  }
139
-
132
+
140
133
  &--sm {
141
134
  #{$root}__title {
142
135
  font-size: var(--#{$prefix}sectionintro-sm-title-font-size);
143
136
  }
144
-
137
+
145
138
  #{$root}__text {
146
139
  font-size: calc(var(--#{$prefix}sectionintro-text-font-size) * 0.9);
147
140
  }
148
141
  }
149
-
142
+
150
143
  &--lg {
151
144
  #{$root}__title {
152
145
  font-size: var(--#{$prefix}sectionintro-lg-title-font-size);
153
146
  }
154
-
147
+
155
148
  #{$root}__text {
156
149
  font-size: calc(var(--#{$prefix}sectionintro-text-font-size) * 1.1);
157
150
  }
158
151
  }
159
-
152
+
160
153
  @include media-breakpoint-up(md) {
161
154
  &__container {
162
155
  display: flex;
163
156
  flex-direction: column;
164
157
  }
165
-
158
+
166
159
  &--has-bg {
167
160
  padding: rem(60px) var(--#{$prefix}sectionintro-padding-x);
168
161
  }
@@ -52,11 +52,11 @@
52
52
  border: 1px solid var(--#{$prefix}select-border-color);
53
53
  border-radius: var(--#{$prefix}select-border-radius);
54
54
  cursor: pointer;
55
-
55
+
56
56
  @include transition.basic-transition();
57
57
 
58
58
  &:hover {
59
- border-color: var(--#{$prefix}select-border-color-hover);
59
+ border-color: var(--#{$prefix}select-border-color-hover);
60
60
  }
61
61
  }
62
62
 
@@ -86,8 +86,7 @@
86
86
  }
87
87
 
88
88
  &__panel {
89
- padding: var(--#{$prefix}select-panel-padding-x)
90
- var(--#{$prefix}select-panel-padding-y);
89
+ padding: var(--#{$prefix}select-panel-padding-x) var(--#{$prefix}select-panel-padding-y);
91
90
  }
92
91
 
93
92
  &__items {
@@ -97,15 +96,15 @@
97
96
  }
98
97
 
99
98
  &__item {
100
- padding: var(--#{$prefix}select-item-padding-x)
101
- var(--#{$prefix}select-item-padding-y);
99
+ padding: var(--#{$prefix}select-item-padding-x) var(--#{$prefix}select-item-padding-y);
102
100
  color: var(--#{$prefix}select-item-color);
103
101
  background-color: var(--#{$prefix}select-item-bg);
104
102
  border-radius: var(--#{$prefix}select-item-border-radius);
105
103
  @include transition.basic-transition;
106
104
 
107
- &,&>* {
108
- cursor: pointer;
105
+ &,
106
+ & > * {
107
+ cursor: pointer;
109
108
  }
110
109
 
111
110
  &:hover {
@@ -9,42 +9,71 @@
9
9
  .c-side-menu {
10
10
  $root: &;
11
11
 
12
+ // 1. CSS Custom Properties
12
13
  --#{config.$prefix}side-menu-padding-x: #{rem.rem($side-menu-padding-x)};
13
14
  --#{config.$prefix}side-menu-padding-y: #{rem.rem($side-menu-padding-y)};
14
15
  --#{config.$prefix}side-menu-bg: #{$side-menu-bg};
15
16
  --#{config.$prefix}side-menu-border-radius: #{$side-menu-border-radius};
17
+ --#{config.$prefix}side-menu-border-width: #{$side-menu-border-width};
18
+ --#{config.$prefix}side-menu-border-color: #{$side-menu-border-color};
19
+ --#{config.$prefix}side-menu-box-shadow: #{$side-menu-box-shadow};
16
20
  --#{config.$prefix}side-menu-title-font-size: #{$side-menu-title-font-size};
17
21
  --#{config.$prefix}side-menu-title-font-weight: #{$side-menu-title-font-weight};
18
22
  --#{config.$prefix}side-menu-title-color: #{$side-menu-title-color};
19
23
  --#{config.$prefix}side-menu-title-spacer-y: #{rem.rem($side-menu-title-spacer-y)};
24
+ --#{config.$prefix}side-menu-toggler-padding-x: #{rem.rem($side-menu-toggler-padding-x)};
25
+ --#{config.$prefix}side-menu-toggler-padding-y: #{rem.rem($side-menu-toggler-padding-y)};
26
+ --#{config.$prefix}side-menu-toggler-bg: #{$side-menu-toggler-bg};
27
+ --#{config.$prefix}side-menu-toggler-hover-bg: #{$side-menu-toggler-hover-bg};
28
+ --#{config.$prefix}side-menu-toggler-border-radius: #{$side-menu-toggler-border-radius};
29
+ --#{config.$prefix}side-menu-toggler-transition: #{$side-menu-toggler-transition};
20
30
  --#{config.$prefix}side-menu-item-padding-x: #{rem.rem($side-menu-item-padding-x)};
21
31
  --#{config.$prefix}side-menu-item-padding-y: #{rem.rem($side-menu-item-padding-y)};
22
32
  --#{config.$prefix}side-menu-item-font-size: #{$side-menu-item-font-size};
33
+ --#{config.$prefix}side-menu-item-font-weight: #{$side-menu-item-font-weight};
23
34
  --#{config.$prefix}side-menu-item-color: #{$side-menu-item-color};
24
-
35
+ --#{config.$prefix}side-menu-item-hover-color: #{$side-menu-item-hover-color};
36
+ --#{config.$prefix}side-menu-item-active-color: #{$side-menu-item-active-color};
37
+ --#{config.$prefix}side-menu-item-disabled-color: #{$side-menu-item-disabled-color};
38
+ --#{config.$prefix}side-menu-item-bg: #{$side-menu-item-bg};
39
+ --#{config.$prefix}side-menu-item-hover-bg: #{$side-menu-item-hover-bg};
40
+ --#{config.$prefix}side-menu-item-active-bg: #{$side-menu-item-active-bg};
41
+ --#{config.$prefix}side-menu-item-disabled-bg: #{$side-menu-item-disabled-bg};
42
+ --#{config.$prefix}side-menu-item-border-radius: #{$side-menu-item-border-radius};
43
+ --#{config.$prefix}side-menu-item-transition: #{$side-menu-item-transition};
44
+ --#{config.$prefix}side-menu-item-gap: #{rem.rem($side-menu-item-gap)};
45
+ --#{config.$prefix}side-menu-list-margin-bottom: #{rem.rem($side-menu-list-margin-bottom)};
46
+ --#{config.$prefix}side-menu-list-gap: #{rem.rem($side-menu-list-gap)};
47
+ --#{config.$prefix}side-menu-wrapper-transition: #{$side-menu-wrapper-transition};
48
+ --#{config.$prefix}side-menu-inner-padding-top: #{rem.rem($side-menu-inner-padding-top)};
49
+
50
+ // 2. Base Component Styles
25
51
  width: 100%;
26
- padding: var(--#{config.$prefix}side-menu-padding-y)
27
- var(--#{config.$prefix}side-menu-padding-x);
52
+ padding: var(--#{config.$prefix}side-menu-padding-y) var(--#{config.$prefix}side-menu-padding-x);
28
53
  background: var(--#{config.$prefix}side-menu-bg);
29
54
  border-radius: var(--#{config.$prefix}side-menu-border-radius);
55
+ border: var(--#{config.$prefix}side-menu-border-width) solid
56
+ var(--#{config.$prefix}side-menu-border-color);
57
+ box-shadow: var(--#{config.$prefix}side-menu-box-shadow);
30
58
 
59
+ // 3. Responsive Styles
31
60
  @include media-breakpoint-down(md) {
32
- padding: rem.rem(12px) rem.rem(16px);
61
+ padding: #{rem.rem($side-menu-mobile-padding-y)} #{rem.rem($side-menu-mobile-padding-x)};
33
62
  }
34
63
 
64
+ // 4. Element Styles (BEM Elements)
35
65
  &__wrapper {
36
66
  @include media-breakpoint-down(md) {
37
67
  height: 0px;
38
68
  overflow: hidden;
39
69
  user-select: none;
40
-
41
- @include transition.basic-transition();
70
+ transition: var(--#{config.$prefix}side-menu-wrapper-transition);
42
71
  }
43
72
  }
44
73
 
45
74
  &__inner {
46
75
  @include media-breakpoint-down(md) {
47
- padding-top: rem.rem(20px);
76
+ padding-top: var(--#{config.$prefix}side-menu-inner-padding-top);
48
77
  }
49
78
  }
50
79
 
@@ -53,12 +82,60 @@
53
82
  font-size: var(--#{config.$prefix}side-menu-title-font-size);
54
83
  font-weight: var(--#{config.$prefix}side-menu-title-font-weight);
55
84
  margin-bottom: var(--#{config.$prefix}side-menu-title-spacer-y);
85
+ margin: 0 0 var(--#{config.$prefix}side-menu-title-spacer-y) 0;
86
+ }
87
+
88
+ &__toggler {
89
+ display: none;
90
+ align-items: center;
91
+ justify-content: space-between;
92
+ width: 100%;
93
+ padding: var(--#{config.$prefix}side-menu-toggler-padding-y)
94
+ var(--#{config.$prefix}side-menu-toggler-padding-x);
95
+ background: var(--#{config.$prefix}side-menu-toggler-bg);
96
+ border: none;
97
+ border-radius: var(--#{config.$prefix}side-menu-toggler-border-radius);
98
+ cursor: pointer;
99
+ user-select: none;
100
+ transition: var(--#{config.$prefix}side-menu-toggler-transition);
101
+ text-align: left;
102
+
103
+ @include media-breakpoint-down(md) {
104
+ display: flex;
105
+ }
106
+
107
+ &:hover {
108
+ background: var(--#{config.$prefix}side-menu-toggler-hover-bg);
109
+ }
110
+
111
+ &:focus {
112
+ outline: 2px solid var(--#{config.$prefix}focus-ring-color);
113
+ outline-offset: 2px;
114
+ }
115
+
116
+ &:active {
117
+ transform: scale(0.98);
118
+ }
119
+
120
+ &[aria-disabled='true'] {
121
+ opacity: 0.6;
122
+ cursor: not-allowed;
123
+ pointer-events: none;
124
+ }
125
+ }
126
+
127
+ &__toggler-icon {
128
+ transition: var(--#{config.$prefix}side-menu-toggler-transition);
129
+ font-size: 0.875em;
56
130
  }
57
131
 
58
132
  &__list {
59
133
  list-style: none;
60
- padding-left: 0;
61
- margin-bottom: 12px;
134
+ padding: 0;
135
+ margin: 0 0 var(--#{config.$prefix}side-menu-list-margin-bottom) 0;
136
+ display: flex;
137
+ flex-direction: column;
138
+ gap: var(--#{config.$prefix}side-menu-list-gap);
62
139
 
63
140
  &:last-child {
64
141
  margin-bottom: 0;
@@ -66,43 +143,92 @@
66
143
  }
67
144
 
68
145
  &__item {
69
- display: flex;
70
- align-items: center;
146
+ // List item wrapper - no specific styles needed
71
147
  }
72
148
 
73
149
  &__link {
74
- display: inline-block;
150
+ display: flex;
151
+ align-items: center;
152
+ gap: var(--#{config.$prefix}side-menu-item-gap);
153
+ width: 100%;
154
+ padding: var(--#{config.$prefix}side-menu-item-padding-y)
155
+ var(--#{config.$prefix}side-menu-item-padding-x);
75
156
  color: var(--#{config.$prefix}side-menu-item-color);
76
157
  font-size: var(--#{config.$prefix}side-menu-item-font-size);
77
- padding: var(--#{config.$prefix}side-menu-item-padding-y)
78
- var(--#{config.$prefix}side-menu-item-padding-y);
158
+ font-weight: var(--#{config.$prefix}side-menu-item-font-weight);
159
+ background: var(--#{config.$prefix}side-menu-item-bg);
160
+ border: none;
161
+ border-radius: var(--#{config.$prefix}side-menu-item-border-radius);
162
+ text-decoration: none;
163
+ cursor: pointer;
164
+ transition: var(--#{config.$prefix}side-menu-item-transition);
165
+
166
+ &:hover {
167
+ color: var(--#{config.$prefix}side-menu-item-hover-color);
168
+ background: var(--#{config.$prefix}side-menu-item-hover-bg);
169
+ text-decoration: none;
170
+ }
79
171
 
172
+ &:focus {
173
+ outline: 2px solid var(--#{config.$prefix}focus-ring-color);
174
+ outline-offset: 2px;
175
+ }
176
+
177
+ &:active {
178
+ transform: scale(0.98);
179
+ }
180
+
181
+ // 5. State Classes
80
182
  &.is-active {
81
- color: var(--#{config.$prefix}brand-text-emphasis);
183
+ color: var(--#{config.$prefix}side-menu-item-active-color);
184
+ background: var(--#{config.$prefix}side-menu-item-active-bg);
82
185
  font-weight: typography.$font-weight-medium;
83
186
  }
187
+
188
+ &.is-disabled,
189
+ &[aria-disabled='true'] {
190
+ color: var(--#{config.$prefix}side-menu-item-disabled-color);
191
+ background: var(--#{config.$prefix}side-menu-item-disabled-bg);
192
+ cursor: not-allowed;
193
+ pointer-events: none;
194
+ opacity: 0.6;
195
+ }
84
196
  }
85
197
 
86
- &__toggler {
87
- display: none;
88
- justify-content: space-between;
89
- font-size: typography.$font-size-lg;
90
- font-weight: typography.$font-weight-medium;
91
- cursor: pointer;
92
- user-select: none;
198
+ &__link-icon {
199
+ flex-shrink: 0;
200
+ font-size: 1em;
201
+ }
93
202
 
94
- @include media-breakpoint-down(md) {
95
- display: flex;
203
+ &__link-text {
204
+ flex: 1;
205
+ }
206
+
207
+ // 6. State Classes
208
+ &.is-open {
209
+ #{$root}__toggler-icon {
210
+ transform: rotate(90deg);
96
211
  }
97
212
  }
98
213
 
99
- &__toggler-icon {
100
- @include transition.basic-transition();
214
+ // 7. Dark Mode Support
215
+ .dark-mode & {
216
+ --#{config.$prefix}side-menu-bg: #{$side-menu-bg-dark};
217
+ --#{config.$prefix}side-menu-border-color: #{$side-menu-border-color-dark};
218
+ --#{config.$prefix}side-menu-title-color: #{$side-menu-title-color-dark};
219
+ --#{config.$prefix}side-menu-item-color: #{$side-menu-item-color-dark};
220
+ --#{config.$prefix}side-menu-item-hover-color: #{$side-menu-item-hover-color-dark};
221
+ --#{config.$prefix}side-menu-item-active-color: #{$side-menu-item-active-color-dark};
101
222
  }
102
223
 
103
- &.is-open {
224
+ // 8. Accessibility Considerations
225
+ @media (prefers-reduced-motion: reduce) {
226
+ --#{config.$prefix}side-menu-wrapper-transition: none;
227
+ --#{config.$prefix}side-menu-toggler-transition: none;
228
+ --#{config.$prefix}side-menu-item-transition: none;
229
+
104
230
  #{$root}__toggler-icon {
105
- transform: rotate(90deg);
231
+ transition: none;
106
232
  }
107
233
  }
108
234
  }
@@ -47,7 +47,6 @@
47
47
  width: var(--#{$prefix}skeleton-height);
48
48
  }
49
49
 
50
-
51
50
  @each $size, $value in $skeleton-sizes {
52
51
  &--#{$size} {
53
52
  --#{$prefix}skeleton-height: #{$value};