@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,1038 @@
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 _array_without_holes(arr) {
10
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
11
+ }
12
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
13
+ try {
14
+ var info = gen[key](arg);
15
+ var value = info.value;
16
+ } catch (error) {
17
+ reject(error);
18
+ return;
19
+ }
20
+ if (info.done) {
21
+ resolve(value);
22
+ } else {
23
+ Promise.resolve(value).then(_next, _throw);
24
+ }
25
+ }
26
+ function _async_to_generator(fn) {
27
+ return function() {
28
+ var self = this, args = arguments;
29
+ return new Promise(function(resolve, reject) {
30
+ var gen = fn.apply(self, args);
31
+ function _next(value) {
32
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
33
+ }
34
+ function _throw(err) {
35
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
36
+ }
37
+ _next(undefined);
38
+ });
39
+ };
40
+ }
41
+ function _iterable_to_array(iter) {
42
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
43
+ }
44
+ function _iterable_to_array_limit(arr, i) {
45
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
46
+ if (_i == null) return;
47
+ var _arr = [];
48
+ var _n = true;
49
+ var _d = false;
50
+ var _s, _e;
51
+ try {
52
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
53
+ _arr.push(_s.value);
54
+ if (i && _arr.length === i) break;
55
+ }
56
+ } catch (err) {
57
+ _d = true;
58
+ _e = err;
59
+ } finally{
60
+ try {
61
+ if (!_n && _i["return"] != null) _i["return"]();
62
+ } finally{
63
+ if (_d) throw _e;
64
+ }
65
+ }
66
+ return _arr;
67
+ }
68
+ function _non_iterable_rest() {
69
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
70
+ }
71
+ function _non_iterable_spread() {
72
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
73
+ }
74
+ function _sliced_to_array(arr, i) {
75
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
76
+ }
77
+ function _to_consumable_array(arr) {
78
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
79
+ }
80
+ function _unsupported_iterable_to_array(o, minLen) {
81
+ if (!o) return;
82
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
83
+ var n = Object.prototype.toString.call(o).slice(8, -1);
84
+ if (n === "Object" && o.constructor) n = o.constructor.name;
85
+ if (n === "Map" || n === "Set") return Array.from(n);
86
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
87
+ }
88
+ function _ts_generator(thisArg, body) {
89
+ var f, y, t, _ = {
90
+ label: 0,
91
+ sent: function() {
92
+ if (t[0] & 1) throw t[1];
93
+ return t[1];
94
+ },
95
+ trys: [],
96
+ ops: []
97
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
98
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
99
+ return this;
100
+ }), g;
101
+ function verb(n) {
102
+ return function(v) {
103
+ return step([
104
+ n,
105
+ v
106
+ ]);
107
+ };
108
+ }
109
+ function step(op) {
110
+ if (f) throw new TypeError("Generator is already executing.");
111
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
112
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
113
+ if (y = 0, t) op = [
114
+ op[0] & 2,
115
+ t.value
116
+ ];
117
+ switch(op[0]){
118
+ case 0:
119
+ case 1:
120
+ t = op;
121
+ break;
122
+ case 4:
123
+ _.label++;
124
+ return {
125
+ value: op[1],
126
+ done: false
127
+ };
128
+ case 5:
129
+ _.label++;
130
+ y = op[1];
131
+ op = [
132
+ 0
133
+ ];
134
+ continue;
135
+ case 7:
136
+ op = _.ops.pop();
137
+ _.trys.pop();
138
+ continue;
139
+ default:
140
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
141
+ _ = 0;
142
+ continue;
143
+ }
144
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
145
+ _.label = op[1];
146
+ break;
147
+ }
148
+ if (op[0] === 6 && _.label < t[1]) {
149
+ _.label = t[1];
150
+ t = op;
151
+ break;
152
+ }
153
+ if (t && _.label < t[2]) {
154
+ _.label = t[2];
155
+ _.ops.push(op);
156
+ break;
157
+ }
158
+ if (t[2]) _.ops.pop();
159
+ _.trys.pop();
160
+ continue;
161
+ }
162
+ op = body.call(thisArg, _);
163
+ } catch (e) {
164
+ op = [
165
+ 6,
166
+ e
167
+ ];
168
+ y = 0;
169
+ } finally{
170
+ f = t = 0;
171
+ }
172
+ if (op[0] & 5) throw op[1];
173
+ return {
174
+ value: op[0] ? op[1] : void 0,
175
+ done: true
176
+ };
177
+ }
178
+ }
179
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
180
+ import { useState } from "react";
181
+ import { transformStorySource } from "../utilities/transformers.js";
182
+ import Stack from "../components/Stack.js";
183
+ import ResourceList from "../components/ResourceList.js";
184
+ import Text from "../components/Text.js";
185
+ import Card from "../components/Card.js";
186
+ import Button from "../components/Button.js";
187
+ import Badge from "../components/Badge.js";
188
+ import Box from "../components/Box.js";
189
+ export default {
190
+ title: 'Litho/ResourceList',
191
+ component: ResourceList,
192
+ parameters: {
193
+ layout: 'padded',
194
+ docs: {
195
+ description: {
196
+ component: "A ResourceList component for displaying collections of items with loading states, empty states, and customizable rendering. It includes an Item subcomponent for consistent item styling and interaction handling."
197
+ },
198
+ source: {
199
+ transform: transformStorySource
200
+ }
201
+ }
202
+ },
203
+ tags: [
204
+ 'autodocs'
205
+ ],
206
+ argTypes: {
207
+ items: {
208
+ control: 'object',
209
+ description: 'Array of items to display in the list'
210
+ },
211
+ loading: {
212
+ control: 'boolean',
213
+ description: 'Whether the list is in a loading state'
214
+ },
215
+ emptyState: {
216
+ control: 'text',
217
+ description: 'Content to display when the list is empty'
218
+ },
219
+ renderItem: {
220
+ control: false,
221
+ description: 'Function to render each item in the list'
222
+ },
223
+ resourceName: {
224
+ control: 'object',
225
+ description: 'Object containing singular and plural resource names'
226
+ },
227
+ divider: {
228
+ control: 'boolean',
229
+ description: 'Whether to show dividers between items'
230
+ },
231
+ gap: {
232
+ control: 'select',
233
+ options: [
234
+ 'none',
235
+ 'small',
236
+ 'large'
237
+ ],
238
+ description: 'Gap size between items'
239
+ }
240
+ }
241
+ };
242
+ export var Default = {
243
+ render: function() {
244
+ var customers = [
245
+ {
246
+ id: 1,
247
+ name: 'John Smith',
248
+ email: 'john@example.com',
249
+ status: 'active'
250
+ },
251
+ {
252
+ id: 2,
253
+ name: 'Sarah Johnson',
254
+ email: 'sarah@example.com',
255
+ status: 'active'
256
+ },
257
+ {
258
+ id: 3,
259
+ name: 'Mike Wilson',
260
+ email: 'mike@example.com',
261
+ status: 'inactive'
262
+ },
263
+ {
264
+ id: 4,
265
+ name: 'Lisa Brown',
266
+ email: 'lisa@example.com',
267
+ status: 'active'
268
+ }
269
+ ];
270
+ var renderCustomer = function(customer, index) {
271
+ return /*#__PURE__*/ _jsx(ResourceList.Item, {
272
+ id: "customer-".concat(customer.id),
273
+ children: /*#__PURE__*/ _jsxs(Stack, {
274
+ horizontal: true,
275
+ align: "space-between",
276
+ blockAlign: "center",
277
+ children: [
278
+ /*#__PURE__*/ _jsxs(Stack, {
279
+ gap: "xs",
280
+ children: [
281
+ /*#__PURE__*/ _jsx(Text, {
282
+ variant: "headingSm",
283
+ children: customer.name
284
+ }),
285
+ /*#__PURE__*/ _jsx(Text, {
286
+ variant: "bodySm",
287
+ color: "subdued",
288
+ children: customer.email
289
+ })
290
+ ]
291
+ }),
292
+ /*#__PURE__*/ _jsx(Badge, {
293
+ tone: customer.status === 'active' ? 'success' : 'warning',
294
+ children: customer.status
295
+ })
296
+ ]
297
+ })
298
+ }, customer.id);
299
+ };
300
+ return /*#__PURE__*/ _jsx(Card, {
301
+ title: "Customer List",
302
+ padded: true,
303
+ children: /*#__PURE__*/ _jsx(ResourceList, {
304
+ items: customers,
305
+ renderItem: renderCustomer,
306
+ resourceName: {
307
+ singular: 'customer',
308
+ plural: 'customers'
309
+ }
310
+ })
311
+ });
312
+ },
313
+ parameters: {
314
+ docs: {
315
+ description: {
316
+ story: 'Basic resource list displaying customer information.'
317
+ }
318
+ }
319
+ }
320
+ };
321
+ export var WithSelection = {
322
+ render: function() {
323
+ var _useState = _sliced_to_array(useState(new Set()), 2), selectedItems = _useState[0], setSelectedItems = _useState[1];
324
+ var products = [
325
+ {
326
+ id: 1,
327
+ name: 'Wireless Headphones',
328
+ price: '$159.99',
329
+ stock: 45
330
+ },
331
+ {
332
+ id: 2,
333
+ name: 'Bluetooth Speaker',
334
+ price: '$89.99',
335
+ stock: 23
336
+ },
337
+ {
338
+ id: 3,
339
+ name: 'Phone Case',
340
+ price: '$24.99',
341
+ stock: 156
342
+ },
343
+ {
344
+ id: 4,
345
+ name: 'Screen Protector',
346
+ price: '$12.99',
347
+ stock: 89
348
+ },
349
+ {
350
+ id: 5,
351
+ name: 'Car Charger',
352
+ price: '$19.99',
353
+ stock: 67
354
+ }
355
+ ];
356
+ var handleItemClick = function(productId) {
357
+ var newSelected = new Set(selectedItems);
358
+ if (newSelected.has(productId)) {
359
+ newSelected.delete(productId);
360
+ } else {
361
+ newSelected.add(productId);
362
+ }
363
+ setSelectedItems(newSelected);
364
+ };
365
+ var renderProduct = function(product, index) {
366
+ return /*#__PURE__*/ _jsx(ResourceList.Item, {
367
+ id: "product-".concat(product.id),
368
+ selected: selectedItems.has(product.id),
369
+ onClick: function() {
370
+ return handleItemClick(product.id);
371
+ },
372
+ accessibilityLabel: "Select ".concat(product.name),
373
+ children: /*#__PURE__*/ _jsxs(Stack, {
374
+ horizontal: true,
375
+ align: "space-between",
376
+ blockAlign: "center",
377
+ children: [
378
+ /*#__PURE__*/ _jsxs(Stack, {
379
+ gap: "xs",
380
+ children: [
381
+ /*#__PURE__*/ _jsx(Text, {
382
+ variant: "headingSm",
383
+ children: product.name
384
+ }),
385
+ /*#__PURE__*/ _jsxs(Text, {
386
+ variant: "bodySm",
387
+ color: "subdued",
388
+ children: [
389
+ "Stock: ",
390
+ product.stock,
391
+ " units"
392
+ ]
393
+ })
394
+ ]
395
+ }),
396
+ /*#__PURE__*/ _jsx(Text, {
397
+ variant: "headingSm",
398
+ children: product.price
399
+ })
400
+ ]
401
+ })
402
+ }, product.id);
403
+ };
404
+ return /*#__PURE__*/ _jsxs(Card, {
405
+ title: "Product Inventory",
406
+ padded: true,
407
+ children: [
408
+ /*#__PURE__*/ _jsx(Box, {
409
+ paddingBlockEnd: "4",
410
+ children: /*#__PURE__*/ _jsxs(Text, {
411
+ variant: "bodySm",
412
+ color: "subdued",
413
+ children: [
414
+ "Click items to select them. ",
415
+ selectedItems.size,
416
+ " item",
417
+ selectedItems.size !== 1 ? 's' : '',
418
+ " selected."
419
+ ]
420
+ })
421
+ }),
422
+ /*#__PURE__*/ _jsx(ResourceList, {
423
+ items: products,
424
+ renderItem: renderProduct,
425
+ resourceName: {
426
+ singular: 'product',
427
+ plural: 'products'
428
+ }
429
+ }),
430
+ selectedItems.size > 0 && /*#__PURE__*/ _jsx(Box, {
431
+ paddingBlockStart: "4",
432
+ children: /*#__PURE__*/ _jsxs(Stack, {
433
+ horizontal: true,
434
+ gap: "md",
435
+ children: [
436
+ /*#__PURE__*/ _jsx(Button, {
437
+ size: "slim",
438
+ onClick: function() {
439
+ return alert("Bulk edit ".concat(selectedItems.size, " items"));
440
+ },
441
+ children: "Bulk Edit"
442
+ }),
443
+ /*#__PURE__*/ _jsx(Button, {
444
+ size: "slim",
445
+ destructive: true,
446
+ onClick: function() {
447
+ return setSelectedItems(new Set());
448
+ },
449
+ children: "Clear Selection"
450
+ })
451
+ ]
452
+ })
453
+ })
454
+ ]
455
+ });
456
+ },
457
+ parameters: {
458
+ docs: {
459
+ description: {
460
+ story: 'Resource list with selectable items and bulk actions.'
461
+ }
462
+ }
463
+ }
464
+ };
465
+ export var LoadingState = {
466
+ render: function() {
467
+ var _useState = _sliced_to_array(useState(true), 2), loading = _useState[0], setLoading = _useState[1];
468
+ var _useState1 = _sliced_to_array(useState([]), 2), items = _useState1[0], setItems = _useState1[1];
469
+ var simulateLoading = function() {
470
+ return _async_to_generator(function() {
471
+ return _ts_generator(this, function(_state) {
472
+ switch(_state.label){
473
+ case 0:
474
+ setLoading(true);
475
+ setItems([]);
476
+ // Simulate API call
477
+ return [
478
+ 4,
479
+ new Promise(function(resolve) {
480
+ return setTimeout(resolve, 2000);
481
+ })
482
+ ];
483
+ case 1:
484
+ _state.sent();
485
+ setItems([
486
+ {
487
+ id: 1,
488
+ title: 'First Item',
489
+ description: 'Description for first item'
490
+ },
491
+ {
492
+ id: 2,
493
+ title: 'Second Item',
494
+ description: 'Description for second item'
495
+ },
496
+ {
497
+ id: 3,
498
+ title: 'Third Item',
499
+ description: 'Description for third item'
500
+ }
501
+ ]);
502
+ setLoading(false);
503
+ return [
504
+ 2
505
+ ];
506
+ }
507
+ });
508
+ })();
509
+ };
510
+ var renderItem = function(item, index) {
511
+ return /*#__PURE__*/ _jsx(ResourceList.Item, {
512
+ id: "item-".concat(item.id),
513
+ children: /*#__PURE__*/ _jsxs(Stack, {
514
+ gap: "xs",
515
+ children: [
516
+ /*#__PURE__*/ _jsx(Text, {
517
+ variant: "headingSm",
518
+ children: item.title
519
+ }),
520
+ /*#__PURE__*/ _jsx(Text, {
521
+ variant: "bodySm",
522
+ color: "subdued",
523
+ children: item.description
524
+ })
525
+ ]
526
+ })
527
+ }, item.id);
528
+ };
529
+ return /*#__PURE__*/ _jsxs(Card, {
530
+ title: "Loading State Demo",
531
+ padded: true,
532
+ children: [
533
+ /*#__PURE__*/ _jsx(Box, {
534
+ paddingBlockEnd: "4",
535
+ children: /*#__PURE__*/ _jsx(Button, {
536
+ onClick: simulateLoading,
537
+ disabled: loading,
538
+ children: loading ? 'Loading...' : 'Reload Items'
539
+ })
540
+ }),
541
+ /*#__PURE__*/ _jsx(ResourceList, {
542
+ items: items,
543
+ loading: loading,
544
+ renderItem: renderItem,
545
+ resourceName: {
546
+ singular: 'item',
547
+ plural: 'items'
548
+ }
549
+ })
550
+ ]
551
+ });
552
+ },
553
+ parameters: {
554
+ docs: {
555
+ description: {
556
+ story: 'Resource list demonstrating loading state with spinner.'
557
+ }
558
+ }
559
+ }
560
+ };
561
+ export var EmptyState = {
562
+ render: function() {
563
+ var _useState = _sliced_to_array(useState([]), 2), items = _useState[0], setItems = _useState[1];
564
+ var _useState1 = _sliced_to_array(useState('default'), 2), emptyStateType = _useState1[0], setEmptyStateType = _useState1[1];
565
+ var addItem = function() {
566
+ var newItem = {
567
+ id: items.length + 1,
568
+ name: "Item ".concat(items.length + 1),
569
+ description: "Description for item ".concat(items.length + 1)
570
+ };
571
+ setItems(_to_consumable_array(items).concat([
572
+ newItem
573
+ ]));
574
+ };
575
+ var clearItems = function() {
576
+ setItems([]);
577
+ };
578
+ var renderItem = function(item, index) {
579
+ return /*#__PURE__*/ _jsx(ResourceList.Item, {
580
+ id: "item-".concat(item.id),
581
+ children: /*#__PURE__*/ _jsxs(Stack, {
582
+ horizontal: true,
583
+ align: "space-between",
584
+ blockAlign: "center",
585
+ children: [
586
+ /*#__PURE__*/ _jsxs(Stack, {
587
+ gap: "xs",
588
+ children: [
589
+ /*#__PURE__*/ _jsx(Text, {
590
+ variant: "headingSm",
591
+ children: item.name
592
+ }),
593
+ /*#__PURE__*/ _jsx(Text, {
594
+ variant: "bodySm",
595
+ color: "subdued",
596
+ children: item.description
597
+ })
598
+ ]
599
+ }),
600
+ /*#__PURE__*/ _jsx(Button, {
601
+ size: "slim",
602
+ onClick: function() {
603
+ return setItems(items.filter(function(i) {
604
+ return i.id !== item.id;
605
+ }));
606
+ },
607
+ children: "Remove"
608
+ })
609
+ ]
610
+ })
611
+ }, item.id);
612
+ };
613
+ var customEmptyState = /*#__PURE__*/ _jsx(Box, {
614
+ padding: "12",
615
+ paddingInline: "4",
616
+ children: /*#__PURE__*/ _jsxs(Stack, {
617
+ gap: "md",
618
+ align: "center",
619
+ children: [
620
+ /*#__PURE__*/ _jsx(Text, {
621
+ style: {
622
+ fontSize: '3rem'
623
+ },
624
+ children: "\uD83D\uDCDD"
625
+ }),
626
+ /*#__PURE__*/ _jsx(Text, {
627
+ variant: "headingMd",
628
+ alignment: "center",
629
+ children: "No items yet"
630
+ }),
631
+ /*#__PURE__*/ _jsx(Text, {
632
+ variant: "bodySm",
633
+ color: "subdued",
634
+ alignment: "center",
635
+ children: "Get started by adding your first item to the list."
636
+ }),
637
+ /*#__PURE__*/ _jsx(Button, {
638
+ primary: true,
639
+ onClick: addItem,
640
+ children: "Add First Item"
641
+ })
642
+ ]
643
+ })
644
+ });
645
+ return /*#__PURE__*/ _jsxs(Card, {
646
+ title: "Empty State Demo",
647
+ padded: true,
648
+ children: [
649
+ /*#__PURE__*/ _jsx(Box, {
650
+ paddingBlockEnd: "4",
651
+ children: /*#__PURE__*/ _jsxs(Stack, {
652
+ horizontal: true,
653
+ gap: "md",
654
+ blockAlign: "center",
655
+ children: [
656
+ /*#__PURE__*/ _jsx(Button, {
657
+ onClick: addItem,
658
+ disabled: items.length >= 5,
659
+ children: "Add Item"
660
+ }),
661
+ /*#__PURE__*/ _jsx(Button, {
662
+ onClick: clearItems,
663
+ disabled: items.length === 0,
664
+ children: "Clear All"
665
+ }),
666
+ /*#__PURE__*/ _jsx(Box, {
667
+ style: {
668
+ marginLeft: 'auto'
669
+ },
670
+ children: /*#__PURE__*/ _jsxs(Stack, {
671
+ horizontal: true,
672
+ gap: "sm",
673
+ blockAlign: "center",
674
+ children: [
675
+ /*#__PURE__*/ _jsx(Text, {
676
+ variant: "bodySm",
677
+ children: "Empty state:"
678
+ }),
679
+ /*#__PURE__*/ _jsxs("select", {
680
+ value: emptyStateType,
681
+ onChange: function(e) {
682
+ return setEmptyStateType(e.target.value);
683
+ },
684
+ style: {
685
+ padding: '0.25rem',
686
+ borderRadius: '4px',
687
+ border: '1px solid #ccc'
688
+ },
689
+ children: [
690
+ /*#__PURE__*/ _jsx("option", {
691
+ value: "default",
692
+ children: "Default"
693
+ }),
694
+ /*#__PURE__*/ _jsx("option", {
695
+ value: "custom",
696
+ children: "Custom"
697
+ })
698
+ ]
699
+ })
700
+ ]
701
+ })
702
+ })
703
+ ]
704
+ })
705
+ }),
706
+ /*#__PURE__*/ _jsx(ResourceList, {
707
+ items: items,
708
+ renderItem: renderItem,
709
+ resourceName: {
710
+ singular: 'item',
711
+ plural: 'items'
712
+ },
713
+ emptyState: emptyStateType === 'custom' ? customEmptyState : 'No items found.'
714
+ })
715
+ ]
716
+ });
717
+ },
718
+ parameters: {
719
+ docs: {
720
+ description: {
721
+ story: 'Resource list with default and custom empty states.'
722
+ }
723
+ }
724
+ }
725
+ };
726
+ export var WithoutDividers = {
727
+ render: function() {
728
+ var notifications = [
729
+ {
730
+ id: 1,
731
+ title: 'New order received',
732
+ time: '2 minutes ago',
733
+ read: false
734
+ },
735
+ {
736
+ id: 2,
737
+ title: 'Payment processed',
738
+ time: '15 minutes ago',
739
+ read: false
740
+ },
741
+ {
742
+ id: 3,
743
+ title: 'Shipment delivered',
744
+ time: '1 hour ago',
745
+ read: true
746
+ },
747
+ {
748
+ id: 4,
749
+ title: 'Customer feedback',
750
+ time: '3 hours ago',
751
+ read: true
752
+ },
753
+ {
754
+ id: 5,
755
+ title: 'Weekly report ready',
756
+ time: '1 day ago',
757
+ read: true
758
+ }
759
+ ];
760
+ var renderNotification = function(notification, index) {
761
+ return /*#__PURE__*/ _jsx(ResourceList.Item, {
762
+ id: "notification-".concat(notification.id),
763
+ children: /*#__PURE__*/ _jsxs(Stack, {
764
+ horizontal: true,
765
+ gap: "md",
766
+ blockAlign: "center",
767
+ children: [
768
+ /*#__PURE__*/ _jsx(Box, {
769
+ borderRadius: "50%",
770
+ style: {
771
+ width: '8px',
772
+ height: '8px',
773
+ backgroundColor: notification.read ? 'transparent' : '#007bff',
774
+ flexShrink: 0
775
+ }
776
+ }),
777
+ /*#__PURE__*/ _jsx(Box, {
778
+ style: {
779
+ flex: 1
780
+ },
781
+ children: /*#__PURE__*/ _jsxs(Stack, {
782
+ gap: "xs",
783
+ children: [
784
+ /*#__PURE__*/ _jsx(Text, {
785
+ variant: "headingSm",
786
+ style: {
787
+ fontWeight: notification.read ? 'normal' : 'bold'
788
+ },
789
+ children: notification.title
790
+ }),
791
+ /*#__PURE__*/ _jsx(Text, {
792
+ variant: "bodySm",
793
+ color: "subdued",
794
+ children: notification.time
795
+ })
796
+ ]
797
+ })
798
+ }),
799
+ !notification.read && /*#__PURE__*/ _jsx(Badge, {
800
+ tone: "info",
801
+ children: "New"
802
+ })
803
+ ]
804
+ })
805
+ }, notification.id);
806
+ };
807
+ return /*#__PURE__*/ _jsx(Card, {
808
+ title: "Notifications",
809
+ padded: true,
810
+ children: /*#__PURE__*/ _jsx(ResourceList, {
811
+ items: notifications,
812
+ renderItem: renderNotification,
813
+ resourceName: {
814
+ singular: 'notification',
815
+ plural: 'notifications'
816
+ },
817
+ divider: false,
818
+ gap: "small"
819
+ })
820
+ });
821
+ },
822
+ parameters: {
823
+ docs: {
824
+ description: {
825
+ story: 'Resource list without dividers, using gap spacing instead.'
826
+ }
827
+ }
828
+ }
829
+ };
830
+ export var ComplexItems = {
831
+ render: function() {
832
+ var _useState = _sliced_to_array(useState(null), 2), selectedOrder = _useState[0], setSelectedOrder = _useState[1];
833
+ var orders = [
834
+ {
835
+ id: 'ORD-001',
836
+ customer: 'John Smith',
837
+ items: 3,
838
+ total: '$234.50',
839
+ status: 'shipped',
840
+ date: '2024-01-15',
841
+ address: '123 Main St, Anytown, ST 12345'
842
+ },
843
+ {
844
+ id: 'ORD-002',
845
+ customer: 'Sarah Johnson',
846
+ items: 1,
847
+ total: '$89.99',
848
+ status: 'processing',
849
+ date: '2024-01-16',
850
+ address: '456 Oak Ave, Another City, ST 67890'
851
+ },
852
+ {
853
+ id: 'ORD-003',
854
+ customer: 'Mike Wilson',
855
+ items: 5,
856
+ total: '$567.25',
857
+ status: 'delivered',
858
+ date: '2024-01-12',
859
+ address: '789 Pine Rd, Somewhere, ST 13579'
860
+ },
861
+ {
862
+ id: 'ORD-004',
863
+ customer: 'Lisa Brown',
864
+ items: 2,
865
+ total: '$145.75',
866
+ status: 'pending',
867
+ date: '2024-01-17',
868
+ address: '321 Elm St, Elsewhere, ST 24680'
869
+ }
870
+ ];
871
+ var getStatusColor = function(status) {
872
+ switch(status){
873
+ case 'delivered':
874
+ return 'success';
875
+ case 'shipped':
876
+ return 'info';
877
+ case 'processing':
878
+ return 'warning';
879
+ case 'pending':
880
+ return 'critical';
881
+ default:
882
+ return 'default';
883
+ }
884
+ };
885
+ var renderOrder = function(order, index) {
886
+ return /*#__PURE__*/ _jsx(ResourceList.Item, {
887
+ id: "order-".concat(order.id),
888
+ selected: selectedOrder === order.id,
889
+ onClick: function() {
890
+ return setSelectedOrder(order.id === selectedOrder ? null : order.id);
891
+ },
892
+ accessibilityLabel: "View details for order ".concat(order.id),
893
+ children: /*#__PURE__*/ _jsxs(Stack, {
894
+ gap: "sm",
895
+ children: [
896
+ /*#__PURE__*/ _jsxs(Stack, {
897
+ horizontal: true,
898
+ align: "space-between",
899
+ blockAlign: "start",
900
+ children: [
901
+ /*#__PURE__*/ _jsxs(Stack, {
902
+ gap: "xs",
903
+ children: [
904
+ /*#__PURE__*/ _jsx(Text, {
905
+ variant: "headingSm",
906
+ children: order.id
907
+ }),
908
+ /*#__PURE__*/ _jsx(Text, {
909
+ variant: "bodySm",
910
+ children: order.customer
911
+ })
912
+ ]
913
+ }),
914
+ /*#__PURE__*/ _jsxs(Stack, {
915
+ gap: "xs",
916
+ align: "end",
917
+ children: [
918
+ /*#__PURE__*/ _jsx(Text, {
919
+ variant: "headingSm",
920
+ children: order.total
921
+ }),
922
+ /*#__PURE__*/ _jsx(Badge, {
923
+ tone: getStatusColor(order.status),
924
+ children: order.status
925
+ })
926
+ ]
927
+ })
928
+ ]
929
+ }),
930
+ /*#__PURE__*/ _jsxs(Stack, {
931
+ horizontal: true,
932
+ align: "space-between",
933
+ blockAlign: "center",
934
+ children: [
935
+ /*#__PURE__*/ _jsxs(Text, {
936
+ variant: "bodySm",
937
+ color: "subdued",
938
+ children: [
939
+ order.items,
940
+ " item",
941
+ order.items !== 1 ? 's' : '',
942
+ " • ",
943
+ order.date
944
+ ]
945
+ }),
946
+ /*#__PURE__*/ _jsxs(Text, {
947
+ variant: "bodyXs",
948
+ color: "subdued",
949
+ children: [
950
+ "Click to ",
951
+ selectedOrder === order.id ? 'hide' : 'show',
952
+ " details"
953
+ ]
954
+ })
955
+ ]
956
+ }),
957
+ selectedOrder === order.id && /*#__PURE__*/ _jsxs(Box, {
958
+ paddingBlockStart: "4",
959
+ padding: "4",
960
+ background: "subdued",
961
+ borderRadius: "default",
962
+ style: {
963
+ borderLeft: '3px solid #007bff'
964
+ },
965
+ children: [
966
+ /*#__PURE__*/ _jsxs(Stack, {
967
+ gap: "sm",
968
+ children: [
969
+ /*#__PURE__*/ _jsx(Text, {
970
+ variant: "headingXs",
971
+ children: "Shipping Address"
972
+ }),
973
+ /*#__PURE__*/ _jsx(Text, {
974
+ variant: "bodySm",
975
+ color: "subdued",
976
+ children: order.address
977
+ })
978
+ ]
979
+ }),
980
+ /*#__PURE__*/ _jsx(Box, {
981
+ paddingBlockStart: "4",
982
+ children: /*#__PURE__*/ _jsxs(Stack, {
983
+ horizontal: true,
984
+ gap: "sm",
985
+ children: [
986
+ /*#__PURE__*/ _jsx(Button, {
987
+ size: "slim",
988
+ children: "View Details"
989
+ }),
990
+ /*#__PURE__*/ _jsx(Button, {
991
+ size: "slim",
992
+ children: "Track Package"
993
+ }),
994
+ /*#__PURE__*/ _jsx(Button, {
995
+ size: "slim",
996
+ children: "Contact Customer"
997
+ })
998
+ ]
999
+ })
1000
+ })
1001
+ ]
1002
+ })
1003
+ ]
1004
+ })
1005
+ }, order.id);
1006
+ };
1007
+ return /*#__PURE__*/ _jsxs(Card, {
1008
+ title: "Order Management",
1009
+ padded: true,
1010
+ children: [
1011
+ /*#__PURE__*/ _jsx(Box, {
1012
+ paddingBlockEnd: "4",
1013
+ children: /*#__PURE__*/ _jsx(Text, {
1014
+ variant: "bodySm",
1015
+ color: "subdued",
1016
+ children: "Click on any order to view additional details and actions."
1017
+ })
1018
+ }),
1019
+ /*#__PURE__*/ _jsx(ResourceList, {
1020
+ items: orders,
1021
+ renderItem: renderOrder,
1022
+ resourceName: {
1023
+ singular: 'order',
1024
+ plural: 'orders'
1025
+ },
1026
+ gap: "small"
1027
+ })
1028
+ ]
1029
+ });
1030
+ },
1031
+ parameters: {
1032
+ docs: {
1033
+ description: {
1034
+ story: 'Resource list with complex, interactive items that expand to show details.'
1035
+ }
1036
+ }
1037
+ }
1038
+ };