@graphprotocol/grc-20 0.31.0 → 0.32.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/README.md +4 -0
- package/dist/constants.d.ts +7 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +8 -0
- package/dist/constants.js.map +1 -0
- package/dist/convert-ids.d.ts +2 -0
- package/dist/convert-ids.d.ts.map +1 -0
- package/dist/convert-ids.js +42 -0
- package/dist/convert-ids.js.map +1 -0
- package/dist/examples/ranks/create-ordinal-rank.js +4 -4
- package/dist/examples/ranks/create-ordinal-rank.js.map +1 -1
- package/dist/examples/ranks/create-weighted-rank.js +4 -4
- package/dist/examples/ranks/create-weighted-rank.js.map +1 -1
- package/dist/proto.d.ts +4 -8
- package/dist/proto.d.ts.map +1 -1
- package/dist/proto.js +4 -8
- package/dist/proto.js.map +1 -1
- package/dist/protov2.d.ts +11 -0
- package/dist/protov2.d.ts.map +1 -0
- package/dist/protov2.js +11 -0
- package/dist/protov2.js.map +1 -0
- package/dist/scripts/setup-rank-types.d.ts +2 -2
- package/dist/scripts/setup-rank-types.d.ts.map +1 -1
- package/dist/scripts/setup-rank-types.js.map +1 -1
- package/dist/src/codec/convert.d.ts +18 -0
- package/dist/src/codec/convert.d.ts.map +1 -0
- package/dist/src/codec/convert.js +188 -0
- package/dist/src/codec/convert.js.map +1 -0
- package/dist/src/core/account.d.ts +2 -2
- package/dist/src/core/account.d.ts.map +1 -1
- package/dist/src/core/account.js +2 -0
- package/dist/src/core/account.js.map +1 -1
- package/dist/src/core/account.test.js +69 -22
- package/dist/src/core/account.test.js.map +1 -1
- package/dist/src/core/blocks/data.d.ts +3 -3
- package/dist/src/core/blocks/data.d.ts.map +1 -1
- package/dist/src/core/blocks/data.js +2 -1
- package/dist/src/core/blocks/data.js.map +1 -1
- package/dist/src/core/blocks/data.test.js +74 -36
- package/dist/src/core/blocks/data.test.js.map +1 -1
- package/dist/src/core/blocks/image.d.ts +15 -0
- package/dist/src/core/blocks/image.d.ts.map +1 -0
- package/dist/src/core/blocks/image.js +15 -0
- package/dist/src/core/blocks/image.js.map +1 -0
- package/dist/src/core/blocks/text.d.ts +3 -3
- package/dist/src/core/blocks/text.d.ts.map +1 -1
- package/dist/src/core/blocks/text.js +2 -1
- package/dist/src/core/blocks/text.js.map +1 -1
- package/dist/src/core/blocks/text.test.js +79 -15
- package/dist/src/core/blocks/text.test.js.map +1 -1
- package/dist/src/core/idsv2/content.d.ts +59 -0
- package/dist/src/core/idsv2/content.d.ts.map +1 -0
- package/dist/src/core/idsv2/content.js +59 -0
- package/dist/src/core/idsv2/content.js.map +1 -0
- package/dist/src/core/idsv2/network.d.ts +5 -0
- package/dist/src/core/idsv2/network.d.ts.map +1 -0
- package/dist/src/core/idsv2/network.js +5 -0
- package/dist/src/core/idsv2/network.js.map +1 -0
- package/dist/src/core/idsv2/system.d.ts +222 -0
- package/dist/src/core/idsv2/system.d.ts.map +1 -0
- package/dist/src/core/idsv2/system.js +230 -0
- package/dist/src/core/idsv2/system.js.map +1 -0
- package/dist/src/core/image.d.ts +40 -0
- package/dist/src/core/image.d.ts.map +1 -0
- package/dist/src/core/image.js +76 -0
- package/dist/src/core/image.js.map +1 -0
- package/dist/src/core/image.test.d.ts +2 -0
- package/dist/src/core/image.test.d.ts.map +1 -0
- package/dist/src/core/image.test.js +52 -0
- package/dist/src/core/image.test.js.map +1 -0
- package/dist/src/core/relation.d.ts +88 -0
- package/dist/src/core/relation.d.ts.map +1 -0
- package/dist/src/core/relation.js +89 -0
- package/dist/src/core/relation.js.map +1 -0
- package/dist/src/core/relation.test.d.ts +2 -0
- package/dist/src/core/relation.test.d.ts.map +1 -0
- package/dist/src/core/relation.test.js +45 -0
- package/dist/src/core/relation.test.js.map +1 -0
- package/dist/src/core/triple.d.ts +50 -0
- package/dist/src/core/triple.d.ts.map +1 -0
- package/dist/src/core/triple.js +56 -0
- package/dist/src/core/triple.js.map +1 -0
- package/dist/src/core/triple.test.d.ts +2 -0
- package/dist/src/core/triple.test.d.ts.map +1 -0
- package/dist/src/core/triple.test.js +37 -0
- package/dist/src/core/triple.test.js.map +1 -0
- package/dist/src/encoding.d.ts +2 -1
- package/dist/src/encoding.d.ts.map +1 -1
- package/dist/src/encoding.js +2 -2
- package/dist/src/encoding.js.map +1 -1
- package/dist/src/encoding.test.d.ts +2 -0
- package/dist/src/encoding.test.d.ts.map +1 -0
- package/dist/src/encoding.test.js +644 -0
- package/dist/src/encoding.test.js.map +1 -0
- package/dist/src/encodings/get-register-space-calldata.d.ts +32 -0
- package/dist/src/encodings/get-register-space-calldata.d.ts.map +1 -0
- package/dist/src/encodings/get-register-space-calldata.js +39 -0
- package/dist/src/encodings/get-register-space-calldata.js.map +1 -0
- package/dist/src/encodings/get-register-space-calldata.test.d.ts +2 -0
- package/dist/src/encodings/get-register-space-calldata.test.d.ts.map +1 -0
- package/dist/src/encodings/get-register-space-calldata.test.js +15 -0
- package/dist/src/encodings/get-register-space-calldata.test.js.map +1 -0
- package/dist/src/full-flow-test.test.js +125 -37
- package/dist/src/full-flow-test.test.js.map +1 -1
- package/dist/src/graph/constants.d.ts +4 -0
- package/dist/src/graph/constants.d.ts.map +1 -1
- package/dist/src/graph/constants.js +14 -0
- package/dist/src/graph/constants.js.map +1 -1
- package/dist/src/graph/create-entity.d.ts +0 -1
- package/dist/src/graph/create-entity.d.ts.map +1 -1
- package/dist/src/graph/create-entity.js +155 -111
- package/dist/src/graph/create-entity.js.map +1 -1
- package/dist/src/graph/create-entity.test.js +339 -206
- package/dist/src/graph/create-entity.test.js.map +1 -1
- package/dist/src/graph/create-image.d.ts.map +1 -1
- package/dist/src/graph/create-image.js +15 -14
- package/dist/src/graph/create-image.js.map +1 -1
- package/dist/src/graph/create-image.test.js +109 -50
- package/dist/src/graph/create-image.test.js.map +1 -1
- package/dist/src/graph/create-property.d.ts.map +1 -1
- package/dist/src/graph/create-property.js +10 -19
- package/dist/src/graph/create-property.js.map +1 -1
- package/dist/src/graph/create-property.test.js +129 -19
- package/dist/src/graph/create-property.test.js.map +1 -1
- package/dist/src/graph/create-relation.d.ts +1 -3
- package/dist/src/graph/create-relation.d.ts.map +1 -1
- package/dist/src/graph/create-relation.js +21 -37
- package/dist/src/graph/create-relation.js.map +1 -1
- package/dist/src/graph/create-relation.test.js +186 -200
- package/dist/src/graph/create-relation.test.js.map +1 -1
- package/dist/src/graph/create-space.d.ts +4 -3
- package/dist/src/graph/create-space.d.ts.map +1 -1
- package/dist/src/graph/create-space.js +2 -2
- package/dist/src/graph/create-space.js.map +1 -1
- package/dist/src/graph/create-type.d.ts.map +1 -1
- package/dist/src/graph/create-type.js +16 -21
- package/dist/src/graph/create-type.js.map +1 -1
- package/dist/src/graph/create-type.test.js +76 -67
- package/dist/src/graph/create-type.test.js.map +1 -1
- package/dist/src/graph/delete-entity.d.ts +14 -0
- package/dist/src/graph/delete-entity.d.ts.map +1 -0
- package/dist/src/graph/delete-entity.js +21 -0
- package/dist/src/graph/delete-entity.js.map +1 -0
- package/dist/src/graph/delete-entity.test.d.ts +2 -0
- package/dist/src/graph/delete-entity.test.d.ts.map +1 -0
- package/dist/src/graph/delete-entity.test.js +23 -0
- package/dist/src/graph/delete-entity.test.js.map +1 -0
- package/dist/src/graph/delete-relation.d.ts.map +1 -1
- package/dist/src/graph/delete-relation.js +3 -6
- package/dist/src/graph/delete-relation.js.map +1 -1
- package/dist/src/graph/delete-relation.test.js +6 -8
- package/dist/src/graph/delete-relation.test.js.map +1 -1
- package/dist/src/graph/graph.test.d.ts +2 -0
- package/dist/src/graph/graph.test.d.ts.map +1 -0
- package/dist/src/graph/graph.test.js +46 -0
- package/dist/src/graph/graph.test.js.map +1 -0
- package/dist/src/graph/helpers/create-default-properties.d.ts +5 -0
- package/dist/src/graph/helpers/create-default-properties.d.ts.map +1 -0
- package/dist/src/graph/helpers/create-default-properties.js +44 -0
- package/dist/src/graph/helpers/create-default-properties.js.map +1 -0
- package/dist/src/graph/helpers/create-properties.d.ts +8 -0
- package/dist/src/graph/helpers/create-properties.d.ts.map +1 -0
- package/dist/src/graph/helpers/create-properties.js +53 -0
- package/dist/src/graph/helpers/create-properties.js.map +1 -0
- package/dist/src/graph/index.d.ts +1 -4
- package/dist/src/graph/index.d.ts.map +1 -1
- package/dist/src/graph/index.js +1 -4
- package/dist/src/graph/index.js.map +1 -1
- package/dist/src/graph/update-entity.d.ts.map +1 -1
- package/dist/src/graph/update-entity.js +109 -57
- package/dist/src/graph/update-entity.js.map +1 -1
- package/dist/src/graph/update-entity.test.js +167 -40
- package/dist/src/graph/update-entity.test.js.map +1 -1
- package/dist/src/graph/update-relation.d.ts +1 -2
- package/dist/src/graph/update-relation.d.ts.map +1 -1
- package/dist/src/graph/update-relation.js +12 -16
- package/dist/src/graph/update-relation.js.map +1 -1
- package/dist/src/graph/update-relation.test.js +75 -109
- package/dist/src/graph/update-relation.test.js.map +1 -1
- package/dist/src/graphv2/constants.d.ts +2 -0
- package/dist/src/graphv2/constants.d.ts.map +1 -0
- package/dist/src/graphv2/constants.js +2 -0
- package/dist/src/graphv2/constants.js.map +1 -0
- package/dist/src/graphv2/create-entity.d.ts +52 -0
- package/dist/src/graphv2/create-entity.d.ts.map +1 -0
- package/dist/src/graphv2/create-entity.js +140 -0
- package/dist/src/graphv2/create-entity.js.map +1 -0
- package/dist/src/graphv2/create-entity.test.d.ts +2 -0
- package/dist/src/graphv2/create-entity.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-entity.test.js +158 -0
- package/dist/src/graphv2/create-entity.test.js.map +1 -0
- package/dist/src/graphv2/create-image.d.ts +28 -0
- package/dist/src/graphv2/create-image.d.ts.map +1 -0
- package/dist/src/graphv2/create-image.js +71 -0
- package/dist/src/graphv2/create-image.js.map +1 -0
- package/dist/src/graphv2/create-image.test.d.ts +2 -0
- package/dist/src/graphv2/create-image.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-image.test.js +142 -0
- package/dist/src/graphv2/create-image.test.js.map +1 -0
- package/dist/src/graphv2/create-property.d.ts +22 -0
- package/dist/src/graphv2/create-property.d.ts.map +1 -0
- package/dist/src/graphv2/create-property.js +129 -0
- package/dist/src/graphv2/create-property.js.map +1 -0
- package/dist/src/graphv2/create-property.test.d.ts +2 -0
- package/dist/src/graphv2/create-property.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-property.test.js +82 -0
- package/dist/src/graphv2/create-property.test.js.map +1 -0
- package/dist/src/graphv2/create-relation.d.ts +33 -0
- package/dist/src/graphv2/create-relation.d.ts.map +1 -0
- package/dist/src/graphv2/create-relation.js +66 -0
- package/dist/src/graphv2/create-relation.js.map +1 -0
- package/dist/src/graphv2/create-relation.test.d.ts +2 -0
- package/dist/src/graphv2/create-relation.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-relation.test.js +208 -0
- package/dist/src/graphv2/create-relation.test.js.map +1 -0
- package/dist/src/graphv2/create-space.d.ts +13 -0
- package/dist/src/graphv2/create-space.d.ts.map +1 -0
- package/dist/src/graphv2/create-space.js +21 -0
- package/dist/src/graphv2/create-space.js.map +1 -0
- package/dist/src/graphv2/create-type.d.ts +22 -0
- package/dist/src/graphv2/create-type.d.ts.map +1 -0
- package/dist/src/graphv2/create-type.js +64 -0
- package/dist/src/graphv2/create-type.js.map +1 -0
- package/dist/src/graphv2/create-type.test.d.ts +2 -0
- package/dist/src/graphv2/create-type.test.d.ts.map +1 -0
- package/dist/src/graphv2/create-type.test.js +109 -0
- package/dist/src/graphv2/create-type.test.js.map +1 -0
- package/dist/src/graphv2/delete-entity.d.ts +14 -0
- package/dist/src/graphv2/delete-entity.d.ts.map +1 -0
- package/dist/src/graphv2/delete-entity.js +21 -0
- package/dist/src/graphv2/delete-entity.js.map +1 -0
- package/dist/src/graphv2/delete-entity.test.d.ts +2 -0
- package/dist/src/graphv2/delete-entity.test.d.ts.map +1 -0
- package/dist/src/graphv2/delete-entity.test.js +24 -0
- package/dist/src/graphv2/delete-entity.test.js.map +1 -0
- package/dist/src/graphv2/delete-relation.d.ts +14 -0
- package/dist/src/graphv2/delete-relation.d.ts.map +1 -0
- package/dist/src/graphv2/delete-relation.js +21 -0
- package/dist/src/graphv2/delete-relation.js.map +1 -0
- package/dist/src/graphv2/delete-relation.test.d.ts +2 -0
- package/dist/src/graphv2/delete-relation.test.d.ts.map +1 -0
- package/dist/src/graphv2/delete-relation.test.js +24 -0
- package/dist/src/graphv2/delete-relation.test.js.map +1 -0
- package/dist/src/graphv2/index.d.ts +12 -0
- package/dist/src/graphv2/index.d.ts.map +1 -0
- package/dist/src/graphv2/index.js +12 -0
- package/dist/src/graphv2/index.js.map +1 -0
- package/dist/src/graphv2/remove-entity-properties.d.ts +25 -0
- package/dist/src/graphv2/remove-entity-properties.d.ts.map +1 -0
- package/dist/src/graphv2/remove-entity-properties.js +24 -0
- package/dist/src/graphv2/remove-entity-properties.js.map +1 -0
- package/dist/src/graphv2/unset-entity-values.d.ts +21 -0
- package/dist/src/graphv2/unset-entity-values.d.ts.map +1 -0
- package/dist/src/graphv2/unset-entity-values.js +26 -0
- package/dist/src/graphv2/unset-entity-values.js.map +1 -0
- package/dist/src/graphv2/unset-entity-values.test.d.ts +2 -0
- package/dist/src/graphv2/unset-entity-values.test.d.ts.map +1 -0
- package/dist/src/graphv2/unset-entity-values.test.js +40 -0
- package/dist/src/graphv2/unset-entity-values.test.js.map +1 -0
- package/dist/src/graphv2/unset-relation-fields.d.ts +25 -0
- package/dist/src/graphv2/unset-relation-fields.d.ts.map +1 -0
- package/dist/src/graphv2/unset-relation-fields.js +34 -0
- package/dist/src/graphv2/unset-relation-fields.js.map +1 -0
- package/dist/src/graphv2/unset-relation-fields.test.d.ts +2 -0
- package/dist/src/graphv2/unset-relation-fields.test.d.ts.map +1 -0
- package/dist/src/graphv2/unset-relation-fields.test.js +64 -0
- package/dist/src/graphv2/unset-relation-fields.test.js.map +1 -0
- package/dist/src/graphv2/update-entity.d.ts +28 -0
- package/dist/src/graphv2/update-entity.d.ts.map +1 -0
- package/dist/src/graphv2/update-entity.js +73 -0
- package/dist/src/graphv2/update-entity.js.map +1 -0
- package/dist/src/graphv2/update-entity.test.d.ts +2 -0
- package/dist/src/graphv2/update-entity.test.d.ts.map +1 -0
- package/dist/src/graphv2/update-entity.test.js +116 -0
- package/dist/src/graphv2/update-entity.test.js.map +1 -0
- package/dist/src/graphv2/update-relation.d.ts +21 -0
- package/dist/src/graphv2/update-relation.d.ts.map +1 -0
- package/dist/src/graphv2/update-relation.js +37 -0
- package/dist/src/graphv2/update-relation.js.map +1 -0
- package/dist/src/id-utils.d.ts +6 -0
- package/dist/src/id-utils.d.ts.map +1 -1
- package/dist/src/id-utils.js +13 -0
- package/dist/src/id-utils.js.map +1 -1
- package/dist/src/idv2.d.ts +27 -0
- package/dist/src/idv2.d.ts.map +1 -0
- package/dist/src/idv2.js +88 -0
- package/dist/src/idv2.js.map +1 -0
- package/dist/src/idv2.test.d.ts +2 -0
- package/dist/src/idv2.test.d.ts.map +1 -0
- package/dist/src/idv2.test.js +26 -0
- package/dist/src/idv2.test.js.map +1 -0
- package/dist/src/image.d.ts +8 -0
- package/dist/src/image.d.ts.map +1 -0
- package/dist/src/image.js +8 -0
- package/dist/src/image.js.map +1 -0
- package/dist/src/ipfs.d.ts +7 -6
- package/dist/src/ipfs.d.ts.map +1 -1
- package/dist/src/ipfs.js +31 -11
- package/dist/src/ipfs.js.map +1 -1
- package/dist/src/ipfs.test.js +130 -17
- package/dist/src/ipfs.test.js.map +1 -1
- package/dist/src/ipfsv2.d.ts +96 -0
- package/dist/src/ipfsv2.d.ts.map +1 -0
- package/dist/src/ipfsv2.js +163 -0
- package/dist/src/ipfsv2.js.map +1 -0
- package/dist/src/ipfsv2.test.d.ts +2 -0
- package/dist/src/ipfsv2.test.d.ts.map +1 -0
- package/dist/src/ipfsv2.test.js +22 -0
- package/dist/src/ipfsv2.test.js.map +1 -0
- package/dist/src/proto/editv2.d.ts +11 -0
- package/dist/src/proto/editv2.d.ts.map +1 -0
- package/dist/src/proto/editv2.js +81 -0
- package/dist/src/proto/editv2.js.map +1 -0
- package/dist/src/proto/editv2.test.d.ts +2 -0
- package/dist/src/proto/editv2.test.d.ts.map +1 -0
- package/dist/src/proto/editv2.test.js +211 -0
- package/dist/src/proto/editv2.test.js.map +1 -0
- package/dist/src/proto/gen/src/proto/ipfsv2_pb.d.ts +410 -0
- package/dist/src/proto/gen/src/proto/ipfsv2_pb.d.ts.map +1 -0
- package/dist/src/proto/gen/src/proto/ipfsv2_pb.js +536 -0
- package/dist/src/proto/gen/src/proto/ipfsv2_pb.js.map +1 -0
- package/dist/src/proto/index.d.ts +7 -1
- package/dist/src/proto/index.d.ts.map +1 -1
- package/dist/src/proto/index.js +6 -1
- package/dist/src/proto/index.js.map +1 -1
- package/dist/src/ranks/create-rank.d.ts.map +1 -1
- package/dist/src/ranks/create-rank.js +54 -47
- package/dist/src/ranks/create-rank.js.map +1 -1
- package/dist/src/ranks/create-rank.test.js +181 -94
- package/dist/src/ranks/create-rank.test.js.map +1 -1
- package/dist/src/relation.d.ts +7 -0
- package/dist/src/relation.d.ts.map +1 -0
- package/dist/src/relation.js +7 -0
- package/dist/src/relation.js.map +1 -0
- package/dist/src/smart-wallet-2.test-invalid.d.ts +2 -0
- package/dist/src/smart-wallet-2.test-invalid.d.ts.map +1 -0
- package/dist/src/smart-wallet-2.test-invalid.js +49 -0
- package/dist/src/smart-wallet-2.test-invalid.js.map +1 -0
- package/dist/src/smart-wallet-2.test.d.ts +2 -0
- package/dist/src/smart-wallet-2.test.d.ts.map +1 -0
- package/dist/src/smart-wallet-2.test.js +49 -0
- package/dist/src/smart-wallet-2.test.js.map +1 -0
- package/dist/src/system-ids-v2.d.ts +7 -0
- package/dist/src/system-ids-v2.d.ts.map +1 -0
- package/dist/src/system-ids-v2.js +7 -0
- package/dist/src/system-ids-v2.js.map +1 -0
- package/dist/src/triple.d.ts +7 -0
- package/dist/src/triple.d.ts.map +1 -0
- package/dist/src/triple.js +7 -0
- package/dist/src/triple.js.map +1 -0
- package/dist/src/types-backup.d.ts +134 -0
- package/dist/src/types-backup.d.ts.map +1 -0
- package/dist/src/types-backup.js +13 -0
- package/dist/src/types-backup.js.map +1 -0
- package/dist/src/types.d.ts +52 -89
- package/dist/src/types.d.ts.map +1 -1
- package/dist/src/types.js.map +1 -1
- package/dist/src/typesv2.d.ts +173 -0
- package/dist/src/typesv2.d.ts.map +1 -0
- package/dist/src/typesv2.js +8 -0
- package/dist/src/typesv2.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +2 -5
|
@@ -1,6 +1,7 @@
|
|
|
1
|
+
import { createRelation as grcCreateRelation } from '@geoprotocol/grc-20';
|
|
1
2
|
import { PROPERTIES, SCHEMA_TYPE, TYPES_PROPERTY } from '../core/ids/system.js';
|
|
2
3
|
import { Id } from '../id.js';
|
|
3
|
-
import { assertValid, generate } from '../id-utils.js';
|
|
4
|
+
import { assertValid, generate, toGrcId } from '../id-utils.js';
|
|
4
5
|
import { createEntity } from './create-entity.js';
|
|
5
6
|
/**
|
|
6
7
|
* Creates a type with the given name, description, cover and properties.
|
|
@@ -37,30 +38,24 @@ export const createType = ({ id: providedId, name, description, cover, propertie
|
|
|
37
38
|
});
|
|
38
39
|
// set property "Types" to "Type"
|
|
39
40
|
assertValid(id);
|
|
40
|
-
ops.push({
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
type: TYPES_PROPERTY,
|
|
48
|
-
},
|
|
49
|
-
});
|
|
41
|
+
ops.push(grcCreateRelation({
|
|
42
|
+
id: toGrcId(generate()),
|
|
43
|
+
entity: toGrcId(generate()),
|
|
44
|
+
from: toGrcId(id),
|
|
45
|
+
to: toGrcId(SCHEMA_TYPE),
|
|
46
|
+
relationType: toGrcId(TYPES_PROPERTY),
|
|
47
|
+
}));
|
|
50
48
|
if (properties) {
|
|
51
49
|
for (const propertyId of properties) {
|
|
52
50
|
assertValid(propertyId, '`propertyId` in `createType`');
|
|
53
51
|
// Set Properties on the Type
|
|
54
|
-
ops.push({
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
type: PROPERTIES,
|
|
62
|
-
},
|
|
63
|
-
});
|
|
52
|
+
ops.push(grcCreateRelation({
|
|
53
|
+
id: toGrcId(generate()),
|
|
54
|
+
entity: toGrcId(generate()),
|
|
55
|
+
from: toGrcId(id),
|
|
56
|
+
to: toGrcId(propertyId),
|
|
57
|
+
relationType: toGrcId(PROPERTIES),
|
|
58
|
+
}));
|
|
64
59
|
}
|
|
65
60
|
}
|
|
66
61
|
return { id: Id(id), ops };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-type.js","sourceRoot":"","sources":["../../../src/graph/create-type.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAChF,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"create-type.js","sourceRoot":"","sources":["../../../src/graph/create-type.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,cAAc,IAAI,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAC5F,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAChF,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAEhE,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EACzB,EAAE,EAAE,UAAU,EACd,IAAI,EACJ,WAAW,EACX,KAAK,EACL,UAAU,GACO,EAAgB,EAAE;IACnC,IAAI,UAAU,EAAE,CAAC;QACf,WAAW,CAAC,UAAU,EAAE,sBAAsB,CAAC,CAAC;IAClD,CAAC;IACD,KAAK,MAAM,UAAU,IAAI,UAAU,IAAI,EAAE,EAAE,CAAC;QAC1C,WAAW,CAAC,UAAU,EAAE,8BAA8B,CAAC,CAAC;IAC1D,CAAC;IACD,MAAM,EAAE,GAAG,UAAU,IAAI,QAAQ,EAAE,CAAC;IAEpC,MAAM,EAAE,GAAG,EAAE,GAAG,YAAY,CAAC;QAC3B,EAAE;QACF,IAAI;QACJ,WAAW;QACX,KAAK;KACN,CAAC,CAAC;IAEH,iCAAiC;IACjC,WAAW,CAAC,EAAE,CAAC,CAAC;IACf,GAAe,CAAC,IAAI,CACnB,iBAAiB,CAAC;QAChB,EAAE,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC;QACvB,MAAM,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,EAAE,OAAO,CAAC,EAAE,CAAC;QACjB,EAAE,EAAE,OAAO,CAAC,WAAW,CAAC;QACxB,YAAY,EAAE,OAAO,CAAC,cAAc,CAAC;KACtC,CAAC,CACH,CAAC;IAEF,IAAI,UAAU,EAAE,CAAC;QACf,KAAK,MAAM,UAAU,IAAI,UAAU,EAAE,CAAC;YACpC,WAAW,CAAC,UAAU,EAAE,8BAA8B,CAAC,CAAC;YACxD,6BAA6B;YAC5B,GAAe,CAAC,IAAI,CACnB,iBAAiB,CAAC;gBAChB,EAAE,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACvB,MAAM,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC;gBAC3B,IAAI,EAAE,OAAO,CAAC,EAAE,CAAC;gBACjB,EAAE,EAAE,OAAO,CAAC,UAAU,CAAC;gBACvB,YAAY,EAAE,OAAO,CAAC,UAAU,CAAC;aAClC,CAAC,CACH,CAAC;QACJ,CAAC;IACH,CAAC;IAED,OAAO,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC;AAC7B,CAAC,CAAC"}
|
|
@@ -2,6 +2,7 @@ import { describe, expect, it } from 'vitest';
|
|
|
2
2
|
import { AUTHORS_PROPERTY, WEBSITE_PROPERTY } from '../core/ids/content.js';
|
|
3
3
|
import { NAME_PROPERTY, PROPERTIES, SCHEMA_TYPE, TYPES_PROPERTY } from '../core/ids/system.js';
|
|
4
4
|
import { Id } from '../id.js';
|
|
5
|
+
import { toGrcId } from '../id-utils.js';
|
|
5
6
|
import { createType } from './create-type.js';
|
|
6
7
|
describe('createType', () => {
|
|
7
8
|
it('creates a basic type', async () => {
|
|
@@ -13,31 +14,25 @@ describe('createType', () => {
|
|
|
13
14
|
expect(type.ops).toBeDefined();
|
|
14
15
|
expect(type.ops.length).toBe(2);
|
|
15
16
|
// Check entity creation
|
|
16
|
-
|
|
17
|
-
expect(type
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
value: 'Article',
|
|
24
|
-
},
|
|
25
|
-
],
|
|
26
|
-
},
|
|
27
|
-
type: 'UPDATE_ENTITY',
|
|
17
|
+
const entityOp = type.ops[0];
|
|
18
|
+
expect(entityOp.type).toBe('createEntity');
|
|
19
|
+
expect(entityOp.id).toEqual(toGrcId(type.id));
|
|
20
|
+
// Verify name value
|
|
21
|
+
const nameValue = entityOp.values.find(v => {
|
|
22
|
+
const propBytes = v.property;
|
|
23
|
+
return propBytes.every((b, i) => b === toGrcId(NAME_PROPERTY)[i]);
|
|
28
24
|
});
|
|
29
|
-
|
|
30
|
-
expect(
|
|
31
|
-
if (
|
|
32
|
-
expect(
|
|
33
|
-
relation: {
|
|
34
|
-
fromEntity: type.id,
|
|
35
|
-
toEntity: SCHEMA_TYPE,
|
|
36
|
-
type: TYPES_PROPERTY,
|
|
37
|
-
},
|
|
38
|
-
type: 'CREATE_RELATION',
|
|
39
|
-
});
|
|
25
|
+
expect(nameValue).toBeDefined();
|
|
26
|
+
expect(nameValue?.value.type).toBe('text');
|
|
27
|
+
if (nameValue?.value.type === 'text') {
|
|
28
|
+
expect(nameValue.value.value).toBe('Article');
|
|
40
29
|
}
|
|
30
|
+
// Check type relation to SCHEMA_TYPE
|
|
31
|
+
const typeRelOp = type.ops[1];
|
|
32
|
+
expect(typeRelOp.type).toBe('createRelation');
|
|
33
|
+
expect(typeRelOp.from).toEqual(toGrcId(type.id));
|
|
34
|
+
expect(typeRelOp.to).toEqual(toGrcId(SCHEMA_TYPE));
|
|
35
|
+
expect(typeRelOp.relationType).toEqual(toGrcId(TYPES_PROPERTY));
|
|
41
36
|
});
|
|
42
37
|
it('creates a type with multiple properties', async () => {
|
|
43
38
|
const type = createType({
|
|
@@ -49,60 +44,74 @@ describe('createType', () => {
|
|
|
49
44
|
expect(type.ops).toBeDefined();
|
|
50
45
|
expect(type.ops.length).toBe(4);
|
|
51
46
|
// Check entity creation
|
|
52
|
-
|
|
53
|
-
expect(type
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
expect(
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
type: 'CREATE_RELATION',
|
|
74
|
-
});
|
|
75
|
-
// Check website relation
|
|
76
|
-
expect(type.ops[2]?.type).toBe('CREATE_RELATION');
|
|
77
|
-
expect(type.ops[2]).toMatchObject({
|
|
78
|
-
relation: {
|
|
79
|
-
fromEntity: type.id,
|
|
80
|
-
toEntity: WEBSITE_PROPERTY,
|
|
81
|
-
type: PROPERTIES,
|
|
82
|
-
},
|
|
83
|
-
type: 'CREATE_RELATION',
|
|
84
|
-
});
|
|
85
|
-
// Check author relation
|
|
86
|
-
expect(type.ops[3]?.type).toBe('CREATE_RELATION');
|
|
87
|
-
expect(type.ops[3]).toMatchObject({
|
|
88
|
-
relation: {
|
|
89
|
-
fromEntity: type.id,
|
|
90
|
-
toEntity: AUTHORS_PROPERTY,
|
|
91
|
-
type: PROPERTIES,
|
|
92
|
-
},
|
|
93
|
-
type: 'CREATE_RELATION',
|
|
94
|
-
});
|
|
47
|
+
const entityOp = type.ops[0];
|
|
48
|
+
expect(entityOp.type).toBe('createEntity');
|
|
49
|
+
expect(entityOp.id).toEqual(toGrcId(type.id));
|
|
50
|
+
// Check types relation to SCHEMA_TYPE
|
|
51
|
+
const typeRelOp = type.ops[1];
|
|
52
|
+
expect(typeRelOp.type).toBe('createRelation');
|
|
53
|
+
expect(typeRelOp.from).toEqual(toGrcId(type.id));
|
|
54
|
+
expect(typeRelOp.to).toEqual(toGrcId(SCHEMA_TYPE));
|
|
55
|
+
expect(typeRelOp.relationType).toEqual(toGrcId(TYPES_PROPERTY));
|
|
56
|
+
// Check first property relation
|
|
57
|
+
const prop1RelOp = type.ops[2];
|
|
58
|
+
expect(prop1RelOp.type).toBe('createRelation');
|
|
59
|
+
expect(prop1RelOp.from).toEqual(toGrcId(type.id));
|
|
60
|
+
expect(prop1RelOp.to).toEqual(toGrcId(WEBSITE_PROPERTY));
|
|
61
|
+
expect(prop1RelOp.relationType).toEqual(toGrcId(PROPERTIES));
|
|
62
|
+
// Check second property relation
|
|
63
|
+
const prop2RelOp = type.ops[3];
|
|
64
|
+
expect(prop2RelOp.type).toBe('createRelation');
|
|
65
|
+
expect(prop2RelOp.from).toEqual(toGrcId(type.id));
|
|
66
|
+
expect(prop2RelOp.to).toEqual(toGrcId(AUTHORS_PROPERTY));
|
|
67
|
+
expect(prop2RelOp.relationType).toEqual(toGrcId(PROPERTIES));
|
|
95
68
|
});
|
|
96
69
|
it('creates a type with a provided id', async () => {
|
|
70
|
+
const providedId = Id('b1dc6e5c63e143bab3d4755b251a4ea1');
|
|
97
71
|
const type = createType({
|
|
98
|
-
id:
|
|
72
|
+
id: providedId,
|
|
99
73
|
name: 'Article',
|
|
100
74
|
});
|
|
101
75
|
expect(type).toBeDefined();
|
|
102
76
|
expect(type.id).toBe('b1dc6e5c63e143bab3d4755b251a4ea1');
|
|
77
|
+
// Verify the entity op uses the provided ID
|
|
78
|
+
const entityOp = type.ops[0];
|
|
79
|
+
expect(entityOp.id).toEqual(toGrcId(providedId));
|
|
80
|
+
// Verify the type relation uses the provided ID
|
|
81
|
+
const typeRelOp = type.ops[1];
|
|
82
|
+
expect(typeRelOp.from).toEqual(toGrcId(providedId));
|
|
103
83
|
});
|
|
104
84
|
it('throws an error if the provided id is invalid', () => {
|
|
105
85
|
expect(() => createType({ id: 'invalid' })).toThrow('Invalid id: "invalid" for `id` in `createType`');
|
|
106
86
|
});
|
|
87
|
+
it('throws an error if a property id is invalid', () => {
|
|
88
|
+
expect(() => createType({
|
|
89
|
+
name: 'Article',
|
|
90
|
+
properties: ['invalid-property'],
|
|
91
|
+
})).toThrow('Invalid id: "invalid-property" for `properties` in `createType`');
|
|
92
|
+
});
|
|
93
|
+
it('creates a type with name, description, and cover', async () => {
|
|
94
|
+
const coverId = Id('30145d36d5a54244be593d111d879ba5');
|
|
95
|
+
const type = createType({
|
|
96
|
+
name: 'Article',
|
|
97
|
+
description: 'A news article type',
|
|
98
|
+
cover: coverId,
|
|
99
|
+
});
|
|
100
|
+
expect(type).toBeDefined();
|
|
101
|
+
// 1 createEntity + 1 cover relation + 1 type relation to SCHEMA_TYPE
|
|
102
|
+
expect(type.ops.length).toBe(3);
|
|
103
|
+
// Check entity op has name and description
|
|
104
|
+
const entityOp = type.ops[0];
|
|
105
|
+
expect(entityOp.type).toBe('createEntity');
|
|
106
|
+
expect(entityOp.values.length).toBe(2); // name + description
|
|
107
|
+
// Check cover relation
|
|
108
|
+
const coverRelOp = type.ops[1];
|
|
109
|
+
expect(coverRelOp.type).toBe('createRelation');
|
|
110
|
+
expect(coverRelOp.to).toEqual(toGrcId(coverId));
|
|
111
|
+
// Check type relation to SCHEMA_TYPE
|
|
112
|
+
const typeRelOp = type.ops[2];
|
|
113
|
+
expect(typeRelOp.type).toBe('createRelation');
|
|
114
|
+
expect(typeRelOp.to).toEqual(toGrcId(SCHEMA_TYPE));
|
|
115
|
+
});
|
|
107
116
|
});
|
|
108
117
|
//# sourceMappingURL=create-type.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-type.test.js","sourceRoot":"","sources":["../../../src/graph/create-type.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"create-type.test.js","sourceRoot":"","sources":["../../../src/graph/create-type.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { CreateResult, DeleteEntityParams } from '../types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Deletes an entity from a space.
|
|
4
|
+
*
|
|
5
|
+
* @example
|
|
6
|
+
* ```ts
|
|
7
|
+
* const { ops } = await deleteEntity({ id: entityId });
|
|
8
|
+
* ```
|
|
9
|
+
*
|
|
10
|
+
* @param params – {@link DeleteEntityParams}
|
|
11
|
+
* @returns The operations to delete the entity.
|
|
12
|
+
*/
|
|
13
|
+
export declare const deleteEntity: ({ id }: DeleteEntityParams) => CreateResult;
|
|
14
|
+
//# sourceMappingURL=delete-entity.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-entity.d.ts","sourceRoot":"","sources":["../../../src/graph/delete-entity.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAkB,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAEpF;;;;;;;;;;GAUG;AACH,eAAO,MAAM,YAAY,GAAI,QAAQ,kBAAkB,KAAG,YAQzD,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Id, assertValid } from '../id.js';
|
|
2
|
+
/**
|
|
3
|
+
* Deletes an entity from a space.
|
|
4
|
+
*
|
|
5
|
+
* @example
|
|
6
|
+
* ```ts
|
|
7
|
+
* const { ops } = await deleteEntity({ id: entityId });
|
|
8
|
+
* ```
|
|
9
|
+
*
|
|
10
|
+
* @param params – {@link DeleteEntityParams}
|
|
11
|
+
* @returns The operations to delete the entity.
|
|
12
|
+
*/
|
|
13
|
+
export const deleteEntity = ({ id }) => {
|
|
14
|
+
assertValid(id, '`id` in `deleteEntity`');
|
|
15
|
+
const op = {
|
|
16
|
+
type: 'DELETE_ENTITY',
|
|
17
|
+
id: Id(id),
|
|
18
|
+
};
|
|
19
|
+
return { id: Id(id), ops: [op] };
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=delete-entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-entity.js","sourceRoot":"","sources":["../../../src/graph/delete-entity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAG3C;;;;;;;;;;GAUG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAAE,EAAE,EAAsB,EAAgB,EAAE;IACvE,WAAW,CAAC,EAAE,EAAE,wBAAwB,CAAC,CAAC;IAC1C,MAAM,EAAE,GAAmB;QACzB,IAAI,EAAE,eAAe;QACrB,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC;KACX,CAAC;IAEF,OAAO,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;AACnC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-entity.test.d.ts","sourceRoot":"","sources":["../../../src/graph/delete-entity.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { Id } from '../id.js';
|
|
3
|
+
import { deleteEntity } from './delete-entity.js';
|
|
4
|
+
describe('deleteEntity', () => {
|
|
5
|
+
it('should create a delete entity operation with valid ID', () => {
|
|
6
|
+
const id = Id('5cade575-7ecd-41ae-8348-1b22ffc2f94e');
|
|
7
|
+
const result = deleteEntity({ id });
|
|
8
|
+
expect(result).toEqual({
|
|
9
|
+
id,
|
|
10
|
+
ops: [
|
|
11
|
+
{
|
|
12
|
+
type: 'DELETE_ENTITY',
|
|
13
|
+
id: id,
|
|
14
|
+
},
|
|
15
|
+
],
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
it('should throw an error when ID validation fails', () => {
|
|
19
|
+
const id = 'invalid-id';
|
|
20
|
+
expect(() => deleteEntity({ id })).toThrow('Invalid id: "invalid-id"');
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
//# sourceMappingURL=delete-entity.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete-entity.test.js","sourceRoot":"","sources":["../../../src/graph/delete-entity.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,uDAAuD,EAAE,GAAG,EAAE;QAC/D,MAAM,EAAE,GAAG,EAAE,CAAC,sCAAsC,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,YAAY,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAEpC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,EAAE;YACF,GAAG,EAAE;gBACH;oBACE,IAAI,EAAE,eAAe;oBACrB,EAAE,EAAE,EAAE;iBACP;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,MAAM,EAAE,GAAG,YAAY,CAAC;QAExB,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC;IACzE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-relation.d.ts","sourceRoot":"","sources":["../../../src/graph/delete-relation.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"delete-relation.d.ts","sourceRoot":"","sources":["../../../src/graph/delete-relation.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAEtE;;;;;;;;;;GAUG;AACH,eAAO,MAAM,cAAc,GAAI,QAAQ,oBAAoB,KAAG,YAI7D,CAAC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { deleteRelation as grcDeleteRelation } from '@geoprotocol/grc-20';
|
|
1
2
|
import { Id } from '../id.js';
|
|
2
|
-
import { assertValid } from '../id-utils.js';
|
|
3
|
+
import { assertValid, toGrcId } from '../id-utils.js';
|
|
3
4
|
/**
|
|
4
5
|
* Deletes a relation.
|
|
5
6
|
*
|
|
@@ -13,10 +14,6 @@ import { assertValid } from '../id-utils.js';
|
|
|
13
14
|
*/
|
|
14
15
|
export const deleteRelation = ({ id }) => {
|
|
15
16
|
assertValid(id, '`id` in `deleteRelation`');
|
|
16
|
-
|
|
17
|
-
type: 'DELETE_RELATION',
|
|
18
|
-
id: Id(id),
|
|
19
|
-
};
|
|
20
|
-
return { id: Id(id), ops: [op] };
|
|
17
|
+
return { id: Id(id), ops: [grcDeleteRelation(toGrcId(id))] };
|
|
21
18
|
};
|
|
22
19
|
//# sourceMappingURL=delete-relation.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-relation.js","sourceRoot":"","sources":["../../../src/graph/delete-relation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"delete-relation.js","sourceRoot":"","sources":["../../../src/graph/delete-relation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,IAAI,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAGtD;;;;;;;;;;GAUG;AACH,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAAE,EAAE,EAAwB,EAAgB,EAAE;IAC3E,WAAW,CAAC,EAAE,EAAE,0BAA0B,CAAC,CAAC;IAE5C,OAAO,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;AAC/D,CAAC,CAAC"}
|
|
@@ -1,18 +1,16 @@
|
|
|
1
1
|
import { describe, expect, it } from 'vitest';
|
|
2
2
|
import { Id } from '../id.js';
|
|
3
|
+
import { toGrcId } from '../id-utils.js';
|
|
3
4
|
import { deleteRelation } from './delete-relation.js';
|
|
4
5
|
describe('deleteRelation', () => {
|
|
5
6
|
it('should create a delete relation operation with valid ID', () => {
|
|
6
7
|
const id = Id('5cade5757ecd41ae83481b22ffc2f94e');
|
|
7
8
|
const result = deleteRelation({ id });
|
|
8
|
-
expect(result).
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
id: id,
|
|
14
|
-
},
|
|
15
|
-
],
|
|
9
|
+
expect(result.id).toBe(id);
|
|
10
|
+
expect(result.ops).toHaveLength(1);
|
|
11
|
+
expect(result.ops[0]).toMatchObject({
|
|
12
|
+
type: 'deleteRelation',
|
|
13
|
+
id: toGrcId(id),
|
|
16
14
|
});
|
|
17
15
|
});
|
|
18
16
|
it('should throw an error when ID validation fails', () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-relation.test.js","sourceRoot":"","sources":["../../../src/graph/delete-relation.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,EAAE,CAAC,yDAAyD,EAAE,GAAG,EAAE;QACjE,MAAM,EAAE,GAAG,EAAE,CAAC,kCAAkC,CAAC,CAAC;QAClD,MAAM,MAAM,GAAG,cAAc,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAEtC,MAAM,CAAC,MAAM,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"delete-relation.test.js","sourceRoot":"","sources":["../../../src/graph/delete-relation.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,EAAE,CAAC,yDAAyD,EAAE,GAAG,EAAE;QACjE,MAAM,EAAE,GAAG,EAAE,CAAC,kCAAkC,CAAC,CAAC;QAClD,MAAM,MAAM,GAAG,cAAc,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAEtC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC3B,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAClC,IAAI,EAAE,gBAAgB;YACtB,EAAE,EAAE,OAAO,CAAC,EAAE,CAAC;SAChB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,MAAM,EAAE,GAAG,YAAY,CAAC;QAExB,MAAM,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC;IAC3E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph.test.d.ts","sourceRoot":"","sources":["../../../src/graph/graph.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { createEntity } from './create-entity.js';
|
|
3
|
+
import { createProperty } from './create-property.js';
|
|
4
|
+
import { createType } from './create-type.js';
|
|
5
|
+
describe('Graph', () => {
|
|
6
|
+
it('creates types, entities and relations', async () => {
|
|
7
|
+
const ops = [];
|
|
8
|
+
// create age property
|
|
9
|
+
const { id: agePropertyId, ops: createAgePropertyOps } = createProperty({
|
|
10
|
+
type: 'NUMBER',
|
|
11
|
+
name: 'Age',
|
|
12
|
+
});
|
|
13
|
+
ops.push(...createAgePropertyOps);
|
|
14
|
+
// create likes property
|
|
15
|
+
const { id: likesPropertyId, ops: createLikesPropertyOps } = createProperty({
|
|
16
|
+
type: 'RELATION',
|
|
17
|
+
name: 'Likes',
|
|
18
|
+
});
|
|
19
|
+
ops.push(...createLikesPropertyOps);
|
|
20
|
+
// create person type
|
|
21
|
+
const { id: personTypeId, ops: createPersonTypeOps } = createType({
|
|
22
|
+
name: 'Person',
|
|
23
|
+
properties: [agePropertyId],
|
|
24
|
+
});
|
|
25
|
+
ops.push(...createPersonTypeOps);
|
|
26
|
+
// create restaurant entity
|
|
27
|
+
const { id: restaurantId, ops: createRestaurantOps } = createEntity({
|
|
28
|
+
name: 'Restaurant',
|
|
29
|
+
types: [personTypeId],
|
|
30
|
+
});
|
|
31
|
+
ops.push(...createRestaurantOps);
|
|
32
|
+
// create person entity
|
|
33
|
+
const { id: personId, ops: createPersonOps } = createEntity({
|
|
34
|
+
name: 'Jane Doe',
|
|
35
|
+
types: [personTypeId],
|
|
36
|
+
properties: {
|
|
37
|
+
[likesPropertyId]: {
|
|
38
|
+
to: restaurantId,
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
});
|
|
42
|
+
ops.push(...createPersonOps);
|
|
43
|
+
expect(ops.length).toBe(16);
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
//# sourceMappingURL=graph.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph.test.js","sourceRoot":"","sources":["../../../src/graph/graph.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,QAAQ,CAAC,OAAO,EAAE,GAAG,EAAE;IACrB,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,GAAG,GAAc,EAAE,CAAC;QAE1B,sBAAsB;QACtB,MAAM,EAAE,EAAE,EAAE,aAAa,EAAE,GAAG,EAAE,oBAAoB,EAAE,GAAG,cAAc,CAAC;YACtE,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,KAAK;SACZ,CAAC,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,GAAG,oBAAoB,CAAC,CAAC;QAElC,wBAAwB;QACxB,MAAM,EAAE,EAAE,EAAE,eAAe,EAAE,GAAG,EAAE,sBAAsB,EAAE,GAAG,cAAc,CAAC;YAC1E,IAAI,EAAE,UAAU;YAChB,IAAI,EAAE,OAAO;SACd,CAAC,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,GAAG,sBAAsB,CAAC,CAAC;QAEpC,qBAAqB;QACrB,MAAM,EAAE,EAAE,EAAE,YAAY,EAAE,GAAG,EAAE,mBAAmB,EAAE,GAAG,UAAU,CAAC;YAChE,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE,CAAC,aAAa,CAAC;SAC5B,CAAC,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,GAAG,mBAAmB,CAAC,CAAC;QAEjC,2BAA2B;QAC3B,MAAM,EAAE,EAAE,EAAE,YAAY,EAAE,GAAG,EAAE,mBAAmB,EAAE,GAAG,YAAY,CAAC;YAClE,IAAI,EAAE,YAAY;YAClB,KAAK,EAAE,CAAC,YAAY,CAAC;SACtB,CAAC,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,GAAG,mBAAmB,CAAC,CAAC;QAEjC,uBAAuB;QACvB,MAAM,EAAE,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,eAAe,EAAE,GAAG,YAAY,CAAC;YAC1D,IAAI,EAAE,UAAU;YAChB,KAAK,EAAE,CAAC,YAAY,CAAC;YACrB,UAAU,EAAE;gBACV,CAAC,eAAe,CAAC,EAAE;oBACjB,EAAE,EAAE,YAAY;iBACjB;aACF;SACF,CAAC,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC,CAAC;QAE7B,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-default-properties.d.ts","sourceRoot":"","sources":["../../../../src/graph/helpers/create-default-properties.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,iBAAiB,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAC;AAE5D,eAAO,MAAM,uBAAuB,GAAI,QAAQ,iBAAiB,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,SA0CvF,CAAC"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { COVER_PROPERTY, DESCRIPTION_PROPERTY, NAME_PROPERTY } from '../../core/ids/system.js';
|
|
2
|
+
import { assertValid } from '../../id.js';
|
|
3
|
+
import { Relation } from '../../relation.js';
|
|
4
|
+
import { Triple } from '../../triple.js';
|
|
5
|
+
export const createDefaultProperties = (params) => {
|
|
6
|
+
const { entityId, name, description, cover } = params;
|
|
7
|
+
const ops = [];
|
|
8
|
+
if (name) {
|
|
9
|
+
// set property "Name" to the provided name
|
|
10
|
+
const nameTripleOp = Triple.make({
|
|
11
|
+
entityId,
|
|
12
|
+
attributeId: NAME_PROPERTY,
|
|
13
|
+
value: {
|
|
14
|
+
type: 'TEXT',
|
|
15
|
+
value: name,
|
|
16
|
+
},
|
|
17
|
+
});
|
|
18
|
+
ops.push(nameTripleOp);
|
|
19
|
+
}
|
|
20
|
+
if (description) {
|
|
21
|
+
// set property "Description" to the provided description
|
|
22
|
+
const descriptionTripleOp = Triple.make({
|
|
23
|
+
entityId,
|
|
24
|
+
attributeId: DESCRIPTION_PROPERTY,
|
|
25
|
+
value: {
|
|
26
|
+
type: 'TEXT',
|
|
27
|
+
value: description,
|
|
28
|
+
},
|
|
29
|
+
});
|
|
30
|
+
ops.push(descriptionTripleOp);
|
|
31
|
+
}
|
|
32
|
+
if (cover) {
|
|
33
|
+
// add ID of cover "Image" to property "Cover"
|
|
34
|
+
assertValid(cover);
|
|
35
|
+
const relationOp = Relation.make({
|
|
36
|
+
fromId: entityId,
|
|
37
|
+
relationTypeId: COVER_PROPERTY,
|
|
38
|
+
toId: cover,
|
|
39
|
+
});
|
|
40
|
+
ops.push(relationOp);
|
|
41
|
+
}
|
|
42
|
+
return ops;
|
|
43
|
+
};
|
|
44
|
+
//# sourceMappingURL=create-default-properties.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-default-properties.js","sourceRoot":"","sources":["../../../../src/graph/helpers/create-default-properties.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAC/F,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAGzC,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,MAAgD,EAAE,EAAE;IAC1F,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;IACtD,MAAM,GAAG,GAAS,EAAE,CAAC;IAErB,IAAI,IAAI,EAAE,CAAC;QACT,2CAA2C;QAC3C,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC;YAC/B,QAAQ;YACR,WAAW,EAAE,aAAa;YAC1B,KAAK,EAAE;gBACL,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,IAAI;aACZ;SACF,CAAC,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,WAAW,EAAE,CAAC;QAChB,yDAAyD;QACzD,MAAM,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC;YACtC,QAAQ;YACR,WAAW,EAAE,oBAAoB;YACjC,KAAK,EAAE;gBACL,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,WAAW;aACnB;SACF,CAAC,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IAChC,CAAC;IAED,IAAI,KAAK,EAAE,CAAC;QACV,8CAA8C;QAC9C,WAAW,CAAC,KAAK,CAAC,CAAC;QACnB,MAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC;YAC/B,MAAM,EAAE,QAAQ;YAChB,cAAc,EAAE,cAAc;YAC9B,IAAI,EAAE,KAAK;SACZ,CAAC,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACvB,CAAC;IAED,OAAO,GAAG,CAAC;AACb,CAAC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { Op, PropertiesParam } from '../../types.js';
|
|
2
|
+
type CreatePropertiesParams = {
|
|
3
|
+
entityId: string;
|
|
4
|
+
properties: PropertiesParam;
|
|
5
|
+
};
|
|
6
|
+
export declare const createProperties: (params: CreatePropertiesParams) => Op[];
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=create-properties.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-properties.d.ts","sourceRoot":"","sources":["../../../../src/graph/helpers/create-properties.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,EAAE,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAE1D,KAAK,sBAAsB,GAAG;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,eAAe,CAAC;CAC7B,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,QAAQ,sBAAsB,SAgD9D,CAAC"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { assertValid, generate } from '../../id.js';
|
|
2
|
+
import { Relation } from '../../relation.js';
|
|
3
|
+
import { Triple } from '../../triple.js';
|
|
4
|
+
export const createProperties = (params) => {
|
|
5
|
+
const { entityId, properties } = params;
|
|
6
|
+
const ops = [];
|
|
7
|
+
for (const [attributeId, property] of Object.entries(properties)) {
|
|
8
|
+
assertValid(attributeId);
|
|
9
|
+
if ('type' in property) {
|
|
10
|
+
const propertyTripleOp = Triple.make({
|
|
11
|
+
entityId,
|
|
12
|
+
attributeId,
|
|
13
|
+
value: property,
|
|
14
|
+
});
|
|
15
|
+
ops.push(propertyTripleOp);
|
|
16
|
+
}
|
|
17
|
+
else if ('to' in property) {
|
|
18
|
+
const relationId = property.relationId ?? generate();
|
|
19
|
+
assertValid(relationId);
|
|
20
|
+
assertValid(property.to);
|
|
21
|
+
const propertyRelationOp = Relation.make({
|
|
22
|
+
relationId,
|
|
23
|
+
fromId: entityId,
|
|
24
|
+
relationTypeId: attributeId,
|
|
25
|
+
toId: property.to,
|
|
26
|
+
position: property.position,
|
|
27
|
+
});
|
|
28
|
+
ops.push(propertyRelationOp);
|
|
29
|
+
if (property.properties) {
|
|
30
|
+
ops.push(...createProperties({ entityId, properties: property.properties }));
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
else if (Array.isArray(property)) {
|
|
34
|
+
for (const relation of property) {
|
|
35
|
+
const relationId = relation.relationId ?? generate();
|
|
36
|
+
assertValid(relationId);
|
|
37
|
+
assertValid(relation.to);
|
|
38
|
+
const propertyRelationOp = Relation.make({
|
|
39
|
+
relationId,
|
|
40
|
+
fromId: entityId,
|
|
41
|
+
relationTypeId: attributeId,
|
|
42
|
+
toId: relation.to,
|
|
43
|
+
});
|
|
44
|
+
ops.push(propertyRelationOp);
|
|
45
|
+
if (relation.properties) {
|
|
46
|
+
ops.push(...createProperties({ entityId, properties: relation.properties }));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return ops;
|
|
52
|
+
};
|
|
53
|
+
//# sourceMappingURL=create-properties.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-properties.js","sourceRoot":"","sources":["../../../../src/graph/helpers/create-properties.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAQzC,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,MAA8B,EAAE,EAAE;IACjE,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,MAAM,CAAC;IACxC,MAAM,GAAG,GAAS,EAAE,CAAC;IAErB,KAAK,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;QACjE,WAAW,CAAC,WAAW,CAAC,CAAC;QACzB,IAAI,MAAM,IAAI,QAAQ,EAAE,CAAC;YACvB,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC;gBACnC,QAAQ;gBACR,WAAW;gBACX,KAAK,EAAE,QAAQ;aAChB,CAAC,CAAC;YACH,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC7B,CAAC;aAAM,IAAI,IAAI,IAAI,QAAQ,EAAE,CAAC;YAC5B,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,IAAI,QAAQ,EAAE,CAAC;YACrD,WAAW,CAAC,UAAU,CAAC,CAAC;YACxB,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YACzB,MAAM,kBAAkB,GAAG,QAAQ,CAAC,IAAI,CAAC;gBACvC,UAAU;gBACV,MAAM,EAAE,QAAQ;gBAChB,cAAc,EAAE,WAAW;gBAC3B,IAAI,EAAE,QAAQ,CAAC,EAAE;gBACjB,QAAQ,EAAE,QAAQ,CAAC,QAAQ;aAC5B,CAAC,CAAC;YACH,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAC7B,IAAI,QAAQ,CAAC,UAAU,EAAE,CAAC;gBACxB,GAAG,CAAC,IAAI,CAAC,GAAG,gBAAgB,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;YAC/E,CAAC;QACH,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnC,KAAK,MAAM,QAAQ,IAAI,QAAQ,EAAE,CAAC;gBAChC,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,IAAI,QAAQ,EAAE,CAAC;gBACrD,WAAW,CAAC,UAAU,CAAC,CAAC;gBACxB,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;gBACzB,MAAM,kBAAkB,GAAG,QAAQ,CAAC,IAAI,CAAC;oBACvC,UAAU;oBACV,MAAM,EAAE,QAAQ;oBAChB,cAAc,EAAE,WAAW;oBAC3B,IAAI,EAAE,QAAQ,CAAC,EAAE;iBAClB,CAAC,CAAC;gBACH,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;gBAC7B,IAAI,QAAQ,CAAC,UAAU,EAAE,CAAC;oBACxB,GAAG,CAAC,IAAI,CAAC,GAAG,gBAAgB,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;gBAC/E,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,GAAG,CAAC;AACb,CAAC,CAAC"}
|