@techsio/ui-kit 0.3.2 → 0.4.0

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 (446) hide show
  1. package/README.md +59 -6
  2. package/dist/.storybook/decorator.d.ts +12 -0
  3. package/dist/.storybook/decorator.d.ts.map +1 -0
  4. package/dist/.storybook/main.d.ts +4 -0
  5. package/dist/.storybook/main.d.ts.map +1 -0
  6. package/dist/.storybook/preview.d.ts +5 -0
  7. package/dist/.storybook/preview.d.ts.map +1 -0
  8. package/dist/.storybook/test-runner.d.ts +12 -0
  9. package/dist/.storybook/test-runner.d.ts.map +1 -0
  10. package/dist/atoms/badge.js +37 -19
  11. package/dist/atoms/button.js +167 -154
  12. package/dist/atoms/checkbox.js +52 -0
  13. package/dist/atoms/figma/badge.figma.js +33 -0
  14. package/dist/atoms/figma/button.figma.js +76 -0
  15. package/dist/atoms/figma/checkbox.figma.js +35 -0
  16. package/dist/atoms/figma/icon.figma.js +33 -0
  17. package/dist/atoms/figma/image.figma.js +21 -0
  18. package/dist/atoms/figma/input.figma.js +34 -0
  19. package/dist/atoms/figma/label.figma.js +25 -0
  20. package/dist/atoms/figma/link-button.figma.js +42 -0
  21. package/dist/atoms/figma/link.figma.js +15 -0
  22. package/dist/atoms/figma/numeric-input.figma.js +52 -0
  23. package/dist/atoms/figma/rating.figma.js +38 -0
  24. package/dist/atoms/figma/skeleton.figma.js +119 -0
  25. package/dist/atoms/figma/status-text.figma.js +27 -0
  26. package/dist/atoms/figma/textarea.figma.js +38 -0
  27. package/dist/atoms/figma/tooltip.figma.js +47 -0
  28. package/dist/atoms/icon.js +17 -17
  29. package/dist/atoms/image.js +22 -4
  30. package/dist/atoms/input.js +40 -34
  31. package/dist/atoms/label.js +10 -10
  32. package/dist/atoms/link-button.js +19 -18
  33. package/dist/atoms/link.js +6 -4
  34. package/dist/atoms/numeric-input.js +98 -70
  35. package/dist/atoms/rating.js +30 -30
  36. package/dist/atoms/skeleton.js +47 -47
  37. package/dist/atoms/status-text.js +75 -0
  38. package/dist/atoms/textarea.js +48 -42
  39. package/dist/atoms/tooltip.js +17 -17
  40. package/dist/molecules/accordion.js +58 -60
  41. package/dist/molecules/breadcrumb.js +206 -124
  42. package/dist/molecules/carousel.js +139 -87
  43. package/dist/molecules/color-select.js +56 -56
  44. package/dist/molecules/combobox.js +131 -104
  45. package/dist/molecules/dialog.js +97 -97
  46. package/dist/molecules/figma/accordion.figma.js +41 -0
  47. package/dist/molecules/figma/breadcrumb.figma.js +31 -0
  48. package/dist/molecules/figma/carousel.figma.js +34 -0
  49. package/dist/molecules/figma/combobox.figma.js +38 -0
  50. package/dist/molecules/figma/dialog.figma.js +24 -0
  51. package/dist/molecules/figma/form-checkbox.figma.js +41 -0
  52. package/dist/molecules/figma/form-input.figma.js +38 -0
  53. package/dist/molecules/figma/form-numeric-input.figma.js +67 -0
  54. package/dist/molecules/figma/form-textarea.figma.js +38 -0
  55. package/dist/molecules/figma/menu.figma.js +26 -0
  56. package/dist/molecules/figma/pagination.figma.js +22 -0
  57. package/dist/molecules/figma/popover.figma.js +38 -0
  58. package/dist/molecules/figma/product-card.figma.js +34 -0
  59. package/dist/molecules/figma/radio-card.figma.js +35 -0
  60. package/dist/molecules/figma/radio-group.figma.js +45 -0
  61. package/dist/molecules/figma/search-form.figma.js +24 -0
  62. package/dist/molecules/figma/select.figma.js +46 -0
  63. package/dist/molecules/figma/slider.figma.js +30 -0
  64. package/dist/molecules/figma/steps.figma.js +33 -0
  65. package/dist/molecules/figma/switch.figma.js +33 -0
  66. package/dist/molecules/figma/tabs.figma.js +46 -0
  67. package/dist/molecules/figma/toast.figma.js +34 -0
  68. package/dist/molecules/figma/tree-view.figma.js +30 -0
  69. package/dist/molecules/form-checkbox.js +121 -48
  70. package/dist/molecules/form-input.js +15 -27
  71. package/dist/molecules/form-numeric-input.js +11 -24
  72. package/dist/molecules/form-textarea.js +15 -27
  73. package/dist/molecules/menu.js +69 -67
  74. package/dist/molecules/pagination.js +112 -76
  75. package/dist/molecules/phone-input.js +654 -0
  76. package/dist/molecules/popover.js +221 -96
  77. package/dist/molecules/product-card.js +38 -37
  78. package/dist/molecules/radio-card.js +517 -0
  79. package/dist/molecules/radio-group.js +341 -0
  80. package/dist/molecules/search-form.js +170 -91
  81. package/dist/molecules/select.js +369 -141
  82. package/dist/molecules/slider.js +72 -85
  83. package/dist/molecules/steps.js +517 -152
  84. package/dist/molecules/switch.js +37 -43
  85. package/dist/molecules/tabs.js +63 -61
  86. package/dist/molecules/toast.js +32 -32
  87. package/dist/molecules/tree-view.js +89 -83
  88. package/dist/organisms/footer.js +50 -52
  89. package/dist/organisms/gallery.js +244 -0
  90. package/dist/organisms/header.js +60 -58
  91. package/dist/organisms/table.js +52 -52
  92. package/dist/src/atoms/badge.d.ts +27 -7
  93. package/dist/src/atoms/badge.d.ts.map +1 -1
  94. package/dist/src/atoms/button.d.ts +7 -6
  95. package/dist/src/atoms/button.d.ts.map +1 -1
  96. package/dist/src/atoms/checkbox.d.ts +11 -0
  97. package/dist/src/atoms/checkbox.d.ts.map +1 -0
  98. package/dist/src/atoms/figma/badge.figma.d.ts +2 -0
  99. package/dist/src/atoms/figma/badge.figma.d.ts.map +1 -0
  100. package/dist/src/atoms/figma/button.figma.d.ts +2 -0
  101. package/dist/src/atoms/figma/button.figma.d.ts.map +1 -0
  102. package/dist/src/atoms/figma/checkbox.figma.d.ts +2 -0
  103. package/dist/src/atoms/figma/checkbox.figma.d.ts.map +1 -0
  104. package/dist/src/atoms/figma/icon.figma.d.ts +2 -0
  105. package/dist/src/atoms/figma/icon.figma.d.ts.map +1 -0
  106. package/dist/src/atoms/figma/image.figma.d.ts +2 -0
  107. package/dist/src/atoms/figma/image.figma.d.ts.map +1 -0
  108. package/dist/src/atoms/figma/input.figma.d.ts +2 -0
  109. package/dist/src/atoms/figma/input.figma.d.ts.map +1 -0
  110. package/dist/src/atoms/figma/label.figma.d.ts +2 -0
  111. package/dist/src/atoms/figma/label.figma.d.ts.map +1 -0
  112. package/dist/src/atoms/figma/link-button.figma.d.ts +2 -0
  113. package/dist/src/atoms/figma/link-button.figma.d.ts.map +1 -0
  114. package/dist/src/atoms/figma/link.figma.d.ts +2 -0
  115. package/dist/src/atoms/figma/link.figma.d.ts.map +1 -0
  116. package/dist/src/atoms/figma/numeric-input.figma.d.ts +2 -0
  117. package/dist/src/atoms/figma/numeric-input.figma.d.ts.map +1 -0
  118. package/dist/src/atoms/figma/rating.figma.d.ts +2 -0
  119. package/dist/src/atoms/figma/rating.figma.d.ts.map +1 -0
  120. package/dist/src/atoms/figma/skeleton.figma.d.ts +2 -0
  121. package/dist/src/atoms/figma/skeleton.figma.d.ts.map +1 -0
  122. package/dist/src/atoms/figma/status-text.figma.d.ts +2 -0
  123. package/dist/src/atoms/figma/status-text.figma.d.ts.map +1 -0
  124. package/dist/src/atoms/figma/textarea.figma.d.ts +2 -0
  125. package/dist/src/atoms/figma/textarea.figma.d.ts.map +1 -0
  126. package/dist/src/atoms/figma/tooltip.figma.d.ts +2 -0
  127. package/dist/src/atoms/figma/tooltip.figma.d.ts.map +1 -0
  128. package/dist/src/atoms/icon.d.ts +6 -6
  129. package/dist/src/atoms/image.d.ts +35 -9
  130. package/dist/src/atoms/image.d.ts.map +1 -1
  131. package/dist/src/atoms/input.d.ts +3 -3
  132. package/dist/src/atoms/input.d.ts.map +1 -1
  133. package/dist/src/atoms/label.d.ts +2 -2
  134. package/dist/src/atoms/link-button.d.ts +71 -12
  135. package/dist/src/atoms/link-button.d.ts.map +1 -1
  136. package/dist/src/atoms/link.d.ts +5 -5
  137. package/dist/src/atoms/link.d.ts.map +1 -1
  138. package/dist/src/atoms/numeric-input.d.ts +23 -22
  139. package/dist/src/atoms/numeric-input.d.ts.map +1 -1
  140. package/dist/src/atoms/rating.d.ts +6 -5
  141. package/dist/src/atoms/rating.d.ts.map +1 -1
  142. package/dist/src/atoms/skeleton.d.ts +15 -15
  143. package/dist/src/atoms/skeleton.d.ts.map +1 -1
  144. package/dist/src/atoms/status-text.d.ts +97 -0
  145. package/dist/src/atoms/status-text.d.ts.map +1 -0
  146. package/dist/src/atoms/textarea.d.ts +3 -3
  147. package/dist/src/atoms/textarea.d.ts.map +1 -1
  148. package/dist/src/atoms/tooltip.d.ts +3 -3
  149. package/dist/src/atoms/tooltip.d.ts.map +1 -1
  150. package/dist/src/molecules/accordion.d.ts +14 -13
  151. package/dist/src/molecules/accordion.d.ts.map +1 -1
  152. package/dist/src/molecules/breadcrumb.d.ts +132 -35
  153. package/dist/src/molecules/breadcrumb.d.ts.map +1 -1
  154. package/dist/src/molecules/carousel.d.ts +67 -16
  155. package/dist/src/molecules/carousel.d.ts.map +1 -1
  156. package/dist/src/molecules/color-select.d.ts +4 -4
  157. package/dist/src/molecules/combobox.d.ts +36 -9
  158. package/dist/src/molecules/combobox.d.ts.map +1 -1
  159. package/dist/src/molecules/dialog.d.ts +3 -3
  160. package/dist/src/molecules/dialog.d.ts.map +1 -1
  161. package/dist/src/molecules/figma/accordion.figma.d.ts +2 -0
  162. package/dist/src/molecules/figma/accordion.figma.d.ts.map +1 -0
  163. package/dist/src/molecules/figma/breadcrumb.figma.d.ts +2 -0
  164. package/dist/src/molecules/figma/breadcrumb.figma.d.ts.map +1 -0
  165. package/dist/src/molecules/figma/carousel.figma.d.ts +2 -0
  166. package/dist/src/molecules/figma/carousel.figma.d.ts.map +1 -0
  167. package/dist/src/molecules/figma/combobox.figma.d.ts +2 -0
  168. package/dist/src/molecules/figma/combobox.figma.d.ts.map +1 -0
  169. package/dist/src/molecules/figma/dialog.figma.d.ts +2 -0
  170. package/dist/src/molecules/figma/dialog.figma.d.ts.map +1 -0
  171. package/dist/src/molecules/figma/form-checkbox.figma.d.ts +2 -0
  172. package/dist/src/molecules/figma/form-checkbox.figma.d.ts.map +1 -0
  173. package/dist/src/molecules/figma/form-input.figma.d.ts +2 -0
  174. package/dist/src/molecules/figma/form-input.figma.d.ts.map +1 -0
  175. package/dist/src/molecules/figma/form-numeric-input.figma.d.ts +2 -0
  176. package/dist/src/molecules/figma/form-numeric-input.figma.d.ts.map +1 -0
  177. package/dist/src/molecules/figma/form-textarea.figma.d.ts +2 -0
  178. package/dist/src/molecules/figma/form-textarea.figma.d.ts.map +1 -0
  179. package/dist/src/molecules/figma/menu.figma.d.ts +2 -0
  180. package/dist/src/molecules/figma/menu.figma.d.ts.map +1 -0
  181. package/dist/src/molecules/figma/pagination.figma.d.ts +2 -0
  182. package/dist/src/molecules/figma/pagination.figma.d.ts.map +1 -0
  183. package/dist/src/molecules/figma/popover.figma.d.ts +2 -0
  184. package/dist/src/molecules/figma/popover.figma.d.ts.map +1 -0
  185. package/dist/src/molecules/figma/product-card.figma.d.ts +2 -0
  186. package/dist/src/molecules/figma/product-card.figma.d.ts.map +1 -0
  187. package/dist/src/molecules/figma/radio-card.figma.d.ts +2 -0
  188. package/dist/src/molecules/figma/radio-card.figma.d.ts.map +1 -0
  189. package/dist/src/molecules/figma/radio-group.figma.d.ts +2 -0
  190. package/dist/src/molecules/figma/radio-group.figma.d.ts.map +1 -0
  191. package/dist/src/molecules/figma/search-form.figma.d.ts +2 -0
  192. package/dist/src/molecules/figma/search-form.figma.d.ts.map +1 -0
  193. package/dist/src/molecules/figma/select.figma.d.ts +2 -0
  194. package/dist/src/molecules/figma/select.figma.d.ts.map +1 -0
  195. package/dist/src/molecules/figma/slider.figma.d.ts +2 -0
  196. package/dist/src/molecules/figma/slider.figma.d.ts.map +1 -0
  197. package/dist/src/molecules/figma/steps.figma.d.ts +2 -0
  198. package/dist/src/molecules/figma/steps.figma.d.ts.map +1 -0
  199. package/dist/src/molecules/figma/switch.figma.d.ts +2 -0
  200. package/dist/src/molecules/figma/switch.figma.d.ts.map +1 -0
  201. package/dist/src/molecules/figma/tabs.figma.d.ts +2 -0
  202. package/dist/src/molecules/figma/tabs.figma.d.ts.map +1 -0
  203. package/dist/src/molecules/figma/toast.figma.d.ts +2 -0
  204. package/dist/src/molecules/figma/toast.figma.d.ts.map +1 -0
  205. package/dist/src/molecules/figma/tree-view.figma.d.ts +2 -0
  206. package/dist/src/molecules/figma/tree-view.figma.d.ts.map +1 -0
  207. package/dist/src/molecules/form-checkbox.d.ts +22 -12
  208. package/dist/src/molecules/form-checkbox.d.ts.map +1 -1
  209. package/dist/src/molecules/form-input.d.ts +8 -6
  210. package/dist/src/molecules/form-input.d.ts.map +1 -1
  211. package/dist/src/molecules/form-numeric-input.d.ts +6 -6
  212. package/dist/src/molecules/form-numeric-input.d.ts.map +1 -1
  213. package/dist/src/molecules/form-textarea.d.ts +8 -6
  214. package/dist/src/molecules/form-textarea.d.ts.map +1 -1
  215. package/dist/src/molecules/menu.d.ts +11 -11
  216. package/dist/src/molecules/menu.d.ts.map +1 -1
  217. package/dist/src/molecules/pagination.d.ts +37 -9
  218. package/dist/src/molecules/pagination.d.ts.map +1 -1
  219. package/dist/src/molecules/phone-input.d.ts +246 -0
  220. package/dist/src/molecules/phone-input.d.ts.map +1 -0
  221. package/dist/src/molecules/popover.d.ts +76 -24
  222. package/dist/src/molecules/popover.d.ts.map +1 -1
  223. package/dist/src/molecules/product-card.d.ts +11 -10
  224. package/dist/src/molecules/product-card.d.ts.map +1 -1
  225. package/dist/src/molecules/radio-card.d.ts +429 -0
  226. package/dist/src/molecules/radio-card.d.ts.map +1 -0
  227. package/dist/src/molecules/radio-group.d.ts +245 -0
  228. package/dist/src/molecules/radio-group.d.ts.map +1 -0
  229. package/dist/src/molecules/search-form.d.ts +94 -27
  230. package/dist/src/molecules/search-form.d.ts.map +1 -1
  231. package/dist/src/molecules/select.d.ts +124 -30
  232. package/dist/src/molecules/select.d.ts.map +1 -1
  233. package/dist/src/molecules/slider.d.ts +9 -12
  234. package/dist/src/molecules/slider.d.ts.map +1 -1
  235. package/dist/src/molecules/steps.d.ts +236 -64
  236. package/dist/src/molecules/steps.d.ts.map +1 -1
  237. package/dist/src/molecules/switch.d.ts +7 -7
  238. package/dist/src/molecules/switch.d.ts.map +1 -1
  239. package/dist/src/molecules/tabs.d.ts +10 -10
  240. package/dist/src/molecules/tabs.d.ts.map +1 -1
  241. package/dist/src/molecules/toast.d.ts +6 -6
  242. package/dist/src/molecules/tree-view.d.ts +14 -14
  243. package/dist/src/molecules/tree-view.d.ts.map +1 -1
  244. package/dist/src/organisms/footer.d.ts +15 -6
  245. package/dist/src/organisms/footer.d.ts.map +1 -1
  246. package/dist/src/organisms/gallery.d.ts +147 -0
  247. package/dist/src/organisms/gallery.d.ts.map +1 -0
  248. package/dist/src/organisms/header.d.ts +9 -9
  249. package/dist/src/organisms/header.d.ts.map +1 -1
  250. package/dist/src/organisms/table.d.ts +10 -10
  251. package/dist/src/organisms/table.d.ts.map +1 -1
  252. package/dist/src/templates/accordion.d.ts +3 -3
  253. package/dist/src/templates/breadcrumb.d.ts +28 -0
  254. package/dist/src/templates/breadcrumb.d.ts.map +1 -0
  255. package/dist/src/templates/carousel.d.ts +4 -4
  256. package/dist/src/templates/carousel.d.ts.map +1 -1
  257. package/dist/src/templates/gallery.d.ts +43 -0
  258. package/dist/src/templates/gallery.d.ts.map +1 -0
  259. package/dist/src/templates/numeric-input.d.ts +5 -5
  260. package/dist/src/templates/popover.d.ts +19 -0
  261. package/dist/src/templates/popover.d.ts.map +1 -0
  262. package/dist/src/templates/product-card.d.ts +4 -4
  263. package/dist/src/templates/select.d.ts +22 -0
  264. package/dist/src/templates/select.d.ts.map +1 -0
  265. package/dist/src/templates/tabs.d.ts +4 -4
  266. package/dist/src/types/zag.d.ts +19 -18
  267. package/dist/src/types/zag.d.ts.map +1 -1
  268. package/dist/src/utils.d.ts +1 -1
  269. package/dist/src/utils.d.ts.map +1 -1
  270. package/dist/stories/atoms/badge.stories.d.ts +12 -0
  271. package/dist/stories/atoms/badge.stories.d.ts.map +1 -0
  272. package/dist/stories/atoms/button.stories.d.ts +12 -0
  273. package/dist/stories/atoms/button.stories.d.ts.map +1 -0
  274. package/dist/stories/atoms/checkbox.stories.d.ts +56 -0
  275. package/dist/stories/atoms/checkbox.stories.d.ts.map +1 -0
  276. package/dist/stories/atoms/icon.stories.d.ts +11 -0
  277. package/dist/stories/atoms/icon.stories.d.ts.map +1 -0
  278. package/dist/stories/atoms/image.stories.d.ts +8 -0
  279. package/dist/stories/atoms/image.stories.d.ts.map +1 -0
  280. package/dist/stories/atoms/input.stories.d.ts +8 -0
  281. package/dist/stories/atoms/input.stories.d.ts.map +1 -0
  282. package/dist/stories/atoms/numeric-input.stories.d.ts +23 -0
  283. package/dist/stories/atoms/numeric-input.stories.d.ts.map +1 -0
  284. package/dist/stories/atoms/rating.stories.d.ts +10 -0
  285. package/dist/stories/atoms/rating.stories.d.ts.map +1 -0
  286. package/dist/stories/atoms/skeleton.stories.d.ts +34 -0
  287. package/dist/stories/atoms/skeleton.stories.d.ts.map +1 -0
  288. package/dist/stories/atoms/status-text.stories.d.ts +15 -0
  289. package/dist/stories/atoms/status-text.stories.d.ts.map +1 -0
  290. package/dist/stories/atoms/textarea.stories.d.ts +12 -0
  291. package/dist/stories/atoms/textarea.stories.d.ts.map +1 -0
  292. package/dist/stories/atoms/tooltip.stories.d.ts +28 -0
  293. package/dist/stories/atoms/tooltip.stories.d.ts.map +1 -0
  294. package/dist/stories/helpers/icon-options.d.ts +4 -0
  295. package/dist/stories/helpers/icon-options.d.ts.map +1 -0
  296. package/dist/stories/molecules/accordion.stories.d.ts +14 -0
  297. package/dist/stories/molecules/accordion.stories.d.ts.map +1 -0
  298. package/dist/stories/molecules/breadcrumb.stories.d.ts +14 -0
  299. package/dist/stories/molecules/breadcrumb.stories.d.ts.map +1 -0
  300. package/dist/stories/molecules/carousel.stories.d.ts +19 -0
  301. package/dist/stories/molecules/carousel.stories.d.ts.map +1 -0
  302. package/dist/stories/molecules/color-select.stories.d.ts +12 -0
  303. package/dist/stories/molecules/color-select.stories.d.ts.map +1 -0
  304. package/dist/stories/molecules/combobox.stories.d.ts +11 -0
  305. package/dist/stories/molecules/combobox.stories.d.ts.map +1 -0
  306. package/dist/stories/molecules/dialog.stories.d.ts +19 -0
  307. package/dist/stories/molecules/dialog.stories.d.ts.map +1 -0
  308. package/dist/stories/molecules/form-checkbox.stories.d.ts +17 -0
  309. package/dist/stories/molecules/form-checkbox.stories.d.ts.map +1 -0
  310. package/dist/stories/molecules/form-input.stories.d.ts +12 -0
  311. package/dist/stories/molecules/form-input.stories.d.ts.map +1 -0
  312. package/dist/stories/molecules/form-numeric-input.stories.d.ts +17 -0
  313. package/dist/stories/molecules/form-numeric-input.stories.d.ts.map +1 -0
  314. package/dist/stories/molecules/form-textarea.stories.d.ts +12 -0
  315. package/dist/stories/molecules/form-textarea.stories.d.ts.map +1 -0
  316. package/dist/stories/molecules/menu.stories.d.ts +22 -0
  317. package/dist/stories/molecules/menu.stories.d.ts.map +1 -0
  318. package/dist/stories/molecules/pagination.stories.d.ts +13 -0
  319. package/dist/stories/molecules/pagination.stories.d.ts.map +1 -0
  320. package/dist/stories/molecules/phone-input.stories.d.ts +19 -0
  321. package/dist/stories/molecules/phone-input.stories.d.ts.map +1 -0
  322. package/dist/stories/molecules/popover.stories.d.ts +140 -0
  323. package/dist/stories/molecules/popover.stories.d.ts.map +1 -0
  324. package/dist/stories/molecules/product-card.stories.d.ts +41 -0
  325. package/dist/stories/molecules/product-card.stories.d.ts.map +1 -0
  326. package/dist/stories/molecules/radio-card.stories.d.ts +13 -0
  327. package/dist/stories/molecules/radio-card.stories.d.ts.map +1 -0
  328. package/dist/stories/molecules/radio-group.stories.d.ts +13 -0
  329. package/dist/stories/molecules/radio-group.stories.d.ts.map +1 -0
  330. package/dist/stories/molecules/search-form.stories.d.ts +16 -0
  331. package/dist/stories/molecules/search-form.stories.d.ts.map +1 -0
  332. package/dist/stories/molecules/select.stories.d.ts +19 -0
  333. package/dist/stories/molecules/select.stories.d.ts.map +1 -0
  334. package/dist/stories/molecules/slider.stories.d.ts +19 -0
  335. package/dist/stories/molecules/slider.stories.d.ts.map +1 -0
  336. package/dist/stories/molecules/steps.stories.d.ts +19 -0
  337. package/dist/stories/molecules/steps.stories.d.ts.map +1 -0
  338. package/dist/stories/molecules/switch.stories.d.ts +13 -0
  339. package/dist/stories/molecules/switch.stories.d.ts.map +1 -0
  340. package/dist/stories/molecules/tabs.stories.d.ts +18 -0
  341. package/dist/stories/molecules/tabs.stories.d.ts.map +1 -0
  342. package/dist/stories/molecules/toast.stories.d.ts +11 -0
  343. package/dist/stories/molecules/toast.stories.d.ts.map +1 -0
  344. package/dist/stories/molecules/tree-view.stories.d.ts +17 -0
  345. package/dist/stories/molecules/tree-view.stories.d.ts.map +1 -0
  346. package/dist/stories/organisms/footer.stories.d.ts +12 -0
  347. package/dist/stories/organisms/footer.stories.d.ts.map +1 -0
  348. package/dist/stories/organisms/gallery.stories.d.ts +73 -0
  349. package/dist/stories/organisms/gallery.stories.d.ts.map +1 -0
  350. package/dist/stories/organisms/header.stories.d.ts +12 -0
  351. package/dist/stories/organisms/header.stories.d.ts.map +1 -0
  352. package/dist/stories/organisms/table.stories.d.ts +56 -0
  353. package/dist/stories/organisms/table.stories.d.ts.map +1 -0
  354. package/dist/stories/overview/apca-contrast-test.stories.d.ts +8 -0
  355. package/dist/stories/overview/apca-contrast-test.stories.d.ts.map +1 -0
  356. package/dist/stories/overview/color-palette.stories.d.ts +8 -0
  357. package/dist/stories/overview/color-palette.stories.d.ts.map +1 -0
  358. package/dist/stories/overview/component-comparison.stories.d.ts +6 -0
  359. package/dist/stories/overview/component-comparison.stories.d.ts.map +1 -0
  360. package/dist/stories/templates/accordion.stories.d.ts +8 -0
  361. package/dist/stories/templates/accordion.stories.d.ts.map +1 -0
  362. package/dist/stories/templates/breadcrumb.stories.d.ts +12 -0
  363. package/dist/stories/templates/breadcrumb.stories.d.ts.map +1 -0
  364. package/dist/stories/templates/carousel.stories.d.ts +8 -0
  365. package/dist/stories/templates/carousel.stories.d.ts.map +1 -0
  366. package/dist/stories/templates/comprehensive-form.stories.d.ts +26 -0
  367. package/dist/stories/templates/comprehensive-form.stories.d.ts.map +1 -0
  368. package/dist/stories/templates/gallery.stories.d.ts +7 -0
  369. package/dist/stories/templates/gallery.stories.d.ts.map +1 -0
  370. package/dist/stories/templates/numeric-input.stories.d.ts +8 -0
  371. package/dist/stories/templates/numeric-input.stories.d.ts.map +1 -0
  372. package/dist/stories/templates/popover.stories.d.ts +55 -0
  373. package/dist/stories/templates/popover.stories.d.ts.map +1 -0
  374. package/dist/stories/templates/product-card.stories.d.ts +10 -0
  375. package/dist/stories/templates/product-card.stories.d.ts.map +1 -0
  376. package/dist/stories/templates/select.stories.d.ts +10 -0
  377. package/dist/stories/templates/select.stories.d.ts.map +1 -0
  378. package/dist/stories/templates/tabs.stories.d.ts +8 -0
  379. package/dist/stories/templates/tabs.stories.d.ts.map +1 -0
  380. package/dist/templates/accordion.js +9 -9
  381. package/dist/templates/breadcrumb.js +78 -0
  382. package/dist/templates/carousel.js +13 -15
  383. package/dist/templates/gallery.js +89 -0
  384. package/dist/templates/numeric-input.js +4 -4
  385. package/dist/templates/popover.js +35 -0
  386. package/dist/templates/product-card.js +10 -10
  387. package/dist/templates/select.js +43 -0
  388. package/dist/templates/tabs.js +8 -8
  389. package/dist/test/visual.spec.d.ts +2 -0
  390. package/dist/test/visual.spec.d.ts.map +1 -0
  391. package/dist/utils.js +1 -1
  392. package/package.json +41 -28
  393. package/src/tokens/_base.css +3 -3
  394. package/src/tokens/_layout.css +4 -0
  395. package/src/tokens/_semantic.css +49 -10
  396. package/src/tokens/_tokens-base.css +67 -0
  397. package/src/tokens/_typography.css +36 -6
  398. package/src/tokens/components/_form-control.css +67 -0
  399. package/src/tokens/components/atoms/_badge.css +16 -5
  400. package/src/tokens/components/atoms/_button.css +16 -10
  401. package/src/tokens/components/atoms/_checkbox.css +52 -0
  402. package/src/tokens/components/atoms/_icon.css +90 -2
  403. package/src/tokens/components/atoms/_image.css +5 -0
  404. package/src/tokens/components/atoms/_input.css +11 -32
  405. package/src/tokens/components/atoms/_label.css +11 -0
  406. package/src/tokens/components/atoms/_numeric-input.css +27 -13
  407. package/src/tokens/components/atoms/_rating.css +2 -2
  408. package/src/tokens/components/atoms/_status-text.css +32 -0
  409. package/src/tokens/components/atoms/_textarea.css +15 -17
  410. package/src/tokens/components/components.css +10 -1
  411. package/src/tokens/components/molecules/_accordion.css +1 -8
  412. package/src/tokens/components/molecules/_breadcrumb.css +42 -20
  413. package/src/tokens/components/molecules/_carousel.css +10 -2
  414. package/src/tokens/components/molecules/_color-select.css +3 -3
  415. package/src/tokens/components/molecules/_combobox.css +15 -21
  416. package/src/tokens/components/molecules/_dialog.css +0 -1
  417. package/src/tokens/components/molecules/_menu.css +0 -1
  418. package/src/tokens/components/molecules/_pagination.css +3 -3
  419. package/src/tokens/components/molecules/_phone-input.css +63 -0
  420. package/src/tokens/components/molecules/_popover.css +3 -0
  421. package/src/tokens/components/molecules/_product-card.css +9 -1
  422. package/src/tokens/components/molecules/_radio-card.css +197 -0
  423. package/src/tokens/components/molecules/_radio-group.css +150 -0
  424. package/src/tokens/components/molecules/_search-form.css +7 -3
  425. package/src/tokens/components/molecules/_select.css +41 -20
  426. package/src/tokens/components/molecules/_steps.css +115 -34
  427. package/src/tokens/components/molecules/_toast.css +5 -5
  428. package/src/tokens/components/molecules/_tree-view.css +5 -6
  429. package/src/tokens/components/organisms/_footer.css +1 -6
  430. package/src/tokens/components/organisms/_gallery.css +35 -0
  431. package/src/tokens/components/organisms/_header.css +8 -0
  432. package/src/tokens/figma/dark/variables.css +1406 -0
  433. package/src/tokens/figma/light/variables.css +1406 -0
  434. package/src/tokens/index.css +1 -65
  435. package/src/tokens/tokens-only.css +1 -64
  436. package/dist/atoms/error-text.js +0 -38
  437. package/dist/atoms/extra-text.js +0 -27
  438. package/dist/molecules/checkbox.js +0 -98
  439. package/dist/src/atoms/error-text.d.ts +0 -29
  440. package/dist/src/atoms/error-text.d.ts.map +0 -1
  441. package/dist/src/atoms/extra-text.d.ts +0 -27
  442. package/dist/src/atoms/extra-text.d.ts.map +0 -1
  443. package/dist/src/molecules/checkbox.d.ts +0 -19
  444. package/dist/src/molecules/checkbox.d.ts.map +0 -1
  445. package/src/tokens/components/molecules/_checkbox.css +0 -34
  446. package/src/tokens/components/molecules/index.css +0 -2
