@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,710 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: Object.getOwnPropertyDescriptor(all, name).get
9
+ });
10
+ }
11
+ _export(exports, {
12
+ get AccessibilityExample () {
13
+ return AccessibilityExample;
14
+ },
15
+ get CustomIcons () {
16
+ return CustomIcons;
17
+ },
18
+ get Default () {
19
+ return Default;
20
+ },
21
+ get DifferentContexts () {
22
+ return DifferentContexts;
23
+ },
24
+ get DifferentMessages () {
25
+ return DifferentMessages;
26
+ },
27
+ get FormValidation () {
28
+ return FormValidation;
29
+ },
30
+ get MultipleErrors () {
31
+ return MultipleErrors;
32
+ },
33
+ get WithFormField () {
34
+ return WithFormField;
35
+ },
36
+ get default () {
37
+ return _default;
38
+ }
39
+ });
40
+ var _jsxruntime = require("react/jsx-runtime");
41
+ var _transformers = require("../utilities/transformers.js");
42
+ var _InlineError = /*#__PURE__*/ _interop_require_default(require("../components/InlineError.js"));
43
+ var _Text = /*#__PURE__*/ _interop_require_default(require("../components/Text.js"));
44
+ var _Card = /*#__PURE__*/ _interop_require_default(require("../components/Card.js"));
45
+ var _TextField = /*#__PURE__*/ _interop_require_default(require("../components/TextField.js"));
46
+ var _Button = /*#__PURE__*/ _interop_require_default(require("../components/Button.js"));
47
+ var _ = require("../");
48
+ var _polarisicons = require("@shopify/polaris-icons");
49
+ var _react = require("react");
50
+ function _array_like_to_array(arr, len) {
51
+ if (len == null || len > arr.length) len = arr.length;
52
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
53
+ return arr2;
54
+ }
55
+ function _array_with_holes(arr) {
56
+ if (Array.isArray(arr)) return arr;
57
+ }
58
+ function _define_property(obj, key, value) {
59
+ if (key in obj) {
60
+ Object.defineProperty(obj, key, {
61
+ value: value,
62
+ enumerable: true,
63
+ configurable: true,
64
+ writable: true
65
+ });
66
+ } else {
67
+ obj[key] = value;
68
+ }
69
+ return obj;
70
+ }
71
+ function _interop_require_default(obj) {
72
+ return obj && obj.__esModule ? obj : {
73
+ default: obj
74
+ };
75
+ }
76
+ function _iterable_to_array_limit(arr, i) {
77
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
78
+ if (_i == null) return;
79
+ var _arr = [];
80
+ var _n = true;
81
+ var _d = false;
82
+ var _s, _e;
83
+ try {
84
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
85
+ _arr.push(_s.value);
86
+ if (i && _arr.length === i) break;
87
+ }
88
+ } catch (err) {
89
+ _d = true;
90
+ _e = err;
91
+ } finally{
92
+ try {
93
+ if (!_n && _i["return"] != null) _i["return"]();
94
+ } finally{
95
+ if (_d) throw _e;
96
+ }
97
+ }
98
+ return _arr;
99
+ }
100
+ function _non_iterable_rest() {
101
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
102
+ }
103
+ function _object_spread(target) {
104
+ for(var i = 1; i < arguments.length; i++){
105
+ var source = arguments[i] != null ? arguments[i] : {};
106
+ var ownKeys = Object.keys(source);
107
+ if (typeof Object.getOwnPropertySymbols === "function") {
108
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
109
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
110
+ }));
111
+ }
112
+ ownKeys.forEach(function(key) {
113
+ _define_property(target, key, source[key]);
114
+ });
115
+ }
116
+ return target;
117
+ }
118
+ function ownKeys(object, enumerableOnly) {
119
+ var keys = Object.keys(object);
120
+ if (Object.getOwnPropertySymbols) {
121
+ var symbols = Object.getOwnPropertySymbols(object);
122
+ if (enumerableOnly) {
123
+ symbols = symbols.filter(function(sym) {
124
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
125
+ });
126
+ }
127
+ keys.push.apply(keys, symbols);
128
+ }
129
+ return keys;
130
+ }
131
+ function _object_spread_props(target, source) {
132
+ source = source != null ? source : {};
133
+ if (Object.getOwnPropertyDescriptors) {
134
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
135
+ } else {
136
+ ownKeys(Object(source)).forEach(function(key) {
137
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
138
+ });
139
+ }
140
+ return target;
141
+ }
142
+ function _sliced_to_array(arr, i) {
143
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
144
+ }
145
+ function _unsupported_iterable_to_array(o, minLen) {
146
+ if (!o) return;
147
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
148
+ var n = Object.prototype.toString.call(o).slice(8, -1);
149
+ if (n === "Object" && o.constructor) n = o.constructor.name;
150
+ if (n === "Map" || n === "Set") return Array.from(n);
151
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
152
+ }
153
+ var _default = {
154
+ title: 'Litho/InlineError',
155
+ component: _InlineError.default,
156
+ parameters: {
157
+ layout: 'padded',
158
+ docs: {
159
+ description: {
160
+ component: "An InlineError component that displays error messages with an icon. It's typically used alongside form fields to show validation errors or other important messages."
161
+ }
162
+ }
163
+ },
164
+ args: {
165
+ message: 'This field is required',
166
+ fieldID: 'example-field'
167
+ },
168
+ tags: [
169
+ 'autodocs'
170
+ ],
171
+ argTypes: {
172
+ message: {
173
+ control: 'text',
174
+ description: 'The error message to display'
175
+ },
176
+ fieldID: {
177
+ control: 'text',
178
+ description: 'ID of the associated field for accessibility'
179
+ },
180
+ icon: {
181
+ control: false,
182
+ description: 'Icon to display with the error message'
183
+ }
184
+ }
185
+ };
186
+ var Default = {
187
+ render: function(args) {
188
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, _object_spread({}, args));
189
+ }
190
+ };
191
+ var DifferentMessages = {
192
+ render: function() {
193
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
194
+ gap: "4",
195
+ children: [
196
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
197
+ message: "This field is required",
198
+ fieldID: "field1"
199
+ }),
200
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
201
+ message: "Password must be at least 8 characters",
202
+ fieldID: "field2"
203
+ }),
204
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
205
+ message: "Email format is invalid",
206
+ fieldID: "field3"
207
+ }),
208
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
209
+ message: "Username is already taken",
210
+ fieldID: "field4"
211
+ }),
212
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
213
+ message: "File size must be less than 10MB",
214
+ fieldID: "field5"
215
+ })
216
+ ]
217
+ });
218
+ },
219
+ parameters: {
220
+ docs: {
221
+ description: {
222
+ story: 'Different types of error messages.'
223
+ }
224
+ }
225
+ }
226
+ };
227
+ var CustomIcons = {
228
+ render: function() {
229
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
230
+ gap: "4",
231
+ children: [
232
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
233
+ message: "This is a critical error",
234
+ fieldID: "field1"
235
+ }),
236
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
237
+ message: "This is a warning message",
238
+ fieldID: "field2",
239
+ icon: _polarisicons.AlertMinor
240
+ }),
241
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
242
+ message: "This is an informational message",
243
+ fieldID: "field3",
244
+ icon: _polarisicons.InfoMinor
245
+ })
246
+ ]
247
+ });
248
+ },
249
+ parameters: {
250
+ docs: {
251
+ description: {
252
+ story: 'Error messages with different icon types.'
253
+ }
254
+ }
255
+ }
256
+ };
257
+ var WithFormField = {
258
+ render: function() {
259
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
260
+ gap: "2",
261
+ children: [
262
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
263
+ label: "Email Address",
264
+ placeholder: "Enter your email",
265
+ error: true
266
+ }),
267
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
268
+ message: "Please enter a valid email address",
269
+ fieldID: "email-field"
270
+ })
271
+ ]
272
+ });
273
+ },
274
+ parameters: {
275
+ docs: {
276
+ description: {
277
+ story: 'Inline error displayed below a form field.'
278
+ }
279
+ }
280
+ }
281
+ };
282
+ var FormValidation = {
283
+ render: function() {
284
+ var _useState = _sliced_to_array((0, _react.useState)({
285
+ name: '',
286
+ email: '',
287
+ password: '',
288
+ confirmPassword: ''
289
+ }), 2), formData = _useState[0], setFormData = _useState[1];
290
+ var _useState1 = _sliced_to_array((0, _react.useState)({}), 2), errors = _useState1[0], setErrors = _useState1[1];
291
+ var _useState2 = _sliced_to_array((0, _react.useState)({}), 2), touched = _useState2[0], setTouched = _useState2[1];
292
+ var validateField = function(field, value) {
293
+ switch(field){
294
+ case 'name':
295
+ return value.length < 2 ? 'Name must be at least 2 characters' : '';
296
+ case 'email':
297
+ return !/\S+@\S+\.\S+/.test(value) ? 'Please enter a valid email address' : '';
298
+ case 'password':
299
+ return value.length < 8 ? 'Password must be at least 8 characters' : '';
300
+ case 'confirmPassword':
301
+ return value !== formData.password ? 'Passwords do not match' : '';
302
+ default:
303
+ return '';
304
+ }
305
+ };
306
+ var handleChange = function(field, value) {
307
+ setFormData(function(prev) {
308
+ return _object_spread_props(_object_spread({}, prev), _define_property({}, field, value));
309
+ });
310
+ if (touched[field]) {
311
+ var error = validateField(field, value);
312
+ setErrors(function(prev) {
313
+ return _object_spread_props(_object_spread({}, prev), _define_property({}, field, error));
314
+ });
315
+ }
316
+ };
317
+ var handleBlur = function(field) {
318
+ setTouched(function(prev) {
319
+ return _object_spread_props(_object_spread({}, prev), _define_property({}, field, true));
320
+ });
321
+ var error = validateField(field, formData[field]);
322
+ setErrors(function(prev) {
323
+ return _object_spread_props(_object_spread({}, prev), _define_property({}, field, error));
324
+ });
325
+ };
326
+ var handleSubmit = function(e) {
327
+ e.preventDefault();
328
+ var newErrors = {};
329
+ Object.keys(formData).forEach(function(field) {
330
+ var error = validateField(field, formData[field]);
331
+ if (error) newErrors[field] = error;
332
+ });
333
+ setErrors(newErrors);
334
+ setTouched({
335
+ name: true,
336
+ email: true,
337
+ password: true,
338
+ confirmPassword: true
339
+ });
340
+ if (Object.keys(newErrors).length === 0) {
341
+ alert('Form submitted successfully!');
342
+ }
343
+ };
344
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
345
+ title: "Create Account",
346
+ padded: true,
347
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)("form", {
348
+ onSubmit: handleSubmit,
349
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
350
+ gap: "6",
351
+ children: [
352
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
353
+ children: [
354
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
355
+ label: "Full Name",
356
+ value: formData.name,
357
+ onChange: function(value) {
358
+ return handleChange('name', value);
359
+ },
360
+ onBlur: function() {
361
+ return handleBlur('name');
362
+ },
363
+ error: !!errors.name,
364
+ placeholder: "Enter your full name"
365
+ }),
366
+ errors.name && /*#__PURE__*/ (0, _jsxruntime.jsx)(_.Box, {
367
+ paddingBlockStart: "2",
368
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
369
+ message: errors.name,
370
+ fieldID: "name-field"
371
+ })
372
+ })
373
+ ]
374
+ }),
375
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
376
+ children: [
377
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
378
+ label: "Email Address",
379
+ type: "email",
380
+ value: formData.email,
381
+ onChange: function(value) {
382
+ return handleChange('email', value);
383
+ },
384
+ onBlur: function() {
385
+ return handleBlur('email');
386
+ },
387
+ error: !!errors.email,
388
+ placeholder: "Enter your email"
389
+ }),
390
+ errors.email && /*#__PURE__*/ (0, _jsxruntime.jsx)(_.Box, {
391
+ paddingBlockStart: "2",
392
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
393
+ message: errors.email,
394
+ fieldID: "email-field"
395
+ })
396
+ })
397
+ ]
398
+ }),
399
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
400
+ children: [
401
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
402
+ label: "Password",
403
+ type: "password",
404
+ value: formData.password,
405
+ onChange: function(value) {
406
+ return handleChange('password', value);
407
+ },
408
+ onBlur: function() {
409
+ return handleBlur('password');
410
+ },
411
+ error: !!errors.password,
412
+ placeholder: "Create a password"
413
+ }),
414
+ errors.password && /*#__PURE__*/ (0, _jsxruntime.jsx)(_.Box, {
415
+ paddingBlockStart: "2",
416
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
417
+ message: errors.password,
418
+ fieldID: "password-field"
419
+ })
420
+ })
421
+ ]
422
+ }),
423
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
424
+ children: [
425
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
426
+ label: "Confirm Password",
427
+ type: "password",
428
+ value: formData.confirmPassword,
429
+ onChange: function(value) {
430
+ return handleChange('confirmPassword', value);
431
+ },
432
+ onBlur: function() {
433
+ return handleBlur('confirmPassword');
434
+ },
435
+ error: !!errors.confirmPassword,
436
+ placeholder: "Confirm your password"
437
+ }),
438
+ errors.confirmPassword && /*#__PURE__*/ (0, _jsxruntime.jsx)(_.Box, {
439
+ paddingBlockStart: "2",
440
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
441
+ message: errors.confirmPassword,
442
+ fieldID: "confirm-password-field"
443
+ })
444
+ })
445
+ ]
446
+ }),
447
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
448
+ primary: true,
449
+ submit: true,
450
+ children: "Create Account"
451
+ })
452
+ ]
453
+ })
454
+ })
455
+ });
456
+ },
457
+ parameters: {
458
+ docs: {
459
+ description: {
460
+ story: 'Complete form validation example with inline errors.'
461
+ }
462
+ }
463
+ }
464
+ };
465
+ var MultipleErrors = {
466
+ render: function() {
467
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
468
+ title: "File Upload",
469
+ padded: true,
470
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
471
+ gap: "6",
472
+ children: [
473
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
474
+ label: "Upload Files",
475
+ placeholder: "Select files to upload",
476
+ error: true
477
+ }),
478
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
479
+ gap: "2",
480
+ children: [
481
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
482
+ message: "File size must be less than 10MB",
483
+ fieldID: "file-upload"
484
+ }),
485
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
486
+ message: "Only JPG, PNG, and GIF files are allowed",
487
+ fieldID: "file-upload"
488
+ }),
489
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
490
+ message: "Maximum 5 files can be uploaded at once",
491
+ fieldID: "file-upload"
492
+ })
493
+ ]
494
+ }),
495
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.HorizontalStack, {
496
+ gap: "4",
497
+ children: [
498
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
499
+ children: "Choose Files"
500
+ }),
501
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
502
+ primary: true,
503
+ disabled: true,
504
+ children: "Upload"
505
+ })
506
+ ]
507
+ })
508
+ ]
509
+ })
510
+ });
511
+ },
512
+ parameters: {
513
+ docs: {
514
+ description: {
515
+ story: 'Multiple inline errors for a single field with complex validation.'
516
+ }
517
+ }
518
+ }
519
+ };
520
+ var DifferentContexts = {
521
+ render: function() {
522
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
523
+ gap: "8",
524
+ children: [
525
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
526
+ title: "Login Form",
527
+ padded: true,
528
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
529
+ gap: "4",
530
+ children: [
531
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
532
+ label: "Username",
533
+ error: true,
534
+ placeholder: "Enter username"
535
+ }),
536
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
537
+ message: "Username not found",
538
+ fieldID: "username"
539
+ }),
540
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
541
+ label: "Password",
542
+ type: "password",
543
+ error: true,
544
+ placeholder: "Enter password"
545
+ }),
546
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
547
+ message: "Incorrect password",
548
+ fieldID: "password"
549
+ })
550
+ ]
551
+ })
552
+ }),
553
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
554
+ title: "Payment Information",
555
+ padded: true,
556
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
557
+ gap: "4",
558
+ children: [
559
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
560
+ label: "Card Number",
561
+ error: true,
562
+ placeholder: "1234 5678 9012 3456"
563
+ }),
564
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
565
+ message: "Invalid card number",
566
+ fieldID: "card-number"
567
+ }),
568
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(Grid, {
569
+ columns: 2,
570
+ gap: "4",
571
+ children: [
572
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
573
+ children: [
574
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
575
+ label: "Expiry Date",
576
+ error: true,
577
+ placeholder: "MM/YY"
578
+ }),
579
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_.Box, {
580
+ paddingBlockStart: "2",
581
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
582
+ message: "Card has expired",
583
+ fieldID: "expiry"
584
+ })
585
+ })
586
+ ]
587
+ }),
588
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
589
+ children: [
590
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
591
+ label: "CVV",
592
+ error: true,
593
+ placeholder: "123"
594
+ }),
595
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_.Box, {
596
+ paddingBlockStart: "2",
597
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
598
+ message: "Invalid CVV",
599
+ fieldID: "cvv"
600
+ })
601
+ })
602
+ ]
603
+ })
604
+ ]
605
+ })
606
+ ]
607
+ })
608
+ }),
609
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
610
+ title: "Settings",
611
+ padded: true,
612
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
613
+ gap: "4",
614
+ children: [
615
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
616
+ label: "API Endpoint",
617
+ error: true,
618
+ placeholder: "https://api.example.com"
619
+ }),
620
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
621
+ message: "Unable to connect to this endpoint",
622
+ fieldID: "api-endpoint"
623
+ }),
624
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
625
+ label: "Timeout (seconds)",
626
+ error: true,
627
+ placeholder: "30"
628
+ }),
629
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
630
+ message: "Timeout must be between 1 and 300 seconds",
631
+ fieldID: "timeout"
632
+ })
633
+ ]
634
+ })
635
+ })
636
+ ]
637
+ });
638
+ },
639
+ parameters: {
640
+ docs: {
641
+ description: {
642
+ story: 'Inline errors in different contexts - login, payment, and settings forms.'
643
+ }
644
+ }
645
+ }
646
+ };
647
+ var AccessibilityExample = {
648
+ render: function() {
649
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
650
+ title: "Accessibility Features",
651
+ padded: true,
652
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_.VerticalStack, {
653
+ gap: "6",
654
+ children: [
655
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
656
+ variant: "headingSm",
657
+ children: "Each inline error is properly associated with its field using aria-describedby"
658
+ }),
659
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
660
+ children: [
661
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
662
+ label: "Username",
663
+ error: true,
664
+ placeholder: "Enter username",
665
+ "aria-describedby": "username-fieldError"
666
+ }),
667
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_.Box, {
668
+ paddingBlockStart: "2",
669
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
670
+ message: "Username must be at least 3 characters long",
671
+ fieldID: "username-field"
672
+ })
673
+ })
674
+ ]
675
+ }),
676
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
677
+ children: [
678
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
679
+ label: "Email",
680
+ type: "email",
681
+ error: true,
682
+ placeholder: "Enter email",
683
+ "aria-describedby": "email-fieldError"
684
+ }),
685
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_.Box, {
686
+ paddingBlockStart: "2",
687
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_InlineError.default, {
688
+ message: "Please enter a valid email address",
689
+ fieldID: "email-field"
690
+ })
691
+ })
692
+ ]
693
+ }),
694
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
695
+ color: "subdued",
696
+ variant: "bodySm",
697
+ children: "Screen readers will announce the error messages when users focus on the corresponding fields."
698
+ })
699
+ ]
700
+ })
701
+ });
702
+ },
703
+ parameters: {
704
+ docs: {
705
+ description: {
706
+ story: 'Demonstrates proper accessibility implementation with aria-describedby.'
707
+ }
708
+ }
709
+ }
710
+ };