@heymantle/litho 0.0.3 → 0.0.5

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 (369) hide show
  1. package/dist/cjs/components/ActionList.js +50 -16
  2. package/dist/cjs/components/AnnouncementBar.js +10 -3
  3. package/dist/cjs/components/AppProvider.js +10 -1
  4. package/dist/cjs/components/Autocomplete.js +55 -22
  5. package/dist/cjs/components/Badge.js +2 -1
  6. package/dist/cjs/components/Banner.js +35 -31
  7. package/dist/cjs/components/Box.js +5 -3
  8. package/dist/cjs/components/Button.js +78 -18
  9. package/dist/cjs/components/Card.js +6 -45
  10. package/dist/cjs/components/Checkbox.js +16 -6
  11. package/dist/cjs/components/ChoiceList.js +7 -4
  12. package/dist/cjs/components/ColorField.js +10 -5
  13. package/dist/cjs/components/DatePicker.js +13 -8
  14. package/dist/cjs/components/DropZone.js +33 -18
  15. package/dist/cjs/components/EmptyState.js +17 -9
  16. package/dist/cjs/components/Filters.js +36 -23
  17. package/dist/cjs/components/FooterHelp.js +7 -2
  18. package/dist/cjs/components/Form.js +18 -3
  19. package/dist/cjs/components/Frame.js +48 -23
  20. package/dist/cjs/components/FrameSaveBar.js +21 -12
  21. package/dist/cjs/components/HorizontalStack.js +9 -2
  22. package/dist/cjs/components/Icon.js +1 -0
  23. package/dist/cjs/components/Layout.js +3 -3
  24. package/dist/cjs/components/LayoutSection.js +2 -2
  25. package/dist/cjs/components/Link.js +6 -2
  26. package/dist/cjs/components/List.js +4 -3
  27. package/dist/cjs/components/Listbox.js +9 -4
  28. package/dist/cjs/components/Modal.js +26 -17
  29. package/dist/cjs/components/Navigation.js +30 -20
  30. package/dist/cjs/components/Page.js +8 -3
  31. package/dist/cjs/components/Pagination.js +11 -4
  32. package/dist/cjs/components/Pane.js +168 -41
  33. package/dist/cjs/components/Popover.js +59 -6
  34. package/dist/cjs/components/RangeSlider.js +11 -4
  35. package/dist/cjs/components/ResourceList.js +9 -3
  36. package/dist/cjs/components/Select.js +2 -0
  37. package/dist/cjs/components/Stack.js +223 -0
  38. package/dist/cjs/components/Table.js +33 -20
  39. package/dist/cjs/components/Tabs.js +41 -11
  40. package/dist/cjs/components/Text.js +8 -5
  41. package/dist/cjs/components/TextField.js +23 -13
  42. package/dist/cjs/components/Thumbnail.js +7 -2
  43. package/dist/cjs/components/TimePicker.js +7 -2
  44. package/dist/cjs/components/Tip.js +10 -4
  45. package/dist/cjs/components/Tooltip.js +16 -8
  46. package/dist/cjs/components/TopBar.js +17 -9
  47. package/dist/cjs/components/VerticalStack.js +8 -2
  48. package/dist/cjs/dev/verify-publish.js +37 -4
  49. package/dist/cjs/index.js +4 -0
  50. package/dist/cjs/postcss.config.js +21 -0
  51. package/dist/cjs/stories/ActionList.stories.js +365 -0
  52. package/dist/cjs/stories/AnnouncementBar.stories.js +244 -0
  53. package/dist/cjs/stories/Autocomplete.stories.js +874 -0
  54. package/dist/cjs/stories/Badge.stories.js +183 -0
  55. package/dist/cjs/stories/Banner.stories.js +201 -0
  56. package/dist/cjs/stories/Box.stories.js +601 -0
  57. package/dist/cjs/stories/Button.stories.js +325 -0
  58. package/dist/cjs/stories/ButtonGroup.stories.js +404 -0
  59. package/dist/cjs/stories/Card.stories.js +278 -0
  60. package/dist/cjs/stories/Checkbox.stories.js +266 -0
  61. package/dist/cjs/stories/ChoiceList.stories.js +885 -0
  62. package/dist/cjs/stories/Collapsible.stories.js +917 -0
  63. package/dist/cjs/stories/ColorField.stories.js +887 -0
  64. package/dist/cjs/stories/ContextualSaveBar.stories.js +971 -0
  65. package/dist/cjs/stories/DatePicker.stories.js +584 -0
  66. package/dist/cjs/stories/Divider.stories.js +766 -0
  67. package/dist/cjs/stories/DropZone.stories.js +1210 -0
  68. package/dist/cjs/stories/EmptyState.stories.js +296 -0
  69. package/dist/cjs/stories/Filters.stories.js +1355 -0
  70. package/dist/cjs/stories/FooterHelp.stories.js +874 -0
  71. package/dist/cjs/stories/Form.stories.js +943 -0
  72. package/dist/cjs/stories/Grid.stories.js +1199 -0
  73. package/dist/cjs/stories/HorizontalStack.stories.js +1064 -0
  74. package/dist/cjs/stories/Icon.stories.js +599 -0
  75. package/dist/cjs/stories/Image.stories.js +883 -0
  76. package/dist/cjs/stories/InlineError.stories.js +711 -0
  77. package/dist/cjs/stories/Label.stories.js +665 -0
  78. package/dist/cjs/stories/Layout.stories.js +687 -0
  79. package/dist/cjs/stories/LayoutSection.stories.js +1275 -0
  80. package/dist/cjs/stories/Link.stories.js +425 -0
  81. package/dist/cjs/stories/List.stories.js +1048 -0
  82. package/dist/cjs/stories/Listbox.stories.js +824 -0
  83. package/dist/cjs/stories/Loading.stories.js +909 -0
  84. package/dist/cjs/stories/Modal.stories.js +363 -0
  85. package/dist/cjs/stories/Navigation.stories.js +605 -0
  86. package/dist/cjs/stories/Page.stories.js +327 -0
  87. package/dist/cjs/stories/Pagination.stories.js +438 -0
  88. package/dist/cjs/stories/Pane.stories.js +1550 -0
  89. package/dist/cjs/stories/Popover.stories.js +641 -0
  90. package/dist/cjs/stories/PopoverManager.stories.js +1233 -0
  91. package/dist/cjs/stories/ProgressBar.stories.js +513 -0
  92. package/dist/cjs/stories/RadioButton.stories.js +642 -0
  93. package/dist/cjs/stories/RadioButtonCard.stories.js +816 -0
  94. package/dist/cjs/stories/RangeSlider.stories.js +896 -0
  95. package/dist/cjs/stories/ResourceList.stories.js +1076 -0
  96. package/dist/cjs/stories/Select.stories.js +413 -0
  97. package/dist/cjs/stories/SkeletonText.stories.js +777 -0
  98. package/dist/cjs/stories/Spinner.stories.js +403 -0
  99. package/dist/cjs/stories/Stack.stories.js +1397 -0
  100. package/dist/cjs/stories/Table.stories.js +628 -0
  101. package/dist/cjs/stories/Tabs.stories.js +722 -0
  102. package/dist/cjs/stories/Tag.stories.js +628 -0
  103. package/dist/cjs/stories/Text.stories.js +262 -0
  104. package/dist/cjs/stories/TextField.stories.js +377 -0
  105. package/dist/cjs/stories/Thumbnail.stories.js +863 -0
  106. package/dist/cjs/stories/TimePicker.stories.js +967 -0
  107. package/dist/cjs/stories/Tip.stories.js +753 -0
  108. package/dist/cjs/stories/Tooltip.stories.js +357 -0
  109. package/dist/cjs/stories/TopBar.stories.js +157 -0
  110. package/dist/cjs/stories/VerticalStack.stories.js +1287 -0
  111. package/dist/cjs/tailwind.config.js +17 -0
  112. package/dist/cjs/utilities/transformers.js +66 -0
  113. package/dist/cjs/vite.config.js +35 -0
  114. package/dist/esm/components/ActionList.js +41 -12
  115. package/dist/esm/components/AnnouncementBar.js +3 -1
  116. package/dist/esm/components/AppProvider.js +10 -1
  117. package/dist/esm/components/Autocomplete.js +44 -16
  118. package/dist/esm/components/Badge.js +2 -2
  119. package/dist/esm/components/Banner.js +20 -21
  120. package/dist/esm/components/Box.js +5 -4
  121. package/dist/esm/components/Button.js +68 -13
  122. package/dist/esm/components/Card.js +6 -4
  123. package/dist/esm/components/Checkbox.js +6 -1
  124. package/dist/esm/components/ChoiceList.js +7 -4
  125. package/dist/esm/components/ColorField.js +3 -3
  126. package/dist/esm/components/DatePicker.js +6 -1
  127. package/dist/esm/components/DropZone.js +14 -4
  128. package/dist/esm/components/EmptyState.js +6 -3
  129. package/dist/esm/components/Filters.js +14 -6
  130. package/dist/esm/components/FooterHelp.js +1 -1
  131. package/dist/esm/components/Form.js +18 -3
  132. package/dist/esm/components/Frame.js +27 -15
  133. package/dist/esm/components/FrameSaveBar.js +10 -6
  134. package/dist/esm/components/HorizontalStack.js +9 -2
  135. package/dist/esm/components/Icon.js +1 -0
  136. package/dist/esm/components/InlineError.js +1 -1
  137. package/dist/esm/components/Layout.js +4 -4
  138. package/dist/esm/components/LayoutSection.js +2 -2
  139. package/dist/esm/components/Link.js +6 -2
  140. package/dist/esm/components/List.js +4 -3
  141. package/dist/esm/components/Listbox.js +4 -4
  142. package/dist/esm/components/Modal.js +8 -4
  143. package/dist/esm/components/Navigation.js +16 -11
  144. package/dist/esm/components/Page.js +9 -4
  145. package/dist/esm/components/Pagination.js +3 -1
  146. package/dist/esm/components/Pane.js +165 -43
  147. package/dist/esm/components/Popover.js +18 -6
  148. package/dist/esm/components/RangeSlider.js +3 -1
  149. package/dist/esm/components/ResourceList.js +2 -1
  150. package/dist/esm/components/Select.js +2 -0
  151. package/dist/esm/components/Stack.js +213 -0
  152. package/dist/esm/components/Table.js +17 -4
  153. package/dist/esm/components/Tabs.js +41 -11
  154. package/dist/esm/components/Text.js +8 -6
  155. package/dist/esm/components/TextField.js +6 -1
  156. package/dist/esm/components/Thumbnail.js +1 -1
  157. package/dist/esm/components/TimePicker.js +1 -1
  158. package/dist/esm/components/Tip.js +3 -2
  159. package/dist/esm/components/Tooltip.js +4 -1
  160. package/dist/esm/components/TopBar.js +7 -4
  161. package/dist/esm/components/VerticalStack.js +8 -2
  162. package/dist/esm/dev/verify-publish.js +37 -4
  163. package/dist/esm/index.js +1 -0
  164. package/dist/esm/postcss.config.js +6 -0
  165. package/dist/esm/stories/ActionList.stories.js +327 -0
  166. package/dist/esm/stories/AnnouncementBar.stories.js +212 -0
  167. package/dist/esm/stories/Autocomplete.stories.js +836 -0
  168. package/dist/esm/stories/Badge.stories.js +138 -0
  169. package/dist/esm/stories/Banner.stories.js +159 -0
  170. package/dist/esm/stories/Box.stories.js +560 -0
  171. package/dist/esm/stories/Button.stories.js +277 -0
  172. package/dist/esm/stories/ButtonGroup.stories.js +357 -0
  173. package/dist/esm/stories/Card.stories.js +240 -0
  174. package/dist/esm/stories/Checkbox.stories.js +219 -0
  175. package/dist/esm/stories/ChoiceList.stories.js +835 -0
  176. package/dist/esm/stories/Collapsible.stories.js +879 -0
  177. package/dist/esm/stories/ColorField.stories.js +846 -0
  178. package/dist/esm/stories/ContextualSaveBar.stories.js +939 -0
  179. package/dist/esm/stories/DatePicker.stories.js +537 -0
  180. package/dist/esm/stories/Divider.stories.js +722 -0
  181. package/dist/esm/stories/DropZone.stories.js +1166 -0
  182. package/dist/esm/stories/EmptyState.stories.js +246 -0
  183. package/dist/esm/stories/Filters.stories.js +1317 -0
  184. package/dist/esm/stories/FooterHelp.stories.js +818 -0
  185. package/dist/esm/stories/Form.stories.js +908 -0
  186. package/dist/esm/stories/Grid.stories.js +1152 -0
  187. package/dist/esm/stories/HorizontalStack.stories.js +1011 -0
  188. package/dist/esm/stories/Icon.stories.js +558 -0
  189. package/dist/esm/stories/Image.stories.js +836 -0
  190. package/dist/esm/stories/InlineError.stories.js +667 -0
  191. package/dist/esm/stories/Label.stories.js +612 -0
  192. package/dist/esm/stories/Layout.stories.js +649 -0
  193. package/dist/esm/stories/LayoutSection.stories.js +1234 -0
  194. package/dist/esm/stories/Link.stories.js +381 -0
  195. package/dist/esm/stories/List.stories.js +992 -0
  196. package/dist/esm/stories/Listbox.stories.js +780 -0
  197. package/dist/esm/stories/Loading.stories.js +859 -0
  198. package/dist/esm/stories/Modal.stories.js +322 -0
  199. package/dist/esm/stories/Navigation.stories.js +567 -0
  200. package/dist/esm/stories/Page.stories.js +280 -0
  201. package/dist/esm/stories/Pagination.stories.js +394 -0
  202. package/dist/esm/stories/Pane.stories.js +1512 -0
  203. package/dist/esm/stories/Popover.stories.js +609 -0
  204. package/dist/esm/stories/PopoverManager.stories.js +1201 -0
  205. package/dist/esm/stories/ProgressBar.stories.js +472 -0
  206. package/dist/esm/stories/RadioButton.stories.js +598 -0
  207. package/dist/esm/stories/RadioButtonCard.stories.js +772 -0
  208. package/dist/esm/stories/RangeSlider.stories.js +849 -0
  209. package/dist/esm/stories/ResourceList.stories.js +1038 -0
  210. package/dist/esm/stories/Select.stories.js +363 -0
  211. package/dist/esm/stories/SkeletonText.stories.js +718 -0
  212. package/dist/esm/stories/Spinner.stories.js +362 -0
  213. package/dist/esm/stories/Stack.stories.js +1338 -0
  214. package/dist/esm/stories/Table.stories.js +584 -0
  215. package/dist/esm/stories/Tabs.stories.js +684 -0
  216. package/dist/esm/stories/Tag.stories.js +581 -0
  217. package/dist/esm/stories/Text.stories.js +217 -0
  218. package/dist/esm/stories/TextField.stories.js +332 -0
  219. package/dist/esm/stories/Thumbnail.stories.js +810 -0
  220. package/dist/esm/stories/TimePicker.stories.js +911 -0
  221. package/dist/esm/stories/Tip.stories.js +706 -0
  222. package/dist/esm/stories/Tooltip.stories.js +313 -0
  223. package/dist/esm/stories/TopBar.stories.js +116 -0
  224. package/dist/esm/stories/VerticalStack.stories.js +1240 -0
  225. package/dist/esm/tailwind.config.js +7 -0
  226. package/dist/esm/utilities/transformers.js +47 -0
  227. package/dist/esm/vite.config.js +20 -0
  228. package/dist/types/components/ActionList.d.ts +122 -0
  229. package/dist/types/components/ActionList.d.ts.map +1 -0
  230. package/dist/types/components/AnnouncementBar.d.ts +21 -0
  231. package/dist/types/components/AnnouncementBar.d.ts.map +1 -0
  232. package/dist/types/components/AppProvider.d.ts +61 -0
  233. package/dist/types/components/AppProvider.d.ts.map +1 -0
  234. package/dist/types/components/Autocomplete.d.ts +135 -0
  235. package/dist/types/components/Autocomplete.d.ts.map +1 -0
  236. package/dist/types/components/Badge.d.ts +21 -0
  237. package/dist/types/components/Badge.d.ts.map +1 -0
  238. package/dist/types/components/Banner.d.ts +78 -0
  239. package/dist/types/components/Banner.d.ts.map +1 -0
  240. package/dist/types/components/Box.d.ts +70 -0
  241. package/dist/types/components/Box.d.ts.map +1 -0
  242. package/dist/types/components/Button.d.ts +133 -0
  243. package/dist/types/components/Button.d.ts.map +1 -0
  244. package/dist/types/components/ButtonGroup.d.ts +26 -0
  245. package/dist/types/components/ButtonGroup.d.ts.map +1 -0
  246. package/dist/types/components/Card.d.ts +141 -0
  247. package/dist/types/components/Card.d.ts.map +1 -0
  248. package/dist/types/components/Checkbox.d.ts +56 -0
  249. package/dist/types/components/Checkbox.d.ts.map +1 -0
  250. package/dist/types/components/ChoiceList.d.ts +69 -0
  251. package/dist/types/components/ChoiceList.d.ts.map +1 -0
  252. package/dist/types/components/Collapsible.d.ts +17 -0
  253. package/dist/types/components/Collapsible.d.ts.map +1 -0
  254. package/dist/types/components/ColorField.d.ts +36 -0
  255. package/dist/types/components/ColorField.d.ts.map +1 -0
  256. package/dist/types/components/ContextualSaveBar.d.ts +22 -0
  257. package/dist/types/components/ContextualSaveBar.d.ts.map +1 -0
  258. package/dist/types/components/DatePicker.d.ts +66 -0
  259. package/dist/types/components/DatePicker.d.ts.map +1 -0
  260. package/dist/types/components/Divider.d.ts +21 -0
  261. package/dist/types/components/Divider.d.ts.map +1 -0
  262. package/dist/types/components/DropZone.d.ts +108 -0
  263. package/dist/types/components/DropZone.d.ts.map +1 -0
  264. package/dist/types/components/EmptyState.d.ts +52 -0
  265. package/dist/types/components/EmptyState.d.ts.map +1 -0
  266. package/dist/types/components/Filters.d.ts +168 -0
  267. package/dist/types/components/Filters.d.ts.map +1 -0
  268. package/dist/types/components/FooterHelp.d.ts +21 -0
  269. package/dist/types/components/FooterHelp.d.ts.map +1 -0
  270. package/dist/types/components/Form.d.ts +39 -0
  271. package/dist/types/components/Form.d.ts.map +1 -0
  272. package/dist/types/components/Frame.d.ts +51 -0
  273. package/dist/types/components/Frame.d.ts.map +1 -0
  274. package/dist/types/components/FrameSaveBar.d.ts +8 -0
  275. package/dist/types/components/FrameSaveBar.d.ts.map +1 -0
  276. package/dist/types/components/Grid.d.ts +39 -0
  277. package/dist/types/components/Grid.d.ts.map +1 -0
  278. package/dist/types/components/HorizontalStack.d.ts +36 -0
  279. package/dist/types/components/HorizontalStack.d.ts.map +1 -0
  280. package/dist/types/components/Icon.d.ts +43 -0
  281. package/dist/types/components/Icon.d.ts.map +1 -0
  282. package/dist/types/components/Image.d.ts +45 -0
  283. package/dist/types/components/Image.d.ts.map +1 -0
  284. package/dist/types/components/InlineError.d.ts +22 -0
  285. package/dist/types/components/InlineError.d.ts.map +1 -0
  286. package/dist/types/components/Label.d.ts +28 -0
  287. package/dist/types/components/Label.d.ts.map +1 -0
  288. package/dist/types/components/Layout.d.ts +44 -0
  289. package/dist/types/components/Layout.d.ts.map +1 -0
  290. package/dist/types/components/LayoutSection.d.ts +24 -0
  291. package/dist/types/components/LayoutSection.d.ts.map +1 -0
  292. package/dist/types/components/Link.d.ts +38 -0
  293. package/dist/types/components/Link.d.ts.map +1 -0
  294. package/dist/types/components/List.d.ts +33 -0
  295. package/dist/types/components/List.d.ts.map +1 -0
  296. package/dist/types/components/Listbox.d.ts +34 -0
  297. package/dist/types/components/Listbox.d.ts.map +1 -0
  298. package/dist/types/components/Loading.d.ts +13 -0
  299. package/dist/types/components/Loading.d.ts.map +1 -0
  300. package/dist/types/components/Modal.d.ts +75 -0
  301. package/dist/types/components/Modal.d.ts.map +1 -0
  302. package/dist/types/components/Navigation.d.ts +105 -0
  303. package/dist/types/components/Navigation.d.ts.map +1 -0
  304. package/dist/types/components/Page.d.ts +59 -0
  305. package/dist/types/components/Page.d.ts.map +1 -0
  306. package/dist/types/components/Pagination.d.ts +39 -0
  307. package/dist/types/components/Pagination.d.ts.map +1 -0
  308. package/dist/types/components/Pane.d.ts +11 -0
  309. package/dist/types/components/Pane.d.ts.map +1 -0
  310. package/dist/types/components/Popover.d.ts +56 -0
  311. package/dist/types/components/Popover.d.ts.map +1 -0
  312. package/dist/types/components/PopoverManager.d.ts +3 -0
  313. package/dist/types/components/PopoverManager.d.ts.map +1 -0
  314. package/dist/types/components/ProgressBar.d.ts +24 -0
  315. package/dist/types/components/ProgressBar.d.ts.map +1 -0
  316. package/dist/types/components/RadioButton.d.ts +39 -0
  317. package/dist/types/components/RadioButton.d.ts.map +1 -0
  318. package/dist/types/components/RadioButtonCard.d.ts +41 -0
  319. package/dist/types/components/RadioButtonCard.d.ts.map +1 -0
  320. package/dist/types/components/RangeSlider.d.ts +44 -0
  321. package/dist/types/components/RangeSlider.d.ts.map +1 -0
  322. package/dist/types/components/ResourceList.d.ts +54 -0
  323. package/dist/types/components/ResourceList.d.ts.map +1 -0
  324. package/dist/types/components/Select.d.ts +48 -0
  325. package/dist/types/components/Select.d.ts.map +1 -0
  326. package/dist/types/components/SkeletonText.d.ts +28 -0
  327. package/dist/types/components/SkeletonText.d.ts.map +1 -0
  328. package/dist/types/components/Spinner.d.ts +18 -0
  329. package/dist/types/components/Spinner.d.ts.map +1 -0
  330. package/dist/types/components/Stack.d.ts +49 -0
  331. package/dist/types/components/Stack.d.ts.map +1 -0
  332. package/dist/types/components/Table.d.ts +197 -0
  333. package/dist/types/components/Table.d.ts.map +1 -0
  334. package/dist/types/components/Tabs.d.ts +43 -0
  335. package/dist/types/components/Tabs.d.ts.map +1 -0
  336. package/dist/types/components/Tag.d.ts +26 -0
  337. package/dist/types/components/Tag.d.ts.map +1 -0
  338. package/dist/types/components/Text.d.ts +32 -0
  339. package/dist/types/components/Text.d.ts.map +1 -0
  340. package/dist/types/components/TextField.d.ts +109 -0
  341. package/dist/types/components/TextField.d.ts.map +1 -0
  342. package/dist/types/components/Thumbnail.d.ts +18 -0
  343. package/dist/types/components/Thumbnail.d.ts.map +1 -0
  344. package/dist/types/components/TimePicker.d.ts +3 -0
  345. package/dist/types/components/TimePicker.d.ts.map +1 -0
  346. package/dist/types/components/Tip.d.ts +23 -0
  347. package/dist/types/components/Tip.d.ts.map +1 -0
  348. package/dist/types/components/Tooltip.d.ts +84 -0
  349. package/dist/types/components/Tooltip.d.ts.map +1 -0
  350. package/dist/types/components/TopBar.d.ts +43 -0
  351. package/dist/types/components/TopBar.d.ts.map +1 -0
  352. package/dist/types/components/VerticalStack.d.ts +27 -0
  353. package/dist/types/components/VerticalStack.d.ts.map +1 -0
  354. package/dist/types/index.d.ts +63 -0
  355. package/dist/types/index.d.ts.map +1 -0
  356. package/dist/types/styles/Table.d.ts +1570 -0
  357. package/dist/types/styles/Table.d.ts.map +1 -0
  358. package/dist/types/utilities/dates.d.ts +46 -0
  359. package/dist/types/utilities/dates.d.ts.map +1 -0
  360. package/dist/types/utilities/transformers.d.ts +4 -0
  361. package/dist/types/utilities/transformers.d.ts.map +1 -0
  362. package/dist/types/utilities/useIndexResourceState.d.ts +21 -0
  363. package/dist/types/utilities/useIndexResourceState.d.ts.map +1 -0
  364. package/dist/types/utilities/useMounted.d.ts +2 -0
  365. package/dist/types/utilities/useMounted.d.ts.map +1 -0
  366. package/dist/types/utilities/useTableScrollState.d.ts +29 -0
  367. package/dist/types/utilities/useTableScrollState.d.ts.map +1 -0
  368. package/index.css +17 -0
  369. package/package.json +38 -7
