@graphprotocol/grc-20 0.25.1 → 0.25.2

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.
Files changed (244) hide show
  1. package/dist/constants.d.ts +7 -0
  2. package/dist/constants.d.ts.map +1 -0
  3. package/dist/constants.js +8 -0
  4. package/dist/constants.js.map +1 -0
  5. package/dist/convert-ids.d.ts +2 -0
  6. package/dist/convert-ids.d.ts.map +1 -0
  7. package/dist/convert-ids.js +42 -0
  8. package/dist/convert-ids.js.map +1 -0
  9. package/dist/protov2.d.ts +11 -0
  10. package/dist/protov2.d.ts.map +1 -0
  11. package/dist/protov2.js +11 -0
  12. package/dist/protov2.js.map +1 -0
  13. package/dist/src/core/blocks/image.d.ts +15 -0
  14. package/dist/src/core/blocks/image.d.ts.map +1 -0
  15. package/dist/src/core/blocks/image.js +15 -0
  16. package/dist/src/core/blocks/image.js.map +1 -0
  17. package/dist/src/core/idsv2/content.d.ts +59 -0
  18. package/dist/src/core/idsv2/content.d.ts.map +1 -0
  19. package/dist/src/core/idsv2/content.js +59 -0
  20. package/dist/src/core/idsv2/content.js.map +1 -0
  21. package/dist/src/core/idsv2/network.d.ts +5 -0
  22. package/dist/src/core/idsv2/network.d.ts.map +1 -0
  23. package/dist/src/core/idsv2/network.js +5 -0
  24. package/dist/src/core/idsv2/network.js.map +1 -0
  25. package/dist/src/core/idsv2/system.d.ts +222 -0
  26. package/dist/src/core/idsv2/system.d.ts.map +1 -0
  27. package/dist/src/core/idsv2/system.js +230 -0
  28. package/dist/src/core/idsv2/system.js.map +1 -0
  29. package/dist/src/core/image.d.ts +40 -0
  30. package/dist/src/core/image.d.ts.map +1 -0
  31. package/dist/src/core/image.js +76 -0
  32. package/dist/src/core/image.js.map +1 -0
  33. package/dist/src/core/image.test.d.ts +2 -0
  34. package/dist/src/core/image.test.d.ts.map +1 -0
  35. package/dist/src/core/image.test.js +52 -0
  36. package/dist/src/core/image.test.js.map +1 -0
  37. package/dist/src/core/relation.d.ts +88 -0
  38. package/dist/src/core/relation.d.ts.map +1 -0
  39. package/dist/src/core/relation.js +89 -0
  40. package/dist/src/core/relation.js.map +1 -0
  41. package/dist/src/core/relation.test.d.ts +2 -0
  42. package/dist/src/core/relation.test.d.ts.map +1 -0
  43. package/dist/src/core/relation.test.js +45 -0
  44. package/dist/src/core/relation.test.js.map +1 -0
  45. package/dist/src/core/triple.d.ts +50 -0
  46. package/dist/src/core/triple.d.ts.map +1 -0
  47. package/dist/src/core/triple.js +56 -0
  48. package/dist/src/core/triple.js.map +1 -0
  49. package/dist/src/core/triple.test.d.ts +2 -0
  50. package/dist/src/core/triple.test.d.ts.map +1 -0
  51. package/dist/src/core/triple.test.js +37 -0
  52. package/dist/src/core/triple.test.js.map +1 -0
  53. package/dist/src/graph/delete-entity.d.ts +14 -0
  54. package/dist/src/graph/delete-entity.d.ts.map +1 -0
  55. package/dist/src/graph/delete-entity.js +21 -0
  56. package/dist/src/graph/delete-entity.js.map +1 -0
  57. package/dist/src/graph/delete-entity.test.d.ts +2 -0
  58. package/dist/src/graph/delete-entity.test.d.ts.map +1 -0
  59. package/dist/src/graph/delete-entity.test.js +23 -0
  60. package/dist/src/graph/delete-entity.test.js.map +1 -0
  61. package/dist/src/graph/graph.test.d.ts +2 -0
  62. package/dist/src/graph/graph.test.d.ts.map +1 -0
  63. package/dist/src/graph/graph.test.js +46 -0
  64. package/dist/src/graph/graph.test.js.map +1 -0
  65. package/dist/src/graph/helpers/create-default-properties.d.ts +5 -0
  66. package/dist/src/graph/helpers/create-default-properties.d.ts.map +1 -0
  67. package/dist/src/graph/helpers/create-default-properties.js +44 -0
  68. package/dist/src/graph/helpers/create-default-properties.js.map +1 -0
  69. package/dist/src/graph/helpers/create-properties.d.ts +8 -0
  70. package/dist/src/graph/helpers/create-properties.d.ts.map +1 -0
  71. package/dist/src/graph/helpers/create-properties.js +53 -0
  72. package/dist/src/graph/helpers/create-properties.js.map +1 -0
  73. package/dist/src/graphv2/constants.d.ts +2 -0
  74. package/dist/src/graphv2/constants.d.ts.map +1 -0
  75. package/dist/src/graphv2/constants.js +2 -0
  76. package/dist/src/graphv2/constants.js.map +1 -0
  77. package/dist/src/graphv2/create-entity.d.ts +52 -0
  78. package/dist/src/graphv2/create-entity.d.ts.map +1 -0
  79. package/dist/src/graphv2/create-entity.js +140 -0
  80. package/dist/src/graphv2/create-entity.js.map +1 -0
  81. package/dist/src/graphv2/create-entity.test.d.ts +2 -0
  82. package/dist/src/graphv2/create-entity.test.d.ts.map +1 -0
  83. package/dist/src/graphv2/create-entity.test.js +158 -0
  84. package/dist/src/graphv2/create-entity.test.js.map +1 -0
  85. package/dist/src/graphv2/create-image.d.ts +28 -0
  86. package/dist/src/graphv2/create-image.d.ts.map +1 -0
  87. package/dist/src/graphv2/create-image.js +71 -0
  88. package/dist/src/graphv2/create-image.js.map +1 -0
  89. package/dist/src/graphv2/create-image.test.d.ts +2 -0
  90. package/dist/src/graphv2/create-image.test.d.ts.map +1 -0
  91. package/dist/src/graphv2/create-image.test.js +142 -0
  92. package/dist/src/graphv2/create-image.test.js.map +1 -0
  93. package/dist/src/graphv2/create-property.d.ts +22 -0
  94. package/dist/src/graphv2/create-property.d.ts.map +1 -0
  95. package/dist/src/graphv2/create-property.js +129 -0
  96. package/dist/src/graphv2/create-property.js.map +1 -0
  97. package/dist/src/graphv2/create-property.test.d.ts +2 -0
  98. package/dist/src/graphv2/create-property.test.d.ts.map +1 -0
  99. package/dist/src/graphv2/create-property.test.js +82 -0
  100. package/dist/src/graphv2/create-property.test.js.map +1 -0
  101. package/dist/src/graphv2/create-relation.d.ts +33 -0
  102. package/dist/src/graphv2/create-relation.d.ts.map +1 -0
  103. package/dist/src/graphv2/create-relation.js +66 -0
  104. package/dist/src/graphv2/create-relation.js.map +1 -0
  105. package/dist/src/graphv2/create-relation.test.d.ts +2 -0
  106. package/dist/src/graphv2/create-relation.test.d.ts.map +1 -0
  107. package/dist/src/graphv2/create-relation.test.js +208 -0
  108. package/dist/src/graphv2/create-relation.test.js.map +1 -0
  109. package/dist/src/graphv2/create-space.d.ts +13 -0
  110. package/dist/src/graphv2/create-space.d.ts.map +1 -0
  111. package/dist/src/graphv2/create-space.js +21 -0
  112. package/dist/src/graphv2/create-space.js.map +1 -0
  113. package/dist/src/graphv2/create-type.d.ts +22 -0
  114. package/dist/src/graphv2/create-type.d.ts.map +1 -0
  115. package/dist/src/graphv2/create-type.js +64 -0
  116. package/dist/src/graphv2/create-type.js.map +1 -0
  117. package/dist/src/graphv2/create-type.test.d.ts +2 -0
  118. package/dist/src/graphv2/create-type.test.d.ts.map +1 -0
  119. package/dist/src/graphv2/create-type.test.js +109 -0
  120. package/dist/src/graphv2/create-type.test.js.map +1 -0
  121. package/dist/src/graphv2/delete-entity.d.ts +14 -0
  122. package/dist/src/graphv2/delete-entity.d.ts.map +1 -0
  123. package/dist/src/graphv2/delete-entity.js +21 -0
  124. package/dist/src/graphv2/delete-entity.js.map +1 -0
  125. package/dist/src/graphv2/delete-entity.test.d.ts +2 -0
  126. package/dist/src/graphv2/delete-entity.test.d.ts.map +1 -0
  127. package/dist/src/graphv2/delete-entity.test.js +24 -0
  128. package/dist/src/graphv2/delete-entity.test.js.map +1 -0
  129. package/dist/src/graphv2/delete-relation.d.ts +14 -0
  130. package/dist/src/graphv2/delete-relation.d.ts.map +1 -0
  131. package/dist/src/graphv2/delete-relation.js +21 -0
  132. package/dist/src/graphv2/delete-relation.js.map +1 -0
  133. package/dist/src/graphv2/delete-relation.test.d.ts +2 -0
  134. package/dist/src/graphv2/delete-relation.test.d.ts.map +1 -0
  135. package/dist/src/graphv2/delete-relation.test.js +24 -0
  136. package/dist/src/graphv2/delete-relation.test.js.map +1 -0
  137. package/dist/src/graphv2/index.d.ts +12 -0
  138. package/dist/src/graphv2/index.d.ts.map +1 -0
  139. package/dist/src/graphv2/index.js +12 -0
  140. package/dist/src/graphv2/index.js.map +1 -0
  141. package/dist/src/graphv2/remove-entity-properties.d.ts +25 -0
  142. package/dist/src/graphv2/remove-entity-properties.d.ts.map +1 -0
  143. package/dist/src/graphv2/remove-entity-properties.js +24 -0
  144. package/dist/src/graphv2/remove-entity-properties.js.map +1 -0
  145. package/dist/src/graphv2/unset-entity-values.d.ts +21 -0
  146. package/dist/src/graphv2/unset-entity-values.d.ts.map +1 -0
  147. package/dist/src/graphv2/unset-entity-values.js +26 -0
  148. package/dist/src/graphv2/unset-entity-values.js.map +1 -0
  149. package/dist/src/graphv2/unset-entity-values.test.d.ts +2 -0
  150. package/dist/src/graphv2/unset-entity-values.test.d.ts.map +1 -0
  151. package/dist/src/graphv2/unset-entity-values.test.js +40 -0
  152. package/dist/src/graphv2/unset-entity-values.test.js.map +1 -0
  153. package/dist/src/graphv2/unset-relation-fields.d.ts +25 -0
  154. package/dist/src/graphv2/unset-relation-fields.d.ts.map +1 -0
  155. package/dist/src/graphv2/unset-relation-fields.js +34 -0
  156. package/dist/src/graphv2/unset-relation-fields.js.map +1 -0
  157. package/dist/src/graphv2/unset-relation-fields.test.d.ts +2 -0
  158. package/dist/src/graphv2/unset-relation-fields.test.d.ts.map +1 -0
  159. package/dist/src/graphv2/unset-relation-fields.test.js +64 -0
  160. package/dist/src/graphv2/unset-relation-fields.test.js.map +1 -0
  161. package/dist/src/graphv2/update-entity.d.ts +28 -0
  162. package/dist/src/graphv2/update-entity.d.ts.map +1 -0
  163. package/dist/src/graphv2/update-entity.js +73 -0
  164. package/dist/src/graphv2/update-entity.js.map +1 -0
  165. package/dist/src/graphv2/update-entity.test.d.ts +2 -0
  166. package/dist/src/graphv2/update-entity.test.d.ts.map +1 -0
  167. package/dist/src/graphv2/update-entity.test.js +116 -0
  168. package/dist/src/graphv2/update-entity.test.js.map +1 -0
  169. package/dist/src/graphv2/update-relation.d.ts +21 -0
  170. package/dist/src/graphv2/update-relation.d.ts.map +1 -0
  171. package/dist/src/graphv2/update-relation.js +37 -0
  172. package/dist/src/graphv2/update-relation.js.map +1 -0
  173. package/dist/src/id-utils.d.ts.map +1 -1
  174. package/dist/src/id-utils.js.map +1 -1
  175. package/dist/src/idv2.d.ts +27 -0
  176. package/dist/src/idv2.d.ts.map +1 -0
  177. package/dist/src/idv2.js +88 -0
  178. package/dist/src/idv2.js.map +1 -0
  179. package/dist/src/idv2.test.d.ts +2 -0
  180. package/dist/src/idv2.test.d.ts.map +1 -0
  181. package/dist/src/idv2.test.js +26 -0
  182. package/dist/src/idv2.test.js.map +1 -0
  183. package/dist/src/image.d.ts +8 -0
  184. package/dist/src/image.d.ts.map +1 -0
  185. package/dist/src/image.js +8 -0
  186. package/dist/src/image.js.map +1 -0
  187. package/dist/src/ipfs.d.ts.map +1 -1
  188. package/dist/src/ipfs.js +3 -1
  189. package/dist/src/ipfs.js.map +1 -1
  190. package/dist/src/ipfs.test.js +1 -1
  191. package/dist/src/ipfs.test.js.map +1 -1
  192. package/dist/src/ipfsv2.d.ts +96 -0
  193. package/dist/src/ipfsv2.d.ts.map +1 -0
  194. package/dist/src/ipfsv2.js +163 -0
  195. package/dist/src/ipfsv2.js.map +1 -0
  196. package/dist/src/ipfsv2.test.d.ts +2 -0
  197. package/dist/src/ipfsv2.test.d.ts.map +1 -0
  198. package/dist/src/ipfsv2.test.js +22 -0
  199. package/dist/src/ipfsv2.test.js.map +1 -0
  200. package/dist/src/proto/edit.d.ts +2 -2
  201. package/dist/src/proto/edit.d.ts.map +1 -1
  202. package/dist/src/proto/edit.js +27 -25
  203. package/dist/src/proto/edit.js.map +1 -1
  204. package/dist/src/proto/editv2.d.ts +11 -0
  205. package/dist/src/proto/editv2.d.ts.map +1 -0
  206. package/dist/src/proto/editv2.js +81 -0
  207. package/dist/src/proto/editv2.js.map +1 -0
  208. package/dist/src/proto/editv2.test.d.ts +2 -0
  209. package/dist/src/proto/editv2.test.d.ts.map +1 -0
  210. package/dist/src/proto/editv2.test.js +211 -0
  211. package/dist/src/proto/editv2.test.js.map +1 -0
  212. package/dist/src/proto/gen/src/proto/ipfsv2_pb.d.ts +410 -0
  213. package/dist/src/proto/gen/src/proto/ipfsv2_pb.d.ts.map +1 -0
  214. package/dist/src/proto/gen/src/proto/ipfsv2_pb.js +536 -0
  215. package/dist/src/proto/gen/src/proto/ipfsv2_pb.js.map +1 -0
  216. package/dist/src/relation.d.ts +7 -0
  217. package/dist/src/relation.d.ts.map +1 -0
  218. package/dist/src/relation.js +7 -0
  219. package/dist/src/relation.js.map +1 -0
  220. package/dist/src/smart-wallet-2.test-invalid.d.ts +2 -0
  221. package/dist/src/smart-wallet-2.test-invalid.d.ts.map +1 -0
  222. package/dist/src/smart-wallet-2.test-invalid.js +49 -0
  223. package/dist/src/smart-wallet-2.test-invalid.js.map +1 -0
  224. package/dist/src/smart-wallet-2.test.d.ts +2 -0
  225. package/dist/src/smart-wallet-2.test.d.ts.map +1 -0
  226. package/dist/src/smart-wallet-2.test.js +49 -0
  227. package/dist/src/smart-wallet-2.test.js.map +1 -0
  228. package/dist/src/system-ids-v2.d.ts +7 -0
  229. package/dist/src/system-ids-v2.d.ts.map +1 -0
  230. package/dist/src/system-ids-v2.js +7 -0
  231. package/dist/src/system-ids-v2.js.map +1 -0
  232. package/dist/src/triple.d.ts +7 -0
  233. package/dist/src/triple.d.ts.map +1 -0
  234. package/dist/src/triple.js +7 -0
  235. package/dist/src/triple.js.map +1 -0
  236. package/dist/src/types-backup.d.ts +134 -0
  237. package/dist/src/types-backup.d.ts.map +1 -0
  238. package/dist/src/types-backup.js +13 -0
  239. package/dist/src/types-backup.js.map +1 -0
  240. package/dist/src/typesv2.d.ts +173 -0
  241. package/dist/src/typesv2.d.ts.map +1 -0
  242. package/dist/src/typesv2.js +8 -0
  243. package/dist/src/typesv2.js.map +1 -0
  244. package/package.json +10 -10
