selva-shared 0.8.1

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 (506) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +45 -0
  3. package/dist/components/AppLayout.svelte +439 -0
  4. package/dist/components/AppLayout.svelte.d.ts +17 -0
  5. package/dist/components/CollapsedPanelStrip.svelte +67 -0
  6. package/dist/components/CollapsedPanelStrip.svelte.d.ts +11 -0
  7. package/dist/components/ComputeMessages.svelte +172 -0
  8. package/dist/components/ComputeMessages.svelte.d.ts +7 -0
  9. package/dist/components/ErrorScreen.svelte +55 -0
  10. package/dist/components/ErrorScreen.svelte.d.ts +9 -0
  11. package/dist/components/StateManager.svelte +318 -0
  12. package/dist/components/StateManager.svelte.d.ts +9 -0
  13. package/dist/components/Viewer.svelte +207 -0
  14. package/dist/components/Viewer.svelte.d.ts +12 -0
  15. package/dist/components/layout/FooterItemRenderer.svelte +20 -0
  16. package/dist/components/layout/FooterItemRenderer.svelte.d.ts +7 -0
  17. package/dist/components/layout/PageContainer.svelte +36 -0
  18. package/dist/components/layout/PageContainer.svelte.d.ts +12 -0
  19. package/dist/components/layout/PageFooter.svelte +223 -0
  20. package/dist/components/layout/PageFooter.svelte.d.ts +9 -0
  21. package/dist/components/layout/PageHeader.svelte +89 -0
  22. package/dist/components/layout/PageHeader.svelte.d.ts +12 -0
  23. package/dist/components/layout/index.d.ts +3 -0
  24. package/dist/components/layout/index.js +4 -0
  25. package/dist/components/preview/ChartOutput.svelte +257 -0
  26. package/dist/components/preview/ChartOutput.svelte.d.ts +8 -0
  27. package/dist/components/preview/Group.svelte +121 -0
  28. package/dist/components/preview/Group.svelte.d.ts +23 -0
  29. package/dist/components/preview/InputControl.svelte +119 -0
  30. package/dist/components/preview/InputControl.svelte.d.ts +11 -0
  31. package/dist/components/preview/OutputDisplay.svelte +296 -0
  32. package/dist/components/preview/OutputDisplay.svelte.d.ts +9 -0
  33. package/dist/components/preview/TabBar.svelte +36 -0
  34. package/dist/components/preview/TabBar.svelte.d.ts +8 -0
  35. package/dist/components/preview/TabContent.svelte +124 -0
  36. package/dist/components/preview/TabContent.svelte.d.ts +13 -0
  37. package/dist/components/preview/TabLayout.svelte +109 -0
  38. package/dist/components/preview/TabLayout.svelte.d.ts +13 -0
  39. package/dist/components/preview/index.d.ts +3 -0
  40. package/dist/components/preview/index.js +4 -0
  41. package/dist/components/preview/inputs/CheckboxInput.svelte +29 -0
  42. package/dist/components/preview/inputs/CheckboxInput.svelte.d.ts +10 -0
  43. package/dist/components/preview/inputs/ColorInput.svelte +21 -0
  44. package/dist/components/preview/inputs/ColorInput.svelte.d.ts +7 -0
  45. package/dist/components/preview/inputs/DropdownInput.svelte +40 -0
  46. package/dist/components/preview/inputs/DropdownInput.svelte.d.ts +10 -0
  47. package/dist/components/preview/inputs/FileInput.svelte +358 -0
  48. package/dist/components/preview/inputs/FileInput.svelte.d.ts +10 -0
  49. package/dist/components/preview/inputs/NumberInput.svelte +152 -0
  50. package/dist/components/preview/inputs/NumberInput.svelte.d.ts +11 -0
  51. package/dist/components/preview/inputs/TextInput.svelte +74 -0
  52. package/dist/components/preview/inputs/TextInput.svelte.d.ts +11 -0
  53. package/dist/components/preview/inputs/index.d.ts +6 -0
  54. package/dist/components/preview/inputs/index.js +6 -0
  55. package/dist/components/ui/CalculateButton.svelte +56 -0
  56. package/dist/components/ui/CalculateButton.svelte.d.ts +9 -0
  57. package/dist/components/ui/SolvingIndicator.svelte +55 -0
  58. package/dist/components/ui/SolvingIndicator.svelte.d.ts +6 -0
  59. package/dist/components/ui/StateDisplay.svelte +106 -0
  60. package/dist/components/ui/StateDisplay.svelte.d.ts +10 -0
  61. package/dist/components/ui/alert/alert-description.svelte +23 -0
  62. package/dist/components/ui/alert/alert-description.svelte.d.ts +5 -0
  63. package/dist/components/ui/alert/alert-title.svelte +20 -0
  64. package/dist/components/ui/alert/alert-title.svelte.d.ts +5 -0
  65. package/dist/components/ui/alert/alert.svelte +44 -0
  66. package/dist/components/ui/alert/alert.svelte.d.ts +26 -0
  67. package/dist/components/ui/alert/index.d.ts +5 -0
  68. package/dist/components/ui/alert/index.js +7 -0
  69. package/dist/components/ui/alert-dialog/alert-dialog-action.svelte +18 -0
  70. package/dist/components/ui/alert-dialog/alert-dialog-action.svelte.d.ts +4 -0
  71. package/dist/components/ui/alert-dialog/alert-dialog-cancel.svelte +18 -0
  72. package/dist/components/ui/alert-dialog/alert-dialog-cancel.svelte.d.ts +4 -0
  73. package/dist/components/ui/alert-dialog/alert-dialog-content.svelte +27 -0
  74. package/dist/components/ui/alert-dialog/alert-dialog-content.svelte.d.ts +8 -0
  75. package/dist/components/ui/alert-dialog/alert-dialog-description.svelte +17 -0
  76. package/dist/components/ui/alert-dialog/alert-dialog-description.svelte.d.ts +4 -0
  77. package/dist/components/ui/alert-dialog/alert-dialog-footer.svelte +20 -0
  78. package/dist/components/ui/alert-dialog/alert-dialog-footer.svelte.d.ts +5 -0
  79. package/dist/components/ui/alert-dialog/alert-dialog-header.svelte +20 -0
  80. package/dist/components/ui/alert-dialog/alert-dialog-header.svelte.d.ts +5 -0
  81. package/dist/components/ui/alert-dialog/alert-dialog-overlay.svelte +20 -0
  82. package/dist/components/ui/alert-dialog/alert-dialog-overlay.svelte.d.ts +4 -0
  83. package/dist/components/ui/alert-dialog/alert-dialog-title.svelte +17 -0
  84. package/dist/components/ui/alert-dialog/alert-dialog-title.svelte.d.ts +4 -0
  85. package/dist/components/ui/alert-dialog/alert-dialog-trigger.svelte +7 -0
  86. package/dist/components/ui/alert-dialog/alert-dialog-trigger.svelte.d.ts +4 -0
  87. package/dist/components/ui/alert-dialog/index.d.ts +12 -0
  88. package/dist/components/ui/alert-dialog/index.js +15 -0
  89. package/dist/components/ui/badge/badge.svelte +50 -0
  90. package/dist/components/ui/badge/badge.svelte.d.ts +32 -0
  91. package/dist/components/ui/badge/index.d.ts +2 -0
  92. package/dist/components/ui/badge/index.js +2 -0
  93. package/dist/components/ui/button/button.svelte +83 -0
  94. package/dist/components/ui/button/button.svelte.d.ts +67 -0
  95. package/dist/components/ui/button/index.d.ts +2 -0
  96. package/dist/components/ui/button/index.js +4 -0
  97. package/dist/components/ui/button-group/button-group-separator.svelte +20 -0
  98. package/dist/components/ui/button-group/button-group-separator.svelte.d.ts +13 -0
  99. package/dist/components/ui/button-group/button-group-text.svelte +30 -0
  100. package/dist/components/ui/button-group/button-group-text.svelte.d.ts +11 -0
  101. package/dist/components/ui/button-group/button-group.svelte +46 -0
  102. package/dist/components/ui/button-group/button-group.svelte.d.ts +26 -0
  103. package/dist/components/ui/button-group/index.d.ts +4 -0
  104. package/dist/components/ui/button-group/index.js +6 -0
  105. package/dist/components/ui/card/card-action.svelte +20 -0
  106. package/dist/components/ui/card/card-action.svelte.d.ts +5 -0
  107. package/dist/components/ui/card/card-content.svelte +15 -0
  108. package/dist/components/ui/card/card-content.svelte.d.ts +5 -0
  109. package/dist/components/ui/card/card-description.svelte +20 -0
  110. package/dist/components/ui/card/card-description.svelte.d.ts +5 -0
  111. package/dist/components/ui/card/card-footer.svelte +20 -0
  112. package/dist/components/ui/card/card-footer.svelte.d.ts +5 -0
  113. package/dist/components/ui/card/card-header.svelte +23 -0
  114. package/dist/components/ui/card/card-header.svelte.d.ts +5 -0
  115. package/dist/components/ui/card/card-title.svelte +20 -0
  116. package/dist/components/ui/card/card-title.svelte.d.ts +5 -0
  117. package/dist/components/ui/card/card.svelte +23 -0
  118. package/dist/components/ui/card/card.svelte.d.ts +5 -0
  119. package/dist/components/ui/card/index.d.ts +8 -0
  120. package/dist/components/ui/card/index.js +10 -0
  121. package/dist/components/ui/checkbox/checkbox.svelte +36 -0
  122. package/dist/components/ui/checkbox/checkbox.svelte.d.ts +4 -0
  123. package/dist/components/ui/checkbox/index.d.ts +2 -0
  124. package/dist/components/ui/checkbox/index.js +4 -0
  125. package/dist/components/ui/collapsible/collapsible-content.svelte +7 -0
  126. package/dist/components/ui/collapsible/collapsible-content.svelte.d.ts +4 -0
  127. package/dist/components/ui/collapsible/collapsible-trigger.svelte +7 -0
  128. package/dist/components/ui/collapsible/collapsible-trigger.svelte.d.ts +4 -0
  129. package/dist/components/ui/collapsible/collapsible.svelte +11 -0
  130. package/dist/components/ui/collapsible/collapsible.svelte.d.ts +4 -0
  131. package/dist/components/ui/collapsible/index.d.ts +4 -0
  132. package/dist/components/ui/collapsible/index.js +6 -0
  133. package/dist/components/ui/context-menu/context-menu-checkbox-item.svelte +38 -0
  134. package/dist/components/ui/context-menu/context-menu-checkbox-item.svelte.d.ts +9 -0
  135. package/dist/components/ui/context-menu/context-menu-content.svelte +25 -0
  136. package/dist/components/ui/context-menu/context-menu-content.svelte.d.ts +7 -0
  137. package/dist/components/ui/context-menu/context-menu-group-heading.svelte +21 -0
  138. package/dist/components/ui/context-menu/context-menu-group-heading.svelte.d.ts +7 -0
  139. package/dist/components/ui/context-menu/context-menu-group.svelte +7 -0
  140. package/dist/components/ui/context-menu/context-menu-group.svelte.d.ts +4 -0
  141. package/dist/components/ui/context-menu/context-menu-item.svelte +27 -0
  142. package/dist/components/ui/context-menu/context-menu-item.svelte.d.ts +8 -0
  143. package/dist/components/ui/context-menu/context-menu-label.svelte +24 -0
  144. package/dist/components/ui/context-menu/context-menu-label.svelte.d.ts +8 -0
  145. package/dist/components/ui/context-menu/context-menu-radio-group.svelte +16 -0
  146. package/dist/components/ui/context-menu/context-menu-radio-group.svelte.d.ts +4 -0
  147. package/dist/components/ui/context-menu/context-menu-radio-item.svelte +31 -0
  148. package/dist/components/ui/context-menu/context-menu-radio-item.svelte.d.ts +4 -0
  149. package/dist/components/ui/context-menu/context-menu-separator.svelte +17 -0
  150. package/dist/components/ui/context-menu/context-menu-separator.svelte.d.ts +4 -0
  151. package/dist/components/ui/context-menu/context-menu-shortcut.svelte +20 -0
  152. package/dist/components/ui/context-menu/context-menu-shortcut.svelte.d.ts +5 -0
  153. package/dist/components/ui/context-menu/context-menu-sub-content.svelte +20 -0
  154. package/dist/components/ui/context-menu/context-menu-sub-content.svelte.d.ts +4 -0
  155. package/dist/components/ui/context-menu/context-menu-sub-trigger.svelte +29 -0
  156. package/dist/components/ui/context-menu/context-menu-sub-trigger.svelte.d.ts +8 -0
  157. package/dist/components/ui/context-menu/context-menu-trigger.svelte +7 -0
  158. package/dist/components/ui/context-menu/context-menu-trigger.svelte.d.ts +4 -0
  159. package/dist/components/ui/context-menu/index.d.ts +16 -0
  160. package/dist/components/ui/context-menu/index.js +19 -0
  161. package/dist/components/ui/dialog/dialog-close.svelte +7 -0
  162. package/dist/components/ui/dialog/dialog-close.svelte.d.ts +4 -0
  163. package/dist/components/ui/dialog/dialog-content.svelte +43 -0
  164. package/dist/components/ui/dialog/dialog-content.svelte.d.ts +11 -0
  165. package/dist/components/ui/dialog/dialog-description.svelte +17 -0
  166. package/dist/components/ui/dialog/dialog-description.svelte.d.ts +4 -0
  167. package/dist/components/ui/dialog/dialog-footer.svelte +20 -0
  168. package/dist/components/ui/dialog/dialog-footer.svelte.d.ts +5 -0
  169. package/dist/components/ui/dialog/dialog-header.svelte +20 -0
  170. package/dist/components/ui/dialog/dialog-header.svelte.d.ts +5 -0
  171. package/dist/components/ui/dialog/dialog-overlay.svelte +20 -0
  172. package/dist/components/ui/dialog/dialog-overlay.svelte.d.ts +4 -0
  173. package/dist/components/ui/dialog/dialog-title.svelte +17 -0
  174. package/dist/components/ui/dialog/dialog-title.svelte.d.ts +4 -0
  175. package/dist/components/ui/dialog/dialog-trigger.svelte +7 -0
  176. package/dist/components/ui/dialog/dialog-trigger.svelte.d.ts +4 -0
  177. package/dist/components/ui/dialog/index.d.ts +11 -0
  178. package/dist/components/ui/dialog/index.js +14 -0
  179. package/dist/components/ui/field/field-content.svelte +20 -0
  180. package/dist/components/ui/field/field-content.svelte.d.ts +5 -0
  181. package/dist/components/ui/field/field-description.svelte +25 -0
  182. package/dist/components/ui/field/field-description.svelte.d.ts +5 -0
  183. package/dist/components/ui/field/field-error.svelte +58 -0
  184. package/dist/components/ui/field/field-error.svelte.d.ts +12 -0
  185. package/dist/components/ui/field/field-group.svelte +23 -0
  186. package/dist/components/ui/field/field-group.svelte.d.ts +5 -0
  187. package/dist/components/ui/field/field-label.svelte +26 -0
  188. package/dist/components/ui/field/field-label.svelte.d.ts +10 -0
  189. package/dist/components/ui/field/field-legend.svelte +29 -0
  190. package/dist/components/ui/field/field-legend.svelte.d.ts +8 -0
  191. package/dist/components/ui/field/field-separator.svelte +38 -0
  192. package/dist/components/ui/field/field-separator.svelte.d.ts +9 -0
  193. package/dist/components/ui/field/field-set.svelte +24 -0
  194. package/dist/components/ui/field/field-set.svelte.d.ts +5 -0
  195. package/dist/components/ui/field/field-title.svelte +23 -0
  196. package/dist/components/ui/field/field-title.svelte.d.ts +5 -0
  197. package/dist/components/ui/field/field.svelte +53 -0
  198. package/dist/components/ui/field/field.svelte.d.ts +29 -0
  199. package/dist/components/ui/field/index.d.ts +11 -0
  200. package/dist/components/ui/field/index.js +13 -0
  201. package/dist/components/ui/index.d.ts +21 -0
  202. package/dist/components/ui/index.js +24 -0
  203. package/dist/components/ui/input/index.d.ts +2 -0
  204. package/dist/components/ui/input/index.js +4 -0
  205. package/dist/components/ui/input/input.svelte +52 -0
  206. package/dist/components/ui/input/input.svelte.d.ts +13 -0
  207. package/dist/components/ui/label/index.d.ts +2 -0
  208. package/dist/components/ui/label/index.js +4 -0
  209. package/dist/components/ui/label/label.svelte +20 -0
  210. package/dist/components/ui/label/label.svelte.d.ts +4 -0
  211. package/dist/components/ui/mode-toggle/index.d.ts +1 -0
  212. package/dist/components/ui/mode-toggle/index.js +1 -0
  213. package/dist/components/ui/mode-toggle/mode-toggle.svelte +16 -0
  214. package/dist/components/ui/mode-toggle/mode-toggle.svelte.d.ts +18 -0
  215. package/dist/components/ui/resizable/index.d.ts +4 -0
  216. package/dist/components/ui/resizable/index.js +6 -0
  217. package/dist/components/ui/resizable/resizable-handle.svelte +30 -0
  218. package/dist/components/ui/resizable/resizable-handle.svelte.d.ts +8 -0
  219. package/dist/components/ui/resizable/resizable-pane-group.svelte +20 -0
  220. package/dist/components/ui/resizable/resizable-pane-group.svelte.d.ts +7 -0
  221. package/dist/components/ui/scroll-area/index.d.ts +3 -0
  222. package/dist/components/ui/scroll-area/index.js +5 -0
  223. package/dist/components/ui/scroll-area/scroll-area-scrollbar.svelte +31 -0
  224. package/dist/components/ui/scroll-area/scroll-area-scrollbar.svelte.d.ts +4 -0
  225. package/dist/components/ui/scroll-area/scroll-area.svelte +43 -0
  226. package/dist/components/ui/scroll-area/scroll-area.svelte.d.ts +11 -0
  227. package/dist/components/ui/select/index.d.ts +11 -0
  228. package/dist/components/ui/select/index.js +14 -0
  229. package/dist/components/ui/select/select-content.svelte +40 -0
  230. package/dist/components/ui/select/select-content.svelte.d.ts +8 -0
  231. package/dist/components/ui/select/select-group-heading.svelte +21 -0
  232. package/dist/components/ui/select/select-group-heading.svelte.d.ts +10 -0
  233. package/dist/components/ui/select/select-group.svelte +7 -0
  234. package/dist/components/ui/select/select-group.svelte.d.ts +4 -0
  235. package/dist/components/ui/select/select-item.svelte +38 -0
  236. package/dist/components/ui/select/select-item.svelte.d.ts +4 -0
  237. package/dist/components/ui/select/select-label.svelte +20 -0
  238. package/dist/components/ui/select/select-label.svelte.d.ts +6 -0
  239. package/dist/components/ui/select/select-scroll-down-button.svelte +20 -0
  240. package/dist/components/ui/select/select-scroll-down-button.svelte.d.ts +4 -0
  241. package/dist/components/ui/select/select-scroll-up-button.svelte +20 -0
  242. package/dist/components/ui/select/select-scroll-up-button.svelte.d.ts +4 -0
  243. package/dist/components/ui/select/select-separator.svelte +18 -0
  244. package/dist/components/ui/select/select-separator.svelte.d.ts +4 -0
  245. package/dist/components/ui/select/select-trigger.svelte +29 -0
  246. package/dist/components/ui/select/select-trigger.svelte.d.ts +8 -0
  247. package/dist/components/ui/separator/index.d.ts +2 -0
  248. package/dist/components/ui/separator/index.js +4 -0
  249. package/dist/components/ui/separator/separator.svelte +21 -0
  250. package/dist/components/ui/separator/separator.svelte.d.ts +4 -0
  251. package/dist/components/ui/slider/index.d.ts +2 -0
  252. package/dist/components/ui/slider/index.js +4 -0
  253. package/dist/components/ui/slider/slider.svelte +52 -0
  254. package/dist/components/ui/slider/slider.svelte.d.ts +5 -0
  255. package/dist/components/ui/sonner/index.d.ts +2 -0
  256. package/dist/components/ui/sonner/index.js +2 -0
  257. package/dist/components/ui/sonner/sonner.svelte +13 -0
  258. package/dist/components/ui/sonner/sonner.svelte.d.ts +4 -0
  259. package/dist/components/ui/switch/index.d.ts +2 -0
  260. package/dist/components/ui/switch/index.js +4 -0
  261. package/dist/components/ui/switch/switch.svelte +29 -0
  262. package/dist/components/ui/switch/switch.svelte.d.ts +4 -0
  263. package/dist/components/ui/tabs/index.d.ts +5 -0
  264. package/dist/components/ui/tabs/index.js +7 -0
  265. package/dist/components/ui/tabs/tabs-content.svelte +17 -0
  266. package/dist/components/ui/tabs/tabs-content.svelte.d.ts +4 -0
  267. package/dist/components/ui/tabs/tabs-list.svelte +16 -0
  268. package/dist/components/ui/tabs/tabs-list.svelte.d.ts +4 -0
  269. package/dist/components/ui/tabs/tabs-trigger.svelte +20 -0
  270. package/dist/components/ui/tabs/tabs-trigger.svelte.d.ts +4 -0
  271. package/dist/components/ui/tabs/tabs.svelte +19 -0
  272. package/dist/components/ui/tabs/tabs.svelte.d.ts +4 -0
  273. package/dist/components/ui/textarea/index.d.ts +2 -0
  274. package/dist/components/ui/textarea/index.js +4 -0
  275. package/dist/components/ui/textarea/textarea.svelte +23 -0
  276. package/dist/components/ui/textarea/textarea.svelte.d.ts +5 -0
  277. package/dist/components/ui/theme-switcher/ThemeSwitcher.svelte +39 -0
  278. package/dist/components/ui/theme-switcher/ThemeSwitcher.svelte.d.ts +3 -0
  279. package/dist/components/ui/theme-switcher/index.d.ts +1 -0
  280. package/dist/components/ui/theme-switcher/index.js +1 -0
  281. package/dist/composables/useFooterItem.svelte.d.ts +15 -0
  282. package/dist/composables/useFooterItem.svelte.js +31 -0
  283. package/dist/constants.d.ts +6 -0
  284. package/dist/constants.js +6 -0
  285. package/dist/contexts/FOOTER_USAGE.md +164 -0
  286. package/dist/contexts/footerContext.svelte.d.ts +17 -0
  287. package/dist/contexts/footerContext.svelte.js +24 -0
  288. package/dist/dummy-output-values.d.ts +3 -0
  289. package/dist/dummy-output-values.js +53 -0
  290. package/dist/dummy-surface-chart.json +13 -0
  291. package/dist/example-schema-left-only.json +367 -0
  292. package/dist/example-schema-right-only.json +322 -0
  293. package/dist/example-schema.json +1582 -0
  294. package/dist/features/preview/handlers.d.ts +55 -0
  295. package/dist/features/preview/handlers.js +175 -0
  296. package/dist/features/preview/index.d.ts +2 -0
  297. package/dist/features/preview/index.js +2 -0
  298. package/dist/features/preview/notifications.d.ts +11 -0
  299. package/dist/features/preview/notifications.js +41 -0
  300. package/dist/index.d.ts +29 -0
  301. package/dist/index.js +39 -0
  302. package/dist/stores/themeStore.svelte.d.ts +12 -0
  303. package/dist/stores/themeStore.svelte.js +42 -0
  304. package/dist/styles/base.css +142 -0
  305. package/dist/styles/themes/cyberpunk.css +98 -0
  306. package/dist/styles/themes/neutral.css +72 -0
  307. package/dist/styles/themes/ocean.css +75 -0
  308. package/dist/styles/themes/selva.css +105 -0
  309. package/dist/themes.d.ts +5 -0
  310. package/dist/themes.js +13 -0
  311. package/dist/types/generated/index.d.ts +6 -0
  312. package/dist/types/generated/index.js +6 -0
  313. package/dist/types/generated/preset.d.ts +80 -0
  314. package/dist/types/generated/preset.js +7 -0
  315. package/dist/types/generated/schema.d.ts +451 -0
  316. package/dist/types/generated/schema.js +48 -0
  317. package/dist/utils/computeThrottle.svelte.d.ts +28 -0
  318. package/dist/utils/computeThrottle.svelte.js +93 -0
  319. package/dist/utils/debounce.d.ts +14 -0
  320. package/dist/utils/debounce.js +25 -0
  321. package/dist/utils/file-download.d.ts +26 -0
  322. package/dist/utils/file-download.js +76 -0
  323. package/dist/utils/loadScript.d.ts +14 -0
  324. package/dist/utils/loadScript.js +41 -0
  325. package/dist/utils/param-exporter.d.ts +30 -0
  326. package/dist/utils/param-exporter.js +186 -0
  327. package/dist/utils/solving.svelte.d.ts +12 -0
  328. package/dist/utils/solving.svelte.js +86 -0
  329. package/dist/utils/utils-shared.d.ts +9 -0
  330. package/dist/utils/utils-shared.js +53 -0
  331. package/dist/utils/visibility-rules.d.ts +12 -0
  332. package/dist/utils/visibility-rules.js +52 -0
  333. package/dist/utils.d.ts +12 -0
  334. package/dist/utils.js +5 -0
  335. package/package.json +70 -0
  336. package/src/lib/components/AppLayout.svelte +439 -0
  337. package/src/lib/components/CollapsedPanelStrip.svelte +67 -0
  338. package/src/lib/components/ComputeMessages.svelte +172 -0
  339. package/src/lib/components/ErrorScreen.svelte +55 -0
  340. package/src/lib/components/StateManager.svelte +318 -0
  341. package/src/lib/components/Viewer.svelte +207 -0
  342. package/src/lib/components/layout/FooterItemRenderer.svelte +20 -0
  343. package/src/lib/components/layout/PageContainer.svelte +36 -0
  344. package/src/lib/components/layout/PageFooter.svelte +223 -0
  345. package/src/lib/components/layout/PageHeader.svelte +89 -0
  346. package/src/lib/components/layout/index.ts +4 -0
  347. package/src/lib/components/preview/ChartOutput.svelte +257 -0
  348. package/src/lib/components/preview/Group.svelte +121 -0
  349. package/src/lib/components/preview/InputControl.svelte +119 -0
  350. package/src/lib/components/preview/OutputDisplay.svelte +296 -0
  351. package/src/lib/components/preview/TabBar.svelte +36 -0
  352. package/src/lib/components/preview/TabContent.svelte +124 -0
  353. package/src/lib/components/preview/TabLayout.svelte +109 -0
  354. package/src/lib/components/preview/index.ts +4 -0
  355. package/src/lib/components/preview/inputs/CheckboxInput.svelte +29 -0
  356. package/src/lib/components/preview/inputs/ColorInput.svelte +21 -0
  357. package/src/lib/components/preview/inputs/DropdownInput.svelte +40 -0
  358. package/src/lib/components/preview/inputs/FileInput.svelte +358 -0
  359. package/src/lib/components/preview/inputs/NumberInput.svelte +152 -0
  360. package/src/lib/components/preview/inputs/TextInput.svelte +74 -0
  361. package/src/lib/components/preview/inputs/index.ts +6 -0
  362. package/src/lib/components/ui/CalculateButton.svelte +56 -0
  363. package/src/lib/components/ui/SolvingIndicator.svelte +55 -0
  364. package/src/lib/components/ui/StateDisplay.svelte +106 -0
  365. package/src/lib/components/ui/alert/alert-description.svelte +23 -0
  366. package/src/lib/components/ui/alert/alert-title.svelte +20 -0
  367. package/src/lib/components/ui/alert/alert.svelte +44 -0
  368. package/src/lib/components/ui/alert/index.ts +14 -0
  369. package/src/lib/components/ui/alert-dialog/alert-dialog-action.svelte +18 -0
  370. package/src/lib/components/ui/alert-dialog/alert-dialog-cancel.svelte +18 -0
  371. package/src/lib/components/ui/alert-dialog/alert-dialog-content.svelte +27 -0
  372. package/src/lib/components/ui/alert-dialog/alert-dialog-description.svelte +17 -0
  373. package/src/lib/components/ui/alert-dialog/alert-dialog-footer.svelte +20 -0
  374. package/src/lib/components/ui/alert-dialog/alert-dialog-header.svelte +20 -0
  375. package/src/lib/components/ui/alert-dialog/alert-dialog-overlay.svelte +20 -0
  376. package/src/lib/components/ui/alert-dialog/alert-dialog-title.svelte +17 -0
  377. package/src/lib/components/ui/alert-dialog/alert-dialog-trigger.svelte +7 -0
  378. package/src/lib/components/ui/alert-dialog/index.ts +39 -0
  379. package/src/lib/components/ui/badge/badge.svelte +50 -0
  380. package/src/lib/components/ui/badge/index.ts +2 -0
  381. package/src/lib/components/ui/button/button.svelte +83 -0
  382. package/src/lib/components/ui/button/index.ts +17 -0
  383. package/src/lib/components/ui/button-group/button-group-separator.svelte +20 -0
  384. package/src/lib/components/ui/button-group/button-group-text.svelte +30 -0
  385. package/src/lib/components/ui/button-group/button-group.svelte +46 -0
  386. package/src/lib/components/ui/button-group/index.ts +13 -0
  387. package/src/lib/components/ui/card/card-action.svelte +20 -0
  388. package/src/lib/components/ui/card/card-content.svelte +15 -0
  389. package/src/lib/components/ui/card/card-description.svelte +20 -0
  390. package/src/lib/components/ui/card/card-footer.svelte +20 -0
  391. package/src/lib/components/ui/card/card-header.svelte +23 -0
  392. package/src/lib/components/ui/card/card-title.svelte +20 -0
  393. package/src/lib/components/ui/card/card.svelte +23 -0
  394. package/src/lib/components/ui/card/index.ts +25 -0
  395. package/src/lib/components/ui/checkbox/checkbox.svelte +36 -0
  396. package/src/lib/components/ui/checkbox/index.ts +6 -0
  397. package/src/lib/components/ui/collapsible/collapsible-content.svelte +7 -0
  398. package/src/lib/components/ui/collapsible/collapsible-trigger.svelte +7 -0
  399. package/src/lib/components/ui/collapsible/collapsible.svelte +11 -0
  400. package/src/lib/components/ui/collapsible/index.ts +13 -0
  401. package/src/lib/components/ui/context-menu/context-menu-checkbox-item.svelte +38 -0
  402. package/src/lib/components/ui/context-menu/context-menu-content.svelte +25 -0
  403. package/src/lib/components/ui/context-menu/context-menu-group-heading.svelte +21 -0
  404. package/src/lib/components/ui/context-menu/context-menu-group.svelte +7 -0
  405. package/src/lib/components/ui/context-menu/context-menu-item.svelte +27 -0
  406. package/src/lib/components/ui/context-menu/context-menu-label.svelte +24 -0
  407. package/src/lib/components/ui/context-menu/context-menu-radio-group.svelte +16 -0
  408. package/src/lib/components/ui/context-menu/context-menu-radio-item.svelte +31 -0
  409. package/src/lib/components/ui/context-menu/context-menu-separator.svelte +17 -0
  410. package/src/lib/components/ui/context-menu/context-menu-shortcut.svelte +20 -0
  411. package/src/lib/components/ui/context-menu/context-menu-sub-content.svelte +20 -0
  412. package/src/lib/components/ui/context-menu/context-menu-sub-trigger.svelte +29 -0
  413. package/src/lib/components/ui/context-menu/context-menu-trigger.svelte +7 -0
  414. package/src/lib/components/ui/context-menu/index.ts +51 -0
  415. package/src/lib/components/ui/dialog/dialog-close.svelte +7 -0
  416. package/src/lib/components/ui/dialog/dialog-content.svelte +43 -0
  417. package/src/lib/components/ui/dialog/dialog-description.svelte +17 -0
  418. package/src/lib/components/ui/dialog/dialog-footer.svelte +20 -0
  419. package/src/lib/components/ui/dialog/dialog-header.svelte +20 -0
  420. package/src/lib/components/ui/dialog/dialog-overlay.svelte +20 -0
  421. package/src/lib/components/ui/dialog/dialog-title.svelte +17 -0
  422. package/src/lib/components/ui/dialog/dialog-trigger.svelte +7 -0
  423. package/src/lib/components/ui/dialog/index.ts +37 -0
  424. package/src/lib/components/ui/field/field-content.svelte +20 -0
  425. package/src/lib/components/ui/field/field-description.svelte +25 -0
  426. package/src/lib/components/ui/field/field-error.svelte +58 -0
  427. package/src/lib/components/ui/field/field-group.svelte +23 -0
  428. package/src/lib/components/ui/field/field-label.svelte +26 -0
  429. package/src/lib/components/ui/field/field-legend.svelte +29 -0
  430. package/src/lib/components/ui/field/field-separator.svelte +38 -0
  431. package/src/lib/components/ui/field/field-set.svelte +24 -0
  432. package/src/lib/components/ui/field/field-title.svelte +23 -0
  433. package/src/lib/components/ui/field/field.svelte +53 -0
  434. package/src/lib/components/ui/field/index.ts +33 -0
  435. package/src/lib/components/ui/index.ts +33 -0
  436. package/src/lib/components/ui/input/index.ts +7 -0
  437. package/src/lib/components/ui/input/input.svelte +52 -0
  438. package/src/lib/components/ui/label/index.ts +7 -0
  439. package/src/lib/components/ui/label/label.svelte +20 -0
  440. package/src/lib/components/ui/mode-toggle/index.ts +1 -0
  441. package/src/lib/components/ui/mode-toggle/mode-toggle.svelte +16 -0
  442. package/src/lib/components/ui/resizable/index.ts +13 -0
  443. package/src/lib/components/ui/resizable/resizable-handle.svelte +30 -0
  444. package/src/lib/components/ui/resizable/resizable-pane-group.svelte +20 -0
  445. package/src/lib/components/ui/scroll-area/index.ts +10 -0
  446. package/src/lib/components/ui/scroll-area/scroll-area-scrollbar.svelte +31 -0
  447. package/src/lib/components/ui/scroll-area/scroll-area.svelte +43 -0
  448. package/src/lib/components/ui/select/index.ts +37 -0
  449. package/src/lib/components/ui/select/select-content.svelte +40 -0
  450. package/src/lib/components/ui/select/select-group-heading.svelte +21 -0
  451. package/src/lib/components/ui/select/select-group.svelte +7 -0
  452. package/src/lib/components/ui/select/select-item.svelte +38 -0
  453. package/src/lib/components/ui/select/select-label.svelte +20 -0
  454. package/src/lib/components/ui/select/select-scroll-down-button.svelte +20 -0
  455. package/src/lib/components/ui/select/select-scroll-up-button.svelte +20 -0
  456. package/src/lib/components/ui/select/select-separator.svelte +18 -0
  457. package/src/lib/components/ui/select/select-trigger.svelte +29 -0
  458. package/src/lib/components/ui/separator/index.ts +7 -0
  459. package/src/lib/components/ui/separator/separator.svelte +21 -0
  460. package/src/lib/components/ui/slider/index.ts +7 -0
  461. package/src/lib/components/ui/slider/slider.svelte +52 -0
  462. package/src/lib/components/ui/sonner/index.ts +2 -0
  463. package/src/lib/components/ui/sonner/sonner.svelte +13 -0
  464. package/src/lib/components/ui/switch/index.ts +7 -0
  465. package/src/lib/components/ui/switch/switch.svelte +29 -0
  466. package/src/lib/components/ui/tabs/index.ts +16 -0
  467. package/src/lib/components/ui/tabs/tabs-content.svelte +17 -0
  468. package/src/lib/components/ui/tabs/tabs-list.svelte +16 -0
  469. package/src/lib/components/ui/tabs/tabs-trigger.svelte +20 -0
  470. package/src/lib/components/ui/tabs/tabs.svelte +19 -0
  471. package/src/lib/components/ui/textarea/index.ts +7 -0
  472. package/src/lib/components/ui/textarea/textarea.svelte +23 -0
  473. package/src/lib/components/ui/theme-switcher/ThemeSwitcher.svelte +39 -0
  474. package/src/lib/components/ui/theme-switcher/index.ts +1 -0
  475. package/src/lib/composables/useFooterItem.svelte.ts +39 -0
  476. package/src/lib/constants.ts +6 -0
  477. package/src/lib/contexts/FOOTER_USAGE.md +164 -0
  478. package/src/lib/contexts/footerContext.svelte.ts +52 -0
  479. package/src/lib/dummy-output-values.ts +62 -0
  480. package/src/lib/dummy-surface-chart.json +13 -0
  481. package/src/lib/example-schema-left-only.json +367 -0
  482. package/src/lib/example-schema-right-only.json +322 -0
  483. package/src/lib/example-schema.json +1582 -0
  484. package/src/lib/features/preview/handlers.ts +243 -0
  485. package/src/lib/features/preview/index.ts +2 -0
  486. package/src/lib/features/preview/notifications.ts +52 -0
  487. package/src/lib/index.ts +52 -0
  488. package/src/lib/stores/themeStore.svelte.ts +54 -0
  489. package/src/lib/styles/base.css +142 -0
  490. package/src/lib/styles/themes/cyberpunk.css +98 -0
  491. package/src/lib/styles/themes/neutral.css +72 -0
  492. package/src/lib/styles/themes/ocean.css +75 -0
  493. package/src/lib/styles/themes/selva.css +105 -0
  494. package/src/lib/themes.ts +18 -0
  495. package/src/lib/types/generated/index.ts +6 -0
  496. package/src/lib/types/generated/preset.ts +82 -0
  497. package/src/lib/types/generated/schema.ts +527 -0
  498. package/src/lib/utils/computeThrottle.svelte.ts +117 -0
  499. package/src/lib/utils/debounce.ts +30 -0
  500. package/src/lib/utils/file-download.ts +88 -0
  501. package/src/lib/utils/loadScript.ts +52 -0
  502. package/src/lib/utils/param-exporter.ts +242 -0
  503. package/src/lib/utils/solving.svelte.ts +100 -0
  504. package/src/lib/utils/utils-shared.ts +57 -0
  505. package/src/lib/utils/visibility-rules.ts +97 -0
  506. package/src/lib/utils.ts +13 -0