@@ -0,0 +1,1355 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: Object.getOwnPropertyDescriptor(all, name).get
9
+ });
10
+ }
11
+ _export(exports, {
12
+ get ComplexFiltering () {
13
+ return ComplexFiltering;
14
+ },
15
+ get Default () {
16
+ return Default;
17
+ },
18
+ get FilterPills () {
19
+ return FilterPills;
20
+ },
21
+ get FilterTabs () {
22
+ return FilterTabs;
23
+ },
24
+ get ResponsiveBehavior () {
25
+ return ResponsiveBehavior;
26
+ },
27
+ get WithSearchField () {
28
+ return WithSearchField;
29
+ },
30
+ get default () {
31
+ return _default;
32
+ }
33
+ });
34
+ var _jsxruntime = require("react/jsx-runtime");
35
+ var _react = require("react");
36
+ var _Filters = /*#__PURE__*/ _interop_require_default(require("../components/Filters.js"));
37
+ var _Stack = /*#__PURE__*/ _interop_require_default(require("../components/Stack.js"));
38
+ var _Text = /*#__PURE__*/ _interop_require_default(require("../components/Text.js"));
39
+ var _Card = /*#__PURE__*/ _interop_require_default(require("../components/Card.js"));
40
+ var _Button = /*#__PURE__*/ _interop_require_default(require("../components/Button.js"));
41
+ var _Select = /*#__PURE__*/ _interop_require_default(require("../components/Select.js"));
42
+ var _Checkbox = /*#__PURE__*/ _interop_require_default(require("../components/Checkbox.js"));
43
+ var _RangeSlider = /*#__PURE__*/ _interop_require_default(require("../components/RangeSlider.js"));
44
+ var _Box = /*#__PURE__*/ _interop_require_default(require("../components/Box.js"));
45
+ var _transformers = require("../utilities/transformers.js");
46
+ function _array_like_to_array(arr, len) {
47
+ if (len == null || len > arr.length) len = arr.length;
48
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
49
+ return arr2;
50
+ }
51
+ function _array_with_holes(arr) {
52
+ if (Array.isArray(arr)) return arr;
53
+ }
54
+ function _array_without_holes(arr) {
55
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
56
+ }
57
+ function _define_property(obj, key, value) {
58
+ if (key in obj) {
59
+ Object.defineProperty(obj, key, {
60
+ value: value,
61
+ enumerable: true,
62
+ configurable: true,
63
+ writable: true
64
+ });
65
+ } else {
66
+ obj[key] = value;
67
+ }
68
+ return obj;
69
+ }
70
+ function _interop_require_default(obj) {
71
+ return obj && obj.__esModule ? obj : {
72
+ default: obj
73
+ };
74
+ }
75
+ function _iterable_to_array(iter) {
76
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
77
+ }
78
+ function _iterable_to_array_limit(arr, i) {
79
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
80
+ if (_i == null) return;
81
+ var _arr = [];
82
+ var _n = true;
83
+ var _d = false;
84
+ var _s, _e;
85
+ try {
86
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
87
+ _arr.push(_s.value);
88
+ if (i && _arr.length === i) break;
89
+ }
90
+ } catch (err) {
91
+ _d = true;
92
+ _e = err;
93
+ } finally{
94
+ try {
95
+ if (!_n && _i["return"] != null) _i["return"]();
96
+ } finally{
97
+ if (_d) throw _e;
98
+ }
99
+ }
100
+ return _arr;
101
+ }
102
+ function _non_iterable_rest() {
103
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
104
+ }
105
+ function _non_iterable_spread() {
106
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
107
+ }
108
+ function _object_spread(target) {
109
+ for(var i = 1; i < arguments.length; i++){
110
+ var source = arguments[i] != null ? arguments[i] : {};
111
+ var ownKeys = Object.keys(source);
112
+ if (typeof Object.getOwnPropertySymbols === "function") {
113
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
114
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
115
+ }));
116
+ }
117
+ ownKeys.forEach(function(key) {
118
+ _define_property(target, key, source[key]);
119
+ });
120
+ }
121
+ return target;
122
+ }
123
+ function ownKeys(object, enumerableOnly) {
124
+ var keys = Object.keys(object);
125
+ if (Object.getOwnPropertySymbols) {
126
+ var symbols = Object.getOwnPropertySymbols(object);
127
+ if (enumerableOnly) {
128
+ symbols = symbols.filter(function(sym) {
129
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
130
+ });
131
+ }
132
+ keys.push.apply(keys, symbols);
133
+ }
134
+ return keys;
135
+ }
136
+ function _object_spread_props(target, source) {
137
+ source = source != null ? source : {};
138
+ if (Object.getOwnPropertyDescriptors) {
139
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
140
+ } else {
141
+ ownKeys(Object(source)).forEach(function(key) {
142
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
143
+ });
144
+ }
145
+ return target;
146
+ }
147
+ function _sliced_to_array(arr, i) {
148
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
149
+ }
150
+ function _to_consumable_array(arr) {
151
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
152
+ }
153
+ function _unsupported_iterable_to_array(o, minLen) {
154
+ if (!o) return;
155
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
156
+ var n = Object.prototype.toString.call(o).slice(8, -1);
157
+ if (n === "Object" && o.constructor) n = o.constructor.name;
158
+ if (n === "Map" || n === "Set") return Array.from(n);
159
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
160
+ }
161
+ var _default = {
162
+ title: 'Litho/Filters',
163
+ component: _Filters.default,
164
+ parameters: {
165
+ layout: 'padded',
166
+ docs: {
167
+ description: {
168
+ component: "A comprehensive Filters component that manages filters for datasets. It includes visible filters, more filters dropdown, query text field, filter pills, and tabs for complex filtering scenarios."
169
+ }
170
+ }
171
+ },
172
+ tags: [
173
+ 'autodocs'
174
+ ],
175
+ argTypes: {
176
+ filters: {
177
+ control: 'object',
178
+ description: 'Array of available filters'
179
+ },
180
+ appliedFilters: {
181
+ control: 'object',
182
+ description: 'Array of currently applied filters'
183
+ },
184
+ showTextField: {
185
+ control: 'boolean',
186
+ description: 'Whether to show the query text field'
187
+ },
188
+ queryValue: {
189
+ control: 'text',
190
+ description: 'Current value of the query text field'
191
+ },
192
+ queryPlaceholder: {
193
+ control: 'text',
194
+ description: 'Placeholder text for the query field'
195
+ },
196
+ padded: {
197
+ control: 'boolean',
198
+ description: 'Whether to apply padding to the filters container'
199
+ }
200
+ }
201
+ };
202
+ var Default = {
203
+ render: function() {
204
+ var _useState = _sliced_to_array((0, _react.useState)([]), 2), appliedFilters = _useState[0], setAppliedFilters = _useState[1];
205
+ var _useState1 = _sliced_to_array((0, _react.useState)(''), 2), status = _useState1[0], setStatus = _useState1[1];
206
+ var _useState2 = _sliced_to_array((0, _react.useState)(''), 2), category = _useState2[0], setCategory = _useState2[1];
207
+ var _useState3 = _sliced_to_array((0, _react.useState)([
208
+ 0,
209
+ 1000
210
+ ]), 2), priceRange = _useState3[0], setPriceRange = _useState3[1];
211
+ var filters = [
212
+ {
213
+ key: 'status',
214
+ label: 'Status',
215
+ shortcut: true,
216
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Select.default, {
217
+ label: "Status",
218
+ labelHidden: true,
219
+ options: [
220
+ {
221
+ label: 'All statuses',
222
+ value: ''
223
+ },
224
+ {
225
+ label: 'Active',
226
+ value: 'active'
227
+ },
228
+ {
229
+ label: 'Inactive',
230
+ value: 'inactive'
231
+ },
232
+ {
233
+ label: 'Pending',
234
+ value: 'pending'
235
+ }
236
+ ],
237
+ value: status,
238
+ onChange: function(value) {
239
+ setStatus(value);
240
+ updateAppliedFilters('status', value, value ? "Status: ".concat(value) : null);
241
+ }
242
+ })
243
+ },
244
+ {
245
+ key: 'category',
246
+ label: 'Category',
247
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Select.default, {
248
+ label: "Category",
249
+ labelHidden: true,
250
+ options: [
251
+ {
252
+ label: 'All categories',
253
+ value: ''
254
+ },
255
+ {
256
+ label: 'Electronics',
257
+ value: 'electronics'
258
+ },
259
+ {
260
+ label: 'Clothing',
261
+ value: 'clothing'
262
+ },
263
+ {
264
+ label: 'Books',
265
+ value: 'books'
266
+ },
267
+ {
268
+ label: 'Home & Garden',
269
+ value: 'home'
270
+ }
271
+ ],
272
+ value: category,
273
+ onChange: function(value) {
274
+ setCategory(value);
275
+ updateAppliedFilters('category', value, value ? "Category: ".concat(value) : null);
276
+ }
277
+ })
278
+ },
279
+ {
280
+ key: 'price',
281
+ label: 'Price Range',
282
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
283
+ gap: "md",
284
+ children: [
285
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
286
+ variant: "bodySm",
287
+ children: [
288
+ "Price: $",
289
+ priceRange[0],
290
+ " - $",
291
+ priceRange[1]
292
+ ]
293
+ }),
294
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_RangeSlider.default, {
295
+ label: "Price Range",
296
+ labelHidden: true,
297
+ min: 0,
298
+ max: 1000,
299
+ value: priceRange,
300
+ onChange: function(value) {
301
+ setPriceRange(value);
302
+ updateAppliedFilters('price', value, "Price: $".concat(value[0], " - $").concat(value[1]));
303
+ }
304
+ })
305
+ ]
306
+ })
307
+ }
308
+ ];
309
+ var updateAppliedFilters = function(key, value, label) {
310
+ setAppliedFilters(function(prev) {
311
+ var filtered = prev.filter(function(f) {
312
+ return f.key !== key;
313
+ });
314
+ if (value && (Array.isArray(value) && value.some(function(v) {
315
+ return v !== 0 && v !== 1000;
316
+ }) || !Array.isArray(value) && value !== '')) {
317
+ return _to_consumable_array(filtered).concat([
318
+ {
319
+ key: key,
320
+ label: label,
321
+ onRemove: function() {
322
+ if (key === 'status') setStatus('');
323
+ if (key === 'category') setCategory('');
324
+ if (key === 'price') setPriceRange([
325
+ 0,
326
+ 1000
327
+ ]);
328
+ setAppliedFilters(function(prev) {
329
+ return prev.filter(function(f) {
330
+ return f.key !== key;
331
+ });
332
+ });
333
+ }
334
+ }
335
+ ]);
336
+ }
337
+ return filtered;
338
+ });
339
+ };
340
+ var handleClearAll = function() {
341
+ setStatus('');
342
+ setCategory('');
343
+ setPriceRange([
344
+ 0,
345
+ 1000
346
+ ]);
347
+ setAppliedFilters([]);
348
+ };
349
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Card.default, {
350
+ title: "Product Filters",
351
+ padded: true,
352
+ children: [
353
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default, {
354
+ filters: filters,
355
+ appliedFilters: appliedFilters,
356
+ onClearAll: handleClearAll
357
+ }),
358
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
359
+ marginBlockStart: "8",
360
+ padding: "4",
361
+ background: "subdued",
362
+ borderRadius: "default",
363
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
364
+ gap: "sm",
365
+ children: [
366
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
367
+ variant: "headingSm",
368
+ children: "Current Filters:"
369
+ }),
370
+ appliedFilters.length > 0 ? /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
371
+ gap: "xs",
372
+ children: appliedFilters.map(function(filter) {
373
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
374
+ variant: "bodyXs",
375
+ children: [
376
+ "• ",
377
+ filter.label
378
+ ]
379
+ }, filter.key);
380
+ })
381
+ }) : /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
382
+ variant: "bodyXs",
383
+ color: "subdued",
384
+ children: "No filters applied"
385
+ })
386
+ ]
387
+ })
388
+ })
389
+ ]
390
+ });
391
+ },
392
+ parameters: {
393
+ docs: {
394
+ description: {
395
+ story: 'Basic filters with status, category, and price range options.'
396
+ },
397
+ source: {
398
+ transform: _transformers.transformStorySource
399
+ }
400
+ }
401
+ }
402
+ };
403
+ var WithSearchField = {
404
+ render: function() {
405
+ var _useState = _sliced_to_array((0, _react.useState)([]), 2), appliedFilters = _useState[0], setAppliedFilters = _useState[1];
406
+ var _useState1 = _sliced_to_array((0, _react.useState)(''), 2), queryValue = _useState1[0], setQueryValue = _useState1[1];
407
+ var _useState2 = _sliced_to_array((0, _react.useState)([]), 2), selectedTags = _useState2[0], setSelectedTags = _useState2[1];
408
+ var _useState3 = _sliced_to_array((0, _react.useState)([]), 2), selectedAuthors = _useState3[0], setSelectedAuthors = _useState3[1];
409
+ var availableTags = [
410
+ 'React',
411
+ 'JavaScript',
412
+ 'CSS',
413
+ 'Node.js',
414
+ 'TypeScript',
415
+ 'GraphQL'
416
+ ];
417
+ var availableAuthors = [
418
+ 'John Doe',
419
+ 'Jane Smith',
420
+ 'Bob Wilson',
421
+ 'Alice Brown'
422
+ ];
423
+ var filters = [
424
+ {
425
+ key: 'tags',
426
+ label: 'Tags',
427
+ shortcut: true,
428
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
429
+ gap: "sm",
430
+ children: availableTags.map(function(tag) {
431
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Checkbox.default, {
432
+ label: tag,
433
+ checked: selectedTags.includes(tag),
434
+ onChange: function(checked) {
435
+ var newTags = checked ? _to_consumable_array(selectedTags).concat([
436
+ tag
437
+ ]) : selectedTags.filter(function(t) {
438
+ return t !== tag;
439
+ });
440
+ setSelectedTags(newTags);
441
+ updateAppliedFilters('tags', newTags, newTags.length > 0 ? "Tags: ".concat(newTags.join(', ')) : null);
442
+ }
443
+ }, tag);
444
+ })
445
+ })
446
+ },
447
+ {
448
+ key: 'authors',
449
+ label: 'Authors',
450
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
451
+ gap: "sm",
452
+ children: availableAuthors.map(function(author) {
453
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Checkbox.default, {
454
+ label: author,
455
+ checked: selectedAuthors.includes(author),
456
+ onChange: function(checked) {
457
+ var newAuthors = checked ? _to_consumable_array(selectedAuthors).concat([
458
+ author
459
+ ]) : selectedAuthors.filter(function(a) {
460
+ return a !== author;
461
+ });
462
+ setSelectedAuthors(newAuthors);
463
+ updateAppliedFilters('authors', newAuthors, newAuthors.length > 0 ? "Authors: ".concat(newAuthors.join(', ')) : null);
464
+ }
465
+ }, author);
466
+ })
467
+ })
468
+ }
469
+ ];
470
+ var updateAppliedFilters = function(key, value, label) {
471
+ setAppliedFilters(function(prev) {
472
+ var filtered = prev.filter(function(f) {
473
+ return f.key !== key;
474
+ });
475
+ if (value && Array.isArray(value) && value.length > 0) {
476
+ return _to_consumable_array(filtered).concat([
477
+ {
478
+ key: key,
479
+ label: label,
480
+ onRemove: function() {
481
+ if (key === 'tags') setSelectedTags([]);
482
+ if (key === 'authors') setSelectedAuthors([]);
483
+ setAppliedFilters(function(prev) {
484
+ return prev.filter(function(f) {
485
+ return f.key !== key;
486
+ });
487
+ });
488
+ }
489
+ }
490
+ ]);
491
+ }
492
+ return filtered;
493
+ });
494
+ };
495
+ var handleClearAll = function() {
496
+ setSelectedTags([]);
497
+ setSelectedAuthors([]);
498
+ setAppliedFilters([]);
499
+ };
500
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Card.default, {
501
+ title: "Article Search & Filters",
502
+ padded: true,
503
+ children: [
504
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default, {
505
+ filters: filters,
506
+ appliedFilters: appliedFilters,
507
+ onClearAll: handleClearAll,
508
+ showTextField: true,
509
+ queryValue: queryValue,
510
+ onQueryChange: setQueryValue,
511
+ onQueryClear: function() {
512
+ return setQueryValue('');
513
+ },
514
+ queryPlaceholder: "Search articles..."
515
+ }),
516
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
517
+ marginBlockStart: "8",
518
+ padding: "4",
519
+ background: "subdued",
520
+ borderRadius: "default",
521
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
522
+ gap: "sm",
523
+ children: [
524
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
525
+ variant: "headingSm",
526
+ children: "Search & Filter Summary:"
527
+ }),
528
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
529
+ gap: "xs",
530
+ children: [
531
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
532
+ variant: "bodyXs",
533
+ children: [
534
+ "Search Query: ",
535
+ queryValue || 'None'
536
+ ]
537
+ }),
538
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
539
+ variant: "bodyXs",
540
+ children: [
541
+ "Active Filters: ",
542
+ appliedFilters.length
543
+ ]
544
+ }),
545
+ appliedFilters.map(function(filter) {
546
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
547
+ variant: "bodyXs",
548
+ style: {
549
+ marginLeft: '1rem'
550
+ },
551
+ children: [
552
+ "• ",
553
+ filter.label
554
+ ]
555
+ }, filter.key);
556
+ })
557
+ ]
558
+ })
559
+ ]
560
+ })
561
+ })
562
+ ]
563
+ });
564
+ },
565
+ parameters: {
566
+ docs: {
567
+ description: {
568
+ story: 'Filters with search text field for comprehensive filtering.'
569
+ },
570
+ source: {
571
+ transform: _transformers.transformStorySource
572
+ }
573
+ }
574
+ }
575
+ };
576
+ var FilterTabs = {
577
+ render: function() {
578
+ var _tabs_selectedTab, _tabs_selectedTab_accessory_props, _tabs_selectedTab_accessory, _tabs_selectedTab1;
579
+ var _useState = _sliced_to_array((0, _react.useState)(0), 2), selectedTab = _useState[0], setSelectedTab = _useState[1];
580
+ var _useState1 = _sliced_to_array((0, _react.useState)([]), 2), appliedFilters = _useState1[0], setAppliedFilters = _useState1[1];
581
+ var tabs = [
582
+ {
583
+ id: 'all',
584
+ content: 'All Items',
585
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
586
+ variant: "bodySm",
587
+ color: "subdued",
588
+ children: "245 items"
589
+ })
590
+ },
591
+ {
592
+ id: 'active',
593
+ content: 'Active',
594
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
595
+ variant: "bodySm",
596
+ color: "subdued",
597
+ children: "128 items"
598
+ })
599
+ },
600
+ {
601
+ id: 'inactive',
602
+ content: 'Inactive',
603
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
604
+ variant: "bodySm",
605
+ color: "subdued",
606
+ children: "89 items"
607
+ })
608
+ },
609
+ {
610
+ id: 'pending',
611
+ content: 'Pending Review',
612
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
613
+ variant: "bodySm",
614
+ color: "subdued",
615
+ children: "28 items"
616
+ })
617
+ },
618
+ {
619
+ id: 'draft',
620
+ content: 'Draft',
621
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
622
+ variant: "bodySm",
623
+ color: "subdued",
624
+ children: "15 items"
625
+ })
626
+ },
627
+ {
628
+ id: 'archived',
629
+ content: 'Archived',
630
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
631
+ variant: "bodySm",
632
+ color: "subdued",
633
+ children: "67 items"
634
+ })
635
+ }
636
+ ];
637
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Card.default, {
638
+ title: "Status Filters with Tabs",
639
+ padded: true,
640
+ children: [
641
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Tabs, {
642
+ tabs: tabs,
643
+ selected: selectedTab,
644
+ onSelect: setSelectedTab
645
+ }),
646
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
647
+ marginBlockStart: "8",
648
+ padding: "4",
649
+ background: "subdued",
650
+ borderRadius: "default",
651
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
652
+ gap: "sm",
653
+ children: [
654
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
655
+ variant: "headingSm",
656
+ children: "Selected Tab:"
657
+ }),
658
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
659
+ variant: "bodyXs",
660
+ children: [
661
+ (_tabs_selectedTab = tabs[selectedTab]) === null || _tabs_selectedTab === void 0 ? void 0 : _tabs_selectedTab.content,
662
+ " - ",
663
+ (_tabs_selectedTab1 = tabs[selectedTab]) === null || _tabs_selectedTab1 === void 0 ? void 0 : (_tabs_selectedTab_accessory = _tabs_selectedTab1.accessory) === null || _tabs_selectedTab_accessory === void 0 ? void 0 : (_tabs_selectedTab_accessory_props = _tabs_selectedTab_accessory.props) === null || _tabs_selectedTab_accessory_props === void 0 ? void 0 : _tabs_selectedTab_accessory_props.children
664
+ ]
665
+ })
666
+ ]
667
+ })
668
+ })
669
+ ]
670
+ });
671
+ },
672
+ parameters: {
673
+ docs: {
674
+ description: {
675
+ story: 'Filter tabs for quick status-based filtering with item counts.'
676
+ },
677
+ source: {
678
+ transform: _transformers.transformStorySource
679
+ }
680
+ }
681
+ }
682
+ };
683
+ var ComplexFiltering = {
684
+ render: function() {
685
+ var _tabs_selectedTab;
686
+ var _useState = _sliced_to_array((0, _react.useState)([]), 2), appliedFilters = _useState[0], setAppliedFilters = _useState[1];
687
+ var _useState1 = _sliced_to_array((0, _react.useState)(''), 2), queryValue = _useState1[0], setQueryValue = _useState1[1];
688
+ var _useState2 = _sliced_to_array((0, _react.useState)(0), 2), selectedTab = _useState2[0], setSelectedTab = _useState2[1];
689
+ var _useState3 = _sliced_to_array((0, _react.useState)([
690
+ 0,
691
+ 500
692
+ ]), 2), priceRange = _useState3[0], setPriceRange = _useState3[1];
693
+ var _useState4 = _sliced_to_array((0, _react.useState)([]), 2), selectedBrands = _useState4[0], setSelectedBrands = _useState4[1];
694
+ var _useState5 = _sliced_to_array((0, _react.useState)([]), 2), selectedColors = _useState5[0], setSelectedColors = _useState5[1];
695
+ var _useState6 = _sliced_to_array((0, _react.useState)(''), 2), availability = _useState6[0], setAvailability = _useState6[1];
696
+ var _useState7 = _sliced_to_array((0, _react.useState)(''), 2), rating = _useState7[0], setRating = _useState7[1];
697
+ var availableBrands = [
698
+ 'Apple',
699
+ 'Samsung',
700
+ 'Google',
701
+ 'OnePlus',
702
+ 'Xiaomi'
703
+ ];
704
+ var availableColors = [
705
+ 'Black',
706
+ 'White',
707
+ 'Blue',
708
+ 'Red',
709
+ 'Gold'
710
+ ];
711
+ var tabs = [
712
+ {
713
+ id: 'all',
714
+ content: 'All Products',
715
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
716
+ variant: "bodySm",
717
+ color: "subdued",
718
+ children: "1,234"
719
+ })
720
+ },
721
+ {
722
+ id: 'phones',
723
+ content: 'Phones',
724
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
725
+ variant: "bodySm",
726
+ color: "subdued",
727
+ children: "456"
728
+ })
729
+ },
730
+ {
731
+ id: 'tablets',
732
+ content: 'Tablets',
733
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
734
+ variant: "bodySm",
735
+ color: "subdued",
736
+ children: "123"
737
+ })
738
+ },
739
+ {
740
+ id: 'accessories',
741
+ content: 'Accessories',
742
+ accessory: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
743
+ variant: "bodySm",
744
+ color: "subdued",
745
+ children: "655"
746
+ })
747
+ }
748
+ ];
749
+ var filters = [
750
+ {
751
+ key: 'price',
752
+ label: 'Price Range',
753
+ shortcut: true,
754
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
755
+ gap: "md",
756
+ children: [
757
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
758
+ variant: "bodySm",
759
+ children: [
760
+ "$",
761
+ priceRange[0],
762
+ " - $",
763
+ priceRange[1]
764
+ ]
765
+ }),
766
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_RangeSlider.default, {
767
+ label: "Price Range",
768
+ labelHidden: true,
769
+ min: 0,
770
+ max: 500,
771
+ value: priceRange,
772
+ onChange: function(value) {
773
+ setPriceRange(value);
774
+ updateAppliedFilters('price', value, "Price: $".concat(value[0], " - $").concat(value[1]));
775
+ }
776
+ })
777
+ ]
778
+ })
779
+ },
780
+ {
781
+ key: 'brand',
782
+ label: 'Brand',
783
+ shortcut: true,
784
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
785
+ gap: "sm",
786
+ children: availableBrands.map(function(brand) {
787
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Checkbox.default, {
788
+ label: brand,
789
+ checked: selectedBrands.includes(brand),
790
+ onChange: function(checked) {
791
+ var newBrands = checked ? _to_consumable_array(selectedBrands).concat([
792
+ brand
793
+ ]) : selectedBrands.filter(function(b) {
794
+ return b !== brand;
795
+ });
796
+ setSelectedBrands(newBrands);
797
+ updateAppliedFilters('brand', newBrands, newBrands.length > 0 ? "Brand: ".concat(newBrands.join(', ')) : null);
798
+ }
799
+ }, brand);
800
+ })
801
+ })
802
+ },
803
+ {
804
+ key: 'color',
805
+ label: 'Color',
806
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
807
+ gap: "sm",
808
+ children: availableColors.map(function(color) {
809
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Checkbox.default, {
810
+ label: color,
811
+ checked: selectedColors.includes(color),
812
+ onChange: function(checked) {
813
+ var newColors = checked ? _to_consumable_array(selectedColors).concat([
814
+ color
815
+ ]) : selectedColors.filter(function(c) {
816
+ return c !== color;
817
+ });
818
+ setSelectedColors(newColors);
819
+ updateAppliedFilters('color', newColors, newColors.length > 0 ? "Color: ".concat(newColors.join(', ')) : null);
820
+ }
821
+ }, color);
822
+ })
823
+ })
824
+ },
825
+ {
826
+ key: 'availability',
827
+ label: 'Availability',
828
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Select.default, {
829
+ label: "Availability",
830
+ labelHidden: true,
831
+ options: [
832
+ {
833
+ label: 'All items',
834
+ value: ''
835
+ },
836
+ {
837
+ label: 'In stock',
838
+ value: 'in-stock'
839
+ },
840
+ {
841
+ label: 'Out of stock',
842
+ value: 'out-of-stock'
843
+ },
844
+ {
845
+ label: 'Pre-order',
846
+ value: 'pre-order'
847
+ }
848
+ ],
849
+ value: availability,
850
+ onChange: function(value) {
851
+ setAvailability(value);
852
+ updateAppliedFilters('availability', value, value ? "Availability: ".concat(value) : null);
853
+ }
854
+ })
855
+ },
856
+ {
857
+ key: 'rating',
858
+ label: 'Customer Rating',
859
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Select.default, {
860
+ label: "Rating",
861
+ labelHidden: true,
862
+ options: [
863
+ {
864
+ label: 'All ratings',
865
+ value: ''
866
+ },
867
+ {
868
+ label: '4+ stars',
869
+ value: '4+'
870
+ },
871
+ {
872
+ label: '3+ stars',
873
+ value: '3+'
874
+ },
875
+ {
876
+ label: '2+ stars',
877
+ value: '2+'
878
+ }
879
+ ],
880
+ value: rating,
881
+ onChange: function(value) {
882
+ setRating(value);
883
+ updateAppliedFilters('rating', value, value ? "Rating: ".concat(value, " stars") : null);
884
+ }
885
+ })
886
+ }
887
+ ];
888
+ var updateAppliedFilters = function(key, value, label) {
889
+ setAppliedFilters(function(prev) {
890
+ var filtered = prev.filter(function(f) {
891
+ return f.key !== key;
892
+ });
893
+ if (value && (Array.isArray(value) && value.length > 0 || !Array.isArray(value) && value !== '' && !(Array.isArray(value) && value[0] === 0 && value[1] === 500))) {
894
+ return _to_consumable_array(filtered).concat([
895
+ {
896
+ key: key,
897
+ label: label,
898
+ onRemove: function() {
899
+ if (key === 'price') setPriceRange([
900
+ 0,
901
+ 500
902
+ ]);
903
+ if (key === 'brand') setSelectedBrands([]);
904
+ if (key === 'color') setSelectedColors([]);
905
+ if (key === 'availability') setAvailability('');
906
+ if (key === 'rating') setRating('');
907
+ setAppliedFilters(function(prev) {
908
+ return prev.filter(function(f) {
909
+ return f.key !== key;
910
+ });
911
+ });
912
+ }
913
+ }
914
+ ]);
915
+ }
916
+ return filtered;
917
+ });
918
+ };
919
+ var handleClearAll = function() {
920
+ setPriceRange([
921
+ 0,
922
+ 500
923
+ ]);
924
+ setSelectedBrands([]);
925
+ setSelectedColors([]);
926
+ setAvailability('');
927
+ setRating('');
928
+ setAppliedFilters([]);
929
+ };
930
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
931
+ gap: "md",
932
+ children: [
933
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
934
+ title: "Product Category",
935
+ padded: true,
936
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Tabs, {
937
+ tabs: tabs,
938
+ selected: selectedTab,
939
+ onSelect: setSelectedTab
940
+ })
941
+ }),
942
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
943
+ title: "Search & Filters",
944
+ padded: true,
945
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default, {
946
+ filters: filters,
947
+ appliedFilters: appliedFilters,
948
+ onClearAll: handleClearAll,
949
+ showTextField: true,
950
+ queryValue: queryValue,
951
+ onQueryChange: setQueryValue,
952
+ onQueryClear: function() {
953
+ return setQueryValue('');
954
+ },
955
+ queryPlaceholder: "Search products..."
956
+ })
957
+ }),
958
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
959
+ title: "Results Summary",
960
+ padded: true,
961
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
962
+ gap: "md",
963
+ children: [
964
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
965
+ horizontal: true,
966
+ gap: "lg",
967
+ children: [
968
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
969
+ gap: "sm",
970
+ children: [
971
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
972
+ variant: "headingSm",
973
+ children: "Category:"
974
+ }),
975
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
976
+ variant: "bodyXs",
977
+ children: (_tabs_selectedTab = tabs[selectedTab]) === null || _tabs_selectedTab === void 0 ? void 0 : _tabs_selectedTab.content
978
+ })
979
+ ]
980
+ }),
981
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
982
+ gap: "sm",
983
+ children: [
984
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
985
+ variant: "headingSm",
986
+ children: "Search Query:"
987
+ }),
988
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
989
+ variant: "bodyXs",
990
+ children: queryValue || 'None'
991
+ })
992
+ ]
993
+ })
994
+ ]
995
+ }),
996
+ appliedFilters.length > 0 && /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
997
+ gap: "sm",
998
+ children: [
999
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
1000
+ variant: "headingSm",
1001
+ children: [
1002
+ "Active Filters (",
1003
+ appliedFilters.length,
1004
+ "):"
1005
+ ]
1006
+ }),
1007
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
1008
+ gap: "xs",
1009
+ children: appliedFilters.map(function(filter) {
1010
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
1011
+ variant: "bodyXs",
1012
+ children: [
1013
+ "• ",
1014
+ filter.label
1015
+ ]
1016
+ }, filter.key);
1017
+ })
1018
+ })
1019
+ ]
1020
+ })
1021
+ ]
1022
+ })
1023
+ })
1024
+ ]
1025
+ });
1026
+ },
1027
+ parameters: {
1028
+ docs: {
1029
+ description: {
1030
+ story: 'Complex filtering scenario with tabs, search, and multiple filter types for e-commerce.'
1031
+ },
1032
+ source: {
1033
+ transform: _transformers.transformStorySource
1034
+ }
1035
+ }
1036
+ }
1037
+ };
1038
+ var FilterPills = {
1039
+ render: function() {
1040
+ var _useState = _sliced_to_array((0, _react.useState)({
1041
+ new: false,
1042
+ popular: false,
1043
+ sale: false,
1044
+ featured: false
1045
+ }), 2), pillStates = _useState[0], setPillStates = _useState[1];
1046
+ var togglePill = function(key) {
1047
+ setPillStates(function(prev) {
1048
+ return _object_spread_props(_object_spread({}, prev), _define_property({}, key, !prev[key]));
1049
+ });
1050
+ };
1051
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
1052
+ title: "Filter Pills Demo",
1053
+ padded: true,
1054
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1055
+ gap: "lg",
1056
+ children: [
1057
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1058
+ gap: "md",
1059
+ children: [
1060
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1061
+ variant: "headingSm",
1062
+ children: "Interactive Pills"
1063
+ }),
1064
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1065
+ horizontal: true,
1066
+ gap: "sm",
1067
+ wrap: true,
1068
+ children: [
1069
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Pill, {
1070
+ label: "New Arrivals",
1071
+ applied: pillStates.new,
1072
+ onClick: function() {
1073
+ return togglePill('new');
1074
+ }
1075
+ }),
1076
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Pill, {
1077
+ label: "Popular",
1078
+ applied: pillStates.popular,
1079
+ onClick: function() {
1080
+ return togglePill('popular');
1081
+ }
1082
+ }),
1083
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Pill, {
1084
+ label: "On Sale",
1085
+ applied: pillStates.sale,
1086
+ onClick: function() {
1087
+ return togglePill('sale');
1088
+ }
1089
+ }),
1090
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Pill, {
1091
+ label: "Featured",
1092
+ applied: pillStates.featured,
1093
+ onClick: function() {
1094
+ return togglePill('featured');
1095
+ }
1096
+ })
1097
+ ]
1098
+ })
1099
+ ]
1100
+ }),
1101
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1102
+ gap: "md",
1103
+ children: [
1104
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1105
+ variant: "headingSm",
1106
+ children: "Pill States"
1107
+ }),
1108
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1109
+ horizontal: true,
1110
+ gap: "sm",
1111
+ wrap: true,
1112
+ children: [
1113
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Pill, {
1114
+ label: "Available",
1115
+ applied: false
1116
+ }),
1117
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Pill, {
1118
+ label: "Applied",
1119
+ applied: true
1120
+ }),
1121
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Pill, {
1122
+ label: "Disabled",
1123
+ applied: false,
1124
+ disabled: true
1125
+ }),
1126
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Pill, {
1127
+ destructive: true
1128
+ })
1129
+ ]
1130
+ })
1131
+ ]
1132
+ }),
1133
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1134
+ padding: "4",
1135
+ background: "subdued",
1136
+ borderRadius: "default",
1137
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1138
+ gap: "sm",
1139
+ children: [
1140
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1141
+ variant: "headingSm",
1142
+ children: "Current Selection:"
1143
+ }),
1144
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1145
+ gap: "xs",
1146
+ children: [
1147
+ Object.entries(pillStates).filter(function(param) {
1148
+ var _param = _sliced_to_array(param, 2), _ = _param[0], applied = _param[1];
1149
+ return applied;
1150
+ }).map(function(param) {
1151
+ var _param = _sliced_to_array(param, 2), key = _param[0], _ = _param[1];
1152
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
1153
+ variant: "bodyXs",
1154
+ children: [
1155
+ "• ",
1156
+ key.charAt(0).toUpperCase() + key.slice(1)
1157
+ ]
1158
+ }, key);
1159
+ }),
1160
+ Object.values(pillStates).every(function(v) {
1161
+ return !v;
1162
+ }) && /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1163
+ color: "subdued",
1164
+ variant: "bodyXs",
1165
+ children: "No filters selected"
1166
+ })
1167
+ ]
1168
+ })
1169
+ ]
1170
+ })
1171
+ })
1172
+ ]
1173
+ })
1174
+ });
1175
+ },
1176
+ parameters: {
1177
+ docs: {
1178
+ description: {
1179
+ story: 'Standalone filter pills in various states and configurations.'
1180
+ },
1181
+ source: {
1182
+ transform: _transformers.transformStorySource
1183
+ }
1184
+ }
1185
+ }
1186
+ };
1187
+ var ResponsiveBehavior = {
1188
+ render: function() {
1189
+ var _useState = _sliced_to_array((0, _react.useState)([]), 2), appliedFilters = _useState[0], setAppliedFilters = _useState[1];
1190
+ var _useState1 = _sliced_to_array((0, _react.useState)(''), 2), queryValue = _useState1[0], setQueryValue = _useState1[1];
1191
+ var _useState2 = _sliced_to_array((0, _react.useState)(0), 2), selectedTab = _useState2[0], setSelectedTab = _useState2[1];
1192
+ var longTabs = [
1193
+ {
1194
+ id: '1',
1195
+ content: 'All Products & Services'
1196
+ },
1197
+ {
1198
+ id: '2',
1199
+ content: 'Electronics & Gadgets'
1200
+ },
1201
+ {
1202
+ id: '3',
1203
+ content: 'Fashion & Accessories'
1204
+ },
1205
+ {
1206
+ id: '4',
1207
+ content: 'Home & Garden Supplies'
1208
+ },
1209
+ {
1210
+ id: '5',
1211
+ content: 'Sports & Outdoor Equipment'
1212
+ },
1213
+ {
1214
+ id: '6',
1215
+ content: 'Books & Educational Materials'
1216
+ },
1217
+ {
1218
+ id: '7',
1219
+ content: 'Health & Beauty Products'
1220
+ },
1221
+ {
1222
+ id: '8',
1223
+ content: 'Automotive & Transportation'
1224
+ }
1225
+ ];
1226
+ var filters = [
1227
+ {
1228
+ key: 'featured',
1229
+ label: 'Featured',
1230
+ shortcut: true,
1231
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
1232
+ children: "Featured filter content"
1233
+ })
1234
+ },
1235
+ {
1236
+ key: 'bestseller',
1237
+ label: 'Best Sellers',
1238
+ shortcut: true,
1239
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
1240
+ children: "Best sellers filter content"
1241
+ })
1242
+ },
1243
+ {
1244
+ key: 'price',
1245
+ label: 'Price Range',
1246
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
1247
+ children: "Price range filter content"
1248
+ })
1249
+ },
1250
+ {
1251
+ key: 'brand',
1252
+ label: 'Brand',
1253
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
1254
+ children: "Brand filter content"
1255
+ })
1256
+ },
1257
+ {
1258
+ key: 'rating',
1259
+ label: 'Customer Rating',
1260
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
1261
+ children: "Rating filter content"
1262
+ })
1263
+ },
1264
+ {
1265
+ key: 'shipping',
1266
+ label: 'Shipping Options',
1267
+ filter: /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
1268
+ children: "Shipping filter content"
1269
+ })
1270
+ }
1271
+ ];
1272
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1273
+ gap: "md",
1274
+ children: [
1275
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
1276
+ title: "Responsive Filter Tabs",
1277
+ padded: true,
1278
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1279
+ gap: "md",
1280
+ children: [
1281
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1282
+ variant: "bodyXs",
1283
+ children: "These tabs scroll horizontally on smaller screens with navigation arrows."
1284
+ }),
1285
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default.Tabs, {
1286
+ tabs: longTabs,
1287
+ selected: selectedTab,
1288
+ onSelect: setSelectedTab
1289
+ })
1290
+ ]
1291
+ })
1292
+ }),
1293
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
1294
+ title: "Responsive Filters Layout",
1295
+ padded: true,
1296
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1297
+ gap: "md",
1298
+ children: [
1299
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1300
+ variant: "bodyXs",
1301
+ children: "Filter pills wrap to new lines on smaller screens, and the search field adapts to available space."
1302
+ }),
1303
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Filters.default, {
1304
+ filters: filters,
1305
+ appliedFilters: appliedFilters,
1306
+ showTextField: true,
1307
+ queryValue: queryValue,
1308
+ onQueryChange: setQueryValue,
1309
+ onQueryClear: function() {
1310
+ return setQueryValue('');
1311
+ },
1312
+ queryPlaceholder: "Search across all categories..."
1313
+ })
1314
+ ]
1315
+ })
1316
+ }),
1317
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
1318
+ title: "Mobile-Optimized Tips",
1319
+ padded: true,
1320
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1321
+ gap: "sm",
1322
+ children: [
1323
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1324
+ variant: "bodyXs",
1325
+ children: "• Tabs become horizontally scrollable with touch/swipe support"
1326
+ }),
1327
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1328
+ variant: "bodyXs",
1329
+ children: "• Filter pills stack vertically when space is limited"
1330
+ }),
1331
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1332
+ variant: "bodyXs",
1333
+ children: "• Search field takes full width on mobile"
1334
+ }),
1335
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1336
+ variant: "bodyXs",
1337
+ children: "• Popover content adapts to screen size and orientation"
1338
+ })
1339
+ ]
1340
+ })
1341
+ })
1342
+ ]
1343
+ });
1344
+ },
1345
+ parameters: {
1346
+ docs: {
1347
+ description: {
1348
+ story: 'Demonstrates responsive behavior of filters across different screen sizes.'
1349
+ },
1350
+ source: {
1351
+ transform: _transformers.transformStorySource
1352
+ }
1353
+ }
1354
+ }
1355
+ };