@dxos/plugin-automation 0.8.2-main.fbd8ed0 → 0.8.2-staging.4d6ad0f

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 (120) hide show
  1. package/dist/lib/browser/AutomationContainer-HQK7FTN6.mjs +40 -0
  2. package/dist/lib/{node-esm/AutomationContainer-OP43F4PD.mjs.map → browser/AutomationContainer-HQK7FTN6.mjs.map} +1 -1
  3. package/dist/lib/browser/AutomationPanel-GU37N5LO.mjs +11 -0
  4. package/dist/lib/browser/FunctionsContainer-B7RDWVMX.mjs +39 -0
  5. package/dist/lib/{node-esm/FunctionsContainer-5TVRDIX5.mjs.map → browser/FunctionsContainer-B7RDWVMX.mjs.map} +1 -1
  6. package/dist/lib/browser/{FunctionsPanel-NSI3P53X.mjs → FunctionsPanel-LCCPDIT6.mjs} +3 -3
  7. package/dist/lib/browser/{app-graph-builder-2OGPEVBA.mjs → app-graph-builder-BYECL42X.mjs} +4 -3
  8. package/dist/lib/browser/{app-graph-builder-2OGPEVBA.mjs.map → app-graph-builder-BYECL42X.mjs.map} +3 -3
  9. package/dist/lib/browser/{chunk-ADYCSC6Y.mjs → chunk-4E2KPMLB.mjs} +3 -3
  10. package/dist/lib/{node-esm/chunk-EEA6CZ6B.mjs.map → browser/chunk-4E2KPMLB.mjs.map} +1 -1
  11. package/dist/lib/browser/chunk-4QTXMPBC.mjs +229 -0
  12. package/dist/lib/browser/chunk-4QTXMPBC.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-D2ESAYQD.mjs +149 -0
  14. package/dist/lib/browser/chunk-D2ESAYQD.mjs.map +7 -0
  15. package/dist/lib/browser/{chunk-SGT76SL2.mjs → chunk-ELQ2FX5G.mjs} +5 -5
  16. package/dist/lib/browser/{chunk-WKKQV4PC.mjs → chunk-IHAKPP5A.mjs} +2 -2
  17. package/dist/lib/browser/{chunk-WKKQV4PC.mjs.map → chunk-IHAKPP5A.mjs.map} +1 -1
  18. package/dist/lib/browser/chunk-ZTRYR6RJ.mjs +94 -0
  19. package/dist/lib/{node-esm/chunk-AD4C4IK2.mjs.map → browser/chunk-ZTRYR6RJ.mjs.map} +1 -1
  20. package/dist/lib/browser/index.mjs +6 -6
  21. package/dist/lib/browser/{intent-resolver-X3H6ZSP4.mjs → intent-resolver-ZRBBYZUX.mjs} +3 -3
  22. package/dist/lib/browser/meta.json +1 -1
  23. package/dist/lib/browser/{react-surface-MOXIHBMS.mjs → react-surface-VKO6PA2P.mjs} +4 -4
  24. package/dist/lib/browser/types.mjs +2 -2
  25. package/dist/lib/node/{AutomationContainer-FIFH4P5T.cjs → AutomationContainer-5J7LJK7L.cjs} +26 -20
  26. package/dist/lib/node/{AutomationContainer-FIFH4P5T.cjs.map → AutomationContainer-5J7LJK7L.cjs.map} +1 -1
  27. package/dist/lib/node/{AutomationPanel-HTNEWBGB.cjs → AutomationPanel-NPDBUQ7D.cjs} +9 -9
  28. package/dist/lib/node/{AutomationPanel-HTNEWBGB.cjs.map → AutomationPanel-NPDBUQ7D.cjs.map} +2 -2
  29. package/dist/lib/node/{FunctionsContainer-LF2F6CPE.cjs → FunctionsContainer-LNLDZUZ6.cjs} +25 -19
  30. package/dist/lib/node/{FunctionsContainer-LF2F6CPE.cjs.map → FunctionsContainer-LNLDZUZ6.cjs.map} +1 -1
  31. package/dist/lib/node/{FunctionsPanel-6HOAIMQ3.cjs → FunctionsPanel-7AOXIQMA.cjs} +8 -8
  32. package/dist/lib/node/FunctionsPanel-7AOXIQMA.cjs.map +7 -0
  33. package/dist/lib/node/{app-graph-builder-3XGDVWHR.cjs → app-graph-builder-DUKR2BRB.cjs} +17 -16
  34. package/dist/lib/node/{app-graph-builder-3XGDVWHR.cjs.map → app-graph-builder-DUKR2BRB.cjs.map} +3 -3
  35. package/dist/lib/node/{chunk-7GXNXMSM.cjs → chunk-3EF7MLFX.cjs} +5 -5
  36. package/dist/lib/node/{chunk-7GXNXMSM.cjs.map → chunk-3EF7MLFX.cjs.map} +1 -1
  37. package/dist/lib/node/chunk-4O627QZU.cjs +175 -0
  38. package/dist/lib/node/chunk-4O627QZU.cjs.map +7 -0
  39. package/dist/lib/node/{chunk-SV2CB3FT.cjs → chunk-DOLMQUQ5.cjs} +8 -8
  40. package/dist/lib/node/{chunk-GDCG2BML.cjs → chunk-GIIVTK4O.cjs} +7 -7
  41. package/dist/lib/node/{chunk-GDCG2BML.cjs.map → chunk-GIIVTK4O.cjs.map} +1 -1
  42. package/dist/lib/node/chunk-O42NQYQT.cjs +252 -0
  43. package/dist/lib/node/chunk-O42NQYQT.cjs.map +7 -0
  44. package/dist/lib/node/chunk-WXQAVUBJ.cjs +122 -0
  45. package/dist/lib/node/{chunk-CBHWMYKF.cjs.map → chunk-WXQAVUBJ.cjs.map} +1 -1
  46. package/dist/lib/node/index.cjs +20 -20
  47. package/dist/lib/node/{intent-resolver-Q7WJ4PZZ.cjs → intent-resolver-JC4Q4TYU.cjs} +7 -7
  48. package/dist/lib/node/meta.json +1 -1
  49. package/dist/lib/node/{react-surface-43VHU36V.cjs → react-surface-HB3MYTCK.cjs} +15 -15
  50. package/dist/lib/node/types.cjs +3 -3
  51. package/dist/lib/node/types.cjs.map +1 -1
  52. package/dist/lib/node-esm/AutomationContainer-OJGH76X2.mjs +41 -0
  53. package/dist/lib/{browser/AutomationContainer-DA6IW7O2.mjs.map → node-esm/AutomationContainer-OJGH76X2.mjs.map} +1 -1
  54. package/dist/lib/node-esm/{AutomationPanel-ZQKRBWP2.mjs → AutomationPanel-HIWEJUWL.mjs} +4 -4
  55. package/dist/lib/node-esm/FunctionsContainer-PPR6XNNR.mjs +40 -0
  56. package/dist/lib/{browser/FunctionsContainer-MPBMMOMS.mjs.map → node-esm/FunctionsContainer-PPR6XNNR.mjs.map} +1 -1
  57. package/dist/lib/node-esm/{FunctionsPanel-NMEW26KL.mjs → FunctionsPanel-SBXKWTHR.mjs} +3 -3
  58. package/dist/lib/node-esm/{app-graph-builder-UR2E5CQY.mjs → app-graph-builder-UAXHKKGW.mjs} +4 -3
  59. package/dist/lib/node-esm/{app-graph-builder-UR2E5CQY.mjs.map → app-graph-builder-UAXHKKGW.mjs.map} +3 -3
  60. package/dist/lib/node-esm/chunk-5IAHBEHR.mjs +95 -0
  61. package/dist/lib/{browser/chunk-TRC3J2I6.mjs.map → node-esm/chunk-5IAHBEHR.mjs.map} +1 -1
  62. package/dist/lib/node-esm/{chunk-EEA6CZ6B.mjs → chunk-6JOJ2NN4.mjs} +3 -3
  63. package/dist/lib/{browser/chunk-ADYCSC6Y.mjs.map → node-esm/chunk-6JOJ2NN4.mjs.map} +1 -1
  64. package/dist/lib/node-esm/chunk-D5HK4XLC.mjs +230 -0
  65. package/dist/lib/node-esm/chunk-D5HK4XLC.mjs.map +7 -0
  66. package/dist/lib/node-esm/{chunk-DZ44LGYT.mjs → chunk-HCCLRNMJ.mjs} +2 -2
  67. package/dist/lib/node-esm/{chunk-DZ44LGYT.mjs.map → chunk-HCCLRNMJ.mjs.map} +1 -1
  68. package/dist/lib/node-esm/chunk-P2FKMPRE.mjs +150 -0
  69. package/dist/lib/node-esm/chunk-P2FKMPRE.mjs.map +7 -0
  70. package/dist/lib/node-esm/{chunk-CUPEMOYK.mjs → chunk-Z7VAQDEE.mjs} +5 -5
  71. package/dist/lib/node-esm/index.mjs +6 -6
  72. package/dist/lib/node-esm/{intent-resolver-HEUGQ6SL.mjs → intent-resolver-KRCXJEDR.mjs} +3 -3
  73. package/dist/lib/node-esm/meta.json +1 -1
  74. package/dist/lib/node-esm/{react-surface-TER7JEF6.mjs → react-surface-TRKCIZAB.mjs} +4 -4
  75. package/dist/lib/node-esm/types.mjs +2 -2
  76. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  77. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  78. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  79. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  80. package/package.json +27 -26
  81. package/src/capabilities/app-graph-builder.ts +1 -0
  82. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +3 -2
  83. package/src/components/AutomationPanel/AutomationPanel.tsx +14 -10
  84. package/src/components/TriggerEditor/TriggerEditor.tsx +29 -27
  85. package/src/meta.ts +1 -1
  86. package/src/testing/test-functions.ts +5 -5
  87. package/dist/lib/browser/AutomationContainer-DA6IW7O2.mjs +0 -34
  88. package/dist/lib/browser/AutomationPanel-R42D3LDD.mjs +0 -11
  89. package/dist/lib/browser/FunctionsContainer-MPBMMOMS.mjs +0 -33
  90. package/dist/lib/browser/chunk-2QF27UJ2.mjs +0 -140
  91. package/dist/lib/browser/chunk-2QF27UJ2.mjs.map +0 -7
  92. package/dist/lib/browser/chunk-BNQNURZN.mjs +0 -211
  93. package/dist/lib/browser/chunk-BNQNURZN.mjs.map +0 -7
  94. package/dist/lib/browser/chunk-TRC3J2I6.mjs +0 -88
  95. package/dist/lib/node/FunctionsPanel-6HOAIMQ3.cjs.map +0 -7
  96. package/dist/lib/node/chunk-CBHWMYKF.cjs +0 -116
  97. package/dist/lib/node/chunk-S3Z4AP77.cjs +0 -234
  98. package/dist/lib/node/chunk-S3Z4AP77.cjs.map +0 -7
  99. package/dist/lib/node/chunk-TI3WBQIB.cjs +0 -166
  100. package/dist/lib/node/chunk-TI3WBQIB.cjs.map +0 -7
  101. package/dist/lib/node-esm/AutomationContainer-OP43F4PD.mjs +0 -35
  102. package/dist/lib/node-esm/FunctionsContainer-5TVRDIX5.mjs +0 -34
  103. package/dist/lib/node-esm/chunk-AD4C4IK2.mjs +0 -89
  104. package/dist/lib/node-esm/chunk-DIUPZXCQ.mjs +0 -141
  105. package/dist/lib/node-esm/chunk-DIUPZXCQ.mjs.map +0 -7
  106. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs +0 -212
  107. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs.map +0 -7
  108. /package/dist/lib/browser/{AutomationPanel-R42D3LDD.mjs.map → AutomationPanel-GU37N5LO.mjs.map} +0 -0
  109. /package/dist/lib/browser/{FunctionsPanel-NSI3P53X.mjs.map → FunctionsPanel-LCCPDIT6.mjs.map} +0 -0
  110. /package/dist/lib/browser/{chunk-SGT76SL2.mjs.map → chunk-ELQ2FX5G.mjs.map} +0 -0
  111. /package/dist/lib/browser/{intent-resolver-X3H6ZSP4.mjs.map → intent-resolver-ZRBBYZUX.mjs.map} +0 -0
  112. /package/dist/lib/browser/{react-surface-MOXIHBMS.mjs.map → react-surface-VKO6PA2P.mjs.map} +0 -0
  113. /package/dist/lib/node/{chunk-SV2CB3FT.cjs.map → chunk-DOLMQUQ5.cjs.map} +0 -0
  114. /package/dist/lib/node/{intent-resolver-Q7WJ4PZZ.cjs.map → intent-resolver-JC4Q4TYU.cjs.map} +0 -0
  115. /package/dist/lib/node/{react-surface-43VHU36V.cjs.map → react-surface-HB3MYTCK.cjs.map} +0 -0
  116. /package/dist/lib/node-esm/{AutomationPanel-ZQKRBWP2.mjs.map → AutomationPanel-HIWEJUWL.mjs.map} +0 -0
  117. /package/dist/lib/node-esm/{FunctionsPanel-NMEW26KL.mjs.map → FunctionsPanel-SBXKWTHR.mjs.map} +0 -0
  118. /package/dist/lib/node-esm/{chunk-CUPEMOYK.mjs.map → chunk-Z7VAQDEE.mjs.map} +0 -0
  119. /package/dist/lib/node-esm/{intent-resolver-HEUGQ6SL.mjs.map → intent-resolver-KRCXJEDR.mjs.map} +0 -0
  120. /package/dist/lib/node-esm/{react-surface-TER7JEF6.mjs.map → react-surface-TRKCIZAB.mjs.map} +0 -0
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/components/FunctionsPanel/FunctionsPanel.tsx", "../../../src/components/FunctionsPanel/index.ts"],
4
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;",
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,UAAM,EAAEC,EAAC,IAAKC,eAAeC,iBAAAA;AAC7B,UAAMC,YAAYC,SAASL,OAAOM,OAAOC,KAAKC,YAAAA,CAAAA;AAC9C,UAAMC,UAAUJ,SAASL,OAAOM,OAAOC,KAAKG,UAAAA,CAAAA;AAC5C,UAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AAEtC,UAAMC,sBAAsBC,QAC1B,MACEX,UAAUY,OACR,CAACC,KAAKC,SAAAA;AACJ,YAAMC,WAAWD,KAAKE,QAAQC,QAAQC;AACtC,UAAIH,UAAU;AACZ,cAAMI,SAASd,QAAQe,KAAK,CAACC,MAAMA,EAAEH,OAAOH,QAAAA;AAC5C,YAAII,QAAQ;AACVN,cAAIC,KAAKI,EAAE,IAAIC;QACjB;MACF;AACA,aAAON;IACT,GACA,CAAC,CAAA,GAEL;MAACb;MAAWK;KAAQ;AAGtB,UAAMiB,gBAAgBC,YACpB,CAACT,SAAAA;AACC,YAAMK,SAAST,oBAAoBI,KAAKI,EAAE;AAC1C,aAAOC,QAAQK;IACjB,GACA;MAACd;KAAoB;AAGvB,UAAMe,mBAAmBF,YACvB,CAACT,SAAAA;AACC,YAAMK,SAAST,oBAAoBI,KAAKI,EAAE;AAC1C,UAAIC,QAAQ;AACV,aAAKX,SAASkB,aAAaC,aAAaC,MAAM;UAAEC,MAAM;UAAQC,SAAS;YAACC,iBAAiBZ,MAAAA;;QAAS,CAAA,CAAA;MACpG;IACF,GACA;MAACT;MAAqBF;KAAS;AAGjC,WACE,sBAAA,cAACwB,OAAAA;MAAIC,MAAK;MAAOC,WAAWC,GAAGC,kBAAAA;OAC7B,sBAAA,cAACC,KAAKC,MAAI;MAAeC,OAAOvC;MAAWwC,QAAQC,OAAOC,GAAGtC,YAAAA;MAAeuC,OAAO,CAAC7B,SAASA,KAAKI;OAC/F,CAAC,EAAEqB,MAAK,MACP,sBAAA,cAACP,OAAAA;MAAIC,MAAK;MAAOC,WAAU;OACxBK,OAAO1B,IAAI,CAACC,SACX,sBAAA,cAACuB,KAAKO,MAAI;MACRC,KAAK/B,KAAKI;MACV4B,MAAMhC;MACNiC,YAAYZ,GAAGzC,MAAMsD,YAAY,gBAAgB,SAAS,eAAA;OAE1D,sBAAA,cAAChB,OAAAA;MAAIE,WAAU;OACb,sBAAA,cAACG,KAAKY,WAAS;MAACF,YAAW;OAAYjC,KAAKU,IAAI,GAC/CF,cAAcR,IAAAA,KACb,sBAAA,cAACkB,OAAAA;MAAIE,WAAU;OAAqCZ,cAAcR,IAAAA,CAAAA,CAAAA,GAGrEJ,oBAAoBI,KAAKI,EAAE,KAC1B,sBAAA,cAACgC,QAAAA;MAAOC,SAAS,MAAM1B,iBAAiBX,IAAAA;OAAQjB,EAAE,oCAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAQ7DG,UAAUoD,WAAW,KAAK,sBAAA,cAACpB,OAAAA;MAAIE,WAAU;OAAmCrC,EAAE,oBAAA,CAAA,CAAA;;;;AAGrF;;;ACvFA,IAAA,yBAAewD;",
6
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
7
  }
