@dxos/plugin-automation 0.8.4-main.3f58842 → 0.8.4-main.548089c

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 (194) hide show
  1. package/dist/lib/browser/AutomationPanel-W6K45EP4.mjs +11 -0
  2. package/dist/lib/browser/AutomationSettings-YGXYZZEU.mjs +68 -0
  3. package/dist/lib/browser/AutomationSettings-YGXYZZEU.mjs.map +7 -0
  4. package/dist/lib/browser/FunctionsContainer-JIFRD7DW.mjs +151 -0
  5. package/dist/lib/browser/FunctionsContainer-JIFRD7DW.mjs.map +7 -0
  6. package/dist/lib/browser/{FunctionsPanel-56ZKRVM5.mjs → FunctionsPanel-CRW6SJUN.mjs} +3 -3
  7. package/dist/lib/browser/{app-graph-builder-ZTAUTFI4.mjs → app-graph-builder-W7LLC6XW.mjs} +13 -12
  8. package/dist/lib/browser/app-graph-builder-W7LLC6XW.mjs.map +7 -0
  9. package/dist/lib/browser/{chunk-ERTIGJYE.mjs → chunk-DLZNSNOV.mjs} +72 -35
  10. package/dist/lib/browser/chunk-DLZNSNOV.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-HUHVG4BU.mjs +14 -0
  12. package/dist/lib/browser/chunk-HUHVG4BU.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-FSJZXTS2.mjs → chunk-JW7XSPYW.mjs} +69 -32
  14. package/dist/lib/browser/chunk-JW7XSPYW.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-LZQFZO3B.mjs +17 -0
  16. package/dist/lib/browser/chunk-LZQFZO3B.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-RYEK6OMM.mjs +67 -0
  18. package/dist/lib/browser/chunk-RYEK6OMM.mjs.map +7 -0
  19. package/dist/lib/browser/{chunk-LYJVTIVD.mjs → chunk-TWWFNOIR.mjs} +30 -15
  20. package/dist/lib/browser/chunk-TWWFNOIR.mjs.map +7 -0
  21. package/dist/lib/browser/chunk-XAKZ4ANY.mjs +15 -0
  22. package/dist/lib/browser/chunk-XAKZ4ANY.mjs.map +7 -0
  23. package/dist/lib/browser/{chunk-HN7OHFCB.mjs → chunk-YBPJCY3F.mjs} +3 -3
  24. package/dist/lib/browser/chunk-YBPJCY3F.mjs.map +7 -0
  25. package/dist/lib/browser/compute-runtime-EIQTHJFZ.mjs +113 -0
  26. package/dist/lib/browser/compute-runtime-EIQTHJFZ.mjs.map +7 -0
  27. package/dist/lib/browser/hooks/index.mjs +11 -0
  28. package/dist/lib/browser/index.mjs +46 -19
  29. package/dist/lib/browser/index.mjs.map +4 -4
  30. package/dist/lib/browser/{intent-resolver-U3ZAQEFW.mjs → intent-resolver-5HR7M7T6.mjs} +15 -14
  31. package/dist/lib/browser/intent-resolver-5HR7M7T6.mjs.map +7 -0
  32. package/dist/lib/browser/meta.json +1 -1
  33. package/dist/lib/browser/{react-surface-4DFSM7OX.mjs → react-surface-LXPASRXE.mjs} +20 -20
  34. package/dist/lib/browser/react-surface-LXPASRXE.mjs.map +7 -0
  35. package/dist/lib/browser/types/index.mjs +2 -2
  36. package/dist/lib/node-esm/{AutomationPanel-YYUMSK2W.mjs → AutomationPanel-NI6EHUWH.mjs} +4 -4
  37. package/dist/lib/node-esm/AutomationSettings-3BAIEDRA.mjs +69 -0
  38. package/dist/lib/node-esm/AutomationSettings-3BAIEDRA.mjs.map +7 -0
  39. package/dist/lib/node-esm/FunctionsContainer-MK76KBEW.mjs +152 -0
  40. package/dist/lib/node-esm/FunctionsContainer-MK76KBEW.mjs.map +7 -0
  41. package/dist/lib/node-esm/{FunctionsPanel-KGIOZSPZ.mjs → FunctionsPanel-RVVCS6VH.mjs} +3 -3
  42. package/dist/lib/node-esm/FunctionsPanel-RVVCS6VH.mjs.map +7 -0
  43. package/dist/lib/node-esm/{app-graph-builder-3FP63ZSG.mjs → app-graph-builder-SLQOO7GH.mjs} +13 -12
  44. package/dist/lib/node-esm/app-graph-builder-SLQOO7GH.mjs.map +7 -0
  45. package/dist/lib/node-esm/chunk-CEVIVRTY.mjs +19 -0
  46. package/dist/lib/node-esm/chunk-CEVIVRTY.mjs.map +7 -0
  47. package/dist/lib/node-esm/chunk-CPJ33QGN.mjs +16 -0
  48. package/dist/lib/node-esm/chunk-CPJ33QGN.mjs.map +7 -0
  49. package/dist/lib/node-esm/{chunk-OEZNHUL2.mjs → chunk-ECJKIUBO.mjs} +3 -3
  50. package/dist/lib/node-esm/chunk-ECJKIUBO.mjs.map +7 -0
  51. package/dist/lib/node-esm/chunk-KB7NFEYY.mjs +16 -0
  52. package/dist/lib/node-esm/chunk-KB7NFEYY.mjs.map +7 -0
  53. package/dist/lib/node-esm/chunk-LMTQG3PX.mjs +68 -0
  54. package/dist/lib/node-esm/chunk-LMTQG3PX.mjs.map +7 -0
  55. package/dist/lib/node-esm/{chunk-HIMYPGHF.mjs → chunk-O4KCL7XS.mjs} +72 -35
  56. package/dist/lib/node-esm/chunk-O4KCL7XS.mjs.map +7 -0
  57. package/dist/lib/node-esm/{chunk-ZGPUV5VS.mjs → chunk-RVK52XGK.mjs} +30 -15
  58. package/dist/lib/node-esm/chunk-RVK52XGK.mjs.map +7 -0
  59. package/dist/lib/node-esm/{chunk-AZH66CED.mjs → chunk-W76WUTZY.mjs} +69 -32
  60. package/dist/lib/node-esm/chunk-W76WUTZY.mjs.map +7 -0
  61. package/dist/lib/node-esm/compute-runtime-URROOC34.mjs +114 -0
  62. package/dist/lib/node-esm/compute-runtime-URROOC34.mjs.map +7 -0
  63. package/dist/lib/node-esm/hooks/index.mjs +12 -0
  64. package/dist/lib/node-esm/hooks/index.mjs.map +7 -0
  65. package/dist/lib/node-esm/index.mjs +46 -19
  66. package/dist/lib/node-esm/index.mjs.map +4 -4
  67. package/dist/lib/node-esm/{intent-resolver-3QWXEBPX.mjs → intent-resolver-KDRYB5BC.mjs} +15 -14
  68. package/dist/lib/node-esm/intent-resolver-KDRYB5BC.mjs.map +7 -0
  69. package/dist/lib/node-esm/meta.json +1 -1
  70. package/dist/lib/node-esm/{react-surface-3PNW7NDW.mjs → react-surface-AFCHOTCJ.mjs} +20 -20
  71. package/dist/lib/node-esm/react-surface-AFCHOTCJ.mjs.map +7 -0
  72. package/dist/lib/node-esm/types/index.mjs +2 -2
  73. package/dist/types/src/AutomationPlugin.d.ts +1 -1
  74. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  75. package/dist/types/src/capabilities/app-graph-builder.d.ts +1 -1
  76. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  77. package/dist/types/src/capabilities/capabilities.d.ts +20 -0
  78. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -0
  79. package/dist/types/src/capabilities/compute-runtime.d.ts +5 -0
  80. package/dist/types/src/capabilities/compute-runtime.d.ts.map +1 -0
  81. package/dist/types/src/capabilities/index.d.ts +5 -3
  82. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  83. package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
  84. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  85. package/dist/types/src/capabilities/react-surface.d.ts +1 -1
  86. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  87. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +6 -5
  88. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  89. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts +48 -4
  90. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  91. package/dist/types/src/components/AutomationSettings.d.ts +5 -0
  92. package/dist/types/src/components/AutomationSettings.d.ts.map +1 -0
  93. package/dist/types/src/components/FunctionsContainer.d.ts.map +1 -1
  94. package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +1 -1
  95. package/dist/types/src/components/FunctionsRegistry/FunctionsRegistry.d.ts +8 -0
  96. package/dist/types/src/components/FunctionsRegistry/FunctionsRegistry.d.ts.map +1 -0
  97. package/dist/types/src/components/FunctionsRegistry/index.d.ts +2 -0
  98. package/dist/types/src/components/FunctionsRegistry/index.d.ts.map +1 -0
  99. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts +2 -2
  100. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts.map +1 -1
  101. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +1 -1
  102. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +7 -5
  103. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  104. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts +49 -4
  105. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  106. package/dist/types/src/components/TriggerSettings.d.ts +6 -0
  107. package/dist/types/src/components/TriggerSettings.d.ts.map +1 -0
  108. package/dist/types/src/components/index.d.ts +2 -2
  109. package/dist/types/src/components/index.d.ts.map +1 -1
  110. package/dist/types/src/events.d.ts +4 -0
  111. package/dist/types/src/events.d.ts.map +1 -0
  112. package/dist/types/src/hooks/index.d.ts +3 -0
  113. package/dist/types/src/hooks/index.d.ts.map +1 -0
  114. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts +8 -0
  115. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts.map +1 -0
  116. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts +11 -0
  117. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts.map +1 -0
  118. package/dist/types/src/index.d.ts +3 -0
  119. package/dist/types/src/index.d.ts.map +1 -1
  120. package/dist/types/src/meta.d.ts +0 -1
  121. package/dist/types/src/meta.d.ts.map +1 -1
  122. package/dist/types/src/translations.d.ts +5 -0
  123. package/dist/types/src/translations.d.ts.map +1 -1
  124. package/dist/types/src/types/schema.d.ts +1 -1
  125. package/dist/types/src/types/schema.d.ts.map +1 -1
  126. package/dist/types/tsconfig.tsbuildinfo +1 -1
  127. package/package.json +63 -38
  128. package/src/AutomationPlugin.tsx +37 -31
  129. package/src/capabilities/app-graph-builder.ts +16 -15
  130. package/src/capabilities/capabilities.ts +41 -0
  131. package/src/capabilities/compute-runtime.ts +127 -0
  132. package/src/capabilities/index.ts +3 -0
  133. package/src/capabilities/intent-resolver.ts +11 -11
  134. package/src/capabilities/react-surface.tsx +15 -15
  135. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +15 -16
  136. package/src/components/AutomationPanel/AutomationPanel.tsx +105 -53
  137. package/src/components/AutomationSettings.tsx +30 -0
  138. package/src/components/FunctionsContainer.tsx +18 -13
  139. package/src/components/FunctionsPanel/FunctionsPanel.tsx +35 -16
  140. package/src/components/FunctionsRegistry/FunctionsRegistry.tsx +135 -0
  141. package/src/components/FunctionsRegistry/index.ts +5 -0
  142. package/src/components/TriggerEditor/FunctionInputEditor.tsx +10 -4
  143. package/src/components/TriggerEditor/SpecSelector.tsx +23 -17
  144. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +69 -26
  145. package/src/components/TriggerEditor/TriggerEditor.tsx +45 -25
  146. package/src/components/TriggerSettings.tsx +25 -0
  147. package/src/components/index.ts +1 -1
  148. package/src/events.ts +11 -0
  149. package/src/hooks/index.ts +6 -0
  150. package/src/hooks/useComputeRuntimeCallback.ts +32 -0
  151. package/src/hooks/useTriggerRuntimeControls.ts +53 -0
  152. package/src/index.ts +3 -0
  153. package/src/meta.ts +6 -5
  154. package/src/testing/test-functions.ts +1 -1
  155. package/src/translations.ts +7 -0
  156. package/src/types/schema.ts +1 -1
  157. package/dist/lib/browser/AutomationContainer-VZNV2ZQF.mjs +0 -38
  158. package/dist/lib/browser/AutomationContainer-VZNV2ZQF.mjs.map +0 -7
  159. package/dist/lib/browser/AutomationPanel-ZWA6GOFY.mjs +0 -11
  160. package/dist/lib/browser/FunctionsContainer-IOB333TX.mjs +0 -39
  161. package/dist/lib/browser/FunctionsContainer-IOB333TX.mjs.map +0 -7
  162. package/dist/lib/browser/app-graph-builder-ZTAUTFI4.mjs.map +0 -7
  163. package/dist/lib/browser/chunk-ECSTS2UI.mjs +0 -14
  164. package/dist/lib/browser/chunk-ECSTS2UI.mjs.map +0 -7
  165. package/dist/lib/browser/chunk-ERTIGJYE.mjs.map +0 -7
  166. package/dist/lib/browser/chunk-FSJZXTS2.mjs.map +0 -7
  167. package/dist/lib/browser/chunk-GW5U2DGT.mjs +0 -15
  168. package/dist/lib/browser/chunk-GW5U2DGT.mjs.map +0 -7
  169. package/dist/lib/browser/chunk-HN7OHFCB.mjs.map +0 -7
  170. package/dist/lib/browser/chunk-LYJVTIVD.mjs.map +0 -7
  171. package/dist/lib/browser/intent-resolver-U3ZAQEFW.mjs.map +0 -7
  172. package/dist/lib/browser/react-surface-4DFSM7OX.mjs.map +0 -7
  173. package/dist/lib/node-esm/AutomationContainer-WMIH3F4V.mjs +0 -39
  174. package/dist/lib/node-esm/AutomationContainer-WMIH3F4V.mjs.map +0 -7
  175. package/dist/lib/node-esm/FunctionsContainer-DJWB6WFH.mjs +0 -40
  176. package/dist/lib/node-esm/FunctionsContainer-DJWB6WFH.mjs.map +0 -7
  177. package/dist/lib/node-esm/app-graph-builder-3FP63ZSG.mjs.map +0 -7
  178. package/dist/lib/node-esm/chunk-AZH66CED.mjs.map +0 -7
  179. package/dist/lib/node-esm/chunk-HIMYPGHF.mjs.map +0 -7
  180. package/dist/lib/node-esm/chunk-NK5N3QKD.mjs +0 -17
  181. package/dist/lib/node-esm/chunk-NK5N3QKD.mjs.map +0 -7
  182. package/dist/lib/node-esm/chunk-OEZNHUL2.mjs.map +0 -7
  183. package/dist/lib/node-esm/chunk-SGZPTJ47.mjs +0 -16
  184. package/dist/lib/node-esm/chunk-SGZPTJ47.mjs.map +0 -7
  185. package/dist/lib/node-esm/chunk-ZGPUV5VS.mjs.map +0 -7
  186. package/dist/lib/node-esm/intent-resolver-3QWXEBPX.mjs.map +0 -7
  187. package/dist/lib/node-esm/react-surface-3PNW7NDW.mjs.map +0 -7
  188. package/dist/types/src/components/AutomationContainer.d.ts +0 -5
  189. package/dist/types/src/components/AutomationContainer.d.ts.map +0 -1
  190. package/src/components/AutomationContainer.tsx +0 -30
  191. /package/dist/lib/browser/{AutomationPanel-ZWA6GOFY.mjs.map → AutomationPanel-W6K45EP4.mjs.map} +0 -0
  192. /package/dist/lib/browser/{FunctionsPanel-56ZKRVM5.mjs.map → FunctionsPanel-CRW6SJUN.mjs.map} +0 -0
  193. /package/dist/lib/{node-esm/AutomationPanel-YYUMSK2W.mjs.map → browser/hooks/index.mjs.map} +0 -0
  194. /package/dist/lib/node-esm/{FunctionsPanel-KGIOZSPZ.mjs.map → AutomationPanel-NI6EHUWH.mjs.map} +0 -0
