@powerhousedao/vetra 6.0.0-dev.249 → 6.0.0-dev.250

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 (121) hide show
  1. package/dist/app-module-Bbj7PI-S.js +94 -0
  2. package/dist/app-module-Bbj7PI-S.js.map +1 -0
  3. package/dist/connect-CTIucT0o.js +6 -0
  4. package/dist/connect-CTIucT0o.js.map +1 -0
  5. package/dist/document-editor-DS-bZMKx.js +93 -0
  6. package/dist/document-editor-DS-bZMKx.js.map +1 -0
  7. package/dist/document-models/app-module/index.d.ts +349 -2
  8. package/dist/document-models/app-module/index.d.ts.map +1 -0
  9. package/dist/document-models/app-module/index.js +3 -2
  10. package/dist/document-models/document-editor/index.d.ts +325 -2
  11. package/dist/document-models/document-editor/index.d.ts.map +1 -0
  12. package/dist/document-models/document-editor/index.js +3 -2
  13. package/dist/document-models/index.d.ts +6 -29
  14. package/dist/document-models/index.js +6 -2
  15. package/dist/document-models/processor-module/index.d.ts +357 -2
  16. package/dist/document-models/processor-module/index.d.ts.map +1 -0
  17. package/dist/document-models/processor-module/index.js +3 -2
  18. package/dist/document-models/subgraph-module/index.d.ts +296 -2
  19. package/dist/document-models/subgraph-module/index.d.ts.map +1 -0
  20. package/dist/document-models/subgraph-module/index.js +3 -2
  21. package/dist/document-models/vetra-package/index.d.ts +386 -2
  22. package/dist/document-models/vetra-package/index.d.ts.map +1 -0
  23. package/dist/document-models/vetra-package/index.js +3 -2
  24. package/dist/{editor-DqkJ0B4G.js → editor-BSQfwcdz.js} +5 -4
  25. package/dist/{editor-DqkJ0B4G.js.map → editor-BSQfwcdz.js.map} +1 -1
  26. package/dist/{editor-CGNcK2z0.js → editor-Bku8e2dr.js} +5 -5
  27. package/dist/{editor-CGNcK2z0.js.map → editor-Bku8e2dr.js.map} +1 -1
  28. package/dist/{editor-ddcGG42r.js → editor-CbtrPBTP.js} +5 -4
  29. package/dist/{editor-ddcGG42r.js.map → editor-CbtrPBTP.js.map} +1 -1
  30. package/dist/{editor-D4FHn5u4.js → editor-D70FYIwV.js} +2 -2
  31. package/dist/{editor-D4FHn5u4.js.map → editor-D70FYIwV.js.map} +1 -1
  32. package/dist/{editor-CdzYJozI.js → editor-Dtg8STyT.js} +5 -5
  33. package/dist/{editor-CdzYJozI.js.map → editor-Dtg8STyT.js.map} +1 -1
  34. package/dist/{editor-CgkzQJ4g.js → editor-SfVorwsP.js} +6 -6
  35. package/dist/{editor-CgkzQJ4g.js.map → editor-SfVorwsP.js.map} +1 -1
  36. package/dist/editors/hooks/index.js +1 -1
  37. package/dist/editors/index.d.ts +13 -12
  38. package/dist/editors/index.d.ts.map +1 -1
  39. package/dist/editors/index.js +2 -2
  40. package/dist/{codegen-PnsnCMkw.js → factory-CweZppg6.js} +51 -3
  41. package/dist/factory-CweZppg6.js.map +1 -0
  42. package/dist/factory-D8ZDOMP3.js +79 -0
  43. package/dist/factory-D8ZDOMP3.js.map +1 -0
  44. package/dist/{hooks-Vx4YtE1e.js → hooks-Xexr33XS.js} +1 -1
  45. package/dist/{hooks-Vx4YtE1e.js.map → hooks-Xexr33XS.js.map} +1 -1
  46. package/dist/index.d.ts +7 -2
  47. package/dist/index.d.ts.map +1 -1
  48. package/dist/index.js +13 -5
  49. package/dist/index.js.map +1 -1
  50. package/dist/{processor-module-CkuQiq7B.js → module-BWlCj_0C.js} +159 -204
  51. package/dist/module-BWlCj_0C.js.map +1 -0
  52. package/dist/{subgraph-module-CU_-umq2.js → module-BoGgbKmO.js} +111 -153
  53. package/dist/module-BoGgbKmO.js.map +1 -0
  54. package/dist/module-BoX1rWiq.d.ts +6 -0
  55. package/dist/module-BoX1rWiq.d.ts.map +1 -0
  56. package/dist/module-CG6K37P8.d.ts +6 -0
  57. package/dist/module-CG6K37P8.d.ts.map +1 -0
  58. package/dist/{app-module-BbhoykB5.js → module-CTPfENDU.js} +149 -189
  59. package/dist/module-CTPfENDU.js.map +1 -0
  60. package/dist/{module-BW12i5H3.js → module-CXIFrq-R.js} +15 -11
  61. package/dist/module-CXIFrq-R.js.map +1 -0
  62. package/dist/{vetra-package-VqptqKzx.js → module-CZLiUtDI.js} +186 -236
  63. package/dist/module-CZLiUtDI.js.map +1 -0
  64. package/dist/module-Cr-9knz_.d.ts +6 -0
  65. package/dist/module-Cr-9knz_.d.ts.map +1 -0
  66. package/dist/{document-editor-CHM7Pu4m.js → module-D0SK3Nds.js} +137 -180
  67. package/dist/module-D0SK3Nds.js.map +1 -0
  68. package/dist/module-DhhQLYnQ.d.ts +6 -0
  69. package/dist/module-DhhQLYnQ.d.ts.map +1 -0
  70. package/dist/module-J-kGIl1E.d.ts +6 -0
  71. package/dist/module-J-kGIl1E.d.ts.map +1 -0
  72. package/dist/powerhouse.manifest.d.ts +8 -5
  73. package/dist/powerhouse.manifest.d.ts.map +1 -1
  74. package/dist/powerhouse.manifest.js +19 -12
  75. package/dist/processor-module-D0lRrrpW.js +95 -0
  76. package/dist/processor-module-D0lRrrpW.js.map +1 -0
  77. package/dist/processors/codegen/index.d.ts +21322 -2
  78. package/dist/processors/codegen/index.d.ts.map +1 -0
  79. package/dist/processors/codegen/index.js +2 -2
  80. package/dist/processors/index.d.ts +4 -15
  81. package/dist/processors/index.d.ts.map +1 -1
  82. package/dist/processors/index.js +8 -81
  83. package/dist/processors/index.js.map +1 -1
  84. package/dist/processors/vetra-read-model/index.d.ts +18599 -2
  85. package/dist/processors/vetra-read-model/index.d.ts.map +1 -0
  86. package/dist/processors/vetra-read-model/index.js +2 -54
  87. package/dist/subgraph-module-B3ipwOza.js +92 -0
  88. package/dist/subgraph-module-B3ipwOza.js.map +1 -0
  89. package/dist/switchboard-JOTFVXuj.js +8 -0
  90. package/dist/switchboard-JOTFVXuj.js.map +1 -0
  91. package/dist/{useVetraDocument-DF0teXXM.js → useVetraDocument-DoAwvHVi.js} +1 -1
  92. package/dist/{useVetraDocument-DF0teXXM.js.map → useVetraDocument-DoAwvHVi.js.map} +1 -1
  93. package/dist/vetra-package-YNLxEA-U.js +100 -0
  94. package/dist/vetra-package-YNLxEA-U.js.map +1 -0
  95. package/package.json +9 -8
  96. package/dist/app-module-BbhoykB5.js.map +0 -1
  97. package/dist/codegen-PnsnCMkw.js.map +0 -1
  98. package/dist/document-editor-CHM7Pu4m.js.map +0 -1
  99. package/dist/document-models/index.d.ts.map +0 -1
  100. package/dist/editor-Bsu4yikl.js +0 -2
  101. package/dist/index-CHfOF-Et.d.ts +0 -363
  102. package/dist/index-CHfOF-Et.d.ts.map +0 -1
  103. package/dist/index-CL_CHW_Z.d.ts +0 -330
  104. package/dist/index-CL_CHW_Z.d.ts.map +0 -1
  105. package/dist/index-C_kUPMNf.d.ts +0 -298
  106. package/dist/index-C_kUPMNf.d.ts.map +0 -1
  107. package/dist/index-CxWUNzph.d.ts +0 -21319
  108. package/dist/index-CxWUNzph.d.ts.map +0 -1
  109. package/dist/index-Ofk3NYAC.d.ts +0 -18596
  110. package/dist/index-Ofk3NYAC.d.ts.map +0 -1
  111. package/dist/index-Qr_rU6VS.d.ts +0 -271
  112. package/dist/index-Qr_rU6VS.d.ts.map +0 -1
  113. package/dist/index-cBMMID-w.d.ts +0 -323
  114. package/dist/index-cBMMID-w.d.ts.map +0 -1
  115. package/dist/module-BW12i5H3.js.map +0 -1
  116. package/dist/module-XCoMwFat.js +0 -59
  117. package/dist/module-XCoMwFat.js.map +0 -1
  118. package/dist/processor-module-CkuQiq7B.js.map +0 -1
  119. package/dist/processors/vetra-read-model/index.js.map +0 -1
  120. package/dist/subgraph-module-CU_-umq2.js.map +0 -1
  121. package/dist/vetra-package-VqptqKzx.js.map +0 -1
