@nanoforge-dev/editor 0.0.2-beta.394e65b → 0.0.2-beta.51374be

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 (136) hide show
  1. package/dist/client/_app/immutable/assets/0.9jvpTw2w.css +1 -0
  2. package/dist/client/_app/immutable/assets/0.9jvpTw2w.css.br +0 -0
  3. package/dist/client/_app/immutable/assets/0.9jvpTw2w.css.gz +0 -0
  4. package/dist/client/_app/immutable/chunks/{BDBSsbMb.js → Ca8OJQR_.js} +1 -1
  5. package/dist/client/_app/immutable/chunks/Ca8OJQR_.js.br +0 -0
  6. package/dist/client/_app/immutable/chunks/Ca8OJQR_.js.gz +0 -0
  7. package/dist/client/_app/immutable/chunks/{CmuvbAn5.js → D9jhAoAX.js} +1 -1
  8. package/dist/client/_app/immutable/chunks/D9jhAoAX.js.br +0 -0
  9. package/dist/client/_app/immutable/chunks/D9jhAoAX.js.gz +0 -0
  10. package/dist/client/_app/immutable/chunks/{DfAL3LhV.js → DK4SHdlR.js} +1 -1
  11. package/dist/client/_app/immutable/chunks/DK4SHdlR.js.br +0 -0
  12. package/dist/client/_app/immutable/chunks/{DfAL3LhV.js.gz → DK4SHdlR.js.gz} +0 -0
  13. package/dist/client/_app/immutable/chunks/{BApLQfqY.js → Dz68q4V9.js} +3 -3
  14. package/dist/client/_app/immutable/chunks/Dz68q4V9.js.br +0 -0
  15. package/dist/client/_app/immutable/chunks/Dz68q4V9.js.gz +0 -0
  16. package/dist/client/_app/immutable/chunks/{Ctc_6ReW.js → IqbhOKXb.js} +1 -1
  17. package/dist/client/_app/immutable/chunks/IqbhOKXb.js.br +4 -0
  18. package/dist/client/_app/immutable/chunks/IqbhOKXb.js.gz +0 -0
  19. package/dist/client/_app/immutable/chunks/{Coa6r0tY.js → qkSCjfDU.js} +1 -1
  20. package/dist/client/_app/immutable/chunks/qkSCjfDU.js.br +0 -0
  21. package/dist/client/_app/immutable/chunks/qkSCjfDU.js.gz +0 -0
  22. package/dist/client/_app/immutable/entry/{app.BzOeKbPs.js → app.CsQ3MwoD.js} +2 -2
  23. package/dist/client/_app/immutable/entry/app.CsQ3MwoD.js.br +0 -0
  24. package/dist/client/_app/immutable/entry/app.CsQ3MwoD.js.gz +0 -0
  25. package/dist/client/_app/immutable/entry/start.BsMc2lPs.js +1 -0
  26. package/dist/client/_app/immutable/entry/start.BsMc2lPs.js.br +0 -0
  27. package/dist/client/_app/immutable/entry/start.BsMc2lPs.js.gz +0 -0
  28. package/dist/client/_app/immutable/nodes/{1.OaHPDibP.js → 1.DEF0BAW6.js} +1 -1
  29. package/dist/client/_app/immutable/nodes/1.DEF0BAW6.js.br +3 -0
  30. package/dist/client/_app/immutable/nodes/1.DEF0BAW6.js.gz +0 -0
  31. package/dist/client/_app/immutable/nodes/{9.Hjdmo-wG.js → 10.neKYblyP.js} +1 -1
  32. package/dist/client/_app/immutable/nodes/10.neKYblyP.js.br +0 -0
  33. package/dist/client/_app/immutable/nodes/10.neKYblyP.js.gz +0 -0
  34. package/dist/client/_app/immutable/nodes/2.CHyBnCIr.js +1 -0
  35. package/dist/client/_app/immutable/nodes/2.CHyBnCIr.js.br +0 -0
  36. package/dist/client/_app/immutable/nodes/2.CHyBnCIr.js.gz +0 -0
  37. package/dist/client/_app/immutable/nodes/3.C2Mh4Qd_.js +6 -0
  38. package/dist/client/_app/immutable/nodes/3.C2Mh4Qd_.js.br +0 -0
  39. package/dist/client/_app/immutable/nodes/3.C2Mh4Qd_.js.gz +0 -0
  40. package/dist/client/_app/version.json +1 -1
  41. package/dist/client/_app/version.json.br +0 -0
  42. package/dist/client/_app/version.json.gz +0 -0
  43. package/dist/server/chunks/{0-CM-Y6ut6.js → 0-C38YutqS.js} +3 -3
  44. package/dist/server/chunks/{0-CM-Y6ut6.js.map → 0-C38YutqS.js.map} +1 -1
  45. package/dist/server/chunks/{1-C2ffLW3O.js → 1-QN9C5iMI.js} +5 -5
  46. package/dist/server/chunks/{1-C2ffLW3O.js.map → 1-QN9C5iMI.js.map} +1 -1
  47. package/dist/server/chunks/{9-CDMb5iwc.js → 10-z9ayGqF8.js} +10 -10
  48. package/dist/server/chunks/10-z9ayGqF8.js.map +1 -0
  49. package/dist/server/chunks/{2-BAs82M_7.js → 2-DSFx0l21.js} +7 -7
  50. package/dist/server/chunks/{2-BAs82M_7.js.map → 2-DSFx0l21.js.map} +1 -1
  51. package/dist/server/chunks/3-BduDSsDs.js +22 -0
  52. package/dist/server/chunks/3-BduDSsDs.js.map +1 -0
  53. package/dist/server/chunks/{3-CtfjP4uZ.js → 4-BYQgShv3.js} +3 -3
  54. package/dist/server/chunks/{3-CtfjP4uZ.js.map → 4-BYQgShv3.js.map} +1 -1
  55. package/dist/server/chunks/{8-s07Rj2Zo.js → 5-B4IXyXqv.js} +3 -3
  56. package/dist/server/chunks/{8-s07Rj2Zo.js.map → 5-B4IXyXqv.js.map} +1 -1
  57. package/dist/server/chunks/{4-DP-_gDay.js → 6-DH_IMDRv.js} +3 -3
  58. package/dist/server/chunks/{4-DP-_gDay.js.map → 6-DH_IMDRv.js.map} +1 -1
  59. package/dist/server/chunks/{6-Dl_h_OyU.js → 7-CPMeoSUO.js} +3 -3
  60. package/dist/server/chunks/{6-Dl_h_OyU.js.map → 7-CPMeoSUO.js.map} +1 -1
  61. package/dist/server/chunks/{7-BUEKgK7m.js → 8-CRTa48Fz.js} +3 -3
  62. package/dist/server/chunks/{7-BUEKgK7m.js.map → 8-CRTa48Fz.js.map} +1 -1
  63. package/dist/server/chunks/{5-610NKQc3.js → 9-DPn3d8kr.js} +3 -3
  64. package/dist/server/chunks/{5-610NKQc3.js.map → 9-DPn3d8kr.js.map} +1 -1
  65. package/dist/server/chunks/{_page.svelte-vOyGpofm.js → _page.svelte-CSpYC4UR.js} +164 -28
  66. package/dist/server/chunks/_page.svelte-CSpYC4UR.js.map +1 -0
  67. package/dist/server/chunks/{_page.svelte-Bn7BSazx.js → _page.svelte-CnqdKe-f.js} +5 -5
  68. package/dist/server/chunks/{_page.svelte-Bn7BSazx.js.map → _page.svelte-CnqdKe-f.js.map} +1 -1
  69. package/dist/server/chunks/{_page.svelte-DR4jsdM6.js → _page.svelte-DGISbQoh.js} +6 -6
  70. package/dist/server/chunks/{_page.svelte-DR4jsdM6.js.map → _page.svelte-DGISbQoh.js.map} +1 -1
  71. package/dist/server/chunks/{_server.ts-DlC2sxcm.js → _server.ts-y6LeO9-5.js} +14 -2
  72. package/dist/server/chunks/_server.ts-y6LeO9-5.js.map +1 -0
  73. package/dist/server/chunks/{client-bZcBshMs.js → client-CKx4JfSs.js} +2 -2
  74. package/dist/server/chunks/{client-bZcBshMs.js.map → client-CKx4JfSs.js.map} +1 -1
  75. package/dist/server/chunks/{error-DYeUQ7mQ.js → error-bOWEqlVk.js} +53 -30
  76. package/dist/server/chunks/error-bOWEqlVk.js.map +1 -0
  77. package/dist/server/chunks/{error.svelte-DDsdZM_m.js → error.svelte-Bs8SPOoy.js} +2 -2
  78. package/dist/server/chunks/{error.svelte-DDsdZM_m.js.map → error.svelte-Bs8SPOoy.js.map} +1 -1
  79. package/dist/server/chunks/{hooks.server-BGpE7svk.js → hooks.server-BCsvwndF.js} +2 -2
  80. package/dist/server/chunks/{hooks.server-BGpE7svk.js.map → hooks.server-BCsvwndF.js.map} +1 -1
  81. package/dist/server/chunks/{internal2-DBpj29pr.js → internal2-B-CDEkbN.js} +3 -3
  82. package/dist/server/chunks/{internal2-DBpj29pr.js.map → internal2-B-CDEkbN.js.map} +1 -1
  83. package/dist/server/chunks/{logo-DQI0khKS.js → logo-BsWuqjoe.js} +2 -2
  84. package/dist/server/chunks/logo-BsWuqjoe.js.map +1 -0
  85. package/dist/server/chunks/{project-loader-DaQVgPID.js → project-loader-D_rtPhxK.js} +3 -3
  86. package/dist/server/chunks/{project-loader-DaQVgPID.js.map → project-loader-D_rtPhxK.js.map} +1 -1
  87. package/dist/server/chunks/{schemas-BDVbWglI.js → schemas-DbvpJ_u0.js} +4 -4
  88. package/dist/server/chunks/{schemas-BDVbWglI.js.map → schemas-DbvpJ_u0.js.map} +1 -1
  89. package/dist/server/chunks/{state-DwdUA00F.js → state-CEUkMO8P.js} +2 -2
  90. package/dist/server/chunks/{state-DwdUA00F.js.map → state-CEUkMO8P.js.map} +1 -1
  91. package/dist/server/index.js +1 -1
  92. package/dist/server/manifest.js +28 -28
  93. package/dist/server/manifest.js.map +1 -1
  94. package/package.json +1 -1
  95. package/dist/client/_app/immutable/assets/0.DOl0zkp7.css +0 -1
  96. package/dist/client/_app/immutable/assets/0.DOl0zkp7.css.br +0 -0
  97. package/dist/client/_app/immutable/assets/0.DOl0zkp7.css.gz +0 -0
  98. package/dist/client/_app/immutable/chunks/BApLQfqY.js.br +0 -0
  99. package/dist/client/_app/immutable/chunks/BApLQfqY.js.gz +0 -0
  100. package/dist/client/_app/immutable/chunks/BDBSsbMb.js.br +0 -0
  101. package/dist/client/_app/immutable/chunks/BDBSsbMb.js.gz +0 -0
  102. package/dist/client/_app/immutable/chunks/CmuvbAn5.js.br +0 -0
  103. package/dist/client/_app/immutable/chunks/CmuvbAn5.js.gz +0 -0
  104. package/dist/client/_app/immutable/chunks/Coa6r0tY.js.br +0 -0
  105. package/dist/client/_app/immutable/chunks/Coa6r0tY.js.gz +0 -0
  106. package/dist/client/_app/immutable/chunks/Ctc_6ReW.js.br +0 -0
  107. package/dist/client/_app/immutable/chunks/Ctc_6ReW.js.gz +0 -0
  108. package/dist/client/_app/immutable/chunks/DfAL3LhV.js.br +0 -0
  109. package/dist/client/_app/immutable/entry/app.BzOeKbPs.js.br +0 -0
  110. package/dist/client/_app/immutable/entry/app.BzOeKbPs.js.gz +0 -0
  111. package/dist/client/_app/immutable/entry/start.CNF2MUuM.js +0 -1
  112. package/dist/client/_app/immutable/entry/start.CNF2MUuM.js.br +0 -0
  113. package/dist/client/_app/immutable/entry/start.CNF2MUuM.js.gz +0 -0
  114. package/dist/client/_app/immutable/nodes/1.OaHPDibP.js.br +0 -2
  115. package/dist/client/_app/immutable/nodes/1.OaHPDibP.js.gz +0 -0
  116. package/dist/client/_app/immutable/nodes/10.BRGL1_0_.js +0 -6
  117. package/dist/client/_app/immutable/nodes/10.BRGL1_0_.js.br +0 -0
  118. package/dist/client/_app/immutable/nodes/10.BRGL1_0_.js.gz +0 -0
  119. package/dist/client/_app/immutable/nodes/2.BK6m2FYa.js +0 -1
  120. package/dist/client/_app/immutable/nodes/2.BK6m2FYa.js.br +0 -0
  121. package/dist/client/_app/immutable/nodes/2.BK6m2FYa.js.gz +0 -0
  122. package/dist/client/_app/immutable/nodes/9.Hjdmo-wG.js.br +0 -0
  123. package/dist/client/_app/immutable/nodes/9.Hjdmo-wG.js.gz +0 -0
  124. package/dist/server/chunks/10-DhkWDAeT.js +0 -22
  125. package/dist/server/chunks/10-DhkWDAeT.js.map +0 -1
  126. package/dist/server/chunks/9-CDMb5iwc.js.map +0 -1
  127. package/dist/server/chunks/_page.svelte-vOyGpofm.js.map +0 -1
  128. package/dist/server/chunks/_server.ts-DlC2sxcm.js.map +0 -1
  129. package/dist/server/chunks/error-DYeUQ7mQ.js.map +0 -1
  130. package/dist/server/chunks/logo-DQI0khKS.js.map +0 -1
  131. /package/dist/client/_app/immutable/assets/{10.BP_hUVIU.css → 3.BP_hUVIU.css} +0 -0
  132. /package/dist/client/_app/immutable/assets/{10.BP_hUVIU.css.br → 3.BP_hUVIU.css.br} +0 -0
  133. /package/dist/client/_app/immutable/assets/{10.BP_hUVIU.css.gz → 3.BP_hUVIU.css.gz} +0 -0
  134. /package/dist/client/_app/immutable/nodes/{0.CPqemWaq.js → 0.XFd95L6z.js} +0 -0
  135. /package/dist/client/_app/immutable/nodes/{0.CPqemWaq.js.br → 0.XFd95L6z.js.br} +0 -0
  136. /package/dist/client/_app/immutable/nodes/{0.CPqemWaq.js.gz → 0.XFd95L6z.js.gz} +0 -0