@@ -0,0 +1,11 @@
1
+ import {
2
+ AutomationPanel,
3
+ AutomationPanel_default
4
+ } from "./chunk-DLZNSNOV.mjs";
5
+ import "./chunk-JW7XSPYW.mjs";
6
+ import "./chunk-LZQFZO3B.mjs";
7
+ export {
8
+ AutomationPanel,
9
+ AutomationPanel_default as default
10
+ };
11
+ //# sourceMappingURL=AutomationPanel-W6K45EP4.mjs.map
@@ -0,0 +1,68 @@
1
+ import {
2
+ useTriggerRuntimeControls
3
+ } from "./chunk-RYEK6OMM.mjs";
4
+ import "./chunk-XAKZ4ANY.mjs";
5
+ import {
6
+ AutomationPanel
7
+ } from "./chunk-DLZNSNOV.mjs";
8
+ import "./chunk-JW7XSPYW.mjs";
9
+ import {
10
+ meta
11
+ } from "./chunk-LZQFZO3B.mjs";
12
+
13
+ // src/components/AutomationSettings.tsx
14
+ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
15
+ import React2 from "react";
16
+ import { useTranslation as useTranslation2 } from "@dxos/react-ui";
17
+ import { ControlPage, ControlSection } from "@dxos/react-ui-form";
18
+
19
+ // src/components/TriggerSettings.tsx
20
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
21
+ import React from "react";
22
+ import { Input, useTranslation } from "@dxos/react-ui";
23
+ import { ControlItemInput } from "@dxos/react-ui-form";
24
+ var TriggersSettings = ({ space }) => {
25
+ var _effect = _useSignals();
26
+ try {
27
+ const { triggers, isRunning, start, stop } = useTriggerRuntimeControls(space);
28
+ const { t } = useTranslation(meta.id);
29
+ return /* @__PURE__ */ React.createElement("div", {
30
+ className: "container-max-width grid grid-cols-1 md:grid-cols-[1fr_min-content]"
31
+ }, /* @__PURE__ */ React.createElement(ControlItemInput, {
32
+ title: t("runtime label"),
33
+ description: t("runtime description")
34
+ }, /* @__PURE__ */ React.createElement(Input.Switch, {
35
+ classNames: "justify-self-end",
36
+ checked: isRunning,
37
+ onCheckedChange: isRunning ? stop : start
38
+ })));
39
+ } finally {
40
+ _effect.f();
41
+ }
42
+ };
43
+
44
+ // src/components/AutomationSettings.tsx
45
+ var AutomationSettings = (props) => {
46
+ var _effect = _useSignals2();
47
+ try {
48
+ const { t } = useTranslation2(meta.id);
49
+ return /* @__PURE__ */ React2.createElement(ControlPage, null, /* @__PURE__ */ React2.createElement(ControlSection, {
50
+ title: t("automation verbose label", {
51
+ ns: meta.id
52
+ }),
53
+ description: t("automation description", {
54
+ ns: meta.id
55
+ })
56
+ }, /* @__PURE__ */ React2.createElement(AutomationPanel, props), /* @__PURE__ */ React2.createElement(TriggersSettings, {
57
+ space: props.space
58
+ })));
59
+ } finally {
60
+ _effect.f();
61
+ }
62
+ };
63
+ var AutomationSettings_default = AutomationSettings;
64
+ export {
65
+ AutomationSettings,
66
+ AutomationSettings_default as default
67
+ };
68
+ //# sourceMappingURL=AutomationSettings-YGXYZZEU.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/AutomationSettings.tsx", "../../../src/components/TriggerSettings.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { useTranslation } from '@dxos/react-ui';\nimport { ControlPage, ControlSection } from '@dxos/react-ui-form';\n\nimport { meta } from '../meta';\n\nimport { AutomationPanel, type AutomationPanelProps } from './AutomationPanel';\nimport { TriggersSettings } from './TriggerSettings';\n\nexport const AutomationSettings = (props: AutomationPanelProps) => {\n const { t } = useTranslation(meta.id);\n return (\n <ControlPage>\n <ControlSection\n title={t('automation verbose label', { ns: meta.id })}\n description={t('automation description', { ns: meta.id })}\n >\n <AutomationPanel {...props} />\n <TriggersSettings space={props.space} />\n </ControlSection>\n </ControlPage>\n );\n};\n\nexport default AutomationSettings;\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type Space } from '@dxos/react-client/echo';\nimport { Input, useTranslation } from '@dxos/react-ui';\nimport { ControlItemInput } from '@dxos/react-ui-form';\n\nimport { useTriggerRuntimeControls } from '../hooks';\nimport { meta } from '../meta';\n\nexport const TriggersSettings = ({ space }: { space: Space }) => {\n const { triggers, isRunning, start, stop } = useTriggerRuntimeControls(space);\n const { t } = useTranslation(meta.id);\n\n return (\n <div className='container-max-width grid grid-cols-1 md:grid-cols-[1fr_min-content]'>\n <ControlItemInput title={t('runtime label')} description={t('runtime description')}>\n <Input.Switch classNames='justify-self-end' checked={isRunning} onCheckedChange={isRunning ? stop : start} />\n </ControlItemInput>\n </div>\n );\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;AAIA,OAAOA,YAAW;AAElB,SAASC,kBAAAA,uBAAsB;AAC/B,SAASC,aAAaC,sBAAsB;;;;ACH5C,OAAOC,WAAW;AAGlB,SAASC,OAAOC,sBAAsB;AACtC,SAASC,wBAAwB;AAK1B,IAAMC,mBAAmB,CAAC,EAAEC,MAAK,MAAoB;;;AAC1D,UAAM,EAAEC,UAAUC,WAAWC,OAAOC,KAAI,IAAKC,0BAA0BL,KAAAA;AACvE,UAAM,EAAEM,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AAEpC,WACE,sBAAA,cAACC,OAAAA;MAAIC,WAAU;OACb,sBAAA,cAACC,kBAAAA;MAAiBC,OAAOP,EAAE,eAAA;MAAkBQ,aAAaR,EAAE,qBAAA;OAC1D,sBAAA,cAACS,MAAMC,QAAM;MAACC,YAAW;MAAmBC,SAAShB;MAAWiB,iBAAiBjB,YAAYE,OAAOD;;;;;AAI5G;;;ADVO,IAAMiB,qBAAqB,CAACC,UAAAA;;;AACjC,UAAM,EAAEC,EAAC,IAAKC,gBAAeC,KAAKC,EAAE;AACpC,WACE,gBAAAC,OAAA,cAACC,aAAAA,MACC,gBAAAD,OAAA,cAACE,gBAAAA;MACCC,OAAOP,EAAE,4BAA4B;QAAEQ,IAAIN,KAAKC;MAAG,CAAA;MACnDM,aAAaT,EAAE,0BAA0B;QAAEQ,IAAIN,KAAKC;MAAG,CAAA;OAEvD,gBAAAC,OAAA,cAACM,iBAAoBX,KAAAA,GACrB,gBAAAK,OAAA,cAACO,kBAAAA;MAAiBC,OAAOb,MAAMa;;;;;AAIvC;AAEA,IAAA,6BAAed;",
6
+ "names": ["React", "useTranslation", "ControlPage", "ControlSection", "React", "Input", "useTranslation", "ControlItemInput", "TriggersSettings", "space", "triggers", "isRunning", "start", "stop", "useTriggerRuntimeControls", "t", "useTranslation", "meta", "id", "div", "className", "ControlItemInput", "title", "description", "Input", "Switch", "classNames", "checked", "onCheckedChange", "AutomationSettings", "props", "t", "useTranslation", "meta", "id", "React", "ControlPage", "ControlSection", "title", "ns", "description", "AutomationPanel", "TriggersSettings", "space"]
7
+ }
@@ -0,0 +1,151 @@
1
+ import {
2
+ FunctionsPanel
3
+ } from "./chunk-TWWFNOIR.mjs";
4
+ import {
5
+ meta
6
+ } from "./chunk-LZQFZO3B.mjs";
7
+
8
+ // src/components/FunctionsContainer.tsx
9
+ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
10
+ import React2 from "react";
11
+ import { useTranslation as useTranslation2 } from "@dxos/react-ui";
12
+ import { ControlPage, ControlSection } from "@dxos/react-ui-form";
13
+
14
+ // src/components/FunctionsRegistry/FunctionsRegistry.tsx
15
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
16
+ import * as Array from "effect/Array";
17
+ import * as EffectFunction from "effect/Function";
18
+ import * as Order from "effect/Order";
19
+ import * as Schema from "effect/Schema";
20
+ import { useState } from "react";
21
+ import React, { useCallback } from "react";
22
+ import { Obj } from "@dxos/echo";
23
+ import { Function } from "@dxos/functions";
24
+ import { getDeployedFunctions } from "@dxos/functions-runtime/edge";
25
+ import { useClient } from "@dxos/react-client";
26
+ import { Filter, Query, useQuery } from "@dxos/react-client/echo";
27
+ import { useAsyncEffect } from "@dxos/react-ui";
28
+ import { IconButton, useTranslation } from "@dxos/react-ui";
29
+ import { controlItemClasses } from "@dxos/react-ui-form";
30
+ import { List } from "@dxos/react-ui-list";
31
+ import { ghostHover, mx } from "@dxos/react-ui-theme";
32
+ var grid = "grid grid-cols-[1fr_1fr_auto] min-bs-[2.5rem]";
33
+ var FunctionsRegistry = ({ space }) => {
34
+ var _effect = _useSignals();
35
+ try {
36
+ const client = useClient();
37
+ const [loading, setLoading] = useState(true);
38
+ const [functions, setFunctions] = useState([]);
39
+ const { t } = useTranslation(meta.id);
40
+ const dbFunctions = useQuery(space, Filter.type(Function.Function));
41
+ const state = (func) => {
42
+ const dbFunction = dbFunctions.find((f) => f.key === func.key);
43
+ if (!dbFunction) {
44
+ return "import";
45
+ }
46
+ if (dbFunction.version === func.version && dbFunction.updated === func.updated) {
47
+ return "none";
48
+ }
49
+ return "update";
50
+ };
51
+ useAsyncEffect(async () => {
52
+ setLoading(true);
53
+ const functions2 = await getDeployedFunctions(client);
54
+ setFunctions(functions2);
55
+ setLoading(false);
56
+ }, []);
57
+ const dedupedFunctions = EffectFunction.pipe(functions, Array.filter((_) => _.key !== void 0), Array.sort(Order.reverse(Order.mapInput(Order.string, (_) => _.updated ?? ""))), Array.dedupeWith((self, that) => self.key === that.key), Array.sort(Order.mapInput(Order.string, (_) => _.key ?? "")));
58
+ const hanleImportOrUpdate = useCallback(async (func) => {
59
+ const { objects: [existingFunc] } = await space.db.query(Query.type(Function.Function, {
60
+ key: func.key
61
+ })).run();
62
+ if (!existingFunc) {
63
+ space.db.add(func);
64
+ return;
65
+ }
66
+ existingFunc.version = func.version;
67
+ existingFunc.updated = func.updated;
68
+ existingFunc.name = func.name;
69
+ existingFunc.description = func.description;
70
+ existingFunc.inputSchema = JSON.parse(JSON.stringify(func.inputSchema));
71
+ existingFunc.outputSchema = JSON.parse(JSON.stringify(func.outputSchema));
72
+ Obj.getMeta(existingFunc).keys = JSON.parse(JSON.stringify(Obj.getMeta(func).keys));
73
+ }, [
74
+ space
75
+ ]);
76
+ return /* @__PURE__ */ React.createElement("div", {
77
+ role: "none",
78
+ className: mx(controlItemClasses)
79
+ }, dedupedFunctions.length > 0 && /* @__PURE__ */ React.createElement(List.Root, {
80
+ items: dedupedFunctions,
81
+ isItem: Schema.is(Function.Function),
82
+ getId: (func) => func.id
83
+ }, ({ items }) => /* @__PURE__ */ React.createElement("div", {
84
+ role: "list",
85
+ className: "flex flex-col w-full"
86
+ }, items?.map((func) => /* @__PURE__ */ React.createElement(List.Item, {
87
+ key: func.id,
88
+ item: func,
89
+ classNames: mx(grid, ghostHover, "items-center", "pli-2", "min-bs-[3rem]")
90
+ }, /* @__PURE__ */ React.createElement("div", {
91
+ className: "flex flex-col truncate"
92
+ }, /* @__PURE__ */ React.createElement(List.ItemTitle, {
93
+ classNames: "truncate"
94
+ }, func.name), /* @__PURE__ */ React.createElement("div", {
95
+ className: "text-xs text-description truncate"
96
+ }, func.key)), /* @__PURE__ */ React.createElement("div", {
97
+ className: "flex flex-col truncate"
98
+ }, /* @__PURE__ */ React.createElement("div", {
99
+ className: "text-xs text-description truncate"
100
+ }, func.version), /* @__PURE__ */ React.createElement("div", {
101
+ className: "text-xs text-description truncate"
102
+ }, func.updated ? `Uploaded ${new Date(func.updated).toLocaleString()}` : "")), /* @__PURE__ */ React.createElement(IconButton, {
103
+ iconOnly: true,
104
+ icon: state(func) === "update" ? "ph--arrows-clockwise--regular" : "ph--download--regular",
105
+ label: state(func) === "update" ? t("update function button label") : t("import function button label"),
106
+ disabled: state(func) === "none",
107
+ onClick: () => hanleImportOrUpdate(func)
108
+ }))))), dedupedFunctions.length === 0 && !loading && /* @__PURE__ */ React.createElement("div", {
109
+ className: "text-center plb-4 text-gray-500"
110
+ }, t("no functions found")), loading && /* @__PURE__ */ React.createElement("div", {
111
+ className: "text-center plb-4 text-gray-500"
112
+ }, t("loading functions")));
113
+ } finally {
114
+ _effect.f();
115
+ }
116
+ };
117
+
118
+ // src/components/FunctionsContainer.tsx
119
+ var FunctionsContainer = ({ space }) => {
120
+ var _effect = _useSignals2();
121
+ try {
122
+ const { t } = useTranslation2(meta.id);
123
+ return /* @__PURE__ */ React2.createElement(ControlPage, null, /* @__PURE__ */ React2.createElement(ControlSection, {
124
+ title: t("functions verbose label", {
125
+ ns: meta.id
126
+ }),
127
+ description: t("functions description", {
128
+ ns: meta.id
129
+ })
130
+ }, /* @__PURE__ */ React2.createElement(FunctionsPanel, {
131
+ space
132
+ })), /* @__PURE__ */ React2.createElement(ControlSection, {
133
+ title: t("functions registry verbose label", {
134
+ ns: meta.id
135
+ }),
136
+ description: t("functions registry description", {
137
+ ns: meta.id
138
+ })
139
+ }, /* @__PURE__ */ React2.createElement(FunctionsRegistry, {
140
+ space
141
+ })));
142
+ } finally {
143
+ _effect.f();
144
+ }
145
+ };
146
+ var FunctionsContainer_default = FunctionsContainer;
147
+ export {
148
+ FunctionsContainer,
149
+ FunctionsContainer_default as default
150
+ };
151
+ //# sourceMappingURL=FunctionsContainer-JIFRD7DW.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/FunctionsContainer.tsx", "../../../src/components/FunctionsRegistry/FunctionsRegistry.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type Space } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { ControlPage, ControlSection } from '@dxos/react-ui-form';\n\nimport { meta } from '../meta';\n\nimport { FunctionsPanel } from './FunctionsPanel';\nimport { FunctionsRegistry } from './FunctionsRegistry';\n\nexport const FunctionsContainer = ({ space }: { space: Space }) => {\n const { t } = useTranslation(meta.id);\n return (\n <ControlPage>\n <ControlSection\n title={t('functions verbose label', { ns: meta.id })}\n description={t('functions description', { ns: meta.id })}\n >\n <FunctionsPanel space={space} />\n </ControlSection>\n <ControlSection\n title={t('functions registry verbose label', { ns: meta.id })}\n description={t('functions registry description', { ns: meta.id })}\n >\n <FunctionsRegistry space={space} />\n </ControlSection>\n </ControlPage>\n );\n};\n\nexport default FunctionsContainer;\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Array from 'effect/Array';\nimport * as EffectFunction from 'effect/Function';\nimport * as Order from 'effect/Order';\nimport * as Schema from 'effect/Schema';\nimport { useState } from 'react';\nimport React, { useCallback } from 'react';\n\nimport { Obj } from '@dxos/echo';\nimport { Function } from '@dxos/functions';\nimport { getDeployedFunctions } from '@dxos/functions-runtime/edge';\nimport { useClient } from '@dxos/react-client';\nimport { Filter, Query, type Space, useQuery } from '@dxos/react-client/echo';\nimport { useAsyncEffect } from '@dxos/react-ui';\nimport { IconButton, 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 { meta } from '../../meta';\n\nconst grid = 'grid grid-cols-[1fr_1fr_auto] min-bs-[2.5rem]';\n\ntype FunctionsRegistryProps = {\n space: Space;\n};\n\nexport const FunctionsRegistry = ({ space }: FunctionsRegistryProps) => {\n const client = useClient();\n const [loading, setLoading] = useState(true);\n const [functions, setFunctions] = useState<Function.Function[]>([]);\n const { t } = useTranslation(meta.id);\n\n const dbFunctions = useQuery(space, Filter.type(Function.Function));\n\n const state = (func: Function.Function) => {\n const dbFunction = dbFunctions.find((f) => f.key === func.key);\n if (!dbFunction) {\n return 'import';\n }\n if (dbFunction.version === func.version && dbFunction.updated === func.updated) {\n return 'none';\n }\n return 'update';\n };\n\n useAsyncEffect(async () => {\n setLoading(true);\n const functions = await getDeployedFunctions(client);\n setFunctions(functions);\n setLoading(false);\n }, []);\n\n const dedupedFunctions = EffectFunction.pipe(\n functions,\n Array.filter((_) => _.key !== undefined),\n Array.sort(Order.reverse(Order.mapInput(Order.string, (_: Function.Function) => _.updated ?? ''))),\n Array.dedupeWith((self, that) => self.key === that.key),\n Array.sort(Order.mapInput(Order.string, (_: Function.Function) => _.key ?? '')),\n );\n\n const hanleImportOrUpdate = useCallback(\n async (func: Function.Function) => {\n const {\n objects: [existingFunc],\n } = await space.db.query(Query.type(Function.Function, { key: func.key })).run();\n if (!existingFunc) {\n space.db.add(func);\n return;\n }\n existingFunc.version = func.version;\n existingFunc.updated = func.updated;\n existingFunc.name = func.name;\n existingFunc.description = func.description;\n // TODO(dmaretskyi): A workaround for an ECHO bug.\n existingFunc.inputSchema = JSON.parse(JSON.stringify(func.inputSchema));\n existingFunc.outputSchema = JSON.parse(JSON.stringify(func.outputSchema));\n Obj.getMeta(existingFunc).keys = JSON.parse(JSON.stringify(Obj.getMeta(func).keys));\n },\n [space],\n );\n\n return (\n <div role='none' className={mx(controlItemClasses)}>\n {dedupedFunctions.length > 0 && (\n <List.Root<Function.Function>\n items={dedupedFunctions}\n isItem={Schema.is(Function.Function)}\n getId={(func) => func.id}\n >\n {({ items }) => (\n <div role='list' className='flex flex-col w-full'>\n {items?.map((func) => (\n <List.Item<Function.Function>\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 <div className='text-xs text-description truncate'>{func.key}</div>\n </div>\n <div className='flex flex-col truncate'>\n <div className='text-xs text-description truncate'>{func.version}</div>\n <div className='text-xs text-description truncate'>\n {func.updated ? `Uploaded ${new Date(func.updated).toLocaleString()}` : ''}\n </div>\n </div>\n\n <IconButton\n iconOnly\n icon={state(func) === 'update' ? 'ph--arrows-clockwise--regular' : 'ph--download--regular'}\n label={\n state(func) === 'update' ? t('update function button label') : t('import function button label')\n }\n disabled={state(func) === 'none'}\n onClick={() => hanleImportOrUpdate(func)}\n />\n </List.Item>\n ))}\n </div>\n )}\n </List.Root>\n )}\n\n {dedupedFunctions.length === 0 && !loading && (\n <div className='text-center plb-4 text-gray-500'>{t('no functions found')}</div>\n )}\n {loading && <div className='text-center plb-4 text-gray-500'>{t('loading functions')}</div>}\n </div>\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "useTranslation", "ControlPage", "ControlSection", "Array", "EffectFunction", "Order", "Schema", "useState", "React", "useCallback", "Obj", "Function", "getDeployedFunctions", "useClient", "Filter", "Query", "useQuery", "useAsyncEffect", "IconButton", "useTranslation", "controlItemClasses", "List", "ghostHover", "mx", "grid", "FunctionsRegistry", "space", "client", "useClient", "loading", "setLoading", "useState", "functions", "setFunctions", "t", "useTranslation", "meta", "id", "dbFunctions", "useQuery", "Filter", "type", "Function", "state", "func", "dbFunction", "find", "f", "key", "version", "updated", "useAsyncEffect", "getDeployedFunctions", "dedupedFunctions", "pipe", "filter", "_", "undefined", "sort", "reverse", "mapInput", "string", "dedupeWith", "self", "that", "hanleImportOrUpdate", "useCallback", "objects", "existingFunc", "db", "query", "Query", "run", "add", "name", "description", "inputSchema", "JSON", "parse", "stringify", "outputSchema", "Obj", "getMeta", "keys", "div", "role", "className", "mx", "controlItemClasses", "length", "List", "Root", "items", "isItem", "is", "getId", "map", "Item", "item", "classNames", "ghostHover", "ItemTitle", "Date", "toLocaleString", "IconButton", "iconOnly", "icon", "label", "disabled", "onClick", "FunctionsContainer", "space", "t", "useTranslation", "meta", "id", "React", "ControlPage", "ControlSection", "title", "ns", "description", "FunctionsPanel", "FunctionsRegistry"]
7
+ }
@@ -1,10 +1,10 @@
1
1
  import {
2
2
  FunctionsPanel,
3
3
  FunctionsPanel_default
4
- } from "./chunk-LYJVTIVD.mjs";
5
- import "./chunk-GW5U2DGT.mjs";
4
+ } from "./chunk-TWWFNOIR.mjs";
5
+ import "./chunk-LZQFZO3B.mjs";
6
6
  export {
7
7
  FunctionsPanel,
8
8
  FunctionsPanel_default as default
9
9
  };
