@dxos/echo 0.8.4-staging.ac66bdf99f → 0.9.0
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/LICENSE +102 -5
- package/README.md +7 -7
- package/dist/lib/neutral/Annotation.mjs +37 -6
- package/dist/lib/neutral/Database.mjs +6 -17
- package/dist/lib/neutral/Entity.mjs +31 -20
- package/dist/lib/neutral/Err.mjs +3 -3
- package/dist/lib/neutral/Feed.mjs +23 -19
- package/dist/lib/neutral/Filter.mjs +13 -15
- package/dist/lib/neutral/Format.mjs +23 -3
- package/dist/lib/neutral/JsonSchema.mjs +7 -8
- package/dist/lib/neutral/Key.mjs +9 -5
- package/dist/lib/neutral/Migration.mjs +11 -10
- package/dist/lib/neutral/Obj.mjs +29 -20
- package/dist/lib/neutral/Order.mjs +7 -3
- package/dist/lib/neutral/Query.mjs +17 -17
- package/dist/lib/neutral/QueryResult.mjs +1 -1
- package/dist/lib/neutral/Ref.mjs +10 -9
- package/dist/lib/neutral/Registry.mjs +14 -0
- package/dist/lib/neutral/Relation.mjs +28 -25
- package/dist/lib/neutral/Scope.mjs +12 -0
- package/dist/lib/neutral/Tag.mjs +17 -14
- package/dist/lib/neutral/Type.mjs +54 -26
- package/dist/lib/neutral/{chunk-OMUPQMLR.mjs → chunk-35INCYOE.mjs} +1 -1
- package/dist/lib/neutral/chunk-35INCYOE.mjs.map +7 -0
- package/dist/lib/neutral/chunk-3PBP4V4O.mjs +101 -0
- package/dist/lib/neutral/chunk-3PBP4V4O.mjs.map +7 -0
- package/dist/lib/neutral/chunk-4ZUHOTCG.mjs +184 -0
- package/dist/lib/neutral/chunk-4ZUHOTCG.mjs.map +7 -0
- package/dist/lib/neutral/chunk-5SMDBFVB.mjs +108 -0
- package/dist/lib/neutral/chunk-5SMDBFVB.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-OS35K56T.mjs → chunk-5SUJPHAE.mjs} +3 -3
- package/dist/lib/neutral/{chunk-OS35K56T.mjs.map → chunk-5SUJPHAE.mjs.map} +2 -2
- package/dist/lib/neutral/{chunk-GZQTCRJB.mjs → chunk-6M2Z6WBH.mjs} +22 -2
- package/dist/lib/neutral/chunk-6M2Z6WBH.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-V36VO5SS.mjs → chunk-6YDI3J37.mjs} +32 -40
- package/dist/lib/neutral/chunk-6YDI3J37.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-MOR5ERFM.mjs → chunk-7FPIAJIV.mjs} +701 -1256
- package/dist/lib/neutral/chunk-7FPIAJIV.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-ANHVGJI4.mjs → chunk-7LOUAPYZ.mjs} +9 -5
- package/dist/lib/neutral/chunk-7LOUAPYZ.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-JUXPFOEI.mjs → chunk-7PI7C4EF.mjs} +48 -88
- package/dist/lib/neutral/chunk-7PI7C4EF.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-UBEZSGXY.mjs → chunk-BBFJWWAV.mjs} +6 -6
- package/dist/lib/neutral/chunk-BBFJWWAV.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-UI6MWK5W.mjs → chunk-EVK6XBXO.mjs} +16 -2
- package/dist/lib/neutral/chunk-EVK6XBXO.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-7RO7CPBZ.mjs → chunk-IGK6FN65.mjs} +2 -2
- package/dist/lib/neutral/{chunk-HBUZJNZO.mjs → chunk-LWXVKPPW.mjs} +94 -99
- package/dist/lib/neutral/chunk-LWXVKPPW.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-BVOFLCVF.mjs → chunk-MZ7K3MLL.mjs} +9 -6
- package/dist/lib/neutral/chunk-MZ7K3MLL.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-TBKX6JQO.mjs → chunk-O6BH7EPN.mjs} +30 -3
- package/dist/lib/neutral/chunk-O6BH7EPN.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-EAMSSLZC.mjs → chunk-QQIYS74I.mjs} +83 -46
- package/dist/lib/neutral/chunk-QQIYS74I.mjs.map +7 -0
- package/dist/lib/neutral/chunk-R5W6DXR4.mjs +678 -0
- package/dist/lib/neutral/chunk-R5W6DXR4.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-WAK4DMFV.mjs → chunk-RIVWNMSF.mjs} +12 -7
- package/dist/lib/neutral/chunk-RIVWNMSF.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-T6W2LEZU.mjs → chunk-SBVFRTST.mjs} +73 -38
- package/dist/lib/neutral/chunk-SBVFRTST.mjs.map +7 -0
- package/dist/lib/neutral/chunk-T6E37YIP.mjs +251 -0
- package/dist/lib/neutral/chunk-T6E37YIP.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-DQYLD2RB.mjs → chunk-TFEWTY5A.mjs} +155 -129
- package/dist/lib/neutral/chunk-TFEWTY5A.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-B4BASU6W.mjs → chunk-TYGKCRMK.mjs} +85 -76
- package/dist/lib/neutral/chunk-TYGKCRMK.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-4OIBYSXE.mjs → chunk-UUP46KUQ.mjs} +78 -32
- package/dist/lib/neutral/chunk-UUP46KUQ.mjs.map +7 -0
- package/dist/lib/neutral/chunk-WISOH2XH.mjs +36 -0
- package/dist/lib/neutral/chunk-WISOH2XH.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-G3IQMKF7.mjs → chunk-WTQJHC75.mjs} +111 -112
- package/dist/lib/neutral/chunk-WTQJHC75.mjs.map +7 -0
- package/dist/lib/neutral/chunk-WU3GIANS.mjs +31 -0
- package/dist/lib/neutral/chunk-WU3GIANS.mjs.map +7 -0
- package/dist/lib/neutral/{chunk-TU3GW67D.mjs → chunk-ZGNNFYHS.mjs} +40 -40
- package/dist/lib/neutral/chunk-ZGNNFYHS.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +47 -41
- package/dist/lib/neutral/internal/index.mjs +137 -72
- package/dist/lib/neutral/meta.json +1 -1
- package/dist/lib/neutral/testing/index.mjs +261 -178
- package/dist/lib/neutral/testing/index.mjs.map +4 -4
- package/dist/types/src/Annotation.d.ts +108 -4
- package/dist/types/src/Annotation.d.ts.map +1 -1
- package/dist/types/src/Annotation.test.d.ts +2 -0
- package/dist/types/src/Annotation.test.d.ts.map +1 -0
- package/dist/types/src/Collection.d.ts +2 -3
- package/dist/types/src/Collection.d.ts.map +1 -1
- package/dist/types/src/Database.d.ts +56 -49
- package/dist/types/src/Database.d.ts.map +1 -1
- package/dist/types/src/Dataset.d.ts +16 -6
- package/dist/types/src/Dataset.d.ts.map +1 -1
- package/dist/types/src/Entity.d.ts +101 -28
- package/dist/types/src/Entity.d.ts.map +1 -1
- package/dist/types/src/Err.d.ts +27 -27
- package/dist/types/src/Err.d.ts.map +1 -1
- package/dist/types/src/Feed.d.ts +66 -19
- package/dist/types/src/Feed.d.ts.map +1 -1
- package/dist/types/src/Filter.d.ts +38 -12
- package/dist/types/src/Filter.d.ts.map +1 -1
- package/dist/types/src/Format.d.ts +0 -2
- package/dist/types/src/Format.d.ts.map +1 -1
- package/dist/types/src/Hypergraph.d.ts +14 -9
- package/dist/types/src/Hypergraph.d.ts.map +1 -1
- package/dist/types/src/Json.d.ts +33 -0
- package/dist/types/src/Json.d.ts.map +1 -0
- package/dist/types/src/Json.test.d.ts +2 -0
- package/dist/types/src/Json.test.d.ts.map +1 -0
- package/dist/types/src/JsonSchema.d.ts +2 -2
- package/dist/types/src/JsonSchema.d.ts.map +1 -1
- package/dist/types/src/Key.d.ts +1 -1
- package/dist/types/src/Key.d.ts.map +1 -1
- package/dist/types/src/Migration.d.ts +26 -11
- package/dist/types/src/Migration.d.ts.map +1 -1
- package/dist/types/src/Obj.d.ts +104 -61
- package/dist/types/src/Obj.d.ts.map +1 -1
- package/dist/types/src/Order.d.ts +10 -0
- package/dist/types/src/Order.d.ts.map +1 -1
- package/dist/types/src/Query.d.ts +34 -12
- package/dist/types/src/Query.d.ts.map +1 -1
- package/dist/types/src/QueryResult.d.ts +21 -0
- package/dist/types/src/QueryResult.d.ts.map +1 -1
- package/dist/types/src/Ref.d.ts +15 -7
- package/dist/types/src/Ref.d.ts.map +1 -1
- package/dist/types/src/Registry.d.ts +131 -0
- package/dist/types/src/Registry.d.ts.map +1 -0
- package/dist/types/src/Relation.d.ts +73 -41
- package/dist/types/src/Relation.d.ts.map +1 -1
- package/dist/types/src/Scope.d.ts +35 -0
- package/dist/types/src/Scope.d.ts.map +1 -0
- package/dist/types/src/Tag.d.ts +21 -5
- package/dist/types/src/Tag.d.ts.map +1 -1
- package/dist/types/src/Type.d.ts +362 -95
- package/dist/types/src/Type.d.ts.map +1 -1
- package/dist/types/src/View.d.ts +9 -12
- package/dist/types/src/View.d.ts.map +1 -1
- package/dist/types/src/exemplars.test.d.ts +2 -0
- package/dist/types/src/exemplars.test.d.ts.map +1 -0
- package/dist/types/src/index.d.ts +4 -3
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/internal/Annotation/annotations.d.ts +79 -38
- package/dist/types/src/internal/Annotation/annotations.d.ts.map +1 -1
- package/dist/types/src/internal/Annotation/dictionary.d.ts +24 -0
- package/dist/types/src/internal/Annotation/dictionary.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/entity-dictionary.d.ts +14 -0
- package/dist/types/src/internal/Annotation/entity-dictionary.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/index.d.ts +4 -2
- package/dist/types/src/internal/Annotation/index.d.ts.map +1 -1
- package/dist/types/src/internal/Annotation/sorting.d.ts.map +1 -1
- package/dist/types/src/internal/Annotation/util.d.ts +14 -5
- package/dist/types/src/internal/Annotation/util.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/api.d.ts +17 -3
- package/dist/types/src/internal/Entity/api.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/entity.d.ts +72 -8
- package/dist/types/src/internal/Entity/entity.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/guard.d.ts +10 -0
- package/dist/types/src/internal/Entity/guard.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/index.d.ts +2 -0
- package/dist/types/src/internal/Entity/index.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/model.d.ts +21 -17
- package/dist/types/src/internal/Entity/model.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/object.d.ts +3 -3
- package/dist/types/src/internal/Entity/object.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/relation.d.ts +30 -7
- package/dist/types/src/internal/Entity/relation.d.ts.map +1 -1
- package/dist/types/src/internal/Entity/type-kind.d.ts +24 -0
- package/dist/types/src/internal/Entity/type-kind.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/type-uri.d.ts +24 -0
- package/dist/types/src/internal/Entity/type-uri.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/version.d.ts.map +1 -1
- package/dist/types/src/internal/Format/date.d.ts.map +1 -1
- package/dist/types/src/internal/Format/format.d.ts +3 -2
- package/dist/types/src/internal/Format/format.d.ts.map +1 -1
- package/dist/types/src/internal/Format/index.d.ts +2 -2
- package/dist/types/src/internal/Format/index.d.ts.map +1 -1
- package/dist/types/src/internal/Format/number.d.ts.map +1 -1
- package/dist/types/src/internal/Format/object.d.ts +3 -1
- package/dist/types/src/internal/Format/object.d.ts.map +1 -1
- package/dist/types/src/internal/Format/types.d.ts.map +1 -1
- package/dist/types/src/internal/JsonSchema/json-schema-normalize.d.ts.map +1 -1
- package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts +34 -34
- package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts.map +1 -1
- package/dist/types/src/internal/JsonSchema/json-schema.d.ts +3 -2
- package/dist/types/src/internal/JsonSchema/json-schema.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/atoms.d.ts +38 -0
- package/dist/types/src/internal/Obj/atoms.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/clone.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/common.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/create-object.d.ts +12 -12
- package/dist/types/src/internal/Obj/create-object.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/deleted.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/index.d.ts +1 -1
- package/dist/types/src/internal/Obj/index.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/json-serializer.d.ts +8 -8
- package/dist/types/src/internal/Obj/json-serializer.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/set-value.d.ts +1 -1
- package/dist/types/src/internal/Obj/set-value.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/snapshot.d.ts.map +1 -1
- package/dist/types/src/internal/Obj/typed-object.d.ts +1 -1
- 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.d.ts → Query/pretty.d.ts} +1 -1
- package/dist/types/src/internal/Query/pretty.d.ts.map +1 -0
- package/dist/types/src/internal/Ref/atoms.d.ts +10 -0
- package/dist/types/src/internal/Ref/atoms.d.ts.map +1 -0
- package/dist/types/src/internal/Ref/ref-array.d.ts +2 -2
- package/dist/types/src/internal/Ref/ref.d.ts +50 -19
- package/dist/types/src/internal/Ref/ref.d.ts.map +1 -1
- package/dist/types/src/internal/Ref/utils.d.ts +8 -0
- package/dist/types/src/internal/Ref/utils.d.ts.map +1 -0
- package/dist/types/src/internal/Type/compose.d.ts.map +1 -1
- package/dist/types/src/internal/Type/index.d.ts +1 -2
- package/dist/types/src/internal/Type/index.d.ts.map +1 -1
- package/dist/types/src/internal/Type/manipulation.d.ts +0 -1
- package/dist/types/src/internal/Type/manipulation.d.ts.map +1 -1
- package/dist/types/src/internal/Type/type-schema.d.ts +52 -0
- package/dist/types/src/internal/Type/type-schema.d.ts.map +1 -0
- package/dist/types/src/internal/common/api/meta.d.ts +14 -11
- package/dist/types/src/internal/common/api/meta.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/change-context.d.ts +1 -1
- package/dist/types/src/internal/common/proxy/change-context.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/errors.d.ts +1 -1
- package/dist/types/src/internal/common/proxy/errors.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/event-batch.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/json-serializer.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/make-object.d.ts +11 -5
- package/dist/types/src/internal/common/proxy/make-object.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/ownership.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/proxy-utils.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/reactive-array.d.ts +1 -1
- package/dist/types/src/internal/common/proxy/reactive.d.ts +1 -1
- package/dist/types/src/internal/common/proxy/reactive.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/reactive.test.d.ts +2 -0
- package/dist/types/src/internal/common/proxy/reactive.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/schema-validator.d.ts.map +1 -1
- package/dist/types/src/internal/common/proxy/typed-handler.d.ts +18 -2
- package/dist/types/src/internal/common/proxy/typed-handler.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/base.d.ts +4 -4
- package/dist/types/src/internal/common/types/base.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/entity.d.ts +62 -5
- package/dist/types/src/internal/common/types/entity.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/index.d.ts +1 -1
- package/dist/types/src/internal/common/types/index.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/meta.d.ts +33 -12
- package/dist/types/src/internal/common/types/meta.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/model-symbols.d.ts +15 -4
- package/dist/types/src/internal/common/types/model-symbols.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/typename.d.ts +7 -0
- package/dist/types/src/internal/common/types/typename.d.ts.map +1 -1
- package/dist/types/src/internal/common/types/version.d.ts +1 -1
- package/dist/types/src/internal/common/types/well-known-types.d.ts +11 -0
- package/dist/types/src/internal/common/types/well-known-types.d.ts.map +1 -0
- package/dist/types/src/internal/index.d.ts +2 -2
- package/dist/types/src/internal/index.d.ts.map +1 -1
- package/dist/types/src/testing/index.d.ts +1 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/registry.d.ts +9 -0
- package/dist/types/src/testing/registry.d.ts.map +1 -0
- package/dist/types/src/testing/test-data.d.ts +8 -8
- package/dist/types/src/testing/test-data.d.ts.map +1 -1
- package/dist/types/src/testing/test-schema.d.ts +83 -89
- package/dist/types/src/testing/test-schema.d.ts.map +1 -1
- package/dist/types/src/testing/util.d.ts +5 -3
- package/dist/types/src/testing/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +26 -24
- package/src/Annotation.test.ts +439 -0
- package/src/Annotation.ts +158 -4
- package/src/Collection.ts +5 -9
- package/src/Database.ts +93 -100
- package/src/Dataset.ts +10 -2
- package/src/Entity.test.ts +116 -6
- package/src/Entity.ts +134 -32
- package/src/Err.ts +4 -4
- package/src/Feed.ts +92 -44
- package/src/Filter.ts +70 -40
- package/src/Format.ts +0 -4
- package/src/Hypergraph.ts +14 -9
- package/src/Json.test.ts +175 -0
- package/src/Json.ts +103 -0
- package/src/Key.ts +1 -1
- package/src/Migration.ts +39 -19
- package/src/Obj.test.ts +122 -20
- package/src/Obj.ts +168 -91
- package/src/Order.ts +22 -0
- package/src/Query.test.ts +183 -154
- package/src/Query.ts +172 -85
- package/src/QueryResult.ts +26 -0
- package/src/Ref.ts +22 -4
- package/src/Registry.ts +155 -0
- package/src/Relation.test.ts +10 -10
- package/src/Relation.ts +116 -69
- package/src/Scope.ts +50 -0
- package/src/Tag.md +88 -0
- package/src/Tag.ts +49 -6
- package/src/Type.test.ts +223 -18
- package/src/Type.ts +609 -131
- package/src/View.ts +14 -23
- package/src/exemplars.test.ts +21 -0
- package/src/index.ts +4 -4
- package/src/internal/Annotation/annotations.test.ts +31 -11
- package/src/internal/Annotation/annotations.ts +143 -111
- package/src/internal/Annotation/dictionary.ts +47 -0
- package/src/internal/Annotation/entity-dictionary.ts +74 -0
- package/src/internal/Annotation/index.ts +4 -2
- package/src/internal/Annotation/util.ts +17 -8
- package/src/internal/Entity/api.ts +54 -7
- package/src/internal/Entity/entity.ts +196 -47
- package/src/internal/Entity/guard.ts +26 -0
- package/src/internal/Entity/index.ts +2 -0
- package/src/internal/Entity/model.ts +38 -28
- package/src/internal/Entity/object.ts +21 -5
- package/src/internal/Entity/relation.ts +68 -34
- package/src/internal/Entity/type-kind.ts +75 -0
- package/src/internal/Entity/type-uri.ts +92 -0
- package/src/internal/Entity/util.ts +9 -9
- package/src/internal/Format/date.ts +0 -4
- package/src/internal/Format/format.test.ts +21 -0
- package/src/internal/Format/index.ts +2 -3
- package/src/internal/Format/object.ts +21 -4
- package/src/internal/Format/types.ts +1 -1
- package/src/internal/JsonSchema/annotations.ts +1 -1
- package/src/internal/JsonSchema/json-schema-type.ts +4 -4
- package/src/internal/JsonSchema/json-schema.test.ts +71 -145
- package/src/internal/JsonSchema/json-schema.ts +49 -35
- package/src/internal/Obj/atoms.ts +244 -0
- package/src/internal/Obj/clone.ts +9 -4
- package/src/internal/Obj/create-object.test.ts +12 -10
- package/src/internal/Obj/create-object.ts +68 -22
- package/src/internal/Obj/index.ts +1 -1
- package/src/internal/Obj/inspect.ts +5 -3
- package/src/internal/Obj/json-serializer.test.ts +101 -22
- package/src/internal/Obj/json-serializer.ts +89 -33
- package/src/internal/Obj/set-value.test.ts +22 -45
- package/src/internal/Obj/set-value.ts +12 -19
- package/src/internal/Obj/snapshot.ts +13 -4
- package/src/internal/Obj/typed-object.test.ts +9 -11
- package/src/internal/Obj/typed-object.ts +1 -1
- package/src/internal/Query/index.ts +5 -0
- package/src/internal/{Query.ts → Query/pretty.ts} +40 -12
- package/src/internal/Ref/atoms.ts +20 -0
- package/src/internal/Ref/ref-array.ts +3 -3
- package/src/internal/Ref/ref.test.ts +18 -27
- package/src/internal/Ref/ref.ts +137 -59
- package/src/internal/Ref/utils.ts +45 -0
- package/src/internal/Type/compose.test.ts +3 -1
- package/src/internal/Type/index.ts +1 -2
- package/src/internal/Type/manipulation.ts +0 -25
- package/src/internal/Type/type-schema.ts +60 -0
- package/src/internal/common/README.md +2 -2
- package/src/internal/common/api/meta.ts +19 -17
- package/src/internal/common/proxy/change-context.ts +1 -1
- package/src/internal/common/proxy/change.test.ts +91 -83
- package/src/internal/common/proxy/errors.ts +2 -2
- package/src/internal/common/proxy/handler.test.ts +1 -1
- package/src/internal/common/proxy/json-serializer.ts +27 -16
- package/src/internal/common/proxy/make-object.ts +44 -20
- package/src/internal/common/proxy/ownership.ts +2 -2
- package/src/internal/common/proxy/reactive-array.ts +1 -1
- package/src/internal/common/proxy/reactive.test.ts +54 -0
- package/src/internal/common/proxy/reactive.ts +11 -2
- package/src/internal/common/proxy/schema.test.ts +48 -86
- package/src/internal/common/proxy/typed-handler.test.ts +12 -11
- package/src/internal/common/proxy/typed-handler.ts +78 -16
- package/src/internal/common/proxy/typed-object.test.ts +16 -28
- package/src/internal/common/types/base.ts +4 -4
- package/src/internal/common/types/entity.ts +80 -1
- package/src/internal/common/types/index.ts +6 -1
- package/src/internal/common/types/meta.ts +62 -20
- package/src/internal/common/types/model-symbols.ts +24 -4
- package/src/internal/common/types/typename.ts +39 -3
- package/src/internal/common/types/well-known-types.ts +15 -0
- package/src/internal/index.ts +6 -4
- package/src/testing/api.test.ts +15 -9
- package/src/testing/index.ts +1 -0
- package/src/testing/registry.ts +44 -0
- package/src/testing/test-data.ts +159 -99
- package/src/testing/test-schema.ts +22 -58
- package/src/testing/util.ts +14 -11
- package/dist/lib/neutral/Extension.mjs +0 -18
- package/dist/lib/neutral/SchemaRegistry.mjs +0 -2
- package/dist/lib/neutral/chunk-2KHZ36F5.mjs +0 -361
- package/dist/lib/neutral/chunk-2KHZ36F5.mjs.map +0 -7
- package/dist/lib/neutral/chunk-4OIBYSXE.mjs.map +0 -7
- package/dist/lib/neutral/chunk-4P3IXBLT.mjs +0 -45
- package/dist/lib/neutral/chunk-4P3IXBLT.mjs.map +0 -7
- package/dist/lib/neutral/chunk-ANHVGJI4.mjs.map +0 -7
- package/dist/lib/neutral/chunk-B4BASU6W.mjs.map +0 -7
- package/dist/lib/neutral/chunk-BNCCGLJN.mjs +0 -7
- package/dist/lib/neutral/chunk-BNCCGLJN.mjs.map +0 -7
- package/dist/lib/neutral/chunk-BVOFLCVF.mjs.map +0 -7
- package/dist/lib/neutral/chunk-DQYLD2RB.mjs.map +0 -7
- package/dist/lib/neutral/chunk-EAMSSLZC.mjs.map +0 -7
- package/dist/lib/neutral/chunk-G3IQMKF7.mjs.map +0 -7
- package/dist/lib/neutral/chunk-GZQTCRJB.mjs.map +0 -7
- package/dist/lib/neutral/chunk-HBUZJNZO.mjs.map +0 -7
- package/dist/lib/neutral/chunk-JUXPFOEI.mjs.map +0 -7
- package/dist/lib/neutral/chunk-MOR5ERFM.mjs.map +0 -7
- package/dist/lib/neutral/chunk-OMUPQMLR.mjs.map +0 -7
- package/dist/lib/neutral/chunk-PHU22NLC.mjs +0 -136
- package/dist/lib/neutral/chunk-PHU22NLC.mjs.map +0 -7
- package/dist/lib/neutral/chunk-ROG4RXXL.mjs +0 -97
- package/dist/lib/neutral/chunk-ROG4RXXL.mjs.map +0 -7
- package/dist/lib/neutral/chunk-T6W2LEZU.mjs.map +0 -7
- package/dist/lib/neutral/chunk-TBKX6JQO.mjs.map +0 -7
- package/dist/lib/neutral/chunk-TU3GW67D.mjs.map +0 -7
- package/dist/lib/neutral/chunk-UBEZSGXY.mjs.map +0 -7
- package/dist/lib/neutral/chunk-UI6MWK5W.mjs.map +0 -7
- package/dist/lib/neutral/chunk-V36VO5SS.mjs.map +0 -7
- package/dist/lib/neutral/chunk-WAK4DMFV.mjs.map +0 -7
- package/dist/lib/neutral/chunk-YAHXAYOW.mjs +0 -56
- package/dist/lib/neutral/chunk-YAHXAYOW.mjs.map +0 -7
- package/dist/lib/neutral/chunk-YS6Q3XAD.mjs +0 -50
- package/dist/lib/neutral/chunk-YS6Q3XAD.mjs.map +0 -7
- package/dist/types/src/Extension.d.ts +0 -80
- package/dist/types/src/Extension.d.ts.map +0 -1
- package/dist/types/src/Extension.test.d.ts +0 -2
- package/dist/types/src/Extension.test.d.ts.map +0 -1
- package/dist/types/src/SchemaRegistry.d.ts +0 -84
- package/dist/types/src/SchemaRegistry.d.ts.map +0 -1
- package/dist/types/src/internal/Obj/ids.d.ts +0 -6
- package/dist/types/src/internal/Obj/ids.d.ts.map +0 -1
- package/dist/types/src/internal/Query.d.ts.map +0 -1
- package/dist/types/src/internal/Type/echo-schema.d.ts +0 -181
- package/dist/types/src/internal/Type/echo-schema.d.ts.map +0 -1
- package/dist/types/src/internal/Type/persistent-schema.d.ts +0 -20
- package/dist/types/src/internal/Type/persistent-schema.d.ts.map +0 -1
- package/src/Extension.test.ts +0 -235
- package/src/Extension.ts +0 -122
- package/src/SchemaRegistry.ts +0 -106
- package/src/internal/Obj/ids.ts +0 -12
- package/src/internal/Type/echo-schema.ts +0 -423
- package/src/internal/Type/persistent-schema.ts +0 -33
- /package/dist/lib/neutral/{Extension.mjs.map → Registry.mjs.map} +0 -0
- /package/dist/lib/neutral/{SchemaRegistry.mjs.map → Scope.mjs.map} +0 -0
- /package/dist/lib/neutral/{chunk-7RO7CPBZ.mjs.map → chunk-IGK6FN65.mjs.map} +0 -0
|
@@ -6,14 +6,7 @@ import * as Match from 'effect/Match';
|
|
|
6
6
|
import * as Option from 'effect/Option';
|
|
7
7
|
import * as SchemaAST from 'effect/SchemaAST';
|
|
8
8
|
|
|
9
|
-
import {
|
|
10
|
-
type SchemaProperty,
|
|
11
|
-
getArrayElementType,
|
|
12
|
-
getBaseType,
|
|
13
|
-
getProperties,
|
|
14
|
-
isArrayType,
|
|
15
|
-
isNestedType,
|
|
16
|
-
} from '@dxos/effect';
|
|
9
|
+
import { SchemaEx } from '@dxos/effect';
|
|
17
10
|
import { invariant } from '@dxos/invariant';
|
|
18
11
|
|
|
19
12
|
import { type Mutable } from '../common/proxy';
|
|
@@ -21,7 +14,7 @@ import { getSchema } from '../common/types';
|
|
|
21
14
|
|
|
22
15
|
/**
|
|
23
16
|
* Set a deeply nested property on an object.
|
|
24
|
-
* Must be called within an Obj.
|
|
17
|
+
* Must be called within an Obj.update or Relation.update callback.
|
|
25
18
|
*/
|
|
26
19
|
export const setValue = (obj: Mutable<any>, path: readonly (string | number)[], value: any): void => {
|
|
27
20
|
invariant(path.length > 0, 'Path must not be empty');
|
|
@@ -38,7 +31,7 @@ export const setValue = (obj: Mutable<any>, path: readonly (string | number)[],
|
|
|
38
31
|
const key = typeof part === 'number' ? part : String(part);
|
|
39
32
|
if (parent[key] === undefined) {
|
|
40
33
|
const propertyAST = getPropertyAST(currentAST, String(part));
|
|
41
|
-
const shouldBeArray = propertyAST ? isArrayType(propertyAST) : false;
|
|
34
|
+
const shouldBeArray = propertyAST ? SchemaEx.isArrayType(propertyAST) : false;
|
|
42
35
|
|
|
43
36
|
if (shouldBeArray) {
|
|
44
37
|
// Create array.
|
|
@@ -73,16 +66,16 @@ const getPropertyAST = (ast: SchemaAST.AST | undefined, propertyName: string): S
|
|
|
73
66
|
return undefined;
|
|
74
67
|
}
|
|
75
68
|
|
|
76
|
-
if (isNestedType(ast)) {
|
|
77
|
-
const properties = getProperties(ast);
|
|
69
|
+
if (SchemaEx.isNestedType(ast)) {
|
|
70
|
+
const properties = SchemaEx.getProperties(ast);
|
|
78
71
|
const property = properties.find((p) => p.name.toString() === propertyName);
|
|
79
72
|
if (property) {
|
|
80
|
-
return getBaseType(property).type;
|
|
73
|
+
return SchemaEx.getBaseType(property).type;
|
|
81
74
|
}
|
|
82
75
|
}
|
|
83
76
|
|
|
84
|
-
if (isArrayType(ast)) {
|
|
85
|
-
const elementType = getArrayElementType(ast);
|
|
77
|
+
if (SchemaEx.isArrayType(ast)) {
|
|
78
|
+
const elementType = SchemaEx.getArrayElementType(ast);
|
|
86
79
|
return elementType;
|
|
87
80
|
}
|
|
88
81
|
|
|
@@ -96,17 +89,17 @@ const getPropertyAST = (ast: SchemaAST.AST | undefined, propertyName: string): S
|
|
|
96
89
|
* @param ast - Schema AST to inspect.
|
|
97
90
|
* @returns Array of required properties with their types.
|
|
98
91
|
*/
|
|
99
|
-
const getRequiredProperties = (ast: SchemaAST.AST | undefined): SchemaProperty[] => {
|
|
92
|
+
const getRequiredProperties = (ast: SchemaAST.AST | undefined): SchemaEx.SchemaProperty[] => {
|
|
100
93
|
if (!ast) {
|
|
101
94
|
return [];
|
|
102
95
|
}
|
|
103
96
|
|
|
104
97
|
// Only objects/structs have properties with optional/required distinction.
|
|
105
|
-
if (!isNestedType(ast)) {
|
|
98
|
+
if (!SchemaEx.isNestedType(ast)) {
|
|
106
99
|
return [];
|
|
107
100
|
}
|
|
108
101
|
|
|
109
|
-
const properties = getProperties(ast);
|
|
102
|
+
const properties = SchemaEx.getProperties(ast);
|
|
110
103
|
|
|
111
104
|
// Filter to only required properties (where isOptional === false).
|
|
112
105
|
return properties.filter((p) => !p.isOptional);
|
|
@@ -156,7 +149,7 @@ const createObjectWithDefaults = (ast: SchemaAST.AST | undefined): any => {
|
|
|
156
149
|
const defaultValue = getDefaultValueForType(prop.type);
|
|
157
150
|
if (defaultValue !== undefined) {
|
|
158
151
|
obj[prop.name] = defaultValue;
|
|
159
|
-
} else if (isNestedType(prop.type)) {
|
|
152
|
+
} else if (SchemaEx.isNestedType(prop.type)) {
|
|
160
153
|
obj[prop.name] = createObjectWithDefaults(prop.type);
|
|
161
154
|
}
|
|
162
155
|
}
|
|
@@ -7,18 +7,20 @@ import { deepMapValues } from '@dxos/util';
|
|
|
7
7
|
|
|
8
8
|
import {
|
|
9
9
|
KindId,
|
|
10
|
-
MetaId,
|
|
11
10
|
ObjectDatabaseId,
|
|
12
11
|
ObjectDeletedId,
|
|
12
|
+
ParentId,
|
|
13
13
|
RelationSourceDXNId,
|
|
14
14
|
RelationSourceId,
|
|
15
15
|
RelationTargetDXNId,
|
|
16
16
|
RelationTargetId,
|
|
17
17
|
SchemaId,
|
|
18
|
-
|
|
18
|
+
SelfURIId,
|
|
19
19
|
SnapshotKindId,
|
|
20
|
+
TypeEntityId,
|
|
20
21
|
TypeId,
|
|
21
22
|
} from '../common/types';
|
|
23
|
+
import { MetaId } from '../common/types/model-symbols';
|
|
22
24
|
|
|
23
25
|
/**
|
|
24
26
|
* Copy a Symbol-keyed property from source to target if it has a defined value.
|
|
@@ -83,16 +85,23 @@ export const getSnapshot = <T extends object>(obj: T): T => {
|
|
|
83
85
|
// Type introspection symbols.
|
|
84
86
|
copySymbolProperty(source, snapshot, TypeId);
|
|
85
87
|
copySymbolProperty(source, snapshot, SchemaId);
|
|
86
|
-
copySymbolProperty(source, snapshot,
|
|
88
|
+
copySymbolProperty(source, snapshot, TypeEntityId);
|
|
89
|
+
copySymbolProperty(source, snapshot, SelfURIId);
|
|
87
90
|
|
|
88
91
|
// Database reference (required for Obj.getDatabase to work on snapshots).
|
|
89
92
|
copySymbolProperty(source, snapshot, ObjectDatabaseId);
|
|
90
93
|
copySymbolProperty(source, snapshot, ObjectDeletedId);
|
|
91
94
|
|
|
92
|
-
//
|
|
95
|
+
// Parent reference (required for Obj.getParent to work on snapshots).
|
|
96
|
+
copySymbolProperty(source, snapshot, ParentId);
|
|
97
|
+
|
|
98
|
+
// Metadata symbol. Copy arrays/objects so the snapshot is not affected by mutations to the live meta.
|
|
93
99
|
copySymbolProperty(source, snapshot, MetaId, (meta: any) => ({
|
|
94
100
|
keys: [...(meta?.keys ?? [])],
|
|
95
101
|
tags: [...(meta?.tags ?? [])],
|
|
102
|
+
...(meta?.key != null ? { key: meta.key } : {}),
|
|
103
|
+
...(meta?.version != null ? { version: meta.version } : {}),
|
|
104
|
+
...(meta?.annotations ? { annotations: { ...meta.annotations } } : {}),
|
|
96
105
|
}));
|
|
97
106
|
|
|
98
107
|
// Relation endpoint symbols.
|
|
@@ -6,29 +6,27 @@ import * as Schema from 'effect/Schema';
|
|
|
6
6
|
import * as SchemaAST from 'effect/SchemaAST';
|
|
7
7
|
import { describe, expect, test } from 'vitest';
|
|
8
8
|
|
|
9
|
+
import { DXN } from '@dxos/keys';
|
|
10
|
+
|
|
11
|
+
import * as Type from '../../Type';
|
|
9
12
|
import { EchoObjectSchema } from '../Entity';
|
|
10
13
|
|
|
11
14
|
const Organization = Schema.Struct({
|
|
12
15
|
name: Schema.String,
|
|
13
|
-
}).pipe(
|
|
14
|
-
EchoObjectSchema({
|
|
15
|
-
typename: 'com.example.type.organization',
|
|
16
|
-
version: '0.1.0',
|
|
17
|
-
}),
|
|
18
|
-
);
|
|
16
|
+
}).pipe(EchoObjectSchema(DXN.make('com.example.type.organization', '0.1.0')));
|
|
19
17
|
|
|
20
|
-
|
|
18
|
+
type Organization = Type.InstanceType<typeof Organization>;
|
|
21
19
|
|
|
22
20
|
describe('EchoObjectSchema DSL', () => {
|
|
23
|
-
test('type is a
|
|
24
|
-
expect(Schema.isSchema(Organization)).to.be.true;
|
|
21
|
+
test('type is a Type.Type entity', async () => {
|
|
22
|
+
expect(Schema.isSchema(Type.getSchema(Organization))).to.be.true;
|
|
25
23
|
});
|
|
26
24
|
|
|
27
25
|
test('static typename accessor', async () => {
|
|
28
|
-
expect(Organization
|
|
26
|
+
expect(Type.getTypename(Organization)).to.eq('com.example.type.organization');
|
|
29
27
|
});
|
|
30
28
|
|
|
31
29
|
test('expect schema', async () => {
|
|
32
|
-
expect(SchemaAST.isTypeLiteral(Organization.ast)).to.be.true;
|
|
30
|
+
expect(SchemaAST.isTypeLiteral(Type.getSchema(Organization).ast)).to.be.true;
|
|
33
31
|
});
|
|
34
32
|
});
|
|
@@ -12,7 +12,7 @@ import { type AnyEntity } from '../common/types';
|
|
|
12
12
|
* Implements effect schema to define object properties.
|
|
13
13
|
* Has a typename and version.
|
|
14
14
|
*
|
|
15
|
-
* In contrast to
|
|
15
|
+
* In contrast to a stored `Type.Type` entity, this definition is not recorded in the database.
|
|
16
16
|
*
|
|
17
17
|
* @deprecated Use `Type.AnyObj` from `@dxos/echo` instead.
|
|
18
18
|
*/
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//
|
|
2
|
-
// Copyright
|
|
2
|
+
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
import { type QueryAST } from '@dxos/echo-protocol';
|
|
@@ -10,6 +10,18 @@ import { type QueryAST } from '@dxos/echo-protocol';
|
|
|
10
10
|
export const prettyFilter = (filter: QueryAST.Filter): string => {
|
|
11
11
|
switch (filter.type) {
|
|
12
12
|
case 'object': {
|
|
13
|
+
// A type-less object filter with only a meta-key constraint is `Filter.key(...)`.
|
|
14
|
+
if (
|
|
15
|
+
filter.typename === null &&
|
|
16
|
+
(filter.id === undefined || filter.id.length === 0) &&
|
|
17
|
+
Object.keys(filter.props).length === 0 &&
|
|
18
|
+
(filter.foreignKeys === undefined || filter.foreignKeys.length === 0) &&
|
|
19
|
+
filter.metaKey !== undefined
|
|
20
|
+
) {
|
|
21
|
+
return filter.metaVersion !== undefined
|
|
22
|
+
? `Filter.key(${JSON.stringify(filter.metaKey)}, { version: ${JSON.stringify(filter.metaVersion)} })`
|
|
23
|
+
: `Filter.key(${JSON.stringify(filter.metaKey)})`;
|
|
24
|
+
}
|
|
13
25
|
const parts: string[] = [];
|
|
14
26
|
if (filter.typename !== null) {
|
|
15
27
|
parts.push(String(filter.typename));
|
|
@@ -25,6 +37,13 @@ export const prettyFilter = (filter: QueryAST.Filter): string => {
|
|
|
25
37
|
if (filter.foreignKeys !== undefined && filter.foreignKeys.length > 0) {
|
|
26
38
|
parts.push(`foreignKeys: [${filter.foreignKeys.map((fk) => JSON.stringify(fk)).join(', ')}]`);
|
|
27
39
|
}
|
|
40
|
+
if (filter.metaKey !== undefined) {
|
|
41
|
+
parts.push(
|
|
42
|
+
filter.metaVersion !== undefined
|
|
43
|
+
? `metaKey: ${JSON.stringify(filter.metaKey)} (${filter.metaVersion})`
|
|
44
|
+
: `metaKey: ${JSON.stringify(filter.metaKey)}`,
|
|
45
|
+
);
|
|
46
|
+
}
|
|
28
47
|
return parts.length > 0 ? `Filter.type(${parts.join(', ')})` : 'Filter.everything()';
|
|
29
48
|
}
|
|
30
49
|
case 'compare':
|
|
@@ -97,6 +116,9 @@ export const prettyQuery = (query: QueryAST.Query): string => {
|
|
|
97
116
|
return 'Order.natural()';
|
|
98
117
|
} else if (o.kind === 'rank') {
|
|
99
118
|
return `Order.rank(${JSON.stringify(o.direction)})`;
|
|
119
|
+
} else if (o.kind === 'timestamp') {
|
|
120
|
+
const fn = o.field === 'updatedAt' ? 'updated' : 'created';
|
|
121
|
+
return `Order.${fn}(${JSON.stringify(o.direction)})`;
|
|
100
122
|
} else {
|
|
101
123
|
return `Order.property(${JSON.stringify(o.property)}, ${JSON.stringify(o.direction)})`;
|
|
102
124
|
}
|
|
@@ -109,22 +131,28 @@ export const prettyQuery = (query: QueryAST.Query): string => {
|
|
|
109
131
|
if (opts.deleted !== undefined) {
|
|
110
132
|
parts.push(`deleted: ${JSON.stringify(opts.deleted)}`);
|
|
111
133
|
}
|
|
134
|
+
if (opts.debugLabel !== undefined) {
|
|
135
|
+
parts.push(`debugLabel: ${JSON.stringify(opts.debugLabel)}`);
|
|
136
|
+
}
|
|
112
137
|
return `${prettyQuery(query.query)}.options({ ${parts.join(', ')} })`;
|
|
113
138
|
}
|
|
114
139
|
case 'from': {
|
|
115
140
|
if (query.from._tag === 'scope') {
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
if (scope.spaceIds !== undefined) {
|
|
119
|
-
parts.push(`spaceIds: [${scope.spaceIds.map((s) => JSON.stringify(s)).join(', ')}]`);
|
|
120
|
-
}
|
|
121
|
-
if (scope.queues !== undefined) {
|
|
122
|
-
parts.push(`queues: [${scope.queues.map(String).join(', ')}]`);
|
|
123
|
-
}
|
|
124
|
-
if (scope.allQueuesFromSpaces !== undefined) {
|
|
125
|
-
parts.push(`allQueuesFromSpaces: ${scope.allQueuesFromSpaces}`);
|
|
141
|
+
if (query.from.scopes.length === 0) {
|
|
142
|
+
return `${prettyQuery(query.query)}.from('all-accessible-spaces')`;
|
|
126
143
|
}
|
|
127
|
-
|
|
144
|
+
const scopeStrs = query.from.scopes.map((scope) => {
|
|
145
|
+
if (scope._tag === 'space') {
|
|
146
|
+
return scope.includeAllFeeds
|
|
147
|
+
? `{ space: ${JSON.stringify(scope.spaceId)}, includeAllFeeds: true }`
|
|
148
|
+
: `{ space: ${JSON.stringify(scope.spaceId)} }`;
|
|
149
|
+
}
|
|
150
|
+
if (scope._tag === 'feed') {
|
|
151
|
+
return `{ feed: ${JSON.stringify(String(scope.feedUri))} }`;
|
|
152
|
+
}
|
|
153
|
+
return `{ registry: ${JSON.stringify(scope.location)} }`;
|
|
154
|
+
});
|
|
155
|
+
return `${prettyQuery(query.query)}.from([${scopeStrs.join(', ')}])`;
|
|
128
156
|
}
|
|
129
157
|
return `${prettyQuery(query.query)}.from(${prettyQuery(query.from.query)})`;
|
|
130
158
|
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Atom from '@effect-atom/atom/Atom';
|
|
6
|
+
|
|
7
|
+
import type { Ref } from './ref';
|
|
8
|
+
import { loadRefTarget } from './utils';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Atom family for ECHO refs.
|
|
12
|
+
* Uses ref reference as key — same ref returns same atom.
|
|
13
|
+
* This atom only updates once when the ref loads — it does not subscribe to target object changes.
|
|
14
|
+
* Use `Obj.atom(ref)` if you need reactive snapshots of ECHO objects via a ref.
|
|
15
|
+
*/
|
|
16
|
+
export const refSimpleFamily = Atom.family(<T>(ref: Ref<T>): Atom.Atom<T | undefined> => {
|
|
17
|
+
return Atom.make<T | undefined>((get) => {
|
|
18
|
+
return loadRefTarget(ref, get, (target) => target);
|
|
19
|
+
});
|
|
20
|
+
});
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { type
|
|
5
|
+
import { type EntityId } from '@dxos/keys';
|
|
6
6
|
import { isNonNullable } from '@dxos/util';
|
|
7
7
|
|
|
8
8
|
import { type AnyEntity } from '../common/types';
|
|
@@ -29,8 +29,8 @@ export const RefArray = Object.freeze({
|
|
|
29
29
|
/**
|
|
30
30
|
* Removes the ref with the given id.
|
|
31
31
|
*/
|
|
32
|
-
removeById: (refs: Ref<AnyEntity>[], id:
|
|
33
|
-
const index = refs.findIndex(Ref.
|
|
32
|
+
removeById: (refs: Ref<AnyEntity>[], id: EntityId) => {
|
|
33
|
+
const index = refs.findIndex(Ref.hasEntityId(id));
|
|
34
34
|
if (index >= 0) {
|
|
35
35
|
refs.splice(index, 1);
|
|
36
36
|
}
|
|
@@ -5,46 +5,37 @@
|
|
|
5
5
|
import * as Schema from 'effect/Schema';
|
|
6
6
|
import { describe, expect, test } from 'vitest';
|
|
7
7
|
|
|
8
|
-
import {
|
|
8
|
+
import { EID, EntityId, DXN } from '@dxos/keys';
|
|
9
9
|
|
|
10
|
-
import
|
|
10
|
+
import * as Type from '../../Type';
|
|
11
|
+
import { EchoObjectSchema, getObjectEchoUri } from '../Entity';
|
|
11
12
|
import { createObject } from '../Obj';
|
|
12
13
|
import { Ref, getReferenceAst } from './ref';
|
|
13
14
|
|
|
14
15
|
const Task = Schema.Struct({
|
|
15
16
|
title: Schema.optional(Schema.String),
|
|
16
|
-
}).pipe(
|
|
17
|
-
EchoObjectSchema({
|
|
18
|
-
typename: 'com.example.type.task',
|
|
19
|
-
version: '0.1.0',
|
|
20
|
-
}),
|
|
21
|
-
);
|
|
17
|
+
}).pipe(EchoObjectSchema(DXN.make('com.example.type.task', '0.1.0')));
|
|
22
18
|
|
|
23
|
-
type Task =
|
|
19
|
+
type Task = Type.InstanceType<typeof Task>;
|
|
24
20
|
|
|
25
21
|
const Contact = Schema.Struct({
|
|
26
22
|
name: Schema.String,
|
|
27
23
|
email: Schema.optional(Schema.String),
|
|
28
24
|
tasks: Schema.Array(Ref(Task)),
|
|
29
|
-
}).pipe(
|
|
30
|
-
EchoObjectSchema({
|
|
31
|
-
typename: 'com.example.type.person',
|
|
32
|
-
version: '0.1.0',
|
|
33
|
-
}),
|
|
34
|
-
);
|
|
25
|
+
}).pipe(EchoObjectSchema(DXN.make('com.example.type.person', '0.1.0')));
|
|
35
26
|
|
|
36
|
-
type Contact =
|
|
27
|
+
type Contact = Type.InstanceType<typeof Contact>;
|
|
37
28
|
|
|
38
29
|
describe('Ref', () => {
|
|
39
30
|
test('Schema is', () => {
|
|
40
|
-
Ref(Contact).pipe(Schema.is)(Ref.
|
|
31
|
+
Ref(Contact).pipe(Schema.is)(Ref.fromURI(EID.make({ entityId: EntityId.random() })));
|
|
41
32
|
});
|
|
42
33
|
|
|
43
34
|
test('ref ast', () => {
|
|
44
35
|
const ref = Ref(Task);
|
|
45
36
|
expect(ref.ast._tag).toEqual('Declaration');
|
|
46
37
|
const refAst = getReferenceAst(ref.ast);
|
|
47
|
-
expect(refAst).toEqual({ typename: Task
|
|
38
|
+
expect(refAst).toEqual({ typename: Type.getTypename(Task), version: Type.getVersion(Task) });
|
|
48
39
|
});
|
|
49
40
|
|
|
50
41
|
// TODO(dmaretskyi): Figure out how to expose this in the API.
|
|
@@ -55,14 +46,14 @@ describe('Ref', () => {
|
|
|
55
46
|
const json = JSON.parse(JSON.stringify(contact));
|
|
56
47
|
expect(json).toEqual({
|
|
57
48
|
id: contact.id,
|
|
58
|
-
'@type': `dxn
|
|
49
|
+
'@type': `dxn:${Type.getTypename(Contact)}:${Type.getVersion(Contact)}`,
|
|
59
50
|
'@meta': {
|
|
60
51
|
keys: [],
|
|
61
52
|
},
|
|
62
53
|
name: 'John Doe',
|
|
63
54
|
tasks: [
|
|
64
55
|
{
|
|
65
|
-
'/':
|
|
56
|
+
'/': getObjectEchoUri(task)!.toString(),
|
|
66
57
|
target: JSON.parse(JSON.stringify(task)),
|
|
67
58
|
},
|
|
68
59
|
],
|
|
@@ -76,25 +67,25 @@ describe('Ref', () => {
|
|
|
76
67
|
const json = JSON.parse(JSON.stringify(contact));
|
|
77
68
|
expect(json).toEqual({
|
|
78
69
|
id: contact.id,
|
|
79
|
-
'@type': `dxn
|
|
70
|
+
'@type': `dxn:${Type.getTypename(Contact)}:${Type.getVersion(Contact)}`,
|
|
80
71
|
'@meta': {
|
|
81
72
|
keys: [],
|
|
82
73
|
},
|
|
83
74
|
name: 'John Doe',
|
|
84
|
-
tasks: [{ '/':
|
|
75
|
+
tasks: [{ '/': getObjectEchoUri(task)!.toString() }],
|
|
85
76
|
});
|
|
86
77
|
});
|
|
87
78
|
|
|
88
79
|
test('decode object', () => {
|
|
89
|
-
const id =
|
|
80
|
+
const id = EntityId.random();
|
|
90
81
|
const contactData = {
|
|
91
|
-
id:
|
|
82
|
+
id: EntityId.random(),
|
|
92
83
|
name: 'John Doe',
|
|
93
|
-
tasks: [{ '/': `
|
|
84
|
+
tasks: [{ '/': `echo:/${id}` }],
|
|
94
85
|
};
|
|
95
86
|
|
|
96
|
-
const contact = Contact.pipe(Schema.decodeUnknownSync)(contactData);
|
|
87
|
+
const contact = Type.getSchema(Contact).pipe(Schema.decodeUnknownSync)(contactData);
|
|
97
88
|
expect(Ref.isRef(contact.tasks[0])).toEqual(true);
|
|
98
|
-
expect(contact.tasks[0].
|
|
89
|
+
expect(contact.tasks[0].uri.toString()).toEqual(`echo:/${id}`);
|
|
99
90
|
});
|
|
100
91
|
});
|