@heymantle/litho 0.0.3 → 0.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (369) hide show
  1. package/dist/cjs/components/ActionList.js +50 -16
  2. package/dist/cjs/components/AnnouncementBar.js +10 -3
  3. package/dist/cjs/components/AppProvider.js +10 -1
  4. package/dist/cjs/components/Autocomplete.js +55 -22
  5. package/dist/cjs/components/Badge.js +2 -1
  6. package/dist/cjs/components/Banner.js +35 -31
  7. package/dist/cjs/components/Box.js +5 -3
  8. package/dist/cjs/components/Button.js +78 -18
  9. package/dist/cjs/components/Card.js +6 -45
  10. package/dist/cjs/components/Checkbox.js +16 -6
  11. package/dist/cjs/components/ChoiceList.js +7 -4
  12. package/dist/cjs/components/ColorField.js +10 -5
  13. package/dist/cjs/components/DatePicker.js +13 -8
  14. package/dist/cjs/components/DropZone.js +33 -18
  15. package/dist/cjs/components/EmptyState.js +17 -9
  16. package/dist/cjs/components/Filters.js +36 -23
  17. package/dist/cjs/components/FooterHelp.js +7 -2
  18. package/dist/cjs/components/Form.js +18 -3
  19. package/dist/cjs/components/Frame.js +48 -23
  20. package/dist/cjs/components/FrameSaveBar.js +21 -12
  21. package/dist/cjs/components/HorizontalStack.js +9 -2
  22. package/dist/cjs/components/Icon.js +1 -0
  23. package/dist/cjs/components/Layout.js +3 -3
  24. package/dist/cjs/components/LayoutSection.js +2 -2
  25. package/dist/cjs/components/Link.js +6 -2
  26. package/dist/cjs/components/List.js +4 -3
  27. package/dist/cjs/components/Listbox.js +9 -4
  28. package/dist/cjs/components/Modal.js +26 -17
  29. package/dist/cjs/components/Navigation.js +30 -20
  30. package/dist/cjs/components/Page.js +8 -3
  31. package/dist/cjs/components/Pagination.js +11 -4
  32. package/dist/cjs/components/Pane.js +168 -41
  33. package/dist/cjs/components/Popover.js +59 -6
  34. package/dist/cjs/components/RangeSlider.js +11 -4
  35. package/dist/cjs/components/ResourceList.js +9 -3
  36. package/dist/cjs/components/Select.js +2 -0
  37. package/dist/cjs/components/Stack.js +223 -0
  38. package/dist/cjs/components/Table.js +33 -20
  39. package/dist/cjs/components/Tabs.js +41 -11
  40. package/dist/cjs/components/Text.js +8 -5
  41. package/dist/cjs/components/TextField.js +23 -13
  42. package/dist/cjs/components/Thumbnail.js +7 -2
  43. package/dist/cjs/components/TimePicker.js +7 -2
  44. package/dist/cjs/components/Tip.js +10 -4
  45. package/dist/cjs/components/Tooltip.js +16 -8
  46. package/dist/cjs/components/TopBar.js +17 -9
  47. package/dist/cjs/components/VerticalStack.js +8 -2
  48. package/dist/cjs/dev/verify-publish.js +37 -4
  49. package/dist/cjs/index.js +4 -0
  50. package/dist/cjs/postcss.config.js +21 -0
  51. package/dist/cjs/stories/ActionList.stories.js +365 -0
  52. package/dist/cjs/stories/AnnouncementBar.stories.js +244 -0
  53. package/dist/cjs/stories/Autocomplete.stories.js +874 -0
  54. package/dist/cjs/stories/Badge.stories.js +183 -0
  55. package/dist/cjs/stories/Banner.stories.js +201 -0
  56. package/dist/cjs/stories/Box.stories.js +601 -0
  57. package/dist/cjs/stories/Button.stories.js +325 -0
  58. package/dist/cjs/stories/ButtonGroup.stories.js +404 -0
  59. package/dist/cjs/stories/Card.stories.js +278 -0
  60. package/dist/cjs/stories/Checkbox.stories.js +266 -0
  61. package/dist/cjs/stories/ChoiceList.stories.js +885 -0
  62. package/dist/cjs/stories/Collapsible.stories.js +917 -0
  63. package/dist/cjs/stories/ColorField.stories.js +887 -0
  64. package/dist/cjs/stories/ContextualSaveBar.stories.js +971 -0
  65. package/dist/cjs/stories/DatePicker.stories.js +584 -0
  66. package/dist/cjs/stories/Divider.stories.js +766 -0
  67. package/dist/cjs/stories/DropZone.stories.js +1210 -0
  68. package/dist/cjs/stories/EmptyState.stories.js +296 -0
  69. package/dist/cjs/stories/Filters.stories.js +1355 -0
  70. package/dist/cjs/stories/FooterHelp.stories.js +874 -0
  71. package/dist/cjs/stories/Form.stories.js +943 -0
  72. package/dist/cjs/stories/Grid.stories.js +1199 -0
  73. package/dist/cjs/stories/HorizontalStack.stories.js +1064 -0
  74. package/dist/cjs/stories/Icon.stories.js +599 -0
  75. package/dist/cjs/stories/Image.stories.js +883 -0
  76. package/dist/cjs/stories/InlineError.stories.js +711 -0
  77. package/dist/cjs/stories/Label.stories.js +665 -0
  78. package/dist/cjs/stories/Layout.stories.js +687 -0
  79. package/dist/cjs/stories/LayoutSection.stories.js +1275 -0
  80. package/dist/cjs/stories/Link.stories.js +425 -0
  81. package/dist/cjs/stories/List.stories.js +1048 -0
  82. package/dist/cjs/stories/Listbox.stories.js +824 -0
  83. package/dist/cjs/stories/Loading.stories.js +909 -0
  84. package/dist/cjs/stories/Modal.stories.js +363 -0
  85. package/dist/cjs/stories/Navigation.stories.js +605 -0
  86. package/dist/cjs/stories/Page.stories.js +327 -0
  87. package/dist/cjs/stories/Pagination.stories.js +438 -0
  88. package/dist/cjs/stories/Pane.stories.js +1550 -0
  89. package/dist/cjs/stories/Popover.stories.js +641 -0
  90. package/dist/cjs/stories/PopoverManager.stories.js +1233 -0
  91. package/dist/cjs/stories/ProgressBar.stories.js +513 -0
  92. package/dist/cjs/stories/RadioButton.stories.js +642 -0
  93. package/dist/cjs/stories/RadioButtonCard.stories.js +816 -0
  94. package/dist/cjs/stories/RangeSlider.stories.js +896 -0
  95. package/dist/cjs/stories/ResourceList.stories.js +1076 -0
  96. package/dist/cjs/stories/Select.stories.js +413 -0
  97. package/dist/cjs/stories/SkeletonText.stories.js +777 -0
  98. package/dist/cjs/stories/Spinner.stories.js +403 -0
  99. package/dist/cjs/stories/Stack.stories.js +1397 -0
  100. package/dist/cjs/stories/Table.stories.js +628 -0
  101. package/dist/cjs/stories/Tabs.stories.js +722 -0
  102. package/dist/cjs/stories/Tag.stories.js +628 -0
  103. package/dist/cjs/stories/Text.stories.js +262 -0
  104. package/dist/cjs/stories/TextField.stories.js +377 -0
  105. package/dist/cjs/stories/Thumbnail.stories.js +863 -0
  106. package/dist/cjs/stories/TimePicker.stories.js +967 -0
  107. package/dist/cjs/stories/Tip.stories.js +753 -0
  108. package/dist/cjs/stories/Tooltip.stories.js +357 -0
  109. package/dist/cjs/stories/TopBar.stories.js +157 -0
  110. package/dist/cjs/stories/VerticalStack.stories.js +1287 -0
  111. package/dist/cjs/tailwind.config.js +17 -0
  112. package/dist/cjs/utilities/transformers.js +66 -0
  113. package/dist/cjs/vite.config.js +35 -0
  114. package/dist/esm/components/ActionList.js +41 -12
  115. package/dist/esm/components/AnnouncementBar.js +3 -1
  116. package/dist/esm/components/AppProvider.js +10 -1
  117. package/dist/esm/components/Autocomplete.js +44 -16
  118. package/dist/esm/components/Badge.js +2 -2
  119. package/dist/esm/components/Banner.js +20 -21
  120. package/dist/esm/components/Box.js +5 -4
  121. package/dist/esm/components/Button.js +68 -13
  122. package/dist/esm/components/Card.js +6 -4
  123. package/dist/esm/components/Checkbox.js +6 -1
  124. package/dist/esm/components/ChoiceList.js +7 -4
  125. package/dist/esm/components/ColorField.js +3 -3
  126. package/dist/esm/components/DatePicker.js +6 -1
  127. package/dist/esm/components/DropZone.js +14 -4
  128. package/dist/esm/components/EmptyState.js +6 -3
  129. package/dist/esm/components/Filters.js +14 -6
  130. package/dist/esm/components/FooterHelp.js +1 -1
  131. package/dist/esm/components/Form.js +18 -3
  132. package/dist/esm/components/Frame.js +27 -15
  133. package/dist/esm/components/FrameSaveBar.js +10 -6
  134. package/dist/esm/components/HorizontalStack.js +9 -2
  135. package/dist/esm/components/Icon.js +1 -0
  136. package/dist/esm/components/InlineError.js +1 -1
  137. package/dist/esm/components/Layout.js +4 -4
  138. package/dist/esm/components/LayoutSection.js +2 -2
  139. package/dist/esm/components/Link.js +6 -2
  140. package/dist/esm/components/List.js +4 -3
  141. package/dist/esm/components/Listbox.js +4 -4
  142. package/dist/esm/components/Modal.js +8 -4
  143. package/dist/esm/components/Navigation.js +16 -11
  144. package/dist/esm/components/Page.js +9 -4
  145. package/dist/esm/components/Pagination.js +3 -1
  146. package/dist/esm/components/Pane.js +165 -43
  147. package/dist/esm/components/Popover.js +18 -6
  148. package/dist/esm/components/RangeSlider.js +3 -1
  149. package/dist/esm/components/ResourceList.js +2 -1
  150. package/dist/esm/components/Select.js +2 -0
  151. package/dist/esm/components/Stack.js +213 -0
  152. package/dist/esm/components/Table.js +17 -4
  153. package/dist/esm/components/Tabs.js +41 -11
  154. package/dist/esm/components/Text.js +8 -6
  155. package/dist/esm/components/TextField.js +6 -1
  156. package/dist/esm/components/Thumbnail.js +1 -1
  157. package/dist/esm/components/TimePicker.js +1 -1
  158. package/dist/esm/components/Tip.js +3 -2
  159. package/dist/esm/components/Tooltip.js +4 -1
  160. package/dist/esm/components/TopBar.js +7 -4
  161. package/dist/esm/components/VerticalStack.js +8 -2
  162. package/dist/esm/dev/verify-publish.js +37 -4
  163. package/dist/esm/index.js +1 -0
  164. package/dist/esm/postcss.config.js +6 -0
  165. package/dist/esm/stories/ActionList.stories.js +327 -0
  166. package/dist/esm/stories/AnnouncementBar.stories.js +212 -0
  167. package/dist/esm/stories/Autocomplete.stories.js +836 -0
  168. package/dist/esm/stories/Badge.stories.js +138 -0
  169. package/dist/esm/stories/Banner.stories.js +159 -0
  170. package/dist/esm/stories/Box.stories.js +560 -0
  171. package/dist/esm/stories/Button.stories.js +277 -0
  172. package/dist/esm/stories/ButtonGroup.stories.js +357 -0
  173. package/dist/esm/stories/Card.stories.js +240 -0
  174. package/dist/esm/stories/Checkbox.stories.js +219 -0
  175. package/dist/esm/stories/ChoiceList.stories.js +835 -0
  176. package/dist/esm/stories/Collapsible.stories.js +879 -0
  177. package/dist/esm/stories/ColorField.stories.js +846 -0
  178. package/dist/esm/stories/ContextualSaveBar.stories.js +939 -0
  179. package/dist/esm/stories/DatePicker.stories.js +537 -0
  180. package/dist/esm/stories/Divider.stories.js +722 -0
  181. package/dist/esm/stories/DropZone.stories.js +1166 -0
  182. package/dist/esm/stories/EmptyState.stories.js +246 -0
  183. package/dist/esm/stories/Filters.stories.js +1317 -0
  184. package/dist/esm/stories/FooterHelp.stories.js +818 -0
  185. package/dist/esm/stories/Form.stories.js +908 -0
  186. package/dist/esm/stories/Grid.stories.js +1152 -0
  187. package/dist/esm/stories/HorizontalStack.stories.js +1011 -0
  188. package/dist/esm/stories/Icon.stories.js +558 -0
  189. package/dist/esm/stories/Image.stories.js +836 -0
  190. package/dist/esm/stories/InlineError.stories.js +667 -0
  191. package/dist/esm/stories/Label.stories.js +612 -0
  192. package/dist/esm/stories/Layout.stories.js +649 -0
  193. package/dist/esm/stories/LayoutSection.stories.js +1234 -0
  194. package/dist/esm/stories/Link.stories.js +381 -0
  195. package/dist/esm/stories/List.stories.js +992 -0
  196. package/dist/esm/stories/Listbox.stories.js +780 -0
  197. package/dist/esm/stories/Loading.stories.js +859 -0
  198. package/dist/esm/stories/Modal.stories.js +322 -0
  199. package/dist/esm/stories/Navigation.stories.js +567 -0
  200. package/dist/esm/stories/Page.stories.js +280 -0
  201. package/dist/esm/stories/Pagination.stories.js +394 -0
  202. package/dist/esm/stories/Pane.stories.js +1512 -0
  203. package/dist/esm/stories/Popover.stories.js +609 -0
  204. package/dist/esm/stories/PopoverManager.stories.js +1201 -0
  205. package/dist/esm/stories/ProgressBar.stories.js +472 -0
  206. package/dist/esm/stories/RadioButton.stories.js +598 -0
  207. package/dist/esm/stories/RadioButtonCard.stories.js +772 -0
  208. package/dist/esm/stories/RangeSlider.stories.js +849 -0
  209. package/dist/esm/stories/ResourceList.stories.js +1038 -0
  210. package/dist/esm/stories/Select.stories.js +363 -0
  211. package/dist/esm/stories/SkeletonText.stories.js +718 -0
  212. package/dist/esm/stories/Spinner.stories.js +362 -0
  213. package/dist/esm/stories/Stack.stories.js +1338 -0
  214. package/dist/esm/stories/Table.stories.js +584 -0
  215. package/dist/esm/stories/Tabs.stories.js +684 -0
  216. package/dist/esm/stories/Tag.stories.js +581 -0
  217. package/dist/esm/stories/Text.stories.js +217 -0
  218. package/dist/esm/stories/TextField.stories.js +332 -0
  219. package/dist/esm/stories/Thumbnail.stories.js +810 -0
  220. package/dist/esm/stories/TimePicker.stories.js +911 -0
  221. package/dist/esm/stories/Tip.stories.js +706 -0
  222. package/dist/esm/stories/Tooltip.stories.js +313 -0
  223. package/dist/esm/stories/TopBar.stories.js +116 -0
  224. package/dist/esm/stories/VerticalStack.stories.js +1240 -0
  225. package/dist/esm/tailwind.config.js +7 -0
  226. package/dist/esm/utilities/transformers.js +47 -0
  227. package/dist/esm/vite.config.js +20 -0
  228. package/dist/types/components/ActionList.d.ts +122 -0
  229. package/dist/types/components/ActionList.d.ts.map +1 -0
  230. package/dist/types/components/AnnouncementBar.d.ts +21 -0
  231. package/dist/types/components/AnnouncementBar.d.ts.map +1 -0
  232. package/dist/types/components/AppProvider.d.ts +61 -0
  233. package/dist/types/components/AppProvider.d.ts.map +1 -0
  234. package/dist/types/components/Autocomplete.d.ts +135 -0
  235. package/dist/types/components/Autocomplete.d.ts.map +1 -0
  236. package/dist/types/components/Badge.d.ts +21 -0
  237. package/dist/types/components/Badge.d.ts.map +1 -0
  238. package/dist/types/components/Banner.d.ts +78 -0
  239. package/dist/types/components/Banner.d.ts.map +1 -0
  240. package/dist/types/components/Box.d.ts +70 -0
  241. package/dist/types/components/Box.d.ts.map +1 -0
  242. package/dist/types/components/Button.d.ts +133 -0
  243. package/dist/types/components/Button.d.ts.map +1 -0
  244. package/dist/types/components/ButtonGroup.d.ts +26 -0
  245. package/dist/types/components/ButtonGroup.d.ts.map +1 -0
  246. package/dist/types/components/Card.d.ts +141 -0
  247. package/dist/types/components/Card.d.ts.map +1 -0
  248. package/dist/types/components/Checkbox.d.ts +56 -0
  249. package/dist/types/components/Checkbox.d.ts.map +1 -0
  250. package/dist/types/components/ChoiceList.d.ts +69 -0
  251. package/dist/types/components/ChoiceList.d.ts.map +1 -0
  252. package/dist/types/components/Collapsible.d.ts +17 -0
  253. package/dist/types/components/Collapsible.d.ts.map +1 -0
  254. package/dist/types/components/ColorField.d.ts +36 -0
  255. package/dist/types/components/ColorField.d.ts.map +1 -0
  256. package/dist/types/components/ContextualSaveBar.d.ts +22 -0
  257. package/dist/types/components/ContextualSaveBar.d.ts.map +1 -0
  258. package/dist/types/components/DatePicker.d.ts +66 -0
  259. package/dist/types/components/DatePicker.d.ts.map +1 -0
  260. package/dist/types/components/Divider.d.ts +21 -0
  261. package/dist/types/components/Divider.d.ts.map +1 -0
  262. package/dist/types/components/DropZone.d.ts +108 -0
  263. package/dist/types/components/DropZone.d.ts.map +1 -0
  264. package/dist/types/components/EmptyState.d.ts +52 -0
  265. package/dist/types/components/EmptyState.d.ts.map +1 -0
  266. package/dist/types/components/Filters.d.ts +168 -0
  267. package/dist/types/components/Filters.d.ts.map +1 -0
  268. package/dist/types/components/FooterHelp.d.ts +21 -0
  269. package/dist/types/components/FooterHelp.d.ts.map +1 -0
  270. package/dist/types/components/Form.d.ts +39 -0
  271. package/dist/types/components/Form.d.ts.map +1 -0
  272. package/dist/types/components/Frame.d.ts +51 -0
  273. package/dist/types/components/Frame.d.ts.map +1 -0
  274. package/dist/types/components/FrameSaveBar.d.ts +8 -0
  275. package/dist/types/components/FrameSaveBar.d.ts.map +1 -0
  276. package/dist/types/components/Grid.d.ts +39 -0
  277. package/dist/types/components/Grid.d.ts.map +1 -0
  278. package/dist/types/components/HorizontalStack.d.ts +36 -0
  279. package/dist/types/components/HorizontalStack.d.ts.map +1 -0
  280. package/dist/types/components/Icon.d.ts +43 -0
  281. package/dist/types/components/Icon.d.ts.map +1 -0
  282. package/dist/types/components/Image.d.ts +45 -0
  283. package/dist/types/components/Image.d.ts.map +1 -0
  284. package/dist/types/components/InlineError.d.ts +22 -0
  285. package/dist/types/components/InlineError.d.ts.map +1 -0
  286. package/dist/types/components/Label.d.ts +28 -0
  287. package/dist/types/components/Label.d.ts.map +1 -0
  288. package/dist/types/components/Layout.d.ts +44 -0
  289. package/dist/types/components/Layout.d.ts.map +1 -0
  290. package/dist/types/components/LayoutSection.d.ts +24 -0
  291. package/dist/types/components/LayoutSection.d.ts.map +1 -0
  292. package/dist/types/components/Link.d.ts +38 -0
  293. package/dist/types/components/Link.d.ts.map +1 -0
  294. package/dist/types/components/List.d.ts +33 -0
  295. package/dist/types/components/List.d.ts.map +1 -0
  296. package/dist/types/components/Listbox.d.ts +34 -0
  297. package/dist/types/components/Listbox.d.ts.map +1 -0
  298. package/dist/types/components/Loading.d.ts +13 -0
  299. package/dist/types/components/Loading.d.ts.map +1 -0
  300. package/dist/types/components/Modal.d.ts +75 -0
  301. package/dist/types/components/Modal.d.ts.map +1 -0
  302. package/dist/types/components/Navigation.d.ts +105 -0
  303. package/dist/types/components/Navigation.d.ts.map +1 -0
  304. package/dist/types/components/Page.d.ts +59 -0
  305. package/dist/types/components/Page.d.ts.map +1 -0
  306. package/dist/types/components/Pagination.d.ts +39 -0
  307. package/dist/types/components/Pagination.d.ts.map +1 -0
  308. package/dist/types/components/Pane.d.ts +11 -0
  309. package/dist/types/components/Pane.d.ts.map +1 -0
  310. package/dist/types/components/Popover.d.ts +56 -0
  311. package/dist/types/components/Popover.d.ts.map +1 -0
  312. package/dist/types/components/PopoverManager.d.ts +3 -0
  313. package/dist/types/components/PopoverManager.d.ts.map +1 -0
  314. package/dist/types/components/ProgressBar.d.ts +24 -0
  315. package/dist/types/components/ProgressBar.d.ts.map +1 -0
  316. package/dist/types/components/RadioButton.d.ts +39 -0
  317. package/dist/types/components/RadioButton.d.ts.map +1 -0
  318. package/dist/types/components/RadioButtonCard.d.ts +41 -0
  319. package/dist/types/components/RadioButtonCard.d.ts.map +1 -0
  320. package/dist/types/components/RangeSlider.d.ts +44 -0
  321. package/dist/types/components/RangeSlider.d.ts.map +1 -0
  322. package/dist/types/components/ResourceList.d.ts +54 -0
  323. package/dist/types/components/ResourceList.d.ts.map +1 -0
  324. package/dist/types/components/Select.d.ts +48 -0
  325. package/dist/types/components/Select.d.ts.map +1 -0
  326. package/dist/types/components/SkeletonText.d.ts +28 -0
  327. package/dist/types/components/SkeletonText.d.ts.map +1 -0
  328. package/dist/types/components/Spinner.d.ts +18 -0
  329. package/dist/types/components/Spinner.d.ts.map +1 -0
  330. package/dist/types/components/Stack.d.ts +49 -0
  331. package/dist/types/components/Stack.d.ts.map +1 -0
  332. package/dist/types/components/Table.d.ts +197 -0
  333. package/dist/types/components/Table.d.ts.map +1 -0
  334. package/dist/types/components/Tabs.d.ts +43 -0
  335. package/dist/types/components/Tabs.d.ts.map +1 -0
  336. package/dist/types/components/Tag.d.ts +26 -0
  337. package/dist/types/components/Tag.d.ts.map +1 -0
  338. package/dist/types/components/Text.d.ts +32 -0
  339. package/dist/types/components/Text.d.ts.map +1 -0
  340. package/dist/types/components/TextField.d.ts +109 -0
  341. package/dist/types/components/TextField.d.ts.map +1 -0
  342. package/dist/types/components/Thumbnail.d.ts +18 -0
  343. package/dist/types/components/Thumbnail.d.ts.map +1 -0
  344. package/dist/types/components/TimePicker.d.ts +3 -0
  345. package/dist/types/components/TimePicker.d.ts.map +1 -0
  346. package/dist/types/components/Tip.d.ts +23 -0
  347. package/dist/types/components/Tip.d.ts.map +1 -0
  348. package/dist/types/components/Tooltip.d.ts +84 -0
  349. package/dist/types/components/Tooltip.d.ts.map +1 -0
  350. package/dist/types/components/TopBar.d.ts +43 -0
  351. package/dist/types/components/TopBar.d.ts.map +1 -0
  352. package/dist/types/components/VerticalStack.d.ts +27 -0
  353. package/dist/types/components/VerticalStack.d.ts.map +1 -0
  354. package/dist/types/index.d.ts +63 -0
  355. package/dist/types/index.d.ts.map +1 -0
  356. package/dist/types/styles/Table.d.ts +1570 -0
  357. package/dist/types/styles/Table.d.ts.map +1 -0
  358. package/dist/types/utilities/dates.d.ts +46 -0
  359. package/dist/types/utilities/dates.d.ts.map +1 -0
  360. package/dist/types/utilities/transformers.d.ts +4 -0
  361. package/dist/types/utilities/transformers.d.ts.map +1 -0
  362. package/dist/types/utilities/useIndexResourceState.d.ts +21 -0
  363. package/dist/types/utilities/useIndexResourceState.d.ts.map +1 -0
  364. package/dist/types/utilities/useMounted.d.ts +2 -0
  365. package/dist/types/utilities/useMounted.d.ts.map +1 -0
  366. package/dist/types/utilities/useTableScrollState.d.ts +29 -0
  367. package/dist/types/utilities/useTableScrollState.d.ts.map +1 -0
  368. package/index.css +17 -0
  369. package/package.json +38 -7
