@dxos/plugin-automation 0.8.2-main.f081794 → 0.8.2-main.fbd8ed0

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 (144) hide show
  1. package/dist/lib/browser/{AutomationContainer-KEQ5RNIW.mjs → AutomationContainer-DA6IW7O2.mjs} +3 -3
  2. package/dist/lib/browser/{AutomationPanel-G3OB6ELR.mjs → AutomationPanel-R42D3LDD.mjs} +3 -3
  3. package/dist/lib/browser/{FunctionsContainer-STXBW4CX.mjs → FunctionsContainer-MPBMMOMS.mjs} +2 -2
  4. package/dist/lib/browser/{FunctionsPanel-JJPLIAJW.mjs → FunctionsPanel-NSI3P53X.mjs} +2 -2
  5. package/dist/lib/browser/{app-graph-builder-ND64CHOM.mjs → app-graph-builder-2OGPEVBA.mjs} +13 -15
  6. package/dist/lib/browser/app-graph-builder-2OGPEVBA.mjs.map +7 -0
  7. package/dist/lib/browser/{chunk-NGG4ICAQ.mjs → chunk-2QF27UJ2.mjs} +12 -12
  8. package/dist/lib/browser/chunk-2QF27UJ2.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-ADYCSC6Y.mjs +39 -0
  10. package/dist/lib/browser/chunk-ADYCSC6Y.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-BNQNURZN.mjs +211 -0
  12. package/dist/lib/browser/chunk-BNQNURZN.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-QJPKWYTL.mjs → chunk-SGT76SL2.mjs} +5 -5
  14. package/dist/lib/browser/{chunk-65VL4EYS.mjs → chunk-TRC3J2I6.mjs} +6 -6
  15. package/dist/lib/browser/chunk-TRC3J2I6.mjs.map +7 -0
  16. package/dist/lib/browser/index.mjs +6 -6
  17. package/dist/lib/browser/index.mjs.map +1 -1
  18. package/dist/lib/browser/{intent-resolver-3J647TIZ.mjs → intent-resolver-X3H6ZSP4.mjs} +22 -16
  19. package/dist/lib/browser/intent-resolver-X3H6ZSP4.mjs.map +7 -0
  20. package/dist/lib/browser/meta.json +1 -1
  21. package/dist/lib/browser/{react-surface-L22QIANU.mjs → react-surface-MOXIHBMS.mjs} +4 -4
  22. package/dist/lib/browser/{react-surface-L22QIANU.mjs.map → react-surface-MOXIHBMS.mjs.map} +1 -1
  23. package/dist/lib/browser/types.mjs +1 -1
  24. package/dist/lib/node/{AutomationContainer-E5I76FPP.cjs → AutomationContainer-FIFH4P5T.cjs} +7 -7
  25. package/dist/lib/node/{AutomationPanel-YLXAFJDP.cjs → AutomationPanel-HTNEWBGB.cjs} +8 -8
  26. package/dist/lib/node/{AutomationPanel-YLXAFJDP.cjs.map → AutomationPanel-HTNEWBGB.cjs.map} +2 -2
  27. package/dist/lib/node/{FunctionsContainer-3HCURMEB.cjs → FunctionsContainer-LF2F6CPE.cjs} +6 -6
  28. package/dist/lib/node/{FunctionsPanel-SYIZHPGU.cjs → FunctionsPanel-6HOAIMQ3.cjs} +7 -7
  29. package/dist/lib/node/{FunctionsPanel-SYIZHPGU.cjs.map → FunctionsPanel-6HOAIMQ3.cjs.map} +2 -2
  30. package/dist/lib/node/{app-graph-builder-TVFR6RXO.cjs → app-graph-builder-3XGDVWHR.cjs} +16 -18
  31. package/dist/lib/node/app-graph-builder-3XGDVWHR.cjs.map +7 -0
  32. package/dist/lib/node/{chunk-BSK5SHTR.cjs → chunk-CBHWMYKF.cjs} +9 -9
  33. package/dist/lib/node/chunk-CBHWMYKF.cjs.map +7 -0
  34. package/dist/lib/node/{chunk-PSIJDHAX.cjs → chunk-GDCG2BML.cjs} +19 -19
  35. package/dist/lib/node/chunk-GDCG2BML.cjs.map +7 -0
  36. package/dist/lib/node/chunk-S3Z4AP77.cjs +234 -0
  37. package/dist/lib/node/chunk-S3Z4AP77.cjs.map +7 -0
  38. package/dist/lib/node/{chunk-L5TWLPGA.cjs → chunk-SV2CB3FT.cjs} +8 -8
  39. package/dist/lib/node/{chunk-SRXHHBDE.cjs → chunk-TI3WBQIB.cjs} +18 -18
  40. package/dist/lib/node/chunk-TI3WBQIB.cjs.map +7 -0
  41. package/dist/lib/node/index.cjs +13 -13
  42. package/dist/lib/node/index.cjs.map +2 -2
  43. package/dist/lib/node/{intent-resolver-4YYZ2MMZ.cjs → intent-resolver-Q7WJ4PZZ.cjs} +28 -22
  44. package/dist/lib/node/intent-resolver-Q7WJ4PZZ.cjs.map +7 -0
  45. package/dist/lib/node/meta.json +1 -1
  46. package/dist/lib/node/{react-surface-PCZCHIET.cjs → react-surface-43VHU36V.cjs} +11 -11
  47. package/dist/lib/node/react-surface-43VHU36V.cjs.map +7 -0
  48. package/dist/lib/node/types.cjs +2 -2
  49. package/dist/lib/node/types.cjs.map +1 -1
  50. package/dist/lib/node-esm/{AutomationContainer-22PUFPSE.mjs → AutomationContainer-OP43F4PD.mjs} +3 -3
  51. package/dist/lib/node-esm/{AutomationPanel-6UXIAJVS.mjs → AutomationPanel-ZQKRBWP2.mjs} +3 -3
  52. package/dist/lib/node-esm/{FunctionsContainer-XG5WVAN3.mjs → FunctionsContainer-5TVRDIX5.mjs} +2 -2
  53. package/dist/lib/node-esm/{FunctionsPanel-J3QGUESH.mjs → FunctionsPanel-NMEW26KL.mjs} +2 -2
  54. package/dist/lib/node-esm/{app-graph-builder-NYLOXWVV.mjs → app-graph-builder-UR2E5CQY.mjs} +13 -15
  55. package/dist/lib/node-esm/app-graph-builder-UR2E5CQY.mjs.map +7 -0
  56. package/dist/lib/node-esm/{chunk-4UPGANGV.mjs → chunk-AD4C4IK2.mjs} +6 -6
  57. package/dist/lib/node-esm/chunk-AD4C4IK2.mjs.map +7 -0
  58. package/dist/lib/node-esm/{chunk-TMMB5ETD.mjs → chunk-CUPEMOYK.mjs} +5 -5
  59. package/dist/lib/node-esm/{chunk-HMYAQLGF.mjs → chunk-DIUPZXCQ.mjs} +12 -12
  60. package/dist/lib/node-esm/chunk-DIUPZXCQ.mjs.map +7 -0
  61. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs +212 -0
  62. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs.map +7 -0
  63. package/dist/lib/node-esm/{chunk-YYBCQXB2.mjs → chunk-EEA6CZ6B.mjs} +16 -16
  64. package/dist/lib/node-esm/chunk-EEA6CZ6B.mjs.map +7 -0
  65. package/dist/lib/node-esm/index.mjs +6 -6
  66. package/dist/lib/node-esm/index.mjs.map +1 -1
  67. package/dist/lib/node-esm/{intent-resolver-WXIXG5UY.mjs → intent-resolver-HEUGQ6SL.mjs} +22 -16
  68. package/dist/lib/node-esm/intent-resolver-HEUGQ6SL.mjs.map +7 -0
  69. package/dist/lib/node-esm/meta.json +1 -1
  70. package/dist/lib/node-esm/{react-surface-VSO4NWC6.mjs → react-surface-TER7JEF6.mjs} +4 -4
  71. package/dist/lib/node-esm/{react-surface-VSO4NWC6.mjs.map → react-surface-TER7JEF6.mjs.map} +1 -1
  72. package/dist/lib/node-esm/types.mjs +1 -1
  73. package/dist/types/src/capabilities/app-graph-builder.d.ts +2 -179
  74. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  75. package/dist/types/src/capabilities/index.d.ts +2 -178
  76. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  77. package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
  78. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  79. package/dist/types/src/components/AutomationContainer.d.ts.map +1 -1
  80. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +1 -1
  81. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  82. package/dist/types/src/components/FunctionsContainer.d.ts.map +1 -1
  83. package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +1 -1
  84. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts +12 -0
  85. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts.map +1 -0
  86. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts +5 -0
  87. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +1 -0
  88. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -1
  89. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  90. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  91. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  92. package/dist/types/src/types.d.ts +15 -15
  93. package/dist/types/src/types.d.ts.map +1 -1
  94. package/dist/types/tsconfig.tsbuildinfo +1 -1
  95. package/package.json +31 -24
  96. package/src/AutomationPlugin.tsx +1 -1
  97. package/src/capabilities/app-graph-builder.ts +64 -41
  98. package/src/capabilities/intent-resolver.ts +25 -14
  99. package/src/capabilities/react-surface.tsx +1 -1
  100. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +2 -2
  101. package/src/components/AutomationPanel/AutomationPanel.tsx +11 -10
  102. package/src/components/FunctionsPanel/FunctionsPanel.tsx +5 -5
  103. package/src/components/TriggerEditor/FunctionInputEditor.tsx +77 -0
  104. package/src/components/TriggerEditor/SpecSelector.tsx +59 -0
  105. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +17 -8
  106. package/src/components/TriggerEditor/TriggerEditor.tsx +53 -93
  107. package/src/testing/test-functions.ts +23 -9
  108. package/src/types.ts +11 -10
  109. package/dist/lib/browser/app-graph-builder-ND64CHOM.mjs.map +0 -7
  110. package/dist/lib/browser/chunk-65VL4EYS.mjs.map +0 -7
  111. package/dist/lib/browser/chunk-FALBBJNO.mjs +0 -138
  112. package/dist/lib/browser/chunk-FALBBJNO.mjs.map +0 -7
  113. package/dist/lib/browser/chunk-FCLWFVFX.mjs +0 -39
  114. package/dist/lib/browser/chunk-FCLWFVFX.mjs.map +0 -7
  115. package/dist/lib/browser/chunk-NGG4ICAQ.mjs.map +0 -7
  116. package/dist/lib/browser/intent-resolver-3J647TIZ.mjs.map +0 -7
  117. package/dist/lib/node/app-graph-builder-TVFR6RXO.cjs.map +0 -7
  118. package/dist/lib/node/chunk-BSK5SHTR.cjs.map +0 -7
  119. package/dist/lib/node/chunk-FTEDH5Q6.cjs +0 -167
  120. package/dist/lib/node/chunk-FTEDH5Q6.cjs.map +0 -7
  121. package/dist/lib/node/chunk-PSIJDHAX.cjs.map +0 -7
  122. package/dist/lib/node/chunk-SRXHHBDE.cjs.map +0 -7
  123. package/dist/lib/node/intent-resolver-4YYZ2MMZ.cjs.map +0 -7
  124. package/dist/lib/node/react-surface-PCZCHIET.cjs.map +0 -7
  125. package/dist/lib/node-esm/app-graph-builder-NYLOXWVV.mjs.map +0 -7
  126. package/dist/lib/node-esm/chunk-4UPGANGV.mjs.map +0 -7
  127. package/dist/lib/node-esm/chunk-HMYAQLGF.mjs.map +0 -7
  128. package/dist/lib/node-esm/chunk-M4QXMIIB.mjs +0 -139
  129. package/dist/lib/node-esm/chunk-M4QXMIIB.mjs.map +0 -7
  130. package/dist/lib/node-esm/chunk-YYBCQXB2.mjs.map +0 -7
  131. package/dist/lib/node-esm/intent-resolver-WXIXG5UY.mjs.map +0 -7
  132. /package/dist/lib/browser/{AutomationContainer-KEQ5RNIW.mjs.map → AutomationContainer-DA6IW7O2.mjs.map} +0 -0
  133. /package/dist/lib/browser/{AutomationPanel-G3OB6ELR.mjs.map → AutomationPanel-R42D3LDD.mjs.map} +0 -0
  134. /package/dist/lib/browser/{FunctionsContainer-STXBW4CX.mjs.map → FunctionsContainer-MPBMMOMS.mjs.map} +0 -0
  135. /package/dist/lib/browser/{FunctionsPanel-JJPLIAJW.mjs.map → FunctionsPanel-NSI3P53X.mjs.map} +0 -0
  136. /package/dist/lib/browser/{chunk-QJPKWYTL.mjs.map → chunk-SGT76SL2.mjs.map} +0 -0
  137. /package/dist/lib/node/{AutomationContainer-E5I76FPP.cjs.map → AutomationContainer-FIFH4P5T.cjs.map} +0 -0
  138. /package/dist/lib/node/{FunctionsContainer-3HCURMEB.cjs.map → FunctionsContainer-LF2F6CPE.cjs.map} +0 -0
  139. /package/dist/lib/node/{chunk-L5TWLPGA.cjs.map → chunk-SV2CB3FT.cjs.map} +0 -0
  140. /package/dist/lib/node-esm/{AutomationContainer-22PUFPSE.mjs.map → AutomationContainer-OP43F4PD.mjs.map} +0 -0
  141. /package/dist/lib/node-esm/{AutomationPanel-6UXIAJVS.mjs.map → AutomationPanel-ZQKRBWP2.mjs.map} +0 -0
  142. /package/dist/lib/node-esm/{FunctionsContainer-XG5WVAN3.mjs.map → FunctionsContainer-5TVRDIX5.mjs.map} +0 -0
  143. /package/dist/lib/node-esm/{FunctionsPanel-J3QGUESH.mjs.map → FunctionsPanel-NMEW26KL.mjs.map} +0 -0
  144. /package/dist/lib/node-esm/{chunk-TMMB5ETD.mjs.map → chunk-CUPEMOYK.mjs.map} +0 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/react-surface.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Capabilities, contributes, createSurface, useLayout } from '@dxos/app-framework';\nimport { isInstanceOf } from '@dxos/echo-schema';\nimport { ScriptType } from '@dxos/functions';\nimport { getSpace, parseId, useSpace } from '@dxos/react-client/echo';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { AutomationContainer, AutomationPanel, FunctionsContainer } from '../components';\nimport { meta } from '../meta';\n\nexport default () =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: `${meta.id}/space-settings-automation`,\n role: 'article',\n filter: (data): data is { subject: string } => data.subject === `${meta.id}/space-settings-automation`,\n component: () => {\n const layout = useLayout();\n const { spaceId } = parseId(layout.workspace);\n const space = useSpace(spaceId);\n if (!space || !spaceId) {\n return null;\n }\n\n return <AutomationContainer space={space} />;\n },\n }),\n createSurface({\n id: `${meta.id}/space-settings-functions`,\n role: 'article',\n filter: (data): data is { subject: string } => data.subject === `${meta.id}/space-settings-functions`,\n component: () => {\n const layout = useLayout();\n const { spaceId } = parseId(layout.workspace);\n const space = useSpace(spaceId);\n if (!space || !spaceId) {\n return null;\n }\n\n return <FunctionsContainer space={space} />;\n },\n }),\n createSurface({\n id: `${meta.id}/companion/automation`,\n role: 'article',\n filter: (data): data is { companionTo: ScriptType; subject: 'automation' } =>\n isInstanceOf(ScriptType, data.companionTo) && data.subject === 'automation',\n component: ({ data, role }) => {\n return (\n <StackItem.Content role={role}>\n <AutomationPanel space={getSpace(data.companionTo)!} object={data.companionTo} />\n </StackItem.Content>\n );\n },\n }),\n ]);\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,mBAAkB;AAElB,2BAAoE;AACpE,yBAA6B;AAC7B,uBAA2B;AAC3B,kBAA4C;AAC5C,4BAA0B;AAK1B,IAAA,wBAAe,UACbA,kCAAYC,kCAAaC,cAAc;MACrCC,oCAAc;IACZC,IAAI,GAAGC,2BAAKD,EAAE;IACdE,MAAM;IACNC,QAAQ,CAACC,SAAsCA,KAAKC,YAAY,GAAGJ,2BAAKD,EAAE;IAC1EM,WAAW,MAAA;AACT,YAAMC,aAASC,gCAAAA;AACf,YAAM,EAAEC,QAAO,QAAKC,qBAAQH,OAAOI,SAAS;AAC5C,YAAMC,YAAQC,sBAASJ,OAAAA;AACvB,UAAI,CAACG,SAAS,CAACH,SAAS;AACtB,eAAO;MACT;AAEA,aAAO,6BAAAK,QAAA,cAACC,2CAAAA;QAAoBH;;IAC9B;EACF,CAAA;MACAb,oCAAc;IACZC,IAAI,GAAGC,2BAAKD,EAAE;IACdE,MAAM;IACNC,QAAQ,CAACC,SAAsCA,KAAKC,YAAY,GAAGJ,2BAAKD,EAAE;IAC1EM,WAAW,MAAA;AACT,YAAMC,aAASC,gCAAAA;AACf,YAAM,EAAEC,QAAO,QAAKC,qBAAQH,OAAOI,SAAS;AAC5C,YAAMC,YAAQC,sBAASJ,OAAAA;AACvB,UAAI,CAACG,SAAS,CAACH,SAAS;AACtB,eAAO;MACT;AAEA,aAAO,6BAAAK,QAAA,cAACE,0CAAAA;QAAmBJ;;IAC7B;EACF,CAAA;MACAb,oCAAc;IACZC,IAAI,GAAGC,2BAAKD,EAAE;IACdE,MAAM;IACNC,QAAQ,CAACC,aACPa,iCAAaC,6BAAYd,KAAKe,WAAW,KAAKf,KAAKC,YAAY;IACjEC,WAAW,CAAC,EAAEF,MAAMF,KAAI,MAAE;AACxB,aACE,6BAAAY,QAAA,cAACM,gCAAUC,SAAO;QAACnB;SACjB,6BAAAY,QAAA,cAACQ,uCAAAA;QAAgBV,WAAOW,sBAASnB,KAAKe,WAAW;QAAIK,QAAQpB,KAAKe;;IAGxE;EACF,CAAA;CACD;",
