@dxos/echo 0.8.4-main.b97322e → 0.8.4-main.dedc0f3
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/README.md +1 -1
- package/dist/lib/browser/{chunk-EUA7CM23.mjs → chunk-MTR3E5S2.mjs} +201 -34
- package/dist/lib/browser/chunk-MTR3E5S2.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +5 -1
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +1 -1
- package/dist/lib/node-esm/{chunk-IV6BWGHK.mjs → chunk-MYZLAJSR.mjs} +201 -34
- package/dist/lib/node-esm/chunk-MYZLAJSR.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +5 -1
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/testing/index.mjs +1 -1
- package/dist/types/src/Obj.d.ts +101 -12
- package/dist/types/src/Obj.d.ts.map +1 -1
- package/dist/types/src/Relation.d.ts +6 -4
- package/dist/types/src/Relation.d.ts.map +1 -1
- package/dist/types/src/Type.d.ts +1 -1
- package/dist/types/src/Type.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +2 -1
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/query/dsl.d.ts +20 -0
- package/dist/types/src/query/dsl.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +19 -13
- package/src/Obj.ts +203 -18
- package/src/Relation.ts +10 -8
- package/src/Type.ts +3 -1
- package/src/index.ts +2 -1
- package/src/query/dsl.test.ts +10 -1
- package/src/query/dsl.ts +60 -2
- package/src/test/api.test.ts +9 -2
- package/dist/lib/browser/chunk-EUA7CM23.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-IV6BWGHK.mjs.map +0 -7
package/README.md
CHANGED
|
@@ -122,7 +122,7 @@ Defines attributes and encoding placed on objects.
|
|
|
122
122
|
| | Optional | Runtime prop | Runtime type | JSON prop | JSON type | Description |
|
|
123
123
|
| ------------------- | ----------------------- | -------------------------------------- | ---------------------- | --------------------------- | ---------- | ------------------------------ |
|
|
124
124
|
| Id | No | `id` | `ObjectID` ULID string | `id` | string | Unique object ID |
|
|
125
|
-
| Self DXN | Yes | `Symbol(@dxos/echo/
|
|
125
|
+
| Self DXN | Yes | `Symbol(@dxos/echo/DXN)` | `DXN` | `@dxn` | string | DXN to the object itself |
|
|
126
126
|
| Type | No | `Symbol(@dxos/echo/Type)` | `DXN` | `@type` | string | DXN to the object type |
|
|
127
127
|
| Schema | Yes | `Symbol(@dxos/echo/Schema)` | Effect-Schema | - | | Reference to the object schema |
|
|
128
128
|
| Tombstone marker | Yes | `Symbol(@dxos/echo/Deleted)` | `boolean` | `@deleted` | boolean | Deletion marker |
|
|
@@ -16,27 +16,43 @@ import { SpaceId, ObjectId } from "@dxos/keys";
|
|
|
16
16
|
// src/Obj.ts
|
|
17
17
|
var Obj_exports = {};
|
|
18
18
|
__export(Obj_exports, {
|
|
19
|
+
Meta: () => Meta,
|
|
20
|
+
VersionTypeId: () => VersionTypeId2,
|
|
21
|
+
clone: () => clone,
|
|
22
|
+
compareVersions: () => compareVersions,
|
|
23
|
+
decodeVersion: () => decodeVersion,
|
|
24
|
+
deleteKeys: () => deleteKeys,
|
|
25
|
+
encodeVersion: () => encodeVersion,
|
|
19
26
|
fromJSON: () => fromJSON,
|
|
20
27
|
getDXN: () => getDXN,
|
|
28
|
+
getKeys: () => getKeys,
|
|
21
29
|
getLabel: () => getLabel2,
|
|
22
30
|
getMeta: () => getMeta2,
|
|
23
31
|
getSchema: () => getSchema2,
|
|
32
|
+
getSnapshot: () => getSnapshot2,
|
|
24
33
|
getTypeDXN: () => getTypeDXN,
|
|
25
34
|
getTypename: () => getTypename,
|
|
26
35
|
instanceOf: () => instanceOf,
|
|
27
36
|
isDeleted: () => isDeleted2,
|
|
28
37
|
isObject: () => isObject,
|
|
38
|
+
isVersion: () => isVersion,
|
|
29
39
|
make: () => make,
|
|
30
|
-
|
|
40
|
+
setLabel: () => setLabel2,
|
|
41
|
+
toJSON: () => toJSON,
|
|
42
|
+
version: () => version,
|
|
43
|
+
versionValid: () => versionValid
|
|
31
44
|
});
|
|
32
45
|
import { Schema } from "effect";
|
|
46
|
+
import { dual } from "effect/Function";
|
|
33
47
|
import * as EchoSchema from "@dxos/echo-schema";
|
|
34
48
|
import { assertArgument, invariant } from "@dxos/invariant";
|
|
49
|
+
import * as LiveObject from "@dxos/live-object";
|
|
35
50
|
import { live } from "@dxos/live-object";
|
|
36
|
-
import { assumeType } from "@dxos/util";
|
|
51
|
+
import { assumeType, deepMapValues } from "@dxos/util";
|
|
37
52
|
var __dxlog_file = "/__w/dxos/dxos/packages/core/echo/echo/src/Obj.ts";
|
|
53
|
+
var Meta = EchoSchema.MetaId;
|
|
38
54
|
var make = (schema, props, meta) => {
|
|
39
|
-
assertArgument(EchoSchema.getTypeAnnotation(schema)?.kind === EchoSchema.EntityKind.Object, "Expected an object schema");
|
|
55
|
+
assertArgument(EchoSchema.getTypeAnnotation(schema)?.kind === EchoSchema.EntityKind.Object, "schema", "Expected an object schema");
|
|
40
56
|
if (props[EchoSchema.MetaId] != null) {
|
|
41
57
|
meta = props[EchoSchema.MetaId];
|
|
42
58
|
delete props[EchoSchema.MetaId];
|
|
@@ -55,11 +71,11 @@ var instanceOf = (...args) => {
|
|
|
55
71
|
};
|
|
56
72
|
var getSchema2 = EchoSchema.getSchema;
|
|
57
73
|
var getDXN = (obj) => {
|
|
58
|
-
assertArgument(!Schema.isSchema(obj), "Object should not be a schema.");
|
|
74
|
+
assertArgument(!Schema.isSchema(obj), "obj", "Object should not be a schema.");
|
|
59
75
|
const dxn = EchoSchema.getObjectDXN(obj);
|
|
60
76
|
invariant(dxn != null, "Invalid object.", {
|
|
61
77
|
F: __dxlog_file,
|
|
62
|
-
L:
|
|
78
|
+
L: 113,
|
|
63
79
|
S: void 0,
|
|
64
80
|
A: [
|
|
65
81
|
"dxn != null",
|
|
@@ -80,7 +96,7 @@ var getMeta2 = (obj) => {
|
|
|
80
96
|
const meta = EchoSchema.getMeta(obj);
|
|
81
97
|
invariant(meta != null, "Invalid object.", {
|
|
82
98
|
F: __dxlog_file,
|
|
83
|
-
L:
|
|
99
|
+
L: 141,
|
|
84
100
|
S: void 0,
|
|
85
101
|
A: [
|
|
86
102
|
"meta != null",
|
|
@@ -89,11 +105,33 @@ var getMeta2 = (obj) => {
|
|
|
89
105
|
});
|
|
90
106
|
return meta;
|
|
91
107
|
};
|
|
108
|
+
var getKeys = dual(2, (obj, source) => {
|
|
109
|
+
const meta = EchoSchema.getMeta(obj);
|
|
110
|
+
invariant(meta != null, "Invalid object.", {
|
|
111
|
+
F: __dxlog_file,
|
|
112
|
+
L: 153,
|
|
113
|
+
S: void 0,
|
|
114
|
+
A: [
|
|
115
|
+
"meta != null",
|
|
116
|
+
"'Invalid object.'"
|
|
117
|
+
]
|
|
118
|
+
});
|
|
119
|
+
return meta.keys.filter((key) => key.source === source);
|
|
120
|
+
});
|
|
121
|
+
var deleteKeys = (obj, source) => {
|
|
122
|
+
const meta = EchoSchema.getMeta(obj);
|
|
123
|
+
for (let i = 0; i < meta.keys.length; i++) {
|
|
124
|
+
if (meta.keys[i].source === source) {
|
|
125
|
+
meta.keys.splice(i, 1);
|
|
126
|
+
i--;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
};
|
|
92
130
|
var isDeleted2 = (obj) => {
|
|
93
131
|
const deleted = EchoSchema.isDeleted(obj);
|
|
94
132
|
invariant(typeof deleted === "boolean", "Invalid object.", {
|
|
95
133
|
F: __dxlog_file,
|
|
96
|
-
L:
|
|
134
|
+
L: 175,
|
|
97
135
|
S: void 0,
|
|
98
136
|
A: [
|
|
99
137
|
"typeof deleted === 'boolean'",
|
|
@@ -108,8 +146,86 @@ var getLabel2 = (obj) => {
|
|
|
108
146
|
return EchoSchema.getLabel(schema, obj);
|
|
109
147
|
}
|
|
110
148
|
};
|
|
149
|
+
var setLabel2 = (obj, label) => {
|
|
150
|
+
const schema = getSchema2(obj);
|
|
151
|
+
if (schema != null) {
|
|
152
|
+
EchoSchema.setLabel(schema, obj, label);
|
|
153
|
+
}
|
|
154
|
+
};
|
|
111
155
|
var toJSON = (obj) => EchoSchema.objectToJSON(obj);
|
|
112
156
|
var fromJSON = EchoSchema.objectFromJSON;
|
|
157
|
+
var getSnapshot2 = LiveObject.getSnapshot;
|
|
158
|
+
var clone = (obj, opts) => {
|
|
159
|
+
const { id, ...data } = obj;
|
|
160
|
+
const schema = getSchema2(obj);
|
|
161
|
+
invariant(schema != null, "Object should have a schema", {
|
|
162
|
+
F: __dxlog_file,
|
|
163
|
+
L: 240,
|
|
164
|
+
S: void 0,
|
|
165
|
+
A: [
|
|
166
|
+
"schema != null",
|
|
167
|
+
"'Object should have a schema'"
|
|
168
|
+
]
|
|
169
|
+
});
|
|
170
|
+
const props = deepMapValues(data, (value, recurse) => {
|
|
171
|
+
if (EchoSchema.Ref.isRef(value)) {
|
|
172
|
+
return value;
|
|
173
|
+
}
|
|
174
|
+
return recurse(value);
|
|
175
|
+
});
|
|
176
|
+
if (opts?.retainId) {
|
|
177
|
+
props.id = id;
|
|
178
|
+
}
|
|
179
|
+
const meta = getMeta2(obj);
|
|
180
|
+
props[EchoSchema.MetaId] = deepMapValues(meta, (value, recurse) => {
|
|
181
|
+
if (EchoSchema.Ref.isRef(value)) {
|
|
182
|
+
return value;
|
|
183
|
+
}
|
|
184
|
+
return recurse(value);
|
|
185
|
+
});
|
|
186
|
+
return make(schema, props);
|
|
187
|
+
};
|
|
188
|
+
var VersionTypeId2 = EchoSchema.VersionTypeId;
|
|
189
|
+
var unversioned = {
|
|
190
|
+
[VersionTypeId2]: {},
|
|
191
|
+
versioned: false
|
|
192
|
+
};
|
|
193
|
+
var isVersion = (obj) => {
|
|
194
|
+
return obj != null && typeof obj === "object" && VersionTypeId2 in obj;
|
|
195
|
+
};
|
|
196
|
+
var version = (obj) => {
|
|
197
|
+
const version2 = obj[EchoSchema.ObjectVersionId];
|
|
198
|
+
if (version2 === void 0) {
|
|
199
|
+
return unversioned;
|
|
200
|
+
}
|
|
201
|
+
return version2;
|
|
202
|
+
};
|
|
203
|
+
var versionValid = (version2) => {
|
|
204
|
+
assertArgument(isVersion(version2), "version", "Invalid version object");
|
|
205
|
+
return !!version2.versioned;
|
|
206
|
+
};
|
|
207
|
+
var compareVersions = (version1, version2) => {
|
|
208
|
+
assertArgument(isVersion(version1), "version1", "Invalid version object");
|
|
209
|
+
assertArgument(isVersion(version2), "version2", "Invalid version object");
|
|
210
|
+
if (!versionValid(version1) || !versionValid(version2)) {
|
|
211
|
+
return "unversioned";
|
|
212
|
+
}
|
|
213
|
+
if (version1.automergeHeads?.length !== version2.automergeHeads?.length) {
|
|
214
|
+
return "different";
|
|
215
|
+
}
|
|
216
|
+
if (version1.automergeHeads?.some((head) => !version2.automergeHeads?.includes(head))) {
|
|
217
|
+
return "different";
|
|
218
|
+
}
|
|
219
|
+
return "equal";
|
|
220
|
+
};
|
|
221
|
+
var encodeVersion = (version2) => {
|
|
222
|
+
return JSON.stringify(version2);
|
|
223
|
+
};
|
|
224
|
+
var decodeVersion = (version2) => {
|
|
225
|
+
const parsed = JSON.parse(version2);
|
|
226
|
+
parsed[VersionTypeId2] = {};
|
|
227
|
+
return parsed;
|
|
228
|
+
};
|
|
113
229
|
|
|
114
230
|
// src/Ref.ts
|
|
115
231
|
var Ref_exports = {};
|
|
@@ -147,7 +263,7 @@ var __dxlog_file2 = "/__w/dxos/dxos/packages/core/echo/echo/src/Relation.ts";
|
|
|
147
263
|
var Source = EchoSchema3.RelationSourceId;
|
|
148
264
|
var Target = EchoSchema3.RelationTargetId;
|
|
149
265
|
var make3 = (schema, props, meta) => {
|
|
150
|
-
assertArgument2(EchoSchema3.getTypeAnnotation(schema)?.kind === EchoSchema3.EntityKind.Relation, "Expected a relation schema");
|
|
266
|
+
assertArgument2(EchoSchema3.getTypeAnnotation(schema)?.kind === EchoSchema3.EntityKind.Relation, "schema", "Expected a relation schema");
|
|
151
267
|
if (props[EchoSchema3.MetaId] != null) {
|
|
152
268
|
meta = props[EchoSchema3.MetaId];
|
|
153
269
|
delete props[EchoSchema3.MetaId];
|
|
@@ -174,7 +290,7 @@ var getSourceDXN = (value) => {
|
|
|
174
290
|
const dxn = value[EchoSchema3.RelationSourceDXNId];
|
|
175
291
|
invariant2(dxn instanceof DXN, void 0, {
|
|
176
292
|
F: __dxlog_file2,
|
|
177
|
-
L:
|
|
293
|
+
L: 100,
|
|
178
294
|
S: void 0,
|
|
179
295
|
A: [
|
|
180
296
|
"dxn instanceof DXN",
|
|
@@ -189,7 +305,7 @@ var getTargetDXN = (value) => {
|
|
|
189
305
|
const dxn = value[EchoSchema3.RelationTargetDXNId];
|
|
190
306
|
invariant2(dxn instanceof DXN, void 0, {
|
|
191
307
|
F: __dxlog_file2,
|
|
192
|
-
L:
|
|
308
|
+
L: 112,
|
|
193
309
|
S: void 0,
|
|
194
310
|
A: [
|
|
195
311
|
"dxn instanceof DXN",
|
|
@@ -204,7 +320,7 @@ var getSource = (relation) => {
|
|
|
204
320
|
const obj = relation[EchoSchema3.RelationSourceId];
|
|
205
321
|
invariant2(obj !== void 0, `Invalid source: ${relation.id}`, {
|
|
206
322
|
F: __dxlog_file2,
|
|
207
|
-
L:
|
|
323
|
+
L: 124,
|
|
208
324
|
S: void 0,
|
|
209
325
|
A: [
|
|
210
326
|
"obj !== undefined",
|
|
@@ -219,7 +335,7 @@ var getTarget = (relation) => {
|
|
|
219
335
|
const obj = relation[EchoSchema3.RelationTargetId];
|
|
220
336
|
invariant2(obj !== void 0, `Invalid target: ${relation.id}`, {
|
|
221
337
|
F: __dxlog_file2,
|
|
222
|
-
L:
|
|
338
|
+
L: 136,
|
|
223
339
|
S: void 0,
|
|
224
340
|
A: [
|
|
225
341
|
"obj !== undefined",
|
|
@@ -240,7 +356,7 @@ __export(Type_exports, {
|
|
|
240
356
|
KindId: () => KindId,
|
|
241
357
|
Obj: () => Obj,
|
|
242
358
|
ObjectId: () => ObjectId2,
|
|
243
|
-
Ref: () =>
|
|
359
|
+
Ref: () => Ref4,
|
|
244
360
|
Relation: () => Relation,
|
|
245
361
|
SpaceId: () => SpaceId2,
|
|
246
362
|
getDXN: () => getDXN2,
|
|
@@ -261,7 +377,7 @@ var Kind = EchoSchema4.EntityKind;
|
|
|
261
377
|
var Obj = EchoSchema4.EchoObject;
|
|
262
378
|
var Expando2 = EchoSchema4.Expando;
|
|
263
379
|
var Relation = EchoSchema4.EchoRelation;
|
|
264
|
-
var
|
|
380
|
+
var Ref4 = EchoSchema4.Ref;
|
|
265
381
|
var getDXN2 = (schema) => {
|
|
266
382
|
return EchoSchema4.getSchemaDXN(schema);
|
|
267
383
|
};
|
|
@@ -269,7 +385,7 @@ var getTypename2 = (schema) => {
|
|
|
269
385
|
const typename = EchoSchema4.getSchemaTypename(schema);
|
|
270
386
|
invariant3(typeof typename === "string" && !typename.startsWith("dxn:"), "Invalid typename", {
|
|
271
387
|
F: __dxlog_file3,
|
|
272
|
-
L:
|
|
388
|
+
L: 212,
|
|
273
389
|
S: void 0,
|
|
274
390
|
A: [
|
|
275
391
|
"typeof typename === 'string' && !typename.startsWith('dxn:')",
|
|
@@ -279,17 +395,17 @@ var getTypename2 = (schema) => {
|
|
|
279
395
|
return typename;
|
|
280
396
|
};
|
|
281
397
|
var getVersion = (schema) => {
|
|
282
|
-
const
|
|
283
|
-
invariant3(typeof
|
|
398
|
+
const version2 = EchoSchema4.getSchemaVersion(schema);
|
|
399
|
+
invariant3(typeof version2 === "string" && version2.match(/^\d+\.\d+\.\d+$/), "Invalid version", {
|
|
284
400
|
F: __dxlog_file3,
|
|
285
|
-
L:
|
|
401
|
+
L: 222,
|
|
286
402
|
S: void 0,
|
|
287
403
|
A: [
|
|
288
404
|
"typeof version === 'string' && version.match(/^\\d+\\.\\d+\\.\\d+$/)",
|
|
289
405
|
"'Invalid version'"
|
|
290
406
|
]
|
|
291
407
|
});
|
|
292
|
-
return
|
|
408
|
+
return version2;
|
|
293
409
|
};
|
|
294
410
|
var isMutable2 = EchoSchema4.isMutable;
|
|
295
411
|
var getMeta3 = (schema) => {
|
|
@@ -305,10 +421,42 @@ import { raise as raise2 } from "@dxos/debug";
|
|
|
305
421
|
import { getTypeReference } from "@dxos/echo-schema";
|
|
306
422
|
import { assertArgument as assertArgument3 } from "@dxos/invariant";
|
|
307
423
|
import { DXN as DXN3, ObjectId as ObjectId3 } from "@dxos/keys";
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
424
|
+
function _define_property(obj, key, value) {
|
|
425
|
+
if (key in obj) {
|
|
426
|
+
Object.defineProperty(obj, key, {
|
|
427
|
+
value,
|
|
428
|
+
enumerable: true,
|
|
429
|
+
configurable: true,
|
|
430
|
+
writable: true
|
|
431
|
+
});
|
|
432
|
+
} else {
|
|
433
|
+
obj[key] = value;
|
|
311
434
|
}
|
|
435
|
+
return obj;
|
|
436
|
+
}
|
|
437
|
+
var OrderClass = class _OrderClass {
|
|
438
|
+
static is(value) {
|
|
439
|
+
return typeof value === "object" && value !== null && "~Order" in value;
|
|
440
|
+
}
|
|
441
|
+
constructor(ast) {
|
|
442
|
+
_define_property(this, "ast", void 0);
|
|
443
|
+
_define_property(this, "~Order", void 0);
|
|
444
|
+
this.ast = ast;
|
|
445
|
+
this["~Order"] = _OrderClass.variance;
|
|
446
|
+
}
|
|
447
|
+
};
|
|
448
|
+
_define_property(OrderClass, "variance", {});
|
|
449
|
+
(function(Order2) {
|
|
450
|
+
Order2.natural = new OrderClass({
|
|
451
|
+
kind: "natural"
|
|
452
|
+
});
|
|
453
|
+
Order2.property = (property, direction) => new OrderClass({
|
|
454
|
+
kind: "property",
|
|
455
|
+
property,
|
|
456
|
+
direction
|
|
457
|
+
});
|
|
458
|
+
})(Order || (Order = {}));
|
|
459
|
+
var FilterClass = class _FilterClass {
|
|
312
460
|
static is(value) {
|
|
313
461
|
return typeof value === "object" && value !== null && "~Filter" in value;
|
|
314
462
|
}
|
|
@@ -337,7 +485,7 @@ var FilterClass = class _FilterClass {
|
|
|
337
485
|
});
|
|
338
486
|
}
|
|
339
487
|
static ids(...ids) {
|
|
340
|
-
assertArgument3(ids.every((id) => ObjectId3.isValid(id)), "ids must be valid");
|
|
488
|
+
assertArgument3(ids.every((id) => ObjectId3.isValid(id)), "ids", "ids must be valid");
|
|
341
489
|
if (ids.length === 0) {
|
|
342
490
|
return Filter.nothing();
|
|
343
491
|
}
|
|
@@ -357,7 +505,7 @@ var FilterClass = class _FilterClass {
|
|
|
357
505
|
});
|
|
358
506
|
}
|
|
359
507
|
static typename(typename) {
|
|
360
|
-
assertArgument3(!typename.startsWith("dxn:"), "Typename must no be qualified");
|
|
508
|
+
assertArgument3(!typename.startsWith("dxn:"), "typename", "Typename must no be qualified");
|
|
361
509
|
return new _FilterClass({
|
|
362
510
|
type: "object",
|
|
363
511
|
typename: DXN3.fromTypename(typename).toString(),
|
|
@@ -474,15 +622,18 @@ var FilterClass = class _FilterClass {
|
|
|
474
622
|
});
|
|
475
623
|
}
|
|
476
624
|
constructor(ast) {
|
|
625
|
+
_define_property(this, "ast", void 0);
|
|
626
|
+
_define_property(this, "~Filter", void 0);
|
|
477
627
|
this.ast = ast;
|
|
478
628
|
this["~Filter"] = _FilterClass.variance;
|
|
479
629
|
}
|
|
480
630
|
};
|
|
631
|
+
_define_property(FilterClass, "variance", {});
|
|
481
632
|
var Filter = FilterClass;
|
|
482
633
|
var propsFilterToAst = (predicates) => {
|
|
483
634
|
let idFilter;
|
|
484
635
|
if ("id" in predicates) {
|
|
485
|
-
assertArgument3(typeof predicates.id === "string" || Array.isArray(predicates.id), "invalid id filter");
|
|
636
|
+
assertArgument3(typeof predicates.id === "string" || Array.isArray(predicates.id), "predicates.id", "invalid id filter");
|
|
486
637
|
idFilter = typeof predicates.id === "string" ? [
|
|
487
638
|
predicates.id
|
|
488
639
|
] : predicates.id;
|
|
@@ -497,12 +648,12 @@ var propsFilterToAst = (predicates) => {
|
|
|
497
648
|
};
|
|
498
649
|
};
|
|
499
650
|
var QueryClass = class _QueryClass {
|
|
500
|
-
static {
|
|
501
|
-
this.variance = {};
|
|
502
|
-
}
|
|
503
651
|
static is(value) {
|
|
504
652
|
return typeof value === "object" && value !== null && "~Query" in value;
|
|
505
653
|
}
|
|
654
|
+
static fromAst(ast) {
|
|
655
|
+
return new _QueryClass(ast);
|
|
656
|
+
}
|
|
506
657
|
static select(filter) {
|
|
507
658
|
return new _QueryClass({
|
|
508
659
|
type: "select",
|
|
@@ -531,10 +682,6 @@ var QueryClass = class _QueryClass {
|
|
|
531
682
|
exclude: exclude.ast
|
|
532
683
|
});
|
|
533
684
|
}
|
|
534
|
-
constructor(ast) {
|
|
535
|
-
this.ast = ast;
|
|
536
|
-
this["~Query"] = _QueryClass.variance;
|
|
537
|
-
}
|
|
538
685
|
select(filter) {
|
|
539
686
|
if (Filter.is(filter)) {
|
|
540
687
|
return new _QueryClass({
|
|
@@ -596,6 +743,13 @@ var QueryClass = class _QueryClass {
|
|
|
596
743
|
direction: "target"
|
|
597
744
|
});
|
|
598
745
|
}
|
|
746
|
+
orderBy(...order) {
|
|
747
|
+
return new _QueryClass({
|
|
748
|
+
type: "order",
|
|
749
|
+
query: this.ast,
|
|
750
|
+
order: order.map((o) => o.ast)
|
|
751
|
+
});
|
|
752
|
+
}
|
|
599
753
|
options(options) {
|
|
600
754
|
return new _QueryClass({
|
|
601
755
|
type: "options",
|
|
@@ -603,8 +757,19 @@ var QueryClass = class _QueryClass {
|
|
|
603
757
|
options
|
|
604
758
|
});
|
|
605
759
|
}
|
|
760
|
+
constructor(ast) {
|
|
761
|
+
_define_property(this, "ast", void 0);
|
|
762
|
+
_define_property(this, "~Query", void 0);
|
|
763
|
+
this.ast = ast;
|
|
764
|
+
this["~Query"] = _QueryClass.variance;
|
|
765
|
+
}
|
|
606
766
|
};
|
|
767
|
+
_define_property(QueryClass, "variance", {});
|
|
607
768
|
var Query = QueryClass;
|
|
769
|
+
var Order;
|
|
770
|
+
|
|
771
|
+
// src/index.ts
|
|
772
|
+
import { QueryAST } from "@dxos/echo-protocol";
|
|
608
773
|
|
|
609
774
|
export {
|
|
610
775
|
Key_exports,
|
|
@@ -614,6 +779,8 @@ export {
|
|
|
614
779
|
Type_exports,
|
|
615
780
|
Filter,
|
|
616
781
|
Query,
|
|
617
|
-
|
|
782
|
+
Order,
|
|
783
|
+
DXN4 as DXN,
|
|
784
|
+
QueryAST
|
|
618
785
|
};
|
|
619
|
-
//# sourceMappingURL=chunk-
|
|
786
|
+
//# sourceMappingURL=chunk-MTR3E5S2.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/Key.ts", "../../../src/Obj.ts", "../../../src/Ref.ts", "../../../src/Relation.ts", "../../../src/Type.ts", "../../../src/index.ts", "../../../src/query/dsl.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nexport { SpaceId, ObjectId } from '@dxos/keys';\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\nimport { dual } from 'effect/Function';\n\nimport * as EchoSchema from '@dxos/echo-schema';\nimport { assertArgument, invariant } from '@dxos/invariant';\nimport { type DXN } from '@dxos/keys';\nimport * as LiveObject from '@dxos/live-object';\nimport { live } from '@dxos/live-object';\nimport { assumeType, deepMapValues } from '@dxos/util';\n\nimport type * as Ref from './Ref';\nimport type * as Relation from './Relation';\nimport type * as Type from './Type';\n\n/**\n * NOTE: Don't export: Obj.Any and Obj.Obj form the public API.\n */\ninterface BaseObj extends EchoSchema.HasId, Type.OfKind<EchoSchema.EntityKind.Object> {}\n\n/**\n * Object type with specific properties.\n */\nexport type Obj<Props> = BaseObj & Props;\n\n/**\n * Base type for all ECHO objects.\n */\nexport interface Any extends BaseObj {}\n\ntype Props<T = any> = { id?: EchoSchema.ObjectId } & Type.Properties<T>;\n\nexport type MakeProps<T extends Type.Obj.Any> = NoInfer<Props<Schema.Schema.Type<T>>> & {\n [Meta]?: Partial<EchoSchema.ObjectMeta>;\n};\n\nexport const Meta: unique symbol = EchoSchema.MetaId as any;\n\n// TODO(dmaretskyi): Expose Meta = EchoSchema.MetaId.\n\n/**\n * Creates new object.\n * @param schema - Object schema.\n * @param props - Object properties.\n * @param meta - Object metadata (deprecated) -- pass with Obj.Meta.\n *\n * Meta can be passed as a symbol in `props`.\n *\n * Example:\n * ```ts\n * const obj = Obj.make(Person, { [Obj.Meta]: { keys: [...] }, name: 'John' });\n * ```\n */\nexport const make = <S extends Type.Obj.Any>(\n schema: S,\n props: MakeProps<S>,\n meta?: EchoSchema.ObjectMeta,\n): LiveObject.Live<Schema.Schema.Type<S>> => {\n assertArgument(\n EchoSchema.getTypeAnnotation(schema)?.kind === EchoSchema.EntityKind.Object,\n 'schema',\n 'Expected an object schema',\n );\n\n if (props[EchoSchema.MetaId] != null) {\n meta = props[EchoSchema.MetaId] as any;\n delete props[EchoSchema.MetaId];\n }\n\n return live<Schema.Schema.Type<S>>(schema, props as any, meta);\n};\n\nexport const isObject = (obj: unknown): obj is Any => {\n assumeType<EchoSchema.InternalObjectProps>(obj);\n return typeof obj === 'object' && obj !== null && obj[EchoSchema.EntityKindId] === EchoSchema.EntityKind.Object;\n};\n\n/**\n * Test if object or relation is an instance of a schema.\n * @example\n * ```ts\n * const john = Obj.make(Person, { name: 'John' });\n * const johnIsPerson = Obj.instanceOf(Person)(john);\n *\n * const isPerson = Obj.instanceOf(Person);\n * if(isPerson(john)) {\n * // john is Person\n * }\n * ```\n */\nexport const instanceOf: {\n <S extends Type.Relation.Any | Type.Obj.Any>(schema: S): (value: unknown) => value is Schema.Schema.Type<S>;\n <S extends Type.Relation.Any | Type.Obj.Any>(schema: S, value: unknown): value is Schema.Schema.Type<S>;\n} = ((\n ...args: [schema: Type.Relation.Any | Type.Obj.Any, value: unknown] | [schema: Type.Relation.Any | Type.Obj.Any]\n) => {\n if (args.length === 1) {\n return (obj: unknown) => EchoSchema.isInstanceOf(args[0], obj);\n }\n\n return EchoSchema.isInstanceOf(args[0], args[1]);\n}) as any;\n\nexport const getSchema = EchoSchema.getSchema;\n\n// TODO(dmaretskyi): Allow returning undefined.\nexport const getDXN = (obj: Any | Relation.Any): DXN => {\n assertArgument(!Schema.isSchema(obj), 'obj', 'Object should not be a schema.');\n const dxn = EchoSchema.getObjectDXN(obj);\n invariant(dxn != null, 'Invalid object.');\n return dxn;\n};\n\n/**\n * @returns The DXN of the object's type.\n * @example dxn:example.com/type/Contact:1.0.0\n */\n// TODO(burdon): Expando does not have a type.\nexport const getTypeDXN = EchoSchema.getType;\n\n/**\n * @returns The typename of the object's type.\n * @example `example.com/type/Contact`\n */\nexport const getTypename = (obj: Any | Relation.Any): string | undefined => {\n const schema = getSchema(obj);\n if (schema == null) {\n // Try to extract typename from DXN.\n return EchoSchema.getType(obj)?.asTypeDXN()?.type;\n }\n\n return EchoSchema.getSchemaTypename(schema);\n};\n\n// TODO(dmaretskyi): Allow returning undefined.\nexport const getMeta = (obj: Any | Relation.Any): EchoSchema.ObjectMeta => {\n const meta = EchoSchema.getMeta(obj);\n invariant(meta != null, 'Invalid object.');\n return meta;\n};\n\n/**\n * @returns Foreign keys for the object from the specified source.\n */\nexport const getKeys: {\n (obj: Any | Relation.Any, source: string): EchoSchema.ForeignKey[];\n (source: string): (obj: Any | Relation.Any) => EchoSchema.ForeignKey[];\n} = dual(2, (obj: Any | Relation.Any, source?: string): EchoSchema.ForeignKey[] => {\n const meta = EchoSchema.getMeta(obj);\n invariant(meta != null, 'Invalid object.');\n return meta.keys.filter((key) => key.source === source);\n});\n\n/**\n * Delete all keys from the object for the specified source.\n * @param obj\n * @param source\n */\nexport const deleteKeys = (obj: Any | Relation.Any, source: string) => {\n const meta = EchoSchema.getMeta(obj);\n for (let i = 0; i < meta.keys.length; i++) {\n if (meta.keys[i].source === source) {\n meta.keys.splice(i, 1);\n i--;\n }\n }\n};\n\n// TODO(dmaretskyi): Default to `false`.\nexport const isDeleted = (obj: Any | Relation.Any): boolean => {\n const deleted = EchoSchema.isDeleted(obj);\n invariant(typeof deleted === 'boolean', 'Invalid object.');\n return deleted;\n};\n\n// TODO(burdon): Rename \"label\"\nexport const getLabel = (obj: Any | Relation.Any): string | undefined => {\n const schema = getSchema(obj);\n if (schema != null) {\n return EchoSchema.getLabel(schema, obj);\n }\n};\n\nexport const setLabel = (obj: Any | Relation.Any, label: string) => {\n const schema = getSchema(obj);\n if (schema != null) {\n EchoSchema.setLabel(schema, obj, label);\n }\n};\n\n/**\n * JSON representation of an object.\n */\nexport type JSON = EchoSchema.ObjectJSON;\n\n/**\n * Converts object to its JSON representation.\n *\n * The same algorithm is used when calling the standard `JSON.stringify(obj)` function.\n */\n// TODO(burdon): Base util type for Obj/Relation?\nexport const toJSON = (obj: Any | Relation.Any): JSON => EchoSchema.objectToJSON(obj);\n\n/**\n * Creates an object from its json representation, performing schema validation.\n * References and schemas will be resolvable if the `refResolver` is provided.\n *\n * The function need to be async to support resolving the schema as well as the relation endpoints.\n *\n * @param options.refResolver - Resolver for references. Produces hydrated references that can be resolved.\n * @param options.dxn - Override object DXN. Changes the result of `Obj.getDXN`.\n */\nexport const fromJSON: (json: unknown, options?: { refResolver?: Ref.Resolver; dxn?: DXN }) => Promise<Any> =\n EchoSchema.objectFromJSON as any;\n\n/**\n * Returns an immutable snapshot of an object.\n */\nexport const getSnapshot: <T extends Any>(obj: Obj<T>) => T = LiveObject.getSnapshot;\n\nexport type CloneOptions = {\n /**\n * Retain the original object's ID.\n * @default false\n */\n retainId?: boolean;\n};\n\n/**\n * Clones an object or relation.\n * This does not clone referenced objects, only the properties in the object.\n * @returns A new object with the same schema and properties.\n */\nexport const clone = <T extends Any | Relation.Any>(obj: T, opts?: CloneOptions): T => {\n const { id, ...data } = obj;\n const schema = getSchema(obj);\n invariant(schema != null, 'Object should have a schema');\n const props: any = deepMapValues(data, (value, recurse) => {\n if (EchoSchema.Ref.isRef(value)) {\n return value;\n }\n return recurse(value);\n });\n if (opts?.retainId) {\n props.id = id;\n }\n const meta = getMeta(obj);\n props[EchoSchema.MetaId] = deepMapValues(meta, (value, recurse) => {\n if (EchoSchema.Ref.isRef(value)) {\n return value;\n }\n return recurse(value);\n });\n return make(schema, props);\n};\n\nexport const VersionTypeId = EchoSchema.VersionTypeId;\nexport type VersionType = typeof VersionTypeId;\n\n/**\n * Represent object version.\n * May be backed by Automerge.\n * Objects with no history are not versioned.\n */\nexport interface Version {\n [VersionTypeId]: {};\n\n /**\n * Whether the object is versioned.\n */\n versioned: boolean;\n\n /**\n * Automerge heads.\n */\n automergeHeads?: string[];\n}\n\nconst unversioned: Version = {\n [VersionTypeId]: {},\n versioned: false,\n};\n\n/**\n * Checks that `obj` is a version object.\n */\nexport const isVersion = (obj: unknown): obj is Version => {\n return obj != null && typeof obj === 'object' && VersionTypeId in obj;\n};\n\n/**\n * Returns the version of the object.\n */\nexport const version = (obj: Any | Relation.Any): Version => {\n const version = (obj as any)[EchoSchema.ObjectVersionId];\n if (version === undefined) {\n return unversioned;\n }\n return version;\n};\n\n/**\n * Checks that `version` is a valid version object.\n */\nexport const versionValid = (version: Version): boolean => {\n assertArgument(isVersion(version), 'version', 'Invalid version object');\n return !!version.versioned;\n};\n\nexport type VersionCompareResult = 'unversioned' | 'equal' | 'different';\n\n/**\n * Compares two versions.\n * @param version1\n * @param version2\n * @returns 'unversioned' if either object is unversioned, 'equal' if the versions are equal, 'different' if the versions are different.\n */\nexport const compareVersions = (version1: Version, version2: Version): VersionCompareResult => {\n assertArgument(isVersion(version1), 'version1', 'Invalid version object');\n assertArgument(isVersion(version2), 'version2', 'Invalid version object');\n\n if (!versionValid(version1) || !versionValid(version2)) {\n return 'unversioned';\n }\n\n if (version1.automergeHeads?.length !== version2.automergeHeads?.length) {\n return 'different';\n }\n if (version1.automergeHeads?.some((head) => !version2.automergeHeads?.includes(head))) {\n return 'different';\n }\n\n return 'equal';\n};\n\nexport const encodeVersion = (version: Version): string => {\n return JSON.stringify(version);\n};\n\nexport const decodeVersion = (version: string): Version => {\n const parsed = JSON.parse(version);\n parsed[VersionTypeId] = {};\n return parsed;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport * as EchoSchema from '@dxos/echo-schema';\n\nimport type * as Obj from './Obj';\n\nexport type Ref<T> = EchoSchema.Ref<T>;\nexport type Any = EchoSchema.Ref<Obj.Any>;\n\nexport const Array = EchoSchema.RefArray;\n\n/**\n * Extract reference target.\n */\nexport type Target<R extends Any> = R extends EchoSchema.Ref<infer T> ? T : never;\n\n/**\n * Reference resolver.\n */\nexport type Resolver = EchoSchema.RefResolver;\n\nexport const isRef: (value: unknown) => value is Any = EchoSchema.Ref.isRef;\n\nexport const make = EchoSchema.Ref.make;\n\n// TODO(dmaretskyi): Consider just allowing `make` to accept DXN.\nexport const fromDXN = EchoSchema.Ref.fromDXN;\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Schema } from 'effect';\n\nimport { raise } from '@dxos/debug';\nimport * as EchoSchema from '@dxos/echo-schema';\nimport { assertArgument, invariant } from '@dxos/invariant';\nimport { DXN } from '@dxos/keys';\nimport { type Live, live } from '@dxos/live-object';\nimport { assumeType } from '@dxos/util';\n\nimport type * as Obj from './Obj';\nimport type * as Type from './Type';\n\n/**\n * NOTE: Don't export: Relation.Relation and Relation.Any form the public API.\n */\ninterface BaseRelation<Source, Target>\n extends EchoSchema.HasId,\n Type.Relation.Endpoints<Source, Target>,\n Type.OfKind<EchoSchema.EntityKind.Relation> {}\n\n/**\n * Relation type with specific properties.\n */\nexport type Relation<Source extends Obj.Any, Target extends Obj.Any, Props> = BaseRelation<Source, Target> & Props;\n\n/**\n * Base type for all ECHO relations.\n */\nexport interface Any extends BaseRelation<Obj.Any, Obj.Any> {}\n\n// TODO(dmaretskyi): Has to be `unique symbol`.\nexport const Source: unique symbol = EchoSchema.RelationSourceId as any;\nexport type Source = typeof Source;\nexport const Target: unique symbol = EchoSchema.RelationTargetId as any;\nexport type Target = typeof Target;\n\ntype MakeProps<T extends Any> = {\n id?: EchoSchema.ObjectId;\n [Source]: T[Source];\n [Target]: T[Target];\n} & Type.Properties<T>;\n\n/**\n * Creates new relation.\n * @param schema - Relation schema.\n * @param props - Relation properties. Endpoints are passed as [Relation.Source] and [Relation.Target] keys.\n * @param meta - Relation metadata.\n * @returns\n */\n// NOTE: Writing the definition this way (with generic over schema) makes typescript perfer to infer the type from the first param (this schema) rather than the second param (the props).\n// TODO(dmaretskyi): Move meta into props.\nexport const make = <S extends Type.Relation.Any>(\n schema: S,\n props: NoInfer<MakeProps<Schema.Schema.Type<S>>>,\n meta?: EchoSchema.ObjectMeta,\n): Live<Schema.Schema.Type<S> & Type.OfKind<EchoSchema.EntityKind.Relation>> => {\n assertArgument(\n EchoSchema.getTypeAnnotation(schema)?.kind === EchoSchema.EntityKind.Relation,\n 'schema',\n 'Expected a relation schema',\n );\n\n if (props[EchoSchema.MetaId] != null) {\n meta = props[EchoSchema.MetaId] as any;\n delete props[EchoSchema.MetaId];\n }\n\n const sourceDXN = EchoSchema.getObjectDXN(props[Source]) ?? raise(new Error('Unresolved relation source'));\n const targetDXN = EchoSchema.getObjectDXN(props[Target]) ?? raise(new Error('Unresolved relation target'));\n (props as any)[EchoSchema.RelationSourceDXNId] = sourceDXN;\n (props as any)[EchoSchema.RelationTargetDXNId] = targetDXN;\n\n return live<Schema.Schema.Type<S>>(schema, props as any, meta);\n};\n\nexport const isRelation = (value: unknown): value is Any => {\n if (typeof value !== 'object' || value === null) {\n return false;\n }\n if (EchoSchema.ATTR_RELATION_SOURCE in value || EchoSchema.ATTR_RELATION_TARGET in value) {\n return true;\n }\n\n const kind = (value as any)[EchoSchema.EntityKindId];\n return kind === EchoSchema.EntityKind.Relation;\n};\n\n/**\n * @returns Relation source DXN.\n * @throws If the object is not a relation.\n */\nexport const getSourceDXN = (value: Any): DXN => {\n assertArgument(isRelation(value), 'Expected a relation');\n assumeType<EchoSchema.InternalObjectProps>(value);\n const dxn = (value as EchoSchema.InternalObjectProps)[EchoSchema.RelationSourceDXNId];\n invariant(dxn instanceof DXN);\n return dxn;\n};\n\n/**\n * @returns Relation target DXN.\n * @throws If the object is not a relation.\n */\nexport const getTargetDXN = (value: Any): DXN => {\n assertArgument(isRelation(value), 'Expected a relation');\n assumeType<EchoSchema.InternalObjectProps>(value);\n const dxn = (value as EchoSchema.InternalObjectProps)[EchoSchema.RelationTargetDXNId];\n invariant(dxn instanceof DXN);\n return dxn;\n};\n\n/**\n * @returns Relation source.\n * @throws If the object is not a relation.\n */\nexport const getSource = <T extends Any>(relation: T): Type.Relation.Source<T> => {\n assertArgument(isRelation(relation), 'Expected a relation');\n assumeType<EchoSchema.InternalObjectProps>(relation);\n const obj = (relation as EchoSchema.InternalObjectProps)[EchoSchema.RelationSourceId];\n invariant(obj !== undefined, `Invalid source: ${relation.id}`);\n return obj as Type.Relation.Source<T>;\n};\n\n/**\n * @returns Relation target.\n * @throws If the object is not a relation.\n */\nexport const getTarget = <T extends Any>(relation: T): Type.Relation.Target<T> => {\n assertArgument(isRelation(relation), 'Expected a relation');\n assumeType<EchoSchema.InternalObjectProps>(relation);\n const obj = (relation as EchoSchema.InternalObjectProps)[EchoSchema.RelationTargetId];\n invariant(obj !== undefined, `Invalid target: ${relation.id}`);\n return obj as Type.Relation.Target<T>;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Schema } from 'effect';\nimport { type Simplify } from 'effect/Schema';\n\nimport { type EncodedReference } from '@dxos/echo-protocol';\nimport * as EchoSchema from '@dxos/echo-schema';\nimport { type ToMutable } from '@dxos/echo-schema';\nimport { invariant } from '@dxos/invariant';\nimport type * as Keys from '@dxos/keys';\n\nimport type * as RelationModule from './Relation';\n\n//\n// Kind\n//\n\nexport const KindId: unique symbol = EchoSchema.EntityKindId as any;\nexport type KindId = typeof KindId;\n\nexport const Kind = EchoSchema.EntityKind;\n\n/**\n * Assigns a kind to an Object or Relation instance.\n */\n// NOTE: Needed to make `isRelation` and `isObject` checks work.\nexport interface OfKind<Kind extends EchoSchema.EntityKind> {\n readonly id: Keys.ObjectId;\n readonly [KindId]: Kind;\n}\n\n/**\n * Base ECHO schema type.\n */\nexport type Schema = EchoSchema.EchoSchema;\n\n/**\n * Returns all properties of an object or relation except for the id and kind.\n */\nexport type Properties<T = any> = Omit<T, 'id' | KindId | RelationModule.Source | RelationModule.Target>;\n\n//\n// Obj\n//\n\ninterface ObjJsonProps {\n id: string;\n}\n\n/**\n * Return type of the `Obj` schema constructor.\n *\n * This typedef avoids `TS4023` error (name from external module cannot be used named).\n * See Effect's note on interface types.\n */\nexport interface obj<Self extends Schema.Schema.Any>\n extends EchoSchema.TypeMeta,\n Schema.AnnotableClass<\n obj<Self>,\n OfKind<EchoSchema.EntityKind.Object> & ToMutable<Schema.Schema.Type<Self>>,\n Simplify<ObjJsonProps & ToMutable<Schema.Schema.Encoded<Self>>>,\n Schema.Schema.Context<Self>\n > {}\n\n/**\n * Object schema.\n */\nexport const Obj: {\n (opts: EchoSchema.TypeMeta): <Self extends Schema.Schema.Any>(self: Self) => obj<Self>;\n} = EchoSchema.EchoObject as any;\n\n/**\n * Object schema type definitions.\n */\nexport namespace Obj {\n /**\n * Type that represents an arbitrary schema type of an object.\n * NOTE: This is not an instance type.\n */\n // TODO(dmaretskyi): If schema was covariant, we could specify props in here, like `id: ObjectId`.\n // TODO(burdon): This erases the ECHO type info (e.g., id, typename).\n export type Any = Schema.Schema.AnyNoContext;\n}\n\n//\n// Expando\n//\n\n// TODO(burdon): We're using Expando in many places as a base type.\nexport interface Expando extends OfKind<EchoSchema.EntityKind.Object> {\n [key: string]: any;\n}\n\ntype ExpandoEncoded = Simplify<ObjJsonProps & { [key: string]: any }>;\n\nexport const Expando: Schema.Schema<Expando, ExpandoEncoded, never> = EchoSchema.Expando as any;\n\n//\n// Relation\n//\n\ninterface RelationJsonProps {\n id: string;\n [EchoSchema.ATTR_RELATION_SOURCE]: string;\n [EchoSchema.ATTR_RELATION_TARGET]: string;\n}\n\n/**\n * Return type of the `Relation` schema constructor.\n *\n * This typedef avoids `TS4023` error (name from external module cannot be used named).\n * See Effect's note on interface types.\n */\nexport interface relation<\n Self extends Schema.Schema.Any,\n SourceSchema extends Schema.Schema.Any,\n TargetSchema extends Schema.Schema.Any,\n> extends EchoSchema.TypeMeta,\n Schema.AnnotableClass<\n relation<Self, SourceSchema, TargetSchema>,\n OfKind<EchoSchema.EntityKind.Relation> &\n Relation.Endpoints<Schema.Schema.Type<SourceSchema>, Schema.Schema.Type<TargetSchema>> &\n ToMutable<Schema.Schema.Type<Self>>,\n Simplify<RelationJsonProps & ToMutable<Schema.Schema.Encoded<Self>>>,\n Schema.Schema.Context<Self>\n > {}\n\n/**\n * Relation schema.\n */\n// TODO(dmaretskyi): I have to redefine the type here so that the definition uses symbols from @dxos/echo/Relation.\nexport const Relation: {\n <Source extends Schema.Schema.AnyNoContext, Target extends Schema.Schema.AnyNoContext>(\n opts: EchoSchema.EchoRelationOptions<Source, Target>,\n ): <Self extends Schema.Schema.Any>(self: Self) => relation<Self, Source, Target>;\n} = EchoSchema.EchoRelation as any;\n\n/**\n * Relation schema type definitions.\n */\nexport namespace Relation {\n /**\n * Type that represents an arbitrary schema type of a relation.\n * NOTE: This is not an instance type.\n */\n // TODO(dmaretskyi): If schema was covariant, we could specify props in here, like `id: ObjectId`.\n export type Any = Schema.Schema.AnyNoContext;\n\n /**\n * Get relation source type.\n */\n export type Source<A> = A extends Relation.Endpoints<infer S, infer _T> ? S : never;\n\n /**\n * Get relation target type.\n */\n export type Target<A> = A extends Relation.Endpoints<infer _S, infer T> ? T : never;\n\n export type Endpoints<Source, Target> = {\n [RelationModule.Source]: Source;\n [RelationModule.Target]: Target;\n };\n}\n\n//\n// Ref\n//\n\n/**\n * Return type of the `Ref` schema constructor.\n *\n * This typedef avoids `TS4023` error (name from external module cannot be used named).\n * See Effect's note on interface types.\n */\nexport interface ref<TargetSchema extends Schema.Schema.Any>\n extends EchoSchema.Ref$<Schema.Schema.Type<TargetSchema>> {}\n\n/**\n * Ref schema.\n */\nexport const Ref: <S extends Obj.Any>(schema: S) => ref<S> = EchoSchema.Ref;\n\nexport interface Ref<T> extends Schema.SchemaClass<EchoSchema.Ref<T>, EncodedReference> {}\n\n// TODO(buurdon): Move to Ref?\nexport namespace Ref {\n /**\n * Type that represents an arbitrary schema type of a reference.\n * NOTE: This is not an instance type.\n */\n export type Any = Schema.Schema<EchoSchema.Ref<any>, EncodedReference>;\n}\n\n/**\n * Gets the full DXN of the schema.\n * Will include the version if it's a `type` DXN.\n * @example \"dxn:example.com/type/Person:0.1.0\"\n * @example \"dxn:echo:SSSSSSSSSS:XXXXXXXXXXXXX\"\n */\nexport const getDXN = (schema: Obj.Any | Relation.Any): Keys.DXN | undefined => {\n return EchoSchema.getSchemaDXN(schema);\n};\n\n/**\n * @param schema - Schema to get the typename from.\n * @returns The typename of the schema. Example: `example.com/type/Person`.\n */\nexport const getTypename = (schema: Obj.Any | Relation.Any): string => {\n const typename = EchoSchema.getSchemaTypename(schema);\n invariant(typeof typename === 'string' && !typename.startsWith('dxn:'), 'Invalid typename');\n return typename;\n};\n\n/**\n * Gets the version of the schema.\n * @example 0.1.0\n */\nexport const getVersion = (schema: Obj.Any | Relation.Any): string => {\n const version = EchoSchema.getSchemaVersion(schema);\n invariant(typeof version === 'string' && version.match(/^\\d+\\.\\d+\\.\\d+$/), 'Invalid version');\n return version;\n};\n\n/**\n * @returns True if the schema is mutable.\n */\nexport const isMutable = EchoSchema.isMutable;\n\n/**\n * ECHO type metadata.\n */\nexport type Meta = EchoSchema.TypeAnnotation;\n\n/**\n * Gets the meta data of the schema.\n */\nexport const getMeta = (schema: Obj.Any | Relation.Any): Meta | undefined => {\n return EchoSchema.getTypeAnnotation(schema);\n};\n\n// TODO(dmaretskyi): Remove re-exports.\nexport { SpaceId, ObjectId, DXN } from '@dxos/keys';\n\nexport { Format, JsonSchemaType as JsonSchema, toEffectSchema, toJsonSchema } from '@dxos/echo-schema';\n", "//\n// Copyright 2025 DXOS.org\n//\n\nexport * as Key from './Key';\nexport * as Obj from './Obj';\nexport * as Ref from './Ref';\nexport * as Relation from './Relation';\nexport * as Type from './Type';\n\nexport { DXN } from '@dxos/keys';\nexport { Filter, Order, Query } from './query';\nexport { QueryAST } from '@dxos/echo-protocol';\nexport { type Live } from '@dxos/live-object';\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\nimport type { NonEmptyArray } from 'effect/Array';\nimport type { Simplify } from 'effect/Schema';\n\nimport { raise } from '@dxos/debug';\nimport { type ForeignKey, type QueryAST } from '@dxos/echo-protocol';\nimport { getTypeReference } from '@dxos/echo-schema';\nimport { assertArgument } from '@dxos/invariant';\nimport { DXN, ObjectId } from '@dxos/keys';\n\nimport * as Ref from '../Ref';\nimport type * as Type from '../Type';\n\n// TODO(dmaretskyi): Split up into interfaces for objects and relations so they can have separate verbs.\n// TODO(dmaretskyi): Undirected relation traversals.\n\nexport interface Order<T> {\n // TODO(dmaretskyi): See new effect-schema approach to variance.\n '~Order': { value: T };\n\n ast: QueryAST.Order;\n}\n\nclass OrderClass implements Order<any> {\n private static variance: Order<any>['~Order'] = {} as Order<any>['~Order'];\n\n static is(value: unknown): value is Order<any> {\n return typeof value === 'object' && value !== null && '~Order' in value;\n }\n\n constructor(public readonly ast: QueryAST.Order) {}\n\n '~Order' = OrderClass.variance;\n}\n\nexport namespace Order {\n export const natural: Order<any> = new OrderClass({ kind: 'natural' });\n export const property = <T>(property: keyof T & string, direction: QueryAST.OrderDirection): Order<T> =>\n new OrderClass({\n kind: 'property',\n property,\n direction,\n });\n}\n\nexport interface Query<T> {\n // TODO(dmaretskyi): See new effect-schema approach to variance.\n '~Query': { value: T };\n\n ast: QueryAST.Query;\n\n /**\n * Filter the current selection based on a filter.\n * @param filter - Filter to select the objects.\n * @returns Query for the selected objects.\n */\n select(filter: Filter<T>): Query<T>;\n select(props: Filter.Props<T>): Query<T>;\n\n /**\n * Traverse an outgoing reference.\n * @param key - Property path inside T that is a reference.\n * @returns Query for the target of the reference.\n */\n reference<K extends RefPropKey<T>>(key: K): Query<T[K] extends Ref.Any ? Ref.Target<T[K]> : never>;\n\n /**\n * Find objects referencing this object.\n * @param target - Schema of the referencing object.\n * @param key - Property path inside the referencing object that is a reference.\n * @returns Query for the referencing objects.\n */\n // TODO(dmaretskyi): any way to enforce `Ref.Target<Schema.Schema.Type<S>[key]> == T`?\n // TODO(dmaretskyi): Ability to go through arrays of references.\n referencedBy<S extends Schema.Schema.All>(\n target: S,\n key: RefPropKey<Schema.Schema.Type<S>>,\n ): Query<Schema.Schema.Type<S>>;\n\n /**\n * Find relations where this object is the source.\n * @returns Query for the relation objects.\n * @param relation - Schema of the relation.\n * @param predicates - Predicates to filter the relation objects.\n */\n sourceOf<S extends Schema.Schema.All>(\n relation: S,\n predicates?: Filter.Props<Schema.Schema.Type<S>>,\n ): Query<Schema.Schema.Type<S>>;\n\n /**\n * Find relations where this object is the target.\n * @returns Query for the relation objects.\n * @param relation - Schema of the relation.\n * @param predicates - Predicates to filter the relation objects.\n */\n targetOf<S extends Schema.Schema.All>(\n relation: S,\n predicates?: Filter.Props<Schema.Schema.Type<S>>,\n ): Query<Schema.Schema.Type<S>>;\n\n /**\n * For a query for relations, get the source objects.\n * @returns Query for the source objects.\n */\n source(): Query<Type.Relation.Source<T>>;\n\n /**\n * For a query for relations, get the target objects.\n * @returns Query for the target objects.\n */\n target(): Query<Type.Relation.Target<T>>;\n\n /**\n * Order the query results.\n * Orders are specified in priority order. The first order will be applied first, etc.\n * @param order - Order to sort the results.\n * @returns Query for the ordered results.\n */\n orderBy(...order: NonEmptyArray<Order<T>>): Query<T>;\n\n /**\n * Add options to a query.\n */\n options(options: QueryAST.QueryOptions): Query<T>;\n}\n\ninterface QueryAPI {\n is(value: unknown): value is Query.Any;\n\n /** Construct a query from an ast. */\n fromAst(ast: QueryAST.Query): Query<any>;\n\n /**\n * Select objects based on a filter.\n * @param filter - Filter to select the objects.\n * @returns Query for the selected objects.\n */\n select<F extends Filter.Any>(filter: F): Query<Filter.Type<F>>;\n\n /**\n * Query for objects of a given schema.\n * @param schema - Schema of the objects.\n * @param predicates - Predicates to filter the objects.\n * @returns Query for the objects.\n *\n * Shorthand for: `Query.select(Filter.type(schema, predicates))`.\n */\n type<S extends Schema.Schema.All>(\n schema: S,\n predicates?: Filter.Props<Schema.Schema.Type<S>>,\n ): Query<Schema.Schema.Type<S>>;\n\n /**\n * Combine results of multiple queries.\n * @param queries - Queries to combine.\n * @returns Query for the combined results.\n */\n // TODO(dmaretskyi): Rename to `combine` or `union`.\n all<T>(...queries: Query<T>[]): Query<T>;\n\n /**\n * Subtract one query from another.\n * @param source - Query to subtract from.\n * @param exclude - Query to subtract.\n * @returns Query for the results of the source query minus the results of the exclude query.\n */\n without<T>(source: Query<T>, exclude: Query<T>): Query<T>;\n}\n\nexport declare namespace Query {\n export type Any = Query<any>;\n\n export type Type<Q extends Any> = Q extends Query<infer T> ? T : never;\n\n export type TextSearchOptions = {\n // TODO(dmaretskyi): Hybrid search.\n type?: 'full-text' | 'vector';\n };\n}\n\nexport interface Filter<T> {\n // TODO(dmaretskyi): See new effect-schema approach to variance.\n '~Filter': { value: T };\n\n ast: QueryAST.Filter;\n}\n\ntype Intersection<Types extends readonly unknown[]> = Types extends [infer First, ...infer Rest]\n ? First & Intersection<Rest>\n : unknown;\n\ninterface FilterAPI {\n is(value: unknown): value is Filter<any>;\n\n /**\n * Filter that matches all objects.\n */\n everything(): Filter<any>;\n\n /**\n * Filter that matches no objects.\n */\n nothing(): Filter<any>;\n\n /**\n * Filter by object IDs.\n */\n // TODO(dmaretskyi): Rename to `Filter.id`.\n ids(...id: ObjectId[]): Filter<any>;\n\n /**\n * Filter by type.\n */\n type<S extends Schema.Schema.All>(\n schema: S,\n props?: Filter.Props<Schema.Schema.Type<S>>,\n ): Filter<Schema.Schema.Type<S>>;\n\n /**\n * Filter by non-qualified typename.\n */\n typename(typename: string): Filter<any>;\n\n /**\n * Filter by fully qualified type DXN.\n */\n typeDXN(dxn: DXN): Filter<any>;\n\n /**\n * Filter by properties.\n *\n * INTERNAL API: Do not use.\n */\n _props<T>(props: Filter.Props<T>): Filter<T>;\n\n /**\n * Full-text or vector search.\n */\n text(\n // TODO(dmaretskyi): Consider passing a vector here, but really the embedding should be done on the query-executor side.\n text: string,\n options?: Query.TextSearchOptions,\n ): Filter<any>;\n\n /**\n * Filter by foreign keys.\n */\n foreignKeys<S extends Schema.Schema.All>(schema: S, keys: ForeignKey[]): Filter<Schema.Schema.Type<S>>;\n\n /**\n * Predicate for property to be equal to the provided value.\n */\n eq<T>(value: T): Filter<T>;\n\n /**\n * Predicate for property to be not equal to the provided value.\n */\n neq<T>(value: T): Filter<T>;\n\n /**\n * Predicate for property to be greater than the provided value.\n */\n gt<T>(value: T): Filter<T>;\n\n /**\n * Predicate for property to be greater than the provided value.\n */\n gt<T>(value: T): Filter<T>;\n\n /**\n * Predicate for property to be greater than or equal to the provided value.\n */\n gte<T>(value: T): Filter<T>;\n\n /**\n * Predicate for property to be less than the provided value.\n */\n lt<T>(value: T): Filter<T>;\n\n /**\n * Predicate for property to be less than or equal to the provided value.\n */\n lte<T>(value: T): Filter<T>;\n\n /**\n * Predicate for property to be in the provided array.\n * @param values - Values to check against.\n */\n in<T>(...values: T[]): Filter<T>;\n\n /**\n * Predicate for property to be in the provided range.\n * @param from - Start of the range (inclusive).\n * @param to - End of the range (exclusive).\n */\n between<T>(from: T, to: T): Filter<T>;\n\n /**\n * Negate the filter.\n */\n not<F extends Filter.Any>(filter: F): Filter<Filter.Type<F>>;\n\n /**\n * Combine filters with a logical AND.\n */\n and<FS extends Filter.Any[]>(...filters: FS): Filter<Filter.And<FS>>;\n\n /**\n * Combine filters with a logical OR.\n */\n or<FS extends Filter.Any[]>(...filters: FS): Filter<Filter.Or<FS>>;\n\n // TODO(dmaretskyi): Add `Filter.match` to support pattern matching on string props.\n}\n\nexport declare namespace Filter {\n type Props<T> = {\n // Predicate or a value as a shorthand for `eq`.\n [K in keyof T & string]?: Filter<T[K]> | T[K];\n };\n\n type Any = Filter<any>;\n\n type Type<F extends Any> = F extends Filter<infer T> ? T : never;\n\n type And<FS extends readonly Any[]> = Simplify<Intersection<{ [K in keyof FS]: Type<FS[K]> }>>;\n\n type Or<FS extends readonly Any[]> = Simplify<{ [K in keyof FS]: Type<FS[K]> }[number]>;\n}\n\nclass FilterClass implements Filter<any> {\n private static variance: Filter<any>['~Filter'] = {} as Filter<any>['~Filter'];\n\n static is(value: unknown): value is Filter<any> {\n return typeof value === 'object' && value !== null && '~Filter' in value;\n }\n\n static everything(): FilterClass {\n return new FilterClass({\n type: 'object',\n typename: null,\n props: {},\n });\n }\n\n static nothing(): FilterClass {\n return new FilterClass({\n type: 'not',\n filter: {\n type: 'object',\n typename: null,\n props: {},\n },\n });\n }\n\n static relation() {\n return new FilterClass({\n type: 'object',\n typename: null,\n props: {},\n });\n }\n\n static ids(...ids: ObjectId[]): Filter<any> {\n assertArgument(\n ids.every((id) => ObjectId.isValid(id)),\n 'ids',\n 'ids must be valid',\n );\n\n if (ids.length === 0) {\n return Filter.nothing();\n }\n\n return new FilterClass({\n type: 'object',\n typename: null,\n id: ids,\n props: {},\n });\n }\n\n static type<S extends Schema.Schema.All>(\n schema: S,\n props?: Filter.Props<Schema.Schema.Type<S>>,\n ): Filter<Schema.Schema.Type<S>> {\n const dxn = getTypeReference(schema)?.toDXN() ?? raise(new TypeError('Schema has no DXN'));\n return new FilterClass({\n type: 'object',\n typename: dxn.toString(),\n ...propsFilterToAst(props ?? {}),\n });\n }\n\n static typename(typename: string): Filter<any> {\n assertArgument(!typename.startsWith('dxn:'), 'typename', 'Typename must no be qualified');\n return new FilterClass({\n type: 'object',\n typename: DXN.fromTypename(typename).toString(),\n props: {},\n });\n }\n\n static typeDXN(dxn: DXN): Filter<any> {\n return new FilterClass({\n type: 'object',\n typename: dxn.toString(),\n props: {},\n });\n }\n\n /**\n * @internal\n */\n static _props<T>(props: Filter.Props<T>): Filter<T> {\n return new FilterClass({\n type: 'object',\n typename: null,\n ...propsFilterToAst(props),\n });\n }\n\n static text(text: string, options?: Query.TextSearchOptions): Filter<any> {\n return new FilterClass({\n type: 'text-search',\n text,\n searchKind: options?.type,\n });\n }\n\n static foreignKeys<S extends Schema.Schema.All>(schema: S, keys: ForeignKey[]): Filter<Schema.Schema.Type<S>> {\n const dxn = getTypeReference(schema)?.toDXN() ?? raise(new TypeError('Schema has no DXN'));\n return new FilterClass({\n type: 'object',\n typename: dxn.toString(),\n props: {},\n foreignKeys: keys,\n });\n }\n\n static eq<T>(value: T): Filter<T> {\n if (!Ref.isRef(value) && typeof value === 'object' && value !== null) {\n throw new TypeError('Cannot use object as a value for eq filter');\n }\n\n return new FilterClass({\n type: 'compare',\n operator: 'eq',\n value: Ref.isRef(value) ? value.noInline().encode() : value,\n });\n }\n\n static neq<T>(value: T): Filter<T> {\n return new FilterClass({\n type: 'compare',\n operator: 'neq',\n value,\n });\n }\n\n static gt<T>(value: T): Filter<T> {\n return new FilterClass({\n type: 'compare',\n operator: 'gt',\n value,\n });\n }\n\n static gte<T>(value: T): Filter<T> {\n return new FilterClass({\n type: 'compare',\n operator: 'gte',\n value,\n });\n }\n\n static lt<T>(value: T): Filter<T> {\n return new FilterClass({\n type: 'compare',\n operator: 'lt',\n value,\n });\n }\n\n static lte<T>(value: T): Filter<T> {\n return new FilterClass({\n type: 'compare',\n operator: 'lte',\n value,\n });\n }\n\n static in<T>(...values: T[]): Filter<T> {\n return new FilterClass({\n type: 'in',\n values,\n });\n }\n\n static between<T>(from: T, to: T): Filter<T> {\n return new FilterClass({\n type: 'range',\n from,\n to,\n });\n }\n\n static not<F extends Filter.Any>(filter: F): Filter<Filter.Type<F>> {\n return new FilterClass({\n type: 'not',\n filter: filter.ast,\n });\n }\n\n static and<T>(...filters: Filter<T>[]): Filter<T> {\n return new FilterClass({\n type: 'and',\n filters: filters.map((f) => f.ast),\n });\n }\n\n static or<T>(...filters: Filter<T>[]): Filter<T> {\n return new FilterClass({\n type: 'or',\n filters: filters.map((f) => f.ast),\n });\n }\n\n private constructor(public readonly ast: QueryAST.Filter) {}\n\n '~Filter' = FilterClass.variance;\n}\n\nexport const Filter: FilterAPI = FilterClass;\n\n/**\n * All property paths inside T that are references.\n */\n// TODO(dmaretskyi): Filter only properties that are references (or optional references, or unions that include references).\ntype RefPropKey<T> = keyof T & string;\n\nconst propsFilterToAst = (predicates: Filter.Props<any>): Pick<QueryAST.FilterObject, 'id' | 'props'> => {\n let idFilter: readonly ObjectId[] | undefined;\n if ('id' in predicates) {\n assertArgument(\n typeof predicates.id === 'string' || Array.isArray(predicates.id),\n 'predicates.id',\n 'invalid id filter',\n );\n idFilter = typeof predicates.id === 'string' ? [predicates.id] : predicates.id;\n Schema.Array(ObjectId).pipe(Schema.validateSync)(idFilter);\n }\n\n return {\n id: idFilter,\n props: Object.fromEntries(\n Object.entries(predicates)\n .filter(([prop, _value]) => prop !== 'id')\n .map(([prop, predicate]) => [prop, Filter.is(predicate) ? predicate.ast : Filter.eq(predicate).ast]),\n ) as Record<string, QueryAST.Filter>,\n };\n};\n\nclass QueryClass implements Query<any> {\n private static variance: Query<any>['~Query'] = {} as Query<any>['~Query'];\n\n static is(value: unknown): value is Query<any> {\n return typeof value === 'object' && value !== null && '~Query' in value;\n }\n\n static fromAst(ast: QueryAST.Query): Query<any> {\n return new QueryClass(ast);\n }\n\n static select<F extends Filter.Any>(filter: F): Query<Filter.Type<F>> {\n return new QueryClass({\n type: 'select',\n filter: filter.ast,\n });\n }\n\n static type(schema: Schema.Schema.All, predicates?: Filter.Props<unknown>): Query<any> {\n return new QueryClass({\n type: 'select',\n filter: FilterClass.type(schema, predicates).ast,\n });\n }\n\n static all(...queries: Query<any>[]): Query<any> {\n if (queries.length === 0) {\n throw new TypeError(\n 'Query.all combines results of multiple queries, to query all objects use Query.select(Filter.everything())',\n );\n }\n return new QueryClass({\n type: 'union',\n queries: queries.map((q) => q.ast),\n });\n }\n\n static without<T>(source: Query<T>, exclude: Query<T>): Query<T> {\n return new QueryClass({\n type: 'set-difference',\n source: source.ast,\n exclude: exclude.ast,\n });\n }\n\n constructor(public readonly ast: QueryAST.Query) {}\n\n '~Query' = QueryClass.variance;\n\n select(filter: Filter<any> | Filter.Props<any>): Query<any> {\n if (Filter.is(filter)) {\n return new QueryClass({\n type: 'filter',\n selection: this.ast,\n filter: filter.ast,\n });\n } else {\n return new QueryClass({\n type: 'filter',\n selection: this.ast,\n filter: FilterClass._props(filter).ast,\n });\n }\n }\n\n reference(key: string): Query<any> {\n return new QueryClass({\n type: 'reference-traversal',\n anchor: this.ast,\n property: key,\n });\n }\n\n referencedBy(target: Schema.Schema.All, key: string): Query<any> {\n const dxn = getTypeReference(target)?.toDXN() ?? raise(new TypeError('Target schema has no DXN'));\n return new QueryClass({\n type: 'incoming-references',\n anchor: this.ast,\n property: key,\n typename: dxn.toString(),\n });\n }\n\n sourceOf(relation: Schema.Schema.All, predicates?: Filter.Props<unknown> | undefined): Query<any> {\n return new QueryClass({\n type: 'relation',\n anchor: this.ast,\n direction: 'outgoing',\n filter: FilterClass.type(relation, predicates).ast,\n });\n }\n\n targetOf(relation: Schema.Schema.All, predicates?: Filter.Props<unknown> | undefined): Query<any> {\n return new QueryClass({\n type: 'relation',\n anchor: this.ast,\n direction: 'incoming',\n filter: FilterClass.type(relation, predicates).ast,\n });\n }\n\n source(): Query<any> {\n return new QueryClass({\n type: 'relation-traversal',\n anchor: this.ast,\n direction: 'source',\n });\n }\n\n target(): Query<any> {\n return new QueryClass({\n type: 'relation-traversal',\n anchor: this.ast,\n direction: 'target',\n });\n }\n\n orderBy(...order: Order<any>[]): Query<any> {\n return new QueryClass({\n type: 'order',\n query: this.ast,\n order: order.map((o) => o.ast),\n });\n }\n\n options(options: QueryAST.QueryOptions): Query<any> {\n return new QueryClass({\n type: 'options',\n query: this.ast,\n options,\n });\n }\n}\n\nexport const Query: QueryAPI = QueryClass;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["SpaceId", "ObjectId", "VersionTypeId", "getLabel", "getMeta", "getSchema", "getSnapshot", "isDeleted", "setLabel", "Schema", "dual", "EchoSchema", "assertArgument", "invariant", "LiveObject", "live", "assumeType", "deepMapValues", "Meta", "MetaId", "make", "schema", "props", "meta", "getTypeAnnotation", "kind", "EntityKind", "Object", "isObject", "obj", "EntityKindId", "instanceOf", "args", "length", "isInstanceOf", "getDXN", "isSchema", "dxn", "getObjectDXN", "getTypeDXN", "getType", "getTypename", "asTypeDXN", "type", "getSchemaTypename", "getKeys", "source", "keys", "filter", "key", "deleteKeys", "i", "splice", "deleted", "label", "toJSON", "objectToJSON", "fromJSON", "objectFromJSON", "clone", "opts", "id", "data", "value", "recurse", "Ref", "isRef", "retainId", "unversioned", "versioned", "isVersion", "version", "ObjectVersionId", "undefined", "versionValid", "compareVersions", "version1", "version2", "automergeHeads", "some", "head", "includes", "encodeVersion", "JSON", "stringify", "decodeVersion", "parsed", "parse", "Array", "make", "EchoSchema", "Array", "RefArray", "isRef", "Ref", "make", "fromDXN", "make", "raise", "EchoSchema", "assertArgument", "invariant", "DXN", "live", "assumeType", "Source", "RelationSourceId", "Target", "RelationTargetId", "schema", "props", "meta", "getTypeAnnotation", "kind", "EntityKind", "Relation", "MetaId", "sourceDXN", "getObjectDXN", "Error", "targetDXN", "RelationSourceDXNId", "RelationTargetDXNId", "isRelation", "value", "ATTR_RELATION_SOURCE", "ATTR_RELATION_TARGET", "EntityKindId", "getSourceDXN", "dxn", "getTargetDXN", "getSource", "relation", "obj", "undefined", "id", "getTarget", "DXN", "Expando", "ObjectId", "Ref", "SpaceId", "getDXN", "getMeta", "getTypename", "isMutable", "EchoSchema", "invariant", "Format", "JsonSchema", "toEffectSchema", "toJsonSchema", "KindId", "EntityKindId", "Kind", "EntityKind", "Obj", "EchoObject", "Relation", "EchoRelation", "schema", "getSchemaDXN", "typename", "getSchemaTypename", "startsWith", "getVersion", "version", "getSchemaVersion", "match", "getTypeAnnotation", "DXN", "Schema", "raise", "getTypeReference", "assertArgument", "DXN", "ObjectId", "OrderClass", "is", "value", "ast", "variance", "Order", "natural", "kind", "property", "direction", "FilterClass", "everything", "type", "typename", "props", "nothing", "filter", "relation", "ids", "assertArgument", "every", "id", "ObjectId", "isValid", "length", "Filter", "schema", "dxn", "getTypeReference", "toDXN", "raise", "TypeError", "toString", "propsFilterToAst", "startsWith", "DXN", "fromTypename", "typeDXN", "_props", "text", "options", "searchKind", "foreignKeys", "keys", "eq", "isRef", "operator", "noInline", "encode", "neq", "gt", "gte", "lt", "lte", "in", "values", "between", "from", "to", "not", "and", "filters", "map", "f", "or", "predicates", "idFilter", "Array", "isArray", "Schema", "pipe", "validateSync", "Object", "fromEntries", "entries", "prop", "_value", "predicate", "QueryClass", "fromAst", "select", "all", "queries", "q", "without", "source", "exclude", "selection", "reference", "key", "anchor", "referencedBy", "target", "sourceOf", "targetOf", "orderBy", "order", "query", "o", "Query", "QueryAST"]
|
|
7
|
+
}
|
|
@@ -4,17 +4,21 @@ import {
|
|
|
4
4
|
Filter,
|
|
5
5
|
Key_exports,
|
|
6
6
|
Obj_exports,
|
|
7
|
+
Order,
|
|
7
8
|
Query,
|
|
9
|
+
QueryAST,
|
|
8
10
|
Ref_exports,
|
|
9
11
|
Relation_exports,
|
|
10
12
|
Type_exports
|
|
11
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-MTR3E5S2.mjs";
|
|
12
14
|
export {
|
|
13
15
|
DXN,
|
|
14
16
|
Filter,
|
|
15
17
|
Key_exports as Key,
|
|
16
18
|
Obj_exports as Obj,
|
|
19
|
+
Order,
|
|
17
20
|
Query,
|
|
21
|
+
QueryAST,
|
|
18
22
|
Ref_exports as Ref,
|
|
19
23
|
Relation_exports as Relation,
|
|
20
24
|
Type_exports as Type
|