@@ -8,106 +8,102 @@ import { tv } from "../utils.js";
8
8
  const accordionVariants = tv({
9
9
  slots: {
10
10
  root: [
11
- 'flex flex-col w-full',
12
- 'bg-accordion-bg rounded-accordion',
13
- 'transition-all duration-200'
11
+ "flex w-full flex-col",
12
+ "rounded-accordion bg-accordion-bg",
13
+ "transition-all duration-200",
14
+ "transition-all duration-200 motion-reduce:transition-none"
14
15
  ],
15
- item: '',
16
- title: 'grid place-items-start',
16
+ item: "",
17
+ title: "grid place-items-start",
17
18
  titleTrigger: [
18
- 'flex items-center relative justify-between w-full cursor-pointer',
19
- 'rounded-none',
20
- 'font-accordion-title',
21
- 'text-accordion-title-fg bg-accordion-title-bg',
22
- 'focus-visible:outline-none',
23
- 'focus-visible:ring',
24
- 'focus-visible:ring-accordion-ring',
25
- 'focus-visible:bg-accordion-bg-hover',
26
- 'data-[disabled]:text-accordion-fg-disabled',
27
- 'hover:bg-accordion-title-bg-hover',
28
- 'px-0 py-0 pr-accordion-icon',
29
- 'data-[disabled=true]:cursor-not-allowed'
19
+ "relative flex w-full cursor-pointer items-center justify-between",
20
+ "rounded-none",
21
+ "font-accordion-title",
22
+ "bg-accordion-title-bg text-accordion-title-fg",
23
+ "hover:bg-accordion-title-bg-hover",
24
+ "pr-accordion-icon",
25
+ "data-[disabled=true]:cursor-not-allowed"
30
26
  ],
31
27
  subtitle: [
32
- 'text-accordion-subtitle-fg'
28
+ "text-accordion-subtitle-fg"
33
29
  ],
34
30
  content: [
35
- 'text-accordion-content-fg bg-accordion-content-bg'
31
+ "bg-accordion-content-bg text-accordion-content-fg"
36
32
  ],
37
33
  icon: [
38
- 'data-[state=expanded]:rotate-180'
34
+ "data-[state=expanded]:rotate-180"
39
35
  ]
40
36
  },
41
37
  variants: {
42
38
  variant: {
43
39
  default: {
44
- root: 'border-accordion-border border-(length:--border-width-accordion)',
45
- item: 'border-b-(length:--border-width-accordion) border-accordion-border'
40
+ root: "border-(length:--border-width-accordion) border-accordion-border",
41
+ item: "border-b-(length:--border-width-accordion) border-accordion-border"
46
42
  },
47
43
  borderless: {},
48
44
  child: {}
49
45
  },
50
46
  shadow: {
51
47
  sm: {
52
- root: 'shadow-accordion-root-sm',
53
- content: 'shadow-accordion-content-sm'
48
+ root: "shadow-accordion-root-sm",
49
+ content: "shadow-accordion-content-sm"
54
50
  },
55
51
  md: {
56
- root: 'shadow-accordion-root-md',
57
- content: 'shadow-accordion-content-md'
52
+ root: "shadow-accordion-root-md",
53
+ content: "shadow-accordion-content-md"
58
54
  },
59
- none: ''
55
+ none: ""
60
56
  },
61
57
  size: {
62
58
  sm: {
63
- title: 'text-accordion-title-sm p-accordion-title-sm',
64
- content: 'text-accordion-content-sm px-accordion-content-sm',
65
- subtitle: 'text-accordion-subtitle-sm'
59
+ title: "p-accordion-title-sm text-accordion-title-sm",
60
+ content: "px-accordion-content-sm text-accordion-content-sm",
61
+ subtitle: "text-accordion-subtitle-sm"
66
62
  },
67
63
  md: {
68
- title: 'text-accordion-title-md p-accordion-title-md',
69
- content: 'text-accordion-content-md p-accordion-content-md',
70
- subtitle: 'text-accordion-subtitle-md'
64
+ title: "p-accordion-title-md text-accordion-title-md",
65
+ content: "p-accordion-content-md text-accordion-content-md",
66
+ subtitle: "text-accordion-subtitle-md"
71
67
  },
72
68
  lg: {
73
- title: 'text-accordion-title-lg p-accordion-title-lg',
74
- content: 'text-accordion-content-lg p-accordion-content-lg',
75
- subtitle: 'text-accordion-subtitle-lg'
69
+ title: "p-accordion-title-lg text-accordion-title-lg",
70
+ content: "p-accordion-content-lg text-accordion-content-lg",
71
+ subtitle: "text-accordion-subtitle-lg"
76
72
  }
77
73
  }
78
74
  },
79
75
  compoundVariants: [
80
76
  {
81
- variant: 'child',
77
+ variant: "child",
82
78
  size: [
83
- 'sm',
84
- 'md',
85
- 'lg'
79
+ "sm",
80
+ "md",
81
+ "lg"
86
82
  ],
87
83
  className: {
88
- content: 'py-0 bg-inherit text-inherit'
84
+ content: "bg-inherit py-0 text-inherit"
89
85
  }
90
86
  }
91
87
  ],
92
88
  defaultVariants: {
93
- size: 'md',
94
- shadow: 'none',
95
- variant: 'default'
89
+ size: "md",
90
+ shadow: "none",
91
+ variant: "default"
96
92
  }
97
93
  });