@@ -1,7 +1,7 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  AUTOMATION_PLUGIN
4
- } from "./chunk-DZ44LGYT.mjs";
4
+ } from "./chunk-HCCLRNMJ.mjs";
5
5
 
6
6
  // packages/plugins/plugin-automation/src/types.ts
7
7
  import { Schema } from "effect";
@@ -13,7 +13,6 @@ var TriggerTemplate = Schema.Union(Schema.Struct({
13
13
  type: Schema.Literal("queue"),
14
14
  queueDXN: Schema.Any
15
15
  }));
16
- var AutomationAction;
17
16
  (function(AutomationAction2) {
18
17
  const AUTOMATION_ACTION = `${AUTOMATION_PLUGIN}/action`;
19
18
  class CreateTriggerFromTemplate extends Schema.TaggedClass()(`${AUTOMATION_ACTION}/create-trigger-from-template`, {
@@ -33,8 +32,9 @@ var AutomationAction;
33
32
  }
34
33
  AutomationAction2.CreateTriggerFromTemplate = CreateTriggerFromTemplate;
35
34
  })(AutomationAction || (AutomationAction = {}));
35
+ var AutomationAction;
36
36
 
37
37
  export {
38
38
  AutomationAction
39
39
  };
40
- //# sourceMappingURL=chunk-EEA6CZ6B.mjs.map
40
+ //# sourceMappingURL=chunk-6JOJ2NN4.mjs.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/types.ts"],
4
4
  "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { SpaceSchema } from '@dxos/react-client/echo';\n\nimport { AUTOMATION_PLUGIN } from './meta';\n\nconst TriggerTemplate = Schema.Union(\n Schema.Struct({ type: Schema.Literal('timer'), cron: Schema.String }),\n Schema.Struct({ type: Schema.Literal('queue'), queueDXN: Schema.Any }),\n);\n\nexport namespace AutomationAction {\n const AUTOMATION_ACTION = `${AUTOMATION_PLUGIN}/action`;\n\n export class CreateTriggerFromTemplate extends Schema.TaggedClass<CreateTriggerFromTemplate>()(\n `${AUTOMATION_ACTION}/create-trigger-from-template`,\n {\n input: Schema.Struct({\n space: SpaceSchema,\n template: TriggerTemplate,\n enabled: Schema.optional(Schema.Boolean),\n // TODO(wittjosiah): Improve how this lookup is done.\n scriptName: Schema.optional(Schema.String),\n input: Schema.optional(Schema.Record({ key: Schema.String, value: Schema.Any })),\n }),\n output: Schema.Void,\n },\n ) {}\n}\n"],