@@ -251,8 +251,8 @@ var actions = {
251
251
  "get-gateway-projects": getGatewayProjectsAction
252
252
  };
253
253
  //#endregion
254
- //#region .svelte-kit/adapter-bun/nodes/3.js
255
- const index = 3;
254
+ //#region .svelte-kit/adapter-bun/nodes/4.js
255
+ const index = 4;
256
256
  const server_id = "src/routes/actions/project/+page.server.ts";
257
257
  const imports = [];
258
258
  const stylesheets = [];
@@ -260,4 +260,4 @@ const fonts = [];
260
260
  //#endregion
261
261
  export { fonts, imports, index, _page_server_ts_exports as server, server_id, stylesheets };
262
262
 
263
- //# sourceMappingURL=3-CtfjP4uZ.js.map
263
+ //# sourceMappingURL=4-BYQgShv3.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"3-CtfjP4uZ.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/3.js"],"sourcesContent":["import { n as Exception } from \"../../../../chunks/const.js\";\nimport { i as loadProjectFromId, n as useActionHandler, r as loadProject } from \"../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsBoolean, IsEnum, IsNotEmpty, IsOptional, IsString, IsUUID, Matches, isBoolean, isString, registerDecorator } from \"class-validator\";\nimport { join } from \"node:path\";\n//#region src/lib/server/actions/project/load.action.ts\nvar LoadProjectBody = class {\n\tid;\n\tpath;\n\tgitUrl;\n\tgatewayId;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], LoadProjectBody.prototype, \"id\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], LoadProjectBody.prototype, \"path\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], LoadProjectBody.prototype, \"gitUrl\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], LoadProjectBody.prototype, \"gatewayId\", void 0);\nvar resolveSessionFromGatewayId = async (gatewayId, { api, git, context }) => {\n\tif (!context.online) throw new Exception(\"Bad Request\", \"Cannot load project from gatewayId while offline\", 400);\n\tconst project = await api.projects.getProject(gatewayId);\n\treturn {\n\t\tpath: join(await git.clone(project.gatewayProjectRegistryUrl, { sshKey: project.gatewayProjectRegistryMetadata.sshKey }), project.gatewayProjectRegistryMetadata.dir ?? \"\"),\n\t\tgateway: {\n\t\t\tid: gatewayId,\n\t\t\tsshKey: project.gatewayProjectRegistryMetadata.sshKey\n\t\t}\n\t};\n};\nvar resolveSessionFromGitUrl = async (gitUrl, { git, context }) => {\n\tif (context.online) throw new Exception(\"Bad Request\", \"Cannot load project from gitUrl while online\", 400);\n\treturn { path: await git.clone(gitUrl) };\n};\nvar resolveSessionFromPath = async (path, { context }) => {\n\tif (context.online) throw new Exception(\"Bad Request\", \"Cannot load project from path while online\", 400);\n\treturn { path };\n};\nvar resolveSessionFunctions = {\n\tpath: resolveSessionFromPath,\n\tgitUrl: resolveSessionFromGitUrl,\n\tgatewayId: resolveSessionFromGatewayId\n};\nvar loadProjectAction = useActionHandler(async (handler) => {\n\tconst { body } = handler;\n\tif (body.id) return await loadProjectFromId(body.id, handler);\n\tconst el = Object.entries(body).find(([, value]) => value);\n\tif (!el) throw new Exception(\"Bad Request\", \"No load origin provided\", 400);\n\tconst resolveSessionFunction = resolveSessionFunctions[el[0]];\n\treturn await loadProject(await resolveSessionFunction(el[1], handler), handler);\n}, {\n\tprojectOptional: true,\n\tbody: LoadProjectBody\n});\n//#endregion\n//#region src/lib/server/actions/project/complete.action.ts\nvar CompleteProjectBody = class {\n\tgatewayId;\n\tlanguage;\n\tmultiplayerServer;\n};\n__decorate([\n\tExpose(),\n\tIsUUID(8),\n\tIsNotEmpty()\n], CompleteProjectBody.prototype, \"gatewayId\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional(),\n\tIsEnum([\"js\", \"ts\"])\n], CompleteProjectBody.prototype, \"language\", void 0);\n__decorate([\n\tExpose(),\n\tIsBoolean(),\n\tIsOptional()\n], CompleteProjectBody.prototype, \"multiplayerServer\", void 0);\nvar completeProjectAction = useActionHandler(async (handler) => {\n\tconst { body, cli, api } = handler;\n\tconst project = await api.projects.getProject(body.gatewayId);\n\tconst resolver = await resolveSessionFunctions.gatewayId(body.gatewayId, handler);\n\tconst parts = resolver.path.split(\"/\");\n\tconst end = parts.pop();\n\tcli.new({\n\t\teditor: true,\n\t\tdirectory: parts.join(\"/\"),\n\t\tname: project.name,\n\t\tpath: end,\n\t\tpackageManager: \"bun\",\n\t\tlanguage: body.language,\n\t\tserver: body.multiplayerServer,\n\t\tdocker: false,\n\t\tlint: false,\n\t\tinitFunctions: true,\n\t\tstrict: false,\n\t\tgit: false\n\t});\n\treturn await loadProject(resolver, handler);\n}, {\n\tbody: CompleteProjectBody,\n\tonlineOnly: true,\n\tprojectOptional: true\n});\n//#endregion\n//#region src/lib/server/actions/project/gateway.action.ts\nvar getGatewayProjectsAction = useActionHandler(async ({ api }) => {\n\treturn (await api.projects.getProjects()).map((project) => ({\n\t\tgatewayId: project.id,\n\t\tname: project.name\n\t}));\n}, {\n\tonlineOnly: true,\n\tprojectOptional: true\n});\n//#endregion\n//#region src/lib/server/actions/project/info.action.ts\nvar InfoProjectBody = class {\n\tname;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], InfoProjectBody.prototype, \"name\", void 0);\nvar getInfoProjectAction = useActionHandler(async ({ fs }) => {\n\tconst config = await fs.getFile(\"nanoforge.config.json\").readJson();\n\treturn {\n\t\tname: config.name,\n\t\tlanguage: config.language,\n\t\thasServer: config.server?.enabled ?? false\n\t};\n});\nvar setInfoProjectAction = useActionHandler(async ({ body, fs }) => {\n\tconst configFile = fs.getFile(\"nanoforge.config.json\");\n\tconst config = await configFile.readJson();\n\tif (body.name) config.name = body.name;\n\tconfigFile.writeJson(config);\n}, { body: InfoProjectBody });\n//#endregion\n//#region src/lib/server/utils/validators/is-string-or-false.validator.ts\nvar IsFalseOrString = (validationOptions) => {\n\treturn (object, propertyName) => {\n\t\tregisterDecorator({\n\t\t\ttarget: object.constructor,\n\t\t\tpropertyName,\n\t\t\t...validationOptions ? { options: validationOptions } : {},\n\t\t\tconstraints: [],\n\t\t\tvalidator: {\n\t\t\t\tvalidate(value) {\n\t\t\t\t\treturn isBoolean(value) && !value || isString(value);\n\t\t\t\t},\n\t\t\t\tdefaultMessage() {\n\t\t\t\t\treturn `$value must be a valid IP address or FQDN`;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t};\n};\n//#endregion\n//#region src/lib/server/actions/project/new.action.ts\nvar CreateProjectBody = class {\n\tprojectName;\n\tprojectPath;\n\tpackageManager;\n\tlanguage;\n\tmultiplayerServer;\n\tdockerContainerization;\n\tcreateGitRepository;\n\tgitRemote;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsNotEmpty(),\n\tMatches(/^[a-z0-9]+(?:-[a-z0-9]+)*$/)\n], CreateProjectBody.prototype, \"projectName\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"projectPath\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional(),\n\tIsEnum([\n\t\t\"npm\",\n\t\t\"pnpm\",\n\t\t\"yarn\",\n\t\t\"bun\"\n\t])\n], CreateProjectBody.prototype, \"packageManager\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional(),\n\tIsEnum([\"js\", \"ts\"])\n], CreateProjectBody.prototype, \"language\", void 0);\n__decorate([\n\tExpose(),\n\tIsBoolean(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"multiplayerServer\", void 0);\n__decorate([\n\tExpose(),\n\tIsBoolean(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"dockerContainerization\", void 0);\n__decorate([\n\tExpose(),\n\tIsBoolean(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"createGitRepository\", void 0);\n__decorate([\n\tExpose(),\n\tIsFalseOrString(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"gitRemote\", void 0);\n//#endregion\n//#region src/routes/actions/project/+page.server.ts\nvar actions = {\n\tload: loadProjectAction,\n\tnew: useActionHandler(async (handler) => {\n\t\tconst { body, cli } = handler;\n\t\tcli.new({\n\t\t\teditor: true,\n\t\t\tdirectory: body.projectPath || void 0,\n\t\t\tname: body.projectName,\n\t\t\tpath: body.projectName,\n\t\t\tpackageManager: body.packageManager,\n\t\t\tlanguage: body.language,\n\t\t\tserver: body.multiplayerServer,\n\t\t\tdocker: body.dockerContainerization,\n\t\t\tgit: body.createGitRepository,\n\t\t\tgitRemote: body.gitRemote,\n\t\t\tlint: false\n\t\t});\n\t\treturn await loadProject({ path: join(body.projectPath ?? \"\", body.projectName) }, handler);\n\t}, {\n\t\tbody: CreateProjectBody,\n\t\tofflineOnly: true,\n\t\tprojectOptional: true\n\t}),\n\tcomplete: completeProjectAction,\n\t\"get-info\": getInfoProjectAction,\n\t\"set-info\": setInfoProjectAction,\n\t\"get-gateway-projects\": getGatewayProjectsAction\n};\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/_page.server.ts.js';\n\nexport const index = 3;\nexport { server };\nexport const server_id = \"src/routes/actions/project/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":"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"}
1
+ {"version":3,"file":"4-BYQgShv3.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/4.js"],"sourcesContent":["import { n as Exception } from \"../../../../chunks/const.js\";\nimport { i as loadProjectFromId, n as useActionHandler, r as loadProject } from \"../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsBoolean, IsEnum, IsNotEmpty, IsOptional, IsString, IsUUID, Matches, isBoolean, isString, registerDecorator } from \"class-validator\";\nimport { join } from \"node:path\";\n//#region src/lib/server/actions/project/load.action.ts\nvar LoadProjectBody = class {\n\tid;\n\tpath;\n\tgitUrl;\n\tgatewayId;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], LoadProjectBody.prototype, \"id\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], LoadProjectBody.prototype, \"path\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], LoadProjectBody.prototype, \"gitUrl\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], LoadProjectBody.prototype, \"gatewayId\", void 0);\nvar resolveSessionFromGatewayId = async (gatewayId, { api, git, context }) => {\n\tif (!context.online) throw new Exception(\"Bad Request\", \"Cannot load project from gatewayId while offline\", 400);\n\tconst project = await api.projects.getProject(gatewayId);\n\treturn {\n\t\tpath: join(await git.clone(project.gatewayProjectRegistryUrl, { sshKey: project.gatewayProjectRegistryMetadata.sshKey }), project.gatewayProjectRegistryMetadata.dir ?? \"\"),\n\t\tgateway: {\n\t\t\tid: gatewayId,\n\t\t\tsshKey: project.gatewayProjectRegistryMetadata.sshKey\n\t\t}\n\t};\n};\nvar resolveSessionFromGitUrl = async (gitUrl, { git, context }) => {\n\tif (context.online) throw new Exception(\"Bad Request\", \"Cannot load project from gitUrl while online\", 400);\n\treturn { path: await git.clone(gitUrl) };\n};\nvar resolveSessionFromPath = async (path, { context }) => {\n\tif (context.online) throw new Exception(\"Bad Request\", \"Cannot load project from path while online\", 400);\n\treturn { path };\n};\nvar resolveSessionFunctions = {\n\tpath: resolveSessionFromPath,\n\tgitUrl: resolveSessionFromGitUrl,\n\tgatewayId: resolveSessionFromGatewayId\n};\nvar loadProjectAction = useActionHandler(async (handler) => {\n\tconst { body } = handler;\n\tif (body.id) return await loadProjectFromId(body.id, handler);\n\tconst el = Object.entries(body).find(([, value]) => value);\n\tif (!el) throw new Exception(\"Bad Request\", \"No load origin provided\", 400);\n\tconst resolveSessionFunction = resolveSessionFunctions[el[0]];\n\treturn await loadProject(await resolveSessionFunction(el[1], handler), handler);\n}, {\n\tprojectOptional: true,\n\tbody: LoadProjectBody\n});\n//#endregion\n//#region src/lib/server/actions/project/complete.action.ts\nvar CompleteProjectBody = class {\n\tgatewayId;\n\tlanguage;\n\tmultiplayerServer;\n};\n__decorate([\n\tExpose(),\n\tIsUUID(8),\n\tIsNotEmpty()\n], CompleteProjectBody.prototype, \"gatewayId\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional(),\n\tIsEnum([\"js\", \"ts\"])\n], CompleteProjectBody.prototype, \"language\", void 0);\n__decorate([\n\tExpose(),\n\tIsBoolean(),\n\tIsOptional()\n], CompleteProjectBody.prototype, \"multiplayerServer\", void 0);\nvar completeProjectAction = useActionHandler(async (handler) => {\n\tconst { body, cli, api } = handler;\n\tconst project = await api.projects.getProject(body.gatewayId);\n\tconst resolver = await resolveSessionFunctions.gatewayId(body.gatewayId, handler);\n\tconst parts = resolver.path.split(\"/\");\n\tconst end = parts.pop();\n\tcli.new({\n\t\teditor: true,\n\t\tdirectory: parts.join(\"/\"),\n\t\tname: project.name,\n\t\tpath: end,\n\t\tpackageManager: \"bun\",\n\t\tlanguage: body.language,\n\t\tserver: body.multiplayerServer,\n\t\tdocker: false,\n\t\tlint: false,\n\t\tinitFunctions: true,\n\t\tstrict: false,\n\t\tgit: false\n\t});\n\treturn await loadProject(resolver, handler);\n}, {\n\tbody: CompleteProjectBody,\n\tonlineOnly: true,\n\tprojectOptional: true\n});\n//#endregion\n//#region src/lib/server/actions/project/gateway.action.ts\nvar getGatewayProjectsAction = useActionHandler(async ({ api }) => {\n\treturn (await api.projects.getProjects()).map((project) => ({\n\t\tgatewayId: project.id,\n\t\tname: project.name\n\t}));\n}, {\n\tonlineOnly: true,\n\tprojectOptional: true\n});\n//#endregion\n//#region src/lib/server/actions/project/info.action.ts\nvar InfoProjectBody = class {\n\tname;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], InfoProjectBody.prototype, \"name\", void 0);\nvar getInfoProjectAction = useActionHandler(async ({ fs }) => {\n\tconst config = await fs.getFile(\"nanoforge.config.json\").readJson();\n\treturn {\n\t\tname: config.name,\n\t\tlanguage: config.language,\n\t\thasServer: config.server?.enabled ?? false\n\t};\n});\nvar setInfoProjectAction = useActionHandler(async ({ body, fs }) => {\n\tconst configFile = fs.getFile(\"nanoforge.config.json\");\n\tconst config = await configFile.readJson();\n\tif (body.name) config.name = body.name;\n\tconfigFile.writeJson(config);\n}, { body: InfoProjectBody });\n//#endregion\n//#region src/lib/server/utils/validators/is-string-or-false.validator.ts\nvar IsFalseOrString = (validationOptions) => {\n\treturn (object, propertyName) => {\n\t\tregisterDecorator({\n\t\t\ttarget: object.constructor,\n\t\t\tpropertyName,\n\t\t\t...validationOptions ? { options: validationOptions } : {},\n\t\t\tconstraints: [],\n\t\t\tvalidator: {\n\t\t\t\tvalidate(value) {\n\t\t\t\t\treturn isBoolean(value) && !value || isString(value);\n\t\t\t\t},\n\t\t\t\tdefaultMessage() {\n\t\t\t\t\treturn `$value must be a valid IP address or FQDN`;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t};\n};\n//#endregion\n//#region src/lib/server/actions/project/new.action.ts\nvar CreateProjectBody = class {\n\tprojectName;\n\tprojectPath;\n\tpackageManager;\n\tlanguage;\n\tmultiplayerServer;\n\tdockerContainerization;\n\tcreateGitRepository;\n\tgitRemote;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsNotEmpty(),\n\tMatches(/^[a-z0-9]+(?:-[a-z0-9]+)*$/)\n], CreateProjectBody.prototype, \"projectName\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"projectPath\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional(),\n\tIsEnum([\n\t\t\"npm\",\n\t\t\"pnpm\",\n\t\t\"yarn\",\n\t\t\"bun\"\n\t])\n], CreateProjectBody.prototype, \"packageManager\", void 0);\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional(),\n\tIsEnum([\"js\", \"ts\"])\n], CreateProjectBody.prototype, \"language\", void 0);\n__decorate([\n\tExpose(),\n\tIsBoolean(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"multiplayerServer\", void 0);\n__decorate([\n\tExpose(),\n\tIsBoolean(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"dockerContainerization\", void 0);\n__decorate([\n\tExpose(),\n\tIsBoolean(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"createGitRepository\", void 0);\n__decorate([\n\tExpose(),\n\tIsFalseOrString(),\n\tIsOptional()\n], CreateProjectBody.prototype, \"gitRemote\", void 0);\n//#endregion\n//#region src/routes/actions/project/+page.server.ts\nvar actions = {\n\tload: loadProjectAction,\n\tnew: useActionHandler(async (handler) => {\n\t\tconst { body, cli } = handler;\n\t\tcli.new({\n\t\t\teditor: true,\n\t\t\tdirectory: body.projectPath || void 0,\n\t\t\tname: body.projectName,\n\t\t\tpath: body.projectName,\n\t\t\tpackageManager: body.packageManager,\n\t\t\tlanguage: body.language,\n\t\t\tserver: body.multiplayerServer,\n\t\t\tdocker: body.dockerContainerization,\n\t\t\tgit: body.createGitRepository,\n\t\t\tgitRemote: body.gitRemote,\n\t\t\tlint: false\n\t\t});\n\t\treturn await loadProject({ path: join(body.projectPath ?? \"\", body.projectName) }, handler);\n\t}, {\n\t\tbody: CreateProjectBody,\n\t\tofflineOnly: true,\n\t\tprojectOptional: true\n\t}),\n\tcomplete: completeProjectAction,\n\t\"get-info\": getInfoProjectAction,\n\t\"set-info\": setInfoProjectAction,\n\t\"get-gateway-projects\": getGatewayProjectsAction\n};\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/_page.server.ts.js';\n\nexport const index = 4;\nexport { server };\nexport const server_id = \"src/routes/actions/project/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":"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"}
@@ -23,8 +23,8 @@ var actions = {
23
23
  }, { body: SetSaveBody })
24
24
  };
