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