5
- "mappings": ";;;;;AAIA,SAASA,cAAc;AAEvB,SAASC,mBAAmB;AAI5B,IAAMC,kBAAkBC,OAAOC,MAC7BD,OAAOE,OAAO;EAAEC,MAAMH,OAAOI,QAAQ,OAAA;EAAUC,MAAML,OAAOM;AAAO,CAAA,GACnEN,OAAOE,OAAO;EAAEC,MAAMH,OAAOI,QAAQ,OAAA;EAAUG,UAAUP,OAAOQ;AAAI,CAAA,CAAA;;UAGrDC,mBAAAA;AACf,QAAMC,oBAAoB,GAAGC,iBAAAA;EAEtB,MAAMC,kCAAkCZ,OAAOa,YAAW,EAC/D,GAAGH,iBAAAA,iCACH;IACEI,OAAOd,OAAOE,OAAO;MACnBa,OAAOC;MACPC,UAAUlB;MACVmB,SAASlB,OAAOmB,SAASnB,OAAOoB,OAAO;;MAEvCC,YAAYrB,OAAOmB,SAASnB,OAAOM,MAAM;MACzCQ,OAAOd,OAAOmB,SAASnB,OAAOsB,OAAO;QAAEC,KAAKvB,OAAOM;QAAQkB,OAAOxB,OAAOQ;MAAI,CAAA,CAAA;IAC/E,CAAA;IACAiB,QAAQzB,OAAO0B;EACjB,CAAA,EAAA;EACC;oBAbUd,4BAAAA;AAcf,GAjBiBH,qBAAAA,mBAAAA,CAAAA,EAAAA;",
5
+ "mappings": ";;;;;;AAIA,SAASA,cAAc;AAEvB,SAASC,mBAAmB;AAI5B,IAAMC,kBAAkBC,OAAOC,MAC7BD,OAAOE,OAAO;EAAEC,MAAMH,OAAOI,QAAQ,OAAA;EAAUC,MAAML,OAAOM;AAAO,CAAA,GACnEN,OAAOE,OAAO;EAAEC,MAAMH,OAAOI,QAAQ,OAAA;EAAUG,UAAUP,OAAOQ;AAAI,CAAA,CAAA;UAGrDC,mBAAAA;AACf,QAAMC,oBAAoB,GAAGC,iBAAAA;EAEtB,MAAMC,kCAAkCZ,OAAOa,YAAW,EAC/D,GAAGH,iBAAAA,iCACH;IACEI,OAAOd,OAAOE,OAAO;MACnBa,OAAOC;MACPC,UAAUlB;MACVmB,SAASlB,OAAOmB,SAASnB,OAAOoB,OAAO;;MAEvCC,YAAYrB,OAAOmB,SAASnB,OAAOM,MAAM;MACzCQ,OAAOd,OAAOmB,SAASnB,OAAOsB,OAAO;QAAEC,KAAKvB,OAAOM;QAAQkB,OAAOxB,OAAOQ;MAAI,CAAA,CAAA;IAC/E,CAAA;IACAiB,QAAQzB,OAAO0B;EACjB,CAAA,EAAA;EACC;oBAbUd,4BAAAA;AAcf,GAjBiBH,qBAAAA,mBAAAA,CAAAA,EAAAA;;",
6
6
  "names": ["Schema", "SpaceSchema", "TriggerTemplate", "Schema", "Union", "Struct", "type", "Literal", "cron", "String", "queueDXN", "Any", "AutomationAction", "AUTOMATION_ACTION", "AUTOMATION_PLUGIN", "CreateTriggerFromTemplate", "TaggedClass", "input", "space", "SpaceSchema", "template", "enabled", "optional", "Boolean", "scriptName", "Record", "key", "value", "output", "Void"]
