@dxos/plugin-debug 0.8.4-main.406dc2a → 0.8.4-main.4a85c3132b
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/DebugGraph-7HXJ2PS2.mjs +16 -0
- package/dist/lib/browser/DebugGraph-7HXJ2PS2.mjs.map +7 -0
- package/dist/lib/browser/DebugObjectPanel-3TCDNUNW.mjs +33 -0
- package/dist/lib/browser/DebugObjectPanel-3TCDNUNW.mjs.map +7 -0
- package/dist/lib/browser/DebugSettings-JZMIUDYB.mjs +174 -0
- package/dist/lib/browser/DebugSettings-JZMIUDYB.mjs.map +7 -0
- package/dist/lib/browser/DebugSpaceObjectsPanel-7NRPLWZ4.mjs +50 -0
- package/dist/lib/browser/DebugSpaceObjectsPanel-7NRPLWZ4.mjs.map +7 -0
- package/dist/lib/browser/DebugStatus-COQGH37G.mjs +125 -0
- package/dist/lib/browser/DebugStatus-COQGH37G.mjs.map +7 -0
- package/dist/lib/browser/DevtoolsOverviewContainer-C75NFVER.mjs +20 -0
- package/dist/lib/browser/DevtoolsOverviewContainer-C75NFVER.mjs.map +7 -0
- package/dist/lib/browser/{SpaceGenerator-VMWHGAJZ.mjs → SpaceGenerator-SWSGJEEL.mjs} +475 -460
- package/dist/lib/browser/SpaceGenerator-SWSGJEEL.mjs.map +7 -0
- package/dist/lib/browser/Wireframe-KAGOKEFW.mjs +53 -0
- package/dist/lib/browser/Wireframe-KAGOKEFW.mjs.map +7 -0
- package/dist/lib/browser/app-graph-builder-LGUQNXHD.mjs +625 -0
- package/dist/lib/browser/app-graph-builder-LGUQNXHD.mjs.map +7 -0
- package/dist/lib/browser/{chunk-SRV2AIGJ.mjs → chunk-4UFQXPP7.mjs} +11 -1
- package/dist/lib/browser/chunk-4UFQXPP7.mjs.map +7 -0
- package/dist/lib/browser/chunk-A5H5GRV6.mjs +20 -0
- package/dist/lib/browser/chunk-A5H5GRV6.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +42 -41
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-context-I3USIAF6.mjs +17 -0
- package/dist/lib/browser/react-context-I3USIAF6.mjs.map +7 -0
- package/dist/lib/browser/react-surface-BTVNKKVQ.mjs +443 -0
- package/dist/lib/browser/react-surface-BTVNKKVQ.mjs.map +7 -0
- package/dist/lib/browser/settings-SLTQJJNF.mjs +32 -0
- package/dist/lib/browser/settings-SLTQJJNF.mjs.map +7 -0
- package/dist/types/src/DebugPlugin.d.ts +7 -1
- package/dist/types/src/DebugPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts +6 -0
- package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +1 -0
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts +3 -0
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +4 -8
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-context/index.d.ts +7 -0
- package/dist/types/src/capabilities/react-context/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-context/react-context.d.ts +10 -0
- package/dist/types/src/capabilities/react-context/react-context.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-surface/index.d.ts +5 -0
- package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts +9 -0
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -0
- package/dist/types/src/capabilities/settings/index.d.ts +3 -0
- package/dist/types/src/capabilities/settings/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/settings/settings.d.ts +6 -0
- package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -0
- package/dist/types/src/components/SchemaTable/SchemaTable.d.ts.map +1 -0
- package/dist/types/src/components/SchemaTable/index.d.ts +2 -0
- package/dist/types/src/components/SchemaTable/index.d.ts.map +1 -0
- package/dist/types/src/components/SpaceGenerator/ObjectGenerator.d.ts +5 -5
- package/dist/types/src/components/SpaceGenerator/ObjectGenerator.d.ts.map +1 -1
- package/dist/types/src/components/SpaceGenerator/index.d.ts +2 -2
- package/dist/types/src/components/SpaceGenerator/index.d.ts.map +1 -1
- package/dist/types/src/components/SpaceGenerator/presets.d.ts +2 -5
- package/dist/types/src/components/SpaceGenerator/presets.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +2 -10
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/containers/DebugGraph/DebugGraph.d.ts +8 -0
- package/dist/types/src/containers/DebugGraph/DebugGraph.d.ts.map +1 -0
- package/dist/types/src/containers/DebugGraph/index.d.ts +3 -0
- package/dist/types/src/containers/DebugGraph/index.d.ts.map +1 -0
- package/dist/types/src/{components → containers/DebugObjectPanel}/DebugObjectPanel.d.ts +2 -2
- package/dist/types/src/containers/DebugObjectPanel/DebugObjectPanel.d.ts.map +1 -0
- package/dist/types/src/containers/DebugObjectPanel/index.d.ts +3 -0
- package/dist/types/src/containers/DebugObjectPanel/index.d.ts.map +1 -0
- package/dist/types/src/containers/DebugSettings/DebugSettings.d.ts +10 -0
- package/dist/types/src/containers/DebugSettings/DebugSettings.d.ts.map +1 -0
- package/dist/types/src/containers/DebugSettings/index.d.ts +3 -0
- package/dist/types/src/containers/DebugSettings/index.d.ts.map +1 -0
- package/dist/types/src/containers/DebugSpaceObjectsPanel/DebugSpaceObjectsPanel.d.ts +3 -0
- package/dist/types/src/containers/DebugSpaceObjectsPanel/DebugSpaceObjectsPanel.d.ts.map +1 -0
- package/dist/types/src/containers/DebugSpaceObjectsPanel/index.d.ts +3 -0
- package/dist/types/src/containers/DebugSpaceObjectsPanel/index.d.ts.map +1 -0
- package/dist/types/src/containers/DebugStatus/DebugStatus.d.ts.map +1 -0
- package/dist/types/src/containers/DebugStatus/index.d.ts +3 -0
- package/dist/types/src/containers/DebugStatus/index.d.ts.map +1 -0
- package/dist/types/src/{components → containers/DevtoolsOverviewContainer}/DevtoolsOverviewContainer.d.ts +0 -1
- package/dist/types/src/containers/DevtoolsOverviewContainer/DevtoolsOverviewContainer.d.ts.map +1 -0
- package/dist/types/src/containers/DevtoolsOverviewContainer/index.d.ts +3 -0
- package/dist/types/src/containers/DevtoolsOverviewContainer/index.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/SpaceGenerator/SpaceGenerator.d.ts +2 -2
- package/dist/types/src/containers/SpaceGenerator/SpaceGenerator.d.ts.map +1 -0
- package/dist/types/src/containers/SpaceGenerator/index.d.ts +3 -0
- package/dist/types/src/containers/SpaceGenerator/index.d.ts.map +1 -0
- package/dist/types/src/{components → containers/Wireframe}/Wireframe.d.ts +2 -2
- package/dist/types/src/containers/Wireframe/Wireframe.d.ts.map +1 -0
- package/dist/types/src/containers/Wireframe/index.d.ts +3 -0
- package/dist/types/src/containers/Wireframe/index.d.ts.map +1 -0
- package/dist/types/src/containers/index.d.ts +10 -0
- package/dist/types/src/containers/index.d.ts.map +1 -0
- package/dist/types/src/meta.d.ts +2 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +3 -1
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +5 -0
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +75 -69
- package/src/DebugPlugin.tsx +27 -31
- package/src/capabilities/app-graph-builder/app-graph-builder.ts +441 -0
- package/src/capabilities/app-graph-builder/index.ts +7 -0
- package/src/capabilities/index.ts +4 -6
- package/src/capabilities/react-context/index.ts +7 -0
- package/src/capabilities/react-context/react-context.tsx +20 -0
- package/src/capabilities/react-surface/index.ts +7 -0
- package/src/capabilities/react-surface/react-surface.tsx +428 -0
- package/src/capabilities/settings/index.ts +7 -0
- package/src/capabilities/settings/settings.ts +31 -0
- package/src/components/SchemaTable/index.ts +5 -0
- package/src/components/SpaceGenerator/ObjectGenerator.tsx +26 -32
- package/src/components/SpaceGenerator/index.ts +2 -3
- package/src/components/SpaceGenerator/presets.ts +250 -127
- package/src/components/index.ts +2 -10
- package/src/containers/DebugGraph/DebugGraph.tsx +13 -0
- package/src/containers/DebugGraph/index.ts +7 -0
- package/src/containers/DebugObjectPanel/DebugObjectPanel.tsx +45 -0
- package/src/containers/DebugObjectPanel/index.ts +7 -0
- package/src/{components → containers/DebugSettings}/DebugSettings.tsx +78 -36
- package/src/containers/DebugSettings/index.ts +7 -0
- package/src/containers/DebugSpaceObjectsPanel/DebugSpaceObjectsPanel.tsx +60 -0
- package/src/containers/DebugSpaceObjectsPanel/index.ts +7 -0
- package/src/containers/DebugStatus/index.ts +7 -0
- package/src/{components → containers/DevtoolsOverviewContainer}/DevtoolsOverviewContainer.tsx +2 -4
- package/src/containers/DevtoolsOverviewContainer/index.ts +7 -0
- package/src/containers/SpaceGenerator/SpaceGenerator.tsx +127 -0
- package/src/containers/SpaceGenerator/index.ts +7 -0
- package/src/{components → containers/Wireframe}/Wireframe.tsx +6 -7
- package/src/containers/Wireframe/index.ts +7 -0
- package/src/containers/index.ts +14 -0
- package/src/meta.ts +7 -4
- package/src/translations.ts +3 -1
- package/src/types.ts +8 -0
- package/dist/lib/browser/DebugGraph-EDOH6R2G.mjs +0 -20
- package/dist/lib/browser/DebugGraph-EDOH6R2G.mjs.map +0 -7
- package/dist/lib/browser/DevtoolsOverviewContainer-EPD6EWT5.mjs +0 -25
- package/dist/lib/browser/DevtoolsOverviewContainer-EPD6EWT5.mjs.map +0 -7
- package/dist/lib/browser/SpaceGenerator-VMWHGAJZ.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-I4IHBKKN.mjs +0 -588
- package/dist/lib/browser/app-graph-builder-I4IHBKKN.mjs.map +0 -7
- package/dist/lib/browser/chunk-SRV2AIGJ.mjs.map +0 -7
- package/dist/lib/browser/chunk-SVCKCXCL.mjs +0 -16
- package/dist/lib/browser/chunk-SVCKCXCL.mjs.map +0 -7
- package/dist/lib/browser/react-context-QLZE7VSQ.mjs +0 -16
- package/dist/lib/browser/react-context-QLZE7VSQ.mjs.map +0 -7
- package/dist/lib/browser/react-surface-GFORPA3A.mjs +0 -772
- package/dist/lib/browser/react-surface-GFORPA3A.mjs.map +0 -7
- package/dist/lib/browser/settings-EBVICEEW.mjs +0 -22
- package/dist/lib/browser/settings-EBVICEEW.mjs.map +0 -7
- package/dist/types/src/capabilities/app-graph-builder.d.ts +0 -4
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +0 -1
- package/dist/types/src/capabilities/react-context.d.ts +0 -8
- package/dist/types/src/capabilities/react-context.d.ts.map +0 -1
- package/dist/types/src/capabilities/react-surface.d.ts +0 -4
- package/dist/types/src/capabilities/react-surface.d.ts.map +0 -1
- package/dist/types/src/capabilities/settings.d.ts +0 -4
- package/dist/types/src/capabilities/settings.d.ts.map +0 -1
- package/dist/types/src/components/Container.d.ts +0 -5
- package/dist/types/src/components/Container.d.ts.map +0 -1
- package/dist/types/src/components/DebugGraph.d.ts +0 -8
- package/dist/types/src/components/DebugGraph.d.ts.map +0 -1
- package/dist/types/src/components/DebugObjectPanel.d.ts.map +0 -1
- package/dist/types/src/components/DebugSettings.d.ts +0 -6
- package/dist/types/src/components/DebugSettings.d.ts.map +0 -1
- package/dist/types/src/components/DebugStatus.d.ts.map +0 -1
- package/dist/types/src/components/DevtoolsOverviewContainer.d.ts.map +0 -1
- package/dist/types/src/components/SpaceGenerator/SchemaTable.d.ts.map +0 -1
- package/dist/types/src/components/SpaceGenerator/SpaceGenerator.d.ts.map +0 -1
- package/dist/types/src/components/SpaceGenerator/SpaceGenerator.stories.d.ts +0 -15
- package/dist/types/src/components/SpaceGenerator/SpaceGenerator.stories.d.ts.map +0 -1
- package/dist/types/src/components/Wireframe.d.ts.map +0 -1
- package/src/capabilities/app-graph-builder.ts +0 -431
- package/src/capabilities/react-context.tsx +0 -16
- package/src/capabilities/react-surface.tsx +0 -399
- package/src/capabilities/settings.ts +0 -19
- package/src/components/Container.tsx +0 -15
- package/src/components/DebugGraph.tsx +0 -14
- package/src/components/DebugObjectPanel.tsx +0 -33
- package/src/components/SpaceGenerator/SpaceGenerator.stories.tsx +0 -52
- package/src/components/SpaceGenerator/SpaceGenerator.tsx +0 -122
- /package/dist/types/src/components/{SpaceGenerator → SchemaTable}/SchemaTable.d.ts +0 -0
- /package/dist/types/src/{components → containers/DebugStatus}/DebugStatus.d.ts +0 -0
- /package/src/components/{SpaceGenerator → SchemaTable}/SchemaTable.tsx +0 -0
- /package/src/{components → containers/DebugStatus}/DebugStatus.tsx +0 -0
|
@@ -1,218 +1,57 @@
|
|
|
1
|
-
// src/
|
|
2
|
-
import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
|
|
1
|
+
// src/containers/SpaceGenerator/SpaceGenerator.tsx
|
|
3
2
|
import React2, { useCallback, useMemo, useState } from "react";
|
|
4
|
-
import {
|
|
3
|
+
import { useOperationInvoker } from "@dxos/app-framework/ui";
|
|
5
4
|
import { ComputeGraph as ComputeGraph2 } from "@dxos/conductor";
|
|
6
|
-
import { Filter as Filter3 } from "@dxos/echo";
|
|
5
|
+
import { Filter as Filter3, Obj as Obj2 } from "@dxos/echo";
|
|
7
6
|
import { Markdown as Markdown3 } from "@dxos/plugin-markdown/types";
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
7
|
+
import { Sheet as Sheet2 } from "@dxos/plugin-sheet/types";
|
|
8
|
+
import { Diagram as Diagram2 } from "@dxos/plugin-sketch/types";
|
|
10
9
|
import { useClient } from "@dxos/react-client";
|
|
11
|
-
import {
|
|
12
|
-
import { IconButton as IconButton2, Input, Toolbar, useAsyncEffect } from "@dxos/react-ui";
|
|
10
|
+
import { IconButton as IconButton2, Input, Panel, ScrollArea, Toolbar, useAsyncEffect } from "@dxos/react-ui";
|
|
13
11
|
import { SyntaxHighlighter } from "@dxos/react-ui-syntax-highlighter";
|
|
14
|
-
import {
|
|
12
|
+
import { Organization as Organization2, Person as Person2, Task } from "@dxos/types";
|
|
15
13
|
import { jsonKeyReplacer, sortKeys } from "@dxos/util";
|
|
16
14
|
|
|
17
|
-
// src/components/
|
|
18
|
-
import
|
|
19
|
-
import {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
const view = await findViewByTypename(views, typename);
|
|
40
|
-
const staticSchema = client?.graph.schemaRegistry.schemas.find((schema2) => Type.getTypename(schema2) === typename);
|
|
41
|
-
if (!view && !staticSchema) {
|
|
42
|
-
await dispatch(createIntent(SpaceAction.AddSchema, {
|
|
43
|
-
space,
|
|
44
|
-
schema,
|
|
45
|
-
show: false
|
|
46
|
-
}));
|
|
47
|
-
} else if (!view && staticSchema) {
|
|
48
|
-
await dispatch(createIntent(SpaceAction.UseStaticSchema, {
|
|
49
|
-
space,
|
|
50
|
-
typename,
|
|
51
|
-
show: false
|
|
52
|
-
}));
|
|
53
|
-
}
|
|
54
|
-
const generate = createAsyncGenerator(generator, schema, {
|
|
55
|
-
db: space.db
|
|
56
|
-
});
|
|
57
|
-
return generate.createObjects(n);
|
|
58
|
-
};
|
|
15
|
+
// src/components/SchemaTable/SchemaTable.tsx
|
|
16
|
+
import React from "react";
|
|
17
|
+
import { IconButton } from "@dxos/react-ui";
|
|
18
|
+
var SchemaTable = ({ types, objects = {}, label, onClick }) => {
|
|
19
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
20
|
+
className: "grid grid-cols-[1fr_80px_40px] gap-1 overflow-none"
|
|
21
|
+
}, /* @__PURE__ */ React.createElement("h2", {
|
|
22
|
+
className: "p-2"
|
|
23
|
+
}, label), types.map((type) => /* @__PURE__ */ React.createElement("div", {
|
|
24
|
+
key: type.typename,
|
|
25
|
+
className: "grid grid-cols-subgrid col-span-3 items-center"
|
|
26
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
27
|
+
className: "px-2 text-sm font-mono text-subdued"
|
|
28
|
+
}, type.typename), /* @__PURE__ */ React.createElement("div", {
|
|
29
|
+
className: "px-2 text-right font-mono"
|
|
30
|
+
}, objects[type.typename] ?? 0), /* @__PURE__ */ React.createElement(IconButton, {
|
|
31
|
+
variant: "ghost",
|
|
32
|
+
icon: "ph--plus--regular",
|
|
33
|
+
iconOnly: true,
|
|
34
|
+
label: "Create data",
|
|
35
|
+
onClick: () => onClick(type.typename)
|
|
36
|
+
}))));
|
|
59
37
|
};
|
|
60
|
-
var staticGenerators = /* @__PURE__ */ new Map([
|
|
61
|
-
[
|
|
62
|
-
Markdown.Document.typename,
|
|
63
|
-
async (space, n, cb) => {
|
|
64
|
-
const objects = range(n).map(() => {
|
|
65
|
-
return space.db.add(Markdown.makeDocument({
|
|
66
|
-
name: faker.commerce.productName(),
|
|
67
|
-
content: faker.lorem.sentences(5)
|
|
68
|
-
}));
|
|
69
|
-
});
|
|
70
|
-
cb?.(objects);
|
|
71
|
-
return objects;
|
|
72
|
-
}
|
|
73
|
-
],
|
|
74
|
-
[
|
|
75
|
-
DiagramType.typename,
|
|
76
|
-
async (space, n, cb) => {
|
|
77
|
-
const objects = range(n).map(() => {
|
|
78
|
-
const obj = space.db.add(Obj.make(DiagramType, {
|
|
79
|
-
name: faker.commerce.productName(),
|
|
80
|
-
canvas: Ref.make(Obj.make(CanvasType, {
|
|
81
|
-
content: {}
|
|
82
|
-
}))
|
|
83
|
-
}));
|
|
84
|
-
return obj;
|
|
85
|
-
});
|
|
86
|
-
cb?.(objects);
|
|
87
|
-
return objects;
|
|
88
|
-
}
|
|
89
|
-
],
|
|
90
|
-
// TODO(burdon): Create unit tests.
|
|
91
|
-
[
|
|
92
|
-
SheetType.typename,
|
|
93
|
-
async (space, n, cb) => {
|
|
94
|
-
const objects = range(n).map(() => {
|
|
95
|
-
const cells = {};
|
|
96
|
-
const year = (/* @__PURE__ */ new Date()).getFullYear();
|
|
97
|
-
const cols = 4;
|
|
98
|
-
const rows = 16;
|
|
99
|
-
for (let col = 1; col <= cols; col++) {
|
|
100
|
-
for (let row = 1; row <= rows; row++) {
|
|
101
|
-
const cell = addressToA1Notation({
|
|
102
|
-
col,
|
|
103
|
-
row
|
|
104
|
-
});
|
|
105
|
-
if (row === 1) {
|
|
106
|
-
cells[cell] = {
|
|
107
|
-
value: `${year} Q${col}`
|
|
108
|
-
};
|
|
109
|
-
} else if (row === rows) {
|
|
110
|
-
const from = addressToA1Notation({
|
|
111
|
-
col,
|
|
112
|
-
row: 2
|
|
113
|
-
});
|
|
114
|
-
const to = addressToA1Notation({
|
|
115
|
-
col,
|
|
116
|
-
row: rows - 1
|
|
117
|
-
});
|
|
118
|
-
cells[cell] = {
|
|
119
|
-
value: `=SUM(${from}:${to})`
|
|
120
|
-
};
|
|
121
|
-
} else if (row > 2 && row < rows - 1) {
|
|
122
|
-
cells[cell] = {
|
|
123
|
-
value: Math.floor(Math.random() * 1e4)
|
|
124
|
-
};
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
return space.db.add(createSheet({
|
|
129
|
-
name: faker.commerce.productName(),
|
|
130
|
-
cells
|
|
131
|
-
}));
|
|
132
|
-
});
|
|
133
|
-
cb?.(objects);
|
|
134
|
-
return objects;
|
|
135
|
-
}
|
|
136
|
-
],
|
|
137
|
-
[
|
|
138
|
-
ComputeGraph.typename,
|
|
139
|
-
async (space, n, cb) => {
|
|
140
|
-
const objects = range(n, () => {
|
|
141
|
-
const model = ComputeGraphModel.create();
|
|
142
|
-
model.builder.createNode({
|
|
143
|
-
id: "gpt-INPUT",
|
|
144
|
-
type: NODE_INPUT
|
|
145
|
-
}).createNode({
|
|
146
|
-
id: "gpt-GPT",
|
|
147
|
-
type: "gpt"
|
|
148
|
-
}).createNode({
|
|
149
|
-
id: "gpt-QUEUE_ID",
|
|
150
|
-
type: "constant",
|
|
151
|
-
value: new DXN(DXN.kind.QUEUE, [
|
|
152
|
-
"data",
|
|
153
|
-
space.id,
|
|
154
|
-
Key.ObjectId.random()
|
|
155
|
-
]).toString()
|
|
156
|
-
}).createNode({
|
|
157
|
-
id: "gpt-APPEND",
|
|
158
|
-
type: "append"
|
|
159
|
-
}).createNode({
|
|
160
|
-
id: "gpt-OUTPUT",
|
|
161
|
-
type: NODE_OUTPUT
|
|
162
|
-
}).createEdge({
|
|
163
|
-
node: "gpt-INPUT",
|
|
164
|
-
property: "prompt"
|
|
165
|
-
}, {
|
|
166
|
-
node: "gpt-GPT",
|
|
167
|
-
property: "prompt"
|
|
168
|
-
}).createEdge({
|
|
169
|
-
node: "gpt-GPT",
|
|
170
|
-
property: "text"
|
|
171
|
-
}, {
|
|
172
|
-
node: "gpt-OUTPUT",
|
|
173
|
-
property: "text"
|
|
174
|
-
}).createEdge({
|
|
175
|
-
node: "gpt-QUEUE_ID",
|
|
176
|
-
property: DEFAULT_OUTPUT
|
|
177
|
-
}, {
|
|
178
|
-
node: "gpt-APPEND",
|
|
179
|
-
property: "id"
|
|
180
|
-
}).createEdge({
|
|
181
|
-
node: "gpt-GPT",
|
|
182
|
-
property: "messages"
|
|
183
|
-
}, {
|
|
184
|
-
node: "gpt-APPEND",
|
|
185
|
-
property: "items"
|
|
186
|
-
}).createEdge({
|
|
187
|
-
node: "gpt-QUEUE_ID",
|
|
188
|
-
property: DEFAULT_OUTPUT
|
|
189
|
-
}, {
|
|
190
|
-
node: "gpt-OUTPUT",
|
|
191
|
-
property: "queue"
|
|
192
|
-
});
|
|
193
|
-
return space.db.add(model.root);
|
|
194
|
-
});
|
|
195
|
-
cb?.(objects);
|
|
196
|
-
return objects;
|
|
197
|
-
}
|
|
198
|
-
]
|
|
199
|
-
]);
|
|
200
38
|
|
|
201
39
|
// src/components/SpaceGenerator/presets.ts
|
|
202
40
|
import * as Schema from "effect/Schema";
|
|
203
|
-
import {
|
|
41
|
+
import { AgentFunctions, EntityExtractionFunctions, ResearchBlueprint } from "@dxos/assistant-toolkit";
|
|
204
42
|
import { Prompt } from "@dxos/blueprints";
|
|
205
|
-
import { NODE_INPUT
|
|
206
|
-
import { DXN
|
|
207
|
-
import {
|
|
43
|
+
import { NODE_INPUT } from "@dxos/conductor";
|
|
44
|
+
import { DXN, Feed, Filter, JsonSchema, Key, Obj, Query, Ref, Tag } from "@dxos/echo";
|
|
45
|
+
import { Trigger, serializeFunction } from "@dxos/functions";
|
|
208
46
|
import { invariant } from "@dxos/invariant";
|
|
209
|
-
import {
|
|
47
|
+
import { GmailFunctions } from "@dxos/plugin-inbox";
|
|
210
48
|
import { Mailbox } from "@dxos/plugin-inbox/types";
|
|
211
|
-
import { Markdown
|
|
49
|
+
import { Markdown } from "@dxos/plugin-markdown/types";
|
|
212
50
|
import { createAppend, createChat, createComputeGraph, createConstant, createFunction, createGpt, createQueue, createRandom, createSurface, createTemplate, createText, createTrigger } from "@dxos/react-ui-canvas-compute";
|
|
213
|
-
import {
|
|
214
|
-
import {
|
|
215
|
-
import {
|
|
51
|
+
import { CanvasBoard, CanvasGraphModel, pointMultiply, pointsToRect, rectToPoints } from "@dxos/react-ui-canvas-editor";
|
|
52
|
+
import { ViewModel } from "@dxos/schema";
|
|
53
|
+
import { Message, Organization, Person, Pipeline } from "@dxos/types";
|
|
54
|
+
import { range, trim } from "@dxos/util";
|
|
216
55
|
var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-debug/src/components/SpaceGenerator/presets.ts";
|
|
217
56
|
var PresetName = /* @__PURE__ */ (function(PresetName2) {
|
|
218
57
|
PresetName2["DXOS_TEAM"] = "dxos-team";
|
|
@@ -220,15 +59,15 @@ var PresetName = /* @__PURE__ */ (function(PresetName2) {
|
|
|
220
59
|
PresetName2["GPT_QUEUE"] = "webhook-gpt-queue";
|
|
221
60
|
PresetName2["CHAT_GPT"] = "chat-gpt-text";
|
|
222
61
|
PresetName2["OBJECT_CHANGE_QUEUE"] = "objectChange-queue";
|
|
223
|
-
PresetName2["FOREX_FUNCTION_CALL"] = "forex-function-call";
|
|
224
62
|
PresetName2["TIMER_TICK_QUEUE"] = "timerTick-queue";
|
|
63
|
+
PresetName2["FOREX_FUNCTION_CALL"] = "forex-function-call";
|
|
225
64
|
PresetName2["DISCORD_MESSAGES"] = "discord-messages";
|
|
226
65
|
return PresetName2;
|
|
227
66
|
})({});
|
|
228
|
-
var
|
|
67
|
+
var generator = () => ({
|
|
229
68
|
schemas: [
|
|
230
|
-
|
|
231
|
-
|
|
69
|
+
CanvasBoard.CanvasBoard,
|
|
70
|
+
Trigger.Trigger
|
|
232
71
|
],
|
|
233
72
|
types: Object.values(PresetName).map((name) => ({
|
|
234
73
|
typename: name
|
|
@@ -237,45 +76,44 @@ var generator2 = () => ({
|
|
|
237
76
|
[
|
|
238
77
|
"dxos-team",
|
|
239
78
|
async (space, n, cb) => {
|
|
240
|
-
const objects =
|
|
241
|
-
const
|
|
242
|
-
label: "Investor"
|
|
243
|
-
}));
|
|
244
|
-
const tagDxn = Obj2.getDXN(tag).toString();
|
|
245
|
-
const org = space.db.add(Obj2.make(DataType2.Organization, {
|
|
79
|
+
const objects = range(n, () => {
|
|
80
|
+
const org = space.db.add(Obj.make(Organization.Organization, {
|
|
246
81
|
name: "DXOS",
|
|
247
82
|
website: "https://dxos.org"
|
|
248
83
|
}));
|
|
249
|
-
const doc = space.db.add(
|
|
84
|
+
const doc = space.db.add(Markdown.make({
|
|
250
85
|
name: "DXOS Research",
|
|
251
86
|
content: "DXOS builds Composer, an open-source AI-powered malleable application."
|
|
252
87
|
}));
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
}, {
|
|
260
|
-
tags: [
|
|
88
|
+
const tag = space.db.add(Tag.make({
|
|
89
|
+
label: "Investor"
|
|
90
|
+
}));
|
|
91
|
+
const tagDxn = Obj.getDXN(tag).toString();
|
|
92
|
+
Obj.change(doc, (d) => {
|
|
93
|
+
Obj.getMeta(d).tags = [
|
|
261
94
|
tagDxn
|
|
262
|
-
]
|
|
95
|
+
];
|
|
96
|
+
});
|
|
97
|
+
space.db.add(Obj.make(Person.Person, {
|
|
98
|
+
[Obj.Meta]: {
|
|
99
|
+
tags: [
|
|
100
|
+
tagDxn
|
|
101
|
+
]
|
|
102
|
+
},
|
|
103
|
+
fullName: "Rich",
|
|
104
|
+
organization: Ref.make(org)
|
|
263
105
|
}));
|
|
264
|
-
space.db.add(
|
|
106
|
+
space.db.add(Obj.make(Person.Person, {
|
|
265
107
|
fullName: "Josiah",
|
|
266
|
-
organization:
|
|
108
|
+
organization: Ref.make(org)
|
|
267
109
|
}));
|
|
268
|
-
space.db.add(
|
|
110
|
+
space.db.add(Obj.make(Person.Person, {
|
|
269
111
|
fullName: "Dima",
|
|
270
|
-
organization:
|
|
112
|
+
organization: Ref.make(org)
|
|
271
113
|
}));
|
|
272
|
-
space.db.add(
|
|
114
|
+
space.db.add(Obj.make(Person.Person, {
|
|
273
115
|
fullName: "Mykola",
|
|
274
|
-
organization:
|
|
275
|
-
}));
|
|
276
|
-
space.db.add(Obj2.make(DataType2.Person, {
|
|
277
|
-
fullName: "Will",
|
|
278
|
-
organization: Ref2.make(org)
|
|
116
|
+
organization: Ref.make(org)
|
|
279
117
|
}));
|
|
280
118
|
return doc;
|
|
281
119
|
});
|
|
@@ -286,40 +124,58 @@ var generator2 = () => ({
|
|
|
286
124
|
[
|
|
287
125
|
"org-research-project",
|
|
288
126
|
async (space, n, cb) => {
|
|
289
|
-
const
|
|
290
|
-
const
|
|
127
|
+
const feeds = await space.db.query(Filter.type(Feed.Feed)).run();
|
|
128
|
+
const mailbox = feeds.find((feed) => feed.kind === Mailbox.kind);
|
|
129
|
+
invariant(mailbox, "Mailbox feed not found", {
|
|
130
|
+
F: __dxlog_file,
|
|
131
|
+
L: 121,
|
|
132
|
+
S: void 0,
|
|
133
|
+
A: [
|
|
134
|
+
"mailbox",
|
|
135
|
+
"'Mailbox feed not found'"
|
|
136
|
+
]
|
|
137
|
+
});
|
|
138
|
+
const queueDxn = Feed.getQueueDxn(mailbox)?.toString();
|
|
139
|
+
invariant(queueDxn, "Mailbox feed missing queue DXN key", {
|
|
140
|
+
F: __dxlog_file,
|
|
141
|
+
L: 123,
|
|
142
|
+
S: void 0,
|
|
143
|
+
A: [
|
|
144
|
+
"queueDxn",
|
|
145
|
+
"'Mailbox feed missing queue DXN key'"
|
|
146
|
+
]
|
|
147
|
+
});
|
|
148
|
+
const tag = await space.db.query(Filter.type(Tag.Tag, {
|
|
291
149
|
label: "Investor"
|
|
292
150
|
})).first();
|
|
293
|
-
const tagDxn =
|
|
294
|
-
const objects =
|
|
295
|
-
const contactsQuery = Query.select(
|
|
296
|
-
const organizationsQuery = Query.select(
|
|
297
|
-
const notesQuery = Query.select(
|
|
298
|
-
|
|
151
|
+
const tagDxn = Obj.getDXN(tag).toString();
|
|
152
|
+
const objects = range(n, () => {
|
|
153
|
+
const contactsQuery = Query.select(Filter.type(Person.Person)).select(Filter.tag(tagDxn));
|
|
154
|
+
const organizationsQuery = Query.select(Filter.type(Organization.Organization)).select(Filter.tag(tagDxn));
|
|
155
|
+
const notesQuery = Query.select(Filter.type(Markdown.Document)).select(Filter.tag(tagDxn));
|
|
156
|
+
space.db.add(Trigger.make({
|
|
299
157
|
enabled: true,
|
|
300
158
|
spec: {
|
|
301
159
|
kind: "timer",
|
|
302
160
|
cron: "* * * * *"
|
|
303
161
|
},
|
|
304
|
-
function:
|
|
162
|
+
function: Ref.make(serializeFunction(GmailFunctions.Sync)),
|
|
305
163
|
input: {
|
|
306
|
-
|
|
164
|
+
mailbox: Ref.make(mailbox)
|
|
307
165
|
}
|
|
308
|
-
});
|
|
309
|
-
space.db.add(
|
|
310
|
-
const contactExtractionTrigger = Obj2.make(FunctionTrigger, {
|
|
166
|
+
}));
|
|
167
|
+
space.db.add(Trigger.make({
|
|
311
168
|
enabled: true,
|
|
312
169
|
// TODO(wittjosiah): Queue trigger doesn't support matching query of the column.
|
|
313
170
|
spec: {
|
|
314
171
|
kind: "queue",
|
|
315
|
-
queue:
|
|
172
|
+
queue: queueDxn
|
|
316
173
|
},
|
|
317
|
-
function:
|
|
174
|
+
function: Ref.make(serializeFunction(EntityExtractionFunctions.Extract)),
|
|
318
175
|
input: {
|
|
319
176
|
source: "{{event.item}}"
|
|
320
177
|
}
|
|
321
|
-
});
|
|
322
|
-
space.db.add(contactExtractionTrigger);
|
|
178
|
+
}));
|
|
323
179
|
const researchPrompt = space.db.add(Prompt.make({
|
|
324
180
|
name: "Research",
|
|
325
181
|
description: "Research organization",
|
|
@@ -329,12 +185,16 @@ var generator2 = () => ({
|
|
|
329
185
|
output: Schema.Any,
|
|
330
186
|
// TODO(dmaretskyi): This mocks research (returns pre-baked result), the actual research might take compute minutes.
|
|
331
187
|
// Remove the mock prompt to do the actual research.
|
|
332
|
-
instructions:
|
|
188
|
+
instructions: trim`
|
|
189
|
+
Research the organization provided as input.
|
|
190
|
+
Create a research note for it at the end.
|
|
191
|
+
NOTE: Do mocked reseach (set mockSearch to true).
|
|
192
|
+
`,
|
|
333
193
|
blueprints: [
|
|
334
|
-
|
|
194
|
+
Ref.make(ResearchBlueprint.make())
|
|
335
195
|
]
|
|
336
196
|
}));
|
|
337
|
-
|
|
197
|
+
space.db.add(Trigger.make({
|
|
338
198
|
enabled: true,
|
|
339
199
|
spec: {
|
|
340
200
|
kind: "subscription",
|
|
@@ -342,61 +202,60 @@ var generator2 = () => ({
|
|
|
342
202
|
ast: organizationsQuery.ast
|
|
343
203
|
}
|
|
344
204
|
},
|
|
345
|
-
function:
|
|
205
|
+
function: Ref.make(serializeFunction(AgentFunctions.Prompt)),
|
|
346
206
|
input: {
|
|
347
|
-
prompt:
|
|
207
|
+
prompt: Ref.make(researchPrompt),
|
|
348
208
|
input: "{{event.subject}}"
|
|
349
209
|
}
|
|
350
|
-
});
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
name: "Mailbox",
|
|
354
|
-
query: Query.select(Filter2.type(DataType2.Message, {
|
|
210
|
+
}));
|
|
211
|
+
const mailboxView = ViewModel.make({
|
|
212
|
+
query: Query.select(Filter.type(Message.Message, {
|
|
355
213
|
properties: {
|
|
356
|
-
labels:
|
|
214
|
+
labels: Filter.contains("investor")
|
|
357
215
|
}
|
|
358
|
-
})).
|
|
216
|
+
})).from({
|
|
359
217
|
queues: [
|
|
360
|
-
|
|
218
|
+
queueDxn
|
|
361
219
|
]
|
|
362
220
|
}),
|
|
363
|
-
jsonSchema:
|
|
364
|
-
presentation: Obj2.make(DataType2.Collection, {
|
|
365
|
-
objects: []
|
|
366
|
-
})
|
|
221
|
+
jsonSchema: JsonSchema.toJsonSchema(Message.Message)
|
|
367
222
|
});
|
|
368
|
-
const contactsView =
|
|
369
|
-
name: "Contacts",
|
|
223
|
+
const contactsView = ViewModel.make({
|
|
370
224
|
query: contactsQuery,
|
|
371
|
-
jsonSchema:
|
|
372
|
-
presentation: Obj2.make(DataType2.Collection, {
|
|
373
|
-
objects: []
|
|
374
|
-
})
|
|
225
|
+
jsonSchema: JsonSchema.toJsonSchema(Person.Person)
|
|
375
226
|
});
|
|
376
|
-
const organizationsView =
|
|
377
|
-
name: "Organizations",
|
|
227
|
+
const organizationsView = ViewModel.make({
|
|
378
228
|
query: organizationsQuery,
|
|
379
|
-
jsonSchema:
|
|
380
|
-
presentation: Obj2.make(DataType2.Collection, {
|
|
381
|
-
objects: []
|
|
382
|
-
})
|
|
229
|
+
jsonSchema: JsonSchema.toJsonSchema(Organization.Organization)
|
|
383
230
|
});
|
|
384
|
-
const notesView =
|
|
385
|
-
name: "Notes",
|
|
231
|
+
const notesView = ViewModel.make({
|
|
386
232
|
query: notesQuery,
|
|
387
|
-
jsonSchema:
|
|
388
|
-
presentation: Obj2.make(DataType2.Collection, {
|
|
389
|
-
objects: []
|
|
390
|
-
})
|
|
233
|
+
jsonSchema: JsonSchema.toJsonSchema(Markdown.Document)
|
|
391
234
|
});
|
|
392
|
-
return space.db.add(
|
|
235
|
+
return space.db.add(Pipeline.make({
|
|
393
236
|
name: "Investor Research",
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
237
|
+
columns: [
|
|
238
|
+
{
|
|
239
|
+
name: "Mailbox",
|
|
240
|
+
view: Ref.make(mailboxView),
|
|
241
|
+
order: []
|
|
242
|
+
},
|
|
243
|
+
{
|
|
244
|
+
name: "Contacts",
|
|
245
|
+
view: Ref.make(contactsView),
|
|
246
|
+
order: []
|
|
247
|
+
},
|
|
248
|
+
{
|
|
249
|
+
name: "Organizations",
|
|
250
|
+
view: Ref.make(organizationsView),
|
|
251
|
+
order: []
|
|
252
|
+
},
|
|
253
|
+
{
|
|
254
|
+
name: "Notes",
|
|
255
|
+
view: Ref.make(notesView),
|
|
256
|
+
order: []
|
|
257
|
+
}
|
|
258
|
+
]
|
|
400
259
|
}));
|
|
401
260
|
});
|
|
402
261
|
cb?.(objects.flat());
|
|
@@ -406,7 +265,7 @@ var generator2 = () => ({
|
|
|
406
265
|
[
|
|
407
266
|
"webhook-gpt-queue",
|
|
408
267
|
async (space, n, cb) => {
|
|
409
|
-
const objects =
|
|
268
|
+
const objects = range(n, () => {
|
|
410
269
|
const canvasModel = CanvasGraphModel.create();
|
|
411
270
|
let functionTrigger;
|
|
412
271
|
canvasModel.builder.call((builder) => {
|
|
@@ -466,9 +325,9 @@ var generator2 = () => ({
|
|
|
466
325
|
[
|
|
467
326
|
"objectChange-queue",
|
|
468
327
|
async (space, n, cb) => {
|
|
469
|
-
const objects =
|
|
328
|
+
const objects = range(n, () => {
|
|
470
329
|
const { canvasModel, computeModel } = createQueueSinkPreset(space, "subscription", (triggerSpec) => triggerSpec.query = {
|
|
471
|
-
ast: Query.select(
|
|
330
|
+
ast: Query.select(Filter.typename("dxos.org/type/Chess")).ast
|
|
472
331
|
}, "type");
|
|
473
332
|
return addToSpace("objectChange-queue", space, canvasModel, computeModel);
|
|
474
333
|
});
|
|
@@ -479,7 +338,7 @@ var generator2 = () => ({
|
|
|
479
338
|
[
|
|
480
339
|
"timerTick-queue",
|
|
481
340
|
async (space, n, cb) => {
|
|
482
|
-
const objects =
|
|
341
|
+
const objects = range(n, () => {
|
|
483
342
|
const { canvasModel, computeModel } = createQueueSinkPreset(space, "timer", (triggerSpec) => triggerSpec.cron = "*/5 * * * * *", "result");
|
|
484
343
|
return addToSpace("timerTick-queue", space, canvasModel, computeModel);
|
|
485
344
|
});
|
|
@@ -534,7 +393,7 @@ var generator2 = () => ({
|
|
|
534
393
|
// const templateComputeNode = computeModel.nodes.find((n) => n.id === template.node);
|
|
535
394
|
// invariant(templateComputeNode, 'Template compute node was not created.');
|
|
536
395
|
// templateComputeNode.value = templateContent.join('\n');
|
|
537
|
-
// templateComputeNode.inputSchema =
|
|
396
|
+
// templateComputeNode.inputSchema = JsonSchema.toJsonSchema(EmailTriggerOutput);
|
|
538
397
|
// attachTrigger(functionTrigger, computeModel);
|
|
539
398
|
// return addToSpace(PresetName.EMAIL_TABLE, space, canvasModel, computeModel);
|
|
540
399
|
// });
|
|
@@ -545,7 +404,7 @@ var generator2 = () => ({
|
|
|
545
404
|
[
|
|
546
405
|
"chat-gpt-text",
|
|
547
406
|
async (space, n, cb) => {
|
|
548
|
-
const objects =
|
|
407
|
+
const objects = range(n, () => {
|
|
549
408
|
const canvasModel = CanvasGraphModel.create();
|
|
550
409
|
canvasModel.builder.call((builder) => {
|
|
551
410
|
const gpt = canvasModel.createNode(createGpt(position({
|
|
@@ -665,7 +524,7 @@ var generator2 = () => ({
|
|
|
665
524
|
// invariant(templateComputeNode, 'Template compute node was not created.');
|
|
666
525
|
// templateComputeNode.value = templateContent.join('\n');
|
|
667
526
|
// const extendedSchema = Schema.extend(EmailTriggerOutput, Schema.Struct({ text: Schema.String }));
|
|
668
|
-
// templateComputeNode.inputSchema =
|
|
527
|
+
// templateComputeNode.inputSchema = JsonSchema.toJsonSchema(extendedSchema);
|
|
669
528
|
// attachTrigger(functionTrigger, computeModel);
|
|
670
529
|
// return addToSpace(PresetName.EMAIL_WITH_SUMMARY, space, canvasModel, computeModel);
|
|
671
530
|
// });
|
|
@@ -676,7 +535,7 @@ var generator2 = () => ({
|
|
|
676
535
|
[
|
|
677
536
|
"forex-function-call",
|
|
678
537
|
async (space, n, cb) => {
|
|
679
|
-
const objects =
|
|
538
|
+
const objects = range(n, () => {
|
|
680
539
|
const canvasModel = CanvasGraphModel.create();
|
|
681
540
|
canvasModel.builder.call((builder) => {
|
|
682
541
|
const sourceCurrency = canvasModel.createNode(createConstant({
|
|
@@ -725,7 +584,7 @@ var generator2 = () => ({
|
|
|
725
584
|
[
|
|
726
585
|
"discord-messages",
|
|
727
586
|
async (space, n, cb) => {
|
|
728
|
-
const objects =
|
|
587
|
+
const objects = range(n, () => {
|
|
729
588
|
const canvasModel = CanvasGraphModel.create();
|
|
730
589
|
let functionTrigger;
|
|
731
590
|
canvasModel.builder.call((builder) => {
|
|
@@ -746,10 +605,10 @@ var generator2 = () => ({
|
|
|
746
605
|
})
|
|
747
606
|
}));
|
|
748
607
|
const queueId = canvasModel.createNode(createConstant({
|
|
749
|
-
value: new
|
|
608
|
+
value: new DXN(DXN.kind.QUEUE, [
|
|
750
609
|
"data",
|
|
751
610
|
space.id,
|
|
752
|
-
|
|
611
|
+
Key.ObjectId.random()
|
|
753
612
|
]).toString(),
|
|
754
613
|
...position({
|
|
755
614
|
x: -10,
|
|
@@ -867,20 +726,22 @@ var createQueueSinkPreset = (space, triggerKind, initSpec, triggerOutputName) =>
|
|
|
867
726
|
const triggerSpec = functionTrigger.spec;
|
|
868
727
|
invariant(triggerSpec && triggerSpec.kind === triggerKind, "No trigger spec.", {
|
|
869
728
|
F: __dxlog_file,
|
|
870
|
-
L:
|
|
729
|
+
L: 762,
|
|
871
730
|
S: void 0,
|
|
872
731
|
A: [
|
|
873
732
|
"triggerSpec && triggerSpec.kind === triggerKind",
|
|
874
733
|
"'No trigger spec.'"
|
|
875
734
|
]
|
|
876
735
|
});
|
|
877
|
-
|
|
736
|
+
Obj.change(functionTrigger, (ft) => {
|
|
737
|
+
initSpec(ft.spec);
|
|
738
|
+
});
|
|
878
739
|
});
|
|
879
740
|
const computeModel = createComputeGraph(canvasModel);
|
|
880
741
|
const templateComputeNode = computeModel.nodes.find((n) => n.id === template.node);
|
|
881
742
|
invariant(templateComputeNode, "Template compute node was not created.", {
|
|
882
743
|
F: __dxlog_file,
|
|
883
|
-
L:
|
|
744
|
+
L: 771,
|
|
884
745
|
S: void 0,
|
|
885
746
|
A: [
|
|
886
747
|
"templateComputeNode",
|
|
@@ -893,7 +754,7 @@ var createQueueSinkPreset = (space, triggerKind, initSpec, triggerOutputName) =>
|
|
|
893
754
|
' "id": "@{{changeId}}"',
|
|
894
755
|
"}"
|
|
895
756
|
].join("\n");
|
|
896
|
-
templateComputeNode.inputSchema =
|
|
757
|
+
templateComputeNode.inputSchema = JsonSchema.toJsonSchema(Schema.Struct({
|
|
897
758
|
type: Schema.String,
|
|
898
759
|
changeId: Schema.String
|
|
899
760
|
}));
|
|
@@ -904,18 +765,18 @@ var createQueueSinkPreset = (space, triggerKind, initSpec, triggerOutputName) =>
|
|
|
904
765
|
};
|
|
905
766
|
};
|
|
906
767
|
var addToSpace = (name, space, canvas, compute) => {
|
|
907
|
-
return space.db.add(
|
|
768
|
+
return space.db.add(Obj.make(CanvasBoard.CanvasBoard, {
|
|
908
769
|
name,
|
|
909
|
-
computeGraph:
|
|
770
|
+
computeGraph: Ref.make(compute.root),
|
|
910
771
|
layout: canvas.graph
|
|
911
772
|
}));
|
|
912
773
|
};
|
|
913
774
|
var setupQueue = (space, canvasModel, args) => {
|
|
914
775
|
const queueId = canvasModel.createNode(createConstant({
|
|
915
|
-
value: new
|
|
776
|
+
value: new DXN(DXN.kind.QUEUE, [
|
|
916
777
|
"data",
|
|
917
778
|
space.id,
|
|
918
|
-
|
|
779
|
+
Key.ObjectId.random()
|
|
919
780
|
]).toString(),
|
|
920
781
|
...args?.idPosition ? rawPosition(args.idPosition) : position({
|
|
921
782
|
x: -18,
|
|
@@ -942,16 +803,18 @@ var setupQueue = (space, canvasModel, args) => {
|
|
|
942
803
|
var attachTrigger = (functionTrigger, computeModel) => {
|
|
943
804
|
invariant(functionTrigger, void 0, {
|
|
944
805
|
F: __dxlog_file,
|
|
945
|
-
L:
|
|
806
|
+
L: 813,
|
|
946
807
|
S: void 0,
|
|
947
808
|
A: [
|
|
948
809
|
"functionTrigger",
|
|
949
810
|
""
|
|
950
811
|
]
|
|
951
812
|
});
|
|
952
|
-
|
|
953
|
-
|
|
954
|
-
|
|
813
|
+
const inputNode = computeModel.nodes.find((node) => node.type === NODE_INPUT);
|
|
814
|
+
Obj.change(functionTrigger, (t) => {
|
|
815
|
+
t.function = Ref.make(computeModel.root);
|
|
816
|
+
t.inputNodeId = inputNode.id;
|
|
817
|
+
});
|
|
955
818
|
};
|
|
956
819
|
var rawPosition = (args) => {
|
|
957
820
|
return {
|
|
@@ -997,163 +860,315 @@ var position = (rect) => {
|
|
|
997
860
|
}
|
|
998
861
|
};
|
|
999
862
|
|
|
1000
|
-
// src/components/SpaceGenerator/
|
|
1001
|
-
import {
|
|
1002
|
-
import
|
|
1003
|
-
import {
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
|
|
1011
|
-
|
|
1012
|
-
|
|
1013
|
-
|
|
1014
|
-
|
|
1015
|
-
|
|
1016
|
-
}, type.typename), /* @__PURE__ */ React.createElement("div", {
|
|
1017
|
-
className: "px-2 text-right font-mono"
|
|
1018
|
-
}, objects[type.typename] ?? 0), /* @__PURE__ */ React.createElement(IconButton, {
|
|
1019
|
-
variant: "ghost",
|
|
1020
|
-
icon: "ph--plus--regular",
|
|
1021
|
-
iconOnly: true,
|
|
1022
|
-
label: "Create data",
|
|
1023
|
-
onClick: () => onClick(type.typename)
|
|
1024
|
-
}))));
|
|
1025
|
-
} finally {
|
|
1026
|
-
_effect.f();
|
|
1027
|
-
}
|
|
863
|
+
// src/components/SpaceGenerator/ObjectGenerator.tsx
|
|
864
|
+
import { addressToA1Notation } from "@dxos/compute";
|
|
865
|
+
import { ComputeGraph, ComputeGraphModel, DEFAULT_OUTPUT, NODE_INPUT as NODE_INPUT2, NODE_OUTPUT } from "@dxos/conductor";
|
|
866
|
+
import { DXN as DXN2, Filter as Filter2, Key as Key2 } from "@dxos/echo";
|
|
867
|
+
import { View } from "@dxos/echo";
|
|
868
|
+
import { Markdown as Markdown2 } from "@dxos/plugin-markdown/types";
|
|
869
|
+
import { Sheet } from "@dxos/plugin-sheet/types";
|
|
870
|
+
import { Diagram } from "@dxos/plugin-sketch/types";
|
|
871
|
+
import { SpaceOperation } from "@dxos/plugin-space/types";
|
|
872
|
+
import { faker } from "@dxos/random";
|
|
873
|
+
import { getTypenameFromQuery } from "@dxos/schema";
|
|
874
|
+
import { createAsyncGenerator } from "@dxos/schema/testing";
|
|
875
|
+
import { range as range2 } from "@dxos/util";
|
|
876
|
+
var generator2 = faker;
|
|
877
|
+
var findViewByTypename = async (views, typename) => {
|
|
878
|
+
return views.find((view) => getTypenameFromQuery(view.query.ast) === typename);
|
|
1028
879
|
};
|
|
880
|
+
var createGenerator = (client, invokePromise, schema) => {
|
|
881
|
+
return async (space, n) => {
|
|
882
|
+
const typename = schema.typename;
|
|
883
|
+
const views = await space.db.query(Filter2.type(View.View)).run();
|
|
884
|
+
const view = await findViewByTypename(views, typename);
|
|
885
|
+
const staticSchema = client?.graph.schemaRegistry.query({
|
|
886
|
+
typename
|
|
887
|
+
}).runSync()[0];
|
|
888
|
+
if (!view && !staticSchema) {
|
|
889
|
+
await invokePromise(SpaceOperation.AddSchema, {
|
|
890
|
+
db: space.db,
|
|
891
|
+
schema,
|
|
892
|
+
show: false
|
|
893
|
+
});
|
|
894
|
+
} else if (!view && staticSchema) {
|
|
895
|
+
await invokePromise(SpaceOperation.UseStaticSchema, {
|
|
896
|
+
db: space.db,
|
|
897
|
+
typename,
|
|
898
|
+
show: false
|
|
899
|
+
});
|
|
900
|
+
}
|
|
901
|
+
const generate = createAsyncGenerator(generator2, schema, {
|
|
902
|
+
db: space.db
|
|
903
|
+
});
|
|
904
|
+
return generate.createObjects(n);
|
|
905
|
+
};
|
|
906
|
+
};
|
|
907
|
+
var staticGenerators = /* @__PURE__ */ new Map([
|
|
908
|
+
[
|
|
909
|
+
Markdown2.Document.typename,
|
|
910
|
+
async (space, n, cb) => {
|
|
911
|
+
const objects = range2(n).map(() => {
|
|
912
|
+
return space.db.add(Markdown2.make({
|
|
913
|
+
name: faker.commerce.productName(),
|
|
914
|
+
content: faker.lorem.sentences(5)
|
|
915
|
+
}));
|
|
916
|
+
});
|
|
917
|
+
cb?.(objects);
|
|
918
|
+
return objects;
|
|
919
|
+
}
|
|
920
|
+
],
|
|
921
|
+
[
|
|
922
|
+
Diagram.Diagram.typename,
|
|
923
|
+
async (space, n, cb) => {
|
|
924
|
+
const objects = range2(n).map(() => {
|
|
925
|
+
const obj = space.db.add(Diagram.make({
|
|
926
|
+
name: faker.commerce.productName()
|
|
927
|
+
}));
|
|
928
|
+
return obj;
|
|
929
|
+
});
|
|
930
|
+
cb?.(objects);
|
|
931
|
+
return objects;
|
|
932
|
+
}
|
|
933
|
+
],
|
|
934
|
+
// TODO(burdon): Create unit tests.
|
|
935
|
+
[
|
|
936
|
+
Sheet.Sheet.typename,
|
|
937
|
+
async (space, n, cb) => {
|
|
938
|
+
const objects = range2(n).map(() => {
|
|
939
|
+
const cells = {};
|
|
940
|
+
const year = (/* @__PURE__ */ new Date()).getFullYear();
|
|
941
|
+
const cols = 4;
|
|
942
|
+
const rows = 16;
|
|
943
|
+
for (let col = 1; col <= cols; col++) {
|
|
944
|
+
for (let row = 1; row <= rows; row++) {
|
|
945
|
+
const cell = addressToA1Notation({
|
|
946
|
+
col,
|
|
947
|
+
row
|
|
948
|
+
});
|
|
949
|
+
if (row === 1) {
|
|
950
|
+
cells[cell] = {
|
|
951
|
+
value: `${year} Q${col}`
|
|
952
|
+
};
|
|
953
|
+
} else if (row === rows) {
|
|
954
|
+
const from = addressToA1Notation({
|
|
955
|
+
col,
|
|
956
|
+
row: 2
|
|
957
|
+
});
|
|
958
|
+
const to = addressToA1Notation({
|
|
959
|
+
col,
|
|
960
|
+
row: rows - 1
|
|
961
|
+
});
|
|
962
|
+
cells[cell] = {
|
|
963
|
+
value: `=SUM(${from}:${to})`
|
|
964
|
+
};
|
|
965
|
+
} else if (row > 2 && row < rows - 1) {
|
|
966
|
+
cells[cell] = {
|
|
967
|
+
value: Math.floor(Math.random() * 1e4)
|
|
968
|
+
};
|
|
969
|
+
}
|
|
970
|
+
}
|
|
971
|
+
}
|
|
972
|
+
return space.db.add(Sheet.make({
|
|
973
|
+
name: faker.commerce.productName(),
|
|
974
|
+
cells
|
|
975
|
+
}));
|
|
976
|
+
});
|
|
977
|
+
cb?.(objects);
|
|
978
|
+
return objects;
|
|
979
|
+
}
|
|
980
|
+
],
|
|
981
|
+
[
|
|
982
|
+
ComputeGraph.typename,
|
|
983
|
+
async (space, n, cb) => {
|
|
984
|
+
const objects = range2(n, () => {
|
|
985
|
+
const model = ComputeGraphModel.create();
|
|
986
|
+
model.builder.createNode({
|
|
987
|
+
id: "gpt-INPUT",
|
|
988
|
+
type: NODE_INPUT2
|
|
989
|
+
}).createNode({
|
|
990
|
+
id: "gpt-GPT",
|
|
991
|
+
type: "gpt"
|
|
992
|
+
}).createNode({
|
|
993
|
+
id: "gpt-QUEUE_ID",
|
|
994
|
+
type: "constant",
|
|
995
|
+
value: new DXN2(DXN2.kind.QUEUE, [
|
|
996
|
+
"data",
|
|
997
|
+
space.id,
|
|
998
|
+
Key2.ObjectId.random()
|
|
999
|
+
]).toString()
|
|
1000
|
+
}).createNode({
|
|
1001
|
+
id: "gpt-APPEND",
|
|
1002
|
+
type: "append"
|
|
1003
|
+
}).createNode({
|
|
1004
|
+
id: "gpt-OUTPUT",
|
|
1005
|
+
type: NODE_OUTPUT
|
|
1006
|
+
}).createEdge({
|
|
1007
|
+
node: "gpt-INPUT",
|
|
1008
|
+
property: "prompt"
|
|
1009
|
+
}, {
|
|
1010
|
+
node: "gpt-GPT",
|
|
1011
|
+
property: "prompt"
|
|
1012
|
+
}).createEdge({
|
|
1013
|
+
node: "gpt-GPT",
|
|
1014
|
+
property: "text"
|
|
1015
|
+
}, {
|
|
1016
|
+
node: "gpt-OUTPUT",
|
|
1017
|
+
property: "text"
|
|
1018
|
+
}).createEdge({
|
|
1019
|
+
node: "gpt-QUEUE_ID",
|
|
1020
|
+
property: DEFAULT_OUTPUT
|
|
1021
|
+
}, {
|
|
1022
|
+
node: "gpt-APPEND",
|
|
1023
|
+
property: "id"
|
|
1024
|
+
}).createEdge({
|
|
1025
|
+
node: "gpt-GPT",
|
|
1026
|
+
property: "messages"
|
|
1027
|
+
}, {
|
|
1028
|
+
node: "gpt-APPEND",
|
|
1029
|
+
property: "items"
|
|
1030
|
+
}).createEdge({
|
|
1031
|
+
node: "gpt-QUEUE_ID",
|
|
1032
|
+
property: DEFAULT_OUTPUT
|
|
1033
|
+
}, {
|
|
1034
|
+
node: "gpt-OUTPUT",
|
|
1035
|
+
property: "queue"
|
|
1036
|
+
});
|
|
1037
|
+
return space.db.add(model.root);
|
|
1038
|
+
});
|
|
1039
|
+
cb?.(objects);
|
|
1040
|
+
return objects;
|
|
1041
|
+
}
|
|
1042
|
+
]
|
|
1043
|
+
]);
|
|
1029
1044
|
|
|
1030
|
-
// src/
|
|
1045
|
+
// src/containers/SpaceGenerator/SpaceGenerator.tsx
|
|
1031
1046
|
var SpaceGenerator = ({ space, onCreateObjects }) => {
|
|
1032
|
-
|
|
1033
|
-
|
|
1034
|
-
|
|
1035
|
-
|
|
1036
|
-
|
|
1037
|
-
|
|
1038
|
-
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
|
|
1042
|
-
|
|
1043
|
-
|
|
1044
|
-
|
|
1045
|
-
|
|
1046
|
-
|
|
1047
|
-
|
|
1048
|
-
|
|
1049
|
-
|
|
1050
|
-
|
|
1051
|
-
|
|
1052
|
-
|
|
1053
|
-
...recordTypes,
|
|
1054
|
-
...presets.schemas
|
|
1055
|
-
]);
|
|
1056
|
-
const recordGenerators = new Map(recordTypes.map((type) => [
|
|
1057
|
-
type.typename,
|
|
1058
|
-
createGenerator(client, dispatch, type)
|
|
1059
|
-
]));
|
|
1060
|
-
return new Map([
|
|
1061
|
-
...staticGenerators,
|
|
1062
|
-
...presets.items,
|
|
1063
|
-
...recordGenerators
|
|
1064
|
-
]);
|
|
1065
|
-
}, [
|
|
1066
|
-
client,
|
|
1067
|
-
recordTypes
|
|
1047
|
+
const { invokePromise } = useOperationInvoker();
|
|
1048
|
+
const client = useClient();
|
|
1049
|
+
const staticTypes = [
|
|
1050
|
+
Markdown3.Document,
|
|
1051
|
+
Diagram2.Diagram,
|
|
1052
|
+
Sheet2.Sheet,
|
|
1053
|
+
ComputeGraph2
|
|
1054
|
+
];
|
|
1055
|
+
const recordTypes = [
|
|
1056
|
+
Organization2.Organization,
|
|
1057
|
+
Person2.Person,
|
|
1058
|
+
Task.Task
|
|
1059
|
+
];
|
|
1060
|
+
const [count, setCount] = useState(1);
|
|
1061
|
+
const [info, setInfo] = useState({});
|
|
1062
|
+
const presets = useMemo(() => generator(), []);
|
|
1063
|
+
useAsyncEffect(async () => {
|
|
1064
|
+
await client.addTypes([
|
|
1065
|
+
...staticTypes,
|
|
1066
|
+
...recordTypes,
|
|
1067
|
+
...presets.schemas
|
|
1068
1068
|
]);
|
|
1069
|
-
|
|
1070
|
-
|
|
1071
|
-
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
|
|
1079
|
-
|
|
1080
|
-
|
|
1081
|
-
setInfo({
|
|
1082
|
-
schema: {
|
|
1083
|
-
static: staticSchema.length,
|
|
1084
|
-
mutable: echoSchema.length
|
|
1085
|
-
},
|
|
1086
|
-
objects: objectMap
|
|
1087
|
-
});
|
|
1088
|
-
};
|
|
1089
|
-
useAsyncEffect(updateInfo, [
|
|
1090
|
-
space
|
|
1069
|
+
}, [
|
|
1070
|
+
client
|
|
1071
|
+
]);
|
|
1072
|
+
const typeMap = useMemo(() => {
|
|
1073
|
+
const recordGenerators = new Map(recordTypes.map((type) => [
|
|
1074
|
+
type.typename,
|
|
1075
|
+
createGenerator(client, invokePromise, type)
|
|
1076
|
+
]));
|
|
1077
|
+
return new Map([
|
|
1078
|
+
...staticGenerators,
|
|
1079
|
+
...presets.items,
|
|
1080
|
+
...recordGenerators
|
|
1091
1081
|
]);
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
|
|
1095
|
-
|
|
1096
|
-
|
|
1082
|
+
}, [
|
|
1083
|
+
client,
|
|
1084
|
+
recordTypes,
|
|
1085
|
+
invokePromise
|
|
1086
|
+
]);
|
|
1087
|
+
const updateInfo = async () => {
|
|
1088
|
+
const echoSchema = await space.db.schemaRegistry.query().run();
|
|
1089
|
+
const staticSchema = await space.db.graph.schemaRegistry.query().run();
|
|
1090
|
+
const objects = await space.db.query(Filter3.everything()).run();
|
|
1091
|
+
const objectMap = sortKeys(objects.reduce((map, obj) => {
|
|
1092
|
+
const type = Obj2.getTypename(obj);
|
|
1093
|
+
if (type) {
|
|
1094
|
+
const count2 = map[type] ?? 0;
|
|
1095
|
+
map[type] = count2 + 1;
|
|
1097
1096
|
}
|
|
1098
|
-
|
|
1099
|
-
|
|
1100
|
-
|
|
1101
|
-
|
|
1102
|
-
|
|
1103
|
-
|
|
1104
|
-
|
|
1105
|
-
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
|
|
1110
|
-
|
|
1111
|
-
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
|
|
1115
|
-
|
|
1116
|
-
|
|
1117
|
-
|
|
1118
|
-
|
|
1119
|
-
|
|
1120
|
-
|
|
1121
|
-
|
|
1122
|
-
|
|
1123
|
-
|
|
1124
|
-
|
|
1125
|
-
|
|
1126
|
-
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
|
|
1130
|
-
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
|
|
1134
|
-
|
|
1135
|
-
|
|
1136
|
-
|
|
1137
|
-
|
|
1138
|
-
|
|
1139
|
-
|
|
1140
|
-
|
|
1141
|
-
|
|
1142
|
-
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
|
|
1148
|
-
|
|
1149
|
-
}
|
|
1150
|
-
|
|
1151
|
-
|
|
1097
|
+
return map;
|
|
1098
|
+
}, {}));
|
|
1099
|
+
setInfo({
|
|
1100
|
+
schema: {
|
|
1101
|
+
static: staticSchema.length,
|
|
1102
|
+
mutable: echoSchema.length
|
|
1103
|
+
},
|
|
1104
|
+
objects: objectMap
|
|
1105
|
+
});
|
|
1106
|
+
};
|
|
1107
|
+
useAsyncEffect(updateInfo, [
|
|
1108
|
+
space
|
|
1109
|
+
]);
|
|
1110
|
+
const handleCreateData = useCallback(async (typename) => {
|
|
1111
|
+
const constructor = typeMap.get(typename);
|
|
1112
|
+
if (constructor) {
|
|
1113
|
+
await constructor(space, count, onCreateObjects);
|
|
1114
|
+
await updateInfo();
|
|
1115
|
+
}
|
|
1116
|
+
}, [
|
|
1117
|
+
typeMap,
|
|
1118
|
+
count
|
|
1119
|
+
]);
|
|
1120
|
+
return /* @__PURE__ */ React2.createElement(Panel.Root, null, /* @__PURE__ */ React2.createElement(Panel.Toolbar, {
|
|
1121
|
+
asChild: true
|
|
1122
|
+
}, /* @__PURE__ */ React2.createElement(Toolbar.Root, null, /* @__PURE__ */ React2.createElement(IconButton2, {
|
|
1123
|
+
icon: "ph--arrow-clockwise--regular",
|
|
1124
|
+
iconOnly: true,
|
|
1125
|
+
label: "Refresh",
|
|
1126
|
+
onClick: updateInfo
|
|
1127
|
+
}), /* @__PURE__ */ React2.createElement(Toolbar.Separator, null), /* @__PURE__ */ React2.createElement(Input.Root, null, /* @__PURE__ */ React2.createElement(Input.TextInput, {
|
|
1128
|
+
type: "number",
|
|
1129
|
+
placeholder: "Count",
|
|
1130
|
+
classNames: "w-[4rem] text-right",
|
|
1131
|
+
min: 1,
|
|
1132
|
+
max: 100,
|
|
1133
|
+
size: 8,
|
|
1134
|
+
value: count,
|
|
1135
|
+
onChange: (event) => setCount(parseInt(event.target.value))
|
|
1136
|
+
})))), /* @__PURE__ */ React2.createElement(Panel.Content, {
|
|
1137
|
+
asChild: true
|
|
1138
|
+
}, /* @__PURE__ */ React2.createElement(ScrollArea.Root, {
|
|
1139
|
+
thin: true,
|
|
1140
|
+
orientation: "vertical"
|
|
1141
|
+
}, /* @__PURE__ */ React2.createElement(ScrollArea.Viewport, {
|
|
1142
|
+
classNames: "gap-4 divide-y divide-subdued-separator"
|
|
1143
|
+
}, /* @__PURE__ */ React2.createElement(SchemaTable, {
|
|
1144
|
+
types: staticTypes,
|
|
1145
|
+
objects: info.objects,
|
|
1146
|
+
label: "Static Types",
|
|
1147
|
+
onClick: handleCreateData
|
|
1148
|
+
}), /* @__PURE__ */ React2.createElement(SchemaTable, {
|
|
1149
|
+
types: recordTypes,
|
|
1150
|
+
objects: info.objects,
|
|
1151
|
+
label: "Record Types",
|
|
1152
|
+
onClick: handleCreateData
|
|
1153
|
+
}), /* @__PURE__ */ React2.createElement(SchemaTable, {
|
|
1154
|
+
types: presets.types,
|
|
1155
|
+
objects: info.objects,
|
|
1156
|
+
label: "Presets",
|
|
1157
|
+
onClick: handleCreateData
|
|
1158
|
+
}), /* @__PURE__ */ React2.createElement(SyntaxHighlighter, {
|
|
1159
|
+
language: "json",
|
|
1160
|
+
classNames: "text-xs"
|
|
1161
|
+
}, JSON.stringify({
|
|
1162
|
+
space,
|
|
1163
|
+
...info
|
|
1164
|
+
}, jsonKeyReplacer({
|
|
1165
|
+
truncate: true
|
|
1166
|
+
}), 2))))));
|
|
1152
1167
|
};
|
|
1153
1168
|
|
|
1154
|
-
// src/
|
|
1169
|
+
// src/containers/SpaceGenerator/index.ts
|
|
1155
1170
|
var SpaceGenerator_default = SpaceGenerator;
|
|
1156
1171
|
export {
|
|
1157
1172
|
SpaceGenerator_default as default
|
|
1158
1173
|
};
|
|
1159
|
-
//# sourceMappingURL=SpaceGenerator-
|
|
1174
|
+
//# sourceMappingURL=SpaceGenerator-SWSGJEEL.mjs.map
|