10
- //# sourceMappingURL=FunctionsPanel-56ZKRVM5.mjs.map
10
+ //# sourceMappingURL=FunctionsPanel-CRW6SJUN.mjs.map
@@ -1,20 +1,21 @@
1
1
  import {
2
2
  meta
3
- } from "./chunk-GW5U2DGT.mjs";
3
+ } from "./chunk-LZQFZO3B.mjs";
4
4
 
5
5
  // src/capabilities/app-graph-builder.ts
6
- import { Rx } from "@effect-rx/rx-react";
7
- import { Option, pipe } from "effect";
6
+ import { Atom } from "@effect-atom/atom-react";
7
+ import * as Function from "effect/Function";
8
+ import * as Option from "effect/Option";
8
9
  import { Capabilities, contributes } from "@dxos/app-framework";
9
10
  import { Obj } from "@dxos/echo";
10
- import { ScriptType } from "@dxos/functions";
11
- import { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR } from "@dxos/plugin-deck/types";
11
+ import { Script } from "@dxos/functions";
12
+ import { ATTENDABLE_PATH_SEPARATOR, PLANK_COMPANION_TYPE } from "@dxos/plugin-deck/types";
12
13
  import { createExtension } from "@dxos/plugin-graph";
13
- import { SPACE_PLUGIN } from "@dxos/plugin-space";
14
- var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
14
+ import { meta as spaceMeta } from "@dxos/plugin-space";
15
+ var app_graph_builder_default = ((context) => contributes(Capabilities.AppGraphBuilder, [
15
16
  createExtension({
16
17
  id: `${meta.id}/space-settings-automation`,
17
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.type === `${SPACE_PLUGIN}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
18
+ connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.type === `${spaceMeta.id}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
18
19
  {
19
20
  id: `automation-${node2.id}`,
20
21
  type: `${meta.id}/space-settings-automation`,
@@ -33,7 +34,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
33
34
  }),
34
35
  createExtension({
35
36
  id: `${meta.id}/space-settings-functions`,
36
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.type === `${SPACE_PLUGIN}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
37
+ connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.type === `${spaceMeta.id}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
37
38
  {
38
39
  id: `functions-${node2.id}`,
39
40
  type: `${meta.id}/space-settings-functions`,
@@ -52,7 +53,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
52
53
  }),
53
54
  createExtension({
54
55
  id: `${meta.id}/script-companion`,
55
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(ScriptType, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
56
+ connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(Script.Script, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
56
57
  {
57
58
  id: [
58
59
  node2.id,
@@ -73,8 +74,8 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
73
74
  }
74
75
  ]), Option.getOrElse(() => [])))
75
76
  })
76
- ]);
77
+ ]));
77
78
  export {
78
79
  app_graph_builder_default as default
79
80
  };