25
25
  //#endregion
26
- //#region .svelte-kit/adapter-bun/nodes/8.js
27
- const index = 8;
26
+ //#region .svelte-kit/adapter-bun/nodes/5.js
27
+ const index = 5;
28
28
  const server_id = "src/routes/actions/project/save/+page.server.ts";
29
29
  const imports = [];
30
30
  const stylesheets = [];
@@ -32,4 +32,4 @@ const fonts = [];
32
32
  //#endregion
33
33
  export { fonts, imports, index, _page_server_ts_exports as server, server_id, stylesheets };
34
34
 
35
- //# sourceMappingURL=8-s07Rj2Zo.js.map
35
+ //# sourceMappingURL=5-B4IXyXqv.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"8-s07Rj2Zo.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/save/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/8.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsNotEmpty, IsObject } from \"class-validator\";\n//#region src/lib/server/actions/project/save/get-save.action.ts\nvar getSaveAction = useActionHandler(async ({ project }) => {\n\treturn project.client.save.getSave();\n});\n//#endregion\n//#region src/lib/server/actions/project/save/set-save.action.ts\nvar SetSaveBody = class {\n\tsave;\n};\n__decorate([\n\tExpose(),\n\tIsObject(),\n\tIsNotEmpty()\n], SetSaveBody.prototype, \"save\", void 0);\n//#endregion\n//#region src/routes/actions/project/save/+page.server.ts\nvar actions = {\n\tget: getSaveAction,\n\tset: useActionHandler(async ({ project, body }) => {\n\t\treturn project.client.save.updateSave(body.save);\n\t}, { body: SetSaveBody })\n};\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/save/_page.server.ts.js';\n\nexport const index = 8;\nexport { server };\nexport const server_id = \"src/routes/actions/project/save/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;;;;AAKA,IAAI,gBAAgB,iBAAiB,OAAO,EAAE,cAAc;CAC3D,OAAO,QAAQ,OAAO,KAAK,QAAQ;AACpC,CAAC;AAGD,IAAI,cAAc,MAAM;CACvB;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,YAAY,WAAW,QAAQ,KAAK,CAAC;AAGxC,IAAI,UAAU;CACb,KAAK;CACL,KAAK,iBAAiB,OAAO,EAAE,SAAS,WAAW;EAClD,OAAO,QAAQ,OAAO,KAAK,WAAW,KAAK,IAAI;CAChD,GAAG,EAAE,MAAM,YAAY,CAAC;AACzB;;;ACvBA,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
1
+ {"version":3,"file":"5-B4IXyXqv.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/save/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/5.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsNotEmpty, IsObject } from \"class-validator\";\n//#region src/lib/server/actions/project/save/get-save.action.ts\nvar getSaveAction = useActionHandler(async ({ project }) => {\n\treturn project.client.save.getSave();\n});\n//#endregion\n//#region src/lib/server/actions/project/save/set-save.action.ts\nvar SetSaveBody = class {\n\tsave;\n};\n__decorate([\n\tExpose(),\n\tIsObject(),\n\tIsNotEmpty()\n], SetSaveBody.prototype, \"save\", void 0);\n//#endregion\n//#region src/routes/actions/project/save/+page.server.ts\nvar actions = {\n\tget: getSaveAction,\n\tset: useActionHandler(async ({ project, body }) => {\n\t\treturn project.client.save.updateSave(body.save);\n\t}, { body: SetSaveBody })\n};\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/save/_page.server.ts.js';\n\nexport const index = 5;\nexport { server };\nexport const server_id = \"src/routes/actions/project/save/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;;;;AAKA,IAAI,gBAAgB,iBAAiB,OAAO,EAAE,cAAc;CAC3D,OAAO,QAAQ,OAAO,KAAK,QAAQ;AACpC,CAAC;AAGD,IAAI,cAAc,MAAM;CACvB;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,YAAY,WAAW,QAAQ,KAAK,CAAC;AAGxC,IAAI,UAAU;CACb,KAAK;CACL,KAAK,iBAAiB,OAAO,EAAE,SAAS,WAAW;EAClD,OAAO,QAAQ,OAAO,KAAK,WAAW,KAAK,IAAI;CAChD,GAAG,EAAE,MAAM,YAAY,CAAC;AACzB;;;ACvBA,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
@@ -17,8 +17,8 @@ var actions = { readdir: useActionHandler(async ({ project, body }) => {
17
17
  return project.client.fs.getDirectory(body.path ?? "").read(true);
18
18
  }, { body: ReaddirFsBody }) };
19
19
  //#endregion
20
- //#region .svelte-kit/adapter-bun/nodes/4.js
21
- const index = 4;
20
+ //#region .svelte-kit/adapter-bun/nodes/6.js
21
+ const index = 6;
22
22
  const server_id = "src/routes/actions/project/fs/+page.server.ts";
23
23
  const imports = [];
24
24
  const stylesheets = [];
@@ -26,4 +26,4 @@ const fonts = [];
26
26
  //#endregion
27
27
  export { fonts, imports, index, _page_server_ts_exports as server, server_id, stylesheets };
28
28
 
29
- //# sourceMappingURL=4-DP-_gDay.js.map
29
+ //# sourceMappingURL=6-DH_IMDRv.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"4-DP-_gDay.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/fs/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/4.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsOptional, IsString } from \"class-validator\";\n//#region src/lib/server/actions/project/fs/readdir.action.ts\nvar ReaddirFsBody = class {\n\tpath;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], ReaddirFsBody.prototype, \"path\", void 0);\n//#endregion\n//#region src/routes/actions/project/fs/+page.server.ts\nvar actions = { readdir: useActionHandler(async ({ project, body }) => {\n\treturn project.client.fs.getDirectory(body.path ?? \"\").read(true);\n}, { body: ReaddirFsBody }) };\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/fs/_page.server.ts.js';\n\nexport const index = 4;\nexport { server };\nexport const server_id = \"src/routes/actions/project/fs/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;;;;AAKA,IAAI,gBAAgB,MAAM;CACzB;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,cAAc,WAAW,QAAQ,KAAK,CAAC;AAG1C,IAAI,UAAU,EAAE,SAAS,iBAAiB,OAAO,EAAE,SAAS,WAAW;CACtE,OAAO,QAAQ,OAAO,GAAG,aAAa,KAAK,QAAQ,EAAE,CAAC,CAAC,KAAK,IAAI;AACjE,GAAG,EAAE,MAAM,cAAc,CAAC,EAAE;;;ACf5B,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
1
+ {"version":3,"file":"6-DH_IMDRv.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/fs/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/6.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsOptional, IsString } from \"class-validator\";\n//#region src/lib/server/actions/project/fs/readdir.action.ts\nvar ReaddirFsBody = class {\n\tpath;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsOptional()\n], ReaddirFsBody.prototype, \"path\", void 0);\n//#endregion\n//#region src/routes/actions/project/fs/+page.server.ts\nvar actions = { readdir: useActionHandler(async ({ project, body }) => {\n\treturn project.client.fs.getDirectory(body.path ?? \"\").read(true);\n}, { body: ReaddirFsBody }) };\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/fs/_page.server.ts.js';\n\nexport const index = 6;\nexport { server };\nexport const server_id = \"src/routes/actions/project/fs/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;;;;AAKA,IAAI,gBAAgB,MAAM;CACzB;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,cAAc,WAAW,QAAQ,KAAK,CAAC;AAG1C,IAAI,UAAU,EAAE,SAAS,iBAAiB,OAAO,EAAE,SAAS,WAAW;CACtE,OAAO,QAAQ,OAAO,GAAG,aAAa,KAAK,QAAQ,EAAE,CAAC,CAAC,KAAK,IAAI;AACjE,GAAG,EAAE,MAAM,cAAc,CAAC,EAAE;;;ACf5B,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
@@ -86,8 +86,8 @@ var actions = {
86
86
  })
87
87
  };
