@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,833 @@
1
+ function _array_like_to_array(arr, len) {
2
+ if (len == null || len > arr.length) len = arr.length;
3
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
4
+ return arr2;
5
+ }
6
+ function _array_with_holes(arr) {
7
+ if (Array.isArray(arr)) return arr;
8
+ }
9
+ function _define_property(obj, key, value) {
10
+ if (key in obj) {
11
+ Object.defineProperty(obj, key, {
12
+ value: value,
13
+ enumerable: true,
14
+ configurable: true,
15
+ writable: true
16
+ });
17
+ } else {
18
+ obj[key] = value;
19
+ }
20
+ return obj;
21
+ }
22
+ function _iterable_to_array_limit(arr, i) {
23
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
24
+ if (_i == null) return;
25
+ var _arr = [];
26
+ var _n = true;
27
+ var _d = false;
28
+ var _s, _e;
29
+ try {
30
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
31
+ _arr.push(_s.value);
32
+ if (i && _arr.length === i) break;
33
+ }
34
+ } catch (err) {
35
+ _d = true;
36
+ _e = err;
37
+ } finally{
38
+ try {
39
+ if (!_n && _i["return"] != null) _i["return"]();
40
+ } finally{
41
+ if (_d) throw _e;
42
+ }
43
+ }
44
+ return _arr;
45
+ }
46
+ function _non_iterable_rest() {
47
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
48
+ }
49
+ function _object_spread(target) {
50
+ for(var i = 1; i < arguments.length; i++){
51
+ var source = arguments[i] != null ? arguments[i] : {};
52
+ var ownKeys = Object.keys(source);
53
+ if (typeof Object.getOwnPropertySymbols === "function") {
54
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
55
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
56
+ }));
57
+ }
58
+ ownKeys.forEach(function(key) {
59
+ _define_property(target, key, source[key]);
60
+ });
61
+ }
62
+ return target;
63
+ }
64
+ function ownKeys(object, enumerableOnly) {
65
+ var keys = Object.keys(object);
66
+ if (Object.getOwnPropertySymbols) {
67
+ var symbols = Object.getOwnPropertySymbols(object);
68
+ if (enumerableOnly) {
69
+ symbols = symbols.filter(function(sym) {
70
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
71
+ });
72
+ }
73
+ keys.push.apply(keys, symbols);
74
+ }
75
+ return keys;
76
+ }
77
+ function _object_spread_props(target, source) {
78
+ source = source != null ? source : {};
79
+ if (Object.getOwnPropertyDescriptors) {
80
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
81
+ } else {
82
+ ownKeys(Object(source)).forEach(function(key) {
83
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
84
+ });
85
+ }
86
+ return target;
87
+ }
88
+ function _sliced_to_array(arr, i) {
89
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
90
+ }
91
+ function _unsupported_iterable_to_array(o, minLen) {
92
+ if (!o) return;
93
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
94
+ var n = Object.prototype.toString.call(o).slice(8, -1);
95
+ if (n === "Object" && o.constructor) n = o.constructor.name;
96
+ if (n === "Map" || n === "Set") return Array.from(n);
97
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
98
+ }
99
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
100
+ import { useState } from "react";
101
+ import Autocomplete from "../components/Autocomplete.js";
102
+ import Text from "../components/Text.js";
103
+ import Card from "../components/Card.js";
104
+ import Button from "../components/Button.js";
105
+ import { SearchMinor, ProductsMinor, CustomersMinor } from "@shopify/polaris-icons";
106
+ import HorizontalStack from "../components/HorizontalStack.js";
107
+ import VerticalStack from "../components/VerticalStack.js";
108
+ import Tag from "../components/Tag.js";
109
+ import Thumbnail from "../components/Thumbnail.js";
110
+ import { transformStorySource } from "../utilities/transformers.js";
111
+ export default {
112
+ title: "Litho/Autocomplete",
113
+ component: Autocomplete,
114
+ parameters: {
115
+ layout: "padded",
116
+ docs: {
117
+ description: {
118
+ component: "An Autocomplete component that provides search functionality with dropdown options. It supports single and multiple selection, grouped options, loading states, and custom empty states."
119
+ }
120
+ }
121
+ },
122
+ tags: [
123
+ "autodocs"
124
+ ],
125
+ argTypes: {
126
+ options: {
127
+ control: "object",
128
+ description: "Array of options to display in the dropdown",
129
+ table: {
130
+ type: {
131
+ summary: "AutocompleteOption[]",
132
+ detail: "{\n label: string;\n value: string;\n title?: string;\n allowMultiple?: boolean;\n selected?: string;\n onSelect?: () => void;\n options?: AutocompleteOption[];\n}"
133
+ }
134
+ }
135
+ },
136
+ selected: {
137
+ control: "object",
138
+ description: "Currently selected option values",
139
+ table: {
140
+ type: {
141
+ summary: "string[]"
142
+ },
143
+ defaultValue: {
144
+ summary: "[]"
145
+ }
146
+ }
147
+ },
148
+ allowMultiple: {
149
+ control: "boolean",
150
+ description: "Whether multiple options can be selected",
151
+ table: {
152
+ type: {
153
+ summary: "boolean"
154
+ },
155
+ defaultValue: {
156
+ summary: "false"
157
+ }
158
+ }
159
+ },
160
+ loading: {
161
+ control: "boolean",
162
+ description: "Whether to show loading spinner",
163
+ table: {
164
+ type: {
165
+ summary: "boolean"
166
+ },
167
+ defaultValue: {
168
+ summary: "false"
169
+ }
170
+ }
171
+ },
172
+ preferredPosition: {
173
+ control: "select",
174
+ options: [
175
+ "below",
176
+ "above"
177
+ ],
178
+ description: "Preferred position of the dropdown",
179
+ table: {
180
+ type: {
181
+ summary: "string"
182
+ },
183
+ defaultValue: {
184
+ summary: "below"
185
+ }
186
+ }
187
+ },
188
+ preferredAlignment: {
189
+ control: "select",
190
+ options: [
191
+ "left",
192
+ "center",
193
+ "right"
194
+ ],
195
+ description: "Preferred alignment of the dropdown",
196
+ table: {
197
+ type: {
198
+ summary: "string"
199
+ },
200
+ defaultValue: {
201
+ summary: "left"
202
+ }
203
+ }
204
+ },
205
+ onSelect: {
206
+ control: false,
207
+ description: "Callback when selection changes",
208
+ table: {
209
+ type: {
210
+ summary: "() => void"
211
+ }
212
+ }
213
+ },
214
+ textField: {
215
+ control: false,
216
+ description: "TextField component used as activator",
217
+ table: {
218
+ type: {
219
+ summary: "React.ReactNode"
220
+ }
221
+ }
222
+ },
223
+ emptyState: {
224
+ control: "object",
225
+ description: "Content to display when no options available",
226
+ table: {
227
+ type: {
228
+ summary: "AutocompleteEmptyState",
229
+ detail: "{\n content: string;\n icon?: React.ReactNode;\n}"
230
+ }
231
+ }
232
+ }
233
+ }
234
+ };
235
+ export var Default = {
236
+ render: function() {
237
+ var _useState = _sliced_to_array(useState([
238
+ "product1"
239
+ ]), 2), selected = _useState[0], setSelected = _useState[1];
240
+ var _useState1 = _sliced_to_array(useState(""), 2), inputValue = _useState1[0], setInputValue = _useState1[1];
241
+ var options = [
242
+ {
243
+ label: "Product A",
244
+ value: "product1"
245
+ },
246
+ {
247
+ label: "Product B",
248
+ value: "product2"
249
+ },
250
+ {
251
+ label: "Product C",
252
+ value: "product3"
253
+ },
254
+ {
255
+ label: "Service A",
256
+ value: "service1"
257
+ },
258
+ {
259
+ label: "Service B",
260
+ value: "service2"
261
+ }
262
+ ];
263
+ var filteredOptions = inputValue ? options.filter(function(option) {
264
+ return option.label.toLowerCase().includes(inputValue.toLowerCase());
265
+ }) : options;
266
+ return /*#__PURE__*/ _jsx(Card, {
267
+ title: "Select a Product",
268
+ style: {
269
+ width: "400px"
270
+ },
271
+ padded: true,
272
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
273
+ gap: "2",
274
+ children: [
275
+ /*#__PURE__*/ _jsx(Autocomplete, {
276
+ options: filteredOptions,
277
+ selected: selected,
278
+ onSelect: setSelected,
279
+ textField: /*#__PURE__*/ _jsx(Autocomplete.TextField, {
280
+ placeholder: "Search products...",
281
+ value: inputValue,
282
+ onChange: setInputValue
283
+ })
284
+ }),
285
+ /*#__PURE__*/ _jsx(HorizontalStack, {
286
+ children: selected.length > 0 && selected.map(function(item) {
287
+ return /*#__PURE__*/ _jsx(Tag, {
288
+ children: item
289
+ }, item);
290
+ })
291
+ })
292
+ ]
293
+ })
294
+ });
295
+ },
296
+ parameters: {
297
+ docs: {
298
+ description: {
299
+ story: "Basic autocomplete with single selection and search filtering."
300
+ },
301
+ source: {
302
+ transform: transformStorySource
303
+ }
304
+ }
305
+ }
306
+ };
307
+ export var MultipleSelection = {
308
+ render: function() {
309
+ var _useState = _sliced_to_array(useState([
310
+ "tag1",
311
+ "tag3"
312
+ ]), 2), selected = _useState[0], setSelected = _useState[1];
313
+ var _useState1 = _sliced_to_array(useState(""), 2), inputValue = _useState1[0], setInputValue = _useState1[1];
314
+ var options = [
315
+ {
316
+ label: "JavaScript",
317
+ value: "tag1"
318
+ },
319
+ {
320
+ label: "React",
321
+ value: "tag2"
322
+ },
323
+ {
324
+ label: "TypeScript",
325
+ value: "tag3"
326
+ },
327
+ {
328
+ label: "Node.js",
329
+ value: "tag4"
330
+ },
331
+ {
332
+ label: "CSS",
333
+ value: "tag5"
334
+ },
335
+ {
336
+ label: "HTML",
337
+ value: "tag6"
338
+ },
339
+ {
340
+ label: "Python",
341
+ value: "tag7"
342
+ },
343
+ {
344
+ label: "GraphQL",
345
+ value: "tag8"
346
+ }
347
+ ];
348
+ var filteredOptions = inputValue ? options.filter(function(option) {
349
+ return option.label.toLowerCase().includes(inputValue.toLowerCase());
350
+ }) : options;
351
+ return /*#__PURE__*/ _jsx(Card, {
352
+ title: "Select Technologies",
353
+ style: {
354
+ width: "400px"
355
+ },
356
+ padded: true,
357
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
358
+ gap: "2",
359
+ children: [
360
+ /*#__PURE__*/ _jsx(Autocomplete, {
361
+ options: filteredOptions,
362
+ selected: selected,
363
+ allowMultiple: true,
364
+ onSelect: setSelected,
365
+ textField: /*#__PURE__*/ _jsx(Autocomplete.TextField, {
366
+ placeholder: "Search technologies...",
367
+ value: inputValue,
368
+ onChange: setInputValue
369
+ })
370
+ }),
371
+ /*#__PURE__*/ _jsx(HorizontalStack, {
372
+ gap: "2",
373
+ children: selected.length > 0 && selected.map(function(item) {
374
+ return /*#__PURE__*/ _jsx(Tag, {
375
+ children: item
376
+ }, item);
377
+ })
378
+ })
379
+ ]
380
+ })
381
+ });
382
+ },
383
+ parameters: {
384
+ docs: {
385
+ description: {
386
+ story: "Autocomplete with multiple selection using checkboxes."
387
+ },
388
+ source: {
389
+ transform: transformStorySource
390
+ }
391
+ }
392
+ }
393
+ };
394
+ export var GroupedOptions = {
395
+ render: function() {
396
+ var _useState = _sliced_to_array(useState([
397
+ "user1"
398
+ ]), 2), selected = _useState[0], setSelected = _useState[1];
399
+ var _useState1 = _sliced_to_array(useState(""), 2), inputValue = _useState1[0], setInputValue = _useState1[1];
400
+ var allOptions = [
401
+ {
402
+ title: "Recent Contacts",
403
+ options: [
404
+ {
405
+ label: "John Doe",
406
+ value: "user1"
407
+ },
408
+ {
409
+ label: "Jane Smith",
410
+ value: "user2"
411
+ },
412
+ {
413
+ label: "Bob Johnson",
414
+ value: "user3"
415
+ }
416
+ ]
417
+ },
418
+ {
419
+ title: "Team Members",
420
+ options: [
421
+ {
422
+ label: "Alice Brown",
423
+ value: "team1"
424
+ },
425
+ {
426
+ label: "Charlie Wilson",
427
+ value: "team2"
428
+ },
429
+ {
430
+ label: "Diana Miller",
431
+ value: "team3"
432
+ }
433
+ ]
434
+ },
435
+ {
436
+ title: "External Contacts",
437
+ options: [
438
+ {
439
+ label: "Mike Davis",
440
+ value: "ext1"
441
+ },
442
+ {
443
+ label: "Sarah Taylor",
444
+ value: "ext2"
445
+ }
446
+ ]
447
+ }
448
+ ];
449
+ var filteredOptions = inputValue ? allOptions.map(function(group) {
450
+ return _object_spread_props(_object_spread({}, group), {
451
+ options: group.options.filter(function(option) {
452
+ return option.label.toLowerCase().includes(inputValue.toLowerCase());
453
+ })
454
+ });
455
+ }).filter(function(group) {
456
+ return group.options.length > 0;
457
+ }) : allOptions;
458
+ return /*#__PURE__*/ _jsx(Card, {
459
+ title: "Select Contact",
460
+ style: {
461
+ width: "400px"
462
+ },
463
+ padded: true,
464
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
465
+ gap: "2",
466
+ children: [
467
+ /*#__PURE__*/ _jsx(Autocomplete, {
468
+ options: filteredOptions,
469
+ selected: selected,
470
+ onSelect: setSelected,
471
+ textField: /*#__PURE__*/ _jsx(Autocomplete.TextField, {
472
+ placeholder: "Search contacts...",
473
+ value: inputValue,
474
+ onChange: setInputValue
475
+ })
476
+ }),
477
+ /*#__PURE__*/ _jsx(HorizontalStack, {
478
+ gap: "2",
479
+ children: selected.length > 0 && selected.map(function(item) {
480
+ return /*#__PURE__*/ _jsx(Tag, {
481
+ children: item
482
+ }, item);
483
+ })
484
+ })
485
+ ]
486
+ })
487
+ });
488
+ },
489
+ parameters: {
490
+ docs: {
491
+ description: {
492
+ story: "Autocomplete with grouped options and section titles."
493
+ },
494
+ source: {
495
+ transform: transformStorySource
496
+ }
497
+ }
498
+ }
499
+ };
500
+ export var EmptyState = {
501
+ render: function() {
502
+ var _useState = _sliced_to_array(useState([]), 2), selected = _useState[0], setSelected = _useState[1];
503
+ var _useState1 = _sliced_to_array(useState("xyz123"), 2), inputValue = _useState1[0], setInputValue = _useState1[1];
504
+ var options = [
505
+ {
506
+ label: "Apple",
507
+ value: "apple"
508
+ },
509
+ {
510
+ label: "Banana",
511
+ value: "banana"
512
+ },
513
+ {
514
+ label: "Cherry",
515
+ value: "cherry"
516
+ }
517
+ ];
518
+ var filteredOptions = inputValue ? options.filter(function(option) {
519
+ return option.label.toLowerCase().includes(inputValue.toLowerCase());
520
+ }) : options;
521
+ return /*#__PURE__*/ _jsxs(Card, {
522
+ title: "No Results Found",
523
+ style: {
524
+ width: "400px"
525
+ },
526
+ padded: true,
527
+ children: [
528
+ /*#__PURE__*/ _jsx(Text, {
529
+ style: {
530
+ marginBottom: "1rem",
531
+ fontSize: "0.9rem"
532
+ },
533
+ children: 'Try searching for "apple", "banana", or "cherry". The current search has no results.'
534
+ }),
535
+ /*#__PURE__*/ _jsx(Autocomplete, {
536
+ options: filteredOptions,
537
+ selected: selected,
538
+ onSelect: setSelected,
539
+ emptyState: {
540
+ icon: SearchMinor,
541
+ content: "No results found. Try a different search term."
542
+ },
543
+ textField: /*#__PURE__*/ _jsx(Autocomplete.TextField, {
544
+ placeholder: "Search fruits...",
545
+ value: inputValue,
546
+ onChange: setInputValue
547
+ })
548
+ }),
549
+ /*#__PURE__*/ _jsx("div", {
550
+ style: {
551
+ marginTop: "1rem"
552
+ },
553
+ children: /*#__PURE__*/ _jsx(Button, {
554
+ onClick: function() {
555
+ return setInputValue("");
556
+ },
557
+ size: "slim",
558
+ children: "Clear Search"
559
+ })
560
+ })
561
+ ]
562
+ });
563
+ },
564
+ parameters: {
565
+ docs: {
566
+ description: {
567
+ story: "Autocomplete with custom empty state when no results found."
568
+ },
569
+ source: {
570
+ transform: transformStorySource
571
+ }
572
+ }
573
+ }
574
+ };
575
+ export var ProductSearch = {
576
+ render: function() {
577
+ var _useState = _sliced_to_array(useState([]), 2), selected = _useState[0], setSelected = _useState[1];
578
+ var _useState1 = _sliced_to_array(useState(""), 2), inputValue = _useState1[0], setInputValue = _useState1[1];
579
+ var products = [
580
+ {
581
+ title: "Electronics",
582
+ options: [
583
+ {
584
+ label: "iPhone 15 Pro",
585
+ value: "iphone15"
586
+ },
587
+ {
588
+ label: "MacBook Air M2",
589
+ value: "macbook"
590
+ },
591
+ {
592
+ label: "AirPods Pro",
593
+ value: "airpods"
594
+ },
595
+ {
596
+ label: "iPad Pro",
597
+ value: "ipad"
598
+ }
599
+ ]
600
+ },
601
+ {
602
+ title: "Clothing",
603
+ options: [
604
+ {
605
+ label: "Cotton T-Shirt",
606
+ value: "tshirt"
607
+ },
608
+ {
609
+ label: "Denim Jeans",
610
+ value: "jeans"
611
+ },
612
+ {
613
+ label: "Running Shoes",
614
+ value: "shoes"
615
+ },
616
+ {
617
+ label: "Winter Jacket",
618
+ value: "jacket"
619
+ }
620
+ ]
621
+ },
622
+ {
623
+ title: "Home & Garden",
624
+ options: [
625
+ {
626
+ label: "Coffee Maker",
627
+ value: "coffee"
628
+ },
629
+ {
630
+ label: "Garden Hose",
631
+ value: "hose"
632
+ },
633
+ {
634
+ label: "Desk Lamp",
635
+ value: "lamp"
636
+ }
637
+ ]
638
+ }
639
+ ];
640
+ var filteredOptions = inputValue ? products.map(function(category) {
641
+ return _object_spread_props(_object_spread({}, category), {
642
+ options: category.options.filter(function(option) {
643
+ return option.label.toLowerCase().includes(inputValue.toLowerCase());
644
+ })
645
+ });
646
+ }).filter(function(category) {
647
+ return category.options.length > 0;
648
+ }) : products;
649
+ return /*#__PURE__*/ _jsxs(Card, {
650
+ title: "Product Catalog Search",
651
+ style: {
652
+ width: "500px"
653
+ },
654
+ padded: true,
655
+ children: [
656
+ /*#__PURE__*/ _jsx(Autocomplete, {
657
+ options: filteredOptions,
658
+ selected: selected,
659
+ allowMultiple: true,
660
+ onSelect: setSelected,
661
+ textField: /*#__PURE__*/ _jsx(Autocomplete.TextField, {
662
+ placeholder: "Search products...",
663
+ value: inputValue,
664
+ onChange: setInputValue
665
+ }),
666
+ emptyState: {
667
+ icon: ProductsMinor,
668
+ content: "No products found matching your search."
669
+ }
670
+ }),
671
+ selected.length > 0 && /*#__PURE__*/ _jsxs("div", {
672
+ style: {
673
+ marginTop: "1.5rem"
674
+ },
675
+ children: [
676
+ /*#__PURE__*/ _jsxs(Text, {
677
+ variant: "headingSm",
678
+ style: {
679
+ marginBottom: "0.5rem"
680
+ },
681
+ children: [
682
+ "Selected Products (",
683
+ selected.length,
684
+ ")"
685
+ ]
686
+ }),
687
+ /*#__PURE__*/ _jsx("div", {
688
+ style: {
689
+ display: "flex",
690
+ flexWrap: "wrap",
691
+ gap: "0.5rem"
692
+ },
693
+ children: selected.map(function(item) {
694
+ return /*#__PURE__*/ _jsx(Tag, {
695
+ children: item
696
+ }, item);
697
+ })
698
+ })
699
+ ]
700
+ })
701
+ ]
702
+ });
703
+ },
704
+ parameters: {
705
+ docs: {
706
+ description: {
707
+ story: "Product search autocomplete with categorized results."
708
+ },
709
+ source: {
710
+ transform: transformStorySource
711
+ }
712
+ }
713
+ }
714
+ };
715
+ export var CustomerSearch = {
716
+ render: function() {
717
+ var _useState = _sliced_to_array(useState([]), 2), selected = _useState[0], setSelected = _useState[1];
718
+ var _useState1 = _sliced_to_array(useState(""), 2), inputValue = _useState1[0], setInputValue = _useState1[1];
719
+ var customers = [
720
+ {
721
+ label: "John Smith (john@example.com)",
722
+ value: "customer1"
723
+ },
724
+ {
725
+ label: "Sarah Johnson (sarah@company.com)",
726
+ value: "customer2"
727
+ },
728
+ {
729
+ label: "Mike Wilson (mike@business.org)",
730
+ value: "customer3"
731
+ },
732
+ {
733
+ label: "Lisa Brown (lisa@startup.io)",
734
+ value: "customer4"
735
+ },
736
+ {
737
+ label: "David Miller (david@corp.net)",
738
+ value: "customer5"
739
+ },
740
+ {
741
+ label: "Emma Davis (emma@agency.com)",
742
+ value: "customer6"
743
+ }
744
+ ];
745
+ var filteredOptions = inputValue ? customers.filter(function(option) {
746
+ return option.label.toLowerCase().includes(inputValue.toLowerCase());
747
+ }) : customers;
748
+ return /*#__PURE__*/ _jsx(Card, {
749
+ title: "Customer Management",
750
+ style: {
751
+ width: "500px"
752
+ },
753
+ padded: true,
754
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
755
+ gap: "2",
756
+ children: [
757
+ /*#__PURE__*/ _jsx(Text, {
758
+ variant: "bodySm",
759
+ children: "Search by name or email address to find customers."
760
+ }),
761
+ /*#__PURE__*/ _jsx(Autocomplete, {
762
+ options: filteredOptions,
763
+ selected: selected,
764
+ allowMultiple: true,
765
+ onSelect: setSelected,
766
+ textField: /*#__PURE__*/ _jsx(Autocomplete.TextField, {
767
+ placeholder: "Search customers by name or email...",
768
+ value: inputValue,
769
+ onChange: setInputValue
770
+ }),
771
+ emptyState: {
772
+ icon: CustomersMinor,
773
+ content: "No customers found. Try searching by name or email."
774
+ }
775
+ }),
776
+ selected.length > 0 && /*#__PURE__*/ _jsxs("div", {
777
+ style: {
778
+ marginTop: "1.5rem"
779
+ },
780
+ children: [
781
+ /*#__PURE__*/ _jsxs(Text, {
782
+ variant: "headingSm",
783
+ style: {
784
+ marginBottom: "0.5rem"
785
+ },
786
+ children: [
787
+ "Selected Customers (",
788
+ selected.length,
789
+ ")"
790
+ ]
791
+ }),
792
+ /*#__PURE__*/ _jsx("div", {
793
+ style: {
794
+ display: "flex",
795
+ flexDirection: "column",
796
+ gap: "0.5rem"
797
+ },
798
+ children: selected.map(function(customerId) {
799
+ var customer = customers.find(function(c) {
800
+ return c.value === customerId;
801
+ });
802
+ return /*#__PURE__*/ _jsxs(HorizontalStack, {
803
+ gap: "2",
804
+ blockAlign: "center",
805
+ children: [
806
+ /*#__PURE__*/ _jsx(Thumbnail, {
807
+ size: "small"
808
+ }),
809
+ /*#__PURE__*/ _jsx(Text, {
810
+ variant: "bodySm",
811
+ children: customer === null || customer === void 0 ? void 0 : customer.label
812
+ })
813
+ ]
814
+ });
815
+ })
816
+ })
817
+ ]
818
+ })
819
+ ]
820
+ })
821
+ });
822
+ },
823
+ parameters: {
824
+ docs: {
825
+ description: {
826
+ story: "Customer search with email addresses and multiple selection."
827
+ },
828
+ source: {
829
+ transform: transformStorySource
830
+ }
831
+ }
832
+ }
833
+ };