@rakeyshgidwani/roger-ui-bank-theme-stan-design 0.2.6 → 0.2.8

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 (468) hide show
  1. package/CHANGELOG.md +1 -1
  2. package/dist/components/ui/accessibility-demo.d.ts +259 -0
  3. package/dist/components/ui/accessibility-demo.esm.js +265 -0
  4. package/dist/components/ui/accessibility-demo.js +265 -0
  5. package/dist/components/ui/advanced-component-architecture-demo.d.ts +718 -0
  6. package/dist/components/ui/advanced-component-architecture-demo.esm.js +860 -0
  7. package/dist/components/ui/advanced-component-architecture-demo.js +860 -0
  8. package/dist/components/ui/advanced-transition-system-demo.d.ts +660 -0
  9. package/dist/components/ui/advanced-transition-system-demo.esm.js +624 -0
  10. package/dist/components/ui/advanced-transition-system-demo.js +624 -0
  11. package/dist/components/ui/advanced-transition-system.d.ts +391 -0
  12. package/dist/components/ui/advanced-transition-system.esm.js +351 -0
  13. package/dist/components/ui/advanced-transition-system.js +351 -0
  14. package/dist/components/ui/animation/animated-container.d.ts +162 -0
  15. package/dist/components/ui/animation/animated-container.esm.js +143 -0
  16. package/dist/components/ui/animation/animated-container.js +143 -0
  17. package/dist/components/ui/animation/index.d.ts +9 -0
  18. package/dist/components/ui/animation/index.esm.js +19 -0
  19. package/dist/components/ui/animation/index.js +19 -0
  20. package/dist/components/ui/animation/staggered-container.d.ts +64 -0
  21. package/dist/components/ui/animation/staggered-container.esm.js +59 -0
  22. package/dist/components/ui/animation/staggered-container.js +59 -0
  23. package/dist/components/ui/animation-demo.d.ts +238 -0
  24. package/dist/components/ui/animation-demo.esm.js +218 -0
  25. package/dist/components/ui/animation-demo.js +218 -0
  26. package/dist/components/ui/badge.d.ts +28 -0
  27. package/dist/components/ui/badge.esm.js +30 -0
  28. package/dist/components/ui/badge.js +30 -0
  29. package/dist/components/ui/battery-conscious-animation-demo.d.ts +561 -0
  30. package/dist/components/ui/battery-conscious-animation-demo.esm.js +533 -0
  31. package/dist/components/ui/battery-conscious-animation-demo.js +533 -0
  32. package/dist/components/ui/border-radius-shadow-demo.d.ts +183 -0
  33. package/dist/components/ui/border-radius-shadow-demo.esm.js +176 -0
  34. package/dist/components/ui/border-radius-shadow-demo.js +176 -0
  35. package/dist/components/ui/button.d.ts +33 -0
  36. package/dist/components/ui/button.esm.js +30 -0
  37. package/dist/components/ui/button.js +30 -0
  38. package/dist/components/ui/card.d.ts +205 -0
  39. package/dist/components/ui/card.esm.js +182 -0
  40. package/dist/components/ui/card.js +182 -0
  41. package/dist/components/ui/checkbox.d.ts +26 -0
  42. package/dist/components/ui/checkbox.esm.js +30 -0
  43. package/dist/components/ui/checkbox.js +30 -0
  44. package/dist/components/ui/color-preview.d.ts +402 -0
  45. package/dist/components/ui/color-preview.esm.js +388 -0
  46. package/dist/components/ui/color-preview.js +388 -0
  47. package/dist/components/ui/data-display/chart.d.ts +646 -0
  48. package/dist/components/ui/data-display/chart.esm.js +625 -0
  49. package/dist/components/ui/data-display/chart.js +625 -0
  50. package/dist/components/ui/data-display/data-grid-simple.d.ts +73 -0
  51. package/dist/components/ui/data-display/data-grid-simple.esm.js +76 -0
  52. package/dist/components/ui/data-display/data-grid-simple.js +76 -0
  53. package/dist/components/ui/data-display/data-grid.d.ts +670 -0
  54. package/dist/components/ui/data-display/data-grid.esm.js +667 -0
  55. package/dist/components/ui/data-display/data-grid.js +667 -0
  56. package/dist/components/ui/data-display/list.d.ts +448 -0
  57. package/dist/components/ui/data-display/list.esm.js +448 -0
  58. package/dist/components/ui/data-display/list.js +448 -0
  59. package/dist/components/ui/data-display/table.d.ts +472 -0
  60. package/dist/components/ui/data-display/table.esm.js +474 -0
  61. package/dist/components/ui/data-display/table.js +474 -0
  62. package/dist/components/ui/data-display/timeline.d.ts +433 -0
  63. package/dist/components/ui/data-display/timeline.esm.js +436 -0
  64. package/dist/components/ui/data-display/timeline.js +436 -0
  65. package/dist/components/ui/data-display/tree.d.ts +594 -0
  66. package/dist/components/ui/data-display/tree.esm.js +570 -0
  67. package/dist/components/ui/data-display/tree.js +570 -0
  68. package/dist/components/ui/data-display/types.d.ts +534 -0
  69. package/dist/components/ui/data-display/types.esm.js +511 -0
  70. package/dist/components/ui/data-display/types.js +511 -0
  71. package/dist/components/ui/enterprise-mobile-experience-demo.d.ts +735 -0
  72. package/dist/components/ui/enterprise-mobile-experience-demo.esm.js +699 -0
  73. package/dist/components/ui/enterprise-mobile-experience-demo.js +699 -0
  74. package/dist/components/ui/enterprise-mobile-experience.d.ts +461 -0
  75. package/dist/components/ui/enterprise-mobile-experience.esm.js +413 -0
  76. package/dist/components/ui/enterprise-mobile-experience.js +413 -0
  77. package/dist/components/ui/feedback/alert.d.ts +154 -0
  78. package/dist/components/ui/feedback/alert.esm.js +150 -0
  79. package/dist/components/ui/feedback/alert.js +150 -0
  80. package/dist/components/ui/feedback/progress.d.ts +288 -0
  81. package/dist/components/ui/feedback/progress.esm.js +269 -0
  82. package/dist/components/ui/feedback/progress.js +269 -0
  83. package/dist/components/ui/feedback/skeleton.d.ts +182 -0
  84. package/dist/components/ui/feedback/skeleton.esm.js +175 -0
  85. package/dist/components/ui/feedback/skeleton.js +175 -0
  86. package/dist/components/ui/feedback/toast.d.ts +277 -0
  87. package/dist/components/ui/feedback/toast.esm.js +256 -0
  88. package/dist/components/ui/feedback/toast.js +256 -0
  89. package/dist/components/ui/feedback/types.d.ts +123 -0
  90. package/dist/components/ui/feedback/types.esm.js +125 -0
  91. package/dist/components/ui/feedback/types.js +125 -0
  92. package/dist/components/ui/font-preview.d.ts +282 -0
  93. package/dist/components/ui/font-preview.esm.js +286 -0
  94. package/dist/components/ui/font-preview.js +286 -0
  95. package/dist/components/ui/form-demo.d.ts +544 -0
  96. package/dist/components/ui/form-demo.esm.js +516 -0
  97. package/dist/components/ui/form-demo.js +516 -0
  98. package/dist/components/ui/hardware-acceleration-demo.d.ts +540 -0
  99. package/dist/components/ui/hardware-acceleration-demo.esm.js +497 -0
  100. package/dist/components/ui/hardware-acceleration-demo.js +497 -0
  101. package/dist/components/ui/input.d.ts +33 -0
  102. package/dist/components/ui/input.esm.js +32 -0
  103. package/dist/components/ui/input.js +32 -0
  104. package/dist/components/ui/label.d.ts +13 -0
  105. package/dist/components/ui/label.esm.js +16 -0
  106. package/dist/components/ui/label.js +16 -0
  107. package/dist/components/ui/layout-demo.d.ts +352 -0
  108. package/dist/components/ui/layout-demo.esm.js +342 -0
  109. package/dist/components/ui/layout-demo.js +342 -0
  110. package/dist/components/ui/layouts/adaptive-layout.d.ts +132 -0
  111. package/dist/components/ui/layouts/adaptive-layout.esm.js +120 -0
  112. package/dist/components/ui/layouts/adaptive-layout.js +120 -0
  113. package/dist/components/ui/layouts/desktop-layout.d.ts +219 -0
  114. package/dist/components/ui/layouts/desktop-layout.esm.js +204 -0
  115. package/dist/components/ui/layouts/desktop-layout.js +204 -0
  116. package/dist/components/ui/layouts/index.d.ts +5 -0
  117. package/dist/components/ui/layouts/index.esm.js +10 -0
  118. package/dist/components/ui/layouts/index.js +10 -0
  119. package/dist/components/ui/layouts/mobile-layout.d.ts +158 -0
  120. package/dist/components/ui/layouts/mobile-layout.esm.js +152 -0
  121. package/dist/components/ui/layouts/mobile-layout.js +152 -0
  122. package/dist/components/ui/layouts/tablet-layout.d.ts +192 -0
  123. package/dist/components/ui/layouts/tablet-layout.esm.js +183 -0
  124. package/dist/components/ui/layouts/tablet-layout.js +183 -0
  125. package/dist/components/ui/mobile-form-validation.d.ts +439 -0
  126. package/dist/components/ui/mobile-form-validation.esm.js +418 -0
  127. package/dist/components/ui/mobile-form-validation.js +418 -0
  128. package/dist/components/ui/mobile-input-demo.d.ts +197 -0
  129. package/dist/components/ui/mobile-input-demo.esm.js +195 -0
  130. package/dist/components/ui/mobile-input-demo.js +195 -0
  131. package/dist/components/ui/mobile-input.d.ts +273 -0
  132. package/dist/components/ui/mobile-input.esm.js +216 -0
  133. package/dist/components/ui/mobile-input.js +216 -0
  134. package/dist/components/ui/mobile-skeleton-loading-demo.d.ts +628 -0
  135. package/dist/components/ui/mobile-skeleton-loading-demo.esm.js +621 -0
  136. package/dist/components/ui/mobile-skeleton-loading-demo.js +621 -0
  137. package/dist/components/ui/navigation/breadcrumb.d.ts +149 -0
  138. package/dist/components/ui/navigation/breadcrumb.esm.js +155 -0
  139. package/dist/components/ui/navigation/breadcrumb.js +155 -0
  140. package/dist/components/ui/navigation/index.d.ts +25 -0
  141. package/dist/components/ui/navigation/index.esm.js +14 -0
  142. package/dist/components/ui/navigation/index.js +14 -0
  143. package/dist/components/ui/navigation/menu.d.ts +366 -0
  144. package/dist/components/ui/navigation/menu.esm.js +360 -0
  145. package/dist/components/ui/navigation/menu.js +360 -0
  146. package/dist/components/ui/navigation/navigation-demo.d.ts +169 -0
  147. package/dist/components/ui/navigation/navigation-demo.esm.js +317 -0
  148. package/dist/components/ui/navigation/navigation-demo.js +317 -0
  149. package/dist/components/ui/navigation/pagination.d.ts +261 -0
  150. package/dist/components/ui/navigation/pagination.esm.js +260 -0
  151. package/dist/components/ui/navigation/pagination.js +260 -0
  152. package/dist/components/ui/navigation/sidebar.d.ts +375 -0
  153. package/dist/components/ui/navigation/sidebar.esm.js +369 -0
  154. package/dist/components/ui/navigation/sidebar.js +369 -0
  155. package/dist/components/ui/navigation/stepper.d.ts +294 -0
  156. package/dist/components/ui/navigation/stepper.esm.js +292 -0
  157. package/dist/components/ui/navigation/stepper.js +292 -0
  158. package/dist/components/ui/navigation/tabs.d.ts +196 -0
  159. package/dist/components/ui/navigation/tabs.esm.js +194 -0
  160. package/dist/components/ui/navigation/tabs.js +194 -0
  161. package/dist/components/ui/navigation/types.d.ts +293 -0
  162. package/dist/components/ui/navigation/types.esm.js +298 -0
  163. package/dist/components/ui/navigation/types.js +298 -0
  164. package/dist/components/ui/overlay/backdrop.d.ts +79 -0
  165. package/dist/components/ui/overlay/backdrop.esm.js +80 -0
  166. package/dist/components/ui/overlay/backdrop.js +80 -0
  167. package/dist/components/ui/overlay/focus-manager.d.ts +141 -0
  168. package/dist/components/ui/overlay/focus-manager.esm.js +141 -0
  169. package/dist/components/ui/overlay/focus-manager.js +141 -0
  170. package/dist/components/ui/overlay/index.d.ts +27 -0
  171. package/dist/components/ui/overlay/index.esm.js +16 -0
  172. package/dist/components/ui/overlay/index.js +16 -0
  173. package/dist/components/ui/overlay/modal.d.ts +262 -0
  174. package/dist/components/ui/overlay/modal.esm.js +266 -0
  175. package/dist/components/ui/overlay/modal.js +266 -0
  176. package/dist/components/ui/overlay/overlay-manager.d.ts +107 -0
  177. package/dist/components/ui/overlay/overlay-manager.esm.js +105 -0
  178. package/dist/components/ui/overlay/overlay-manager.js +105 -0
  179. package/dist/components/ui/overlay/popover.d.ts +450 -0
  180. package/dist/components/ui/overlay/popover.esm.js +446 -0
  181. package/dist/components/ui/overlay/popover.js +446 -0
  182. package/dist/components/ui/overlay/portal.d.ts +75 -0
  183. package/dist/components/ui/overlay/portal.esm.js +79 -0
  184. package/dist/components/ui/overlay/portal.js +79 -0
  185. package/dist/components/ui/overlay/tooltip.d.ts +298 -0
  186. package/dist/components/ui/overlay/tooltip.esm.js +288 -0
  187. package/dist/components/ui/overlay/tooltip.js +288 -0
  188. package/dist/components/ui/overlay/types.d.ts +194 -0
  189. package/dist/components/ui/overlay/types.esm.js +195 -0
  190. package/dist/components/ui/overlay/types.js +195 -0
  191. package/dist/components/ui/performance-demo.d.ts +583 -0
  192. package/dist/components/ui/performance-demo.esm.js +549 -0
  193. package/dist/components/ui/performance-demo.js +549 -0
  194. package/dist/components/ui/semantic-input-system-demo.d.ts +490 -0
  195. package/dist/components/ui/semantic-input-system-demo.esm.js +465 -0
  196. package/dist/components/ui/semantic-input-system-demo.js +465 -0
  197. package/dist/components/ui/theme-customizer.d.ts +378 -0
  198. package/dist/components/ui/theme-customizer.esm.js +354 -0
  199. package/dist/components/ui/theme-customizer.js +354 -0
  200. package/dist/components/ui/theme-preview.d.ts +305 -0
  201. package/dist/components/ui/theme-preview.esm.js +258 -0
  202. package/dist/components/ui/theme-preview.js +258 -0
  203. package/dist/components/ui/theme-switcher.d.ts +259 -0
  204. package/dist/components/ui/theme-switcher.esm.js +238 -0
  205. package/dist/components/ui/theme-switcher.js +238 -0
  206. package/dist/components/ui/theme-toggle.d.ts +34 -0
  207. package/dist/components/ui/theme-toggle.esm.js +38 -0
  208. package/dist/components/ui/theme-toggle.js +38 -0
  209. package/dist/components/ui/token-demo.d.ts +188 -0
  210. package/dist/components/ui/token-demo.esm.js +183 -0
  211. package/dist/components/ui/token-demo.js +183 -0
  212. package/dist/components/ui/touch-demo.d.ts +455 -0
  213. package/dist/components/ui/touch-demo.esm.js +433 -0
  214. package/dist/components/ui/touch-demo.js +433 -0
  215. package/dist/components/ui/touch-friendly-interface-demo.d.ts +512 -0
  216. package/dist/components/ui/touch-friendly-interface-demo.esm.js +481 -0
  217. package/dist/components/ui/touch-friendly-interface-demo.js +481 -0
  218. package/dist/components/ui/touch-friendly-interface.d.ts +292 -0
  219. package/dist/components/ui/touch-friendly-interface.esm.js +272 -0
  220. package/dist/components/ui/touch-friendly-interface.js +272 -0
  221. package/dist/hooks/index.d.ts +161 -0
  222. package/dist/hooks/index.esm.js +190 -0
  223. package/dist/hooks/index.js +190 -0
  224. package/dist/hooks/use-accessibility-support.d.ts +516 -0
  225. package/dist/hooks/use-accessibility-support.esm.js +488 -0
  226. package/dist/hooks/use-accessibility-support.js +488 -0
  227. package/dist/hooks/use-adaptive-layout.d.ts +287 -0
  228. package/dist/hooks/use-adaptive-layout.esm.js +266 -0
  229. package/dist/hooks/use-adaptive-layout.js +266 -0
  230. package/dist/hooks/use-advanced-patterns.d.ts +292 -0
  231. package/dist/hooks/use-advanced-patterns.esm.js +279 -0
  232. package/dist/hooks/use-advanced-patterns.js +279 -0
  233. package/dist/hooks/use-advanced-transition-system.d.ts +390 -0
  234. package/dist/hooks/use-advanced-transition-system.esm.js +352 -0
  235. package/dist/hooks/use-advanced-transition-system.js +352 -0
  236. package/dist/hooks/use-animation-profile.d.ts +285 -0
  237. package/dist/hooks/use-animation-profile.esm.js +259 -0
  238. package/dist/hooks/use-animation-profile.js +259 -0
  239. package/dist/hooks/use-battery-animations.d.ts +382 -0
  240. package/dist/hooks/use-battery-animations.esm.js +359 -0
  241. package/dist/hooks/use-battery-animations.js +359 -0
  242. package/dist/hooks/use-battery-conscious-loading.d.ts +473 -0
  243. package/dist/hooks/use-battery-conscious-loading.esm.js +432 -0
  244. package/dist/hooks/use-battery-conscious-loading.js +432 -0
  245. package/dist/hooks/use-battery-optimization.d.ts +328 -0
  246. package/dist/hooks/use-battery-optimization.esm.js +307 -0
  247. package/dist/hooks/use-battery-optimization.js +307 -0
  248. package/dist/hooks/use-battery-status.d.ts +297 -0
  249. package/dist/hooks/use-battery-status.esm.js +277 -0
  250. package/dist/hooks/use-battery-status.js +277 -0
  251. package/dist/hooks/use-component-performance.d.ts +342 -0
  252. package/dist/hooks/use-component-performance.esm.js +329 -0
  253. package/dist/hooks/use-component-performance.js +329 -0
  254. package/dist/hooks/use-device-loading-states.d.ts +456 -0
  255. package/dist/hooks/use-device-loading-states.esm.js +416 -0
  256. package/dist/hooks/use-device-loading-states.js +416 -0
  257. package/dist/hooks/use-device.d.ts +104 -0
  258. package/dist/hooks/use-device.esm.js +99 -0
  259. package/dist/hooks/use-device.js +99 -0
  260. package/dist/hooks/use-enterprise-mobile-experience.d.ts +486 -0
  261. package/dist/hooks/use-enterprise-mobile-experience.esm.js +439 -0
  262. package/dist/hooks/use-enterprise-mobile-experience.js +439 -0
  263. package/dist/hooks/use-form-feedback.d.ts +401 -0
  264. package/dist/hooks/use-form-feedback.esm.js +360 -0
  265. package/dist/hooks/use-form-feedback.js +360 -0
  266. package/dist/hooks/use-form-performance.d.ts +511 -0
  267. package/dist/hooks/use-form-performance.esm.js +478 -0
  268. package/dist/hooks/use-form-performance.js +478 -0
  269. package/dist/hooks/use-frame-rate.d.ts +249 -0
  270. package/dist/hooks/use-frame-rate.esm.js +232 -0
  271. package/dist/hooks/use-frame-rate.js +232 -0
  272. package/dist/hooks/use-gestures.d.ts +336 -0
  273. package/dist/hooks/use-gestures.esm.js +314 -0
  274. package/dist/hooks/use-gestures.js +314 -0
  275. package/dist/hooks/use-hardware-acceleration.d.ts +339 -0
  276. package/dist/hooks/use-hardware-acceleration.esm.js +313 -0
  277. package/dist/hooks/use-hardware-acceleration.js +313 -0
  278. package/dist/hooks/use-input-accessibility.d.ts +451 -0
  279. package/dist/hooks/use-input-accessibility.esm.js +417 -0
  280. package/dist/hooks/use-input-accessibility.js +417 -0
  281. package/dist/hooks/use-input-performance.d.ts +503 -0
  282. package/dist/hooks/use-input-performance.esm.js +471 -0
  283. package/dist/hooks/use-input-performance.js +471 -0
  284. package/dist/hooks/use-layout-performance.d.ts +317 -0
  285. package/dist/hooks/use-layout-performance.esm.js +298 -0
  286. package/dist/hooks/use-layout-performance.js +298 -0
  287. package/dist/hooks/use-loading-accessibility.d.ts +532 -0
  288. package/dist/hooks/use-loading-accessibility.esm.js +495 -0
  289. package/dist/hooks/use-loading-accessibility.js +495 -0
  290. package/dist/hooks/use-loading-performance.d.ts +471 -0
  291. package/dist/hooks/use-loading-performance.esm.js +449 -0
  292. package/dist/hooks/use-loading-performance.js +449 -0
  293. package/dist/hooks/use-memory-usage.d.ts +285 -0
  294. package/dist/hooks/use-memory-usage.esm.js +268 -0
  295. package/dist/hooks/use-memory-usage.js +268 -0
  296. package/dist/hooks/use-mobile-form-layout.d.ts +462 -0
  297. package/dist/hooks/use-mobile-form-layout.esm.js +427 -0
  298. package/dist/hooks/use-mobile-form-layout.js +427 -0
  299. package/dist/hooks/use-mobile-form-validation.d.ts +516 -0
  300. package/dist/hooks/use-mobile-form-validation.esm.js +451 -0
  301. package/dist/hooks/use-mobile-form-validation.js +451 -0
  302. package/dist/hooks/use-mobile-keyboard-optimization.d.ts +469 -0
  303. package/dist/hooks/use-mobile-keyboard-optimization.esm.js +431 -0
  304. package/dist/hooks/use-mobile-keyboard-optimization.js +431 -0
  305. package/dist/hooks/use-mobile-layout.d.ts +300 -0
  306. package/dist/hooks/use-mobile-layout.esm.js +280 -0
  307. package/dist/hooks/use-mobile-layout.js +280 -0
  308. package/dist/hooks/use-mobile-optimization.d.ts +404 -0
  309. package/dist/hooks/use-mobile-optimization.esm.js +378 -0
  310. package/dist/hooks/use-mobile-optimization.js +378 -0
  311. package/dist/hooks/use-mobile-skeleton.d.ts +399 -0
  312. package/dist/hooks/use-mobile-skeleton.esm.js +369 -0
  313. package/dist/hooks/use-mobile-skeleton.js +369 -0
  314. package/dist/hooks/use-mobile-touch.d.ts +412 -0
  315. package/dist/hooks/use-mobile-touch.esm.js +379 -0
  316. package/dist/hooks/use-mobile-touch.js +379 -0
  317. package/dist/hooks/use-performance-throttling.d.ts +346 -0
  318. package/dist/hooks/use-performance-throttling.esm.js +324 -0
  319. package/dist/hooks/use-performance-throttling.js +324 -0
  320. package/dist/hooks/use-performance.d.ts +314 -0
  321. package/dist/hooks/use-performance.esm.js +278 -0
  322. package/dist/hooks/use-performance.js +278 -0
  323. package/dist/hooks/use-reusable-architecture.d.ts +412 -0
  324. package/dist/hooks/use-reusable-architecture.esm.js +385 -0
  325. package/dist/hooks/use-reusable-architecture.js +385 -0
  326. package/dist/hooks/use-semantic-input-types.d.ts +354 -0
  327. package/dist/hooks/use-semantic-input-types.esm.js +315 -0
  328. package/dist/hooks/use-semantic-input-types.js +315 -0
  329. package/dist/hooks/use-semantic-input.d.ts +563 -0
  330. package/dist/hooks/use-semantic-input.esm.js +513 -0
  331. package/dist/hooks/use-semantic-input.js +513 -0
  332. package/dist/hooks/use-tablet-layout.d.ts +382 -0
  333. package/dist/hooks/use-tablet-layout.esm.js +355 -0
  334. package/dist/hooks/use-tablet-layout.js +355 -0
  335. package/dist/hooks/use-touch-friendly-input.d.ts +520 -0
  336. package/dist/hooks/use-touch-friendly-input.esm.js +480 -0
  337. package/dist/hooks/use-touch-friendly-input.js +480 -0
  338. package/dist/hooks/use-touch-friendly-interface.d.ts +329 -0
  339. package/dist/hooks/use-touch-friendly-interface.esm.js +299 -0
  340. package/dist/hooks/use-touch-friendly-interface.js +299 -0
  341. package/dist/hooks/use-touch-optimization.d.ts +373 -0
  342. package/dist/hooks/use-touch-optimization.esm.js +348 -0
  343. package/dist/hooks/use-touch-optimization.js +348 -0
  344. package/dist/index.esm.js +2 -2
  345. package/dist/index.js +2 -2
  346. package/dist/lib/utils.d.ts +3 -0
  347. package/dist/lib/utils.esm.js +6 -0
  348. package/dist/lib/utils.js +6 -0
  349. package/dist/plugins/theme-css-generator.d.ts +345 -0
  350. package/dist/plugins/theme-css-generator.esm.js +305 -0
  351. package/dist/plugins/theme-css-generator.js +305 -0
  352. package/dist/styles.css +1 -1
  353. package/dist/themes/ThemeContext.d.ts +27 -0
  354. package/dist/themes/ThemeContext.esm.js +31 -0
  355. package/dist/themes/ThemeContext.js +31 -0
  356. package/dist/themes/ThemeProvider.d.ts +222 -0
  357. package/dist/themes/ThemeProvider.esm.js +229 -0
  358. package/dist/themes/ThemeProvider.js +229 -0
  359. package/dist/themes/accessibility/index.d.ts +7 -0
  360. package/dist/themes/accessibility/index.esm.js +27 -0
  361. package/dist/themes/accessibility/index.js +27 -0
  362. package/dist/themes/accessibility.d.ts +259 -0
  363. package/dist/themes/accessibility.esm.js +220 -0
  364. package/dist/themes/accessibility.js +220 -0
  365. package/dist/themes/aria-patterns.d.ts +418 -0
  366. package/dist/themes/aria-patterns.esm.js +384 -0
  367. package/dist/themes/aria-patterns.js +384 -0
  368. package/dist/themes/base-themes.d.ts +34 -0
  369. package/dist/themes/base-themes.esm.js +52 -0
  370. package/dist/themes/base-themes.js +52 -0
  371. package/dist/themes/colorManager.d.ts +327 -0
  372. package/dist/themes/colorManager.esm.js +362 -0
  373. package/dist/themes/colorManager.js +362 -0
  374. package/dist/themes/examples/dark-theme.d.ts +139 -0
  375. package/dist/themes/examples/dark-theme.esm.js +124 -0
  376. package/dist/themes/examples/dark-theme.js +124 -0
  377. package/dist/themes/examples/minimal-theme.d.ts +93 -0
  378. package/dist/themes/examples/minimal-theme.esm.js +86 -0
  379. package/dist/themes/examples/minimal-theme.js +86 -0
  380. package/dist/themes/focus-management.d.ts +699 -0
  381. package/dist/themes/focus-management.esm.js +642 -0
  382. package/dist/themes/focus-management.js +642 -0
  383. package/dist/themes/fontLoader.d.ts +163 -0
  384. package/dist/themes/fontLoader.esm.js +192 -0
  385. package/dist/themes/fontLoader.js +192 -0
  386. package/dist/themes/high-contrast.d.ts +619 -0
  387. package/dist/themes/high-contrast.esm.js +573 -0
  388. package/dist/themes/high-contrast.js +573 -0
  389. package/dist/themes/index.d.ts +11 -0
  390. package/dist/themes/index.esm.js +19 -0
  391. package/dist/themes/index.js +19 -0
  392. package/dist/themes/inheritance.d.ts +160 -0
  393. package/dist/themes/inheritance.esm.js +219 -0
  394. package/dist/themes/inheritance.js +219 -0
  395. package/dist/themes/keyboard-navigation.d.ts +550 -0
  396. package/dist/themes/keyboard-navigation.esm.js +521 -0
  397. package/dist/themes/keyboard-navigation.js +521 -0
  398. package/dist/themes/motion-reduction.d.ts +660 -0
  399. package/dist/themes/motion-reduction.esm.js +602 -0
  400. package/dist/themes/motion-reduction.js +602 -0
  401. package/dist/themes/navigation.d.ts +232 -0
  402. package/dist/themes/navigation.esm.js +238 -0
  403. package/dist/themes/navigation.js +238 -0
  404. package/dist/themes/screen-reader.d.ts +645 -0
  405. package/dist/themes/screen-reader.esm.js +580 -0
  406. package/dist/themes/screen-reader.js +580 -0
  407. package/dist/themes/systemThemeDetector.d.ts +148 -0
  408. package/dist/themes/systemThemeDetector.esm.js +174 -0
  409. package/dist/themes/systemThemeDetector.js +174 -0
  410. package/dist/themes/themeCSSUpdater.d.ts +229 -0
  411. package/dist/themes/themeCSSUpdater.esm.js +250 -0
  412. package/dist/themes/themeCSSUpdater.js +250 -0
  413. package/dist/themes/themePersistence.d.ts +192 -0
  414. package/dist/themes/themePersistence.esm.js +217 -0
  415. package/dist/themes/themePersistence.js +217 -0
  416. package/dist/themes/themes/stan-design.d.ts +678 -0
  417. package/dist/themes/themes/stan-design.esm.js +518 -0
  418. package/dist/themes/themes/stan-design.js +518 -0
  419. package/dist/themes/types.d.ts +454 -0
  420. package/dist/themes/types.esm.js +446 -0
  421. package/dist/themes/types.js +446 -0
  422. package/dist/themes/useSystemTheme.d.ts +43 -0
  423. package/dist/themes/useSystemTheme.esm.js +48 -0
  424. package/dist/themes/useSystemTheme.js +48 -0
  425. package/dist/themes/useTheme.d.ts +20 -0
  426. package/dist/themes/useTheme.esm.js +87 -0
  427. package/dist/themes/useTheme.js +87 -0
  428. package/dist/themes/validation.d.ts +406 -0
  429. package/dist/themes/validation.esm.js +411 -0
  430. package/dist/themes/validation.js +411 -0
  431. package/dist/tokens/index.d.ts +25 -0
  432. package/dist/tokens/index.esm.js +23 -0
  433. package/dist/tokens/index.js +23 -0
  434. package/dist/tokens/tokenExporter.d.ts +336 -0
  435. package/dist/tokens/tokenExporter.esm.js +371 -0
  436. package/dist/tokens/tokenExporter.js +371 -0
  437. package/dist/tokens/tokenGenerator.d.ts +250 -0
  438. package/dist/tokens/tokenGenerator.esm.js +267 -0
  439. package/dist/tokens/tokenGenerator.js +267 -0
  440. package/dist/tokens/tokenManager.d.ts +194 -0
  441. package/dist/tokens/tokenManager.esm.js +235 -0
  442. package/dist/tokens/tokenManager.js +235 -0
  443. package/dist/tokens/tokenValidator.d.ts +488 -0
  444. package/dist/tokens/tokenValidator.esm.js +497 -0
  445. package/dist/tokens/tokenValidator.js +497 -0
  446. package/dist/tokens/types.d.ts +78 -0
  447. package/dist/tokens/types.esm.js +64 -0
  448. package/dist/tokens/types.js +64 -0
  449. package/dist/utils/bundle-analyzer.d.ts +260 -0
  450. package/dist/utils/bundle-analyzer.esm.js +242 -0
  451. package/dist/utils/bundle-analyzer.js +242 -0
  452. package/dist/utils/bundle-splitting.d.ts +483 -0
  453. package/dist/utils/bundle-splitting.esm.js +458 -0
  454. package/dist/utils/bundle-splitting.js +458 -0
  455. package/dist/utils/lazy-loading.d.ts +437 -0
  456. package/dist/utils/lazy-loading.esm.js +415 -0
  457. package/dist/utils/lazy-loading.js +415 -0
  458. package/dist/utils/performance-monitor.d.ts +513 -0
  459. package/dist/utils/performance-monitor.esm.js +472 -0
  460. package/dist/utils/performance-monitor.js +472 -0
  461. package/dist/utils/tree-shaking.d.ts +274 -0
  462. package/dist/utils/tree-shaking.esm.js +266 -0
  463. package/dist/utils/tree-shaking.js +266 -0
  464. package/package.json +1 -1
  465. package/src/index.ts +2 -2
  466. package/src/themes/accessibility/index.ts +1 -1
  467. package/src/themes/focus-management.ts +3 -3
  468. package/src/themes/keyboard-navigation.ts +3 -3