88
88
  //#endregion
89
- //#region .svelte-kit/adapter-bun/nodes/6.js
90
- const index = 6;
89
+ //#region .svelte-kit/adapter-bun/nodes/7.js
90
+ const index = 7;
91
91
  const server_id = "src/routes/actions/project/package/+page.server.ts";
92
92
  const imports = [];
93
93
  const stylesheets = [];
@@ -95,4 +95,4 @@ const fonts = [];
95
95
  //#endregion
96
96
  export { fonts, imports, index, _page_server_ts_exports as server, server_id, stylesheets };
97
97
 
98
- //# sourceMappingURL=6-Dl_h_OyU.js.map
98
+ //# sourceMappingURL=7-CPMeoSUO.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"6-Dl_h_OyU.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/package/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/6.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsNotEmpty, IsString } from \"class-validator\";\n//#region src/lib/server/actions/project/package/add-components.action.ts\nvar AddComponentBody = class {\n\tcomponentNames;\n};\n__decorate([\n\tExpose(),\n\tIsString({ each: true }),\n\tIsNotEmpty()\n], AddComponentBody.prototype, \"componentNames\", void 0);\nvar addComponentsProjectAction = useActionHandler(async ({ body, project }) => {\n\treturn await Promise.all(body.componentNames.map((componentName) => project.client.package.installComponent(componentName)));\n}, { body: AddComponentBody });\n//#endregion\n//#region src/lib/server/actions/project/package/add-systems.action.ts\nvar AddSystemBody = class {\n\tsystemNames;\n};\n__decorate([\n\tExpose(),\n\tIsString({ each: true }),\n\tIsNotEmpty()\n], AddSystemBody.prototype, \"systemNames\", void 0);\nvar addSystemsProjectAction = useActionHandler(async ({ body, project }) => {\n\treturn await Promise.all(body.systemNames.map((systemName) => project.client.package.installSystem(systemName)));\n}, { body: AddSystemBody });\n//#endregion\n//#region src/lib/server/actions/project/package/create-component.action.ts\nvar CreateComponentBody = class {\n\tcomponentName;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsNotEmpty()\n], CreateComponentBody.prototype, \"componentName\", void 0);\nvar createComponentProjectAction = useActionHandler(async ({ body, project }) => {\n\treturn project.client.package.createComponent(body.componentName);\n}, { body: CreateComponentBody });\n//#endregion\n//#region src/lib/server/actions/project/package/create-system.action.ts\nvar CreateSystemBody = class {\n\tsystemName;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsNotEmpty()\n], CreateSystemBody.prototype, \"systemName\", void 0);\nvar createSystemProjectAction = useActionHandler(async ({ body, project }) => {\n\treturn project.client.package.createSystem(body.systemName);\n}, { body: CreateSystemBody });\n//#endregion\n//#region src/lib/server/actions/project/package/get-components-manifests.action.ts\nvar GetComponentManifestBody = class {\n\tcomponentPaths;\n};\n__decorate([\n\tExpose(),\n\tIsString({ each: true }),\n\tIsNotEmpty()\n], GetComponentManifestBody.prototype, \"componentPaths\", void 0);\nvar getComponentsManifestsAction = useActionHandler(async ({ body, project }) => {\n\treturn await Promise.all(body.componentPaths.map((path) => project.client.package.getComponentManifest(path)));\n}, { body: GetComponentManifestBody });\n//#endregion\n//#region src/lib/server/actions/project/package/get-components.action.ts\nvar getComponentsAction = useActionHandler(async ({ project }) => {\n\treturn await project.client.package.getComponents();\n});\n//#endregion\n//#region src/lib/server/actions/project/package/get-systems-manifests.action.ts\nvar GetSystemManifestBody = class {\n\tsystemPaths;\n};\n__decorate([\n\tExpose(),\n\tIsString({ each: true }),\n\tIsNotEmpty()\n], GetSystemManifestBody.prototype, \"systemPaths\", void 0);\n//#endregion\n//#region src/routes/actions/project/package/+page.server.ts\nvar actions = {\n\t\"add-components\": addComponentsProjectAction,\n\t\"add-systems\": addSystemsProjectAction,\n\t\"create-component\": createComponentProjectAction,\n\t\"create-system\": createSystemProjectAction,\n\t\"get-components-manifests\": getComponentsManifestsAction,\n\t\"get-systems-manifests\": useActionHandler(async ({ body, project }) => {\n\t\treturn await Promise.all(body.systemPaths.map((path) => project.client.package.getSystemManifest(path)));\n\t}, { body: GetSystemManifestBody }),\n\t\"get-components\": getComponentsAction,\n\t\"get-systems\": useActionHandler(async ({ project }) => {\n\t\treturn await project.client.package.getSystems();\n\t})\n};\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/package/_page.server.ts.js';\n\nexport const index = 6;\nexport { server };\nexport const server_id = \"src/routes/actions/project/package/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;;;;AAKA,IAAI,mBAAmB,MAAM;CAC5B;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS,EAAE,MAAM,KAAK,CAAC;CACvB,WAAW;AACZ,GAAG,iBAAiB,WAAW,kBAAkB,KAAK,CAAC;AACvD,IAAI,6BAA6B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAC9E,OAAO,MAAM,QAAQ,IAAI,KAAK,eAAe,KAAK,kBAAkB,QAAQ,OAAO,QAAQ,iBAAiB,aAAa,CAAC,CAAC;AAC5H,GAAG,EAAE,MAAM,iBAAiB,CAAC;AAG7B,IAAI,gBAAgB,MAAM;CACzB;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS,EAAE,MAAM,KAAK,CAAC;CACvB,WAAW;AACZ,GAAG,cAAc,WAAW,eAAe,KAAK,CAAC;AACjD,IAAI,0BAA0B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAC3E,OAAO,MAAM,QAAQ,IAAI,KAAK,YAAY,KAAK,eAAe,QAAQ,OAAO,QAAQ,cAAc,UAAU,CAAC,CAAC;AAChH,GAAG,EAAE,MAAM,cAAc,CAAC;AAG1B,IAAI,sBAAsB,MAAM;CAC/B;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,oBAAoB,WAAW,iBAAiB,KAAK,CAAC;AACzD,IAAI,+BAA+B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAChF,OAAO,QAAQ,OAAO,QAAQ,gBAAgB,KAAK,aAAa;AACjE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAGhC,IAAI,mBAAmB,MAAM;CAC5B;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,iBAAiB,WAAW,cAAc,KAAK,CAAC;AACnD,IAAI,4BAA4B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAC7E,OAAO,QAAQ,OAAO,QAAQ,aAAa,KAAK,UAAU;AAC3D,GAAG,EAAE,MAAM,iBAAiB,CAAC;AAG7B,IAAI,2BAA2B,MAAM;CACpC;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS,EAAE,MAAM,KAAK,CAAC;CACvB,WAAW;AACZ,GAAG,yBAAyB,WAAW,kBAAkB,KAAK,CAAC;AAC/D,IAAI,+BAA+B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAChF,OAAO,MAAM,QAAQ,IAAI,KAAK,eAAe,KAAK,SAAS,QAAQ,OAAO,QAAQ,qBAAqB,IAAI,CAAC,CAAC;AAC9G,GAAG,EAAE,MAAM,yBAAyB,CAAC;AAGrC,IAAI,sBAAsB,iBAAiB,OAAO,EAAE,cAAc;CACjE,OAAO,MAAM,QAAQ,OAAO,QAAQ,cAAc;AACnD,CAAC;AAGD,IAAI,wBAAwB,MAAM;CACjC;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS,EAAE,MAAM,KAAK,CAAC;CACvB,WAAW;AACZ,GAAG,sBAAsB,WAAW,eAAe,KAAK,CAAC;AAGzD,IAAI,UAAU;CACb,kBAAkB;CAClB,eAAe;CACf,oBAAoB;CACpB,iBAAiB;CACjB,4BAA4B;CAC5B,yBAAyB,iBAAiB,OAAO,EAAE,MAAM,cAAc;EACtE,OAAO,MAAM,QAAQ,IAAI,KAAK,YAAY,KAAK,SAAS,QAAQ,OAAO,QAAQ,kBAAkB,IAAI,CAAC,CAAC;CACxG,GAAG,EAAE,MAAM,sBAAsB,CAAC;CAClC,kBAAkB;CAClB,eAAe,iBAAiB,OAAO,EAAE,cAAc;EACtD,OAAO,MAAM,QAAQ,OAAO,QAAQ,WAAW;CAChD,CAAC;AACF;;;AChGA,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
1
+ {"version":3,"file":"7-CPMeoSUO.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/package/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/7.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsNotEmpty, IsString } from \"class-validator\";\n//#region src/lib/server/actions/project/package/add-components.action.ts\nvar AddComponentBody = class {\n\tcomponentNames;\n};\n__decorate([\n\tExpose(),\n\tIsString({ each: true }),\n\tIsNotEmpty()\n], AddComponentBody.prototype, \"componentNames\", void 0);\nvar addComponentsProjectAction = useActionHandler(async ({ body, project }) => {\n\treturn await Promise.all(body.componentNames.map((componentName) => project.client.package.installComponent(componentName)));\n}, { body: AddComponentBody });\n//#endregion\n//#region src/lib/server/actions/project/package/add-systems.action.ts\nvar AddSystemBody = class {\n\tsystemNames;\n};\n__decorate([\n\tExpose(),\n\tIsString({ each: true }),\n\tIsNotEmpty()\n], AddSystemBody.prototype, \"systemNames\", void 0);\nvar addSystemsProjectAction = useActionHandler(async ({ body, project }) => {\n\treturn await Promise.all(body.systemNames.map((systemName) => project.client.package.installSystem(systemName)));\n}, { body: AddSystemBody });\n//#endregion\n//#region src/lib/server/actions/project/package/create-component.action.ts\nvar CreateComponentBody = class {\n\tcomponentName;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsNotEmpty()\n], CreateComponentBody.prototype, \"componentName\", void 0);\nvar createComponentProjectAction = useActionHandler(async ({ body, project }) => {\n\treturn project.client.package.createComponent(body.componentName);\n}, { body: CreateComponentBody });\n//#endregion\n//#region src/lib/server/actions/project/package/create-system.action.ts\nvar CreateSystemBody = class {\n\tsystemName;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsNotEmpty()\n], CreateSystemBody.prototype, \"systemName\", void 0);\nvar createSystemProjectAction = useActionHandler(async ({ body, project }) => {\n\treturn project.client.package.createSystem(body.systemName);\n}, { body: CreateSystemBody });\n//#endregion\n//#region src/lib/server/actions/project/package/get-components-manifests.action.ts\nvar GetComponentManifestBody = class {\n\tcomponentPaths;\n};\n__decorate([\n\tExpose(),\n\tIsString({ each: true }),\n\tIsNotEmpty()\n], GetComponentManifestBody.prototype, \"componentPaths\", void 0);\nvar getComponentsManifestsAction = useActionHandler(async ({ body, project }) => {\n\treturn await Promise.all(body.componentPaths.map((path) => project.client.package.getComponentManifest(path)));\n}, { body: GetComponentManifestBody });\n//#endregion\n//#region src/lib/server/actions/project/package/get-components.action.ts\nvar getComponentsAction = useActionHandler(async ({ project }) => {\n\treturn await project.client.package.getComponents();\n});\n//#endregion\n//#region src/lib/server/actions/project/package/get-systems-manifests.action.ts\nvar GetSystemManifestBody = class {\n\tsystemPaths;\n};\n__decorate([\n\tExpose(),\n\tIsString({ each: true }),\n\tIsNotEmpty()\n], GetSystemManifestBody.prototype, \"systemPaths\", void 0);\n//#endregion\n//#region src/routes/actions/project/package/+page.server.ts\nvar actions = {\n\t\"add-components\": addComponentsProjectAction,\n\t\"add-systems\": addSystemsProjectAction,\n\t\"create-component\": createComponentProjectAction,\n\t\"create-system\": createSystemProjectAction,\n\t\"get-components-manifests\": getComponentsManifestsAction,\n\t\"get-systems-manifests\": useActionHandler(async ({ body, project }) => {\n\t\treturn await Promise.all(body.systemPaths.map((path) => project.client.package.getSystemManifest(path)));\n\t}, { body: GetSystemManifestBody }),\n\t\"get-components\": getComponentsAction,\n\t\"get-systems\": useActionHandler(async ({ project }) => {\n\t\treturn await project.client.package.getSystems();\n\t})\n};\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/package/_page.server.ts.js';\n\nexport const index = 7;\nexport { server };\nexport const server_id = \"src/routes/actions/project/package/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;;;;AAKA,IAAI,mBAAmB,MAAM;CAC5B;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS,EAAE,MAAM,KAAK,CAAC;CACvB,WAAW;AACZ,GAAG,iBAAiB,WAAW,kBAAkB,KAAK,CAAC;AACvD,IAAI,6BAA6B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAC9E,OAAO,MAAM,QAAQ,IAAI,KAAK,eAAe,KAAK,kBAAkB,QAAQ,OAAO,QAAQ,iBAAiB,aAAa,CAAC,CAAC;AAC5H,GAAG,EAAE,MAAM,iBAAiB,CAAC;AAG7B,IAAI,gBAAgB,MAAM;CACzB;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS,EAAE,MAAM,KAAK,CAAC;CACvB,WAAW;AACZ,GAAG,cAAc,WAAW,eAAe,KAAK,CAAC;AACjD,IAAI,0BAA0B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAC3E,OAAO,MAAM,QAAQ,IAAI,KAAK,YAAY,KAAK,eAAe,QAAQ,OAAO,QAAQ,cAAc,UAAU,CAAC,CAAC;AAChH,GAAG,EAAE,MAAM,cAAc,CAAC;AAG1B,IAAI,sBAAsB,MAAM;CAC/B;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,oBAAoB,WAAW,iBAAiB,KAAK,CAAC;AACzD,IAAI,+BAA+B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAChF,OAAO,QAAQ,OAAO,QAAQ,gBAAgB,KAAK,aAAa;AACjE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAGhC,IAAI,mBAAmB,MAAM;CAC5B;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,iBAAiB,WAAW,cAAc,KAAK,CAAC;AACnD,IAAI,4BAA4B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAC7E,OAAO,QAAQ,OAAO,QAAQ,aAAa,KAAK,UAAU;AAC3D,GAAG,EAAE,MAAM,iBAAiB,CAAC;AAG7B,IAAI,2BAA2B,MAAM;CACpC;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS,EAAE,MAAM,KAAK,CAAC;CACvB,WAAW;AACZ,GAAG,yBAAyB,WAAW,kBAAkB,KAAK,CAAC;AAC/D,IAAI,+BAA+B,iBAAiB,OAAO,EAAE,MAAM,cAAc;CAChF,OAAO,MAAM,QAAQ,IAAI,KAAK,eAAe,KAAK,SAAS,QAAQ,OAAO,QAAQ,qBAAqB,IAAI,CAAC,CAAC;AAC9G,GAAG,EAAE,MAAM,yBAAyB,CAAC;AAGrC,IAAI,sBAAsB,iBAAiB,OAAO,EAAE,cAAc;CACjE,OAAO,MAAM,QAAQ,OAAO,QAAQ,cAAc;AACnD,CAAC;AAGD,IAAI,wBAAwB,MAAM;CACjC;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS,EAAE,MAAM,KAAK,CAAC;CACvB,WAAW;AACZ,GAAG,sBAAsB,WAAW,eAAe,KAAK,CAAC;AAGzD,IAAI,UAAU;CACb,kBAAkB;CAClB,eAAe;CACf,oBAAoB;CACpB,iBAAiB;CACjB,4BAA4B;CAC5B,yBAAyB,iBAAiB,OAAO,EAAE,MAAM,cAAc;EACtE,OAAO,MAAM,QAAQ,IAAI,KAAK,YAAY,KAAK,SAAS,QAAQ,OAAO,QAAQ,kBAAkB,IAAI,CAAC,CAAC;CACxG,GAAG,EAAE,MAAM,sBAAsB,CAAC;CAClC,kBAAkB;CAClB,eAAe,iBAAiB,OAAO,EAAE,cAAc;EACtD,OAAO,MAAM,QAAQ,OAAO,QAAQ,WAAW;CAChD,CAAC;AACF;;;AChGA,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
@@ -15,8 +15,8 @@ var actions = {
15
15
  })