7
7
  }
@@ -0,0 +1,230 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ AUTOMATION_PLUGIN
4
+ } from "./chunk-HCCLRNMJ.mjs";
5
+
6
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
7
+ import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
8
+ import React3, { useCallback as useCallback3, useMemo as useMemo3 } from "react";
9
+ import { ComputeGraph } from "@dxos/conductor";
10
+ import { Type } from "@dxos/echo";
11
+ import { FunctionType, FunctionTriggerSchema, ScriptType } from "@dxos/functions";
12
+ import { Filter, Ref, useQuery } from "@dxos/react-client/echo";
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 { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
17
+ import React, { useCallback, useMemo } from "react";
18
+ import { RefImpl, toEffectSchema } from "@dxos/echo-schema";
19
+ import { useOnTransition } from "@dxos/react-ui";
20
+ import { Form, useFormValues } from "@dxos/react-ui-form";
21
+ var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
22
+ var _effect = _useSignals();
23
+ try {
24
+ const selectedFunctionValue = useFormValues([
25
+ "function"
26
+ ]);
27
+ const selectedFunctionId = useMemo(() => {
28
+ if (selectedFunctionValue instanceof RefImpl) {
29
+ return selectedFunctionValue.dxn.toString().split("dxn:echo:@:").at(1);
30
+ }
31
+ }, [
32
+ selectedFunctionValue
33
+ ]);
34
+ const selectedFunction = useMemo(() => functions.find((f) => f.id === selectedFunctionId), [
35
+ functions,
36
+ selectedFunctionId
37
+ ]);
38
+ useOnTransition(
39
+ // Clear function parameter input when the function changes.
40
+ selectedFunctionValue,
41
+ (prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
42
+ (currValue) => currValue !== void 0,
43
+ () => onValueChange("object", {})
44
+ );
45
+ const inputSchema = useMemo(() => selectedFunction?.inputSchema, [
46
+ selectedFunction
47
+ ]);
48
+ const effectSchema = useMemo(() => inputSchema ? toEffectSchema(inputSchema) : void 0, [
49
+ inputSchema
50
+ ]);
51
+ const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
52
+ const values = useMemo(() => getValue() ?? {}, [
53
+ getValue
54
+ ]);
55
+ const handleValuesChanged = useCallback((values2) => {
56
+ onValueChange("object", values2);
57
+ }, [
58
+ onValueChange
59
+ ]);
60
+ if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
61
+ return null;
62
+ }
63
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("h3", {
64
+ className: "text-md"
65
+ }, "Function parameters"), /* @__PURE__ */ React.createElement(Form, {
66
+ schema: effectSchema,
67
+ values,
68
+ classNames: "p-0",
69
+ onValuesChanged: handleValuesChanged,
70
+ onQueryRefOptions
71
+ }));
72
+ } finally {
73
+ _effect.f();
74
+ }
75
+ };
76
+
77
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/SpecSelector.tsx
78
+ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
79
+ import React2, { useCallback as useCallback2, useMemo as useMemo2 } from "react";
80
+ import { TriggerKind } from "@dxos/functions";
81
+ import { useTranslation } from "@dxos/react-ui";
82
+ import { SelectInput, useInputProps } from "@dxos/react-ui-form";
83
+ var SpecSelector = (props) => {
84
+ var _effect = _useSignals2();
85
+ try {
86
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
87
+ const specProps = useInputProps([
88
+ "spec"
89
+ ]);
90
+ const handleTypeChange = useCallback2((_type, value) => {
91
+ const getDefaultTriggerSpec = (kind) => {
92
+ switch (kind) {
93
+ case TriggerKind.Timer:
94
+ return {
95
+ kind: TriggerKind.Timer,
96
+ cron: ""
97
+ };
98
+ case TriggerKind.Subscription:
99
+ return {
100
+ kind: TriggerKind.Subscription,
101
+ filter: {}
102
+ };
103
+ case TriggerKind.Queue:
104
+ return {
105
+ kind: TriggerKind.Queue,
106
+ queue: ""
107
+ };
108
+ case TriggerKind.Email:
109
+ return {
110
+ kind: TriggerKind.Email
111
+ };
112
+ case TriggerKind.Webhook:
113
+ return {
114
+ kind: TriggerKind.Webhook
115
+ };
116
+ default:
117
+ return void 0;
118
+ }
119
+ };
120
+ const defaultSpec = getDefaultTriggerSpec(value);
121
+ if (!defaultSpec) {
122
+ return;
123
+ }
124
+ specProps.onValueChange("object", defaultSpec);
125
+ }, [
126
+ specProps
127
+ ]);
128
+ const options = useMemo2(() => Object.values(TriggerKind).map((kind) => ({
129
+ value: kind,
130
+ label: t(`trigger type ${kind}`)
131
+ })), [
132
+ t
133
+ ]);
134
+ return /* @__PURE__ */ React2.createElement(SelectInput, {
135
+ ...props,
136
+ options,
137
+ onValueChange: handleTypeChange
138
+ });
139
+ } finally {
140
+ _effect.f();
141
+ }
142
+ };
143
+
144
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
145
+ var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
146
+ var _effect = _useSignals3();
147
+ try {
148
+ const handleSave = (values) => {
149
+ onSave?.(values);
150
+ };
151
+ const handleRefQueryLookup = useRefQueryLookupHandler({
152
+ space
153
+ });
154
+ const Custom = useCustomInputs(space, handleRefQueryLookup);
155
+ return /* @__PURE__ */ React3.createElement(Form2, {
156
+ Custom,
157
+ schema: FunctionTriggerSchema,
158
+ values: trigger,
159
+ onSave: handleSave,
160
+ onCancel,
161
+ onQueryRefOptions: handleRefQueryLookup
162
+ });
163
+ } finally {
164
+ _effect.f();
165
+ }
166
+ };
167
+ var useCustomInputs = (space, onQueryRefOptions) => {
168
+ const functions = useQuery(space, Filter.type(FunctionType));
169
+ const workflows = useQuery(space, Filter.type(ComputeGraph));
170
+ const scripts = useQuery(space, Filter.type(ScriptType));
171
+ return useMemo3(() => ({
172
+ // Function selector.
173
+ ["function"]: (props) => {
174
+ const getValue = useCallback3(() => {
175
+ const formValue = props.getValue();
176
+ if (Ref.isRef(formValue)) {
177
+ return formValue.dxn.toString();
178
+ }
179
+ return void 0;
180
+ }, [
181
+ props
182
+ ]);
183
+ const handleOnValueChange = useCallback3((_type, dxnString) => {
184
+ const dxn = Type.DXN.parse(dxnString);
185
+ if (dxn) {
186
+ const ref = Ref.fromDXN(dxn);
187
+ props.onValueChange("object", ref);
188
+ }
189
+ }, [
190
+ props.onValueChange
191
+ ]);
192
+ return /* @__PURE__ */ React3.createElement(SelectInput2, {
193
+ ...props,
194
+ getValue,
195
+ onValueChange: handleOnValueChange,
196
+ options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
197
+ });
198
+ },
199
+ // Spec selector.
200
+ ["spec.kind"]: SpecSelector,
201
+ // Function input editor.
202
+ ["input"]: (props) => /* @__PURE__ */ React3.createElement(FunctionInputEditor, {
203
+ ...props,
204
+ functions,
205
+ onQueryRefOptions
206
+ })
207
+ }), [
208
+ workflows,
209
+ scripts,
210
+ functions
211
+ ]);
212
+ };
213
+ var getWorkflowOptions = (graphs) => {
214
+ return graphs.map((graph) => ({
215
+ label: `compute-${graph.id}`,
216
+ value: `dxn:echo:@:${graph.id}`
217
+ }));
218
+ };
219
+ var getFunctionOptions = (scripts, functions) => {
220
+ const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
221
+ return functions.map((fn) => ({
222
+ label: getLabel(fn),
223
+ value: `dxn:echo:@:${fn.id}`
224
+ }));
225
+ };
226
+
227
+ export {
228
+ TriggerEditor
229
+ };
230
+ //# sourceMappingURL=chunk-D5HK4XLC.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx", "../../../src/components/TriggerEditor/FunctionInputEditor.tsx", "../../../src/components/TriggerEditor/SpecSelector.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { ComputeGraph } from '@dxos/conductor';\nimport { Type } from '@dxos/echo';\nimport {\n FunctionType,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n type FunctionTrigger,\n ScriptType,\n} from '@dxos/functions';\nimport { Filter, Ref, useQuery, type Space } from '@dxos/react-client/echo';\nimport { type CustomInputMap, Form, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nimport { FunctionInputEditor, type FunctionInputEditorProps } from './FunctionInputEditor';\nimport { SpecSelector } from './SpecSelector';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTriggerType;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {\n const handleSave = (values: FunctionTriggerType) => {\n onSave?.(values);\n };\n\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n const Custom = useCustomInputs(space, handleRefQueryLookup);\n\n return (\n <Form\n Custom={Custom}\n schema={FunctionTriggerSchema}\n values={trigger}\n onSave={handleSave}\n onCancel={onCancel}\n onQueryRefOptions={handleRefQueryLookup}\n />\n );\n};\n\nconst useCustomInputs = (space: Space, onQueryRefOptions: FunctionInputEditorProps['onQueryRefOptions']) => {\n const functions = useQuery(space, Filter.type(FunctionType));\n const workflows = useQuery(space, Filter.type(ComputeGraph));\n const scripts = useQuery(space, Filter.type(ScriptType));\n\n return useMemo(\n (): CustomInputMap => ({\n // Function selector.\n ['function' satisfies keyof FunctionTriggerType]: (props) => {\n const getValue = useCallback(() => {\n const formValue = props.getValue();\n if (Ref.isRef(formValue)) {\n return formValue.dxn.toString() as string;\n }\n return undefined;\n }, [props]);\n\n const handleOnValueChange = useCallback(\n (_type: any, dxnString: string) => {\n const dxn = Type.DXN.parse(dxnString);\n if (dxn) {\n const ref = Ref.fromDXN(dxn);\n props.onValueChange('object', ref);\n }\n },\n [props.onValueChange],\n );\n\n return (\n <SelectInput\n {...props}\n getValue={getValue as any}\n onValueChange={handleOnValueChange}\n options={getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))}\n />\n );\n },\n\n // Spec selector.\n ['spec.kind' as const]: SpecSelector,\n\n // Function input editor.\n ['input' as const]: (props) => (\n <FunctionInputEditor {...props} functions={functions} onQueryRefOptions={onQueryRefOptions} />\n ),\n }),\n [workflows, scripts, functions],\n );\n};\n\nconst getWorkflowOptions = (graphs: ComputeGraph[]) => {\n return graphs.map((graph) => ({ label: `compute-${graph.id}`, value: `dxn:echo:@:${graph.id}` }));\n};\n\nconst getFunctionOptions = (scripts: ScriptType[], functions: FunctionType[]) => {\n const getLabel = (fn: FunctionType) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;\n return functions.map((fn) => ({ label: getLabel(fn), value: `dxn:echo:@:${fn.id}` }));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { type JsonPath, RefImpl, toEffectSchema } from '@dxos/echo-schema';\nimport { type FunctionType } from '@dxos/functions';\nimport { useOnTransition } from '@dxos/react-ui';\nimport { Form, type FormInputStateProps, type QueryRefOptions, useFormValues } from '@dxos/react-ui-form';\n\nexport type FunctionInputEditorProps = {\n functions: FunctionType[];\n onQueryRefOptions: QueryRefOptions;\n} & FormInputStateProps;\n\n/**\n * Editor component for function input parameters.\n */\nexport const FunctionInputEditor = ({\n functions,\n getValue,\n onValueChange,\n onQueryRefOptions,\n}: FunctionInputEditorProps) => {\n const selectedFunctionValue = useFormValues(['function' as JsonPath]);\n const selectedFunctionId = useMemo(() => {\n if (selectedFunctionValue instanceof RefImpl) {\n return selectedFunctionValue.dxn.toString().split('dxn:echo:@:').at(1);\n }\n }, [selectedFunctionValue]);\n\n const selectedFunction = useMemo(\n () => functions.find((f) => f.id === selectedFunctionId),\n [functions, selectedFunctionId],\n );\n\n useOnTransition(\n // Clear function parameter input when the function changes.\n selectedFunctionValue,\n (prevValue) => prevValue !== undefined && prevValue !== selectedFunctionValue,\n (currValue) => currValue !== undefined,\n () => onValueChange('object', {}),\n );\n\n const inputSchema = useMemo(() => selectedFunction?.inputSchema, [selectedFunction]);\n const effectSchema = useMemo(() => (inputSchema ? toEffectSchema(inputSchema) : undefined), [inputSchema]);\n const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;\n\n const values = useMemo(() => getValue() ?? {}, [getValue]);\n\n const handleValuesChanged = useCallback(\n (values: any) => {\n onValueChange('object', values);\n },\n [onValueChange],\n );\n\n if (selectedFunction === undefined || effectSchema === undefined || propertyCount === 0) {\n return null;\n }\n\n return (\n <>\n <h3 className='text-md'>Function parameters</h3>\n {/* TODO(ZaymonFC): Try using <FormFields /> internal component for this nesting.\n This would allow errors to flow up to the root context. */}\n <Form\n schema={effectSchema}\n values={values}\n classNames='p-0'\n onValuesChanged={handleValuesChanged}\n onQueryRefOptions={onQueryRefOptions}\n />\n </>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { type FunctionTriggerType, TriggerKind, type TriggerType } from '@dxos/functions';\nimport { useTranslation } from '@dxos/react-ui';\nimport { SelectInput, type InputProps, useInputProps } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type SpecSelectorProps = InputProps;\n\nexport const SpecSelector = (props: SpecSelectorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const specProps = useInputProps(['spec' satisfies keyof FunctionTriggerType]);\n\n const handleTypeChange = useCallback(\n (_type: any, value: string): TriggerType | undefined => {\n const getDefaultTriggerSpec = (kind: string) => {\n switch (kind) {\n case TriggerKind.Timer:\n return { kind: TriggerKind.Timer, cron: '' };\n case TriggerKind.Subscription:\n return { kind: TriggerKind.Subscription, filter: {} };\n case TriggerKind.Queue:\n return { kind: TriggerKind.Queue, queue: '' };\n case TriggerKind.Email:\n return { kind: TriggerKind.Email };\n case TriggerKind.Webhook:\n return { kind: TriggerKind.Webhook };\n default:\n return undefined;\n }\n };\n\n const defaultSpec = getDefaultTriggerSpec(value);\n if (!defaultSpec) {\n return;\n }\n\n // Update the entire spec object, not just the `spec.kind`.\n specProps.onValueChange('object', defaultSpec);\n },\n [specProps],\n );\n\n const options = useMemo(\n () =>\n Object.values(TriggerKind).map((kind) => ({\n value: kind,\n label: t(`trigger type ${kind}`),\n })),\n [t],\n );\n\n return <SelectInput {...props} options={options} onValueChange={handleTypeChange} />;\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "useCallback", "useMemo", "ComputeGraph", "Type", "FunctionType", "FunctionTriggerSchema", "ScriptType", "Filter", "Ref", "useQuery", "Form", "SelectInput", "useRefQueryLookupHandler", "React", "useCallback", "useMemo", "RefImpl", "toEffectSchema", "useOnTransition", "Form", "useFormValues", "FunctionInputEditor", "functions", "getValue", "onValueChange", "onQueryRefOptions", "selectedFunctionValue", "useFormValues", "selectedFunctionId", "useMemo", "RefImpl", "dxn", "toString", "split", "at", "selectedFunction", "find", "f", "id", "useOnTransition", "prevValue", "undefined", "currValue", "inputSchema", "effectSchema", "toEffectSchema", "propertyCount", "properties", "Object", "keys", "length", "values", "handleValuesChanged", "useCallback", "h3", "className", "Form", "schema", "classNames", "onValuesChanged", "React", "useCallback", "useMemo", "TriggerKind", "useTranslation", "SelectInput", "useInputProps", "SpecSelector", "props", "t", "useTranslation", "AUTOMATION_PLUGIN", "specProps", "useInputProps", "handleTypeChange", "useCallback", "_type", "value", "getDefaultTriggerSpec", "kind", "TriggerKind", "Timer", "cron", "Subscription", "filter", "Queue", "queue", "Email", "Webhook", "undefined", "defaultSpec", "onValueChange", "options", "useMemo", "Object", "values", "map", "label", "React", "SelectInput", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "handleSave", "values", "handleRefQueryLookup", "useRefQueryLookupHandler", "Custom", "useCustomInputs", "React", "Form", "schema", "FunctionTriggerSchema", "onQueryRefOptions", "functions", "useQuery", "Filter", "type", "FunctionType", "workflows", "ComputeGraph", "scripts", "ScriptType", "useMemo", "props", "getValue", "useCallback", "formValue", "Ref", "isRef", "dxn", "toString", "undefined", "handleOnValueChange", "_type", "dxnString", "Type", "DXN", "parse", "ref", "fromDXN", "onValueChange", "SelectInput", "options", "getWorkflowOptions", "concat", "getFunctionOptions", "SpecSelector", "FunctionInputEditor", "graphs", "map", "graph", "label", "id", "value", "getLabel", "fn", "find", "s", "source", "target", "name"]
7
+ }
@@ -7,11 +7,11 @@ var meta = {
7
7
  name: "Automation",
8
8
  description: "The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.",
9
9
  icon: "ph--robot--regular",
10
- source: "https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-automation"
10
+ source: "https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-automation"
11
11
  };
