@heymantle/litho 0.0.2 → 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 (354) hide show
  1. package/README.md +1 -1
  2. package/dist/cjs/components/ActionList.js +50 -16
  3. package/dist/cjs/components/AnnouncementBar.js +10 -3
  4. package/dist/cjs/components/AppProvider.js +10 -1
  5. package/dist/cjs/components/Autocomplete.js +33 -11
  6. package/dist/cjs/components/Badge.js +2 -1
  7. package/dist/cjs/components/Banner.js +35 -31
  8. package/dist/cjs/components/Box.js +5 -3
  9. package/dist/cjs/components/Button.js +34 -12
  10. package/dist/cjs/components/Card.js +5 -45
  11. package/dist/cjs/components/Checkbox.js +16 -6
  12. package/dist/cjs/components/ChoiceList.js +7 -4
  13. package/dist/cjs/components/ColorField.js +8 -3
  14. package/dist/cjs/components/DatePicker.js +13 -8
  15. package/dist/cjs/components/DropZone.js +33 -18
  16. package/dist/cjs/components/EmptyState.js +15 -7
  17. package/dist/cjs/components/Filters.js +32 -20
  18. package/dist/cjs/components/FooterHelp.js +7 -2
  19. package/dist/cjs/components/Form.js +18 -3
  20. package/dist/cjs/components/Frame.js +40 -15
  21. package/dist/cjs/components/FrameSaveBar.js +21 -12
  22. package/dist/cjs/components/Layout.js +3 -3
  23. package/dist/cjs/components/LayoutSection.js +2 -2
  24. package/dist/cjs/components/Link.js +6 -2
  25. package/dist/cjs/components/List.js +1 -0
  26. package/dist/cjs/components/Listbox.js +9 -4
  27. package/dist/cjs/components/Modal.js +26 -17
  28. package/dist/cjs/components/Navigation.js +30 -20
  29. package/dist/cjs/components/Page.js +8 -3
  30. package/dist/cjs/components/Pagination.js +11 -4
  31. package/dist/cjs/components/Pane.js +118 -35
  32. package/dist/cjs/components/Popover.js +59 -6
  33. package/dist/cjs/components/RangeSlider.js +11 -4
  34. package/dist/cjs/components/ResourceList.js +9 -3
  35. package/dist/cjs/components/Select.js +2 -0
  36. package/dist/cjs/components/Table.js +32 -19
  37. package/dist/cjs/components/Text.js +8 -5
  38. package/dist/cjs/components/TextField.js +23 -13
  39. package/dist/cjs/components/Thumbnail.js +7 -2
  40. package/dist/cjs/components/TimePicker.js +7 -2
  41. package/dist/cjs/components/Tip.js +10 -4
  42. package/dist/cjs/components/Tooltip.js +16 -8
  43. package/dist/cjs/components/TopBar.js +17 -9
  44. package/dist/cjs/dev/verify-publish.js +102 -0
  45. package/dist/cjs/postcss.config.js +21 -0
  46. package/dist/cjs/stories/ActionList.stories.js +365 -0
  47. package/dist/cjs/stories/AnnouncementBar.stories.js +244 -0
  48. package/dist/cjs/stories/Autocomplete.stories.js +871 -0
  49. package/dist/cjs/stories/Badge.stories.js +183 -0
  50. package/dist/cjs/stories/Banner.stories.js +201 -0
  51. package/dist/cjs/stories/Box.stories.js +599 -0
  52. package/dist/cjs/stories/Button.stories.js +325 -0
  53. package/dist/cjs/stories/ButtonGroup.stories.js +404 -0
  54. package/dist/cjs/stories/Card.stories.js +278 -0
  55. package/dist/cjs/stories/Checkbox.stories.js +266 -0
  56. package/dist/cjs/stories/ChoiceList.stories.js +884 -0
  57. package/dist/cjs/stories/Collapsible.stories.js +905 -0
  58. package/dist/cjs/stories/ColorField.stories.js +883 -0
  59. package/dist/cjs/stories/ContextualSaveBar.stories.js +970 -0
  60. package/dist/cjs/stories/DatePicker.stories.js +584 -0
  61. package/dist/cjs/stories/Divider.stories.js +759 -0
  62. package/dist/cjs/stories/DropZone.stories.js +1205 -0
  63. package/dist/cjs/stories/EmptyState.stories.js +296 -0
  64. package/dist/cjs/stories/Filters.stories.js +1353 -0
  65. package/dist/cjs/stories/FooterHelp.stories.js +869 -0
  66. package/dist/cjs/stories/Form.stories.js +940 -0
  67. package/dist/cjs/stories/Grid.stories.js +1199 -0
  68. package/dist/cjs/stories/HorizontalStack.stories.js +1064 -0
  69. package/dist/cjs/stories/Icon.stories.js +596 -0
  70. package/dist/cjs/stories/Image.stories.js +883 -0
  71. package/dist/cjs/stories/InlineError.stories.js +710 -0
  72. package/dist/cjs/stories/Label.stories.js +665 -0
  73. package/dist/cjs/stories/Layout.stories.js +685 -0
  74. package/dist/cjs/stories/LayoutSection.stories.js +1267 -0
  75. package/dist/cjs/stories/Link.stories.js +423 -0
  76. package/dist/cjs/stories/List.stories.js +1031 -0
  77. package/dist/cjs/stories/Listbox.stories.js +820 -0
  78. package/dist/cjs/stories/Loading.stories.js +900 -0
  79. package/dist/cjs/stories/Modal.stories.js +363 -0
  80. package/dist/cjs/stories/Navigation.stories.js +605 -0
  81. package/dist/cjs/stories/Page.stories.js +318 -0
  82. package/dist/cjs/stories/Pagination.stories.js +438 -0
  83. package/dist/cjs/stories/Pane.stories.js +1535 -0
  84. package/dist/cjs/stories/Popover.stories.js +637 -0
  85. package/dist/cjs/stories/PopoverManager.stories.js +1225 -0
  86. package/dist/cjs/stories/ProgressBar.stories.js +506 -0
  87. package/dist/cjs/stories/RadioButton.stories.js +642 -0
  88. package/dist/cjs/stories/RadioButtonCard.stories.js +816 -0
  89. package/dist/cjs/stories/RangeSlider.stories.js +892 -0
  90. package/dist/cjs/stories/ResourceList.stories.js +1067 -0
  91. package/dist/cjs/stories/Select.stories.js +413 -0
  92. package/dist/cjs/stories/SkeletonText.stories.js +776 -0
  93. package/dist/cjs/stories/Spinner.stories.js +396 -0
  94. package/dist/cjs/stories/Table.stories.js +628 -0
  95. package/dist/cjs/stories/Tabs.stories.js +723 -0
  96. package/dist/cjs/stories/Tag.stories.js +620 -0
  97. package/dist/cjs/stories/Text.stories.js +262 -0
  98. package/dist/cjs/stories/TextField.stories.js +377 -0
  99. package/dist/cjs/stories/Thumbnail.stories.js +859 -0
  100. package/dist/cjs/stories/TimePicker.stories.js +966 -0
  101. package/dist/cjs/stories/Tip.stories.js +753 -0
  102. package/dist/cjs/stories/Tooltip.stories.js +357 -0
  103. package/dist/cjs/stories/TopBar.stories.js +155 -0
  104. package/dist/cjs/stories/VerticalStack.stories.js +1287 -0
  105. package/dist/cjs/tailwind.config.js +17 -0
  106. package/dist/cjs/utilities/transformers.js +66 -0
  107. package/dist/cjs/vite.config.js +35 -0
  108. package/dist/esm/components/ActionList.js +41 -12
  109. package/dist/esm/components/AnnouncementBar.js +3 -1
  110. package/dist/esm/components/AppProvider.js +10 -1
  111. package/dist/esm/components/Autocomplete.js +21 -4
  112. package/dist/esm/components/Badge.js +2 -2
  113. package/dist/esm/components/Banner.js +20 -21
  114. package/dist/esm/components/Box.js +5 -4
  115. package/dist/esm/components/Button.js +24 -7
  116. package/dist/esm/components/Card.js +5 -4
  117. package/dist/esm/components/Checkbox.js +6 -1
  118. package/dist/esm/components/ChoiceList.js +7 -4
  119. package/dist/esm/components/ColorField.js +1 -1
  120. package/dist/esm/components/DatePicker.js +6 -1
  121. package/dist/esm/components/DropZone.js +14 -4
  122. package/dist/esm/components/EmptyState.js +4 -1
  123. package/dist/esm/components/Filters.js +10 -3
  124. package/dist/esm/components/FooterHelp.js +1 -1
  125. package/dist/esm/components/Form.js +18 -3
  126. package/dist/esm/components/Frame.js +18 -6
  127. package/dist/esm/components/FrameSaveBar.js +10 -6
  128. package/dist/esm/components/InlineError.js +1 -1
  129. package/dist/esm/components/Layout.js +4 -4
  130. package/dist/esm/components/LayoutSection.js +2 -2
  131. package/dist/esm/components/Link.js +6 -2
  132. package/dist/esm/components/List.js +1 -0
  133. package/dist/esm/components/Listbox.js +4 -4
  134. package/dist/esm/components/Modal.js +8 -4
  135. package/dist/esm/components/Navigation.js +16 -11
  136. package/dist/esm/components/Page.js +9 -4
  137. package/dist/esm/components/Pagination.js +3 -1
  138. package/dist/esm/components/Pane.js +114 -36
  139. package/dist/esm/components/Popover.js +18 -6
  140. package/dist/esm/components/RangeSlider.js +3 -1
  141. package/dist/esm/components/ResourceList.js +2 -1
  142. package/dist/esm/components/Select.js +2 -0
  143. package/dist/esm/components/Table.js +16 -3
  144. package/dist/esm/components/Text.js +8 -6
  145. package/dist/esm/components/TextField.js +6 -1
  146. package/dist/esm/components/Thumbnail.js +1 -1
  147. package/dist/esm/components/TimePicker.js +1 -1
  148. package/dist/esm/components/Tip.js +3 -2
  149. package/dist/esm/components/Tooltip.js +4 -1
  150. package/dist/esm/components/TopBar.js +7 -4
  151. package/dist/esm/dev/verify-publish.js +93 -0
  152. package/dist/esm/postcss.config.js +6 -0
  153. package/dist/esm/stories/ActionList.stories.js +327 -0
  154. package/dist/esm/stories/AnnouncementBar.stories.js +212 -0
  155. package/dist/esm/stories/Autocomplete.stories.js +833 -0
  156. package/dist/esm/stories/Badge.stories.js +138 -0
  157. package/dist/esm/stories/Banner.stories.js +159 -0
  158. package/dist/esm/stories/Box.stories.js +558 -0
  159. package/dist/esm/stories/Button.stories.js +277 -0
  160. package/dist/esm/stories/ButtonGroup.stories.js +357 -0
  161. package/dist/esm/stories/Card.stories.js +240 -0
  162. package/dist/esm/stories/Checkbox.stories.js +219 -0
  163. package/dist/esm/stories/ChoiceList.stories.js +834 -0
  164. package/dist/esm/stories/Collapsible.stories.js +867 -0
  165. package/dist/esm/stories/ColorField.stories.js +842 -0
  166. package/dist/esm/stories/ContextualSaveBar.stories.js +938 -0
  167. package/dist/esm/stories/DatePicker.stories.js +537 -0
  168. package/dist/esm/stories/Divider.stories.js +715 -0
  169. package/dist/esm/stories/DropZone.stories.js +1161 -0
  170. package/dist/esm/stories/EmptyState.stories.js +246 -0
  171. package/dist/esm/stories/Filters.stories.js +1315 -0
  172. package/dist/esm/stories/FooterHelp.stories.js +813 -0
  173. package/dist/esm/stories/Form.stories.js +905 -0
  174. package/dist/esm/stories/Grid.stories.js +1152 -0
  175. package/dist/esm/stories/HorizontalStack.stories.js +1011 -0
  176. package/dist/esm/stories/Icon.stories.js +555 -0
  177. package/dist/esm/stories/Image.stories.js +836 -0
  178. package/dist/esm/stories/InlineError.stories.js +666 -0
  179. package/dist/esm/stories/Label.stories.js +612 -0
  180. package/dist/esm/stories/Layout.stories.js +647 -0
  181. package/dist/esm/stories/LayoutSection.stories.js +1226 -0
  182. package/dist/esm/stories/Link.stories.js +379 -0
  183. package/dist/esm/stories/List.stories.js +975 -0
  184. package/dist/esm/stories/Listbox.stories.js +776 -0
  185. package/dist/esm/stories/Loading.stories.js +850 -0
  186. package/dist/esm/stories/Modal.stories.js +322 -0
  187. package/dist/esm/stories/Navigation.stories.js +567 -0
  188. package/dist/esm/stories/Page.stories.js +276 -0
  189. package/dist/esm/stories/Pagination.stories.js +394 -0
  190. package/dist/esm/stories/Pane.stories.js +1497 -0
  191. package/dist/esm/stories/Popover.stories.js +605 -0
  192. package/dist/esm/stories/PopoverManager.stories.js +1193 -0
  193. package/dist/esm/stories/ProgressBar.stories.js +465 -0
  194. package/dist/esm/stories/RadioButton.stories.js +598 -0
  195. package/dist/esm/stories/RadioButtonCard.stories.js +772 -0
  196. package/dist/esm/stories/RangeSlider.stories.js +845 -0
  197. package/dist/esm/stories/ResourceList.stories.js +1029 -0
  198. package/dist/esm/stories/Select.stories.js +363 -0
  199. package/dist/esm/stories/SkeletonText.stories.js +717 -0
  200. package/dist/esm/stories/Spinner.stories.js +355 -0
  201. package/dist/esm/stories/Table.stories.js +584 -0
  202. package/dist/esm/stories/Tabs.stories.js +685 -0
  203. package/dist/esm/stories/Tag.stories.js +573 -0
  204. package/dist/esm/stories/Text.stories.js +217 -0
  205. package/dist/esm/stories/TextField.stories.js +332 -0
  206. package/dist/esm/stories/Thumbnail.stories.js +806 -0
  207. package/dist/esm/stories/TimePicker.stories.js +910 -0
  208. package/dist/esm/stories/Tip.stories.js +706 -0
  209. package/dist/esm/stories/Tooltip.stories.js +313 -0
  210. package/dist/esm/stories/TopBar.stories.js +114 -0
  211. package/dist/esm/stories/VerticalStack.stories.js +1240 -0
  212. package/dist/esm/tailwind.config.js +7 -0
  213. package/dist/esm/utilities/transformers.js +47 -0
  214. package/dist/esm/vite.config.js +20 -0
  215. package/dist/types/components/ActionList.d.ts +122 -0
  216. package/dist/types/components/ActionList.d.ts.map +1 -0
  217. package/dist/types/components/AnnouncementBar.d.ts +21 -0
  218. package/dist/types/components/AnnouncementBar.d.ts.map +1 -0
  219. package/dist/types/components/AppProvider.d.ts +61 -0
  220. package/dist/types/components/AppProvider.d.ts.map +1 -0
  221. package/dist/types/components/Autocomplete.d.ts +130 -0
  222. package/dist/types/components/Autocomplete.d.ts.map +1 -0
  223. package/dist/types/components/Badge.d.ts +21 -0
  224. package/dist/types/components/Badge.d.ts.map +1 -0
  225. package/dist/types/components/Banner.d.ts +78 -0
  226. package/dist/types/components/Banner.d.ts.map +1 -0
  227. package/dist/types/components/Box.d.ts +70 -0
  228. package/dist/types/components/Box.d.ts.map +1 -0
  229. package/dist/types/components/Button.d.ts +123 -0
  230. package/dist/types/components/Button.d.ts.map +1 -0
  231. package/dist/types/components/ButtonGroup.d.ts +26 -0
  232. package/dist/types/components/ButtonGroup.d.ts.map +1 -0
  233. package/dist/types/components/Card.d.ts +139 -0
  234. package/dist/types/components/Card.d.ts.map +1 -0
  235. package/dist/types/components/Checkbox.d.ts +56 -0
  236. package/dist/types/components/Checkbox.d.ts.map +1 -0
  237. package/dist/types/components/ChoiceList.d.ts +69 -0
  238. package/dist/types/components/ChoiceList.d.ts.map +1 -0
  239. package/dist/types/components/Collapsible.d.ts +17 -0
  240. package/dist/types/components/Collapsible.d.ts.map +1 -0
  241. package/dist/types/components/ColorField.d.ts +36 -0
  242. package/dist/types/components/ColorField.d.ts.map +1 -0
  243. package/dist/types/components/ContextualSaveBar.d.ts +22 -0
  244. package/dist/types/components/ContextualSaveBar.d.ts.map +1 -0
  245. package/dist/types/components/DatePicker.d.ts +66 -0
  246. package/dist/types/components/DatePicker.d.ts.map +1 -0
  247. package/dist/types/components/Divider.d.ts +21 -0
  248. package/dist/types/components/Divider.d.ts.map +1 -0
  249. package/dist/types/components/DropZone.d.ts +108 -0
  250. package/dist/types/components/DropZone.d.ts.map +1 -0
  251. package/dist/types/components/EmptyState.d.ts +52 -0
  252. package/dist/types/components/EmptyState.d.ts.map +1 -0
  253. package/dist/types/components/Filters.d.ts +166 -0
  254. package/dist/types/components/Filters.d.ts.map +1 -0
  255. package/dist/types/components/FooterHelp.d.ts +21 -0
  256. package/dist/types/components/FooterHelp.d.ts.map +1 -0
  257. package/dist/types/components/Form.d.ts +39 -0
  258. package/dist/types/components/Form.d.ts.map +1 -0
  259. package/dist/types/components/Frame.d.ts +51 -0
  260. package/dist/types/components/Frame.d.ts.map +1 -0
  261. package/dist/types/components/FrameSaveBar.d.ts +8 -0
  262. package/dist/types/components/FrameSaveBar.d.ts.map +1 -0
  263. package/dist/types/components/Grid.d.ts +39 -0
  264. package/dist/types/components/Grid.d.ts.map +1 -0
  265. package/dist/types/components/HorizontalStack.d.ts +36 -0
  266. package/dist/types/components/HorizontalStack.d.ts.map +1 -0
  267. package/dist/types/components/Icon.d.ts +43 -0
  268. package/dist/types/components/Icon.d.ts.map +1 -0
  269. package/dist/types/components/Image.d.ts +45 -0
  270. package/dist/types/components/Image.d.ts.map +1 -0
  271. package/dist/types/components/InlineError.d.ts +22 -0
  272. package/dist/types/components/InlineError.d.ts.map +1 -0
  273. package/dist/types/components/Label.d.ts +28 -0
  274. package/dist/types/components/Label.d.ts.map +1 -0
  275. package/dist/types/components/Layout.d.ts +44 -0
  276. package/dist/types/components/Layout.d.ts.map +1 -0
  277. package/dist/types/components/LayoutSection.d.ts +24 -0
  278. package/dist/types/components/LayoutSection.d.ts.map +1 -0
  279. package/dist/types/components/Link.d.ts +38 -0
  280. package/dist/types/components/Link.d.ts.map +1 -0
  281. package/dist/types/components/List.d.ts +33 -0
  282. package/dist/types/components/List.d.ts.map +1 -0
  283. package/dist/types/components/Listbox.d.ts +34 -0
  284. package/dist/types/components/Listbox.d.ts.map +1 -0
  285. package/dist/types/components/Loading.d.ts +13 -0
  286. package/dist/types/components/Loading.d.ts.map +1 -0
  287. package/dist/types/components/Modal.d.ts +75 -0
  288. package/dist/types/components/Modal.d.ts.map +1 -0
  289. package/dist/types/components/Navigation.d.ts +105 -0
  290. package/dist/types/components/Navigation.d.ts.map +1 -0
  291. package/dist/types/components/Page.d.ts +59 -0
  292. package/dist/types/components/Page.d.ts.map +1 -0
  293. package/dist/types/components/Pagination.d.ts +39 -0
  294. package/dist/types/components/Pagination.d.ts.map +1 -0
  295. package/dist/types/components/Pane.d.ts +11 -0
  296. package/dist/types/components/Pane.d.ts.map +1 -0
  297. package/dist/types/components/Popover.d.ts +56 -0
  298. package/dist/types/components/Popover.d.ts.map +1 -0
  299. package/dist/types/components/PopoverManager.d.ts +3 -0
  300. package/dist/types/components/PopoverManager.d.ts.map +1 -0
  301. package/dist/types/components/ProgressBar.d.ts +24 -0
  302. package/dist/types/components/ProgressBar.d.ts.map +1 -0
  303. package/dist/types/components/RadioButton.d.ts +39 -0
  304. package/dist/types/components/RadioButton.d.ts.map +1 -0
  305. package/dist/types/components/RadioButtonCard.d.ts +41 -0
  306. package/dist/types/components/RadioButtonCard.d.ts.map +1 -0
  307. package/dist/types/components/RangeSlider.d.ts +44 -0
  308. package/dist/types/components/RangeSlider.d.ts.map +1 -0
  309. package/dist/types/components/ResourceList.d.ts +54 -0
  310. package/dist/types/components/ResourceList.d.ts.map +1 -0
  311. package/dist/types/components/Select.d.ts +48 -0
  312. package/dist/types/components/Select.d.ts.map +1 -0
  313. package/dist/types/components/SkeletonText.d.ts +28 -0
  314. package/dist/types/components/SkeletonText.d.ts.map +1 -0
  315. package/dist/types/components/Spinner.d.ts +18 -0
  316. package/dist/types/components/Spinner.d.ts.map +1 -0
  317. package/dist/types/components/Table.d.ts +197 -0
  318. package/dist/types/components/Table.d.ts.map +1 -0
  319. package/dist/types/components/Tabs.d.ts +41 -0
  320. package/dist/types/components/Tabs.d.ts.map +1 -0
  321. package/dist/types/components/Tag.d.ts +26 -0
  322. package/dist/types/components/Tag.d.ts.map +1 -0
  323. package/dist/types/components/Text.d.ts +32 -0
  324. package/dist/types/components/Text.d.ts.map +1 -0
  325. package/dist/types/components/TextField.d.ts +109 -0
  326. package/dist/types/components/TextField.d.ts.map +1 -0
  327. package/dist/types/components/Thumbnail.d.ts +18 -0
  328. package/dist/types/components/Thumbnail.d.ts.map +1 -0
  329. package/dist/types/components/TimePicker.d.ts +3 -0
  330. package/dist/types/components/TimePicker.d.ts.map +1 -0
  331. package/dist/types/components/Tip.d.ts +23 -0
  332. package/dist/types/components/Tip.d.ts.map +1 -0
  333. package/dist/types/components/Tooltip.d.ts +84 -0
  334. package/dist/types/components/Tooltip.d.ts.map +1 -0
  335. package/dist/types/components/TopBar.d.ts +43 -0
  336. package/dist/types/components/TopBar.d.ts.map +1 -0
  337. package/dist/types/components/VerticalStack.d.ts +27 -0
  338. package/dist/types/components/VerticalStack.d.ts.map +1 -0
  339. package/dist/types/index.d.ts +62 -0
  340. package/dist/types/index.d.ts.map +1 -0
  341. package/dist/types/styles/Table.d.ts +1570 -0
  342. package/dist/types/styles/Table.d.ts.map +1 -0
  343. package/dist/types/utilities/dates.d.ts +46 -0
  344. package/dist/types/utilities/dates.d.ts.map +1 -0
  345. package/dist/types/utilities/transformers.d.ts +4 -0
  346. package/dist/types/utilities/transformers.d.ts.map +1 -0
  347. package/dist/types/utilities/useIndexResourceState.d.ts +21 -0
  348. package/dist/types/utilities/useIndexResourceState.d.ts.map +1 -0
  349. package/dist/types/utilities/useMounted.d.ts +2 -0
  350. package/dist/types/utilities/useMounted.d.ts.map +1 -0
  351. package/dist/types/utilities/useTableScrollState.d.ts +29 -0
  352. package/dist/types/utilities/useTableScrollState.d.ts.map +1 -0
  353. package/index.css +6 -0
  354. package/package.json +45 -11