16
16
  };
17
17
  //#endregion
18
- //#region .svelte-kit/adapter-bun/nodes/7.js
19
- const index = 7;
18
+ //#region .svelte-kit/adapter-bun/nodes/8.js
19
+ const index = 8;
20
20
  const server_id = "src/routes/actions/project/loader/+page.server.ts";
21
21
  const imports = [];
22
22
  const stylesheets = [];
@@ -24,4 +24,4 @@ const fonts = [];
24
24
  //#endregion
25
25
  export { fonts, imports, index, _page_server_ts_exports as server, server_id, stylesheets };
26
26
 
27
- //# sourceMappingURL=7-BUEKgK7m.js.map
27
+ //# sourceMappingURL=8-CRTa48Fz.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"7-BUEKgK7m.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/loader/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/7.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\n//#endregion\n//#region src/routes/actions/project/loader/+page.server.ts\nvar actions = {\n\tbuild: useActionHandler(async ({ cli }) => {\n\t\tcli.generate({ editor: true });\n\t\tcli.build({ editor: true });\n\t}),\n\tenv: useActionHandler(async ({ project }) => {\n\t\treturn project.client.loader.getEnv();\n\t}),\n\tmanifest: useActionHandler(async ({ project }) => {\n\t\treturn project.client.loader.getManifest();\n\t})\n};\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/loader/_page.server.ts.js';\n\nexport const index = 7;\nexport { server };\nexport const server_id = \"src/routes/actions/project/loader/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;AAGA,IAAI,UAAU;CACb,OAAO,iBAAiB,OAAO,EAAE,UAAU;EAC1C,IAAI,SAAS,EAAE,QAAQ,KAAK,CAAC;EAC7B,IAAI,MAAM,EAAE,QAAQ,KAAK,CAAC;CAC3B,CAAC;CACD,KAAK,iBAAiB,OAAO,EAAE,cAAc;EAC5C,OAAO,QAAQ,OAAO,OAAO,OAAO;CACrC,CAAC;CACD,UAAU,iBAAiB,OAAO,EAAE,cAAc;EACjD,OAAO,QAAQ,OAAO,OAAO,YAAY;CAC1C,CAAC;AACF;;;ACZA,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
1
+ {"version":3,"file":"8-CRTa48Fz.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/loader/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/8.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\n//#endregion\n//#region src/routes/actions/project/loader/+page.server.ts\nvar actions = {\n\tbuild: useActionHandler(async ({ cli }) => {\n\t\tcli.generate({ editor: true });\n\t\tcli.build({ editor: true });\n\t}),\n\tenv: useActionHandler(async ({ project }) => {\n\t\treturn project.client.loader.getEnv();\n\t}),\n\tmanifest: useActionHandler(async ({ project }) => {\n\t\treturn project.client.loader.getManifest();\n\t})\n};\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/loader/_page.server.ts.js';\n\nexport const index = 8;\nexport { server };\nexport const server_id = \"src/routes/actions/project/loader/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;AAGA,IAAI,UAAU;CACb,OAAO,iBAAiB,OAAO,EAAE,UAAU;EAC1C,IAAI,SAAS,EAAE,QAAQ,KAAK,CAAC;EAC7B,IAAI,MAAM,EAAE,QAAQ,KAAK,CAAC;CAC3B,CAAC;CACD,KAAK,iBAAiB,OAAO,EAAE,cAAc;EAC5C,OAAO,QAAQ,OAAO,OAAO,OAAO;CACrC,CAAC;CACD,UAAU,iBAAiB,OAAO,EAAE,cAAc;EACjD,OAAO,QAAQ,OAAO,OAAO,YAAY;CAC1C,CAAC;AACF;;;ACZA,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
@@ -17,8 +17,8 @@ var actions = { install: useActionHandler(async ({ body, project }) => {
17
17
  return await project.client.library.installLibrary(body.libraryName);
18
18
  }, { body: InstallLibraryBody }) };
19
19
  //#endregion
20
- //#region .svelte-kit/adapter-bun/nodes/5.js
21
- const index = 5;
20
+ //#region .svelte-kit/adapter-bun/nodes/9.js
21
+ const index = 9;
22
22
  const server_id = "src/routes/actions/project/library/+page.server.ts";
23
23
  const imports = [];
24
24
  const stylesheets = [];
@@ -26,4 +26,4 @@ const fonts = [];
26
26
  //#endregion
27
27
  export { fonts, imports, index, _page_server_ts_exports as server, server_id, stylesheets };
28
28
 
29
- //# sourceMappingURL=5-610NKQc3.js.map
29
+ //# sourceMappingURL=9-DPn3d8kr.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"5-610NKQc3.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/library/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/5.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsNotEmpty, IsString } from \"class-validator\";\n//#region src/lib/server/actions/project/library/install-library.action.ts\nvar InstallLibraryBody = class {\n\tlibraryName;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsNotEmpty()\n], InstallLibraryBody.prototype, \"libraryName\", void 0);\n//#endregion\n//#region src/routes/actions/project/library/+page.server.ts\nvar actions = { install: useActionHandler(async ({ body, project }) => {\n\treturn await project.client.library.installLibrary(body.libraryName);\n}, { body: InstallLibraryBody }) };\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/library/_page.server.ts.js';\n\nexport const index = 5;\nexport { server };\nexport const server_id = \"src/routes/actions/project/library/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;;;;AAKA,IAAI,qBAAqB,MAAM;CAC9B;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,mBAAmB,WAAW,eAAe,KAAK,CAAC;AAGtD,IAAI,UAAU,EAAE,SAAS,iBAAiB,OAAO,EAAE,MAAM,cAAc;CACtE,OAAO,MAAM,QAAQ,OAAO,QAAQ,eAAe,KAAK,WAAW;AACpE,GAAG,EAAE,MAAM,mBAAmB,CAAC,EAAE;;;ACfjC,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
1
+ {"version":3,"file":"9-DPn3d8kr.js","names":[],"sources":["../../../.svelte-kit/adapter-bun/entries/pages/actions/project/library/_page.server.ts.js","../../../.svelte-kit/adapter-bun/nodes/9.js"],"sourcesContent":["import { n as useActionHandler } from \"../../../../../chunks/request-handler.js\";\nimport { t as __decorate } from \"../../../../../chunks/decorate.js\";\nimport { Expose } from \"class-transformer\";\nimport { IsNotEmpty, IsString } from \"class-validator\";\n//#region src/lib/server/actions/project/library/install-library.action.ts\nvar InstallLibraryBody = class {\n\tlibraryName;\n};\n__decorate([\n\tExpose(),\n\tIsString(),\n\tIsNotEmpty()\n], InstallLibraryBody.prototype, \"libraryName\", void 0);\n//#endregion\n//#region src/routes/actions/project/library/+page.server.ts\nvar actions = { install: useActionHandler(async ({ body, project }) => {\n\treturn await project.client.library.installLibrary(body.libraryName);\n}, { body: InstallLibraryBody }) };\n//#endregion\nexport { actions };\n","import * as server from '../entries/pages/actions/project/library/_page.server.ts.js';\n\nexport const index = 9;\nexport { server };\nexport const server_id = \"src/routes/actions/project/library/+page.server.ts\";\nexport const imports = [];\nexport const stylesheets = [];\nexport const fonts = [];\n"],"mappings":";;;;;;;AAKA,IAAI,qBAAqB,MAAM;CAC9B;AACD;AACA,WAAW;CACV,OAAO;CACP,SAAS;CACT,WAAW;AACZ,GAAG,mBAAmB,WAAW,eAAe,KAAK,CAAC;AAGtD,IAAI,UAAU,EAAE,SAAS,iBAAiB,OAAO,EAAE,MAAM,cAAc;CACtE,OAAO,MAAM,QAAQ,OAAO,QAAQ,eAAe,KAAK,WAAW;AACpE,GAAG,EAAE,MAAM,mBAAmB,CAAC,EAAE;;;ACfjC,MAAa,QAAQ;AAErB,MAAa,YAAY;AACzB,MAAa,UAAU,CAAC;AACxB,MAAa,cAAc,CAAC;AAC5B,MAAa,QAAQ,CAAC"}
@@ -1,12 +1,12 @@
1
- import { $ as onDestroy, D as ensure_array_like, M as get$1, St as writable, _t as to_array, bt as unsubscribe_stores, dt as spread_props, f as attr, ft as store_get, g as bind_props, h as attributes, k as escape_html, m as attr_style, p as attr_class, pt as stringify, r as on, tt as props_id, w as derived, y as clsx$1 } from "./events-Bhh2w-5S.js";
2
- import "./internal2-DBpj29pr.js";
1
+ import { $ as onDestroy, D as ensure_array_like, M as get$1, P as getContext, St as writable, _t as to_array, bt as unsubscribe_stores, ct as setContext, dt as spread_props, f as attr, ft as store_get, g as bind_props, h as attributes, k as escape_html, m as attr_style, p as attr_class, pt as stringify, r as on, tt as props_id, w as derived, y as clsx$1 } from "./events-Bhh2w-5S.js";
2
+ import "./internal2-B-CDEkbN.js";
3
3
  import { r as formatFrom } from "./format-DGOlJxF5.js";
4
- import "./client-bZcBshMs.js";
5
- import "./state-DwdUA00F.js";
4
+ import "./client-CKx4JfSs.js";
5
+ import "./state-CEUkMO8P.js";
6
6
  import { c as SvelteMap, t as Icon$1 } from "./loader-circle-CFNm9vip.js";
7
- import { $ as createBitsAttrs, A as Portal, C as MenuMenuState, J as boolToStr, K as attachRef, O as Popper_layer, P as RovingFocusGroup, Q as cn, S as MenuItemState, T as MenuSeparatorState, U as Switch, W as Switch_thumb, X as boxWith, Y as boolToTrueOrUndef, Z as capitalize, _ as Floating_layer_anchor, _t as useId, b as Loading_button, bt as tv, ct as getFloatingContentCSSVars, d as DOMContext, dt as mergeProps, et as createId, ft as noop, g as Floating_layer, gt as useDebounce, h as FloatingArrowState, j as PresenceManager, k as Popper_layer_force_mount, l as Context, lt as isElement$1, mt as simpleBox, n as Button, ot as getDataTransitionAttrs, p as DropdownMenuTriggerState, q as boolToEmptyStrOrUndef, r as CONTEXT_MENU_TRIGGER_ATTR, st as getDocument, t as AnimationsComplete, tt as createQuery, u as ContextMenuTriggerState, ut as isFocusVisible, vt as useProject, w as MenuRootState, x as MenuContentState, y as IsMounted, yt as watch } from "./error-DYeUQ7mQ.js";
8
- import { a as Dialog_header, c as Skeleton, i as Dialog_footer, n as Dialog_content, o as Dialog_title, r as Dialog_description, s as Input, t as Dialog } from "./logo-DQI0khKS.js";
9
- import { n as Progress_bar, t as Full_page_project_spinner } from "./project-loader-DaQVgPID.js";
7
+ import { $ as createBitsAttrs, A as Portal, C as MenuMenuState, I as Select, J as boolToStr, K as attachRef, L as Select_content, O as Popper_layer, P as RovingFocusGroup, Q as cn, R as Select_item, S as MenuItemState, T as MenuSeparatorState, U as Switch, V as Spinner, W as Switch_thumb, X as boxWith, Y as boolToTrueOrUndef, Z as capitalize, _ as Floating_layer_anchor, _t as useId, b as Loading_button, bt as tv, ct as getFloatingContentCSSVars, d as DOMContext, dt as mergeProps, et as createId, ft as noop, g as Floating_layer, gt as useDebounce, h as FloatingArrowState, j as PresenceManager, k as Popper_layer_force_mount, l as Context, lt as isElement$1, mt as simpleBox, n as Button, ot as getDataTransitionAttrs, p as DropdownMenuTriggerState, q as boolToEmptyStrOrUndef, r as CONTEXT_MENU_TRIGGER_ATTR, st as getDocument, t as AnimationsComplete, tt as createQuery, u as ContextMenuTriggerState, ut as isFocusVisible, vt as useProject, w as MenuRootState, x as MenuContentState, y as IsMounted, yt as watch, z as Select_trigger } from "./error-bOWEqlVk.js";
8
+ import { a as Dialog_header, c as Skeleton, i as Dialog_footer, n as Dialog_content, o as Dialog_title, r as Dialog_description, s as Input, t as Dialog } from "./logo-BsWuqjoe.js";
9
+ import { n as Progress_bar, t as Full_page_project_spinner } from "./project-loader-D_rtPhxK.js";
10
10
  //#region .svelte-kit/adapter-bun/entries/pages/dashboard/_page.svelte.js
11
11
  function Arrow($$renderer, $$props) {
12
12
  $$renderer.component(($$renderer) => {
@@ -3222,7 +3222,7 @@ function EditorGame($$renderer, $$props) {
3222
3222
  $$renderer.push("<!--[-1-->");
3223
3223
  $$renderer.push(`<button aria-label="Pause" class="h-fit cursor-pointer hover:bg-neutral-700 rounded-md"><span class="block h-7 w-7 i-ic-round-pause text-yellow"></span></button>`);
3224
3224
  }
3225
- $$renderer.push(`<!--]--> <button aria-label="Stop"${attr_class(`h-fit ${gameState === GameState.PLAY ? "cursor-pointer hover:bg-neutral-700" : ""} rounded-md`)}><span${attr_class(`block h-7 w-7 i-ic-round-stop ${gameState === GameState.PLAY ? "text-red-600" : "text-red-950"}`)}></span></button> <button aria-label="Reload from server"${attr_class(`h-fit ${gameState !== GameState.RELOAD_FROM_SERVER ? "cursor-pointer hover:bg-neutral-700" : ""} rounded-md`)}><span${attr_class(`block h-7 w-7 i-ic-round-autorenew ${gameState !== GameState.RELOAD_FROM_SERVER ? "text-blue-500" : "text-blue-950"}`)}></span></button></div></div> <div class="h-full w-full bg-black mb-8"><div class="editor-game-container svelte-1rzbbvo"></div></div></div></div>`);
3225
+ $$renderer.push(`<!--]--> <button aria-label="Stop"${attr_class(`h-fit ${gameState === GameState.PLAY ? "cursor-pointer hover:bg-neutral-700" : ""} rounded-md`)}><span${attr_class(`block h-7 w-7 i-ic-round-stop ${gameState === GameState.PLAY ? "text-red-600" : "text-red-950"}`)}></span></button> <button aria-label="Reload from server"${attr_class(`h-fit ${gameState !== GameState.RELOAD_FROM_SERVER ? "cursor-pointer hover:bg-neutral-700" : ""} rounded-md`)}><span${attr_class(`block h-7 w-7 i-ic-round-autorenew ${gameState !== GameState.RELOAD_FROM_SERVER ? "text-sky-600" : "text-sky-950"}`)}></span></button></div></div> <div class="h-full w-full bg-black mb-8"><div class="editor-game-container svelte-1rzbbvo"></div></div></div></div>`);
3226
3226
  });
3227
3227
  }
3228
3228
  var exampleLogs = [
@@ -3712,6 +3712,27 @@ function Icon($$renderer, $$props) {
3712
3712
  }
3713
3713
  var currentDir = writable("");
3714
3714
  var joinPath = (path, name) => `${path ? `${path}/` : ""}${name}`;
3715
+ var FILE_TYPES = [
3716
+ ["ts", ["ts", "js"]],
3717
+ ["3d", ["fbd"]],
3718
+ ["song", [
3719
+ "mp3",
3720
+ "wav",
3721
+ "flac"
3722
+ ]],
3723
+ ["img", [
3724
+ "png",
3725
+ "jpg",
3726
+ "jpeg",
3727
+ "gif",
3728
+ "svg",
3729
+ "webp"
3730
+ ]]
3731
+ ];
3732
+ var getType = (name) => {
3733
+ const [type] = FILE_TYPES.find(([, exts]) => exts.includes(name.split(".").pop())) ?? ["unknown"];
3734
+ return type;
3735
+ };
3715
3736
  function Content_item($$renderer, $$props) {
3716
3737
  $$renderer.component(($$renderer) => {
3717
3738
  var $$store_subs;
@@ -4121,7 +4142,7 @@ function Tabs_trigger($$renderer, $$props) {
4121
4142
  Tabs_trigger$1($$renderer, spread_props([
4122
4143
  {
4123
4144
  "data-slot": "tabs-trigger",
4124
- class: cn("gap-1.5 border-b-2 border-transparent duration-300 px-1.5 py-0.5 text-sm font-medium has-data-[icon=inline-end]:pr-1 has-data-[icon=inline-start]:pl-1 group-data-[variant=default]/tabs-list:data-[state=active]:shadow-sm group-data-[variant=line]/tabs-list:data-[state=active]:shadow-none [&_svg:not([class*='size-'])]:size-4 focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:outline-ring text-foreground/60 hover:text-foreground dark:text-muted-foreground dark:hover:text-foreground relative inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center whitespace-nowrap transition-all group-data-[orientation=vertical]/tabs:w-full group-data-[orientation=vertical]/tabs:justify-start focus-visible:ring-[3px] focus-visible:outline-1 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0", "group-data-[variant=line]/tabs-list:bg-transparent group-data-[variant=line]/tabs-list:data-[state=active]:bg-transparent dark:group-data-[variant=line]/tabs-list:data-[state=active]:border-transparent dark:group-data-[variant=line]/tabs-list:data-[state=active]:bg-transparent", "data-[state=active]:bg-background dark:data-[state=active]:text-foreground dark:data-[state=active]:border-input data-[state=active]:border-primary dark:data-[state=active]:bg-input/30 data-[state=active]:text-foreground", "after:bg-foreground after:absolute after:opacity-0 after:transition-opacity group-data-[orientation=horizontal]/tabs:after:inset-x-0 group-data-[orientation=horizontal]/tabs:after:bottom-[-5px] group-data-[orientation=horizontal]/tabs:after:h-0.5 group-data-[orientation=vertical]/tabs:after:inset-y-0 group-data-[orientation=vertical]/tabs:after:-right-1 group-data-[orientation=vertical]/tabs:after:w-0.5 group-data-[variant=line]/tabs-list:data-[state=active]:after:opacity-100", className)
4145
+ class: cn("gap-1.5 border-b-2 border-transparent duration-300 px-1.5 py-0.5 text-sm font-medium hover:cursor-pointer has-data-[icon=inline-end]:pr-1 has-data-[icon=inline-start]:pl-1 group-data-[variant=default]/tabs-list:data-[state=active]:shadow-sm group-data-[variant=line]/tabs-list:data-[state=active]:shadow-none [&_svg:not([class*='size-'])]:size-4 focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:outline-ring text-foreground/60 hover:text-foreground dark:text-muted-foreground dark:hover:text-foreground relative inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center whitespace-nowrap transition-all group-data-[orientation=vertical]/tabs:w-full group-data-[orientation=vertical]/tabs:justify-start focus-visible:ring-[3px] focus-visible:outline-1 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0", "group-data-[variant=line]/tabs-list:bg-transparent group-data-[variant=line]/tabs-list:data-[state=active]:bg-transparent dark:group-data-[variant=line]/tabs-list:data-[state=active]:border-transparent dark:group-data-[variant=line]/tabs-list:data-[state=active]:bg-transparent", "data-[state=active]:bg-background dark:data-[state=active]:text-foreground dark:data-[state=active]:border-input data-[state=active]:border-primary dark:data-[state=active]:bg-input/30 data-[state=active]:text-foreground", "after:bg-foreground after:absolute after:opacity-0 after:transition-opacity group-data-[orientation=horizontal]/tabs:after:inset-x-0 group-data-[orientation=horizontal]/tabs:after:bottom-[-5px] group-data-[orientation=horizontal]/tabs:after:h-0.5 group-data-[orientation=vertical]/tabs:after:inset-y-0 group-data-[orientation=vertical]/tabs:after:-right-1 group-data-[orientation=vertical]/tabs:after:w-0.5 group-data-[variant=line]/tabs-list:data-[state=active]:after:opacity-100", className)
4125
4146
  },
4126
4147
  restProps,
4127
4148
  {
@@ -4906,9 +4927,11 @@ function Package_row($$renderer, $$props) {
4906
4927
  const activeSceneData = derived(() => store_get($$store_subs ??= {}, "$activeScene", activeScene())?.store);
4907
4928
  const selectedEntity = derived(() => store_get($$store_subs ??= {}, "$activeScene", activeScene()).entities.selected);
4908
4929
  const selectedEntityData = derived(() => store_get($$store_subs ??= {}, "$selectedEntity", selectedEntity())?.store);
4930
+ let deleteLoading = false;
4909
4931
  const disabled = derived(() => {
4910
4932
  if (type === "component" ? !store_get($$store_subs ??= {}, "$selectedEntity", selectedEntity()) : !store_get($$store_subs ??= {}, "$activeScene", activeScene())) return "selected";
4911
4933
  if (type === "component" ? !!store_get($$store_subs ??= {}, "$selectedEntityData", selectedEntityData())?.components[handle.id] : store_get($$store_subs ??= {}, "$activeSceneData", activeSceneData()).systems.includes(handle.id)) return "added";
4934
+ if (deleteLoading) return "delete";
4912
4935
  return null;
4913
4936
  });
4914
4937
  const items = derived(() => ITEMS[type]);
@@ -4928,9 +4951,18 @@ function Package_row($$renderer, $$props) {
4928
4951
  };
4929
4952
  const onOpenCode = (e) => {
4930
4953
  e.stopPropagation();
4954
+ const item = get$1(pkg());
4955
+ if (type === "library" || !item.path) return;
4956
+ tabsStore.openTab({
4957
+ type: getType(item.path),
4958
+ title: item.path.split("/").at(-1) ?? item.name,
4959
+ metadata: { path: item.path }
4960
+ });
4931
4961
  };
4932
- const handleDelete = () => {
4933
- handle.delete();
4962
+ const handleDelete = async () => {
4963
+ deleteLoading = true;
4964
+ await handle.delete();
4965
+ deleteLoading = false;
4934
4966
  };
4935
4967
  const onDelete = (e) => {
4936
4968
  e.stopPropagation();
@@ -4982,13 +5014,20 @@ function Package_row($$renderer, $$props) {
4982
5014
  } else $$renderer.push("<!--[-1-->");
4983
5015
  $$renderer.push(`<!--]--> `);
4984
5016
  Button($$renderer, {
4985
- disabled: type === "library",
5017
+ disabled: type === "library" || deleteLoading,
4986
5018
  variant: "ghost",
4987
5019
  size: "icon",
4988
5020
  class: "text-destructive hover:text-destructive hover:bg-destructive/20",
4989
5021
  onclick: onDelete,
4990
5022
  children: ($$renderer) => {
4991
- $$renderer.push(`<span class="i-ic-baseline-delete"></span>`);
5023
+ if (deleteLoading) {
5024
+ $$renderer.push("<!--[0-->");
5025
+ Spinner($$renderer, { class: "w-3 h-3" });
5026
+ } else {
5027
+ $$renderer.push("<!--[-1-->");
5028
+ $$renderer.push(`<span class="i-ic-baseline-delete"></span>`);
5029
+ }
5030
+ $$renderer.push(`<!--]-->`);
4992
5031
  },
4993
5032
  $$slots: { default: true }
4994
5033
  });
@@ -5023,11 +5062,18 @@ function Package_row($$renderer, $$props) {
5023
5062
  } else $$renderer.push("<!--[-1-->");
5024
5063
  $$renderer.push(`<!--]--> `);
5025
5064
  Context_menu_item($$renderer, {
5026
- disabled: type === "library",
5065
+ disabled: type === "library" || deleteLoading,
5027
5066
  variant: "destructive",
5028
5067
  onclick: onDelete,
5029
5068
  children: ($$renderer) => {
5030
- $$renderer.push(`<span class="i-ic-baseline-delete"></span> Delete`);
5069
+ if (deleteLoading) {
5070
+ $$renderer.push("<!--[0-->");
5071
+ Spinner($$renderer, { class: "w-3 h-3" });
5072
+ } else {
5073
+ $$renderer.push("<!--[-1-->");
5074
+ $$renderer.push(`<span class="i-ic-baseline-delete"></span>`);
5075
+ }
5076
+ $$renderer.push(`<!--]--> Delete`);
5031
5077
  },
5032
5078
  $$slots: { default: true }
5033
5079
  });
@@ -5265,6 +5311,7 @@ function Package_tab($$renderer, $$props) {
5265
5311
  const packages = derived(() => manager.store);
5266
5312
  const nameCapitalized = derived(() => capitalize(type));
5267
5313
  const namePlural = derived(() => type === "library" ? "libraries" : type + "s");
5314
+ getContext("ecsQuery");
5268
5315
  let query = "";
5269
5316
  const sorted = derived(() => store_get($$store_subs ??= {}, "$packages", packages()).filter((c) => !query || (c.name ?? c.id).toLowerCase().includes(query.toLowerCase())).sort((a, b) => (a.name ?? a.id).localeCompare(b.name ?? b.id)));
5270
5317
  let createOpen = false;
@@ -5463,6 +5510,15 @@ function Widget$2($$renderer, $$props) {
5463
5510
  $$renderer.component(($$renderer) => {
5464
5511
  const { ecs } = useProject();
5465
5512
  let selectedTab = "scenes";
5513
+ let query = {
5514
+ entities: "",
5515
+ packages: ""
5516
+ };
5517
+ const selectTab = (tab) => {
5518
+ selectedTab = tab;
5519
+ };
5520
+ setContext("selectTab", selectTab);
5521
+ setContext("ecsQuery", query);
5466
5522
  let $$settled = true;
5467
5523
  let $$inner_renderer;
5468
5524
  function $$render_inner($$renderer) {
@@ -5478,7 +5534,7 @@ function Widget$2($$renderer, $$props) {
5478
5534
  children: ($$renderer) => {
5479
5535
  Tabs_list($$renderer, {
5480
5536
  variant: "line",
5481
- class: "w-full justify-start rounded-none border-b border-border bg-neutral-800 shrink-0 h-auto py-0 px-0 gap-0",
5537
+ class: "w-full justify-start rounded-none border-b border-border bg-neutral-800 shrink-0 h-auto py-0 px-0 gap-0 overflow-x-scroll",
5482
5538
  children: ($$renderer) => {
5483
5539
  Tabs_trigger($$renderer, {
5484
5540
  value: "scenes",
@@ -5737,17 +5793,97 @@ function Component_param_row($$renderer, $$props) {
5737
5793
  $$renderer.push(`<div class="grid grid-cols-[140px_1fr] m-2 mb-1 items-center gap-2"><div class="text-neutral-200 text-sm">${escape_html(store_get($$store_subs ??= {}, "$param", param()).name)}</div> `);
5738
5794
  if (store_get($$store_subs ??= {}, "$param", param()).type === "string") {
5739
5795
  $$renderer.push("<!--[0-->");
5740
- Input($$renderer, {
5741
- type: "text",
5742
- onchange: handleChange,
5743
- get value() {
5744
- return value;
5745
- },
5746
- set value($$value) {
5747
- value = $$value;
5748
- $$settled = false;
5749
- }
5750
- });
5796
+ if (store_get($$store_subs ??= {}, "$param", param()).enum) {
5797
+ $$renderer.push("<!--[0-->");
5798
+ Select($$renderer, {
5799
+ type: "single",
5800
+ onValueChange: handleChange,
5801
+ get value() {
5802
+ return value;
5803
+ },
5804
+ set value($$value) {
5805
+ value = $$value;
5806
+ $$settled = false;
5807
+ },
5808
+ children: ($$renderer) => {
5809
+ Select_trigger($$renderer, {
5810
+ class: "w-full",
5811
+ children: ($$renderer) => {
5812
+ $$renderer.push(`<!---->${escape_html(value)}`);
5813
+ },
5814
+ $$slots: { default: true }
5815
+ });
5816
+ $$renderer.push(`<!----> `);
5817
+ Select_content($$renderer, {
5818
+ children: ($$renderer) => {
5819
+ if (Array.isArray(store_get($$store_subs ??= {}, "$param", param()).enum)) {
5820
+ $$renderer.push("<!--[0-->");
5821
+ if (!!store_get($$store_subs ??= {}, "$param", param()).enum.length) {
5822
+ $$renderer.push("<!--[0-->");
5823
+ $$renderer.push(`<!--[-->`);
5824
+ const each_array = ensure_array_like(store_get($$store_subs ??= {}, "$param", param()).enum);
5825
+ for (let $$index = 0, $$length = each_array.length; $$index < $$length; $$index++) {
5826
+ let opt = each_array[$$index];
5827
+ Select_item($$renderer, {
5828
+ value: opt,
5829
+ children: ($$renderer) => {
5830
+ $$renderer.push(`<!---->${escape_html(opt)}`);
5831
+ },
5832
+ $$slots: { default: true }
5833
+ });
5834
+ }
5835
+ $$renderer.push(`<!--]-->`);
5836
+ } else {
5837
+ $$renderer.push("<!--[-1-->");
5838
+ $$renderer.push(`<div class="px-4 py-2 text-muted-foreground italic">No options</div>`);
5839
+ }
5840
+ $$renderer.push(`<!--]-->`);
5841
+ } else {
5842
+ $$renderer.push("<!--[-1-->");
5843
+ if (Object.keys(store_get($$store_subs ??= {}, "$param", param()).enum).length === 0) {
5844
+ $$renderer.push("<!--[0-->");
5845
+ $$renderer.push(`<!--[-->`);
5846
+ const each_array_1 = ensure_array_like(Object.entries(store_get($$store_subs ??= {}, "$param", param()).enum));
5847
+ for (let $$index_1 = 0, $$length = each_array_1.length; $$index_1 < $$length; $$index_1++) {
5848
+ let [displayOpt, realOpt] = each_array_1[$$index_1];
5849
+ Select_item($$renderer, {
5850
+ value: realOpt,
5851
+ children: ($$renderer) => {
5852
+ $$renderer.push(`<!---->${escape_html(displayOpt)}`);
5853
+ },
5854
+ $$slots: { default: true }
5855
+ });
5856
+ }
5857
+ $$renderer.push(`<!--]-->`);
5858
+ } else {
5859
+ $$renderer.push("<!--[-1-->");
5860
+ $$renderer.push(`<div class="px-4 py-2 text-muted-foreground italic">No options</div>`);
5861
+ }
5862
+ $$renderer.push(`<!--]-->`);
5863
+ }
5864
+ $$renderer.push(`<!--]-->`);
5865
+ },
5866
+ $$slots: { default: true }
5867
+ });
5868
+ $$renderer.push(`<!---->`);
5869
+ },
5870
+ $$slots: { default: true }
5871
+ });
5872
+ } else {
5873
+ $$renderer.push("<!--[-1-->");
5874
+ Input($$renderer, {
5875
+ type: "text",
5876
+ onchange: handleChange,
5877
+ get value() {
5878
+ return value;
5879
+ },
5880
+ set value($$value) {
5881
+ value = $$value;
5882
+ $$settled = false;
5883
+ }
5884
+ });
5885
+ }
5886
+ $$renderer.push(`<!--]-->`);
5751
5887
  } else if (store_get($$store_subs ??= {}, "$param", param()).type === "number") {
5752
5888
  $$renderer.push("<!--[1-->");
5753
5889
  Input($$renderer, {
@@ -6271,4 +6407,4 @@ function _page($$renderer, $$props) {
6271
6407
  //#endregion
6272
6408
  export { _page as default };
6273
6409
 
6274
- //# sourceMappingURL=_page.svelte-vOyGpofm.js.map
6410
+ //# sourceMappingURL=_page.svelte-CSpYC4UR.js.map