80
- //# sourceMappingURL=app-graph-builder-ZTAUTFI4.mjs.map
81
+ //# sourceMappingURL=app-graph-builder-W7LLC6XW.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 { Atom } from '@effect-atom/atom-react';\nimport * as Function from 'effect/Function';\nimport * as Option from 'effect/Option';\n\nimport { Capabilities, type PluginContext, contributes } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { Script } from '@dxos/functions';\nimport { ATTENDABLE_PATH_SEPARATOR, PLANK_COMPANION_TYPE } from '@dxos/plugin-deck/types';\nimport { createExtension } from '@dxos/plugin-graph';\nimport { meta as spaceMeta } 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 Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => (node.type === `${spaceMeta.id}/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 Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => (node.type === `${spaceMeta.id}/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 Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => (Obj.instanceOf(Script.Script, 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 disposition: 'hidden',\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n ]);\n"],
5
+ "mappings": ";;;;;AAIA,SAASA,YAAY;AACrB,YAAYC,cAAc;AAC1B,YAAYC,YAAY;AAExB,SAASC,cAAkCC,mBAAmB;AAC9D,SAASC,WAAW;AACpB,SAASC,cAAc;AACvB,SAASC,2BAA2BC,4BAA4B;AAChE,SAASC,uBAAuB;AAChC,SAASC,QAAQC,iBAAiB;AAIlC,IAAA,6BAAe,CAACC,YACdC,YAAYC,aAAaC,iBAAiB;EACxCC,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,KAAKC,KAAK,CAACC,QACAC,cACPD,IAAIH,IAAAA,GACGK,eAAQ,CAACL,UAAUA,MAAKM,SAAS,GAAGC,UAAUV,EAAE,cAAqBW,YAAKR,KAAAA,IAAeS,YAAI,CAAA,GAC7FC,WAAI,CAACV,UAAS;MACnB;QACEH,IAAI,cAAcG,MAAKH,EAAE;QACzBS,MAAM,GAAGR,KAAKD,EAAE;QAChBc,MAAM,GAAGb,KAAKD,EAAE;QAChBe,YAAY;UACVC,OAAO;YAAC;YAA0B;cAAEC,IAAIhB,KAAKD;YAAG;;UAChDkB,MAAM;QACR;MACF;KACD,GACMC,iBAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACApB,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,KAAKC,KAAK,CAACC,QACAC,cACPD,IAAIH,IAAAA,GACGK,eAAQ,CAACL,UAAUA,MAAKM,SAAS,GAAGC,UAAUV,EAAE,cAAqBW,YAAKR,KAAAA,IAAeS,YAAI,CAAA,GAC7FC,WAAI,CAACV,UAAS;MACnB;QACEH,IAAI,aAAaG,MAAKH,EAAE;QACxBS,MAAM,GAAGR,KAAKD,EAAE;QAChBc,MAAM,GAAGb,KAAKD,EAAE;QAChBe,YAAY;UACVC,OAAO;YAAC;YAAyB;cAAEC,IAAIhB,KAAKD;YAAG;;UAC/CkB,MAAM;QACR;MACF;KACD,GACMC,iBAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACApB,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,KAAKC,KAAK,CAACC,QACAC,cACPD,IAAIH,IAAAA,GACGK,eAAQ,CAACL,UAAUiB,IAAIC,WAAWC,OAAOA,QAAQnB,MAAKW,IAAI,IAAWH,YAAKR,KAAAA,IAAeS,YAAI,CAAA,GAC7FC,WAAI,CAACV,UAAS;MACnB;QACEH,IAAI;UAACG,MAAKH;UAAI;UAAcuB,KAAKC,yBAAAA;QACjCf,MAAMgB;QACNX,MAAM;QACNC,YAAY;UACVC,OAAO;YAAC;YAA2B;cAAEC,IAAIhB,KAAKD;YAAG;;UACjDkB,MAAM;UACNQ,aAAa;QACf;MACF;KACD,GACMP,iBAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;CACD;",
6
+ "names": ["Atom", "Function", "Option", "Capabilities", "contributes", "Obj", "Script", "ATTENDABLE_PATH_SEPARATOR", "PLANK_COMPANION_TYPE", "createExtension", "meta", "spaceMeta", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "meta", "connector", "node", "Atom", "make", "get", "pipe", "flatMap", "type", "spaceMeta", "some", "none", "map", "data", "properties", "label", "ns", "icon", "getOrElse", "Obj", "instanceOf", "Script", "join", "ATTENDABLE_PATH_SEPARATOR", "PLANK_COMPANION_TYPE", "disposition"]
7
+ }
@@ -1,40 +1,59 @@
1
1
  import {
2
2
  TriggerEditor
3
- } from "./chunk-FSJZXTS2.mjs";
3
+ } from "./chunk-JW7XSPYW.mjs";
4
4
  import {
5
- AUTOMATION_PLUGIN
6
- } from "./chunk-GW5U2DGT.mjs";
5
+ meta
6
+ } from "./chunk-LZQFZO3B.mjs";
7
7
 