@@ -1,54 +1,2 @@
1
- import { t as logger } from "../../logger-BLNtquAC.js";
2
- //#region processors/vetra-read-model/index.ts
3
- var VetraReadModelProcessor = class {
4
- relationalDb;
5
- constructor(relationalDb) {
6
- this.relationalDb = relationalDb;
7
- }
8
- async onOperations(operations) {
9
- logger.info(">>> VetraReadModelProcessor.onOperations()");
10
- if (operations.length === 0) return;
11
- for (const { operation, context } of operations) {
12
- if (context.documentType !== "powerhouse/package") continue;
13
- const state = context.resultingState ? JSON.parse(context.resultingState) : void 0;
14
- const getString = (val) => typeof val === "string" ? val : null;
15
- const now = /* @__PURE__ */ new Date();
16
- const operationTimestamp = new Date(parseInt(operation.timestampUtcMs, 10));
17
- await this.relationalDb.insertInto("vetra_package").values({
18
- document_id: context.documentId,
19
- name: getString(state?.name),
20
- description: getString(state?.description),
21
- category: getString(state?.category),
22
- author_name: getString(state?.author?.name),
23
- author_website: getString(state?.author?.website),
24
- keywords: state?.keywords ? JSON.stringify(state.keywords) : null,
25
- github_url: getString(state?.githubUrl),
26
- npm_url: getString(state?.npmUrl),
27
- last_operation_index: operation.index,
28
- last_operation_hash: operation.hash,
29
- last_operation_timestamp: operationTimestamp,
30
- drive_id: "",
31
- created_at: now,
32
- updated_at: now
33
- }).onConflict((oc) => oc.column("document_id").doUpdateSet({
34
- name: getString(state?.name),
35
- description: getString(state?.description),
36
- category: getString(state?.category),
37
- author_name: getString(state?.author?.name),
38
- author_website: getString(state?.author?.website),
39
- keywords: state?.keywords ? JSON.stringify(state.keywords) : null,
40
- github_url: getString(state?.githubUrl),
41
- npm_url: getString(state?.npmUrl),
42
- last_operation_index: operation.index,
43
- last_operation_hash: operation.hash,
44
- last_operation_timestamp: operationTimestamp,
45
- updated_at: now
46
- })).execute();
47
- }
48
- }
49
- async onDisconnect() {}
50
- };
51
- //#endregion
52
- export { VetraReadModelProcessor };
53
-
54
- //# sourceMappingURL=index.js.map
1
+ import { n as VetraReadModelProcessor, t as vetraReadModelFactoryBuilder } from "../../factory-D8ZDOMP3.js";
2
+ export { VetraReadModelProcessor, vetraReadModelFactoryBuilder };
@@ -0,0 +1,92 @@
1
+ import { a as utils, d as isSubgraphModuleDocument, l as assertIsSubgraphModuleDocument, t as SubgraphModule } from "./module-BoGgbKmO.js";
2
+ import { PHDocumentController, createBaseState, defaultBaseState } from "document-model";
3
+ import { useDocumentById, useDocumentsInSelectedDrive, useDocumentsInSelectedFolder, useSelectedDocument } from "@powerhousedao/reactor-browser";
4
+ //#region document-models/subgraph-module/v1/gen/controller.ts
5
+ /**
6
+ * WARNING: DO NOT EDIT
7
+ * This file is auto-generated and updated by codegen
8
+ */
9
+ const SubgraphModuleController = PHDocumentController.forDocumentModel(SubgraphModule);
10
+ //#endregion
11
+ //#region document-models/subgraph-module/v1/gen/ph-factories.ts
12
+ function defaultGlobalState() {
13
+ return {
14
+ name: "",
15
+ status: "DRAFT"
16
+ };
17
+ }
18
+ function defaultLocalState() {
19
+ return {};
20
+ }
21
+ function defaultPHState() {
22
+ return {
23
+ ...defaultBaseState(),
24
+ global: defaultGlobalState(),
25
+ local: defaultLocalState()
26
+ };
27
+ }
28
+ function createGlobalState(state) {
29
+ return {
30
+ ...defaultGlobalState(),
31
+ ...state || {}
32
+ };
33
+ }
34
+ function createLocalState(state) {
35
+ return {
36
+ ...defaultLocalState(),
37
+ ...state || {}
38
+ };
39
+ }
40
+ function createState$1(baseState, globalState, localState) {
41
+ return {
42
+ ...createBaseState(baseState?.auth, baseState?.document),
43
+ global: createGlobalState(globalState),
44
+ local: createLocalState(localState)
45
+ };
46
+ }
47
+ /**
48
+ * Creates a SubgraphModuleDocument with custom global and local state
49
+ * This properly handles the PHBaseState requirements while allowing
50
+ * document-specific state to be set.
51
+ */
52
+ function createSubgraphModuleDocument(state) {
53
+ return utils.createDocument(state ? createState$1(createBaseState(state.auth, state.document), state.global, state.local) : void 0);
54
+ }
55
+ //#endregion
56
+ //#region document-models/subgraph-module/v1/hooks.ts
57
+ /** Hook to get a SubgraphModule document by its id */
58
+ function useSubgraphModuleDocumentById(documentId) {
59
+ const [document, dispatch] = useDocumentById(documentId);
60
+ if (!isSubgraphModuleDocument(document)) return [void 0, void 0];
61
+ return [document, dispatch];
62
+ }
63
+ /** Hook to get the selected SubgraphModule document */
64
+ function useSelectedSubgraphModuleDocument() {
65
+ const [document, dispatch] = useSelectedDocument();
66
+ assertIsSubgraphModuleDocument(document);
67
+ return [document, dispatch];
68
+ }
69
+ /** Hook to get all SubgraphModule documents in the selected drive */
70
+ function useSubgraphModuleDocumentsInSelectedDrive() {
71
+ return useDocumentsInSelectedDrive()?.filter(isSubgraphModuleDocument);
72
+ }
73
+ /** Hook to get all SubgraphModule documents in the selected folder */
74
+ function useSubgraphModuleDocumentsInSelectedFolder() {
75
+ return useDocumentsInSelectedFolder()?.filter(isSubgraphModuleDocument);
76
+ }
77
+ //#endregion
78
+ //#region document-models/subgraph-module/upgrades/versions.ts
79
+ const supportedVersions = [1];
80
+ const latestVersion = supportedVersions[0];
81
+ //#endregion
82
+ //#region document-models/subgraph-module/upgrades/upgrade-manifest.ts
83
+ const subgraphModuleUpgradeManifest = {
84
+ documentType: "powerhouse/subgraph",
85
+ latestVersion,
86
+ supportedVersions,
87
+ upgrades: {}
88
+ };
89
+ //#endregion
90
+ export { useSubgraphModuleDocumentById as a, createState$1 as c, defaultLocalState as d, defaultPHState as f, useSelectedSubgraphModuleDocument as i, createSubgraphModuleDocument as l, latestVersion as n, useSubgraphModuleDocumentsInSelectedDrive as o, SubgraphModuleController as p, supportedVersions as r, useSubgraphModuleDocumentsInSelectedFolder as s, subgraphModuleUpgradeManifest as t, defaultGlobalState as u };
91
+
92
+ //# sourceMappingURL=subgraph-module-B3ipwOza.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"subgraph-module-B3ipwOza.js","names":["createState"],"sources":["../document-models/subgraph-module/v1/gen/controller.ts","../document-models/subgraph-module/v1/gen/ph-factories.ts","../document-models/subgraph-module/v1/hooks.ts","../document-models/subgraph-module/upgrades/versions.ts","../document-models/subgraph-module/upgrades/upgrade-manifest.ts"],"sourcesContent":["/**\n * WARNING: DO NOT EDIT\n * This file is auto-generated and updated by codegen\n */\nimport { PHDocumentController } from \"document-model\";\nimport { SubgraphModule } from \"../module.js\";\nimport type { SubgraphModuleAction, SubgraphModulePHState } from \"./types.js\";\n\nexport const SubgraphModuleController = PHDocumentController.forDocumentModel<\n SubgraphModulePHState,\n SubgraphModuleAction\n>(SubgraphModule);\n","/**\n * WARNING: DO NOT EDIT\n * This file is auto-generated and updated by codegen\n * Factory methods for creating SubgraphModuleDocument instances\n */\nimport type { PHAuthState, PHBaseState, PHDocumentState } from \"document-model\";\nimport { createBaseState, defaultBaseState } from \"document-model\";\nimport type {\n SubgraphModuleDocument,\n SubgraphModuleGlobalState,\n SubgraphModuleLocalState,\n SubgraphModulePHState,\n} from \"./types.js\";\nimport { utils } from \"./utils.js\";\n\nexport function defaultGlobalState(): SubgraphModuleGlobalState {\n return {\n name: \"\",\n status: \"DRAFT\",\n };\n}\n\nexport function defaultLocalState(): SubgraphModuleLocalState {\n return {};\n}\n\nexport function defaultPHState(): SubgraphModulePHState {\n return {\n ...defaultBaseState(),\n global: defaultGlobalState(),\n local: defaultLocalState(),\n };\n}\n\nexport function createGlobalState(\n state?: Partial<SubgraphModuleGlobalState>,\n): SubgraphModuleGlobalState {\n return {\n ...defaultGlobalState(),\n ...(state || {}),\n };\n}\n\nexport function createLocalState(\n state?: Partial<SubgraphModuleLocalState>,\n): SubgraphModuleLocalState {\n return {\n ...defaultLocalState(),\n ...(state || {}),\n } as SubgraphModuleLocalState;\n}\n\nexport function createState(\n baseState?: Partial<PHBaseState>,\n globalState?: Partial<SubgraphModuleGlobalState>,\n localState?: Partial<SubgraphModuleLocalState>,\n): SubgraphModulePHState {\n return {\n ...createBaseState(baseState?.auth, baseState?.document),\n global: createGlobalState(globalState),\n local: createLocalState(localState),\n };\n}\n\n/**\n * Creates a SubgraphModuleDocument with custom global and local state\n * This properly handles the PHBaseState requirements while allowing\n * document-specific state to be set.\n */\nexport function createSubgraphModuleDocument(\n state?: Partial<{\n auth?: Partial<PHAuthState>;\n document?: Partial<PHDocumentState>;\n global?: Partial<SubgraphModuleGlobalState>;\n local?: Partial<SubgraphModuleLocalState>;\n }>,\n): SubgraphModuleDocument {\n const document = utils.createDocument(\n state\n ? createState(\n createBaseState(state.auth, state.document),\n state.global,\n state.local,\n )\n : undefined,\n );\n\n return document;\n}\n","/**\n * WARNING: DO NOT EDIT\n * This file is auto-generated and updated by codegen\n */\nimport type { DocumentDispatch } from \"@powerhousedao/reactor-browser\";\nimport {\n useDocumentById,\n useDocumentsInSelectedDrive,\n useDocumentsInSelectedFolder,\n useSelectedDocument,\n} from \"@powerhousedao/reactor-browser\";\nimport type {\n SubgraphModuleAction,\n SubgraphModuleDocument,\n} from \"document-models/subgraph-module/v1\";\nimport {\n assertIsSubgraphModuleDocument,\n isSubgraphModuleDocument,\n} from \"./gen/document-schema.js\";\n\n/** Hook to get a SubgraphModule document by its id */\nexport function useSubgraphModuleDocumentById(\n documentId: string | null | undefined,\n):\n | [SubgraphModuleDocument, DocumentDispatch<SubgraphModuleAction>]\n | [undefined, undefined] {\n const [document, dispatch] = useDocumentById(documentId);\n if (!isSubgraphModuleDocument(document)) return [undefined, undefined];\n return [document, dispatch];\n}\n\n/** Hook to get the selected SubgraphModule document */\nexport function useSelectedSubgraphModuleDocument(): [\n SubgraphModuleDocument,\n DocumentDispatch<SubgraphModuleAction>,\n] {\n const [document, dispatch] = useSelectedDocument();\n\n assertIsSubgraphModuleDocument(document);\n return [document, dispatch] as const;\n}\n\n/** Hook to get all SubgraphModule documents in the selected drive */\nexport function useSubgraphModuleDocumentsInSelectedDrive() {\n const documentsInSelectedDrive = useDocumentsInSelectedDrive();\n return documentsInSelectedDrive?.filter(isSubgraphModuleDocument);\n}\n\n/** Hook to get all SubgraphModule documents in the selected folder */\nexport function useSubgraphModuleDocumentsInSelectedFolder() {\n const documentsInSelectedFolder = useDocumentsInSelectedFolder();\n return documentsInSelectedFolder?.filter(isSubgraphModuleDocument);\n}\n","export const supportedVersions = [1] as const;\n\nexport const latestVersion = supportedVersions[0];\n","/**\n * WARNING: DO NOT EDIT\n * This file is auto-generated and updated by codegen\n */\nimport type { UpgradeManifest } from \"document-model\";\nimport { latestVersion, supportedVersions } from \"./versions.js\";\n\nexport const subgraphModuleUpgradeManifest: UpgradeManifest<\n typeof supportedVersions\n> = {\n documentType: \"powerhouse/subgraph\",\n latestVersion,\n supportedVersions,\n upgrades: {},\n};\n"],"mappings":";;;;;;;;AAQA,MAAa,2BAA2B,qBAAqB,iBAG3D,eAAe;;;ACIjB,SAAgB,qBAAgD;AAC9D,QAAO;EACL,MAAM;EACN,QAAQ;EACT;;AAGH,SAAgB,oBAA8C;AAC5D,QAAO,EAAE;;AAGX,SAAgB,iBAAwC;AACtD,QAAO;EACL,GAAG,kBAAkB;EACrB,QAAQ,oBAAoB;EAC5B,OAAO,mBAAmB;EAC3B;;AAGH,SAAgB,kBACd,OAC2B;AAC3B,QAAO;EACL,GAAG,oBAAoB;EACvB,GAAI,SAAS,EAAE;EAChB;;AAGH,SAAgB,iBACd,OAC0B;AAC1B,QAAO;EACL,GAAG,mBAAmB;EACtB,GAAI,SAAS,EAAE;EAChB;;AAGH,SAAgBA,cACd,WACA,aACA,YACuB;AACvB,QAAO;EACL,GAAG,gBAAgB,WAAW,MAAM,WAAW,SAAS;EACxD,QAAQ,kBAAkB,YAAY;EACtC,OAAO,iBAAiB,WAAW;EACpC;;;;;;;AAQH,SAAgB,6BACd,OAMwB;AAWxB,QAViB,MAAM,eACrB,QACIA,cACE,gBAAgB,MAAM,MAAM,MAAM,SAAS,EAC3C,MAAM,QACN,MAAM,MACP,GACD,KAAA,EACL;;;;;AChEH,SAAgB,8BACd,YAGyB;CACzB,MAAM,CAAC,UAAU,YAAY,gBAAgB,WAAW;AACxD,KAAI,CAAC,yBAAyB,SAAS,CAAE,QAAO,CAAC,KAAA,GAAW,KAAA,EAAU;AACtE,QAAO,CAAC,UAAU,SAAS;;;AAI7B,SAAgB,oCAGd;CACA,MAAM,CAAC,UAAU,YAAY,qBAAqB;AAElD,gCAA+B,SAAS;AACxC,QAAO,CAAC,UAAU,SAAS;;;AAI7B,SAAgB,4CAA4C;AAE1D,QADiC,6BAA6B,EAC7B,OAAO,yBAAyB;;;AAInE,SAAgB,6CAA6C;AAE3D,QADkC,8BAA8B,EAC9B,OAAO,yBAAyB;;;;ACnDpE,MAAa,oBAAoB,CAAC,EAAE;AAEpC,MAAa,gBAAgB,kBAAkB;;;ACK/C,MAAa,gCAET;CACF,cAAc;CACd;CACA;CACA,UAAU,EAAE;CACb"}
@@ -0,0 +1,8 @@
1
+ import { t as codegenFactoryBuilder } from "./factory-CweZppg6.js";
2
+ import { t as vetraReadModelFactoryBuilder } from "./factory-D8ZDOMP3.js";
3
+ //#region processors/switchboard.ts
4
+ const processorFactoryBuilders = [vetraReadModelFactoryBuilder, codegenFactoryBuilder];
5
+ //#endregion
6
+ export { processorFactoryBuilders };
7
+
8
+ //# sourceMappingURL=switchboard-JOTFVXuj.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"switchboard-JOTFVXuj.js","names":[],"sources":["../processors/switchboard.ts"],"sourcesContent":["/**\n * WARNING: DO NOT EDIT\n * This file is auto-generated and updated by codegen\n */\nimport type { ProcessorFactoryBuilder } from \"@powerhousedao/reactor-browser\";\nimport { codegenFactoryBuilder } from \"./codegen/factory.js\";\nimport { vetraReadModelFactoryBuilder } from \"./vetra-read-model/factory.js\";\n\nexport const processorFactoryBuilders: ProcessorFactoryBuilder[] = [\n vetraReadModelFactoryBuilder,\n codegenFactoryBuilder,\n];\n"],"mappings":";;;AAQA,MAAa,2BAAsD,CACjE,8BACA,sBACD"}
@@ -27,4 +27,4 @@ function useSelectedDriveVetraPackage() {
27
27
  //#endregion
28
28
  export { useSelectedProcessorModuleDocument as n, useSelectedSubgraphModuleDocument as r, useSelectedDriveVetraPackage as t };
29
29
 
30
- //# sourceMappingURL=useVetraDocument-DF0teXXM.js.map
30
+ //# sourceMappingURL=useVetraDocument-DoAwvHVi.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useVetraDocument-DF0teXXM.js","names":[],"sources":["../editors/hooks/useVetraDocument.ts"],"sourcesContent":["import {\n useDocumentOfType,\n useSelectedDocumentId,\n useSelectedDocumentOfType,\n useSelectedDrive,\n} from \"@powerhousedao/reactor-browser\";\nimport { isFileNode } from \"@powerhousedao/shared/document-drive\";\nimport type {\n AppModuleAction,\n AppModuleDocument,\n} from \"../../document-models/app-module/index.js\";\nimport {\n type DocumentEditorAction,\n type DocumentEditorDocument,\n} from \"../../document-models/document-editor/index.js\";\nimport type {\n ProcessorModuleAction,\n ProcessorModuleDocument,\n} from \"../../document-models/processor-module/index.js\";\nimport type {\n SubgraphModuleAction,\n SubgraphModuleDocument,\n} from \"../../document-models/subgraph-module/index.js\";\nimport type {\n VetraPackageAction,\n VetraPackageDocument,\n} from \"../../document-models/vetra-package/index.js\";\n\nconst VETRA_PACKAGE_DOCUMENT_TYPE = \"powerhouse/package\";\nconst DOCUMENT_EDITOR_DOCUMENT_TYPE = \"powerhouse/document-editor\";\nconst SUBGRAPH_MODULE_DOCUMENT_TYPE = \"powerhouse/subgraph\";\nconst PROCESSOR_MODULE_DOCUMENT_TYPE = \"powerhouse/processor\";\n\nexport function useAppModuleDocument(documentId: string | undefined | null) {\n return useDocumentOfType<AppModuleDocument, AppModuleAction>(\n documentId,\n \"powerhouse/app\",\n );\n}\n\nexport function useSelectedAppModuleDocument() {\n const documentId = useSelectedDocumentId();\n return useAppModuleDocument(documentId);\n}\n\nexport function useDocumentEditorDocument(\n documentId: string | undefined | null,\n) {\n return useDocumentOfType<DocumentEditorDocument, DocumentEditorAction>(\n documentId,\n DOCUMENT_EDITOR_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedDocumentEditorDocument() {\n const documentId = useSelectedDocumentId();\n return useDocumentEditorDocument(documentId);\n}\n\nexport function useProcessorModuleDocument(\n documentId: string | undefined | null,\n) {\n return useDocumentOfType<ProcessorModuleDocument, ProcessorModuleAction>(\n documentId,\n PROCESSOR_MODULE_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedProcessorModuleDocument() {\n const documentId = useSelectedDocumentId();\n return useProcessorModuleDocument(documentId);\n}\n\nexport function useSubgraphModuleDocument(\n documentId: string | undefined | null,\n) {\n return useDocumentOfType<SubgraphModuleDocument, SubgraphModuleAction>(\n documentId,\n SUBGRAPH_MODULE_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedSubgraphModuleDocument() {\n const documentId = useSelectedDocumentId();\n return useSubgraphModuleDocument(documentId);\n}\n\nexport function useVetraPackageDocument(documentId: string | undefined | null) {\n return useDocumentOfType<VetraPackageDocument, VetraPackageAction>(\n documentId,\n VETRA_PACKAGE_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedVetraPackageDocument() {\n return useSelectedDocumentOfType<VetraPackageDocument, VetraPackageAction>(\n VETRA_PACKAGE_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedDriveVetraPackage() {\n const [selectedDrive] = useSelectedDrive();\n const documentId = selectedDrive.state.global.nodes.find(\n (node) =>\n isFileNode(node) && node.documentType === VETRA_PACKAGE_DOCUMENT_TYPE,\n )?.id;\n\n return useVetraPackageDocument(documentId);\n}\n"],"mappings":";;;AA4BA,MAAM,8BAA8B;AAEpC,MAAM,gCAAgC;AACtC,MAAM,iCAAiC;AA4BvC,SAAgB,2BACd,YACA;AACA,QAAO,kBACL,YACA,+BACD;;AAGH,SAAgB,qCAAqC;AAEnD,QAAO,2BADY,uBAAuB,CACG;;AAG/C,SAAgB,0BACd,YACA;AACA,QAAO,kBACL,YACA,8BACD;;AAGH,SAAgB,oCAAoC;AAElD,QAAO,0BADY,uBAAuB,CACE;;AAG9C,SAAgB,wBAAwB,YAAuC;AAC7E,QAAO,kBACL,YACA,4BACD;;AASH,SAAgB,+BAA+B;CAC7C,MAAM,CAAC,iBAAiB,kBAAkB;CAC1C,MAAM,aAAa,cAAc,MAAM,OAAO,MAAM,MACjD,SACC,WAAW,KAAK,IAAI,KAAK,iBAAiB,4BAC7C,EAAE;AAEH,QAAO,wBAAwB,WAAW"}
1
+ {"version":3,"file":"useVetraDocument-DoAwvHVi.js","names":[],"sources":["../editors/hooks/useVetraDocument.ts"],"sourcesContent":["import {\n useDocumentOfType,\n useSelectedDocumentId,\n useSelectedDocumentOfType,\n useSelectedDrive,\n} from \"@powerhousedao/reactor-browser\";\nimport { isFileNode } from \"@powerhousedao/shared/document-drive\";\nimport type {\n AppModuleAction,\n AppModuleDocument,\n} from \"../../document-models/app-module/index.js\";\nimport {\n type DocumentEditorAction,\n type DocumentEditorDocument,\n} from \"../../document-models/document-editor/index.js\";\nimport type {\n ProcessorModuleAction,\n ProcessorModuleDocument,\n} from \"../../document-models/processor-module/index.js\";\nimport type {\n SubgraphModuleAction,\n SubgraphModuleDocument,\n} from \"../../document-models/subgraph-module/index.js\";\nimport type {\n VetraPackageAction,\n VetraPackageDocument,\n} from \"../../document-models/vetra-package/index.js\";\n\nconst VETRA_PACKAGE_DOCUMENT_TYPE = \"powerhouse/package\";\nconst DOCUMENT_EDITOR_DOCUMENT_TYPE = \"powerhouse/document-editor\";\nconst SUBGRAPH_MODULE_DOCUMENT_TYPE = \"powerhouse/subgraph\";\nconst PROCESSOR_MODULE_DOCUMENT_TYPE = \"powerhouse/processor\";\n\nexport function useAppModuleDocument(documentId: string | undefined | null) {\n return useDocumentOfType<AppModuleDocument, AppModuleAction>(\n documentId,\n \"powerhouse/app\",\n );\n}\n\nexport function useSelectedAppModuleDocument() {\n const documentId = useSelectedDocumentId();\n return useAppModuleDocument(documentId);\n}\n\nexport function useDocumentEditorDocument(\n documentId: string | undefined | null,\n) {\n return useDocumentOfType<DocumentEditorDocument, DocumentEditorAction>(\n documentId,\n DOCUMENT_EDITOR_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedDocumentEditorDocument() {\n const documentId = useSelectedDocumentId();\n return useDocumentEditorDocument(documentId);\n}\n\nexport function useProcessorModuleDocument(\n documentId: string | undefined | null,\n) {\n return useDocumentOfType<ProcessorModuleDocument, ProcessorModuleAction>(\n documentId,\n PROCESSOR_MODULE_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedProcessorModuleDocument() {\n const documentId = useSelectedDocumentId();\n return useProcessorModuleDocument(documentId);\n}\n\nexport function useSubgraphModuleDocument(\n documentId: string | undefined | null,\n) {\n return useDocumentOfType<SubgraphModuleDocument, SubgraphModuleAction>(\n documentId,\n SUBGRAPH_MODULE_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedSubgraphModuleDocument() {\n const documentId = useSelectedDocumentId();\n return useSubgraphModuleDocument(documentId);\n}\n\nexport function useVetraPackageDocument(documentId: string | undefined | null) {\n return useDocumentOfType<VetraPackageDocument, VetraPackageAction>(\n documentId,\n VETRA_PACKAGE_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedVetraPackageDocument() {\n return useSelectedDocumentOfType<VetraPackageDocument, VetraPackageAction>(\n VETRA_PACKAGE_DOCUMENT_TYPE,\n );\n}\n\nexport function useSelectedDriveVetraPackage() {\n const [selectedDrive] = useSelectedDrive();\n const documentId = selectedDrive.state.global.nodes.find(\n (node) =>\n isFileNode(node) && node.documentType === VETRA_PACKAGE_DOCUMENT_TYPE,\n )?.id;\n\n return useVetraPackageDocument(documentId);\n}\n"],"mappings":";;;AA4BA,MAAM,8BAA8B;AAEpC,MAAM,gCAAgC;AACtC,MAAM,iCAAiC;AA4BvC,SAAgB,2BACd,YACA;AACA,QAAO,kBACL,YACA,+BACD;;AAGH,SAAgB,qCAAqC;AAEnD,QAAO,2BADY,uBAAuB,CACG;;AAG/C,SAAgB,0BACd,YACA;AACA,QAAO,kBACL,YACA,8BACD;;AAGH,SAAgB,oCAAoC;AAElD,QAAO,0BADY,uBAAuB,CACE;;AAG9C,SAAgB,wBAAwB,YAAuC;AAC7E,QAAO,kBACL,YACA,4BACD;;AASH,SAAgB,+BAA+B;CAC7C,MAAM,CAAC,iBAAiB,kBAAkB;CAC1C,MAAM,aAAa,cAAc,MAAM,OAAO,MAAM,MACjD,SACC,WAAW,KAAK,IAAI,KAAK,iBAAiB,4BAC7C,EAAE;AAEH,QAAO,wBAAwB,WAAW"}
@@ -0,0 +1,100 @@
1
+ import { a as utils, d as isVetraPackageDocument, l as assertIsVetraPackageDocument, t as VetraPackage } from "./module-CZLiUtDI.js";
2
+ import { PHDocumentController, createBaseState, defaultBaseState } from "document-model";
3
+ import { useDocumentById, useDocumentsInSelectedDrive, useDocumentsInSelectedFolder, useSelectedDocument } from "@powerhousedao/reactor-browser";
4
+ //#region document-models/vetra-package/v1/gen/controller.ts
5
+ /**
6
+ * WARNING: DO NOT EDIT
7
+ * This file is auto-generated and updated by codegen
8
+ */
9
+ const VetraPackageController = PHDocumentController.forDocumentModel(VetraPackage);
10
+ //#endregion
11
+ //#region document-models/vetra-package/v1/gen/ph-factories.ts
12
+ function defaultGlobalState() {
13
+ return {
14
+ name: null,
15
+ description: null,
16
+ category: null,
17
+ author: {
18
+ name: null,
19
+ website: null
20
+ },
21
+ keywords: [],
22
+ githubUrl: null,
23
+ npmUrl: null
24
+ };
25
+ }
26
+ function defaultLocalState() {
27
+ return {};
28
+ }
29
+ function defaultPHState() {
30
+ return {
31
+ ...defaultBaseState(),
32
+ global: defaultGlobalState(),
33
+ local: defaultLocalState()
34
+ };
35
+ }
36
+ function createGlobalState(state) {
37
+ return {
38
+ ...defaultGlobalState(),
39
+ ...state || {}
40
+ };
41
+ }
42
+ function createLocalState(state) {
43
+ return {
44
+ ...defaultLocalState(),
45
+ ...state || {}
46
+ };
47
+ }
48
+ function createState$1(baseState, globalState, localState) {
49
+ return {
50
+ ...createBaseState(baseState?.auth, baseState?.document),
51
+ global: createGlobalState(globalState),
52
+ local: createLocalState(localState)
53
+ };
54
+ }
55
+ /**
56
+ * Creates a VetraPackageDocument with custom global and local state
57
+ * This properly handles the PHBaseState requirements while allowing
58
+ * document-specific state to be set.
59
+ */
60
+ function createVetraPackageDocument(state) {
61
+ return utils.createDocument(state ? createState$1(createBaseState(state.auth, state.document), state.global, state.local) : void 0);
62
+ }
63
+ //#endregion
64
+ //#region document-models/vetra-package/v1/hooks.ts
65
+ /** Hook to get a VetraPackage document by its id */
66
+ function useVetraPackageDocumentById(documentId) {
67
+ const [document, dispatch] = useDocumentById(documentId);
68
+ if (!isVetraPackageDocument(document)) return [void 0, void 0];
69
+ return [document, dispatch];
70
+ }
71
+ /** Hook to get the selected VetraPackage document */
72
+ function useSelectedVetraPackageDocument() {
73
+ const [document, dispatch] = useSelectedDocument();
74
+ assertIsVetraPackageDocument(document);
75
+ return [document, dispatch];
76
+ }
77
+ /** Hook to get all VetraPackage documents in the selected drive */
78
+ function useVetraPackageDocumentsInSelectedDrive() {
79
+ return useDocumentsInSelectedDrive()?.filter(isVetraPackageDocument);
80
+ }
81
+ /** Hook to get all VetraPackage documents in the selected folder */
82
+ function useVetraPackageDocumentsInSelectedFolder() {
83
+ return useDocumentsInSelectedFolder()?.filter(isVetraPackageDocument);
84
+ }
85
+ //#endregion
86
+ //#region document-models/vetra-package/upgrades/versions.ts
87
+ const supportedVersions = [1];
88
+ const latestVersion = supportedVersions[0];
89
+ //#endregion
90
+ //#region document-models/vetra-package/upgrades/upgrade-manifest.ts
91
+ const vetraPackageUpgradeManifest = {
92
+ documentType: "powerhouse/package",
93
+ latestVersion,
94
+ supportedVersions,
95
+ upgrades: {}
96
+ };
97
+ //#endregion
98
+ export { useVetraPackageDocumentById as a, createState$1 as c, defaultLocalState as d, defaultPHState as f, useSelectedVetraPackageDocument as i, createVetraPackageDocument as l, latestVersion as n, useVetraPackageDocumentsInSelectedDrive as o, VetraPackageController as p, supportedVersions as r, useVetraPackageDocumentsInSelectedFolder as s, vetraPackageUpgradeManifest as t, defaultGlobalState as u };
99
+
100
+ //# sourceMappingURL=vetra-package-YNLxEA-U.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vetra-package-YNLxEA-U.js","names":["createState"],"sources":["../document-models/vetra-package/v1/gen/controller.ts","../document-models/vetra-package/v1/gen/ph-factories.ts","../document-models/vetra-package/v1/hooks.ts","../document-models/vetra-package/upgrades/versions.ts","../document-models/vetra-package/upgrades/upgrade-manifest.ts"],"sourcesContent":["/**\n * WARNING: DO NOT EDIT\n * This file is auto-generated and updated by codegen\n */\nimport { PHDocumentController } from \"document-model\";\nimport { VetraPackage } from \"../module.js\";\nimport type { VetraPackageAction, VetraPackagePHState } from \"./types.js\";\n\nexport const VetraPackageController = PHDocumentController.forDocumentModel<\n VetraPackagePHState,\n VetraPackageAction\n>(VetraPackage);\n","/**\n * WARNING: DO NOT EDIT\n * This file is auto-generated and updated by codegen\n * Factory methods for creating VetraPackageDocument instances\n */\nimport type { PHAuthState, PHBaseState, PHDocumentState } from \"document-model\";\nimport { createBaseState, defaultBaseState } from \"document-model\";\nimport type {\n VetraPackageDocument,\n VetraPackageGlobalState,\n VetraPackageLocalState,\n VetraPackagePHState,\n} from \"./types.js\";\nimport { utils } from \"./utils.js\";\n\nexport function defaultGlobalState(): VetraPackageGlobalState {\n return {\n name: null,\n description: null,\n category: null,\n author: {\n name: null,\n website: null,\n },\n keywords: [],\n githubUrl: null,\n npmUrl: null,\n };\n}\n\nexport function defaultLocalState(): VetraPackageLocalState {\n return {};\n}\n\nexport function defaultPHState(): VetraPackagePHState {\n return {\n ...defaultBaseState(),\n global: defaultGlobalState(),\n local: defaultLocalState(),\n };\n}\n\nexport function createGlobalState(\n state?: Partial<VetraPackageGlobalState>,\n): VetraPackageGlobalState {\n return {\n ...defaultGlobalState(),\n ...(state || {}),\n };\n}\n\nexport function createLocalState(\n state?: Partial<VetraPackageLocalState>,\n): VetraPackageLocalState {\n return {\n ...defaultLocalState(),\n ...(state || {}),\n } as VetraPackageLocalState;\n}\n\nexport function createState(\n baseState?: Partial<PHBaseState>,\n globalState?: Partial<VetraPackageGlobalState>,\n localState?: Partial<VetraPackageLocalState>,\n): VetraPackagePHState {\n return {\n ...createBaseState(baseState?.auth, baseState?.document),\n global: createGlobalState(globalState),\n local: createLocalState(localState),\n };\n}\n\n/**\n * Creates a VetraPackageDocument with custom global and local state\n * This properly handles the PHBaseState requirements while allowing\n * document-specific state to be set.\n */\nexport function createVetraPackageDocument(\n state?: Partial<{\n auth?: Partial<PHAuthState>;\n document?: Partial<PHDocumentState>;\n global?: Partial<VetraPackageGlobalState>;\n local?: Partial<VetraPackageLocalState>;\n }>,\n): VetraPackageDocument {\n const document = utils.createDocument(\n state\n ? createState(\n createBaseState(state.auth, state.document),\n state.global,\n state.local,\n )\n : undefined,\n );\n\n return document;\n}\n","/**\n * WARNING: DO NOT EDIT\n * This file is auto-generated and updated by codegen\n */\nimport type { DocumentDispatch } from \"@powerhousedao/reactor-browser\";\nimport {\n useDocumentById,\n useDocumentsInSelectedDrive,\n useDocumentsInSelectedFolder,\n useSelectedDocument,\n} from \"@powerhousedao/reactor-browser\";\nimport type {\n VetraPackageAction,\n VetraPackageDocument,\n} from \"document-models/vetra-package/v1\";\nimport {\n assertIsVetraPackageDocument,\n isVetraPackageDocument,\n} from \"./gen/document-schema.js\";\n\n/** Hook to get a VetraPackage document by its id */\nexport function useVetraPackageDocumentById(\n documentId: string | null | undefined,\n):\n | [VetraPackageDocument, DocumentDispatch<VetraPackageAction>]\n | [undefined, undefined] {\n const [document, dispatch] = useDocumentById(documentId);\n if (!isVetraPackageDocument(document)) return [undefined, undefined];\n return [document, dispatch];\n}\n\n/** Hook to get the selected VetraPackage document */\nexport function useSelectedVetraPackageDocument(): [\n VetraPackageDocument,\n DocumentDispatch<VetraPackageAction>,\n] {\n const [document, dispatch] = useSelectedDocument();\n\n assertIsVetraPackageDocument(document);\n return [document, dispatch] as const;\n}\n\n/** Hook to get all VetraPackage documents in the selected drive */\nexport function useVetraPackageDocumentsInSelectedDrive() {\n const documentsInSelectedDrive = useDocumentsInSelectedDrive();\n return documentsInSelectedDrive?.filter(isVetraPackageDocument);\n}\n\n/** Hook to get all VetraPackage documents in the selected folder */\nexport function useVetraPackageDocumentsInSelectedFolder() {\n const documentsInSelectedFolder = useDocumentsInSelectedFolder();\n return documentsInSelectedFolder?.filter(isVetraPackageDocument);\n}\n","export const supportedVersions = [1] as const;\n\nexport const latestVersion = supportedVersions[0];\n","/**\n * WARNING: DO NOT EDIT\n * This file is auto-generated and updated by codegen\n */\nimport type { UpgradeManifest } from \"document-model\";\nimport { latestVersion, supportedVersions } from \"./versions.js\";\n\nexport const vetraPackageUpgradeManifest: UpgradeManifest<\n typeof supportedVersions\n> = {\n documentType: \"powerhouse/package\",\n latestVersion,\n supportedVersions,\n upgrades: {},\n};\n"],"mappings":";;;;;;;;AAQA,MAAa,yBAAyB,qBAAqB,iBAGzD,aAAa;;;ACIf,SAAgB,qBAA8C;AAC5D,QAAO;EACL,MAAM;EACN,aAAa;EACb,UAAU;EACV,QAAQ;GACN,MAAM;GACN,SAAS;GACV;EACD,UAAU,EAAE;EACZ,WAAW;EACX,QAAQ;EACT;;AAGH,SAAgB,oBAA4C;AAC1D,QAAO,EAAE;;AAGX,SAAgB,iBAAsC;AACpD,QAAO;EACL,GAAG,kBAAkB;EACrB,QAAQ,oBAAoB;EAC5B,OAAO,mBAAmB;EAC3B;;AAGH,SAAgB,kBACd,OACyB;AACzB,QAAO;EACL,GAAG,oBAAoB;EACvB,GAAI,SAAS,EAAE;EAChB;;AAGH,SAAgB,iBACd,OACwB;AACxB,QAAO;EACL,GAAG,mBAAmB;EACtB,GAAI,SAAS,EAAE;EAChB;;AAGH,SAAgBA,cACd,WACA,aACA,YACqB;AACrB,QAAO;EACL,GAAG,gBAAgB,WAAW,MAAM,WAAW,SAAS;EACxD,QAAQ,kBAAkB,YAAY;EACtC,OAAO,iBAAiB,WAAW;EACpC;;;;;;;AAQH,SAAgB,2BACd,OAMsB;AAWtB,QAViB,MAAM,eACrB,QACIA,cACE,gBAAgB,MAAM,MAAM,MAAM,SAAS,EAC3C,MAAM,QACN,MAAM,MACP,GACD,KAAA,EACL;;;;;ACxEH,SAAgB,4BACd,YAGyB;CACzB,MAAM,CAAC,UAAU,YAAY,gBAAgB,WAAW;AACxD,KAAI,CAAC,uBAAuB,SAAS,CAAE,QAAO,CAAC,KAAA,GAAW,KAAA,EAAU;AACpE,QAAO,CAAC,UAAU,SAAS;;;AAI7B,SAAgB,kCAGd;CACA,MAAM,CAAC,UAAU,YAAY,qBAAqB;AAElD,8BAA6B,SAAS;AACtC,QAAO,CAAC,UAAU,SAAS;;;AAI7B,SAAgB,0CAA0C;AAExD,QADiC,6BAA6B,EAC7B,OAAO,uBAAuB;;;AAIjE,SAAgB,2CAA2C;AAEzD,QADkC,8BAA8B,EAC9B,OAAO,uBAAuB;;;;ACnDlE,MAAa,oBAAoB,CAAC,EAAE;AAEpC,MAAa,gBAAgB,kBAAkB;;;ACK/C,MAAa,8BAET;CACF,cAAc;CACd;CACA;CACA,UAAU,EAAE;CACb"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@powerhousedao/vetra",
3
- "version": "6.0.0-dev.249",
3
+ "version": "6.0.0-dev.250",
4
4
  "license": "AGPL-3.0-only",
5
5
  "type": "module",
6
6
  "sideEffects": false,
@@ -47,12 +47,12 @@
47
47
  "change-case": "5.4.4",
48
48
  "react": "19.2.6",
49
49
  "zod": "4.3.6",
50
- "@powerhousedao/codegen": "6.0.0-dev.249",
51
- "@powerhousedao/config": "6.0.0-dev.249",
52
- "@powerhousedao/design-system": "6.0.0-dev.249",
53
- "@powerhousedao/reactor-browser": "6.0.0-dev.249",
54
- "@powerhousedao/shared": "6.0.0-dev.249",
55
- "document-model": "6.0.0-dev.249"
50
+ "@powerhousedao/codegen": "6.0.0-dev.250",
51
+ "@powerhousedao/config": "6.0.0-dev.250",
52
+ "@powerhousedao/design-system": "6.0.0-dev.250",
53
+ "@powerhousedao/reactor-browser": "6.0.0-dev.250",
54
+ "@powerhousedao/shared": "6.0.0-dev.250",
55
+ "document-model": "6.0.0-dev.250"
56
56
  },
