@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
package/src/Obj.test.ts
CHANGED
|
@@ -4,6 +4,8 @@
|
|
|
4
4
|
|
|
5
5
|
import { describe, expectTypeOf, test, expect } from 'vitest';
|
|
6
6
|
|
|
7
|
+
import { EID } from '@dxos/keys';
|
|
8
|
+
|
|
7
9
|
import * as Entity from './Entity';
|
|
8
10
|
import { SnapshotKindId } from './internal';
|
|
9
11
|
import * as Obj from './Obj';
|
|
@@ -12,6 +14,26 @@ import * as Relation from './Relation';
|
|
|
12
14
|
import { TestSchema } from './testing';
|
|
13
15
|
|
|
14
16
|
describe('Obj', () => {
|
|
17
|
+
describe('make', () => {
|
|
18
|
+
test('generates a random id when none is provided', ({ expect }) => {
|
|
19
|
+
const obj = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
20
|
+
expect(obj.id).toBeDefined();
|
|
21
|
+
expect(obj.id.length).toBeGreaterThan(0);
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
test('uses the provided id at creation time', ({ expect }) => {
|
|
25
|
+
const a = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
26
|
+
const b = Obj.make(TestSchema.Person, { name: 'Bob', id: a.id });
|
|
27
|
+
expect(b.id).toBe(a.id);
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
test('rejects an invalid id format', ({ expect }) => {
|
|
31
|
+
expect(() => Obj.make(TestSchema.Person, { name: 'Alice', id: 'not-a-ulid' })).toThrow(
|
|
32
|
+
/Invalid object id format/,
|
|
33
|
+
);
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
|
|
15
37
|
describe('getSnapshot', () => {
|
|
16
38
|
test('getSnapshot returns an immutable snapshot with SnapshotKindId', ({ expect }) => {
|
|
17
39
|
const obj = Obj.make(TestSchema.Person, { name: 'Test' });
|
|
@@ -42,8 +64,8 @@ describe('Obj', () => {
|
|
|
42
64
|
const snapshot = Obj.getSnapshot(obj);
|
|
43
65
|
|
|
44
66
|
// getDXN - works with both.
|
|
45
|
-
expect(Obj.
|
|
46
|
-
expect(Obj.
|
|
67
|
+
expect(Obj.getURI(obj)).toBeDefined();
|
|
68
|
+
expect(Obj.getURI(snapshot)).toBeDefined();
|
|
47
69
|
|
|
48
70
|
// getTypename - works with both.
|
|
49
71
|
expect(Obj.getTypename(obj)).toBe('com.example.type.person');
|
|
@@ -80,6 +102,86 @@ describe('Obj', () => {
|
|
|
80
102
|
expect(SnapshotKindId in snapshot).toBe(true);
|
|
81
103
|
expect(Entity.KindId in snapshot).toBe(false);
|
|
82
104
|
});
|
|
105
|
+
|
|
106
|
+
test('getSnapshot preserves parent', ({ expect }) => {
|
|
107
|
+
const parent = Obj.make(TestSchema.Organization, { name: 'parent' });
|
|
108
|
+
const child = Obj.make(TestSchema.Person, { name: 'child' });
|
|
109
|
+
Obj.setParent(child, parent);
|
|
110
|
+
|
|
111
|
+
const snapshot = Obj.getSnapshot(child);
|
|
112
|
+
|
|
113
|
+
expect(Obj.getParent(child)).toBe(parent);
|
|
114
|
+
expect(Obj.getParent(snapshot)).toBe(parent);
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
describe('getURI', () => {
|
|
119
|
+
test('default returns EID', ({ expect }) => {
|
|
120
|
+
const obj = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
121
|
+
const uri = Obj.getURI(obj);
|
|
122
|
+
expect(EID.isEID(uri)).toBe(true);
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
test("prefer: 'relative' returns local EID echo:/<id>", ({ expect }) => {
|
|
126
|
+
const obj = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
127
|
+
const uri = Obj.getURI(obj, { prefer: 'relative' });
|
|
128
|
+
expect(uri).toMatch(/^echo:\/[^/]/);
|
|
129
|
+
expect(EID.isLocal(EID.parse(uri))).toBe(true);
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
test("prefer: 'relative' works with snapshot", ({ expect }) => {
|
|
133
|
+
const obj = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
134
|
+
const snapshot = Obj.getSnapshot(obj);
|
|
135
|
+
expect(Obj.getURI(snapshot, { prefer: 'relative' })).toBe(Obj.getURI(obj, { prefer: 'relative' }));
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
test("prefer: 'named' returns dxn: URI when meta.key is set", ({ expect }) => {
|
|
139
|
+
const obj = Obj.make(TestSchema.Person, {
|
|
140
|
+
[Obj.Meta]: { key: 'org.dxos.blueprint.webSearch' },
|
|
141
|
+
name: 'Alice',
|
|
142
|
+
});
|
|
143
|
+
const uri = Obj.getURI(obj, { prefer: 'named' });
|
|
144
|
+
expect(uri).toBe('dxn:org.dxos.blueprint.webSearch');
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
test("prefer: 'named' falls back to EID when meta.key is absent", ({ expect }) => {
|
|
148
|
+
const obj = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
149
|
+
const uri = Obj.getURI(obj, { prefer: 'named' });
|
|
150
|
+
expect(EID.isEID(uri)).toBe(true);
|
|
151
|
+
});
|
|
152
|
+
|
|
153
|
+
test("prefer: 'named' handles key with hyphens (falls back to raw key URI)", ({ expect }) => {
|
|
154
|
+
const obj = Obj.make(TestSchema.Person, {
|
|
155
|
+
[Obj.Meta]: { key: 'org.dxos.blueprint.web-search' },
|
|
156
|
+
name: 'Alice',
|
|
157
|
+
});
|
|
158
|
+
// Hyphens in the final DXN segment are invalid; falls back to the raw key as URI.
|
|
159
|
+
const uri = Obj.getURI(obj, { prefer: 'named' });
|
|
160
|
+
expect(uri).toBe('org.dxos.blueprint.web-search');
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
test("prefer: 'absolute' falls back to current EID when object has no database", ({ expect }) => {
|
|
164
|
+
const obj = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
165
|
+
// Without a database the space id is unknown; result is at least a valid EID.
|
|
166
|
+
const uri = Obj.getURI(obj, { prefer: 'absolute' });
|
|
167
|
+
expect(EID.isEID(uri)).toBe(true);
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
test("prefer: 'relative' returns the same local EID for reactive and snapshot", ({ expect }) => {
|
|
171
|
+
const obj = Obj.make(TestSchema.Person, { name: 'Alice' });
|
|
172
|
+
const snapshot = Obj.getSnapshot(obj);
|
|
173
|
+
expect(Obj.getURI(snapshot, { prefer: 'relative' })).toBe(Obj.getURI(obj, { prefer: 'relative' }));
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
test("prefer: 'named' works the same on snapshot as on reactive (meta.key is preserved)", ({ expect }) => {
|
|
177
|
+
const obj = Obj.make(TestSchema.Person, {
|
|
178
|
+
[Obj.Meta]: { key: 'com.example.foo' },
|
|
179
|
+
name: 'Alice',
|
|
180
|
+
});
|
|
181
|
+
const snapshot = Obj.getSnapshot(obj);
|
|
182
|
+
expect(Obj.getURI(snapshot, { prefer: 'named' })).toBe(Obj.getURI(obj, { prefer: 'named' }));
|
|
183
|
+
expect(Obj.getURI(snapshot, { prefer: 'named' })).toBe('dxn:com.example.foo');
|
|
184
|
+
});
|
|
83
185
|
});
|
|
84
186
|
|
|
85
187
|
describe('snapshotOf', () => {
|
|
@@ -117,7 +219,7 @@ describe('Obj', () => {
|
|
|
117
219
|
|
|
118
220
|
test('returns keys from reactive object and snapshot', ({ expect }) => {
|
|
119
221
|
const obj = Obj.make(TestSchema.Person, { name: 'Test' });
|
|
120
|
-
Obj.
|
|
222
|
+
Obj.update(obj, (obj) => {
|
|
121
223
|
const meta = Obj.getMeta(obj);
|
|
122
224
|
meta.keys.push({ source: SOURCE, id: 'key-1' });
|
|
123
225
|
meta.keys.push({ source: SOURCE, id: 'key-2' });
|
|
@@ -134,7 +236,7 @@ describe('Obj', () => {
|
|
|
134
236
|
|
|
135
237
|
test('throws for plain object without metadata', ({ expect }) => {
|
|
136
238
|
const plain = { id: 'plain-1', name: 'Plain' };
|
|
137
|
-
expect(() => Obj.getKeys(plain as any, SOURCE)).toThrow(/
|
|
239
|
+
expect(() => Obj.getKeys(plain as any, SOURCE)).toThrow(/EntityMeta not found/);
|
|
138
240
|
});
|
|
139
241
|
});
|
|
140
242
|
|
|
@@ -166,7 +268,7 @@ describe('Obj', () => {
|
|
|
166
268
|
|
|
167
269
|
const cloned = Obj.clone(original);
|
|
168
270
|
|
|
169
|
-
Obj.
|
|
271
|
+
Obj.update(original, (original) => {
|
|
170
272
|
original.name = 'Bob';
|
|
171
273
|
});
|
|
172
274
|
|
|
@@ -206,7 +308,7 @@ describe('Obj', () => {
|
|
|
206
308
|
expect(cloned.employer?.target).toBe(person.employer?.target);
|
|
207
309
|
|
|
208
310
|
// Modifying the referenced object affects both
|
|
209
|
-
Obj.
|
|
311
|
+
Obj.update(employer, (employer) => {
|
|
210
312
|
employer.name = 'Updated DXOS';
|
|
211
313
|
});
|
|
212
314
|
|
|
@@ -234,7 +336,7 @@ describe('Obj', () => {
|
|
|
234
336
|
expect(cloned.employer?.target?.name).toBe(employer.name);
|
|
235
337
|
|
|
236
338
|
// Modifying the original referenced object does not affect the clone
|
|
237
|
-
Obj.
|
|
339
|
+
Obj.update(employer, (employer) => {
|
|
238
340
|
employer.name = 'Updated DXOS';
|
|
239
341
|
});
|
|
240
342
|
|
|
@@ -329,11 +431,11 @@ describe('Obj', () => {
|
|
|
329
431
|
expect(cloned.address?.city).toBe('San Francisco');
|
|
330
432
|
expect(cloned.address?.state).toBe('CA');
|
|
331
433
|
expect(cloned.address?.zip).toBe('94102');
|
|
332
|
-
expect(cloned.address?.coordinates
|
|
333
|
-
expect(cloned.address?.coordinates
|
|
434
|
+
expect(cloned.address?.coordinates?.lat).toBe(37.7749);
|
|
435
|
+
expect(cloned.address?.coordinates?.lng).toBe(-122.4194);
|
|
334
436
|
|
|
335
437
|
// Modifying nested properties should be independent
|
|
336
|
-
Obj.
|
|
438
|
+
Obj.update(person, (person) => {
|
|
337
439
|
person.address!.city = 'New York';
|
|
338
440
|
});
|
|
339
441
|
|
|
@@ -366,7 +468,7 @@ describe('Obj', () => {
|
|
|
366
468
|
expect(cloned.tasks?.[2]?.target).not.toBe(task3);
|
|
367
469
|
|
|
368
470
|
// Modifying original tasks should not affect cloned ones
|
|
369
|
-
Obj.
|
|
471
|
+
Obj.update(task1, (task1) => {
|
|
370
472
|
task1.title = 'Updated Task 1';
|
|
371
473
|
});
|
|
372
474
|
|
|
@@ -405,7 +507,7 @@ describe('Obj', () => {
|
|
|
405
507
|
const cloned = Obj.clone(person);
|
|
406
508
|
|
|
407
509
|
expect(Obj.instanceOf(TestSchema.Person, cloned)).toBe(true);
|
|
408
|
-
expect(Obj.
|
|
510
|
+
expect(Obj.getType(cloned)).toBe(Obj.getType(person));
|
|
409
511
|
});
|
|
410
512
|
});
|
|
411
513
|
|
|
@@ -449,7 +551,7 @@ describe('Obj', () => {
|
|
|
449
551
|
test('returns false when values already match', () => {
|
|
450
552
|
const target = Obj.make(TestSchema.Organization, { name: 'Acme', properties: { region: 'EU' } });
|
|
451
553
|
const source = Obj.make(TestSchema.Organization, { name: 'Acme', properties: { region: 'EU' } });
|
|
452
|
-
Obj.
|
|
554
|
+
Obj.update(target, (target) => {
|
|
453
555
|
expect(Obj.updateFrom(target, source)).toBe(false);
|
|
454
556
|
});
|
|
455
557
|
});
|
|
@@ -463,7 +565,7 @@ describe('Obj', () => {
|
|
|
463
565
|
name: 'New',
|
|
464
566
|
properties: { a: '2', b: '3' },
|
|
465
567
|
});
|
|
466
|
-
Obj.
|
|
568
|
+
Obj.update(target, (target) => {
|
|
467
569
|
expect(Obj.updateFrom(target, source)).toBe(true);
|
|
468
570
|
});
|
|
469
571
|
expect(target.name).toBe('New');
|
|
@@ -487,10 +589,10 @@ describe('Obj', () => {
|
|
|
487
589
|
employer: Ref.make(orgB),
|
|
488
590
|
address: { city: 'Portland', state: 'OR', zip: '97201', coordinates: { lat: 45.5, lng: -122.6 } },
|
|
489
591
|
});
|
|
490
|
-
Obj.
|
|
592
|
+
Obj.update(target, (target) => {
|
|
491
593
|
expect(Obj.updateFrom(target, source)).toBe(true);
|
|
492
594
|
});
|
|
493
|
-
expect(target.employer?.
|
|
595
|
+
expect(target.employer?.uri.toString()).toBe(Ref.make(orgB).uri.toString());
|
|
494
596
|
expect(target.address?.city).toBe('Portland');
|
|
495
597
|
});
|
|
496
598
|
|
|
@@ -510,16 +612,16 @@ describe('Obj', () => {
|
|
|
510
612
|
email: 'bob@x.test',
|
|
511
613
|
tasks: [Ref.make(t1), Ref.make(t3)],
|
|
512
614
|
});
|
|
513
|
-
Obj.
|
|
615
|
+
Obj.update(target, (target) => {
|
|
514
616
|
expect(Obj.updateFrom(target, source)).toBe(true);
|
|
515
617
|
});
|
|
516
|
-
expect(target.tasks?.map((r) => r.
|
|
618
|
+
expect(target.tasks?.map((r) => r.uri)).toEqual(source.tasks?.map((r) => r.uri));
|
|
517
619
|
});
|
|
518
620
|
|
|
519
621
|
test('respects include option', () => {
|
|
520
622
|
const target = Obj.make(TestSchema.Organization, { name: 'Keep', properties: { x: '1' } });
|
|
521
623
|
const source = Obj.make(TestSchema.Organization, { name: 'Drop', properties: { x: '2' } });
|
|
522
|
-
Obj.
|
|
624
|
+
Obj.update(target, (target) => {
|
|
523
625
|
expect(Obj.updateFrom(target, source, { include: ['properties'] })).toBe(true);
|
|
524
626
|
});
|
|
525
627
|
expect(target.name).toBe('Keep');
|
|
@@ -529,7 +631,7 @@ describe('Obj', () => {
|
|
|
529
631
|
test('respects exclude option', () => {
|
|
530
632
|
const target = Obj.make(TestSchema.Organization, { name: 'Old', properties: { x: '1' } });
|
|
531
633
|
const source = Obj.make(TestSchema.Organization, { name: 'New', properties: { x: '2' } });
|
|
532
|
-
Obj.
|
|
634
|
+
Obj.update(target, (target) => {
|
|
533
635
|
expect(Obj.updateFrom(target, source, { exclude: ['name'] })).toBe(true);
|
|
534
636
|
});
|
|
535
637
|
expect(target.name).toBe('Old');
|