6
+ "names": ["contributes", "Capabilities", "ReactSurface", "createSurface", "id", "meta", "role", "filter", "data", "subject", "component", "layout", "useLayout", "spaceId", "parseId", "workspace", "space", "useSpace", "React", "AutomationContainer", "FunctionsContainer", "isInstanceOf", "ScriptType", "companionTo", "StackItem", "Content", "AutomationPanel", "getSpace", "object"]
7
+ }
@@ -18,10 +18,10 @@ var __copyProps = (to, from, except, desc) => {
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
19
  var types_exports = {};
20
20
  __export(types_exports, {
21
- AutomationAction: () => import_chunk_PSIJDHAX.AutomationAction
21
+ AutomationAction: () => import_chunk_GDCG2BML.AutomationAction
22
22
  });
23
23
  module.exports = __toCommonJS(types_exports);
24
- var import_chunk_PSIJDHAX = require("./chunk-PSIJDHAX.cjs");
24
+ var import_chunk_GDCG2BML = require("./chunk-GDCG2BML.cjs");
25
25
  var import_chunk_7GXNXMSM = require("./chunk-7GXNXMSM.cjs");
26
26
  // Annotate the CommonJS export names for ESM import in node:
27
27
  0 && (module.exports = {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["types.cjs"],
4
- "sourcesContent": ["import {\n AutomationAction\n} from \"./chunk-PSIJDHAX.cjs\";\nimport \"./chunk-7GXNXMSM.cjs\";\nexport {\n AutomationAction\n};\n//# sourceMappingURL=types.cjs.map\n"],
4
+ "sourcesContent": ["import {\n AutomationAction\n} from \"./chunk-GDCG2BML.cjs\";\nimport \"./chunk-7GXNXMSM.cjs\";\nexport {\n AutomationAction\n};\n//# sourceMappingURL=types.cjs.map\n"],
5
5
  "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAEO;AACP,4BAAO;",
6
6
  "names": []
7
7
  }
@@ -1,8 +1,8 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  AutomationPanel
4
- } from "./chunk-HMYAQLGF.mjs";
5
- import "./chunk-M4QXMIIB.mjs";
4
+ } from "./chunk-DIUPZXCQ.mjs";
5
+ import "./chunk-DZ7RKC52.mjs";
6
6
  import {
7
7
  AUTOMATION_PLUGIN
8
8
  } from "./chunk-DZ44LGYT.mjs";