8
8
  // src/components/AutomationPanel/AutomationPanel.tsx
9
9
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
10
- import { Schema } from "effect";
11
- import React, { useState } from "react";
12
- import { Filter, Obj } from "@dxos/echo";
13
- import { FunctionType, FunctionTrigger, FunctionTriggerSchema, ScriptType, TriggerKind } from "@dxos/functions";
10
+ import * as Array from "effect/Array";
11
+ import * as EFn from "effect/Function";
12
+ import * as Match from "effect/Match";
13
+ import * as Schema from "effect/Schema";
14
+ import React, { useMemo, useState } from "react";
15
+ import { Filter, Obj, Tag } from "@dxos/echo";
16
+ import { Function, Script, Trigger } from "@dxos/functions";
17
+ import { useTypeOptions } from "@dxos/plugin-space";
14
18
  import { useClient } from "@dxos/react-client";
15
- import { useQuery, getSpace } from "@dxos/react-client/echo";
19
+ import { getSpace, useQuery } from "@dxos/react-client/echo";
16
20
  import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
17
21
  import { ControlItem, controlItemClasses } from "@dxos/react-ui-form";
18
22
  import { List } from "@dxos/react-ui-list";
19
23
  import { ghostHover, mx } from "@dxos/react-ui-theme";
24
+ import { View } from "@dxos/schema";
25
+ import { Project } from "@dxos/types";
20
26
  var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
