@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,850 @@
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, Fragment as _Fragment } from "react/jsx-runtime";
100
+ import { transformStorySource } from "../utilities/transformers.js";
101
+ import Loading from "../components/Loading.js";
102
+ import Text from "../components/Text.js";
103
+ import Card from "../components/Card.js";
104
+ import Button from "../components/Button.js";
105
+ import VerticalStack from "../components/VerticalStack.js";
106
+ import HorizontalStack from "../components/HorizontalStack.js";
107
+ import Box from "../components/Box.js";
108
+ import { useState } from "react";
109
+ export default {
110
+ title: 'Litho/Loading',
111
+ component: Loading,
112
+ parameters: {
113
+ layout: 'padded',
114
+ docs: {
115
+ description: {
116
+ component: "A Loading component that displays loading states and spinner animations. Loading components help indicate when content is being fetched or processed, improving user experience during wait times."
117
+ },
118
+ source: {
119
+ transform: transformStorySource
120
+ }
121
+ }
122
+ },
123
+ tags: [
124
+ 'autodocs'
125
+ ],
126
+ argTypes: {
127
+ maxDuration: {
128
+ control: 'number',
129
+ description: 'Maximum duration in milliseconds for the loading progress bar to reach 100%'
130
+ }
131
+ }
132
+ };
133
+ export var Default = {
134
+ render: function(args) {
135
+ return /*#__PURE__*/ _jsx(Loading, _object_spread({}, args));
136
+ }
137
+ };
138
+ export var Sizes = {
139
+ render: function() {
140
+ return /*#__PURE__*/ _jsxs(HorizontalStack, {
141
+ gap: "2",
142
+ blockAlign: "center",
143
+ children: [
144
+ /*#__PURE__*/ _jsxs(VerticalStack, {
145
+ gap: "2",
146
+ inlineAlign: "center",
147
+ children: [
148
+ /*#__PURE__*/ _jsx(Loading, {
149
+ size: "small"
150
+ }),
151
+ /*#__PURE__*/ _jsx(Text, {
152
+ children: "Small"
153
+ })
154
+ ]
155
+ }),
156
+ /*#__PURE__*/ _jsxs(VerticalStack, {
157
+ gap: "2",
158
+ inlineAlign: "center",
159
+ children: [
160
+ /*#__PURE__*/ _jsx(Loading, {
161
+ size: "medium"
162
+ }),
163
+ /*#__PURE__*/ _jsx(Text, {
164
+ children: "Medium"
165
+ })
166
+ ]
167
+ }),
168
+ /*#__PURE__*/ _jsxs(VerticalStack, {
169
+ gap: "2",
170
+ inlineAlign: "center",
171
+ children: [
172
+ /*#__PURE__*/ _jsx(Loading, {
173
+ size: "large"
174
+ }),
175
+ /*#__PURE__*/ _jsx(Text, {
176
+ children: "Large"
177
+ })
178
+ ]
179
+ })
180
+ ]
181
+ });
182
+ },
183
+ parameters: {
184
+ docs: {
185
+ description: {
186
+ story: 'Different sizes of loading spinners.'
187
+ }
188
+ }
189
+ }
190
+ };
191
+ export var Colors = {
192
+ render: function() {
193
+ return /*#__PURE__*/ _jsxs(HorizontalStack, {
194
+ gap: "12",
195
+ children: [
196
+ /*#__PURE__*/ _jsxs(VerticalStack, {
197
+ gap: "4",
198
+ inlineAlign: "center",
199
+ children: [
200
+ /*#__PURE__*/ _jsx(Loading, {
201
+ color: "default"
202
+ }),
203
+ /*#__PURE__*/ _jsx(Text, {
204
+ children: "Default"
205
+ })
206
+ ]
207
+ }),
208
+ /*#__PURE__*/ _jsxs(VerticalStack, {
209
+ gap: "4",
210
+ inlineAlign: "center",
211
+ children: [
212
+ /*#__PURE__*/ _jsx(Loading, {
213
+ color: "subdued"
214
+ }),
215
+ /*#__PURE__*/ _jsx(Text, {
216
+ children: "Subdued"
217
+ })
218
+ ]
219
+ }),
220
+ /*#__PURE__*/ _jsxs(VerticalStack, {
221
+ gap: "4",
222
+ inlineAlign: "center",
223
+ as: Box,
224
+ padding: "8",
225
+ background: "bg-surface-dark",
226
+ borderRadius: "2",
227
+ children: [
228
+ /*#__PURE__*/ _jsx(Loading, {
229
+ color: "white"
230
+ }),
231
+ /*#__PURE__*/ _jsx(Text, {
232
+ color: "text-inverse",
233
+ children: "White"
234
+ })
235
+ ]
236
+ })
237
+ ]
238
+ });
239
+ },
240
+ parameters: {
241
+ docs: {
242
+ description: {
243
+ story: 'Different colors for loading spinners to match various backgrounds.'
244
+ }
245
+ }
246
+ }
247
+ };
248
+ export var InlineLoading = {
249
+ render: function() {
250
+ return /*#__PURE__*/ _jsxs(HorizontalStack, {
251
+ gap: "2",
252
+ blockAlign: "center",
253
+ children: [
254
+ /*#__PURE__*/ _jsx(Loading, {
255
+ size: "small"
256
+ }),
257
+ /*#__PURE__*/ _jsx(Text, {
258
+ children: "Loading data..."
259
+ })
260
+ ]
261
+ });
262
+ },
263
+ parameters: {
264
+ docs: {
265
+ description: {
266
+ story: 'Inline loading spinner with descriptive text.'
267
+ }
268
+ }
269
+ }
270
+ };
271
+ export var CardLoading = {
272
+ render: function() {
273
+ return /*#__PURE__*/ _jsx(Card, {
274
+ title: "User Profile",
275
+ padded: true,
276
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
277
+ gap: "4",
278
+ inlineAlign: "center",
279
+ blockAlign: "center",
280
+ as: Box,
281
+ padding: "12",
282
+ children: [
283
+ /*#__PURE__*/ _jsx(Loading, {
284
+ size: "large"
285
+ }),
286
+ /*#__PURE__*/ _jsx(Text, {
287
+ children: "Loading user information..."
288
+ })
289
+ ]
290
+ })
291
+ });
292
+ },
293
+ parameters: {
294
+ docs: {
295
+ description: {
296
+ story: 'Loading state within a card container.'
297
+ }
298
+ }
299
+ }
300
+ };
301
+ export var OverlayLoading = {
302
+ render: function() {
303
+ var _useState = _sliced_to_array(useState(false), 2), isLoading = _useState[0], setIsLoading = _useState[1];
304
+ var handleLoadData = function() {
305
+ setIsLoading(true);
306
+ setTimeout(function() {
307
+ return setIsLoading(false);
308
+ }, 3000);
309
+ };
310
+ return /*#__PURE__*/ _jsx(Box, {
311
+ position: "relative",
312
+ children: /*#__PURE__*/ _jsxs(Card, {
313
+ title: "Data Dashboard",
314
+ padded: true,
315
+ children: [
316
+ /*#__PURE__*/ _jsxs(VerticalStack, {
317
+ gap: "4",
318
+ children: [
319
+ /*#__PURE__*/ _jsxs(HorizontalStack, {
320
+ align: "space-between",
321
+ children: [
322
+ /*#__PURE__*/ _jsx(Text, {
323
+ variant: "headingSm",
324
+ children: "Sales Data"
325
+ }),
326
+ /*#__PURE__*/ _jsx(Button, {
327
+ onClick: handleLoadData,
328
+ disabled: isLoading,
329
+ children: "Refresh Data"
330
+ })
331
+ ]
332
+ }),
333
+ /*#__PURE__*/ _jsx(Box, {
334
+ padding: "8",
335
+ background: "surface-neutral-subdued",
336
+ borderRadius: "1",
337
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
338
+ gap: "1",
339
+ children: [
340
+ /*#__PURE__*/ _jsx(Text, {
341
+ children: "Revenue: $125,000"
342
+ }),
343
+ /*#__PURE__*/ _jsx(Text, {
344
+ children: "Orders: 1,250"
345
+ }),
346
+ /*#__PURE__*/ _jsx(Text, {
347
+ children: "Customers: 847"
348
+ })
349
+ ]
350
+ })
351
+ })
352
+ ]
353
+ }),
354
+ isLoading && /*#__PURE__*/ _jsxs(VerticalStack, {
355
+ gap: "4",
356
+ inlineAlign: "center",
357
+ blockAlign: "center",
358
+ as: Box,
359
+ position: "absolute",
360
+ insetBlockStart: "0",
361
+ insetInlineStart: "0",
362
+ insetInlineEnd: "0",
363
+ insetBlockEnd: "0",
364
+ borderRadius: "2",
365
+ style: {
366
+ backgroundColor: 'rgba(255, 255, 255, 0.8)'
367
+ },
368
+ children: [
369
+ /*#__PURE__*/ _jsx(Loading, {
370
+ size: "large"
371
+ }),
372
+ /*#__PURE__*/ _jsx(Text, {
373
+ children: "Refreshing data..."
374
+ })
375
+ ]
376
+ })
377
+ ]
378
+ })
379
+ });
380
+ },
381
+ parameters: {
382
+ docs: {
383
+ description: {
384
+ story: 'Loading overlay that covers content during data refresh.'
385
+ }
386
+ }
387
+ }
388
+ };
389
+ export var ButtonLoading = {
390
+ render: function() {
391
+ var _useState = _sliced_to_array(useState({
392
+ save: false,
393
+ upload: false,
394
+ process: false
395
+ }), 2), loadingStates = _useState[0], setLoadingStates = _useState[1];
396
+ var handleButtonClick = function(action) {
397
+ setLoadingStates(function(prev) {
398
+ return _object_spread_props(_object_spread({}, prev), _define_property({}, action, true));
399
+ });
400
+ setTimeout(function() {
401
+ setLoadingStates(function(prev) {
402
+ return _object_spread_props(_object_spread({}, prev), _define_property({}, action, false));
403
+ });
404
+ }, 2000);
405
+ };
406
+ return /*#__PURE__*/ _jsxs(HorizontalStack, {
407
+ gap: "4",
408
+ children: [
409
+ /*#__PURE__*/ _jsx(Button, {
410
+ primary: true,
411
+ onClick: function() {
412
+ return handleButtonClick('save');
413
+ },
414
+ disabled: loadingStates.save,
415
+ children: loadingStates.save ? /*#__PURE__*/ _jsxs(HorizontalStack, {
416
+ gap: "2",
417
+ blockAlign: "center",
418
+ children: [
419
+ /*#__PURE__*/ _jsx(Loading, {
420
+ size: "small",
421
+ color: "white"
422
+ }),
423
+ /*#__PURE__*/ _jsx("span", {
424
+ children: "Saving..."
425
+ })
426
+ ]
427
+ }) : 'Save Changes'
428
+ }),
429
+ /*#__PURE__*/ _jsx(Button, {
430
+ onClick: function() {
431
+ return handleButtonClick('upload');
432
+ },
433
+ disabled: loadingStates.upload,
434
+ children: loadingStates.upload ? /*#__PURE__*/ _jsxs(HorizontalStack, {
435
+ gap: "2",
436
+ blockAlign: "center",
437
+ children: [
438
+ /*#__PURE__*/ _jsx(Loading, {
439
+ size: "small"
440
+ }),
441
+ /*#__PURE__*/ _jsx("span", {
442
+ children: "Uploading..."
443
+ })
444
+ ]
445
+ }) : 'Upload File'
446
+ }),
447
+ /*#__PURE__*/ _jsx(Button, {
448
+ onClick: function() {
449
+ return handleButtonClick('process');
450
+ },
451
+ disabled: loadingStates.process,
452
+ children: loadingStates.process ? /*#__PURE__*/ _jsxs(HorizontalStack, {
453
+ gap: "2",
454
+ blockAlign: "center",
455
+ children: [
456
+ /*#__PURE__*/ _jsx(Loading, {
457
+ size: "small"
458
+ }),
459
+ /*#__PURE__*/ _jsx("span", {
460
+ children: "Processing..."
461
+ })
462
+ ]
463
+ }) : 'Process Data'
464
+ })
465
+ ]
466
+ });
467
+ },
468
+ parameters: {
469
+ docs: {
470
+ description: {
471
+ story: 'Loading spinners integrated into button states.'
472
+ }
473
+ }
474
+ }
475
+ };
476
+ export var TableLoading = {
477
+ render: function() {
478
+ var _useState = _sliced_to_array(useState(true), 2), loadingTable = _useState[0], setLoadingTable = _useState[1];
479
+ var toggleLoading = function() {
480
+ return setLoadingTable(!loadingTable);
481
+ };
482
+ return /*#__PURE__*/ _jsxs(Card, {
483
+ title: "Customer Data",
484
+ padded: true,
485
+ children: [
486
+ /*#__PURE__*/ _jsx(Box, {
487
+ marginBlockEnd: "4",
488
+ children: /*#__PURE__*/ _jsx(Button, {
489
+ onClick: toggleLoading,
490
+ children: loadingTable ? 'Show Data' : 'Show Loading'
491
+ })
492
+ }),
493
+ loadingTable ? /*#__PURE__*/ _jsxs(VerticalStack, {
494
+ gap: "4",
495
+ inlineAlign: "center",
496
+ blockAlign: "center",
497
+ as: Box,
498
+ padding: "16",
499
+ children: [
500
+ /*#__PURE__*/ _jsx(Loading, {
501
+ size: "large"
502
+ }),
503
+ /*#__PURE__*/ _jsx(Text, {
504
+ children: "Loading customer data..."
505
+ }),
506
+ /*#__PURE__*/ _jsx(Text, {
507
+ color: "subdued",
508
+ variant: "bodyXs",
509
+ children: "This may take a few moments"
510
+ })
511
+ ]
512
+ }) : /*#__PURE__*/ _jsx(Box, {
513
+ borderWidth: "1",
514
+ borderColor: "border-subdued",
515
+ borderRadius: "1",
516
+ children: /*#__PURE__*/ _jsxs("table", {
517
+ style: {
518
+ width: '100%',
519
+ borderCollapse: 'collapse'
520
+ },
521
+ children: [
522
+ /*#__PURE__*/ _jsx("thead", {
523
+ children: /*#__PURE__*/ _jsxs("tr", {
524
+ style: {
525
+ backgroundColor: '#f9f9f9'
526
+ },
527
+ children: [
528
+ /*#__PURE__*/ _jsx("th", {
529
+ style: {
530
+ padding: '0.75rem',
531
+ textAlign: 'left',
532
+ borderBottom: '1px solid #e1e1e1'
533
+ },
534
+ children: "Name"
535
+ }),
536
+ /*#__PURE__*/ _jsx("th", {
537
+ style: {
538
+ padding: '0.75rem',
539
+ textAlign: 'left',
540
+ borderBottom: '1px solid #e1e1e1'
541
+ },
542
+ children: "Email"
543
+ }),
544
+ /*#__PURE__*/ _jsx("th", {
545
+ style: {
546
+ padding: '0.75rem',
547
+ textAlign: 'left',
548
+ borderBottom: '1px solid #e1e1e1'
549
+ },
550
+ children: "Status"
551
+ })
552
+ ]
553
+ })
554
+ }),
555
+ /*#__PURE__*/ _jsxs("tbody", {
556
+ children: [
557
+ /*#__PURE__*/ _jsxs("tr", {
558
+ children: [
559
+ /*#__PURE__*/ _jsx("td", {
560
+ style: {
561
+ padding: '0.75rem',
562
+ borderBottom: '1px solid #e1e1e1'
563
+ },
564
+ children: "John Doe"
565
+ }),
566
+ /*#__PURE__*/ _jsx("td", {
567
+ style: {
568
+ padding: '0.75rem',
569
+ borderBottom: '1px solid #e1e1e1'
570
+ },
571
+ children: "john@example.com"
572
+ }),
573
+ /*#__PURE__*/ _jsx("td", {
574
+ style: {
575
+ padding: '0.75rem',
576
+ borderBottom: '1px solid #e1e1e1'
577
+ },
578
+ children: "Active"
579
+ })
580
+ ]
581
+ }),
582
+ /*#__PURE__*/ _jsxs("tr", {
583
+ children: [
584
+ /*#__PURE__*/ _jsx("td", {
585
+ style: {
586
+ padding: '0.75rem',
587
+ borderBottom: '1px solid #e1e1e1'
588
+ },
589
+ children: "Jane Smith"
590
+ }),
591
+ /*#__PURE__*/ _jsx("td", {
592
+ style: {
593
+ padding: '0.75rem',
594
+ borderBottom: '1px solid #e1e1e1'
595
+ },
596
+ children: "jane@example.com"
597
+ }),
598
+ /*#__PURE__*/ _jsx("td", {
599
+ style: {
600
+ padding: '0.75rem',
601
+ borderBottom: '1px solid #e1e1e1'
602
+ },
603
+ children: "Pending"
604
+ })
605
+ ]
606
+ })
607
+ ]
608
+ })
609
+ ]
610
+ })
611
+ })
612
+ ]
613
+ });
614
+ },
615
+ parameters: {
616
+ docs: {
617
+ description: {
618
+ story: 'Loading state for table data with descriptive messaging.'
619
+ }
620
+ }
621
+ }
622
+ };
623
+ export var ProgressiveLoading = {
624
+ render: function() {
625
+ var _useState = _sliced_to_array(useState(0), 2), currentStep = _useState[0], setCurrentStep = _useState[1];
626
+ var _useState1 = _sliced_to_array(useState(false), 2), isRunning = _useState1[0], setIsRunning = _useState1[1];
627
+ var steps = [
628
+ 'Initializing...',
629
+ 'Connecting to server...',
630
+ 'Authenticating user...',
631
+ 'Loading data...',
632
+ 'Processing results...',
633
+ 'Complete!'
634
+ ];
635
+ var startProcess = function() {
636
+ setIsRunning(true);
637
+ setCurrentStep(0);
638
+ var interval = setInterval(function() {
639
+ setCurrentStep(function(prev) {
640
+ if (prev >= steps.length - 1) {
641
+ clearInterval(interval);
642
+ setIsRunning(false);
643
+ return prev;
644
+ }
645
+ return prev + 1;
646
+ });
647
+ }, 1000);
648
+ };
649
+ var resetProcess = function() {
650
+ setCurrentStep(0);
651
+ setIsRunning(false);
652
+ };
653
+ return /*#__PURE__*/ _jsx(Card, {
654
+ title: "Data Import Process",
655
+ padded: true,
656
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
657
+ gap: "8",
658
+ children: [
659
+ /*#__PURE__*/ _jsxs(HorizontalStack, {
660
+ gap: "4",
661
+ children: [
662
+ /*#__PURE__*/ _jsx(Button, {
663
+ primary: true,
664
+ onClick: startProcess,
665
+ disabled: isRunning,
666
+ children: "Start Import"
667
+ }),
668
+ /*#__PURE__*/ _jsx(Button, {
669
+ onClick: resetProcess,
670
+ disabled: isRunning,
671
+ children: "Reset"
672
+ })
673
+ ]
674
+ }),
675
+ /*#__PURE__*/ _jsx(VerticalStack, {
676
+ gap: "4",
677
+ inlineAlign: "center",
678
+ as: Box,
679
+ padding: "8",
680
+ background: "subdued",
681
+ borderRadius: "lg",
682
+ children: isRunning || currentStep > 0 ? /*#__PURE__*/ _jsxs(_Fragment, {
683
+ children: [
684
+ /*#__PURE__*/ _jsx(Loading, {
685
+ size: "large",
686
+ color: currentStep === steps.length - 1 ? 'success' : 'default'
687
+ }),
688
+ /*#__PURE__*/ _jsx(Text, {
689
+ variant: "headingSm",
690
+ children: steps[currentStep]
691
+ }),
692
+ /*#__PURE__*/ _jsx(Box, {
693
+ style: {
694
+ width: '200px',
695
+ height: '4px',
696
+ backgroundColor: '#e1e1e1',
697
+ borderRadius: '2px',
698
+ overflow: 'hidden'
699
+ },
700
+ children: /*#__PURE__*/ _jsx("div", {
701
+ style: {
702
+ height: '100%',
703
+ backgroundColor: currentStep === steps.length - 1 ? '#4caf50' : '#2196f3',
704
+ width: "".concat((currentStep + 1) / steps.length * 100, "%"),
705
+ transition: 'width 0.3s ease'
706
+ }
707
+ })
708
+ }),
709
+ /*#__PURE__*/ _jsxs(Text, {
710
+ color: "subdued",
711
+ variant: "bodyXs",
712
+ children: [
713
+ "Step ",
714
+ currentStep + 1,
715
+ " of ",
716
+ steps.length
717
+ ]
718
+ })
719
+ ]
720
+ }) : /*#__PURE__*/ _jsx(Text, {
721
+ color: "subdued",
722
+ children: 'Click "Start Import" to begin the process'
723
+ })
724
+ })
725
+ ]
726
+ })
727
+ });
728
+ },
729
+ parameters: {
730
+ docs: {
731
+ description: {
732
+ story: 'Progressive loading with step-by-step status updates and progress bar.'
733
+ }
734
+ }
735
+ }
736
+ };
737
+ export var SkeletonLoading = {
738
+ render: function() {
739
+ var _useState = _sliced_to_array(useState(true), 2), showSkeleton = _useState[0], setShowSkeleton = _useState[1];
740
+ return /*#__PURE__*/ _jsxs(Card, {
741
+ title: "Article Preview",
742
+ padded: true,
743
+ children: [
744
+ /*#__PURE__*/ _jsx(Box, {
745
+ marginBlockEnd: "4",
746
+ children: /*#__PURE__*/ _jsx(Button, {
747
+ onClick: function() {
748
+ return setShowSkeleton(!showSkeleton);
749
+ },
750
+ children: showSkeleton ? 'Show Content' : 'Show Skeleton'
751
+ })
752
+ }),
753
+ showSkeleton ? /*#__PURE__*/ _jsxs(VerticalStack, {
754
+ gap: "4",
755
+ children: [
756
+ /*#__PURE__*/ _jsxs(HorizontalStack, {
757
+ gap: "4",
758
+ blockAlign: "center",
759
+ children: [
760
+ /*#__PURE__*/ _jsx(Loading, {
761
+ size: "small"
762
+ }),
763
+ /*#__PURE__*/ _jsx(Text, {
764
+ color: "subdued",
765
+ children: "Loading article..."
766
+ })
767
+ ]
768
+ }),
769
+ /*#__PURE__*/ _jsx(Box, {
770
+ style: {
771
+ height: '24px',
772
+ backgroundColor: '#e1e1e1',
773
+ borderRadius: '4px',
774
+ width: '70%'
775
+ }
776
+ }),
777
+ /*#__PURE__*/ _jsx(Box, {
778
+ style: {
779
+ height: '16px',
780
+ backgroundColor: '#e1e1e1',
781
+ borderRadius: '4px',
782
+ width: '100%'
783
+ }
784
+ }),
785
+ /*#__PURE__*/ _jsx(Box, {
786
+ style: {
787
+ height: '16px',
788
+ backgroundColor: '#e1e1e1',
789
+ borderRadius: '4px',
790
+ width: '85%'
791
+ }
792
+ }),
793
+ /*#__PURE__*/ _jsx(Box, {
794
+ style: {
795
+ height: '16px',
796
+ backgroundColor: '#e1e1e1',
797
+ borderRadius: '4px',
798
+ width: '60%'
799
+ }
800
+ }),
801
+ /*#__PURE__*/ _jsx(Box, {
802
+ style: {
803
+ height: '120px',
804
+ backgroundColor: '#e1e1e1',
805
+ borderRadius: '4px',
806
+ width: '100%'
807
+ }
808
+ })
809
+ ]
810
+ }) : /*#__PURE__*/ _jsxs(VerticalStack, {
811
+ gap: "4",
812
+ children: [
813
+ /*#__PURE__*/ _jsx(Text, {
814
+ variant: "headingLg",
815
+ children: "How to Build Better User Interfaces"
816
+ }),
817
+ /*#__PURE__*/ _jsx(Text, {
818
+ children: "Creating intuitive and accessible user interfaces requires careful consideration of user needs, design principles, and modern development practices."
819
+ }),
820
+ /*#__PURE__*/ _jsx(Text, {
821
+ children: "In this article, we'll explore the key concepts that make interfaces both beautiful and functional, from color theory and typography to interaction design and usability testing."
822
+ }),
823
+ /*#__PURE__*/ _jsx(VerticalStack, {
824
+ inlineAlign: "center",
825
+ blockAlign: "center",
826
+ as: Box,
827
+ style: {
828
+ height: '120px',
829
+ backgroundColor: '#f0f8ff',
830
+ borderRadius: '4px',
831
+ border: '1px dashed #2196f3'
832
+ },
833
+ children: /*#__PURE__*/ _jsx(Text, {
834
+ color: "subdued",
835
+ children: "[Article Image]"
836
+ })
837
+ })
838
+ ]
839
+ })
840
+ ]
841
+ });
842
+ },
843
+ parameters: {
844
+ docs: {
845
+ description: {
846
+ story: 'Skeleton loading placeholders that mimic the final content structure.'
847
+ }
848
+ }
849
+ }
850
+ };