@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,685 @@
1
+ function _array_like_to_array(arr, len) {
2
+ if (len == null || len > arr.length) len = arr.length;
3
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
4
+ return arr2;
5
+ }
6
+ function _array_with_holes(arr) {
7
+ if (Array.isArray(arr)) return arr;
8
+ }
9
+ function _define_property(obj, key, value) {
10
+ if (key in obj) {
11
+ Object.defineProperty(obj, key, {
12
+ value: value,
13
+ enumerable: true,
14
+ configurable: true,
15
+ writable: true
16
+ });
17
+ } else {
18
+ obj[key] = value;
19
+ }
20
+ return obj;
21
+ }
22
+ function _iterable_to_array_limit(arr, i) {
23
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
24
+ if (_i == null) return;
25
+ var _arr = [];
26
+ var _n = true;
27
+ var _d = false;
28
+ var _s, _e;
29
+ try {
30
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
31
+ _arr.push(_s.value);
32
+ if (i && _arr.length === i) break;
33
+ }
34
+ } catch (err) {
35
+ _d = true;
36
+ _e = err;
37
+ } finally{
38
+ try {
39
+ if (!_n && _i["return"] != null) _i["return"]();
40
+ } finally{
41
+ if (_d) throw _e;
42
+ }
43
+ }
44
+ return _arr;
45
+ }
46
+ function _non_iterable_rest() {
47
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
48
+ }
49
+ function _object_spread(target) {
50
+ for(var i = 1; i < arguments.length; i++){
51
+ var source = arguments[i] != null ? arguments[i] : {};
52
+ var ownKeys = Object.keys(source);
53
+ if (typeof Object.getOwnPropertySymbols === "function") {
54
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
55
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
56
+ }));
57
+ }
58
+ ownKeys.forEach(function(key) {
59
+ _define_property(target, key, source[key]);
60
+ });
61
+ }
62
+ return target;
63
+ }
64
+ function ownKeys(object, enumerableOnly) {
65
+ var keys = Object.keys(object);
66
+ if (Object.getOwnPropertySymbols) {
67
+ var symbols = Object.getOwnPropertySymbols(object);
68
+ if (enumerableOnly) {
69
+ symbols = symbols.filter(function(sym) {
70
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
71
+ });
72
+ }
73
+ keys.push.apply(keys, symbols);
74
+ }
75
+ return keys;
76
+ }
77
+ function _object_spread_props(target, source) {
78
+ source = source != null ? source : {};
79
+ if (Object.getOwnPropertyDescriptors) {
80
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
81
+ } else {
82
+ ownKeys(Object(source)).forEach(function(key) {
83
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
84
+ });
85
+ }
86
+ return target;
87
+ }
88
+ function _sliced_to_array(arr, i) {
89
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
90
+ }
91
+ function _unsupported_iterable_to_array(o, minLen) {
92
+ if (!o) return;
93
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
94
+ var n = Object.prototype.toString.call(o).slice(8, -1);
95
+ if (n === "Object" && o.constructor) n = o.constructor.name;
96
+ if (n === "Map" || n === "Set") return Array.from(n);
97
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
98
+ }
99
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
100
+ import { useState } from "react";
101
+ import { transformStorySource } from "../utilities/transformers.js";
102
+ import Tabs from "../components/Tabs.js";
103
+ import Text from "../components/Text.js";
104
+ import Card from "../components/Card.js";
105
+ import Button from "../components/Button.js";
106
+ import TextField from "../components/TextField.js";
107
+ import VerticalStack from "../components/VerticalStack.js";
108
+ import HorizontalStack from "../components/HorizontalStack.js";
109
+ import Box from "../components/Box.js";
110
+ export default {
111
+ title: 'Litho/Tabs',
112
+ component: Tabs,
113
+ parameters: {
114
+ layout: 'padded',
115
+ docs: {
116
+ description: {
117
+ component: "A Tabs component that allows users to switch between different views or sections of content. Tabs help organize related information in a compact interface."
118
+ },
119
+ source: {
120
+ transform: transformStorySource
121
+ }
122
+ }
123
+ },
124
+ args: {
125
+ tabs: [
126
+ {
127
+ id: 'tab1',
128
+ content: 'Tab 1',
129
+ panelID: 'panel1'
130
+ },
131
+ {
132
+ id: 'tab2',
133
+ content: 'Tab 2',
134
+ panelID: 'panel2'
135
+ },
136
+ {
137
+ id: 'tab3',
138
+ content: 'Tab 3',
139
+ panelID: 'panel3'
140
+ }
141
+ ],
142
+ selected: 0
143
+ },
144
+ tags: [
145
+ 'autodocs'
146
+ ],
147
+ argTypes: {
148
+ tabs: {
149
+ control: 'object',
150
+ description: 'Array of tab configuration objects with id, content, icon, and disclosure properties'
151
+ },
152
+ selected: {
153
+ control: 'number',
154
+ description: 'Index of the currently selected tab'
155
+ },
156
+ fullWidth: {
157
+ control: 'boolean',
158
+ description: 'Whether the tabs should expand to fit the container width'
159
+ },
160
+ disclosureText: {
161
+ control: 'text',
162
+ description: 'Label for the "More" disclosure tab'
163
+ },
164
+ disclosure: {
165
+ control: 'boolean',
166
+ description: 'Whether the "More" disclosure is enabled'
167
+ },
168
+ activeDisclosure: {
169
+ control: 'boolean',
170
+ description: 'Whether the "More" disclosure is currently active'
171
+ },
172
+ padded: {
173
+ control: 'boolean',
174
+ description: 'Whether to apply padding to the Tabs container'
175
+ },
176
+ borderBottom: {
177
+ control: 'boolean',
178
+ description: 'Whether to apply a bottom border to the Tabs container'
179
+ },
180
+ onSelect: {
181
+ action: 'tabSelected',
182
+ description: 'Callback fired when a tab is selected, receives the tab index'
183
+ }
184
+ }
185
+ };
186
+ export var Default = {
187
+ render: function(args) {
188
+ var _args_tabs_selected;
189
+ var _useState = _sliced_to_array(useState(args.selected || 0), 2), selected = _useState[0], setSelected = _useState[1];
190
+ return /*#__PURE__*/ _jsxs("div", {
191
+ children: [
192
+ /*#__PURE__*/ _jsx(Tabs, _object_spread_props(_object_spread({}, args), {
193
+ selected: selected,
194
+ onSelect: setSelected
195
+ })),
196
+ /*#__PURE__*/ _jsx(Box, {
197
+ paddingBlockStart: "4",
198
+ padding: "4",
199
+ background: "surface-neutral-subdued",
200
+ borderRadius: "1",
201
+ children: /*#__PURE__*/ _jsxs(Text, {
202
+ children: [
203
+ "Content for ",
204
+ (_args_tabs_selected = args.tabs[selected]) === null || _args_tabs_selected === void 0 ? void 0 : _args_tabs_selected.content
205
+ ]
206
+ })
207
+ })
208
+ ]
209
+ });
210
+ }
211
+ };
212
+ export var WithPanels = {
213
+ render: function() {
214
+ var _useState = _sliced_to_array(useState(0), 2), selected = _useState[0], setSelected = _useState[1];
215
+ var tabs = [
216
+ {
217
+ id: 'overview',
218
+ content: 'Overview',
219
+ panelID: 'overview-panel'
220
+ },
221
+ {
222
+ id: 'details',
223
+ content: 'Details',
224
+ panelID: 'details-panel'
225
+ },
226
+ {
227
+ id: 'settings',
228
+ content: 'Settings',
229
+ panelID: 'settings-panel'
230
+ }
231
+ ];
232
+ var panels = [
233
+ /*#__PURE__*/ _jsxs("div", {
234
+ children: [
235
+ /*#__PURE__*/ _jsx(Text, {
236
+ variant: "headingMd",
237
+ style: {
238
+ marginBottom: '1rem'
239
+ },
240
+ children: "Overview"
241
+ }),
242
+ /*#__PURE__*/ _jsx(Text, {
243
+ children: "This is the overview section with summary information about the current item."
244
+ })
245
+ ]
246
+ }, "overview"),
247
+ /*#__PURE__*/ _jsxs("div", {
248
+ children: [
249
+ /*#__PURE__*/ _jsx(Text, {
250
+ variant: "headingMd",
251
+ style: {
252
+ marginBottom: '1rem'
253
+ },
254
+ children: "Details"
255
+ }),
256
+ /*#__PURE__*/ _jsx(Text, {
257
+ children: "Detailed information and specifications can be found in this section."
258
+ })
259
+ ]
260
+ }, "details"),
261
+ /*#__PURE__*/ _jsxs("div", {
262
+ children: [
263
+ /*#__PURE__*/ _jsx(Text, {
264
+ variant: "headingMd",
265
+ style: {
266
+ marginBottom: '1rem'
267
+ },
268
+ children: "Settings"
269
+ }),
270
+ /*#__PURE__*/ _jsx(Text, {
271
+ children: "Configure options and preferences in this section."
272
+ })
273
+ ]
274
+ }, "settings")
275
+ ];
276
+ return /*#__PURE__*/ _jsxs("div", {
277
+ children: [
278
+ /*#__PURE__*/ _jsx(Tabs, {
279
+ tabs: tabs,
280
+ selected: selected,
281
+ onSelect: setSelected
282
+ }),
283
+ /*#__PURE__*/ _jsx("div", {
284
+ style: {
285
+ marginTop: '1rem',
286
+ padding: '1rem',
287
+ border: '1px solid #e1e1e1',
288
+ borderRadius: '4px'
289
+ },
290
+ children: panels[selected]
291
+ })
292
+ ]
293
+ });
294
+ },
295
+ parameters: {
296
+ docs: {
297
+ description: {
298
+ story: 'Tabs with corresponding content panels that change based on selection.'
299
+ }
300
+ }
301
+ }
302
+ };
303
+ export var ManyTabs = {
304
+ render: function() {
305
+ var _tabs_selected;
306
+ var _useState = _sliced_to_array(useState(0), 2), selected = _useState[0], setSelected = _useState[1];
307
+ var tabs = [
308
+ {
309
+ id: 'dashboard',
310
+ content: 'Dashboard',
311
+ panelID: 'dashboard-panel'
312
+ },
313
+ {
314
+ id: 'analytics',
315
+ content: 'Analytics',
316
+ panelID: 'analytics-panel'
317
+ },
318
+ {
319
+ id: 'customers',
320
+ content: 'Customers',
321
+ panelID: 'customers-panel'
322
+ },
323
+ {
324
+ id: 'products',
325
+ content: 'Products',
326
+ panelID: 'products-panel'
327
+ },
328
+ {
329
+ id: 'orders',
330
+ content: 'Orders',
331
+ panelID: 'orders-panel'
332
+ },
333
+ {
334
+ id: 'inventory',
335
+ content: 'Inventory',
336
+ panelID: 'inventory-panel'
337
+ },
338
+ {
339
+ id: 'reports',
340
+ content: 'Reports',
341
+ panelID: 'reports-panel'
342
+ },
343
+ {
344
+ id: 'settings',
345
+ content: 'Settings',
346
+ panelID: 'settings-panel'
347
+ }
348
+ ];
349
+ return /*#__PURE__*/ _jsxs("div", {
350
+ children: [
351
+ /*#__PURE__*/ _jsx(Tabs, {
352
+ tabs: tabs,
353
+ selected: selected,
354
+ onSelect: setSelected
355
+ }),
356
+ /*#__PURE__*/ _jsx("div", {
357
+ style: {
358
+ marginTop: '1rem',
359
+ padding: '1rem',
360
+ backgroundColor: '#f9f9f9',
361
+ borderRadius: '4px'
362
+ },
363
+ children: /*#__PURE__*/ _jsxs(Text, {
364
+ children: [
365
+ "Content for ",
366
+ (_tabs_selected = tabs[selected]) === null || _tabs_selected === void 0 ? void 0 : _tabs_selected.content
367
+ ]
368
+ })
369
+ })
370
+ ]
371
+ });
372
+ },
373
+ parameters: {
374
+ docs: {
375
+ description: {
376
+ story: 'Tabs handle overflow gracefully when there are many tabs.'
377
+ }
378
+ }
379
+ }
380
+ };
381
+ export var FormTabs = {
382
+ render: function() {
383
+ var _useState = _sliced_to_array(useState(0), 2), selected = _useState[0], setSelected = _useState[1];
384
+ var tabs = [
385
+ {
386
+ id: 'basic',
387
+ content: 'Basic Info',
388
+ panelID: 'basic-panel'
389
+ },
390
+ {
391
+ id: 'advanced',
392
+ content: 'Advanced',
393
+ panelID: 'advanced-panel'
394
+ },
395
+ {
396
+ id: 'permissions',
397
+ content: 'Permissions',
398
+ panelID: 'permissions-panel'
399
+ }
400
+ ];
401
+ var panels = [
402
+ /*#__PURE__*/ _jsxs("div", {
403
+ style: {
404
+ display: 'flex',
405
+ flexDirection: 'column',
406
+ gap: '1rem'
407
+ },
408
+ children: [
409
+ /*#__PURE__*/ _jsx(TextField, {
410
+ label: "Name",
411
+ placeholder: "Enter name"
412
+ }),
413
+ /*#__PURE__*/ _jsx(TextField, {
414
+ label: "Email",
415
+ placeholder: "Enter email"
416
+ }),
417
+ /*#__PURE__*/ _jsx(TextField, {
418
+ label: "Phone",
419
+ placeholder: "Enter phone number"
420
+ })
421
+ ]
422
+ }, "basic"),
423
+ /*#__PURE__*/ _jsxs("div", {
424
+ style: {
425
+ display: 'flex',
426
+ flexDirection: 'column',
427
+ gap: '1rem'
428
+ },
429
+ children: [
430
+ /*#__PURE__*/ _jsx(TextField, {
431
+ label: "Company",
432
+ placeholder: "Enter company name"
433
+ }),
434
+ /*#__PURE__*/ _jsx(TextField, {
435
+ label: "Job Title",
436
+ placeholder: "Enter job title"
437
+ }),
438
+ /*#__PURE__*/ _jsx(TextField, {
439
+ label: "Department",
440
+ placeholder: "Enter department"
441
+ })
442
+ ]
443
+ }, "advanced"),
444
+ /*#__PURE__*/ _jsxs("div", {
445
+ style: {
446
+ display: 'flex',
447
+ flexDirection: 'column',
448
+ gap: '1rem'
449
+ },
450
+ children: [
451
+ /*#__PURE__*/ _jsx(Text, {
452
+ children: "Permission settings would go here."
453
+ }),
454
+ /*#__PURE__*/ _jsxs("div", {
455
+ style: {
456
+ display: 'flex',
457
+ gap: '0.5rem'
458
+ },
459
+ children: [
460
+ /*#__PURE__*/ _jsx(Button, {
461
+ children: "Grant Access"
462
+ }),
463
+ /*#__PURE__*/ _jsx(Button, {
464
+ children: "Revoke Access"
465
+ })
466
+ ]
467
+ })
468
+ ]
469
+ }, "permissions")
470
+ ];
471
+ return /*#__PURE__*/ _jsxs(Card, {
472
+ title: "User Settings",
473
+ padded: true,
474
+ children: [
475
+ /*#__PURE__*/ _jsx(Tabs, {
476
+ tabs: tabs,
477
+ selected: selected,
478
+ onSelect: setSelected
479
+ }),
480
+ /*#__PURE__*/ _jsx("div", {
481
+ style: {
482
+ marginTop: '1.5rem'
483
+ },
484
+ children: panels[selected]
485
+ }),
486
+ /*#__PURE__*/ _jsx("div", {
487
+ style: {
488
+ marginTop: '2rem',
489
+ paddingTop: '1rem',
490
+ borderTop: '1px solid #e1e1e1'
491
+ },
492
+ children: /*#__PURE__*/ _jsxs("div", {
493
+ style: {
494
+ display: 'flex',
495
+ gap: '0.5rem'
496
+ },
497
+ children: [
498
+ /*#__PURE__*/ _jsx(Button, {
499
+ primary: true,
500
+ children: "Save Changes"
501
+ }),
502
+ /*#__PURE__*/ _jsx(Button, {
503
+ children: "Cancel"
504
+ })
505
+ ]
506
+ })
507
+ })
508
+ ]
509
+ });
510
+ },
511
+ parameters: {
512
+ docs: {
513
+ description: {
514
+ story: 'Tabs are commonly used in forms to organize different sections of information.'
515
+ }
516
+ }
517
+ }
518
+ };
519
+ export var WithIcons = {
520
+ render: function() {
521
+ var _tabs_selected;
522
+ var _useState = _sliced_to_array(useState(0), 2), selected = _useState[0], setSelected = _useState[1];
523
+ var tabs = [
524
+ {
525
+ id: 'home',
526
+ content: '🏠 Home',
527
+ panelID: 'home-panel'
528
+ },
529
+ {
530
+ id: 'search',
531
+ content: '🔍 Search',
532
+ panelID: 'search-panel'
533
+ },
534
+ {
535
+ id: 'notifications',
536
+ content: '🔔 Notifications',
537
+ panelID: 'notifications-panel'
538
+ },
539
+ {
540
+ id: 'profile',
541
+ content: '👤 Profile',
542
+ panelID: 'profile-panel'
543
+ }
544
+ ];
545
+ return /*#__PURE__*/ _jsxs("div", {
546
+ children: [
547
+ /*#__PURE__*/ _jsx(Tabs, {
548
+ tabs: tabs,
549
+ selected: selected,
550
+ onSelect: setSelected
551
+ }),
552
+ /*#__PURE__*/ _jsx("div", {
553
+ style: {
554
+ marginTop: '1rem',
555
+ padding: '1rem',
556
+ backgroundColor: '#f9f9f9',
557
+ borderRadius: '4px'
558
+ },
559
+ children: /*#__PURE__*/ _jsxs(Text, {
560
+ children: [
561
+ "Content for ",
562
+ (_tabs_selected = tabs[selected]) === null || _tabs_selected === void 0 ? void 0 : _tabs_selected.content
563
+ ]
564
+ })
565
+ })
566
+ ]
567
+ });
568
+ },
569
+ parameters: {
570
+ docs: {
571
+ description: {
572
+ story: 'Tab labels can include icons or emojis for better visual recognition.'
573
+ }
574
+ }
575
+ }
576
+ };
577
+ export var NavigationExample = {
578
+ render: function() {
579
+ var _useState = _sliced_to_array(useState(0), 2), selected = _useState[0], setSelected = _useState[1];
580
+ var _useState1 = _sliced_to_array(useState('recent'), 2), activeOrder = _useState1[0], setActiveOrder = _useState1[1];
581
+ var tabs = [
582
+ {
583
+ id: 'all',
584
+ content: 'All Orders',
585
+ panelID: 'all-panel'
586
+ },
587
+ {
588
+ id: 'pending',
589
+ content: 'Pending',
590
+ panelID: 'pending-panel'
591
+ },
592
+ {
593
+ id: 'shipped',
594
+ content: 'Shipped',
595
+ panelID: 'shipped-panel'
596
+ },
597
+ {
598
+ id: 'delivered',
599
+ content: 'Delivered',
600
+ panelID: 'delivered-panel'
601
+ }
602
+ ];
603
+ var orderData = {
604
+ all: [
605
+ 'Order #1001',
606
+ 'Order #1002',
607
+ 'Order #1003',
608
+ 'Order #1004',
609
+ 'Order #1005'
610
+ ],
611
+ pending: [
612
+ 'Order #1001',
613
+ 'Order #1003'
614
+ ],
615
+ shipped: [
616
+ 'Order #1002',
617
+ 'Order #1004'
618
+ ],
619
+ delivered: [
620
+ 'Order #1005'
621
+ ]
622
+ };
623
+ var tabKeys = [
624
+ 'all',
625
+ 'pending',
626
+ 'shipped',
627
+ 'delivered'
628
+ ];
629
+ var currentOrders = orderData[tabKeys[selected]] || [];
630
+ return /*#__PURE__*/ _jsxs(Card, {
631
+ title: "Order Management",
632
+ padded: true,
633
+ children: [
634
+ /*#__PURE__*/ _jsx(Tabs, {
635
+ tabs: tabs,
636
+ selected: selected,
637
+ onSelect: setSelected
638
+ }),
639
+ /*#__PURE__*/ _jsx("div", {
640
+ style: {
641
+ marginTop: '1.5rem'
642
+ },
643
+ children: currentOrders.length > 0 ? /*#__PURE__*/ _jsx("div", {
644
+ style: {
645
+ display: 'flex',
646
+ flexDirection: 'column',
647
+ gap: '0.5rem'
648
+ },
649
+ children: currentOrders.map(function(order, index) {
650
+ return /*#__PURE__*/ _jsxs("div", {
651
+ style: {
652
+ padding: '0.75rem',
653
+ border: '1px solid #e1e1e1',
654
+ borderRadius: '4px',
655
+ display: 'flex',
656
+ justifyContent: 'space-between',
657
+ alignItems: 'center'
658
+ },
659
+ children: [
660
+ /*#__PURE__*/ _jsx(Text, {
661
+ children: order
662
+ }),
663
+ /*#__PURE__*/ _jsx(Button, {
664
+ size: "small",
665
+ children: "View Details"
666
+ })
667
+ ]
668
+ }, index);
669
+ })
670
+ }) : /*#__PURE__*/ _jsx(Text, {
671
+ color: "subdued",
672
+ children: "No orders in this category."
673
+ })
674
+ })
675
+ ]
676
+ });
677
+ },
678
+ parameters: {
679
+ docs: {
680
+ description: {
681
+ story: 'Real-world example showing tabs used for filtering and organizing content.'
682
+ }
683
+ }
684
+ }
685
+ };