21
- var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
27
+ var AutomationPanel = ({ classNames, space, object, initialTrigger, onDone }) => {
22
28
  var _effect = _useSignals();
23
29
  try {
24
- const { t } = useTranslation(AUTOMATION_PLUGIN);
30
+ const { t } = useTranslation(meta.id);
25
31
  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));
32
+ const functions = useQuery(space, Filter.type(Function.Function));
33
+ const triggers = useQuery(space, Filter.type(Trigger.Trigger));
34
+ const filteredTriggers = useMemo(() => {
35
+ return object ? triggers.filter(triggerMatch(object)) : triggers;
36
+ }, [
37
+ object,
38
+ triggers
39
+ ]);
40
+ const tags = useQuery(space, Filter.type(Tag.Tag));
41
+ const types = useTypeOptions({
42
+ space,
43
+ annotation: [
44
+ "dynamic",
45
+ "limited-static",
46
+ "object-form"
47
+ ]
48
+ });
29
49
  const [trigger, setTrigger] = useState(initialTrigger);
30
50
  const [selected, setSelected] = useState();
31
51
  const handleSelect = (trigger2) => {
32
- const { id: _, ...values } = trigger2;
33
- setTrigger(values);
52
+ setTrigger(trigger2);
34
53
  setSelected(trigger2);
35
54
  };
