@dxos/echo 0.8.4-main.66e292d → 0.8.4-main.69d29f4

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 (459) hide show
  1. package/README.md +1 -2
  2. package/dist/lib/browser/Annotation.mjs +33 -0
  3. package/dist/lib/browser/Annotation.mjs.map +7 -0
  4. package/dist/lib/browser/Database.mjs +18 -0
  5. package/dist/lib/browser/Database.mjs.map +7 -0
  6. package/dist/lib/browser/Entity.mjs +52 -0
  7. package/dist/lib/browser/Entity.mjs.map +7 -0
  8. package/dist/lib/browser/Err.mjs +11 -0
  9. package/dist/lib/browser/Err.mjs.map +7 -0
  10. package/dist/lib/browser/Filter.mjs +62 -0
  11. package/dist/lib/browser/Filter.mjs.map +7 -0
  12. package/dist/lib/browser/Format.mjs +67 -0
  13. package/dist/lib/browser/Format.mjs.map +7 -0
  14. package/dist/lib/browser/JsonSchema.mjs +20 -0
  15. package/dist/lib/browser/JsonSchema.mjs.map +7 -0
  16. package/dist/lib/browser/Key.mjs +13 -0
  17. package/dist/lib/browser/Key.mjs.map +7 -0
  18. package/dist/lib/browser/Obj.mjs +91 -0
  19. package/dist/lib/browser/Obj.mjs.map +7 -0
  20. package/dist/lib/browser/Order.mjs +13 -0
  21. package/dist/lib/browser/Order.mjs.map +7 -0
  22. package/dist/lib/browser/Query.mjs +27 -0
  23. package/dist/lib/browser/Query.mjs.map +7 -0
  24. package/dist/lib/browser/QueryResult.mjs +3 -0
  25. package/dist/lib/browser/QueryResult.mjs.map +7 -0
  26. package/dist/lib/browser/Ref.mjs +23 -0
  27. package/dist/lib/browser/Ref.mjs.map +7 -0
  28. package/dist/lib/browser/Relation.mjs +85 -0
  29. package/dist/lib/browser/Relation.mjs.map +7 -0
  30. package/dist/lib/browser/SchemaRegistry.mjs +3 -0
  31. package/dist/lib/browser/SchemaRegistry.mjs.map +7 -0
  32. package/dist/lib/browser/Tag.mjs +26 -0
  33. package/dist/lib/browser/Tag.mjs.map +7 -0
  34. package/dist/lib/browser/Type.mjs +48 -0
  35. package/dist/lib/browser/Type.mjs.map +7 -0
  36. package/dist/lib/browser/chunk-2RMVRVOB.mjs +250 -0
  37. package/dist/lib/browser/chunk-2RMVRVOB.mjs.map +7 -0
  38. package/dist/lib/browser/chunk-5RDNDPMX.mjs +74 -0
  39. package/dist/lib/browser/chunk-5RDNDPMX.mjs.map +7 -0
  40. package/dist/lib/browser/chunk-73M2G455.mjs +98 -0
  41. package/dist/lib/browser/chunk-73M2G455.mjs.map +7 -0
  42. package/dist/lib/browser/chunk-7STIBCP7.mjs +133 -0
  43. package/dist/lib/browser/chunk-7STIBCP7.mjs.map +7 -0
  44. package/dist/lib/browser/chunk-AFGYYVVQ.mjs +57 -0
  45. package/dist/lib/browser/chunk-AFGYYVVQ.mjs.map +7 -0
  46. package/dist/lib/browser/chunk-BC6R4CAF.mjs +24 -0
  47. package/dist/lib/browser/chunk-BC6R4CAF.mjs.map +7 -0
  48. package/dist/lib/browser/chunk-BPYFLHWO.mjs +158 -0
  49. package/dist/lib/browser/chunk-BPYFLHWO.mjs.map +7 -0
  50. package/dist/lib/browser/chunk-CBPFF3ZO.mjs +204 -0
  51. package/dist/lib/browser/chunk-CBPFF3ZO.mjs.map +7 -0
  52. package/dist/lib/browser/chunk-CGS2ULMK.mjs +11 -0
  53. package/dist/lib/browser/chunk-CGS2ULMK.mjs.map +7 -0
  54. package/dist/lib/browser/chunk-CJ5YELTO.mjs +39 -0
  55. package/dist/lib/browser/chunk-CJ5YELTO.mjs.map +7 -0
  56. package/dist/lib/browser/chunk-FPOISFQK.mjs +40 -0
  57. package/dist/lib/browser/chunk-FPOISFQK.mjs.map +7 -0
  58. package/dist/lib/browser/chunk-INHXFXY5.mjs +22 -0
  59. package/dist/lib/browser/chunk-INHXFXY5.mjs.map +7 -0
  60. package/dist/lib/browser/chunk-IXVWLTG7.mjs +9 -0
  61. package/dist/lib/browser/chunk-IXVWLTG7.mjs.map +7 -0
  62. package/dist/lib/browser/chunk-JMKVF2YQ.mjs +43 -0
  63. package/dist/lib/browser/chunk-JMKVF2YQ.mjs.map +7 -0
  64. package/dist/lib/browser/chunk-L4RXUJHJ.mjs +143 -0
  65. package/dist/lib/browser/chunk-L4RXUJHJ.mjs.map +7 -0
  66. package/dist/lib/browser/chunk-MYCCGG2T.mjs +15 -0
  67. package/dist/lib/browser/chunk-MYCCGG2T.mjs.map +7 -0
  68. package/dist/lib/browser/{chunk-7GH6RXJ3.mjs → chunk-PAM4KEXE.mjs} +2005 -1841
  69. package/dist/lib/browser/chunk-PAM4KEXE.mjs.map +7 -0
  70. package/dist/lib/browser/chunk-QIWDIPLR.mjs +41 -0
  71. package/dist/lib/browser/chunk-QIWDIPLR.mjs.map +7 -0
  72. package/dist/lib/browser/chunk-R3S54KRI.mjs +403 -0
  73. package/dist/lib/browser/chunk-R3S54KRI.mjs.map +7 -0
  74. package/dist/lib/browser/chunk-RK4Z4JUZ.mjs +283 -0
  75. package/dist/lib/browser/chunk-RK4Z4JUZ.mjs.map +7 -0
  76. package/dist/lib/browser/chunk-TPIL3G6Y.mjs +288 -0
  77. package/dist/lib/browser/chunk-TPIL3G6Y.mjs.map +7 -0
  78. package/dist/lib/browser/chunk-YKTSSMDS.mjs +69 -0
  79. package/dist/lib/browser/chunk-YKTSSMDS.mjs.map +7 -0
  80. package/dist/lib/browser/chunk-ZHXZGIXD.mjs +9 -0
  81. package/dist/lib/browser/chunk-ZHXZGIXD.mjs.map +7 -0
  82. package/dist/lib/browser/index.mjs +65 -25
  83. package/dist/lib/browser/internal/index.mjs +213 -92
  84. package/dist/lib/browser/meta.json +1 -1
  85. package/dist/lib/browser/testing/index.mjs +80 -41
  86. package/dist/lib/browser/testing/index.mjs.map +3 -3
  87. package/dist/lib/node-esm/Annotation.mjs +33 -0
  88. package/dist/lib/node-esm/Annotation.mjs.map +7 -0
  89. package/dist/lib/node-esm/Database.mjs +18 -0
  90. package/dist/lib/node-esm/Database.mjs.map +7 -0
  91. package/dist/lib/node-esm/Entity.mjs +52 -0
  92. package/dist/lib/node-esm/Entity.mjs.map +7 -0
  93. package/dist/lib/node-esm/Err.mjs +11 -0
  94. package/dist/lib/node-esm/Err.mjs.map +7 -0
  95. package/dist/lib/node-esm/Filter.mjs +62 -0
  96. package/dist/lib/node-esm/Filter.mjs.map +7 -0
  97. package/dist/lib/node-esm/Format.mjs +67 -0
  98. package/dist/lib/node-esm/Format.mjs.map +7 -0
  99. package/dist/lib/node-esm/JsonSchema.mjs +20 -0
  100. package/dist/lib/node-esm/JsonSchema.mjs.map +7 -0
  101. package/dist/lib/node-esm/Key.mjs +13 -0
  102. package/dist/lib/node-esm/Key.mjs.map +7 -0
  103. package/dist/lib/node-esm/Obj.mjs +91 -0
  104. package/dist/lib/node-esm/Obj.mjs.map +7 -0
  105. package/dist/lib/node-esm/Order.mjs +13 -0
  106. package/dist/lib/node-esm/Order.mjs.map +7 -0
  107. package/dist/lib/node-esm/Query.mjs +27 -0
  108. package/dist/lib/node-esm/Query.mjs.map +7 -0
  109. package/dist/lib/node-esm/QueryResult.mjs +3 -0
  110. package/dist/lib/node-esm/QueryResult.mjs.map +7 -0
  111. package/dist/lib/node-esm/Ref.mjs +23 -0
  112. package/dist/lib/node-esm/Ref.mjs.map +7 -0
  113. package/dist/lib/node-esm/Relation.mjs +85 -0
  114. package/dist/lib/node-esm/Relation.mjs.map +7 -0
  115. package/dist/lib/node-esm/SchemaRegistry.mjs +3 -0
  116. package/dist/lib/node-esm/SchemaRegistry.mjs.map +7 -0
  117. package/dist/lib/node-esm/Tag.mjs +26 -0
  118. package/dist/lib/node-esm/Tag.mjs.map +7 -0
  119. package/dist/lib/node-esm/Type.mjs +48 -0
  120. package/dist/lib/node-esm/Type.mjs.map +7 -0
  121. package/dist/lib/node-esm/chunk-2RIFBW3A.mjs +250 -0
  122. package/dist/lib/node-esm/chunk-2RIFBW3A.mjs.map +7 -0
  123. package/dist/lib/node-esm/chunk-5CB2ZW74.mjs +57 -0
  124. package/dist/lib/node-esm/chunk-5CB2ZW74.mjs.map +7 -0
  125. package/dist/lib/node-esm/{chunk-M4B6BMD2.mjs → chunk-5U5F4AWK.mjs} +2005 -1841
  126. package/dist/lib/node-esm/chunk-5U5F4AWK.mjs.map +7 -0
  127. package/dist/lib/node-esm/chunk-AJEMYSIR.mjs +22 -0
  128. package/dist/lib/node-esm/chunk-AJEMYSIR.mjs.map +7 -0
  129. package/dist/lib/node-esm/chunk-BKYE5IW6.mjs +158 -0
  130. package/dist/lib/node-esm/chunk-BKYE5IW6.mjs.map +7 -0
  131. package/dist/lib/node-esm/chunk-BYOD7EVP.mjs +98 -0
  132. package/dist/lib/node-esm/chunk-BYOD7EVP.mjs.map +7 -0
  133. package/dist/lib/node-esm/chunk-FWTSPIFF.mjs +133 -0
  134. package/dist/lib/node-esm/chunk-FWTSPIFF.mjs.map +7 -0
  135. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  136. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  137. package/dist/lib/node-esm/chunk-K37NA7PO.mjs +43 -0
  138. package/dist/lib/node-esm/chunk-K37NA7PO.mjs.map +7 -0
  139. package/dist/lib/node-esm/chunk-LIXUCQJM.mjs +41 -0
  140. package/dist/lib/node-esm/chunk-LIXUCQJM.mjs.map +7 -0
  141. package/dist/lib/node-esm/chunk-MOLNWFNL.mjs +9 -0
  142. package/dist/lib/node-esm/chunk-MOLNWFNL.mjs.map +7 -0
  143. package/dist/lib/node-esm/chunk-MOWUEW5P.mjs +15 -0
  144. package/dist/lib/node-esm/chunk-MOWUEW5P.mjs.map +7 -0
  145. package/dist/lib/node-esm/chunk-NBWL7UCZ.mjs +40 -0
  146. package/dist/lib/node-esm/chunk-NBWL7UCZ.mjs.map +7 -0
  147. package/dist/lib/node-esm/chunk-OZEDKT4R.mjs +204 -0
  148. package/dist/lib/node-esm/chunk-OZEDKT4R.mjs.map +7 -0
  149. package/dist/lib/node-esm/chunk-PW3VCWL5.mjs +24 -0
  150. package/dist/lib/node-esm/chunk-PW3VCWL5.mjs.map +7 -0
  151. package/dist/lib/node-esm/chunk-TSTKBFST.mjs +403 -0
  152. package/dist/lib/node-esm/chunk-TSTKBFST.mjs.map +7 -0
  153. package/dist/lib/node-esm/chunk-UKGVOINP.mjs +9 -0
  154. package/dist/lib/node-esm/chunk-UKGVOINP.mjs.map +7 -0
  155. package/dist/lib/node-esm/chunk-UV63HEHQ.mjs +143 -0
  156. package/dist/lib/node-esm/chunk-UV63HEHQ.mjs.map +7 -0
  157. package/dist/lib/node-esm/chunk-WXLVPCRJ.mjs +288 -0
  158. package/dist/lib/node-esm/chunk-WXLVPCRJ.mjs.map +7 -0
  159. package/dist/lib/node-esm/chunk-WZ6YBELW.mjs +74 -0
  160. package/dist/lib/node-esm/chunk-WZ6YBELW.mjs.map +7 -0
  161. package/dist/lib/node-esm/chunk-XHJRMQZD.mjs +69 -0
  162. package/dist/lib/node-esm/chunk-XHJRMQZD.mjs.map +7 -0
  163. package/dist/lib/node-esm/chunk-YOLH5KS4.mjs +283 -0
  164. package/dist/lib/node-esm/chunk-YOLH5KS4.mjs.map +7 -0
  165. package/dist/lib/node-esm/chunk-YQ2NWGL5.mjs +39 -0
  166. package/dist/lib/node-esm/chunk-YQ2NWGL5.mjs.map +7 -0
  167. package/dist/lib/node-esm/index.mjs +65 -25
  168. package/dist/lib/node-esm/internal/index.mjs +213 -92
  169. package/dist/lib/node-esm/meta.json +1 -1
  170. package/dist/lib/node-esm/testing/index.mjs +80 -41
  171. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  172. package/dist/types/src/Annotation.d.ts +1 -1
  173. package/dist/types/src/Annotation.d.ts.map +1 -1
  174. package/dist/types/src/Database.d.ts +117 -60
  175. package/dist/types/src/Database.d.ts.map +1 -1
  176. package/dist/types/src/Entity.d.ts +111 -5
  177. package/dist/types/src/Entity.d.ts.map +1 -1
  178. package/dist/types/src/Entity.test.d.ts +2 -0
  179. package/dist/types/src/Entity.test.d.ts.map +1 -0
  180. package/dist/types/src/{errors.d.ts → Err.d.ts} +13 -17
  181. package/dist/types/src/Err.d.ts.map +1 -0
  182. package/dist/types/src/Filter.d.ts +120 -0
  183. package/dist/types/src/Filter.d.ts.map +1 -0
  184. package/dist/types/src/Format.d.ts.map +1 -1
  185. package/dist/types/src/Hypergraph.d.ts +60 -0
  186. package/dist/types/src/Hypergraph.d.ts.map +1 -0
  187. package/dist/types/src/Obj.d.ts +268 -76
  188. package/dist/types/src/Obj.d.ts.map +1 -1
  189. package/dist/types/src/Obj.test.d.ts +2 -0
  190. package/dist/types/src/Obj.test.d.ts.map +1 -0
  191. package/dist/types/src/Order.d.ts +16 -0
  192. package/dist/types/src/Order.d.ts.map +1 -0
  193. package/dist/types/src/{query/query.d.ts → Query.d.ts} +53 -50
  194. package/dist/types/src/Query.d.ts.map +1 -0
  195. package/dist/types/src/Query.test.d.ts +2 -0
  196. package/dist/types/src/Query.test.d.ts.map +1 -0
  197. package/dist/types/src/QueryResult.d.ts +80 -0
  198. package/dist/types/src/QueryResult.d.ts.map +1 -0
  199. package/dist/types/src/Ref.d.ts +9 -7
  200. package/dist/types/src/Ref.d.ts.map +1 -1
  201. package/dist/types/src/Relation.d.ts +235 -18
  202. package/dist/types/src/Relation.d.ts.map +1 -1
  203. package/dist/types/src/Relation.test.d.ts +2 -0
  204. package/dist/types/src/Relation.test.d.ts.map +1 -0
  205. package/dist/types/src/SchemaRegistry.d.ts +84 -0
  206. package/dist/types/src/SchemaRegistry.d.ts.map +1 -0
  207. package/dist/types/src/Tag.d.ts +6 -6
  208. package/dist/types/src/Tag.d.ts.map +1 -1
  209. package/dist/types/src/Type.d.ts +213 -50
  210. package/dist/types/src/Type.d.ts.map +1 -1
  211. package/dist/types/src/Type.test.d.ts +2 -0
  212. package/dist/types/src/Type.test.d.ts.map +1 -0
  213. package/dist/types/src/index.d.ts +8 -2
  214. package/dist/types/src/index.d.ts.map +1 -1
  215. package/dist/types/src/internal/annotations/annotations.d.ts +23 -27
  216. package/dist/types/src/internal/annotations/annotations.d.ts.map +1 -1
  217. package/dist/types/src/internal/annotations/util.d.ts +1 -0
  218. package/dist/types/src/internal/annotations/util.d.ts.map +1 -1
  219. package/dist/types/src/internal/api/annotations.d.ts +23 -0
  220. package/dist/types/src/internal/api/annotations.d.ts.map +1 -0
  221. package/dist/types/src/internal/api/entity.d.ts +13 -0
  222. package/dist/types/src/internal/api/entity.d.ts.map +1 -0
  223. package/dist/types/src/internal/api/index.d.ts +15 -0
  224. package/dist/types/src/internal/api/index.d.ts.map +1 -0
  225. package/dist/types/src/internal/api/meta.d.ts +42 -0
  226. package/dist/types/src/internal/api/meta.d.ts.map +1 -0
  227. package/dist/types/src/internal/api/sorting.d.ts +24 -0
  228. package/dist/types/src/internal/api/sorting.d.ts.map +1 -0
  229. package/dist/types/src/internal/api/version.d.ts +42 -0
  230. package/dist/types/src/internal/api/version.d.ts.map +1 -0
  231. package/dist/types/src/internal/entities/entity.d.ts +13 -3
  232. package/dist/types/src/internal/entities/entity.d.ts.map +1 -1
  233. package/dist/types/src/internal/entities/index.d.ts +1 -1
  234. package/dist/types/src/internal/entities/index.d.ts.map +1 -1
  235. package/dist/types/src/internal/entities/model.d.ts +14 -7
  236. package/dist/types/src/internal/entities/model.d.ts.map +1 -1
  237. package/dist/types/src/internal/entities/object.d.ts +8 -1
  238. package/dist/types/src/internal/entities/object.d.ts.map +1 -1
  239. package/dist/types/src/internal/entities/relation.d.ts +8 -1
  240. package/dist/types/src/internal/entities/relation.d.ts.map +1 -1
  241. package/dist/types/src/internal/formats/format.d.ts +4 -4
  242. package/dist/types/src/internal/formats/format.d.ts.map +1 -1
  243. package/dist/types/src/internal/formats/select.d.ts +6 -4
  244. package/dist/types/src/internal/formats/select.d.ts.map +1 -1
  245. package/dist/types/src/internal/formats/string.d.ts +4 -0
  246. package/dist/types/src/internal/formats/string.d.ts.map +1 -1
  247. package/dist/types/src/internal/formats/types.d.ts +6 -2
  248. package/dist/types/src/internal/formats/types.d.ts.map +1 -1
  249. package/dist/types/src/internal/index.d.ts +2 -1
  250. package/dist/types/src/internal/index.d.ts.map +1 -1
  251. package/dist/types/src/internal/json-schema/json-schema-normalize.d.ts.map +1 -1
  252. package/dist/types/src/internal/json-schema/json-schema-type.d.ts +130 -29
  253. package/dist/types/src/internal/json-schema/json-schema-type.d.ts.map +1 -1
  254. package/dist/types/src/internal/json-schema/json-schema.d.ts +2 -1
  255. package/dist/types/src/internal/json-schema/json-schema.d.ts.map +1 -1
  256. package/dist/types/src/internal/object/clone.d.ts +8 -0
  257. package/dist/types/src/internal/object/clone.d.ts.map +1 -0
  258. package/dist/types/src/internal/object/create-object.d.ts +1 -1
  259. package/dist/types/src/internal/object/index.d.ts +3 -0
  260. package/dist/types/src/internal/object/index.d.ts.map +1 -1
  261. package/dist/types/src/internal/object/json-serializer.d.ts +13 -7
  262. package/dist/types/src/internal/object/json-serializer.d.ts.map +1 -1
  263. package/dist/types/src/internal/object/schema-validator.d.ts +1 -14
  264. package/dist/types/src/internal/object/schema-validator.d.ts.map +1 -1
  265. package/dist/types/src/internal/object/set-value.d.ts +7 -0
  266. package/dist/types/src/internal/object/set-value.d.ts.map +1 -0
  267. package/dist/types/src/internal/object/set-value.test.d.ts +2 -0
  268. package/dist/types/src/internal/object/set-value.test.d.ts.map +1 -0
  269. package/dist/types/src/internal/object/snapshot.d.ts +6 -0
  270. package/dist/types/src/internal/object/snapshot.d.ts.map +1 -0
  271. package/dist/types/src/internal/object/typed-object.d.ts +7 -13
  272. package/dist/types/src/internal/object/typed-object.d.ts.map +1 -1
  273. package/dist/types/src/internal/proxy/change-context.d.ts +55 -0
  274. package/dist/types/src/internal/proxy/change-context.d.ts.map +1 -0
  275. package/dist/types/src/internal/proxy/change.test.d.ts +2 -0
  276. package/dist/types/src/internal/proxy/change.test.d.ts.map +1 -0
  277. package/dist/types/src/internal/proxy/define-hidden-property.d.ts +5 -0
  278. package/dist/types/src/internal/proxy/define-hidden-property.d.ts.map +1 -0
  279. package/dist/types/src/internal/proxy/errors.d.ts +19 -0
  280. package/dist/types/src/internal/proxy/errors.d.ts.map +1 -0
  281. package/dist/types/src/internal/proxy/event-batch.d.ts +10 -0
  282. package/dist/types/src/internal/proxy/event-batch.d.ts.map +1 -0
  283. package/dist/types/src/internal/proxy/index.d.ts +11 -0
  284. package/dist/types/src/internal/proxy/index.d.ts.map +1 -1
  285. package/dist/types/src/internal/proxy/json-serializer.d.ts +6 -0
  286. package/dist/types/src/internal/proxy/json-serializer.d.ts.map +1 -0
  287. package/dist/types/src/internal/proxy/make-object.d.ts +2 -4
  288. package/dist/types/src/internal/proxy/make-object.d.ts.map +1 -1
  289. package/dist/types/src/internal/proxy/ownership.d.ts +57 -0
  290. package/dist/types/src/internal/proxy/ownership.d.ts.map +1 -0
  291. package/dist/types/src/internal/proxy/proxy-types.d.ts +18 -0
  292. package/dist/types/src/internal/proxy/proxy-types.d.ts.map +1 -0
  293. package/dist/types/src/internal/proxy/proxy-utils.d.ts +47 -0
  294. package/dist/types/src/internal/proxy/proxy-utils.d.ts.map +1 -0
  295. package/dist/types/src/internal/proxy/reactive-array.d.ts +8 -0
  296. package/dist/types/src/internal/proxy/reactive-array.d.ts.map +1 -0
  297. package/dist/types/src/internal/proxy/reactive.d.ts +39 -0
  298. package/dist/types/src/internal/proxy/reactive.d.ts.map +1 -0
  299. package/dist/types/src/internal/proxy/schema-validator.d.ts +15 -0
  300. package/dist/types/src/internal/proxy/schema-validator.d.ts.map +1 -0
  301. package/dist/types/src/internal/proxy/symbols.d.ts +3 -0
  302. package/dist/types/src/internal/proxy/symbols.d.ts.map +1 -0
  303. package/dist/types/src/internal/proxy/typed-handler.d.ts +14 -11
  304. package/dist/types/src/internal/proxy/typed-handler.d.ts.map +1 -1
  305. package/dist/types/src/internal/ref/ref-array.d.ts +4 -4
  306. package/dist/types/src/internal/ref/ref-array.d.ts.map +1 -1
  307. package/dist/types/src/internal/ref/ref.d.ts +16 -7
  308. package/dist/types/src/internal/ref/ref.d.ts.map +1 -1
  309. package/dist/types/src/internal/schema/compose.d.ts +2 -1
  310. package/dist/types/src/internal/schema/compose.d.ts.map +1 -1
  311. package/dist/types/src/internal/schema/echo-schema.d.ts +15 -3
  312. package/dist/types/src/internal/schema/echo-schema.d.ts.map +1 -1
  313. package/dist/types/src/internal/schema/index.d.ts +0 -2
  314. package/dist/types/src/internal/schema/index.d.ts.map +1 -1
  315. package/dist/types/src/internal/schema/persistent-schema.d.ts +9 -7
  316. package/dist/types/src/internal/schema/persistent-schema.d.ts.map +1 -1
  317. package/dist/types/src/internal/types/base.d.ts +5 -16
  318. package/dist/types/src/internal/types/base.d.ts.map +1 -1
  319. package/dist/types/src/internal/types/entity.d.ts +27 -2
  320. package/dist/types/src/internal/types/entity.d.ts.map +1 -1
  321. package/dist/types/src/internal/types/meta.d.ts +6 -14
  322. package/dist/types/src/internal/types/meta.d.ts.map +1 -1
  323. package/dist/types/src/testing/test-schema.d.ts +141 -175
  324. package/dist/types/src/testing/test-schema.d.ts.map +1 -1
  325. package/dist/types/src/testing/util.d.ts +6 -1
  326. package/dist/types/src/testing/util.d.ts.map +1 -1
  327. package/dist/types/tsconfig.tsbuildinfo +1 -1
  328. package/package.json +130 -23
  329. package/src/Annotation.ts +5 -4
  330. package/src/Database.ts +229 -82
  331. package/src/Entity.test.ts +22 -0
  332. package/src/Entity.ts +173 -7
  333. package/src/{errors.ts → Err.ts} +2 -2
  334. package/src/Filter.ts +376 -0
  335. package/src/Format.ts +0 -2
  336. package/src/Hypergraph.ts +74 -0
  337. package/src/Obj.test.ts +386 -0
  338. package/src/Obj.ts +338 -250
  339. package/src/{query/order.ts → Order.ts} +19 -9
  340. package/src/{query/query.test.ts → Query.test.ts} +180 -49
  341. package/src/{query/query.ts → Query.ts} +115 -122
  342. package/src/QueryResult.ts +106 -0
  343. package/src/Ref.ts +20 -3
  344. package/src/Relation.test.ts +82 -0
  345. package/src/Relation.ts +364 -27
  346. package/src/SchemaRegistry.ts +105 -0
  347. package/src/Tag.ts +1 -1
  348. package/src/Type.test.ts +52 -0
  349. package/src/Type.ts +322 -88
  350. package/src/index.ts +9 -5
  351. package/src/internal/README.md +36 -17
  352. package/src/internal/annotations/annotations.test.ts +6 -6
  353. package/src/internal/annotations/annotations.ts +73 -76
  354. package/src/internal/annotations/util.ts +2 -0
  355. package/src/internal/api/annotations.ts +60 -0
  356. package/src/internal/api/entity.ts +29 -0
  357. package/src/internal/api/index.ts +19 -0
  358. package/src/internal/api/meta.ts +88 -0
  359. package/src/internal/api/sorting.ts +53 -0
  360. package/src/internal/api/version.ts +96 -0
  361. package/src/internal/entities/entity.ts +36 -19
  362. package/src/internal/entities/index.ts +1 -1
  363. package/src/internal/entities/model.ts +17 -12
  364. package/src/internal/entities/object.ts +21 -8
  365. package/src/internal/entities/relation.ts +23 -7
  366. package/src/internal/formats/format.test.ts +1 -1
  367. package/src/internal/formats/format.ts +7 -8
  368. package/src/internal/formats/object.ts +2 -2
  369. package/src/internal/formats/select.ts +6 -4
  370. package/src/internal/formats/string.ts +5 -0
  371. package/src/internal/formats/types.ts +9 -3
  372. package/src/internal/index.ts +2 -1
  373. package/src/internal/json-schema/json-schema-normalize.ts +4 -2
  374. package/src/internal/json-schema/json-schema-type.ts +31 -32
  375. package/src/internal/json-schema/json-schema.test.ts +19 -17
  376. package/src/internal/json-schema/json-schema.ts +14 -10
  377. package/src/internal/object/clone.ts +48 -0
  378. package/src/internal/object/create-object.ts +2 -2
  379. package/src/internal/object/index.ts +3 -0
  380. package/src/internal/object/inspect.ts +3 -3
  381. package/src/internal/object/json-serializer.test.ts +6 -2
  382. package/src/internal/object/json-serializer.ts +28 -70
  383. package/src/internal/object/schema-validator.test.ts +3 -7
  384. package/src/internal/object/schema-validator.ts +2 -238
  385. package/src/internal/object/set-value.test.ts +281 -0
  386. package/src/internal/object/set-value.ts +165 -0
  387. package/src/internal/object/snapshot.ts +70 -0
  388. package/src/internal/object/typed-object.test.ts +11 -11
  389. package/src/internal/object/typed-object.ts +8 -72
  390. package/src/internal/proxy/change-context.ts +138 -0
  391. package/src/internal/proxy/change.test.ts +519 -0
  392. package/src/internal/proxy/define-hidden-property.ts +14 -0
  393. package/src/internal/proxy/errors.ts +42 -0
  394. package/src/internal/proxy/event-batch.ts +44 -0
  395. package/src/internal/proxy/handler.test.ts +30 -80
  396. package/src/internal/proxy/index.ts +11 -0
  397. package/src/internal/proxy/json-serializer.ts +87 -0
  398. package/src/internal/proxy/make-object.ts +33 -50
  399. package/src/internal/proxy/ownership.ts +253 -0
  400. package/src/internal/proxy/proxy-types.ts +23 -0
  401. package/src/internal/proxy/proxy-utils.ts +150 -0
  402. package/src/internal/proxy/reactive-array.ts +71 -0
  403. package/src/internal/proxy/reactive.ts +69 -0
  404. package/src/internal/proxy/schema-validator.ts +244 -0
  405. package/src/internal/proxy/schema.test.ts +23 -15
  406. package/src/internal/proxy/symbols.ts +7 -0
  407. package/src/internal/proxy/typed-handler.test.ts +247 -35
  408. package/src/internal/proxy/typed-handler.ts +265 -56
  409. package/src/internal/proxy/typed-object.test.ts +37 -26
  410. package/src/internal/ref/ref-array.ts +4 -4
  411. package/src/internal/ref/ref.test.ts +1 -1
  412. package/src/internal/ref/ref.ts +64 -40
  413. package/src/internal/schema/compose.test.ts +3 -3
  414. package/src/internal/schema/compose.ts +13 -9
  415. package/src/internal/schema/echo-schema.ts +49 -11
  416. package/src/internal/schema/index.ts +0 -2
  417. package/src/internal/schema/persistent-schema.ts +3 -4
  418. package/src/internal/types/base.ts +6 -21
  419. package/src/internal/types/entity.ts +35 -4
  420. package/src/internal/types/meta.ts +13 -24
  421. package/src/testing/api.test.ts +31 -5
  422. package/src/testing/test-schema.ts +55 -30
  423. package/src/testing/util.ts +22 -15
  424. package/dist/lib/browser/chunk-7GH6RXJ3.mjs.map +0 -7
  425. package/dist/lib/browser/chunk-E4UTVJNF.mjs +0 -1111
  426. package/dist/lib/browser/chunk-E4UTVJNF.mjs.map +0 -7
  427. package/dist/lib/node-esm/chunk-JE5RXM2I.mjs +0 -1111
  428. package/dist/lib/node-esm/chunk-JE5RXM2I.mjs.map +0 -7
  429. package/dist/lib/node-esm/chunk-M4B6BMD2.mjs.map +0 -7
  430. package/dist/types/src/errors.d.ts.map +0 -1
  431. package/dist/types/src/internal/entities/expando.d.ts +0 -16
  432. package/dist/types/src/internal/entities/expando.d.ts.map +0 -1
  433. package/dist/types/src/internal/schema/runtime-schema-registry.d.ts +0 -18
  434. package/dist/types/src/internal/schema/runtime-schema-registry.d.ts.map +0 -1
  435. package/dist/types/src/internal/schema/snapshot.d.ts +0 -6
  436. package/dist/types/src/internal/schema/snapshot.d.ts.map +0 -1
  437. package/dist/types/src/query/filter.d.ts +0 -167
  438. package/dist/types/src/query/filter.d.ts.map +0 -1
  439. package/dist/types/src/query/index.d.ts +0 -5
  440. package/dist/types/src/query/index.d.ts.map +0 -1
  441. package/dist/types/src/query/order.d.ts +0 -12
  442. package/dist/types/src/query/order.d.ts.map +0 -1
  443. package/dist/types/src/query/query.d.ts.map +0 -1
  444. package/dist/types/src/query/query.test.d.ts +0 -2
  445. package/dist/types/src/query/query.test.d.ts.map +0 -1
  446. package/dist/types/src/query/testing.d.ts +0 -51
  447. package/dist/types/src/query/testing.d.ts.map +0 -1
  448. package/dist/types/src/query/types.d.ts +0 -17
  449. package/dist/types/src/query/types.d.ts.map +0 -1
  450. package/dist/types/src/query/util.d.ts +0 -8
  451. package/dist/types/src/query/util.d.ts.map +0 -1
  452. package/src/internal/entities/expando.ts +0 -23
  453. package/src/internal/schema/runtime-schema-registry.ts +0 -78
  454. package/src/internal/schema/snapshot.ts +0 -25
  455. package/src/query/filter.ts +0 -455
  456. package/src/query/index.ts +0 -9
  457. package/src/query/testing.ts +0 -64
  458. package/src/query/types.ts +0 -23
  459. package/src/query/util.ts +0 -25
