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