@@ -0,0 +1,45 @@
1
+ import { expect, it } from 'vitest';
2
+ import { RELATION_INDEX } from './ids/system.js';
3
+ import { Position, PositionRange } from './position.js';
4
+ import { make, remove, reorder } from './relation.js';
5
+ it('should generate CreateRelationOp for CREATE_RELATION', () => {
6
+ const op = make({
7
+ relationId: 'test-relation-id',
8
+ fromId: 'test-entity-id',
9
+ relationTypeId: 'test-relation-type-id',
10
+ toId: 'test-entity-id',
11
+ position: 'test-position',
12
+ });
13
+ expect(op).toEqual({
14
+ type: 'CREATE_RELATION',
15
+ relation: {
16
+ id: 'test-relation-id',
17
+ type: 'test-relation-type-id',
18
+ fromEntity: 'test-entity-id',
19
+ toEntity: 'test-entity-id',
20
+ index: 'test-position',
21
+ },
22
+ });
23
+ });
24
+ it('should generate DeleteRelationOp for DELETE_RELATION', () => {
25
+ const op = remove('test-relation-id');
26
+ expect(op).toEqual({
27
+ type: 'DELETE_RELATION',
28
+ relation: {
29
+ id: 'test-relation-id',
30
+ },
31
+ });
32
+ });
33
+ it('should generate Op that places the fractional indexer between the two provided values', () => {
34
+ const op = reorder({
35
+ relationId: 'test-relation-id',
36
+ beforeIndex: PositionRange.FIRST,
37
+ afterIndex: PositionRange.LAST,
38
+ });
39
+ expect(op.type).toBe('SET_TRIPLE');
40
+ expect(op.triple.attribute).toBe(RELATION_INDEX);
41
+ expect(op.triple.entity).toBe('test-relation-id');
42
+ expect(op.triple.value.type).toBe('TEXT');
43
+ // @TODO how do we test that the resulting value is in-between the two indexes?
44
+ });
45
+ //# sourceMappingURL=relation.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"relation.test.js","sourceRoot":"","sources":["../../../src/core/relation.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAEtD,EAAE,CAAC,sDAAsD,EAAE,GAAG,EAAE;IAC9D,MAAM,EAAE,GAAG,IAAI,CAAC;QACd,UAAU,EAAE,kBAAkB;QAC9B,MAAM,EAAE,gBAAgB;QACxB,cAAc,EAAE,uBAAuB;QACvC,IAAI,EAAE,gBAAgB;QACtB,QAAQ,EAAE,eAAe;KAC1B,CAAC,CAAC;IAEH,MAAM,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC;QACjB,IAAI,EAAE,iBAAiB;QACvB,QAAQ,EAAE;YACR,EAAE,EAAE,kBAAkB;YACtB,IAAI,EAAE,uBAAuB;YAC7B,UAAU,EAAE,gBAAgB;YAC5B,QAAQ,EAAE,gBAAgB;YAC1B,KAAK,EAAE,eAAe;SACvB;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,sDAAsD,EAAE,GAAG,EAAE;IAC9D,MAAM,EAAE,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;IAEtC,MAAM,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC;QACjB,IAAI,EAAE,iBAAiB;QACvB,QAAQ,EAAE;YACR,EAAE,EAAE,kBAAkB;SACvB;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,uFAAuF,EAAE,GAAG,EAAE;IAC/F,MAAM,EAAE,GAAG,OAAO,CAAC;QACjB,UAAU,EAAE,kBAAkB;QAC9B,WAAW,EAAE,aAAa,CAAC,KAAK;QAChC,UAAU,EAAE,aAAa,CAAC,IAAI;KAC/B,CAAC,CAAC;IAEH,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACjD,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAClD,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC1C,+EAA+E;AACjF,CAAC,CAAC,CAAC"}
@@ -0,0 +1,50 @@
1
+ /**
2
+ * This module provides utility functions for working with Triples in TypeScript.
3
+ *
4
+ * @since 0.0.6
5
+ */
6
+ import type { DeleteTripleOp, SetTripleOp, Value } from '../types.js';
7
+ type CreateTripleParams = {
8
+ attributeId: string;
9
+ entityId: string;
10
+ value: Value;
11
+ };
12
+ /**
13
+ * Generates op for creating a new Triple.
14
+ *
15
+ * @example
16
+ * ```ts
17
+ * const op = Triple.make({
18
+ * attributeId: 'attribute-id',
19
+ * entityId: 'entity-id',
20
+ * value: {
21
+ * type: 'TEXT',
22
+ * value: 'value',
23
+ * },
24
+ * });
25
+ * ```
26
+ * @param args – {@link CreateTripleParams}
27
+ * @returns – {@link SetTripleOp}
28
+ */
29
+ export declare function make(args: CreateTripleParams): SetTripleOp;
30
+ type DeleteTripleParams = {
31
+ attributeId: string;
32
+ entityId: string;
33
+ };
34
+ /**
35
+ * Generates op for deleting a Triple.
36
+ *
37
+ * @example
38
+ * ```ts
39
+ * const op = Triple.remove({
40
+ * attributeId: 'attribute-id',
41
+ * entityId: 'entity-id',
42
+ * });
43
+ * ```
44
+ *
45
+ * @param args – {@link DeleteTripleParams}
46
+ * @returns – {@link DeleteTripleOp}
47
+ */
48
+ export declare function remove(args: DeleteTripleParams): DeleteTripleOp;
49
+ export {};
50
+ //# sourceMappingURL=triple.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triple.d.ts","sourceRoot":"","sources":["../../../src/core/triple.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEtE,KAAK,kBAAkB,GAAG;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,KAAK,CAAC;CACd,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,IAAI,CAAC,IAAI,EAAE,kBAAkB,GAAG,WAAW,CAS1D;AAED,KAAK,kBAAkB,GAAG;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF;;;;;;;;;;;;;GAaG;AACH,wBAAgB,MAAM,CAAC,IAAI,EAAE,kBAAkB,GAAG,cAAc,CAQ/D"}
@@ -0,0 +1,56 @@
1
+ /**
2
+ * This module provides utility functions for working with Triples in TypeScript.
3
+ *
4
+ * @since 0.0.6
5
+ */
6
+ /**
7
+ * Generates op for creating a new Triple.
8
+ *
9
+ * @example
10
+ * ```ts
11
+ * const op = Triple.make({
12
+ * attributeId: 'attribute-id',
13
+ * entityId: 'entity-id',
14
+ * value: {
15
+ * type: 'TEXT',
16
+ * value: 'value',
17
+ * },
18
+ * });
19
+ * ```
20
+ * @param args – {@link CreateTripleParams}
21
+ * @returns – {@link SetTripleOp}
22
+ */
23
+ export function make(args) {
24
+ return {
25
+ type: 'SET_TRIPLE',
26
+ triple: {
27
+ attribute: args.attributeId,
28
+ entity: args.entityId,
29
+ value: args.value,
30
+ },
31
+ };
32
+ }
33
+ /**
34
+ * Generates op for deleting a Triple.
35
+ *
36
+ * @example
37
+ * ```ts
38
+ * const op = Triple.remove({
39
+ * attributeId: 'attribute-id',
40
+ * entityId: 'entity-id',
41
+ * });
42
+ * ```
43
+ *
44
+ * @param args – {@link DeleteTripleParams}
45
+ * @returns – {@link DeleteTripleOp}
46
+ */
47
+ export function remove(args) {
48
+ return {
49
+ type: 'DELETE_TRIPLE',
50
+ triple: {
51
+ attribute: args.attributeId,
52
+ entity: args.entityId,
53
+ },
54
+ };
55
+ }
56
+ //# sourceMappingURL=triple.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triple.js","sourceRoot":"","sources":["../../../src/core/triple.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAUH;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,UAAU,IAAI,CAAC,IAAwB;IAC3C,OAAO;QACL,IAAI,EAAE,YAAY;QAClB,MAAM,EAAE;YACN,SAAS,EAAE,IAAI,CAAC,WAAW;YAC3B,MAAM,EAAE,IAAI,CAAC,QAAQ;YACrB,KAAK,EAAE,IAAI,CAAC,KAAK;SAClB;KACF,CAAC;AACJ,CAAC;AAOD;;;;;;;;;;;;;GAaG;AACH,MAAM,UAAU,MAAM,CAAC,IAAwB;IAC7C,OAAO;QACL,IAAI,EAAE,eAAe;QACrB,MAAM,EAAE;YACN,SAAS,EAAE,IAAI,CAAC,WAAW;YAC3B,MAAM,EAAE,IAAI,CAAC,QAAQ;SACtB;KACF,CAAC;AACJ,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=triple.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triple.test.d.ts","sourceRoot":"","sources":["../../../src/core/triple.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,37 @@
1
+ import { expect, it } from 'vitest';
2
+ import { make, remove } from './triple.js';
3
+ it('should generate SetTripleOp for SET_TRIPLE', () => {
4
+ const op = make({
5
+ attributeId: 'test-attribute-id',
6
+ entityId: 'test-entity-id',
7
+ value: {
8
+ type: 'TEXT',
9
+ value: 'test value',
10
+ },
11
+ });
12
+ expect(op).toEqual({
13
+ type: 'SET_TRIPLE',
14
+ triple: {
15
+ attribute: 'test-attribute-id',
16
+ entity: 'test-entity-id',
17
+ value: {
18
+ type: 'TEXT',
19
+ value: 'test value',
20
+ },
21
+ },
22
+ });
23
+ });
24
+ it('should generate DeleteTripleOp for DELETE_TRIPLE', () => {
25
+ const op = remove({
26
+ attributeId: 'test-attribute-id',
27
+ entityId: 'test-entity-id',
28
+ });
29
+ expect(op).toEqual({
30
+ type: 'DELETE_TRIPLE',
31
+ triple: {
32
+ attribute: 'test-attribute-id',
33
+ entity: 'test-entity-id',
34
+ },
35
+ });
36
+ });
37
+ //# sourceMappingURL=triple.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triple.test.js","sourceRoot":"","sources":["../../../src/core/triple.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE3C,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;IACpD,MAAM,EAAE,GAAG,IAAI,CAAC;QACd,WAAW,EAAE,mBAAmB;QAChC,QAAQ,EAAE,gBAAgB;QAC1B,KAAK,EAAE;YACL,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,YAAY;SACpB;KACF,CAAC,CAAC;IAEH,MAAM,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC;QACjB,IAAI,EAAE,YAAY;QAClB,MAAM,EAAE;YACN,SAAS,EAAE,mBAAmB;YAC9B,MAAM,EAAE,gBAAgB;YACxB,KAAK,EAAE;gBACL,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,YAAY;aACpB;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;IAC1D,MAAM,EAAE,GAAG,MAAM,CAAC;QAChB,WAAW,EAAE,mBAAmB;QAChC,QAAQ,EAAE,gBAAgB;KAC3B,CAAC,CAAC;IAEH,MAAM,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC;QACjB,IAAI,EAAE,eAAe;QACrB,MAAM,EAAE;YACN,SAAS,EAAE,mBAAmB;YAC9B,MAAM,EAAE,gBAAgB;SACzB;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=delete-entity.test.d.ts.map
@@ -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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=graph.test.d.ts.map
@@ -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,5 @@
1
+ import type { DefaultProperties, Op } from '../../types.js';
2
+ export declare const createDefaultProperties: (params: DefaultProperties & {
3
+ entityId: string;
4
+ }) => Op[];
5
+ //# sourceMappingURL=create-default-properties.d.ts.map
@@ -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"}
@@ -0,0 +1,2 @@
1
+ export declare const DEFAULT_API_HOST = "https://api-testnet.grc-20.thegraph.com";
2
+ //# sourceMappingURL=constants.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/graphv2/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,gBAAgB,4CAA4C,CAAC"}
@@ -0,0 +1,2 @@
1
+ export const DEFAULT_API_HOST = 'https://api-testnet.grc-20.thegraph.com';
2
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/graphv2/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,gBAAgB,GAAG,yCAAyC,CAAC"}
@@ -0,0 +1,52 @@
1
+ import type { CreateResult, EntityParams } from '../typesv2.js';
2
+ /**
3
+ * Creates an entity with the given name, description, cover, properties, and types.
4
+ * All IDs passed to this function (cover, types, property IDs, relation IDs, etc.) are validated.
5
+ * If any invalid ID is provided, the function will throw an error.
6
+ *
7
+ * @example
8
+ * ```ts
9
+ * const { id, ops } = createEntity({
10
+ * id: entityId, // optional and will be generated if not provided
11
+ * name: 'name of the entity',
12
+ * description: 'description of the entity',
13
+ * cover: imageEntityId,
14
+ * types: [typeEntityId1, typeEntityId2],
15
+ * values: {
16
+ * // value property like text, number, url, time, point, checkbox
17
+ * [propertyId]: {
18
+ * value: 'value of the property',
19
+ * }
20
+ * },
21
+ * relations: {
22
+ * [relationId]: {
23
+ * to: 'id of the entity',
24
+ * id: 'id of the relation', // optional
25
+ * toSpace: 'id of the to space', // optional
26
+ * position: positionString, // optional
27
+ * entityId: 'id of the relation entity', // optional and will be generated if not provided
28
+ * entityName: 'name of the relation entity', // optional
29
+ * entityDescription: 'description of the relation entity', // optional
30
+ * entityCover: 'id of the cover', // optional
31
+ * entityValues: { // optional values for the relation entity
32
+ * [propertyId]: {
33
+ * value: 'value of the property',
34
+ * },
35
+ * },
36
+ * entityRelations: {
37
+ * [relationId]: {
38
+ * to: 'id of the entity',
39
+ * id: 'id of the relation', // optional
40
+ * position: positionString, // optional
41
+ * },
42
+ * },
43
+ * },
44
+ * },
45
+ * });
46
+ * ```
47
+ * @param params – {@link EntityParams}
48
+ * @returns – {@link CreateResult}
49
+ * @throws Will throw an error if any provided ID is invalid
50
+ */
51
+ export declare const createEntity: ({ id: providedId, name, description, cover, values, relations, types, }: EntityParams) => CreateResult;
52
+ //# sourceMappingURL=create-entity.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-entity.d.ts","sourceRoot":"","sources":["../../../src/graphv2/create-entity.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,YAAY,EAA6B,MAAM,eAAe,CAAC;AAG3F;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgDG;AACH,eAAO,MAAM,YAAY,GAAI,yEAQ1B,YAAY,KAAG,YA4FjB,CAAC"}