@@ -32,4 +32,4 @@ export {
32
32
  AutomationContainer,
33
33
  AutomationContainer_default as default
34
34
  };
35
- //# sourceMappingURL=AutomationContainer-22PUFPSE.mjs.map
35
+ //# sourceMappingURL=AutomationContainer-OP43F4PD.mjs.map
@@ -2,11 +2,11 @@ import { createRequire } from 'node:module';const require = createRequire(import
2
2
  import {
3
3
  AutomationPanel,
4
4
  AutomationPanel_default
5
- } from "./chunk-HMYAQLGF.mjs";
6
- import "./chunk-M4QXMIIB.mjs";
5
+ } from "./chunk-DIUPZXCQ.mjs";
6
+ import "./chunk-DZ7RKC52.mjs";
7
7
  import "./chunk-DZ44LGYT.mjs";
8
8
  export {
9
9
  AutomationPanel,
10
10
  AutomationPanel_default as default
11
11
  };
12
- //# sourceMappingURL=AutomationPanel-6UXIAJVS.mjs.map
12
+ //# sourceMappingURL=AutomationPanel-ZQKRBWP2.mjs.map
@@ -1,7 +1,7 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  FunctionsPanel
4
- } from "./chunk-4UPGANGV.mjs";
4
+ } from "./chunk-AD4C4IK2.mjs";
5
5
  import {
6
6
  AUTOMATION_PLUGIN
7
7
  } from "./chunk-DZ44LGYT.mjs";
@@ -31,4 +31,4 @@ export {
31
31
  FunctionsContainer,
32
32
  FunctionsContainer_default as default
33
33
  };
34
- //# sourceMappingURL=FunctionsContainer-XG5WVAN3.mjs.map
34
+ //# sourceMappingURL=FunctionsContainer-5TVRDIX5.mjs.map
@@ -2,10 +2,10 @@ import { createRequire } from 'node:module';const require = createRequire(import
2
2
  import {
3
3
  FunctionsPanel,
4
4
  FunctionsPanel_default
5
- } from "./chunk-4UPGANGV.mjs";
5
+ } from "./chunk-AD4C4IK2.mjs";
6
6
  import "./chunk-DZ44LGYT.mjs";
7
7
  export {
8
8
  FunctionsPanel,
9
9
  FunctionsPanel_default as default
10
10
  };
11
- //# sourceMappingURL=FunctionsPanel-J3QGUESH.mjs.map
11
+ //# sourceMappingURL=FunctionsPanel-NMEW26KL.mjs.map
@@ -4,20 +4,20 @@ import {
4
4
  } from "./chunk-DZ44LGYT.mjs";
