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