98
94
  const AccordionContext = /*#__PURE__*/ createContext(null);
99
95
  function useAccordionContext() {
100
96
  const context = useContext(AccordionContext);
101
- if (!context) throw new Error('Accordion components must be used within Accordion.Root');
97
+ if (!context) throw new Error("Accordion components must be used within Accordion.Root");
102
98
  return context;
103
99
  }
104
100
  const AccordionItemContext = /*#__PURE__*/ createContext(null);
105
101
  function useAccordionItemContext() {
106
102
  const context = useContext(AccordionItemContext);
107
- if (!context) throw new Error('Accordion item components must be used within Accordion.Item');
103
+ if (!context) throw new Error("Accordion item components must be used within Accordion.Item");
108
104
  return context;
109
105
  }
110
- function Accordion({ id, defaultValue, value, collapsible = true, multiple = false, dir = 'ltr', onChange, size, shadow, disabled = false, children, ref, className, variant, ...props }) {
106
+ function Accordion({ id, defaultValue, value, collapsible = true, multiple = false, dir = "ltr", onChange, size, shadow, disabled = false, children, ref, className, variant, ...props }) {
111
107
  const generatedId = useId();
112
108
  const uniqueId = id || generatedId;
113
109
  const service = useMachine(machine, {
@@ -117,10 +113,10 @@ function Accordion({ id, defaultValue, value, collapsible = true, multiple = fal
117
113
  collapsible,
118
114
  multiple,
119
115
  dir,
120
- orientation: 'vertical',
116
+ orientation: "vertical",
121
117
  disabled,
122
- onValueChange: ({ value })=>{
123
- onChange?.(value);
118
+ onValueChange: ({ value: newValue })=>{
119
+ onChange?.(newValue);
124
120
  }
125
121
  });
126
122
  const api = connect(service, normalizeProps);
@@ -138,10 +134,10 @@ function Accordion({ id, defaultValue, value, collapsible = true, multiple = fal
138
134
  variant
139
135
  },
140
136
  children: /*#__PURE__*/ jsx("div", {
141
- ref: ref,
142
137
  className: styles.root({
143
138
  className
144
139
  }),
140
+ ref: ref,
145
141
  ...props,
146
142
  ...api.getRootProps(),
147
143
  children: children
@@ -173,13 +169,14 @@ Accordion.Header = function({ children, ref, className, ...props }) {
173
169
  const { api, styles } = useAccordionContext();
174
170
  const { value, disabled } = useAccordionItemContext();
175
171
  return /*#__PURE__*/ jsx("header", {
176
- ref: ref,
177
172
  className: className,
173
+ ref: ref,
178
174
  ...props,
179
175
  children: /*#__PURE__*/ jsx(Button, {
180
- type: "button",
181
- theme: "borderless",
182
176
  className: styles.titleTrigger(),
177
+ size: "current",
178
+ theme: "unstyled",
179
+ type: "button",
183
180
  ...api.getItemTriggerProps({
184
181
  value,
185
182
  disabled
@@ -193,30 +190,31 @@ Accordion.Content = function({ children, ref, className, ...props }) {
193
190
  const { api, styles } = useAccordionContext();
194
191
  const { value } = useAccordionItemContext();
195
192
  return /*#__PURE__*/ jsx("div", {
196
- ref: ref,
197
193
  className: styles.content({
198
194
  className
199
195
  }),
196
+ ref: ref,
200
197
  ...props,
201
198
  ...api.getItemContentProps({
202
199
  value
203
200
  }),
204
- "data-state": api.value.includes(value) ? 'expanded' : 'collapsed',
201
+ "data-state": api.value.includes(value) ? "expanded" : "collapsed",
205
202
  children: children
206
203
  });
207
204
  };
208
- Accordion.Indicator = function({ icon = 'token-icon-accordion-chevron', ref, className, ...props }) {
205
+ Accordion.Indicator = function({ icon = "token-icon-accordion-chevron", iconSize, ref, className, ...props }) {
209
206
  const { api, styles } = useAccordionContext();
210
207
  const { value } = useAccordionItemContext();
211
208
  const isExpanded = api.value.includes(value);
212
209
  return /*#__PURE__*/ jsx("span", {
213
- ref: ref,
214
210
  className: className,
211
+ ref: ref,
215
212
  ...props,
216
213
  children: /*#__PURE__*/ jsx(Icon, {
217
214
  className: styles.icon(),
215
+ "data-state": isExpanded ? "expanded" : "collapsed",
218
216
  icon: icon,
219
- "data-state": isExpanded ? 'expanded' : 'collapsed'
217
+ size: iconSize
220
218
  })
221
219
  });
222
220
  };
@@ -234,10 +232,10 @@ Accordion.Title = function({ children, ref, className, ...props }) {
234
232
  Accordion.Subtitle = function({ children, ref, className, ...props }) {
235
233
  const { styles } = useAccordionContext();
236
234
  return /*#__PURE__*/ jsx("span", {
237
- ref: ref,
238
235
  className: styles.subtitle({
239
236
  className
240
237
  }),
238
+ ref: ref,
241
239
  ...props,
242
240
  children: children
243
241
  });
@@ -1,168 +1,250 @@
1
- import { jsx, jsxs } from "react/jsx-runtime";
2
- import { tv } from "tailwind-variants";
1
+ import { jsx } from "react/jsx-runtime";
2
+ import { createContext, useContext } from "react";
3
3
  import { Icon } from "../atoms/icon.js";
4
4
  import { Link } from "../atoms/link.js";
5
- const breadcrumbsVariants = tv({
5
+ import { tv } from "../utils.js";
6
+ const BreadcrumbVariants = tv({
6
7
  slots: {
7
8
  root: [
8
- 'inline-flex flex-wrap items-center',
9
- 'bg-breadcrumb-bg'
9
+ "inline-flex flex-wrap items-center",
10
+ "bg-breadcrumb-bg"
10
11
  ],
11
12
  list: [
12
- 'flex items-center',
13
- 'break-words',
14
- 'list-none'
13
+ "flex flex-wrap items-center",
14
+ "break-words",
15
+ "list-none",
16
+ "text-breadcrumb-list-fg"
15
17
  ],
16
18
  item: [
17
- 'inline-flex items-center',
18
- 'text-breadcrumb-item-fg',
19
- 'hover:text-breadcrumb-fg-hover',
20
- 'data-[current=true]:text-breadcrumb-fg-current',
21
- 'h-full'
19
+ "inline-flex min-w-0 items-center",
20
+ "text-breadcrumb-item-fg"
22
21
  ],
23
22
  link: [
24
- 'no-underline',
25
- 'cursor-pointer',
26
- 'hover:text-breadcrumb-fg-hover',
27
- 'focus:outline-none',
28
- 'focus-visible:ring',
29
- 'focus-visible:ring-breadcrumb-ring'
23
+ "inline-flex min-w-0 items-center",
24
+ "rounded-breadcrumb-link",
25
+ "text-breadcrumb-link-fg",
26
+ "no-underline",
27
+ "cursor-pointer",
28
+ "hover:text-breadcrumb-link-fg-hover",
29
+ "focus-visible:outline-(style:--default-ring-style) focus-visible:outline-(length:--default-ring-width)",
30
+ "focus-visible:outline-breadcrumb-ring",
31
+ "focus-visible:outline-offset-(length:--default-ring-offset)",
32
+ "transition-colors duration-200 motion-reduce:transition-none"
30
33
  ],
31
34
  currentLink: [
32
- 'cursor-default'
35
+ "inline-flex min-w-0 items-center",
36
+ "rounded-breadcrumb-link",
37
+ "text-breadcrumb-current-link-fg",
38
+ "cursor-default"
33
39
  ],
40
+ icon: [
41
+ "inline-flex items-center justify-center"
42
+ ],
43
+ iconSize: "",
34
44
  separator: [
35
- 'text-breadcrumb-separator-fg',
36
- 'inline-flex items-center justify-center',
37
- 'rtl:rotate-180'
45
+ "inline-flex shrink-0 items-center justify-center",
46
+ "text-breadcrumb-separator-fg",
47
+ "rtl:rotate-180"
48
+ ],
49
+ separatorIcon: [
50
+ "inline-flex items-center justify-center"
38
51
  ],
52
+ separatorIconSize: "",
39
53
  ellipsis: [
40
- 'text-breadcrumb-ellipsis-fg',
41
- 'inline-flex items-center justify-center'
42
- ]
54
+ "inline-flex shrink-0 items-center justify-center",
55
+ "text-breadcrumb-ellipsis-fg"
56
+ ],
57
+ ellipsisIcon: [
58
+ "inline-flex items-center justify-center"
59
+ ],
60
+ ellipsisIconSize: ""
43
61
  },
44
- compoundSlots: [
45
- {
46
- slots: [
47
- 'link',
48
- 'currentLink'
49
- ],
50
- class: [
51
- 'font-medium inline-flex items-center',
52
- 'outline-none focus:outline-none'
53
- ]
54
- }
55
- ],
56
62
  variants: {
63
+ variant: {
64
+ plain: {},
65
+ underline: {
66
+ link: "underline",
67
+ currentLink: "underline"
68
+ }
69
+ },
57
70
  size: {
58
71
  sm: {
59
- root: 'text-breadcrumb-sm p-breadcrumb-sm',
60
- list: 'gap-breadcrumb-sm',
61
- item: 'gap-breadcrumb-sm',
62
- separator: 'gap-breadcrumb-sm',
63
- ellipsis: 'text-breadcrumb-sm'
72
+ root: "p-breadcrumb-root-sm text-breadcrumb-sm",
73
+ list: "gap-breadcrumb-list-sm",
74
+ link: "gap-breadcrumb-link-sm",
75
+ currentLink: "gap-breadcrumb-link-sm",
76
+ iconSize: "text-breadcrumb-icon-sm",
77
+ separator: "gap-breadcrumb-separator-sm",
78
+ separatorIconSize: "text-breadcrumb-separator-icon-sm",
79
+ ellipsisIconSize: "text-breadcrumb-ellipsis-icon-sm"
64
80
  },
65
81
  md: {
66
- root: 'text-breadcrumb-md p-breadcrumb-md',
67
- list: 'gap-breadcrumb-md',
68
- item: 'gap-breadcrumb-md',
69
- separator: 'gap-breadcrumb-md',
70
- ellipsis: 'text-breadcrumb-md'
82
+ root: "p-breadcrumb-root-md text-breadcrumb-md",
83
+ list: "gap-breadcrumb-list-md",
84
+ link: "gap-breadcrumb-link-md",
85
+ currentLink: "gap-breadcrumb-link-md",
86
+ iconSize: "text-breadcrumb-icon-md",
87
+ separator: "gap-breadcrumb-separator-md",
88
+ separatorIconSize: "text-breadcrumb-separator-icon-md",
89
+ ellipsisIconSize: "text-breadcrumb-ellipsis-icon-md"
71
90
  },
72
91
  lg: {
73
- root: 'text-breadcrumb-lg p-breadcrumb-lg',
74
- list: 'gap-breadcrumb-lg',
75
- item: 'gap-breadcrumb-lg',
76
- separator: 'gap-breadcrumb-lg',
77
- ellipsis: 'text-breadcrumb-lg'
92
+ root: "p-breadcrumb-root-lg text-breadcrumb-lg",
93
+ list: "gap-breadcrumb-list-lg",
94
+ link: "gap-breadcrumb-link-lg",
95
+ currentLink: "gap-breadcrumb-link-lg",
96
+ iconSize: "text-breadcrumb-icon-lg",
97
+ separator: "gap-breadcrumb-separator-lg",
98
+ separatorIconSize: "text-breadcrumb-separator-icon-lg",
99
+ ellipsisIconSize: "text-breadcrumb-ellipsis-icon-lg"
78
100
  }
79
101
  }
80
102
  },
81
103
  defaultVariants: {
82
- size: 'md'
104
+ size: "md",
105
+ variant: "plain"
83
106
  }
84
107
  });
85
- function BreadcrumbItem({ label, href, icon, separator = 'token-icon-breadcrumb-separator', isCurrentPage, lastItem, linkAs }) {
86
- const { item, currentLink, link, separator: separatorSlot } = breadcrumbsVariants({
87
- size: 'md'
108
+ const BreadcrumbContext = /*#__PURE__*/ createContext(null);
109
+ function useBreadcrumbContext() {
110
+ const context = useContext(BreadcrumbContext);
111
+ if (!context) throw new Error("Breadcrumb components must be used within Breadcrumb.Root");
112
+ return context;
113
+ }
114
+ function getContextualIconClassName({ className, defaultClassName, useDefaultClassName }) {
115
+ if (!useDefaultClassName) return className;
116
+ return [
117
+ defaultClassName,
118
+ className
119
+ ].filter(Boolean).join(" ");
120
+ }
121
+ function Breadcrumb({ children, className, ref, size, variant, "aria-label": ariaLabel = "breadcrumb", ...props }) {
122
+ const styles = BreadcrumbVariants({
123
+ size,
124
+ variant
88
125
  });
89
- return /*#__PURE__*/ jsxs("li", {
90
- className: item(),
91
- "data-current": isCurrentPage,
92
- children: [
93
- icon && /*#__PURE__*/ jsx(Icon, {
94
- icon: icon
95
- }),
96
- isCurrentPage ? /*#__PURE__*/ jsx("span", {
97
- className: currentLink(),
98
- "aria-current": "page",
99
- children: label
100
- }) : /*#__PURE__*/ jsx(Link, {
101
- as: linkAs,
102
- href: href || '#',
103
- className: link(),
104
- children: label
126
+ return /*#__PURE__*/ jsx(BreadcrumbContext.Provider, {
127
+ value: {
128
+ styles
129
+ },
130
+ children: /*#__PURE__*/ jsx("nav", {
131
+ "aria-label": ariaLabel,
132
+ className: styles.root({
133
+ className
105
134
  }),
106
- !lastItem && /*#__PURE__*/ jsx("span", {
107
- className: separatorSlot(),
108
- children: /*#__PURE__*/ jsx(Icon, {
109
- icon: separator ?? 'token-icon-breadcrumb-separator'
110
- })
111
- })
112
- ]
135
+ ref: ref,
136
+ ...props,
137
+ children: children
138
+ })
113
139
  });
114
140
  }
115
- function BreadcrumbEllipsis() {
116
- const { ellipsis, separator: separatorSlot } = breadcrumbsVariants({
117
- size: 'md'
141
+ Breadcrumb.List = function({ children, className, ref, ...props }) {
142
+ const { styles } = useBreadcrumbContext();
143
+ return /*#__PURE__*/ jsx("ol", {
144
+ className: styles.list({
145
+ className
146
+ }),
147
+ ref: ref,
148
+ ...props,
149
+ children: children
118
150
  });
119
- return /*#__PURE__*/ jsxs("li", {
120
- className: ellipsis(),
121
- children: [
122
- /*#__PURE__*/ jsx("span", {
123
- "aria-hidden": "true",
124
- children: /*#__PURE__*/ jsx(Icon, {
125
- icon: "token-icon-breadcrumb-ellipsis"
126
- })
127
- }),
128
- /*#__PURE__*/ jsx("span", {
129
- className: separatorSlot(),
130
- children: /*#__PURE__*/ jsx(Icon, {
131
- icon: 'token-icon-breadcrumb-separator'
132
- })
151
+ };
152
+ Breadcrumb.Item = function({ children, className, ref, ...props }) {
153
+ const { styles } = useBreadcrumbContext();
154
+ return /*#__PURE__*/ jsx("li", {
155
+ className: styles.item({
156
+ className
157
+ }),
158
+ ref: ref,
159
+ ...props,
160
+ children: children
161
+ });
162
+ };
163
+ Breadcrumb.Link = function({ children, className, ...props }) {
164
+ const { styles } = useBreadcrumbContext();
165
+ return /*#__PURE__*/ jsx(Link, {
166
+ className: styles.link({
167
+ className
168
+ }),
169
+ ...props,
170
+ children: children
171
+ });
172
+ };
173
+ Breadcrumb.CurrentLink = function({ children, className, ref, ...props }) {
174
+ const { styles } = useBreadcrumbContext();
175
+ return /*#__PURE__*/ jsx("span", {
176
+ "aria-current": "page",
177
+ className: styles.currentLink({
178
+ className
179
+ }),
180
+ ref: ref,
181
+ ...props,
182
+ children: children
183
+ });
184
+ };
185
+ Breadcrumb.Icon = function({ className, size, ...props }) {
186
+ const { styles } = useBreadcrumbContext();
187
+ return /*#__PURE__*/ jsx(Icon, {
188
+ className: styles.icon({
189
+ className: getContextualIconClassName({
190
+ className,
191
+ defaultClassName: styles.iconSize(),
192
+ useDefaultClassName: !size
133
193
  })
134
- ]
194
+ }),
195
+ size: size,
196
+ ...props
135
197
  });
136
- }
137
- function Breadcrumb({ items, maxItems = 0, size = 'md', className, 'aria-label': ariaLabel = 'breadcrumb', linkAs, ...props }) {
138
- const { root, list } = breadcrumbsVariants({
139
- size
198
+ };
199
+ Breadcrumb.Separator = function({ children, className, icon = "token-icon-breadcrumb-separator", iconProps, iconSize, ref, ...props }) {
200
+ const { styles } = useBreadcrumbContext();
201
+ const { className: iconClassName, ...restIconProps } = iconProps ?? {};
202
+ return /*#__PURE__*/ jsx("li", {
203
+ "aria-hidden": "true",
204
+ className: styles.separator({
205
+ className
206
+ }),
207
+ ref: ref,
208
+ ...props,
209
+ children: children ?? /*#__PURE__*/ jsx(Icon, {
210
+ className: styles.separatorIcon({
211
+ className: getContextualIconClassName({
212
+ className: iconClassName,
213
+ defaultClassName: styles.separatorIconSize(),
214
+ useDefaultClassName: !iconSize
215
+ })
216
+ }),
217
+ icon: icon,
218
+ size: iconSize,
219
+ ...restIconProps
220
+ })
140
221
  });
141
- const displayItems = maxItems <= 0 || items.length <= maxItems ? items : 1 === maxItems ? [
142
- items.at(-1)
143
- ] : [
144
- items[0],
145
- 'ellipsis',
146
- ...items.slice(-(maxItems - 1))
147
- ];
148
- return /*#__PURE__*/ jsx("nav", {
149
- className: root({
222
+ };
223
+ Breadcrumb.Ellipsis = function({ children, className, icon = "token-icon-breadcrumb-ellipsis", iconProps, iconSize, ref, ...props }) {
224
+ const { styles } = useBreadcrumbContext();
225
+ const { className: iconClassName, ...restIconProps } = iconProps ?? {};
226
+ return /*#__PURE__*/ jsx("li", {
227
+ "aria-hidden": "true",
228
+ className: styles.ellipsis({
150
229
  className
151
230
  }),
152
- "aria-label": ariaLabel,
231
+ ref: ref,
232
+ role: "presentation",
153
233
  ...props,
154
- children: /*#__PURE__*/ jsx("ol", {
155
- className: list(),
156
- children: displayItems.map((item, index)=>'ellipsis' === item ? /*#__PURE__*/ jsx(BreadcrumbEllipsis, {}, "ellipsis") : item && 'string' != typeof item && /*#__PURE__*/ jsx(BreadcrumbItem, {
157
- label: item.label,
158
- href: item.href,
159
- icon: item.icon,
160
- separator: item.separator,
161
- lastItem: index === displayItems.length - 1,
162
- linkAs: linkAs,
163
- isCurrentPage: item.isCurrent || index === displayItems.length - 1
164
- }, `${item.label}`))
234
+ children: children ?? /*#__PURE__*/ jsx(Icon, {
235
+ className: styles.ellipsisIcon({
236
+ className: getContextualIconClassName({
237
+ className: iconClassName,
238
+ defaultClassName: styles.ellipsisIconSize(),
239
+ useDefaultClassName: !iconSize
240
+ })
241
+ }),
242
+ icon: icon,
243
+ size: iconSize,
244
+ ...restIconProps
165
245
  })
166
246
  });
167
- }
247
+ };
248
+ Breadcrumb.Root = Breadcrumb;
249
+ Breadcrumb.displayName = "Breadcrumb";
168
250
  export { Breadcrumb };