@graphprotocol/grc-20 0.5.5 → 0.6.1
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 +101 -4
- package/dist/index.d.ts +5 -7
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -7
- package/dist/index.js.map +1 -1
- package/dist/src/core/account.js +5 -5
- package/dist/src/core/account.js.map +1 -1
- package/dist/src/core/account.test.js +7 -7
- package/dist/src/core/account.test.js.map +1 -1
- package/dist/src/core/blocks/data.d.ts.map +1 -1
- package/dist/src/core/blocks/data.js +9 -9
- package/dist/src/core/blocks/data.js.map +1 -1
- package/dist/src/core/blocks/data.test.js +12 -12
- package/dist/src/core/blocks/data.test.js.map +1 -1
- package/dist/src/core/blocks/text.js +5 -5
- package/dist/src/core/blocks/text.js.map +1 -1
- package/dist/src/core/blocks/text.test.js +5 -5
- package/dist/src/core/blocks/text.test.js.map +1 -1
- package/dist/src/core/ids/content.d.ts +36 -1
- package/dist/src/core/ids/content.d.ts.map +1 -1
- package/dist/src/core/ids/content.js +144 -1
- package/dist/src/core/ids/content.js.map +1 -1
- package/dist/src/core/ids/system.d.ts +45 -0
- package/dist/src/core/ids/system.d.ts.map +1 -1
- package/dist/src/core/ids/system.js +168 -0
- package/dist/src/core/ids/system.js.map +1 -1
- package/dist/src/core/image.d.ts.map +1 -1
- package/dist/src/core/image.js +4 -4
- package/dist/src/core/image.js.map +1 -1
- package/dist/src/core/image.test.js +5 -5
- package/dist/src/core/image.test.js.map +1 -1
- package/dist/src/core/relation.d.ts +2 -2
- package/dist/src/core/relation.d.ts.map +1 -1
- package/dist/src/core/relation.js +2 -2
- package/dist/src/core/relation.js.map +1 -1
- package/dist/src/core/relation.test.js +2 -2
- package/dist/src/core/relation.test.js.map +1 -1
- package/dist/src/core/scheme.test.js.map +1 -1
- package/dist/src/graph/constants.d.ts +2 -0
- package/dist/src/graph/constants.d.ts.map +1 -0
- package/dist/src/graph/constants.js +2 -0
- package/dist/src/graph/constants.js.map +1 -0
- package/dist/src/graph/create-entity.d.ts +14 -0
- package/dist/src/graph/create-entity.d.ts.map +1 -0
- package/dist/src/graph/create-entity.js +29 -0
- package/dist/src/graph/create-entity.js.map +1 -0
- package/dist/src/graph/create-entity.test.d.ts +2 -0
- package/dist/src/graph/create-entity.test.d.ts.map +1 -0
- package/dist/src/graph/create-entity.test.js +277 -0
- package/dist/src/graph/create-entity.test.js.map +1 -0
- package/dist/src/graph/create-property.d.ts +17 -0
- package/dist/src/graph/create-property.d.ts.map +1 -0
- package/dist/src/graph/create-property.js +92 -0
- package/dist/src/graph/create-property.js.map +1 -0
- package/dist/src/graph/create-property.test.d.ts +2 -0
- package/dist/src/graph/create-property.test.d.ts.map +1 -0
- package/dist/src/graph/create-property.test.js +70 -0
- package/dist/src/graph/create-property.test.js.map +1 -0
- package/dist/src/graph/create-space.d.ts +12 -0
- package/dist/src/graph/create-space.d.ts.map +1 -0
- package/dist/src/graph/create-space.js +20 -0
- package/dist/src/graph/create-space.js.map +1 -0
- package/dist/src/graph/create-type.d.ts +13 -0
- package/dist/src/graph/create-type.d.ts.map +1 -0
- package/dist/src/graph/create-type.js +31 -0
- package/dist/src/graph/create-type.js.map +1 -0
- package/dist/src/graph/create-type.test.d.ts +2 -0
- package/dist/src/graph/create-type.test.d.ts.map +1 -0
- package/dist/src/graph/create-type.test.js +94 -0
- package/dist/src/graph/create-type.test.js.map +1 -0
- 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 +42 -0
- package/dist/src/graph/helpers/create-default-properties.js.map +1 -0
- package/dist/src/graph/helpers/create-properties.d.ts +9 -0
- package/dist/src/graph/helpers/create-properties.d.ts.map +1 -0
- package/dist/src/graph/helpers/create-properties.js +48 -0
- package/dist/src/graph/helpers/create-properties.js.map +1 -0
- package/dist/src/graph/index.d.ts +6 -0
- package/dist/src/graph/index.d.ts.map +1 -0
- package/dist/src/graph/index.js +6 -0
- package/dist/src/graph/index.js.map +1 -0
- package/dist/src/graph/publish.d.ts +13 -0
- package/dist/src/graph/publish.d.ts.map +1 -0
- package/dist/src/graph/publish.js +22 -0
- package/dist/src/graph/publish.js.map +1 -0
- package/dist/src/ipfs.js +1 -1
- package/dist/src/ipfs.js.map +1 -1
- package/dist/src/proto/edit.d.ts +1 -1
- package/dist/src/proto/edit.d.ts.map +1 -1
- package/dist/src/proto/edit.js +1 -1
- package/dist/src/proto/edit.js.map +1 -1
- package/dist/src/proto/edit.test.js +48 -6
- package/dist/src/proto/edit.test.js.map +1 -1
- package/dist/src/proto/gen/src/proto/ipfs_pb.d.ts +14 -6
- package/dist/src/proto/gen/src/proto/ipfs_pb.d.ts.map +1 -1
- package/dist/src/proto/gen/src/proto/ipfs_pb.js +116 -106
- package/dist/src/proto/gen/src/proto/ipfs_pb.js.map +1 -1
- package/dist/src/system-ids.d.ts +3 -3
- package/dist/src/system-ids.d.ts.map +1 -1
- package/dist/src/system-ids.js +3 -3
- package/dist/src/system-ids.js.map +1 -1
- package/dist/src/types.d.ts +22 -0
- package/dist/src/types.d.ts.map +1 -1
- package/dist/src/types.js.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -52,9 +52,9 @@ When writing data, these ops are grouped into a logical set called an "Edit." An
|
|
|
52
52
|
Entities throughout The Graph are referenced via globally unique identifiers. The SDK exposes APIs for creating these IDs.
|
|
53
53
|
|
|
54
54
|
```ts
|
|
55
|
-
import {
|
|
55
|
+
import { Id } from '@graphprotocol/grc-20';
|
|
56
56
|
|
|
57
|
-
const newId =
|
|
57
|
+
const newId = Id.generate();
|
|
58
58
|
```
|
|
59
59
|
|
|
60
60
|
### Making ops
|
|
@@ -94,6 +94,103 @@ const setRelationOp: CreateRelationOp = Relation.make({
|
|
|
94
94
|
const deleteRelationOp: DeleteRelationOp = Relation.remove('id of relation');
|
|
95
95
|
```
|
|
96
96
|
|
|
97
|
+
### Creating properties, types and entities
|
|
98
|
+
|
|
99
|
+
Working with triple and relations ops is a low level API and give you maximum flexibility. In order to ease the process of creating and updating data, the library also exports APIs for creating properties, types and entities.
|
|
100
|
+
|
|
101
|
+
```ts
|
|
102
|
+
import { Graph } from '@graphprotocol/grc-20';
|
|
103
|
+
|
|
104
|
+
// create a property
|
|
105
|
+
const propertyResult = Graph.createProperty({
|
|
106
|
+
name: 'name of the property',
|
|
107
|
+
type: 'TEXT', // TEXT | NUMBER | URL | TIME | POINT | CHECKBOX | RELATION,
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
// create a type
|
|
111
|
+
const { id: personTypeId, ops: createPersonTypeOps } = Graph.createType({
|
|
112
|
+
name: 'name of the type',
|
|
113
|
+
properties: […listOfPropertyIds],
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
// create an entity
|
|
117
|
+
const { id: restaurantId, ops: createRestaurantOps } = Graph.createEntity({
|
|
118
|
+
name: 'name of the entity',
|
|
119
|
+
types: […listOfTypeIds],
|
|
120
|
+
properties: {
|
|
121
|
+
// value property like text, number, url, time, point, checkbox
|
|
122
|
+
[propertyId]: {
|
|
123
|
+
type: 'TEXT', // TEXT | NUMBER | URL | TIME | POINT | CHECKBOX,
|
|
124
|
+
value: 'value of the property',
|
|
125
|
+
},
|
|
126
|
+
// relation property
|
|
127
|
+
[propertyId]: {
|
|
128
|
+
to: 'id of the entity',
|
|
129
|
+
},
|
|
130
|
+
},
|
|
131
|
+
});
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
#### Example Flow
|
|
135
|
+
|
|
136
|
+
```ts
|
|
137
|
+
import { Graph } from '@graphprotocol/grc-20';
|
|
138
|
+
|
|
139
|
+
const ops: Array<Op> = [];
|
|
140
|
+
|
|
141
|
+
// create an age property
|
|
142
|
+
const { id: agePropertyId, ops: createAgePropertyOps } = Graph.createProperty({
|
|
143
|
+
type: 'NUMBER',
|
|
144
|
+
name: 'Age',
|
|
145
|
+
});
|
|
146
|
+
ops.push(...createAgePropertyOps);
|
|
147
|
+
|
|
148
|
+
// create a likes property
|
|
149
|
+
const { id: likesPropertyId, ops: createLikesPropertyOps } = Graph.createProperty({
|
|
150
|
+
type: 'RELATION',
|
|
151
|
+
name: 'Likes',
|
|
152
|
+
});
|
|
153
|
+
ops.push(...createLikesPropertyOps);
|
|
154
|
+
|
|
155
|
+
// create a person type
|
|
156
|
+
const { id: personTypeId, ops: createPersonTypeOps } = Graph.createType({
|
|
157
|
+
name: 'Person',
|
|
158
|
+
properties: [agePropertyId, likesPropertyId],
|
|
159
|
+
});
|
|
160
|
+
ops.push(...createPersonTypeOps);
|
|
161
|
+
|
|
162
|
+
// create a restaurant entity with a website property
|
|
163
|
+
const restaurantTypeId = 'A9QizqoXSqjfPUBjLoPJa2';
|
|
164
|
+
const { id: restaurantId, ops: createRestaurantOps } = Graph.createEntity({
|
|
165
|
+
name: 'Yum Yum',
|
|
166
|
+
description: 'A restaurant serving fusion cuisine',
|
|
167
|
+
types: [restaurantTypeId],
|
|
168
|
+
properties: {
|
|
169
|
+
[WEBSITE_PROPERTY]: {
|
|
170
|
+
type: 'URL',
|
|
171
|
+
value: 'https://example.com',
|
|
172
|
+
},
|
|
173
|
+
},
|
|
174
|
+
});
|
|
175
|
+
ops.push(...createRestaurantOps);
|
|
176
|
+
|
|
177
|
+
// create a person entity with a likes relation to the restaurant entity
|
|
178
|
+
const { id: personId, ops: createPersonOps } = Graph.createEntity({
|
|
179
|
+
name: 'Jane Doe',
|
|
180
|
+
types: [personTypeId],
|
|
181
|
+
properties: {
|
|
182
|
+
[agePropertyId]: {
|
|
183
|
+
type: 'NUMBER',
|
|
184
|
+
value: 42,
|
|
185
|
+
},
|
|
186
|
+
[likesPropertyId]: {
|
|
187
|
+
to: restaurantId,
|
|
188
|
+
},
|
|
189
|
+
},
|
|
190
|
+
});
|
|
191
|
+
ops.push(...createPersonOps);
|
|
192
|
+
```
|
|
193
|
+
|
|
97
194
|
### Writing an edit to IPFS
|
|
98
195
|
|
|
99
196
|
Once you have a set of ops ready to publish, you'll need to binary encode them into an Edit and upload the Edit to IPFS.
|
|
@@ -105,9 +202,9 @@ Additionally, the indexer expects that IPFS CIDs be prefixed with `ipfs://` so i
|
|
|
105
202
|
We've abstracted the IPFS publishing and binary encoding into a single API.
|
|
106
203
|
|
|
107
204
|
```ts
|
|
108
|
-
import {
|
|
205
|
+
import { Ipfs } from '@graphprotocol/grc-20';
|
|
109
206
|
|
|
110
|
-
const cid = await
|
|
207
|
+
const cid = await Ipfs.publishEdit({
|
|
111
208
|
name: 'Edit name',
|
|
112
209
|
ops: ops,
|
|
113
210
|
author: '0x000000000000000000000000000000000000',
|
package/dist/index.d.ts
CHANGED
|
@@ -5,14 +5,12 @@ export * from './src/types.js';
|
|
|
5
5
|
*
|
|
6
6
|
* @since 0.0.6
|
|
7
7
|
*/
|
|
8
|
-
export * as
|
|
8
|
+
export * as Id from './src/id.js';
|
|
9
9
|
/**
|
|
10
10
|
* This module provides utility functions for working with base58 ids
|
|
11
11
|
* in TypeScript.
|
|
12
|
-
*
|
|
13
|
-
* @since 0.0.6
|
|
14
12
|
*/
|
|
15
|
-
export
|
|
13
|
+
export * as Base58 from './src/core/base58.js';
|
|
16
14
|
export { getAcceptEditorArguments, getAcceptSubspaceArguments, getCalldataForSpaceGovernanceType, getProcessGeoProposalArguments, getRemoveEditorArguments, getRemoveSubspaceArguments, } from './src/encodings/index.js';
|
|
17
15
|
/**
|
|
18
16
|
* This module provides utility functions for working with knowledge graph
|
|
@@ -21,7 +19,7 @@ export { getAcceptEditorArguments, getAcceptSubspaceArguments, getCalldataForSpa
|
|
|
21
19
|
* @since 0.0.6
|
|
22
20
|
*/
|
|
23
21
|
export { Account } from './src/account.js';
|
|
24
|
-
export {
|
|
22
|
+
export { DataBlock, ImageBlock, TextBlock } from './src/blocks.js';
|
|
25
23
|
/**
|
|
26
24
|
* This module provides utility functions for working with knowledge graph
|
|
27
25
|
* images in TypeScript.
|
|
@@ -51,7 +49,7 @@ export { GraphUrl } from './src/scheme.js';
|
|
|
51
49
|
/**
|
|
52
50
|
* Provides ids for commonly used entities across the Knowledge Graph.
|
|
53
51
|
*/
|
|
54
|
-
export {
|
|
52
|
+
export { ContentIds, NetworkIds, SystemIds } from './src/system-ids.js';
|
|
55
53
|
export { getChecksumAddress } from './src/core/get-checksum-address.js';
|
|
56
54
|
/**
|
|
57
55
|
* This module provides utility functions for interacting with the default
|
|
@@ -59,5 +57,5 @@ export { getChecksumAddress } from './src/core/get-checksum-address.js';
|
|
|
59
57
|
*
|
|
60
58
|
* @since 0.1.1
|
|
61
59
|
*/
|
|
62
|
-
export * as
|
|
60
|
+
export * as Ipfs from './src/ipfs.js';
|
|
63
61
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAE/B;;;;;GAKG;AACH,OAAO,KAAK,EAAE,MAAM,aAAa,CAAC;AAElC
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAE/B;;;;;GAKG;AACH,OAAO,KAAK,EAAE,MAAM,aAAa,CAAC;AAElC;;;GAGG;AACH,OAAO,KAAK,MAAM,MAAM,sBAAsB,CAAC;AAE/C,OAAO,EACL,wBAAwB,EACxB,0BAA0B,EAC1B,iCAAiC,EACjC,8BAA8B,EAC9B,wBAAwB,EACxB,0BAA0B,GAC3B,MAAM,0BAA0B,CAAC;AAElC;;;;;GAKG;AACH,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAEnE;;;;;GAKG;AACH,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAE5D;;;;GAIG;AACH,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEzC;;;;GAIG;AACH,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C;;;;GAIG;AACH,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C;;GAEG;AACH,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAExE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AAExE;;;;;GAKG;AACH,OAAO,KAAK,IAAI,MAAM,eAAe,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -5,14 +5,12 @@ export * from './src/types.js';
|
|
|
5
5
|
*
|
|
6
6
|
* @since 0.0.6
|
|
7
7
|
*/
|
|
8
|
-
export * as
|
|
8
|
+
export * as Id from './src/id.js';
|
|
9
9
|
/**
|
|
10
10
|
* This module provides utility functions for working with base58 ids
|
|
11
11
|
* in TypeScript.
|
|
12
|
-
*
|
|
13
|
-
* @since 0.0.6
|
|
14
12
|
*/
|
|
15
|
-
export
|
|
13
|
+
export * as Base58 from './src/core/base58.js';
|
|
16
14
|
export { getAcceptEditorArguments, getAcceptSubspaceArguments, getCalldataForSpaceGovernanceType, getProcessGeoProposalArguments, getRemoveEditorArguments, getRemoveSubspaceArguments, } from './src/encodings/index.js';
|
|
17
15
|
/**
|
|
18
16
|
* This module provides utility functions for working with knowledge graph
|
|
@@ -21,7 +19,7 @@ export { getAcceptEditorArguments, getAcceptSubspaceArguments, getCalldataForSpa
|
|
|
21
19
|
* @since 0.0.6
|
|
22
20
|
*/
|
|
23
21
|
export { Account } from './src/account.js';
|
|
24
|
-
export {
|
|
22
|
+
export { DataBlock, ImageBlock, TextBlock } from './src/blocks.js';
|
|
25
23
|
/**
|
|
26
24
|
* This module provides utility functions for working with knowledge graph
|
|
27
25
|
* images in TypeScript.
|
|
@@ -51,7 +49,7 @@ export { GraphUrl } from './src/scheme.js';
|
|
|
51
49
|
/**
|
|
52
50
|
* Provides ids for commonly used entities across the Knowledge Graph.
|
|
53
51
|
*/
|
|
54
|
-
export {
|
|
52
|
+
export { ContentIds, NetworkIds, SystemIds } from './src/system-ids.js';
|
|
55
53
|
export { getChecksumAddress } from './src/core/get-checksum-address.js';
|
|
56
54
|
/**
|
|
57
55
|
* This module provides utility functions for interacting with the default
|
|
@@ -59,5 +57,5 @@ export { getChecksumAddress } from './src/core/get-checksum-address.js';
|
|
|
59
57
|
*
|
|
60
58
|
* @since 0.1.1
|
|
61
59
|
*/
|
|
62
|
-
export * as
|
|
60
|
+
export * as Ipfs from './src/ipfs.js';
|
|
63
61
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAE/B;;;;;GAKG;AACH,OAAO,KAAK,EAAE,MAAM,aAAa,CAAC;AAElC
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAE/B;;;;;GAKG;AACH,OAAO,KAAK,EAAE,MAAM,aAAa,CAAC;AAElC;;;GAGG;AACH,OAAO,KAAK,MAAM,MAAM,sBAAsB,CAAC;AAE/C,OAAO,EACL,wBAAwB,EACxB,0BAA0B,EAC1B,iCAAiC,EACjC,8BAA8B,EAC9B,wBAAwB,EACxB,0BAA0B,GAC3B,MAAM,0BAA0B,CAAC;AAElC;;;;;GAKG;AACH,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAEnE;;;;;GAKG;AACH,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAE5D;;;;GAIG;AACH,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEzC;;;;GAIG;AACH,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C;;;;GAIG;AACH,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C;;GAEG;AACH,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAExE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AAExE;;;;;GAKG;AACH,OAAO,KAAK,IAAI,MAAM,eAAe,CAAC"}
|
package/dist/src/core/account.js
CHANGED
|
@@ -8,7 +8,7 @@ import { generate } from '../id.js';
|
|
|
8
8
|
import { Relation } from '../relation.js';
|
|
9
9
|
import { getChecksumAddress } from './get-checksum-address.js';
|
|
10
10
|
import { ETHEREUM } from './ids/network.js';
|
|
11
|
-
import { ACCOUNT_TYPE,
|
|
11
|
+
import { ACCOUNT_TYPE, ADDRESS_PROPERTY, NAME_PROPERTY, NETWORK_PROPERTY, TYPES_PROPERTY } from './ids/system.js';
|
|
12
12
|
/**
|
|
13
13
|
* Returns the ops to create an entity representing an Account.
|
|
14
14
|
*
|
|
@@ -32,21 +32,21 @@ export function make(address) {
|
|
|
32
32
|
// Types -> Account
|
|
33
33
|
Relation.make({
|
|
34
34
|
fromId: accountId,
|
|
35
|
-
relationTypeId:
|
|
35
|
+
relationTypeId: TYPES_PROPERTY,
|
|
36
36
|
toId: ACCOUNT_TYPE,
|
|
37
37
|
}),
|
|
38
38
|
// Network -> Ethereum
|
|
39
39
|
// Signals that the account is for the Ethereum family of chains
|
|
40
40
|
Relation.make({
|
|
41
41
|
fromId: accountId,
|
|
42
|
-
relationTypeId:
|
|
42
|
+
relationTypeId: NETWORK_PROPERTY,
|
|
43
43
|
toId: ETHEREUM,
|
|
44
44
|
}),
|
|
45
45
|
{
|
|
46
46
|
type: 'SET_TRIPLE',
|
|
47
47
|
triple: {
|
|
48
48
|
entity: accountId,
|
|
49
|
-
attribute:
|
|
49
|
+
attribute: ADDRESS_PROPERTY,
|
|
50
50
|
value: {
|
|
51
51
|
type: 'TEXT',
|
|
52
52
|
value: checkedAddress,
|
|
@@ -57,7 +57,7 @@ export function make(address) {
|
|
|
57
57
|
type: 'SET_TRIPLE',
|
|
58
58
|
triple: {
|
|
59
59
|
entity: accountId,
|
|
60
|
-
attribute:
|
|
60
|
+
attribute: NAME_PROPERTY,
|
|
61
61
|
value: {
|
|
62
62
|
type: 'TEXT',
|
|
63
63
|
value: checkedAddress,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"account.js","sourceRoot":"","sources":["../../../src/core/account.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,
|
|
1
|
+
{"version":3,"file":"account.js","sourceRoot":"","sources":["../../../src/core/account.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,aAAa,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAOlH;;;;;;;;;;;;;GAaG;AACH,MAAM,UAAU,IAAI,CAAC,OAAe;IAClC,MAAM,SAAS,GAAG,QAAQ,EAAE,CAAC;IAC7B,MAAM,cAAc,GAAG,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAEnD,OAAO;QACL,SAAS;QACT,GAAG,EAAE;YACH,mBAAmB;YACnB,QAAQ,CAAC,IAAI,CAAC;gBACZ,MAAM,EAAE,SAAS;gBACjB,cAAc,EAAE,cAAc;gBAC9B,IAAI,EAAE,YAAY;aACnB,CAAC;YACF,sBAAsB;YACtB,gEAAgE;YAChE,QAAQ,CAAC,IAAI,CAAC;gBACZ,MAAM,EAAE,SAAS;gBACjB,cAAc,EAAE,gBAAgB;gBAChC,IAAI,EAAE,QAAQ;aACf,CAAC;YACF;gBACE,IAAI,EAAE,YAAY;gBAClB,MAAM,EAAE;oBACN,MAAM,EAAE,SAAS;oBACjB,SAAS,EAAE,gBAAgB;oBAC3B,KAAK,EAAE;wBACL,IAAI,EAAE,MAAM;wBACZ,KAAK,EAAE,cAAc;qBACtB;iBACF;aACF;YACD;gBACE,IAAI,EAAE,YAAY;gBAClB,MAAM,EAAE;oBACN,MAAM,EAAE,SAAS;oBACjB,SAAS,EAAE,aAAa;oBACxB,KAAK,EAAE;wBACL,IAAI,EAAE,MAAM;wBACZ,KAAK,EAAE,cAAc;qBACtB;iBACF;aACF;SACF;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -1,24 +1,24 @@
|
|
|
1
1
|
import { expect, it } from 'vitest';
|
|
2
|
+
import { NetworkIds, SystemIds } from '../system-ids.js';
|
|
2
3
|
import { make } from './account.js';
|
|
3
|
-
import { NETWORK_IDS, SYSTEM_IDS } from '../system-ids.js';
|
|
4
4
|
const ZERO_ADDRESS = '0x0000000000000000000000000000000000000000';
|
|
5
5
|
it('should generate ops for an account entity', () => {
|
|
6
6
|
const { accountId, ops } = make(ZERO_ADDRESS);
|
|
7
7
|
const [accountTypeOp, networkOp, addressOp, nameOp] = ops;
|
|
8
8
|
expect(accountTypeOp.type).toBe('CREATE_RELATION');
|
|
9
|
-
expect(accountTypeOp.relation.type).toBe(
|
|
10
|
-
expect(accountTypeOp.relation.toEntity).toBe(
|
|
9
|
+
expect(accountTypeOp.relation.type).toBe(SystemIds.TYPES_PROPERTY);
|
|
10
|
+
expect(accountTypeOp.relation.toEntity).toBe(SystemIds.ACCOUNT_TYPE);
|
|
11
11
|
expect(accountTypeOp.relation.fromEntity).toBe(accountId);
|
|
12
12
|
expect(networkOp.type).toBe('CREATE_RELATION');
|
|
13
|
-
expect(networkOp.relation.type).toBe(
|
|
14
|
-
expect(networkOp.relation.toEntity).toBe(
|
|
13
|
+
expect(networkOp.relation.type).toBe(SystemIds.NETWORK_PROPERTY);
|
|
14
|
+
expect(networkOp.relation.toEntity).toBe(NetworkIds.ETHEREUM);
|
|
15
15
|
expect(networkOp.relation.fromEntity).toBe(accountId);
|
|
16
16
|
expect(addressOp.type).toBe('SET_TRIPLE');
|
|
17
|
-
expect(addressOp.triple.attribute).toBe(
|
|
17
|
+
expect(addressOp.triple.attribute).toBe(SystemIds.ADDRESS_PROPERTY);
|
|
18
18
|
expect(addressOp.triple.value.type).toBe('TEXT');
|
|
19
19
|
expect(addressOp.triple.value.value).toBe(ZERO_ADDRESS);
|
|
20
20
|
expect(nameOp.type).toBe('SET_TRIPLE');
|
|
21
|
-
expect(nameOp.triple.attribute).toBe(
|
|
21
|
+
expect(nameOp.triple.attribute).toBe(SystemIds.NAME_PROPERTY);
|
|
22
22
|
expect(nameOp.triple.value.type).toBe('TEXT');
|
|
23
23
|
expect(nameOp.triple.value.value).toBe(ZERO_ADDRESS);
|
|
24
24
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"account.test.js","sourceRoot":"","sources":["../../../src/core/account.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"account.test.js","sourceRoot":"","sources":["../../../src/core/account.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAEpC,MAAM,YAAY,GAAG,4CAA4C,CAAC;AAElE,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;IACnD,MAAM,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;IAC9C,MAAM,CAAC,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,CAAC,GAAG,GAAG,CAAC;IAE1D,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IACnD,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;IACnE,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IACrE,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAE1D,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC/C,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;IACjE,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IAC9D,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAEtD,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1C,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;IACpE,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACjD,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAExD,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACvC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;IAC9D,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC9C,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AACvD,CAAC,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"data.d.ts","sourceRoot":"","sources":["../../../../src/core/blocks/data.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,OAAO,KAAK,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAEpE,KAAK,mBAAmB,GAAG,OAAO,GAAG,YAAY,GAAG,KAAK,CAAC;AAa1D,KAAK,aAAa,GAAG;
|
|
1
|
+
{"version":3,"file":"data.d.ts","sourceRoot":"","sources":["../../../../src/core/blocks/data.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,OAAO,KAAK,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAEpE,KAAK,mBAAmB,GAAG,OAAO,GAAG,YAAY,GAAG,KAAK,CAAC;AAa1D,KAAK,aAAa,GAAG;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,mBAAmB,CAAC;IAChC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,IAAI,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,aAAa,GAAG,CAAC,WAAW,GAAG,gBAAgB,CAAC,EAAE,CAuC9G"}
|
|
@@ -6,15 +6,15 @@
|
|
|
6
6
|
*/
|
|
7
7
|
import { generate } from '../../id.js';
|
|
8
8
|
import { Relation } from '../../relation.js';
|
|
9
|
-
import {
|
|
9
|
+
import { SystemIds } from '../../system-ids.js';
|
|
10
10
|
function getSourceTypeId(sourceType) {
|
|
11
11
|
switch (sourceType) {
|
|
12
12
|
case 'COLLECTION':
|
|
13
|
-
return
|
|
13
|
+
return SystemIds.COLLECTION_DATA_SOURCE;
|
|
14
14
|
case 'GEO':
|
|
15
|
-
return
|
|
15
|
+
return SystemIds.ALL_OF_GEO_DATA_SOURCE;
|
|
16
16
|
case 'QUERY':
|
|
17
|
-
return
|
|
17
|
+
return SystemIds.QUERY_DATA_SOURCE;
|
|
18
18
|
}
|
|
19
19
|
}
|
|
20
20
|
/**
|
|
@@ -38,17 +38,17 @@ export function make({ fromId, sourceType, position, name }) {
|
|
|
38
38
|
const newBlockId = generate();
|
|
39
39
|
const dataBlockType = Relation.make({
|
|
40
40
|
fromId: newBlockId,
|
|
41
|
-
relationTypeId:
|
|
42
|
-
toId:
|
|
41
|
+
relationTypeId: SystemIds.TYPES_PROPERTY,
|
|
42
|
+
toId: SystemIds.DATA_BLOCK,
|
|
43
43
|
});
|
|
44
44
|
const dataBlockSourceType = Relation.make({
|
|
45
45
|
fromId: newBlockId,
|
|
46
|
-
relationTypeId:
|
|
46
|
+
relationTypeId: SystemIds.DATA_SOURCE_TYPE_RELATION_TYPE,
|
|
47
47
|
toId: getSourceTypeId(sourceType),
|
|
48
48
|
});
|
|
49
49
|
const dataBlockRelation = Relation.make({
|
|
50
50
|
fromId,
|
|
51
|
-
relationTypeId:
|
|
51
|
+
relationTypeId: SystemIds.BLOCKS,
|
|
52
52
|
toId: newBlockId,
|
|
53
53
|
position,
|
|
54
54
|
});
|
|
@@ -57,7 +57,7 @@ export function make({ fromId, sourceType, position, name }) {
|
|
|
57
57
|
ops.push({
|
|
58
58
|
type: 'SET_TRIPLE',
|
|
59
59
|
triple: {
|
|
60
|
-
attribute:
|
|
60
|
+
attribute: SystemIds.NAME_PROPERTY,
|
|
61
61
|
entity: newBlockId,
|
|
62
62
|
value: {
|
|
63
63
|
type: 'TEXT',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"data.js","sourceRoot":"","sources":["../../../../src/core/blocks/data.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"data.js","sourceRoot":"","sources":["../../../../src/core/blocks/data.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAKhD,SAAS,eAAe,CAAC,UAA+B;IACtD,QAAQ,UAAU,EAAE,CAAC;QACnB,KAAK,YAAY;YACf,OAAO,SAAS,CAAC,sBAAsB,CAAC;QAC1C,KAAK,KAAK;YACR,OAAO,SAAS,CAAC,sBAAsB,CAAC;QAC1C,KAAK,OAAO;YACV,OAAO,SAAS,CAAC,iBAAiB,CAAC;IACvC,CAAC;AACH,CAAC;AASD;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,UAAU,IAAI,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAiB;IACxE,MAAM,UAAU,GAAG,QAAQ,EAAE,CAAC;IAE9B,MAAM,aAAa,GAAG,QAAQ,CAAC,IAAI,CAAC;QAClC,MAAM,EAAE,UAAU;QAClB,cAAc,EAAE,SAAS,CAAC,cAAc;QACxC,IAAI,EAAE,SAAS,CAAC,UAAU;KAC3B,CAAC,CAAC;IAEH,MAAM,mBAAmB,GAAG,QAAQ,CAAC,IAAI,CAAC;QACxC,MAAM,EAAE,UAAU;QAClB,cAAc,EAAE,SAAS,CAAC,8BAA8B;QACxD,IAAI,EAAE,eAAe,CAAC,UAAU,CAAC;KAClC,CAAC,CAAC;IAEH,MAAM,iBAAiB,GAAG,QAAQ,CAAC,IAAI,CAAC;QACtC,MAAM;QACN,cAAc,EAAE,SAAS,CAAC,MAAM;QAChC,IAAI,EAAE,UAAU;QAChB,QAAQ;KACT,CAAC,CAAC;IAEH,MAAM,GAAG,GAAuC,CAAC,aAAa,EAAE,mBAAmB,EAAE,iBAAiB,CAAC,CAAC;IAExG,IAAI,IAAI,EAAE,CAAC;QACT,GAAG,CAAC,IAAI,CAAC;YACP,IAAI,EAAE,YAAY;YAClB,MAAM,EAAE;gBACN,SAAS,EAAE,SAAS,CAAC,aAAa;gBAClC,MAAM,EAAE,UAAU;gBAClB,KAAK,EAAE;oBACL,IAAI,EAAE,MAAM;oBACZ,KAAK,EAAE,IAAI;iBACZ;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED,OAAO,GAAG,CAAC;AACb,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { expect, it } from 'vitest';
|
|
2
|
+
import { SystemIds } from '~/src/system-ids.js';
|
|
2
3
|
import { make } from './data.js';
|
|
3
|
-
import { SYSTEM_IDS } from '~/src/system-ids.js';
|
|
4
4
|
it('should generate ops for a data block entity', () => {
|
|
5
5
|
const ops = make({
|
|
6
6
|
fromId: 'test-entity-id',
|
|
@@ -10,17 +10,17 @@ it('should generate ops for a data block entity', () => {
|
|
|
10
10
|
const [blockTypeOp, blockSourceTypeOp, blockRelationOp] = ops;
|
|
11
11
|
expect(blockTypeOp?.type).toBe('CREATE_RELATION');
|
|
12
12
|
if (blockTypeOp?.type === 'CREATE_RELATION') {
|
|
13
|
-
expect(blockTypeOp?.relation.type).toBe(
|
|
14
|
-
expect(blockTypeOp?.relation.toEntity).toBe(
|
|
13
|
+
expect(blockTypeOp?.relation.type).toBe(SystemIds.TYPES_PROPERTY);
|
|
14
|
+
expect(blockTypeOp?.relation.toEntity).toBe(SystemIds.DATA_BLOCK);
|
|
15
15
|
}
|
|
16
16
|
expect(blockSourceTypeOp?.type).toBe('CREATE_RELATION');
|
|
17
17
|
if (blockSourceTypeOp?.type === 'CREATE_RELATION') {
|
|
18
|
-
expect(blockSourceTypeOp?.relation.type).toBe(
|
|
19
|
-
expect(blockSourceTypeOp?.relation.toEntity).toBe(
|
|
18
|
+
expect(blockSourceTypeOp?.relation.type).toBe(SystemIds.DATA_SOURCE_TYPE_RELATION_TYPE);
|
|
19
|
+
expect(blockSourceTypeOp?.relation.toEntity).toBe(SystemIds.QUERY_DATA_SOURCE);
|
|
20
20
|
}
|
|
21
21
|
expect(blockRelationOp?.type).toBe('CREATE_RELATION');
|
|
22
22
|
if (blockRelationOp?.type === 'CREATE_RELATION') {
|
|
23
|
-
expect(blockRelationOp?.relation.type).toBe(
|
|
23
|
+
expect(blockRelationOp?.relation.type).toBe(SystemIds.BLOCKS);
|
|
24
24
|
expect(blockRelationOp?.relation.fromEntity).toBe('test-entity-id');
|
|
25
25
|
}
|
|
26
26
|
expect(ops.length).toBe(3);
|
|
@@ -35,22 +35,22 @@ it('should generate ops for a data block entity with a name', () => {
|
|
|
35
35
|
const [blockTypeOp, blockSourceTypeOp, blockRelationOp, blockNameOp] = ops;
|
|
36
36
|
expect(blockTypeOp?.type).toBe('CREATE_RELATION');
|
|
37
37
|
if (blockTypeOp?.type === 'CREATE_RELATION') {
|
|
38
|
-
expect(blockTypeOp?.relation.type).toBe(
|
|
39
|
-
expect(blockTypeOp?.relation.toEntity).toBe(
|
|
38
|
+
expect(blockTypeOp?.relation.type).toBe(SystemIds.TYPES_PROPERTY);
|
|
39
|
+
expect(blockTypeOp?.relation.toEntity).toBe(SystemIds.DATA_BLOCK);
|
|
40
40
|
}
|
|
41
41
|
expect(blockSourceTypeOp?.type).toBe('CREATE_RELATION');
|
|
42
42
|
if (blockSourceTypeOp?.type === 'CREATE_RELATION') {
|
|
43
|
-
expect(blockSourceTypeOp?.relation.type).toBe(
|
|
44
|
-
expect(blockSourceTypeOp?.relation.toEntity).toBe(
|
|
43
|
+
expect(blockSourceTypeOp?.relation.type).toBe(SystemIds.DATA_SOURCE_TYPE_RELATION_TYPE);
|
|
44
|
+
expect(blockSourceTypeOp?.relation.toEntity).toBe(SystemIds.QUERY_DATA_SOURCE);
|
|
45
45
|
}
|
|
46
46
|
expect(blockRelationOp?.type).toBe('CREATE_RELATION');
|
|
47
47
|
if (blockRelationOp?.type === 'CREATE_RELATION') {
|
|
48
|
-
expect(blockRelationOp?.relation.type).toBe(
|
|
48
|
+
expect(blockRelationOp?.relation.type).toBe(SystemIds.BLOCKS);
|
|
49
49
|
expect(blockRelationOp?.relation.fromEntity).toBe('test-entity-id');
|
|
50
50
|
}
|
|
51
51
|
expect(blockNameOp?.type).toBe('SET_TRIPLE');
|
|
52
52
|
if (blockNameOp?.type === 'SET_TRIPLE') {
|
|
53
|
-
expect(blockNameOp?.triple.attribute).toBe(
|
|
53
|
+
expect(blockNameOp?.triple.attribute).toBe(SystemIds.NAME_PROPERTY);
|
|
54
54
|
expect(blockNameOp?.triple.value.type).toBe('TEXT');
|
|
55
55
|
expect(blockNameOp?.triple.value.value).toBe('test-name');
|
|
56
56
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"data.test.js","sourceRoot":"","sources":["../../../../src/core/blocks/data.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"data.test.js","sourceRoot":"","sources":["../../../../src/core/blocks/data.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
*/
|
|
7
7
|
import { generate } from '../../id.js';
|
|
8
8
|
import { Relation } from '../../relation.js';
|
|
9
|
-
import {
|
|
9
|
+
import { SystemIds } from '../../system-ids.js';
|
|
10
10
|
/**
|
|
11
11
|
* Returns the ops to create an entity representing a Text Block.
|
|
12
12
|
*
|
|
@@ -27,13 +27,13 @@ export function make({ fromId, text, position }) {
|
|
|
27
27
|
const newBlockId = generate();
|
|
28
28
|
const textBlockType = Relation.make({
|
|
29
29
|
fromId: newBlockId,
|
|
30
|
-
relationTypeId:
|
|
31
|
-
toId:
|
|
30
|
+
relationTypeId: SystemIds.TYPES_PROPERTY,
|
|
31
|
+
toId: SystemIds.TEXT_BLOCK,
|
|
32
32
|
});
|
|
33
33
|
const textBlockMarkdownText = {
|
|
34
34
|
type: 'SET_TRIPLE',
|
|
35
35
|
triple: {
|
|
36
|
-
attribute:
|
|
36
|
+
attribute: SystemIds.MARKDOWN_CONTENT,
|
|
37
37
|
entity: newBlockId,
|
|
38
38
|
value: {
|
|
39
39
|
type: 'TEXT',
|
|
@@ -43,7 +43,7 @@ export function make({ fromId, text, position }) {
|
|
|
43
43
|
};
|
|
44
44
|
const textBlockRelation = Relation.make({
|
|
45
45
|
fromId,
|
|
46
|
-
relationTypeId:
|
|
46
|
+
relationTypeId: SystemIds.BLOCKS,
|
|
47
47
|
toId: newBlockId,
|
|
48
48
|
position,
|
|
49
49
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"text.js","sourceRoot":"","sources":["../../../../src/core/blocks/text.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"text.js","sourceRoot":"","sources":["../../../../src/core/blocks/text.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAKhD;;;;;;;;;;;;;;;GAeG;AACH,MAAM,UAAU,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAiB;IAC5D,MAAM,UAAU,GAAG,QAAQ,EAAE,CAAC;IAE9B,MAAM,aAAa,GAAG,QAAQ,CAAC,IAAI,CAAC;QAClC,MAAM,EAAE,UAAU;QAClB,cAAc,EAAE,SAAS,CAAC,cAAc;QACxC,IAAI,EAAE,SAAS,CAAC,UAAU;KAC3B,CAAC,CAAC;IAEH,MAAM,qBAAqB,GAAG;QAC5B,IAAI,EAAE,YAAY;QAClB,MAAM,EAAE;YACN,SAAS,EAAE,SAAS,CAAC,gBAAgB;YACrC,MAAM,EAAE,UAAU;YAClB,KAAK,EAAE;gBACL,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,IAAI;aACZ;SACF;KACO,CAAC;IAEX,MAAM,iBAAiB,GAAG,QAAQ,CAAC,IAAI,CAAC;QACtC,MAAM;QACN,cAAc,EAAE,SAAS,CAAC,MAAM;QAChC,IAAI,EAAE,UAAU;QAChB,QAAQ;KACT,CAAC,CAAC;IAEH,OAAO,CAAC,aAAa,EAAE,qBAAqB,EAAE,iBAAiB,CAAC,CAAC;AACnE,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { expect, it } from 'vitest';
|
|
2
|
+
import { SystemIds } from '~/src/system-ids.js';
|
|
2
3
|
import { make } from './text.js';
|
|
3
|
-
import { SYSTEM_IDS } from '~/src/system-ids.js';
|
|
4
4
|
it('should generate ops for a text block entity', () => {
|
|
5
5
|
const ops = make({
|
|
6
6
|
fromId: 'test-entity-id',
|
|
@@ -10,18 +10,18 @@ it('should generate ops for a text block entity', () => {
|
|
|
10
10
|
const [blockTypeOp, blockMarkdownTextOp, blockRelationOp] = ops;
|
|
11
11
|
expect(blockTypeOp?.type).toBe('CREATE_RELATION');
|
|
12
12
|
if (blockTypeOp?.type === 'CREATE_RELATION') {
|
|
13
|
-
expect(blockTypeOp?.relation.type).toBe(
|
|
14
|
-
expect(blockTypeOp?.relation.toEntity).toBe(
|
|
13
|
+
expect(blockTypeOp?.relation.type).toBe(SystemIds.TYPES_PROPERTY);
|
|
14
|
+
expect(blockTypeOp?.relation.toEntity).toBe(SystemIds.TEXT_BLOCK);
|
|
15
15
|
}
|
|
16
16
|
expect(blockMarkdownTextOp?.type).toBe('SET_TRIPLE');
|
|
17
17
|
if (blockMarkdownTextOp?.type === 'SET_TRIPLE') {
|
|
18
|
-
expect(blockMarkdownTextOp?.triple.attribute).toBe(
|
|
18
|
+
expect(blockMarkdownTextOp?.triple.attribute).toBe(SystemIds.MARKDOWN_CONTENT);
|
|
19
19
|
expect(blockMarkdownTextOp?.triple.value.type).toBe('TEXT');
|
|
20
20
|
expect(blockMarkdownTextOp?.triple.value.value).toBe('test-text');
|
|
21
21
|
}
|
|
22
22
|
expect(blockRelationOp?.type).toBe('CREATE_RELATION');
|
|
23
23
|
if (blockRelationOp?.type === 'CREATE_RELATION') {
|
|
24
|
-
expect(blockRelationOp?.relation.type).toBe(
|
|
24
|
+
expect(blockRelationOp?.relation.type).toBe(SystemIds.BLOCKS);
|
|
25
25
|
expect(blockRelationOp?.relation.fromEntity).toBe('test-entity-id');
|
|
26
26
|
}
|
|
27
27
|
expect(ops.length).toBe(3);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"text.test.js","sourceRoot":"","sources":["../../../../src/core/blocks/text.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"text.test.js","sourceRoot":"","sources":["../../../../src/core/blocks/text.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;IACrD,MAAM,GAAG,GAAG,IAAI,CAAC;QACf,MAAM,EAAE,gBAAgB;QACxB,IAAI,EAAE,WAAW;QACjB,QAAQ,EAAE,eAAe;KAC1B,CAAC,CAAC;IAEH,MAAM,CAAC,WAAW,EAAE,mBAAmB,EAAE,eAAe,CAAC,GAAG,GAAG,CAAC;IAEhE,MAAM,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAClD,IAAI,WAAW,EAAE,IAAI,KAAK,iBAAiB,EAAE,CAAC;QAC5C,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QAClE,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IACpE,CAAC;IAED,MAAM,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACrD,IAAI,mBAAmB,EAAE,IAAI,KAAK,YAAY,EAAE,CAAC;QAC/C,MAAM,CAAC,mBAAmB,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QAC/E,MAAM,CAAC,mBAAmB,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC5D,MAAM,CAAC,mBAAmB,EAAE,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACpE,CAAC;IAED,MAAM,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IACtD,IAAI,eAAe,EAAE,IAAI,KAAK,iBAAiB,EAAE,CAAC;QAChD,MAAM,CAAC,eAAe,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC9D,MAAM,CAAC,eAAe,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACtE,CAAC;IAED,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAC7B,CAAC,CAAC,CAAC"}
|