5
5
 
6
6
  // packages/plugins/plugin-automation/src/capabilities/app-graph-builder.ts
7
+ import { Rx } from "@effect-rx/rx-react";
8
+ import { Option, pipe } from "effect";
7
9
  import { Capabilities, contributes } from "@dxos/app-framework";
8
10
  import { isInstanceOf } from "@dxos/echo-schema";
9
11
  import { ScriptType } from "@dxos/functions";
10
12
  import { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR } from "@dxos/plugin-deck/types";
11
13
  import { createExtension } from "@dxos/plugin-graph";
12
- import { SCRIPT_PLUGIN } from "@dxos/plugin-script/types";
13
14
  import { SPACE_PLUGIN } from "@dxos/plugin-space";
14
15
  var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
15
16
  createExtension({
16
17
  id: `${meta.id}/space-settings-automation`,
17
- filter: (node) => node.type === `${SPACE_PLUGIN}/settings`,
18
- connector: ({ node }) => [
18
+ connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.type === `${SPACE_PLUGIN}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
19
19
  {
20
- id: `automation-${node.id}`,
20
+ id: `automation-${node2.id}`,
21
21
  type: `${meta.id}/space-settings-automation`,
22
22
  data: `${meta.id}/space-settings-automation`,
23
23
  properties: {
@@ -30,14 +30,13 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
30
30
  icon: "ph--lightning--regular"
31
31
  }
32
32
  }
33
- ]
33
+ ]), Option.getOrElse(() => [])))
34
34
  }),
35
35
  createExtension({
36
36
  id: `${meta.id}/space-settings-functions`,
37
- filter: (node) => node.type === `${SPACE_PLUGIN}/settings`,
38
- connector: ({ node }) => [
37
+ connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.type === `${SPACE_PLUGIN}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
39
38
  {
40
- id: `functions-${node.id}`,
39
+ id: `functions-${node2.id}`,
41
40
  type: `${meta.id}/space-settings-functions`,
42
41
  data: `${meta.id}/space-settings-functions`,
43
42
  properties: {
@@ -50,15 +49,14 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
50
49
  icon: "ph--function--regular"
51
50
  }
52
51
  }
53
- ]
52
+ ]), Option.getOrElse(() => [])))
54
53
  }),
55
54
  createExtension({
56
- id: `${SCRIPT_PLUGIN}/script-companion`,
57
- filter: (node) => isInstanceOf(ScriptType, node.data),
58
- connector: ({ node }) => [
55
+ id: `${meta.id}/script-companion`,
56
+ connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => isInstanceOf(ScriptType, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
59
57
  {
60
58
  id: [
61
- node.id,
59
+ node2.id,
62
60
  "automation"
63
61
  ].join(ATTENDABLE_PATH_SEPARATOR),
64
62
  type: PLANK_COMPANION_TYPE,
@@ -73,10 +71,10 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
73
71
  icon: "ph--lightning--regular"
74
72
  }
75
73
  }
76
- ]
74
+ ]), Option.getOrElse(() => [])))
77
75
  })
78
76
  ]);
79
77
  export {
80
78
  app_graph_builder_default as default
81
79
  };
82
- //# sourceMappingURL=app-graph-builder-NYLOXWVV.mjs.map
80
+ //# sourceMappingURL=app-graph-builder-UR2E5CQY.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/app-graph-builder.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Rx } from '@effect-rx/rx-react';\nimport { Option, pipe } from 'effect';\n\nimport { Capabilities, contributes, type PluginContext } from '@dxos/app-framework';\nimport { isInstanceOf } from '@dxos/echo-schema';\nimport { ScriptType } from '@dxos/functions';\nimport { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR } from '@dxos/plugin-deck/types';\nimport { createExtension } from '@dxos/plugin-graph';\nimport { SPACE_PLUGIN } from '@dxos/plugin-space';\n\nimport { meta } from '../meta';\n\nexport default (context: PluginContext) =>\n contributes(Capabilities.AppGraphBuilder, [\n createExtension({\n id: `${meta.id}/space-settings-automation`,\n connector: (node) =>\n Rx.make((get) =>\n pipe(\n get(node),\n Option.flatMap((node) => (node.type === `${SPACE_PLUGIN}/settings` ? Option.some(node) : Option.none())),\n Option.map((node) => [\n {\n id: `automation-${node.id}`,\n type: `${meta.id}/space-settings-automation`,\n data: `${meta.id}/space-settings-automation`,\n properties: {\n label: ['automation panel label', { ns: meta.id }],\n icon: 'ph--lightning--regular',\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n createExtension({\n id: `${meta.id}/space-settings-functions`,\n connector: (node) =>\n Rx.make((get) =>\n pipe(\n get(node),\n Option.flatMap((node) => (node.type === `${SPACE_PLUGIN}/settings` ? Option.some(node) : Option.none())),\n Option.map((node) => [\n {\n id: `functions-${node.id}`,\n type: `${meta.id}/space-settings-functions`,\n data: `${meta.id}/space-settings-functions`,\n properties: {\n label: ['functions panel label', { ns: meta.id }],\n icon: 'ph--function--regular',\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n createExtension({\n id: `${meta.id}/script-companion`,\n connector: (node) =>\n Rx.make((get) =>\n pipe(\n get(node),\n Option.flatMap((node) => (isInstanceOf(ScriptType, node.data) ? Option.some(node) : Option.none())),\n Option.map((node) => [\n {\n id: [node.id, 'automation'].join(ATTENDABLE_PATH_SEPARATOR),\n type: PLANK_COMPANION_TYPE,\n data: 'automation',\n properties: {\n label: ['script automation label', { ns: meta.id }],\n icon: 'ph--lightning--regular',\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n ]);\n"],
5
+ "mappings": ";;;;;;AAIA,SAASA,UAAU;AACnB,SAASC,QAAQC,YAAY;AAE7B,SAASC,cAAcC,mBAAuC;AAC9D,SAASC,oBAAoB;AAC7B,SAASC,kBAAkB;AAC3B,SAASC,sBAAsBC,iCAAiC;AAChE,SAASC,uBAAuB;AAChC,SAASC,oBAAoB;AAI7B,IAAA,4BAAe,CAACC,YACdC,YAAYC,aAAaC,iBAAiB;EACxCC,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UAAUA,MAAKO,SAAS,GAAGC,YAAAA,cAA0BH,OAAOI,KAAKT,KAAAA,IAAQK,OAAOK,KAAI,CAAA,GACpGL,OAAOM,IAAI,CAACX,UAAS;MACnB;QACEH,IAAI,cAAcG,MAAKH,EAAE;QACzBU,MAAM,GAAGT,KAAKD,EAAE;QAChBe,MAAM,GAAGd,KAAKD,EAAE;QAChBgB,YAAY;UACVC,OAAO;YAAC;YAA0B;cAAEC,IAAIjB,KAAKD;YAAG;;UAChDmB,MAAM;QACR;MACF;KACD,GACDX,OAAOY,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACArB,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UAAUA,MAAKO,SAAS,GAAGC,YAAAA,cAA0BH,OAAOI,KAAKT,KAAAA,IAAQK,OAAOK,KAAI,CAAA,GACpGL,OAAOM,IAAI,CAACX,UAAS;MACnB;QACEH,IAAI,aAAaG,MAAKH,EAAE;QACxBU,MAAM,GAAGT,KAAKD,EAAE;QAChBe,MAAM,GAAGd,KAAKD,EAAE;QAChBgB,YAAY;UACVC,OAAO;YAAC;YAAyB;cAAEC,IAAIjB,KAAKD;YAAG;;UAC/CmB,MAAM;QACR;MACF;KACD,GACDX,OAAOY,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACArB,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UAAUkB,aAAaC,YAAYnB,MAAKY,IAAI,IAAIP,OAAOI,KAAKT,KAAAA,IAAQK,OAAOK,KAAI,CAAA,GAC/FL,OAAOM,IAAI,CAACX,UAAS;MACnB;QACEH,IAAI;UAACG,MAAKH;UAAI;UAAcuB,KAAKC,yBAAAA;QACjCd,MAAMe;QACNV,MAAM;QACNC,YAAY;UACVC,OAAO;YAAC;YAA2B;cAAEC,IAAIjB,KAAKD;YAAG;;UACjDmB,MAAM;QACR;MACF;KACD,GACDX,OAAOY,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;CACD;",
6
+ "names": ["Rx", "Option", "pipe", "Capabilities", "contributes", "isInstanceOf", "ScriptType", "PLANK_COMPANION_TYPE", "ATTENDABLE_PATH_SEPARATOR", "createExtension", "SPACE_PLUGIN", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "meta", "connector", "node", "Rx", "make", "get", "pipe", "Option", "flatMap", "type", "SPACE_PLUGIN", "some", "none", "map", "data", "properties", "label", "ns", "icon", "getOrElse", "isInstanceOf", "ScriptType", "join", "ATTENDABLE_PATH_SEPARATOR", "PLANK_COMPANION_TYPE"]
7
+ }
@@ -4,10 +4,10 @@ import {
4
4
  } from "./chunk-DZ44LGYT.mjs";