12
12
 
13
13
  export {
14
14
  AUTOMATION_PLUGIN,
15
15
  meta
16
16
  };
17
- //# sourceMappingURL=chunk-DZ44LGYT.mjs.map
17
+ //# sourceMappingURL=chunk-HCCLRNMJ.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/meta.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const AUTOMATION_PLUGIN = 'dxos.org/plugin/automation';\n\nexport const meta: PluginMeta = {\n id: AUTOMATION_PLUGIN,\n name: 'Automation',\n description:\n 'The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.',\n icon: 'ph--robot--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-automation',\n};\n"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const AUTOMATION_PLUGIN = 'dxos.org/plugin/automation';\n\nexport const meta: PluginMeta = {\n id: AUTOMATION_PLUGIN,\n name: 'Automation',\n description:\n 'The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.',\n icon: 'ph--robot--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-automation',\n};\n"],
5
5
  "mappings": ";;;AAMO,IAAMA,oBAAoB;AAE1B,IAAMC,OAAmB;EAC9BC,IAAIF;EACJG,MAAM;EACNC,aACE;EACFC,MAAM;EACNC,QAAQ;AACV;",
6
6
  "names": ["AUTOMATION_PLUGIN", "meta", "id", "name", "description", "icon", "source"]
7
7
  }
