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