@dxos/echo 0.8.4-main.e098934 → 0.8.4-main.ead640a
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/chunk-HKFCK2GL.mjs +175 -0
- package/dist/lib/browser/chunk-HKFCK2GL.mjs.map +7 -0
- package/dist/lib/browser/{chunk-EIXXFUN5.mjs → chunk-MAAYELT7.mjs} +477 -486
- package/dist/lib/browser/chunk-MAAYELT7.mjs.map +7 -0
- package/dist/lib/browser/chunk-MB6MMNFP.mjs +3857 -0
- package/dist/lib/browser/chunk-MB6MMNFP.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +12 -7
- package/dist/lib/browser/internal/index.mjs +332 -0
- package/dist/lib/browser/internal/index.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/query/index.mjs +15 -0
- package/dist/lib/browser/query/index.mjs.map +7 -0
- package/dist/lib/browser/testing/index.mjs +260 -32
- package/dist/lib/browser/testing/index.mjs.map +4 -4
- package/dist/lib/node-esm/{chunk-TCY7IVTS.mjs → chunk-5NWDGIBT.mjs} +477 -486
- package/dist/lib/node-esm/chunk-5NWDGIBT.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-AUAH4E2J.mjs +175 -0
- package/dist/lib/node-esm/chunk-AUAH4E2J.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-BQRA4VLX.mjs +3857 -0
- package/dist/lib/node-esm/chunk-BQRA4VLX.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +12 -7
- package/dist/lib/node-esm/internal/index.mjs +332 -0
- package/dist/lib/node-esm/internal/index.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/query/index.mjs +15 -0
- package/dist/lib/node-esm/query/index.mjs.map +7 -0
- package/dist/lib/node-esm/testing/index.mjs +260 -32
- package/dist/lib/node-esm/testing/index.mjs.map +4 -4
- package/dist/types/src/Obj.d.ts +22 -5
- package/dist/types/src/Obj.d.ts.map +1 -1
- package/dist/types/src/Ref.d.ts +1 -1
- package/dist/types/src/Ref.d.ts.map +1 -1
- package/dist/types/src/Relation.d.ts +5 -4
- package/dist/types/src/Relation.d.ts.map +1 -1
- package/dist/types/src/Type.d.ts +16 -17
- package/dist/types/src/Type.d.ts.map +1 -1
- package/dist/types/src/errors.d.ts +8 -8
- package/dist/types/src/index.d.ts +2 -2
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/internal/ast/annotation-helper.d.ts +8 -0
- package/dist/types/src/internal/ast/annotation-helper.d.ts.map +1 -0
- package/dist/types/src/internal/ast/annotations.d.ts +125 -0
- package/dist/types/src/internal/ast/annotations.d.ts.map +1 -0
- package/dist/types/src/internal/ast/annotations.test.d.ts +2 -0
- package/dist/types/src/internal/ast/annotations.test.d.ts.map +1 -0
- package/dist/types/src/internal/ast/entity-kind.d.ts +10 -0
- package/dist/types/src/internal/ast/entity-kind.d.ts.map +1 -0
- package/dist/types/src/internal/ast/index.d.ts +5 -0
- package/dist/types/src/internal/ast/index.d.ts.map +1 -0
- package/dist/types/src/internal/ast/types.d.ts +6 -0
- package/dist/types/src/internal/ast/types.d.ts.map +1 -0
- package/dist/types/src/internal/formats/date.d.ts +63 -0
- package/dist/types/src/internal/formats/date.d.ts.map +1 -0
- package/dist/types/src/internal/formats/date.test.d.ts +2 -0
- package/dist/types/src/internal/formats/date.test.d.ts.map +1 -0
- package/dist/types/src/internal/formats/format.d.ts +30 -0
- package/dist/types/src/internal/formats/format.d.ts.map +1 -0
- package/dist/types/src/internal/formats/format.test.d.ts +2 -0
- package/dist/types/src/internal/formats/format.test.d.ts.map +1 -0
- package/dist/types/src/internal/formats/index.d.ts +8 -0
- package/dist/types/src/internal/formats/index.d.ts.map +1 -0
- package/dist/types/src/internal/formats/number.d.ts +31 -0
- package/dist/types/src/internal/formats/number.d.ts.map +1 -0
- package/dist/types/src/internal/formats/object.d.ts +35 -0
- package/dist/types/src/internal/formats/object.d.ts.map +1 -0
- package/dist/types/src/internal/formats/select.d.ts +11 -0
- package/dist/types/src/internal/formats/select.d.ts.map +1 -0
- package/dist/types/src/internal/formats/string.d.ts +38 -0
- package/dist/types/src/internal/formats/string.d.ts.map +1 -0
- package/dist/types/src/internal/formats/types.d.ts +68 -0
- package/dist/types/src/internal/formats/types.d.ts.map +1 -0
- package/dist/types/src/internal/index.d.ts +15 -0
- package/dist/types/src/internal/index.d.ts.map +1 -0
- package/dist/types/src/internal/json/annotations.d.ts +19 -0
- package/dist/types/src/internal/json/annotations.d.ts.map +1 -0
- package/dist/types/src/internal/json/effect-schema.test.d.ts +2 -0
- package/dist/types/src/internal/json/effect-schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/json/index.d.ts +2 -0
- package/dist/types/src/internal/json/index.d.ts.map +1 -0
- package/dist/types/src/internal/json/json-schema.d.ts +28 -0
- package/dist/types/src/internal/json/json-schema.d.ts.map +1 -0
- package/dist/types/src/internal/json/json-schema.test.d.ts +2 -0
- package/dist/types/src/internal/json/json-schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/json-schema/index.d.ts +3 -0
- package/dist/types/src/internal/json-schema/index.d.ts.map +1 -0
- package/dist/types/src/internal/json-schema/json-schema-normalize.d.ts +7 -0
- package/dist/types/src/internal/json-schema/json-schema-normalize.d.ts.map +1 -0
- package/dist/types/src/internal/json-schema/json-schema-type.d.ts +250 -0
- package/dist/types/src/internal/json-schema/json-schema-type.d.ts.map +1 -0
- package/dist/types/src/internal/object/accessors.d.ts +37 -0
- package/dist/types/src/internal/object/accessors.d.ts.map +1 -0
- package/dist/types/src/internal/object/common.d.ts +18 -0
- package/dist/types/src/internal/object/common.d.ts.map +1 -0
- package/dist/types/src/internal/object/create.d.ts +40 -0
- package/dist/types/src/internal/object/create.d.ts.map +1 -0
- package/dist/types/src/internal/object/create.test.d.ts +2 -0
- package/dist/types/src/internal/object/create.test.d.ts.map +1 -0
- package/dist/types/src/internal/object/deleted.d.ts +6 -0
- package/dist/types/src/internal/object/deleted.d.ts.map +1 -0
- package/dist/types/src/internal/object/entity.d.ts +33 -0
- package/dist/types/src/internal/object/entity.d.ts.map +1 -0
- package/dist/types/src/internal/object/expando.d.ts +14 -0
- package/dist/types/src/internal/object/expando.d.ts.map +1 -0
- package/dist/types/src/internal/object/ids.d.ts +6 -0
- package/dist/types/src/internal/object/ids.d.ts.map +1 -0
- package/dist/types/src/internal/object/index.d.ts +16 -0
- package/dist/types/src/internal/object/index.d.ts.map +1 -0
- package/dist/types/src/internal/object/inspect.d.ts +2 -0
- package/dist/types/src/internal/object/inspect.d.ts.map +1 -0
- package/dist/types/src/internal/object/json-serializer.d.ts +32 -0
- package/dist/types/src/internal/object/json-serializer.d.ts.map +1 -0
- package/dist/types/src/internal/object/json-serializer.test.d.ts +2 -0
- package/dist/types/src/internal/object/json-serializer.test.d.ts.map +1 -0
- package/dist/types/src/internal/object/meta.d.ts +31 -0
- package/dist/types/src/internal/object/meta.d.ts.map +1 -0
- package/dist/types/src/internal/object/model.d.ts +117 -0
- package/dist/types/src/internal/object/model.d.ts.map +1 -0
- package/dist/types/src/internal/object/relation.d.ts +17 -0
- package/dist/types/src/internal/object/relation.d.ts.map +1 -0
- package/dist/types/src/internal/object/schema-validator.d.ts +15 -0
- package/dist/types/src/internal/object/schema-validator.d.ts.map +1 -0
- package/dist/types/src/internal/object/schema-validator.test.d.ts +2 -0
- package/dist/types/src/internal/object/schema-validator.test.d.ts.map +1 -0
- package/dist/types/src/internal/object/typed-object.d.ts +31 -0
- package/dist/types/src/internal/object/typed-object.d.ts.map +1 -0
- package/dist/types/src/internal/object/typed-object.test.d.ts +2 -0
- package/dist/types/src/internal/object/typed-object.test.d.ts.map +1 -0
- package/dist/types/src/internal/object/typename.d.ts +15 -0
- package/dist/types/src/internal/object/typename.d.ts.map +1 -0
- package/dist/types/src/internal/object/version.d.ts +14 -0
- package/dist/types/src/internal/object/version.d.ts.map +1 -0
- package/dist/types/src/internal/projection/compose.d.ts +6 -0
- package/dist/types/src/internal/projection/compose.d.ts.map +1 -0
- package/dist/types/src/internal/projection/compose.test.d.ts +2 -0
- package/dist/types/src/internal/projection/compose.test.d.ts.map +1 -0
- package/dist/types/src/internal/projection/index.d.ts +2 -0
- package/dist/types/src/internal/projection/index.d.ts.map +1 -0
- package/dist/types/src/internal/proxy/handler.test.d.ts +2 -0
- package/dist/types/src/internal/proxy/handler.test.d.ts.map +1 -0
- package/dist/types/src/internal/proxy/reactive-object.d.ts +15 -0
- package/dist/types/src/internal/proxy/reactive-object.d.ts.map +1 -0
- package/dist/types/src/internal/proxy/schema.test.d.ts +2 -0
- package/dist/types/src/internal/proxy/schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/proxy/typed-handler.d.ts +44 -0
- package/dist/types/src/internal/proxy/typed-handler.d.ts.map +1 -0
- package/dist/types/src/internal/proxy/typed-handler.test.d.ts +2 -0
- package/dist/types/src/internal/proxy/typed-handler.test.d.ts.map +1 -0
- package/dist/types/src/internal/proxy/typed-object.test.d.ts +2 -0
- package/dist/types/src/internal/proxy/typed-object.test.d.ts.map +1 -0
- package/dist/types/src/internal/query/index.d.ts +2 -0
- package/dist/types/src/internal/query/index.d.ts.map +1 -0
- package/dist/types/src/internal/query/query.d.ts +17 -0
- package/dist/types/src/internal/query/query.d.ts.map +1 -0
- package/dist/types/src/internal/ref/index.d.ts +3 -0
- package/dist/types/src/internal/ref/index.d.ts.map +1 -0
- package/dist/types/src/internal/ref/ref-array.d.ts +21 -0
- package/dist/types/src/internal/ref/ref-array.d.ts.map +1 -0
- package/dist/types/src/internal/ref/ref.d.ts +206 -0
- package/dist/types/src/internal/ref/ref.d.ts.map +1 -0
- package/dist/types/src/internal/ref/ref.test.d.ts +2 -0
- package/dist/types/src/internal/ref/ref.test.d.ts.map +1 -0
- package/dist/types/src/internal/schema/echo-schema.d.ts +168 -0
- package/dist/types/src/internal/schema/echo-schema.d.ts.map +1 -0
- package/dist/types/src/internal/schema/index.d.ts +7 -0
- package/dist/types/src/internal/schema/index.d.ts.map +1 -0
- package/dist/types/src/internal/schema/manipulation.d.ts +10 -0
- package/dist/types/src/internal/schema/manipulation.d.ts.map +1 -0
- package/dist/types/src/internal/schema/runtime-schema-registry.d.ts +18 -0
- package/dist/types/src/internal/schema/runtime-schema-registry.d.ts.map +1 -0
- package/dist/types/src/internal/schema/snapshot.d.ts +6 -0
- package/dist/types/src/internal/schema/snapshot.d.ts.map +1 -0
- package/dist/types/src/internal/schema/stored-schema.d.ts +13 -0
- package/dist/types/src/internal/schema/stored-schema.d.ts.map +1 -0
- package/dist/types/src/internal/testing/index.d.ts +3 -0
- package/dist/types/src/internal/testing/index.d.ts.map +1 -0
- package/dist/types/src/internal/testing/types.d.ts +455 -0
- package/dist/types/src/internal/testing/types.d.ts.map +1 -0
- package/dist/types/src/internal/testing/utils.d.ts +10 -0
- package/dist/types/src/internal/testing/utils.d.ts.map +1 -0
- package/dist/types/src/internal/types/index.d.ts +3 -0
- package/dist/types/src/internal/types/index.d.ts.map +1 -0
- package/dist/types/src/internal/types/types.d.ts +79 -0
- package/dist/types/src/internal/types/types.d.ts.map +1 -0
- package/dist/types/src/internal/types/types.test.d.ts +2 -0
- package/dist/types/src/internal/types/types.test.d.ts.map +1 -0
- package/dist/types/src/internal/types/util.d.ts +5 -0
- package/dist/types/src/internal/types/util.d.ts.map +1 -0
- package/dist/types/src/query/index.d.ts +2 -1
- package/dist/types/src/query/index.d.ts.map +1 -1
- package/dist/types/src/query/{dsl.d.ts → query.d.ts} +28 -23
- package/dist/types/src/query/query.d.ts.map +1 -0
- package/dist/types/src/query/query.test.d.ts +2 -0
- package/dist/types/src/query/query.test.d.ts.map +1 -0
- package/dist/types/src/query/tag.d.ts +17 -0
- package/dist/types/src/query/tag.d.ts.map +1 -0
- package/dist/types/src/testing/echo-schema.d.ts +7 -0
- package/dist/types/src/testing/echo-schema.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +2 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/types.d.ts +18 -18
- package/dist/types/src/testing/types.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +29 -18
- package/src/Obj.ts +77 -12
- package/src/Ref.ts +1 -2
- package/src/Relation.ts +15 -5
- package/src/Type.ts +29 -30
- package/src/index.ts +2 -2
- package/src/internal/ast/annotation-helper.ts +22 -0
- package/src/internal/ast/annotations.test.ts +98 -0
- package/src/internal/ast/annotations.ts +219 -0
- package/src/internal/ast/entity-kind.ts +15 -0
- package/src/internal/ast/index.ts +8 -0
- package/src/internal/ast/types.ts +17 -0
- package/src/internal/formats/date.test.ts +56 -0
- package/src/internal/formats/date.ts +217 -0
- package/src/internal/formats/format.test.ts +77 -0
- package/src/internal/formats/format.ts +52 -0
- package/src/internal/formats/index.ts +12 -0
- package/src/internal/formats/number.ts +89 -0
- package/src/internal/formats/object.ts +80 -0
- package/src/internal/formats/select.ts +16 -0
- package/src/internal/formats/string.ts +76 -0
- package/src/internal/formats/types.ts +175 -0
- package/src/internal/index.ts +22 -0
- package/src/internal/json/annotations.ts +50 -0
- package/src/internal/json/effect-schema.test.ts +143 -0
- package/src/internal/json/index.ts +5 -0
- package/src/internal/json/json-schema.test.ts +857 -0
- package/src/internal/json/json-schema.ts +519 -0
- package/src/internal/json-schema/index.ts +6 -0
- package/src/internal/json-schema/json-schema-normalize.ts +109 -0
- package/src/internal/json-schema/json-schema-type.ts +403 -0
- package/src/internal/object/accessors.ts +153 -0
- package/src/internal/object/common.ts +76 -0
- package/src/internal/object/create.test.ts +118 -0
- package/src/internal/object/create.ts +96 -0
- package/src/internal/object/deleted.ts +19 -0
- package/src/internal/object/entity.ts +248 -0
- package/src/internal/object/expando.ts +21 -0
- package/src/internal/object/ids.ts +12 -0
- package/src/internal/object/index.ts +19 -0
- package/src/internal/object/inspect.ts +48 -0
- package/src/internal/object/json-serializer.test.ts +99 -0
- package/src/internal/object/json-serializer.ts +225 -0
- package/src/internal/object/meta.ts +61 -0
- package/src/internal/object/model.ts +170 -0
- package/src/internal/object/relation.ts +24 -0
- package/src/internal/object/schema-validator.test.ts +186 -0
- package/src/internal/object/schema-validator.ts +241 -0
- package/src/internal/object/typed-object.test.ts +34 -0
- package/src/internal/object/typed-object.ts +88 -0
- package/src/internal/object/typename.ts +61 -0
- package/src/internal/object/version.ts +22 -0
- package/src/internal/projection/compose.test.ts +43 -0
- package/src/internal/projection/compose.ts +36 -0
- package/src/internal/projection/index.ts +5 -0
- package/src/internal/proxy/handler.test.ts +163 -0
- package/src/internal/proxy/reactive-object.ts +108 -0
- package/src/internal/proxy/schema.test.ts +136 -0
- package/src/internal/proxy/typed-handler.test.ts +102 -0
- package/src/internal/proxy/typed-handler.ts +228 -0
- package/src/internal/proxy/typed-object.test.ts +100 -0
- package/src/internal/query/index.ts +5 -0
- package/src/internal/query/query.ts +23 -0
- package/src/internal/ref/index.ts +6 -0
- package/src/internal/ref/ref-array.ts +39 -0
- package/src/internal/ref/ref.test.ts +100 -0
- package/src/internal/ref/ref.ts +521 -0
- package/src/internal/schema/echo-schema.ts +383 -0
- package/src/internal/schema/index.ts +10 -0
- package/src/internal/schema/manipulation.ts +92 -0
- package/src/internal/schema/runtime-schema-registry.ts +78 -0
- package/src/internal/schema/snapshot.ts +25 -0
- package/src/internal/schema/stored-schema.ts +26 -0
- package/src/internal/testing/index.ts +6 -0
- package/src/internal/testing/types.ts +211 -0
- package/src/internal/testing/utils.ts +54 -0
- package/src/internal/types/index.ts +6 -0
- package/src/internal/types/types.test.ts +48 -0
- package/src/internal/types/types.ts +176 -0
- package/src/internal/types/util.ts +9 -0
- package/src/query/index.ts +2 -1
- package/src/query/query.test.ts +401 -0
- package/src/query/{dsl.ts → query.ts} +82 -45
- package/src/query/tag.ts +37 -0
- package/src/test/api.test.ts +9 -9
- package/src/testing/echo-schema.ts +39 -0
- package/src/testing/index.ts +2 -0
- package/src/testing/types.ts +1 -1
- package/dist/lib/browser/chunk-EIXXFUN5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-TCY7IVTS.mjs.map +0 -7
- package/dist/types/src/experimental/database.d.ts +0 -8
- package/dist/types/src/experimental/database.d.ts.map +0 -1
- package/dist/types/src/experimental/index.d.ts +0 -1
- package/dist/types/src/experimental/index.d.ts.map +0 -1
- package/dist/types/src/experimental/queue.d.ts +0 -8
- package/dist/types/src/experimental/queue.d.ts.map +0 -1
- package/dist/types/src/experimental/space.d.ts +0 -8
- package/dist/types/src/experimental/space.d.ts.map +0 -1
- package/dist/types/src/query/dsl.d.ts.map +0 -1
- package/dist/types/src/query/dsl.test.d.ts +0 -2
- package/dist/types/src/query/dsl.test.d.ts.map +0 -1
- package/src/experimental/database.ts +0 -11
- package/src/experimental/index.ts +0 -7
- package/src/experimental/queue.ts +0 -11
- package/src/experimental/space.ts +0 -11
- package/src/query/dsl.test.ts +0 -362
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/query/query.ts", "../../../src/Ref.ts", "../../../src/query/tag.ts", "../../../src/Obj.ts", "../../../src/Type.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport type * as EffectArray from 'effect/Array';\nimport * as Match from 'effect/Match';\nimport * as Schema from 'effect/Schema';\nimport type * as Types from 'effect/Types';\n\nimport { raise } from '@dxos/debug';\nimport { type ForeignKey, type QueryAST } from '@dxos/echo-protocol';\nimport { assertArgument } from '@dxos/invariant';\nimport { DXN, ObjectId } from '@dxos/keys';\n\nimport { getTypeReference } from '../internal';\nimport type * as Obj from '../Obj';\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// TODO(wittjosiah): Make Filter & Query pipeable.\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 or optional reference.\n * @returns Query for the target of the reference.\n */\n reference<K extends RefPropKey<T>>(\n key: K,\n ): Query<\n T[K] extends Ref.Any\n ? Ref.Target<T[K]>\n : T[K] extends Ref.Any | undefined\n ? Ref.Target<Exclude<T[K], undefined>>\n : never\n >;\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 | string,\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 | string,\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 | string,\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: EffectArray.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 | string,\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: Types.Contravariant<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 /** Construct a filter from an ast. */\n fromAst(ast: QueryAST.Filter): Filter<Obj.Any>;\n\n /**\n * Filter that matches all objects.\n */\n // TODO(dmaretskyi): `Obj.Any` would be more type-safe, but causes annoying errors in existing code\n everything(): Filter<Obj.AnyProps>;\n\n /**\n * Filter that matches no objects.\n */\n // TODO(dmaretskyi): Filter<never>?\n nothing(): Filter<any>;\n\n /**\n * Filter by object IDs.\n */\n // TODO(dmaretskyi): Rename to `Filter.id`.\n ids(...id: ObjectId[]): Filter<Obj.AnyProps>;\n\n /**\n * Filter by type.\n */\n type<S extends Schema.Schema.All>(\n schema: S | string,\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<Obj.AnyProps>;\n\n /**\n * Filter by fully qualified type DXN.\n */\n typeDXN(dxn: DXN): Filter<Obj.AnyProps>;\n\n /**\n * Filter by tag.\n */\n tag(tag: string): Filter<Obj.Any>;\n\n /**\n * Filter by properties.\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 an array property to contain the provided value.\n * @param value - Value to check against.\n */\n contains<T>(value: T): Filter<readonly T[] | undefined>;\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<unknown>;\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[]> = Schema.Simplify<Intersection<{ [K in keyof FS]: Type<FS[K]> }>>;\n\n type Or<FS extends readonly Any[]> = Schema.Simplify<{ [K in keyof FS]: Type<FS[K]> }[number]>;\n}\n\n// TODO(dmaretskyi): Separate object instead of statics for better devex with type errors.\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 fromAst(ast: QueryAST.Filter): Filter<any> {\n return new FilterClass(ast);\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 | string,\n props?: Filter.Props<Schema.Schema.Type<S>>,\n ): Filter<Schema.Schema.Type<S>> {\n const dxn = getTypeDXNFromSpecifier(schema);\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 static tag(tag: string): Filter<any> {\n return new FilterClass({\n type: 'tag',\n tag,\n });\n }\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>(\n schema: S | string,\n keys: ForeignKey[],\n ): Filter<Schema.Schema.Type<S>> {\n const dxn = getTypeDXNFromSpecifier(schema);\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 contains<T>(value: T): Filter<readonly T[] | undefined> {\n return new FilterClass({\n type: 'contains',\n value,\n });\n }\n\n static between<T>(from: T, to: T): Filter<unknown> {\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, processPredicate(predicate)]),\n ) as Record<string, QueryAST.Filter>,\n };\n};\n\nconst processPredicate = (predicate: any): QueryAST.Filter => {\n return Match.value(predicate).pipe(\n Match.withReturnType<QueryAST.Filter>(),\n Match.when(Filter.is, (predicate) => predicate.ast),\n // TODO(wittjosiah): Add support for array predicates.\n Match.when(Array.isArray, (_predicate) => {\n throw new Error('Array predicates are not yet supported.');\n }),\n Match.when(\n (predicate: any) => !Ref.isRef(predicate) && typeof predicate === 'object' && predicate !== null,\n (predicate) => {\n const nestedProps = Object.fromEntries(\n Object.entries(predicate).map(([key, value]) => [key, processPredicate(value)]),\n );\n\n return {\n type: 'object',\n typename: null,\n props: nestedProps,\n };\n },\n ),\n Match.orElse((value) => Filter.eq(value).ast),\n );\n};\n\n// TODO(dmaretskyi): Separate object instead of statics for better devex with type errors.\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 | string, 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 | string, key: string): Query.Any {\n const dxn = getTypeDXNFromSpecifier(target);\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 | string, 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 | string, 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\n/**\n * @param input schema or a typename string\n * @return type DXN\n */\nconst getTypeDXNFromSpecifier = (input: Schema.Schema.All | string): DXN => {\n if (Schema.isSchema(input)) {\n return getTypeReference(input)?.toDXN() ?? raise(new TypeError('Schema has no DXN'));\n } else {\n assertArgument(typeof input === 'string', 'input');\n assertArgument(!input.startsWith('dxn:'), 'input');\n return DXN.fromTypename(input);\n }\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport * as EchoSchema from './internal';\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 * as Schema from 'effect/Schema';\n\nimport { LabelAnnotation } from '../internal';\nimport * as Obj from '../Obj';\nimport * as Type from '../Type';\n\nexport const Tag = Schema.Struct({\n label: Schema.String,\n hue: Schema.optional(Schema.String), // TODO(burdon): Color name?\n}).pipe(\n Type.Obj({\n typename: 'dxos.org/type/Tag',\n version: '0.1.0',\n }),\n LabelAnnotation.set(['label']),\n);\nexport type Tag = Schema.Schema.Type<typeof Tag>;\n\nexport const make = (props: Obj.MakeProps<typeof Tag>) => Obj.make(Tag, props);\n\nexport type TagMap = Record<string, Tag>;\n\nexport const sortTags = ({ label: a }: Tag, { label: b }: Tag) => a.localeCompare(b);\n\nexport const createTagList = (tags: TagMap): Tag[] =>\n Object.entries(tags)\n .map(([id, tag]) => ({ ...tag, id }))\n .sort(sortTags);\n\nexport const findTagByLabel = (tags: TagMap | undefined, name: string): Tag | undefined => {\n const entry = Object.entries(tags ?? {}).find(([_, tag]) => tag.label.toLowerCase() === name.toLowerCase());\n return entry ? { ...entry[1], id: entry[0] } : undefined;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Function from 'effect/Function';\nimport * as Schema from 'effect/Schema';\n\nimport { assertArgument, invariant } from '@dxos/invariant';\nimport { type DXN } from '@dxos/keys';\nimport * as LiveObject from '@dxos/live-object';\nimport { assumeType, deepMapValues } from '@dxos/util';\n\nimport { live } from './internal';\nimport * as EchoSchema from './internal';\nimport type * as Ref from './Ref';\nimport type * as Relation from './Relation';\nimport * 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 * This type does not define any properties.\n */\nexport interface Any extends BaseObj {}\n\n/**\n * Object with arbitrary properties.\n *\n * NOTE: Due to how typescript works, this type is not assignable to a specific schema type.\n * In that case, use `Obj.instanceOf` to check if an object is of a specific type.\n */\nexport interface AnyProps extends BaseObj {\n [key: string]: any;\n}\n\nexport const Any = Schema.Struct({}).pipe(\n Type.Obj({\n typename: 'dxos.org/types/Any',\n version: '0.1.0',\n }),\n);\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\nconst DEFAULT_META: EchoSchema.ObjectMeta = {\n keys: [],\n};\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?: Partial<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 // Set default fields on meta on creation.\n meta = { ...structuredClone(DEFAULT_META), ...props[EchoSchema.MetaId] };\n delete props[EchoSchema.MetaId];\n }\n\n const filterUndefined = Object.fromEntries(Object.entries(props).filter(([_, v]) => v !== undefined));\n\n return live<Schema.Schema.Type<S>>(schema, filterUndefined as any, { keys: [], ...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} = Function.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\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\nexport const getDescription = (obj: Any | Relation.Any): string | undefined => {\n const schema = getSchema(obj);\n if (schema != null) {\n return EchoSchema.getDescription(schema, obj);\n }\n};\n\nexport const setDescription = (obj: Any | Relation.Any, description: string) => {\n const schema = getSchema(obj);\n if (schema != null) {\n EchoSchema.setDescription(schema, obj, description);\n }\n};\n\nconst compare = (a?: string, b?: string) => {\n if (a == null) {\n return b == null ? 0 : 1;\n }\n\n if (b == null) {\n return -1;\n }\n\n return a.localeCompare(b);\n};\n\nexport type Comparator = (a: Any, b: Any) => number;\n\nexport const sortByLabel: Comparator = (a: Any, b: Any) => compare(getLabel(a), getLabel(b));\nexport const sortByTypename: Comparator = (a: Any, b: Any) => compare(getTypename(a), getTypename(b));\nexport const sort = (...comparators: Comparator[]): Comparator => {\n return (a: Any, b: Any) => {\n for (const comparator of comparators) {\n const result = comparator(a, b);\n if (result !== 0) {\n return result;\n }\n }\n\n return 0;\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 type * as EffectSchema from 'effect/Schema';\n\nimport { type EncodedReference } from '@dxos/echo-protocol';\nimport { invariant } from '@dxos/invariant';\nimport type * as Keys from '@dxos/keys';\n\nimport { type ToMutable } from './internal';\nimport * as EchoSchema from './internal';\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 EffectSchema.Schema.Any>\n extends EchoSchema.TypeMeta,\n EffectSchema.AnnotableClass<\n obj<Self>,\n OfKind<EchoSchema.EntityKind.Object> & ToMutable<EffectSchema.Schema.Type<Self>>,\n EffectSchema.Simplify<ObjJsonProps & ToMutable<EffectSchema.Schema.Encoded<Self>>>,\n EffectSchema.Schema.Context<Self>\n > {}\n\n/**\n * Object schema.\n */\nexport const Obj: {\n (opts: EchoSchema.TypeMeta): <Self extends EffectSchema.Schema.Any>(self: Self) => obj<Self>;\n} = EchoSchema.EchoObject as any;\n\n/**\n * Object schema type definitions.\n */\nexport declare 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 = EffectSchema.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 = EffectSchema.Simplify<ObjJsonProps & { [key: string]: any }>;\n\nexport const Expando: EffectSchema.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 EffectSchema.Schema.Any,\n SourceSchema extends EffectSchema.Schema.Any,\n TargetSchema extends EffectSchema.Schema.Any,\n> extends EchoSchema.TypeMeta,\n EffectSchema.AnnotableClass<\n relation<Self, SourceSchema, TargetSchema>,\n OfKind<EchoSchema.EntityKind.Relation> &\n Relation.Endpoints<EffectSchema.Schema.Type<SourceSchema>, EffectSchema.Schema.Type<TargetSchema>> &\n ToMutable<EffectSchema.Schema.Type<Self>>,\n EffectSchema.Simplify<RelationJsonProps & ToMutable<EffectSchema.Schema.Encoded<Self>>>,\n EffectSchema.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 EffectSchema.Schema.AnyNoContext, Target extends EffectSchema.Schema.AnyNoContext>(\n opts: EchoSchema.EchoRelationOptions<Source, Target>,\n ): <Self extends EffectSchema.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 = EffectSchema.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 EffectSchema.Schema.Any>\n extends EchoSchema.Ref$<EffectSchema.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 EffectSchema.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 = EffectSchema.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 './internal';\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Match", "Schema", "raise", "assertArgument", "DXN", "ObjectId", "Array", "Array", "RefArray", "isRef", "Ref", "make", "fromDXN", "OrderClass", "is", "value", "ast", "variance", "Order", "natural", "kind", "property", "direction", "FilterClass", "fromAst", "everything", "type", "typename", "props", "nothing", "filter", "relation", "ids", "assertArgument", "every", "id", "ObjectId", "isValid", "length", "Filter", "schema", "dxn", "getTypeDXNFromSpecifier", "toString", "propsFilterToAst", "startsWith", "DXN", "fromTypename", "typeDXN", "tag", "text", "options", "searchKind", "foreignKeys", "keys", "eq", "isRef", "TypeError", "operator", "noInline", "encode", "neq", "gt", "gte", "lt", "lte", "in", "values", "contains", "between", "from", "to", "not", "and", "filters", "map", "f", "or", "predicates", "idFilter", "Array", "isArray", "Schema", "pipe", "validateSync", "Object", "fromEntries", "entries", "prop", "_value", "predicate", "processPredicate", "withReturnType", "when", "_predicate", "Error", "nestedProps", "key", "orElse", "QueryClass", "select", "all", "queries", "q", "without", "source", "exclude", "selection", "reference", "anchor", "referencedBy", "target", "sourceOf", "targetOf", "orderBy", "order", "query", "o", "Query", "input", "isSchema", "getTypeReference", "toDXN", "raise", "make", "Schema", "VersionTypeId", "getDXN", "getDescription", "getLabel", "getMeta", "getSchema", "getSnapshot", "getTypename", "isDeleted", "make", "setDescription", "setLabel", "Function", "Schema", "assertArgument", "invariant", "LiveObject", "assumeType", "deepMapValues", "DXN", "Expando", "ObjectId", "Ref", "getMeta", "isMutable", "invariant", "SpaceId", "ObjectId", "DXN", "KindId", "EntityKindId", "Kind", "EntityKind", "Obj", "EchoObject", "Expando", "Relation", "EchoRelation", "Ref", "getDXN", "schema", "getSchemaDXN", "getTypename", "typename", "getSchemaTypename", "invariant", "startsWith", "getVersion", "version", "getSchemaVersion", "match", "isMutable", "getMeta", "getTypeAnnotation", "Any", "Struct", "pipe", "Obj", "typename", "version", "Meta", "MetaId", "DEFAULT_META", "keys", "make", "schema", "props", "meta", "assertArgument", "getTypeAnnotation", "kind", "EntityKind", "Object", "structuredClone", "filterUndefined", "fromEntries", "entries", "filter", "_", "v", "undefined", "live", "isObject", "obj", "assumeType", "EntityKindId", "instanceOf", "args", "length", "isInstanceOf", "getSchema", "getDXN", "isSchema", "dxn", "getObjectDXN", "invariant", "getTypeDXN", "getType", "getTypename", "asTypeDXN", "type", "getSchemaTypename", "getMeta", "getKeys", "dual", "source", "key", "deleteKeys", "i", "splice", "isDeleted", "deleted", "getLabel", "setLabel", "label", "EchoSchema", "getDescription", "setDescription", "description", "compare", "a", "b", "localeCompare", "sortByLabel", "sortByTypename", "sort", "comparators", "comparator", "result", "toJSON", "objectToJSON", "fromJSON", "objectFromJSON", "getSnapshot", "clone", "opts", "id", "data", "deepMapValues", "value", "recurse", "Ref", "isRef", "retainId", "VersionTypeId", "unversioned", "versioned", "isVersion", "ObjectVersionId", "versionValid", "compareVersions", "version1", "version2", "automergeHeads", "some", "head", "includes", "encodeVersion", "JSON", "stringify", "decodeVersion", "parsed", "parse", "Tag", "Struct", "label", "String", "hue", "optional", "pipe", "Obj", "typename", "version", "LabelAnnotation", "set", "make", "props", "sortTags", "a", "b", "localeCompare", "createTagList", "tags", "Object", "entries", "map", "id", "tag", "sort", "findTagByLabel", "name", "entry", "find", "_", "toLowerCase", "undefined"]
|
|
7
|
+
}
|