package/src/Type.ts CHANGED
@@ -2,28 +2,31 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import type * as Schema$ from 'effect/Schema';
5
+ import * as Schema from 'effect/Schema';
6
6
 
7
7
  import { type EncodedReference } from '@dxos/echo-protocol';
8
8
  import { invariant } from '@dxos/invariant';
9
- import { type DXN } from '@dxos/keys';
9
+ import { type DXN, type ObjectId } from '@dxos/keys';
10
10
  import { type ToMutable } from '@dxos/util';
11
11
 
12
12
  import type * as Entity$ from './Entity';
13
13
  import {
14
+ ANY_OBJECT_TYPENAME,
15
+ ANY_OBJECT_VERSION,
14
16
  type ATTR_RELATION_SOURCE,
15
17
  type ATTR_RELATION_TARGET,
18
+ type AnyEntity,
19
+ type AnyProperties,
16
20
  EchoObjectSchema,
17
21
  EchoRelationSchema,
18
22
  type EchoRelationSchemaOptions,
19
23
  EchoSchema,
20
- Expando as Expando$,
21
- type ExpandoEncoded,
24
+ EntityKind,
22
25
  PersistentSchema,
23
- type PersistentSchemaEncoded,
24
26
  Ref as Ref$,
25
27
  type RefFn,
26
28
  type RefSchema,
29
+ SchemaKindId,
27
30
  type TypeAnnotation,
28
31
  type TypeMeta,
29
32
  getSchemaDXN,
@@ -45,126 +48,256 @@ export { toEffectSchema, toJsonSchema };
45
48
  export type Properties<T = any> = Omit<T, 'id' | Entity$.KindId | Relation$.Source | Relation$.Target>;
46
49
 
47
50
  //
48
- // Entity
51
+ // Internal types (not exported)
49
52
  //
50
53
 
51
- export namespace Entity {
52
- /**
53
- * Type.Obj.Any | Type.Relation.Any.
54
- */
55
- export type Any = Obj.Any | Relation.Any;
54
+ /**
55
+ * Type that marks a schema as an ECHO schema.
56
+ * The value indicates the entity kind (Object or Relation).
57
+ */
58
+ type EchoSchemaKind<K extends EntityKind = EntityKind> = {
59
+ readonly [SchemaKindId]: K;
60
+ };
61
+
62
+ /**
63
+ * JSON-encoded properties for objects.
64
+ */
65
+ interface ObjJsonProps {
66
+ id: string;
67
+ }
68
+
69
+ /**
70
+ * JSON-encoded properties for relations.
71
+ */
72
+ interface RelationJsonProps {
73
+ id: string;
74
+ [ATTR_RELATION_SOURCE]: string;
75
+ [ATTR_RELATION_TARGET]: string;
56
76
  }
57
77
 
58
78
  //
59
- // Obj
79
+ // Obj - Runtime schema for any ECHO object
60
80
  //
61
81
 
62
- interface ObjJsonProps {
63
- id: string;
64
- }
82
+ // Internal type for the Obj schema constant.
83
+ // NOTE: The `any` in the type intersection is intentional - it makes this type bidirectionally
84
+ // assignable with specific object types (e.g., Type.Obj can be assigned to/from Meeting.Meeting).
85
+ // This is needed because operation schemas erase type information.
86
+ // TODO(wittjosiah): Consider alternatives to the `any` intersection hack:
87
+ // - Generic operation schemas that preserve input type in output
88
+ // - Branded types that specific schemas also carry
89
+ // - Accept the limitation and require explicit type narrowing at call sites
90
+ type ObjSchemaType = Schema.Schema<
91
+ any & AnyEntity & Entity$.OfKind<typeof Entity$.Kind.Object> & AnyProperties,
92
+ { id: string } & AnyProperties
93
+ > &
94
+ EchoSchemaKind<EntityKind.Object> &
95
+ TypeMeta;
96
+
97
+ // Internal schema definition.
98
+ // NOTE: The EchoObjectSchema annotation is required for Type.Ref(Type.Obj) to work.
99
+ // The typename/version only satisfy ECHO schema machinery for reference targets.
100
+ const ObjSchema = Schema.Struct({
101
+ id: Schema.String,
102
+ }).pipe(
103
+ Schema.extend(Schema.Record({ key: Schema.String, value: Schema.Unknown })),
104
+ EchoObjectSchema({ typename: ANY_OBJECT_TYPENAME, version: ANY_OBJECT_VERSION }),
105
+ );
65
106
 
66
107
  /**
67
- * Return type of the `Obj` schema constructor.
108
+ * Runtime Effect schema for any ECHO object.
109
+ * Use for validation, parsing, or as a reference target for collections.
68
110
  *
69
- * This typedef avoids `TS4023` error (name from external module cannot be used named).
70
- * See Effect's note on interface types.
111
+ * NOTE: `Schema.is(Type.Obj)` does STRUCTURAL validation only (checks for `id` field).
112
+ * Use `Obj.isObject()` for proper ECHO instance type guards that check the KindId brand.
113
+ *
114
+ * @example
115
+ * ```ts
116
+ * // Structural type guard (accepts any object with id field)
117
+ * if (Schema.is(Type.Obj)(unknownValue)) { ... }
118
+ *
119
+ * // ECHO instance type guard (checks KindId brand)
120
+ * if (Obj.isObject(unknownValue)) { ... }
121
+ *
122
+ * // Reference to any object type
123
+ * const Collection = Schema.Struct({
124
+ * objects: Schema.Array(Type.Ref(Type.Obj)),
125
+ * }).pipe(Type.object({ typename: 'Collection', version: '0.1.0' }));
126
+ * ```
71
127
  */
72
- export interface obj<Self extends Schema$.Schema.Any>
73
- extends TypeMeta,
74
- Schema$.AnnotableClass<
75
- obj<Self>,
76
- Entity$.OfKind<typeof Entity$.Kind.Object> & ToMutable<Schema$.Schema.Type<Self>>,
77
- Schema$.Simplify<ObjJsonProps & ToMutable<Schema$.Schema.Encoded<Self>>>,
78
- Schema$.Schema.Context<Self>
79
- > {}
128
+ // TODO(wittjosiah): Investigate if Schema.filter can validate KindId on ECHO instances.
129
+ // Effect Schema normalizes proxy objects to plain objects before calling filter predicates.
130
+ // Possible approaches: custom Schema.declare, AST manipulation, or upstream contribution.
131
+ export const Obj: ObjSchemaType = Object.assign(ObjSchema, {
132
+ [SchemaKindId]: (ObjSchema as any)[SchemaKindId],
133
+ }) as unknown as ObjSchemaType;
80
134
 
81
135
  /**
82
- * Object schema.
136
+ * TypeScript type for an ECHO object schema.
137
+ * `T` is the instance type produced by the schema.
138
+ * `Fields` is the optional struct fields type for introspection.
139
+ *
140
+ * @example
141
+ * ```ts
142
+ * const PersonSchema: Type.Obj<Person> = Schema.Struct({
143
+ * name: Schema.String,
144
+ * }).pipe(Type.object({ typename: 'Person', version: '0.1.0' }));
145
+ *
146
+ * // Access fields for introspection:
147
+ * Object.keys(PersonSchema.fields); // ['name']
148
+ * ```
83
149
  */
84
- export const Obj: {
85
- (opts: TypeMeta): <Self extends Schema$.Schema.Any>(self: Self) => obj<Self>;
86
- } = EchoObjectSchema as any;
150
+ export interface Obj<T = any, Fields extends Schema.Struct.Fields = Schema.Struct.Fields>
151
+ extends TypeMeta,
152
+ EchoSchemaKind<EntityKind.Object>,
153
+ Schema.AnnotableClass<
154
+ Obj<T, Fields>,
155
+ Entity$.OfKind<typeof Entity$.Kind.Object> & T,
156
+ Schema.Simplify<ObjJsonProps & ToMutable<T>>,
157
+ never
158
+ > {
159
+ /**
160
+ * The fields defined in the original struct schema.
161
+ * Allows accessing field definitions for introspection.
162
+ */
163
+ readonly fields: Fields;
164
+ }
87
165
 
88
166
  /**
89
- * Object schema type definitions.
167
+ * Structural base type for any ECHO object schema.
168
+ * Accepts both static schemas (created with Type.object()) and EchoSchema.
169
+ * NOTE: Does not include the brand symbol to avoid TS4053 declaration portability issues.
170
+ * Use Type.isObjectSchema() for runtime type guards.
90
171
  */
91
- export declare namespace Obj {
172
+ type ObjectSchemaBase = Schema.Schema.AnyNoContext & {
173
+ readonly typename: string;
174
+ readonly version: string;
175
+ };
176
+
177
+ export namespace Obj {
92
178
  /**
93
- * Type that represents an arbitrary schema type of an object.
94
- * NOTE: This is not an instance type.
179
+ * Type that represents any ECHO object schema.
180
+ * Accepts both static schemas (Type.object()) and mutable schemas (EchoSchema).
95
181
  */
96
- // TODO(dmaretskyi): If schema was covariant, we could specify props in here, like `id: ObjectId`.
97
- // TODO(burdon): This erases the ECHO type info (e.g., id, typename).
98
- export type Any = obj<Schema$.Schema.AnyNoContext>;
182
+ export type Any = ObjectSchemaBase;
99
183
  }
100
184
 
101
- //
102
- // Expando
103
- //
104
-
105
- export const Expando: obj<Schema$.Schema<Expando$, ExpandoEncoded>> = Expando$ as any;
106
- export type Expando = obj<Schema$.Schema<Expando$, ExpandoEncoded>>;
185
+ /**
186
+ * Factory function to create an ECHO object schema.
187
+ * Adds object metadata annotations to an Effect schema.
188
+ *
189
+ * @example
190
+ * ```ts
191
+ * const Person = Schema.Struct({
192
+ * name: Schema.String,
193
+ * }).pipe(Type.object({ typename: 'example.com/type/Person', version: '0.1.0' }));
194
+ * ```
195
+ */
196
+ export const object: {
197
+ (opts: TypeMeta): <Self extends Schema.Schema.Any>(self: Self) => Obj<Schema.Schema.Type<Self>>;
198
+ } = EchoObjectSchema as any;
107
199
 
108
200
  //
109
- // Schema
201
+ // PersistentType (Schema stored in database)
110
202
  //
111
203
 
112
- export const PersistentType: obj<Schema$.Schema<PersistentSchema, PersistentSchemaEncoded>> = PersistentSchema as any;
113
- export type PersistentType = obj<Schema$.Schema<PersistentSchema, PersistentSchemaEncoded>>;
204
+ export const PersistentType: Obj<PersistentSchema> = PersistentSchema as any;
205
+
206
+ export interface PersistentType extends Schema.Schema.Type<typeof PersistentType> {}
114
207
 
115
208
  export { EchoSchema as RuntimeType };
116
209
 
117
210
  //
118
- // Relation
211
+ // Relation - Runtime schema for any ECHO relation
119
212
  //
120
213
 
121
- interface RelationJsonProps {
122
- id: string;
123
- [ATTR_RELATION_SOURCE]: string;
124
- [ATTR_RELATION_TARGET]: string;
125
- }
214
+ // Internal type for the Relation schema constant.
215
+ type RelationSchemaType = Schema.Schema<
216
+ { id: ObjectId } & Record<string, unknown>,
217
+ { id: string } & Record<string, unknown>
218
+ > &
219
+ EchoSchemaKind<EntityKind.Relation> &
220
+ TypeMeta;
221
+
222
+ // Internal schema definition.
223
+ // NOTE: The EchoRelationSchema annotation is required for Type.Ref(Type.Relation) to work.
224
+ // The typename/version/source/target only satisfy ECHO schema machinery for reference targets.
225
+ const RelationSchema = Schema.Struct({
226
+ id: Schema.String,
227
+ }).pipe(
228
+ Schema.extend(Schema.Record({ key: Schema.String, value: Schema.Unknown })),
229
+ EchoRelationSchema({
230
+ typename: 'dxos.org/schema/AnyRelation',
231
+ version: '0.0.0',
232
+ source: ObjSchema,
233
+ target: ObjSchema,
234
+ }),
235
+ );
126
236
 
127
237
  /**
128
- * Return type of the `Relation` schema constructor.
238
+ * Runtime Effect schema for any ECHO relation.
239
+ * Use for validation, parsing, or as a reference target for collections.
240
+ * A relation has `id`, source, and target fields plus any additional properties.
129
241
  *
130
- * This typedef avoids `TS4023` error (name from external module cannot be used named).
131
- * See Effect's note on interface types.
242
+ * NOTE: `Schema.is(Type.Relation)` does STRUCTURAL validation only (checks for `id` field).
243
+ * Use `Relation.isRelation()` for proper ECHO instance type guards that check the KindId brand.
244
+ *
245
+ * @example
246
+ * ```ts
247
+ * // Structural type guard (accepts any object with id field)
248
+ * if (Schema.is(Type.Relation)(unknownValue)) { ... }
249
+ *
250
+ * // ECHO instance type guard (checks KindId brand)
251
+ * if (Relation.isRelation(unknownValue)) { ... }
252
+ * ```
132
253
  */
133
- export interface relation<
134
- Self extends Schema$.Schema.Any,
135
- SourceSchema extends Schema$.Schema.Any,
136
- TargetSchema extends Schema$.Schema.Any,
137
- > extends TypeMeta,
138
- Schema$.AnnotableClass<
139
- relation<Self, SourceSchema, TargetSchema>,
140
- Entity$.OfKind<typeof Entity$.Kind.Relation> &
141
- Relation.Endpoints<Schema$.Schema.Type<SourceSchema>, Schema$.Schema.Type<TargetSchema>> &
142
- ToMutable<Schema$.Schema.Type<Self>>,
143
- Schema$.Simplify<RelationJsonProps & ToMutable<Schema$.Schema.Encoded<Self>>>,
144
- Schema$.Schema.Context<Self>
145
- > {}
254
+ export const Relation: RelationSchemaType = Object.assign(RelationSchema, {
255
+ [SchemaKindId]: (RelationSchema as any)[SchemaKindId],
256
+ }) as unknown as RelationSchemaType;
146
257
 
147
258
  /**
148
- * Relation schema.
259
+ * TypeScript type for an ECHO relation schema.
260
+ * `T` is the instance type produced by the schema (excluding source/target).
261
+ * `Source` and `Target` are the endpoint types.
262
+ * `Fields` is the optional struct fields type for introspection.
149
263
  */
150
- // TODO(dmaretskyi): I have to redefine the type here so that the definition uses symbols from @dxos/echo/Relation.
151
- // TODO(burdon): Remove?
152
- export const Relation: {
153
- <Source extends Schema$.Schema.AnyNoContext, Target extends Schema$.Schema.AnyNoContext>(
154
- opts: EchoRelationSchemaOptions<Source, Target>,
155
- ): <Self extends Schema$.Schema.Any>(self: Self) => relation<Self, Source, Target>;
156
- } = EchoRelationSchema as any;
264
+ export interface Relation<
265
+ T = any,
266
+ Source = any,
267
+ Target = any,
268
+ Fields extends Schema.Struct.Fields = Schema.Struct.Fields,
269
+ > extends TypeMeta,
270
+ EchoSchemaKind<EntityKind.Relation>,
271
+ Schema.AnnotableClass<
272
+ Relation<T, Source, Target, Fields>,
273
+ Entity$.OfKind<typeof Entity$.Kind.Relation> & Relation.Endpoints<Source, Target> & T,
274
+ Schema.Simplify<RelationJsonProps & ToMutable<T>>,
275
+ never
276
+ > {
277
+ /**
278
+ * The fields defined in the original struct schema.
279
+ * Allows accessing field definitions for introspection.
280
+ */
281
+ readonly fields: Fields;
282
+ }
157
283
 
158
284
  /**
159
- * Relation schema type definitions.
285
+ * Structural base type for any ECHO relation schema.
286
+ * Accepts static schemas (created with Type.relation()).
287
+ * NOTE: Does not include the brand symbol to avoid TS4053 declaration portability issues.
288
+ * Use Type.isRelationSchema() for runtime type guards.
160
289
  */
290
+ type RelationSchemaBase = Schema.Schema.AnyNoContext & {
291
+ readonly typename: string;
292
+ readonly version: string;
293
+ };
294
+
161
295
  export namespace Relation {
162
296
  /**
163
- * Type that represents an arbitrary schema type of a relation.
164
- * NOTE: This is not an instance type.
297
+ * Type that represents any ECHO relation schema.
298
+ * Accepts static schemas (Type.relation()).
165
299
  */
166
- // TODO(dmaretskyi): If schema was covariant, we could specify props in here, like `id: ObjectId`.
167
- export type Any = Schema$.Schema.AnyNoContext;
300
+ export type Any = RelationSchemaBase;
168
301
 
169
302
  /**
170
303
  * Get relation source type.
@@ -182,9 +315,84 @@ export namespace Relation {
182
315
  };
183
316
  }
184
317
 
318
+ /**
319
+ * Factory function to create an ECHO relation schema.
320
+ * Adds relation metadata annotations to an Effect schema.
321
+ *
322
+ * @example
323
+ * ```ts
324
+ * const WorksFor = Schema.Struct({
325
+ * role: Schema.String,
326
+ * }).pipe(Type.relation({
327
+ * typename: 'example.com/type/WorksFor',
328
+ * version: '0.1.0',
329
+ * source: Person,
330
+ * target: Company,
331
+ * }));
332
+ * ```
333
+ */
334
+ export const relation: {
335
+ <SourceSchema extends Schema.Schema.AnyNoContext, TargetSchema extends Schema.Schema.AnyNoContext>(
336
+ opts: EchoRelationSchemaOptions<SourceSchema, TargetSchema>,
337
+ ): <Self extends Schema.Schema.Any>(
338
+ self: Self,
339
+ ) => Relation<Schema.Schema.Type<Self>, Schema.Schema.Type<SourceSchema>, Schema.Schema.Type<TargetSchema>>;
340
+ } = EchoRelationSchema as any;
341
+
342
+ //
343
+ // Entity - Entity schema types (union of Object | Relation)
344
+ //
345
+
346
+ export namespace Entity {
347
+ /**
348
+ * Runtime Effect schema for any ECHO entity (object or relation).
349
+ * Use for validation, parsing, or type guards on unknown values.
350
+ *
351
+ * @example
352
+ * ```ts
353
+ * if (Schema.is(Type.Entity.Any)(unknownValue)) {
354
+ * // unknownValue is an ECHO entity
355
+ * }
356
+ * ```
357
+ */
358
+ export const Any: Schema.Schema<
359
+ { id: ObjectId } & Record<string, unknown>,
360
+ { id: string } & Record<string, unknown>
361
+ > = Schema.Union(Obj, Relation);
362
+
363
+ /**
364
+ * Type alias for any ECHO entity schema (object or relation).
365
+ * Use this in type annotations for schema parameters.
366
+ */
367
+ export type Any = Obj.Any | Relation.Any;
368
+ }
369
+
370
+ /**
371
+ * Type guard to check if a schema is an object schema.
372
+ * NOTE: This checks SCHEMAS, not instances. Use Obj.isObject for instances.
373
+ */
374
+ export const isObjectSchema = (schema: Entity.Any): schema is Obj.Any => {
375
+ return (schema as any)[SchemaKindId] === EntityKind.Object;
376
+ };
377
+
378
+ /**
379
+ * Type guard to check if a schema is a relation schema.
380
+ * NOTE: This checks SCHEMAS, not instances. Use Relation.isRelation for instances.
381
+ */
382
+ export const isRelationSchema = (schema: Entity.Any): schema is Relation.Any => {
383
+ return (schema as any)[SchemaKindId] === EntityKind.Relation;
384
+ };
385
+
185
386
  //
186
387
  // Ref
187
- // TODO(burdon): Reconcile Type.Ref with Ref.Ref.
388
+ //
389
+ // NOTE: `Type.Ref` vs `Ref.Ref`:
390
+ // - `Type.Ref<T>` is the SCHEMA type - a schema that produces `Ref.Ref<T>` instances.
391
+ // - `Ref.Ref<T>` is the INSTANCE type - the actual runtime ref object.
392
+ //
393
+ // Example:
394
+ // const taskRef: Ref.Ref<Task> = Ref.make(task); // Instance
395
+ // const schema: Type.Ref<Task> = Type.Ref(Task); // Schema
188
396
  //
189
397
 
190
398
  /**
@@ -193,23 +401,49 @@ export namespace Relation {
193
401
  * This typedef avoids `TS4023` error (name from external module cannot be used named).
194
402
  * See Effect's note on interface types.
195
403
  */
196
- export interface ref<TargetSchema extends Schema$.Schema.Any> extends RefSchema<Schema$.Schema.Type<TargetSchema>> {}
404
+ export interface ref<TargetSchema extends Schema.Schema.Any> extends RefSchema<Schema.Schema.Type<TargetSchema>> {}
197
405
 
198
406
  /**
199
- * Ref schema.
407
+ * Factory function to create a Ref schema for the given target schema.
408
+ * Use this in schema definitions to declare reference fields.
409
+ *
410
+ * @example
411
+ * ```ts
412
+ * const Task = Schema.Struct({
413
+ * assignee: Type.Ref(Person), // Creates a Ref schema
414
+ * }).pipe(Type.object({ typename: 'Task', version: '0.1.0' }));
415
+ * ```
200
416
  */
201
417
  export const Ref: RefFn = Ref$;
202
418
 
203
- export interface Ref<T> extends Schema$.SchemaClass<Ref$<T>, EncodedReference> {}
419
+ /**
420
+ * TypeScript type for a Ref schema.
421
+ * This is the type of the SCHEMA itself, not the runtime ref instance.
422
+ * For the instance type, use `Ref.Ref<T>` from the Ref module.
423
+ *
424
+ * @example
425
+ * ```ts
426
+ * // Schema type annotation (rarely needed, usually inferred):
427
+ * const refSchema: Type.Ref<Task> = Type.Ref(Task);
428
+ *
429
+ * // Instance type annotation (use Ref.Ref instead):
430
+ * const refInstance: Ref.Ref<Task> = Ref.make(task);
431
+ * ```
432
+ */
433
+ export interface Ref<T> extends Schema.SchemaClass<Ref$<T>, EncodedReference> {}
204
434
 
205
435
  export namespace Ref {
206
436
  /**
207
- * Type that represents an arbitrary schema type of a reference.
208
- * NOTE: This is not an instance type.
437
+ * Type that represents any Ref schema (with unknown target type).
438
+ * This is a schema type, not an instance type.
209
439
  */
210
- export type Any = Schema$.Schema<Ref$<any>, EncodedReference>;
440
+ export type Any = Schema.Schema<Ref$<any>, EncodedReference>;
211
441
  }
212
442
 
443
+ //
444
+ // Schema utility functions
445
+ //
446
+
213
447
  /**
214
448
  * Gets the full DXN of the schema.
215
449
  * Will include the version if it's a `type` DXN.
package/src/index.ts CHANGED
@@ -2,21 +2,25 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
+ export { QueryAST } from '@dxos/echo-protocol';
6
+ // TODO(wittjosiah): Refactor DXN to not use statics similar to Query.
5
7
  export { DXN } from '@dxos/keys';
6
8
 
7
- export * from './errors';
8
-
9
- // TODO(burdon): Separate namesapces for Query (Query.Query, Query.Filter, etc.)
10
- export * from './query';
11
-
12
9
  export * as Annotation from './Annotation';
13
10
  export * as Database from './Database';
14
11
  export * as Entity from './Entity';
12
+ export * as Err from './Err';
13
+ export * as Filter from './Filter';
15
14
  export * as Format from './Format';
15
+ export * as Hypergraph from './Hypergraph';
16
16
  export * as JsonSchema from './JsonSchema';
17
17
  export * as Key from './Key';
18
18
  export * as Obj from './Obj';
19
+ export * as Order from './Order';
20
+ export * as Query from './Query';
21
+ export * as QueryResult from './QueryResult';
19
22
  export * as Ref from './Ref';
20
23
  export * as Relation from './Relation';
24
+ export * as SchemaRegistry from './SchemaRegistry';
21
25
  export * as Tag from './Tag';
22
26
  export * as Type from './Type';
@@ -11,7 +11,7 @@
11
11
  - [x] Entity.Any = Obj.Any | Relation.Any
12
12
  - NOTE: Relation does not extend (in not polymorphic with) Obj.
13
13
  - [x] import LabelAnnotation => Annotation.LabelAnnotation
14
- - [x] import Expando => Type.Expando
14
+ - [x] import Expando => @dxos/schema (Expando.Expando)
15
15
  - [x] live => Obj.make
16
16
  - [x] Rename live => makeObject
17
17
  - [x] Rename {EchoObject, EchoRelation} => {EchoObjecSchema, EchoRelationSchema}
@@ -23,30 +23,47 @@
23
23
  - [x] TODO(burdon): FIX!!!
24
24
  - [x] Fix failing tests.
25
25
  - [x] Reconcile types/version with entities/model/version
26
- - [x] Type.Expando => Obj.Any
26
+ - [x] Expando moved to @dxos/schema
27
27
  - [x] Narrow QueryResult and match Schema and Object generics.
28
28
 
29
29
  2. Clean-up
30
30
 
31
- - [ ] TODO(wittjosiah): Find a simpler way to define this type.
32
- - [ ] TODO(wittjosiah): Should be Type.obj<...> or equivalent.
33
- - [ ] Fix Obj.instanceOf(Type.Expando...
34
- - [ ] Add Obj.Unknown and Relation.Unknown to match Entity.Unknown.
35
- - [ ] Ref.Array.targets doesn't satisfy Obj.Any because it uses AnyEchoObject.
36
- - [ ] Add Relation.MakeProps
37
- - [ ] Schema registry should return Type.Entity.Any instead of Schema.Schema.AnyNoContext.
38
- - [ ] Remove echo-db/AnyLiveObject<T> => Obj.Obj<T>
31
+ - [x] QueryResult namespace
32
+ - [x] SchemaRegistry interface
33
+ - [x] Schema registry should return Type.Entity.Any instead of Schema.Schema.AnyNoContext.
34
+ - [x] Hypergraph interface
35
+ - [x] Obj.getDatabase
36
+ - [x] SpaceAction.AddObject target should be a db not a space.
37
+ - [x] Add Relation.MakeProps
38
+ - [x] Add Obj.Unknown and Relation.Unknown to match Entity.Unknown.
39
+ - [x] TODO(wittjosiah): Should be Type.obj<...> or equivalent.
40
+ - [x] TODO(wittjosiah): Find a simpler way to define this type.
41
+ - [x] Ref.Array.targets doesn't satisfy Obj.Any because it uses AnyEchoObject.
42
+ - [x] Remove echo-db/AnyLiveObject<T> => Obj.Obj<T>
43
+ - [x] Rename AnyEchoObject => AnyEntity
44
+ - [x] Remove WithId => AnyEntity
45
+ - [x] Remove WithMeta => AnyEntity
46
+ - [x] Obj.Any => Obj.Unknown
47
+ - [x] Relation.Any => Relation.Unknown
48
+ - [x] Ref.Any => Ref.Unknown
49
+ - [x] Obj.AnyProps => Obj.Any
50
+ - [x] Factor Expando out of @dxos/echo (moved to @dxos/schema)
51
+ - [x] Obj.instanceOf works with Expando (tested in @dxos/schema)
52
+ - [x] Obj.Snapshot should be same shape as Obj.Obj but with a different brand
53
+ - [x] Mutators should only work on object after it is made mutable
54
+
55
+ - [ ] Review usage of Obj.Any, see if it could be stricter
56
+ - [ ] Type.Obj should validate using the echo object brand
57
+ - [ ] Mutable could be a branded type to fix "NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`"
58
+ - [ ] space properties, queues, messagins preventing getSpace from being removed
59
+ - [ ] Schema registry should use Query.Query.
60
+ - [ ] Move EchoSchemaRegistry into hypergraph
39
61
  - [ ] Narrow QueryResult and match Schema and Object generics.
62
+ - [ ] BaseSchema
40
63
  - [ ] Directly import JSONPath, etc. from @dxos/effect.
41
- - [ ] DISCUSS: Standradize $ suffix to disambuguate imports (GPT recommended).
42
- - [ ] Reconcile Type.Ref with Ref.Ref
43
64
  - [ ] Promote parts of src/internal/ref to Ref.ts
44
- - [ ] Rename AnyEchoObject => AnyEntity? (or accept that Object != Obj from naming perspective.)
45
- - [ ] Remove WithId => AnyEchoObject
46
- - [ ] Remove WithMeta => AnyEchoObject
47
- - [ ] BaseSchema
48
65
  - [ ] JsonPath, JsonProp, getValue, setValue => Json.Path?
49
- - [ ] Move EchoSchemaRegistry into hypergraph
66
+ - [ ] DISCUSS: Standradize $ suffix to disambuguate imports (GPT recommended).
50
67
 
51
68
  3. Audit usage from @dxos/echo-db
52
69
 
@@ -81,3 +98,5 @@
81
98
  - [ ] Consolidate getters (getType, getSchema, getTypename, getSchemaTypename, etc.)
82
99
  - [ ] ReactiveObject should specify id property? Reconcile AnyProperties, ReactiveObject, HasId, WithId, etc.
83
100
  - [ ] Can we us S.is(MyType) to detect objects with our types system? (Branding?)
101
+ - [ ] Type.Expando doesn't work with AtomQuery result type (have to use Obj.Any instead).
102
+ - [ ] Obj.Any doesn't work with Obj.change callback types (have to use `any` for the mutable parameter).
@@ -7,7 +7,7 @@ import { describe, test } from 'vitest';
7
7
 
8
8
  import { EchoObjectSchema } from '../entities';
9
9
 
10
- import { LabelAnnotation, TypenameSchema, VersionSchema, getLabel } from './annotations';
10
+ import { LabelAnnotation, TypenameSchema, VersionSchema, getLabelWithSchema } from './annotations';
11
11
 
12
12
  // TODO(dmaretskyi): Use one of the testing schemas.
13
13
  const TestObject = Schema.Struct({
@@ -51,7 +51,7 @@ describe('annotations', () => {
51
51
  });
52
52
  });
53
53
 
54
- describe('getLabel', () => {
54
+ describe('getLabelWithSchema', () => {
55
55
  test('should return first available label value', ({ expect }) => {
56
56
  const obj: TestObject = {
57
57
  name: 'Primary Name',
@@ -59,7 +59,7 @@ describe('annotations', () => {
59
59
  other: 'Other',
60
60
  };
61
61
 
62
- expect(getLabel(TestObject, obj)).toEqual('Primary Name');
62
+ expect(getLabelWithSchema(TestObject, obj)).toEqual('Primary Name');
63
63
  });
64
64
 
65
65
  test('should fallback to second path if first is undefined', ({ expect }) => {
@@ -69,7 +69,7 @@ describe('annotations', () => {
69
69
  other: 'Other',
70
70
  };
71
71
 
72
- expect(getLabel(TestObject, obj)).toEqual('Fallback Name');
72
+ expect(getLabelWithSchema(TestObject, obj)).toEqual('Fallback Name');
73
73
  });
74
74
 
75
75
  test('should return undefined if no label paths resolve', ({ expect }) => {
@@ -79,7 +79,7 @@ describe('annotations', () => {
79
79
  other: 'Other',
80
80
  };
81
81
 
82
- expect(getLabel(TestObject, obj)).toBeUndefined();
82
+ expect(getLabelWithSchema(TestObject, obj)).toBeUndefined();
83
83
  });
84
84
 
85
85
  test('should return label from echo object', ({ expect }) => {
@@ -90,7 +90,7 @@ describe('annotations', () => {
90
90
  other: 'Other',
91
91
  };
92
92
 
93
- expect(getLabel(TestEchoSchema, obj)).toEqual('Primary Name');
93
+ expect(getLabelWithSchema(TestEchoSchema, obj)).toEqual('Primary Name');
94
94
  });
95
95
  });
96
96
  });