@geoprotocol/geo-sdk 0.18.2 → 0.19.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.
Files changed (352) hide show
  1. package/README.md +995 -372
  2. package/dist/contracts.d.ts +0 -11
  3. package/dist/contracts.d.ts.map +1 -1
  4. package/dist/contracts.js +0 -11
  5. package/dist/contracts.js.map +1 -1
  6. package/dist/index.d.ts +7 -0
  7. package/dist/index.d.ts.map +1 -1
  8. package/dist/index.js +7 -0
  9. package/dist/index.js.map +1 -1
  10. package/dist/lite.d.ts +2 -0
  11. package/dist/lite.d.ts.map +1 -1
  12. package/dist/lite.js +2 -0
  13. package/dist/lite.js.map +1 -1
  14. package/dist/src/abis/dao-space-v2.test.d.ts +2 -0
  15. package/dist/src/abis/dao-space-v2.test.d.ts.map +1 -0
  16. package/dist/src/abis/dao-space-v2.test.js +67 -0
  17. package/dist/src/abis/dao-space-v2.test.js.map +1 -0
  18. package/dist/src/client/api.d.ts +86 -0
  19. package/dist/src/client/api.d.ts.map +1 -0
  20. package/dist/src/client/api.js +169 -0
  21. package/dist/src/client/api.js.map +1 -0
  22. package/dist/src/client/comments.d.ts +59 -0
  23. package/dist/src/client/comments.d.ts.map +1 -0
  24. package/dist/src/client/comments.js +96 -0
  25. package/dist/src/client/comments.js.map +1 -0
  26. package/dist/src/client/context.d.ts +20 -0
  27. package/dist/src/client/context.d.ts.map +1 -0
  28. package/dist/src/client/context.js +20 -0
  29. package/dist/src/client/context.js.map +1 -0
  30. package/dist/src/client/dao-spaces.d.ts +348 -0
  31. package/dist/src/client/dao-spaces.d.ts.map +1 -0
  32. package/dist/src/client/dao-spaces.js +494 -0
  33. package/dist/src/client/dao-spaces.js.map +1 -0
  34. package/dist/src/client/dao-spaces.test.d.ts +2 -0
  35. package/dist/src/client/dao-spaces.test.d.ts.map +1 -0
  36. package/dist/src/client/dao-spaces.test.js +263 -0
  37. package/dist/src/client/dao-spaces.test.js.map +1 -0
  38. package/dist/src/client/edits.d.ts +100 -0
  39. package/dist/src/client/edits.d.ts.map +1 -0
  40. package/dist/src/client/edits.js +131 -0
  41. package/dist/src/client/edits.js.map +1 -0
  42. package/dist/src/client/edits.test.d.ts +2 -0
  43. package/dist/src/client/edits.test.d.ts.map +1 -0
  44. package/dist/src/client/edits.test.js +98 -0
  45. package/dist/src/client/edits.test.js.map +1 -0
  46. package/dist/src/client/entities.d.ts +23 -0
  47. package/dist/src/client/entities.d.ts.map +1 -0
  48. package/dist/src/client/entities.js +88 -0
  49. package/dist/src/client/entities.js.map +1 -0
  50. package/dist/src/client/entity-votes.d.ts +141 -0
  51. package/dist/src/client/entity-votes.d.ts.map +1 -0
  52. package/dist/src/client/entity-votes.js +168 -0
  53. package/dist/src/client/entity-votes.js.map +1 -0
  54. package/dist/src/client/entity-votes.test.d.ts +2 -0
  55. package/dist/src/client/entity-votes.test.d.ts.map +1 -0
  56. package/dist/src/client/entity-votes.test.js +93 -0
  57. package/dist/src/client/entity-votes.test.js.map +1 -0
  58. package/dist/src/client/graph-workflows.test.d.ts +2 -0
  59. package/dist/src/client/graph-workflows.test.d.ts.map +1 -0
  60. package/dist/src/client/graph-workflows.test.js +83 -0
  61. package/dist/src/client/graph-workflows.test.js.map +1 -0
  62. package/dist/src/client/images-storage.test.d.ts +2 -0
  63. package/dist/src/client/images-storage.test.d.ts.map +1 -0
  64. package/dist/src/client/images-storage.test.js +52 -0
  65. package/dist/src/client/images-storage.test.js.map +1 -0
  66. package/dist/src/client/images.d.ts +35 -0
  67. package/dist/src/client/images.d.ts.map +1 -0
  68. package/dist/src/client/images.js +90 -0
  69. package/dist/src/client/images.js.map +1 -0
  70. package/dist/src/client/personal-spaces.d.ts +155 -0
  71. package/dist/src/client/personal-spaces.d.ts.map +1 -0
  72. package/dist/src/client/personal-spaces.js +198 -0
  73. package/dist/src/client/personal-spaces.js.map +1 -0
  74. package/dist/src/client/proposals.d.ts +185 -0
  75. package/dist/src/client/proposals.d.ts.map +1 -0
  76. package/dist/src/client/proposals.js +294 -0
  77. package/dist/src/client/proposals.js.map +1 -0
  78. package/dist/src/client/proposals.test.d.ts +2 -0
  79. package/dist/src/client/proposals.test.d.ts.map +1 -0
  80. package/dist/src/client/proposals.test.js +243 -0
  81. package/dist/src/client/proposals.test.js.map +1 -0
  82. package/dist/src/client/spaces.test.d.ts +2 -0
  83. package/dist/src/client/spaces.test.d.ts.map +1 -0
  84. package/dist/src/client/spaces.test.js +155 -0
  85. package/dist/src/client/spaces.test.js.map +1 -0
  86. package/dist/src/client/storage.d.ts +52 -0
  87. package/dist/src/client/storage.d.ts.map +1 -0
  88. package/dist/src/client/storage.js +53 -0
  89. package/dist/src/client/storage.js.map +1 -0
  90. package/dist/src/client.d.ts +325 -0
  91. package/dist/src/client.d.ts.map +1 -0
  92. package/dist/src/client.js +452 -0
  93. package/dist/src/client.js.map +1 -0
  94. package/dist/src/client.test.d.ts +2 -0
  95. package/dist/src/client.test.d.ts.map +1 -0
  96. package/dist/src/client.test.js +120 -0
  97. package/dist/src/client.test.js.map +1 -0
  98. package/dist/src/contracts-v2/abis.d.ts +196 -0
  99. package/dist/src/contracts-v2/abis.d.ts.map +1 -0
  100. package/dist/src/contracts-v2/abis.js +110 -0
  101. package/dist/src/contracts-v2/abis.js.map +1 -0
  102. package/dist/src/contracts-v2/actions.d.ts +56 -0
  103. package/dist/src/contracts-v2/actions.d.ts.map +1 -0
  104. package/dist/src/contracts-v2/actions.js +83 -0
  105. package/dist/src/contracts-v2/actions.js.map +1 -0
  106. package/dist/src/contracts-v2/encoding.d.ts +80 -0
  107. package/dist/src/contracts-v2/encoding.d.ts.map +1 -0
  108. package/dist/src/contracts-v2/encoding.js +193 -0
  109. package/dist/src/contracts-v2/encoding.js.map +1 -0
  110. package/dist/src/contracts-v2/encoding.test.d.ts +2 -0
  111. package/dist/src/contracts-v2/encoding.test.d.ts.map +1 -0
  112. package/dist/src/contracts-v2/encoding.test.js +93 -0
  113. package/dist/src/contracts-v2/encoding.test.js.map +1 -0
  114. package/dist/src/contracts-v2/local-geobrowser.e2e.test.d.ts +2 -0
  115. package/dist/src/contracts-v2/local-geobrowser.e2e.test.d.ts.map +1 -0
  116. package/dist/src/contracts-v2/local-geobrowser.e2e.test.js +239 -0
  117. package/dist/src/contracts-v2/local-geobrowser.e2e.test.js.map +1 -0
  118. package/dist/src/contracts-v2/voting-settings.d.ts +48 -0
  119. package/dist/src/contracts-v2/voting-settings.d.ts.map +1 -0
  120. package/dist/src/contracts-v2/voting-settings.js +69 -0
  121. package/dist/src/contracts-v2/voting-settings.js.map +1 -0
  122. package/dist/src/dao-space/constants.d.ts +6 -3
  123. package/dist/src/dao-space/constants.d.ts.map +1 -1
  124. package/dist/src/dao-space/constants.js +6 -5
  125. package/dist/src/dao-space/constants.js.map +1 -1
  126. package/dist/src/dao-space/create-space.d.ts +1 -31
  127. package/dist/src/dao-space/create-space.d.ts.map +1 -1
  128. package/dist/src/dao-space/create-space.js +5 -70
  129. package/dist/src/dao-space/create-space.js.map +1 -1
  130. package/dist/src/dao-space/execute-proposal.d.ts +1 -22
  131. package/dist/src/dao-space/execute-proposal.d.ts.map +1 -1
  132. package/dist/src/dao-space/execute-proposal.js +12 -59
  133. package/dist/src/dao-space/execute-proposal.js.map +1 -1
  134. package/dist/src/dao-space/propose-add-editor.test.js +1 -1
  135. package/dist/src/dao-space/propose-add-editor.test.js.map +1 -1
  136. package/dist/src/dao-space/propose-edit.d.ts +1 -30
  137. package/dist/src/dao-space/propose-edit.d.ts.map +1 -1
  138. package/dist/src/dao-space/propose-edit.js +12 -108
  139. package/dist/src/dao-space/propose-edit.js.map +1 -1
  140. package/dist/src/dao-space/propose-edit.test.js +8 -1
  141. package/dist/src/dao-space/propose-edit.test.js.map +1 -1
  142. package/dist/src/dao-space/propose-remove-editor.d.ts.map +1 -1
  143. package/dist/src/dao-space/propose-remove-editor.js +5 -5
  144. package/dist/src/dao-space/propose-remove-editor.js.map +1 -1
  145. package/dist/src/dao-space/propose-remove-editor.test.js +3 -8
  146. package/dist/src/dao-space/propose-remove-editor.test.js.map +1 -1
  147. package/dist/src/dao-space/propose-remove-member.d.ts.map +1 -1
  148. package/dist/src/dao-space/propose-remove-member.js +5 -5
  149. package/dist/src/dao-space/propose-remove-member.js.map +1 -1
  150. package/dist/src/dao-space/propose-request-membership.d.ts.map +1 -1
  151. package/dist/src/dao-space/propose-request-membership.js +4 -4
  152. package/dist/src/dao-space/propose-request-membership.js.map +1 -1
  153. package/dist/src/dao-space/propose-update-voting-settings.d.ts +8 -0
  154. package/dist/src/dao-space/propose-update-voting-settings.d.ts.map +1 -0
  155. package/dist/src/dao-space/propose-update-voting-settings.js +19 -0
  156. package/dist/src/dao-space/propose-update-voting-settings.js.map +1 -0
  157. package/dist/src/dao-space/propose-update-voting-settings.test.d.ts +2 -0
  158. package/dist/src/dao-space/propose-update-voting-settings.test.d.ts.map +1 -0
  159. package/dist/src/dao-space/propose-update-voting-settings.test.js +118 -0
  160. package/dist/src/dao-space/propose-update-voting-settings.test.js.map +1 -0
  161. package/dist/src/dao-space/vote-proposal.d.ts +1 -24
  162. package/dist/src/dao-space/vote-proposal.d.ts.map +1 -1
  163. package/dist/src/dao-space/vote-proposal.js +12 -64
  164. package/dist/src/dao-space/vote-proposal.js.map +1 -1
  165. package/dist/src/e2e/local-geobrowser.d.ts +9 -0
  166. package/dist/src/e2e/local-geobrowser.d.ts.map +1 -0
  167. package/dist/src/e2e/local-geobrowser.js +35 -0
  168. package/dist/src/e2e/local-geobrowser.js.map +1 -0
  169. package/dist/src/e2e/v2-contracts.test.d.ts +2 -0
  170. package/dist/src/e2e/v2-contracts.test.d.ts.map +1 -0
  171. package/dist/src/e2e/v2-contracts.test.js +25 -0
  172. package/dist/src/e2e/v2-contracts.test.js.map +1 -0
  173. package/dist/src/e2e-api-surface.test.d.ts +2 -0
  174. package/dist/src/e2e-api-surface.test.d.ts.map +1 -0
  175. package/dist/src/e2e-api-surface.test.js +1021 -0
  176. package/dist/src/e2e-api-surface.test.js.map +1 -0
  177. package/dist/src/e2e-flows.test.d.ts +2 -0
  178. package/dist/src/e2e-flows.test.d.ts.map +1 -0
  179. package/dist/src/e2e-flows.test.js +445 -0
  180. package/dist/src/e2e-flows.test.js.map +1 -0
  181. package/dist/src/e2e-legacy-api-surface.test.d.ts +2 -0
  182. package/dist/src/e2e-legacy-api-surface.test.d.ts.map +1 -0
  183. package/dist/src/e2e-legacy-api-surface.test.js +840 -0
  184. package/dist/src/e2e-legacy-api-surface.test.js.map +1 -0
  185. package/dist/src/encoding.d.ts +3 -0
  186. package/dist/src/encoding.d.ts.map +1 -1
  187. package/dist/src/encoding.js +3 -0
  188. package/dist/src/encoding.js.map +1 -1
  189. package/dist/src/encodings/get-create-dao-space-calldata.d.ts +3 -89
  190. package/dist/src/encodings/get-create-dao-space-calldata.d.ts.map +1 -1
  191. package/dist/src/encodings/get-create-dao-space-calldata.js +5 -95
  192. package/dist/src/encodings/get-create-dao-space-calldata.js.map +1 -1
  193. package/dist/src/encodings/get-create-personal-space-calldata.d.ts +2 -0
  194. package/dist/src/encodings/get-create-personal-space-calldata.d.ts.map +1 -1
  195. package/dist/src/encodings/get-create-personal-space-calldata.js +2 -0
  196. package/dist/src/encodings/get-create-personal-space-calldata.js.map +1 -1
  197. package/dist/src/graph/comment-utils.d.ts +4 -0
  198. package/dist/src/graph/comment-utils.d.ts.map +1 -1
  199. package/dist/src/graph/comment-utils.js +4 -0
  200. package/dist/src/graph/comment-utils.js.map +1 -1
  201. package/dist/src/graph/constants.d.ts +12 -3
  202. package/dist/src/graph/constants.d.ts.map +1 -1
  203. package/dist/src/graph/constants.js +11 -5
  204. package/dist/src/graph/constants.js.map +1 -1
  205. package/dist/src/graph/create-comment.d.ts +3 -22
  206. package/dist/src/graph/create-comment.d.ts.map +1 -1
  207. package/dist/src/graph/create-comment.js +6 -136
  208. package/dist/src/graph/create-comment.js.map +1 -1
  209. package/dist/src/graph/create-comment.test.js +19 -8
  210. package/dist/src/graph/create-comment.test.js.map +1 -1
  211. package/dist/src/graph/create-entity.d.ts +2 -0
  212. package/dist/src/graph/create-entity.d.ts.map +1 -1
  213. package/dist/src/graph/create-entity.js +2 -0
  214. package/dist/src/graph/create-entity.js.map +1 -1
  215. package/dist/src/graph/create-image.d.ts +2 -21
  216. package/dist/src/graph/create-image.d.ts.map +1 -1
  217. package/dist/src/graph/create-image.js +7 -69
  218. package/dist/src/graph/create-image.js.map +1 -1
  219. package/dist/src/graph/create-property.d.ts +2 -0
  220. package/dist/src/graph/create-property.d.ts.map +1 -1
  221. package/dist/src/graph/create-property.js +2 -0
  222. package/dist/src/graph/create-property.js.map +1 -1
  223. package/dist/src/graph/create-proposal-review.d.ts +1 -27
  224. package/dist/src/graph/create-proposal-review.d.ts.map +1 -1
  225. package/dist/src/graph/create-proposal-review.js +4 -61
  226. package/dist/src/graph/create-proposal-review.js.map +1 -1
  227. package/dist/src/graph/create-relation.d.ts +2 -0
  228. package/dist/src/graph/create-relation.d.ts.map +1 -1
  229. package/dist/src/graph/create-relation.js +2 -0
  230. package/dist/src/graph/create-relation.js.map +1 -1
  231. package/dist/src/graph/create-type.d.ts +2 -0
  232. package/dist/src/graph/create-type.d.ts.map +1 -1
  233. package/dist/src/graph/create-type.js +2 -0
  234. package/dist/src/graph/create-type.js.map +1 -1
  235. package/dist/src/graph/delete-entity.d.ts +2 -14
  236. package/dist/src/graph/delete-entity.d.ts.map +1 -1
  237. package/dist/src/graph/delete-entity.js +5 -78
  238. package/dist/src/graph/delete-entity.js.map +1 -1
  239. package/dist/src/graph/delete-entity.test.js +7 -0
  240. package/dist/src/graph/delete-entity.test.js.map +1 -1
  241. package/dist/src/graph/delete-relation.d.ts +2 -0
  242. package/dist/src/graph/delete-relation.d.ts.map +1 -1
  243. package/dist/src/graph/delete-relation.js +2 -0
  244. package/dist/src/graph/delete-relation.js.map +1 -1
  245. package/dist/src/graph/entity-vote.d.ts +37 -0
  246. package/dist/src/graph/entity-vote.d.ts.map +1 -0
  247. package/dist/src/graph/entity-vote.js +44 -0
  248. package/dist/src/graph/entity-vote.js.map +1 -0
  249. package/dist/src/graph/entity-vote.test.d.ts +2 -0
  250. package/dist/src/graph/entity-vote.test.d.ts.map +1 -0
  251. package/dist/src/graph/entity-vote.test.js +123 -0
  252. package/dist/src/graph/entity-vote.test.js.map +1 -0
  253. package/dist/src/graph/index.d.ts +1 -0
  254. package/dist/src/graph/index.d.ts.map +1 -1
  255. package/dist/src/graph/index.js +1 -0
  256. package/dist/src/graph/index.js.map +1 -1
  257. package/dist/src/graph/update-comment.d.ts +3 -0
  258. package/dist/src/graph/update-comment.d.ts.map +1 -1
  259. package/dist/src/graph/update-comment.js +3 -0
  260. package/dist/src/graph/update-comment.js.map +1 -1
  261. package/dist/src/graph/update-entity.d.ts +2 -0
  262. package/dist/src/graph/update-entity.d.ts.map +1 -1
  263. package/dist/src/graph/update-entity.js +2 -0
  264. package/dist/src/graph/update-entity.js.map +1 -1
  265. package/dist/src/graph/update-proposal-review.d.ts +2 -27
  266. package/dist/src/graph/update-proposal-review.d.ts.map +1 -1
  267. package/dist/src/graph/update-proposal-review.js +4 -50
  268. package/dist/src/graph/update-proposal-review.js.map +1 -1
  269. package/dist/src/graph/update-relation.d.ts +2 -0
  270. package/dist/src/graph/update-relation.d.ts.map +1 -1
  271. package/dist/src/graph/update-relation.js +2 -0
  272. package/dist/src/graph/update-relation.js.map +1 -1
  273. package/dist/src/ipfs-core.d.ts +42 -0
  274. package/dist/src/ipfs-core.d.ts.map +1 -0
  275. package/dist/src/ipfs-core.js +165 -0
  276. package/dist/src/ipfs-core.js.map +1 -0
  277. package/dist/src/ipfs-core.test.d.ts +2 -0
  278. package/dist/src/ipfs-core.test.d.ts.map +1 -0
  279. package/dist/src/ipfs-core.test.js +56 -0
  280. package/dist/src/ipfs-core.test.js.map +1 -0
  281. package/dist/src/ipfs.d.ts +7 -52
  282. package/dist/src/ipfs.d.ts.map +1 -1
  283. package/dist/src/ipfs.js +27 -170
  284. package/dist/src/ipfs.js.map +1 -1
  285. package/dist/src/networks.d.ts +46 -0
  286. package/dist/src/networks.d.ts.map +1 -0
  287. package/dist/src/networks.js +90 -0
  288. package/dist/src/networks.js.map +1 -0
  289. package/dist/src/ops/comments.d.ts +80 -0
  290. package/dist/src/ops/comments.d.ts.map +1 -0
  291. package/dist/src/ops/comments.js +142 -0
  292. package/dist/src/ops/comments.js.map +1 -0
  293. package/dist/src/ops/entities.d.ts +50 -0
  294. package/dist/src/ops/entities.d.ts.map +1 -0
  295. package/dist/src/ops/entities.js +51 -0
  296. package/dist/src/ops/entities.js.map +1 -0
  297. package/dist/src/ops/images.d.ts +37 -0
  298. package/dist/src/ops/images.d.ts.map +1 -0
  299. package/dist/src/ops/images.js +69 -0
  300. package/dist/src/ops/images.js.map +1 -0
  301. package/dist/src/ops/index.d.ts +7 -0
  302. package/dist/src/ops/index.d.ts.map +1 -0
  303. package/dist/src/ops/index.js +7 -0
  304. package/dist/src/ops/index.js.map +1 -0
  305. package/dist/src/ops/index.test.d.ts +2 -0
  306. package/dist/src/ops/index.test.d.ts.map +1 -0
  307. package/dist/src/ops/index.test.js +115 -0
  308. package/dist/src/ops/index.test.js.map +1 -0
  309. package/dist/src/ops/properties.d.ts +20 -0
  310. package/dist/src/ops/properties.d.ts.map +1 -0
  311. package/dist/src/ops/properties.js +20 -0
  312. package/dist/src/ops/properties.js.map +1 -0
  313. package/dist/src/ops/proposal-reviews.d.ts +43 -0
  314. package/dist/src/ops/proposal-reviews.d.ts.map +1 -0
  315. package/dist/src/ops/proposal-reviews.js +103 -0
  316. package/dist/src/ops/proposal-reviews.js.map +1 -0
  317. package/dist/src/ops/relations.d.ts +57 -0
  318. package/dist/src/ops/relations.d.ts.map +1 -0
  319. package/dist/src/ops/relations.js +59 -0
  320. package/dist/src/ops/relations.js.map +1 -0
  321. package/dist/src/ops/types.d.ts +20 -0
  322. package/dist/src/ops/types.d.ts.map +1 -0
  323. package/dist/src/ops/types.js +20 -0
  324. package/dist/src/ops/types.js.map +1 -0
  325. package/dist/src/personal-space/constants.d.ts +1 -0
  326. package/dist/src/personal-space/constants.d.ts.map +1 -1
  327. package/dist/src/personal-space/constants.js +1 -0
  328. package/dist/src/personal-space/constants.js.map +1 -1
  329. package/dist/src/personal-space/create-space.d.ts +1 -18
  330. package/dist/src/personal-space/create-space.d.ts.map +1 -1
  331. package/dist/src/personal-space/create-space.js +1 -18
  332. package/dist/src/personal-space/create-space.js.map +1 -1
  333. package/dist/src/personal-space/has-space.d.ts +9 -2
  334. package/dist/src/personal-space/has-space.d.ts.map +1 -1
  335. package/dist/src/personal-space/has-space.js +9 -13
  336. package/dist/src/personal-space/has-space.js.map +1 -1
  337. package/dist/src/personal-space/has-space.test.d.ts +2 -0
  338. package/dist/src/personal-space/has-space.test.d.ts.map +1 -0
  339. package/dist/src/personal-space/has-space.test.js +30 -0
  340. package/dist/src/personal-space/has-space.test.js.map +1 -0
  341. package/dist/src/personal-space/publish-edit.d.ts +1 -22
  342. package/dist/src/personal-space/publish-edit.d.ts.map +1 -1
  343. package/dist/src/personal-space/publish-edit.js +10 -64
  344. package/dist/src/personal-space/publish-edit.js.map +1 -1
  345. package/dist/src/smart-wallet.d.ts +2 -4
  346. package/dist/src/smart-wallet.d.ts.map +1 -1
  347. package/dist/src/smart-wallet.js +6 -9
  348. package/dist/src/smart-wallet.js.map +1 -1
  349. package/dist/src/types.d.ts +25 -0
  350. package/dist/src/types.d.ts.map +1 -1
  351. package/dist/src/types.js.map +1 -1
  352. package/package.json +14 -1