5
5
 
6
6
  // packages/plugins/plugin-automation/src/components/FunctionsPanel/FunctionsPanel.tsx
7
+ import { Schema } from "effect";
7
8
  import React, { useCallback, useMemo } from "react";
8
9
  import { createIntent, LayoutAction, useIntentDispatcher } from "@dxos/app-framework";
9
- import { S } from "@dxos/echo-schema";
10
- import { FunctionType, ScriptType } from "@dxos/functions/types";
10
+ import { FunctionType, ScriptType } from "@dxos/functions";
11
11
  import { Filter, fullyQualifiedId, useQuery } from "@dxos/react-client/echo";
12
12
  import { Button, useTranslation } from "@dxos/react-ui";
13
13
  import { controlItemClasses } from "@dxos/react-ui-form";
@@ -16,8 +16,8 @@ import { ghostHover, mx } from "@dxos/react-ui-theme";
16
16
  var grid = "grid grid-cols-[1fr_auto] min-bs-[2.5rem]";
17
17
  var FunctionsPanel = ({ space }) => {
18
18
  const { t } = useTranslation(AUTOMATION_PLUGIN);
19
- const functions = useQuery(space, Filter.schema(FunctionType));
20
- const scripts = useQuery(space, Filter.schema(ScriptType));
19
+ const functions = useQuery(space, Filter.type(FunctionType));
20
+ const scripts = useQuery(space, Filter.type(ScriptType));
21
21
  const { dispatchPromise: dispatch } = useIntentDispatcher();
22
22
  const functionToScriptMap = useMemo(() => functions.reduce((map, func) => {
23
23
  const scriptId = func.source?.target?.id;
@@ -57,7 +57,7 @@ var FunctionsPanel = ({ space }) => {
57
57
  className: mx(controlItemClasses)
58
58
  }, /* @__PURE__ */ React.createElement(List.Root, {
59
59
  items: functions,
60
- isItem: S.is(FunctionType),
60
+ isItem: Schema.is(FunctionType),
61
61
  getId: (func) => func.id
62
62
  }, ({ items }) => /* @__PURE__ */ React.createElement("div", {
63
63
  role: "list",
@@ -86,4 +86,4 @@ export {
86
86
  FunctionsPanel,
87
87
  FunctionsPanel_default
88
88
  };
89
- //# sourceMappingURL=chunk-4UPGANGV.mjs.map
89
+ //# sourceMappingURL=chunk-AD4C4IK2.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/FunctionsPanel/FunctionsPanel.tsx", "../../../src/components/FunctionsPanel/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\nimport React, { useCallback, useMemo } from 'react';\n\nimport { createIntent, LayoutAction, useIntentDispatcher } from '@dxos/app-framework';\nimport { FunctionType, ScriptType } from '@dxos/functions';\nimport { Filter, fullyQualifiedId, useQuery, type Space } from '@dxos/react-client/echo';\nimport { Button, useTranslation } from '@dxos/react-ui';\nimport { controlItemClasses } from '@dxos/react-ui-form';\nimport { List } from '@dxos/react-ui-list';\nimport { ghostHover, mx } from '@dxos/react-ui-theme';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nconst grid = 'grid grid-cols-[1fr_auto] min-bs-[2.5rem]';\n\nexport type FunctionsPanelProps = {\n space: Space;\n};\n\nexport const FunctionsPanel = ({ space }: FunctionsPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const functions = useQuery(space, Filter.type(FunctionType));\n const scripts = useQuery(space, Filter.type(ScriptType));\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n\n const functionToScriptMap = useMemo(\n () =>\n functions.reduce(\n (map, func) => {\n const scriptId = func.source?.target?.id;\n if (scriptId) {\n const script = scripts.find((s) => s.id === scriptId);\n if (script) {\n map[func.id] = script;\n }\n }\n return map;\n },\n {} as Record<string, ScriptType>,\n ),\n [functions, scripts],\n );\n\n const getScriptName = useCallback(\n (func: FunctionType) => {\n const script = functionToScriptMap[func.id];\n return script?.name;\n },\n [functionToScriptMap],\n );\n\n const handleGoToScript = useCallback(\n (func: FunctionType) => {\n const script = functionToScriptMap[func.id];\n if (script) {\n void dispatch(createIntent(LayoutAction.Open, { part: 'main', subject: [fullyQualifiedId(script)] }));\n }\n },\n [functionToScriptMap, dispatch],\n );\n\n return (\n <div role='none' className={mx(controlItemClasses)}>\n <List.Root<FunctionType> items={functions} isItem={Schema.is(FunctionType)} getId={(func) => func.id}>\n {({ items }) => (\n <div role='list' className='flex flex-col w-full'>\n {items?.map((func) => (\n <List.Item<FunctionType>\n key={func.id}\n item={func}\n classNames={mx(grid, ghostHover, 'items-center', 'pli-2', 'min-bs-[3rem]')}\n >\n <div className='flex flex-col truncate'>\n <List.ItemTitle classNames='truncate'>{func.name}</List.ItemTitle>\n {getScriptName(func) && (\n <div className='text-xs text-description truncate'>{getScriptName(func)}</div>\n )}\n </div>\n {functionToScriptMap[func.id] && (\n <Button onClick={() => handleGoToScript(func)}>{t('go to function source button label')}</Button>\n )}\n </List.Item>\n ))}\n </div>\n )}\n </List.Root>\n\n {functions.length === 0 && <div className='text-center plb-4 text-gray-500'>{t('no functions found')}</div>}\n </div>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { FunctionsPanel } from './FunctionsPanel';\n\nexport * from './FunctionsPanel';\nexport default FunctionsPanel;\n"],
5
+ "mappings": ";;;;;;AAIA,SAASA,cAAc;AACvB,OAAOC,SAASC,aAAaC,eAAe;AAE5C,SAASC,cAAcC,cAAcC,2BAA2B;AAChE,SAASC,cAAcC,kBAAkB;AACzC,SAASC,QAAQC,kBAAkBC,gBAA4B;AAC/D,SAASC,QAAQC,sBAAsB;AACvC,SAASC,0BAA0B;AACnC,SAASC,YAAY;AACrB,SAASC,YAAYC,UAAU;AAI/B,IAAMC,OAAO;AAMN,IAAMC,iBAAiB,CAAC,EAAEC,MAAK,MAAuB;AAC3D,QAAM,EAAEC,EAAC,IAAKC,eAAeC,iBAAAA;AAC7B,QAAMC,YAAYC,SAASL,OAAOM,OAAOC,KAAKC,YAAAA,CAAAA;AAC9C,QAAMC,UAAUJ,SAASL,OAAOM,OAAOC,KAAKG,UAAAA,CAAAA;AAC5C,QAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AAEtC,QAAMC,sBAAsBC,QAC1B,MACEX,UAAUY,OACR,CAACC,KAAKC,SAAAA;AACJ,UAAMC,WAAWD,KAAKE,QAAQC,QAAQC;AACtC,QAAIH,UAAU;AACZ,YAAMI,SAASd,QAAQe,KAAK,CAACC,MAAMA,EAAEH,OAAOH,QAAAA;AAC5C,UAAII,QAAQ;AACVN,YAAIC,KAAKI,EAAE,IAAIC;MACjB;IACF;AACA,WAAON;EACT,GACA,CAAC,CAAA,GAEL;IAACb;IAAWK;GAAQ;AAGtB,QAAMiB,gBAAgBC,YACpB,CAACT,SAAAA;AACC,UAAMK,SAAST,oBAAoBI,KAAKI,EAAE;AAC1C,WAAOC,QAAQK;EACjB,GACA;IAACd;GAAoB;AAGvB,QAAMe,mBAAmBF,YACvB,CAACT,SAAAA;AACC,UAAMK,SAAST,oBAAoBI,KAAKI,EAAE;AAC1C,QAAIC,QAAQ;AACV,WAAKX,SAASkB,aAAaC,aAAaC,MAAM;QAAEC,MAAM;QAAQC,SAAS;UAACC,iBAAiBZ,MAAAA;;MAAS,CAAA,CAAA;IACpG;EACF,GACA;IAACT;IAAqBF;GAAS;AAGjC,SACE,sBAAA,cAACwB,OAAAA;IAAIC,MAAK;IAAOC,WAAWC,GAAGC,kBAAAA;KAC7B,sBAAA,cAACC,KAAKC,MAAI;IAAeC,OAAOvC;IAAWwC,QAAQC,OAAOC,GAAGtC,YAAAA;IAAeuC,OAAO,CAAC7B,SAASA,KAAKI;KAC/F,CAAC,EAAEqB,MAAK,MACP,sBAAA,cAACP,OAAAA;IAAIC,MAAK;IAAOC,WAAU;KACxBK,OAAO1B,IAAI,CAACC,SACX,sBAAA,cAACuB,KAAKO,MAAI;IACRC,KAAK/B,KAAKI;IACV4B,MAAMhC;IACNiC,YAAYZ,GAAGzC,MAAMsD,YAAY,gBAAgB,SAAS,eAAA;KAE1D,sBAAA,cAAChB,OAAAA;IAAIE,WAAU;KACb,sBAAA,cAACG,KAAKY,WAAS;IAACF,YAAW;KAAYjC,KAAKU,IAAI,GAC/CF,cAAcR,IAAAA,KACb,sBAAA,cAACkB,OAAAA;IAAIE,WAAU;KAAqCZ,cAAcR,IAAAA,CAAAA,CAAAA,GAGrEJ,oBAAoBI,KAAKI,EAAE,KAC1B,sBAAA,cAACgC,QAAAA;IAAOC,SAAS,MAAM1B,iBAAiBX,IAAAA;KAAQjB,EAAE,oCAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAQ7DG,UAAUoD,WAAW,KAAK,sBAAA,cAACpB,OAAAA;IAAIE,WAAU;KAAmCrC,EAAE,oBAAA,CAAA,CAAA;AAGrF;;;ACvFA,IAAA,yBAAewD;",
6
+ "names": ["Schema", "React", "useCallback", "useMemo", "createIntent", "LayoutAction", "useIntentDispatcher", "FunctionType", "ScriptType", "Filter", "fullyQualifiedId", "useQuery", "Button", "useTranslation", "controlItemClasses", "List", "ghostHover", "mx", "grid", "FunctionsPanel", "space", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "type", "FunctionType", "scripts", "ScriptType", "dispatchPromise", "dispatch", "useIntentDispatcher", "functionToScriptMap", "useMemo", "reduce", "map", "func", "scriptId", "source", "target", "id", "script", "find", "s", "getScriptName", "useCallback", "name", "handleGoToScript", "createIntent", "LayoutAction", "Open", "part", "subject", "fullyQualifiedId", "div", "role", "className", "mx", "controlItemClasses", "List", "Root", "items", "isItem", "Schema", "is", "getId", "Item", "key", "item", "classNames", "ghostHover", "ItemTitle", "Button", "onClick", "length", "FunctionsPanel"]
7
+ }
@@ -2,10 +2,10 @@ import { createRequire } from 'node:module';const require = createRequire(import
2
2
 
3
3
  // packages/plugins/plugin-automation/src/components/index.ts
4
4
  import { lazy } from "react";
5
- var AutomationContainer = lazy(() => import("./AutomationContainer-22PUFPSE.mjs"));
6
- var AutomationPanel = lazy(() => import("./AutomationPanel-6UXIAJVS.mjs"));
7
- var FunctionsContainer = lazy(() => import("./FunctionsContainer-XG5WVAN3.mjs"));
8
- var FunctionsPanel = lazy(() => import("./FunctionsPanel-J3QGUESH.mjs"));
5
+ var AutomationContainer = lazy(() => import("./AutomationContainer-OP43F4PD.mjs"));
6
+ var AutomationPanel = lazy(() => import("./AutomationPanel-ZQKRBWP2.mjs"));
7
+ var FunctionsContainer = lazy(() => import("./FunctionsContainer-5TVRDIX5.mjs"));
8
+ var FunctionsPanel = lazy(() => import("./FunctionsPanel-NMEW26KL.mjs"));
9
9
 
10
10
  export {
11
11
  AutomationContainer,
@@ -13,4 +13,4 @@ export {
13
13
  FunctionsContainer,
14
14
  FunctionsPanel
15
15
  };
16
- //# sourceMappingURL=chunk-TMMB5ETD.mjs.map
16
+ //# sourceMappingURL=chunk-CUPEMOYK.mjs.map
@@ -1,15 +1,15 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  TriggerEditor
4
- } from "./chunk-M4QXMIIB.mjs";
4
+ } from "./chunk-DZ7RKC52.mjs";
5
5
  import {
6
6
  AUTOMATION_PLUGIN
7
7
  } from "./chunk-DZ44LGYT.mjs";
8
8
 
9
9
  // packages/plugins/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
10
+ import { Schema } from "effect";
10
11
  import React, { useState } from "react";
11
- import { S } from "@dxos/echo-schema";
12
- import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions/types";
12
+ import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions";
13
13
  import { useClient } from "@dxos/react-client";
14
14
  import { live, Filter, useQuery, getSpace } from "@dxos/react-client/echo";
15
15
  import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
@@ -20,9 +20,9 @@ var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
20
20
  var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
21
21
  const { t } = useTranslation(AUTOMATION_PLUGIN);
22
22
  const client = useClient();
23
- const triggers = useQuery(space, Filter.schema(FunctionTrigger));
24
- const functions = useQuery(space, Filter.schema(FunctionType));
25
- const scripts = useQuery(space, Filter.schema(ScriptType));
23
+ const triggers = useQuery(space, Filter.type(FunctionTrigger));
24
+ const functions = useQuery(space, Filter.type(FunctionType));
25
+ const scripts = useQuery(space, Filter.type(ScriptType));
26
26
  const [trigger, setTrigger] = useState(initialTrigger);
27
27
  const [selected, setSelected] = useState();
28
28
  const handleSelect = (trigger2) => {
@@ -67,7 +67,7 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
67
67
  className: controlItemClasses
68
68
  }, /* @__PURE__ */ React.createElement(List.Root, {
69
69
  items: triggers,
70
- isItem: S.is(FunctionTrigger),
70
+ isItem: Schema.is(FunctionTrigger),
71
71
  getId: (field) => field.id
72
72
  }, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
73
73
  role: "list",
@@ -101,13 +101,13 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
101
101
  })));
102
102
  };
103
103
  var getCopyAction = (client, trigger) => {
104
- if (trigger?.spec?.type === TriggerKind.Email) {
104
+ if (trigger?.spec?.kind === TriggerKind.Email) {
105
105
  return {
106
106
  translationKey: "trigger copy email",
107
107
  contentProvider: () => `${getSpace(trigger).id}@dxos.network`
108
108
  };
109
109
  }
110
- if (trigger?.spec?.type === TriggerKind.Webhook) {
110
+ if (trigger?.spec?.kind === TriggerKind.Webhook) {
111
111
  return {
112
112
  translationKey: "trigger copy url",
113
113
  contentProvider: () => getWebhookUrl(client, trigger)
@@ -123,8 +123,8 @@ var getWebhookUrl = (client, trigger) => {
123
123
  return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
124
124
  };
125
125
  var getFunctionName = (scripts, functions, trigger) => {
126
- const shortId = trigger.function && `${trigger.function?.slice(0, 16)}\u2026`;
127
- const functionObject = functions.find((fn) => `dxn:worker:${fn.name}` === trigger.function);
126
+ const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
127
+ const functionObject = functions.find((fn) => fn === trigger.function?.target);
128
128
  if (!functionObject) {
129
129
  return shortId;
130
130
  }
@@ -138,4 +138,4 @@ export {
138
138
  AutomationPanel,
139
139
  AutomationPanel_default
140
140
  };
141
- //# sourceMappingURL=chunk-HMYAQLGF.mjs.map
141
+ //# sourceMappingURL=chunk-DIUPZXCQ.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/AutomationPanel/AutomationPanel.tsx", "../../../src/components/AutomationPanel/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Schema } from 'effect';\nimport React, { useState } from 'react';\n\nimport {\n FunctionType,\n FunctionTrigger,\n FunctionTriggerSchema,\n TriggerKind,\n type FunctionTriggerType,\n ScriptType,\n} from '@dxos/functions';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { live, Filter, useQuery, type Space, type Live, getSpace } from '@dxos/react-client/echo';\nimport { Clipboard, IconButton, Input, Separator, useTranslation } from '@dxos/react-ui';\nimport { ControlItem, controlItemClasses } from '@dxos/react-ui-form';\nimport { List } from '@dxos/react-ui-list';\nimport { ghostHover, mx } from '@dxos/react-ui-theme';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\nimport { TriggerEditor, type TriggerEditorProps } from '../TriggerEditor';\n\nconst grid = 'grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]';\n\nexport type AutomationPanelProps = {\n space: Space;\n object?: Live<any>;\n initialTrigger?: FunctionTriggerType;\n onDone?: () => void;\n};\n\n// TODO(burdon): Factor out common layout with ViewEditor.\nexport const AutomationPanel = ({ space, object, initialTrigger, onDone }: AutomationPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const client = useClient();\n const triggers = useQuery(space, Filter.type(FunctionTrigger));\n const functions = useQuery(space, Filter.type(FunctionType));\n const scripts = useQuery(space, Filter.type(ScriptType));\n\n const [trigger, setTrigger] = useState<FunctionTriggerType | undefined>(initialTrigger);\n const [selected, setSelected] = useState<FunctionTrigger>();\n\n const handleSelect = (trigger: FunctionTrigger) => {\n const { id: _, ...values } = trigger;\n setTrigger(values);\n setSelected(trigger);\n };\n\n const handleAdd = () => {\n setTrigger(live(FunctionTriggerSchema, {}));\n setSelected(undefined);\n };\n\n const handleDelete = (trigger: FunctionTrigger) => {\n space.db.remove(trigger);\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleSave: TriggerEditorProps['onSave'] = (trigger) => {\n if (selected) {\n Object.assign(selected, trigger);\n } else {\n space.db.add(live(FunctionTrigger, trigger));\n }\n\n setTrigger(undefined);\n setSelected(undefined);\n onDone?.();\n };\n\n const handleCancel: TriggerEditorProps['onCancel'] = () => {\n setTrigger(undefined);\n onDone?.();\n };\n\n return (\n <div className='flex flex-col w-full'>\n {trigger ? (\n <ControlItem title={t('trigger editor title')}>\n <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />\n </ControlItem>\n ) : (\n <div role='none' className={controlItemClasses}>\n <List.Root<FunctionTrigger> items={triggers} isItem={Schema.is(FunctionTrigger)} getId={(field) => field.id}>\n {({ items: triggers }) => (\n <div role='list' className='flex flex-col w-full'>\n {triggers?.map((trigger) => {\n const copyAction = getCopyAction(client, trigger);\n return (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center', 'px-2')}\n >\n <Input.Root>\n <Input.Switch\n checked={trigger.enabled}\n onCheckedChange={(checked) => (trigger.enabled = checked)}\n />\n </Input.Root>\n\n <div className={'flex'}>\n <List.ItemTitle\n classNames='px-1 cursor-pointer w-0 shrink truncate'\n onClick={() => handleSelect(trigger)}\n >\n {getFunctionName(scripts, functions, trigger) ?? '∅'}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose copy action */}\n {copyAction && (\n <Clipboard.IconButton\n label={t(copyAction.translationKey)}\n value={copyAction.contentProvider()}\n />\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n {triggers.length > 0 && <Separator classNames='mlb-4' />}\n <IconButton icon='ph--plus--regular' label={t('new trigger label')} onClick={handleAdd} />\n </div>\n )}\n </div>\n );\n};\n\nconst getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {\n if (trigger?.spec?.kind === TriggerKind.Email) {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.kind === TriggerKind.Webhook) {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {\n const spaceId = getSpace(trigger)!.id;\n const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);\n const isSecure = edgeUrl.protocol.startsWith('https') || edgeUrl.protocol.startsWith('wss');\n edgeUrl.protocol = isSecure ? 'https' : 'http';\n return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();\n};\n\nconst getFunctionName = (scripts: ScriptType[], functions: FunctionType[], trigger: FunctionTriggerType) => {\n // TODO(wittjosiah): Truncation should be done in the UI.\n // Warning that the List component is currently a can of worms.\n const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}…`;\n const functionObject = functions.find((fn) => fn === trigger.function?.target);\n if (!functionObject) {\n return shortId;\n }\n\n return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { AutomationPanel } from './AutomationPanel';\n\nexport * from './AutomationPanel';\n\nexport default AutomationPanel;\n"],
5
+ "mappings": "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",
6
+ "names": ["Schema", "React", "useState", "FunctionType", "FunctionTrigger", "FunctionTriggerSchema", "TriggerKind", "ScriptType", "useClient", "live", "Filter", "useQuery", "getSpace", "Clipboard", "IconButton", "Input", "Separator", "useTranslation", "ControlItem", "controlItemClasses", "List", "ghostHover", "mx", "grid", "AutomationPanel", "space", "object", "initialTrigger", "onDone", "t", "useTranslation", "AUTOMATION_PLUGIN", "client", "useClient", "triggers", "useQuery", "Filter", "type", "FunctionTrigger", "functions", "FunctionType", "scripts", "ScriptType", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "id", "_", "values", "handleAdd", "live", "FunctionTriggerSchema", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "div", "className", "ControlItem", "title", "TriggerEditor", "onSave", "onCancel", "role", "controlItemClasses", "List", "Root", "items", "isItem", "Schema", "is", "getId", "field", "map", "copyAction", "getCopyAction", "Item", "key", "item", "classNames", "mx", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "Clipboard", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "length", "Separator", "icon", "spec", "kind", "TriggerKind", "Email", "getSpace", "Webhook", "getWebhookUrl", "spaceId", "edgeUrl", "URL", "config", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "shortId", "function", "dxn", "slice", "functionObject", "find", "fn", "target", "s", "source", "name", "AutomationPanel"]
7
+ }
@@ -0,0 +1,212 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ AUTOMATION_PLUGIN
4
+ } from "./chunk-DZ44LGYT.mjs";
5
+
6
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
7
+ import React3, { useCallback as useCallback3, useMemo as useMemo3 } from "react";
8
+ import { ComputeGraph } from "@dxos/conductor";
9
+ import { DXN } from "@dxos/echo";
10
+ import { FunctionType, FunctionTriggerSchema, ScriptType } from "@dxos/functions";
11
+ import { Filter, Ref, useQuery } from "@dxos/react-client/echo";
12
+ import { useTranslation as useTranslation2 } from "@dxos/react-ui";
13
+ import { Form as Form2, SelectInput as SelectInput2, useRefQueryLookupHandler } from "@dxos/react-ui-form";
14
+
15
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/FunctionInputEditor.tsx
16
+ import React, { useCallback, useMemo } from "react";
17
+ import { RefImpl, toEffectSchema } from "@dxos/echo-schema";
18
+ import { useOnTransition } from "@dxos/react-ui";
19
+ import { Form, useFormValues } from "@dxos/react-ui-form";
20
+ var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
21
+ const selectedFunctionValue = useFormValues([
22
+ "function"
23
+ ]);
24
+ const selectedFunctionId = useMemo(() => {
25
+ if (selectedFunctionValue instanceof RefImpl) {
26
+ return selectedFunctionValue.dxn.toString().split("dxn:echo:@:").at(1);
27
+ }
28
+ }, [
29
+ selectedFunctionValue
30
+ ]);
31
+ const selectedFunction = useMemo(() => functions.find((f) => f.id === selectedFunctionId), [
32
+ functions,
33
+ selectedFunctionId
34
+ ]);
35
+ useOnTransition(
36
+ // Clear function parameter input when the function changes.
37
+ selectedFunctionValue,
38
+ (prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
39
+ (currValue) => currValue !== void 0,
40
+ () => onValueChange("object", {})
41
+ );
42
+ const inputSchema = useMemo(() => selectedFunction?.inputSchema, [
43
+ selectedFunction
44
+ ]);
45
+ const effectSchema = useMemo(() => inputSchema ? toEffectSchema(inputSchema) : void 0, [
46
+ inputSchema
47
+ ]);
48
+ const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
49
+ const values = useMemo(() => getValue() ?? {}, [
50
+ getValue
51
+ ]);
52
+ const handleValuesChanged = useCallback((values2) => {
53
+ onValueChange("object", values2);
54
+ }, [
55
+ onValueChange
56
+ ]);
57
+ if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
58
+ return null;
59
+ }
60
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("h3", {
61
+ className: "text-md"
62
+ }, "Function parameters"), /* @__PURE__ */ React.createElement(Form, {
63
+ schema: effectSchema,
64
+ values,
65
+ classNames: "p-0",
66
+ onValuesChanged: handleValuesChanged,
67
+ onQueryRefOptions
68
+ }));
69
+ };
70
+
71
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/SpecSelector.tsx
72
+ import React2, { useCallback as useCallback2, useMemo as useMemo2 } from "react";
73
+ import { TriggerKind } from "@dxos/functions";
74
+ import { useTranslation } from "@dxos/react-ui";
75
+ import { SelectInput, useInputProps } from "@dxos/react-ui-form";
76
+ var SpecSelector = (props) => {
77
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
78
+ const specProps = useInputProps([
79
+ "spec"
80
+ ]);
81
+ const handleTypeChange = useCallback2((_type, value) => {
82
+ const getDefaultTriggerSpec = (kind) => {
83
+ switch (kind) {
84
+ case TriggerKind.Timer:
85
+ return {
86
+ kind: TriggerKind.Timer,
87
+ cron: ""
88
+ };
89
+ case TriggerKind.Subscription:
90
+ return {
91
+ kind: TriggerKind.Subscription,
92
+ filter: {}
93
+ };
94
+ case TriggerKind.Queue:
95
+ return {
96
+ kind: TriggerKind.Queue,
97
+ queue: ""
98
+ };
99
+ case TriggerKind.Email:
100
+ return {
101
+ kind: TriggerKind.Email
102
+ };
103
+ case TriggerKind.Webhook:
104
+ return {
105
+ kind: TriggerKind.Webhook
106
+ };
107
+ default:
108
+ return void 0;
109
+ }
110
+ };
111
+ const defaultSpec = getDefaultTriggerSpec(value);
112
+ if (!defaultSpec) {
113
+ return;
114
+ }
115
+ specProps.onValueChange("object", defaultSpec);
116
+ }, [
117
+ specProps
118
+ ]);
119
+ const options = useMemo2(() => Object.values(TriggerKind).map((kind) => ({
120
+ value: kind,
121
+ label: t(`trigger type ${kind}`)
122
+ })), [
123
+ t
124
+ ]);
125
+ return /* @__PURE__ */ React2.createElement(SelectInput, {
126
+ ...props,
127
+ options,
128
+ onValueChange: handleTypeChange
129
+ });
130
+ };
131
+
132
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
133
+ var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
134
+ const { t } = useTranslation2(AUTOMATION_PLUGIN);
135
+ const functions = useQuery(space, Filter.type(FunctionType));
136
+ const workflows = useQuery(space, Filter.type(ComputeGraph));
137
+ const scripts = useQuery(space, Filter.type(ScriptType));
138
+ const handleSave = (values) => {
139
+ onSave?.(values);
140
+ };
141
+ const handleRefQueryLookup = useRefQueryLookupHandler({
142
+ space
143
+ });
144
+ const Custom = useMemo3(() => ({
145
+ ["function"]: (props) => {
146
+ const getValue = useCallback3(() => {
147
+ const formValue = props.getValue();
148
+ if (Ref.isRef(formValue)) {
149
+ return formValue.dxn.toString();
150
+ }
151
+ return void 0;
152
+ }, [
153
+ props
154
+ ]);
155
+ const handleOnValueChange = useCallback3((_type, dxnString) => {
156
+ const dxn = DXN.parse(dxnString);
157
+ if (dxn) {
158
+ const ref = Ref.fromDXN(dxn);
159
+ props.onValueChange("object", ref);
160
+ }
161
+ }, [
162
+ props.onValueChange
163
+ ]);
164
+ return /* @__PURE__ */ React3.createElement(SelectInput2, {
165
+ ...props,
166
+ getValue,
167
+ onValueChange: handleOnValueChange,
168
+ options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
169
+ });
170
+ },
171
+ ["spec.kind"]: SpecSelector,
172
+ ["input"]: (props) => /* @__PURE__ */ React3.createElement(FunctionInputEditor, {
173
+ ...props,
174
+ functions,
175
+ onQueryRefOptions: handleRefQueryLookup
176
+ })
177
+ }), [
178
+ workflows,
179
+ scripts,
180
+ functions,
181
+ t
182
+ ]);
183
+ return /* @__PURE__ */ React3.createElement("div", {
184
+ role: "none",
185
+ className: "bs-full is-full"
186
+ }, /* @__PURE__ */ React3.createElement(Form2, {
187
+ schema: FunctionTriggerSchema,
188
+ values: trigger,
189
+ onSave: handleSave,
190
+ onCancel,
191
+ Custom,
192
+ onQueryRefOptions: handleRefQueryLookup
193
+ }));
194
+ };
195
+ var getWorkflowOptions = (graphs) => {
196
+ return graphs.map((graph) => ({
197
+ label: `compute-${graph.id}`,
198
+ value: `dxn:echo:@:${graph.id}`
199
+ }));
200
+ };
201
+ var getFunctionOptions = (scripts, functions) => {
202
+ const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
203
+ return functions.map((fn) => ({
204
+ label: getLabel(fn),
205
+ value: `dxn:echo:@:${fn.id}`
206
+ }));
207
+ };
208
+
209
+ export {
210
+ TriggerEditor
211
+ };
212
+ //# sourceMappingURL=chunk-DZ7RKC52.mjs.map