@heymantle/litho 0.0.3 → 0.0.5

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