@@ -0,0 +1,51 @@
1
+ import { createEntity } from '../graph/create-entity.js';
2
+ import { updateEntity } from '../graph/update-entity.js';
3
+ /**
4
+ * Builds create-entity ops.
5
+ *
6
+ * This is the pure version of entity creation. It validates supplied IDs and
7
+ * encodes the same operation shape as the legacy `createEntity(...)` helper.
8
+ *
9
+ * @example
10
+ * ```ts
11
+ * import { entities } from '@geoprotocol/geo-sdk/ops';
12
+ *
13
+ * const { id, ops } = entities.create({
14
+ * name: 'Restaurant',
15
+ * description: 'A neighborhood restaurant',
16
+ * types: [restaurantTypeId],
17
+ * values: [
18
+ * {
19
+ * property: websitePropertyId,
20
+ * type: 'text',
21
+ * value: 'https://example.com',
22
+ * },
23
+ * ],
24
+ * });
25
+ * ```
26
+ *
27
+ * @param params Entity fields, values, relations, and types to encode.
28
+ * @returns Generated or supplied entity ID and create ops.
29
+ * @throws When any supplied ID is invalid.
30
+ */
31
+ export const create = (params) => createEntity(params);
32
+ /**
33
+ * Builds update-entity ops.
34
+ *
35
+ * @example
36
+ * ```ts
37
+ * import { entities } from '@geoprotocol/geo-sdk/ops';
38
+ *
39
+ * const { ops } = entities.update({
40
+ * id: entityId,
41
+ * name: 'Updated restaurant name',
42
+ * unset: [{ property: oldDescriptionPropertyId }],
43
+ * });
44
+ * ```
45
+ *
46
+ * @param params Entity ID and values/properties to update or unset.
47
+ * @returns Entity ID and update ops.
48
+ * @throws When any supplied ID is invalid.
49
+ */
50
+ export const update = (params) => updateEntity(params);
51
+ //# sourceMappingURL=entities.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"entities.js","sourceRoot":"","sources":["../../../src/ops/entities.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAGzD;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,MAAoB,EAAgB,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;AAEnF;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,MAA0B,EAAgB,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC"}
@@ -0,0 +1,37 @@
1
+ import { Id } from '../id.js';
2
+ import type { CreateImageResult } from '../types.js';
3
+ export type CreateImageOpsParams = {
4
+ /** Uploaded IPFS URI for the image file. */
5
+ cid: string;
6
+ /** Optional image dimensions. */
7
+ dimensions?: {
8
+ width: number;
9
+ height: number;
10
+ };
11
+ /** Optional name value for the image entity. */
12
+ name?: string;
13
+ /** Optional description value for the image entity. */
14
+ description?: string;
15
+ /** Optional image entity ID. Generated when omitted. */
16
+ id?: Id | string;
17
+ };
18
+ /**
19
+ * Builds image entity ops from an image CID and optional metadata.
20
+ *
21
+ * @example
22
+ * ```ts
23
+ * import { images } from '@geoprotocol/geo-sdk/ops';
24
+ *
25
+ * const { id, ops } = images.create({
26
+ * cid: 'ipfs://baf...',
27
+ * name: 'Cover image',
28
+ * dimensions: { width: 1200, height: 630 },
29
+ * });
30
+ * ```
31
+ *
32
+ * @param params Uploaded CID, optional dimensions, optional metadata, and optional entity ID.
33
+ * @returns Image entity ID, CID, dimensions, and create ops.
34
+ * @throws When the optional image entity ID is invalid.
35
+ */
36
+ export declare const create: ({ cid, dimensions, name, description, id: providedId, }: CreateImageOpsParams) => CreateImageResult;
37
+ //# sourceMappingURL=images.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"images.d.ts","sourceRoot":"","sources":["../../../src/ops/images.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAE9B,OAAO,KAAK,EAAE,iBAAiB,EAAmB,MAAM,aAAa,CAAC;AAGtE,MAAM,MAAM,oBAAoB,GAAG;IACjC,4CAA4C;IAC5C,GAAG,EAAE,MAAM,CAAC;IACZ,iCAAiC;IACjC,UAAU,CAAC,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;IAC/C,gDAAgD;IAChD,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,uDAAuD;IACvD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,wDAAwD;IACxD,EAAE,CAAC,EAAE,EAAE,GAAG,MAAM,CAAC;CAClB,CAAC;AAEF;;;;;;;;;;;;;;;;;GAiBG;AACH,eAAO,MAAM,MAAM,GAAI,yDAMpB,oBAAoB,KAAG,iBAkDzB,CAAC"}
@@ -0,0 +1,69 @@
1
+ import { createRelation as grcCreateRelation } from '@geoprotocol/grc-20';
2
+ import { IMAGE_HEIGHT_PROPERTY, IMAGE_TYPE, IMAGE_URL_PROPERTY, IMAGE_WIDTH_PROPERTY, TYPES_PROPERTY, } from '../core/ids/system.js';
3
+ import { Id } from '../id.js';
4
+ import { assertValid, generate, toGrcId } from '../id-utils.js';
5
+ import { create as createEntity } from './entities.js';
6
+ /**
7
+ * Builds image entity ops from an image CID and optional metadata.
8
+ *
9
+ * @example
10
+ * ```ts
11
+ * import { images } from '@geoprotocol/geo-sdk/ops';
12
+ *
13
+ * const { id, ops } = images.create({
14
+ * cid: 'ipfs://baf...',
15
+ * name: 'Cover image',
16
+ * dimensions: { width: 1200, height: 630 },
17
+ * });
18
+ * ```
19
+ *
20
+ * @param params Uploaded CID, optional dimensions, optional metadata, and optional entity ID.
21
+ * @returns Image entity ID, CID, dimensions, and create ops.
22
+ * @throws When the optional image entity ID is invalid.
23
+ */
24
+ export const create = ({ cid, dimensions, name, description, id: providedId, }) => {
25
+ if (providedId)
26
+ assertValid(providedId, '`id` in `Ops.images.create`');
27
+ const id = providedId ?? generate();
28
+ const values = [
29
+ {
30
+ property: IMAGE_URL_PROPERTY,
31
+ type: 'text',
32
+ value: cid,
33
+ },
34
+ ];
35
+ if (dimensions?.height) {
36
+ values.push({
37
+ property: IMAGE_HEIGHT_PROPERTY,
38
+ type: 'float',
39
+ value: dimensions.height,
40
+ });
41
+ }
42
+ if (dimensions?.width) {
43
+ values.push({
44
+ property: IMAGE_WIDTH_PROPERTY,
45
+ type: 'float',
46
+ value: dimensions.width,
47
+ });
48
+ }
49
+ const result = createEntity({
50
+ id,
51
+ name,
52
+ description,
53
+ values,
54
+ });
55
+ result.ops.push(grcCreateRelation({
56
+ id: toGrcId(generate()),
57
+ entity: toGrcId(generate()),
58
+ from: toGrcId(id),
59
+ to: toGrcId(IMAGE_TYPE),
60
+ relationType: toGrcId(TYPES_PROPERTY),
61
+ }));
62
+ return {
63
+ id: Id(id),
64
+ cid,
65
+ dimensions,
66
+ ops: result.ops,
67
+ };
68
+ };
69
+ //# sourceMappingURL=images.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"images.js","sourceRoot":"","sources":["../../../src/ops/images.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,IAAI,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EACL,qBAAqB,EACrB,UAAU,EACV,kBAAkB,EAClB,oBAAoB,EACpB,cAAc,GACf,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAEhE,OAAO,EAAE,MAAM,IAAI,YAAY,EAAE,MAAM,eAAe,CAAC;AAevD;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,EACrB,GAAG,EACH,UAAU,EACV,IAAI,EACJ,WAAW,EACX,EAAE,EAAE,UAAU,GACO,EAAqB,EAAE;IAC5C,IAAI,UAAU;QAAE,WAAW,CAAC,UAAU,EAAE,6BAA6B,CAAC,CAAC;IAEvE,MAAM,EAAE,GAAG,UAAU,IAAI,QAAQ,EAAE,CAAC;IACpC,MAAM,MAAM,GAAoB;QAC9B;YACE,QAAQ,EAAE,kBAAkB;YAC5B,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,GAAG;SACX;KACF,CAAC;IAEF,IAAI,UAAU,EAAE,MAAM,EAAE,CAAC;QACvB,MAAM,CAAC,IAAI,CAAC;YACV,QAAQ,EAAE,qBAAqB;YAC/B,IAAI,EAAE,OAAO;YACb,KAAK,EAAE,UAAU,CAAC,MAAM;SACzB,CAAC,CAAC;IACL,CAAC;IACD,IAAI,UAAU,EAAE,KAAK,EAAE,CAAC;QACtB,MAAM,CAAC,IAAI,CAAC;YACV,QAAQ,EAAE,oBAAoB;YAC9B,IAAI,EAAE,OAAO;YACb,KAAK,EAAE,UAAU,CAAC,KAAK;SACxB,CAAC,CAAC;IACL,CAAC;IAED,MAAM,MAAM,GAAG,YAAY,CAAC;QAC1B,EAAE;QACF,IAAI;QACJ,WAAW;QACX,MAAM;KACP,CAAC,CAAC;IAEH,MAAM,CAAC,GAAG,CAAC,IAAI,CACb,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,UAAU,CAAC;QACvB,YAAY,EAAE,OAAO,CAAC,cAAc,CAAC;KACtC,CAAC,CACH,CAAC;IAEF,OAAO;QACL,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC;QACV,GAAG;QACH,UAAU;QACV,GAAG,EAAE,MAAM,CAAC,GAAG;KAChB,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ export * as comments from './comments.js';
2
+ export * as entities from './entities.js';
3
+ export * as properties from './properties.js';
4
+ export * as proposalReviews from './proposal-reviews.js';
5
+ export * as relations from './relations.js';
6
+ export * as types from './types.js';
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ops/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAC;AAC1C,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAC;AAC1C,OAAO,KAAK,UAAU,MAAM,iBAAiB,CAAC;AAC9C,OAAO,KAAK,eAAe,MAAM,uBAAuB,CAAC;AACzD,OAAO,KAAK,SAAS,MAAM,gBAAgB,CAAC;AAC5C,OAAO,KAAK,KAAK,MAAM,YAAY,CAAC"}
@@ -0,0 +1,7 @@
1
+ export * as comments from './comments.js';
2
+ export * as entities from './entities.js';
3
+ export * as properties from './properties.js';
4
+ export * as proposalReviews from './proposal-reviews.js';
5
+ export * as relations from './relations.js';
6
+ export * as types from './types.js';
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/ops/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAC;AAC1C,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAC;AAC1C,OAAO,KAAK,UAAU,MAAM,iBAAiB,CAAC;AAC9C,OAAO,KAAK,eAAe,MAAM,uBAAuB,CAAC;AACzD,OAAO,KAAK,SAAS,MAAM,gBAAgB,CAAC;AAC5C,OAAO,KAAK,KAAK,MAAM,YAAY,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../../../src/ops/index.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,115 @@
1
+ import { describe, expect, it } from 'vitest';
2
+ import { DESCRIPTION_PROPERTY, MARKDOWN_CONTENT, NAME_PROPERTY, REPLY_TO_PROPERTY } from '../core/ids/system.js';
3
+ import { createEntity } from '../graph/create-entity.js';
4
+ import { createProperty } from '../graph/create-property.js';
5
+ import { createProposalReview } from '../graph/create-proposal-review.js';
6
+ import { createRelation } from '../graph/create-relation.js';
7
+ import { createType } from '../graph/create-type.js';
8
+ import { deleteRelation } from '../graph/delete-relation.js';
9
+ import { updateComment } from '../graph/update-comment.js';
10
+ import { updateEntity } from '../graph/update-entity.js';
11
+ import { updateProposalReview } from '../graph/update-proposal-review.js';
12
+ import { updateRelation } from '../graph/update-relation.js';
13
+ import { generate, toGrcId } from '../id-utils.js';
14
+ import * as Ops from './index.js';
15
+ describe('Ops', () => {
16
+ const normalizeGeneratedRelationIds = (ops) => ops.map(op => (op.type === 'createRelation' ? { ...op, entity: 'generated', id: 'generated' } : op));
17
+ it('matches Graph entity builders', () => {
18
+ const id = generate();
19
+ const property = generate();
20
+ const params = {
21
+ id,
22
+ name: 'Test entity',
23
+ values: [{ property, type: 'text', value: 'hello' }],
24
+ };
25
+ expect(Ops.entities.create(params)).toEqual(createEntity(params));
26
+ expect(Ops.entities.update({ id, name: 'Updated' })).toEqual(updateEntity({ id, name: 'Updated' }));
27
+ expect('delete' in Ops.entities).toBe(false);
28
+ });
29
+ it('matches Graph schema and relation builders', () => {
30
+ const entityA = generate();
31
+ const entityB = generate();
32
+ const relationId = generate();
33
+ const typeId = generate();
34
+ expect(Ops.types.create({ id: typeId, name: 'Type', properties: [NAME_PROPERTY] }).id).toEqual(createType({ id: typeId, name: 'Type', properties: [NAME_PROPERTY] }).id);
35
+ const propertyParams = { id: generate(), name: 'Website', dataType: 'TEXT' };
36
+ expect(Ops.properties.create(propertyParams).id).toEqual(createProperty(propertyParams).id);
37
+ const createRelationParams = {
38
+ id: relationId,
39
+ fromEntity: entityA,
40
+ toEntity: entityB,
41
+ type: DESCRIPTION_PROPERTY,
42
+ };
43
+ expect(Ops.relations.create(createRelationParams).id).toEqual(createRelation(createRelationParams).id);
44
+ expect(Ops.relations.create(createRelationParams).ops.length).toBe(createRelation(createRelationParams).ops.length);
45
+ expect(Ops.relations.update({ id: relationId, position: 'abc' })).toEqual(updateRelation({ id: relationId, position: 'abc' }));
46
+ expect(Ops.relations.delete({ id: relationId })).toEqual(deleteRelation({ id: relationId }));
47
+ });
48
+ it('creates and updates comment ops', () => {
49
+ const id = generate();
50
+ const root = generate();
51
+ const space = generate();
52
+ const result = Ops.comments.create({
53
+ id,
54
+ content: 'Hello',
55
+ replyTo: { entityId: root, spaceId: space },
56
+ });
57
+ expect(result.id).toBe(id);
58
+ expect(result.ops.length).toBeGreaterThan(0);
59
+ expect(Ops.comments.update({ id, content: 'Updated' })).toEqual(updateComment({ id, content: 'Updated' }));
60
+ expect(Ops.comments.update({ id, content: 'Updated' }).ops[0]).toMatchObject({ type: 'updateEntity' });
61
+ expect(MARKDOWN_CONTENT).toBeTruthy();
62
+ });
63
+ it('creates comment reply chains from supplied context', () => {
64
+ const id = generate();
65
+ const parent = generate();
66
+ const commentA = generate();
67
+ const root = generate();
68
+ const space = generate();
69
+ const rootSpace = generate();
70
+ const result = Ops.comments.create({
71
+ id,
72
+ content: 'Deep reply',
73
+ replyTo: { entityId: parent, spaceId: space },
74
+ replyToRelations: [
75
+ { entityId: root, spaceId: rootSpace, position: 'a1' },
76
+ { entityId: commentA, spaceId: space, position: 'a0' },
77
+ ],
78
+ });
79
+ const replyRels = result.ops.filter((op) => op.type === 'createRelation' &&
80
+ op.relationType.every((byte, index) => byte === toGrcId(REPLY_TO_PROPERTY)[index]));
81
+ expect(replyRels).toHaveLength(3);
82
+ expect(replyRels[0]?.to).toEqual(toGrcId(parent));
83
+ expect(replyRels[1]?.to).toEqual(toGrcId(commentA));
84
+ expect(replyRels[2]?.to).toEqual(toGrcId(root));
85
+ expect(replyRels[0]?.position?.localeCompare(replyRels[1]?.position ?? '')).toBeLessThan(0);
86
+ expect(replyRels[1]?.position?.localeCompare(replyRels[2]?.position ?? '')).toBeLessThan(0);
87
+ });
88
+ it('matches Graph proposal review builders', () => {
89
+ const createParams = {
90
+ id: generate(),
91
+ proposal: { id: generate(), name: 'Test proposal' },
92
+ pass: false,
93
+ content: 'Detailed notes',
94
+ completeness: 0.8,
95
+ accuracy: 1,
96
+ skill: 0.6,
97
+ effort: 0.4,
98
+ };
99
+ const updateParams = {
100
+ proposalReviewId: createParams.id,
101
+ pass: true,
102
+ content: 'Updated notes',
103
+ completeness: 1,
104
+ accuracy: 0.8,
105
+ skill: 0.6,
106
+ effort: 0.4,
107
+ };
108
+ const createdWithOps = Ops.proposalReviews.create(createParams);
109
+ const createdWithGraph = createProposalReview(createParams);
110
+ expect(createdWithOps.id).toBe(createdWithGraph.id);
111
+ expect(normalizeGeneratedRelationIds(createdWithOps.ops)).toEqual(normalizeGeneratedRelationIds(createdWithGraph.ops));
112
+ expect(Ops.proposalReviews.update(updateParams)).toEqual(updateProposalReview(updateParams));
113
+ });
114
+ });
115
+ //# sourceMappingURL=index.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../../src/ops/index.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ import type { CreatePropertyParams, CreateResult } from '../types.js';
2
+ /**
3
+ * Builds create-property ops.
4
+ *
5
+ * @example
6
+ * ```ts
7
+ * import { properties } from '@geoprotocol/geo-sdk/ops';
8
+ *
9
+ * const { id, ops } = properties.create({
10
+ * name: 'Website',
11
+ * dataType: 'TEXT',
12
+ * });
13
+ * ```
14
+ *
15
+ * @param params Property ID, name, data type, and optional relation-property metadata.
16
+ * @returns Generated or supplied property entity ID and create ops.
17
+ * @throws When any supplied ID is invalid.
18
+ */
19
+ export declare const create: (params: CreatePropertyParams) => CreateResult;
20
+ //# sourceMappingURL=properties.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"properties.d.ts","sourceRoot":"","sources":["../../../src/ops/properties.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEtE;;;;;;;;;;;;;;;;GAgBG;AACH,eAAO,MAAM,MAAM,GAAI,QAAQ,oBAAoB,KAAG,YAAsC,CAAC"}
@@ -0,0 +1,20 @@
1
+ import { createProperty } from '../graph/create-property.js';
2
+ /**
3
+ * Builds create-property ops.
4
+ *
5
+ * @example
6
+ * ```ts
7
+ * import { properties } from '@geoprotocol/geo-sdk/ops';
8
+ *
9
+ * const { id, ops } = properties.create({
10
+ * name: 'Website',
11
+ * dataType: 'TEXT',
12
+ * });
13
+ * ```
14
+ *
15
+ * @param params Property ID, name, data type, and optional relation-property metadata.
16
+ * @returns Generated or supplied property entity ID and create ops.
17
+ * @throws When any supplied ID is invalid.
18
+ */
19
+ export const create = (params) => createProperty(params);
20
+ //# sourceMappingURL=properties.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"properties.js","sourceRoot":"","sources":["../../../src/ops/properties.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAG7D;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,MAA4B,EAAgB,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC"}
@@ -0,0 +1,43 @@
1
+ import type { CreateProposalReviewParams, CreateResult, UpdateProposalReviewParams } from '../types.js';
2
+ /**
3
+ * Builds create-proposal-review ops.
4
+ *
5
+ * The review is linked to the proposal through the proposals relation and can
6
+ * include pass/fail, optional markdown content, and optional rating values.
7
+ *
8
+ * @example
9
+ * ```ts
10
+ * import { proposalReviews } from '@geoprotocol/geo-sdk/ops';
11
+ *
12
+ * const { id, ops } = proposalReviews.create({
13
+ * proposal: { id: proposalId, name: 'Improve restaurant data' },
14
+ * pass: true,
15
+ * content: 'The edit is complete and accurate.',
16
+ * });
17
+ * ```
18
+ *
19
+ * @param params Proposal reference, pass/fail value, optional content, optional ratings, and optional review ID.
20
+ * @returns Generated or supplied review entity ID and create ops.
21
+ * @throws When the review ID or proposal ID is invalid.
22
+ */
23
+ export declare const create: (params: CreateProposalReviewParams) => CreateResult;
24
+ /**
25
+ * Builds update-proposal-review ops.
26
+ *
27
+ * @example
28
+ * ```ts
29
+ * import { proposalReviews } from '@geoprotocol/geo-sdk/ops';
30
+ *
31
+ * const { ops } = proposalReviews.update({
32
+ * proposalReviewId: reviewId,
33
+ * pass: false,
34
+ * content: 'Needs more sources.',
35
+ * });
36
+ * ```
37
+ *
38
+ * @param params Review ID, pass/fail value, optional content, and optional rating values.
39
+ * @returns Review entity ID and update ops.
40
+ * @throws When the review ID is invalid.
41
+ */
42
+ export declare const update: (params: UpdateProposalReviewParams) => CreateResult;
43
+ //# sourceMappingURL=proposal-reviews.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"proposal-reviews.d.ts","sourceRoot":"","sources":["../../../src/ops/proposal-reviews.ts"],"names":[],"mappings":"AAYA,OAAO,KAAK,EACV,0BAA0B,EAC1B,YAAY,EAEZ,0BAA0B,EAC3B,MAAM,aAAa,CAAC;AAGrB;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,eAAO,MAAM,MAAM,GAAI,QAAQ,0BAA0B,KAAG,YA2C3D,CAAC;AAEF;;;;;;;;;;;;;;;;;GAiBG;AACH,eAAO,MAAM,MAAM,GAAI,QAAQ,0BAA0B,KAAG,YAgC3D,CAAC"}
@@ -0,0 +1,103 @@
1
+ import { ACCURACY_RATING_PROPERTY, BOUNTY_REVIEW_TYPE, COMPLETENESS_RATING_PROPERTY, EFFORT_RATING_PROPERTY, MARKDOWN_CONTENT, PASS_PROPERTY, PROPOSALS_PROPERTY, SKILL_RATING_PROPERTY, } from '../core/ids/system.js';
2
+ import { Id } from '../id.js';
3
+ import { assertValid, generate } from '../id-utils.js';
4
+ import { create as createEntity, update as updateEntity } from './entities.js';
5
+ /**
6
+ * Builds create-proposal-review ops.
7
+ *
8
+ * The review is linked to the proposal through the proposals relation and can
9
+ * include pass/fail, optional markdown content, and optional rating values.
10
+ *
11
+ * @example
12
+ * ```ts
13
+ * import { proposalReviews } from '@geoprotocol/geo-sdk/ops';
14
+ *
15
+ * const { id, ops } = proposalReviews.create({
16
+ * proposal: { id: proposalId, name: 'Improve restaurant data' },
17
+ * pass: true,
18
+ * content: 'The edit is complete and accurate.',
19
+ * });
20
+ * ```
21
+ *
22
+ * @param params Proposal reference, pass/fail value, optional content, optional ratings, and optional review ID.
23
+ * @returns Generated or supplied review entity ID and create ops.
24
+ * @throws When the review ID or proposal ID is invalid.
25
+ */
26
+ export const create = (params) => {
27
+ if (params.id)
28
+ assertValid(params.id, '`id` in `Ops.proposalReviews.create`');
29
+ assertValid(params.proposal.id, '`proposal.id` in `Ops.proposalReviews.create`');
30
+ const id = params.id ?? generate();
31
+ const values = [
32
+ {
33
+ property: PASS_PROPERTY,
34
+ type: 'boolean',
35
+ value: params.pass,
36
+ },
37
+ ];
38
+ if (params.content) {
39
+ values.push({
40
+ property: MARKDOWN_CONTENT,
41
+ type: 'text',
42
+ value: params.content,
43
+ });
44
+ }
45
+ if ('completeness' in params) {
46
+ values.push({ property: COMPLETENESS_RATING_PROPERTY, type: 'float', value: params.completeness }, { property: ACCURACY_RATING_PROPERTY, type: 'float', value: params.accuracy }, { property: SKILL_RATING_PROPERTY, type: 'float', value: params.skill }, { property: EFFORT_RATING_PROPERTY, type: 'float', value: params.effort });
47
+ }
48
+ const { ops } = createEntity({
49
+ id,
50
+ name: params.proposal.name,
51
+ types: [BOUNTY_REVIEW_TYPE],
52
+ values,
53
+ relations: {
54
+ [PROPOSALS_PROPERTY]: {
55
+ toEntity: params.proposal.id,
56
+ },
57
+ },
58
+ });
59
+ return { id: Id(id), ops };
60
+ };
61
+ /**
62
+ * Builds update-proposal-review ops.
63
+ *
64
+ * @example
65
+ * ```ts
66
+ * import { proposalReviews } from '@geoprotocol/geo-sdk/ops';
67
+ *
68
+ * const { ops } = proposalReviews.update({
69
+ * proposalReviewId: reviewId,
70
+ * pass: false,
71
+ * content: 'Needs more sources.',
72
+ * });
73
+ * ```
74
+ *
75
+ * @param params Review ID, pass/fail value, optional content, and optional rating values.
76
+ * @returns Review entity ID and update ops.
77
+ * @throws When the review ID is invalid.
78
+ */
79
+ export const update = (params) => {
80
+ assertValid(params.proposalReviewId, '`proposalReviewId` in `Ops.proposalReviews.update`');
81
+ const values = [
82
+ {
83
+ property: PASS_PROPERTY,
84
+ type: 'boolean',
85
+ value: params.pass,
86
+ },
87
+ ];
88
+ if (params.content) {
89
+ values.push({
90
+ property: MARKDOWN_CONTENT,
91
+ type: 'text',
92
+ value: params.content,
93
+ });
94
+ }
95
+ if ('completeness' in params) {
96
+ values.push({ property: COMPLETENESS_RATING_PROPERTY, type: 'float', value: params.completeness }, { property: ACCURACY_RATING_PROPERTY, type: 'float', value: params.accuracy }, { property: SKILL_RATING_PROPERTY, type: 'float', value: params.skill }, { property: EFFORT_RATING_PROPERTY, type: 'float', value: params.effort });
97
+ }
98
+ return updateEntity({
99
+ id: params.proposalReviewId,
100
+ values,
101
+ });
102
+ };
103
+ //# sourceMappingURL=proposal-reviews.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"proposal-reviews.js","sourceRoot":"","sources":["../../../src/ops/proposal-reviews.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,wBAAwB,EACxB,kBAAkB,EAClB,4BAA4B,EAC5B,sBAAsB,EACtB,gBAAgB,EAChB,aAAa,EACb,kBAAkB,EAClB,qBAAqB,GACtB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAOvD,OAAO,EAAE,MAAM,IAAI,YAAY,EAAE,MAAM,IAAI,YAAY,EAAE,MAAM,eAAe,CAAC;AAE/E;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,MAAkC,EAAgB,EAAE;IACzE,IAAI,MAAM,CAAC,EAAE;QAAE,WAAW,CAAC,MAAM,CAAC,EAAE,EAAE,sCAAsC,CAAC,CAAC;IAC9E,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,EAAE,+CAA+C,CAAC,CAAC;IAEjF,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,IAAI,QAAQ,EAAE,CAAC;IACnC,MAAM,MAAM,GAAoB;QAC9B;YACE,QAAQ,EAAE,aAAa;YACvB,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,MAAM,CAAC,IAAI;SACnB;KACF,CAAC;IAEF,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;QACnB,MAAM,CAAC,IAAI,CAAC;YACV,QAAQ,EAAE,gBAAgB;YAC1B,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,MAAM,CAAC,OAAO;SACtB,CAAC,CAAC;IACL,CAAC;IAED,IAAI,cAAc,IAAI,MAAM,EAAE,CAAC;QAC7B,MAAM,CAAC,IAAI,CACT,EAAE,QAAQ,EAAE,4BAA4B,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,YAAY,EAAE,EACrF,EAAE,QAAQ,EAAE,wBAAwB,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,QAAQ,EAAE,EAC7E,EAAE,QAAQ,EAAE,qBAAqB,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACvE,EAAE,QAAQ,EAAE,sBAAsB,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,CAC1E,CAAC;IACJ,CAAC;IAED,MAAM,EAAE,GAAG,EAAE,GAAG,YAAY,CAAC;QAC3B,EAAE;QACF,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI;QAC1B,KAAK,EAAE,CAAC,kBAAkB,CAAC;QAC3B,MAAM;QACN,SAAS,EAAE;YACT,CAAC,kBAAkB,CAAC,EAAE;gBACpB,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC,EAAE;aAC7B;SACF;KACF,CAAC,CAAC;IAEH,OAAO,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC;AAC7B,CAAC,CAAC;AAEF;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,MAAkC,EAAgB,EAAE;IACzE,WAAW,CAAC,MAAM,CAAC,gBAAgB,EAAE,oDAAoD,CAAC,CAAC;IAE3F,MAAM,MAAM,GAAoB;QAC9B;YACE,QAAQ,EAAE,aAAa;YACvB,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,MAAM,CAAC,IAAI;SACnB;KACF,CAAC;IAEF,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;QACnB,MAAM,CAAC,IAAI,CAAC;YACV,QAAQ,EAAE,gBAAgB;YAC1B,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,MAAM,CAAC,OAAO;SACtB,CAAC,CAAC;IACL,CAAC;IAED,IAAI,cAAc,IAAI,MAAM,EAAE,CAAC;QAC7B,MAAM,CAAC,IAAI,CACT,EAAE,QAAQ,EAAE,4BAA4B,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,YAAY,EAAE,EACrF,EAAE,QAAQ,EAAE,wBAAwB,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,QAAQ,EAAE,EAC7E,EAAE,QAAQ,EAAE,qBAAqB,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACvE,EAAE,QAAQ,EAAE,sBAAsB,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,CAC1E,CAAC;IACJ,CAAC;IAED,OAAO,YAAY,CAAC;QAClB,EAAE,EAAE,MAAM,CAAC,gBAAgB;QAC3B,MAAM;KACP,CAAC,CAAC;AACL,CAAC,CAAC"}
@@ -0,0 +1,57 @@
1
+ import type { CreateResult, DeleteRelationParams, RelationParams, UpdateRelationParams } from '../types.js';
2
+ /**
3
+ * Builds create-relation ops.
4
+ *
5
+ * @example
6
+ * ```ts
7
+ * import { relations } from '@geoprotocol/geo-sdk/ops';
8
+ *
9
+ * const { id, ops } = relations.create({
10
+ * fromEntity: restaurantId,
11
+ * toEntity: personId,
12
+ * type: likesPropertyId,
13
+ * position: 'a0',
14
+ * });
15
+ * ```
16
+ *
17
+ * @param params Relation endpoints, relation type, optional relation ID, and optional relation entity fields.
18
+ * @returns Generated or supplied relation entity ID and create ops.
19
+ * @throws When any supplied ID is invalid.
20
+ */
21
+ export declare const create: (params: RelationParams) => CreateResult;
22
+ /**
23
+ * Builds update-relation ops.
24
+ *
25
+ * @example
26
+ * ```ts
27
+ * import { relations } from '@geoprotocol/geo-sdk/ops';
28
+ *
29
+ * const { ops } = relations.update({
30
+ * id: relationId,
31
+ * position: 'a1',
32
+ * });
33
+ * ```
34
+ *
35
+ * @param params Relation ID plus fields to update.
36
+ * @returns Relation ID and update ops.
37
+ * @throws When any supplied ID is invalid.
38
+ */
39
+ export declare const update: (params: UpdateRelationParams) => CreateResult;
40
+ /**
41
+ * Builds delete-relation ops.
42
+ *
43
+ * @example
44
+ * ```ts
45
+ * import { relations } from '@geoprotocol/geo-sdk/ops';
46
+ *
47
+ * const { ops } = relations.delete({ id: relationId });
48
+ * ```
49
+ *
50
+ * @param params Relation ID to delete.
51
+ * @returns Relation ID and delete ops.
52
+ * @throws When the relation ID is invalid.
53
+ */
54
+ export declare const deleteRelationOps: (params: DeleteRelationParams) => CreateResult;
55
+ /** Alias for {@link deleteRelationOps}. */
56
+ export { deleteRelationOps as delete };
57
+ //# sourceMappingURL=relations.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"relations.d.ts","sourceRoot":"","sources":["../../../src/ops/relations.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,oBAAoB,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAE5G;;;;;;;;;;;;;;;;;;GAkBG;AACH,eAAO,MAAM,MAAM,GAAI,QAAQ,cAAc,KAAG,YAAsC,CAAC;AAEvF;;;;;;;;;;;;;;;;GAgBG;AACH,eAAO,MAAM,MAAM,GAAI,QAAQ,oBAAoB,KAAG,YAAsC,CAAC;AAE7F;;;;;;;;;;;;;GAaG;AACH,eAAO,MAAM,iBAAiB,GAAI,QAAQ,oBAAoB,KAAG,YAAsC,CAAC;AAExG,2CAA2C;AAC3C,OAAO,EAAE,iBAAiB,IAAI,MAAM,EAAE,CAAC"}