@heymantle/litho 0.0.3 → 0.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (353) hide show
  1. package/dist/cjs/components/ActionList.js +50 -16
  2. package/dist/cjs/components/AnnouncementBar.js +10 -3
  3. package/dist/cjs/components/AppProvider.js +10 -1
  4. package/dist/cjs/components/Autocomplete.js +33 -11
  5. package/dist/cjs/components/Badge.js +2 -1
  6. package/dist/cjs/components/Banner.js +35 -31
  7. package/dist/cjs/components/Box.js +5 -3
  8. package/dist/cjs/components/Button.js +34 -12
  9. package/dist/cjs/components/Card.js +5 -45
  10. package/dist/cjs/components/Checkbox.js +16 -6
  11. package/dist/cjs/components/ChoiceList.js +7 -4
  12. package/dist/cjs/components/ColorField.js +8 -3
  13. package/dist/cjs/components/DatePicker.js +13 -8
  14. package/dist/cjs/components/DropZone.js +33 -18
  15. package/dist/cjs/components/EmptyState.js +15 -7
  16. package/dist/cjs/components/Filters.js +32 -20
  17. package/dist/cjs/components/FooterHelp.js +7 -2
  18. package/dist/cjs/components/Form.js +18 -3
  19. package/dist/cjs/components/Frame.js +40 -15
  20. package/dist/cjs/components/FrameSaveBar.js +21 -12
  21. package/dist/cjs/components/Layout.js +3 -3
  22. package/dist/cjs/components/LayoutSection.js +2 -2
  23. package/dist/cjs/components/Link.js +6 -2
  24. package/dist/cjs/components/List.js +1 -0
  25. package/dist/cjs/components/Listbox.js +9 -4
  26. package/dist/cjs/components/Modal.js +26 -17
  27. package/dist/cjs/components/Navigation.js +30 -20
  28. package/dist/cjs/components/Page.js +8 -3
  29. package/dist/cjs/components/Pagination.js +11 -4
  30. package/dist/cjs/components/Pane.js +118 -35
  31. package/dist/cjs/components/Popover.js +59 -6
  32. package/dist/cjs/components/RangeSlider.js +11 -4
  33. package/dist/cjs/components/ResourceList.js +9 -3
  34. package/dist/cjs/components/Select.js +2 -0
  35. package/dist/cjs/components/Table.js +32 -19
  36. package/dist/cjs/components/Text.js +8 -5
  37. package/dist/cjs/components/TextField.js +23 -13
  38. package/dist/cjs/components/Thumbnail.js +7 -2
  39. package/dist/cjs/components/TimePicker.js +7 -2
  40. package/dist/cjs/components/Tip.js +10 -4
  41. package/dist/cjs/components/Tooltip.js +16 -8
  42. package/dist/cjs/components/TopBar.js +17 -9
  43. package/dist/cjs/dev/verify-publish.js +37 -4
  44. package/dist/cjs/postcss.config.js +21 -0
  45. package/dist/cjs/stories/ActionList.stories.js +365 -0
  46. package/dist/cjs/stories/AnnouncementBar.stories.js +244 -0
  47. package/dist/cjs/stories/Autocomplete.stories.js +871 -0
  48. package/dist/cjs/stories/Badge.stories.js +183 -0
  49. package/dist/cjs/stories/Banner.stories.js +201 -0
  50. package/dist/cjs/stories/Box.stories.js +599 -0
  51. package/dist/cjs/stories/Button.stories.js +325 -0
  52. package/dist/cjs/stories/ButtonGroup.stories.js +404 -0
  53. package/dist/cjs/stories/Card.stories.js +278 -0
  54. package/dist/cjs/stories/Checkbox.stories.js +266 -0
  55. package/dist/cjs/stories/ChoiceList.stories.js +884 -0
  56. package/dist/cjs/stories/Collapsible.stories.js +905 -0
  57. package/dist/cjs/stories/ColorField.stories.js +883 -0
  58. package/dist/cjs/stories/ContextualSaveBar.stories.js +970 -0
  59. package/dist/cjs/stories/DatePicker.stories.js +584 -0
  60. package/dist/cjs/stories/Divider.stories.js +759 -0
  61. package/dist/cjs/stories/DropZone.stories.js +1205 -0
  62. package/dist/cjs/stories/EmptyState.stories.js +296 -0
  63. package/dist/cjs/stories/Filters.stories.js +1353 -0
  64. package/dist/cjs/stories/FooterHelp.stories.js +869 -0
  65. package/dist/cjs/stories/Form.stories.js +940 -0
  66. package/dist/cjs/stories/Grid.stories.js +1199 -0
  67. package/dist/cjs/stories/HorizontalStack.stories.js +1064 -0
  68. package/dist/cjs/stories/Icon.stories.js +596 -0
  69. package/dist/cjs/stories/Image.stories.js +883 -0
  70. package/dist/cjs/stories/InlineError.stories.js +710 -0
  71. package/dist/cjs/stories/Label.stories.js +665 -0
  72. package/dist/cjs/stories/Layout.stories.js +685 -0
  73. package/dist/cjs/stories/LayoutSection.stories.js +1267 -0
  74. package/dist/cjs/stories/Link.stories.js +423 -0
  75. package/dist/cjs/stories/List.stories.js +1031 -0
  76. package/dist/cjs/stories/Listbox.stories.js +820 -0
  77. package/dist/cjs/stories/Loading.stories.js +900 -0
  78. package/dist/cjs/stories/Modal.stories.js +363 -0
  79. package/dist/cjs/stories/Navigation.stories.js +605 -0
  80. package/dist/cjs/stories/Page.stories.js +318 -0
  81. package/dist/cjs/stories/Pagination.stories.js +438 -0
  82. package/dist/cjs/stories/Pane.stories.js +1535 -0
  83. package/dist/cjs/stories/Popover.stories.js +637 -0
  84. package/dist/cjs/stories/PopoverManager.stories.js +1225 -0
  85. package/dist/cjs/stories/ProgressBar.stories.js +506 -0
  86. package/dist/cjs/stories/RadioButton.stories.js +642 -0
  87. package/dist/cjs/stories/RadioButtonCard.stories.js +816 -0
  88. package/dist/cjs/stories/RangeSlider.stories.js +892 -0
  89. package/dist/cjs/stories/ResourceList.stories.js +1067 -0
  90. package/dist/cjs/stories/Select.stories.js +413 -0
  91. package/dist/cjs/stories/SkeletonText.stories.js +776 -0
  92. package/dist/cjs/stories/Spinner.stories.js +396 -0
  93. package/dist/cjs/stories/Table.stories.js +628 -0
  94. package/dist/cjs/stories/Tabs.stories.js +723 -0
  95. package/dist/cjs/stories/Tag.stories.js +620 -0
  96. package/dist/cjs/stories/Text.stories.js +262 -0
  97. package/dist/cjs/stories/TextField.stories.js +377 -0
  98. package/dist/cjs/stories/Thumbnail.stories.js +859 -0
  99. package/dist/cjs/stories/TimePicker.stories.js +966 -0
  100. package/dist/cjs/stories/Tip.stories.js +753 -0
  101. package/dist/cjs/stories/Tooltip.stories.js +357 -0
  102. package/dist/cjs/stories/TopBar.stories.js +155 -0
  103. package/dist/cjs/stories/VerticalStack.stories.js +1287 -0
  104. package/dist/cjs/tailwind.config.js +17 -0
  105. package/dist/cjs/utilities/transformers.js +66 -0
  106. package/dist/cjs/vite.config.js +35 -0
  107. package/dist/esm/components/ActionList.js +41 -12
  108. package/dist/esm/components/AnnouncementBar.js +3 -1
  109. package/dist/esm/components/AppProvider.js +10 -1
  110. package/dist/esm/components/Autocomplete.js +21 -4
  111. package/dist/esm/components/Badge.js +2 -2
  112. package/dist/esm/components/Banner.js +20 -21
  113. package/dist/esm/components/Box.js +5 -4
  114. package/dist/esm/components/Button.js +24 -7
  115. package/dist/esm/components/Card.js +5 -4
  116. package/dist/esm/components/Checkbox.js +6 -1
  117. package/dist/esm/components/ChoiceList.js +7 -4
  118. package/dist/esm/components/ColorField.js +1 -1
  119. package/dist/esm/components/DatePicker.js +6 -1
  120. package/dist/esm/components/DropZone.js +14 -4
  121. package/dist/esm/components/EmptyState.js +4 -1
  122. package/dist/esm/components/Filters.js +10 -3
  123. package/dist/esm/components/FooterHelp.js +1 -1
  124. package/dist/esm/components/Form.js +18 -3
  125. package/dist/esm/components/Frame.js +18 -6
  126. package/dist/esm/components/FrameSaveBar.js +10 -6
  127. package/dist/esm/components/InlineError.js +1 -1
  128. package/dist/esm/components/Layout.js +4 -4
  129. package/dist/esm/components/LayoutSection.js +2 -2
  130. package/dist/esm/components/Link.js +6 -2
  131. package/dist/esm/components/List.js +1 -0
  132. package/dist/esm/components/Listbox.js +4 -4
  133. package/dist/esm/components/Modal.js +8 -4
  134. package/dist/esm/components/Navigation.js +16 -11
  135. package/dist/esm/components/Page.js +9 -4
  136. package/dist/esm/components/Pagination.js +3 -1
  137. package/dist/esm/components/Pane.js +114 -36
  138. package/dist/esm/components/Popover.js +18 -6
  139. package/dist/esm/components/RangeSlider.js +3 -1
  140. package/dist/esm/components/ResourceList.js +2 -1
  141. package/dist/esm/components/Select.js +2 -0
  142. package/dist/esm/components/Table.js +16 -3
  143. package/dist/esm/components/Text.js +8 -6
  144. package/dist/esm/components/TextField.js +6 -1
  145. package/dist/esm/components/Thumbnail.js +1 -1
  146. package/dist/esm/components/TimePicker.js +1 -1
  147. package/dist/esm/components/Tip.js +3 -2
  148. package/dist/esm/components/Tooltip.js +4 -1
  149. package/dist/esm/components/TopBar.js +7 -4
  150. package/dist/esm/dev/verify-publish.js +37 -4
  151. package/dist/esm/postcss.config.js +6 -0
  152. package/dist/esm/stories/ActionList.stories.js +327 -0
  153. package/dist/esm/stories/AnnouncementBar.stories.js +212 -0
  154. package/dist/esm/stories/Autocomplete.stories.js +833 -0
  155. package/dist/esm/stories/Badge.stories.js +138 -0
  156. package/dist/esm/stories/Banner.stories.js +159 -0
  157. package/dist/esm/stories/Box.stories.js +558 -0
  158. package/dist/esm/stories/Button.stories.js +277 -0
  159. package/dist/esm/stories/ButtonGroup.stories.js +357 -0
  160. package/dist/esm/stories/Card.stories.js +240 -0
  161. package/dist/esm/stories/Checkbox.stories.js +219 -0
  162. package/dist/esm/stories/ChoiceList.stories.js +834 -0
  163. package/dist/esm/stories/Collapsible.stories.js +867 -0
  164. package/dist/esm/stories/ColorField.stories.js +842 -0
  165. package/dist/esm/stories/ContextualSaveBar.stories.js +938 -0
  166. package/dist/esm/stories/DatePicker.stories.js +537 -0
  167. package/dist/esm/stories/Divider.stories.js +715 -0
  168. package/dist/esm/stories/DropZone.stories.js +1161 -0
  169. package/dist/esm/stories/EmptyState.stories.js +246 -0
  170. package/dist/esm/stories/Filters.stories.js +1315 -0
  171. package/dist/esm/stories/FooterHelp.stories.js +813 -0
  172. package/dist/esm/stories/Form.stories.js +905 -0
  173. package/dist/esm/stories/Grid.stories.js +1152 -0
  174. package/dist/esm/stories/HorizontalStack.stories.js +1011 -0
  175. package/dist/esm/stories/Icon.stories.js +555 -0
  176. package/dist/esm/stories/Image.stories.js +836 -0
  177. package/dist/esm/stories/InlineError.stories.js +666 -0
  178. package/dist/esm/stories/Label.stories.js +612 -0
  179. package/dist/esm/stories/Layout.stories.js +647 -0
  180. package/dist/esm/stories/LayoutSection.stories.js +1226 -0
  181. package/dist/esm/stories/Link.stories.js +379 -0
  182. package/dist/esm/stories/List.stories.js +975 -0
  183. package/dist/esm/stories/Listbox.stories.js +776 -0
  184. package/dist/esm/stories/Loading.stories.js +850 -0
  185. package/dist/esm/stories/Modal.stories.js +322 -0
  186. package/dist/esm/stories/Navigation.stories.js +567 -0
  187. package/dist/esm/stories/Page.stories.js +276 -0
  188. package/dist/esm/stories/Pagination.stories.js +394 -0
  189. package/dist/esm/stories/Pane.stories.js +1497 -0
  190. package/dist/esm/stories/Popover.stories.js +605 -0
  191. package/dist/esm/stories/PopoverManager.stories.js +1193 -0
  192. package/dist/esm/stories/ProgressBar.stories.js +465 -0
  193. package/dist/esm/stories/RadioButton.stories.js +598 -0
  194. package/dist/esm/stories/RadioButtonCard.stories.js +772 -0
  195. package/dist/esm/stories/RangeSlider.stories.js +845 -0
  196. package/dist/esm/stories/ResourceList.stories.js +1029 -0
  197. package/dist/esm/stories/Select.stories.js +363 -0
  198. package/dist/esm/stories/SkeletonText.stories.js +717 -0
  199. package/dist/esm/stories/Spinner.stories.js +355 -0
  200. package/dist/esm/stories/Table.stories.js +584 -0
  201. package/dist/esm/stories/Tabs.stories.js +685 -0
  202. package/dist/esm/stories/Tag.stories.js +573 -0
  203. package/dist/esm/stories/Text.stories.js +217 -0
  204. package/dist/esm/stories/TextField.stories.js +332 -0
  205. package/dist/esm/stories/Thumbnail.stories.js +806 -0
  206. package/dist/esm/stories/TimePicker.stories.js +910 -0
  207. package/dist/esm/stories/Tip.stories.js +706 -0
  208. package/dist/esm/stories/Tooltip.stories.js +313 -0
  209. package/dist/esm/stories/TopBar.stories.js +114 -0
  210. package/dist/esm/stories/VerticalStack.stories.js +1240 -0
  211. package/dist/esm/tailwind.config.js +7 -0
  212. package/dist/esm/utilities/transformers.js +47 -0
  213. package/dist/esm/vite.config.js +20 -0
  214. package/dist/types/components/ActionList.d.ts +122 -0
  215. package/dist/types/components/ActionList.d.ts.map +1 -0
  216. package/dist/types/components/AnnouncementBar.d.ts +21 -0
  217. package/dist/types/components/AnnouncementBar.d.ts.map +1 -0
  218. package/dist/types/components/AppProvider.d.ts +61 -0
  219. package/dist/types/components/AppProvider.d.ts.map +1 -0
  220. package/dist/types/components/Autocomplete.d.ts +130 -0
  221. package/dist/types/components/Autocomplete.d.ts.map +1 -0
  222. package/dist/types/components/Badge.d.ts +21 -0
  223. package/dist/types/components/Badge.d.ts.map +1 -0
  224. package/dist/types/components/Banner.d.ts +78 -0
  225. package/dist/types/components/Banner.d.ts.map +1 -0
  226. package/dist/types/components/Box.d.ts +70 -0
  227. package/dist/types/components/Box.d.ts.map +1 -0
  228. package/dist/types/components/Button.d.ts +123 -0
  229. package/dist/types/components/Button.d.ts.map +1 -0
  230. package/dist/types/components/ButtonGroup.d.ts +26 -0
  231. package/dist/types/components/ButtonGroup.d.ts.map +1 -0
  232. package/dist/types/components/Card.d.ts +139 -0
  233. package/dist/types/components/Card.d.ts.map +1 -0
  234. package/dist/types/components/Checkbox.d.ts +56 -0
  235. package/dist/types/components/Checkbox.d.ts.map +1 -0
  236. package/dist/types/components/ChoiceList.d.ts +69 -0
  237. package/dist/types/components/ChoiceList.d.ts.map +1 -0
  238. package/dist/types/components/Collapsible.d.ts +17 -0
  239. package/dist/types/components/Collapsible.d.ts.map +1 -0
  240. package/dist/types/components/ColorField.d.ts +36 -0
  241. package/dist/types/components/ColorField.d.ts.map +1 -0
  242. package/dist/types/components/ContextualSaveBar.d.ts +22 -0
  243. package/dist/types/components/ContextualSaveBar.d.ts.map +1 -0
  244. package/dist/types/components/DatePicker.d.ts +66 -0
  245. package/dist/types/components/DatePicker.d.ts.map +1 -0
  246. package/dist/types/components/Divider.d.ts +21 -0
  247. package/dist/types/components/Divider.d.ts.map +1 -0
  248. package/dist/types/components/DropZone.d.ts +108 -0
  249. package/dist/types/components/DropZone.d.ts.map +1 -0
  250. package/dist/types/components/EmptyState.d.ts +52 -0
  251. package/dist/types/components/EmptyState.d.ts.map +1 -0
  252. package/dist/types/components/Filters.d.ts +166 -0
  253. package/dist/types/components/Filters.d.ts.map +1 -0
  254. package/dist/types/components/FooterHelp.d.ts +21 -0
  255. package/dist/types/components/FooterHelp.d.ts.map +1 -0
  256. package/dist/types/components/Form.d.ts +39 -0
  257. package/dist/types/components/Form.d.ts.map +1 -0
  258. package/dist/types/components/Frame.d.ts +51 -0
  259. package/dist/types/components/Frame.d.ts.map +1 -0
  260. package/dist/types/components/FrameSaveBar.d.ts +8 -0
  261. package/dist/types/components/FrameSaveBar.d.ts.map +1 -0
  262. package/dist/types/components/Grid.d.ts +39 -0
  263. package/dist/types/components/Grid.d.ts.map +1 -0
  264. package/dist/types/components/HorizontalStack.d.ts +36 -0
  265. package/dist/types/components/HorizontalStack.d.ts.map +1 -0
  266. package/dist/types/components/Icon.d.ts +43 -0
  267. package/dist/types/components/Icon.d.ts.map +1 -0
  268. package/dist/types/components/Image.d.ts +45 -0
  269. package/dist/types/components/Image.d.ts.map +1 -0
  270. package/dist/types/components/InlineError.d.ts +22 -0
  271. package/dist/types/components/InlineError.d.ts.map +1 -0
  272. package/dist/types/components/Label.d.ts +28 -0
  273. package/dist/types/components/Label.d.ts.map +1 -0
  274. package/dist/types/components/Layout.d.ts +44 -0
  275. package/dist/types/components/Layout.d.ts.map +1 -0
  276. package/dist/types/components/LayoutSection.d.ts +24 -0
  277. package/dist/types/components/LayoutSection.d.ts.map +1 -0
  278. package/dist/types/components/Link.d.ts +38 -0
  279. package/dist/types/components/Link.d.ts.map +1 -0
  280. package/dist/types/components/List.d.ts +33 -0
  281. package/dist/types/components/List.d.ts.map +1 -0
  282. package/dist/types/components/Listbox.d.ts +34 -0
  283. package/dist/types/components/Listbox.d.ts.map +1 -0
  284. package/dist/types/components/Loading.d.ts +13 -0
  285. package/dist/types/components/Loading.d.ts.map +1 -0
  286. package/dist/types/components/Modal.d.ts +75 -0
  287. package/dist/types/components/Modal.d.ts.map +1 -0
  288. package/dist/types/components/Navigation.d.ts +105 -0
  289. package/dist/types/components/Navigation.d.ts.map +1 -0
  290. package/dist/types/components/Page.d.ts +59 -0
  291. package/dist/types/components/Page.d.ts.map +1 -0
  292. package/dist/types/components/Pagination.d.ts +39 -0
  293. package/dist/types/components/Pagination.d.ts.map +1 -0
  294. package/dist/types/components/Pane.d.ts +11 -0
  295. package/dist/types/components/Pane.d.ts.map +1 -0
  296. package/dist/types/components/Popover.d.ts +56 -0
  297. package/dist/types/components/Popover.d.ts.map +1 -0
  298. package/dist/types/components/PopoverManager.d.ts +3 -0
  299. package/dist/types/components/PopoverManager.d.ts.map +1 -0
  300. package/dist/types/components/ProgressBar.d.ts +24 -0
  301. package/dist/types/components/ProgressBar.d.ts.map +1 -0
  302. package/dist/types/components/RadioButton.d.ts +39 -0
  303. package/dist/types/components/RadioButton.d.ts.map +1 -0
  304. package/dist/types/components/RadioButtonCard.d.ts +41 -0
  305. package/dist/types/components/RadioButtonCard.d.ts.map +1 -0
  306. package/dist/types/components/RangeSlider.d.ts +44 -0
  307. package/dist/types/components/RangeSlider.d.ts.map +1 -0
  308. package/dist/types/components/ResourceList.d.ts +54 -0
  309. package/dist/types/components/ResourceList.d.ts.map +1 -0
  310. package/dist/types/components/Select.d.ts +48 -0
  311. package/dist/types/components/Select.d.ts.map +1 -0
  312. package/dist/types/components/SkeletonText.d.ts +28 -0
  313. package/dist/types/components/SkeletonText.d.ts.map +1 -0
  314. package/dist/types/components/Spinner.d.ts +18 -0
  315. package/dist/types/components/Spinner.d.ts.map +1 -0
  316. package/dist/types/components/Table.d.ts +197 -0
  317. package/dist/types/components/Table.d.ts.map +1 -0
  318. package/dist/types/components/Tabs.d.ts +41 -0
  319. package/dist/types/components/Tabs.d.ts.map +1 -0
  320. package/dist/types/components/Tag.d.ts +26 -0
  321. package/dist/types/components/Tag.d.ts.map +1 -0
  322. package/dist/types/components/Text.d.ts +32 -0
  323. package/dist/types/components/Text.d.ts.map +1 -0
  324. package/dist/types/components/TextField.d.ts +109 -0
  325. package/dist/types/components/TextField.d.ts.map +1 -0
  326. package/dist/types/components/Thumbnail.d.ts +18 -0
  327. package/dist/types/components/Thumbnail.d.ts.map +1 -0
  328. package/dist/types/components/TimePicker.d.ts +3 -0
  329. package/dist/types/components/TimePicker.d.ts.map +1 -0
  330. package/dist/types/components/Tip.d.ts +23 -0
  331. package/dist/types/components/Tip.d.ts.map +1 -0
  332. package/dist/types/components/Tooltip.d.ts +84 -0
  333. package/dist/types/components/Tooltip.d.ts.map +1 -0
  334. package/dist/types/components/TopBar.d.ts +43 -0
  335. package/dist/types/components/TopBar.d.ts.map +1 -0
  336. package/dist/types/components/VerticalStack.d.ts +27 -0
  337. package/dist/types/components/VerticalStack.d.ts.map +1 -0
  338. package/dist/types/index.d.ts +62 -0
  339. package/dist/types/index.d.ts.map +1 -0
  340. package/dist/types/styles/Table.d.ts +1570 -0
  341. package/dist/types/styles/Table.d.ts.map +1 -0
  342. package/dist/types/utilities/dates.d.ts +46 -0
  343. package/dist/types/utilities/dates.d.ts.map +1 -0
  344. package/dist/types/utilities/transformers.d.ts +4 -0
  345. package/dist/types/utilities/transformers.d.ts.map +1 -0
  346. package/dist/types/utilities/useIndexResourceState.d.ts +21 -0
  347. package/dist/types/utilities/useIndexResourceState.d.ts.map +1 -0
  348. package/dist/types/utilities/useMounted.d.ts +2 -0
  349. package/dist/types/utilities/useMounted.d.ts.map +1 -0
  350. package/dist/types/utilities/useTableScrollState.d.ts +29 -0
  351. package/dist/types/utilities/useTableScrollState.d.ts.map +1 -0
  352. package/index.css +6 -0
  353. package/package.json +37 -6
