@shohojdhara/atomix 0.1.17 → 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 (704) 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 -1
  7. package/dist/js/244.js +1 -0
  8. package/dist/js/atomix.react.cjs.js +1 -0
  9. package/dist/js/atomix.react.esm.js +1 -1
  10. package/dist/js/atomix.react.umd.js +1 -1
  11. package/dist/js/chunks/cjs/202.9d3b1ef1eaa0d5c8a309.js +1 -0
  12. package/dist/js/chunks/cjs/308.6ea9685ea38ead4120d0.js +1 -0
  13. package/dist/js/chunks/cjs/54.73db6922594e421ba6b1.js +1 -0
  14. package/dist/js/chunks/cjs/619.51feecaadcab819780d4.js +1 -0
  15. package/dist/js/chunks/cjs/690.90f6d11164081cbcbc4d.js +1 -0
  16. package/dist/js/chunks/cjs/894.24877561df336a8dfd14.js +1 -0
  17. package/dist/js/chunks/cjs/897.6c2a71fae95338890de7.js +1 -0
  18. package/dist/types/components/{Navbar → Navigation/Menu}/MegaMenu.d.ts +1 -1
  19. package/dist/types/components/{Navbar → Navigation/Menu}/Menu.d.ts +1 -1
  20. package/dist/types/components/Navigation/Nav/Nav.d.ts +20 -0
  21. package/dist/types/components/{Navbar → Navigation/Nav}/NavDropdown.d.ts +1 -1
  22. package/dist/types/components/Navigation/Nav/NavItem.d.ts +33 -0
  23. package/dist/types/components/Navigation/Navbar/Navbar.d.ts +19 -0
  24. package/dist/types/components/Navigation/SideMenu/SideMenu.d.ts +20 -0
  25. package/dist/types/components/Navigation/SideMenu/SideMenuItem.d.ts +30 -0
  26. package/dist/types/components/Navigation/SideMenu/SideMenuList.d.ts +17 -0
  27. package/dist/types/components/Navigation/index.d.ts +10 -0
  28. package/dist/types/components/index.d.ts +1 -1
  29. package/dist/types/lib/composables/index.d.ts +1 -0
  30. package/dist/types/lib/composables/useSideMenu.d.ts +28 -0
  31. package/dist/types/lib/constants/components.d.ts +72 -0
  32. package/dist/types/lib/types/components.d.ts +103 -0
  33. package/examples/nextjs-example.tsx +271 -0
  34. package/implementation-guide.md +505 -0
  35. package/next.config.js +69 -0
  36. package/package.json +26 -5
  37. package/postcss.config.js +28 -0
  38. package/src/Introduction.mdx +44 -0
  39. package/src/assets/fonts/BigCaslon/BigCaslon-Alternatives.eot +0 -0
  40. package/src/assets/fonts/BigCaslon/BigCaslon-Alternatives.ttf +0 -0
  41. package/src/assets/fonts/BigCaslon/BigCaslon-Alternatives.woff +0 -0
  42. package/src/assets/fonts/BigCaslon/BigCaslon-Alternatives.woff2 +0 -0
  43. package/src/assets/fonts/BigCaslon/BigCaslon-Expert.eot +0 -0
  44. package/src/assets/fonts/BigCaslon/BigCaslon-Expert.ttf +0 -0
  45. package/src/assets/fonts/BigCaslon/BigCaslon-Expert.woff +0 -0
  46. package/src/assets/fonts/BigCaslon/BigCaslon-Expert.woff2 +0 -0
  47. package/src/assets/fonts/BigCaslon/BigCaslon-ItalicSwash.eot +0 -0
  48. package/src/assets/fonts/BigCaslon/BigCaslon-ItalicSwash.ttf +0 -0
  49. package/src/assets/fonts/BigCaslon/BigCaslon-ItalicSwash.woff +0 -0
  50. package/src/assets/fonts/BigCaslon/BigCaslon-ItalicSwash.woff2 +0 -0
  51. package/src/assets/fonts/BigCaslon/BigCaslon-SmallCaps.eot +0 -0
  52. package/src/assets/fonts/BigCaslon/BigCaslon-SmallCaps.ttf +0 -0
  53. package/src/assets/fonts/BigCaslon/BigCaslon-SmallCaps.woff +0 -0
  54. package/src/assets/fonts/BigCaslon/BigCaslon-SmallCaps.woff2 +0 -0
  55. package/src/assets/fonts/BigCaslon/BigCaslonFB-Black.eot +0 -0
  56. package/src/assets/fonts/BigCaslon/BigCaslonFB-Black.ttf +0 -0
  57. package/src/assets/fonts/BigCaslon/BigCaslonFB-Black.woff +0 -0
  58. package/src/assets/fonts/BigCaslon/BigCaslonFB-Black.woff2 +0 -0
  59. package/src/assets/fonts/BigCaslon/BigCaslonFB-BlackItalic.eot +0 -0
  60. package/src/assets/fonts/BigCaslon/BigCaslonFB-BlackItalic.ttf +0 -0
  61. package/src/assets/fonts/BigCaslon/BigCaslonFB-BlackItalic.woff +0 -0
  62. package/src/assets/fonts/BigCaslon/BigCaslonFB-BlackItalic.woff2 +0 -0
  63. package/src/assets/fonts/BigCaslon/BigCaslonFB-Bold.eot +0 -0
  64. package/src/assets/fonts/BigCaslon/BigCaslonFB-Bold.ttf +0 -0
  65. package/src/assets/fonts/BigCaslon/BigCaslonFB-Bold.woff +0 -0
  66. package/src/assets/fonts/BigCaslon/BigCaslonFB-Bold.woff2 +0 -0
  67. package/src/assets/fonts/BigCaslon/BigCaslonFB-BoldItalic.eot +0 -0
  68. package/src/assets/fonts/BigCaslon/BigCaslonFB-BoldItalic.ttf +0 -0
  69. package/src/assets/fonts/BigCaslon/BigCaslonFB-BoldItalic.woff +0 -0
  70. package/src/assets/fonts/BigCaslon/BigCaslonFB-BoldItalic.woff2 +0 -0
  71. package/src/assets/fonts/BigCaslon/BigCaslonFB-Italic.eot +0 -0
  72. package/src/assets/fonts/BigCaslon/BigCaslonFB-Italic.ttf +0 -0
  73. package/src/assets/fonts/BigCaslon/BigCaslonFB-Italic.woff +0 -0
  74. package/src/assets/fonts/BigCaslon/BigCaslonFB-Italic.woff2 +0 -0
  75. package/src/assets/fonts/BigCaslon/BigCaslonFB-Regular.eot +0 -0
  76. package/src/assets/fonts/BigCaslon/BigCaslonFB-Regular.ttf +0 -0
  77. package/src/assets/fonts/BigCaslon/BigCaslonFB-Regular.woff +0 -0
  78. package/src/assets/fonts/BigCaslon/BigCaslonFB-Regular.woff2 +0 -0
  79. package/src/assets/fonts/FilsonPro/FilsonPro-Black.eot +0 -0
  80. package/src/assets/fonts/FilsonPro/FilsonPro-Black.ttf +0 -0
  81. package/src/assets/fonts/FilsonPro/FilsonPro-Black.woff +0 -0
  82. package/src/assets/fonts/FilsonPro/FilsonPro-Black.woff2 +0 -0
  83. package/src/assets/fonts/FilsonPro/FilsonPro-BlackItalic.eot +0 -0
  84. package/src/assets/fonts/FilsonPro/FilsonPro-BlackItalic.ttf +0 -0
  85. package/src/assets/fonts/FilsonPro/FilsonPro-BlackItalic.woff +0 -0
  86. package/src/assets/fonts/FilsonPro/FilsonPro-BlackItalic.woff2 +0 -0
  87. package/src/assets/fonts/FilsonPro/FilsonPro-Bold.eot +0 -0
  88. package/src/assets/fonts/FilsonPro/FilsonPro-Bold.ttf +0 -0
  89. package/src/assets/fonts/FilsonPro/FilsonPro-Bold.woff +0 -0
  90. package/src/assets/fonts/FilsonPro/FilsonPro-Bold.woff2 +0 -0
  91. package/src/assets/fonts/FilsonPro/FilsonPro-BoldItalic.eot +0 -0
  92. package/src/assets/fonts/FilsonPro/FilsonPro-BoldItalic.ttf +0 -0
  93. package/src/assets/fonts/FilsonPro/FilsonPro-BoldItalic.woff +0 -0
  94. package/src/assets/fonts/FilsonPro/FilsonPro-BoldItalic.woff2 +0 -0
  95. package/src/assets/fonts/FilsonPro/FilsonPro-Book.eot +0 -0
  96. package/src/assets/fonts/FilsonPro/FilsonPro-Book.ttf +0 -0
  97. package/src/assets/fonts/FilsonPro/FilsonPro-Book.woff +0 -0
  98. package/src/assets/fonts/FilsonPro/FilsonPro-Book.woff2 +0 -0
  99. package/src/assets/fonts/FilsonPro/FilsonPro-BookItalic.eot +0 -0
  100. package/src/assets/fonts/FilsonPro/FilsonPro-BookItalic.ttf +0 -0
  101. package/src/assets/fonts/FilsonPro/FilsonPro-BookItalic.woff +0 -0
  102. package/src/assets/fonts/FilsonPro/FilsonPro-BookItalic.woff2 +0 -0
  103. package/src/assets/fonts/FilsonPro/FilsonPro-Heavy.eot +0 -0
  104. package/src/assets/fonts/FilsonPro/FilsonPro-Heavy.ttf +0 -0
  105. package/src/assets/fonts/FilsonPro/FilsonPro-Heavy.woff +0 -0
  106. package/src/assets/fonts/FilsonPro/FilsonPro-Heavy.woff2 +0 -0
  107. package/src/assets/fonts/FilsonPro/FilsonPro-HeavyItalic.eot +0 -0
  108. package/src/assets/fonts/FilsonPro/FilsonPro-HeavyItalic.ttf +0 -0
  109. package/src/assets/fonts/FilsonPro/FilsonPro-HeavyItalic.woff +0 -0
  110. package/src/assets/fonts/FilsonPro/FilsonPro-HeavyItalic.woff2 +0 -0
  111. package/src/assets/fonts/FilsonPro/FilsonPro-Light.eot +0 -0
  112. package/src/assets/fonts/FilsonPro/FilsonPro-Light.ttf +0 -0
  113. package/src/assets/fonts/FilsonPro/FilsonPro-Light.woff +0 -0
  114. package/src/assets/fonts/FilsonPro/FilsonPro-Light.woff2 +0 -0
  115. package/src/assets/fonts/FilsonPro/FilsonPro-LightItalic.eot +0 -0
  116. package/src/assets/fonts/FilsonPro/FilsonPro-LightItalic.ttf +0 -0
  117. package/src/assets/fonts/FilsonPro/FilsonPro-LightItalic.woff +0 -0
  118. package/src/assets/fonts/FilsonPro/FilsonPro-LightItalic.woff2 +0 -0
  119. package/src/assets/fonts/FilsonPro/FilsonPro-Medium.eot +0 -0
  120. package/src/assets/fonts/FilsonPro/FilsonPro-Medium.ttf +0 -0
  121. package/src/assets/fonts/FilsonPro/FilsonPro-Medium.woff +0 -0
  122. package/src/assets/fonts/FilsonPro/FilsonPro-Medium.woff2 +0 -0
  123. package/src/assets/fonts/FilsonPro/FilsonPro-MediumItalic.eot +0 -0
  124. package/src/assets/fonts/FilsonPro/FilsonPro-MediumItalic.ttf +0 -0
  125. package/src/assets/fonts/FilsonPro/FilsonPro-MediumItalic.woff +0 -0
  126. package/src/assets/fonts/FilsonPro/FilsonPro-MediumItalic.woff2 +0 -0
  127. package/src/assets/fonts/FilsonPro/FilsonPro-Regular.eot +0 -0
  128. package/src/assets/fonts/FilsonPro/FilsonPro-Regular.ttf +0 -0
  129. package/src/assets/fonts/FilsonPro/FilsonPro-Regular.woff +0 -0
  130. package/src/assets/fonts/FilsonPro/FilsonPro-Regular.woff2 +0 -0
  131. package/src/assets/fonts/FilsonPro/FilsonPro-RegularItalic.eot +0 -0
  132. package/src/assets/fonts/FilsonPro/FilsonPro-RegularItalic.ttf +0 -0
  133. package/src/assets/fonts/FilsonPro/FilsonPro-RegularItalic.woff +0 -0
  134. package/src/assets/fonts/FilsonPro/FilsonPro-RegularItalic.woff2 +0 -0
  135. package/src/assets/fonts/FilsonPro/FilsonPro-Thin.eot +0 -0
  136. package/src/assets/fonts/FilsonPro/FilsonPro-Thin.ttf +0 -0
  137. package/src/assets/fonts/FilsonPro/FilsonPro-Thin.woff +0 -0
  138. package/src/assets/fonts/FilsonPro/FilsonPro-Thin.woff2 +0 -0
  139. package/src/assets/fonts/FilsonPro/FilsonPro-ThinItalic.eot +0 -0
  140. package/src/assets/fonts/FilsonPro/FilsonPro-ThinItalic.ttf +0 -0
  141. package/src/assets/fonts/FilsonPro/FilsonPro-ThinItalic.woff +0 -0
  142. package/src/assets/fonts/FilsonPro/FilsonPro-ThinItalic.woff2 +0 -0
  143. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Bold.eot +0 -0
  144. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Bold.ttf +0 -0
  145. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Bold.woff +0 -0
  146. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Bold.woff2 +0 -0
  147. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-BoldItalic.eot +0 -0
  148. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-BoldItalic.ttf +0 -0
  149. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-BoldItalic.woff +0 -0
  150. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-BoldItalic.woff2 +0 -0
  151. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-CondensedBlack.eot +0 -0
  152. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-CondensedBlack.ttf +0 -0
  153. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-CondensedBlack.woff +0 -0
  154. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-CondensedBlack.woff2 +0 -0
  155. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-CondensedBold.eot +0 -0
  156. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-CondensedBold.ttf +0 -0
  157. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-CondensedBold.woff +0 -0
  158. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-CondensedBold.woff2 +0 -0
  159. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Italic.eot +0 -0
  160. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Italic.ttf +0 -0
  161. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Italic.woff +0 -0
  162. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Italic.woff2 +0 -0
  163. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Light.eot +0 -0
  164. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Light.ttf +0 -0
  165. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Light.woff +0 -0
  166. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Light.woff2 +0 -0
  167. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-LightItalic.eot +0 -0
  168. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-LightItalic.ttf +0 -0
  169. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-LightItalic.woff +0 -0
  170. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-LightItalic.woff2 +0 -0
  171. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Medium.eot +0 -0
  172. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Medium.ttf +0 -0
  173. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Medium.woff +0 -0
  174. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Medium.woff2 +0 -0
  175. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-MediumItalic.eot +0 -0
  176. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-MediumItalic.ttf +0 -0
  177. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-MediumItalic.woff +0 -0
  178. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-MediumItalic.woff2 +0 -0
  179. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Thin.eot +0 -0
  180. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Thin.ttf +0 -0
  181. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Thin.woff +0 -0
  182. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-Thin.woff2 +0 -0
  183. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-ThinItalic.eot +0 -0
  184. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-ThinItalic.ttf +0 -0
  185. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-ThinItalic.woff +0 -0
  186. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-ThinItalic.woff2 +0 -0
  187. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-UltraLight.eot +0 -0
  188. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-UltraLight.ttf +0 -0
  189. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-UltraLight.woff +0 -0
  190. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-UltraLight.woff2 +0 -0
  191. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-UltraLightItalic.eot +0 -0
  192. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-UltraLightItalic.ttf +0 -0
  193. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-UltraLightItalic.woff +0 -0
  194. package/src/assets/fonts/HelveticaNeue/HelveticaNeue-UltraLightItalic.woff2 +0 -0
  195. package/src/assets/fonts/HelveticaNeue/HelveticaNeue.eot +0 -0
  196. package/src/assets/fonts/HelveticaNeue/HelveticaNeue.ttf +0 -0
  197. package/src/assets/fonts/HelveticaNeue/HelveticaNeue.woff +0 -0
  198. package/src/assets/fonts/HelveticaNeue/HelveticaNeue.woff2 +0 -0
  199. package/src/assets/fonts/HelveticaNeue/demo.html +569 -0
  200. package/src/assets/fonts/HelveticaNeue/stylesheet.css +181 -0
  201. package/src/assets/fonts/Lato/Lato-Black.eot +0 -0
  202. package/src/assets/fonts/Lato/Lato-Black.ttf +0 -0
  203. package/src/assets/fonts/Lato/Lato-Black.woff +0 -0
  204. package/src/assets/fonts/Lato/Lato-Black.woff2 +0 -0
  205. package/src/assets/fonts/Lato/Lato-Bold.eot +0 -0
  206. package/src/assets/fonts/Lato/Lato-Bold.ttf +0 -0
  207. package/src/assets/fonts/Lato/Lato-Bold.woff +0 -0
  208. package/src/assets/fonts/Lato/Lato-Bold.woff2 +0 -0
  209. package/src/assets/fonts/Lato/Lato-Light.eot +0 -0
  210. package/src/assets/fonts/Lato/Lato-Light.ttf +0 -0
  211. package/src/assets/fonts/Lato/Lato-Light.woff +0 -0
  212. package/src/assets/fonts/Lato/Lato-Light.woff2 +0 -0
  213. package/src/assets/fonts/Lato/Lato-Regular.eot +0 -0
  214. package/src/assets/fonts/Lato/Lato-Regular.ttf +0 -0
  215. package/src/assets/fonts/Lato/Lato-Regular.woff +0 -0
  216. package/src/assets/fonts/Lato/Lato-Regular.woff2 +0 -0
  217. package/src/assets/fonts/Lux-Icons.woff2 +0 -0
  218. package/src/assets/fonts/MaterialIcons-Regular.eot +0 -0
  219. package/src/assets/fonts/MaterialIcons-Regular.ttf +0 -0
  220. package/src/assets/fonts/MaterialIcons-Regular.woff +0 -0
  221. package/src/assets/fonts/MaterialIcons-Regular.woff2 +0 -0
  222. package/src/assets/fonts/OpenSans-Regular.ttf +0 -0
  223. package/src/assets/fonts/Roboto-Regular.ttf +0 -0
  224. package/src/assets/images/logo-transparent.png +0 -0
  225. package/src/assets/svgs/atomix-logo.svg +9 -0
  226. package/src/components/Accordion/Accordion.stories.tsx +271 -0
  227. package/src/components/Accordion/Accordion.tsx +131 -0
  228. package/src/components/Accordion/index.ts +3 -0
  229. package/src/components/Accordion/scripts/accordionInteractions.ts +70 -0
  230. package/src/components/Accordion/scripts/bundle.ts +24 -0
  231. package/src/components/Accordion/scripts/constants.ts +11 -0
  232. package/src/components/Accordion/scripts/index.ts +212 -0
  233. package/src/components/AtomixLogo/AtomixLogo.tsx +36 -0
  234. package/src/components/AtomixLogo/index.ts +3 -0
  235. package/src/components/AtomixLogo.tsx +40 -0
  236. package/src/components/Avatar/Avatar.stories.tsx +263 -0
  237. package/src/components/Avatar/Avatar.tsx +68 -0
  238. package/src/components/Avatar/AvatarGroup.tsx +73 -0
  239. package/src/components/Avatar/index.ts +3 -0
  240. package/src/components/Avatar/scripts/index.ts +497 -0
  241. package/src/components/Badge/Badge.stories.tsx +374 -0
  242. package/src/components/Badge/Badge.tsx +39 -0
  243. package/src/components/Badge/index.ts +3 -0
  244. package/src/components/Breadcrumb/Breadcrumb.stories.tsx +108 -0
  245. package/src/components/Breadcrumb/Breadcrumb.tsx +98 -0
  246. package/src/components/Breadcrumb/index.ts +3 -0
  247. package/src/components/Breadcrumb/scripts/breadcrumb.ts +208 -0
  248. package/src/components/Breadcrumb/scripts/demo.html +246 -0
  249. package/src/components/Breadcrumb/scripts/index.ts +5 -0
  250. package/src/components/Breadcrumb/scripts/types.ts +69 -0
  251. package/src/components/Button/Button.stories.tsx +313 -0
  252. package/src/components/Button/Button.tsx +70 -0
  253. package/src/components/Button/index.ts +3 -0
  254. package/src/components/Button/scripts/buttonInteractions.ts +73 -0
  255. package/src/components/Button/scripts/index.ts +1 -0
  256. package/src/components/Callout/Callout.stories.tsx +595 -0
  257. package/src/components/Callout/Callout.tsx +78 -0
  258. package/src/components/Callout/index.ts +1 -0
  259. package/src/components/Callout/scripts/CalloutInteractions.ts +350 -0
  260. package/src/components/Callout/scripts/bundle.ts +18 -0
  261. package/src/components/Callout/scripts/index.ts +130 -0
  262. package/src/components/Card/Card.stories.tsx +107 -0
  263. package/src/components/Card/Card.tsx +69 -0
  264. package/src/components/Card/ElevationCard.tsx +47 -0
  265. package/src/components/Card/index.ts +15 -0
  266. package/src/components/Card/scripts/bundle.ts +30 -0
  267. package/src/components/Card/scripts/cardInteractions.ts +171 -0
  268. package/src/components/Card/scripts/demo.html +322 -0
  269. package/src/components/Card/scripts/index.ts +318 -0
  270. package/src/components/ColorModeToggle/ColorModeToggle.stories.tsx +46 -0
  271. package/src/components/ColorModeToggle/ColorModeToggle.tsx +85 -0
  272. package/src/components/ColorModeToggle/index.ts +2 -0
  273. package/src/components/Countdown/Countdown.stories.tsx +47 -0
  274. package/src/components/Countdown/Countdown.tsx +90 -0
  275. package/src/components/Countdown/index.ts +2 -0
  276. package/src/components/Countdown/scripts/index.ts +238 -0
  277. package/src/components/DataTable/DataTable.stories.tsx +249 -0
  278. package/src/components/DataTable/DataTable.tsx +213 -0
  279. package/src/components/DataTable/index.ts +3 -0
  280. package/src/components/DataTable/scripts/bundle.ts +20 -0
  281. package/src/components/DataTable/scripts/index.ts +781 -0
  282. package/src/components/DatePicker/DatePicker.stories.tsx +365 -0
  283. package/src/components/DatePicker/DatePicker.tsx +504 -0
  284. package/src/components/DatePicker/index.ts +4 -0
  285. package/src/components/DatePicker/readme.md +106 -0
  286. package/src/components/DatePicker/scripts/bundle.ts +39 -0
  287. package/src/components/DatePicker/scripts/componentInteractions.ts +230 -0
  288. package/src/components/DatePicker/scripts/index.ts +907 -0
  289. package/src/components/DatePicker/types.ts +167 -0
  290. package/src/components/DatePicker/utils.ts +163 -0
  291. package/src/components/Dropdown/Dropdown.stories.tsx +359 -0
  292. package/src/components/Dropdown/Dropdown.tsx +342 -0
  293. package/src/components/Dropdown/index.ts +14 -0
  294. package/src/components/Dropdown/readme.md +151 -0
  295. package/src/components/Dropdown/scripts/bundle.ts +24 -0
  296. package/src/components/Dropdown/scripts/componentInteractions.ts +39 -0
  297. package/src/components/Dropdown/scripts/index.ts +612 -0
  298. package/src/components/EdgePanel/EdgePanel.stories.tsx +267 -0
  299. package/src/components/EdgePanel/EdgePanel.tsx +73 -0
  300. package/src/components/EdgePanel/index.ts +1 -0
  301. package/src/components/EdgePanel/scripts/bundle.ts +30 -0
  302. package/src/components/EdgePanel/scripts/edgePanelInteractions.ts +206 -0
  303. package/src/components/EdgePanel/scripts/index.ts +415 -0
  304. package/src/components/Form/Checkbox.stories.tsx +77 -0
  305. package/src/components/Form/Checkbox.tsx +69 -0
  306. package/src/components/Form/Form.stories.tsx +491 -0
  307. package/src/components/Form/Form.tsx +46 -0
  308. package/src/components/Form/FormGroup.stories.tsx +163 -0
  309. package/src/components/Form/FormGroup.tsx +53 -0
  310. package/src/components/Form/Input.stories.tsx +107 -0
  311. package/src/components/Form/Input.tsx +87 -0
  312. package/src/components/Form/Radio.stories.tsx +95 -0
  313. package/src/components/Form/Radio.tsx +65 -0
  314. package/src/components/Form/Select.stories.tsx +152 -0
  315. package/src/components/Form/Select.tsx +191 -0
  316. package/src/components/Form/Textarea.stories.tsx +124 -0
  317. package/src/components/Form/Textarea.tsx +78 -0
  318. package/src/components/Form/index.ts +7 -0
  319. package/src/components/Hero/Hero.stories.tsx +297 -0
  320. package/src/components/Hero/Hero.tsx +175 -0
  321. package/src/components/Hero/index.ts +6 -0
  322. package/src/components/Hero/scripts/bundle.ts +33 -0
  323. package/src/components/Hero/scripts/heroInteractions.ts +130 -0
  324. package/src/components/Hero/scripts/index.ts +144 -0
  325. package/src/components/Icon/Icon.tsx +87 -0
  326. package/src/components/Icon/index.ts +2 -0
  327. package/src/components/List/List.stories.tsx +123 -0
  328. package/src/components/List/List.tsx +35 -0
  329. package/src/components/List/ListGroup.tsx +34 -0
  330. package/src/components/List/index.ts +2 -0
  331. package/src/components/Messages/Messages.stories.tsx +161 -0
  332. package/src/components/Messages/Messages.tsx +172 -0
  333. package/src/components/Messages/index.ts +3 -0
  334. package/src/components/Messages/scripts/bundle.ts +47 -0
  335. package/src/components/Messages/scripts/componentInteractions.ts +132 -0
  336. package/src/components/Messages/scripts/index.ts +378 -0
  337. package/src/components/Modal/Modal.stories.tsx +288 -0
  338. package/src/components/Modal/Modal.tsx +198 -0
  339. package/src/components/Modal/README.md +169 -0
  340. package/src/components/Modal/index.ts +1 -0
  341. package/src/components/Modal/scripts/bundle.ts +23 -0
  342. package/src/components/Modal/scripts/index.ts +374 -0
  343. package/src/components/Modal/scripts/modalInteractions.ts +141 -0
  344. package/src/components/Navigation/Menu/MegaMenu.tsx +107 -0
  345. package/src/components/Navigation/Menu/Menu.stories.tsx +340 -0
  346. package/src/components/Navigation/Menu/Menu.tsx +110 -0
  347. package/src/components/Navigation/Nav/Nav.stories.tsx +458 -0
  348. package/src/components/Navigation/Nav/Nav.tsx +50 -0
  349. package/src/components/Navigation/Nav/NavDropdown.tsx +105 -0
  350. package/src/components/Navigation/Nav/NavItem.tsx +159 -0
  351. package/src/components/Navigation/Navbar/Navbar.stories.tsx +552 -0
  352. package/src/components/Navigation/Navbar/Navbar.tsx +150 -0
  353. package/src/components/Navigation/README.md +314 -0
  354. package/src/components/Navigation/SideMenu/SideMenu.README.md +494 -0
  355. package/src/components/Navigation/SideMenu/SideMenu.stories.tsx +618 -0
  356. package/src/components/Navigation/SideMenu/SideMenu.tsx +101 -0
  357. package/src/components/Navigation/SideMenu/SideMenuItem.tsx +95 -0
  358. package/src/components/Navigation/SideMenu/SideMenuList.tsx +41 -0
  359. package/src/components/Navigation/index.ts +23 -0
  360. package/src/components/Navigation/scripts/NavbarInteractions.ts +171 -0
  361. package/src/components/Navigation/scripts/SideMenu.ts +319 -0
  362. package/src/components/Navigation/scripts/SideMenuBundle.ts +69 -0
  363. package/src/components/Navigation/scripts/SideMenuInteractions.ts +250 -0
  364. package/src/components/Navigation/scripts/bundle.ts +58 -0
  365. package/src/components/Navigation/scripts/index.ts +248 -0
  366. package/src/components/Pagination/Pagination.stories.tsx +194 -0
  367. package/src/components/Pagination/Pagination.tsx +162 -0
  368. package/src/components/Pagination/index.ts +1 -0
  369. package/src/components/Pagination/scripts/bundle.ts +15 -0
  370. package/src/components/Pagination/scripts/index.ts +315 -0
  371. package/src/components/PhotoViewer/PhotoViewer.stories.tsx +160 -0
  372. package/src/components/PhotoViewer/PhotoViewer.tsx +246 -0
  373. package/src/components/PhotoViewer/PhotoViewerHeader.tsx +177 -0
  374. package/src/components/PhotoViewer/PhotoViewerImage.tsx +173 -0
  375. package/src/components/PhotoViewer/PhotoViewerInfo.tsx +65 -0
  376. package/src/components/PhotoViewer/PhotoViewerNavigation.tsx +82 -0
  377. package/src/components/PhotoViewer/PhotoViewerThumbnails.tsx +53 -0
  378. package/src/components/PhotoViewer/README.md +358 -0
  379. package/src/components/PhotoViewer/examples/ImageGallery.tsx +190 -0
  380. package/src/components/PhotoViewer/examples/SimpleGallery.tsx +77 -0
  381. package/src/components/PhotoViewer/examples/index.ts +2 -0
  382. package/src/components/PhotoViewer/index.ts +14 -0
  383. package/src/components/PhotoViewer/scripts/PhotoViewerInteractions.ts +253 -0
  384. package/src/components/PhotoViewer/scripts/bundle.ts +81 -0
  385. package/src/components/PhotoViewer/scripts/index.ts +947 -0
  386. package/src/components/Popover/Popover.stories.tsx +143 -0
  387. package/src/components/Popover/Popover.tsx +137 -0
  388. package/src/components/Popover/index.ts +5 -0
  389. package/src/components/Popover/readme.md +120 -0
  390. package/src/components/Popover/scripts/bundle.ts +12 -0
  391. package/src/components/Popover/scripts/componentInteractions.ts +299 -0
  392. package/src/components/Popover/scripts/index.ts +342 -0
  393. package/src/components/ProductReview/ProductReview.stories.tsx +88 -0
  394. package/src/components/ProductReview/ProductReview.tsx +169 -0
  395. package/src/components/ProductReview/index.ts +3 -0
  396. package/src/components/ProductReview/scripts/bundle.ts +3 -0
  397. package/src/components/ProductReview/scripts/componentInteractions.ts +129 -0
  398. package/src/components/ProductReview/scripts/index.ts +3 -0
  399. package/src/components/Progress/Progress.stories.tsx +75 -0
  400. package/src/components/Progress/Progress.tsx +45 -0
  401. package/src/components/Progress/index.ts +1 -0
  402. package/src/components/Progress/scripts/bundle.ts +17 -0
  403. package/src/components/Progress/scripts/componentInteractions.ts +101 -0
  404. package/src/components/Progress/scripts/index.ts +184 -0
  405. package/src/components/Rating/Rating.stories.tsx +109 -0
  406. package/src/components/Rating/Rating.tsx +286 -0
  407. package/src/components/Rating/index.ts +6 -0
  408. package/src/components/Rating/scripts/bundle.ts +39 -0
  409. package/src/components/Rating/scripts/index.d.ts +12 -0
  410. package/src/components/Rating/scripts/index.ts +336 -0
  411. package/src/components/Rating/scripts/ratingInteractions.ts +160 -0
  412. package/src/components/River/River.stories.tsx +230 -0
  413. package/src/components/River/River.tsx +162 -0
  414. package/src/components/River/examples.html +223 -0
  415. package/src/components/River/index.ts +2 -0
  416. package/src/components/River/scripts/index.ts +137 -0
  417. package/src/components/SectionIntro/SectionIntro.stories.tsx +145 -0
  418. package/src/components/SectionIntro/SectionIntro.tsx +197 -0
  419. package/src/components/SectionIntro/index.ts +3 -0
  420. package/src/components/SectionIntro/scripts/bundle.ts +9 -0
  421. package/src/components/SectionIntro/scripts/componentInteractions.ts +37 -0
  422. package/src/components/SectionIntro/scripts/index.ts +163 -0
  423. package/src/components/Spinner/Spinner.stories.tsx +66 -0
  424. package/src/components/Spinner/Spinner.tsx +36 -0
  425. package/src/components/Spinner/index.ts +2 -0
  426. package/src/components/Steps/Steps.stories.tsx +158 -0
  427. package/src/components/Steps/Steps.tsx +154 -0
  428. package/src/components/Steps/index.ts +3 -0
  429. package/src/components/Steps/scripts/index.ts +159 -0
  430. package/src/components/Tab/Tab.stories.tsx +129 -0
  431. package/src/components/Tab/Tab.tsx +133 -0
  432. package/src/components/Tab/index.ts +2 -0
  433. package/src/components/Tab/scripts/index.ts +200 -0
  434. package/src/components/Testimonial/Testimonial.stories.tsx +180 -0
  435. package/src/components/Testimonial/Testimonial.tsx +148 -0
  436. package/src/components/Testimonial/index.ts +3 -0
  437. package/src/components/Testimonial/scripts/index.ts +107 -0
  438. package/src/components/Todo/Todo.stories.tsx +155 -0
  439. package/src/components/Todo/Todo.tsx +158 -0
  440. package/src/components/Todo/index.ts +1 -0
  441. package/src/components/Todo/scripts/bundle.ts +14 -0
  442. package/src/components/Todo/scripts/index.ts +534 -0
  443. package/src/components/Todo/scripts/todoInteractions.ts +118 -0
  444. package/src/components/Todo/scripts/types.ts +19 -0
  445. package/src/components/Toggle/Toggle.stories.tsx +50 -0
  446. package/src/components/Toggle/Toggle.tsx +114 -0
  447. package/src/components/Toggle/index.ts +2 -0
  448. package/src/components/Toggle/scripts/bundle.ts +19 -0
  449. package/src/components/Toggle/scripts/index.ts +118 -0
  450. package/src/components/Toggle/scripts/toggleInteractions.ts +77 -0
  451. package/src/components/Tooltip/Tooltip.stories.tsx +115 -0
  452. package/src/components/Tooltip/Tooltip.tsx +105 -0
  453. package/src/components/Tooltip/index.ts +3 -0
  454. package/src/components/Tooltip/scripts/bundle.ts +0 -0
  455. package/src/components/Tooltip/scripts/index.ts +395 -0
  456. package/src/components/Tooltip/scripts/tooltipInteractions.ts +165 -0
  457. package/src/components/Upload/Upload.stories.tsx +221 -0
  458. package/src/components/Upload/Upload.tsx +422 -0
  459. package/src/components/Upload/index.ts +3 -0
  460. package/src/components/Upload/scripts/index.ts +467 -0
  461. package/src/components/index.ts +117 -0
  462. package/src/design-tokens/BoxShadow/BoxShadow.stories.tsx +115 -0
  463. package/src/design-tokens/Colors/colors.scss +121 -0
  464. package/src/design-tokens/Colors/colors.stories.tsx +313 -0
  465. package/src/design-tokens/Spacing/Spacing.scss +62 -0
  466. package/src/design-tokens/Spacing/Spacing.stories.tsx +115 -0
  467. package/src/design-tokens/Typography/Typography.scss +240 -0
  468. package/src/design-tokens/Typography/Typography.stories.tsx +167 -0
  469. package/src/docs/atomix-component-guidelines.mdx +942 -0
  470. package/src/docs/atomix-roadmap.mdx +325 -0
  471. package/src/docs/implementation-guide.mdx +506 -0
  472. package/src/htmlComponentsEntry.ts +318 -0
  473. package/src/index.ts +21 -0
  474. package/src/layouts/Grid/Container.tsx +56 -0
  475. package/src/layouts/Grid/Grid.stories.tsx +560 -0
  476. package/src/layouts/Grid/Grid.tsx +67 -0
  477. package/src/layouts/Grid/GridCol.tsx +160 -0
  478. package/src/layouts/Grid/README.md +108 -0
  479. package/src/layouts/Grid/Row.tsx +68 -0
  480. package/src/layouts/Grid/index.ts +8 -0
  481. package/src/layouts/MasonryGrid/MasonryGrid.stories.tsx +388 -0
  482. package/src/layouts/MasonryGrid/MasonryGrid.tsx +406 -0
  483. package/src/layouts/MasonryGrid/MasonryGridItem.tsx +42 -0
  484. package/src/layouts/MasonryGrid/README.md +117 -0
  485. package/src/layouts/MasonryGrid/index.ts +4 -0
  486. package/src/layouts/index.ts +9 -0
  487. package/src/lib/README.md +89 -0
  488. package/src/lib/composables/index.ts +44 -0
  489. package/src/lib/composables/useAccordion.ts +129 -0
  490. package/src/lib/composables/useBadge.ts +42 -0
  491. package/src/lib/composables/useBreadcrumb.ts +74 -0
  492. package/src/lib/composables/useButton.ts +59 -0
  493. package/src/lib/composables/useCallout.ts +55 -0
  494. package/src/lib/composables/useCard.ts +155 -0
  495. package/src/lib/composables/useCheckbox.ts +70 -0
  496. package/src/lib/composables/useDataTable.ts +208 -0
  497. package/src/lib/composables/useDatePicker.ts +562 -0
  498. package/src/lib/composables/useDropdown.ts +272 -0
  499. package/src/lib/composables/useEdgePanel.ts +261 -0
  500. package/src/lib/composables/useForm.ts +62 -0
  501. package/src/lib/composables/useFormGroup.ts +51 -0
  502. package/src/lib/composables/useHero.ts +250 -0
  503. package/src/lib/composables/useInput.ts +58 -0
  504. package/src/lib/composables/useMessages.ts +77 -0
  505. package/src/lib/composables/useModal.ts +110 -0
  506. package/src/lib/composables/useNavbar.ts +288 -0
  507. package/src/lib/composables/usePagination.ts +101 -0
  508. package/src/lib/composables/usePhotoViewer.ts +904 -0
  509. package/src/lib/composables/usePopover.ts +354 -0
  510. package/src/lib/composables/useProgress.ts +74 -0
  511. package/src/lib/composables/useRadio.ts +47 -0
  512. package/src/lib/composables/useRating.ts +174 -0
  513. package/src/lib/composables/useRiver.ts +205 -0
  514. package/src/lib/composables/useSelect.ts +52 -0
  515. package/src/lib/composables/useSideMenu.ts +197 -0
  516. package/src/lib/composables/useSpinner.ts +42 -0
  517. package/src/lib/composables/useTextarea.ts +55 -0
  518. package/src/lib/composables/useTodo.ts +142 -0
  519. package/src/lib/constants/components.ts +1050 -0
  520. package/src/lib/constants/index.ts +4 -0
  521. package/src/lib/index.ts +11 -0
  522. package/src/lib/types/components.ts +2498 -0
  523. package/src/lib/types/index.ts +2 -0
  524. package/src/lib/utils/dom.ts +41 -0
  525. package/src/lib/utils/icons.ts +74 -0
  526. package/src/lib/utils/index.ts +7 -0
  527. package/src/lib/utils/useForkRef.ts +36 -0
  528. package/src/styles/01-settings/_index.scss +64 -0
  529. package/src/styles/01-settings/_settings.accordion.scss +29 -0
  530. package/src/styles/01-settings/_settings.animations.scss +2 -0
  531. package/src/styles/01-settings/_settings.avatar-group.scss +20 -0
  532. package/src/styles/01-settings/_settings.avatar.scss +46 -0
  533. package/src/styles/01-settings/_settings.badge.scss +12 -0
  534. package/src/styles/01-settings/_settings.border-radius.scss +12 -0
  535. package/src/styles/01-settings/_settings.border.scss +14 -0
  536. package/src/styles/01-settings/_settings.box-shadow.scss +28 -0
  537. package/src/styles/01-settings/_settings.breadcrumb.scss +19 -0
  538. package/src/styles/01-settings/_settings.breakpoints.scss +8 -0
  539. package/src/styles/01-settings/_settings.btn-group.scss +1 -0
  540. package/src/styles/01-settings/_settings.button.scss +81 -0
  541. package/src/styles/01-settings/_settings.callout.scss +61 -0
  542. package/src/styles/01-settings/_settings.card.scss +36 -0
  543. package/src/styles/01-settings/_settings.checkbox-group.scss +2 -0
  544. package/src/styles/01-settings/_settings.checkbox.scss +20 -0
  545. package/src/styles/01-settings/_settings.color-mode.scss +5 -0
  546. package/src/styles/01-settings/_settings.colors.scss +252 -0
  547. package/src/styles/01-settings/_settings.config.scss +4 -0
  548. package/src/styles/01-settings/_settings.countdown.scss +15 -0
  549. package/src/styles/01-settings/_settings.data-table.scss +52 -0
  550. package/src/styles/01-settings/_settings.datepicker.scss +44 -0
  551. package/src/styles/01-settings/_settings.dropdown.scss +38 -0
  552. package/src/styles/01-settings/_settings.edge-panel.scss +17 -0
  553. package/src/styles/01-settings/_settings.fonts.scss +17 -0
  554. package/src/styles/01-settings/_settings.form-group.scss +11 -0
  555. package/src/styles/01-settings/_settings.form.scss +3 -0
  556. package/src/styles/01-settings/_settings.grid.scss +15 -0
  557. package/src/styles/01-settings/_settings.hero.scss +30 -0
  558. package/src/styles/01-settings/_settings.input.scss +38 -0
  559. package/src/styles/01-settings/_settings.link.scss +12 -0
  560. package/src/styles/01-settings/_settings.list-group.scss +14 -0
  561. package/src/styles/01-settings/_settings.list.scss +10 -0
  562. package/src/styles/01-settings/_settings.maps.scss +278 -0
  563. package/src/styles/01-settings/_settings.masonry-grid.scss +17 -0
  564. package/src/styles/01-settings/_settings.menu.scss +35 -0
  565. package/src/styles/01-settings/_settings.messages.scss +71 -0
  566. package/src/styles/01-settings/_settings.modal.scss +31 -0
  567. package/src/styles/01-settings/_settings.nav.scss +18 -0
  568. package/src/styles/01-settings/_settings.navbar.scss +46 -0
  569. package/src/styles/01-settings/_settings.pagination.scss +29 -0
  570. package/src/styles/01-settings/_settings.photoviewer.scss +35 -0
  571. package/src/styles/01-settings/_settings.popover.scss +13 -0
  572. package/src/styles/01-settings/_settings.position.scss +7 -0
  573. package/src/styles/01-settings/_settings.progress.scss +15 -0
  574. package/src/styles/01-settings/_settings.rating.scss +8 -0
  575. package/src/styles/01-settings/_settings.river.scss +34 -0
  576. package/src/styles/01-settings/_settings.sectionintro.scss +21 -0
  577. package/src/styles/01-settings/_settings.select.scss +32 -0
  578. package/src/styles/01-settings/_settings.side-menu.scss +64 -0
  579. package/src/styles/01-settings/_settings.skeleton.scss +14 -0
  580. package/src/styles/01-settings/_settings.spacing.scss +68 -0
  581. package/src/styles/01-settings/_settings.spinner.scss +13 -0
  582. package/src/styles/01-settings/_settings.steps.scss +26 -0
  583. package/src/styles/01-settings/_settings.tabs.scss +28 -0
  584. package/src/styles/01-settings/_settings.testimonials.scss +18 -0
  585. package/src/styles/01-settings/_settings.todo.scss +50 -0
  586. package/src/styles/01-settings/_settings.toggle.scss +34 -0
  587. package/src/styles/01-settings/_settings.tooltip.scss +19 -0
  588. package/src/styles/01-settings/_settings.typography.scss +93 -0
  589. package/src/styles/01-settings/_settings.upload.scss +70 -0
  590. package/src/styles/01-settings/_settings.z-layers.scss +9 -0
  591. package/src/styles/02-tools/_index.scss +20 -0
  592. package/src/styles/02-tools/_tools.animations.scss +19 -0
  593. package/src/styles/02-tools/_tools.border-radius.scss +78 -0
  594. package/src/styles/02-tools/_tools.breakpoints.scss +48 -0
  595. package/src/styles/02-tools/_tools.button.scss +115 -0
  596. package/src/styles/02-tools/_tools.clearfix.scss +10 -0
  597. package/src/styles/02-tools/_tools.color-functions.scss +28 -0
  598. package/src/styles/02-tools/_tools.color-mode.scss +22 -0
  599. package/src/styles/02-tools/_tools.event.scss +22 -0
  600. package/src/styles/02-tools/_tools.grid.scss +76 -0
  601. package/src/styles/02-tools/_tools.hidden-visually.scss +32 -0
  602. package/src/styles/02-tools/_tools.hidden.scss +2 -0
  603. package/src/styles/02-tools/_tools.map-loop.scss +31 -0
  604. package/src/styles/02-tools/_tools.media-queries.scss +69 -0
  605. package/src/styles/02-tools/_tools.object-fit.scss +4 -0
  606. package/src/styles/02-tools/_tools.placeholder.scss +17 -0
  607. package/src/styles/02-tools/_tools.rem.scss +5 -0
  608. package/src/styles/02-tools/_tools.size.scss +8 -0
  609. package/src/styles/02-tools/_tools.spacing.scss +140 -0
  610. package/src/styles/02-tools/_tools.to-rgb.scss +9 -0
  611. package/src/styles/02-tools/_tools.transition.scss +50 -0
  612. package/src/styles/02-tools/_tools.utilities.scss +14 -0
  613. package/src/styles/02-tools/_tools.utility-api.scss +144 -0
  614. package/src/styles/03-generic/_generic.fonts.scss +24 -0
  615. package/src/styles/03-generic/_generic.reset.scss +402 -0
  616. package/src/styles/03-generic/_generic.root.scss +184 -0
  617. package/src/styles/03-generic/_generic.selection.scss +15 -0
  618. package/src/styles/03-generic/_index.scss +5 -0
  619. package/src/styles/04-elements/_elements.all.scss +16 -0
  620. package/src/styles/04-elements/_elements.body.scss +15 -0
  621. package/src/styles/04-elements/_elements.heading.scss +54 -0
  622. package/src/styles/04-elements/_elements.html.scss +9 -0
  623. package/src/styles/04-elements/_elements.links.scss +11 -0
  624. package/src/styles/04-elements/_index.scss +6 -0
  625. package/src/styles/05-objects/_index.scss +4 -0
  626. package/src/styles/05-objects/_objects.container.scss +36 -0
  627. package/src/styles/05-objects/_objects.grid.scss +25 -0
  628. package/src/styles/05-objects/_objects.masonry-grid.scss +96 -0
  629. package/src/styles/06-components/_components.accordion.scss +109 -0
  630. package/src/styles/06-components/_components.avatar-group.scss +85 -0
  631. package/src/styles/06-components/_components.avatar.scss +101 -0
  632. package/src/styles/06-components/_components.badge.scss +62 -0
  633. package/src/styles/06-components/_components.breadcrumb.scss +80 -0
  634. package/src/styles/06-components/_components.btn-group.scss +35 -0
  635. package/src/styles/06-components/_components.button.scss +134 -0
  636. package/src/styles/06-components/_components.callout.scss +272 -0
  637. package/src/styles/06-components/_components.card.scss +148 -0
  638. package/src/styles/06-components/_components.checkbox-group.scss +17 -0
  639. package/src/styles/06-components/_components.checkbox.scss +135 -0
  640. package/src/styles/06-components/_components.color-mode-toggle.scss +36 -0
  641. package/src/styles/06-components/_components.countdown.scss +63 -0
  642. package/src/styles/06-components/_components.data-table.scss +183 -0
  643. package/src/styles/06-components/_components.datepicker.scss +546 -0
  644. package/src/styles/06-components/_components.dropdown.scss +255 -0
  645. package/src/styles/06-components/_components.edge-panel.scss +350 -0
  646. package/src/styles/06-components/_components.form-group.scss +78 -0
  647. package/src/styles/06-components/_components.form.scss +21 -0
  648. package/src/styles/06-components/_components.hero.scss +147 -0
  649. package/src/styles/06-components/_components.icon.scss +80 -0
  650. package/src/styles/06-components/_components.image-gallery.scss +72 -0
  651. package/src/styles/06-components/_components.input.scss +107 -0
  652. package/src/styles/06-components/_components.list-group.scss +63 -0
  653. package/src/styles/06-components/_components.list.scss +57 -0
  654. package/src/styles/06-components/_components.menu.scss +239 -0
  655. package/src/styles/06-components/_components.messages.scss +332 -0
  656. package/src/styles/06-components/_components.modal.scss +153 -0
  657. package/src/styles/06-components/_components.nav.scss +172 -0
  658. package/src/styles/06-components/_components.navbar.scss +310 -0
  659. package/src/styles/06-components/_components.pagination.scss +155 -0
  660. package/src/styles/06-components/_components.photoviewer.scss +878 -0
  661. package/src/styles/06-components/_components.popover.scss +99 -0
  662. package/src/styles/06-components/_components.product-review.scss +128 -0
  663. package/src/styles/06-components/_components.progress.scss +43 -0
  664. package/src/styles/06-components/_components.rating.scss +161 -0
  665. package/src/styles/06-components/_components.river.scss +216 -0
  666. package/src/styles/06-components/_components.sectionintro.scss +163 -0
  667. package/src/styles/06-components/_components.select.scss +125 -0
  668. package/src/styles/06-components/_components.side-menu.scss +234 -0
  669. package/src/styles/06-components/_components.skeleton.scss +55 -0
  670. package/src/styles/06-components/_components.spinner.scss +45 -0
  671. package/src/styles/06-components/_components.steps.scss +99 -0
  672. package/src/styles/06-components/_components.tabs.scss +124 -0
  673. package/src/styles/06-components/_components.testimonials.scss +65 -0
  674. package/src/styles/06-components/_components.todo.scss +163 -0
  675. package/src/styles/06-components/_components.toggle.scss +100 -0
  676. package/src/styles/06-components/_components.tooltip.scss +136 -0
  677. package/src/styles/06-components/_components.upload.scss +250 -0
  678. package/src/styles/06-components/_index.scss +49 -0
  679. package/src/styles/99-utilities/_index.scss +21 -0
  680. package/src/styles/99-utilities/_utilities.background.scss +28 -0
  681. package/src/styles/99-utilities/_utilities.border.scss +157 -0
  682. package/src/styles/99-utilities/_utilities.clearfix.scss +5 -0
  683. package/src/styles/99-utilities/_utilities.display.scss +13 -0
  684. package/src/styles/99-utilities/_utilities.flex.scss +109 -0
  685. package/src/styles/99-utilities/_utilities.link.scss +96 -0
  686. package/src/styles/99-utilities/_utilities.object-fit.scss +17 -0
  687. package/src/styles/99-utilities/_utilities.opacity.scss +16 -0
  688. package/src/styles/99-utilities/_utilities.overflow.scss +20 -0
  689. package/src/styles/99-utilities/_utilities.position.scss +40 -0
  690. package/src/styles/99-utilities/_utilities.scss +42 -0
  691. package/src/styles/99-utilities/_utilities.shadow.scss +19 -0
  692. package/src/styles/99-utilities/_utilities.sizes.scss +81 -0
  693. package/src/styles/99-utilities/_utilities.spacing.scss +188 -0
  694. package/src/styles/99-utilities/_utilities.text.scss +87 -0
  695. package/src/styles/99-utilities/_utilities.visibility.scss +13 -0
  696. package/src/styles/99-utilities/_utilities.visually-hidden.scss +5 -0
  697. package/src/styles/99-utilities/_utilities.z-index.scss +11 -0
  698. package/src/styles/index.scss +12 -0
  699. package/tsconfig.json +74 -0
  700. package/webpack.config.js +463 -0
  701. package/dist/types/components/Navbar/Nav.d.ts +0 -5
  702. package/dist/types/components/Navbar/NavItem.d.ts +0 -5
  703. package/dist/types/components/Navbar/Navbar.d.ts +0 -5
  704. package/dist/types/components/Navbar/index.d.ts +0 -6
