@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,824 @@
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 CustomIcon () {
13
+ return CustomIcon;
14
+ },
15
+ get Default () {
16
+ return Default;
17
+ },
18
+ get FilterOptions () {
19
+ return FilterOptions;
20
+ },
21
+ get HorizontalOnMobile () {
22
+ return HorizontalOnMobile;
23
+ },
24
+ get KeyboardNavigation () {
25
+ return KeyboardNavigation;
26
+ },
27
+ get MultipleSelection () {
28
+ return MultipleSelection;
29
+ },
30
+ get NavigationMenu () {
31
+ return NavigationMenu;
32
+ },
33
+ get WithIcons () {
34
+ return WithIcons;
35
+ },
36
+ get default () {
37
+ return _default;
38
+ }
39
+ });
40
+ var _jsxruntime = require("react/jsx-runtime");
41
+ var _react = require("react");
42
+ var _transformers = require("../utilities/transformers.js");
43
+ var _Listbox = /*#__PURE__*/ _interop_require_default(require("../components/Listbox.js"));
44
+ var _Text = /*#__PURE__*/ _interop_require_default(require("../components/Text.js"));
45
+ var _Card = /*#__PURE__*/ _interop_require_default(require("../components/Card.js"));
46
+ var _Stack = /*#__PURE__*/ _interop_require_default(require("../components/Stack.js"));
47
+ var _Box = /*#__PURE__*/ _interop_require_default(require("../components/Box.js"));
48
+ var _polarisicons = require("@shopify/polaris-icons");
49
+ function _array_like_to_array(arr, len) {
50
+ if (len == null || len > arr.length) len = arr.length;
51
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
52
+ return arr2;
53
+ }
54
+ function _array_with_holes(arr) {
55
+ if (Array.isArray(arr)) return arr;
56
+ }
57
+ function _array_without_holes(arr) {
58
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
59
+ }
60
+ function _interop_require_default(obj) {
61
+ return obj && obj.__esModule ? obj : {
62
+ default: obj
63
+ };
64
+ }
65
+ function _iterable_to_array(iter) {
66
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
67
+ }
68
+ function _iterable_to_array_limit(arr, i) {
69
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
70
+ if (_i == null) return;
71
+ var _arr = [];
72
+ var _n = true;
73
+ var _d = false;
74
+ var _s, _e;
75
+ try {
76
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
77
+ _arr.push(_s.value);
78
+ if (i && _arr.length === i) break;
79
+ }
80
+ } catch (err) {
81
+ _d = true;
82
+ _e = err;
83
+ } finally{
84
+ try {
85
+ if (!_n && _i["return"] != null) _i["return"]();
86
+ } finally{
87
+ if (_d) throw _e;
88
+ }
89
+ }
90
+ return _arr;
91
+ }
92
+ function _non_iterable_rest() {
93
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
94
+ }
95
+ function _non_iterable_spread() {
96
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
97
+ }
98
+ function _sliced_to_array(arr, i) {
99
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
100
+ }
101
+ function _to_consumable_array(arr) {
102
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
103
+ }
104
+ function _unsupported_iterable_to_array(o, minLen) {
105
+ if (!o) return;
106
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
107
+ var n = Object.prototype.toString.call(o).slice(8, -1);
108
+ if (n === "Object" && o.constructor) n = o.constructor.name;
109
+ if (n === "Map" || n === "Set") return Array.from(n);
110
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
111
+ }
112
+ var _default = {
113
+ title: 'Litho/Listbox',
114
+ component: _Listbox.default,
115
+ parameters: {
116
+ layout: 'padded',
117
+ docs: {
118
+ description: {
119
+ component: "A Listbox component that displays a list of selectable options with keyboard navigation support. It can show icons for selected items and supports both vertical and horizontal layouts."
120
+ },
121
+ source: {
122
+ transform: _transformers.transformStorySource
123
+ }
124
+ }
125
+ },
126
+ tags: [
127
+ 'autodocs'
128
+ ],
129
+ argTypes: {
130
+ options: {
131
+ control: 'object',
132
+ description: 'Array of option objects with label, value, selected, and onAction properties'
133
+ },
134
+ showIcon: {
135
+ control: 'boolean',
136
+ description: 'Whether to show icons for selected options'
137
+ },
138
+ displayHorizontallyOnMobile: {
139
+ control: 'boolean',
140
+ description: 'Whether to display horizontally on mobile devices'
141
+ },
142
+ icon: {
143
+ control: false,
144
+ description: 'Icon to display for selected options'
145
+ }
146
+ }
147
+ };
148
+ var Default = {
149
+ render: function() {
150
+ var _useState = _sliced_to_array((0, _react.useState)('option2'), 2), selectedValue = _useState[0], setSelectedValue = _useState[1];
151
+ var options = [
152
+ {
153
+ label: 'Option 1',
154
+ value: 'option1',
155
+ selected: selectedValue === 'option1',
156
+ onAction: function() {
157
+ return setSelectedValue('option1');
158
+ }
159
+ },
160
+ {
161
+ label: 'Option 2',
162
+ value: 'option2',
163
+ selected: selectedValue === 'option2',
164
+ onAction: function() {
165
+ return setSelectedValue('option2');
166
+ }
167
+ },
168
+ {
169
+ label: 'Option 3',
170
+ value: 'option3',
171
+ selected: selectedValue === 'option3',
172
+ onAction: function() {
173
+ return setSelectedValue('option3');
174
+ }
175
+ }
176
+ ];
177
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
178
+ title: "Select an Option",
179
+ style: {
180
+ width: '300px'
181
+ },
182
+ padded: true,
183
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Listbox.default, {
184
+ options: options
185
+ })
186
+ });
187
+ },
188
+ parameters: {
189
+ docs: {
190
+ description: {
191
+ story: 'Basic listbox with selectable options.'
192
+ }
193
+ }
194
+ }
195
+ };
196
+ var WithIcons = {
197
+ render: function() {
198
+ var _useState = _sliced_to_array((0, _react.useState)('option2'), 2), selectedValue = _useState[0], setSelectedValue = _useState[1];
199
+ var options = [
200
+ {
201
+ label: 'Option 1',
202
+ value: 'option1',
203
+ selected: selectedValue === 'option1',
204
+ onAction: function() {
205
+ return setSelectedValue('option1');
206
+ }
207
+ },
208
+ {
209
+ label: 'Option 2',
210
+ value: 'option2',
211
+ selected: selectedValue === 'option2',
212
+ onAction: function() {
213
+ return setSelectedValue('option2');
214
+ }
215
+ },
216
+ {
217
+ label: 'Option 3',
218
+ value: 'option3',
219
+ selected: selectedValue === 'option3',
220
+ onAction: function() {
221
+ return setSelectedValue('option3');
222
+ }
223
+ }
224
+ ];
225
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
226
+ title: "Select with Icons",
227
+ style: {
228
+ width: '300px'
229
+ },
230
+ padded: true,
231
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Listbox.default, {
232
+ options: options,
233
+ showIcon: true
234
+ })
235
+ });
236
+ },
237
+ parameters: {
238
+ docs: {
239
+ description: {
240
+ story: 'Listbox with icons showing selected state.'
241
+ }
242
+ }
243
+ }
244
+ };
245
+ var CustomIcon = {
246
+ render: function() {
247
+ var _useState = _sliced_to_array((0, _react.useState)('favorite'), 2), selectedValue = _useState[0], setSelectedValue = _useState[1];
248
+ var options = [
249
+ {
250
+ label: 'Favorite',
251
+ value: 'favorite',
252
+ selected: selectedValue === 'favorite',
253
+ onAction: function() {
254
+ return setSelectedValue('favorite');
255
+ }
256
+ },
257
+ {
258
+ label: 'Recent',
259
+ value: 'recent',
260
+ selected: selectedValue === 'recent',
261
+ onAction: function() {
262
+ return setSelectedValue('recent');
263
+ }
264
+ },
265
+ {
266
+ label: 'Archive',
267
+ value: 'archive',
268
+ selected: selectedValue === 'archive',
269
+ onAction: function() {
270
+ return setSelectedValue('archive');
271
+ }
272
+ }
273
+ ];
274
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
275
+ title: "Custom Icon",
276
+ style: {
277
+ width: '300px'
278
+ },
279
+ padded: true,
280
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Listbox.default, {
281
+ options: options,
282
+ showIcon: true,
283
+ icon: _polarisicons.StarFilledMinor
284
+ })
285
+ });
286
+ },
287
+ parameters: {
288
+ docs: {
289
+ description: {
290
+ story: 'Listbox with custom icon for selected items.'
291
+ }
292
+ }
293
+ }
294
+ };
295
+ var MultipleSelection = {
296
+ render: function() {
297
+ var _useState = _sliced_to_array((0, _react.useState)([
298
+ 'option2',
299
+ 'option3'
300
+ ]), 2), selectedValues = _useState[0], setSelectedValues = _useState[1];
301
+ var toggleSelection = function(value) {
302
+ setSelectedValues(function(prev) {
303
+ return prev.includes(value) ? prev.filter(function(v) {
304
+ return v !== value;
305
+ }) : _to_consumable_array(prev).concat([
306
+ value
307
+ ]);
308
+ });
309
+ };
310
+ var options = [
311
+ {
312
+ label: 'Email Notifications',
313
+ value: 'option1',
314
+ selected: selectedValues.includes('option1'),
315
+ onAction: function() {
316
+ return toggleSelection('option1');
317
+ }
318
+ },
319
+ {
320
+ label: 'SMS Notifications',
321
+ value: 'option2',
322
+ selected: selectedValues.includes('option2'),
323
+ onAction: function() {
324
+ return toggleSelection('option2');
325
+ }
326
+ },
327
+ {
328
+ label: 'Push Notifications',
329
+ value: 'option3',
330
+ selected: selectedValues.includes('option3'),
331
+ onAction: function() {
332
+ return toggleSelection('option3');
333
+ }
334
+ },
335
+ {
336
+ label: 'Newsletter',
337
+ value: 'option4',
338
+ selected: selectedValues.includes('option4'),
339
+ onAction: function() {
340
+ return toggleSelection('option4');
341
+ }
342
+ }
343
+ ];
344
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Card.default, {
345
+ title: "Notification Preferences",
346
+ style: {
347
+ width: '300px'
348
+ },
349
+ padded: true,
350
+ children: [
351
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Listbox.default, {
352
+ options: options,
353
+ showIcon: true,
354
+ icon: _polarisicons.MobileAcceptMajor
355
+ }),
356
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
357
+ paddingBlockStart: "4",
358
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
359
+ paddingBlock: "2",
360
+ paddingInline: "2",
361
+ background: "surface-neutral-subdued",
362
+ borderRadius: "base",
363
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
364
+ variant: "bodySm",
365
+ children: [
366
+ "Selected: ",
367
+ selectedValues.length > 0 ? selectedValues.join(', ') : 'None'
368
+ ]
369
+ })
370
+ })
371
+ })
372
+ ]
373
+ });
374
+ },
375
+ parameters: {
376
+ docs: {
377
+ description: {
378
+ story: 'Listbox allowing multiple selections.'
379
+ }
380
+ }
381
+ }
382
+ };
383
+ var NavigationMenu = {
384
+ render: function() {
385
+ var _useState = _sliced_to_array((0, _react.useState)('dashboard'), 2), activeSection = _useState[0], setActiveSection = _useState[1];
386
+ var menuOptions = [
387
+ {
388
+ label: 'Dashboard',
389
+ value: 'dashboard',
390
+ selected: activeSection === 'dashboard',
391
+ onAction: function() {
392
+ return setActiveSection('dashboard');
393
+ }
394
+ },
395
+ {
396
+ label: 'Products',
397
+ value: 'products',
398
+ selected: activeSection === 'products',
399
+ onAction: function() {
400
+ return setActiveSection('products');
401
+ }
402
+ },
403
+ {
404
+ label: 'Customers',
405
+ value: 'customers',
406
+ selected: activeSection === 'customers',
407
+ onAction: function() {
408
+ return setActiveSection('customers');
409
+ }
410
+ },
411
+ {
412
+ label: 'Orders',
413
+ value: 'orders',
414
+ selected: activeSection === 'orders',
415
+ onAction: function() {
416
+ return setActiveSection('orders');
417
+ }
418
+ },
419
+ {
420
+ label: 'Analytics',
421
+ value: 'analytics',
422
+ selected: activeSection === 'analytics',
423
+ onAction: function() {
424
+ return setActiveSection('analytics');
425
+ }
426
+ },
427
+ {
428
+ label: 'Settings',
429
+ value: 'settings',
430
+ selected: activeSection === 'settings',
431
+ onAction: function() {
432
+ return setActiveSection('settings');
433
+ }
434
+ }
435
+ ];
436
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
437
+ horizontal: true,
438
+ gap: "lg",
439
+ children: [
440
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
441
+ width: "200px",
442
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
443
+ title: "Navigation",
444
+ padded: true,
445
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Listbox.default, {
446
+ options: menuOptions
447
+ })
448
+ })
449
+ }),
450
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
451
+ minWidth: "0",
452
+ style: {
453
+ flex: 1
454
+ },
455
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
456
+ title: "".concat(activeSection.charAt(0).toUpperCase() + activeSection.slice(1), " Content"),
457
+ padded: true,
458
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
459
+ children: [
460
+ "This is the content for the ",
461
+ activeSection,
462
+ " section."
463
+ ]
464
+ })
465
+ })
466
+ })
467
+ ]
468
+ });
469
+ },
470
+ parameters: {
471
+ docs: {
472
+ description: {
473
+ story: 'Listbox used as a navigation menu with content area.'
474
+ }
475
+ }
476
+ }
477
+ };
478
+ var FilterOptions = {
479
+ render: function() {
480
+ var _useState = _sliced_to_array((0, _react.useState)([
481
+ 'active'
482
+ ]), 2), selectedFilters = _useState[0], setSelectedFilters = _useState[1];
483
+ var toggleFilter = function(value) {
484
+ setSelectedFilters(function(prev) {
485
+ return prev.includes(value) ? prev.filter(function(v) {
486
+ return v !== value;
487
+ }) : _to_consumable_array(prev).concat([
488
+ value
489
+ ]);
490
+ });
491
+ };
492
+ var filterOptions = [
493
+ {
494
+ label: 'All Items',
495
+ value: 'all',
496
+ selected: selectedFilters.includes('all'),
497
+ onAction: function() {
498
+ return toggleFilter('all');
499
+ }
500
+ },
501
+ {
502
+ label: 'Active',
503
+ value: 'active',
504
+ selected: selectedFilters.includes('active'),
505
+ onAction: function() {
506
+ return toggleFilter('active');
507
+ }
508
+ },
509
+ {
510
+ label: 'Inactive',
511
+ value: 'inactive',
512
+ selected: selectedFilters.includes('inactive'),
513
+ onAction: function() {
514
+ return toggleFilter('inactive');
515
+ }
516
+ },
517
+ {
518
+ label: 'Pending',
519
+ value: 'pending',
520
+ selected: selectedFilters.includes('pending'),
521
+ onAction: function() {
522
+ return toggleFilter('pending');
523
+ }
524
+ },
525
+ {
526
+ label: 'Archived',
527
+ value: 'archived',
528
+ selected: selectedFilters.includes('archived'),
529
+ onAction: function() {
530
+ return toggleFilter('archived');
531
+ }
532
+ }
533
+ ];
534
+ var sampleData = [
535
+ {
536
+ name: 'Item 1',
537
+ status: 'active'
538
+ },
539
+ {
540
+ name: 'Item 2',
541
+ status: 'inactive'
542
+ },
543
+ {
544
+ name: 'Item 3',
545
+ status: 'active'
546
+ },
547
+ {
548
+ name: 'Item 4',
549
+ status: 'pending'
550
+ },
551
+ {
552
+ name: 'Item 5',
553
+ status: 'archived'
554
+ }
555
+ ];
556
+ var filteredData = selectedFilters.includes('all') ? sampleData : sampleData.filter(function(item) {
557
+ return selectedFilters.includes(item.status);
558
+ });
559
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
560
+ horizontal: true,
561
+ gap: "lg",
562
+ children: [
563
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
564
+ width: "200px",
565
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
566
+ title: "Filters",
567
+ padded: true,
568
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Listbox.default, {
569
+ options: filterOptions,
570
+ showIcon: true
571
+ })
572
+ })
573
+ }),
574
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
575
+ minWidth: "0",
576
+ style: {
577
+ flex: 1
578
+ },
579
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
580
+ title: "Filtered Results",
581
+ padded: true,
582
+ children: filteredData.length > 0 ? /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
583
+ gap: "sm",
584
+ children: filteredData.map(function(item, index) {
585
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
586
+ paddingBlock: "2",
587
+ paddingInline: "2",
588
+ borderWidth: "base",
589
+ borderColor: "border-subdued",
590
+ borderRadius: "base",
591
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
592
+ horizontal: true,
593
+ blockAlign: "center",
594
+ inlineAlign: "space-between",
595
+ children: [
596
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
597
+ children: item.name
598
+ }),
599
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
600
+ variant: "bodySm",
601
+ color: "subdued",
602
+ style: {
603
+ textTransform: 'capitalize'
604
+ },
605
+ children: item.status
606
+ })
607
+ ]
608
+ })
609
+ }, index);
610
+ })
611
+ }) : /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
612
+ color: "subdued",
613
+ children: "No items match the selected filters."
614
+ })
615
+ })
616
+ })
617
+ ]
618
+ });
619
+ },
620
+ parameters: {
621
+ docs: {
622
+ description: {
623
+ story: 'Listbox used for filtering data with real-time results.'
624
+ }
625
+ }
626
+ }
627
+ };
628
+ var HorizontalOnMobile = {
629
+ render: function() {
630
+ var _useState = _sliced_to_array((0, _react.useState)('overview'), 2), selectedTab = _useState[0], setSelectedTab = _useState[1];
631
+ var tabOptions = [
632
+ {
633
+ label: 'Overview',
634
+ value: 'overview',
635
+ selected: selectedTab === 'overview',
636
+ onAction: function() {
637
+ return setSelectedTab('overview');
638
+ }
639
+ },
640
+ {
641
+ label: 'Details',
642
+ value: 'details',
643
+ selected: selectedTab === 'details',
644
+ onAction: function() {
645
+ return setSelectedTab('details');
646
+ }
647
+ },
648
+ {
649
+ label: 'Reviews',
650
+ value: 'reviews',
651
+ selected: selectedTab === 'reviews',
652
+ onAction: function() {
653
+ return setSelectedTab('reviews');
654
+ }
655
+ },
656
+ {
657
+ label: 'Specifications',
658
+ value: 'specifications',
659
+ selected: selectedTab === 'specifications',
660
+ onAction: function() {
661
+ return setSelectedTab('specifications');
662
+ }
663
+ },
664
+ {
665
+ label: 'Support',
666
+ value: 'support',
667
+ selected: selectedTab === 'support',
668
+ onAction: function() {
669
+ return setSelectedTab('support');
670
+ }
671
+ }
672
+ ];
673
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Card.default, {
674
+ title: "Product Information",
675
+ padded: true,
676
+ children: [
677
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
678
+ paddingBlockEnd: "4",
679
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Listbox.default, {
680
+ options: tabOptions,
681
+ displayHorizontallyOnMobile: true
682
+ })
683
+ }),
684
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
685
+ paddingBlock: "4",
686
+ paddingInline: "4",
687
+ background: "surface-neutral-subdued",
688
+ borderRadius: "base",
689
+ minHeight: "200px",
690
+ children: [
691
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
692
+ paddingBlockEnd: "4",
693
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
694
+ variant: "headingSm",
695
+ children: [
696
+ selectedTab.charAt(0).toUpperCase() + selectedTab.slice(1),
697
+ " Content"
698
+ ]
699
+ })
700
+ }),
701
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
702
+ children: [
703
+ "This is the content for the ",
704
+ selectedTab,
705
+ " tab. On mobile devices, the tabs above will display horizontally with horizontal scrolling."
706
+ ]
707
+ })
708
+ ]
709
+ })
710
+ ]
711
+ });
712
+ },
713
+ parameters: {
714
+ docs: {
715
+ description: {
716
+ story: 'Listbox that displays horizontally on mobile for better mobile UX.'
717
+ }
718
+ }
719
+ }
720
+ };
721
+ var KeyboardNavigation = {
722
+ render: function() {
723
+ var _useState = _sliced_to_array((0, _react.useState)('item2'), 2), selectedValue = _useState[0], setSelectedValue = _useState[1];
724
+ var options = [
725
+ {
726
+ label: 'First Item',
727
+ value: 'item1',
728
+ selected: selectedValue === 'item1',
729
+ onAction: function() {
730
+ return setSelectedValue('item1');
731
+ }
732
+ },
733
+ {
734
+ label: 'Second Item',
735
+ value: 'item2',
736
+ selected: selectedValue === 'item2',
737
+ onAction: function() {
738
+ return setSelectedValue('item2');
739
+ }
740
+ },
741
+ {
742
+ label: 'Third Item',
743
+ value: 'item3',
744
+ selected: selectedValue === 'item3',
745
+ onAction: function() {
746
+ return setSelectedValue('item3');
747
+ }
748
+ },
749
+ {
750
+ label: 'Fourth Item',
751
+ value: 'item4',
752
+ selected: selectedValue === 'item4',
753
+ onAction: function() {
754
+ return setSelectedValue('item4');
755
+ }
756
+ }
757
+ ];
758
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Card.default, {
759
+ title: "Keyboard Navigation Demo",
760
+ style: {
761
+ width: '300px'
762
+ },
763
+ padded: true,
764
+ children: [
765
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
766
+ paddingBlockEnd: "4",
767
+ children: [
768
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
769
+ variant: "bodySm",
770
+ children: "Try keyboard navigation:"
771
+ }),
772
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
773
+ paddingBlockStart: "2",
774
+ paddingInlineStart: "4",
775
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)("ul", {
776
+ style: {
777
+ fontSize: '0.8rem'
778
+ },
779
+ children: [
780
+ /*#__PURE__*/ (0, _jsxruntime.jsx)("li", {
781
+ children: "↑/↓ arrows: Move between options"
782
+ }),
783
+ /*#__PURE__*/ (0, _jsxruntime.jsx)("li", {
784
+ children: "Enter: Select option"
785
+ }),
786
+ /*#__PURE__*/ (0, _jsxruntime.jsx)("li", {
787
+ children: "Escape: Remove focus"
788
+ })
789
+ ]
790
+ })
791
+ })
792
+ ]
793
+ }),
794
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Listbox.default, {
795
+ options: options,
796
+ showIcon: true
797
+ }),
798
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
799
+ paddingBlockStart: "4",
800
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
801
+ paddingBlock: "2",
802
+ paddingInline: "2",
803
+ background: "surface-accent-subdued",
804
+ borderRadius: "base",
805
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
806
+ variant: "bodySm",
807
+ children: [
808
+ "Selected: ",
809
+ selectedValue
810
+ ]
811
+ })
812
+ })
813
+ })
814
+ ]
815
+ });
816
+ },
817
+ parameters: {
818
+ docs: {
819
+ description: {
820
+ story: 'Demonstrates keyboard navigation features of the listbox.'
821
+ }
822
+ }
823
+ }
824
+ };