@dxos/echo 0.8.4-main.c1de068 → 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 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/Self)` | `DXN` | `@self` | string | DXN to the object itself |
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
- toJSON: () => toJSON
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: 96,
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: 124,
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: 131,
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: 98,
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: 110,
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: 122,
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: 134,
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: () => Ref3,
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 Ref3 = EchoSchema4.Ref;
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: 210,
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 version = EchoSchema4.getSchemaVersion(schema);
283
- invariant3(typeof version === "string" && version.match(/^\d+\.\d+\.\d+$/), "Invalid version", {
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: 220,
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 version;
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
- var FilterClass = class _FilterClass {
309
- static {
310
- this.variance = {};
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
- DXN4 as DXN
782
+ Order,
783
+ DXN4 as DXN,
784
+ QueryAST
618
785
  };
619
- //# sourceMappingURL=chunk-EUA7CM23.mjs.map
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": ";;;;;;;;AAAA;;;;;AAIA,SAASA,SAASC,gBAAgB;;;ACJlC;;;uBAAAC;EAAA;;;;;;;;kBAAAC;EAAA,eAAAC;EAAA,iBAAAC;EAAA,mBAAAC;EAAA;;;mBAAAC;EAAA;;;kBAAAC;EAAA;;;;AAIA,SAASC,cAAc;AACvB,SAASC,YAAY;AAErB,YAAYC,gBAAgB;AAC5B,SAASC,gBAAgBC,iBAAiB;AAE1C,YAAYC,gBAAgB;AAC5B,SAASC,YAAY;AACrB,SAASC,YAAYC,qBAAqB;;AA2BnC,IAAMC,OAAiCC;AAiBvC,IAAMC,OAAO,CAClBC,QACAC,OACAC,SAAAA;AAEAX,iBACaY,6BAAkBH,MAAAA,GAASI,SAAoBC,sBAAWC,QACrE,UACA,2BAAA;AAGF,MAAIL,MAAiBH,iBAAM,KAAK,MAAM;AACpCI,WAAOD,MAAiBH,iBAAM;AAC9B,WAAOG,MAAiBH,iBAAM;EAChC;AAEA,SAAOJ,KAA4BM,QAAQC,OAAcC,IAAAA;AAC3D;AAEO,IAAMK,WAAW,CAACC,QAAAA;AACvBb,aAA2Ca,GAAAA;AAC3C,SAAO,OAAOA,QAAQ,YAAYA,QAAQ,QAAQA,IAAeC,uBAAY,MAAiBJ,sBAAWC;AAC3G;AAeO,IAAMI,aAGR,IACAC,SAAAA;AAEH,MAAIA,KAAKC,WAAW,GAAG;AACrB,WAAO,CAACJ,QAA4BK,wBAAaF,KAAK,CAAA,GAAIH,GAAAA;EAC5D;AAEA,SAAkBK,wBAAaF,KAAK,CAAA,GAAIA,KAAK,CAAA,CAAE;AACjD;AAEO,IAAM3B,aAAuBA;AAG7B,IAAM8B,SAAS,CAACN,QAAAA;AACrBjB,iBAAe,CAACH,OAAO2B,SAASP,GAAAA,GAAM,OAAO,gCAAA;AAC7C,QAAMQ,MAAiBC,wBAAaT,GAAAA;AACpChB,YAAUwB,OAAO,MAAM,mBAAA;;;;;;;;;AACvB,SAAOA;AACT;AAOO,IAAME,aAAwBC;AAM9B,IAAMC,cAAc,CAACZ,QAAAA;AAC1B,QAAMR,SAAShB,WAAUwB,GAAAA;AACzB,MAAIR,UAAU,MAAM;AAElB,WAAkBmB,mBAAQX,GAAAA,GAAMa,UAAAA,GAAaC;EAC/C;AAEA,SAAkBC,6BAAkBvB,MAAAA;AACtC;AAGO,IAAMjB,WAAU,CAACyB,QAAAA;AACtB,QAAMN,OAAkBnB,mBAAQyB,GAAAA;AAChChB,YAAUU,QAAQ,MAAM,mBAAA;;;;;;;;;AACxB,SAAOA;AACT;AAKO,IAAMsB,UAGTnC,KAAK,GAAG,CAACmB,KAAyBiB,WAAAA;AACpC,QAAMvB,OAAkBnB,mBAAQyB,GAAAA;AAChChB,YAAUU,QAAQ,MAAM,mBAAA;;;;;;;;;AACxB,SAAOA,KAAKwB,KAAKC,OAAO,CAACC,QAAQA,IAAIH,WAAWA,MAAAA;AAClD,CAAA;AAOO,IAAMI,aAAa,CAACrB,KAAyBiB,WAAAA;AAClD,QAAMvB,OAAkBnB,mBAAQyB,GAAAA;AAChC,WAASsB,IAAI,GAAGA,IAAI5B,KAAKwB,KAAKd,QAAQkB,KAAK;AACzC,QAAI5B,KAAKwB,KAAKI,CAAAA,EAAGL,WAAWA,QAAQ;AAClCvB,WAAKwB,KAAKK,OAAOD,GAAG,CAAA;AACpBA;IACF;EACF;AACF;AAGO,IAAM5C,aAAY,CAACsB,QAAAA;AACxB,QAAMwB,UAAqB9C,qBAAUsB,GAAAA;AACrChB,YAAU,OAAOwC,YAAY,WAAW,mBAAA;;;;;;;;;AACxC,SAAOA;AACT;AAGO,IAAMlD,YAAW,CAAC0B,QAAAA;AACvB,QAAMR,SAAShB,WAAUwB,GAAAA;AACzB,MAAIR,UAAU,MAAM;AAClB,WAAkBlB,oBAASkB,QAAQQ,GAAAA;EACrC;AACF;AAEO,IAAMrB,YAAW,CAACqB,KAAyByB,UAAAA;AAChD,QAAMjC,SAAShB,WAAUwB,GAAAA;AACzB,MAAIR,UAAU,MAAM;AAClBV,IAAWH,oBAASa,QAAQQ,KAAKyB,KAAAA;EACnC;AACF;AAaO,IAAMC,SAAS,CAAC1B,QAA6C2B,wBAAa3B,GAAAA;AAW1E,IAAM4B,WACAC;AAKN,IAAMpD,eAA4DA;AAelE,IAAMqD,QAAQ,CAA+B9B,KAAQ+B,SAAAA;AAC1D,QAAM,EAAEC,IAAI,GAAGC,KAAAA,IAASjC;AACxB,QAAMR,SAAShB,WAAUwB,GAAAA;AACzBhB,YAAUQ,UAAU,MAAM,+BAAA;;;;;;;;;AAC1B,QAAMC,QAAaL,cAAc6C,MAAM,CAACC,OAAOC,YAAAA;AAC7C,QAAeC,eAAIC,MAAMH,KAAAA,GAAQ;AAC/B,aAAOA;IACT;AACA,WAAOC,QAAQD,KAAAA;EACjB,CAAA;AACA,MAAIH,MAAMO,UAAU;AAClB7C,UAAMuC,KAAKA;EACb;AACA,QAAMtC,OAAOnB,SAAQyB,GAAAA;AACrBP,QAAiBH,iBAAM,IAAIF,cAAcM,MAAM,CAACwC,OAAOC,YAAAA;AACrD,QAAeC,eAAIC,MAAMH,KAAAA,GAAQ;AAC/B,aAAOA;IACT;AACA,WAAOC,QAAQD,KAAAA;EACjB,CAAA;AACA,SAAO3C,KAAKC,QAAQC,KAAAA;AACtB;AAEO,IAAMpB,iBAA2BA;AAsBxC,IAAMkE,cAAuB;EAC3B,CAAClE,cAAAA,GAAgB,CAAC;EAClBmE,WAAW;AACb;AAKO,IAAMC,YAAY,CAACzC,QAAAA;AACxB,SAAOA,OAAO,QAAQ,OAAOA,QAAQ,YAAY3B,kBAAiB2B;AACpE;AAKO,IAAM0C,UAAU,CAAC1C,QAAAA;AACtB,QAAM0C,WAAW1C,IAAuB2C,0BAAe;AACvD,MAAID,aAAYE,QAAW;AACzB,WAAOL;EACT;AACA,SAAOG;AACT;AAKO,IAAMG,eAAe,CAACH,aAAAA;AAC3B3D,iBAAe0D,UAAUC,QAAAA,GAAU,WAAW,wBAAA;AAC9C,SAAO,CAAC,CAACA,SAAQF;AACnB;AAUO,IAAMM,kBAAkB,CAACC,UAAmBC,aAAAA;AACjDjE,iBAAe0D,UAAUM,QAAAA,GAAW,YAAY,wBAAA;AAChDhE,iBAAe0D,UAAUO,QAAAA,GAAW,YAAY,wBAAA;AAEhD,MAAI,CAACH,aAAaE,QAAAA,KAAa,CAACF,aAAaG,QAAAA,GAAW;AACtD,WAAO;EACT;AAEA,MAAID,SAASE,gBAAgB7C,WAAW4C,SAASC,gBAAgB7C,QAAQ;AACvE,WAAO;EACT;AACA,MAAI2C,SAASE,gBAAgBC,KAAK,CAACC,SAAS,CAACH,SAASC,gBAAgBG,SAASD,IAAAA,CAAAA,GAAQ;AACrF,WAAO;EACT;AAEA,SAAO;AACT;AAEO,IAAME,gBAAgB,CAACX,aAAAA;AAC5B,SAAOY,KAAKC,UAAUb,QAAAA;AACxB;AAEO,IAAMc,gBAAgB,CAACd,aAAAA;AAC5B,QAAMe,SAASH,KAAKI,MAAMhB,QAAAA;AAC1Be,SAAOpF,cAAAA,IAAiB,CAAC;AACzB,SAAOoF;AACT;;;AC1VA;;eAAAE;EAAA;;cAAAC;;AAIA,YAAYC,iBAAgB;AAOrB,IAAMC,SAAmBC;AAYzB,IAAMC,QAAqDC,gBAAID;AAE/D,IAAME,QAAkBD,gBAAIC;AAG5B,IAAMC,UAAqBF,gBAAIE;;;AC5BtC;;;;;;;;;cAAAC;;AAMA,SAASC,aAAa;AACtB,YAAYC,iBAAgB;AAC5B,SAASC,kBAAAA,iBAAgBC,aAAAA,kBAAiB;AAC1C,SAASC,WAAW;AACpB,SAAoBC,QAAAA,aAAY;AAChC,SAASC,cAAAA,mBAAkB;;AAwBpB,IAAMC,SAAmCC;AAEzC,IAAMC,SAAmCC;AAkBzC,IAAMX,QAAO,CAClBY,QACAC,OACAC,SAAAA;AAEAX,EAAAA,gBACaY,8BAAkBH,MAAAA,GAASI,SAAoBC,uBAAWC,UACrE,UACA,4BAAA;AAGF,MAAIL,MAAiBM,kBAAM,KAAK,MAAM;AACpCL,WAAOD,MAAiBM,kBAAM;AAC9B,WAAON,MAAiBM,kBAAM;EAChC;AAEA,QAAMC,YAAuBC,yBAAaR,MAAML,MAAAA,CAAO,KAAKP,MAAM,IAAIqB,MAAM,4BAAA,CAAA;AAC5E,QAAMC,YAAuBF,yBAAaR,MAAMH,MAAAA,CAAO,KAAKT,MAAM,IAAIqB,MAAM,4BAAA,CAAA;AAC3ET,QAAyBW,+BAAmB,IAAIJ;AAChDP,QAAyBY,+BAAmB,IAAIF;AAEjD,SAAOjB,MAA4BM,QAAQC,OAAcC,IAAAA;AAC3D;AAEO,IAAMY,aAAa,CAACC,UAAAA;AACzB,MAAI,OAAOA,UAAU,YAAYA,UAAU,MAAM;AAC/C,WAAO;EACT;AACA,MAAeC,oCAAwBD,SAAoBE,oCAAwBF,OAAO;AACxF,WAAO;EACT;AAEA,QAAMX,OAAQW,MAAyBG,wBAAY;AACnD,SAAOd,SAAoBC,uBAAWC;AACxC;AAMO,IAAMa,eAAe,CAACJ,UAAAA;AAC3BxB,EAAAA,gBAAeuB,WAAWC,KAAAA,GAAQ,qBAAA;AAClCpB,EAAAA,YAA2CoB,KAAAA;AAC3C,QAAMK,MAAOL,MAAoDH,+BAAmB;AACpFpB,EAAAA,WAAU4B,eAAe3B,KAAAA,QAAAA;;;;;;;;;AACzB,SAAO2B;AACT;AAMO,IAAMC,eAAe,CAACN,UAAAA;AAC3BxB,EAAAA,gBAAeuB,WAAWC,KAAAA,GAAQ,qBAAA;AAClCpB,EAAAA,YAA2CoB,KAAAA;AAC3C,QAAMK,MAAOL,MAAoDF,+BAAmB;AACpFrB,EAAAA,WAAU4B,eAAe3B,KAAAA,QAAAA;;;;;;;;;AACzB,SAAO2B;AACT;AAMO,IAAME,YAAY,CAAgBC,aAAAA;AACvChC,EAAAA,gBAAeuB,WAAWS,QAAAA,GAAW,qBAAA;AACrC5B,EAAAA,YAA2C4B,QAAAA;AAC3C,QAAMC,MAAOD,SAAuD1B,4BAAgB;AACpFL,EAAAA,WAAUgC,QAAQC,QAAW,mBAAmBF,SAASG,EAAE,IAAE;;;;;;;;;AAC7D,SAAOF;AACT;AAMO,IAAMG,YAAY,CAAgBJ,aAAAA;AACvChC,EAAAA,gBAAeuB,WAAWS,QAAAA,GAAW,qBAAA;AACrC5B,EAAAA,YAA2C4B,QAAAA;AAC3C,QAAMC,MAAOD,SAAuDxB,4BAAgB;AACpFP,EAAAA,WAAUgC,QAAQC,QAAW,mBAAmBF,SAASG,EAAE,IAAE;;;;;;;;;AAC7D,SAAOF;AACT;;;ACzIA;;aAAAI;EAAA,eAAAC;EAAA;;;;;kBAAAC;EAAA,WAAAC;EAAA;iBAAAC;EAAA,cAAAC;EAAA,eAAAC;EAAA,mBAAAC;EAAA;mBAAAC;EAAA;;;AAQA,YAAYC,iBAAgB;AAE5B,SAASC,aAAAA,kBAAiB;AAyO1B,SAASN,WAAAA,UAASF,YAAAA,WAAUF,OAAAA,YAAW;AAEvC,SAASW,QAA0BC,gBAAYC,gBAAgBC,oBAAoB;;AAlO5E,IAAMC,SAAmCC;AAGzC,IAAMC,OAAkBC;AA+CxB,IAAMC,MAEEC;AA0BR,IAAMnB,WAAoEA;AAoC1E,IAAMoB,WAIEC;AA6CR,IAAMnB,OAA2DA;AAmBjE,IAAME,UAAS,CAACkB,WAAAA;AACrB,SAAkBC,yBAAaD,MAAAA;AACjC;AAMO,IAAMhB,eAAc,CAACgB,WAAAA;AAC1B,QAAME,WAAsBC,8BAAkBH,MAAAA;AAC9Cb,EAAAA,WAAU,OAAOe,aAAa,YAAY,CAACA,SAASE,WAAW,MAAA,GAAS,oBAAA;;;;;;;;;AACxE,SAAOF;AACT;AAMO,IAAMG,aAAa,CAACL,WAAAA;AACzB,QAAMM,WAAqBC,6BAAiBP,MAAAA;AAC5Cb,EAAAA,WAAU,OAAOmB,aAAY,YAAYA,SAAQE,MAAM,iBAAA,GAAoB,mBAAA;;;;;;;;;AAC3E,SAAOF;AACT;AAKO,IAAMrB,aAAuBA;AAU7B,IAAMF,WAAU,CAACiB,WAAAA;AACtB,SAAkBS,8BAAkBT,MAAAA;AACtC;;;ACtOA,SAASU,OAAAA,YAAW;;;ACNpB,SAASC,UAAAA,eAAc;AAIvB,SAASC,SAAAA,cAAa;AAEtB,SAASC,wBAAwB;AACjC,SAASC,kBAAAA,uBAAsB;AAC/B,SAASC,OAAAA,MAAKC,YAAAA,iBAAgB;A;;;;;;;;;;;;;AAe9B,IAAMC,aAAN,MAAMA,YAAAA;EAGJ,OAAOC,GAAGC,OAAqC;AAC7C,WAAO,OAAOA,UAAU,YAAYA,UAAU,QAAQ,YAAYA;EACpE;EAEA,YAA4BC,KAAqB;;AAEjD,qBAAA,MAAA,UAAA,MAAA;SAF4BA,MAAAA;SAE5B,QAAA,IAAWH,YAAWI;EAF4B;AAGpD;AATE,iBADIJ,YACWI,YAAiC,CAAC,CAAA;UAWlCC,QAAAA;SACFC,UAAsB,IAAIN,WAAW;IAAEO,MAAM;EAAU,CAAA;SACvDC,WAAW,CAAIA,UAA4BC,cACtD,IAAIT,WAAW;IACbO,MAAM;IACNC;IACAC;EACF,CAAA;AACJ,GARiBJ,UAAAA,QAAAA,CAAAA,EAAAA;AAwSjB,IAAMK,cAAN,MAAMA,aAAAA;EAGJ,OAAOT,GAAGC,OAAsC;AAC9C,WAAO,OAAOA,UAAU,YAAYA,UAAU,QAAQ,aAAaA;EACrE;EAEA,OAAOS,aAA0B;AAC/B,WAAO,IAAID,aAAY;MACrBE,MAAM;MACNC,UAAU;MACVC,OAAO,CAAC;IACV,CAAA;EACF;EAEA,OAAOC,UAAuB;AAC5B,WAAO,IAAIL,aAAY;MACrBE,MAAM;MACNI,QAAQ;QACNJ,MAAM;QACNC,UAAU;QACVC,OAAO,CAAC;MACV;IACF,CAAA;EACF;EAEA,OAAOG,WAAW;AAChB,WAAO,IAAIP,aAAY;MACrBE,MAAM;MACNC,UAAU;MACVC,OAAO,CAAC;IACV,CAAA;EACF;EAEA,OAAOI,OAAOA,KAA8B;AAC1CC,IAAAA,gBACED,IAAIE,MAAM,CAACC,OAAOC,UAASC,QAAQF,EAAAA,CAAAA,GACnC,OACA,mBAAA;AAGF,QAAIH,IAAIM,WAAW,GAAG;AACpB,aAAOC,OAAOV,QAAO;IACvB;AAEA,WAAO,IAAIL,aAAY;MACrBE,MAAM;MACNC,UAAU;MACVQ,IAAIH;MACJJ,OAAO,CAAC;IACV,CAAA;EACF;EAEA,OAAOF,KACLc,QACAZ,OAC+B;AAC/B,UAAMa,MAAMC,iBAAiBF,MAAAA,GAASG,MAAAA,KAAWC,OAAM,IAAIC,UAAU,mBAAA,CAAA;AACrE,WAAO,IAAIrB,aAAY;MACrBE,MAAM;MACNC,UAAUc,IAAIK,SAAQ;MACtB,GAAGC,iBAAiBnB,SAAS,CAAC,CAAA;IAChC,CAAA;EACF;EAEA,OAAOD,SAASA,UAA+B;AAC7CM,IAAAA,gBAAe,CAACN,SAASqB,WAAW,MAAA,GAAS,YAAY,+BAAA;AACzD,WAAO,IAAIxB,aAAY;MACrBE,MAAM;MACNC,UAAUsB,KAAIC,aAAavB,QAAAA,EAAUmB,SAAQ;MAC7ClB,OAAO,CAAC;IACV,CAAA;EACF;EAEA,OAAOuB,QAAQV,KAAuB;AACpC,WAAO,IAAIjB,aAAY;MACrBE,MAAM;MACNC,UAAUc,IAAIK,SAAQ;MACtBlB,OAAO,CAAC;IACV,CAAA;EACF;;;;EAKA,OAAOwB,OAAUxB,OAAmC;AAClD,WAAO,IAAIJ,aAAY;MACrBE,MAAM;MACNC,UAAU;MACV,GAAGoB,iBAAiBnB,KAAAA;IACtB,CAAA;EACF;EAEA,OAAOyB,KAAKA,MAAcC,SAAgD;AACxE,WAAO,IAAI9B,aAAY;MACrBE,MAAM;MACN2B;MACAE,YAAYD,SAAS5B;IACvB,CAAA;EACF;EAEA,OAAO8B,YAAyChB,QAAWiB,MAAmD;AAC5G,UAAMhB,MAAMC,iBAAiBF,MAAAA,GAASG,MAAAA,KAAWC,OAAM,IAAIC,UAAU,mBAAA,CAAA;AACrE,WAAO,IAAIrB,aAAY;MACrBE,MAAM;MACNC,UAAUc,IAAIK,SAAQ;MACtBlB,OAAO,CAAC;MACR4B,aAAaC;IACf,CAAA;EACF;EAEA,OAAOC,GAAM1C,OAAqB;AAChC,QAAI,CAAK2C,MAAM3C,KAAAA,KAAU,OAAOA,UAAU,YAAYA,UAAU,MAAM;AACpE,YAAM,IAAI6B,UAAU,4CAAA;IACtB;AAEA,WAAO,IAAIrB,aAAY;MACrBE,MAAM;MACNkC,UAAU;MACV5C,OAAW2C,MAAM3C,KAAAA,IAASA,MAAM6C,SAAQ,EAAGC,OAAM,IAAK9C;IACxD,CAAA;EACF;EAEA,OAAO+C,IAAO/C,OAAqB;AACjC,WAAO,IAAIQ,aAAY;MACrBE,MAAM;MACNkC,UAAU;MACV5C;IACF,CAAA;EACF;EAEA,OAAOgD,GAAMhD,OAAqB;AAChC,WAAO,IAAIQ,aAAY;MACrBE,MAAM;MACNkC,UAAU;MACV5C;IACF,CAAA;EACF;EAEA,OAAOiD,IAAOjD,OAAqB;AACjC,WAAO,IAAIQ,aAAY;MACrBE,MAAM;MACNkC,UAAU;MACV5C;IACF,CAAA;EACF;EAEA,OAAOkD,GAAMlD,OAAqB;AAChC,WAAO,IAAIQ,aAAY;MACrBE,MAAM;MACNkC,UAAU;MACV5C;IACF,CAAA;EACF;EAEA,OAAOmD,IAAOnD,OAAqB;AACjC,WAAO,IAAIQ,aAAY;MACrBE,MAAM;MACNkC,UAAU;MACV5C;IACF,CAAA;EACF;EAEA,OAAOoD,MAASC,QAAwB;AACtC,WAAO,IAAI7C,aAAY;MACrBE,MAAM;MACN2C;IACF,CAAA;EACF;EAEA,OAAOC,QAAWC,MAASC,IAAkB;AAC3C,WAAO,IAAIhD,aAAY;MACrBE,MAAM;MACN6C;MACAC;IACF,CAAA;EACF;EAEA,OAAOC,IAA0B3C,QAAmC;AAClE,WAAO,IAAIN,aAAY;MACrBE,MAAM;MACNI,QAAQA,OAAOb;IACjB,CAAA;EACF;EAEA,OAAOyD,OAAUC,SAAiC;AAChD,WAAO,IAAInD,aAAY;MACrBE,MAAM;MACNiD,SAASA,QAAQC,IAAI,CAACC,MAAMA,EAAE5D,GAAG;IACnC,CAAA;EACF;EAEA,OAAO6D,MAASH,SAAiC;AAC/C,WAAO,IAAInD,aAAY;MACrBE,MAAM;MACNiD,SAASA,QAAQC,IAAI,CAACC,MAAMA,EAAE5D,GAAG;IACnC,CAAA;EACF;EAEA,YAAoCA,KAAsB;;AAE1D,qBAAA,MAAA,WAAA,MAAA;SAFoCA,MAAAA;SAEpC,SAAA,IAAYO,aAAYN;EAFmC;AAG7D;AAzME,iBADIM,aACWN,YAAmC,CAAC,CAAA;AA2M9C,IAAMqB,SAAoBf;AAQjC,IAAMuB,mBAAmB,CAACgC,eAAAA;AACxB,MAAIC;AACJ,MAAI,QAAQD,YAAY;AACtB9C,IAAAA,gBACE,OAAO8C,WAAW5C,OAAO,YAAY8C,MAAMC,QAAQH,WAAW5C,EAAE,GAChE,iBACA,mBAAA;AAEF6C,eAAW,OAAOD,WAAW5C,OAAO,WAAW;MAAC4C,WAAW5C;QAAM4C,WAAW5C;AAC5EgD,IAAAA,QAAOF,MAAM7C,SAAAA,EAAUgD,KAAKD,QAAOE,YAAY,EAAEL,QAAAA;EACnD;AAEA,SAAO;IACL7C,IAAI6C;IACJpD,OAAO0D,OAAOC,YACZD,OAAOE,QAAQT,UAAAA,EACZjD,OAAO,CAAC,CAAC2D,MAAMC,MAAAA,MAAYD,SAAS,IAAA,EACpCb,IAAI,CAAC,CAACa,MAAME,SAAAA,MAAe;MAACF;MAAMlD,OAAOxB,GAAG4E,SAAAA,IAAaA,UAAU1E,MAAMsB,OAAOmB,GAAGiC,SAAAA,EAAW1E;KAAI,CAAA;EAEzG;AACF;AAEA,IAAM2E,aAAN,MAAMA,YAAAA;EAGJ,OAAO7E,GAAGC,OAAqC;AAC7C,WAAO,OAAOA,UAAU,YAAYA,UAAU,QAAQ,YAAYA;EACpE;EAEA,OAAO6E,QAAQ5E,KAAiC;AAC9C,WAAO,IAAI2E,YAAW3E,GAAAA;EACxB;EAEA,OAAO6E,OAA6BhE,QAAkC;AACpE,WAAO,IAAI8D,YAAW;MACpBlE,MAAM;MACNI,QAAQA,OAAOb;IACjB,CAAA;EACF;EAEA,OAAOS,KAAKc,QAA2BuC,YAAgD;AACrF,WAAO,IAAIa,YAAW;MACpBlE,MAAM;MACNI,QAAQN,YAAYE,KAAKc,QAAQuC,UAAAA,EAAY9D;IAC/C,CAAA;EACF;EAEA,OAAO8E,OAAOC,SAAmC;AAC/C,QAAIA,QAAQ1D,WAAW,GAAG;AACxB,YAAM,IAAIO,UACR,4GAAA;IAEJ;AACA,WAAO,IAAI+C,YAAW;MACpBlE,MAAM;MACNsE,SAASA,QAAQpB,IAAI,CAACqB,MAAMA,EAAEhF,GAAG;IACnC,CAAA;EACF;EAEA,OAAOiF,QAAWC,QAAkBC,SAA6B;AAC/D,WAAO,IAAIR,YAAW;MACpBlE,MAAM;MACNyE,QAAQA,OAAOlF;MACfmF,SAASA,QAAQnF;IACnB,CAAA;EACF;EAMA6E,OAAOhE,QAAqD;AAC1D,QAAIS,OAAOxB,GAAGe,MAAAA,GAAS;AACrB,aAAO,IAAI8D,YAAW;QACpBlE,MAAM;QACN2E,WAAW,KAAKpF;QAChBa,QAAQA,OAAOb;MACjB,CAAA;IACF,OAAO;AACL,aAAO,IAAI2E,YAAW;QACpBlE,MAAM;QACN2E,WAAW,KAAKpF;QAChBa,QAAQN,YAAY4B,OAAOtB,MAAAA,EAAQb;MACrC,CAAA;IACF;EACF;EAEAqF,UAAUC,KAAyB;AACjC,WAAO,IAAIX,YAAW;MACpBlE,MAAM;MACN8E,QAAQ,KAAKvF;MACbK,UAAUiF;IACZ,CAAA;EACF;EAEAE,aAAaC,QAA2BH,KAAyB;AAC/D,UAAM9D,MAAMC,iBAAiBgE,MAAAA,GAAS/D,MAAAA,KAAWC,OAAM,IAAIC,UAAU,0BAAA,CAAA;AACrE,WAAO,IAAI+C,YAAW;MACpBlE,MAAM;MACN8E,QAAQ,KAAKvF;MACbK,UAAUiF;MACV5E,UAAUc,IAAIK,SAAQ;IACxB,CAAA;EACF;EAEA6D,SAAS5E,UAA6BgD,YAA4D;AAChG,WAAO,IAAIa,YAAW;MACpBlE,MAAM;MACN8E,QAAQ,KAAKvF;MACbM,WAAW;MACXO,QAAQN,YAAYE,KAAKK,UAAUgD,UAAAA,EAAY9D;IACjD,CAAA;EACF;EAEA2F,SAAS7E,UAA6BgD,YAA4D;AAChG,WAAO,IAAIa,YAAW;MACpBlE,MAAM;MACN8E,QAAQ,KAAKvF;MACbM,WAAW;MACXO,QAAQN,YAAYE,KAAKK,UAAUgD,UAAAA,EAAY9D;IACjD,CAAA;EACF;EAEAkF,SAAqB;AACnB,WAAO,IAAIP,YAAW;MACpBlE,MAAM;MACN8E,QAAQ,KAAKvF;MACbM,WAAW;IACb,CAAA;EACF;EAEAmF,SAAqB;AACnB,WAAO,IAAId,YAAW;MACpBlE,MAAM;MACN8E,QAAQ,KAAKvF;MACbM,WAAW;IACb,CAAA;EACF;EAEAsF,WAAWC,OAAiC;AAC1C,WAAO,IAAIlB,YAAW;MACpBlE,MAAM;MACNqF,OAAO,KAAK9F;MACZ6F,OAAOA,MAAMlC,IAAI,CAACoC,MAAMA,EAAE/F,GAAG;IAC/B,CAAA;EACF;EAEAqC,QAAQA,SAA4C;AAClD,WAAO,IAAIsC,YAAW;MACpBlE,MAAM;MACNqF,OAAO,KAAK9F;MACZqC;IACF,CAAA;EACF;EAtFA,YAA4BrC,KAAqB;;AAEjD,qBAAA,MAAA,UAAA,MAAA;SAF4BA,MAAAA;SAE5B,QAAA,IAAW2E,YAAW1E;EAF4B;AAuFpD;AAnIE,iBADI0E,YACW1E,YAAiC,CAAC,CAAA;AAqI5C,IAAM+F,QAAkBrB;;;;ADnrB/B,SAASsB,gBAAgB;",
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-EUA7CM23.mjs";
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