@@ -0,0 +1,845 @@
1
+ function _array_like_to_array(arr, len) {
2
+ if (len == null || len > arr.length) len = arr.length;
3
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
4
+ return arr2;
5
+ }
6
+ function _array_with_holes(arr) {
7
+ if (Array.isArray(arr)) return arr;
8
+ }
9
+ function _define_property(obj, key, value) {
10
+ if (key in obj) {
11
+ Object.defineProperty(obj, key, {
12
+ value: value,
13
+ enumerable: true,
14
+ configurable: true,
15
+ writable: true
16
+ });
17
+ } else {
18
+ obj[key] = value;
19
+ }
20
+ return obj;
21
+ }
22
+ function _iterable_to_array_limit(arr, i) {
23
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
24
+ if (_i == null) return;
25
+ var _arr = [];
26
+ var _n = true;
27
+ var _d = false;
28
+ var _s, _e;
29
+ try {
30
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
31
+ _arr.push(_s.value);
32
+ if (i && _arr.length === i) break;
33
+ }
34
+ } catch (err) {
35
+ _d = true;
36
+ _e = err;
37
+ } finally{
38
+ try {
39
+ if (!_n && _i["return"] != null) _i["return"]();
40
+ } finally{
41
+ if (_d) throw _e;
42
+ }
43
+ }
44
+ return _arr;
45
+ }
46
+ function _non_iterable_rest() {
47
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
48
+ }
49
+ function _object_spread(target) {
50
+ for(var i = 1; i < arguments.length; i++){
51
+ var source = arguments[i] != null ? arguments[i] : {};
52
+ var ownKeys = Object.keys(source);
53
+ if (typeof Object.getOwnPropertySymbols === "function") {
54
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
55
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
56
+ }));
57
+ }
58
+ ownKeys.forEach(function(key) {
59
+ _define_property(target, key, source[key]);
60
+ });
61
+ }
62
+ return target;
63
+ }
64
+ function ownKeys(object, enumerableOnly) {
65
+ var keys = Object.keys(object);
66
+ if (Object.getOwnPropertySymbols) {
67
+ var symbols = Object.getOwnPropertySymbols(object);
68
+ if (enumerableOnly) {
69
+ symbols = symbols.filter(function(sym) {
70
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
71
+ });
72
+ }
73
+ keys.push.apply(keys, symbols);
74
+ }
75
+ return keys;
76
+ }
77
+ function _object_spread_props(target, source) {
78
+ source = source != null ? source : {};
79
+ if (Object.getOwnPropertyDescriptors) {
80
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
81
+ } else {
82
+ ownKeys(Object(source)).forEach(function(key) {
83
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
84
+ });
85
+ }
86
+ return target;
87
+ }
88
+ function _sliced_to_array(arr, i) {
89
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
90
+ }
91
+ function _unsupported_iterable_to_array(o, minLen) {
92
+ if (!o) return;
93
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
94
+ var n = Object.prototype.toString.call(o).slice(8, -1);
95
+ if (n === "Object" && o.constructor) n = o.constructor.name;
96
+ if (n === "Map" || n === "Set") return Array.from(n);
97
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
98
+ }
99
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
100
+ import { useState } from "react";
101
+ import { transformStorySource } from "../utilities/transformers.js";
102
+ import RangeSlider from "../components/RangeSlider.js";
103
+ import Text from "../components/Text.js";
104
+ import Card from "../components/Card.js";
105
+ import Button from "../components/Button.js";
106
+ import { VerticalStack, HorizontalStack, Box, Grid } from "../dist/esm/index.js";
107
+ export default {
108
+ title: 'Litho/RangeSlider',
109
+ component: RangeSlider,
110
+ parameters: {
111
+ layout: 'padded',
112
+ docs: {
113
+ description: {
114
+ component: "A RangeSlider component that allows users to select a range of values by dragging handles along a track. RangeSliders are useful for filtering data, setting price ranges, or configuring numeric parameters."
115
+ },
116
+ source: {
117
+ transform: transformStorySource
118
+ }
119
+ }
120
+ },
121
+ args: {
122
+ label: 'Range slider',
123
+ min: 0,
124
+ max: 100,
125
+ value: [
126
+ 25,
127
+ 75
128
+ ]
129
+ },
130
+ tags: [
131
+ 'autodocs'
132
+ ],
133
+ argTypes: {
134
+ label: {
135
+ control: 'text',
136
+ description: 'Label for the range slider'
137
+ },
138
+ min: {
139
+ control: 'number',
140
+ description: 'Minimum value'
141
+ },
142
+ max: {
143
+ control: 'number',
144
+ description: 'Maximum value'
145
+ },
146
+ step: {
147
+ control: 'number',
148
+ description: 'Step increment for the slider'
149
+ },
150
+ value: {
151
+ control: 'object',
152
+ description: 'Selected range as [min, max] array'
153
+ },
154
+ disabled: {
155
+ control: 'boolean',
156
+ description: 'Whether the slider is disabled'
157
+ },
158
+ helpText: {
159
+ control: 'text',
160
+ description: 'Additional descriptive text'
161
+ },
162
+ error: {
163
+ control: 'text',
164
+ description: 'Error message to display'
165
+ },
166
+ prefix: {
167
+ control: 'text',
168
+ description: 'Prefix to display before values'
169
+ },
170
+ suffix: {
171
+ control: 'text',
172
+ description: 'Suffix to display after values'
173
+ },
174
+ onChange: {
175
+ action: 'rangeChanged',
176
+ description: 'Callback when range changes'
177
+ }
178
+ }
179
+ };
180
+ export var Default = {
181
+ render: function(args) {
182
+ var _useState = _sliced_to_array(useState(args.value), 2), value = _useState[0], setValue = _useState[1];
183
+ return /*#__PURE__*/ _jsx(RangeSlider, _object_spread_props(_object_spread({}, args), {
184
+ value: value,
185
+ onChange: function(newValue) {
186
+ var _args_onChange;
187
+ setValue(newValue);
188
+ (_args_onChange = args.onChange) === null || _args_onChange === void 0 ? void 0 : _args_onChange.call(args, newValue);
189
+ }
190
+ }));
191
+ }
192
+ };
193
+ export var PriceRange = {
194
+ args: {
195
+ label: 'Price range',
196
+ min: 0,
197
+ max: 1000,
198
+ step: 10,
199
+ value: [
200
+ 100,
201
+ 500
202
+ ],
203
+ prefix: '$',
204
+ helpText: 'Set your budget range'
205
+ },
206
+ render: function(args) {
207
+ var _useState = _sliced_to_array(useState(args.value), 2), value = _useState[0], setValue = _useState[1];
208
+ return /*#__PURE__*/ _jsx(RangeSlider, _object_spread_props(_object_spread({}, args), {
209
+ value: value,
210
+ onChange: setValue
211
+ }));
212
+ },
213
+ parameters: {
214
+ docs: {
215
+ description: {
216
+ story: 'Range slider for price filtering with currency prefix.'
217
+ }
218
+ }
219
+ }
220
+ };
221
+ export var PercentageRange = {
222
+ args: {
223
+ label: 'Discount range',
224
+ min: 0,
225
+ max: 100,
226
+ step: 5,
227
+ value: [
228
+ 10,
229
+ 50
230
+ ],
231
+ suffix: '%',
232
+ helpText: 'Select discount percentage range'
233
+ },
234
+ render: function(args) {
235
+ var _useState = _sliced_to_array(useState(args.value), 2), value = _useState[0], setValue = _useState[1];
236
+ return /*#__PURE__*/ _jsx(RangeSlider, _object_spread_props(_object_spread({}, args), {
237
+ value: value,
238
+ onChange: setValue
239
+ }));
240
+ },
241
+ parameters: {
242
+ docs: {
243
+ description: {
244
+ story: 'Range slider for percentage values with suffix.'
245
+ }
246
+ }
247
+ }
248
+ };
249
+ export var WithError = {
250
+ args: {
251
+ label: 'Temperature range',
252
+ min: -10,
253
+ max: 40,
254
+ value: [
255
+ 35,
256
+ 45
257
+ ],
258
+ suffix: '°C',
259
+ error: 'Maximum temperature cannot exceed 40°C'
260
+ },
261
+ render: function(args) {
262
+ var _useState = _sliced_to_array(useState(args.value), 2), value = _useState[0], setValue = _useState[1];
263
+ return /*#__PURE__*/ _jsx(RangeSlider, _object_spread_props(_object_spread({}, args), {
264
+ value: value,
265
+ onChange: setValue
266
+ }));
267
+ },
268
+ parameters: {
269
+ docs: {
270
+ description: {
271
+ story: 'Range slider with error state for validation.'
272
+ }
273
+ }
274
+ }
275
+ };
276
+ export var Disabled = {
277
+ args: {
278
+ label: 'Disabled range',
279
+ min: 0,
280
+ max: 100,
281
+ value: [
282
+ 20,
283
+ 80
284
+ ],
285
+ disabled: true,
286
+ helpText: 'This range is currently disabled'
287
+ },
288
+ parameters: {
289
+ docs: {
290
+ description: {
291
+ story: 'Disabled range slider that cannot be interacted with.'
292
+ }
293
+ }
294
+ }
295
+ };
296
+ export var ProductFilter = {
297
+ render: function() {
298
+ var _useState = _sliced_to_array(useState([
299
+ 50,
300
+ 500
301
+ ]), 2), priceRange = _useState[0], setPriceRange = _useState[1];
302
+ var _useState1 = _sliced_to_array(useState([
303
+ 3,
304
+ 5
305
+ ]), 2), ratingRange = _useState1[0], setRatingRange = _useState1[1];
306
+ var _useState2 = _sliced_to_array(useState([
307
+ {
308
+ name: 'Product A',
309
+ price: 25,
310
+ rating: 4.2
311
+ },
312
+ {
313
+ name: 'Product B',
314
+ price: 75,
315
+ rating: 3.8
316
+ },
317
+ {
318
+ name: 'Product C',
319
+ price: 150,
320
+ rating: 4.5
321
+ },
322
+ {
323
+ name: 'Product D',
324
+ price: 300,
325
+ rating: 4.1
326
+ },
327
+ {
328
+ name: 'Product E',
329
+ price: 450,
330
+ rating: 4.8
331
+ },
332
+ {
333
+ name: 'Product F',
334
+ price: 600,
335
+ rating: 2.9
336
+ }
337
+ ]), 2), products = _useState2[0], setProducts = _useState2[1];
338
+ var filteredProducts = products.filter(function(product) {
339
+ return product.price >= priceRange[0] && product.price <= priceRange[1] && product.rating >= ratingRange[0] && product.rating <= ratingRange[1];
340
+ });
341
+ return /*#__PURE__*/ _jsx(Card, {
342
+ title: "Product Filters",
343
+ padded: true,
344
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
345
+ gap: "8",
346
+ children: [
347
+ /*#__PURE__*/ _jsx(RangeSlider, {
348
+ label: "Price range",
349
+ min: 0,
350
+ max: 1000,
351
+ step: 25,
352
+ value: priceRange,
353
+ onChange: setPriceRange,
354
+ prefix: "$",
355
+ helpText: "Filter products by price"
356
+ }),
357
+ /*#__PURE__*/ _jsx(RangeSlider, {
358
+ label: "Rating range",
359
+ min: 1,
360
+ max: 5,
361
+ step: 0.1,
362
+ value: ratingRange,
363
+ onChange: setRatingRange,
364
+ suffix: " stars",
365
+ helpText: "Filter products by customer rating"
366
+ }),
367
+ /*#__PURE__*/ _jsxs(Box, {
368
+ padding: "4",
369
+ background: "bg-surface-neutral-subdued",
370
+ borderRadius: "1",
371
+ children: [
372
+ /*#__PURE__*/ _jsx(Box, {
373
+ paddingBlockEnd: "4",
374
+ children: /*#__PURE__*/ _jsxs(Text, {
375
+ variant: "headingSm",
376
+ children: [
377
+ "Filtered Results (",
378
+ filteredProducts.length,
379
+ ")"
380
+ ]
381
+ })
382
+ }),
383
+ filteredProducts.length > 0 ? /*#__PURE__*/ _jsx(VerticalStack, {
384
+ gap: "2",
385
+ children: filteredProducts.map(function(product, index) {
386
+ return /*#__PURE__*/ _jsx(Box, {
387
+ padding: "2",
388
+ background: "bg-surface",
389
+ borderRadius: "1",
390
+ children: /*#__PURE__*/ _jsxs(HorizontalStack, {
391
+ align: "space-between",
392
+ children: [
393
+ /*#__PURE__*/ _jsx(Text, {
394
+ children: product.name
395
+ }),
396
+ /*#__PURE__*/ _jsxs(HorizontalStack, {
397
+ gap: "4",
398
+ children: [
399
+ /*#__PURE__*/ _jsxs(Text, {
400
+ children: [
401
+ "$",
402
+ product.price
403
+ ]
404
+ }),
405
+ /*#__PURE__*/ _jsxs(Text, {
406
+ children: [
407
+ product.rating,
408
+ " ⭐"
409
+ ]
410
+ })
411
+ ]
412
+ })
413
+ ]
414
+ })
415
+ }, index);
416
+ })
417
+ }) : /*#__PURE__*/ _jsx(Text, {
418
+ color: "subdued",
419
+ children: "No products match your criteria"
420
+ })
421
+ ]
422
+ })
423
+ ]
424
+ })
425
+ });
426
+ },
427
+ parameters: {
428
+ docs: {
429
+ description: {
430
+ story: 'Real-world example using range sliders to filter products by price and rating.'
431
+ }
432
+ }
433
+ }
434
+ };
435
+ export var BudgetPlanner = {
436
+ render: function() {
437
+ var _useState = _sliced_to_array(useState([
438
+ 800,
439
+ 1200
440
+ ]), 2), housing = _useState[0], setHousing = _useState[1];
441
+ var _useState1 = _sliced_to_array(useState([
442
+ 200,
443
+ 400
444
+ ]), 2), food = _useState1[0], setFood = _useState1[1];
445
+ var _useState2 = _sliced_to_array(useState([
446
+ 100,
447
+ 300
448
+ ]), 2), transportation = _useState2[0], setTransportation = _useState2[1];
449
+ var _useState3 = _sliced_to_array(useState([
450
+ 50,
451
+ 200
452
+ ]), 2), entertainment = _useState3[0], setEntertainment = _useState3[1];
453
+ var totalMin = housing[0] + food[0] + transportation[0] + entertainment[0];
454
+ var totalMax = housing[1] + food[1] + transportation[1] + entertainment[1];
455
+ return /*#__PURE__*/ _jsx(Card, {
456
+ title: "Monthly Budget Planner",
457
+ padded: true,
458
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
459
+ gap: "8",
460
+ children: [
461
+ /*#__PURE__*/ _jsx(RangeSlider, {
462
+ label: "Housing & Utilities",
463
+ min: 0,
464
+ max: 2000,
465
+ step: 50,
466
+ value: housing,
467
+ onChange: setHousing,
468
+ prefix: "$",
469
+ helpText: "Rent, mortgage, utilities, insurance"
470
+ }),
471
+ /*#__PURE__*/ _jsx(RangeSlider, {
472
+ label: "Food & Groceries",
473
+ min: 0,
474
+ max: 800,
475
+ step: 25,
476
+ value: food,
477
+ onChange: setFood,
478
+ prefix: "$",
479
+ helpText: "Groceries, dining out, beverages"
480
+ }),
481
+ /*#__PURE__*/ _jsx(RangeSlider, {
482
+ label: "Transportation",
483
+ min: 0,
484
+ max: 600,
485
+ step: 25,
486
+ value: transportation,
487
+ onChange: setTransportation,
488
+ prefix: "$",
489
+ helpText: "Car payment, gas, public transit, maintenance"
490
+ }),
491
+ /*#__PURE__*/ _jsx(RangeSlider, {
492
+ label: "Entertainment & Recreation",
493
+ min: 0,
494
+ max: 500,
495
+ step: 25,
496
+ value: entertainment,
497
+ onChange: setEntertainment,
498
+ prefix: "$",
499
+ helpText: "Movies, hobbies, gym, subscriptions"
500
+ }),
501
+ /*#__PURE__*/ _jsx(Box, {
502
+ padding: "6",
503
+ background: "bg-surface-success-subdued",
504
+ borderRadius: "2",
505
+ borderWidth: "1",
506
+ borderColor: "border-success",
507
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
508
+ gap: "4",
509
+ children: [
510
+ /*#__PURE__*/ _jsx(Text, {
511
+ variant: "headingMd",
512
+ children: "Budget Summary"
513
+ }),
514
+ /*#__PURE__*/ _jsxs(Grid, {
515
+ columns: 2,
516
+ gap: "4",
517
+ children: [
518
+ /*#__PURE__*/ _jsxs(VerticalStack, {
519
+ gap: "1",
520
+ children: [
521
+ /*#__PURE__*/ _jsx(Text, {
522
+ variant: "headingSm",
523
+ children: "Minimum Budget"
524
+ }),
525
+ /*#__PURE__*/ _jsxs(Text, {
526
+ variant: "headingLg",
527
+ style: {
528
+ color: '#2e7d2e'
529
+ },
530
+ children: [
531
+ "$",
532
+ totalMin.toLocaleString()
533
+ ]
534
+ })
535
+ ]
536
+ }),
537
+ /*#__PURE__*/ _jsxs(VerticalStack, {
538
+ gap: "1",
539
+ children: [
540
+ /*#__PURE__*/ _jsx(Text, {
541
+ variant: "headingSm",
542
+ children: "Maximum Budget"
543
+ }),
544
+ /*#__PURE__*/ _jsxs(Text, {
545
+ variant: "headingLg",
546
+ style: {
547
+ color: '#2e7d2e'
548
+ },
549
+ children: [
550
+ "$",
551
+ totalMax.toLocaleString()
552
+ ]
553
+ })
554
+ ]
555
+ })
556
+ ]
557
+ })
558
+ ]
559
+ })
560
+ })
561
+ ]
562
+ })
563
+ });
564
+ },
565
+ parameters: {
566
+ docs: {
567
+ description: {
568
+ story: 'Budget planning tool using multiple range sliders with automatic total calculation.'
569
+ }
570
+ }
571
+ }
572
+ };
573
+ export var DateTimeRange = {
574
+ render: function() {
575
+ var _useState = _sliced_to_array(useState([
576
+ 9,
577
+ 17
578
+ ]), 2), hourRange = _useState[0], setHourRange = _useState[1];
579
+ var _useState1 = _sliced_to_array(useState([
580
+ 1,
581
+ 31
582
+ ]), 2), dayRange = _useState1[0], setDayRange = _useState1[1];
583
+ var formatHour = function(hour) {
584
+ if (hour === 0) return '12:00 AM';
585
+ if (hour < 12) return "".concat(hour, ":00 AM");
586
+ if (hour === 12) return '12:00 PM';
587
+ return "".concat(hour - 12, ":00 PM");
588
+ };
589
+ return /*#__PURE__*/ _jsx(Card, {
590
+ title: "Availability Settings",
591
+ padded: true,
592
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
593
+ gap: "8",
594
+ children: [
595
+ /*#__PURE__*/ _jsxs(VerticalStack, {
596
+ gap: "2",
597
+ children: [
598
+ /*#__PURE__*/ _jsx(RangeSlider, {
599
+ label: "Working hours",
600
+ min: 0,
601
+ max: 23,
602
+ step: 1,
603
+ value: hourRange,
604
+ onChange: setHourRange,
605
+ helpText: "Set your available working hours"
606
+ }),
607
+ /*#__PURE__*/ _jsx(Box, {
608
+ padding: "2",
609
+ background: "bg-surface-info-subdued",
610
+ borderRadius: "1",
611
+ children: /*#__PURE__*/ _jsxs(Text, {
612
+ children: [
613
+ "Available from ",
614
+ formatHour(hourRange[0]),
615
+ " to ",
616
+ formatHour(hourRange[1])
617
+ ]
618
+ })
619
+ })
620
+ ]
621
+ }),
622
+ /*#__PURE__*/ _jsxs(VerticalStack, {
623
+ gap: "2",
624
+ children: [
625
+ /*#__PURE__*/ _jsx(RangeSlider, {
626
+ label: "Available dates this month",
627
+ min: 1,
628
+ max: 31,
629
+ step: 1,
630
+ value: dayRange,
631
+ onChange: setDayRange,
632
+ helpText: "Select the date range you're available"
633
+ }),
634
+ /*#__PURE__*/ _jsx(Box, {
635
+ padding: "2",
636
+ background: "bg-surface-info-subdued",
637
+ borderRadius: "1",
638
+ children: /*#__PURE__*/ _jsxs(Text, {
639
+ children: [
640
+ "Available from the ",
641
+ dayRange[0],
642
+ dayRange[0] === 1 ? 'st' : dayRange[0] === 2 ? 'nd' : dayRange[0] === 3 ? 'rd' : 'th',
643
+ " to the ",
644
+ dayRange[1],
645
+ dayRange[1] === 1 ? 'st' : dayRange[1] === 2 ? 'nd' : dayRange[1] === 3 ? 'rd' : 'th'
646
+ ]
647
+ })
648
+ })
649
+ ]
650
+ }),
651
+ /*#__PURE__*/ _jsx(Box, {
652
+ paddingBlockStart: "4",
653
+ borderBlockStartWidth: "1",
654
+ borderColor: "border",
655
+ children: /*#__PURE__*/ _jsx(Button, {
656
+ primary: true,
657
+ children: "Save Availability"
658
+ })
659
+ })
660
+ ]
661
+ })
662
+ });
663
+ },
664
+ parameters: {
665
+ docs: {
666
+ description: {
667
+ story: 'Availability settings using range sliders for time and date selection.'
668
+ }
669
+ }
670
+ }
671
+ };
672
+ export var AdvancedConfiguration = {
673
+ render: function() {
674
+ var _useState = _sliced_to_array(useState([
675
+ 2,
676
+ 8
677
+ ]), 2), cpuRange = _useState[0], setCpuRange = _useState[1];
678
+ var _useState1 = _sliced_to_array(useState([
679
+ 4,
680
+ 32
681
+ ]), 2), memoryRange = _useState1[0], setMemoryRange = _useState1[1];
682
+ var _useState2 = _sliced_to_array(useState([
683
+ 100,
684
+ 1000
685
+ ]), 2), storageRange = _useState2[0], setStorageRange = _useState2[1];
686
+ var _useState3 = _sliced_to_array(useState([
687
+ 10,
688
+ 100
689
+ ]), 2), bandwidthRange = _useState3[0], setBandwidthRange = _useState3[1];
690
+ var calculateCost = function() {
691
+ var cpuCost = (cpuRange[0] + cpuRange[1]) / 2 * 20;
692
+ var memoryCost = (memoryRange[0] + memoryRange[1]) / 2 * 5;
693
+ var storageCost = (storageRange[0] + storageRange[1]) / 2 * 0.1;
694
+ var bandwidthCost = (bandwidthRange[0] + bandwidthRange[1]) / 2 * 2;
695
+ return Math.round(cpuCost + memoryCost + storageCost + bandwidthCost);
696
+ };
697
+ return /*#__PURE__*/ _jsx(Card, {
698
+ title: "Server Configuration",
699
+ padded: true,
700
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
701
+ gap: "8",
702
+ children: [
703
+ /*#__PURE__*/ _jsx(RangeSlider, {
704
+ label: "CPU Cores",
705
+ min: 1,
706
+ max: 16,
707
+ step: 1,
708
+ value: cpuRange,
709
+ onChange: setCpuRange,
710
+ helpText: "Number of virtual CPU cores"
711
+ }),
712
+ /*#__PURE__*/ _jsx(RangeSlider, {
713
+ label: "Memory (RAM)",
714
+ min: 1,
715
+ max: 64,
716
+ step: 1,
717
+ value: memoryRange,
718
+ onChange: setMemoryRange,
719
+ suffix: " GB",
720
+ helpText: "Amount of system memory"
721
+ }),
722
+ /*#__PURE__*/ _jsx(RangeSlider, {
723
+ label: "Storage",
724
+ min: 10,
725
+ max: 2000,
726
+ step: 10,
727
+ value: storageRange,
728
+ onChange: setStorageRange,
729
+ suffix: " GB",
730
+ helpText: "SSD storage capacity"
731
+ }),
732
+ /*#__PURE__*/ _jsx(RangeSlider, {
733
+ label: "Bandwidth",
734
+ min: 1,
735
+ max: 200,
736
+ step: 5,
737
+ value: bandwidthRange,
738
+ onChange: setBandwidthRange,
739
+ suffix: " Mbps",
740
+ helpText: "Network bandwidth limit"
741
+ }),
742
+ /*#__PURE__*/ _jsx(Box, {
743
+ padding: "6",
744
+ background: "bg-surface-info-subdued",
745
+ borderRadius: "2",
746
+ borderWidth: "1",
747
+ borderColor: "border-info",
748
+ children: /*#__PURE__*/ _jsxs(VerticalStack, {
749
+ gap: "4",
750
+ children: [
751
+ /*#__PURE__*/ _jsxs(Grid, {
752
+ columns: 2,
753
+ gap: "4",
754
+ children: [
755
+ /*#__PURE__*/ _jsxs(VerticalStack, {
756
+ gap: "2",
757
+ children: [
758
+ /*#__PURE__*/ _jsx(Text, {
759
+ variant: "headingSm",
760
+ children: "Configuration Range"
761
+ }),
762
+ /*#__PURE__*/ _jsxs(Text, {
763
+ children: [
764
+ "CPU: ",
765
+ cpuRange[0],
766
+ " - ",
767
+ cpuRange[1],
768
+ " cores"
769
+ ]
770
+ }),
771
+ /*#__PURE__*/ _jsxs(Text, {
772
+ children: [
773
+ "RAM: ",
774
+ memoryRange[0],
775
+ " - ",
776
+ memoryRange[1],
777
+ " GB"
778
+ ]
779
+ }),
780
+ /*#__PURE__*/ _jsxs(Text, {
781
+ children: [
782
+ "Storage: ",
783
+ storageRange[0],
784
+ " - ",
785
+ storageRange[1],
786
+ " GB"
787
+ ]
788
+ }),
789
+ /*#__PURE__*/ _jsxs(Text, {
790
+ children: [
791
+ "Bandwidth: ",
792
+ bandwidthRange[0],
793
+ " - ",
794
+ bandwidthRange[1],
795
+ " Mbps"
796
+ ]
797
+ })
798
+ ]
799
+ }),
800
+ /*#__PURE__*/ _jsxs(VerticalStack, {
801
+ gap: "2",
802
+ children: [
803
+ /*#__PURE__*/ _jsx(Text, {
804
+ variant: "headingSm",
805
+ children: "Estimated Cost"
806
+ }),
807
+ /*#__PURE__*/ _jsxs(Text, {
808
+ variant: "headingXl",
809
+ style: {
810
+ color: '#2196f3'
811
+ },
812
+ children: [
813
+ "$",
814
+ calculateCost(),
815
+ "/month"
816
+ ]
817
+ }),
818
+ /*#__PURE__*/ _jsx(Text, {
819
+ color: "subdued",
820
+ variant: "bodySm",
821
+ children: "Based on average configuration"
822
+ })
823
+ ]
824
+ })
825
+ ]
826
+ }),
827
+ /*#__PURE__*/ _jsx(Button, {
828
+ primary: true,
829
+ children: "Deploy Server"
830
+ })
831
+ ]
832
+ })
833
+ })
834
+ ]
835
+ })
836
+ });
837
+ },
838
+ parameters: {
839
+ docs: {
840
+ description: {
841
+ story: 'Advanced server configuration with real-time cost calculation.'
842
+ }
843
+ }
844
+ }
845
+ };