@@ -0,0 +1,584 @@
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 _iterable_to_array_limit(arr, i) {
10
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
11
+ if (_i == null) return;
12
+ var _arr = [];
13
+ var _n = true;
14
+ var _d = false;
15
+ var _s, _e;
16
+ try {
17
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
18
+ _arr.push(_s.value);
19
+ if (i && _arr.length === i) break;
20
+ }
21
+ } catch (err) {
22
+ _d = true;
23
+ _e = err;
24
+ } finally{
25
+ try {
26
+ if (!_n && _i["return"] != null) _i["return"]();
27
+ } finally{
28
+ if (_d) throw _e;
29
+ }
30
+ }
31
+ return _arr;
32
+ }
33
+ function _non_iterable_rest() {
34
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
35
+ }
36
+ function _sliced_to_array(arr, i) {
37
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
38
+ }
39
+ function _unsupported_iterable_to_array(o, minLen) {
40
+ if (!o) return;
41
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
42
+ var n = Object.prototype.toString.call(o).slice(8, -1);
43
+ if (n === "Object" && o.constructor) n = o.constructor.name;
44
+ if (n === "Map" || n === "Set") return Array.from(n);
45
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
46
+ }
47
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
48
+ import { useState } from "react";
49
+ import { transformStorySource } from "../utilities/transformers.js";
50
+ import Table from "../components/Table.js";
51
+ import Button from "../components/Button.js";
52
+ import Badge from "../components/Badge.js";
53
+ import Text from "../components/Text.js";
54
+ import Checkbox from "../components/Checkbox.js";
55
+ import { EditMinor, DeleteMinor, ViewMinor } from "@shopify/polaris-icons";
56
+ export default {
57
+ title: 'Litho/Table',
58
+ component: Table,
59
+ parameters: {
60
+ layout: 'fullscreen',
61
+ docs: {
62
+ description: {
63
+ component: "A Table component that displays structured data in rows and columns. Tables support sorting, selection, actions, and responsive behavior for complex data presentations."
64
+ },
65
+ source: {
66
+ transform: transformStorySource
67
+ }
68
+ }
69
+ },
70
+ tags: [
71
+ 'autodocs'
72
+ ],
73
+ argTypes: {
74
+ headings: {
75
+ control: 'object',
76
+ description: 'Array of column heading objects or strings'
77
+ },
78
+ headingStyle: {
79
+ control: 'select',
80
+ options: [
81
+ 'default',
82
+ 'subdued'
83
+ ],
84
+ description: 'Style of the heading'
85
+ },
86
+ rows: {
87
+ control: 'object',
88
+ description: 'Array of row data with cell content'
89
+ },
90
+ verticalAlign: {
91
+ control: 'select',
92
+ options: [
93
+ 'top',
94
+ 'middle',
95
+ 'bottom'
96
+ ],
97
+ description: 'Vertical alignment of table content'
98
+ },
99
+ fixedFirstColumns: {
100
+ control: 'number',
101
+ description: 'Number of fixed left columns'
102
+ },
103
+ fixedLastColumns: {
104
+ control: 'number',
105
+ description: 'Number of fixed right columns'
106
+ },
107
+ initialSortColumnIndex: {
108
+ control: 'number',
109
+ description: 'Initial column to sort by'
110
+ },
111
+ defaultSortDirection: {
112
+ control: 'select',
113
+ options: [
114
+ 'ascending',
115
+ 'descending'
116
+ ],
117
+ description: 'Default sort direction'
118
+ },
119
+ increasedTableDensity: {
120
+ control: 'boolean',
121
+ description: 'Whether to reduce padding for higher density'
122
+ },
123
+ footers: {
124
+ control: 'object',
125
+ description: 'Array of footer row content'
126
+ },
127
+ firstColumnMinWidth: {
128
+ control: 'number',
129
+ description: 'Minimum width of the first column'
130
+ },
131
+ bordered: {
132
+ control: 'boolean',
133
+ description: 'Whether to show table borders'
134
+ },
135
+ topBorder: {
136
+ control: 'boolean',
137
+ description: 'Whether to show a top border'
138
+ },
139
+ skeletonRows: {
140
+ control: 'number',
141
+ description: 'Number of skeleton rows to render when loading'
142
+ },
143
+ paginatedSelectAllActionText: {
144
+ control: 'text',
145
+ description: 'Text for the paginated select all action'
146
+ },
147
+ resourceName: {
148
+ control: 'object',
149
+ description: 'Object containing singular and plural resource names'
150
+ },
151
+ itemCount: {
152
+ control: 'number',
153
+ description: 'Total number of items in the table'
154
+ },
155
+ selectable: {
156
+ control: 'boolean',
157
+ description: 'Whether the table rows are selectable'
158
+ },
159
+ loading: {
160
+ control: 'boolean',
161
+ description: 'Whether the table is in loading state'
162
+ },
163
+ hasMoreItems: {
164
+ control: 'boolean',
165
+ description: 'Whether there are more items available for selection'
166
+ },
167
+ noBodyCellPadding: {
168
+ control: 'boolean',
169
+ description: 'Whether to remove padding from body cells'
170
+ },
171
+ bulkActions: {
172
+ control: 'object',
173
+ description: 'Array of bulk action items'
174
+ },
175
+ promotedBulkActions: {
176
+ control: 'object',
177
+ description: 'Array of promoted bulk action items'
178
+ },
179
+ emptyState: {
180
+ control: 'object',
181
+ description: 'Custom empty state component'
182
+ },
183
+ stickyHeader: {
184
+ control: 'boolean',
185
+ description: 'Whether the header should be sticky'
186
+ },
187
+ onSort: {
188
+ action: 'sorted',
189
+ description: 'Callback for sorting events'
190
+ },
191
+ onSelectionChange: {
192
+ action: 'selectionChanged',
193
+ description: 'Callback for selection changes'
194
+ }
195
+ }
196
+ };
197
+ var sampleData = [
198
+ [
199
+ 'John Doe',
200
+ 'john@example.com',
201
+ 'Active',
202
+ '$1,234.56',
203
+ 'Customer'
204
+ ],
205
+ [
206
+ 'Jane Smith',
207
+ 'jane@example.com',
208
+ 'Inactive',
209
+ '$2,567.89',
210
+ 'VIP'
211
+ ],
212
+ [
213
+ 'Bob Johnson',
214
+ 'bob@example.com',
215
+ 'Active',
216
+ '$987.65',
217
+ 'Customer'
218
+ ],
219
+ [
220
+ 'Alice Brown',
221
+ 'alice@example.com',
222
+ 'Pending',
223
+ '$3,456.78',
224
+ 'VIP'
225
+ ],
226
+ [
227
+ 'Charlie Wilson',
228
+ 'charlie@example.com',
229
+ 'Active',
230
+ '$876.54',
231
+ 'Customer'
232
+ ]
233
+ ];
234
+ export var Default = {
235
+ args: {
236
+ columnContentTypes: [
237
+ 'text',
238
+ 'text',
239
+ 'text',
240
+ 'numeric',
241
+ 'text'
242
+ ],
243
+ headings: [
244
+ 'Name',
245
+ 'Email',
246
+ 'Status',
247
+ 'Revenue',
248
+ 'Type'
249
+ ],
250
+ rows: sampleData
251
+ }
252
+ };
253
+ export var WithSelection = {
254
+ args: {
255
+ columnContentTypes: [
256
+ 'text',
257
+ 'text',
258
+ 'text',
259
+ 'numeric',
260
+ 'text'
261
+ ],
262
+ headings: [
263
+ 'Name',
264
+ 'Email',
265
+ 'Status',
266
+ 'Revenue',
267
+ 'Type'
268
+ ],
269
+ rows: sampleData,
270
+ selectable: true
271
+ },
272
+ parameters: {
273
+ docs: {
274
+ description: {
275
+ story: 'Tables can include checkboxes for row selection.'
276
+ }
277
+ }
278
+ }
279
+ };
280
+ export var ZebraStriping = {
281
+ args: {
282
+ columnContentTypes: [
283
+ 'text',
284
+ 'text',
285
+ 'text',
286
+ 'numeric',
287
+ 'text'
288
+ ],
289
+ headings: [
290
+ 'Name',
291
+ 'Email',
292
+ 'Status',
293
+ 'Revenue',
294
+ 'Type'
295
+ ],
296
+ rows: sampleData,
297
+ hasZebraStriping: true
298
+ },
299
+ parameters: {
300
+ docs: {
301
+ description: {
302
+ story: 'Zebra striping makes it easier to scan across rows.'
303
+ }
304
+ }
305
+ }
306
+ };
307
+ export var Sortable = {
308
+ args: {
309
+ columnContentTypes: [
310
+ 'text',
311
+ 'text',
312
+ 'text',
313
+ 'numeric',
314
+ 'text'
315
+ ],
316
+ headings: [
317
+ {
318
+ content: 'Name',
319
+ sortable: true
320
+ },
321
+ {
322
+ content: 'Email',
323
+ sortable: true
324
+ },
325
+ {
326
+ content: 'Status',
327
+ sortable: true
328
+ },
329
+ {
330
+ content: 'Revenue',
331
+ sortable: true
332
+ },
333
+ {
334
+ content: 'Type',
335
+ sortable: true
336
+ }
337
+ ],
338
+ rows: sampleData,
339
+ initialSortColumnIndex: 0,
340
+ defaultSortDirection: 'ascending'
341
+ },
342
+ parameters: {
343
+ docs: {
344
+ description: {
345
+ story: 'Columns can be made sortable by clicking on column headers.'
346
+ }
347
+ }
348
+ }
349
+ };
350
+ export var WithBadges = {
351
+ render: function() {
352
+ var rowsWithBadges = sampleData.map(function(row) {
353
+ return [
354
+ row[0],
355
+ row[1],
356
+ /*#__PURE__*/ _jsx(Badge, {
357
+ status: row[2] === 'Active' ? 'success' : row[2] === 'Inactive' ? 'critical' : 'warning',
358
+ children: row[2]
359
+ }, row[2]),
360
+ row[3],
361
+ /*#__PURE__*/ _jsx(Badge, {
362
+ status: row[4] === 'VIP' ? 'highlight' : 'default',
363
+ children: row[4]
364
+ }, row[4])
365
+ ];
366
+ });
367
+ return /*#__PURE__*/ _jsx(Table, {
368
+ columnContentTypes: [
369
+ 'text',
370
+ 'text',
371
+ 'text',
372
+ 'numeric',
373
+ 'text'
374
+ ],
375
+ headings: [
376
+ 'Name',
377
+ 'Email',
378
+ 'Status',
379
+ 'Revenue',
380
+ 'Type'
381
+ ],
382
+ rows: rowsWithBadges,
383
+ hasZebraStriping: true
384
+ });
385
+ },
386
+ parameters: {
387
+ docs: {
388
+ description: {
389
+ story: 'Table cells can contain rich content like badges and other components.'
390
+ }
391
+ }
392
+ }
393
+ };
394
+ export var WithActions = {
395
+ render: function() {
396
+ var rowsWithActions = sampleData.map(function(row, index) {
397
+ return [
398
+ row[0],
399
+ row[1],
400
+ /*#__PURE__*/ _jsx(Badge, {
401
+ status: row[2] === 'Active' ? 'success' : row[2] === 'Inactive' ? 'critical' : 'warning',
402
+ children: row[2]
403
+ }, row[2]),
404
+ row[3],
405
+ /*#__PURE__*/ _jsxs("div", {
406
+ style: {
407
+ display: 'flex',
408
+ gap: '0.25rem'
409
+ },
410
+ children: [
411
+ /*#__PURE__*/ _jsx(Button, {
412
+ plain: true,
413
+ icon: ViewMinor,
414
+ accessibilityLabel: "View"
415
+ }),
416
+ /*#__PURE__*/ _jsx(Button, {
417
+ plain: true,
418
+ icon: EditMinor,
419
+ accessibilityLabel: "Edit"
420
+ }),
421
+ /*#__PURE__*/ _jsx(Button, {
422
+ plain: true,
423
+ icon: DeleteMinor,
424
+ accessibilityLabel: "Delete"
425
+ })
426
+ ]
427
+ }, "actions-".concat(index))
428
+ ];
429
+ });
430
+ return /*#__PURE__*/ _jsx(Table, {
431
+ columnContentTypes: [
432
+ 'text',
433
+ 'text',
434
+ 'text',
435
+ 'numeric',
436
+ 'text'
437
+ ],
438
+ headings: [
439
+ 'Name',
440
+ 'Email',
441
+ 'Status',
442
+ 'Revenue',
443
+ 'Actions'
444
+ ],
445
+ rows: rowsWithActions,
446
+ hasZebraStriping: true
447
+ });
448
+ },
449
+ parameters: {
450
+ docs: {
451
+ description: {
452
+ story: 'Action buttons can be included in table cells for row-specific operations.'
453
+ }
454
+ }
455
+ }
456
+ };
457
+ export var Empty = {
458
+ args: {
459
+ columnContentTypes: [
460
+ 'text',
461
+ 'text',
462
+ 'text',
463
+ 'numeric',
464
+ 'text'
465
+ ],
466
+ headings: [
467
+ 'Name',
468
+ 'Email',
469
+ 'Status',
470
+ 'Revenue',
471
+ 'Type'
472
+ ],
473
+ rows: []
474
+ },
475
+ parameters: {
476
+ docs: {
477
+ description: {
478
+ story: 'Tables gracefully handle empty states when no data is available.'
479
+ }
480
+ }
481
+ }
482
+ };
483
+ export var Interactive = {
484
+ render: function() {
485
+ var _useState = _sliced_to_array(useState([]), 2), selectedRows = _useState[0], setSelectedRows = _useState[1];
486
+ var _useState1 = _sliced_to_array(useState(0), 2), sortedColumn = _useState1[0], setSortedColumn = _useState1[1];
487
+ var _useState2 = _sliced_to_array(useState('ascending'), 2), sortDirection = _useState2[0], setSortDirection = _useState2[1];
488
+ var handleSelectionChange = function(selection) {
489
+ setSelectedRows(selection);
490
+ };
491
+ var handleSort = function(columnIndex, direction) {
492
+ setSortedColumn(columnIndex);
493
+ setSortDirection(direction);
494
+ };
495
+ return /*#__PURE__*/ _jsxs("div", {
496
+ style: {
497
+ padding: '1rem'
498
+ },
499
+ children: [
500
+ selectedRows.length > 0 && /*#__PURE__*/ _jsxs("div", {
501
+ style: {
502
+ marginBottom: '1rem',
503
+ padding: '0.75rem',
504
+ backgroundColor: '#f0f8ff',
505
+ borderRadius: '4px',
506
+ border: '1px solid #b3d9ff'
507
+ },
508
+ children: [
509
+ /*#__PURE__*/ _jsxs(Text, {
510
+ children: [
511
+ selectedRows.length,
512
+ " row(s) selected"
513
+ ]
514
+ }),
515
+ /*#__PURE__*/ _jsxs("div", {
516
+ style: {
517
+ marginTop: '0.5rem'
518
+ },
519
+ children: [
520
+ /*#__PURE__*/ _jsx(Button, {
521
+ size: "small",
522
+ children: "Bulk Edit"
523
+ }),
524
+ /*#__PURE__*/ _jsx(Button, {
525
+ size: "small",
526
+ destructive: true,
527
+ style: {
528
+ marginLeft: '0.5rem'
529
+ },
530
+ children: "Delete Selected"
531
+ })
532
+ ]
533
+ })
534
+ ]
535
+ }),
536
+ /*#__PURE__*/ _jsx(Table, {
537
+ columnContentTypes: [
538
+ 'text',
539
+ 'text',
540
+ 'text',
541
+ 'numeric',
542
+ 'text'
543
+ ],
544
+ headings: [
545
+ {
546
+ content: 'Name',
547
+ sortable: true
548
+ },
549
+ {
550
+ content: 'Email',
551
+ sortable: true
552
+ },
553
+ {
554
+ content: 'Status',
555
+ sortable: true
556
+ },
557
+ {
558
+ content: 'Revenue',
559
+ sortable: true
560
+ },
561
+ {
562
+ content: 'Type',
563
+ sortable: true
564
+ }
565
+ ],
566
+ rows: sampleData,
567
+ selectable: true,
568
+ hasZebraStriping: true,
569
+ onSelectionChange: handleSelectionChange,
570
+ onSort: handleSort,
571
+ initialSortColumnIndex: sortedColumn,
572
+ defaultSortDirection: sortDirection
573
+ })
574
+ ]
575
+ });
576
+ },
577
+ parameters: {
578
+ docs: {
579
+ description: {
580
+ story: 'Interactive example showing selection and sorting with bulk actions.'
581
+ }
582
+ }
583
+ }
584
+ };