@@ -0,0 +1,150 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ TriggerEditor
4
+ } from "./chunk-D5HK4XLC.mjs";
5
+ import {
6
+ AUTOMATION_PLUGIN
7
+ } from "./chunk-HCCLRNMJ.mjs";
8
+
9
+ // packages/plugins/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
10
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
11
+ import { Schema } from "effect";
12
+ import React, { useState } from "react";
13
+ import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions";
14
+ import { useClient } from "@dxos/react-client";
15
+ import { live, Filter, useQuery, getSpace } from "@dxos/react-client/echo";
16
+ import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
17
+ import { ControlItem, controlItemClasses } from "@dxos/react-ui-form";
18
+ import { List } from "@dxos/react-ui-list";
19
+ import { ghostHover, mx } from "@dxos/react-ui-theme";
20
+ var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
21
+ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
22
+ var _effect = _useSignals();
23
+ try {
24
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
25
+ const client = useClient();
26
+ const triggers = useQuery(space, Filter.type(FunctionTrigger));
27
+ const functions = useQuery(space, Filter.type(FunctionType));
28
+ const scripts = useQuery(space, Filter.type(ScriptType));
29
+ const [trigger, setTrigger] = useState(initialTrigger);
30
+ const [selected, setSelected] = useState();
31
+ const handleSelect = (trigger2) => {
32
+ const { id: _, ...values } = trigger2;
33
+ setTrigger(values);
34
+ setSelected(trigger2);
35
+ };
36
+ const handleAdd = () => {
37
+ setTrigger(live(FunctionTriggerSchema, {}));
38
+ setSelected(void 0);
39
+ };
40
+ const handleDelete = (trigger2) => {
41
+ space.db.remove(trigger2);
42
+ setTrigger(void 0);
43
+ setSelected(void 0);
44
+ };
45
+ const handleSave = (trigger2) => {
46
+ if (selected) {
47
+ Object.assign(selected, trigger2);
48
+ } else {
49
+ space.db.add(live(FunctionTrigger, trigger2));
50
+ }
51
+ setTrigger(void 0);
52
+ setSelected(void 0);
53
+ onDone?.();
54
+ };
55
+ const handleCancel = () => {
56
+ setTrigger(void 0);
57
+ onDone?.();
58
+ };
59
+ if (trigger) {
60
+ return /* @__PURE__ */ React.createElement(ControlItem, {
61
+ title: t("trigger editor title")
62
+ }, /* @__PURE__ */ React.createElement(TriggerEditor, {
63
+ space,
64
+ trigger,
65
+ onSave: handleSave,
66
+ onCancel: handleCancel
67
+ }));
68
+ }
69
+ return /* @__PURE__ */ React.createElement("div", {
70
+ className: "flex flex-col w-full"
71
+ }, /* @__PURE__ */ React.createElement("div", {
72
+ role: "none",
73
+ className: controlItemClasses
74
+ }, triggers.length > 0 && /* @__PURE__ */ React.createElement(List.Root, {
75
+ items: triggers,
76
+ isItem: Schema.is(FunctionTrigger),
77
+ getId: (field) => field.id
78
+ }, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
79
+ role: "list",
80
+ className: "flex flex-col w-full"
81
+ }, triggers2?.map((trigger2) => {
82
+ const copyAction = getCopyAction(client, trigger2);
83
+ return /* @__PURE__ */ React.createElement(List.Item, {
84
+ key: trigger2.id,
85
+ item: trigger2,
86
+ classNames: mx(grid, ghostHover, "items-center", "px-2")
87
+ }, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.Switch, {
88
+ checked: trigger2.enabled,
89
+ onCheckedChange: (checked) => trigger2.enabled = checked
90
+ })), /* @__PURE__ */ React.createElement("div", {
91
+ className: "flex"
92
+ }, /* @__PURE__ */ React.createElement(List.ItemTitle, {
93
+ classNames: "px-1 cursor-pointer w-0 shrink truncate",
94
+ onClick: () => handleSelect(trigger2)
95
+ }, getFunctionName(scripts, functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
96
+ label: t(copyAction.translationKey),
97
+ value: copyAction.contentProvider()
98
+ })), /* @__PURE__ */ React.createElement(List.ItemDeleteButton, {
99
+ onClick: () => handleDelete(trigger2)
100
+ }));
101
+ }))), triggers.length > 0 && /* @__PURE__ */ React.createElement(Separator, {
102
+ classNames: "mlb-4"
103
+ }), /* @__PURE__ */ React.createElement(IconButton, {
104
+ icon: "ph--plus--regular",
105
+ label: t("new trigger label"),
106
+ onClick: handleAdd
107
+ })));
108
+ } finally {
109
+ _effect.f();
110
+ }
111
+ };
112
+ var getCopyAction = (client, trigger) => {
113
+ if (trigger?.spec?.kind === TriggerKind.Email) {
114
+ return {
115
+ translationKey: "trigger copy email",
116
+ contentProvider: () => `${getSpace(trigger).id}@dxos.network`
117
+ };
118
+ }
119
+ if (trigger?.spec?.kind === TriggerKind.Webhook) {
120
+ return {
121
+ translationKey: "trigger copy url",
122
+ contentProvider: () => getWebhookUrl(client, trigger)
123
+ };
124
+ }
125
+ return void 0;
126
+ };
127
+ var getWebhookUrl = (client, trigger) => {
128
+ const spaceId = getSpace(trigger).id;
129
+ const edgeUrl = new URL(client.config.values.runtime.services.edge.url);
130
+ const isSecure = edgeUrl.protocol.startsWith("https") || edgeUrl.protocol.startsWith("wss");
131
+ edgeUrl.protocol = isSecure ? "https" : "http";
132
+ return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
133
+ };
134
+ var getFunctionName = (scripts, functions, trigger) => {
135
+ const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
136
+ const functionObject = functions.find((fn) => fn === trigger.function?.target);
137
+ if (!functionObject) {
138
+ return shortId;
139
+ }
140
+ return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;
141
+ };
142
+
143
+ // packages/plugins/plugin-automation/src/components/AutomationPanel/index.ts
144
+ var AutomationPanel_default = AutomationPanel;
145
+
146
+ export {
147
+ AutomationPanel,
148
+ AutomationPanel_default
149
+ };
150
+ //# sourceMappingURL=chunk-P2FKMPRE.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 if (trigger) {\n return (\n <ControlItem title={t('trigger editor title')}>\n <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />\n </ControlItem>\n );\n }\n\n return (\n <div className='flex flex-col w-full'>\n <div role='none' className={controlItemClasses}>\n {triggers.length > 0 && (\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 )}\n {triggers.length > 0 && <Separator classNames='mlb-4' />}\n <IconButton icon='ph--plus--regular' label={t('new trigger label')} onClick={handleAdd} />\n </div>\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", "ControlItem", "title", "TriggerEditor", "onSave", "onCancel", "div", "className", "role", "controlItemClasses", "length", "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", "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
+ }
@@ -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-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"));
5
+ var AutomationContainer = lazy(() => import("./AutomationContainer-OJGH76X2.mjs"));
6
+ var AutomationPanel = lazy(() => import("./AutomationPanel-HIWEJUWL.mjs"));
7
+ var FunctionsContainer = lazy(() => import("./FunctionsContainer-PPR6XNNR.mjs"));
8
+ var FunctionsPanel = lazy(() => import("./FunctionsPanel-SBXKWTHR.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-CUPEMOYK.mjs.map
16
+ //# sourceMappingURL=chunk-Z7VAQDEE.mjs.map
@@ -4,14 +4,14 @@ import {
4
4
  AutomationPanel,
5
5
  FunctionsContainer,
6
6
  FunctionsPanel
7
- } from "./chunk-CUPEMOYK.mjs";
7
+ } from "./chunk-Z7VAQDEE.mjs";
8
8
  import {
9
9
  TriggerEditor
10
- } from "./chunk-DZ7RKC52.mjs";
10
+ } from "./chunk-D5HK4XLC.mjs";
11
11
  import {
12
12
  AUTOMATION_PLUGIN,
13
13
  meta
14
- } from "./chunk-DZ44LGYT.mjs";
14
+ } from "./chunk-HCCLRNMJ.mjs";
15
15
 