@@ -0,0 +1,172 @@
1
+ <script lang="ts">
2
+ import { CircleAlert, TriangleAlert, ChevronDown, ChevronRight } from '@lucide/svelte';
3
+ import { SvelteMap } from 'svelte/reactivity';
4
+ import * as Collapsible from './ui/collapsible';
5
+ import * as Dialog from './ui/dialog';
6
+
7
+ interface Props {
8
+ errors?: string[];
9
+ warnings?: string[];
10
+ }
11
+
12
+ let { errors = [], warnings = [] }: Props = $props();
13
+
14
+ let open = $state(false);
15
+
16
+ let showErrors = $state(true);
17
+ let showWarnings = $state(false);
18
+
19
+ function groupMessages(messages: string[]): Array<{ message: string; count: number }> {
20
+ const grouped = new SvelteMap<string, number>();
21
+
22
+ for (const msg of messages) {
23
+ // Extract the base message without the component GUID
24
+ const baseMsg = msg.replace(/\([a-f0-9-]{36}\)$/i, '(...)').trim();
25
+ const currentCount = grouped.get(baseMsg) || 0;
26
+ grouped.set(baseMsg, currentCount + 1);
27
+ }
28
+
29
+ return Array.from(grouped.entries())
30
+ .map(([message, count]) => ({ message, count }))
31
+ .sort((a, b) => b.count - a.count);
32
+ }
33
+
34
+ const groupedErrors = $derived(groupMessages(errors));
35
+ const groupedWarnings = $derived(groupMessages(warnings));
36
+ const hasMessages = $derived(errors.length > 0 || warnings.length > 0);
37
+ const totalCount = $derived(errors.length + warnings.length);
38
+ </script>
39
+
40
+ {#if hasMessages}
41
+ <!-- Floating Indicator Badge (hidden on mobile) -->
42
+ <Dialog.Root bind:open>
43
+ <Dialog.Trigger
44
+ class="bottom-12 right-2 sm:bottom-4 sm:right-4 sm:block fixed z-100 hidden focus:outline-none"
45
+ >
46
+ <div
47
+ class="shadow-lg text-xs font-medium hover:shadow-xl hover:-translate-y-0.5 active:translate-y-0 flex cursor-pointer items-stretch overflow-hidden rounded-full border transition-all duration-150
48
+ {errors.length > 0
49
+ ? 'text-destructive-foreground border-destructive/30 bg-destructive'
50
+ : 'border-warning/30 bg-warning/5 text-warning-foreground'}"
51
+ >
52
+ {#if errors.length > 0}
53
+ <span class="gap-1.5 px-3 py-1.5 flex items-center">
54
+ <CircleAlert class="h-3.5 w-3.5 shrink-0" />
55
+ {errors.length}
56
+ </span>
57
+ {/if}
58
+ {#if warnings.length > 0}
59
+ {#if errors.length > 0}
60
+ <span class="bg-destructive-foreground/20 w-px self-stretch"></span>
61
+ <span class="gap-1.5 px-3 py-1.5 flex items-center bg-destructive/80">
62
+ <TriangleAlert class="h-3.5 w-3.5 shrink-0" />
63
+ {warnings.length}
64
+ </span>
65
+ {:else}
66
+ <span class="gap-1.5 px-3 py-1.5 flex items-center">
67
+ <TriangleAlert class="h-3.5 w-3.5 shrink-0" />
68
+ {warnings.length}
69
+ </span>
70
+ {/if}
71
+ {/if}
72
+ </div>
73
+ </Dialog.Trigger>
74
+
75
+ <Dialog.Content class="max-w-2xl max-h-[80vh]">
76
+ <Dialog.Header>
77
+ <Dialog.Title class="gap-2 flex items-center">
78
+ <CircleAlert class="h-5 w-5" />
79
+ Compute Messages
80
+ </Dialog.Title>
81
+ <Dialog.Description>
82
+ {totalCount}
83
+ {totalCount === 1 ? 'issue' : 'issues'} detected during solve
84
+ </Dialog.Description>
85
+ </Dialog.Header>
86
+
87
+ <div class="space-y-3 pr-2 overflow-y-auto" style="max-height: calc(80vh - 180px);">
88
+ <!-- Errors Section -->
89
+ {#if errors.length > 0}
90
+ <Collapsible.Root bind:open={showErrors}>
91
+ <div class="overflow-hidden rounded-lg border border-destructive bg-card">
92
+ <div class="px-4 py-3 flex items-center">
93
+ <Collapsible.Trigger
94
+ class="-mx-4 -my-3 gap-3 px-4 py-3 flex flex-1 items-center text-left transition-colors hover:bg-destructive/5"
95
+ >
96
+ {#if showErrors}
97
+ <ChevronDown class="h-4 w-4 shrink-0 text-destructive" />
98
+ {:else}
99
+ <ChevronRight class="h-4 w-4 shrink-0 text-destructive" />
100
+ {/if}
101
+ <CircleAlert class="h-4 w-4 shrink-0 text-destructive" />
102
+ <span class="text-sm font-medium text-destructive">
103
+ {errors.length === 1 ? '1 Error' : `${errors.length} Errors`}
104
+ </span>
105
+ </Collapsible.Trigger>
106
+ </div>
107
+
108
+ <Collapsible.Content class="space-y-0">
109
+ <div class="max-h-60 px-4 py-3 overflow-y-auto border-t border-destructive bg-card">
110
+ <ul class="space-y-2">
111
+ {#each groupedErrors as { message, count } (message)}
112
+ <li class="gap-2 text-sm flex text-destructive/90">
113
+ <span class="shrink-0">•</span>
114
+ <span class="flex-1">
115
+ {message}
116
+ {#if count > 1}
117
+ <span class="ml-1 font-medium text-destructive/70">×{count} </span>
118
+ {/if}
119
+ </span>
120
+ </li>
121
+ {/each}
122
+ </ul>
123
+ </div>
124
+ </Collapsible.Content>
125
+ </div>
126
+ </Collapsible.Root>
127
+ {/if}
128
+
129
+ <!-- Warnings Section -->
130
+ {#if warnings.length > 0}
131
+ <Collapsible.Root bind:open={showWarnings}>
132
+ <div class="overflow-hidden rounded-lg border border-warning/50 bg-card">
133
+ <div class="px-4 py-3 flex items-center">
134
+ <Collapsible.Trigger
135
+ class="-mx-4 -my-3 gap-3 px-4 py-3 flex flex-1 items-center text-left transition-colors hover:bg-warning/5"
136
+ >
137
+ {#if showWarnings}
138
+ <ChevronDown class="h-4 w-4 shrink-0 text-warning" />
139
+ {:else}
140
+ <ChevronRight class="h-4 w-4 shrink-0 text-warning" />
141
+ {/if}
142
+ <TriangleAlert class="h-4 w-4 shrink-0 text-warning" />
143
+ <span class="text-sm font-medium text-warning">
144
+ {warnings.length === 1 ? '1 Warning' : `${warnings.length} Warnings`}
145
+ </span>
146
+ </Collapsible.Trigger>
147
+ </div>
148
+
149
+ <Collapsible.Content class="space-y-0">
150
+ <div class="max-h-60 px-4 py-3 overflow-y-auto border-t border-warning/50 bg-card">
151
+ <ul class="space-y-2">
152
+ {#each groupedWarnings as { message, count } (message)}
153
+ <li class="gap-2 text-sm flex text-muted-foreground">
154
+ <span class="shrink-0">•</span>
155
+ <span class="flex-1">
156
+ {message}
157
+ {#if count > 1}
158
+ <span class="ml-1 font-medium text-warning/70">×{count}</span>
159
+ {/if}
160
+ </span>
161
+ </li>
162
+ {/each}
163
+ </ul>
164
+ </div>
165
+ </Collapsible.Content>
166
+ </div>
167
+ </Collapsible.Root>
168
+ {/if}
169
+ </div>
170
+ </Dialog.Content>
171
+ </Dialog.Root>
172
+ {/if}
@@ -0,0 +1,7 @@
1
+ interface Props {
2
+ errors?: string[];
3
+ warnings?: string[];
4
+ }
5
+ declare const ComputeMessages: import("svelte").Component<Props, {}, "">;
6
+ type ComputeMessages = ReturnType<typeof ComputeMessages>;
7
+ export default ComputeMessages;
@@ -0,0 +1,55 @@
1
+ <script lang="ts">
2
+ import { AlertCircle } from '@lucide/svelte';
3
+ import * as Card from './ui/card/index.js';
4
+ import { Button } from './ui/button/index.js';
5
+
6
+ interface Props {
7
+ status?: number;
8
+ message?: string;
9
+ details?: string;
10
+ homeLink?: string;
11
+ }
12
+
13
+ let { status = 500, message, details, homeLink = '/' }: Props = $props();
14
+ </script>
15
+
16
+ <div
17
+ class="p-4 flex min-h-screen items-center justify-center bg-background"
18
+ >
19
+ <Card.Root class="max-w-md w-full">
20
+ <Card.Header class="text-center">
21
+ <div class="mb-4 flex justify-center">
22
+ <div class="p-3 rounded-full bg-destructive/10">
23
+ <AlertCircle class="h-8 w-8 text-destructive" />
24
+ </div>
25
+ </div>
26
+ <Card.Title class="text-3xl">{status}</Card.Title>
27
+ </Card.Header>
28
+ <Card.Content class="space-y-4">
29
+ <div class="p-4 rounded-lg border border-destructive/50 bg-destructive/10">
30
+ <div class="gap-3 flex">
31
+ <AlertCircle class="mt-0.5 h-4 w-4 shrink-0 text-destructive" />
32
+ <div class="flex-1">
33
+ <p class="text-sm font-semibold text-destructive">Error</p>
34
+ {#if message}
35
+ <p class="text-sm text-destructive/80">{message}</p>
36
+ {/if}
37
+ </div>
38
+ </div>
39
+ </div>
40
+
41
+ {#if details}
42
+ <div class="bg-muted p-4 rounded-lg">
43
+ <p class="font-mono text-sm text-muted-foreground break-all">
44
+ {details}
45
+ </p>
46
+ </div>
47
+ {/if}
48
+ </Card.Content>
49
+ <Card.Footer class="gap-2 flex">
50
+ <Button variant="outline" class="flex-1">
51
+ <a href={homeLink} class="w-full" rel="external">Go Home</a>
52
+ </Button>
53
+ </Card.Footer>
54
+ </Card.Root>
55
+ </div>
@@ -0,0 +1,9 @@
1
+ interface Props {
2
+ status?: number;
3
+ message?: string;
4
+ details?: string;
5
+ homeLink?: string;
6
+ }
7
+ declare const ErrorScreen: import("svelte").Component<Props, {}, "">;
8
+ type ErrorScreen = ReturnType<typeof ErrorScreen>;
9
+ export default ErrorScreen;
@@ -0,0 +1,318 @@
1
+ <script lang="ts">
2
+ import { Download, Upload, AlertTriangle, CheckCircle } from '@lucide/svelte';
3
+ import type { UISchema, ParameterPreset } from '../types/generated';
4
+ import {
5
+ createSavedState,
6
+ validateSavedState,
7
+ extractLoadableValues,
8
+ exportStateAsJson,
9
+ importStateFromJson
10
+ } from '../utils/param-exporter';
11
+ import { Button, Input, Label, Textarea, Dialog, Card } from '../components/ui';
12
+
13
+ interface Props {
14
+ schema: UISchema;
15
+ currentValues: Record<string, unknown>;
16
+ onLoadValues: (values: Record<string, unknown>) => void;
17
+ }
18
+
19
+ let { schema, currentValues, onLoadValues }: Props = $props();
20
+
21
+ // Save dialog state
22
+ let showExportDialog = $state(false);
23
+ let exportName = $state('');
24
+ let exportDescription = $state('');
25
+ let exportAuthor = $state('');
26
+ let exportTags = $state('');
27
+
28
+ // Import/validation state
29
+ let showValidationDialog = $state(false);
30
+ let showLoadDialog = $state(false);
31
+ let importedState = $state<ParameterPreset | null>(null);
32
+ let validationResult = $state<ReturnType<typeof validateSavedState> | null>(null);
33
+ let fileInputRef = $state<HTMLInputElement | null>(null);
34
+
35
+ function openExportDialog() {
36
+ exportName = `State ${new Date().toLocaleDateString()}`;
37
+ exportDescription = '';
38
+ exportAuthor = schema.author || '';
39
+ exportTags = '';
40
+ showExportDialog = true;
41
+ }
42
+
43
+ function handleExport() {
44
+ if (!exportName.trim()) {
45
+ alert('Please enter a name for this state');
46
+ return;
47
+ }
48
+
49
+ const state = createSavedState(schema, currentValues, {
50
+ name: exportName.trim(),
51
+ description: exportDescription.trim() || undefined,
52
+ author: exportAuthor.trim() || undefined,
53
+ tags: exportTags
54
+ .split(',')
55
+ .map((t) => t.trim())
56
+ .filter((t) => t.length > 0)
57
+ });
58
+
59
+ exportStateAsJson(state);
60
+ showExportDialog = false;
61
+ }
62
+
63
+ async function handleImport(event: Event) {
64
+ const input = event.target as HTMLInputElement;
65
+ if (!input.files || input.files.length === 0) return;
66
+
67
+ try {
68
+ const file = input.files[0];
69
+ const imported = await importStateFromJson(file);
70
+
71
+ // Validate before loading
72
+ const validation = validateSavedState(imported, schema);
73
+
74
+ if (!validation.canLoad) {
75
+ // Show validation errors
76
+ importedState = imported;
77
+ validationResult = validation;
78
+ showValidationDialog = true;
79
+ return;
80
+ }
81
+
82
+ // Warnings only - show validation but allow load
83
+ if (!validation.isValid) {
84
+ importedState = imported;
85
+ validationResult = validation;
86
+ showValidationDialog = true;
87
+ return;
88
+ }
89
+
90
+ // No issues - load immediately
91
+ const values = extractLoadableValues(imported, schema, validation);
92
+ onLoadValues(values);
93
+ } catch (error) {
94
+ alert('Failed to import state: ' + (error as Error).message);
95
+ }
96
+
97
+ // Reset input
98
+ input.value = '';
99
+ }
100
+
101
+ function confirmLoad() {
102
+ if (!importedState || !validationResult) return;
103
+
104
+ if (validationResult.canLoad) {
105
+ const values = extractLoadableValues(importedState, schema, validationResult);
106
+ onLoadValues(values);
107
+ showValidationDialog = false;
108
+ importedState = null;
109
+ validationResult = null;
110
+ }
111
+ }
112
+
113
+ function cancelImport() {
114
+ showValidationDialog = false;
115
+ importedState = null;
116
+ validationResult = null;
117
+ }
118
+
119
+ function openLoadDialog() {
120
+ showLoadDialog = true;
121
+ }
122
+
123
+ function handleLoadClick() {
124
+ fileInputRef?.click();
125
+ showLoadDialog = false;
126
+ }
127
+ </script>
128
+
129
+ <div class="gap-2 mb-2 flex items-center justify-center">
130
+ <Button variant="default" size="sm" onclick={openExportDialog}>
131
+ <Download class="mr-2 h-4 w-4" />
132
+ Save State
133
+ </Button>
134
+
135
+ <Button variant="outline" size="sm" onclick={openLoadDialog}>
136
+ <Upload class="mr-2 h-4 w-4" />
137
+ Load State
138
+ </Button>
139
+
140
+ <input
141
+ bind:this={fileInputRef}
142
+ type="file"
143
+ accept=".sps"
144
+ onchange={handleImport}
145
+ class="hidden"
146
+ />
147
+ </div>
148
+
149
+ <!-- Save Dialog -->
150
+ <Dialog.Root bind:open={showExportDialog}>
151
+ <Dialog.Content>
152
+ <Dialog.Header>
153
+ <Dialog.Title>Save Parameter State</Dialog.Title>
154
+ <Dialog.Description>Save the current parameter values as a .sps file</Dialog.Description>
155
+ </Dialog.Header>
156
+
157
+ <div class="gap-4 py-4 grid">
158
+ <div class="gap-2 grid">
159
+ <Label for="export-name">State Name *</Label>
160
+ <Input id="export-name" bind:value={exportName} placeholder="e.g., Design Option A" />
161
+ </div>
162
+
163
+ <div class="gap-2 grid">
164
+ <Label for="export-description">Description</Label>
165
+ <Textarea
166
+ id="export-description"
167
+ bind:value={exportDescription}
168
+ placeholder="Optional description of this state"
169
+ rows={3}
170
+ />
171
+ </div>
172
+
173
+ <div class="gap-2 grid">
174
+ <Label for="export-author">Author</Label>
175
+ <Input id="export-author" bind:value={exportAuthor} placeholder="Your name or email" />
176
+ </div>
177
+
178
+ <div class="gap-2 grid">
179
+ <Label for="export-tags">Tags</Label>
180
+ <Input
181
+ id="export-tags"
182
+ bind:value={exportTags}
183
+ placeholder="facade, option-a, client-approved (comma-separated)"
184
+ />
185
+ </div>
186
+ </div>
187
+
188
+ <Dialog.Footer>
189
+ <Button variant="outline" onclick={() => (showExportDialog = false)}>Cancel</Button>
190
+ <Button onclick={handleExport}>Save State</Button>
191
+ </Dialog.Footer>
192
+ </Dialog.Content>
193
+ </Dialog.Root>
194
+
195
+ <!-- Load Dialog -->
196
+ <Dialog.Root bind:open={showLoadDialog}>
197
+ <Dialog.Content>
198
+ <Dialog.Header>
199
+ <Dialog.Title>Load Parameter State</Dialog.Title>
200
+ <Dialog.Description>Select a .sps state file from your drive to load</Dialog.Description>
201
+ </Dialog.Header>
202
+
203
+ <div class="py-8">
204
+ <Button onclick={handleLoadClick} class="w-full" size="lg">
205
+ <Upload class="mr-2 h-4 w-4" />
206
+ Select .sps File
207
+ </Button>
208
+ </div>
209
+
210
+ <Dialog.Footer>
211
+ <Button variant="outline" onclick={() => (showLoadDialog = false)}>Cancel</Button>
212
+ </Dialog.Footer>
213
+ </Dialog.Content>
214
+ </Dialog.Root>
215
+
216
+ <!-- Validation Dialog -->
217
+ <Dialog.Root bind:open={showValidationDialog}>
218
+ <Dialog.Content class="max-w-2xl max-h-[80vh] overflow-y-auto">
219
+ <Dialog.Header>
220
+ <Dialog.Title>State Validation Report</Dialog.Title>
221
+ <Dialog.Description>
222
+ {#if importedState}
223
+ Validating state: {importedState.name}
224
+ {/if}
225
+ </Dialog.Description>
226
+ </Dialog.Header>
227
+
228
+ {#if validationResult}
229
+ <div class="gap-4 py-4 grid">
230
+ <!-- Summary Alert -->
231
+ {#if validationResult.isValid}
232
+ <Card.Root
233
+ class="border-success/30 bg-success/5 p-4"
234
+ >
235
+ <div class="gap-3 flex items-start">
236
+ <CheckCircle class="h-5 w-5 text-success" />
237
+ <div>
238
+ <h4 class="text-sm font-semibold text-success-foreground">
239
+ No Issues Found
240
+ </h4>
241
+ <p class="text-sm text-success-foreground/80 mt-1">
242
+ This state can be loaded safely.
243
+ </p>
244
+ </div>
245
+ </div>
246
+ </Card.Root>
247
+ {:else if validationResult.canLoad}
248
+ <Card.Root
249
+ class="border-warning/30 bg-warning/5 p-4"
250
+ >
251
+ <div class="gap-3 flex items-start">
252
+ <AlertTriangle class="h-5 w-5 text-warning" />
253
+ <div>
254
+ <h4 class="text-sm font-semibold text-warning-foreground">
255
+ Warnings Detected
256
+ </h4>
257
+ <p class="text-sm text-warning-foreground/80 mt-1">
258
+ {validationResult.issues.length} warning(s) found, but state can still be loaded.
259
+ </p>
260
+ </div>
261
+ </div>
262
+ </Card.Root>
263
+ {:else}
264
+ <Card.Root class="border-destructive/30 bg-destructive/5 p-4">
265
+ <div class="gap-3 flex items-start">
266
+ <AlertTriangle class="h-5 w-5 text-destructive" />
267
+ <div>
268
+ <h4 class="text-sm font-semibold text-destructive">
269
+ Critical Errors
270
+ </h4>
271
+ <p class="text-sm text-destructive/80 mt-1">
272
+ Cannot load this state due to critical incompatibilities.
273
+ </p>
274
+ </div>
275
+ </div>
276
+ </Card.Root>
277
+ {/if}
278
+
279
+ <!-- Issues List -->
280
+ {#if !validationResult.isValid}
281
+ <div class="space-y-2">
282
+ <h4 class="text-sm font-medium">Issues:</h4>
283
+ {#each validationResult.issues as issue (issue.message)}
284
+ <div
285
+ class="p-3 rounded-lg border {issue.severity === 'error'
286
+ ? 'border-destructive/30 bg-destructive/5'
287
+ : 'border-warning/30 bg-warning/5'}"
288
+ >
289
+ <div class="gap-2 flex items-start">
290
+ <AlertTriangle
291
+ class="h-4 w-4 mt-0.5 {issue.severity === 'error'
292
+ ? 'text-destructive'
293
+ : 'text-warning'}"
294
+ />
295
+ <div class="flex-1">
296
+ <p class="text-sm font-medium">{issue.message}</p>
297
+ {#if issue.details}
298
+ <p class="text-xs mt-1 text-muted-foreground">
299
+ Expected: {issue.details.expected} → Actual: {issue.details.actual}
300
+ </p>
301
+ {/if}
302
+ </div>
303
+ </div>
304
+ </div>
305
+ {/each}
306
+ </div>
307
+ {/if}
308
+ </div>
309
+ {/if}
310
+
311
+ <Dialog.Footer>
312
+ <Button variant="outline" onclick={cancelImport}>Cancel</Button>
313
+ {#if validationResult?.canLoad}
314
+ <Button onclick={confirmLoad}>Load Anyway</Button>
315
+ {/if}
316
+ </Dialog.Footer>
317
+ </Dialog.Content>
318
+ </Dialog.Root>
@@ -0,0 +1,9 @@
1
+ import type { UISchema } from '../types/generated';
2
+ interface Props {
3
+ schema: UISchema;
4
+ currentValues: Record<string, unknown>;
5
+ onLoadValues: (values: Record<string, unknown>) => void;
6
+ }
7
+ declare const StateManager: import("svelte").Component<Props, {}, "">;
8
+ type StateManager = ReturnType<typeof StateManager>;
9
+ export default StateManager;