57
57
  "devDependencies": {
58
58
  "@tailwindcss/cli": "4.2.2",
@@ -69,8 +69,9 @@
69
69
  "ts-morph": "27.0.2",
70
70
  "tsdown": "0.21.1",
71
71
  "vite": "8.0.8",
72
+ "vite-tsconfig-paths": "6.1.1",
72
73
  "vitest": "4.1.1",
73
- "@powerhousedao/builder-tools": "6.0.0-dev.249"
74
+ "@powerhousedao/builder-tools": "6.0.0-dev.250"
74
75
  },
75
76
  "description": "",
76
77
  "scripts": {
@@ -1 +0,0 @@
1
- {"version":3,"file":"app-module-BbhoykB5.js","names":["z","utils","createState","utils","baseOperationsActions","dndOperationsActions","genUtils","customUtils"],"sources":["../document-models/app-module/gen/document-model.ts","../document-models/app-module/gen/schema/zod.ts","../document-models/app-module/gen/base-operations/creators.ts","../document-models/app-module/gen/dnd-operations/creators.ts","../document-models/app-module/gen/document-type.ts","../document-models/app-module/gen/document-schema.ts","../document-models/app-module/src/reducers/base-operations.ts","../document-models/app-module/src/reducers/dnd-operations.ts","../document-models/app-module/gen/reducer.ts","../document-models/app-module/gen/utils.ts","../document-models/app-module/gen/ph-factories.ts","../document-models/app-module/src/utils.ts","../document-models/app-module/hooks.ts","../document-models/app-module/actions.ts","../document-models/app-module/utils.ts"],"sourcesContent":["import type { DocumentModelGlobalState } from \"@powerhousedao/shared/document-model\";\n\nexport const documentModel: DocumentModelGlobalState = {\n id: \"powerhouse/app\",\n name: \"App Module\",\n extension: \".phdm\",\n description: \"\",\n author: {\n name: \"Powerhouse\",\n website: \"https://powerhouse.inc\",\n },\n specifications: [\n {\n version: 1,\n changeLog: [],\n state: {\n global: {\n schema:\n \"type AppModuleState {\\n name: String!\\n status: StatusType!\\n allowedDocumentTypes: [String!]\\n isDragAndDropEnabled: Boolean!\\n}\\n\\nenum StatusType {\\n DRAFT\\n CONFIRMED\\n}\",\n initialValue:\n '{\\n \"name\": \"\",\\n \"status\": \"DRAFT\",\\n \"allowedDocumentTypes\": null,\\n \"isDragAndDropEnabled\": true\\n}',\n examples: [],\n },\n local: {\n schema: \"\",\n initialValue: \"\",\n examples: [],\n },\n },\n modules: [\n {\n id: \"d274599a-ceb5-4f2b-8651-b25787306734\",\n name: \"base_operations\",\n description: \"\",\n operations: [\n {\n id: \"f2ba2ddc-8527-4162-93bd-e045e9932013\",\n name: \"SET_APP_NAME\",\n description: \"\",\n schema: \"input SetAppNameInput {\\n name: String!\\n}\",\n template: \"\",\n reducer: \"\",\n errors: [],\n examples: [],\n scope: \"global\",\n },\n {\n id: \"c842efa4-154c-4fd9-9d12-42bec51af4e9\",\n name: \"SET_APP_STATUS\",\n description: \"\",\n schema: \"input SetAppStatusInput {\\n status: StatusType!\\n}\",\n template: \"\",\n reducer: \"\",\n errors: [],\n examples: [],\n scope: \"global\",\n },\n {\n id: \"7376f168-695f-4aef-94d0-6e381666358c\",\n name: \"ADD_DOCUMENT_TYPE\",\n description: \"\",\n schema:\n \"input AddDocumentTypeInput {\\n documentType: String!\\n}\",\n template: \"\",\n reducer: \"\",\n errors: [],\n examples: [],\n scope: \"global\",\n },\n {\n id: \"310e4e5b-3f14-4e9a-8e09-5583c7698a65\",\n name: \"REMOVE_DOCUMENT_TYPE\",\n description: \"\",\n schema:\n \"input RemoveDocumentTypeInput {\\n documentType: String!\\n}\",\n template: \"\",\n reducer: \"\",\n errors: [],\n examples: [],\n scope: \"global\",\n },\n {\n id: \"b365727a-7df3-48f0-a4f8-02362f02ad1d\",\n name: \"SET_DOCUMENT_TYPES\",\n description: \"\",\n schema:\n \"input SetDocumentTypesInput {\\n documentTypes: [String!]!\\n}\",\n template: \"\",\n reducer: \"\",\n errors: [],\n examples: [],\n scope: \"global\",\n },\n ],\n },\n {\n id: \"270faa10-92e9-40d0-b128-2de32704bcb5\",\n name: \"dnd_operations\",\n description: \"\",\n operations: [\n {\n id: \"077b1ab8-cb32-4b4e-a1fa-76178188c6a1\",\n name: \"SET_DRAG_AND_DROP_ENABLED\",\n description: \"\",\n schema:\n \"input SetDragAndDropEnabledInput {\\n enabled: Boolean!\\n}\",\n template: \"\",\n reducer: \"\",\n errors: [],\n examples: [],\n scope: \"global\",\n },\n ],\n },\n ],\n },\n ],\n};\n","import * as z from \"zod\";\nimport type {\n AddDocumentTypeInput,\n AppModuleState,\n RemoveDocumentTypeInput,\n SetAppNameInput,\n SetAppStatusInput,\n SetDocumentTypesInput,\n SetDragAndDropEnabledInput,\n StatusType,\n} from \"./types.js\";\n\ntype Properties<T> = Required<{\n [K in keyof T]: z.ZodType<T[K]>;\n}>;\n\ntype definedNonNullAny = {};\n\nexport const isDefinedNonNullAny = (v: any): v is definedNonNullAny =>\n v !== undefined && v !== null;\n\nexport const definedNonNullAnySchema = z\n .any()\n .refine((v) => isDefinedNonNullAny(v));\n\nexport const StatusTypeSchema = z.enum([\"CONFIRMED\", \"DRAFT\"]);\n\nexport function AddDocumentTypeInputSchema(): z.ZodObject<\n Properties<AddDocumentTypeInput>\n> {\n return z.object({\n documentType: z.string(),\n });\n}\n\nexport function AppModuleStateSchema(): z.ZodObject<\n Properties<AppModuleState>\n> {\n return z.object({\n __typename: z.literal(\"AppModuleState\").optional(),\n allowedDocumentTypes: z.array(z.string()).nullish(),\n isDragAndDropEnabled: z.boolean(),\n name: z.string(),\n status: StatusTypeSchema,\n });\n}\n\nexport function RemoveDocumentTypeInputSchema(): z.ZodObject<\n Properties<RemoveDocumentTypeInput>\n> {\n return z.object({\n documentType: z.string(),\n });\n}\n\nexport function SetAppNameInputSchema(): z.ZodObject<\n Properties<SetAppNameInput>\n> {\n return z.object({\n name: z.string(),\n });\n}\n\nexport function SetAppStatusInputSchema(): z.ZodObject<\n Properties<SetAppStatusInput>\n> {\n return z.object({\n status: StatusTypeSchema,\n });\n}\n\nexport function SetDocumentTypesInputSchema(): z.ZodObject<\n Properties<SetDocumentTypesInput>\n> {\n return z.object({\n documentTypes: z.array(z.string()),\n });\n}\n\nexport function SetDragAndDropEnabledInputSchema(): z.ZodObject<\n Properties<SetDragAndDropEnabledInput>\n> {\n return z.object({\n enabled: z.boolean(),\n });\n}\n","import { createAction } from \"@powerhousedao/shared/document-model\";\nimport {\n AddDocumentTypeInputSchema,\n RemoveDocumentTypeInputSchema,\n SetAppNameInputSchema,\n SetAppStatusInputSchema,\n SetDocumentTypesInputSchema,\n} from \"../schema/zod.js\";\nimport type {\n AddDocumentTypeInput,\n RemoveDocumentTypeInput,\n SetAppNameInput,\n SetAppStatusInput,\n SetDocumentTypesInput,\n} from \"../types.js\";\nimport type {\n AddDocumentTypeAction,\n RemoveDocumentTypeAction,\n SetAppNameAction,\n SetAppStatusAction,\n SetDocumentTypesAction,\n} from \"./actions.js\";\n\nexport const setAppName = (input: SetAppNameInput) =>\n createAction<SetAppNameAction>(\n \"SET_APP_NAME\",\n { ...input },\n undefined,\n SetAppNameInputSchema,\n \"global\",\n );\n\nexport const setAppStatus = (input: SetAppStatusInput) =>\n createAction<SetAppStatusAction>(\n \"SET_APP_STATUS\",\n { ...input },\n undefined,\n SetAppStatusInputSchema,\n \"global\",\n );\n\nexport const addDocumentType = (input: AddDocumentTypeInput) =>\n createAction<AddDocumentTypeAction>(\n \"ADD_DOCUMENT_TYPE\",\n { ...input },\n undefined,\n AddDocumentTypeInputSchema,\n \"global\",\n );\n\nexport const removeDocumentType = (input: RemoveDocumentTypeInput) =>\n createAction<RemoveDocumentTypeAction>(\n \"REMOVE_DOCUMENT_TYPE\",\n { ...input },\n undefined,\n RemoveDocumentTypeInputSchema,\n \"global\",\n );\n\nexport const setDocumentTypes = (input: SetDocumentTypesInput) =>\n createAction<SetDocumentTypesAction>(\n \"SET_DOCUMENT_TYPES\",\n { ...input },\n undefined,\n SetDocumentTypesInputSchema,\n \"global\",\n );\n","import { createAction } from \"@powerhousedao/shared/document-model\";\nimport { SetDragAndDropEnabledInputSchema } from \"../schema/zod.js\";\nimport type { SetDragAndDropEnabledInput } from \"../types.js\";\nimport type { SetDragAndDropEnabledAction } from \"./actions.js\";\n\nexport const setDragAndDropEnabled = (input: SetDragAndDropEnabledInput) =>\n createAction<SetDragAndDropEnabledAction>(\n \"SET_DRAG_AND_DROP_ENABLED\",\n { ...input },\n undefined,\n SetDragAndDropEnabledInputSchema,\n \"global\",\n );\n","export const appModuleDocumentType = \"powerhouse/app\";\n","import {\n BaseDocumentHeaderSchema,\n BaseDocumentStateSchema,\n} from \"@powerhousedao/shared/document-model\";\nimport { z } from \"zod\";\nimport { appModuleDocumentType } from \"./document-type.js\";\nimport { AppModuleStateSchema } from \"./schema/zod.js\";\nimport type { AppModuleDocument, AppModulePHState } from \"./types.js\";\n\n/** Schema for validating the header object of a AppModule document */\nexport const AppModuleDocumentHeaderSchema = BaseDocumentHeaderSchema.extend({\n documentType: z.literal(appModuleDocumentType),\n});\n\n/** Schema for validating the state object of a AppModule document */\nexport const AppModulePHStateSchema = BaseDocumentStateSchema.extend({\n global: AppModuleStateSchema(),\n});\n\nexport const AppModuleDocumentSchema = z.object({\n header: AppModuleDocumentHeaderSchema,\n state: AppModulePHStateSchema,\n initialState: AppModulePHStateSchema,\n});\n\n/** Simple helper function to check if a state object is a AppModule document state object */\nexport function isAppModuleState(state: unknown): state is AppModulePHState {\n return AppModulePHStateSchema.safeParse(state).success;\n}\n\n/** Simple helper function to assert that a document state object is a AppModule document state object */\nexport function assertIsAppModuleState(\n state: unknown,\n): asserts state is AppModulePHState {\n AppModulePHStateSchema.parse(state);\n}\n\n/** Simple helper function to check if a document is a AppModule document */\nexport function isAppModuleDocument(\n document: unknown,\n): document is AppModuleDocument {\n return AppModuleDocumentSchema.safeParse(document).success;\n}\n\n/** Simple helper function to assert that a document is a AppModule document */\nexport function assertIsAppModuleDocument(\n document: unknown,\n): asserts document is AppModuleDocument {\n AppModuleDocumentSchema.parse(document);\n}\n","import type { AppModuleBaseOperationsOperations } from \"@powerhousedao/vetra/document-models/app-module\";\n\nexport const appModuleBaseOperationsOperations: AppModuleBaseOperationsOperations =\n {\n setAppNameOperation(state, action, dispatch) {\n const trimmedName = action.input.name.trim();\n if (trimmedName === \"\") {\n throw new Error(\"App name cannot be empty\");\n }\n state.name = trimmedName;\n },\n setAppStatusOperation(state, action, dispatch) {\n state.status = action.input.status;\n },\n addDocumentTypeOperation(state, action, dispatch) {\n const existingAllowedDocumentTypes = state.allowedDocumentTypes ?? [];\n const newDocumentType = action.input.documentType;\n const newAllowedDocumentTypesSet = new Set(\n existingAllowedDocumentTypes,\n ).add(newDocumentType);\n const newAllowedDocumentTypes = [...newAllowedDocumentTypesSet];\n state.allowedDocumentTypes = newAllowedDocumentTypes;\n },\n removeDocumentTypeOperation(state, action, dispatch) {\n const existingAllowedDocumentTypes = state.allowedDocumentTypes;\n const documentTypeToRemove = action.input.documentType;\n const newAllowedDocumentTypes = existingAllowedDocumentTypes?.filter(\n (dt) => dt !== documentTypeToRemove,\n );\n state.allowedDocumentTypes = newAllowedDocumentTypes ?? [];\n },\n setDocumentTypesOperation(state, action, dispatch) {\n state.allowedDocumentTypes = action.input.documentTypes;\n },\n };\n","import type { AppModuleDndOperationsOperations } from \"@powerhousedao/vetra/document-models/app-module\";\n\nexport const appModuleDndOperationsOperations: AppModuleDndOperationsOperations =\n {\n setDragAndDropEnabledOperation(state, action, dispatch) {\n state.isDragAndDropEnabled = action.input.enabled;\n },\n };\n","// TODO: remove eslint-disable rules once refactor is done\n\nimport type { AppModulePHState } from \"@powerhousedao/vetra/document-models/app-module\";\nimport type {\n Reducer,\n StateReducer,\n} from \"@powerhousedao/shared/document-model\";\nimport {\n createReducer,\n isDocumentAction,\n} from \"@powerhousedao/shared/document-model\";\n\nimport { appModuleBaseOperationsOperations } from \"../src/reducers/base-operations.js\";\nimport { appModuleDndOperationsOperations } from \"../src/reducers/dnd-operations.js\";\n\nimport {\n AddDocumentTypeInputSchema,\n RemoveDocumentTypeInputSchema,\n SetAppNameInputSchema,\n SetAppStatusInputSchema,\n SetDocumentTypesInputSchema,\n SetDragAndDropEnabledInputSchema,\n} from \"./schema/zod.js\";\n\nconst stateReducer: StateReducer<AppModulePHState> = (\n state,\n action,\n dispatch,\n) => {\n if (isDocumentAction(action)) {\n return state;\n }\n switch (action.type) {\n case \"SET_APP_NAME\": {\n SetAppNameInputSchema().parse(action.input);\n\n appModuleBaseOperationsOperations.setAppNameOperation(\n (state as any)[action.scope],\n action as any,\n dispatch,\n );\n\n break;\n }\n\n case \"SET_APP_STATUS\": {\n SetAppStatusInputSchema().parse(action.input);\n\n appModuleBaseOperationsOperations.setAppStatusOperation(\n (state as any)[action.scope],\n action as any,\n dispatch,\n );\n\n break;\n }\n\n case \"ADD_DOCUMENT_TYPE\": {\n AddDocumentTypeInputSchema().parse(action.input);\n\n appModuleBaseOperationsOperations.addDocumentTypeOperation(\n (state as any)[action.scope],\n action as any,\n dispatch,\n );\n\n break;\n }\n\n case \"REMOVE_DOCUMENT_TYPE\": {\n RemoveDocumentTypeInputSchema().parse(action.input);\n\n appModuleBaseOperationsOperations.removeDocumentTypeOperation(\n (state as any)[action.scope],\n action as any,\n dispatch,\n );\n\n break;\n }\n\n case \"SET_DOCUMENT_TYPES\": {\n SetDocumentTypesInputSchema().parse(action.input);\n\n appModuleBaseOperationsOperations.setDocumentTypesOperation(\n (state as any)[action.scope],\n action as any,\n dispatch,\n );\n\n break;\n }\n\n case \"SET_DRAG_AND_DROP_ENABLED\": {\n SetDragAndDropEnabledInputSchema().parse(action.input);\n\n appModuleDndOperationsOperations.setDragAndDropEnabledOperation(\n (state as any)[action.scope],\n action as any,\n dispatch,\n );\n\n break;\n }\n\n default:\n return state;\n }\n};\n\nexport const reducer: Reducer<AppModulePHState> = createReducer(stateReducer);\n","import type { DocumentModelUtils } from \"@powerhousedao/shared/document-model\";\nimport {\n baseCreateDocument,\n baseLoadFromInput,\n baseSaveToFileHandle,\n defaultBaseState,\n generateId,\n} from \"@powerhousedao/shared/document-model\";\nimport {\n assertIsAppModuleDocument,\n assertIsAppModuleState,\n isAppModuleDocument,\n isAppModuleState,\n} from \"./document-schema.js\";\nimport { appModuleDocumentType } from \"./document-type.js\";\nimport { reducer } from \"./reducer.js\";\nimport type {\n AppModuleGlobalState,\n AppModuleLocalState,\n AppModulePHState,\n} from \"./types.js\";\n\nexport const initialGlobalState: AppModuleGlobalState = {\n name: \"\",\n status: \"DRAFT\",\n allowedDocumentTypes: null,\n isDragAndDropEnabled: true,\n};\nexport const initialLocalState: AppModuleLocalState = {};\n\nexport const utils: DocumentModelUtils<AppModulePHState> = {\n fileExtension: \".phdm\",\n createState(state) {\n return {\n ...defaultBaseState(),\n global: { ...initialGlobalState, ...state?.global },\n local: { ...initialLocalState, ...state?.local },\n };\n },\n createDocument(state) {\n const document = baseCreateDocument(utils.createState, state);\n\n document.header.documentType = appModuleDocumentType;\n\n // for backwards compatibility, but this is NOT a valid signed document id\n document.header.id = generateId();\n\n return document;\n },\n saveToFileHandle(document, input) {\n return baseSaveToFileHandle(document, input);\n },\n loadFromInput(input) {\n return baseLoadFromInput(input, reducer);\n },\n isStateOfType(state) {\n return isAppModuleState(state);\n },\n assertIsStateOfType(state) {\n return assertIsAppModuleState(state);\n },\n isDocumentOfType(document) {\n return isAppModuleDocument(document);\n },\n assertIsDocumentOfType(document) {\n return assertIsAppModuleDocument(document);\n },\n};\n","/**\n * Factory methods for creating AppModuleDocument instances\n */\nimport type {\n PHAuthState,\n PHBaseState,\n PHDocumentState,\n} from \"@powerhousedao/shared/document-model\";\nimport {\n createBaseState,\n defaultBaseState,\n} from \"@powerhousedao/shared/document-model\";\nimport type {\n AppModuleDocument,\n AppModuleGlobalState,\n AppModuleLocalState,\n AppModulePHState,\n} from \"./types.js\";\nimport { utils } from \"./utils.js\";\n\nexport function defaultGlobalState(): AppModuleGlobalState {\n return {\n name: \"\",\n status: \"DRAFT\",\n allowedDocumentTypes: null,\n isDragAndDropEnabled: true,\n };\n}\n\nexport function defaultLocalState(): AppModuleLocalState {\n return {};\n}\n\nexport function defaultPHState(): AppModulePHState {\n return {\n ...defaultBaseState(),\n global: defaultGlobalState(),\n local: defaultLocalState(),\n };\n}\n\nexport function createGlobalState(\n state?: Partial<AppModuleGlobalState>,\n): AppModuleGlobalState {\n return {\n ...defaultGlobalState(),\n ...(state || {}),\n } as AppModuleGlobalState;\n}\n\nexport function createLocalState(\n state?: Partial<AppModuleLocalState>,\n): AppModuleLocalState {\n return {\n ...defaultLocalState(),\n ...(state || {}),\n } as AppModuleLocalState;\n}\n\nexport function createState(\n baseState?: Partial<PHBaseState>,\n globalState?: Partial<AppModuleGlobalState>,\n localState?: Partial<AppModuleLocalState>,\n): AppModulePHState {\n return {\n ...createBaseState(baseState?.auth, baseState?.document),\n global: createGlobalState(globalState),\n local: createLocalState(localState),\n };\n}\n\n/**\n * Creates a AppModuleDocument with custom global and local state\n * This properly handles the PHBaseState requirements while allowing\n * document-specific state to be set.\n */\nexport function createAppModuleDocument(\n state?: Partial<{\n auth?: Partial<PHAuthState>;\n document?: Partial<PHDocumentState>;\n global?: Partial<AppModuleGlobalState>;\n local?: Partial<AppModuleLocalState>;\n }>,\n): AppModuleDocument {\n const document = utils.createDocument(\n state\n ? createState(\n createBaseState(state.auth, state.document),\n state.global,\n state.local,\n )\n : undefined,\n );\n\n return document;\n}\n","export {};\n","import type { DocumentDispatch } from \"@powerhousedao/reactor-browser\";\nimport {\n useDocumentById,\n useDocumentsInSelectedDrive,\n useDocumentsInSelectedFolder,\n useSelectedDocument,\n} from \"@powerhousedao/reactor-browser\";\nimport type {\n AppModuleAction,\n AppModuleDocument,\n} from \"@powerhousedao/vetra/document-models/app-module\";\nimport {\n assertIsAppModuleDocument,\n isAppModuleDocument,\n} from \"./gen/document-schema.js\";\n\n/** Hook to get a AppModule document by its id */\nexport function useAppModuleDocumentById(\n documentId: string | null | undefined,\n):\n | [AppModuleDocument, DocumentDispatch<AppModuleAction>]\n | [undefined, undefined] {\n const [document, dispatch] = useDocumentById(documentId);\n if (!isAppModuleDocument(document)) return [undefined, undefined];\n return [document, dispatch];\n}\n\n/** Hook to get the selected AppModule document */\nexport function useSelectedAppModuleDocument(): [\n AppModuleDocument,\n DocumentDispatch<AppModuleAction>,\n] {\n const [document, dispatch] = useSelectedDocument();\n\n assertIsAppModuleDocument(document);\n return [document, dispatch] as const;\n}\n\n/** Hook to get all AppModule documents in the selected drive */\nexport function useAppModuleDocumentsInSelectedDrive() {\n const documentsInSelectedDrive = useDocumentsInSelectedDrive();\n return documentsInSelectedDrive?.filter(isAppModuleDocument);\n}\n\n/** Hook to get all AppModule documents in the selected folder */\nexport function useAppModuleDocumentsInSelectedFolder() {\n const documentsInSelectedFolder = useDocumentsInSelectedFolder();\n return documentsInSelectedFolder?.filter(isAppModuleDocument);\n}\n","import {\n baseActions,\n type Actions,\n} from \"@powerhousedao/shared/document-model\";\nimport { baseOperationsActions, dndOperationsActions } from \"./gen/creators.js\";\n\n/** Actions for the AppModule document model */\n\nexport const actions: Actions = {\n ...baseActions,\n ...baseOperationsActions,\n ...dndOperationsActions,\n};\n","import type { DocumentModelUtils } from \"@powerhousedao/shared/document-model\";\nimport type { AppModulePHState } from \"./gen/types.js\";\nimport { utils as genUtils } from \"./gen/utils.js\";\nimport * as customUtils from \"./src/utils.js\";\n\n/** Utils for the AppModule document model */\nexport const utils: DocumentModelUtils<AppModulePHState> = {\n ...genUtils,\n ...customUtils,\n};\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"codegen-PnsnCMkw.js","names":[],"sources":["../processors/codegen/document-handlers/base-document-gen.ts","../processors/codegen/interactive-manager.ts","../processors/codegen/document-handlers/document-codegen-manager.ts","../processors/codegen/document-handlers/generators/utils.ts","../processors/codegen/document-handlers/generators/app-generator.ts","../processors/codegen/document-handlers/generators/document-editor-generator.ts","../processors/codegen/document-handlers/generators/document-model-generator.ts","../processors/codegen/document-handlers/generators/package-generator.ts","../processors/codegen/document-handlers/generators/processor-generator.ts","../processors/codegen/document-handlers/generators/subgraph-generator.ts","../processors/codegen/document-handlers/document-codegen-factory.ts","../processors/codegen/index.ts"],"sourcesContent":["import type { Project } from \"ts-morph\";\nimport type { CodegenInput, Config } from \"./types.js\";\n/**\n * Abstract base class for document generators\n * Defines the interface that all document-type handlers must implement\n */\nexport abstract class BaseDocumentGen {\n /**\n * The document type(s) this generator supports\n * Can be a single string or an array of strings for generators that handle multiple types\n */\n abstract readonly supportedDocumentTypes: string | string[];\n project: Project;\n\n constructor(\n protected config: Config,\n project: Project,\n ) {\n this.project = project;\n }\n\n /**\n * Generate code for the given document\n * Must be implemented by each specific document generator\n */\n abstract generate(strand: CodegenInput): Promise<void>;\n\n /**\n * Check if this generator supports the given document type\n */\n supportsDocumentType(documentType: string): boolean {\n if (typeof this.supportedDocumentTypes === \"string\") {\n return this.supportedDocumentTypes === documentType;\n }\n return this.supportedDocumentTypes.includes(documentType);\n }\n\n /**\n * Get all supported document types as an array\n */\n getSupportedDocumentTypes(): string[] {\n if (typeof this.supportedDocumentTypes === \"string\") {\n return [this.supportedDocumentTypes];\n }\n return [...this.supportedDocumentTypes];\n }\n\n /**\n * Validate if this strand should be processed\n * Override this method in specific generators to add custom validation logic\n */\n shouldProcess(strand: CodegenInput): boolean {\n // Basic validation: ensure strand has required properties\n if (!strand.documentId || !strand.documentType) {\n return false;\n }\n\n // Basic validation: check if document type is supported\n if (!this.supportsDocumentType(strand.documentType)) {\n return false;\n }\n\n // Default to processing if basic validation passes\n return true;\n }\n}\n","import { createInterface } from \"node:readline\";\nimport type { CodegenInput } from \"./document-handlers/types.js\";\nimport { logger } from \"./logger.js\";\n\nexport interface QueuedStrand {\n strand: CodegenInput;\n timestamp: number;\n}\n\n/**\n * InteractiveManager handles user interaction for code generation confirmation\n * Supports both individual strand processing and queue-based batch processing\n */\nexport class InteractiveManager {\n private isInteractiveMode: boolean;\n private processingConfirmation = false;\n private strandQueue = new Map<string, QueuedStrand>();\n\n constructor(interactiveMode = false) {\n this.isInteractiveMode = interactiveMode;\n }\n\n private getDocumentKey(documentType: string, documentId: string): string {\n return `${documentType}:${documentId}`;\n }\n\n /**\n * Add a strand to the queue, replacing any existing strand for the same document\n */\n public queueStrand(strand: CodegenInput): void {\n const documentKey = this.getDocumentKey(\n strand.documentType,\n strand.documentId,\n );\n\n this.strandQueue.set(documentKey, {\n strand,\n timestamp: Date.now(),\n });\n\n logger.debug(\n `>>> Queued strand for ${documentKey}, queue size: ${this.strandQueue.size}`,\n );\n }\n\n /**\n * Get all queued strands\n */\n public getQueuedStrands(): QueuedStrand[] {\n return Array.from(this.strandQueue.values());\n }\n\n /**\n * Clear and return all queued strands\n */\n public clearQueue(): QueuedStrand[] {\n const queuedStrands = Array.from(this.strandQueue.values());\n this.strandQueue.clear();\n return queuedStrands;\n }\n\n /**\n * Get the current queue size\n */\n public getQueueSize(): number {\n return this.strandQueue.size;\n }\n\n private async promptUserConfirmation(): Promise<boolean> {\n return new Promise((resolve) => {\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n console.log(\"\\n\" + \"=\".repeat(50));\n console.log(\"🔄 Code generation ready to run.\");\n console.log(\"=\".repeat(50));\n\n process.stdout.write(\n \"Do you want to proceed with code generation? (y/n): \\n\\n\",\n );\n\n rl.on(\"line\", (answer: string) => {\n rl.close();\n console.log(\"\"); // Add blank line after user input\n resolve(answer.toLowerCase() === \"y\" || answer.toLowerCase() === \"yes\");\n });\n });\n }\n\n /**\n * Process generation with user confirmation (legacy single-strand method)\n * This method assumes interactive mode is already enabled (checked by caller)\n */\n public async processWithConfirmation<T>(\n documentType: string,\n generator: () => Promise<T>,\n ): Promise<T | null> {\n if (this.processingConfirmation) {\n logger.debug(\"Already processing confirmation, skipping\");\n return null;\n }\n\n this.processingConfirmation = true;\n\n try {\n // Always prompt user since this method only called in interactive mode\n const shouldProceed = await this.promptUserConfirmation();\n\n if (!shouldProceed) {\n logger.info(`❌ Code generation cancelled by user for ${documentType}`);\n return null;\n }\n\n logger.info(`✅ User approved code generation for ${documentType}`);\n\n const result = await generator();\n return result;\n } catch (error) {\n logger.error(\n `❌ Error during interactive code generation for ${documentType}:`,\n error,\n );\n throw error;\n } finally {\n this.processingConfirmation = false;\n }\n }\n\n /**\n * Process all queued strands with a single user confirmation\n * This is the main method for queue-based interactive processing\n */\n public async processQueueWithConfirmation(\n processor: (strands: QueuedStrand[]) => Promise<void>,\n ): Promise<void> {\n if (this.processingConfirmation) {\n logger.debug(\n \"Already processing confirmation, skipping queue processing\",\n );\n return;\n }\n\n // Check if there are any strands to process\n let queuedStrands = this.getQueuedStrands();\n if (queuedStrands.length === 0) {\n logger.debug(\"No strands in queue to process\");\n return;\n }\n\n this.processingConfirmation = true;\n\n try {\n // Prompt user for confirmation\n const shouldProceed = await this.promptUserConfirmation();\n\n if (!shouldProceed) {\n logger.info(\"❌ Code generation cancelled by user\");\n // Clear the queue since user cancelled\n this.clearQueue();\n return;\n }\n\n // Get and clear the final queue state right before processing\n // (in case new strands were added while waiting for user input)\n queuedStrands = this.clearQueue();\n if (queuedStrands.length === 0) {\n logger.info(\"ℹ️ No documents to process\");\n return;\n }\n\n logger.info(\n `✅ User approved code generation for ${queuedStrands.length} document(s)`,\n );\n\n // Process all queued strands\n await processor(queuedStrands);\n logger.info(\"✅ Code generation completed\");\n } catch (error) {\n logger.error(\"❌ Error during interactive queue processing:\", error);\n throw error;\n } finally {\n this.processingConfirmation = false;\n }\n }\n\n public setInteractiveMode(enabled: boolean): void {\n this.isInteractiveMode = enabled;\n logger.debug(`Interactive mode set to: ${enabled}`);\n }\n\n public isInteractive(): boolean {\n return this.isInteractiveMode;\n }\n\n public isProcessing(): boolean {\n return this.processingConfirmation;\n }\n}\n","import type { Project } from \"ts-morph\";\nimport type { QueuedStrand } from \"../interactive-manager.js\";\nimport { InteractiveManager } from \"../interactive-manager.js\";\nimport { logger } from \"../logger.js\";\nimport type { BaseDocumentGen } from \"./base-document-gen.js\";\nimport type { CodegenInput, Config } from \"./types.js\";\n\nconst DEFAULT_DEBOUNCE_TIME = 1000; // wait 1 second between codegen calls\n\n/**\n * Manager class responsible for routing documents to the correct generator\n * and managing generator registration and instantiation\n */\nexport class DocumentCodegenManager {\n project: Project;\n private generators = new Map<string, BaseDocumentGen>();\n private debounceTimers = new Map<string, NodeJS.Timeout>();\n private processingQueue: Promise<void> = Promise.resolve();\n private interactiveManager: InteractiveManager;\n\n constructor(\n private config: Config,\n project: Project,\n interactiveMode = false,\n ) {\n this.project = project;\n this.interactiveManager = new InteractiveManager(interactiveMode);\n }\n\n /**\n * Register a generator class for a specific document type\n */\n registerGenerator(\n documentType: string,\n generatorClass: new (config: Config, project: Project) => BaseDocumentGen,\n ): void {\n if (this.generators.has(documentType)) {\n logger.warn(\n `⚠️ Generator for document type \"${documentType}\" is already registered. Overwriting.`,\n );\n }\n\n this.generators.set(\n documentType,\n new generatorClass(this.config, this.project),\n );\n logger.debug(`✅ Registered generator for document type: ${documentType}`);\n }\n\n /**\n * Register a generator class that supports multiple document types\n */\n registerMultiTypeGenerator(\n generatorClass: new (config: Config, project: Project) => BaseDocumentGen,\n ): void {\n const generator = new generatorClass(this.config, this.project);\n const supportedTypes = generator.getSupportedDocumentTypes();\n\n for (const documentType of supportedTypes) {\n if (this.generators.has(documentType)) {\n logger.warn(\n `⚠️ Generator for document type \"${documentType}\" is already registered. Overwriting.`,\n );\n }\n this.generators.set(documentType, generator);\n }\n\n logger.debug(\n `✅ Registered multi-type generator for document types: ${supportedTypes.join(\", \")}`,\n );\n }\n\n /**\n * Get a generator instance for the given document type\n * Public method to allow external access for validation\n */\n public getGenerator(documentType: string): BaseDocumentGen | undefined {\n return this.generators.get(documentType);\n }\n\n /**\n * Get all registered document types\n */\n getRegisteredDocumentTypes(): string[] {\n return Array.from(this.generators.keys());\n }\n\n /**\n * Check if a document type is supported\n */\n isDocumentTypeSupported(documentType: string): boolean {\n return this.generators.has(documentType);\n }\n\n /**\n * Route a document to the appropriate generator and handle the generation\n * Handles both interactive and non-interactive modes with queue-based processing\n */\n async routeAndGenerate(strand: CodegenInput): Promise<void> {\n const documentType = strand.documentType;\n\n if (!documentType) {\n logger.error(\"❌ Document type is missing from strand state\");\n throw new Error(\"Document type is missing from strand state\");\n }\n\n const generator = this.getGenerator(documentType);\n\n if (!generator) {\n logger.warn(`⚠️ No generator found for document type: ${documentType}`);\n logger.warn(\n `ℹ️ Supported document types: ${this.getRegisteredDocumentTypes().join(\", \")}`,\n );\n throw new Error(`Unsupported document type: ${documentType}`);\n }\n\n // Validate if this strand should be processed\n if (!generator.shouldProcess(strand)) {\n logger.debug(\n `>>> Generator validation failed for ${documentType}:${strand.documentId}, skipping processing`,\n );\n return;\n }\n\n // Different flow for interactive vs non-interactive mode\n if (this.interactiveManager.isInteractive()) {\n // Interactive mode: queue strands and use debounce timer to trigger batch processing\n logger.debug(\n `>>> Queueing strand for interactive processing: ${documentType}:${strand.documentId}`,\n );\n\n // Add strand to queue (will replace any existing strand for same document)\n this.interactiveManager.queueStrand(strand);\n\n // Clear any existing debounce timer for interactive processing\n const existingTimer = this.debounceTimers.get(\"interactive\");\n if (existingTimer) {\n clearTimeout(existingTimer);\n }\n\n // Set up debounce timer for batch interactive processing\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n const debounceTimer = setTimeout(async () => {\n try {\n await this.interactiveManager.processQueueWithConfirmation(\n async (queuedStrands: QueuedStrand[]) => {\n await this.processQueuedStrands(queuedStrands);\n },\n );\n } catch (error) {\n logger.error(\"❌ Error during interactive batch processing:\", error);\n } finally {\n // Clean up the timer reference\n this.debounceTimers.delete(\"interactive\");\n }\n }, DEFAULT_DEBOUNCE_TIME);\n\n // Store the timer reference using 'interactive' key\n this.debounceTimers.set(\"interactive\", debounceTimer);\n } else {\n // Non-interactive mode: use debouncing per document instance\n // Create unique key for this specific document instance\n const timerKey = `${documentType}:${strand.documentId}`;\n\n // Clear any existing debounce timer for this document instance\n const existingTimer = this.debounceTimers.get(timerKey);\n if (existingTimer) {\n clearTimeout(existingTimer);\n }\n\n // Set up new debounced generation (no interactive confirmation)\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n const debounceTimer = setTimeout(async () => {\n try {\n logger.debug(\n `🔄 Routing document type \"${documentType}\" to generator (debounced)`,\n );\n\n // Direct generation, no interactive confirmation\n await generator.generate(strand);\n logger.debug(\n `✅ Successfully generated code for document type: ${documentType}`,\n );\n } catch (error) {\n logger.error(\n `❌ Error generating code for document type \"${documentType}\":`,\n error,\n );\n // Don't throw - let codegen continue with other documents\n } finally {\n // Clean up the timer reference\n this.debounceTimers.delete(timerKey);\n }\n }, DEFAULT_DEBOUNCE_TIME);\n\n // Store the timer reference\n this.debounceTimers.set(timerKey, debounceTimer);\n }\n }\n\n /**\n * Process multiple strands in priority order (document-model types first)\n */\n private async processQueuedStrands(\n queuedStrands: QueuedStrand[],\n ): Promise<void> {\n logger.debug(`🔄 Processing ${queuedStrands.length} queued strand(s)`);\n\n // Sort by priority (document-model first to ensure dependencies exist)\n const documentModelStrands = queuedStrands.filter(\n (qs: QueuedStrand) =>\n qs.strand.documentType === \"powerhouse/document-model\",\n );\n const otherStrands = queuedStrands.filter(\n (qs: QueuedStrand) =>\n qs.strand.documentType !== \"powerhouse/document-model\",\n );\n\n // Process document models first\n for (const queuedStrand of documentModelStrands) {\n await this.processStrand(queuedStrand.strand);\n }\n\n // Then process other document types\n for (const queuedStrand of otherStrands) {\n await this.processStrand(queuedStrand.strand);\n }\n\n logger.debug(\n `✅ Successfully processed all ${queuedStrands.length} queued strand(s)`,\n );\n }\n\n /**\n * Process a single strand (used internally by processQueuedStrands)\n */\n private async processStrand(strand: CodegenInput): Promise<void> {\n const documentType = strand.documentType;\n const generator = this.getGenerator(documentType);\n\n if (!generator) {\n logger.warn(`⚠️ No generator found for document type: ${documentType}`);\n return;\n }\n\n try {\n logger.debug(`🔄 Generating code for document type: ${documentType}`);\n await generator.generate(strand);\n logger.debug(\n `✅ Successfully generated code for document type: ${documentType}`,\n );\n } catch (error) {\n logger.error(\n `❌ Error generating code for document type \"${documentType}\":`,\n error,\n );\n // Don't throw here to allow other strands to be processed\n }\n }\n\n /**\n * Clear all registered generators\n */\n clearGenerators(): void {\n this.generators.clear();\n logger.debug(\"🧹 Cleared all registered generators\");\n }\n\n /**\n * Get statistics about registered generators\n */\n getStats(): { totalGenerators: number; supportedTypes: string[] } {\n return {\n totalGenerators: this.generators.size,\n supportedTypes: this.getRegisteredDocumentTypes(),\n };\n }\n\n /**\n * Set interactive mode for code generation\n */\n setInteractiveMode(enabled: boolean): void {\n this.interactiveManager.setInteractiveMode(enabled);\n }\n\n /**\n * Check if interactive mode is enabled\n */\n isInteractiveMode(): boolean {\n return this.interactiveManager.isInteractive();\n }\n\n /**\n * Check if the manager is currently processing an interactive confirmation\n */\n isProcessingInteractive(): boolean {\n return this.interactiveManager.isProcessing();\n }\n}\n","import type {\n MinimalBackupData,\n PHDocument,\n} from \"@powerhousedao/shared/document-model\";\nimport { baseMinimalSaveToFile, baseSaveToFile } from \"document-model/node\";\nimport { mkdir } from \"node:fs/promises\";\nimport { join } from \"node:path\";\nimport { logger } from \"../../logger.js\";\n\nconst BACKUP_FOLDER = \"backup-documents\";\n\n/**\n * Exports a document to the backup directory.\n * Creates the backup directory if it doesn't exist.\n *\n * @param document - The document to backup\n * @param workingDir - Current working directory\n * @param extension - File extension for the document type (without dot)\n * @param name - Name of the document to use for the backup file (optional)\n * @returns Promise resolving to the backup file path, or undefined if backup failed\n */\nexport async function backupDocument(\n document: PHDocument,\n workingDir: string,\n extension: string = \"\",\n name?: string,\n): Promise<string | undefined> {\n const docName = name ?? document.header.name;\n\n try {\n const backupPath = join(workingDir, BACKUP_FOLDER);\n await mkdir(backupPath, { recursive: true });\n\n const filePath = await baseSaveToFile(\n document,\n backupPath,\n extension,\n docName,\n );\n\n logger.debug(`📁 Document backed up to: ${filePath}`);\n return filePath;\n } catch (error) {\n logger.warn(`⚠️ Failed to backup document \"${docName}\":`, error);\n return undefined;\n }\n}\n\n/**\n * Creates a minimal backup of a document from strand data.\n * Used when the full document is not available (e.g., in onOperations handler).\n */\nexport async function minimalBackupDocument(\n data: MinimalBackupData,\n workingDir: string,\n extension?: string,\n): Promise<string | undefined> {\n try {\n const backupPath = join(workingDir, BACKUP_FOLDER);\n await mkdir(backupPath, { recursive: true });\n\n const filePath = await baseMinimalSaveToFile(\n data,\n backupPath,\n extension ?? \"\",\n );\n\n logger.debug(`Document backed up to: ${filePath}`);\n return filePath;\n } catch (error) {\n logger.warn(`Failed to backup document \"${data.name}\":`, error);\n return undefined;\n }\n}\n","import { generateApp } from \"@powerhousedao/codegen\";\nimport type {\n AppModuleGlobalState,\n AppModulePHState,\n} from \"@powerhousedao/vetra/document-models/app-module\";\nimport { kebabCase } from \"change-case\";\nimport { logger } from \"../../logger.js\";\nimport { BaseDocumentGen } from \"../base-document-gen.js\";\nimport type { CodegenInput } from \"../types.js\";\nimport { minimalBackupDocument } from \"./utils.js\";\n\n/**\n * Generator for app documents\n */\nexport class AppGenerator extends BaseDocumentGen {\n readonly supportedDocumentTypes = \"powerhouse/app\";\n\n /**\n * Parse and extract the global state from the serialized state string\n */\n private extractGlobalState(\n input: CodegenInput,\n ): AppModuleGlobalState | undefined {\n if (!input.state) {\n return undefined;\n }\n const fullState = input.state as AppModulePHState;\n return fullState.global;\n }\n\n /**\n * Validate if this app strand should be processed\n */\n shouldProcess(input: CodegenInput): boolean {\n // First run base validation\n if (!super.shouldProcess(input)) {\n return false;\n }\n\n const state = this.extractGlobalState(input);\n if (!state) {\n logger.debug(`No state found for app: ${input.documentId}`);\n return false;\n }\n\n // Check if we have a valid app name and it's confirmed\n if (!state.name) {\n logger.debug(`No name found for app: ${input.documentId}`);\n return false;\n }\n\n if (state.status !== \"CONFIRMED\") {\n logger.debug(\n `App not confirmed: ${state.name} (status: ${state.status})`,\n );\n return false;\n }\n\n return true;\n }\n\n async generate(input: CodegenInput): Promise<void> {\n const state = this.extractGlobalState(input);\n if (!state) {\n logger.error(`No state found for app: ${input.documentId}`);\n return;\n }\n\n // Check if we have a valid app name and it's confirmed\n if (state.name && state.status === \"CONFIRMED\") {\n logger.info(`🔄 Starting app generation for app: ${state.name}`);\n try {\n // Generate app ID using kebabCase\n const appId: string = kebabCase(state.name);\n // Generate the app using the codegen function\n await generateApp(\n {\n ...this.config.PH_CONFIG,\n appName: state.name,\n appId: appId,\n allowedDocumentTypes: state.allowedDocumentTypes ?? [],\n isDragAndDropEnabled: state.isDragAndDropEnabled,\n },\n this.project,\n );\n await this.project.save();\n\n logger.info(\n `✅ App generation completed successfully for app: ${state.name}`,\n );\n\n // Backup the document\n const fullState = input.state as AppModulePHState;\n await minimalBackupDocument(\n {\n documentId: input.documentId,\n documentType: input.documentType,\n branch: input.branch,\n state: fullState,\n name: state.name,\n },\n this.config.CURRENT_WORKING_DIR,\n );\n } catch (error) {\n logger.error(\n `❌ Error during app generation for app ${state.name}:`,\n error,\n );\n if (error instanceof Error) {\n logger.error(`❌ Error message: ${error.message}`);\n }\n }\n } else {\n if (!state.name) {\n logger.error(`❌ Skipping app generation - missing name for app`);\n return;\n } else if (state.status !== \"CONFIRMED\") {\n logger.error(\n `❌ Skipping app generation - app \"${state.name}\" is not confirmed (status: ${state.status})`,\n );\n return;\n }\n }\n }\n}\n","import { generateEditor } from \"@powerhousedao/codegen\";\nimport { kebabCase } from \"change-case\";\nimport type {\n DocumentEditorPHState,\n DocumentEditorState,\n} from \"../../../../document-models/document-editor/index.js\";\nimport { logger } from \"../../logger.js\";\nimport { BaseDocumentGen } from \"../base-document-gen.js\";\nimport type { CodegenInput } from \"../types.js\";\nimport { minimalBackupDocument } from \"./utils.js\";\n\n/**\n * Generator for document editor documents\n */\nexport class DocumentEditorGenerator extends BaseDocumentGen {\n readonly supportedDocumentTypes = \"powerhouse/document-editor\";\n\n /**\n * Parse and extract the global state from the serialized state string\n */\n private extractGlobalState(\n input: CodegenInput,\n ): DocumentEditorState | undefined {\n if (!input.state) {\n return undefined;\n }\n const fullState = input.state as DocumentEditorPHState;\n return fullState.global;\n }\n\n /**\n * Validate if this document editor strand should be processed\n */\n shouldProcess(input: CodegenInput): boolean {\n // First run base validation\n if (!super.shouldProcess(input)) {\n return false;\n }\n\n const state = this.extractGlobalState(input);\n if (!state) {\n logger.debug(`No state found for document editor: ${input.documentId}`);\n return false;\n }\n\n // Check if we have a valid editor name, document types, and it's confirmed\n if (!state.name) {\n logger.debug(`No name found for document editor: ${input.documentId}`);\n return false;\n }\n\n if (!state.documentTypes || state.documentTypes.length === 0) {\n logger.debug(\n `No document types found for document editor: ${state.name}`,\n );\n return false;\n }\n\n if (state.status !== \"CONFIRMED\") {\n logger.debug(\n `Document editor not confirmed: ${state.name} (status: ${state.status})`,\n );\n return false;\n }\n\n return true;\n }\n\n async generate(input: CodegenInput): Promise<void> {\n const state = this.extractGlobalState(input);\n if (!state) {\n logger.error(`No state found for document editor: ${input.documentId}`);\n return;\n }\n\n // Validation is already done in shouldProcess, so we can proceed directly\n logger.info(`🔄 Starting editor generation for: ${state.name}`);\n try {\n // Extract document types from the state\n const documentTypes = state.documentTypes.map((dt) => dt.documentType);\n\n // Generate editor ID using kebabCase\n const editorId: string = kebabCase(state.name);\n\n // Generate the editor using the codegen function\n await generateEditor(\n {\n ...this.config.PH_CONFIG,\n editorName: state.name,\n documentTypes: documentTypes,\n editorId: editorId,\n },\n this.project,\n );\n await this.project.save();\n\n logger.info(\n `✅ Editor generation completed successfully for: ${state.name}`,\n );\n\n // Backup the document\n const fullState = input.state as DocumentEditorPHState;\n await minimalBackupDocument(\n {\n documentId: input.documentId,\n documentType: input.documentType,\n branch: input.branch,\n state: fullState,\n name: state.name,\n },\n this.config.CURRENT_WORKING_DIR,\n );\n } catch (error) {\n logger.error(\n `❌ Error during editor generation for ${state.name}:`,\n error,\n );\n if (error instanceof Error) {\n logger.error(`❌ Error message: ${error.message}`);\n }\n // Don't throw - let codegen continue with other documents\n return;\n }\n }\n}\n","import {\n generateDocumentModel,\n validateDocumentModelState,\n} from \"@powerhousedao/codegen\";\nimport type {\n DocumentModelGlobalState,\n DocumentModelPHState,\n} from \"@powerhousedao/shared/document-model\";\nimport { logger } from \"../../logger.js\";\nimport { BaseDocumentGen } from \"../base-document-gen.js\";\nimport type { CodegenInput } from \"../types.js\";\nimport { minimalBackupDocument } from \"./utils.js\";\n\n/**\n * Generator for document model documents\n */\nexport class DocumentModelGenerator extends BaseDocumentGen {\n readonly supportedDocumentTypes = \"powerhouse/document-model\";\n\n /**\n * Parse and extract the global state from the serialized state string\n */\n private extractGlobalState(\n input: CodegenInput,\n ): DocumentModelGlobalState | undefined {\n if (!input.state) {\n return undefined;\n }\n const fullState = input.state as DocumentModelPHState;\n return fullState.global;\n }\n\n /**\n * Validate if this document model strand should be processed\n */\n shouldProcess(input: CodegenInput): boolean {\n // First run base validation\n if (!super.shouldProcess(input)) {\n return false;\n }\n\n // Extract the global state from the full document state\n const globalState = this.extractGlobalState(input);\n if (!globalState) {\n logger.debug(\n `>>> No global state found for document model: ${input.documentId}`,\n );\n return false;\n }\n\n const validationResult = validateDocumentModelState(globalState);\n if (!validationResult.isValid) {\n const errorList = validationResult.errors\n .map((error) => ` - ${error}`)\n .join(\"\\n\");\n logger.info(\n `⚠️ Skipped code generation for '${globalState.name || input.documentId}' due to validation errors:\\n${errorList}`,\n );\n return false;\n }\n\n logger.info(\n `Document model ${globalState.name} is valid, proceeding with code generation`,\n );\n\n return true;\n }\n\n async generate(input: CodegenInput): Promise<void> {\n const globalState = this.extractGlobalState(input);\n if (!globalState) {\n logger.error(\n `❌ No global state found for document model: ${input.documentId}`,\n );\n return;\n }\n // Validation is already done in shouldProcess, so we can proceed directly\n logger.debug(\n `🔄 Starting code generation for document model: ${globalState.name}`,\n );\n try {\n await generateDocumentModel(globalState, this.project);\n await this.project.save();\n logger.info(\n `✅ Code generation completed successfully for: ${globalState.name}`,\n );\n\n // Backup the document\n const fullState = input.state as DocumentModelPHState;\n const extension = globalState.extension?.replace(/^\\.+|\\.+$/g, \"\") || \"\";\n await minimalBackupDocument(\n {\n documentId: input.documentId,\n documentType: input.documentType,\n branch: input.branch,\n state: fullState,\n name: globalState.name,\n },\n this.config.CURRENT_WORKING_DIR,\n extension,\n );\n } catch (error) {\n logger.error(\n `❌ Error during code generation for ${globalState.name}:`,\n error,\n );\n // Don't throw - let codegen continue with other documents\n return;\n }\n }\n}\n","import { createOrUpdateManifest } from \"@powerhousedao/codegen/file-builders\";\nimport type {\n VetraPackageGlobalState,\n VetraPackagePHState,\n} from \"../../../../document-models/vetra-package/index.js\";\nimport { logger } from \"../../logger.js\";\nimport { BaseDocumentGen } from \"../base-document-gen.js\";\nimport type { CodegenInput } from \"../types.js\";\nimport { minimalBackupDocument } from \"./utils.js\";\n\n/**\n * Generator for package documents\n */\nexport class PackageGenerator extends BaseDocumentGen {\n readonly supportedDocumentTypes = \"powerhouse/package\";\n\n /**\n * Validate if this package strand should be processed\n */\n shouldProcess(input: CodegenInput): boolean {\n // First run base validation\n if (!super.shouldProcess(input)) {\n return false;\n }\n\n if (!input.state) {\n logger.debug(`>>> No state found for package: ${input.documentId}`);\n return false;\n }\n\n return true;\n }\n\n async generate(input: CodegenInput): Promise<void> {\n const fullState = input.state as VetraPackagePHState;\n const state = fullState.global as VetraPackageGlobalState;\n\n await createOrUpdateManifest(\n {\n name: state.name ?? \"\",\n category: state.category ?? \"\",\n description: state.description ?? \"\",\n publisher: {\n name: state.author?.name ?? \"\",\n url: state.author?.website ?? \"\",\n },\n },\n this.config.CURRENT_WORKING_DIR,\n );\n\n // Backup the document\n await minimalBackupDocument(\n {\n documentId: input.documentId,\n documentType: input.documentType,\n branch: input.branch,\n state: fullState,\n name: \"vetra-package\",\n },\n this.config.CURRENT_WORKING_DIR,\n );\n }\n}\n","import { generateProcessor } from \"@powerhousedao/codegen\";\nimport {\n PROCESSOR_APPS,\n type ProcessorApp,\n type ProcessorApps,\n} from \"@powerhousedao/shared/processors\";\nimport type {\n ProcessorModulePHState,\n ProcessorModuleState,\n} from \"../../../../document-models/processor-module/index.js\";\nimport { logger } from \"../../logger.js\";\nimport { BaseDocumentGen } from \"../base-document-gen.js\";\nimport type { CodegenInput } from \"../types.js\";\nimport { minimalBackupDocument } from \"./utils.js\";\n\n/**\n * Generator for processor documents\n */\nexport class ProcessorGenerator extends BaseDocumentGen {\n readonly supportedDocumentTypes = \"powerhouse/processor\";\n\n /**\n * Parse and extract the global state from the serialized state string\n */\n private extractGlobalState(\n input: CodegenInput,\n ): ProcessorModuleState | undefined {\n if (!input.state) {\n return undefined;\n }\n const fullState = input.state as ProcessorModulePHState;\n return fullState.global;\n }\n\n /**\n * Validate if this processor strand should be processed\n */\n shouldProcess(input: CodegenInput): boolean {\n // First run base validation\n if (!super.shouldProcess(input)) {\n return false;\n }\n\n const state = this.extractGlobalState(input);\n if (!state) {\n logger.debug(`No state found for processor: ${input.documentId}`);\n return false;\n }\n\n // Check if we have a valid processor name, type, document types, and it's confirmed\n if (!state.name) {\n logger.debug(`No name found for processor: ${input.documentId}`);\n return false;\n }\n\n if (!state.type) {\n logger.debug(`No type found for processor: ${state.name}`);\n return false;\n }\n\n if (!state.documentTypes || state.documentTypes.length === 0) {\n logger.debug(`No document types found for processor: ${state.name}`);\n return false;\n }\n\n if (!state.processorApps || state.processorApps.length === 0) {\n logger.debug(`No processor apps found for processor: ${state.name}`);\n return false;\n }\n\n if (state.status !== \"CONFIRMED\") {\n logger.debug(\n `Processor not confirmed: ${state.name} (status: ${state.status})`,\n );\n return false;\n }\n\n return true;\n }\n\n async generate(input: CodegenInput): Promise<void> {\n const state = this.extractGlobalState(input);\n if (!state) {\n logger.error(`No state found for processor: ${input.documentId}`);\n return;\n }\n\n // Check if we have a valid processor name, type, document types, and it's confirmed\n if (\n state.name &&\n state.type &&\n state.documentTypes.length > 0 &&\n state.processorApps.length > 0 &&\n state.status === \"CONFIRMED\"\n ) {\n logger.info(`🔄 Starting processor generation for: ${state.name}`);\n try {\n // Map the type value from document state to generateProcessor expected values\n let processorType: \"analytics\" | \"relationalDb\";\n if (state.type === \"analytics\") {\n processorType = \"analytics\";\n } else if (state.type === \"relational\") {\n processorType = \"relationalDb\";\n } else {\n logger.error(`❌ Unsupported processor type: ${state.type}`);\n return;\n }\n\n // Extract document types from the state\n const documentTypes = state.documentTypes.map((dt) => dt.documentType);\n\n const processorApps = state.processorApps;\n\n if (!isProcessorApps(processorApps)) {\n logger.error(\n `❌ Unsupported processor apps: ${processorApps.join(\", \")}`,\n );\n return;\n }\n\n // Generate the processor using the codegen function\n await generateProcessor(\n {\n processorName: state.name,\n processorType,\n documentTypes,\n processorApps,\n },\n this.project,\n );\n await this.project.save();\n\n logger.info(\n `✅ Processor generation completed successfully for: ${state.name}`,\n );\n\n // Backup the document\n const fullState = input.state as ProcessorModulePHState;\n await minimalBackupDocument(\n {\n documentId: input.documentId,\n documentType: input.documentType,\n branch: input.branch,\n state: fullState,\n name: state.name,\n },\n this.config.CURRENT_WORKING_DIR,\n );\n } catch (error) {\n logger.error(\n `❌ Error during processor generation for ${state.name}:`,\n error,\n );\n if (error instanceof Error) {\n logger.error(`❌ Error message: ${error.message}`);\n }\n }\n } else {\n if (!state.name) {\n logger.error(\n `❌ Skipping processor generation - missing name for processor`,\n );\n return;\n } else if (!state.type) {\n logger.error(\n `❌ Skipping processor generation - missing type for processor \"${state.name}\"`,\n );\n return;\n } else if (state.documentTypes.length === 0) {\n logger.error(\n `❌ Skipping processor generation - missing document types for processor \"${state.name}\"`,\n );\n return;\n } else if (state.status !== \"CONFIRMED\") {\n logger.error(\n `❌ Skipping processor generation - processor \"${state.name}\" is not confirmed (status: ${state.status})`,\n );\n return;\n }\n }\n }\n}\n\nfunction isProcessorApps(input: readonly string[]): input is ProcessorApps {\n if (input.length === 0) return false;\n if (new Set(input).size !== input.length) {\n return false;\n }\n if (!input.every((i) => PROCESSOR_APPS.includes(i as ProcessorApp)))\n return false;\n\n return true;\n}\n","import { generateSubgraph } from \"@powerhousedao/codegen\";\nimport type {\n SubgraphModulePHState,\n SubgraphModuleState,\n} from \"../../../../document-models/subgraph-module/index.js\";\nimport { logger } from \"../../logger.js\";\nimport { BaseDocumentGen } from \"../base-document-gen.js\";\nimport type { CodegenInput } from \"../types.js\";\nimport { minimalBackupDocument } from \"./utils.js\";\n\n/**\n * Generator for subgraph documents\n */\nexport class SubgraphGenerator extends BaseDocumentGen {\n readonly supportedDocumentTypes = \"powerhouse/subgraph\";\n\n /**\n * Parse and extract the global state from the serialized state string\n */\n private extractGlobalState(\n input: CodegenInput,\n ): SubgraphModuleState | undefined {\n if (!input.state) {\n return undefined;\n }\n const fullState = input.state as SubgraphModulePHState;\n return fullState.global;\n }\n\n /**\n * Validate if this subgraph strand should be processed\n */\n shouldProcess(input: CodegenInput): boolean {\n // First run base validation\n if (!super.shouldProcess(input)) {\n return false;\n }\n\n const state = this.extractGlobalState(input);\n if (!state) {\n logger.debug(`No state found for subgraph: ${input.documentId}`);\n return false;\n }\n\n // Check if we have a valid subgraph name and it's confirmed\n if (!state.name) {\n logger.debug(`No name found for subgraph: ${input.documentId}`);\n return false;\n }\n\n if (state.status !== \"CONFIRMED\") {\n logger.debug(\n `Subgraph not confirmed: ${state.name} (status: ${state.status})`,\n );\n return false;\n }\n\n return true;\n }\n\n async generate(input: CodegenInput): Promise<void> {\n const state = this.extractGlobalState(input);\n if (!state) {\n logger.error(`No state found for subgraph: ${input.documentId}`);\n return;\n }\n\n // Check if we have a valid subgraph name and it's confirmed\n if (state.name && state.status === \"CONFIRMED\") {\n logger.info(`🔄 Starting subgraph generation for: ${state.name}`);\n try {\n await generateSubgraph(state.name, this.project);\n await this.project.save();\n logger.info(\n `✅ Subgraph generation completed successfully for: ${state.name}`,\n );\n\n // Backup the document\n const fullState = input.state as SubgraphModulePHState;\n await minimalBackupDocument(\n {\n documentId: input.documentId,\n documentType: input.documentType,\n branch: input.branch,\n state: fullState,\n name: state.name,\n },\n this.config.CURRENT_WORKING_DIR,\n );\n } catch (error) {\n logger.error(\n `❌ Error during subgraph generation for ${state.name}:`,\n error,\n );\n }\n } else {\n if (!state.name) {\n logger.error(\n `❌ Skipping subgraph generation - missing name for subgraph`,\n );\n return;\n } else if (state.status !== \"CONFIRMED\") {\n logger.error(\n `❌ Skipping subgraph generation - subgraph \"${state.name}\" is not confirmed (status: ${state.status})`,\n );\n return;\n }\n }\n }\n}\n","import type { Project } from \"ts-morph\";\nimport type { BaseDocumentGen } from \"./base-document-gen.js\";\nimport { DocumentCodegenManager } from \"./document-codegen-manager.js\";\nimport {\n AppGenerator,\n DocumentEditorGenerator,\n DocumentModelGenerator,\n PackageGenerator,\n ProcessorGenerator,\n SubgraphGenerator,\n} from \"./generators/index.js\";\nimport type { Config } from \"./types.js\";\n\n/**\n * Factory class for creating and configuring DocumentCodegenManager instances\n * with all the standard generators pre-registered\n */\nexport class DocumentCodegenFactory {\n /**\n * Create a DocumentCodegenManager with all standard generators registered\n */\n static createManager(\n config: Config,\n project: Project,\n interactiveMode: boolean = false,\n ): DocumentCodegenManager {\n const manager = new DocumentCodegenManager(\n config,\n project,\n interactiveMode,\n );\n\n // Register all the standard generators\n manager.registerGenerator(\n \"powerhouse/document-model\",\n DocumentModelGenerator,\n );\n manager.registerGenerator(\"powerhouse/package\", PackageGenerator);\n manager.registerGenerator(\"powerhouse/app\", AppGenerator);\n manager.registerGenerator(\n \"powerhouse/document-editor\",\n DocumentEditorGenerator,\n );\n manager.registerGenerator(\"powerhouse/subgraph\", SubgraphGenerator);\n manager.registerGenerator(\"powerhouse/processor\", ProcessorGenerator);\n\n return manager;\n }\n\n /**\n * Create a DocumentCodegenManager with only specific generators\n */\n static createManagerWithGenerators(\n config: Config,\n generators: Array<new (config: Config) => any>,\n project: Project,\n interactiveMode: boolean = false,\n ): DocumentCodegenManager {\n const manager = new DocumentCodegenManager(\n config,\n project,\n interactiveMode,\n );\n\n for (const generatorClass of generators) {\n const generator = new generatorClass(config) as BaseDocumentGen;\n const supportedTypes = generator.getSupportedDocumentTypes();\n\n for (const documentType of supportedTypes) {\n manager.registerGenerator(documentType, generatorClass);\n }\n }\n\n return manager;\n }\n\n /**\n * Get all available generator classes\n */\n static getAvailableGenerators() {\n return {\n DocumentModelGenerator,\n PackageGenerator,\n AppGenerator,\n DocumentEditorGenerator,\n SubgraphGenerator,\n ProcessorGenerator,\n };\n }\n}\n","import type {\n IProcessor,\n OperationWithContext,\n} from \"@powerhousedao/reactor-browser\";\nimport type { PowerhouseConfig } from \"@powerhousedao/shared\";\nimport type { Project } from \"ts-morph\";\nimport type { DocumentCodegenManager } from \"./document-handlers/document-codegen-manager.js\";\nimport { DocumentCodegenFactory } from \"./document-handlers/index.js\";\nimport type { CodegenInput } from \"./document-handlers/types.js\";\nimport { logger } from \"./logger.js\";\n\nexport class CodegenProcessor implements IProcessor {\n private manager: DocumentCodegenManager;\n\n constructor(\n project: Project,\n config: PowerhouseConfig,\n cwd: string,\n interactiveMode = false,\n ) {\n this.manager = DocumentCodegenFactory.createManager(\n {\n PH_CONFIG: config,\n CURRENT_WORKING_DIR: cwd,\n },\n project,\n interactiveMode,\n );\n\n if (interactiveMode) {\n logger.info(`CodegenProcessor initialized with interactive mode enabled`);\n } else {\n logger.debug(\n `CodegenProcessor initialized with interactive mode disabled`,\n );\n }\n }\n\n async onOperations(operations: OperationWithContext[]): Promise<void> {\n logger.info(\"CodegenProcessor.onOperations()\");\n\n for (const { context } of operations) {\n const generator = this.manager.getGenerator(context.documentType);\n if (!generator) {\n logger.debug(\n `No generator found for document type: ${context.documentType}`,\n );\n continue;\n }\n\n const input: CodegenInput = {\n documentId: context.documentId,\n documentType: context.documentType,\n scope: context.scope,\n branch: context.branch,\n state: context.resultingState\n ? JSON.parse(context.resultingState)\n : undefined,\n };\n\n const shouldProcess = generator.shouldProcess(input);\n if (shouldProcess) {\n await this.manager.routeAndGenerate(input);\n }\n }\n }\n\n async onDisconnect() {}\n\n // Utility methods for external configuration and monitoring\n public setInteractiveMode(enabled: boolean): void {\n this.manager.setInteractiveMode(enabled);\n }\n\n public isInteractive(): boolean {\n return this.manager.isInteractiveMode();\n }\n\n public isProcessingInteractive(): boolean {\n return this.manager.isProcessingInteractive();\n }\n}\n"],"mappings":"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"}