@dxos/plugin-debug 0.8.4-main.67995b8 → 0.8.4-main.f5c0578
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.
- package/dist/lib/browser/{DebugApp-ZDL4CPY5.mjs → DebugApp-F4UFVW4Y.mjs} +40 -40
- package/dist/lib/browser/DebugApp-F4UFVW4Y.mjs.map +7 -0
- package/dist/lib/browser/{SpaceGenerator-6ZOCEREN.mjs → SpaceGenerator-XJJAOTIT.mjs} +33 -34
- package/dist/lib/browser/SpaceGenerator-XJJAOTIT.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-builder-SQXFD2BL.mjs → app-graph-builder-PXPZIIGY.mjs} +4 -4
- package/dist/lib/browser/{app-graph-builder-SQXFD2BL.mjs.map → app-graph-builder-PXPZIIGY.mjs.map} +3 -3
- package/dist/lib/browser/index.mjs +3 -3
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-CHHHE5CF.mjs → react-surface-UNFNQFWK.mjs} +6 -6
- package/dist/lib/browser/{react-surface-CHHHE5CF.mjs.map → react-surface-UNFNQFWK.mjs.map} +3 -3
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/components/DebugApp/DebugApp.d.ts.map +1 -1
- package/dist/types/src/components/SpaceGenerator/ObjectGenerator.d.ts.map +1 -1
- package/dist/types/src/components/SpaceGenerator/SpaceGenerator.d.ts.map +1 -1
- package/dist/types/src/components/SpaceGenerator/draw-util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +55 -55
- package/src/DebugPlugin.tsx +1 -1
- package/src/capabilities/app-graph-builder.ts +3 -3
- package/src/capabilities/react-surface.tsx +3 -3
- package/src/components/DebugApp/DebugApp.tsx +3 -2
- package/src/components/DebugSettings.tsx +2 -2
- package/src/components/SpaceGenerator/ObjectGenerator.tsx +3 -3
- package/src/components/SpaceGenerator/SpaceGenerator.stories.tsx +1 -1
- package/src/components/SpaceGenerator/SpaceGenerator.tsx +4 -4
- package/src/components/SpaceGenerator/draw-util.ts +3 -3
- package/src/components/SpaceGenerator/presets.ts +1 -1
- package/dist/lib/browser/DebugApp-ZDL4CPY5.mjs.map +0 -7
- package/dist/lib/browser/SpaceGenerator-6ZOCEREN.mjs.map +0 -7
|
@@ -2,11 +2,28 @@
|
|
|
2
2
|
import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
|
|
3
3
|
import React3, { useEffect, useState as useState2 } from "react";
|
|
4
4
|
import { useClient, useConfig } from "@dxos/react-client";
|
|
5
|
-
import {
|
|
5
|
+
import { Icon, IconButton, ToggleGroup, ToggleGroupItem, Toolbar } from "@dxos/react-ui";
|
|
6
6
|
|
|
7
|
-
// src/components/
|
|
7
|
+
// src/components/Container.tsx
|
|
8
8
|
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
9
|
-
import React
|
|
9
|
+
import React from "react";
|
|
10
|
+
var Container = ({ toolbar, children }) => {
|
|
11
|
+
var _effect = _useSignals();
|
|
12
|
+
try {
|
|
13
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
14
|
+
role: "none",
|
|
15
|
+
className: "flex flex-col grow overflow-hidden divide-y divide-separator"
|
|
16
|
+
}, toolbar, /* @__PURE__ */ React.createElement("div", {
|
|
17
|
+
className: "flex flex-col grow overflow-auto"
|
|
18
|
+
}, children));
|
|
19
|
+
} finally {
|
|
20
|
+
_effect.f();
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
// src/components/DebugApp/Tree.tsx
|
|
25
|
+
import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
|
|
26
|
+
import React2, { useState } from "react";
|
|
10
27
|
import { SyntaxHighlighter } from "@dxos/react-ui-syntax-highlighter";
|
|
11
28
|
import { mx } from "@dxos/react-ui-theme";
|
|
12
29
|
import { arrayToBuffer } from "@dxos/util";
|
|
@@ -25,9 +42,9 @@ var replacer = (key, value) => {
|
|
|
25
42
|
return value;
|
|
26
43
|
};
|
|
27
44
|
var Json = ({ data }) => {
|
|
28
|
-
var _effect =
|
|
45
|
+
var _effect = _useSignals2();
|
|
29
46
|
try {
|
|
30
|
-
return /* @__PURE__ */
|
|
47
|
+
return /* @__PURE__ */ React2.createElement(SyntaxHighlighter, {
|
|
31
48
|
language: "json"
|
|
32
49
|
}, JSON.stringify(data, replacer, 2));
|
|
33
50
|
} finally {
|
|
@@ -35,11 +52,11 @@ var Json = ({ data }) => {
|
|
|
35
52
|
}
|
|
36
53
|
};
|
|
37
54
|
var Tree = ({ data }) => {
|
|
38
|
-
var _effect =
|
|
55
|
+
var _effect = _useSignals2();
|
|
39
56
|
try {
|
|
40
|
-
return /* @__PURE__ */
|
|
57
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
41
58
|
className: "p-2"
|
|
42
|
-
}, /* @__PURE__ */
|
|
59
|
+
}, /* @__PURE__ */ React2.createElement(Node, {
|
|
43
60
|
data,
|
|
44
61
|
root: true
|
|
45
62
|
}));
|
|
@@ -48,26 +65,26 @@ var Tree = ({ data }) => {
|
|
|
48
65
|
}
|
|
49
66
|
};
|
|
50
67
|
var Node = ({ data, root }) => {
|
|
51
|
-
var _effect =
|
|
68
|
+
var _effect = _useSignals2();
|
|
52
69
|
try {
|
|
53
70
|
if (typeof data !== "object" || data === void 0 || data === null) {
|
|
54
|
-
return /* @__PURE__ */
|
|
71
|
+
return /* @__PURE__ */ React2.createElement(Scalar, {
|
|
55
72
|
value: data
|
|
56
73
|
});
|
|
57
74
|
}
|
|
58
75
|
if (Array.isArray(data)) {
|
|
59
|
-
return /* @__PURE__ */
|
|
76
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
60
77
|
className: "flex flex-col space-y-2"
|
|
61
|
-
}, data.map((value, index) => /* @__PURE__ */
|
|
78
|
+
}, data.map((value, index) => /* @__PURE__ */ React2.createElement(KeyValue, {
|
|
62
79
|
key: index,
|
|
63
80
|
label: String(index),
|
|
64
81
|
data: value,
|
|
65
82
|
className: "bg-teal-50"
|
|
66
83
|
})));
|
|
67
84
|
}
|
|
68
|
-
return /* @__PURE__ */
|
|
85
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
69
86
|
className: "flex flex-col space-y-2"
|
|
70
|
-
}, Object.entries(data).map(([key, value]) => /* @__PURE__ */
|
|
87
|
+
}, Object.entries(data).map(([key, value]) => /* @__PURE__ */ React2.createElement(KeyValue, {
|
|
71
88
|
key,
|
|
72
89
|
label: key,
|
|
73
90
|
data: value,
|
|
@@ -78,18 +95,18 @@ var Node = ({ data, root }) => {
|
|
|
78
95
|
}
|
|
79
96
|
};
|
|
80
97
|
var KeyValue = ({ label, data, className }) => {
|
|
81
|
-
var _effect =
|
|
98
|
+
var _effect = _useSignals2();
|
|
82
99
|
try {
|
|
83
100
|
const [open, setOpen] = useState(true);
|
|
84
101
|
if (data === void 0) {
|
|
85
102
|
return null;
|
|
86
103
|
}
|
|
87
|
-
return /* @__PURE__ */
|
|
104
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
88
105
|
className: "flex"
|
|
89
|
-
}, /* @__PURE__ */
|
|
106
|
+
}, /* @__PURE__ */ React2.createElement(Box, {
|
|
90
107
|
className: mx("border-blue-200 text-sm select-none cursor-pointer", className),
|
|
91
108
|
onClick: () => setOpen((open2) => !open2)
|
|
92
|
-
}, label), open && /* @__PURE__ */
|
|
109
|
+
}, label), open && /* @__PURE__ */ React2.createElement(Node, {
|
|
93
110
|
data
|
|
94
111
|
}));
|
|
95
112
|
} finally {
|
|
@@ -97,9 +114,9 @@ var KeyValue = ({ label, data, className }) => {
|
|
|
97
114
|
}
|
|
98
115
|
};
|
|
99
116
|
var Scalar = ({ value }) => {
|
|
100
|
-
var _effect =
|
|
117
|
+
var _effect = _useSignals2();
|
|
101
118
|
try {
|
|
102
|
-
return /* @__PURE__ */
|
|
119
|
+
return /* @__PURE__ */ React2.createElement(Box, {
|
|
103
120
|
className: "bg-green-50 border-green-200 rounded-r text-sm font-thin"
|
|
104
121
|
}, value === void 0 && "undefined" || value === null && "null" || typeof value === "string" && value || JSON.stringify(value));
|
|
105
122
|
} finally {
|
|
@@ -107,9 +124,9 @@ var Scalar = ({ value }) => {
|
|
|
107
124
|
}
|
|
108
125
|
};
|
|
109
126
|
var Box = ({ children, className, ...props }) => {
|
|
110
|
-
var _effect =
|
|
127
|
+
var _effect = _useSignals2();
|
|
111
128
|
try {
|
|
112
|
-
return /* @__PURE__ */
|
|
129
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
113
130
|
className: mx("flex px-2 border border-l-0 font-mono truncate", className),
|
|
114
131
|
...props
|
|
115
132
|
}, children);
|
|
@@ -118,23 +135,6 @@ var Box = ({ children, className, ...props }) => {
|
|
|
118
135
|
}
|
|
119
136
|
};
|
|
120
137
|
|
|
121
|
-
// src/components/Container.tsx
|
|
122
|
-
import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
|
|
123
|
-
import React2 from "react";
|
|
124
|
-
var Container = ({ toolbar, children }) => {
|
|
125
|
-
var _effect = _useSignals2();
|
|
126
|
-
try {
|
|
127
|
-
return /* @__PURE__ */ React2.createElement("div", {
|
|
128
|
-
role: "none",
|
|
129
|
-
className: "flex flex-col grow overflow-hidden divide-y divide-separator"
|
|
130
|
-
}, toolbar, /* @__PURE__ */ React2.createElement("div", {
|
|
131
|
-
className: "flex flex-col grow overflow-auto"
|
|
132
|
-
}, children));
|
|
133
|
-
} finally {
|
|
134
|
-
_effect.f();
|
|
135
|
-
}
|
|
136
|
-
};
|
|
137
|
-
|
|
138
138
|
// src/components/DebugApp/DebugApp.tsx
|
|
139
139
|
var DebugApp = ({ graph }) => {
|
|
140
140
|
var _effect = _useSignals3();
|
|
@@ -225,4 +225,4 @@ var DebugApp_default = DebugApp;
|
|
|
225
225
|
export {
|
|
226
226
|
DebugApp_default as default
|
|
227
227
|
};
|
|
228
|
-
//# sourceMappingURL=DebugApp-
|
|
228
|
+
//# sourceMappingURL=DebugApp-F4UFVW4Y.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/DebugApp/DebugApp.tsx", "../../../src/components/Container.tsx", "../../../src/components/DebugApp/Tree.tsx", "../../../src/components/DebugApp/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type FC, useEffect, useState } from 'react';\n\nimport { type Graph } from '@dxos/plugin-graph';\nimport { useClient, useConfig } from '@dxos/react-client';\nimport { Icon, IconButton, ToggleGroup, ToggleGroupItem, Toolbar } from '@dxos/react-ui';\n\nimport { Container } from '../Container';\n\nimport { Json, Tree } from './Tree';\n\nexport const DebugApp: FC<{ graph: Graph }> = ({ graph }) => {\n const [view, setView] = useState<'config' | 'diagnostics' | 'graph'>('graph');\n const [data, setData] = useState<any>({});\n const client = useClient();\n const config = useConfig();\n const handleRefresh = async () => {\n const data = await client.diagnostics({ truncate: true });\n setData(data);\n };\n useEffect(() => {\n void handleRefresh();\n }, []);\n\n const handleResetClient = async (force = false) => {\n if (!force && !window.confirm('Reset storage?')) {\n return;\n }\n\n // TODO(burdon): Throws exception.\n await client.reset();\n window.location.href = window.location.origin;\n };\n\n const handleOpenDevtools = () => {\n const vaultUrl = config.values?.runtime?.client?.remoteSource;\n if (vaultUrl) {\n window.open(`https://devtools.dev.dxos.org/?target=${vaultUrl}`);\n }\n };\n\n return (\n <Container\n toolbar={\n <Toolbar.Root classNames='p-1'>\n <ToggleGroup type='single' value={view}>\n <ToggleGroupItem value={'graph'} onClick={() => setView('graph')} title={'Plugin graph'}>\n <Icon icon='ph--graph--regular' size={5} />\n </ToggleGroupItem>\n <ToggleGroupItem value={'diagnostics'} onClick={() => setView('diagnostics')} title={'Diagnostics'}>\n <Icon icon='ph--gauge--regular' size={5} />\n </ToggleGroupItem>\n <ToggleGroupItem value={'config'} onClick={() => setView('config')} title={'Config'}>\n <Icon icon='ph--gear--regular' size={5} />\n </ToggleGroupItem>\n </ToggleGroup>\n\n <Toolbar.Separator variant='gap' />\n <IconButton\n icon='ph--warning--regular'\n iconOnly\n size={5}\n classNames='text-red-700'\n onClick={(event) => handleResetClient(event.shiftKey)}\n label='Reset client'\n />\n <IconButton\n icon='ph--toolbox--duotone'\n iconOnly\n size={5}\n onClick={handleOpenDevtools}\n label='Open Devtools'\n />\n </Toolbar.Root>\n }\n >\n {view === 'graph' && <Tree data={graph.toJSON()} />}\n {view === 'config' && <Json data={data.diagnostics?.config} />}\n {view === 'diagnostics' && <Json data={data} />}\n </Container>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type PropsWithChildren, type ReactNode } from 'react';\n\n// TODO(burdon): Convert to grid.\nexport const Container = ({ toolbar, children }: PropsWithChildren<{ toolbar: ReactNode }>) => {\n return (\n <div role='none' className='flex flex-col grow overflow-hidden divide-y divide-separator'>\n {toolbar}\n <div className='flex flex-col grow overflow-auto'>{children}</div>\n </div>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type FC, type HTMLAttributes, useState } from 'react';\n\nimport { SyntaxHighlighter } from '@dxos/react-ui-syntax-highlighter';\nimport { mx } from '@dxos/react-ui-theme';\nimport { arrayToBuffer } from '@dxos/util';\n\n// TODO(burdon): Copied form devtools.\n\nexport const replacer = (key: any, value: any) => {\n if (typeof value === 'object') {\n if (value instanceof Uint8Array) {\n return arrayToBuffer(value).toString('hex');\n }\n\n if (value?.type === 'Buffer') {\n return Buffer.from(value.data).toString('hex');\n }\n\n if (key === 'downloaded') {\n return undefined;\n }\n }\n\n return value;\n};\n\nexport const Json: FC<{ data?: object }> = ({ data }) => {\n return <SyntaxHighlighter language='json'>{JSON.stringify(data, replacer, 2)}</SyntaxHighlighter>;\n};\n\nexport const Tree: FC<{ data?: object }> = ({ data }) => {\n return (\n <div className='p-2'>\n <Node data={data} root />\n </div>\n );\n};\n\nexport const Node: FC<{ data?: any; root?: boolean }> = ({ data, root }) => {\n if (typeof data !== 'object' || data === undefined || data === null) {\n return <Scalar value={data} />;\n }\n\n if (Array.isArray(data)) {\n return (\n <div className='flex flex-col space-y-2'>\n {data.map((value, index) => (\n <KeyValue key={index} label={String(index)} data={value} className='bg-teal-50' />\n ))}\n </div>\n );\n }\n\n return (\n <div className='flex flex-col space-y-2'>\n {Object.entries(data).map(([key, value]) => (\n <KeyValue key={key} label={key} data={value} className='bg-blue-50' />\n ))}\n </div>\n );\n};\n\nexport const KeyValue: FC<{ label: string; data?: any; className?: string }> = ({ label, data, className }) => {\n const [open, setOpen] = useState(true);\n if (data === undefined) {\n return null;\n }\n\n return (\n <div className='flex'>\n <Box\n className={mx('border-blue-200 text-sm select-none cursor-pointer', className)}\n onClick={() => setOpen((open) => !open)}\n >\n {label}\n </Box>\n {open && <Node data={data} />}\n </div>\n );\n};\n\nconst Scalar: FC<{ value: any }> = ({ value }) => {\n return (\n <Box className='bg-green-50 border-green-200 rounded-r text-sm font-thin'>\n {(value === undefined && 'undefined') ||\n (value === null && 'null') ||\n (typeof value === 'string' && value) ||\n JSON.stringify(value)}\n </Box>\n );\n};\n\nconst Box: FC<HTMLAttributes<HTMLDivElement>> = ({ children, className, ...props }) => {\n return (\n <div className={mx('flex px-2 border border-l-0 font-mono truncate', className)} {...props}>\n {children}\n </div>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { DebugApp } from './DebugApp';\n\nexport default DebugApp;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "useEffect", "useState", "useClient", "useConfig", "Icon", "IconButton", "ToggleGroup", "ToggleGroupItem", "Toolbar", "React", "Container", "toolbar", "children", "div", "role", "className", "React", "useState", "SyntaxHighlighter", "mx", "arrayToBuffer", "replacer", "key", "value", "Uint8Array", "arrayToBuffer", "toString", "type", "Buffer", "from", "data", "undefined", "Json", "React", "SyntaxHighlighter", "language", "JSON", "stringify", "Tree", "div", "className", "Node", "root", "Scalar", "Array", "isArray", "map", "index", "KeyValue", "label", "String", "Object", "entries", "open", "setOpen", "useState", "Box", "mx", "onClick", "children", "props", "DebugApp", "graph", "view", "setView", "useState", "data", "setData", "client", "useClient", "config", "useConfig", "handleRefresh", "diagnostics", "truncate", "useEffect", "handleResetClient", "force", "window", "confirm", "reset", "location", "href", "origin", "handleOpenDevtools", "vaultUrl", "values", "runtime", "remoteSource", "open", "React", "Container", "toolbar", "Toolbar", "Root", "classNames", "ToggleGroup", "type", "value", "ToggleGroupItem", "onClick", "title", "Icon", "icon", "size", "Separator", "variant", "IconButton", "iconOnly", "event", "shiftKey", "label", "Tree", "toJSON", "Json", "DebugApp"]
|
|
7
|
+
}
|
|
@@ -196,43 +196,13 @@ var staticGenerators = /* @__PURE__ */ new Map([
|
|
|
196
196
|
]
|
|
197
197
|
]);
|
|
198
198
|
|
|
199
|
-
// src/components/SpaceGenerator/SchemaTable.tsx
|
|
200
|
-
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
201
|
-
import React from "react";
|
|
202
|
-
import { IconButton } from "@dxos/react-ui";
|
|
203
|
-
var SchemaTable = ({ types, objects = {}, label, onClick }) => {
|
|
204
|
-
var _effect = _useSignals();
|
|
205
|
-
try {
|
|
206
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
207
|
-
className: "grid grid-cols-[1fr_80px_40px] gap-1 overflow-none"
|
|
208
|
-
}, /* @__PURE__ */ React.createElement("h2", {
|
|
209
|
-
className: "p-2"
|
|
210
|
-
}, label), types.map((type) => /* @__PURE__ */ React.createElement("div", {
|
|
211
|
-
key: type.typename,
|
|
212
|
-
className: "grid grid-cols-subgrid col-span-3 items-center"
|
|
213
|
-
}, /* @__PURE__ */ React.createElement("div", {
|
|
214
|
-
className: "px-2 text-sm font-mono text-subdued"
|
|
215
|
-
}, type.typename), /* @__PURE__ */ React.createElement("div", {
|
|
216
|
-
className: "px-2 text-right font-mono"
|
|
217
|
-
}, objects[type.typename] ?? 0), /* @__PURE__ */ React.createElement(IconButton, {
|
|
218
|
-
variant: "ghost",
|
|
219
|
-
icon: "ph--plus--regular",
|
|
220
|
-
iconOnly: true,
|
|
221
|
-
label: "Create data",
|
|
222
|
-
onClick: () => onClick(type.typename)
|
|
223
|
-
}))));
|
|
224
|
-
} finally {
|
|
225
|
-
_effect.f();
|
|
226
|
-
}
|
|
227
|
-
};
|
|
228
|
-
|
|
229
199
|
// src/components/SpaceGenerator/presets.ts
|
|
230
200
|
import { Schema } from "effect";
|
|
231
201
|
import { NODE_INPUT as NODE_INPUT2 } from "@dxos/conductor";
|
|
232
202
|
import { DXN as DXN2, Key as Key2, Obj as Obj2, Ref as Ref2, Type as Type2 } from "@dxos/echo";
|
|
233
203
|
import { FunctionTrigger, TriggerKind } from "@dxos/functions";
|
|
234
204
|
import { invariant } from "@dxos/invariant";
|
|
235
|
-
import { createAppend, createChat, createComputeGraph, createConstant, createFunction, createGpt, createQueue,
|
|
205
|
+
import { createAppend, createChat, createComputeGraph, createConstant, createFunction, createGpt, createQueue, createRandom, createSurface, createTemplate, createText, createTrigger } from "@dxos/react-ui-canvas-compute";
|
|
236
206
|
import { CanvasBoardType, CanvasGraphModel, pointMultiply, pointsToRect, rectToPoints } from "@dxos/react-ui-canvas-editor";
|
|
237
207
|
import { range as range2 } from "@dxos/util";
|
|
238
208
|
var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-debug/src/components/SpaceGenerator/presets.ts";
|
|
@@ -848,6 +818,36 @@ var position = (rect) => {
|
|
|
848
818
|
}
|
|
849
819
|
};
|
|
850
820
|
|
|
821
|
+
// src/components/SpaceGenerator/SchemaTable.tsx
|
|
822
|
+
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
823
|
+
import React from "react";
|
|
824
|
+
import { IconButton } from "@dxos/react-ui";
|
|
825
|
+
var SchemaTable = ({ types, objects = {}, label, onClick }) => {
|
|
826
|
+
var _effect = _useSignals();
|
|
827
|
+
try {
|
|
828
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
829
|
+
className: "grid grid-cols-[1fr_80px_40px] gap-1 overflow-none"
|
|
830
|
+
}, /* @__PURE__ */ React.createElement("h2", {
|
|
831
|
+
className: "p-2"
|
|
832
|
+
}, label), types.map((type) => /* @__PURE__ */ React.createElement("div", {
|
|
833
|
+
key: type.typename,
|
|
834
|
+
className: "grid grid-cols-subgrid col-span-3 items-center"
|
|
835
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
836
|
+
className: "px-2 text-sm font-mono text-subdued"
|
|
837
|
+
}, type.typename), /* @__PURE__ */ React.createElement("div", {
|
|
838
|
+
className: "px-2 text-right font-mono"
|
|
839
|
+
}, objects[type.typename] ?? 0), /* @__PURE__ */ React.createElement(IconButton, {
|
|
840
|
+
variant: "ghost",
|
|
841
|
+
icon: "ph--plus--regular",
|
|
842
|
+
iconOnly: true,
|
|
843
|
+
label: "Create data",
|
|
844
|
+
onClick: () => onClick(type.typename)
|
|
845
|
+
}))));
|
|
846
|
+
} finally {
|
|
847
|
+
_effect.f();
|
|
848
|
+
}
|
|
849
|
+
};
|
|
850
|
+
|
|
851
851
|
// src/components/SpaceGenerator/SpaceGenerator.tsx
|
|
852
852
|
var SpaceGenerator = ({ space, onCreateObjects }) => {
|
|
853
853
|
var _effect = _useSignals2();
|
|
@@ -862,9 +862,8 @@ var SpaceGenerator = ({ space, onCreateObjects }) => {
|
|
|
862
862
|
];
|
|
863
863
|
const recordTypes = [
|
|
864
864
|
DataType2.Organization,
|
|
865
|
-
DataType2.Project,
|
|
866
865
|
DataType2.Person,
|
|
867
|
-
DataType2.
|
|
866
|
+
DataType2.Task
|
|
868
867
|
];
|
|
869
868
|
const [count, setCount] = useState(1);
|
|
870
869
|
const [info, setInfo] = useState({});
|
|
@@ -978,4 +977,4 @@ var SpaceGenerator_default = SpaceGenerator;
|
|
|
978
977
|
export {
|
|
979
978
|
SpaceGenerator_default as default
|
|
980
979
|
};
|
|
981
|
-
//# sourceMappingURL=SpaceGenerator-
|
|
980
|
+
//# sourceMappingURL=SpaceGenerator-XJJAOTIT.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/SpaceGenerator/SpaceGenerator.tsx", "../../../src/components/SpaceGenerator/ObjectGenerator.tsx", "../../../src/components/SpaceGenerator/presets.ts", "../../../src/components/SpaceGenerator/SchemaTable.tsx", "../../../src/components/SpaceGenerator/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useCallback, useMemo, useState } from 'react';\n\nimport { useIntentDispatcher } from '@dxos/app-framework';\nimport { ComputeGraph } from '@dxos/conductor';\nimport { Filter, type Obj } from '@dxos/echo';\nimport { Markdown } from '@dxos/plugin-markdown/types';\nimport { SheetType } from '@dxos/plugin-sheet/types';\nimport { DiagramType } from '@dxos/plugin-sketch/types';\nimport { useClient } from '@dxos/react-client';\nimport { type Space, getTypename } from '@dxos/react-client/echo';\nimport { IconButton, Input, Toolbar, useAsyncEffect } from '@dxos/react-ui';\nimport { SyntaxHighlighter } from '@dxos/react-ui-syntax-highlighter';\nimport { DataType } from '@dxos/schema';\nimport { jsonKeyReplacer, sortKeys } from '@dxos/util';\n\nimport { type ObjectGenerator, createGenerator, staticGenerators } from './ObjectGenerator';\nimport { generator } from './presets';\nimport { SchemaTable } from './SchemaTable';\n\nexport type SpaceGeneratorProps = {\n space: Space;\n onCreateObjects?: (objects: Obj.Any[]) => void;\n};\n\nexport const SpaceGenerator = ({ space, onCreateObjects }: SpaceGeneratorProps) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const client = useClient();\n const staticTypes = [Markdown.Document, DiagramType, SheetType, ComputeGraph]; // TODO(burdon): Make extensible.\n const recordTypes = [DataType.Organization, DataType.Person, DataType.Task];\n const [count, setCount] = useState(1);\n const [info, setInfo] = useState<any>({});\n const presets = useMemo(() => generator(), []);\n\n // Create type generators.\n const typeMap = useMemo(() => {\n client.addTypes([...staticTypes, ...recordTypes, ...presets.schemas]);\n const recordGenerators = new Map<string, ObjectGenerator<any>>(\n recordTypes.map((type) => [type.typename, createGenerator(client, dispatch, type as any)]),\n );\n\n return new Map([...staticGenerators, ...presets.items, ...recordGenerators]);\n }, [client, recordTypes]);\n\n // Query space to get info.\n const updateInfo = async () => {\n // Create schema map.\n const echoSchema = await space.db.schemaRegistry.query().run();\n const staticSchema = space.db.graph.schemaRegistry.schemas;\n\n // Create object map.\n const { objects } = await space.db.query(Filter.everything()).run();\n const objectMap = sortKeys(\n objects.reduce<Record<string, number>>((map, obj) => {\n const type = getTypename(obj);\n if (type) {\n const count = map[type] ?? 0;\n map[type] = count + 1;\n }\n return map;\n }, {}),\n );\n\n setInfo({\n schema: {\n static: staticSchema.length,\n mutable: echoSchema.length,\n },\n objects: objectMap,\n });\n };\n\n useAsyncEffect(updateInfo, [space]);\n\n const handleCreateData = useCallback(\n async (typename: string) => {\n const constructor = typeMap.get(typename);\n if (constructor) {\n // TODO(burdon): Input to specify number of objects.\n await constructor(space, count, onCreateObjects);\n await updateInfo();\n }\n },\n [typeMap, count],\n );\n\n return (\n <div role='none' className='flex flex-col grow overflow-hidden'>\n <Toolbar.Root classNames='border-be border-subduedSeparator'>\n <IconButton icon='ph--arrow-clockwise--regular' iconOnly label='Refresh' onClick={updateInfo} />\n <Toolbar.Separator variant='gap' />\n <Input.Root>\n <Input.TextInput\n type='number'\n min={1}\n max={100}\n placeholder={'Count'}\n classNames='!w-[4rem] !text-right'\n size={8}\n value={count}\n onChange={(ev) => setCount(parseInt(ev.target.value))}\n />\n </Input.Root>\n </Toolbar.Root>\n\n <div className='flex flex-col overflow-y-auto divide-y divide-separator'>\n <SchemaTable types={staticTypes} objects={info.objects} label='Static Types' onClick={handleCreateData} />\n <SchemaTable types={recordTypes} objects={info.objects} label='Record Types' onClick={handleCreateData} />\n <SchemaTable types={presets.types} objects={info.objects} label='Presets' onClick={handleCreateData} />\n\n <div>\n <SyntaxHighlighter classNames='flex text-xs' language='json'>\n {JSON.stringify({ space, ...info }, jsonKeyReplacer({ truncate: true }), 2)}\n </SyntaxHighlighter>\n </div>\n </div>\n </div>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type PromiseIntentDispatcher, createIntent } from '@dxos/app-framework';\nimport { addressToA1Notation } from '@dxos/compute';\nimport { ComputeGraph, ComputeGraphModel, DEFAULT_OUTPUT, NODE_INPUT, NODE_OUTPUT } from '@dxos/conductor';\nimport { DXN, Filter, Key, Obj, Ref, Type } from '@dxos/echo';\nimport { type TypedObject } from '@dxos/echo-schema';\nimport { Markdown } from '@dxos/plugin-markdown/types';\nimport { createSheet } from '@dxos/plugin-sheet/types';\nimport { type CellValue, SheetType } from '@dxos/plugin-sheet/types';\nimport { CanvasType, DiagramType } from '@dxos/plugin-sketch/types';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { faker } from '@dxos/random';\nimport { type Client } from '@dxos/react-client';\nimport { type Space } from '@dxos/react-client/echo';\nimport { DataType } from '@dxos/schema';\nimport { type ValueGenerator, createAsyncGenerator } from '@dxos/schema/testing';\nimport { range } from '@dxos/util';\n\nconst generator: ValueGenerator = faker as any;\n\nexport type ObjectGenerator<T extends Obj.Any> = (space: Space, n: number, cb?: (objects: T[]) => void) => Promise<T[]>;\n\nconst findViewByTypename = async (views: DataType.View[], typename: string) => {\n return views.find((view) => view.query.typename === typename);\n};\n\nexport const createGenerator = <T extends Obj.Any>(\n client: Client,\n dispatch: PromiseIntentDispatcher,\n schema: TypedObject<T>,\n): ObjectGenerator<T> => {\n return async (space: Space, n: number, cb?: (objects: T[]) => void): Promise<T[]> => {\n const typename = schema.typename;\n\n // Find or create table and view.\n const { objects: views } = await space.db.query(Filter.type(DataType.View)).run();\n const view = await findViewByTypename(views, typename);\n const staticSchema = client?.graph.schemaRegistry.schemas.find((schema) => Type.getTypename(schema) === typename);\n if (!view && !staticSchema) {\n await dispatch(createIntent(SpaceAction.AddSchema, { space, schema }));\n } else if (!view && staticSchema) {\n await dispatch(createIntent(SpaceAction.UseStaticSchema, { space, typename }));\n }\n\n // Create objects.\n const generate = createAsyncGenerator(generator, schema, { db: space.db });\n return generate.createObjects(n);\n };\n};\n\nexport const staticGenerators = new Map<string, ObjectGenerator<any>>([\n [\n Markdown.Document.typename,\n async (space, n, cb) => {\n const objects = range(n).map(() => {\n return space.db.add(\n Markdown.makeDocument({\n name: faker.commerce.productName(),\n content: faker.lorem.sentences(5),\n }),\n );\n });\n\n cb?.(objects);\n return objects;\n },\n ],\n [\n DiagramType.typename,\n async (space, n, cb) => {\n const objects = range(n).map(() => {\n // TODO(burdon): Generate diagram.\n const obj = space.db.add(\n Obj.make(DiagramType, {\n name: faker.commerce.productName(),\n canvas: Ref.make(Obj.make(CanvasType, { content: {} })),\n }),\n );\n\n return obj;\n });\n\n cb?.(objects);\n return objects;\n },\n ],\n // TODO(burdon): Create unit tests.\n [\n SheetType.typename,\n async (space, n, cb) => {\n const objects = range(n).map(() => {\n const cells: Record<string, CellValue> = {};\n const year = new Date().getFullYear();\n const cols = 4;\n const rows = 16;\n for (let col = 1; col <= cols; col++) {\n for (let row = 1; row <= rows; row++) {\n const cell = addressToA1Notation({ col, row });\n if (row === 1) {\n cells[cell] = { value: `${year} Q${col}` };\n } else if (row === rows) {\n const from = addressToA1Notation({ col, row: 2 });\n const to = addressToA1Notation({ col, row: rows - 1 });\n cells[cell] = { value: `=SUM(${from}:${to})` };\n } else if (row > 2 && row < rows - 1) {\n cells[cell] = { value: Math.floor(Math.random() * 10_000) };\n }\n }\n }\n\n // TODO(burdon): Set width.\n // TODO(burdon): Set formatting for columns.\n return space.db.add(\n createSheet({\n name: faker.commerce.productName(),\n cells,\n }),\n );\n });\n\n cb?.(objects);\n return objects;\n },\n ],\n [\n ComputeGraph.typename,\n async (space, n, cb) => {\n const objects = range(n, () => {\n const model = ComputeGraphModel.create();\n model.builder\n .createNode({ id: 'gpt-INPUT', type: NODE_INPUT })\n .createNode({ id: 'gpt-GPT', type: 'gpt' })\n .createNode({\n id: 'gpt-QUEUE_ID',\n type: 'constant',\n value: new DXN(DXN.kind.QUEUE, ['data', space.id, Key.ObjectId.random()]).toString(),\n })\n .createNode({ id: 'gpt-APPEND', type: 'append' })\n .createNode({ id: 'gpt-OUTPUT', type: NODE_OUTPUT })\n .createEdge({ node: 'gpt-INPUT', property: 'prompt' }, { node: 'gpt-GPT', property: 'prompt' })\n .createEdge({ node: 'gpt-GPT', property: 'text' }, { node: 'gpt-OUTPUT', property: 'text' })\n .createEdge({ node: 'gpt-QUEUE_ID', property: DEFAULT_OUTPUT }, { node: 'gpt-APPEND', property: 'id' })\n .createEdge({ node: 'gpt-GPT', property: 'messages' }, { node: 'gpt-APPEND', property: 'items' })\n .createEdge({ node: 'gpt-QUEUE_ID', property: DEFAULT_OUTPUT }, { node: 'gpt-OUTPUT', property: 'queue' });\n\n return space.db.add(model.root);\n });\n cb?.(objects);\n return objects;\n },\n ],\n]);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { type ComputeGraphModel, NODE_INPUT } from '@dxos/conductor';\nimport { DXN, Key, Obj, Ref, Type } from '@dxos/echo';\nimport { FunctionTrigger, TriggerKind, type TriggerType } from '@dxos/functions';\nimport { invariant } from '@dxos/invariant';\nimport { type Space } from '@dxos/react-client/echo';\nimport {\n type ComputeShape,\n createAppend,\n createChat,\n createComputeGraph,\n createConstant,\n createFunction,\n createGpt,\n createQueue,\n createRandom,\n createSurface,\n createTemplate,\n createText,\n createTrigger,\n} from '@dxos/react-ui-canvas-compute';\nimport {\n CanvasBoardType,\n CanvasGraphModel,\n pointMultiply,\n pointsToRect,\n rectToPoints,\n} from '@dxos/react-ui-canvas-editor';\nimport { range } from '@dxos/util';\n\nimport { type ObjectGenerator } from './ObjectGenerator';\n\nexport enum PresetName {\n // EMAIL_TABLE = 'email-table',\n GPT_QUEUE = 'webhook-gpt-queue',\n CHAT_GPT = 'chat-gpt-text',\n // EMAIL_WITH_SUMMARY = 'email-gptSummary-table',\n OBJECT_CHANGE_QUEUE = 'objectChange-queue',\n FOREX_FUNCTION_CALL = 'forex-function-call',\n TIMER_TICK_QUEUE = 'timerTick-queue',\n DISCORD_MESSAGES = 'discord-messages',\n // KANBAN_QUEUE = 'kanban-queue',\n}\n\nexport const generator = () => ({\n schemas: [CanvasBoardType, FunctionTrigger],\n types: Object.values(PresetName).map((name) => ({ typename: name })),\n items: [\n [\n PresetName.GPT_QUEUE,\n async (space, n, cb) => {\n const objects = range(n, () => {\n const canvasModel = CanvasGraphModel.create<ComputeShape>();\n\n let functionTrigger: FunctionTrigger | undefined;\n canvasModel.builder.call((builder) => {\n const gpt = canvasModel.createNode(createGpt(position({ x: 0, y: -14 })));\n const triggerShape = createTrigger({\n spaceId: space.id,\n triggerKind: TriggerKind.Webhook,\n ...position({ x: -18, y: -2 }),\n });\n const trigger = canvasModel.createNode(triggerShape);\n const text = canvasModel.createNode(createText(position({ x: 19, y: 3, width: 10, height: 10 })));\n const { queueId } = setupQueue(space, canvasModel);\n const append = canvasModel.createNode(createAppend(position({ x: 10, y: 6 })));\n\n builder\n .createEdge({ source: trigger.id, target: gpt.id, input: 'prompt', output: 'bodyText' })\n .createEdge({ source: gpt.id, target: text.id, output: 'text' })\n .createEdge({ source: queueId.id, target: append.id, input: 'id' })\n .createEdge({ source: gpt.id, target: append.id, output: 'messages', input: 'items' });\n\n functionTrigger = triggerShape.functionTrigger!.target!;\n });\n\n const computeModel = createComputeGraph(canvasModel);\n\n attachTrigger(functionTrigger, computeModel);\n\n return addToSpace(PresetName.GPT_QUEUE, space, canvasModel, computeModel);\n });\n cb?.(objects);\n return objects;\n },\n ],\n\n [\n PresetName.OBJECT_CHANGE_QUEUE,\n async (space, n, cb) => {\n const objects = range(n, () => {\n const { canvasModel, computeModel } = createQueueSinkPreset(\n space,\n TriggerKind.Subscription,\n (triggerSpec) => (triggerSpec.filter = { type: 'dxn:type:dxos.org/type/Chess' }),\n 'type',\n );\n return addToSpace(PresetName.OBJECT_CHANGE_QUEUE, space, canvasModel, computeModel);\n });\n cb?.(objects);\n return objects;\n },\n ],\n\n [\n PresetName.TIMER_TICK_QUEUE,\n async (space, n, cb) => {\n const objects = range(n, () => {\n const { canvasModel, computeModel } = createQueueSinkPreset(\n space,\n TriggerKind.Timer,\n (triggerSpec) => (triggerSpec.cron = '*/5 * * * * *'),\n 'result',\n );\n return addToSpace(PresetName.TIMER_TICK_QUEUE, space, canvasModel, computeModel);\n });\n cb?.(objects);\n return objects;\n },\n ],\n\n // TODO(wittjosiah): Remove?\n // [\n // PresetName.EMAIL_TABLE,\n // async (space, n, cb) => {\n // const objects = range(n, () => {\n // const canvasModel = CanvasGraphModel.create<ComputeShape>();\n\n // const results = space.db.query(Filter.type(TableType)).runSync();\n // const emailTable = results.find((r) => r.object?.view?.target?.query?.typename?.endsWith('Email'));\n // invariant(emailTable, 'Email table not found.');\n\n // const template = canvasModel.createNode(\n // createTemplate({\n // valueType: 'object',\n // ...rawPosition({ centerX: -80, centerY: -64, width: 320, height: 320 }),\n // }),\n // );\n // const templateContent = ['{'];\n\n // let functionTrigger: FunctionTrigger | undefined;\n // canvasModel.builder.call((builder) => {\n // const triggerShape = createTrigger({\n // spaceId: space.id,\n // triggerKind: TriggerKind.Email,\n // ...position({ x: -18, y: -2 }),\n // });\n // const trigger = canvasModel.createNode(triggerShape);\n\n // const tableId = canvasModel.createNode(\n // createConstant({\n // value: DXN.fromLocalObjectId(emailTable.id).toString(),\n // ...position({ x: -18, y: 5, width: 8, height: 6 }),\n // }),\n // );\n\n // const appendToTable = canvasModel.createNode(createAppend(position({ x: 10, y: 6 })));\n\n // const properties = SchemaAST.getPropertySignatures(EmailTriggerOutput.ast);\n // for (let i = 0; i < properties.length; i++) {\n // const propName = properties[i].name.toString();\n // builder.createEdge({ source: trigger.id, target: template.id, input: propName, output: propName });\n // templateContent.push(` \"${propName}\": \"{{${propName}}}\"` + (i === properties.length - 1 ? '' : ','));\n // }\n // templateContent.push('}');\n\n // builder\n // .createEdge({ source: tableId.id, target: appendToTable.id, input: 'id' })\n // .createEdge({ source: template.id, target: appendToTable.id, input: 'items' });\n\n // functionTrigger = triggerShape.functionTrigger!.target!;\n // });\n\n // const computeModel = createComputeGraph(canvasModel);\n\n // const templateComputeNode = computeModel.nodes.find((n) => n.id === template.node);\n // invariant(templateComputeNode, 'Template compute node was not created.');\n // templateComputeNode.value = templateContent.join('\\n');\n // templateComputeNode.inputSchema = Type.toJsonSchema(EmailTriggerOutput);\n\n // attachTrigger(functionTrigger, computeModel);\n\n // return addToSpace(PresetName.EMAIL_TABLE, space, canvasModel, computeModel);\n // });\n // cb?.(objects);\n // return objects;\n // },\n // ],\n\n [\n PresetName.CHAT_GPT,\n async (space, n, cb) => {\n const objects = range(n, () => {\n const canvasModel = CanvasGraphModel.create<ComputeShape>();\n\n canvasModel.builder.call((builder) => {\n const gpt = canvasModel.createNode(createGpt(position({ x: 0, y: -14 })));\n const chat = canvasModel.createNode(createChat(position({ x: -18, y: -2 })));\n const text = canvasModel.createNode(createText(position({ x: 19, y: 3, width: 10, height: 10 })));\n const { queueId } = setupQueue(space, canvasModel);\n\n const append = canvasModel.createNode(createAppend(position({ x: 10, y: 6 })));\n\n builder\n .createEdge({ source: chat.id, target: gpt.id, input: 'prompt' })\n .createEdge({ source: gpt.id, target: text.id, output: 'text' })\n .createEdge({ source: queueId.id, target: append.id, input: 'id' })\n .createEdge({ source: gpt.id, target: append.id, output: 'messages', input: 'items' });\n });\n\n const computeModel = createComputeGraph(canvasModel);\n\n return addToSpace(PresetName.CHAT_GPT, space, canvasModel, computeModel);\n });\n cb?.(objects);\n return objects;\n },\n ],\n\n // TODO(wittjosiah): Remove?\n // [\n // PresetName.EMAIL_WITH_SUMMARY,\n // async (space, n, cb) => {\n // const objects = range(n, () => {\n // const canvasModel = CanvasGraphModel.create<ComputeShape>();\n\n // const results = space.db.query(Filter.type(TableType)).runSync();\n // const emailTable = results.find((r) => r.object?.view?.target?.query?.typename?.endsWith('Email'));\n // invariant(emailTable, 'Email table not found.');\n\n // const template = canvasModel.createNode(\n // createTemplate({\n // valueType: 'object',\n // ...rawPosition({ centerX: 192, centerY: -176, width: 320, height: 320 }),\n // }),\n // );\n // const templateContent = ['{'];\n\n // let functionTrigger: FunctionTrigger | undefined;\n // canvasModel.builder.call((builder) => {\n // const gpt = canvasModel.createNode(\n // createGpt(rawPosition({ centerX: -400, centerY: -112, width: 256, height: 202 })),\n // );\n // const systemPrompt = canvasModel.createNode(\n // createConstant({\n // value: \"use one word to describe content category. don't write anything else\",\n // ...rawPosition({ centerX: -800, centerY: -160, width: 192, height: 128 }),\n // }),\n // );\n // const triggerShape = createTrigger({\n // spaceId: space.id,\n // triggerKind: TriggerKind.Email,\n // ...rawPosition({ centerX: -736, centerY: -384, width: 182, height: 192 }),\n // });\n // const trigger = canvasModel.createNode(triggerShape);\n\n // const { queueId } = setupQueue(space, canvasModel, {\n // idPosition: { centerX: -720, centerY: 224, width: 192, height: 256 },\n // queuePosition: { centerX: -144, centerY: 416, width: 320, height: 448 },\n // });\n // const appendToQueue = canvasModel.createNode(\n // createAppend(rawPosition({ centerX: -80, centerY: 96, width: 122, height: 128 })),\n // );\n\n // const tableId = canvasModel.createNode(\n // createConstant({\n // value: DXN.fromLocalObjectId(emailTable.id).toString(),\n // ...rawPosition({ centerX: -112, centerY: -544, width: 192, height: 256 }),\n // }),\n // );\n\n // const appendToTable = canvasModel.createNode(\n // createAppend(rawPosition({ centerX: 560, centerY: -416, width: 128, height: 122 })),\n // );\n\n // templateContent.push(' \"category\": \"{{text}}\",');\n // builder.createEdge({ source: gpt.id, target: template.id, input: 'text', output: 'text' });\n\n // const properties = SchemaAST.getPropertySignatures(EmailTriggerOutput.ast);\n // for (let i = 0; i < properties.length; i++) {\n // const propName = properties[i].name.toString();\n // builder.createEdge({ source: trigger.id, target: template.id, input: propName, output: propName });\n // templateContent.push(` \"${propName}\": \"{{${propName}}}\"` + (i === properties.length - 1 ? '' : ','));\n // }\n // templateContent.push('}');\n\n // builder\n // .createEdge({ source: tableId.id, target: appendToTable.id, input: 'id' })\n // .createEdge({ source: queueId.id, target: appendToQueue.id, input: 'id' })\n // .createEdge({ source: gpt.id, target: appendToQueue.id, output: 'messages', input: 'items' })\n // .createEdge({ source: systemPrompt.id, target: gpt.id, input: 'systemPrompt' })\n // .createEdge({ source: trigger.id, target: gpt.id, input: 'prompt', output: 'body' })\n // .createEdge({ source: template.id, target: appendToTable.id, input: 'items' });\n\n // functionTrigger = triggerShape.functionTrigger!.target!;\n // });\n\n // const computeModel = createComputeGraph(canvasModel);\n\n // const templateComputeNode = computeModel.nodes.find((n) => n.id === template.node);\n // invariant(templateComputeNode, 'Template compute node was not created.');\n // templateComputeNode.value = templateContent.join('\\n');\n // const extendedSchema = Schema.extend(EmailTriggerOutput, Schema.Struct({ text: Schema.String }));\n // templateComputeNode.inputSchema = Type.toJsonSchema(extendedSchema);\n\n // attachTrigger(functionTrigger, computeModel);\n\n // return addToSpace(PresetName.EMAIL_WITH_SUMMARY, space, canvasModel, computeModel);\n // });\n // cb?.(objects);\n // return objects;\n // },\n // ],\n\n [\n PresetName.FOREX_FUNCTION_CALL,\n async (space, n, cb) => {\n const objects = range(n, () => {\n const canvasModel = CanvasGraphModel.create<ComputeShape>();\n\n canvasModel.builder.call((builder) => {\n const sourceCurrency = canvasModel.createNode(\n createConstant({ value: 'USD', ...position({ x: -10, y: -5 }) }),\n );\n const targetCurrency = canvasModel.createNode(\n createConstant({ value: 'EUR', ...position({ x: -10, y: 5 }) }),\n );\n const converter = canvasModel.createNode(createFunction(position({ x: 0, y: 0 })));\n const view = canvasModel.createNode(createSurface(position({ x: 12, y: 0 })));\n\n builder\n .createEdge({ source: sourceCurrency.id, target: converter.id, input: 'from' })\n .createEdge({ source: targetCurrency.id, target: converter.id, input: 'to' })\n .createEdge({ source: converter.id, target: view.id, output: 'rate' });\n });\n\n const computeModel = createComputeGraph(canvasModel);\n\n return addToSpace(PresetName.FOREX_FUNCTION_CALL, space, canvasModel, computeModel);\n });\n cb?.(objects);\n return objects;\n },\n ],\n\n [\n PresetName.DISCORD_MESSAGES,\n async (space, n, cb) => {\n const objects = range(n, () => {\n const canvasModel = CanvasGraphModel.create<ComputeShape>();\n\n let functionTrigger: FunctionTrigger | undefined;\n canvasModel.builder.call((builder) => {\n const triggerShape = createTrigger({\n spaceId: space.id,\n triggerKind: TriggerKind.Timer,\n ...position({ x: -10, y: -5 }),\n });\n const trigger = canvasModel.createNode(triggerShape);\n // DXOS dev-null channel.\n const channelId = canvasModel.createNode(\n createConstant({ value: '1088569858767212554', ...position({ x: -10, y: 0 }) }),\n );\n const queueId = canvasModel.createNode(\n createConstant({\n value: new DXN(DXN.kind.QUEUE, ['data', space.id, Key.ObjectId.random()]).toString(),\n ...position({ x: -10, y: 5 }),\n }),\n );\n const converter = canvasModel.createNode(createFunction(position({ x: 0, y: 0 })));\n const view = canvasModel.createNode(createText(position({ x: 12, y: 0 })));\n const queue = canvasModel.createNode(createQueue(position({ x: 0, y: 12 })));\n\n builder\n .createEdge({ source: trigger.id, target: converter.id, input: 'tick' })\n .createEdge({ source: channelId.id, target: converter.id, input: 'channelId' })\n .createEdge({ source: queueId.id, target: converter.id, input: 'queueId' })\n .createEdge({ source: converter.id, target: view.id, output: 'newMessages' })\n .createEdge({ source: queueId.id, target: queue.id, input: 'input' });\n\n functionTrigger = triggerShape.functionTrigger!.target!;\n });\n\n const computeModel = createComputeGraph(canvasModel);\n attachTrigger(functionTrigger, computeModel);\n\n return addToSpace(PresetName.DISCORD_MESSAGES, space, canvasModel, computeModel);\n });\n cb?.(objects);\n return objects;\n },\n ],\n\n // TODO(wittjosiah): Remove?\n // [\n // PresetName.KANBAN_QUEUE,\n // async (space, n, cb) => {\n // const objects = range(n, () => {\n // const canvasModel = CanvasGraphModel.create<ComputeShape>();\n\n // // TODO(wittjosiah): Integrate directly w/ Kanban.\n // // const results = space.db.query(Filter.type(KanbanType)).runSync();\n // // const kanban = results.find((r) => r.object?.cardView?.target?.query?.type?.endsWith('Message'));\n // // invariant(kanban, 'Kanban not found.');\n\n // const results = space.db.query(Filter.type(TableType)).runSync();\n // const messages = results.find((r) => r.object?.view?.target?.query?.typename?.endsWith('Message'));\n // invariant(messages, 'Table not found.');\n\n // let functionTrigger: FunctionTrigger | undefined;\n // canvasModel.builder.call((builder) => {\n // const triggerShape = createTrigger({\n // spaceId: space.id,\n // triggerKind: TriggerKind.Queue,\n // ...position({ x: -10, y: -5 }),\n // });\n // const trigger = canvasModel.createNode(triggerShape);\n\n // const tableId = canvasModel.createNode(\n // createConstant({\n // value: DXN.fromLocalObjectId(messages.id).toString(),\n // ...position({ x: -10, y: 5 }),\n // }),\n // );\n // const appendToTable = canvasModel.createNode(createAppend(position({ x: 10, y: 0 })));\n\n // builder\n // .createEdge({ source: tableId.id, target: appendToTable.id, input: 'id' })\n // .createEdge({ source: trigger.id, target: appendToTable.id, input: 'items', output: 'item' });\n\n // functionTrigger = triggerShape.functionTrigger!.target!;\n // });\n\n // const computeModel = createComputeGraph(canvasModel);\n // attachTrigger(functionTrigger, computeModel);\n\n // return addToSpace(PresetName.KANBAN_QUEUE, space, canvasModel, computeModel);\n // });\n // cb?.(objects);\n // return objects;\n // },\n // ],\n ] as [PresetName, ObjectGenerator<any>][],\n});\n\nconst createQueueSinkPreset = <SpecType extends TriggerKind>(\n space: Space,\n triggerKind: SpecType,\n initSpec: (spec: Extract<TriggerType, { kind: SpecType }>) => void,\n triggerOutputName: string,\n) => {\n const canvasModel = CanvasGraphModel.create<ComputeShape>();\n\n const template = canvasModel.createNode(\n createTemplate({\n valueType: 'object',\n ...rawPosition({ centerX: -64, centerY: -79, width: 320, height: 320 }),\n }),\n );\n\n let functionTrigger: FunctionTrigger | undefined;\n canvasModel.builder.call((builder) => {\n const triggerShape = createTrigger({\n spaceId: space.id,\n triggerKind,\n ...rawPosition({ centerX: -578, centerY: -187, height: 320, width: 320 }),\n });\n const trigger = canvasModel.createNode(triggerShape);\n const { queueId } = setupQueue(space, canvasModel, {\n queuePosition: { centerX: -80, centerY: 378, width: 320, height: 448 },\n });\n const append = canvasModel.createNode(\n createAppend(rawPosition({ centerX: 320, centerY: 192, width: 128, height: 122 })),\n );\n const random = canvasModel.createNode(\n createRandom(rawPosition({ centerX: -509, centerY: -30, width: 64, height: 64 })),\n );\n\n builder\n .createEdge({ source: queueId.id, target: append.id, input: 'id' })\n .createEdge({ source: template.id, target: append.id, input: 'items' })\n .createEdge({ source: trigger.id, target: template.id, output: triggerOutputName, input: 'type' })\n .createEdge({\n source: random.id,\n target: template.id,\n input: 'changeId',\n });\n\n functionTrigger = triggerShape.functionTrigger!.target!;\n const triggerSpec = functionTrigger.spec;\n invariant(triggerSpec && triggerSpec.kind === triggerKind, 'No trigger spec.');\n initSpec(triggerSpec as any);\n });\n\n const computeModel = createComputeGraph(canvasModel);\n\n const templateComputeNode = computeModel.nodes.find((n) => n.id === template.node);\n invariant(templateComputeNode, 'Template compute node was not created.');\n templateComputeNode.value = ['{', ' \"@type\": \"{{type}}\",', ' \"id\": \"@{{changeId}}\"', '}'].join('\\n');\n templateComputeNode.inputSchema = Type.toJsonSchema(Schema.Struct({ type: Schema.String, changeId: Schema.String }));\n attachTrigger(functionTrigger, computeModel);\n\n return { canvasModel, computeModel };\n};\n\nconst addToSpace = (name: string, space: Space, canvas: CanvasGraphModel, compute: ComputeGraphModel) => {\n return space.db.add(\n Obj.make(CanvasBoardType, {\n name,\n computeGraph: Ref.make(compute.root),\n layout: canvas.graph,\n }),\n );\n};\n\nconst setupQueue = (\n space: Space,\n canvasModel: CanvasGraphModel,\n args?: { idPosition?: RawPositionInput; queuePosition?: RawPositionInput },\n) => {\n const queueId = canvasModel.createNode(\n createConstant({\n value: new DXN(DXN.kind.QUEUE, ['data', space.id, Key.ObjectId.random()]).toString(),\n ...(args?.idPosition ? rawPosition(args.idPosition) : position({ x: -18, y: 5, width: 8, height: 6 })),\n }),\n );\n const queue = canvasModel.createNode(\n createQueue(\n args?.queuePosition ? rawPosition(args.queuePosition) : position({ x: -3, y: 3, width: 14, height: 10 }),\n ),\n );\n canvasModel.createEdge({ source: queueId.id, target: queue.id });\n return { queue, queueId };\n};\n\nconst attachTrigger = (functionTrigger: FunctionTrigger | undefined, computeModel: ComputeGraphModel) => {\n invariant(functionTrigger);\n functionTrigger.function = Ref.make(computeModel.root);\n const inputNode = computeModel.nodes.find((node) => node.type === NODE_INPUT)!;\n functionTrigger.inputNodeId = inputNode.id;\n};\n\ntype RawPositionInput = { centerX: number; centerY: number; width: number; height: number };\n\nconst rawPosition = (args: RawPositionInput) => {\n return { center: { x: args.centerX, y: args.centerY }, size: { width: args.width, height: args.height } };\n};\n\nconst position = (rect: { x: number; y: number; width?: number; height?: number }) => {\n const snap = 32;\n const [center, size] = rectToPoints({ width: 0, height: 0, ...rect });\n const { x, y, width, height } = pointsToRect([pointMultiply(center, snap), pointMultiply(size, snap)]);\n if (width && height) {\n return { center: { x, y }, size: width && height ? { width, height } : undefined };\n } else {\n return { center: { x, y } };\n }\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { IconButton } from '@dxos/react-ui';\n\nexport type SchemaTableProps = {\n types: any[];\n objects?: Record<string, number | undefined>;\n label: string;\n onClick: (typename: string) => void;\n};\n\nexport const SchemaTable = ({ types, objects = {}, label, onClick }: SchemaTableProps) => {\n return (\n <div className='grid grid-cols-[1fr_80px_40px] gap-1 overflow-none'>\n <h2 className='p-2'>{label}</h2>\n {types.map((type) => (\n <div key={type.typename} className='grid grid-cols-subgrid col-span-3 items-center'>\n <div className='px-2 text-sm font-mono text-subdued'>{type.typename}</div>\n <div className='px-2 text-right font-mono'>{objects[type.typename] ?? 0}</div>\n <IconButton\n variant='ghost'\n icon='ph--plus--regular'\n iconOnly\n label='Create data'\n onClick={() => onClick(type.typename)}\n />\n </div>\n ))}\n </div>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { SpaceGenerator } from './SpaceGenerator';\n\nexport default SpaceGenerator;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "useCallback", "useMemo", "useState", "useIntentDispatcher", "ComputeGraph", "Filter", "Markdown", "SheetType", "DiagramType", "useClient", "getTypename", "IconButton", "Input", "Toolbar", "useAsyncEffect", "SyntaxHighlighter", "DataType", "jsonKeyReplacer", "sortKeys", "createIntent", "addressToA1Notation", "ComputeGraph", "ComputeGraphModel", "DEFAULT_OUTPUT", "NODE_INPUT", "NODE_OUTPUT", "DXN", "Filter", "Key", "Obj", "Ref", "Type", "Markdown", "createSheet", "SheetType", "CanvasType", "DiagramType", "SpaceAction", "faker", "DataType", "createAsyncGenerator", "range", "generator", "faker", "findViewByTypename", "views", "typename", "find", "view", "query", "createGenerator", "client", "dispatch", "schema", "space", "n", "cb", "objects", "db", "Filter", "type", "DataType", "View", "run", "staticSchema", "graph", "schemaRegistry", "schemas", "Type", "getTypename", "createIntent", "SpaceAction", "AddSchema", "UseStaticSchema", "generate", "createAsyncGenerator", "createObjects", "staticGenerators", "Map", "Markdown", "Document", "range", "map", "add", "makeDocument", "name", "commerce", "productName", "content", "lorem", "sentences", "DiagramType", "obj", "Obj", "make", "canvas", "Ref", "CanvasType", "SheetType", "cells", "year", "Date", "getFullYear", "cols", "rows", "col", "row", "cell", "addressToA1Notation", "value", "from", "to", "Math", "floor", "random", "createSheet", "ComputeGraph", "model", "ComputeGraphModel", "create", "builder", "createNode", "id", "NODE_INPUT", "DXN", "kind", "QUEUE", "Key", "ObjectId", "toString", "NODE_OUTPUT", "createEdge", "node", "property", "DEFAULT_OUTPUT", "root", "Schema", "NODE_INPUT", "DXN", "Key", "Obj", "Ref", "Type", "FunctionTrigger", "TriggerKind", "invariant", "createAppend", "createChat", "createComputeGraph", "createConstant", "createFunction", "createGpt", "createQueue", "createRandom", "createSurface", "createTemplate", "createText", "createTrigger", "CanvasBoardType", "CanvasGraphModel", "pointMultiply", "pointsToRect", "rectToPoints", "range", "PresetName", "generator", "schemas", "types", "Object", "values", "map", "name", "typename", "items", "space", "n", "cb", "objects", "canvasModel", "create", "functionTrigger", "builder", "call", "gpt", "createNode", "position", "x", "y", "triggerShape", "spaceId", "id", "triggerKind", "Webhook", "trigger", "text", "width", "height", "queueId", "setupQueue", "append", "createEdge", "source", "target", "input", "output", "computeModel", "attachTrigger", "addToSpace", "createQueueSinkPreset", "Subscription", "triggerSpec", "filter", "type", "Timer", "cron", "chat", "sourceCurrency", "value", "targetCurrency", "converter", "view", "channelId", "kind", "QUEUE", "ObjectId", "random", "toString", "queue", "initSpec", "triggerOutputName", "template", "valueType", "rawPosition", "centerX", "centerY", "queuePosition", "spec", "templateComputeNode", "nodes", "find", "node", "join", "inputSchema", "toJsonSchema", "Struct", "String", "changeId", "canvas", "compute", "db", "add", "make", "computeGraph", "root", "layout", "graph", "args", "idPosition", "function", "inputNode", "inputNodeId", "center", "size", "rect", "snap", "undefined", "React", "IconButton", "SchemaTable", "types", "objects", "label", "onClick", "div", "className", "h2", "map", "type", "key", "typename", "IconButton", "variant", "icon", "iconOnly", "SpaceGenerator", "space", "onCreateObjects", "dispatchPromise", "dispatch", "useIntentDispatcher", "client", "useClient", "staticTypes", "Markdown", "Document", "DiagramType", "SheetType", "ComputeGraph", "recordTypes", "DataType", "Organization", "Person", "Task", "count", "setCount", "useState", "info", "setInfo", "presets", "useMemo", "generator", "typeMap", "addTypes", "schemas", "recordGenerators", "Map", "map", "type", "typename", "createGenerator", "staticGenerators", "items", "updateInfo", "echoSchema", "db", "schemaRegistry", "query", "run", "staticSchema", "graph", "objects", "Filter", "everything", "objectMap", "sortKeys", "reduce", "obj", "getTypename", "schema", "static", "length", "mutable", "useAsyncEffect", "handleCreateData", "useCallback", "constructor", "get", "React", "div", "role", "className", "Toolbar", "Root", "classNames", "IconButton", "icon", "iconOnly", "label", "onClick", "Separator", "variant", "Input", "TextInput", "min", "max", "placeholder", "size", "value", "onChange", "ev", "parseInt", "target", "SchemaTable", "types", "SyntaxHighlighter", "language", "JSON", "stringify", "jsonKeyReplacer", "truncate", "SpaceGenerator"]
|
|
7
|
+
}
|
|
@@ -8,11 +8,11 @@ import {
|
|
|
8
8
|
// src/capabilities/app-graph-builder.ts
|
|
9
9
|
import { Rx } from "@effect-rx/rx-react";
|
|
10
10
|
import { Option, pipe } from "effect";
|
|
11
|
-
import {
|
|
11
|
+
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
12
12
|
import { Obj } from "@dxos/echo";
|
|
13
13
|
import { ATTENDABLE_PATH_SEPARATOR, DECK_COMPANION_TYPE, PLANK_COMPANION_TYPE } from "@dxos/plugin-deck/types";
|
|
14
|
-
import {
|
|
15
|
-
import {
|
|
14
|
+
import { ROOT_ID, createExtension, rxFromSignal } from "@dxos/plugin-graph";
|
|
15
|
+
import { SPACE_PLUGIN, getActiveSpace } from "@dxos/plugin-space";
|
|
16
16
|
var DEVTOOLS_TYPE = "dxos.org/plugin/debug/devtools";
|
|
17
17
|
var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
|
|
18
18
|
// Devtools node.
|
|
@@ -594,4 +594,4 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
594
594
|
export {
|
|
595
595
|
app_graph_builder_default as default
|
|
596
596
|
};
|
|
597
|
-
//# sourceMappingURL=app-graph-builder-
|
|
597
|
+
//# sourceMappingURL=app-graph-builder-PXPZIIGY.mjs.map
|