36
55
  const handleAdd = () => {
37
- setTrigger(Obj.make(FunctionTriggerSchema, {}));
56
+ setTrigger(Trigger.make({}));
38
57
  setSelected(void 0);
39
58
  };
40
59
  const handleDelete = (trigger2) => {
@@ -46,7 +65,7 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
46
65
  if (selected) {
47
66
  Object.assign(selected, trigger2);
48
67
  } else {
49
- space.db.add(Obj.make(FunctionTrigger, trigger2));
68
+ space.db.add(Trigger.make(trigger2));
50
69
  }
51
70
  setTrigger(void 0);
52
71
  setSelected(void 0);
@@ -62,40 +81,43 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
62
81
  }, /* @__PURE__ */ React.createElement(TriggerEditor, {
63
82
  space,
64
83
  trigger,
84
+ readonlySpec: Boolean(object),
85
+ tags,
86
+ types,
65
87
  onSave: handleSave,
66
88
  onCancel: handleCancel
67
89
  }));
68
90
  }
69
91
  return /* @__PURE__ */ React.createElement("div", {
70
- className: controlItemClasses
71
- }, triggers.length > 0 && /* @__PURE__ */ React.createElement(List.Root, {
72
- items: triggers,
73
- isItem: Schema.is(FunctionTrigger),
92
+ className: mx(controlItemClasses, classNames)
93
+ }, filteredTriggers.length > 0 && /* @__PURE__ */ React.createElement(List.Root, {
94
+ items: filteredTriggers,
95
+ isItem: Schema.is(Trigger.Trigger),
74
96
  getId: (field) => field.id
75
- }, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
97
+ }, ({ items: filteredTriggers2 }) => /* @__PURE__ */ React.createElement("div", {
76
98
  role: "list",
77
- className: "flex flex-col w-full"
78
- }, triggers2?.map((trigger2) => {
99
+ className: "flex flex-col is-full"
100
+ }, filteredTriggers2?.map((trigger2) => {
79
101
  const copyAction = getCopyAction(client, trigger2);
80
102
  return /* @__PURE__ */ React.createElement(List.Item, {
81
103
  key: trigger2.id,
82
104
  item: trigger2,
83
- classNames: mx(grid, ghostHover, "items-center", "px-2")
105
+ classNames: mx(grid, ghostHover, "items-center", "pli-2")
84
106
  }, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.Switch, {
85
107
  checked: trigger2.enabled,
86
108
  onCheckedChange: (checked) => trigger2.enabled = checked
87
109
  })), /* @__PURE__ */ React.createElement("div", {
88
110
  className: "flex"
89
111
  }, /* @__PURE__ */ React.createElement(List.ItemTitle, {
90
- classNames: "px-1 cursor-pointer w-0 shrink truncate",
112
+ classNames: "pli-1 cursor-pointer w-0 shrink truncate",
91
113
  onClick: () => handleSelect(trigger2)
92
- }, getFunctionName(scripts, functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
114
+ }, getFunctionName(functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
93
115
  label: t(copyAction.translationKey),
94
116
  value: copyAction.contentProvider()
95
117
  })), /* @__PURE__ */ React.createElement(List.ItemDeleteButton, {
96
118
  onClick: () => handleDelete(trigger2)
97
119
  }));
98
- }))), triggers.length > 0 && /* @__PURE__ */ React.createElement(Separator, {
120
+ }))), filteredTriggers.length > 0 && /* @__PURE__ */ React.createElement(Separator, {
99
121
  classNames: "mlb-4"
100
122
  }), /* @__PURE__ */ React.createElement(IconButton, {
101
123
  icon: "ph--plus--regular",
@@ -107,13 +129,13 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
107
129
  }
108
130
  };