16
16
  // packages/plugins/plugin-automation/src/AutomationPlugin.tsx
17
17
  import { Capabilities, contributes, defineModule, definePlugin, Events } from "@dxos/app-framework";
@@ -20,9 +20,9 @@ import { ClientCapabilities, ClientEvents } from "@dxos/plugin-client";
20
20
 
21
21
  // packages/plugins/plugin-automation/src/capabilities/index.ts
22
22
  import { lazy } from "@dxos/app-framework";
23
- var AppGraphBuilder = lazy(() => import("./app-graph-builder-UR2E5CQY.mjs"));
24
- var IntentResolver = lazy(() => import("./intent-resolver-HEUGQ6SL.mjs"));
25
- var ReactSurface = lazy(() => import("./react-surface-TER7JEF6.mjs"));
23
+ var AppGraphBuilder = lazy(() => import("./app-graph-builder-UAXHKKGW.mjs"));
24
+ var IntentResolver = lazy(() => import("./intent-resolver-KRCXJEDR.mjs"));
25
+ var ReactSurface = lazy(() => import("./react-surface-TRKCIZAB.mjs"));
26
26
 
27
27
  // packages/plugins/plugin-automation/src/translations.ts
28
28
  var translations_default = [
@@ -1,8 +1,8 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  AutomationAction
4
- } from "./chunk-EEA6CZ6B.mjs";
5
- import "./chunk-DZ44LGYT.mjs";
4
+ } from "./chunk-6JOJ2NN4.mjs";
5
+ import "./chunk-HCCLRNMJ.mjs";
6
6
 
7
7
  // packages/plugins/plugin-automation/src/capabilities/intent-resolver.ts
8
8
  import { contributes, Capabilities, createResolver, createIntent, LayoutAction } from "@dxos/app-framework";
@@ -75,4 +75,4 @@ var intent_resolver_default = (context) => contributes(Capabilities.IntentResolv
75
75
  export {
76
76
  intent_resolver_default as default
77
77
  };
78
- //# sourceMappingURL=intent-resolver-HEUGQ6SL.mjs.map
78
+ //# sourceMappingURL=intent-resolver-KRCXJEDR.mjs.map