@@ -0,0 +1,1550 @@
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 CustomLayout () {
13
+ return CustomLayout;
14
+ },
15
+ get Default () {
16
+ return Default;
17
+ },
18
+ get DetailViewPane () {
19
+ return DetailViewPane;
20
+ },
21
+ get FormPane () {
22
+ return FormPane;
23
+ },
24
+ get StackedPanes () {
25
+ return StackedPanes;
26
+ },
27
+ get WithActions () {
28
+ return WithActions;
29
+ },
30
+ get default () {
31
+ return _default;
32
+ }
33
+ });
34
+ var _jsxruntime = require("react/jsx-runtime");
35
+ var _react = require("react");
36
+ var _transformers = require("../utilities/transformers.js");
37
+ var _Stack = /*#__PURE__*/ _interop_require_default(require("../components/Stack.js"));
38
+ var _Pane = /*#__PURE__*/ _interop_require_default(require("../components/Pane.js"));
39
+ var _Text = /*#__PURE__*/ _interop_require_default(require("../components/Text.js"));
40
+ var _Card = /*#__PURE__*/ _interop_require_default(require("../components/Card.js"));
41
+ var _Button = /*#__PURE__*/ _interop_require_default(require("../components/Button.js"));
42
+ var _TextField = /*#__PURE__*/ _interop_require_default(require("../components/TextField.js"));
43
+ var _Page = /*#__PURE__*/ _interop_require_default(require("../components/Page.js"));
44
+ var _Box = /*#__PURE__*/ _interop_require_default(require("../components/Box.js"));
45
+ var _polarisicons = require("@shopify/polaris-icons");
46
+ function _array_like_to_array(arr, len) {
47
+ if (len == null || len > arr.length) len = arr.length;
48
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
49
+ return arr2;
50
+ }
51
+ function _array_with_holes(arr) {
52
+ if (Array.isArray(arr)) return arr;
53
+ }
54
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
55
+ try {
56
+ var info = gen[key](arg);
57
+ var value = info.value;
58
+ } catch (error) {
59
+ reject(error);
60
+ return;
61
+ }
62
+ if (info.done) {
63
+ resolve(value);
64
+ } else {
65
+ Promise.resolve(value).then(_next, _throw);
66
+ }
67
+ }
68
+ function _async_to_generator(fn) {
69
+ return function() {
70
+ var self = this, args = arguments;
71
+ return new Promise(function(resolve, reject) {
72
+ var gen = fn.apply(self, args);
73
+ function _next(value) {
74
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
75
+ }
76
+ function _throw(err) {
77
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
78
+ }
79
+ _next(undefined);
80
+ });
81
+ };
82
+ }
83
+ function _define_property(obj, key, value) {
84
+ if (key in obj) {
85
+ Object.defineProperty(obj, key, {
86
+ value: value,
87
+ enumerable: true,
88
+ configurable: true,
89
+ writable: true
90
+ });
91
+ } else {
92
+ obj[key] = value;
93
+ }
94
+ return obj;
95
+ }
96
+ function _interop_require_default(obj) {
97
+ return obj && obj.__esModule ? obj : {
98
+ default: obj
99
+ };
100
+ }
101
+ function _iterable_to_array_limit(arr, i) {
102
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
103
+ if (_i == null) return;
104
+ var _arr = [];
105
+ var _n = true;
106
+ var _d = false;
107
+ var _s, _e;
108
+ try {
109
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
110
+ _arr.push(_s.value);
111
+ if (i && _arr.length === i) break;
112
+ }
113
+ } catch (err) {
114
+ _d = true;
115
+ _e = err;
116
+ } finally{
117
+ try {
118
+ if (!_n && _i["return"] != null) _i["return"]();
119
+ } finally{
120
+ if (_d) throw _e;
121
+ }
122
+ }
123
+ return _arr;
124
+ }
125
+ function _non_iterable_rest() {
126
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
127
+ }
128
+ function _object_spread(target) {
129
+ for(var i = 1; i < arguments.length; i++){
130
+ var source = arguments[i] != null ? arguments[i] : {};
131
+ var ownKeys = Object.keys(source);
132
+ if (typeof Object.getOwnPropertySymbols === "function") {
133
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
134
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
135
+ }));
136
+ }
137
+ ownKeys.forEach(function(key) {
138
+ _define_property(target, key, source[key]);
139
+ });
140
+ }
141
+ return target;
142
+ }
143
+ function ownKeys(object, enumerableOnly) {
144
+ var keys = Object.keys(object);
145
+ if (Object.getOwnPropertySymbols) {
146
+ var symbols = Object.getOwnPropertySymbols(object);
147
+ if (enumerableOnly) {
148
+ symbols = symbols.filter(function(sym) {
149
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
150
+ });
151
+ }
152
+ keys.push.apply(keys, symbols);
153
+ }
154
+ return keys;
155
+ }
156
+ function _object_spread_props(target, source) {
157
+ source = source != null ? source : {};
158
+ if (Object.getOwnPropertyDescriptors) {
159
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
160
+ } else {
161
+ ownKeys(Object(source)).forEach(function(key) {
162
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
163
+ });
164
+ }
165
+ return target;
166
+ }
167
+ function _sliced_to_array(arr, i) {
168
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
169
+ }
170
+ function _unsupported_iterable_to_array(o, minLen) {
171
+ if (!o) return;
172
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
173
+ var n = Object.prototype.toString.call(o).slice(8, -1);
174
+ if (n === "Object" && o.constructor) n = o.constructor.name;
175
+ if (n === "Map" || n === "Set") return Array.from(n);
176
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
177
+ }
178
+ function _ts_generator(thisArg, body) {
179
+ var f, y, t, _ = {
180
+ label: 0,
181
+ sent: function() {
182
+ if (t[0] & 1) throw t[1];
183
+ return t[1];
184
+ },
185
+ trys: [],
186
+ ops: []
187
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
188
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
189
+ return this;
190
+ }), g;
191
+ function verb(n) {
192
+ return function(v) {
193
+ return step([
194
+ n,
195
+ v
196
+ ]);
197
+ };
198
+ }
199
+ function step(op) {
200
+ if (f) throw new TypeError("Generator is already executing.");
201
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
202
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
203
+ if (y = 0, t) op = [
204
+ op[0] & 2,
205
+ t.value
206
+ ];
207
+ switch(op[0]){
208
+ case 0:
209
+ case 1:
210
+ t = op;
211
+ break;
212
+ case 4:
213
+ _.label++;
214
+ return {
215
+ value: op[1],
216
+ done: false
217
+ };
218
+ case 5:
219
+ _.label++;
220
+ y = op[1];
221
+ op = [
222
+ 0
223
+ ];
224
+ continue;
225
+ case 7:
226
+ op = _.ops.pop();
227
+ _.trys.pop();
228
+ continue;
229
+ default:
230
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
231
+ _ = 0;
232
+ continue;
233
+ }
234
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
235
+ _.label = op[1];
236
+ break;
237
+ }
238
+ if (op[0] === 6 && _.label < t[1]) {
239
+ _.label = t[1];
240
+ t = op;
241
+ break;
242
+ }
243
+ if (t && _.label < t[2]) {
244
+ _.label = t[2];
245
+ _.ops.push(op);
246
+ break;
247
+ }
248
+ if (t[2]) _.ops.pop();
249
+ _.trys.pop();
250
+ continue;
251
+ }
252
+ op = body.call(thisArg, _);
253
+ } catch (e) {
254
+ op = [
255
+ 6,
256
+ e
257
+ ];
258
+ y = 0;
259
+ } finally{
260
+ f = t = 0;
261
+ }
262
+ if (op[0] & 5) throw op[1];
263
+ return {
264
+ value: op[0] ? op[1] : void 0,
265
+ done: true
266
+ };
267
+ }
268
+ }
269
+ var _default = {
270
+ title: 'Litho/Pane',
271
+ component: _Pane.default,
272
+ parameters: {
273
+ layout: 'fullscreen',
274
+ docs: {
275
+ description: {
276
+ component: "A Pane component that provides a slide-out panel interface, typically used on the right side of the screen. It includes header, content, and footer sections with support for actions and close functionality."
277
+ },
278
+ source: {
279
+ transform: _transformers.transformStorySource
280
+ }
281
+ }
282
+ },
283
+ tags: [
284
+ 'autodocs'
285
+ ],
286
+ argTypes: {
287
+ open: {
288
+ control: 'boolean',
289
+ description: 'Whether the pane is open'
290
+ },
291
+ onClose: {
292
+ control: false,
293
+ description: 'Callback when the pane is closed'
294
+ },
295
+ children: {
296
+ control: false,
297
+ description: 'Content to render inside the pane'
298
+ }
299
+ }
300
+ };
301
+ var Default = {
302
+ render: function(args) {
303
+ var _useState = _sliced_to_array((0, _react.useState)(false), 2), paneOpen = _useState[0], setPaneOpen = _useState[1];
304
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Page.default, {
305
+ title: "Pane Demo",
306
+ children: [
307
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Card.default, {
308
+ title: "Basic Pane Example",
309
+ padded: true,
310
+ children: [
311
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
312
+ paddingBlockEnd: "4",
313
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
314
+ children: "Click the button below to open a basic pane with header, content, and footer sections."
315
+ })
316
+ }),
317
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
318
+ primary: true,
319
+ onClick: function() {
320
+ return setPaneOpen(true);
321
+ },
322
+ children: "Open Pane"
323
+ })
324
+ ]
325
+ }),
326
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Pane.default, {
327
+ open: paneOpen,
328
+ onClose: function() {
329
+ return setPaneOpen(false);
330
+ },
331
+ children: [
332
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Header, {
333
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
334
+ variant: "headingMd",
335
+ children: "Basic Pane"
336
+ })
337
+ }),
338
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Content, {
339
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
340
+ padding: "4",
341
+ children: [
342
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
343
+ paddingBlockEnd: "4",
344
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
345
+ children: "This is the content area of the pane. You can put any content here, including forms, lists, or other components."
346
+ })
347
+ }),
348
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
349
+ children: "The pane can be closed by clicking the close button in the header, pressing the Escape key, or programmatically."
350
+ })
351
+ ]
352
+ })
353
+ }),
354
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Footer, {
355
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
356
+ padding: "4",
357
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
358
+ horizontal: true,
359
+ gap: "md",
360
+ align: "end",
361
+ children: [
362
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
363
+ onClick: function() {
364
+ return setPaneOpen(false);
365
+ },
366
+ children: "Cancel"
367
+ }),
368
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
369
+ primary: true,
370
+ onClick: function() {
371
+ return setPaneOpen(false);
372
+ },
373
+ children: "Save"
374
+ })
375
+ ]
376
+ })
377
+ })
378
+ })
379
+ ]
380
+ })
381
+ ]
382
+ });
383
+ }
384
+ };
385
+ var WithActions = {
386
+ render: function() {
387
+ var _useState = _sliced_to_array((0, _react.useState)(false), 2), paneOpen = _useState[0], setPaneOpen = _useState[1];
388
+ var headerActions = [
389
+ {
390
+ icon: _polarisicons.EditMajor,
391
+ onAction: function() {
392
+ return alert('Edit action clicked');
393
+ },
394
+ tooltip: 'Edit item'
395
+ },
396
+ {
397
+ icon: _polarisicons.ShareIosMinor,
398
+ onAction: function() {
399
+ return alert('Share action clicked');
400
+ },
401
+ tooltip: 'Share item'
402
+ },
403
+ {
404
+ icon: _polarisicons.DeleteMajor,
405
+ onAction: function() {
406
+ return alert('Delete action clicked');
407
+ },
408
+ tooltip: 'Delete item',
409
+ destructive: true
410
+ }
411
+ ];
412
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Page.default, {
413
+ title: "Pane with Actions",
414
+ children: [
415
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Card.default, {
416
+ title: "Pane with Header Actions",
417
+ padded: true,
418
+ children: [
419
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
420
+ paddingBlockEnd: "4",
421
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
422
+ children: "This example shows a pane with action buttons in the header alongside the close button."
423
+ })
424
+ }),
425
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
426
+ primary: true,
427
+ onClick: function() {
428
+ return setPaneOpen(true);
429
+ },
430
+ children: "Open Pane with Actions"
431
+ })
432
+ ]
433
+ }),
434
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Pane.default, {
435
+ open: paneOpen,
436
+ onClose: function() {
437
+ return setPaneOpen(false);
438
+ },
439
+ children: [
440
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Header, {
441
+ actions: headerActions,
442
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
443
+ variant: "headingMd",
444
+ children: "Product Details"
445
+ })
446
+ }),
447
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Content, {
448
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
449
+ padding: "4",
450
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
451
+ gap: "md",
452
+ children: [
453
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
454
+ children: [
455
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
456
+ paddingBlockEnd: "2",
457
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
458
+ variant: "headingSm",
459
+ children: "Product Name"
460
+ })
461
+ }),
462
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
463
+ children: "Awesome Product"
464
+ })
465
+ ]
466
+ }),
467
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
468
+ children: [
469
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
470
+ paddingBlockEnd: "2",
471
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
472
+ variant: "headingSm",
473
+ children: "Description"
474
+ })
475
+ }),
476
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
477
+ children: "This is a detailed description of the awesome product. It has many great features and benefits that customers will love."
478
+ })
479
+ ]
480
+ }),
481
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
482
+ children: [
483
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
484
+ paddingBlockEnd: "2",
485
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
486
+ variant: "headingSm",
487
+ children: "Price"
488
+ })
489
+ }),
490
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
491
+ variant: "headingLg",
492
+ children: "$99.99"
493
+ })
494
+ ]
495
+ }),
496
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
497
+ children: [
498
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
499
+ paddingBlockEnd: "2",
500
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
501
+ variant: "headingSm",
502
+ children: "Status"
503
+ })
504
+ }),
505
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
506
+ as: "span",
507
+ padding: "1",
508
+ borderRadius: "1",
509
+ background: "bg-success-subdued",
510
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
511
+ variant: "bodySm",
512
+ tone: "success",
513
+ children: "Active"
514
+ })
515
+ })
516
+ ]
517
+ })
518
+ ]
519
+ })
520
+ })
521
+ }),
522
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Footer, {
523
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
524
+ padding: "4",
525
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
526
+ horizontal: true,
527
+ gap: "md",
528
+ align: "space-between",
529
+ children: [
530
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
531
+ variant: "bodySm",
532
+ color: "subdued",
533
+ children: "Last updated: 2 hours ago"
534
+ }),
535
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
536
+ horizontal: true,
537
+ gap: "md",
538
+ children: [
539
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
540
+ onClick: function() {
541
+ return setPaneOpen(false);
542
+ },
543
+ children: "Close"
544
+ }),
545
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
546
+ primary: true,
547
+ onClick: function() {
548
+ return alert('Changes saved!');
549
+ },
550
+ children: "Save Changes"
551
+ })
552
+ ]
553
+ })
554
+ ]
555
+ })
556
+ })
557
+ })
558
+ ]
559
+ })
560
+ ]
561
+ });
562
+ },
563
+ parameters: {
564
+ docs: {
565
+ description: {
566
+ story: 'Pane with action buttons in the header for common operations like edit, share, and delete.'
567
+ }
568
+ }
569
+ }
570
+ };
571
+ var FormPane = {
572
+ render: function() {
573
+ var _useState = _sliced_to_array((0, _react.useState)(false), 2), paneOpen = _useState[0], setPaneOpen = _useState[1];
574
+ var _useState1 = _sliced_to_array((0, _react.useState)({
575
+ name: '',
576
+ email: '',
577
+ phone: '',
578
+ company: '',
579
+ notes: ''
580
+ }), 2), formData = _useState1[0], setFormData = _useState1[1];
581
+ var _useState2 = _sliced_to_array((0, _react.useState)(false), 2), loading = _useState2[0], setLoading = _useState2[1];
582
+ var handleSave = function() {
583
+ return _async_to_generator(function() {
584
+ return _ts_generator(this, function(_state) {
585
+ switch(_state.label){
586
+ case 0:
587
+ setLoading(true);
588
+ // Simulate API call
589
+ return [
590
+ 4,
591
+ new Promise(function(resolve) {
592
+ return setTimeout(resolve, 2000);
593
+ })
594
+ ];
595
+ case 1:
596
+ _state.sent();
597
+ setLoading(false);
598
+ setPaneOpen(false);
599
+ alert('Contact saved successfully!');
600
+ return [
601
+ 2
602
+ ];
603
+ }
604
+ });
605
+ })();
606
+ };
607
+ var handleFieldChange = function(field, value) {
608
+ setFormData(function(prev) {
609
+ return _object_spread_props(_object_spread({}, prev), _define_property({}, field, value));
610
+ });
611
+ };
612
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Page.default, {
613
+ title: "Form in Pane",
614
+ children: [
615
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Card.default, {
616
+ title: "Contact Form Example",
617
+ padded: true,
618
+ children: [
619
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
620
+ paddingBlockEnd: "4",
621
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
622
+ children: "This example shows how to use a pane for forms, providing a focused editing experience."
623
+ })
624
+ }),
625
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
626
+ primary: true,
627
+ onClick: function() {
628
+ return setPaneOpen(true);
629
+ },
630
+ children: "Add New Contact"
631
+ })
632
+ ]
633
+ }),
634
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Pane.default, {
635
+ open: paneOpen,
636
+ onClose: function() {
637
+ return setPaneOpen(false);
638
+ },
639
+ children: [
640
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Header, {
641
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
642
+ variant: "headingMd",
643
+ children: "Add New Contact"
644
+ })
645
+ }),
646
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Content, {
647
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
648
+ padding: "4",
649
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
650
+ gap: "md",
651
+ children: [
652
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
653
+ label: "Full Name",
654
+ value: formData.name,
655
+ onChange: function(value) {
656
+ return handleFieldChange('name', value);
657
+ },
658
+ placeholder: "Enter full name"
659
+ }),
660
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
661
+ label: "Email Address",
662
+ type: "email",
663
+ value: formData.email,
664
+ onChange: function(value) {
665
+ return handleFieldChange('email', value);
666
+ },
667
+ placeholder: "Enter email address"
668
+ }),
669
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
670
+ label: "Phone Number",
671
+ type: "tel",
672
+ value: formData.phone,
673
+ onChange: function(value) {
674
+ return handleFieldChange('phone', value);
675
+ },
676
+ placeholder: "Enter phone number"
677
+ }),
678
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
679
+ label: "Company",
680
+ value: formData.company,
681
+ onChange: function(value) {
682
+ return handleFieldChange('company', value);
683
+ },
684
+ placeholder: "Enter company name"
685
+ }),
686
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_TextField.default, {
687
+ label: "Notes",
688
+ value: formData.notes,
689
+ onChange: function(value) {
690
+ return handleFieldChange('notes', value);
691
+ },
692
+ multiline: 4,
693
+ placeholder: "Add any additional notes..."
694
+ })
695
+ ]
696
+ })
697
+ })
698
+ }),
699
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Footer, {
700
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
701
+ padding: "4",
702
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
703
+ horizontal: true,
704
+ gap: "md",
705
+ align: "end",
706
+ children: [
707
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
708
+ onClick: function() {
709
+ return setPaneOpen(false);
710
+ },
711
+ disabled: loading,
712
+ children: "Cancel"
713
+ }),
714
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
715
+ primary: true,
716
+ onClick: handleSave,
717
+ loading: loading,
718
+ disabled: !formData.name || !formData.email,
719
+ children: loading ? 'Saving...' : 'Save Contact'
720
+ })
721
+ ]
722
+ })
723
+ })
724
+ })
725
+ ]
726
+ })
727
+ ]
728
+ });
729
+ },
730
+ parameters: {
731
+ docs: {
732
+ description: {
733
+ story: 'Pane containing a form for creating or editing data with validation and loading states.'
734
+ }
735
+ }
736
+ }
737
+ };
738
+ var DetailViewPane = {
739
+ render: function() {
740
+ var _useState = _sliced_to_array((0, _react.useState)(false), 2), paneOpen = _useState[0], setPaneOpen = _useState[1];
741
+ var _useState1 = _sliced_to_array((0, _react.useState)(null), 2), selectedOrder = _useState1[0], setSelectedOrder = _useState1[1];
742
+ var orders = [
743
+ {
744
+ id: 'ORD-001',
745
+ customer: 'John Smith',
746
+ date: '2024-01-15',
747
+ total: '$234.50',
748
+ status: 'Shipped',
749
+ items: [
750
+ {
751
+ name: 'Wireless Headphones',
752
+ quantity: 1,
753
+ price: '$159.99'
754
+ },
755
+ {
756
+ name: 'Phone Case',
757
+ quantity: 2,
758
+ price: '$24.99'
759
+ },
760
+ {
761
+ name: 'Screen Protector',
762
+ quantity: 1,
763
+ price: '$12.99'
764
+ }
765
+ ],
766
+ shipping: {
767
+ address: '123 Main St, Anytown, ST 12345',
768
+ method: 'Standard Shipping',
769
+ tracking: 'TRK123456789'
770
+ }
771
+ },
772
+ {
773
+ id: 'ORD-002',
774
+ customer: 'Sarah Johnson',
775
+ date: '2024-01-16',
776
+ total: '$89.99',
777
+ status: 'Processing',
778
+ items: [
779
+ {
780
+ name: 'Bluetooth Speaker',
781
+ quantity: 1,
782
+ price: '$89.99'
783
+ }
784
+ ],
785
+ shipping: {
786
+ address: '456 Oak Ave, Another City, ST 67890',
787
+ method: 'Express Shipping',
788
+ tracking: null
789
+ }
790
+ }
791
+ ];
792
+ var handleViewOrder = function(order) {
793
+ setSelectedOrder(order);
794
+ setPaneOpen(true);
795
+ };
796
+ var headerActions = selectedOrder ? [
797
+ {
798
+ icon: _polarisicons.EditMajor,
799
+ onAction: function() {
800
+ return alert('Edit order functionality');
801
+ },
802
+ tooltip: 'Edit order'
803
+ },
804
+ {
805
+ icon: _polarisicons.DuplicateMinor,
806
+ onAction: function() {
807
+ return alert('Duplicate order functionality');
808
+ },
809
+ tooltip: 'Duplicate order'
810
+ }
811
+ ] : [];
812
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Page.default, {
813
+ title: "Order Management",
814
+ children: [
815
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
816
+ title: "Orders List",
817
+ padded: true,
818
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
819
+ gap: "sm",
820
+ children: orders.map(function(order) {
821
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
822
+ padding: "4",
823
+ borderWidth: "1",
824
+ borderColor: "border",
825
+ borderRadius: "1",
826
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
827
+ horizontal: true,
828
+ align: "space-between",
829
+ blockAlign: "center",
830
+ children: [
831
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
832
+ gap: "xs",
833
+ children: [
834
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
835
+ variant: "headingSm",
836
+ children: order.id
837
+ }),
838
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
839
+ variant: "bodySm",
840
+ color: "subdued",
841
+ children: [
842
+ order.customer,
843
+ " • ",
844
+ order.date,
845
+ " • ",
846
+ order.total
847
+ ]
848
+ })
849
+ ]
850
+ }),
851
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
852
+ horizontal: true,
853
+ gap: "md",
854
+ blockAlign: "center",
855
+ children: [
856
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
857
+ as: "span",
858
+ paddingInlineStart: "2",
859
+ paddingInlineEnd: "2",
860
+ paddingBlockStart: "1",
861
+ paddingBlockEnd: "1",
862
+ borderRadius: "1",
863
+ background: order.status === 'Shipped' ? 'bg-success-subdued' : 'bg-warning-subdued',
864
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
865
+ variant: "caption",
866
+ tone: order.status === 'Shipped' ? 'success' : 'warning',
867
+ children: order.status
868
+ })
869
+ }),
870
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
871
+ size: "slim",
872
+ onClick: function() {
873
+ return handleViewOrder(order);
874
+ },
875
+ children: "View Details"
876
+ })
877
+ ]
878
+ })
879
+ ]
880
+ })
881
+ }, order.id);
882
+ })
883
+ })
884
+ }),
885
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Pane.default, {
886
+ open: paneOpen,
887
+ onClose: function() {
888
+ return setPaneOpen(false);
889
+ },
890
+ children: [
891
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Header, {
892
+ actions: headerActions,
893
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
894
+ variant: "headingMd",
895
+ children: [
896
+ "Order ",
897
+ selectedOrder === null || selectedOrder === void 0 ? void 0 : selectedOrder.id
898
+ ]
899
+ })
900
+ }),
901
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Content, {
902
+ children: selectedOrder && /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
903
+ padding: "4",
904
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
905
+ gap: "lg",
906
+ children: [
907
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
908
+ children: [
909
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
910
+ paddingBlockEnd: "4",
911
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
912
+ variant: "headingSm",
913
+ children: "Order Information"
914
+ })
915
+ }),
916
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
917
+ as: "div",
918
+ display: "grid",
919
+ style: {
920
+ gridTemplateColumns: '1fr 1fr',
921
+ gap: '1rem'
922
+ },
923
+ children: [
924
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
925
+ gap: "xs",
926
+ children: [
927
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
928
+ variant: "bodySm",
929
+ color: "subdued",
930
+ children: "Customer"
931
+ }),
932
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
933
+ children: selectedOrder.customer
934
+ })
935
+ ]
936
+ }),
937
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
938
+ gap: "xs",
939
+ children: [
940
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
941
+ variant: "bodySm",
942
+ color: "subdued",
943
+ children: "Date"
944
+ }),
945
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
946
+ children: selectedOrder.date
947
+ })
948
+ ]
949
+ }),
950
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
951
+ gap: "xs",
952
+ children: [
953
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
954
+ variant: "bodySm",
955
+ color: "subdued",
956
+ children: "Total"
957
+ }),
958
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
959
+ variant: "headingSm",
960
+ children: selectedOrder.total
961
+ })
962
+ ]
963
+ }),
964
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
965
+ gap: "xs",
966
+ children: [
967
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
968
+ variant: "bodySm",
969
+ color: "subdued",
970
+ children: "Status"
971
+ }),
972
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
973
+ as: "span",
974
+ paddingInlineStart: "2",
975
+ paddingInlineEnd: "2",
976
+ paddingBlockStart: "1",
977
+ paddingBlockEnd: "1",
978
+ borderRadius: "1",
979
+ background: selectedOrder.status === 'Shipped' ? 'bg-success-subdued' : 'bg-warning-subdued',
980
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
981
+ variant: "caption",
982
+ tone: selectedOrder.status === 'Shipped' ? 'success' : 'warning',
983
+ children: selectedOrder.status
984
+ })
985
+ })
986
+ ]
987
+ })
988
+ ]
989
+ })
990
+ ]
991
+ }),
992
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
993
+ children: [
994
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
995
+ paddingBlockEnd: "4",
996
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
997
+ variant: "headingSm",
998
+ children: "Items Ordered"
999
+ })
1000
+ }),
1001
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
1002
+ gap: "sm",
1003
+ children: selectedOrder.items.map(function(item, index) {
1004
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1005
+ padding: "3",
1006
+ borderWidth: "1",
1007
+ borderColor: "border",
1008
+ borderRadius: "1",
1009
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1010
+ horizontal: true,
1011
+ align: "space-between",
1012
+ children: [
1013
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1014
+ gap: "xs",
1015
+ children: [
1016
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1017
+ children: item.name
1018
+ }),
1019
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Text.default, {
1020
+ variant: "bodySm",
1021
+ color: "subdued",
1022
+ children: [
1023
+ "Quantity: ",
1024
+ item.quantity
1025
+ ]
1026
+ })
1027
+ ]
1028
+ }),
1029
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1030
+ variant: "headingSm",
1031
+ children: item.price
1032
+ })
1033
+ ]
1034
+ })
1035
+ }, index);
1036
+ })
1037
+ })
1038
+ ]
1039
+ }),
1040
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
1041
+ children: [
1042
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1043
+ paddingBlockEnd: "4",
1044
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1045
+ variant: "headingSm",
1046
+ children: "Shipping Information"
1047
+ })
1048
+ }),
1049
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1050
+ gap: "sm",
1051
+ children: [
1052
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1053
+ gap: "xs",
1054
+ children: [
1055
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1056
+ variant: "bodySm",
1057
+ color: "subdued",
1058
+ children: "Address"
1059
+ }),
1060
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1061
+ children: selectedOrder.shipping.address
1062
+ })
1063
+ ]
1064
+ }),
1065
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1066
+ gap: "xs",
1067
+ children: [
1068
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1069
+ variant: "bodySm",
1070
+ color: "subdued",
1071
+ children: "Method"
1072
+ }),
1073
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1074
+ children: selectedOrder.shipping.method
1075
+ })
1076
+ ]
1077
+ }),
1078
+ selectedOrder.shipping.tracking && /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1079
+ gap: "xs",
1080
+ children: [
1081
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1082
+ variant: "bodySm",
1083
+ color: "subdued",
1084
+ children: "Tracking Number"
1085
+ }),
1086
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1087
+ children: selectedOrder.shipping.tracking
1088
+ })
1089
+ ]
1090
+ })
1091
+ ]
1092
+ })
1093
+ ]
1094
+ })
1095
+ ]
1096
+ })
1097
+ })
1098
+ }),
1099
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Footer, {
1100
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1101
+ padding: "4",
1102
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1103
+ horizontal: true,
1104
+ gap: "md",
1105
+ align: "end",
1106
+ children: [
1107
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1108
+ onClick: function() {
1109
+ return setPaneOpen(false);
1110
+ },
1111
+ children: "Close"
1112
+ }),
1113
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1114
+ primary: true,
1115
+ onClick: function() {
1116
+ return alert('Print order functionality');
1117
+ },
1118
+ children: "Print Order"
1119
+ })
1120
+ ]
1121
+ })
1122
+ })
1123
+ })
1124
+ ]
1125
+ })
1126
+ ]
1127
+ });
1128
+ },
1129
+ parameters: {
1130
+ docs: {
1131
+ description: {
1132
+ story: 'Pane used for displaying detailed views of list items with comprehensive information.'
1133
+ }
1134
+ }
1135
+ }
1136
+ };
1137
+ var StackedPanes = {
1138
+ render: function() {
1139
+ var _useState = _sliced_to_array((0, _react.useState)(false), 2), firstPaneOpen = _useState[0], setFirstPaneOpen = _useState[1];
1140
+ var _useState1 = _sliced_to_array((0, _react.useState)(false), 2), secondPaneOpen = _useState1[0], setSecondPaneOpen = _useState1[1];
1141
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Page.default, {
1142
+ title: "Stacked Panes",
1143
+ children: [
1144
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
1145
+ title: "Multiple Panes Example",
1146
+ padded: true,
1147
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1148
+ gap: "md",
1149
+ children: [
1150
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1151
+ children: "This example demonstrates how panes can be stacked when multiple levels of detail are needed."
1152
+ }),
1153
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1154
+ primary: true,
1155
+ onClick: function() {
1156
+ return setFirstPaneOpen(true);
1157
+ },
1158
+ children: "Open First Pane"
1159
+ })
1160
+ ]
1161
+ })
1162
+ }),
1163
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Pane.default, {
1164
+ open: firstPaneOpen,
1165
+ onClose: function() {
1166
+ return setFirstPaneOpen(false);
1167
+ },
1168
+ children: [
1169
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Header, {
1170
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1171
+ variant: "headingMd",
1172
+ children: "Categories"
1173
+ })
1174
+ }),
1175
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Content, {
1176
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1177
+ padding: "4",
1178
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1179
+ gap: "md",
1180
+ children: [
1181
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1182
+ children: "Select a category to view its details in a nested pane."
1183
+ }),
1184
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
1185
+ gap: "sm",
1186
+ children: [
1187
+ 'Electronics',
1188
+ 'Clothing',
1189
+ 'Books',
1190
+ 'Home & Garden'
1191
+ ].map(function(category) {
1192
+ return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1193
+ padding: "4",
1194
+ borderWidth: "1",
1195
+ borderColor: "border",
1196
+ borderRadius: "1",
1197
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1198
+ horizontal: true,
1199
+ align: "space-between",
1200
+ blockAlign: "center",
1201
+ children: [
1202
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1203
+ children: category
1204
+ }),
1205
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1206
+ size: "slim",
1207
+ onClick: function() {
1208
+ return setSecondPaneOpen(true);
1209
+ },
1210
+ children: "View Details"
1211
+ })
1212
+ ]
1213
+ })
1214
+ }, category);
1215
+ })
1216
+ })
1217
+ ]
1218
+ })
1219
+ })
1220
+ }),
1221
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Footer, {
1222
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1223
+ padding: "4",
1224
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Stack.default, {
1225
+ horizontal: true,
1226
+ gap: "md",
1227
+ align: "end",
1228
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1229
+ onClick: function() {
1230
+ return setFirstPaneOpen(false);
1231
+ },
1232
+ children: "Close"
1233
+ })
1234
+ })
1235
+ })
1236
+ })
1237
+ ]
1238
+ }),
1239
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Pane.default, {
1240
+ open: secondPaneOpen,
1241
+ onClose: function() {
1242
+ return setSecondPaneOpen(false);
1243
+ },
1244
+ children: [
1245
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Header, {
1246
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1247
+ variant: "headingMd",
1248
+ children: "Category Details"
1249
+ })
1250
+ }),
1251
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Content, {
1252
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1253
+ padding: "4",
1254
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1255
+ gap: "md",
1256
+ children: [
1257
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1258
+ children: "This is a nested pane showing detailed information about the selected category."
1259
+ }),
1260
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1261
+ gap: "md",
1262
+ children: [
1263
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1264
+ gap: "sm",
1265
+ children: [
1266
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1267
+ variant: "headingSm",
1268
+ children: "Category Name"
1269
+ }),
1270
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1271
+ children: "Electronics"
1272
+ })
1273
+ ]
1274
+ }),
1275
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1276
+ gap: "sm",
1277
+ children: [
1278
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1279
+ variant: "headingSm",
1280
+ children: "Description"
1281
+ }),
1282
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1283
+ children: "Consumer electronics including phones, computers, accessories, and gadgets."
1284
+ })
1285
+ ]
1286
+ }),
1287
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1288
+ gap: "sm",
1289
+ children: [
1290
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1291
+ variant: "headingSm",
1292
+ children: "Total Products"
1293
+ }),
1294
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1295
+ children: "1,234 products"
1296
+ })
1297
+ ]
1298
+ }),
1299
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1300
+ gap: "sm",
1301
+ children: [
1302
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1303
+ variant: "headingSm",
1304
+ children: "Popular Items"
1305
+ }),
1306
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1307
+ gap: "xs",
1308
+ children: [
1309
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1310
+ children: "• Smartphones"
1311
+ }),
1312
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1313
+ children: "• Laptops"
1314
+ }),
1315
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1316
+ children: "• Headphones"
1317
+ }),
1318
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1319
+ children: "• Tablets"
1320
+ })
1321
+ ]
1322
+ })
1323
+ ]
1324
+ })
1325
+ ]
1326
+ })
1327
+ ]
1328
+ })
1329
+ })
1330
+ }),
1331
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Footer, {
1332
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1333
+ padding: "4",
1334
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1335
+ horizontal: true,
1336
+ gap: "md",
1337
+ align: "end",
1338
+ children: [
1339
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1340
+ onClick: function() {
1341
+ return setSecondPaneOpen(false);
1342
+ },
1343
+ children: "Close"
1344
+ }),
1345
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1346
+ primary: true,
1347
+ onClick: function() {
1348
+ return alert('Edit category functionality');
1349
+ },
1350
+ children: "Edit Category"
1351
+ })
1352
+ ]
1353
+ })
1354
+ })
1355
+ })
1356
+ ]
1357
+ })
1358
+ ]
1359
+ });
1360
+ },
1361
+ parameters: {
1362
+ docs: {
1363
+ description: {
1364
+ story: 'Example of stacked panes for hierarchical navigation and detailed views.'
1365
+ }
1366
+ }
1367
+ }
1368
+ };
1369
+ var CustomLayout = {
1370
+ render: function() {
1371
+ var _useState = _sliced_to_array((0, _react.useState)(false), 2), paneOpen = _useState[0], setPaneOpen = _useState[1];
1372
+ return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Page.default, {
1373
+ title: "Custom Pane Layout",
1374
+ children: [
1375
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Card.default, {
1376
+ title: "Pane Customization",
1377
+ padded: true,
1378
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1379
+ gap: "md",
1380
+ children: [
1381
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1382
+ children: "This example shows a pane with custom header layout (no borders) and footer styling."
1383
+ }),
1384
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1385
+ primary: true,
1386
+ onClick: function() {
1387
+ return setPaneOpen(true);
1388
+ },
1389
+ children: "Open Custom Pane"
1390
+ })
1391
+ ]
1392
+ })
1393
+ }),
1394
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Pane.default, {
1395
+ open: paneOpen,
1396
+ onClose: function() {
1397
+ return setPaneOpen(false);
1398
+ },
1399
+ children: [
1400
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Pane.default.Header, {
1401
+ bottomBorder: false,
1402
+ showCloseButton: false,
1403
+ children: [
1404
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1405
+ horizontal: true,
1406
+ gap: "sm",
1407
+ blockAlign: "center",
1408
+ children: [
1409
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1410
+ as: "div",
1411
+ style: {
1412
+ width: '8px',
1413
+ height: '8px',
1414
+ borderRadius: '50%',
1415
+ backgroundColor: '#28a745'
1416
+ }
1417
+ }),
1418
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1419
+ variant: "headingMd",
1420
+ children: "Live Chat Support"
1421
+ })
1422
+ ]
1423
+ }),
1424
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1425
+ variant: "bodySm",
1426
+ color: "subdued",
1427
+ children: "Online"
1428
+ })
1429
+ ]
1430
+ }),
1431
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Content, {
1432
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Box.default, {
1433
+ padding: "4",
1434
+ style: {
1435
+ display: 'flex',
1436
+ flexDirection: 'column',
1437
+ gap: '1rem',
1438
+ height: '100%'
1439
+ },
1440
+ children: [
1441
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1442
+ gap: "md",
1443
+ style: {
1444
+ flex: 1
1445
+ },
1446
+ children: [
1447
+ /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
1448
+ style: {
1449
+ alignSelf: 'flex-start',
1450
+ padding: '0.75rem',
1451
+ backgroundColor: '#f0f0f0',
1452
+ borderRadius: '12px',
1453
+ maxWidth: '80%'
1454
+ },
1455
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1456
+ variant: "bodySm",
1457
+ children: "Hello! How can I help you today?"
1458
+ })
1459
+ }),
1460
+ /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
1461
+ style: {
1462
+ alignSelf: 'flex-end',
1463
+ padding: '0.75rem',
1464
+ backgroundColor: '#007bff',
1465
+ color: 'white',
1466
+ borderRadius: '12px',
1467
+ maxWidth: '80%'
1468
+ },
1469
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1470
+ variant: "bodySm",
1471
+ children: "I'm having trouble with my order"
1472
+ })
1473
+ }),
1474
+ /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
1475
+ style: {
1476
+ alignSelf: 'flex-start',
1477
+ padding: '0.75rem',
1478
+ backgroundColor: '#f0f0f0',
1479
+ borderRadius: '12px',
1480
+ maxWidth: '80%'
1481
+ },
1482
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1483
+ variant: "bodySm",
1484
+ children: "I'd be happy to help with your order. Can you provide your order number?"
1485
+ })
1486
+ })
1487
+ ]
1488
+ }),
1489
+ /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1490
+ horizontal: true,
1491
+ gap: "sm",
1492
+ children: [
1493
+ /*#__PURE__*/ (0, _jsxruntime.jsx)("input", {
1494
+ type: "text",
1495
+ placeholder: "Type your message...",
1496
+ style: {
1497
+ flex: 1,
1498
+ padding: '0.75rem',
1499
+ border: '1px solid #ccc',
1500
+ borderRadius: '20px',
1501
+ outline: 'none'
1502
+ }
1503
+ }),
1504
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1505
+ primary: true,
1506
+ children: "Send"
1507
+ })
1508
+ ]
1509
+ })
1510
+ ]
1511
+ })
1512
+ }),
1513
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Pane.default.Footer, {
1514
+ topBorder: false,
1515
+ children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Box.default, {
1516
+ padding: "4",
1517
+ children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(_Stack.default, {
1518
+ horizontal: true,
1519
+ gap: "md",
1520
+ align: "space-between",
1521
+ blockAlign: "center",
1522
+ children: [
1523
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Text.default, {
1524
+ variant: "bodySm",
1525
+ color: "subdued",
1526
+ children: "Agent: Sarah M. • Response time: <1 min"
1527
+ }),
1528
+ /*#__PURE__*/ (0, _jsxruntime.jsx)(_Button.default, {
1529
+ onClick: function() {
1530
+ return setPaneOpen(false);
1531
+ },
1532
+ children: "End Chat"
1533
+ })
1534
+ ]
1535
+ })
1536
+ })
1537
+ })
1538
+ ]
1539
+ })
1540
+ ]
1541
+ });
1542
+ },
1543
+ parameters: {
1544
+ docs: {
1545
+ description: {
1546
+ story: 'Pane with custom layout including no borders and specialized content like a chat interface.'
1547
+ }
1548
+ }
1549
+ }
1550
+ };