@@ -0,0 +1,781 @@
1
+ import { DATA_TABLE_SELECTORS } from '../../../lib/constants/components';
2
+ import { useDataTable } from '../../../lib/composables/useDataTable';
3
+ import Pagination from '../../Pagination/scripts';
4
+
5
+ export { useDataTable };
6
+
7
+ /**
8
+ * DataTable Column Definition
9
+ */
10
+ export interface DataTableColumn {
11
+ key: string;
12
+ title: string;
13
+ sortable?: boolean;
14
+ filterable?: boolean;
15
+ render?: (value: any, row: any) => string | HTMLElement;
16
+ width?: string;
17
+ }
18
+
19
+ /**
20
+ * DataTable Options
21
+ */
22
+ export interface DataTableOptions {
23
+ sortable?: boolean;
24
+ filterable?: boolean;
25
+ paginated?: boolean;
26
+ pageSize?: number;
27
+ striped?: boolean;
28
+ bordered?: boolean;
29
+ dense?: boolean;
30
+ emptyMessage?: string;
31
+ onRowClick?: (row: any) => void;
32
+ loading?: boolean;
33
+ }
34
+
35
+ /**
36
+ * Sort Configuration
37
+ */
38
+ interface SortConfig {
39
+ key: string;
40
+ direction: 'asc' | 'desc';
41
+ }
42
+
43
+ /**
44
+ * Interface for HTMLElement with attached pagination instance
45
+ */
46
+ interface PaginationElement extends HTMLElement {
47
+ paginationInstance?: Pagination;
48
+ }
49
+
50
+ /**
51
+ * DataTable Class
52
+ * Vanilla JS implementation of the DataTable component
53
+ */
54
+ export class DataTable {
55
+ // Default configuration
56
+ private static defaults: DataTableOptions = {
57
+ sortable: false,
58
+ filterable: false,
59
+ paginated: false,
60
+ pageSize: 10,
61
+ striped: false,
62
+ bordered: false,
63
+ dense: false,
64
+ emptyMessage: 'No data available',
65
+ };
66
+
67
+ // DOM elements
68
+ private element: HTMLElement;
69
+ private tableElement: HTMLTableElement | null = null;
70
+ private searchInput: HTMLInputElement | null = null;
71
+ private paginationElement: PaginationElement | null = null;
72
+
73
+ // State
74
+ private data: any[] = [];
75
+ private columns: DataTableColumn[] = [];
76
+ private sortConfig: SortConfig | null = null;
77
+ private currentPage: number = 1;
78
+ private searchQuery: string = '';
79
+
80
+ // Configuration
81
+ private options: DataTableOptions;
82
+
83
+ /**
84
+ * Constructor
85
+ * @param element - DOM element or selector
86
+ * @param data - Data array
87
+ * @param columns - Column definitions
88
+ * @param options - Configuration options
89
+ */
90
+ constructor(
91
+ element: string | HTMLElement,
92
+ data: any[] = [],
93
+ columns: DataTableColumn[] = [],
94
+ options: DataTableOptions = {}
95
+ ) {
96
+ // Get element reference
97
+ this.element =
98
+ typeof element === 'string' ? (document.querySelector(element) as HTMLElement) : element;
99
+
100
+ if (!this.element) {
101
+ throw new Error('DataTable: Element not found');
102
+ }
103
+
104
+ // Store data and columns
105
+ this.data = data;
106
+ this.columns = columns;
107
+
108
+ // Merge default options with provided options
109
+ this.options = { ...DataTable.defaults, ...options };
110
+
111
+ // Initialize the component
112
+ this._initialize();
113
+ }
114
+
115
+ /**
116
+ * Initialize the component
117
+ * @private
118
+ */
119
+ private _initialize(): void {
120
+ // Create container structure
121
+ this._createStructure();
122
+
123
+ // Render table
124
+ this._renderTable();
125
+
126
+ // Bind events
127
+ this._bindEvents();
128
+
129
+ // Add modifier classes
130
+ this._addModifierClasses();
131
+ }
132
+
133
+ /**
134
+ * Create container structure
135
+ * @private
136
+ */
137
+ private _createStructure(): void {
138
+ // Clear element
139
+ this.element.innerHTML = '';
140
+
141
+ // Add container class
142
+ this.element.classList.add('c-data-table-container');
143
+
144
+ // Create toolbar if filterable
145
+ if (this.options.filterable) {
146
+ const toolbar = document.createElement('div');
147
+ toolbar.className = 'c-data-table-toolbar';
148
+
149
+ const searchContainer = document.createElement('div');
150
+ searchContainer.className = 'c-data-table-search';
151
+
152
+ this.searchInput = document.createElement('input');
153
+ this.searchInput.type = 'text';
154
+ this.searchInput.placeholder = 'Search...';
155
+ this.searchInput.className = 'c-data-table-search__input c-input';
156
+ this.searchInput.setAttribute('aria-label', 'Search table');
157
+
158
+ searchContainer.appendChild(this.searchInput);
159
+ toolbar.appendChild(searchContainer);
160
+ this.element.appendChild(toolbar);
161
+ }
162
+
163
+ // Create table wrapper
164
+ const tableWrapper = document.createElement('div');
165
+ tableWrapper.className = 'c-data-table-wrapper';
166
+
167
+ // Create table
168
+ this.tableElement = document.createElement('table');
169
+ this.tableElement.className = 'c-data-table';
170
+
171
+ tableWrapper.appendChild(this.tableElement);
172
+ this.element.appendChild(tableWrapper);
173
+
174
+ // Create pagination container if needed
175
+ if (this.options.paginated) {
176
+ const paginationContainer = document.createElement('div');
177
+ paginationContainer.className = 'c-data-table__pagination-container';
178
+
179
+ this.paginationElement = document.createElement('nav') as PaginationElement;
180
+ this.paginationElement.className = 'c-pagination c-pagination--sm';
181
+ this.paginationElement.setAttribute('aria-label', 'Data table pagination');
182
+ this.paginationElement.setAttribute('data-component', 'pagination');
183
+ this.paginationElement.setAttribute('data-current-page', '1');
184
+ this.paginationElement.setAttribute('data-total-pages', '1');
185
+ this.paginationElement.setAttribute('data-show-first-last-buttons', 'true');
186
+ this.paginationElement.setAttribute('data-show-prev-next-buttons', 'true');
187
+
188
+ paginationContainer.appendChild(this.paginationElement);
189
+ this.element.appendChild(paginationContainer);
190
+ }
191
+ }
192
+
193
+ /**
194
+ * Add modifier classes based on options
195
+ * @private
196
+ */
197
+ private _addModifierClasses(): void {
198
+ if (!this.tableElement) return;
199
+
200
+ if (this.options.striped) {
201
+ this.tableElement.classList.add('c-data-table--striped');
202
+ }
203
+
204
+ if (this.options.bordered) {
205
+ this.tableElement.classList.add('c-data-table--bordered');
206
+ }
207
+
208
+ if (this.options.dense) {
209
+ this.tableElement.classList.add('c-data-table--dense');
210
+ }
211
+ }
212
+
213
+ /**
214
+ * Bind event listeners
215
+ * @private
216
+ */
217
+ private _bindEvents(): void {
218
+ // Search input events
219
+ if (this.searchInput) {
220
+ this.searchInput.addEventListener('input', this._handleSearch.bind(this));
221
+ }
222
+
223
+ // Sort header click events
224
+ if (this.options.sortable && this.tableElement) {
225
+ const headerCells = this.tableElement.querySelectorAll(DATA_TABLE_SELECTORS.HEADER_CELL);
226
+ headerCells.forEach(cell => {
227
+ const columnKey = cell.getAttribute('data-column-key');
228
+ if (columnKey) {
229
+ const column = this.columns.find(col => col.key === columnKey);
230
+ if (column && column.sortable !== false) {
231
+ cell.addEventListener('click', () => this._handleSort(columnKey));
232
+ }
233
+ }
234
+ });
235
+ }
236
+
237
+ // Row click events
238
+ if (this.options.onRowClick && this.tableElement) {
239
+ this.tableElement.addEventListener('click', event => {
240
+ const target = event.target as HTMLElement;
241
+ const row = target.closest(DATA_TABLE_SELECTORS.ROW) as HTMLElement;
242
+ if (row) {
243
+ const rowIndex = parseInt(row.getAttribute('data-row-index') || '-1', 10);
244
+ if (rowIndex >= 0) {
245
+ const rowData = this._getDisplayData()[rowIndex];
246
+ if (rowData && this.options.onRowClick) {
247
+ this.options.onRowClick(rowData);
248
+ }
249
+ }
250
+ }
251
+ });
252
+ }
253
+ }
254
+
255
+ /**
256
+ * Handle search input
257
+ * @private
258
+ */
259
+ private _handleSearch(event: Event): void {
260
+ const input = event.target as HTMLInputElement;
261
+ this.searchQuery = input.value;
262
+ this.currentPage = 1; // Reset to first page
263
+ this._renderTable();
264
+ }
265
+
266
+ /**
267
+ * Handle sort header click
268
+ * @private
269
+ */
270
+ private _handleSort(key: string): void {
271
+ if (!this.options.sortable) return;
272
+
273
+ let direction: 'asc' | 'desc' = 'asc';
274
+
275
+ if (this.sortConfig && this.sortConfig.key === key) {
276
+ direction = this.sortConfig.direction === 'asc' ? 'desc' : 'asc';
277
+ }
278
+
279
+ this.sortConfig = { key, direction };
280
+ this._renderTable();
281
+
282
+ // Dispatch custom event
283
+ this.element.dispatchEvent(
284
+ new CustomEvent('data-table:sort', {
285
+ bubbles: true,
286
+ detail: { sortConfig: this.sortConfig },
287
+ })
288
+ );
289
+ }
290
+
291
+ /**
292
+ * Handle page change
293
+ * @private
294
+ */
295
+ private _handlePageChange(page: number): void {
296
+ if (page < 1 || page > this._getTotalPages()) return;
297
+
298
+ this.currentPage = page;
299
+ this._renderTable();
300
+
301
+ // Dispatch custom event
302
+ this.element.dispatchEvent(
303
+ new CustomEvent('data-table:page', {
304
+ bubbles: true,
305
+ detail: { page: this.currentPage },
306
+ })
307
+ );
308
+ }
309
+
310
+ /**
311
+ * Get filtered data based on search query
312
+ * @private
313
+ */
314
+ private _getFilteredData(): any[] {
315
+ if (!this.searchQuery) return this.data;
316
+
317
+ const lowercaseQuery = this.searchQuery.toLowerCase();
318
+
319
+ return this.data.filter(row => {
320
+ return this.columns.some(column => {
321
+ const value = row[column.key];
322
+ if (value == null) return false;
323
+ return String(value).toLowerCase().includes(lowercaseQuery);
324
+ });
325
+ });
326
+ }
327
+
328
+ /**
329
+ * Get sorted data
330
+ * @private
331
+ */
332
+ private _getSortedData(): any[] {
333
+ const filteredData = this._getFilteredData();
334
+
335
+ if (!this.sortConfig || !this.options.sortable) return filteredData;
336
+
337
+ return [...filteredData].sort((a, b) => {
338
+ const aValue = a[this.sortConfig!.key];
339
+ const bValue = b[this.sortConfig!.key];
340
+
341
+ if (aValue == null) return this.sortConfig!.direction === 'asc' ? -1 : 1;
342
+ if (bValue == null) return this.sortConfig!.direction === 'asc' ? 1 : -1;
343
+
344
+ if (typeof aValue === 'string' && typeof bValue === 'string') {
345
+ return this.sortConfig!.direction === 'asc'
346
+ ? aValue.localeCompare(bValue)
347
+ : bValue.localeCompare(aValue);
348
+ }
349
+
350
+ return this.sortConfig!.direction === 'asc'
351
+ ? aValue > bValue
352
+ ? 1
353
+ : -1
354
+ : aValue > bValue
355
+ ? -1
356
+ : 1;
357
+ });
358
+ }
359
+
360
+ /**
361
+ * Get paginated data
362
+ * @private
363
+ */
364
+ private _getPaginatedData(): any[] {
365
+ const sortedData = this._getSortedData();
366
+
367
+ if (!this.options.paginated) return sortedData;
368
+
369
+ const startIndex = (this.currentPage - 1) * (this.options.pageSize || 10);
370
+ return sortedData.slice(startIndex, startIndex + (this.options.pageSize || 10));
371
+ }
372
+
373
+ /**
374
+ * Get display data (filtered, sorted, paginated)
375
+ * @private
376
+ */
377
+ private _getDisplayData(): any[] {
378
+ return this._getPaginatedData();
379
+ }
380
+
381
+ /**
382
+ * Get total pages
383
+ * @private
384
+ */
385
+ private _getTotalPages(): number {
386
+ if (!this.options.paginated) return 1;
387
+
388
+ const filteredData = this._getFilteredData();
389
+ return Math.max(1, Math.ceil(filteredData.length / (this.options.pageSize || 10)));
390
+ }
391
+
392
+ /**
393
+ * Render table
394
+ * @private
395
+ */
396
+ private _renderTable(): void {
397
+ if (!this.tableElement) return;
398
+
399
+ // Clear table
400
+ this.tableElement.innerHTML = '';
401
+
402
+ // Render header
403
+ this._renderHeader();
404
+
405
+ // Check if loading
406
+ if (this.options.loading) {
407
+ const tbody = document.createElement('tbody');
408
+ const tr = document.createElement('tr');
409
+ const td = document.createElement('td');
410
+
411
+ td.className = 'c-data-table__loading-cell';
412
+ td.colSpan = this.columns.length;
413
+
414
+ const loadingContainer = document.createElement('div');
415
+ loadingContainer.className = 'c-data-table__loading-indicator';
416
+
417
+ loadingContainer.appendChild(this._createSpinner());
418
+
419
+ td.appendChild(loadingContainer);
420
+ tr.appendChild(td);
421
+ tbody.appendChild(tr);
422
+ this.tableElement.appendChild(tbody);
423
+ } else {
424
+ // Render body
425
+ this._renderBody();
426
+ }
427
+
428
+ // Render pagination
429
+ if (this.options.paginated) {
430
+ this._renderPagination();
431
+ }
432
+ }
433
+
434
+ /**
435
+ * Render table header
436
+ * @private
437
+ */
438
+ private _renderHeader(): void {
439
+ if (!this.tableElement) return;
440
+
441
+ const thead = document.createElement('thead');
442
+ thead.className = 'c-data-table__header';
443
+
444
+ const tr = document.createElement('tr');
445
+
446
+ this.columns.forEach(column => {
447
+ const th = document.createElement('th');
448
+ th.className = 'c-data-table__header-cell';
449
+
450
+ if (column.sortable !== false && this.options.sortable) {
451
+ th.classList.add('c-data-table__header-cell--sortable');
452
+ th.setAttribute('data-column-key', column.key);
453
+
454
+ if (this.sortConfig && this.sortConfig.key === column.key) {
455
+ th.setAttribute(
456
+ 'aria-sort',
457
+ this.sortConfig.direction === 'asc' ? 'ascending' : 'descending'
458
+ );
459
+ }
460
+ }
461
+
462
+ if (column.width) {
463
+ th.style.width = column.width;
464
+ }
465
+
466
+ const content = document.createElement('div');
467
+ content.className = 'c-data-table__header-content';
468
+
469
+ const title = document.createElement('span');
470
+ title.textContent = column.title;
471
+ content.appendChild(title);
472
+
473
+ if (column.sortable !== false && this.options.sortable) {
474
+ const sortIcon = document.createElement('span');
475
+ sortIcon.className = 'c-data-table__sort-icon';
476
+
477
+ if (this.sortConfig && this.sortConfig.key === column.key) {
478
+ // Create SVG icon
479
+ const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
480
+ svg.setAttribute('width', '16');
481
+ svg.setAttribute('height', '16');
482
+ svg.setAttribute('viewBox', '0 0 256 256');
483
+
484
+ const path = document.createElementNS('http://www.w3.org/2000/svg', 'path');
485
+
486
+ if (this.sortConfig.direction === 'asc') {
487
+ // CaretUp icon
488
+ path.setAttribute('d', 'M128 90.5L51.6 170l-6.5-5.4l76.4-79.5l6.5 5.4z');
489
+ path.setAttribute('fill', 'currentColor');
490
+ svg.appendChild(path);
491
+
492
+ const path2 = document.createElementNS('http://www.w3.org/2000/svg', 'path');
493
+ path2.setAttribute('d', 'M128 90.5l76.4 79.5l-6.5 5.4l-76.4-79.5l6.5-5.4z');
494
+ path2.setAttribute('fill', 'currentColor');
495
+ svg.appendChild(path2);
496
+ } else {
497
+ // CaretDown icon
498
+ path.setAttribute('d', 'M128 165.5L51.6 86l-6.5 5.4l76.4 79.5l6.5-5.4z');
499
+ path.setAttribute('fill', 'currentColor');
500
+ svg.appendChild(path);
501
+
502
+ const path2 = document.createElementNS('http://www.w3.org/2000/svg', 'path');
503
+ path2.setAttribute('d', 'M128 165.5l76.4-79.5l-6.5-5.4l-76.4 79.5l6.5 5.4z');
504
+ path2.setAttribute('fill', 'currentColor');
505
+ svg.appendChild(path2);
506
+ }
507
+
508
+ sortIcon.appendChild(svg);
509
+ }
510
+
511
+ content.appendChild(sortIcon);
512
+ }
513
+
514
+ th.appendChild(content);
515
+ tr.appendChild(th);
516
+ });
517
+
518
+ thead.appendChild(tr);
519
+ this.tableElement.appendChild(thead);
520
+ }
521
+
522
+ /**
523
+ * Render table body
524
+ * @private
525
+ */
526
+ private _renderBody(): void {
527
+ if (!this.tableElement) return;
528
+
529
+ const tbody = document.createElement('tbody');
530
+ const displayData = this._getDisplayData();
531
+
532
+ if (displayData.length === 0) {
533
+ const tr = document.createElement('tr');
534
+ const td = document.createElement('td');
535
+ td.className = 'c-data-table__empty-cell';
536
+ td.colSpan = this.columns.length;
537
+ td.textContent = this.options.emptyMessage || 'No data available';
538
+ tr.appendChild(td);
539
+ tbody.appendChild(tr);
540
+ } else {
541
+ displayData.forEach((row, rowIndex) => {
542
+ const tr = document.createElement('tr');
543
+ tr.className = 'c-data-table__row';
544
+ tr.setAttribute('data-row-index', rowIndex.toString());
545
+
546
+ if (this.options.onRowClick) {
547
+ tr.setAttribute('role', 'button');
548
+ tr.tabIndex = 0;
549
+ }
550
+
551
+ this.columns.forEach(column => {
552
+ const td = document.createElement('td');
553
+ td.className = 'c-data-table__cell';
554
+
555
+ const value = row[column.key];
556
+
557
+ if (column.render) {
558
+ const rendered = column.render(value, row);
559
+ if (typeof rendered === 'string') {
560
+ td.textContent = rendered;
561
+ } else {
562
+ td.appendChild(rendered);
563
+ }
564
+ } else {
565
+ td.textContent = value != null ? String(value) : '';
566
+ }
567
+
568
+ tr.appendChild(td);
569
+ });
570
+
571
+ tbody.appendChild(tr);
572
+ });
573
+ }
574
+
575
+ this.tableElement.appendChild(tbody);
576
+ }
577
+
578
+ /**
579
+ * Create loading spinner
580
+ * @private
581
+ */
582
+ private _createSpinner(): HTMLElement {
583
+ const spinner = document.createElement('div');
584
+ spinner.className = 'c-spinner c-spinner--primary';
585
+ spinner.setAttribute('role', 'status');
586
+
587
+ const srText = document.createElement('span');
588
+ srText.className = 'u-visually-hidden';
589
+ srText.textContent = 'Loading...';
590
+
591
+ spinner.appendChild(srText);
592
+ return spinner;
593
+ }
594
+
595
+ /**
596
+ * Render pagination
597
+ * @private
598
+ */
599
+ private _renderPagination(): void {
600
+ if (!this.paginationElement) return;
601
+
602
+ const totalPages = this._getTotalPages();
603
+
604
+ if (totalPages <= 1) {
605
+ this.paginationElement.style.display = 'none';
606
+ return;
607
+ } else {
608
+ this.paginationElement.style.display = '';
609
+ }
610
+
611
+ // Update pagination data attributes
612
+ this.paginationElement.setAttribute('data-current-page', String(this.currentPage));
613
+ this.paginationElement.setAttribute('data-total-pages', String(totalPages));
614
+
615
+ // Initialize or update Pagination component
616
+ if (!this.paginationElement.paginationInstance) {
617
+ // Create a new instance if it doesn't exist
618
+ const paginationInstance = new Pagination(this.paginationElement, {
619
+ currentPage: this.currentPage,
620
+ totalPages: totalPages,
621
+ siblingCount: 1,
622
+ showFirstLastButtons: true,
623
+ showPrevNextButtons: true,
624
+ size: 'sm',
625
+ onPageChange: (page: number) => this._handlePageChange(page),
626
+ });
627
+
628
+ // Store the instance in a property on the element
629
+ Object.defineProperty(this.paginationElement, 'paginationInstance', {
630
+ value: paginationInstance,
631
+ writable: true,
632
+ configurable: true,
633
+ });
634
+ } else {
635
+ // Update existing instance
636
+ this.paginationElement.paginationInstance.update({
637
+ currentPage: this.currentPage,
638
+ totalPages: totalPages,
639
+ });
640
+ }
641
+ }
642
+
643
+ /**
644
+ * Update data
645
+ * @public
646
+ */
647
+ public updateData(data: any[]): void {
648
+ this.data = data;
649
+ this.currentPage = 1; // Reset to first page
650
+ this._renderTable();
651
+
652
+ // Dispatch custom event
653
+ this.element.dispatchEvent(
654
+ new CustomEvent('data-table:update', {
655
+ bubbles: true,
656
+ detail: { data },
657
+ })
658
+ );
659
+ }
660
+
661
+ /**
662
+ * Update columns
663
+ * @public
664
+ */
665
+ public updateColumns(columns: DataTableColumn[]): void {
666
+ this.columns = columns;
667
+ this._renderTable();
668
+
669
+ // Dispatch custom event
670
+ this.element.dispatchEvent(
671
+ new CustomEvent('data-table:update', {
672
+ bubbles: true,
673
+ detail: { columns },
674
+ })
675
+ );
676
+ }
677
+
678
+ /**
679
+ * Sort by column
680
+ * @public
681
+ */
682
+ public sortBy(key: string, direction: 'asc' | 'desc' = 'asc'): void {
683
+ if (!this.options.sortable) return;
684
+
685
+ this.sortConfig = { key, direction };
686
+ this._renderTable();
687
+
688
+ // Dispatch custom event
689
+ this.element.dispatchEvent(
690
+ new CustomEvent('data-table:sort', {
691
+ bubbles: true,
692
+ detail: { sortConfig: this.sortConfig },
693
+ })
694
+ );
695
+ }
696
+
697
+ /**
698
+ * Set page
699
+ * @public
700
+ */
701
+ public setPage(page: number): void {
702
+ this._handlePageChange(page);
703
+ }
704
+
705
+ /**
706
+ * Search
707
+ * @public
708
+ */
709
+ public search(query: string): void {
710
+ this.searchQuery = query;
711
+ this.currentPage = 1; // Reset to first page
712
+
713
+ if (this.searchInput) {
714
+ this.searchInput.value = query;
715
+ }
716
+
717
+ this._renderTable();
718
+
719
+ // Dispatch custom event
720
+ this.element.dispatchEvent(
721
+ new CustomEvent('data-table:search', {
722
+ bubbles: true,
723
+ detail: { query },
724
+ })
725
+ );
726
+ }
727
+
728
+ /**
729
+ * Destroy the component
730
+ * @public
731
+ */
732
+ public destroy(): void {
733
+ // Remove event listeners
734
+ if (this.searchInput) {
735
+ this.searchInput.removeEventListener('input', this._handleSearch.bind(this));
736
+ }
737
+
738
+ // Clean up pagination instance if it exists
739
+ if (this.paginationElement && this.paginationElement.paginationInstance) {
740
+ this.paginationElement.paginationInstance.destroy();
741
+ }
742
+
743
+ // Clear element
744
+ this.element.innerHTML = '';
745
+ this.element.classList.remove('c-data-table-container');
746
+
747
+ // Clear references
748
+ this.tableElement = null;
749
+ this.searchInput = null;
750
+ this.paginationElement = null;
751
+
752
+ // Dispatch event
753
+ this.element.dispatchEvent(new CustomEvent('data-table:destroy', { bubbles: true }));
754
+ }
755
+
756
+ /**
757
+ * Initialize all DataTables on the page
758
+ * @public
759
+ * @static
760
+ */
761
+ public static initializeAll(selector = '.c-data-table-container', options = {}): DataTable[] {
762
+ const elements = document.querySelectorAll(selector);
763
+ return Array.from(elements).map(element => {
764
+ // Try to get data from data attributes
765
+ const dataAttr = element.getAttribute('data-table-data');
766
+ const columnsAttr = element.getAttribute('data-table-columns');
767
+
768
+ let data: any[] = [];
769
+ let columns: DataTableColumn[] = [];
770
+
771
+ try {
772
+ if (dataAttr) data = JSON.parse(dataAttr);
773
+ if (columnsAttr) columns = JSON.parse(columnsAttr);
774
+ } catch (e) {
775
+ console.error('Error parsing DataTable data attributes:', e);
776
+ }
777
+
778
+ return new DataTable(element as HTMLElement, data, columns, options);
779
+ });
780
+ }
781
+ }