109
131
  var getCopyAction = (client, trigger) => {
110
- if (trigger?.spec?.kind === TriggerKind.Email) {
132
+ if (trigger?.spec?.kind === "email") {
111
133
  return {
112
134
  translationKey: "trigger copy email",
113
135
  contentProvider: () => `${getSpace(trigger).id}@dxos.network`
114
136
  };
115
137
  }
116
- if (trigger?.spec?.kind === TriggerKind.Webhook) {
138
+ if (trigger?.spec?.kind === "webhook") {
117
139
  return {
118
140
  translationKey: "trigger copy url",
119
141
  contentProvider: () => getWebhookUrl(client, trigger)
@@ -128,14 +150,29 @@ var getWebhookUrl = (client, trigger) => {
128
150
  edgeUrl.protocol = isSecure ? "https" : "http";
129
151
  return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
130
152
  };
131
- var getFunctionName = (scripts, functions, trigger) => {
153
+ var getFunctionName = (functions, trigger) => {
132
154
  const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
133
155
  const functionObject = functions.find((fn) => fn === trigger.function?.target);
134
- if (!functionObject) {
135
- return shortId;
156
+ return functionObject?.name ?? shortId;
157
+ };
158
+ var scriptMatch = (script) => (trigger) => {
159
+ const fn = trigger.function?.target;
160
+ if (!Obj.instanceOf(Function.Function, fn)) {
161
+ return false;
136
162
  }
137
- return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;
163
+ return fn.source?.target === script;
164
+ };
165
+ var projectMatch = (project) => {
166
+ const viewQueries = EFn.pipe(project.collections, Array.map((collection) => collection.target), Array.filter(Schema.is(View.View)), Array.map((view) => Obj.getSnapshot(view).query.ast), Array.map((ast) => JSON.stringify(ast)));
167
+ return (trigger) => {
168
+ const spec = Obj.getSnapshot(trigger).spec;
169
+ if (spec?.kind !== "subscription") {
170
+ return false;
171
+ }
172
+ return viewQueries.some((query) => JSON.stringify(spec.query) === query);
173
+ };
138
174
  };
175
+ var triggerMatch = Match.type().pipe(Match.withReturnType(), Match.when((obj) => Obj.instanceOf(Script.Script, obj), (obj) => scriptMatch(obj)), Match.when((obj) => Obj.instanceOf(Project.Project, obj), (obj) => projectMatch(obj)), Match.orElse((_obj) => () => true));
139
176
 
140
177
  // src/components/AutomationPanel/index.ts
141
178
  var AutomationPanel_default = AutomationPanel;
@@ -144,4 +181,4 @@ export {
144
181
  AutomationPanel,
145
182
  AutomationPanel_default
146
183
  };
147
- //# sourceMappingURL=chunk-ERTIGJYE.mjs.map
184
+ //# sourceMappingURL=chunk-DLZNSNOV.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 * as Array from 'effect/Array';\nimport * as EFn from 'effect/Function';\nimport * as Match from 'effect/Match';\nimport * as Schema from 'effect/Schema';\nimport React, { useMemo, useState } from 'react';\n\nimport { Filter, Obj, Tag } from '@dxos/echo';\nimport { Function, Script, Trigger } from '@dxos/functions';\nimport { useTypeOptions } from '@dxos/plugin-space';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { type Space, getSpace, useQuery } from '@dxos/react-client/echo';\nimport { Clipboard, IconButton, Input, Separator, type ThemedClassName, 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';\nimport { View } from '@dxos/schema';\nimport { Project } from '@dxos/types';\n\nimport { meta } 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 = ThemedClassName<{\n space: Space;\n object?: Obj.Any;\n initialTrigger?: Trigger.Trigger;\n onDone?: () => void;\n}>;\n\n// TODO(burdon): Factor out common layout with ViewEditor.\nexport const AutomationPanel = ({ classNames, space, object, initialTrigger, onDone }: AutomationPanelProps) => {\n const { t } = useTranslation(meta.id);\n const client = useClient();\n const functions = useQuery(space, Filter.type(Function.Function));\n const triggers = useQuery(space, Filter.type(Trigger.Trigger));\n const filteredTriggers = useMemo(() => {\n return object ? triggers.filter(triggerMatch(object)) : triggers;\n }, [object, triggers]);\n const tags = useQuery(space, Filter.type(Tag.Tag));\n const types = useTypeOptions({ space, annotation: ['dynamic', 'limited-static', 'object-form'] });\n\n const [trigger, setTrigger] = useState<Trigger.Trigger | undefined>(initialTrigger);\n const [selected, setSelected] = useState<Trigger.Trigger>();\n\n const handleSelect = (trigger: Trigger.Trigger) => {\n setTrigger(trigger);\n setSelected(trigger);\n };\n\n const handleAdd = () => {\n setTrigger(Trigger.make({}));\n setSelected(undefined);\n };\n\n const handleDelete = (trigger: Trigger.Trigger) => {\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(Trigger.make(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\n space={space}\n trigger={trigger}\n readonlySpec={Boolean(object)}\n tags={tags}\n types={types}\n onSave={handleSave}\n onCancel={handleCancel}\n />\n </ControlItem>\n );\n }\n\n return (\n <div className={mx(controlItemClasses, classNames)}>\n {filteredTriggers.length > 0 && (\n <List.Root<Trigger.Trigger>\n items={filteredTriggers}\n isItem={Schema.is(Trigger.Trigger)}\n getId={(field) => field.id}\n >\n {({ items: filteredTriggers }) => (\n <div role='list' className='flex flex-col is-full'>\n {filteredTriggers?.map((trigger) => {\n const copyAction = getCopyAction(client, trigger);\n return (\n <List.Item<Trigger.Trigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center', 'pli-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='pli-1 cursor-pointer w-0 shrink truncate'\n onClick={() => handleSelect(trigger)}\n >\n {getFunctionName(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 {filteredTriggers.length > 0 && <Separator classNames='mlb-4' />}\n <IconButton icon='ph--plus--regular' label={t('new trigger label')} onClick={handleAdd} />\n </div>\n );\n};\n\nconst getCopyAction = (client: Client, trigger: Trigger.Trigger | undefined) => {\n if (trigger?.spec?.kind === 'email') {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.kind === 'webhook') {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: Trigger.Trigger) => {\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 = (functions: Function.Function[], trigger: Trigger.Trigger) => {\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 return functionObject?.name ?? shortId;\n};\n\nconst scriptMatch = (script: Script.Script) => (trigger: Trigger.Trigger) => {\n const fn = trigger.function?.target;\n if (!Obj.instanceOf(Function.Function, fn)) {\n return false;\n }\n\n return fn.source?.target === script;\n};\n\nconst projectMatch = (project: Project.Project) => {\n const viewQueries = EFn.pipe(\n project.collections,\n Array.map((collection) => collection.target),\n Array.filter(Schema.is(View.View)),\n Array.map((view) => Obj.getSnapshot(view).query.ast),\n Array.map((ast) => JSON.stringify(ast)),\n );\n\n return (trigger: Trigger.Trigger) => {\n const spec = Obj.getSnapshot(trigger).spec;\n if (spec?.kind !== 'subscription') {\n return false;\n }\n\n // TODO(wittjosiah): Implement better way of comparing query ASTs.\n return viewQueries.some((query) => JSON.stringify(spec.query) === query);\n };\n};\n\nconst triggerMatch = Match.type<Obj.Any>().pipe(\n Match.withReturnType<(trigger: Trigger.Trigger) => boolean>(),\n Match.when(\n (obj) => Obj.instanceOf(Script.Script, obj),\n (obj) => scriptMatch(obj),\n ),\n Match.when(\n (obj) => Obj.instanceOf(Project.Project, obj),\n (obj) => projectMatch(obj),\n ),\n Match.orElse((_obj) => () => true),\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": ["Array", "EFn", "Match", "Schema", "React", "useMemo", "useState", "Filter", "Obj", "Tag", "Function", "Script", "Trigger", "useTypeOptions", "useClient", "getSpace", "useQuery", "Clipboard", "IconButton", "Input", "Separator", "useTranslation", "ControlItem", "controlItemClasses", "List", "ghostHover", "mx", "View", "Project", "grid", "AutomationPanel", "classNames", "space", "object", "initialTrigger", "onDone", "t", "useTranslation", "meta", "id", "client", "useClient", "functions", "useQuery", "Filter", "type", "Function", "triggers", "Trigger", "filteredTriggers", "useMemo", "filter", "triggerMatch", "tags", "Tag", "types", "useTypeOptions", "annotation", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "handleAdd", "make", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "ControlItem", "title", "TriggerEditor", "readonlySpec", "Boolean", "onSave", "onCancel", "div", "className", "mx", "controlItemClasses", "length", "List", "Root", "items", "isItem", "is", "getId", "field", "role", "map", "copyAction", "getCopyAction", "Item", "key", "item", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "Clipboard", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "Separator", "icon", "spec", "kind", "getSpace", "getWebhookUrl", "spaceId", "edgeUrl", "URL", "config", "values", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "shortId", "function", "dxn", "slice", "functionObject", "find", "fn", "target", "name", "scriptMatch", "script", "Obj", "instanceOf", "source", "projectMatch", "project", "viewQueries", "pipe", "collections", "collection", "View", "view", "getSnapshot", "query", "ast", "JSON", "stringify", "some", "withReturnType", "when", "obj", "Script", "Project", "orElse", "_obj", "AutomationPanel"]
7
+ }
@@ -0,0 +1,14 @@
1
+ // src/components/index.ts
2
+ import { lazy } from "react";
3
+ var AutomationPanel = lazy(() => import("./AutomationPanel-W6K45EP4.mjs"));
4
+ var AutomationSettings = lazy(() => import("./AutomationSettings-YGXYZZEU.mjs"));
5
+ var FunctionsContainer = lazy(() => import("./FunctionsContainer-JIFRD7DW.mjs"));
6
+ var FunctionsPanel = lazy(() => import("./FunctionsPanel-CRW6SJUN.mjs"));
7
+
8
+ export {
9
+ AutomationPanel,
10
+ AutomationSettings,
11
+ FunctionsContainer,
12
+ FunctionsPanel
13
+ };
14
+ //# sourceMappingURL=chunk-HUHVG4BU.mjs.map