@dxos/echo 0.8.4-main.937b3ca → 0.8.4-main.9be5663bfe
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/dist/lib/{browser → neutral}/Annotation.mjs +9 -5
- package/dist/lib/neutral/Database.mjs +47 -0
- package/dist/lib/{browser → neutral}/Entity.mjs +19 -12
- package/dist/lib/{browser → neutral}/Err.mjs +4 -3
- package/dist/lib/neutral/Extension.mjs +18 -0
- package/dist/lib/neutral/Feed.mjs +48 -0
- package/dist/lib/neutral/Filter.mjs +72 -0
- package/dist/lib/{browser → neutral}/Format.mjs +4 -5
- package/dist/lib/neutral/JsonSchema.mjs +19 -0
- package/dist/lib/{browser → neutral}/Key.mjs +2 -3
- package/dist/lib/{node-esm → neutral}/Obj.mjs +39 -17
- package/dist/lib/{browser → neutral}/Order.mjs +2 -3
- package/dist/lib/neutral/Query.mjs +38 -0
- package/dist/lib/neutral/QueryResult.mjs +2 -0
- package/dist/lib/neutral/Ref.mjs +24 -0
- package/dist/lib/{browser → neutral}/Relation.mjs +22 -13
- package/dist/lib/neutral/SchemaRegistry.mjs +2 -0
- package/dist/lib/neutral/Tag.mjs +29 -0
- package/dist/lib/neutral/Type.mjs +37 -0
- package/dist/lib/{browser/chunk-XDIUHAAX.mjs → neutral/chunk-46QNGNTY.mjs} +9 -5
- package/dist/lib/neutral/chunk-46QNGNTY.mjs.map +7 -0
- package/dist/lib/neutral/chunk-5VKHCUDA.mjs +299 -0
- package/dist/lib/neutral/chunk-5VKHCUDA.mjs.map +7 -0
- package/dist/lib/{node-esm/chunk-YOLH5KS4.mjs → neutral/chunk-6URFBQJH.mjs} +104 -26
- package/dist/lib/neutral/chunk-6URFBQJH.mjs.map +7 -0
- package/dist/lib/neutral/chunk-7SQD3FRZ.mjs +159 -0
- package/dist/lib/neutral/chunk-7SQD3FRZ.mjs.map +7 -0
- package/dist/lib/{browser/chunk-INHXFXY5.mjs → neutral/chunk-ANHVGJI4.mjs} +2 -3
- package/dist/lib/{node-esm/chunk-AJEMYSIR.mjs.map → neutral/chunk-ANHVGJI4.mjs.map} +1 -1
- package/dist/lib/{browser/chunk-ZHXZGIXD.mjs → neutral/chunk-BNCCGLJN.mjs} +1 -3
- package/dist/lib/{node-esm/chunk-MOLNWFNL.mjs.map → neutral/chunk-BNCCGLJN.mjs.map} +2 -2
- package/dist/lib/{browser/chunk-FRDT7RA4.mjs → neutral/chunk-DQYLD2RB.mjs} +15 -16
- package/dist/lib/neutral/chunk-DQYLD2RB.mjs.map +7 -0
- package/dist/lib/{node-esm/chunk-ZBB67AKD.mjs → neutral/chunk-E5PBQJWV.mjs} +9 -6
- package/dist/lib/neutral/chunk-E5PBQJWV.mjs.map +7 -0
- package/dist/lib/neutral/chunk-EBVB5NOH.mjs +133 -0
- package/dist/lib/neutral/chunk-EBVB5NOH.mjs.map +7 -0
- package/dist/lib/neutral/chunk-FNEFSO2C.mjs +787 -0
- package/dist/lib/neutral/chunk-FNEFSO2C.mjs.map +7 -0
- package/dist/lib/{browser/chunk-BJPE6CIC.mjs → neutral/chunk-FW7UJX25.mjs} +1708 -2721
- package/dist/lib/neutral/chunk-FW7UJX25.mjs.map +7 -0
- package/dist/lib/{browser/chunk-PQZW3S6L.mjs → neutral/chunk-GZQTCRJB.mjs} +3 -4
- package/dist/lib/neutral/chunk-GZQTCRJB.mjs.map +7 -0
- package/dist/lib/neutral/chunk-HBJ7JT5A.mjs +120 -0
- package/dist/lib/neutral/chunk-HBJ7JT5A.mjs.map +7 -0
- package/dist/lib/{browser/chunk-CGS2ULMK.mjs → neutral/chunk-J5LGTIGS.mjs} +1 -2
- package/dist/lib/{browser/chunk-U2J7TA7K.mjs → neutral/chunk-OLFCVPOO.mjs} +6 -7
- package/dist/lib/neutral/chunk-OLFCVPOO.mjs.map +7 -0
- package/dist/lib/{browser/chunk-IXVWLTG7.mjs → neutral/chunk-OMUPQMLR.mjs} +1 -3
- package/dist/lib/{browser/chunk-IXVWLTG7.mjs.map → neutral/chunk-OMUPQMLR.mjs.map} +1 -1
- package/dist/lib/neutral/chunk-QWAOTFCY.mjs +396 -0
- package/dist/lib/neutral/chunk-QWAOTFCY.mjs.map +7 -0
- package/dist/lib/neutral/chunk-R72KFH2X.mjs +34 -0
- package/dist/lib/neutral/chunk-R72KFH2X.mjs.map +7 -0
- package/dist/lib/{browser/chunk-ZAGAOZVY.mjs → neutral/chunk-T2JOLN37.mjs} +73 -7
- package/dist/lib/neutral/chunk-T2JOLN37.mjs.map +7 -0
- package/dist/lib/{browser/chunk-YKTSSMDS.mjs → neutral/chunk-TBKX6JQO.mjs} +4 -6
- package/dist/lib/neutral/chunk-TBKX6JQO.mjs.map +7 -0
- package/dist/lib/{browser/chunk-CJ5YELTO.mjs → neutral/chunk-UBEZSGXY.mjs} +15 -3
- package/dist/lib/neutral/chunk-UBEZSGXY.mjs.map +7 -0
- package/dist/lib/{browser/chunk-JMKVF2YQ.mjs → neutral/chunk-UI6MWK5W.mjs} +3 -4
- package/dist/lib/neutral/chunk-UI6MWK5W.mjs.map +7 -0
- package/dist/lib/{browser/chunk-KQQGVHFN.mjs → neutral/chunk-UPWIIW2V.mjs} +12 -58
- package/dist/lib/neutral/chunk-UPWIIW2V.mjs.map +7 -0
- package/dist/lib/{node-esm/chunk-ANLVLWME.mjs → neutral/chunk-WVLOCXB5.mjs} +33 -10
- package/dist/lib/neutral/chunk-WVLOCXB5.mjs.map +7 -0
- package/dist/lib/neutral/chunk-YS6Q3XAD.mjs +50 -0
- package/dist/lib/neutral/chunk-YS6Q3XAD.mjs.map +7 -0
- package/dist/lib/{browser/chunk-2SBB7OWV.mjs → neutral/chunk-YSLSJ7QS.mjs} +73 -25
- package/dist/lib/neutral/chunk-YSLSJ7QS.mjs.map +7 -0
- package/dist/lib/neutral/chunk-ZGVZNBBJ.mjs +415 -0
- package/dist/lib/neutral/chunk-ZGVZNBBJ.mjs.map +7 -0
- package/dist/lib/{node-esm/chunk-NBWL7UCZ.mjs → neutral/chunk-ZIXGDU6F.mjs} +9 -4
- package/dist/lib/neutral/chunk-ZIXGDU6F.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +101 -0
- package/dist/lib/{browser → neutral}/internal/index.mjs +57 -40
- package/dist/lib/neutral/meta.json +1 -0
- package/dist/lib/{node-esm → neutral}/testing/index.mjs +44 -37
- package/dist/lib/neutral/testing/index.mjs.map +7 -0
- package/dist/types/src/Annotation.d.ts +23 -1
- package/dist/types/src/Annotation.d.ts.map +1 -1
- package/dist/types/src/Collection.d.ts +16 -0
- package/dist/types/src/Collection.d.ts.map +1 -0
- package/dist/types/src/Database.d.ts +86 -84
- package/dist/types/src/Database.d.ts.map +1 -1
- package/dist/types/src/Dataset.d.ts +19 -0
- package/dist/types/src/Dataset.d.ts.map +1 -0
- package/dist/types/src/Entity.d.ts +41 -15
- package/dist/types/src/Entity.d.ts.map +1 -1
- package/dist/types/src/Err.d.ts +43 -0
- package/dist/types/src/Err.d.ts.map +1 -1
- package/dist/types/src/Extension.d.ts +80 -0
- package/dist/types/src/Extension.d.ts.map +1 -0
- package/dist/types/src/Extension.test.d.ts +2 -0
- package/dist/types/src/Extension.test.d.ts.map +1 -0
- package/dist/types/src/Feed.d.ts +171 -0
- package/dist/types/src/Feed.d.ts.map +1 -0
- package/dist/types/src/Filter.d.ts +32 -5
- package/dist/types/src/Filter.d.ts.map +1 -1
- package/dist/types/src/Filter.test.d.ts +2 -0
- package/dist/types/src/Filter.test.d.ts.map +1 -0
- package/dist/types/src/Format.d.ts +3 -3
- package/dist/types/src/Format.d.ts.map +1 -1
- package/dist/types/src/Hypergraph.d.ts +8 -3
- package/dist/types/src/Hypergraph.d.ts.map +1 -1
- package/dist/types/src/JsonSchema.d.ts +11 -4
- package/dist/types/src/JsonSchema.d.ts.map +1 -1
- package/dist/types/src/Obj.d.ts +174 -46
- package/dist/types/src/Obj.d.ts.map +1 -1
- package/dist/types/src/Order.d.ts.map +1 -1
- package/dist/types/src/Query.d.ts +109 -15
- package/dist/types/src/Query.d.ts.map +1 -1
- package/dist/types/src/Ref.d.ts +58 -10
- package/dist/types/src/Ref.d.ts.map +1 -1
- package/dist/types/src/Relation.d.ts +75 -29
- package/dist/types/src/Relation.d.ts.map +1 -1
- package/dist/types/src/SchemaRegistry.d.ts +4 -4
- package/dist/types/src/SchemaRegistry.d.ts.map +1 -1
- package/dist/types/src/Tag.d.ts +4 -3
- package/dist/types/src/Tag.d.ts.map +1 -1
- package/dist/types/src/Type.d.ts +51 -180
- package/dist/types/src/Type.d.ts.map +1 -1
- package/dist/types/src/View.d.ts +68 -0
- package/dist/types/src/View.d.ts.map +1 -0
- package/dist/types/src/hierarchy.test.d.ts +2 -0
- package/dist/types/src/hierarchy.test.d.ts.map +1 -0
- package/dist/types/src/index.d.ts +5 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/internal/{annotations → Annotation}/annotations.d.ts +69 -8
- package/dist/types/src/internal/Annotation/annotations.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/annotations.test.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/index.d.ts +4 -0
- package/dist/types/src/internal/Annotation/index.d.ts.map +1 -0
- package/dist/types/src/internal/{api → Annotation}/sorting.d.ts +1 -1
- package/dist/types/src/internal/Annotation/sorting.d.ts.map +1 -0
- package/dist/types/src/internal/{annotations → Annotation}/util.d.ts +13 -1
- package/dist/types/src/internal/Annotation/util.d.ts.map +1 -0
- package/dist/types/src/internal/{api/entity.d.ts → Entity/api.d.ts} +2 -2
- package/dist/types/src/internal/Entity/api.d.ts.map +1 -0
- package/dist/types/src/internal/{entities → Entity}/entity.d.ts +3 -3
- package/dist/types/src/internal/Entity/entity.d.ts.map +1 -0
- package/dist/types/src/internal/{entities → Entity}/index.d.ts +2 -0
- package/dist/types/src/internal/Entity/index.d.ts.map +1 -0
- package/dist/types/src/internal/{entities → Entity}/model.d.ts +4 -26
- package/dist/types/src/internal/Entity/model.d.ts.map +1 -0
- package/dist/types/src/internal/{entities → Entity}/object.d.ts +2 -2
- package/dist/types/src/internal/Entity/object.d.ts.map +1 -0
- package/dist/types/src/internal/{entities → Entity}/relation.d.ts +3 -30
- package/dist/types/src/internal/Entity/relation.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/util.d.ts.map +1 -0
- package/dist/types/src/internal/{api → Entity}/version.d.ts +1 -1
- package/dist/types/src/internal/Entity/version.d.ts.map +1 -0
- package/dist/types/src/internal/Format/date.d.ts.map +1 -0
- package/dist/types/src/internal/Format/date.test.d.ts.map +1 -0
- package/dist/types/src/internal/Format/format.d.ts.map +1 -0
- package/dist/types/src/internal/Format/format.test.d.ts.map +1 -0
- package/dist/types/src/internal/Format/index.d.ts.map +1 -0
- package/dist/types/src/internal/Format/number.d.ts.map +1 -0
- package/dist/types/src/internal/Format/object.d.ts.map +1 -0
- package/dist/types/src/internal/{formats → Format}/select.d.ts +2 -2
- package/dist/types/src/internal/Format/select.d.ts.map +1 -0
- package/dist/types/src/internal/Format/string.d.ts.map +1 -0
- package/dist/types/src/internal/{formats → Format}/types.d.ts +1 -1
- package/dist/types/src/internal/Format/types.d.ts.map +1 -0
- package/dist/types/src/internal/{json-schema → JsonSchema}/annotations.d.ts +1 -1
- package/dist/types/src/internal/JsonSchema/annotations.d.ts.map +1 -0
- package/dist/types/src/internal/JsonSchema/effect-schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/JsonSchema/index.d.ts.map +1 -0
- package/dist/types/src/internal/JsonSchema/json-schema-normalize.d.ts.map +1 -0
- package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema-type.d.ts +131 -30
- package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts.map +1 -0
- package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema.d.ts +2 -1
- package/dist/types/src/internal/JsonSchema/json-schema.d.ts.map +1 -0
- package/dist/types/src/internal/JsonSchema/json-schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/clone.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/common.d.ts.map +1 -0
- package/dist/types/src/internal/{object → Obj}/create-object.d.ts +2 -2
- package/dist/types/src/internal/Obj/create-object.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/create-object.test.d.ts.map +1 -0
- package/dist/types/src/internal/{object → Obj}/deleted.d.ts +1 -1
- package/dist/types/src/internal/Obj/deleted.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/ids.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/index.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/inspect.d.ts.map +1 -0
- package/dist/types/src/internal/{object → Obj}/json-serializer.d.ts +13 -5
- package/dist/types/src/internal/Obj/json-serializer.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/json-serializer.test.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/schema-validator.d.ts +2 -0
- package/dist/types/src/internal/Obj/schema-validator.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/schema-validator.test.d.ts.map +1 -0
- package/dist/types/src/internal/{object → Obj}/set-value.d.ts +1 -1
- package/dist/types/src/internal/Obj/set-value.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/set-value.test.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/snapshot.d.ts.map +1 -0
- package/dist/types/src/internal/{object → Obj}/typed-object.d.ts +4 -4
- package/dist/types/src/internal/Obj/typed-object.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/typed-object.test.d.ts.map +1 -0
- package/dist/types/src/internal/Query.d.ts +10 -0
- package/dist/types/src/internal/Query.d.ts.map +1 -0
- package/dist/types/src/internal/Ref/index.d.ts.map +1 -0
- package/dist/types/src/internal/{ref → Ref}/ref-array.d.ts +1 -1
- package/dist/types/src/internal/Ref/ref-array.d.ts.map +1 -0
- package/dist/types/src/internal/{ref → Ref}/ref.d.ts +18 -4
- package/dist/types/src/internal/Ref/ref.d.ts.map +1 -0
- package/dist/types/src/internal/Ref/ref.test.d.ts.map +1 -0
- package/dist/types/src/internal/Type/compose.d.ts +7 -0
- package/dist/types/src/internal/Type/compose.d.ts.map +1 -0
- package/dist/types/src/internal/Type/compose.test.d.ts.map +1 -0
- package/dist/types/src/internal/{schema → Type}/echo-schema.d.ts +8 -7
- package/dist/types/src/internal/Type/echo-schema.d.ts.map +1 -0
- package/dist/types/src/internal/Type/index.d.ts.map +1 -0
- package/dist/types/src/internal/Type/manipulation.d.ts.map +1 -0
- package/dist/types/src/internal/{schema → Type}/persistent-schema.d.ts +2 -2
- package/dist/types/src/internal/Type/persistent-schema.d.ts.map +1 -0
- package/dist/types/src/internal/{api → common/api}/index.d.ts +0 -4
- package/dist/types/src/internal/common/api/index.d.ts.map +1 -0
- package/dist/types/src/internal/{api → common/api}/meta.d.ts +2 -2
- package/dist/types/src/internal/common/api/meta.d.ts.map +1 -0
- package/dist/types/src/internal/common/index.d.ts +4 -0
- package/dist/types/src/internal/common/index.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/change-context.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/change.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/errors.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/event-batch.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/handler.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/index.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/json-serializer.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/make-object.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/ownership.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/proxy-types.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/proxy-utils.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/reactive-array.d.ts.map +1 -0
- package/dist/types/src/internal/{proxy → common/proxy}/reactive.d.ts +1 -1
- package/dist/types/src/internal/common/proxy/reactive.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/schema-validator.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/symbols.d.ts.map +1 -0
- package/dist/types/src/internal/{proxy → common/proxy}/typed-handler.d.ts +2 -1
- package/dist/types/src/internal/common/proxy/typed-handler.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/typed-handler.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/typed-object.test.d.ts.map +1 -0
- package/dist/types/src/internal/{types → common/types}/base.d.ts +1 -0
- package/dist/types/src/internal/common/types/base.d.ts.map +1 -0
- package/dist/types/src/internal/{types → common/types}/entity.d.ts +2 -2
- package/dist/types/src/internal/common/types/entity.d.ts.map +1 -0
- package/dist/types/src/internal/{types → common/types}/index.d.ts +1 -0
- package/dist/types/src/internal/common/types/index.d.ts.map +1 -0
- package/dist/types/src/internal/{types → common/types}/meta.d.ts +7 -6
- package/dist/types/src/internal/common/types/meta.d.ts.map +1 -0
- package/dist/types/src/internal/common/types/model-symbols.d.ts +54 -0
- package/dist/types/src/internal/common/types/model-symbols.d.ts.map +1 -0
- package/dist/types/src/internal/{types → common/types}/typename.d.ts +8 -0
- package/dist/types/src/internal/common/types/typename.d.ts.map +1 -0
- package/dist/types/src/internal/{types → common/types}/version.d.ts +2 -2
- package/dist/types/src/internal/common/types/version.d.ts.map +1 -0
- package/dist/types/src/internal/index.d.ts +9 -10
- package/dist/types/src/internal/index.d.ts.map +1 -1
- package/dist/types/src/testing/test-data.d.ts.map +1 -1
- package/dist/types/src/testing/test-schema.d.ts +19 -18
- package/dist/types/src/testing/test-schema.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +44 -113
- package/src/Annotation.ts +31 -1
- package/src/Collection.ts +37 -0
- package/src/Database.ts +167 -173
- package/src/Dataset.ts +26 -0
- package/src/Entity.ts +73 -54
- package/src/Err.ts +22 -0
- package/src/Extension.test.ts +235 -0
- package/src/Extension.ts +122 -0
- package/src/Feed.ts +283 -0
- package/src/Filter.test.ts +90 -0
- package/src/Filter.ts +81 -7
- package/src/Format.ts +3 -3
- package/src/Hypergraph.ts +9 -4
- package/src/JsonSchema.ts +14 -4
- package/src/Obj.test.ts +166 -13
- package/src/Obj.ts +407 -145
- package/src/Order.ts +3 -1
- package/src/Query.test.ts +339 -15
- package/src/Query.ts +275 -24
- package/src/Ref.ts +64 -11
- package/src/Relation.test.ts +8 -2
- package/src/Relation.ts +167 -133
- package/src/SchemaRegistry.ts +5 -4
- package/src/Tag.ts +6 -5
- package/src/Type.test.ts +10 -10
- package/src/Type.ts +70 -303
- package/src/View.ts +107 -0
- package/src/hierarchy.test.ts +33 -0
- package/src/index.ts +5 -0
- package/src/internal/{annotations → Annotation}/annotations.test.ts +56 -7
- package/src/internal/{annotations → Annotation}/annotations.ts +134 -16
- package/src/internal/{annotations → Annotation}/index.ts +1 -0
- package/src/internal/{api → Annotation}/sorting.ts +2 -4
- package/src/internal/{annotations → Annotation}/util.ts +14 -1
- package/src/internal/{api/entity.ts → Entity/api.ts} +3 -2
- package/src/internal/{entities → Entity}/entity.ts +6 -4
- package/src/internal/{entities → Entity}/index.ts +2 -0
- package/src/internal/{entities → Entity}/model.ts +17 -42
- package/src/internal/{entities → Entity}/object.ts +3 -6
- package/src/internal/{entities → Entity}/relation.ts +20 -39
- package/src/internal/{api → Entity}/version.ts +2 -2
- package/src/internal/{formats → Format}/date.test.ts +1 -2
- package/src/internal/{formats → Format}/format.test.ts +2 -3
- package/src/internal/{formats → Format}/select.ts +1 -1
- package/src/internal/{formats → Format}/types.ts +3 -3
- package/src/internal/{json-schema → JsonSchema}/annotations.ts +3 -3
- package/src/internal/{json-schema → JsonSchema}/json-schema-normalize.ts +4 -2
- package/src/internal/{json-schema → JsonSchema}/json-schema-type.ts +33 -34
- package/src/internal/{json-schema → JsonSchema}/json-schema.test.ts +48 -49
- package/src/internal/{json-schema → JsonSchema}/json-schema.ts +16 -11
- package/src/internal/{object → Obj}/clone.ts +3 -3
- package/src/internal/{object → Obj}/common.ts +2 -2
- package/src/internal/{object → Obj}/create-object.test.ts +5 -7
- package/src/internal/{object → Obj}/create-object.ts +5 -6
- package/src/internal/{object → Obj}/deleted.ts +2 -2
- package/src/internal/{object → Obj}/inspect.ts +2 -2
- package/src/internal/{object → Obj}/json-serializer.test.ts +31 -8
- package/src/internal/{object → Obj}/json-serializer.ts +58 -24
- package/src/internal/{object → Obj}/schema-validator.test.ts +3 -7
- package/src/internal/{object → Obj}/schema-validator.ts +1 -1
- package/src/internal/{object → Obj}/set-value.test.ts +33 -33
- package/src/internal/{object → Obj}/set-value.ts +2 -2
- package/src/internal/Obj/snapshot.ts +105 -0
- package/src/internal/{object → Obj}/typed-object.test.ts +3 -3
- package/src/internal/{object → Obj}/typed-object.ts +4 -4
- package/src/internal/Query.ts +134 -0
- package/src/internal/{ref → Ref}/ref-array.ts +1 -2
- package/src/internal/{ref → Ref}/ref.test.ts +5 -6
- package/src/internal/{ref → Ref}/ref.ts +29 -5
- package/src/internal/{schema → Type}/compose.test.ts +5 -6
- package/src/internal/{schema → Type}/compose.ts +14 -9
- package/src/internal/{schema → Type}/echo-schema.ts +11 -11
- package/src/internal/{schema → Type}/manipulation.ts +1 -1
- package/src/internal/{schema → Type}/persistent-schema.ts +10 -4
- package/src/internal/{README.md → common/README.md} +1 -1
- package/src/internal/{api → common/api}/index.ts +0 -4
- package/src/internal/{api → common/api}/meta.ts +3 -3
- package/src/internal/common/index.ts +7 -0
- package/src/internal/{proxy → common/proxy}/change.test.ts +65 -65
- package/src/internal/{proxy → common/proxy}/handler.test.ts +2 -4
- package/src/internal/{proxy → common/proxy}/json-serializer.ts +6 -3
- package/src/internal/{proxy → common/proxy}/make-object.ts +13 -4
- package/src/internal/{proxy → common/proxy}/ownership.ts +0 -1
- package/src/internal/{proxy → common/proxy}/reactive.ts +1 -2
- package/src/internal/{proxy → common/proxy}/schema.test.ts +10 -10
- package/src/internal/{proxy → common/proxy}/typed-handler.test.ts +14 -19
- package/src/internal/{proxy → common/proxy}/typed-handler.ts +11 -6
- package/src/internal/{proxy → common/proxy}/typed-object.test.ts +15 -16
- package/src/internal/{types → common/types}/base.ts +1 -1
- package/src/internal/{types → common/types}/entity.ts +2 -2
- package/src/internal/{types → common/types}/index.ts +1 -0
- package/src/internal/{types → common/types}/meta.ts +15 -14
- package/src/internal/common/types/model-symbols.ts +69 -0
- package/src/internal/{types → common/types}/typename.ts +10 -0
- package/src/internal/{types → common/types}/version.ts +2 -3
- package/src/internal/index.ts +9 -31
- package/src/testing/api.test.ts +4 -5
- package/src/testing/test-data.ts +0 -1
- package/src/testing/test-schema.ts +20 -18
- package/dist/lib/browser/Database.mjs +0 -18
- package/dist/lib/browser/Filter.mjs +0 -62
- package/dist/lib/browser/JsonSchema.mjs +0 -20
- package/dist/lib/browser/Obj.mjs +0 -91
- package/dist/lib/browser/Query.mjs +0 -27
- package/dist/lib/browser/QueryResult.mjs +0 -3
- package/dist/lib/browser/Ref.mjs +0 -23
- package/dist/lib/browser/SchemaRegistry.mjs +0 -3
- package/dist/lib/browser/Tag.mjs +0 -26
- package/dist/lib/browser/Type.mjs +0 -48
- package/dist/lib/browser/chunk-22JMFST2.mjs +0 -24
- package/dist/lib/browser/chunk-22JMFST2.mjs.map +0 -7
- package/dist/lib/browser/chunk-2SBB7OWV.mjs.map +0 -7
- package/dist/lib/browser/chunk-6L5HHUVU.mjs +0 -158
- package/dist/lib/browser/chunk-6L5HHUVU.mjs.map +0 -7
- package/dist/lib/browser/chunk-7STIBCP7.mjs +0 -133
- package/dist/lib/browser/chunk-7STIBCP7.mjs.map +0 -7
- package/dist/lib/browser/chunk-BJPE6CIC.mjs.map +0 -7
- package/dist/lib/browser/chunk-CJ5YELTO.mjs.map +0 -7
- package/dist/lib/browser/chunk-FPOISFQK.mjs +0 -40
- package/dist/lib/browser/chunk-FPOISFQK.mjs.map +0 -7
- package/dist/lib/browser/chunk-FRDT7RA4.mjs.map +0 -7
- package/dist/lib/browser/chunk-INHXFXY5.mjs.map +0 -7
- package/dist/lib/browser/chunk-JMKVF2YQ.mjs.map +0 -7
- package/dist/lib/browser/chunk-KQQGVHFN.mjs.map +0 -7
- package/dist/lib/browser/chunk-MYCCGG2T.mjs +0 -15
- package/dist/lib/browser/chunk-MYCCGG2T.mjs.map +0 -7
- package/dist/lib/browser/chunk-NOPVNWPT.mjs +0 -204
- package/dist/lib/browser/chunk-NOPVNWPT.mjs.map +0 -7
- package/dist/lib/browser/chunk-PQZW3S6L.mjs.map +0 -7
- package/dist/lib/browser/chunk-RK4Z4JUZ.mjs +0 -283
- package/dist/lib/browser/chunk-RK4Z4JUZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-U2J7TA7K.mjs.map +0 -7
- package/dist/lib/browser/chunk-W5D2GWAW.mjs +0 -98
- package/dist/lib/browser/chunk-W5D2GWAW.mjs.map +0 -7
- package/dist/lib/browser/chunk-XDIUHAAX.mjs.map +0 -7
- package/dist/lib/browser/chunk-YKTSSMDS.mjs.map +0 -7
- package/dist/lib/browser/chunk-ZAGAOZVY.mjs.map +0 -7
- package/dist/lib/browser/chunk-ZHXZGIXD.mjs.map +0 -7
- package/dist/lib/browser/index.mjs +0 -85
- package/dist/lib/browser/meta.json +0 -1
- package/dist/lib/browser/testing/index.mjs +0 -367
- package/dist/lib/browser/testing/index.mjs.map +0 -7
- package/dist/lib/node-esm/Annotation.mjs +0 -33
- package/dist/lib/node-esm/Annotation.mjs.map +0 -7
- package/dist/lib/node-esm/Database.mjs +0 -18
- package/dist/lib/node-esm/Database.mjs.map +0 -7
- package/dist/lib/node-esm/Entity.mjs +0 -52
- package/dist/lib/node-esm/Entity.mjs.map +0 -7
- package/dist/lib/node-esm/Err.mjs +0 -11
- package/dist/lib/node-esm/Err.mjs.map +0 -7
- package/dist/lib/node-esm/Filter.mjs +0 -62
- package/dist/lib/node-esm/Format.mjs +0 -67
- package/dist/lib/node-esm/JsonSchema.mjs +0 -20
- package/dist/lib/node-esm/JsonSchema.mjs.map +0 -7
- package/dist/lib/node-esm/Key.mjs +0 -13
- package/dist/lib/node-esm/Key.mjs.map +0 -7
- package/dist/lib/node-esm/Obj.mjs.map +0 -7
- package/dist/lib/node-esm/Order.mjs +0 -13
- package/dist/lib/node-esm/Order.mjs.map +0 -7
- package/dist/lib/node-esm/Query.mjs +0 -27
- package/dist/lib/node-esm/Query.mjs.map +0 -7
- package/dist/lib/node-esm/QueryResult.mjs +0 -3
- package/dist/lib/node-esm/QueryResult.mjs.map +0 -7
- package/dist/lib/node-esm/Ref.mjs +0 -23
- package/dist/lib/node-esm/Ref.mjs.map +0 -7
- package/dist/lib/node-esm/Relation.mjs +0 -85
- package/dist/lib/node-esm/Relation.mjs.map +0 -7
- package/dist/lib/node-esm/SchemaRegistry.mjs +0 -3
- package/dist/lib/node-esm/SchemaRegistry.mjs.map +0 -7
- package/dist/lib/node-esm/Tag.mjs +0 -26
- package/dist/lib/node-esm/Tag.mjs.map +0 -7
- package/dist/lib/node-esm/Type.mjs +0 -48
- package/dist/lib/node-esm/Type.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-4PNXQA64.mjs +0 -250
- package/dist/lib/node-esm/chunk-4PNXQA64.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-5OBN7GZW.mjs +0 -158
- package/dist/lib/node-esm/chunk-5OBN7GZW.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-AJEMYSIR.mjs +0 -22
- package/dist/lib/node-esm/chunk-ANLVLWME.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-DMR7OAFK.mjs +0 -57
- package/dist/lib/node-esm/chunk-DMR7OAFK.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-FWTSPIFF.mjs +0 -133
- package/dist/lib/node-esm/chunk-FWTSPIFF.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +0 -11
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ILMLLM4R.mjs +0 -204
- package/dist/lib/node-esm/chunk-ILMLLM4R.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-K37NA7PO.mjs +0 -43
- package/dist/lib/node-esm/chunk-K37NA7PO.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-LT3H4JOX.mjs +0 -3847
- package/dist/lib/node-esm/chunk-LT3H4JOX.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-MOLNWFNL.mjs +0 -9
- package/dist/lib/node-esm/chunk-MOWUEW5P.mjs +0 -15
- package/dist/lib/node-esm/chunk-MOWUEW5P.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NBWL7UCZ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NRN3ZW2T.mjs +0 -143
- package/dist/lib/node-esm/chunk-NRN3ZW2T.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-QLI2EIJ2.mjs +0 -41
- package/dist/lib/node-esm/chunk-QLI2EIJ2.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-QYR67VBV.mjs +0 -288
- package/dist/lib/node-esm/chunk-QYR67VBV.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-UKGVOINP.mjs +0 -9
- package/dist/lib/node-esm/chunk-UKGVOINP.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-W6QIEBTQ.mjs +0 -403
- package/dist/lib/node-esm/chunk-W6QIEBTQ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-XHJRMQZD.mjs +0 -69
- package/dist/lib/node-esm/chunk-XHJRMQZD.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-Y75VU7LB.mjs +0 -74
- package/dist/lib/node-esm/chunk-Y75VU7LB.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-YOLH5KS4.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-YQ2NWGL5.mjs +0 -39
- package/dist/lib/node-esm/chunk-YQ2NWGL5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ZBB67AKD.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -85
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/internal/index.mjs +0 -457
- package/dist/lib/node-esm/internal/index.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/testing/index.mjs.map +0 -7
- package/dist/types/src/internal/annotations/annotations.d.ts.map +0 -1
- package/dist/types/src/internal/annotations/annotations.test.d.ts.map +0 -1
- package/dist/types/src/internal/annotations/index.d.ts +0 -3
- package/dist/types/src/internal/annotations/index.d.ts.map +0 -1
- package/dist/types/src/internal/annotations/util.d.ts.map +0 -1
- package/dist/types/src/internal/api/annotations.d.ts +0 -23
- package/dist/types/src/internal/api/annotations.d.ts.map +0 -1
- package/dist/types/src/internal/api/entity.d.ts.map +0 -1
- package/dist/types/src/internal/api/index.d.ts.map +0 -1
- package/dist/types/src/internal/api/meta.d.ts.map +0 -1
- package/dist/types/src/internal/api/sorting.d.ts.map +0 -1
- package/dist/types/src/internal/api/version.d.ts.map +0 -1
- package/dist/types/src/internal/entities/entity.d.ts.map +0 -1
- package/dist/types/src/internal/entities/index.d.ts.map +0 -1
- package/dist/types/src/internal/entities/model.d.ts.map +0 -1
- package/dist/types/src/internal/entities/object.d.ts.map +0 -1
- package/dist/types/src/internal/entities/relation.d.ts.map +0 -1
- package/dist/types/src/internal/entities/util.d.ts.map +0 -1
- package/dist/types/src/internal/formats/date.d.ts.map +0 -1
- package/dist/types/src/internal/formats/date.test.d.ts.map +0 -1
- package/dist/types/src/internal/formats/format.d.ts.map +0 -1
- package/dist/types/src/internal/formats/format.test.d.ts.map +0 -1
- package/dist/types/src/internal/formats/index.d.ts.map +0 -1
- package/dist/types/src/internal/formats/number.d.ts.map +0 -1
- package/dist/types/src/internal/formats/object.d.ts.map +0 -1
- package/dist/types/src/internal/formats/select.d.ts.map +0 -1
- package/dist/types/src/internal/formats/string.d.ts.map +0 -1
- package/dist/types/src/internal/formats/types.d.ts.map +0 -1
- package/dist/types/src/internal/json-schema/annotations.d.ts.map +0 -1
- package/dist/types/src/internal/json-schema/effect-schema.test.d.ts.map +0 -1
- package/dist/types/src/internal/json-schema/index.d.ts.map +0 -1
- package/dist/types/src/internal/json-schema/json-schema-normalize.d.ts.map +0 -1
- package/dist/types/src/internal/json-schema/json-schema-type.d.ts.map +0 -1
- package/dist/types/src/internal/json-schema/json-schema.d.ts.map +0 -1
- package/dist/types/src/internal/json-schema/json-schema.test.d.ts.map +0 -1
- package/dist/types/src/internal/object/clone.d.ts.map +0 -1
- package/dist/types/src/internal/object/common.d.ts.map +0 -1
- package/dist/types/src/internal/object/create-object.d.ts.map +0 -1
- package/dist/types/src/internal/object/create-object.test.d.ts.map +0 -1
- package/dist/types/src/internal/object/deleted.d.ts.map +0 -1
- package/dist/types/src/internal/object/ids.d.ts.map +0 -1
- package/dist/types/src/internal/object/index.d.ts.map +0 -1
- package/dist/types/src/internal/object/inspect.d.ts.map +0 -1
- package/dist/types/src/internal/object/json-serializer.d.ts.map +0 -1
- package/dist/types/src/internal/object/json-serializer.test.d.ts.map +0 -1
- package/dist/types/src/internal/object/schema-validator.d.ts +0 -2
- package/dist/types/src/internal/object/schema-validator.d.ts.map +0 -1
- package/dist/types/src/internal/object/schema-validator.test.d.ts.map +0 -1
- package/dist/types/src/internal/object/set-value.d.ts.map +0 -1
- package/dist/types/src/internal/object/set-value.test.d.ts.map +0 -1
- package/dist/types/src/internal/object/snapshot.d.ts.map +0 -1
- package/dist/types/src/internal/object/typed-object.d.ts.map +0 -1
- package/dist/types/src/internal/object/typed-object.test.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/change-context.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/change.test.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/define-hidden-property.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/errors.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/event-batch.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/handler.test.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/index.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/json-serializer.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/make-object.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/ownership.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/proxy-types.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/proxy-utils.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/reactive-array.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/reactive.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/schema-validator.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/schema.test.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/symbols.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/typed-handler.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/typed-handler.test.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/typed-object.test.d.ts.map +0 -1
- package/dist/types/src/internal/ref/index.d.ts.map +0 -1
- package/dist/types/src/internal/ref/ref-array.d.ts.map +0 -1
- package/dist/types/src/internal/ref/ref.d.ts.map +0 -1
- package/dist/types/src/internal/ref/ref.test.d.ts.map +0 -1
- package/dist/types/src/internal/schema/compose.d.ts +0 -6
- package/dist/types/src/internal/schema/compose.d.ts.map +0 -1
- package/dist/types/src/internal/schema/compose.test.d.ts.map +0 -1
- package/dist/types/src/internal/schema/echo-schema.d.ts.map +0 -1
- package/dist/types/src/internal/schema/index.d.ts.map +0 -1
- package/dist/types/src/internal/schema/manipulation.d.ts.map +0 -1
- package/dist/types/src/internal/schema/persistent-schema.d.ts.map +0 -1
- package/dist/types/src/internal/types/base.d.ts.map +0 -1
- package/dist/types/src/internal/types/entity.d.ts.map +0 -1
- package/dist/types/src/internal/types/index.d.ts.map +0 -1
- package/dist/types/src/internal/types/meta.d.ts.map +0 -1
- package/dist/types/src/internal/types/typename.d.ts.map +0 -1
- package/dist/types/src/internal/types/version.d.ts.map +0 -1
- package/src/internal/api/annotations.ts +0 -60
- package/src/internal/object/snapshot.ts +0 -70
- /package/dist/lib/{browser → neutral}/Annotation.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Database.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Entity.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Err.mjs.map +0 -0
- /package/dist/lib/{browser/Filter.mjs.map → neutral/Extension.mjs.map} +0 -0
- /package/dist/lib/{browser/Format.mjs.map → neutral/Feed.mjs.map} +0 -0
- /package/dist/lib/{node-esm → neutral}/Filter.mjs.map +0 -0
- /package/dist/lib/{node-esm → neutral}/Format.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/JsonSchema.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Key.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Obj.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Order.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Query.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/QueryResult.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Ref.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Relation.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/SchemaRegistry.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Tag.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/Type.mjs.map +0 -0
- /package/dist/lib/{browser/chunk-CGS2ULMK.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/lib/{browser → neutral}/index.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/internal/index.mjs.map +0 -0
- /package/dist/types/src/internal/{annotations → Annotation}/annotations.test.d.ts +0 -0
- /package/dist/types/src/internal/{entities → Entity}/util.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/date.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/date.test.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/format.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/format.test.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/index.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/number.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/object.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/string.d.ts +0 -0
- /package/dist/types/src/internal/{json-schema → JsonSchema}/effect-schema.test.d.ts +0 -0
- /package/dist/types/src/internal/{json-schema → JsonSchema}/index.d.ts +0 -0
- /package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema-normalize.d.ts +0 -0
- /package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema.test.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/clone.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/common.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/create-object.test.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/ids.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/index.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/inspect.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/json-serializer.test.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/schema-validator.test.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/set-value.test.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/snapshot.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/typed-object.test.d.ts +0 -0
- /package/dist/types/src/internal/{ref → Ref}/index.d.ts +0 -0
- /package/dist/types/src/internal/{ref → Ref}/ref.test.d.ts +0 -0
- /package/dist/types/src/internal/{schema → Type}/compose.test.d.ts +0 -0
- /package/dist/types/src/internal/{schema → Type}/index.d.ts +0 -0
- /package/dist/types/src/internal/{schema → Type}/manipulation.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/change-context.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/change.test.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/define-hidden-property.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/errors.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/event-batch.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/handler.test.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/index.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/json-serializer.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/make-object.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/ownership.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/proxy-types.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/proxy-utils.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/reactive-array.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/schema-validator.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/schema.test.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/symbols.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/typed-handler.test.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/typed-object.test.d.ts +0 -0
- /package/src/internal/{entities → Entity}/util.ts +0 -0
- /package/src/internal/{formats → Format}/date.ts +0 -0
- /package/src/internal/{formats → Format}/format.ts +0 -0
- /package/src/internal/{formats → Format}/index.ts +0 -0
- /package/src/internal/{formats → Format}/number.ts +0 -0
- /package/src/internal/{formats → Format}/object.ts +0 -0
- /package/src/internal/{formats → Format}/string.ts +0 -0
- /package/src/internal/{json-schema → JsonSchema}/effect-schema.test.ts +0 -0
- /package/src/internal/{json-schema → JsonSchema}/index.ts +0 -0
- /package/src/internal/{object → Obj}/ids.ts +0 -0
- /package/src/internal/{object → Obj}/index.ts +0 -0
- /package/src/internal/{ref → Ref}/index.ts +0 -0
- /package/src/internal/{schema → Type}/index.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/change-context.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/define-hidden-property.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/errors.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/event-batch.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/index.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/proxy-types.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/proxy-utils.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/reactive-array.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/schema-validator.ts +0 -0
- /package/src/internal/{proxy → common/proxy}/symbols.ts +0 -0
|
@@ -4,8 +4,8 @@
|
|
|
4
4
|
|
|
5
5
|
import * as Schema from 'effect/Schema';
|
|
6
6
|
|
|
7
|
-
import { getTypename } from '../
|
|
8
|
-
import { type AnyProperties } from '../types';
|
|
7
|
+
import { getTypename } from '../Annotation';
|
|
8
|
+
import { type AnyProperties } from '../common/types';
|
|
9
9
|
|
|
10
10
|
// TODO(dmaretskyi): Rename to represent commonality between objects and relations (e.g. `entity`).
|
|
11
11
|
export type TypedObjectOptions = {
|
|
@@ -2,19 +2,17 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { inspect } from 'util';
|
|
6
|
-
|
|
7
5
|
import * as Schema from 'effect/Schema';
|
|
6
|
+
import { inspect } from 'util';
|
|
8
7
|
import { describe, expect, test } from 'vitest';
|
|
9
8
|
|
|
10
9
|
import { DXN } from '@dxos/keys';
|
|
11
10
|
|
|
12
11
|
import { Relation } from '../../index';
|
|
13
12
|
import { TestSchema } from '../../testing';
|
|
14
|
-
import { getSchemaDXN, getTypeDXN, isInstanceOf } from '../
|
|
15
|
-
import {
|
|
16
|
-
import {
|
|
17
|
-
|
|
13
|
+
import { getSchemaDXN, getTypeDXN, isInstanceOf } from '../Annotation';
|
|
14
|
+
import { ATTR_META, ATTR_TYPE, getSchema } from '../common/types';
|
|
15
|
+
import { ATTR_RELATION_SOURCE, ATTR_RELATION_TARGET } from '../Entity';
|
|
18
16
|
import { createObject } from './create-object';
|
|
19
17
|
import { objectToJSON } from './json-serializer';
|
|
20
18
|
|
|
@@ -110,7 +108,7 @@ describe('create (static version)', () => {
|
|
|
110
108
|
const text = inspect(contact);
|
|
111
109
|
expect(text).toContain('Bot');
|
|
112
110
|
expect(text).toContain('bot@example.com');
|
|
113
|
-
expect(text).toContain('example.
|
|
111
|
+
expect(text).toContain('com.example.type.person');
|
|
114
112
|
expect(text).toContain('0.1.0');
|
|
115
113
|
});
|
|
116
114
|
});
|
|
@@ -8,7 +8,9 @@ import { raise } from '@dxos/debug';
|
|
|
8
8
|
import { assertArgument, failedInvariant } from '@dxos/invariant';
|
|
9
9
|
import { ObjectId } from '@dxos/keys';
|
|
10
10
|
|
|
11
|
-
import { getSchemaDXN, getTypeAnnotation, setTypename } from '../
|
|
11
|
+
import { getSchemaDXN, getTypeAnnotation, setTypename } from '../Annotation';
|
|
12
|
+
import { defineHiddenProperty } from '../common/proxy';
|
|
13
|
+
import { EntityKind, KindId, MetaId, setSchema } from '../common/types';
|
|
12
14
|
import {
|
|
13
15
|
RelationSourceDXNId,
|
|
14
16
|
RelationSourceId,
|
|
@@ -16,10 +18,7 @@ import {
|
|
|
16
18
|
RelationTargetId,
|
|
17
19
|
assertObjectModel,
|
|
18
20
|
getObjectDXN,
|
|
19
|
-
} from '../
|
|
20
|
-
import { defineHiddenProperty } from '../proxy';
|
|
21
|
-
import { EntityKind, KindId, MetaId, setSchema } from '../types';
|
|
22
|
-
|
|
21
|
+
} from '../Entity';
|
|
23
22
|
import { attachedTypedObjectInspector } from './inspect';
|
|
24
23
|
import { attachTypedJsonSerializer } from './json-serializer';
|
|
25
24
|
|
|
@@ -42,7 +41,7 @@ export type CreateObjectProps<T> = T extends { id: string } ? Omit<T, 'id' | Kin
|
|
|
42
41
|
* name: Schema.String,
|
|
43
42
|
* email: Schema.String,
|
|
44
43
|
* }).pipe(Type.object({
|
|
45
|
-
* typename: 'example.
|
|
44
|
+
* typename: 'com.example.type.person',
|
|
46
45
|
* version: '0.1.0',
|
|
47
46
|
* }))
|
|
48
47
|
*
|
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
5
|
+
import { type AnyProperties } from '../common/types';
|
|
6
|
+
import { ObjectDeletedId } from '../Entity';
|
|
7
7
|
|
|
8
8
|
/**
|
|
9
9
|
* @returns `true` if the object has been marked as deleted.
|
|
@@ -6,8 +6,8 @@ import type { InspectOptionsStylized, inspect as inspectFn } from 'node:util';
|
|
|
6
6
|
|
|
7
7
|
import { type CustomInspectFunction, inspectCustom } from '@dxos/debug';
|
|
8
8
|
|
|
9
|
-
import { getTypeDXN } from '../
|
|
10
|
-
import { ATTR_META, ATTR_TYPE, type AnyEntity, MetaId } from '../types';
|
|
9
|
+
import { getTypeDXN } from '../Annotation';
|
|
10
|
+
import { ATTR_META, ATTR_TYPE, type AnyEntity, MetaId } from '../common/types';
|
|
11
11
|
|
|
12
12
|
/*
|
|
13
13
|
* @internal
|
|
@@ -8,20 +8,20 @@ import { DXN } from '@dxos/keys';
|
|
|
8
8
|
|
|
9
9
|
import * as Obj from '../../Obj';
|
|
10
10
|
import { TestSchema } from '../../testing';
|
|
11
|
-
import { getSchemaDXN, getSchemaTypename, getTypeDXN, getTypename } from '../
|
|
12
|
-
import {
|
|
13
|
-
import { makeObject } from '../proxy';
|
|
14
|
-
import {
|
|
15
|
-
import {
|
|
16
|
-
|
|
11
|
+
import { getSchemaDXN, getSchemaTypename, getTypeDXN, getTypename } from '../Annotation';
|
|
12
|
+
import { getMetaChecked } from '../common/api';
|
|
13
|
+
import { makeObject } from '../common/proxy';
|
|
14
|
+
import { ATTR_TYPE, EntityKind, KindId, MetaId, TypeId, getSchema } from '../common/types';
|
|
15
|
+
import { RelationSourceId, RelationTargetId, getObjectDXN } from '../Entity';
|
|
16
|
+
import { Ref, StaticRefResolver } from '../Ref';
|
|
17
17
|
import { createObject } from './create-object';
|
|
18
18
|
import { objectFromJSON, objectToJSON } from './json-serializer';
|
|
19
19
|
|
|
20
20
|
describe('Object JSON serializer', () => {
|
|
21
21
|
test('should serialize and deserialize object', async () => {
|
|
22
22
|
const contact = makeObject(TestSchema.Person, { name: 'Alice' });
|
|
23
|
-
Obj.change(contact, (
|
|
24
|
-
|
|
23
|
+
Obj.change(contact, (contact) => {
|
|
24
|
+
getMetaChecked(contact).keys.push({ id: '12345', source: 'example.com' });
|
|
25
25
|
});
|
|
26
26
|
|
|
27
27
|
const task = createObject(TestSchema.Task, {
|
|
@@ -94,4 +94,27 @@ describe('Object JSON serializer', () => {
|
|
|
94
94
|
expect(getObjectDXN(contactFromJson)).toEqual(getObjectDXN(contact));
|
|
95
95
|
expect(getTypeDXN(contactFromJson)).toEqual(getSchemaDXN(TestSchema.Person));
|
|
96
96
|
});
|
|
97
|
+
|
|
98
|
+
test('deserializes expando without leaking internal json keys', async () => {
|
|
99
|
+
const expando = Obj.make(TestSchema.Expando, { message: 'local-only' });
|
|
100
|
+
const expandoJson = objectToJSON(expando);
|
|
101
|
+
|
|
102
|
+
const refResolver = new StaticRefResolver().addSchema(TestSchema.Expando);
|
|
103
|
+
const expandoFromJson = (await objectFromJSON(expandoJson, { refResolver })) as TestSchema.Expando;
|
|
104
|
+
|
|
105
|
+
expect(expandoFromJson.id).toBe(expando.id);
|
|
106
|
+
expect(expandoFromJson.message).toBe('local-only');
|
|
107
|
+
expect((expandoFromJson as any)[ATTR_TYPE]).toBeUndefined();
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
test('deserializes expando without schema resolver and without leaking internal json keys', async () => {
|
|
111
|
+
const expando = Obj.make(TestSchema.Expando, { message: 'local-only' });
|
|
112
|
+
const expandoJson = objectToJSON(expando);
|
|
113
|
+
|
|
114
|
+
const expandoFromJson = (await objectFromJSON(expandoJson)) as TestSchema.Expando;
|
|
115
|
+
|
|
116
|
+
expect(expandoFromJson.id).toBe(expando.id);
|
|
117
|
+
expect(expandoFromJson.message).toBe('local-only');
|
|
118
|
+
expect((expandoFromJson as any)[ATTR_TYPE]).toBeUndefined();
|
|
119
|
+
});
|
|
97
120
|
});
|
|
@@ -10,13 +10,28 @@ import { assertArgument, invariant } from '@dxos/invariant';
|
|
|
10
10
|
import { DXN, ObjectId } from '@dxos/keys';
|
|
11
11
|
import { assumeType, deepMapValues, visitValues } from '@dxos/util';
|
|
12
12
|
|
|
13
|
+
import type * as Database from '../../Database';
|
|
13
14
|
import type * as Obj from '../../Obj';
|
|
14
|
-
import { getTypeDXN, setTypename } from '../
|
|
15
|
+
import { getTypeDXN, setTypename } from '../Annotation';
|
|
16
|
+
import { attachTypedJsonSerializer, defineHiddenProperty, typedJsonSerializer } from '../common/proxy';
|
|
17
|
+
import {
|
|
18
|
+
ATTR_META,
|
|
19
|
+
ATTR_PARENT,
|
|
20
|
+
ATTR_TYPE,
|
|
21
|
+
type AnyEntity,
|
|
22
|
+
EntityKind,
|
|
23
|
+
KindId,
|
|
24
|
+
MetaId,
|
|
25
|
+
ObjectMetaSchema,
|
|
26
|
+
ParentId,
|
|
27
|
+
setSchema,
|
|
28
|
+
} from '../common/types';
|
|
15
29
|
import {
|
|
16
30
|
ATTR_DELETED,
|
|
17
31
|
ATTR_RELATION_SOURCE,
|
|
18
32
|
ATTR_RELATION_TARGET,
|
|
19
33
|
ATTR_SELF_DXN,
|
|
34
|
+
ObjectDatabaseId,
|
|
20
35
|
type ObjectJSON,
|
|
21
36
|
RelationSourceDXNId,
|
|
22
37
|
RelationSourceId,
|
|
@@ -24,19 +39,8 @@ import {
|
|
|
24
39
|
RelationTargetId,
|
|
25
40
|
SelfDXNId,
|
|
26
41
|
assertObjectModel,
|
|
27
|
-
} from '../
|
|
28
|
-
import {
|
|
29
|
-
import { Ref, type RefResolver, refFromEncodedReference, setRefResolver } from '../ref';
|
|
30
|
-
import {
|
|
31
|
-
ATTR_META,
|
|
32
|
-
ATTR_TYPE,
|
|
33
|
-
type AnyEntity,
|
|
34
|
-
EntityKind,
|
|
35
|
-
KindId,
|
|
36
|
-
MetaId,
|
|
37
|
-
ObjectMetaSchema,
|
|
38
|
-
setSchema,
|
|
39
|
-
} from '../types';
|
|
42
|
+
} from '../Entity';
|
|
43
|
+
import { Ref, type RefResolver, refFromEncodedReference, setRefResolver } from '../Ref';
|
|
40
44
|
|
|
41
45
|
// Re-export for backward compatibility.
|
|
42
46
|
export { attachTypedJsonSerializer };
|
|
@@ -68,10 +72,20 @@ export const objectToJSON = <T extends AnyEntity>(obj: T): SerializedObject<T> =
|
|
|
68
72
|
* Performs schema validation.
|
|
69
73
|
* References and schema will be resolvable if the `refResolver` is provided.
|
|
70
74
|
* The function need to be async to support resolving the schema as well as the relation endpoints.
|
|
75
|
+
*
|
|
76
|
+
* @param jsonData - JSON representation of the object.
|
|
77
|
+
* @param options.refResolver - Resolver for references.
|
|
78
|
+
* @param options.dxn - Override object DXN.
|
|
79
|
+
* @param options.database - Database to associate with the object.
|
|
71
80
|
*/
|
|
72
81
|
export const objectFromJSON = async (
|
|
73
82
|
jsonData: unknown,
|
|
74
|
-
{
|
|
83
|
+
{
|
|
84
|
+
refResolver,
|
|
85
|
+
dxn,
|
|
86
|
+
database,
|
|
87
|
+
parent,
|
|
88
|
+
}: { refResolver?: RefResolver; dxn?: DXN; database?: Database.Database; parent?: Obj.Unknown } = {},
|
|
75
89
|
): Promise<AnyEntity> => {
|
|
76
90
|
assumeType<ObjectJSON>(jsonData);
|
|
77
91
|
assertArgument(typeof jsonData === 'object' && jsonData !== null, 'jsonData', 'expect object');
|
|
@@ -81,15 +95,16 @@ export const objectFromJSON = async (
|
|
|
81
95
|
const type = DXN.parse(jsonData[ATTR_TYPE]);
|
|
82
96
|
const schema = await refResolver?.resolveSchema(type);
|
|
83
97
|
invariant(schema === undefined || Schema.isSchema(schema));
|
|
98
|
+
const decodedInput = stripInternalJsonKeys(jsonData);
|
|
84
99
|
|
|
85
100
|
let obj: any;
|
|
86
101
|
if (schema != null) {
|
|
87
|
-
obj = await schema.pipe(Schema.decodeUnknownPromise)(
|
|
102
|
+
obj = await schema.pipe(Schema.decodeUnknownPromise)(decodedInput);
|
|
88
103
|
if (refResolver) {
|
|
89
104
|
setRefResolverOnData(obj, refResolver);
|
|
90
105
|
}
|
|
91
106
|
} else {
|
|
92
|
-
obj = decodeGeneric(
|
|
107
|
+
obj = decodeGeneric(decodedInput, { refResolver });
|
|
93
108
|
}
|
|
94
109
|
|
|
95
110
|
invariant(ObjectId.isValid(obj.id), 'Invalid object id');
|
|
@@ -126,10 +141,22 @@ export const objectFromJSON = async (
|
|
|
126
141
|
});
|
|
127
142
|
}
|
|
128
143
|
|
|
144
|
+
if (jsonData[ATTR_PARENT]) {
|
|
145
|
+
const parentDxn = DXN.parse(jsonData[ATTR_PARENT]);
|
|
146
|
+
const resolvedParent = (await refResolver?.resolve(parentDxn)) as Obj.Unknown | undefined;
|
|
147
|
+
defineHiddenProperty(obj, ParentId, resolvedParent);
|
|
148
|
+
} else if (parent) {
|
|
149
|
+
defineHiddenProperty(obj, ParentId, parent);
|
|
150
|
+
}
|
|
151
|
+
|
|
129
152
|
if (dxn) {
|
|
130
153
|
defineHiddenProperty(obj, SelfDXNId, dxn);
|
|
131
154
|
}
|
|
132
155
|
|
|
156
|
+
if (database) {
|
|
157
|
+
defineHiddenProperty(obj, ObjectDatabaseId, database);
|
|
158
|
+
}
|
|
159
|
+
|
|
133
160
|
assertObjectModel(obj);
|
|
134
161
|
invariant((obj as any)[ATTR_TYPE] === undefined, 'Invalid object model');
|
|
135
162
|
invariant((obj as any)[ATTR_META] === undefined, 'Invalid object model');
|
|
@@ -141,6 +168,18 @@ export const objectFromJSON = async (
|
|
|
141
168
|
};
|
|
142
169
|
|
|
143
170
|
const decodeGeneric = (jsonData: unknown, options: { refResolver?: RefResolver }) => {
|
|
171
|
+
const props = stripInternalJsonKeys(jsonData);
|
|
172
|
+
|
|
173
|
+
return deepMapValues(props, (value, visitor) => {
|
|
174
|
+
if (isEncodedReference(value)) {
|
|
175
|
+
return refFromEncodedReference(value, options.refResolver);
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
return visitor(value);
|
|
179
|
+
});
|
|
180
|
+
};
|
|
181
|
+
|
|
182
|
+
const stripInternalJsonKeys = (jsonData: unknown) => {
|
|
144
183
|
const {
|
|
145
184
|
[ATTR_TYPE]: _type,
|
|
146
185
|
[ATTR_META]: _meta,
|
|
@@ -151,13 +190,7 @@ const decodeGeneric = (jsonData: unknown, options: { refResolver?: RefResolver }
|
|
|
151
190
|
...props
|
|
152
191
|
} = jsonData as any;
|
|
153
192
|
|
|
154
|
-
return
|
|
155
|
-
if (isEncodedReference(value)) {
|
|
156
|
-
return refFromEncodedReference(value, options.refResolver);
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
return visitor(value);
|
|
160
|
-
});
|
|
193
|
+
return props;
|
|
161
194
|
};
|
|
162
195
|
|
|
163
196
|
export const setRefResolverOnData = (obj: AnyEntity, refResolver: RefResolver) => {
|
|
@@ -182,6 +215,7 @@ export const objectStructureToJson = (objectId: string, structure: ObjectStructu
|
|
|
182
215
|
id: objectId,
|
|
183
216
|
[ATTR_TYPE]: (ObjectStructure.getTypeReference(structure)?.['/'] ?? '') as DXN.String,
|
|
184
217
|
[ATTR_DELETED]: ObjectStructure.isDeleted(structure),
|
|
218
|
+
[ATTR_PARENT]: ObjectStructure.getParent(structure)?.['/'] as DXN.String | undefined,
|
|
185
219
|
[ATTR_RELATION_SOURCE]: ObjectStructure.getRelationSource(structure)?.['/'] as DXN.String | undefined,
|
|
186
220
|
[ATTR_RELATION_TARGET]: ObjectStructure.getRelationTarget(structure)?.['/'] as DXN.String | undefined,
|
|
187
221
|
};
|
|
@@ -27,9 +27,7 @@ describe('schema-validator', () => {
|
|
|
27
27
|
const TestSchema: Schema.Schema.AnyNoContext = Schema.Struct({
|
|
28
28
|
name: Schema.String.annotations({ [annotationId]: annotationValue }),
|
|
29
29
|
parent: Schema.optional(Schema.suspend(() => TestSchema.annotations({ [annotationId]: annotationValue }))),
|
|
30
|
-
friends: Schema.suspend(() =>
|
|
31
|
-
Schema.mutable(Schema.Array(TestSchema.annotations({ [annotationId]: annotationValue }))),
|
|
32
|
-
),
|
|
30
|
+
friends: Schema.suspend(() => Schema.Array(TestSchema.annotations({ [annotationId]: annotationValue }))),
|
|
33
31
|
});
|
|
34
32
|
expect(SchemaValidator.hasTypeAnnotation(TestSchema, 'name', annotationId)).to.be.true;
|
|
35
33
|
expect(SchemaValidator.hasTypeAnnotation(TestSchema, 'parent', annotationId)).to.be.true;
|
|
@@ -41,7 +39,7 @@ describe('schema-validator', () => {
|
|
|
41
39
|
const Person: Schema.Schema.AnyNoContext = Schema.Struct({
|
|
42
40
|
name: Schema.String,
|
|
43
41
|
parent: Schema.optional(Schema.suspend(() => Person)),
|
|
44
|
-
friends: Schema.suspend(() => Schema.
|
|
42
|
+
friends: Schema.suspend(() => Schema.Array(Person)),
|
|
45
43
|
});
|
|
46
44
|
expect(SchemaValidator.hasTypeAnnotation(Person, 'name', annotationId)).to.be.false;
|
|
47
45
|
expect(SchemaValidator.hasTypeAnnotation(Person, 'parent', annotationId)).to.be.false;
|
|
@@ -87,9 +85,7 @@ describe('schema-validator', () => {
|
|
|
87
85
|
const annotationValue = 'bar';
|
|
88
86
|
const Person: Schema.Schema.AnyNoContext = Schema.Struct({
|
|
89
87
|
parent: Schema.optional(Schema.suspend(() => Person.annotations({ [annotationId]: annotationValue }))),
|
|
90
|
-
friends: Schema.suspend(() =>
|
|
91
|
-
Schema.mutable(Schema.Array(Person.annotations({ [annotationId]: annotationValue }))),
|
|
92
|
-
),
|
|
88
|
+
friends: Schema.suspend(() => Schema.Array(Person.annotations({ [annotationId]: annotationValue }))),
|
|
93
89
|
});
|
|
94
90
|
expect(SchemaValidator.getPropertySchema(Person, ['parent']).ast.annotations[annotationId]).to.eq(
|
|
95
91
|
annotationValue,
|
|
@@ -17,7 +17,7 @@ describe('Obj.setValue', () => {
|
|
|
17
17
|
email: 'john@example.com',
|
|
18
18
|
});
|
|
19
19
|
|
|
20
|
-
Obj.change(person, (
|
|
20
|
+
Obj.change(person, (person) => Obj.setValue(person, ['address', 'city'], 'NYC'));
|
|
21
21
|
|
|
22
22
|
expect(person.address).toBeDefined();
|
|
23
23
|
expect(person.address?.city).toBe('NYC');
|
|
@@ -30,7 +30,7 @@ describe('Obj.setValue', () => {
|
|
|
30
30
|
email: 'john@example.com',
|
|
31
31
|
});
|
|
32
32
|
|
|
33
|
-
Obj.change(person, (
|
|
33
|
+
Obj.change(person, (person) => Obj.setValue(person, ['fields', 0, 'label'], 'Phone'));
|
|
34
34
|
|
|
35
35
|
expect(Array.isArray(person.fields)).toBe(true);
|
|
36
36
|
expect(person.fields?.[0].label).toBe('Phone');
|
|
@@ -45,7 +45,7 @@ describe('Obj.setValue', () => {
|
|
|
45
45
|
email: 'john@example.com',
|
|
46
46
|
});
|
|
47
47
|
|
|
48
|
-
Obj.change(person, (
|
|
48
|
+
Obj.change(person, (person) => Obj.setValue(person, ['address', 'coordinates', 'lat'], 40.7128));
|
|
49
49
|
|
|
50
50
|
expect(person.address).toBeDefined();
|
|
51
51
|
expect(person.address?.coordinates).toBeDefined();
|
|
@@ -55,11 +55,11 @@ describe('Obj.setValue', () => {
|
|
|
55
55
|
test('sets multiple nested array elements', ({ expect }) => {
|
|
56
56
|
const Item = Schema.Struct({
|
|
57
57
|
value: Schema.optional(Schema.Number),
|
|
58
|
-
})
|
|
58
|
+
});
|
|
59
59
|
|
|
60
60
|
const Container = Schema.Struct({
|
|
61
61
|
name: Schema.String,
|
|
62
|
-
items: Schema.optional(Schema.
|
|
62
|
+
items: Schema.optional(Schema.Array(Item)),
|
|
63
63
|
}).pipe(
|
|
64
64
|
Type.object({
|
|
65
65
|
typename: 'test.com/Container',
|
|
@@ -69,10 +69,10 @@ describe('Obj.setValue', () => {
|
|
|
69
69
|
|
|
70
70
|
const container = Obj.make(Container, { name: 'box' });
|
|
71
71
|
|
|
72
|
-
Obj.change(container, (
|
|
73
|
-
Obj.setValue(
|
|
74
|
-
Obj.setValue(
|
|
75
|
-
Obj.setValue(
|
|
72
|
+
Obj.change(container, (container) => {
|
|
73
|
+
Obj.setValue(container, ['items', 0, 'value'], 10);
|
|
74
|
+
Obj.setValue(container, ['items', 1, 'value'], 20);
|
|
75
|
+
Obj.setValue(container, ['items', 2, 'value'], 30);
|
|
76
76
|
});
|
|
77
77
|
|
|
78
78
|
expect(container.items).toHaveLength(3);
|
|
@@ -88,7 +88,7 @@ describe('Obj.setValue', () => {
|
|
|
88
88
|
email: 'john@example.com',
|
|
89
89
|
});
|
|
90
90
|
|
|
91
|
-
Obj.change(person, (
|
|
91
|
+
Obj.change(person, (person) => Obj.setValue(person, ['age'], 25));
|
|
92
92
|
|
|
93
93
|
expect(person.age).toBe(25);
|
|
94
94
|
});
|
|
@@ -100,7 +100,7 @@ describe('Obj.setValue', () => {
|
|
|
100
100
|
email: 'john@example.com',
|
|
101
101
|
});
|
|
102
102
|
|
|
103
|
-
Obj.change(person, (
|
|
103
|
+
Obj.change(person, (person) => Obj.setValue(person, ['address', 'city'], 'NYC'));
|
|
104
104
|
|
|
105
105
|
expect(person.address).toBeDefined();
|
|
106
106
|
expect(person.address?.city).toBe('NYC');
|
|
@@ -114,8 +114,8 @@ describe('Obj.setValue', () => {
|
|
|
114
114
|
});
|
|
115
115
|
|
|
116
116
|
let result: any;
|
|
117
|
-
Obj.change(person, (
|
|
118
|
-
result = Obj.setValue(
|
|
117
|
+
Obj.change(person, (person) => {
|
|
118
|
+
result = Obj.setValue(person, ['age'], 30);
|
|
119
119
|
});
|
|
120
120
|
|
|
121
121
|
expect(result).toBe(30);
|
|
@@ -129,7 +129,7 @@ describe('Obj.setValue', () => {
|
|
|
129
129
|
age: 25,
|
|
130
130
|
});
|
|
131
131
|
|
|
132
|
-
Obj.change(person, (
|
|
132
|
+
Obj.change(person, (person) => Obj.setValue(person, ['age'], 30));
|
|
133
133
|
|
|
134
134
|
expect(person.age).toBe(30);
|
|
135
135
|
});
|
|
@@ -142,7 +142,7 @@ describe('Obj.setValue', () => {
|
|
|
142
142
|
address: { city: 'Boston', state: 'MA', coordinates: {} },
|
|
143
143
|
});
|
|
144
144
|
|
|
145
|
-
Obj.change(person, (
|
|
145
|
+
Obj.change(person, (person) => Obj.setValue(person, ['address', 'city'], 'NYC'));
|
|
146
146
|
|
|
147
147
|
expect(person.address?.city).toBe('NYC');
|
|
148
148
|
expect(person.address?.state).toBe('MA');
|
|
@@ -150,7 +150,7 @@ describe('Obj.setValue', () => {
|
|
|
150
150
|
|
|
151
151
|
test('handles two-dimensional arrays', ({ expect }) => {
|
|
152
152
|
const Matrix = Schema.Struct({
|
|
153
|
-
values: Schema.optional(Schema.
|
|
153
|
+
values: Schema.optional(Schema.Array(Schema.Array(Schema.Number))),
|
|
154
154
|
}).pipe(
|
|
155
155
|
Type.object({
|
|
156
156
|
typename: 'test.com/Matrix',
|
|
@@ -160,11 +160,11 @@ describe('Obj.setValue', () => {
|
|
|
160
160
|
|
|
161
161
|
const matrix = Obj.make(Matrix, {});
|
|
162
162
|
|
|
163
|
-
Obj.change(matrix, (
|
|
164
|
-
Obj.setValue(
|
|
165
|
-
Obj.setValue(
|
|
166
|
-
Obj.setValue(
|
|
167
|
-
Obj.setValue(
|
|
163
|
+
Obj.change(matrix, (matrix) => {
|
|
164
|
+
Obj.setValue(matrix, ['values', 0, 0], 1);
|
|
165
|
+
Obj.setValue(matrix, ['values', 0, 1], 2);
|
|
166
|
+
Obj.setValue(matrix, ['values', 1, 0], 3);
|
|
167
|
+
Obj.setValue(matrix, ['values', 1, 1], 4);
|
|
168
168
|
});
|
|
169
169
|
|
|
170
170
|
expect(matrix.values?.[0][0]).toBe(1);
|
|
@@ -180,8 +180,8 @@ describe('Obj.setValue', () => {
|
|
|
180
180
|
email: 'john@example.com',
|
|
181
181
|
});
|
|
182
182
|
|
|
183
|
-
Obj.change(person, (
|
|
184
|
-
expect(() => Obj.setValue(
|
|
183
|
+
Obj.change(person, (person) => {
|
|
184
|
+
expect(() => Obj.setValue(person, [], 'value')).toThrow('Path must not be empty');
|
|
185
185
|
});
|
|
186
186
|
});
|
|
187
187
|
|
|
@@ -192,7 +192,7 @@ describe('Obj.setValue', () => {
|
|
|
192
192
|
email: 'john@example.com',
|
|
193
193
|
});
|
|
194
194
|
|
|
195
|
-
Obj.change(person, (
|
|
195
|
+
Obj.change(person, (person) => Obj.setValue(person, ['age'], 30));
|
|
196
196
|
|
|
197
197
|
expect(person.age).toBe(30);
|
|
198
198
|
});
|
|
@@ -200,11 +200,11 @@ describe('Obj.setValue', () => {
|
|
|
200
200
|
test('handles numeric keys as strings', ({ expect }) => {
|
|
201
201
|
const Item = Schema.Struct({
|
|
202
202
|
value: Schema.optional(Schema.Number),
|
|
203
|
-
})
|
|
203
|
+
});
|
|
204
204
|
|
|
205
205
|
const Container = Schema.Struct({
|
|
206
206
|
name: Schema.String,
|
|
207
|
-
items: Schema.optional(Schema.
|
|
207
|
+
items: Schema.optional(Schema.Array(Item)),
|
|
208
208
|
}).pipe(
|
|
209
209
|
Type.object({
|
|
210
210
|
typename: 'test.com/Container',
|
|
@@ -215,7 +215,7 @@ describe('Obj.setValue', () => {
|
|
|
215
215
|
const container = Obj.make(Container, { name: 'box' });
|
|
216
216
|
|
|
217
217
|
// Using string '0' for array index.
|
|
218
|
-
Obj.change(container, (
|
|
218
|
+
Obj.change(container, (container) => Obj.setValue(container, ['items', '0', 'value'], 42));
|
|
219
219
|
|
|
220
220
|
expect(container.items?.[0].value).toBe(42);
|
|
221
221
|
});
|
|
@@ -227,11 +227,11 @@ describe('Obj.setValue', () => {
|
|
|
227
227
|
id: Schema.String, // Required field.
|
|
228
228
|
title: Schema.optional(Schema.String),
|
|
229
229
|
completed: Schema.optional(Schema.Boolean),
|
|
230
|
-
})
|
|
230
|
+
});
|
|
231
231
|
|
|
232
232
|
const TodoList = Schema.Struct({
|
|
233
233
|
name: Schema.String,
|
|
234
|
-
tasks: Schema.optional(Schema.
|
|
234
|
+
tasks: Schema.optional(Schema.Array(Task)),
|
|
235
235
|
}).pipe(
|
|
236
236
|
Type.object({
|
|
237
237
|
typename: 'test.com/TodoList',
|
|
@@ -243,7 +243,7 @@ describe('Obj.setValue', () => {
|
|
|
243
243
|
|
|
244
244
|
// This should work: setting a nested property on an array element.
|
|
245
245
|
// The required 'id' field should be initialized with a default value.
|
|
246
|
-
Obj.change(todoList, (
|
|
246
|
+
Obj.change(todoList, (todoList) => Obj.setValue(todoList, ['tasks', 0, 'title'], 'Buy groceries'));
|
|
247
247
|
|
|
248
248
|
expect(todoList.tasks?.[0].id).toBe(''); // Default value for required String
|
|
249
249
|
expect(todoList.tasks?.[0].title).toBe('Buy groceries');
|
|
@@ -256,11 +256,11 @@ describe('Obj.setValue', () => {
|
|
|
256
256
|
count: Schema.Number, // Required - should default to 0
|
|
257
257
|
active: Schema.Boolean, // Required - should default to false
|
|
258
258
|
label: Schema.optional(Schema.String), // Optional - should not be initialized
|
|
259
|
-
})
|
|
259
|
+
});
|
|
260
260
|
|
|
261
261
|
const Container = Schema.Struct({
|
|
262
262
|
name: Schema.String,
|
|
263
|
-
items: Schema.optional(Schema.
|
|
263
|
+
items: Schema.optional(Schema.Array(Item)),
|
|
264
264
|
}).pipe(
|
|
265
265
|
Type.object({
|
|
266
266
|
typename: 'test.com/Container',
|
|
@@ -270,7 +270,7 @@ describe('Obj.setValue', () => {
|
|
|
270
270
|
|
|
271
271
|
const container = Obj.make(Container, { name: 'box' });
|
|
272
272
|
|
|
273
|
-
Obj.change(container, (
|
|
273
|
+
Obj.change(container, (container) => Obj.setValue(container, ['items', 0, 'label'], 'First Item'));
|
|
274
274
|
|
|
275
275
|
// All required primitive fields should have default values.
|
|
276
276
|
expect(container.items?.[0].id).toBe('');
|
|
@@ -16,8 +16,8 @@ import {
|
|
|
16
16
|
} from '@dxos/effect';
|
|
17
17
|
import { invariant } from '@dxos/invariant';
|
|
18
18
|
|
|
19
|
-
import { type Mutable } from '../proxy';
|
|
20
|
-
import { getSchema } from '../types';
|
|
19
|
+
import { type Mutable } from '../common/proxy';
|
|
20
|
+
import { getSchema } from '../common/types';
|
|
21
21
|
|
|
22
22
|
/**
|
|
23
23
|
* Set a deeply nested property on an object.
|