@heymantle/litho 0.0.3 → 0.0.4

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