@@ -0,0 +1,260 @@
1
+ /**
2
+ * Pagination Component
3
+ * Provides comprehensive pagination with theme support and responsive design
4
+ */
5
+
6
+ import * as React from 'react';
7
+ import { useMemo } from 'react';
8
+ import { ChevronLeftIcon, ChevronRightIcon } from '@heroicons/react/24/outline';
9
+ import { PaginationProps, PaginationItem } from './types';
10
+
11
+ // Simple icon components
12
+ const ChevronDoubleLeftIcon}> = ({ className = '' }) => (
13
+ <svg className={className} fill="none" viewBox="0 0 24 24" stroke="currentColor">
14
+ <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M11 19l-7-7 7-7m8 14l-7-7 7-7" />
15
+ </svg>
16
+ );
17
+
18
+ const ChevronDoubleRightIcon}> = ({ className = '' }) => (
19
+ <svg className={className} fill="none" viewBox="0 0 24 24" stroke="currentColor">
20
+ <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M13 5l7 7-7 7m-8-14l7 7-7 7" />
21
+ </svg>
22
+ );
23
+
24
+ export const Pagination= ({
25
+ currentPage = 1,
26
+ totalPages = 1,
27
+ totalItems,
28
+ itemsPerPage = 10,
29
+ showFirstLast = true,
30
+ showPrevNext = true,
31
+ showPageNumbers = true,
32
+ maxPageNumbers = 5,
33
+ size = 'md',
34
+ variant = 'default',
35
+ onPageChange,
36
+ onItemsPerPageChange,
37
+ itemsPerPageOptions = [10, 25, 50, 100],
38
+ showItemsPerPage = false,
39
+ showTotal = false,
40
+ totalLabel = 'Total',
41
+ disabled = false,
42
+ loading = false,
43
+ className = '',
44
+ 'data-testid'= 'pagination',
45
+ }) => {
46
+ // Memoize pagination items to avoid unnecessary recalculations
47
+ const paginationItems = useMemo(()] => {
48
+ const items] = [];
49
+
50
+ if (showFirstLast) {
51
+ items.push({
52
+ type,
53
+ page,
54
+ disabled=== 1 || disabled,
55
+ label,
56
+ onClick) => onPageChange(1),
57
+ });
58
+ }
59
+
60
+ if (showPrevNext) {
61
+ items.push({
62
+ type,
63
+ page,
64
+ disabled=== 1 || disabled,
65
+ label,
66
+ onClick) => onPageChange(currentPage - 1),
67
+ });
68
+ }
69
+
70
+ if (showPageNumbers) {
71
+ const pageNumbers = generatePageNumbers(currentPage, totalPages, maxPageNumbers);
72
+
73
+ pageNumbers.forEach((pageNum) => {
74
+ if (pageNum === 'ellipsis') {
75
+ items.push({
76
+ type,
77
+ label,
78
+ disabled,
79
+ });
80
+ } else {
81
+ items.push({
82
+ type,
83
+ page,
84
+ active=== currentPage,
85
+ disabled,
86
+ label),
87
+ onClick) => onPageChange(pageNum as number),
88
+ });
89
+ }
90
+ });
91
+ }
92
+
93
+ if (showPrevNext) {
94
+ items.push({
95
+ type,
96
+ page,
97
+ disabled=== totalPages || disabled,
98
+ label,
99
+ onClick) => onPageChange(currentPage + 1),
100
+ });
101
+ }
102
+
103
+ if (showFirstLast) {
104
+ items.push({
105
+ type,
106
+ page,
107
+ disabled=== totalPages || disabled,
108
+ label,
109
+ onClick) => onPageChange(totalPages),
110
+ });
111
+ }
112
+
113
+ return items;
114
+ }, [currentPage, totalPages, maxPageNumbers, showFirstLast, showPrevNext, showPageNumbers, disabled, onPageChange]);
115
+
116
+
117
+
118
+ function generatePageNumbers(current, total, max))[] {
119
+ if (total <= max) {
120
+ return Array.from({ length}, (_, i) => i + 1);
121
+ }
122
+
123
+ const half = Math.floor(max / 2);
124
+ const start = Math.max(1, current - half);
125
+ const end = Math.min(total, start + max - 1);
126
+
127
+ const numbers)[] = [];
128
+
129
+ if (start > 1) {
130
+ numbers.push(1);
131
+ if (start > 2) numbers.push('ellipsis');
132
+ }
133
+
134
+ for (let i = start; i <= end; i++) {
135
+ numbers.push(i);
136
+ }
137
+
138
+ if (end < total) {
139
+ if (end < total - 1) numbers.push('ellipsis');
140
+ numbers.push(total);
141
+ }
142
+
143
+ return numbers;
144
+ }
145
+
146
+ const getSizeClasses = () => {
147
+ switch (size) {
148
+ case 'sm';
149
+ case 'lg';
150
+ default;
151
+ }
152
+ };
153
+
154
+ const getVariantClasses = () => {
155
+ switch (variant) {
156
+ case 'outlined';
157
+ case 'minimal';
158
+ default;
159
+ }
160
+ };
161
+
162
+ const getThemeClasses = () => {
163
+ return 'pagination pagination--stan-design';
164
+ };
165
+
166
+ const getButtonClasses = (item) => {
167
+ let classes = `pagination__button ${getSizeClasses()} ${getVariantClasses()}`;
168
+
169
+ if (item.disabled) {
170
+ classes += ' pagination__button--disabled';
171
+ } else if (item.active) {
172
+ classes += ' pagination__button--active';
173
+ } else {
174
+ classes += ' pagination__button--inactive';
175
+ }
176
+
177
+ return classes;
178
+ };
179
+
180
+ const handleItemsPerPageChange = (event) => {
181
+ const newItemsPerPage = parseInt(event.target.value, 10);
182
+ if (onItemsPerPageChange) {
183
+ onItemsPerPageChange(newItemsPerPage);
184
+ }
185
+ };
186
+
187
+ if (totalPages <= 1 && !showItemsPerPage && !showTotal) {
188
+ return null;
189
+ }
190
+
191
+ return (
192
+ <div className={`pagination__container ${getThemeClasses()} ${className}`} data-testid={testId}>
193
+ {/* Left side - Items per page and total */}
194
+ <div className="pagination__info">
195
+ {showItemsPerPage && (
196
+ <div className="pagination__items-per-page">
197
+ <label htmlFor="items-per-page" className="pagination__label">
198
+ Items per page="items-per-page"
199
+ value={itemsPerPage}
200
+ onChange={handleItemsPerPageChange}
201
+ disabled={disabled || loading}
202
+ className="pagination__select"
203
+ >
204
+ {itemsPerPageOptions.map((option) => (
205
+ <option key={option} value={option}>
206
+ {option}
207
+ </option>
208
+ ))}
209
+ </select>
210
+ </div>
211
+ )}
212
+
213
+ {showTotal && totalItems !== undefined && (
214
+ <div className="pagination__total">
215
+ {totalLabel}="pagination__total-count">{totalItems.toLocaleString()}</span>
216
+ </div>
217
+ )}
218
+ </div>
219
+
220
+ {/* Center - Page numbers */}
221
+ <div className="pagination__navigation">
222
+ {paginationItems.map((item, index) => {
223
+ if (item.type === 'ellipsis') {
224
+ return (
225
+ <span
226
+ key={`ellipsis-${index}`}
227
+ className="pagination__ellipsis"
228
+ aria-hidden="true"
229
+ >
230
+ {item.label}
231
+ </span>
232
+ );
233
+ }
234
+
235
+ const icon = item.type === 'first' ? <ChevronDoubleLeftIcon className="pagination__button-icon" /> === 'previous' ? <ChevronLeftIcon className="pagination__button-icon" /> === 'next' ? <ChevronRightIcon className="pagination__button-icon" /> === 'last' ? <ChevronDoubleRightIcon className="pagination__button-icon" /> ;
236
+
237
+ return (
238
+ <button
239
+ key={`${item.type}-${item.page || index}`}
240
+ onClick={item.onClick}
241
+ disabled={item.disabled}
242
+ className={getButtonClasses(item)}
243
+ aria-label={item.label}
244
+ aria-current={item.active ? 'page' }
245
+ >
246
+ {icon || item.label}
247
+ </button>
248
+ );
249
+ })}
250
+ </div>
251
+
252
+ {/* Right side - Page info */}
253
+ <div className="pagination__status">
254
+ {`Page ${currentPage} of ${totalPages}`}
255
+ </div>
256
+ </div>
257
+ );
258
+ };
259
+
260
+ export default Pagination;
@@ -0,0 +1,375 @@
1
+
2
+ // Simple icon components
3
+ const ChevronLeftIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
4
+ <svg className={className} fill="none" viewBox="0 0 24 24" stroke="currentColor">
5
+ <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M15 19l-7-7 7-7" />
6
+ </svg>
7
+ );
8
+
9
+ const ChevronRightIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
10
+ <svg className={className} fill="none" viewBox="0 0 24 24" stroke="currentColor">
11
+ <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M9 5l7 7-7 7" />
12
+ </svg>
13
+ );
14
+
15
+ // TODO: Implement close icon functionality in future version
16
+ // const XMarkIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
17
+ // <svg className={className} fill="none" viewBox="0 0 24 24" stroke="currentColor">
18
+ // <path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M6 18L18 6M6 6l12 12" />
19
+ // </svg>
20
+ // );
21
+
22
+ export const Sidebar: React.FC<SidebarProps> = ({
23
+ items = [],
24
+ groups = [],
25
+ variant = 'default',
26
+ size = 'md',
27
+ position = 'left',
28
+ collapsed = false,
29
+ defaultCollapsed = false,
30
+ onCollapseChange,
31
+ collapsible = true,
32
+ showToggle = true,
33
+ toggleIcon,
34
+ header,
35
+ footer,
36
+ overlay = false,
37
+ overlayCloseOnClick = true,
38
+ overlayCloseOnEscape = true,
39
+ overlayCloseOnOutsideClick = true,
40
+ responsive = true,
41
+ breakpoint = 'lg',
42
+ onItemClick,
43
+ onGroupToggle,
44
+ expandedGroups = [],
45
+ defaultExpandedGroups = [],
46
+ // TODO: Implement group icons in future version
47
+ // showGroupIcons = true,
48
+ showItemIcons = true,
49
+ showItemBadges = true,
50
+ showItemDescriptions = true,
51
+ sticky = false,
52
+ zIndex = 1000,
53
+ className = '',
54
+ 'data-testid': testId = 'sidebar',
55
+ }) => {
56
+ const [internalCollapsed, setInternalCollapsed] = useState<boolean>(
57
+ collapsed !== undefined ? collapsed : defaultCollapsed
58
+ );
59
+ const [internalExpandedGroups, setInternalExpandedGroups] = useState<string[]>(
60
+ expandedGroups !== undefined ? expandedGroups : defaultExpandedGroups
61
+ );
62
+ const [isOverlayOpen, setIsOverlayOpen] = useState(false);
63
+ const [isMobile, setIsMobile] = useState(false);
64
+
65
+ const sidebarRef = useRef<HTMLDivElement>(null);
66
+
67
+ // Use controlled or uncontrolled collapsed state
68
+ const currentCollapsed = collapsed !== undefined ? collapsed : internalCollapsed;
69
+ const currentExpandedGroups = expandedGroups !== undefined ? expandedGroups : internalExpandedGroups;
70
+
71
+ // Handle responsive behavior
72
+ useEffect(() => {
73
+ const handleResize = () => {
74
+ const breakpointWidth = breakpoint === 'sm' ? 640 : breakpoint === 'md' ? 768 : breakpoint === 'lg' ? 1024 : 1280;
75
+ setIsMobile(window.innerWidth < breakpointWidth);
76
+ };
77
+
78
+ if (responsive) {
79
+ handleResize();
80
+ window.addEventListener('resize', handleResize);
81
+ }
82
+
83
+ return () => {
84
+ if (responsive) {
85
+ window.removeEventListener('resize', handleResize);
86
+ }
87
+ };
88
+ }, [responsive, breakpoint]);
89
+
90
+ // Handle escape key for overlay
91
+ useEffect(() => {
92
+ const handleEscape = (event: KeyboardEvent) => {
93
+ if (event.key === 'Escape' && isOverlayOpen && overlayCloseOnEscape) {
94
+ setIsOverlayOpen(false);
95
+ }
96
+ };
97
+
98
+ if (isOverlayOpen) {
99
+ document.addEventListener('keydown', handleEscape);
100
+ }
101
+
102
+ return () => {
103
+ document.removeEventListener('keydown', handleEscape);
104
+ };
105
+ }, [isOverlayOpen, overlayCloseOnEscape]);
106
+
107
+ const handleCollapseToggle = useCallback(() => {
108
+ if (!collapsible) return;
109
+
110
+ const newCollapsed = !currentCollapsed;
111
+
112
+ if (collapsed === undefined) {
113
+ setInternalCollapsed(newCollapsed);
114
+ }
115
+
116
+ if (onCollapseChange) {
117
+ onCollapseChange(newCollapsed);
118
+ }
119
+ }, [collapsed, currentCollapsed, collapsible, onCollapseChange]);
120
+
121
+ const handleGroupToggle = useCallback((groupId: string) => {
122
+ const newExpandedGroups = currentExpandedGroups.includes(groupId)
123
+ ? currentExpandedGroups.filter(id => id !== groupId)
124
+ : [...currentExpandedGroups, groupId];
125
+
126
+ if (expandedGroups === undefined) {
127
+ setInternalExpandedGroups(newExpandedGroups);
128
+ }
129
+
130
+ if (onGroupToggle) {
131
+ onGroupToggle(groupId, newExpandedGroups.includes(groupId));
132
+ }
133
+ }, [currentExpandedGroups, expandedGroups, onGroupToggle]);
134
+
135
+ const handleItemClick = useCallback((item: NavigationItem) => {
136
+ if (item.disabled) return;
137
+
138
+ if (onItemClick) {
139
+ onItemClick(item);
140
+ }
141
+
142
+ if (item.onClick) {
143
+ item.onClick();
144
+ }
145
+
146
+ // Close overlay on mobile after item click
147
+ if (isMobile && overlay && overlayCloseOnClick) {
148
+ setIsOverlayOpen(false);
149
+ }
150
+ }, [onItemClick, isMobile, overlay, overlayCloseOnClick]);
151
+
152
+ const handleOverlayClose = useCallback(() => {
153
+ setIsOverlayOpen(false);
154
+ }, []);
155
+
156
+ const getSizeClasses = () => {
157
+ if (currentCollapsed) return 'sidebar--collapsed';
158
+
159
+ switch (size) {
160
+ case 'sm':
161
+ return 'sidebar--size-sm';
162
+ case 'lg':
163
+ return 'sidebar--size-lg';
164
+ case 'xl':
165
+ return 'sidebar--size-xl';
166
+ default: // md
167
+ return 'sidebar--size-md';
168
+ }
169
+ };
170
+
171
+ const getVariantClasses = () => {
172
+ switch (variant) {
173
+ case 'collapsible':
174
+ return 'sidebar--collapsible';
175
+ case 'overlay':
176
+ return 'sidebar--overlay';
177
+ case 'drawer':
178
+ return 'sidebar--drawer';
179
+ default: // default
180
+ return 'sidebar--default';
181
+ }
182
+ };
183
+
184
+ const getThemeClasses = () => {
185
+ return 'sidebar sidebar--stan-design';
186
+ };
187
+
188
+ const getPositionClasses = () => {
189
+ if (variant === 'overlay' || variant === 'drawer') {
190
+ return position === 'right' ? 'sidebar--position-right' : 'sidebar--position-left';
191
+ }
192
+ return '';
193
+ };
194
+
195
+ const getTransformClasses = () => {
196
+ if (variant === 'overlay' || variant === 'drawer' || (isMobile && overlay)) {
197
+ if (position === 'right') {
198
+ return isOverlayOpen ? 'sidebar--open' : 'sidebar--closed-right';
199
+ }
200
+ return isOverlayOpen ? 'sidebar--open' : 'sidebar--closed-left';
201
+ }
202
+ return '';
203
+ };
204
+
205
+ const getItemClasses = (item: NavigationItem) => {
206
+ let classes = `sidebar__item ${
207
+ currentCollapsed ? 'sidebar__item--collapsed' : 'sidebar__item--expanded'
208
+ }`;
209
+
210
+ if (item.disabled) {
211
+ classes += ' sidebar__item--disabled';
212
+ } else if (item.active) {
213
+ classes += ' sidebar__item--active';
214
+ } else {
215
+ classes += ' sidebar__item--default';
216
+ }
217
+
218
+ return classes;
219
+ };
220
+
221
+ const getGroupClasses = (groupId: string) => {
222
+ const isExpanded = currentExpandedGroups.includes(groupId);
223
+ let classes = 'sidebar__group';
224
+
225
+ if (isExpanded) {
226
+ classes += ' sidebar__group--expanded';
227
+ } else {
228
+ classes += ' sidebar__group--collapsed';
229
+ }
230
+
231
+ return classes;
232
+ };
233
+
234
+ const renderMenuItem = (item: NavigationItem) => (
235
+ <button
236
+ key={item.id}
237
+ onClick={() => handleItemClick(item)}
238
+ disabled={item.disabled}
239
+ className={getItemClasses(item)}
240
+ title={currentCollapsed ? item.label : undefined}
241
+ >
242
+ {showItemIcons && item.icon && (
243
+ <span className={`sidebar__item-icon ${currentCollapsed ? 'sidebar__item-icon--collapsed' : 'sidebar__item-icon--expanded'}`}>
244
+ {item.icon}
245
+ </span>
246
+ )}
247
+
248
+ {!currentCollapsed && (
249
+ <div className="sidebar__item-content">
250
+ <div className="sidebar__item-label">{item.label}</div>
251
+ {showItemDescriptions && item.description && (
252
+ <div className="sidebar__item-description">{item.description}</div>
253
+ )}
254
+ </div>
255
+ )}
256
+
257
+ {!currentCollapsed && showItemBadges && item.badge && (
258
+ <span className="sidebar__item-badge">{item.badge}</span>
259
+ )}
260
+ </button>
261
+ );
262
+
263
+ const renderMenuGroup = (group: NavigationGroup) => (
264
+ <div key={group.id}>
265
+ <button
266
+ onClick={() => handleGroupToggle(group.id)}
267
+ className={getGroupClasses(group.id)}
268
+ title={currentCollapsed ? group.title : undefined}
269
+ >
270
+ {/* TODO: Add icon support to NavigationGroup in future version */}
271
+ {/* {showGroupIcons && group.icon && (
272
+ <span className={currentCollapsed ? '' : 'mr-3'}>
273
+ {group.icon}
274
+ </span>
275
+ )} */}
276
+
277
+ {!currentCollapsed && (
278
+ <>
279
+ <div className="sidebar__group-title">{group.title}</div>
280
+ <ChevronRightIcon
281
+ className={`sidebar__group-arrow ${
282
+ currentExpandedGroups.includes(group.id) ? 'sidebar__group-arrow--expanded' : ''
283
+ }`}
284
+ />
285
+ </>
286
+ )}
287
+ </button>
288
+
289
+ {!currentCollapsed && currentExpandedGroups.includes(group.id) && (
290
+ <div className="sidebar__group-items">
291
+ {group.items.map(renderMenuItem)}
292
+ </div>
293
+ )}
294
+ </div>
295
+ );
296
+
297
+ const sidebarContent = (
298
+ <div
299
+ ref={sidebarRef}
300
+ className={`${getSizeClasses()} ${getVariantClasses()} ${getThemeClasses()} ${getPositionClasses()} ${getTransformClasses()} ${className}`}
301
+ data-testid={testId}
302
+ style={{ zIndex }}
303
+ >
304
+ {/* Header */}
305
+ {header && (
306
+ <div className="sidebar__header">
307
+ {header}
308
+ </div>
309
+ )}
310
+
311
+ {/* Toggle Button */}
312
+ {showToggle && collapsible && (
313
+ <div className="sidebar__toggle-container">
314
+ <button
315
+ onClick={handleCollapseToggle}
316
+ className="sidebar__toggle-button"
317
+ aria-label={currentCollapsed ? 'Expand sidebar' : 'Collapse sidebar'}
318
+ >
319
+ {toggleIcon || (currentCollapsed ? <ChevronRightIcon className="sidebar__toggle-icon" /> : <ChevronLeftIcon className="sidebar__toggle-icon" />)}
320
+ </button>
321
+ </div>
322
+ )}
323
+
324
+ {/* Navigation Items */}
325
+ <nav className="sidebar__navigation">
326
+ {groups && groups.length > 0 ? groups.map(renderMenuGroup) : items.map(renderMenuItem)}
327
+ </nav>
328
+
329
+ {/* Footer */}
330
+ {footer && (
331
+ <div className="sidebar__footer">
332
+ {footer}
333
+ </div>
334
+ )}
335
+ </div>
336
+ );
337
+
338
+ // Mobile overlay
339
+ if (isMobile && overlay) {
340
+ return (
341
+ <>
342
+ {/* Overlay Backdrop */}
343
+ {isOverlayOpen && (
344
+ <div
345
+ className="sidebar__overlay-backdrop"
346
+ onClick={overlayCloseOnOutsideClick ? handleOverlayClose : undefined}
347
+ />
348
+ )}
349
+
350
+ {/* Sidebar */}
351
+ {sidebarContent}
352
+
353
+ {/* Mobile Toggle Button */}
354
+ <button
355
+ onClick={() => setIsOverlayOpen(!isOverlayOpen)}
356
+ className="sidebar__mobile-toggle"
357
+ aria-label="Toggle sidebar"
358
+ >
359
+ <svg className="sidebar__mobile-toggle-icon" fill="none" viewBox="0 0 24 24" stroke="currentColor">
360
+ <path strokeLinecap="round" strokeLinejoin="round" strokeWidth="2" d="M4 6h16M4 12h16M4 18h16" />
361
+ </svg>
362
+ </button>
363
+ </>
364
+ );
365
+ }
366
+
367
+ // Desktop sidebar
368
+ return (
369
+ <div className={`sidebar__wrapper ${sticky ? 'sidebar__wrapper--sticky' : ''}`}>
370
+ {sidebarContent}
371
+ </div>
372
+ );
373
+ };
374
+
375
+ export default Sidebar;