@dxos/echo 0.8.4-main.c85a9c8dae → 0.8.4-main.d05539e30a

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 (558) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +3 -3
  3. package/dist/lib/neutral/Annotation.mjs +5 -3
  4. package/dist/lib/neutral/Database.mjs +8 -4
  5. package/dist/lib/neutral/Entity.mjs +16 -11
  6. package/dist/lib/neutral/Err.mjs +1 -1
  7. package/dist/lib/neutral/Extension.mjs +18 -0
  8. package/dist/lib/neutral/Extension.mjs.map +7 -0
  9. package/dist/lib/neutral/Feed.mjs +23 -14
  10. package/dist/lib/neutral/Filter.mjs +23 -10
  11. package/dist/lib/neutral/Format.mjs +3 -3
  12. package/dist/lib/neutral/JsonSchema.mjs +8 -7
  13. package/dist/lib/neutral/Key.mjs +1 -1
  14. package/dist/lib/neutral/Migration.mjs +17 -0
  15. package/dist/lib/neutral/Migration.mjs.map +7 -0
  16. package/dist/lib/neutral/Obj.mjs +16 -10
  17. package/dist/lib/neutral/Order.mjs +1 -1
  18. package/dist/lib/neutral/Query.mjs +19 -13
  19. package/dist/lib/neutral/QueryResult.mjs +1 -1
  20. package/dist/lib/neutral/Ref.mjs +9 -7
  21. package/dist/lib/neutral/Relation.mjs +15 -11
  22. package/dist/lib/neutral/SchemaRegistry.mjs +1 -1
  23. package/dist/lib/neutral/Tag.mjs +14 -10
  24. package/dist/lib/neutral/Type.mjs +10 -7
  25. package/dist/lib/neutral/{chunk-DZQSL6RW.mjs → chunk-44HT3MEC.mjs} +2 -2
  26. package/dist/lib/neutral/{chunk-DZQSL6RW.mjs.map → chunk-44HT3MEC.mjs.map} +1 -1
  27. package/dist/lib/neutral/{chunk-OVUBTQLT.mjs → chunk-5SL5LDLD.mjs} +4 -2
  28. package/dist/lib/neutral/chunk-5SL5LDLD.mjs.map +7 -0
  29. package/dist/lib/neutral/{chunk-ANHVGJI4.mjs → chunk-7RVZT53K.mjs} +1 -1
  30. package/dist/lib/neutral/chunk-APHSOTIX.mjs +34 -0
  31. package/dist/lib/neutral/chunk-APHSOTIX.mjs.map +7 -0
  32. package/dist/lib/neutral/{chunk-ALOGSVBP.mjs → chunk-APJKDGFL.mjs} +72 -6
  33. package/dist/lib/neutral/chunk-APJKDGFL.mjs.map +7 -0
  34. package/dist/lib/neutral/{chunk-T6JEFNP6.mjs → chunk-BICZKPQG.mjs} +1 -1
  35. package/dist/lib/neutral/{chunk-T6JEFNP6.mjs.map → chunk-BICZKPQG.mjs.map} +1 -1
  36. package/dist/lib/neutral/chunk-BMB7IHGB.mjs +346 -0
  37. package/dist/lib/neutral/chunk-BMB7IHGB.mjs.map +7 -0
  38. package/dist/lib/neutral/chunk-FIWO2FZK.mjs +36 -0
  39. package/dist/lib/neutral/chunk-FIWO2FZK.mjs.map +7 -0
  40. package/dist/lib/neutral/{chunk-PP4DNUZU.mjs → chunk-G54OX4IX.mjs} +1418 -2885
  41. package/dist/lib/neutral/chunk-G54OX4IX.mjs.map +7 -0
  42. package/dist/lib/neutral/chunk-GWFFC34K.mjs +50 -0
  43. package/dist/lib/neutral/chunk-GWFFC34K.mjs.map +7 -0
  44. package/dist/lib/neutral/{chunk-5ELDDYWE.mjs → chunk-I2DARWPX.mjs} +17 -19
  45. package/dist/lib/neutral/chunk-I2DARWPX.mjs.map +7 -0
  46. package/dist/lib/neutral/{chunk-KGV3QIRX.mjs → chunk-J54QMAKF.mjs} +125 -17
  47. package/dist/lib/neutral/chunk-J54QMAKF.mjs.map +7 -0
  48. package/dist/lib/neutral/{chunk-BRJSLACP.mjs → chunk-MGSQGHOD.mjs} +71 -17
  49. package/dist/lib/neutral/chunk-MGSQGHOD.mjs.map +7 -0
  50. package/dist/lib/neutral/chunk-MLS7U7AT.mjs +734 -0
  51. package/dist/lib/neutral/chunk-MLS7U7AT.mjs.map +7 -0
  52. package/dist/lib/neutral/{chunk-4KG6IGL4.mjs → chunk-N4B7FHQT.mjs} +4 -4
  53. package/dist/lib/neutral/{chunk-4KG6IGL4.mjs.map → chunk-N4B7FHQT.mjs.map} +2 -2
  54. package/dist/lib/neutral/{chunk-QXF3LGN2.mjs → chunk-N7VOEPSV.mjs} +8 -3
  55. package/dist/lib/neutral/chunk-N7VOEPSV.mjs.map +7 -0
  56. package/dist/lib/neutral/{chunk-T4MPQJ7X.mjs → chunk-PSZBLH53.mjs} +6 -22
  57. package/dist/lib/neutral/chunk-PSZBLH53.mjs.map +7 -0
  58. package/dist/lib/neutral/{chunk-ZWKJ4LZJ.mjs → chunk-PT37DG2F.mjs} +23 -51
  59. package/dist/lib/neutral/chunk-PT37DG2F.mjs.map +7 -0
  60. package/dist/lib/neutral/{chunk-GAWKQ5DZ.mjs → chunk-Q2KKKJSV.mjs} +5 -5
  61. package/dist/lib/neutral/chunk-Q2KKKJSV.mjs.map +7 -0
  62. package/dist/lib/neutral/{chunk-AQP4QKYP.mjs → chunk-Q7ZL2P5H.mjs} +56 -19
  63. package/dist/lib/neutral/chunk-Q7ZL2P5H.mjs.map +7 -0
  64. package/dist/lib/neutral/{chunk-O3TZFQCT.mjs → chunk-QRZ2I3ZM.mjs} +2 -2
  65. package/dist/lib/neutral/chunk-QRZ2I3ZM.mjs.map +7 -0
  66. package/dist/lib/neutral/{chunk-W7OP5HGZ.mjs → chunk-SCPFDS2E.mjs} +14 -10
  67. package/dist/lib/neutral/chunk-SCPFDS2E.mjs.map +7 -0
  68. package/dist/lib/neutral/{chunk-F7KMHDPJ.mjs → chunk-TNBK56IN.mjs} +54 -31
  69. package/dist/lib/neutral/chunk-TNBK56IN.mjs.map +7 -0
  70. package/dist/lib/neutral/{chunk-M2KVTHZM.mjs → chunk-TRPZU2HV.mjs} +10 -10
  71. package/dist/lib/neutral/chunk-TRPZU2HV.mjs.map +7 -0
  72. package/dist/lib/neutral/{chunk-ZTUBYOGB.mjs → chunk-TTCSATUD.mjs} +1 -1
  73. package/dist/lib/neutral/chunk-TTCSATUD.mjs.map +7 -0
  74. package/dist/lib/neutral/{chunk-OMUPQMLR.mjs → chunk-V72DY6LU.mjs} +1 -1
  75. package/dist/lib/neutral/chunk-ZFACXBY6.mjs +136 -0
  76. package/dist/lib/neutral/chunk-ZFACXBY6.mjs.map +7 -0
  77. package/dist/lib/neutral/{chunk-MXQJZCPY.mjs → chunk-ZISMEVKD.mjs} +1 -1
  78. package/dist/lib/neutral/chunk-ZISMEVKD.mjs.map +7 -0
  79. package/dist/lib/neutral/index.mjs +38 -25
  80. package/dist/lib/neutral/internal/index.mjs +50 -38
  81. package/dist/lib/neutral/meta.json +1 -1
  82. package/dist/lib/neutral/testing/index.mjs +196 -136
  83. package/dist/lib/neutral/testing/index.mjs.map +3 -3
  84. package/dist/types/src/Annotation.d.ts +3 -3
  85. package/dist/types/src/Annotation.d.ts.map +1 -1
  86. package/dist/types/src/Collection.d.ts.map +1 -1
  87. package/dist/types/src/Database.d.ts +16 -4
  88. package/dist/types/src/Database.d.ts.map +1 -1
  89. package/dist/types/src/Dataset.d.ts +2 -1
  90. package/dist/types/src/Dataset.d.ts.map +1 -1
  91. package/dist/types/src/Entity.d.ts +17 -11
  92. package/dist/types/src/Entity.d.ts.map +1 -1
  93. package/dist/types/src/Err.d.ts +18 -18
  94. package/dist/types/src/Err.d.ts.map +1 -1
  95. package/dist/types/src/Extension.d.ts +80 -0
  96. package/dist/types/src/Extension.d.ts.map +1 -0
  97. package/dist/types/src/Extension.test.d.ts +2 -0
  98. package/dist/types/src/Extension.test.d.ts.map +1 -0
  99. package/dist/types/src/Feed.d.ts +65 -24
  100. package/dist/types/src/Feed.d.ts.map +1 -1
  101. package/dist/types/src/Filter.d.ts +54 -4
  102. package/dist/types/src/Filter.d.ts.map +1 -1
  103. package/dist/types/src/Filter.test.d.ts +2 -0
  104. package/dist/types/src/Filter.test.d.ts.map +1 -0
  105. package/dist/types/src/Format.d.ts +1 -1
  106. package/dist/types/src/Format.d.ts.map +1 -1
  107. package/dist/types/src/Hypergraph.d.ts +9 -4
  108. package/dist/types/src/Hypergraph.d.ts.map +1 -1
  109. package/dist/types/src/Json.d.ts +33 -0
  110. package/dist/types/src/Json.d.ts.map +1 -0
  111. package/dist/types/src/Json.test.d.ts +2 -0
  112. package/dist/types/src/Json.test.d.ts.map +1 -0
  113. package/dist/types/src/JsonSchema.d.ts +5 -5
  114. package/dist/types/src/JsonSchema.d.ts.map +1 -1
  115. package/dist/types/src/Migration.d.ts +69 -0
  116. package/dist/types/src/Migration.d.ts.map +1 -0
  117. package/dist/types/src/Obj.d.ts +46 -30
  118. package/dist/types/src/Obj.d.ts.map +1 -1
  119. package/dist/types/src/Order.d.ts.map +1 -1
  120. package/dist/types/src/Query.d.ts +13 -2
  121. package/dist/types/src/Query.d.ts.map +1 -1
  122. package/dist/types/src/Ref.d.ts +12 -11
  123. package/dist/types/src/Ref.d.ts.map +1 -1
  124. package/dist/types/src/Relation.d.ts +16 -16
  125. package/dist/types/src/Relation.d.ts.map +1 -1
  126. package/dist/types/src/SchemaRegistry.d.ts +1 -1
  127. package/dist/types/src/Tag.d.ts +2 -2
  128. package/dist/types/src/Tag.d.ts.map +1 -1
  129. package/dist/types/src/Type.d.ts +10 -9
  130. package/dist/types/src/Type.d.ts.map +1 -1
  131. package/dist/types/src/View.d.ts +1 -1
  132. package/dist/types/src/View.d.ts.map +1 -1
  133. package/dist/types/src/exemplars.test.d.ts +2 -0
  134. package/dist/types/src/exemplars.test.d.ts.map +1 -0
  135. package/dist/types/src/index.d.ts +3 -0
  136. package/dist/types/src/index.d.ts.map +1 -1
  137. package/dist/types/src/internal/{annotations → Annotation}/annotations.d.ts +33 -2
  138. package/dist/types/src/internal/Annotation/annotations.d.ts.map +1 -0
  139. package/dist/types/src/internal/Annotation/annotations.test.d.ts.map +1 -0
  140. package/dist/types/src/internal/Annotation/index.d.ts +4 -0
  141. package/dist/types/src/internal/Annotation/index.d.ts.map +1 -0
  142. package/dist/types/src/internal/{api → Annotation}/sorting.d.ts +1 -1
  143. package/dist/types/src/internal/Annotation/sorting.d.ts.map +1 -0
  144. package/dist/types/src/internal/{annotations → Annotation}/util.d.ts +2 -2
  145. package/dist/types/src/internal/Annotation/util.d.ts.map +1 -0
  146. package/dist/types/src/internal/{api/entity.d.ts → Entity/api.d.ts} +2 -2
  147. package/dist/types/src/internal/Entity/api.d.ts.map +1 -0
  148. package/dist/types/src/internal/{entities → Entity}/entity.d.ts +2 -2
  149. package/dist/types/src/internal/Entity/entity.d.ts.map +1 -0
  150. package/dist/types/src/internal/{entities → Entity}/index.d.ts +2 -0
  151. package/dist/types/src/internal/Entity/index.d.ts.map +1 -0
  152. package/dist/types/src/internal/{entities → Entity}/model.d.ts +4 -26
  153. package/dist/types/src/internal/Entity/model.d.ts.map +1 -0
  154. package/dist/types/src/internal/{entities → Entity}/object.d.ts +2 -2
  155. package/dist/types/src/internal/Entity/object.d.ts.map +1 -0
  156. package/dist/types/src/internal/{entities → Entity}/relation.d.ts +3 -30
  157. package/dist/types/src/internal/Entity/relation.d.ts.map +1 -0
  158. package/dist/types/src/internal/Entity/util.d.ts.map +1 -0
  159. package/dist/types/src/internal/{api → Entity}/version.d.ts +1 -1
  160. package/dist/types/src/internal/Entity/version.d.ts.map +1 -0
  161. package/dist/types/src/internal/Format/date.d.ts.map +1 -0
  162. package/dist/types/src/internal/Format/date.test.d.ts.map +1 -0
  163. package/dist/types/src/internal/Format/format.d.ts.map +1 -0
  164. package/dist/types/src/internal/Format/format.test.d.ts.map +1 -0
  165. package/dist/types/src/internal/Format/index.d.ts.map +1 -0
  166. package/dist/types/src/internal/Format/number.d.ts.map +1 -0
  167. package/dist/types/src/internal/Format/object.d.ts.map +1 -0
  168. package/dist/types/src/internal/Format/select.d.ts.map +1 -0
  169. package/dist/types/src/internal/Format/string.d.ts.map +1 -0
  170. package/dist/types/src/internal/{formats → Format}/types.d.ts +1 -1
  171. package/dist/types/src/internal/Format/types.d.ts.map +1 -0
  172. package/dist/types/src/internal/{json-schema → JsonSchema}/annotations.d.ts +1 -1
  173. package/dist/types/src/internal/JsonSchema/annotations.d.ts.map +1 -0
  174. package/dist/types/src/internal/JsonSchema/effect-schema.test.d.ts.map +1 -0
  175. package/dist/types/src/internal/JsonSchema/index.d.ts.map +1 -0
  176. package/dist/types/src/internal/JsonSchema/json-schema-normalize.d.ts.map +1 -0
  177. package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema-type.d.ts +23 -23
  178. package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts.map +1 -0
  179. package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema.d.ts +1 -1
  180. package/dist/types/src/internal/JsonSchema/json-schema.d.ts.map +1 -0
  181. package/dist/types/src/internal/JsonSchema/json-schema.test.d.ts.map +1 -0
  182. package/dist/types/src/internal/Obj/clone.d.ts.map +1 -0
  183. package/dist/types/src/internal/Obj/common.d.ts.map +1 -0
  184. package/dist/types/src/internal/{object → Obj}/create-object.d.ts +2 -2
  185. package/dist/types/src/internal/Obj/create-object.d.ts.map +1 -0
  186. package/dist/types/src/internal/Obj/create-object.test.d.ts.map +1 -0
  187. package/dist/types/src/internal/{object → Obj}/deleted.d.ts +1 -1
  188. package/dist/types/src/internal/Obj/deleted.d.ts.map +1 -0
  189. package/dist/types/src/internal/{object → Obj}/ids.d.ts +1 -1
  190. package/dist/types/src/internal/Obj/ids.d.ts.map +1 -0
  191. package/dist/types/src/internal/Obj/index.d.ts.map +1 -0
  192. package/dist/types/src/internal/Obj/inspect.d.ts.map +1 -0
  193. package/dist/types/src/internal/{object → Obj}/json-serializer.d.ts +13 -5
  194. package/dist/types/src/internal/Obj/json-serializer.d.ts.map +1 -0
  195. package/dist/types/src/internal/Obj/json-serializer.test.d.ts.map +1 -0
  196. package/dist/types/src/internal/Obj/schema-validator.d.ts +2 -0
  197. package/dist/types/src/internal/Obj/schema-validator.d.ts.map +1 -0
  198. package/dist/types/src/internal/Obj/schema-validator.test.d.ts.map +1 -0
  199. package/dist/types/src/internal/{object → Obj}/set-value.d.ts +2 -2
  200. package/dist/types/src/internal/Obj/set-value.d.ts.map +1 -0
  201. package/dist/types/src/internal/Obj/set-value.test.d.ts.map +1 -0
  202. package/dist/types/src/internal/Obj/snapshot.d.ts.map +1 -0
  203. package/dist/types/src/internal/{object → Obj}/typed-object.d.ts +2 -2
  204. package/dist/types/src/internal/Obj/typed-object.d.ts.map +1 -0
  205. package/dist/types/src/internal/Obj/typed-object.test.d.ts.map +1 -0
  206. package/dist/types/src/internal/Query.d.ts +10 -0
  207. package/dist/types/src/internal/Query.d.ts.map +1 -0
  208. package/dist/types/src/internal/Ref/index.d.ts.map +1 -0
  209. package/dist/types/src/internal/{ref → Ref}/ref-array.d.ts +1 -1
  210. package/dist/types/src/internal/Ref/ref-array.d.ts.map +1 -0
  211. package/dist/types/src/internal/{ref → Ref}/ref.d.ts +15 -2
  212. package/dist/types/src/internal/Ref/ref.d.ts.map +1 -0
  213. package/dist/types/src/internal/Ref/ref.test.d.ts.map +1 -0
  214. package/dist/types/src/internal/{schema → Type}/compose.d.ts +1 -1
  215. package/dist/types/src/internal/Type/compose.d.ts.map +1 -0
  216. package/dist/types/src/internal/Type/compose.test.d.ts.map +1 -0
  217. package/dist/types/src/internal/{schema → Type}/echo-schema.d.ts +6 -6
  218. package/dist/types/src/internal/Type/echo-schema.d.ts.map +1 -0
  219. package/dist/types/src/internal/Type/index.d.ts.map +1 -0
  220. package/dist/types/src/internal/Type/manipulation.d.ts.map +1 -0
  221. package/dist/types/src/internal/{schema → Type}/persistent-schema.d.ts +2 -2
  222. package/dist/types/src/internal/Type/persistent-schema.d.ts.map +1 -0
  223. package/dist/types/src/internal/{api → common/api}/index.d.ts +0 -4
  224. package/dist/types/src/internal/common/api/index.d.ts.map +1 -0
  225. package/dist/types/src/internal/{api → common/api}/meta.d.ts +3 -3
  226. package/dist/types/src/internal/common/api/meta.d.ts.map +1 -0
  227. package/dist/types/src/internal/common/index.d.ts +4 -0
  228. package/dist/types/src/internal/common/index.d.ts.map +1 -0
  229. package/dist/types/src/internal/{proxy → common/proxy}/change-context.d.ts +1 -1
  230. package/dist/types/src/internal/common/proxy/change-context.d.ts.map +1 -0
  231. package/dist/types/src/internal/common/proxy/change.test.d.ts.map +1 -0
  232. package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts.map +1 -0
  233. package/dist/types/src/internal/{proxy → common/proxy}/errors.d.ts +1 -1
  234. package/dist/types/src/internal/common/proxy/errors.d.ts.map +1 -0
  235. package/dist/types/src/internal/common/proxy/event-batch.d.ts.map +1 -0
  236. package/dist/types/src/internal/common/proxy/handler.test.d.ts.map +1 -0
  237. package/dist/types/src/internal/common/proxy/index.d.ts.map +1 -0
  238. package/dist/types/src/internal/common/proxy/json-serializer.d.ts.map +1 -0
  239. package/dist/types/src/internal/common/proxy/make-object.d.ts.map +1 -0
  240. package/dist/types/src/internal/common/proxy/ownership.d.ts.map +1 -0
  241. package/dist/types/src/internal/common/proxy/proxy-types.d.ts.map +1 -0
  242. package/dist/types/src/internal/common/proxy/proxy-utils.d.ts.map +1 -0
  243. package/dist/types/src/internal/{proxy → common/proxy}/reactive-array.d.ts +1 -1
  244. package/dist/types/src/internal/common/proxy/reactive-array.d.ts.map +1 -0
  245. package/dist/types/src/internal/{proxy → common/proxy}/reactive.d.ts +2 -2
  246. package/dist/types/src/internal/{proxy → common/proxy}/reactive.d.ts.map +1 -1
  247. package/dist/types/src/internal/common/proxy/reactive.test.d.ts +2 -0
  248. package/dist/types/src/internal/common/proxy/reactive.test.d.ts.map +1 -0
  249. package/dist/types/src/internal/common/proxy/schema-validator.d.ts.map +1 -0
  250. package/dist/types/src/internal/common/proxy/schema.test.d.ts.map +1 -0
  251. package/dist/types/src/internal/common/proxy/symbols.d.ts.map +1 -0
  252. package/dist/types/src/internal/common/proxy/typed-handler.d.ts.map +1 -0
  253. package/dist/types/src/internal/common/proxy/typed-handler.test.d.ts.map +1 -0
  254. package/dist/types/src/internal/common/proxy/typed-object.test.d.ts.map +1 -0
  255. package/dist/types/src/internal/common/types/base.d.ts.map +1 -0
  256. package/dist/types/src/internal/{types → common/types}/entity.d.ts +4 -4
  257. package/dist/types/src/internal/common/types/entity.d.ts.map +1 -0
  258. package/dist/types/src/internal/{types → common/types}/index.d.ts +1 -0
  259. package/dist/types/src/internal/common/types/index.d.ts.map +1 -0
  260. package/dist/types/src/internal/{types → common/types}/meta.d.ts +13 -3
  261. package/dist/types/src/internal/common/types/meta.d.ts.map +1 -0
  262. package/dist/types/src/internal/common/types/model-symbols.d.ts +54 -0
  263. package/dist/types/src/internal/common/types/model-symbols.d.ts.map +1 -0
  264. package/dist/types/src/internal/common/types/typename.d.ts.map +1 -0
  265. package/dist/types/src/internal/{types → common/types}/version.d.ts +1 -1
  266. package/dist/types/src/internal/common/types/version.d.ts.map +1 -0
  267. package/dist/types/src/internal/index.d.ts +9 -10
  268. package/dist/types/src/internal/index.d.ts.map +1 -1
  269. package/dist/types/src/testing/test-data.d.ts +8 -8
  270. package/dist/types/src/testing/test-data.d.ts.map +1 -1
  271. package/dist/types/src/testing/test-schema.d.ts +53 -53
  272. package/dist/types/src/testing/test-schema.d.ts.map +1 -1
  273. package/dist/types/src/testing/util.d.ts.map +1 -1
  274. package/dist/types/tsconfig.tsbuildinfo +1 -1
  275. package/package.json +25 -15
  276. package/src/Annotation.ts +6 -3
  277. package/src/Collection.ts +8 -1
  278. package/src/Database.ts +55 -18
  279. package/src/Dataset.ts +2 -0
  280. package/src/Entity.ts +20 -11
  281. package/src/Err.ts +2 -0
  282. package/src/Extension.test.ts +235 -0
  283. package/src/Extension.ts +122 -0
  284. package/src/Feed.ts +118 -37
  285. package/src/Filter.test.ts +90 -0
  286. package/src/Filter.ts +99 -3
  287. package/src/Format.ts +1 -1
  288. package/src/Hypergraph.ts +10 -5
  289. package/src/Json.test.ts +175 -0
  290. package/src/Json.ts +102 -0
  291. package/src/JsonSchema.ts +7 -5
  292. package/src/Migration.ts +106 -0
  293. package/src/Obj.test.ts +107 -15
  294. package/src/Obj.ts +167 -40
  295. package/src/Order.ts +2 -0
  296. package/src/Query.test.ts +222 -32
  297. package/src/Query.ts +62 -10
  298. package/src/Ref.ts +16 -12
  299. package/src/Relation.test.ts +2 -2
  300. package/src/Relation.ts +28 -21
  301. package/src/SchemaRegistry.ts +1 -1
  302. package/src/Tag.ts +3 -1
  303. package/src/Type.ts +14 -11
  304. package/src/View.ts +9 -2
  305. package/src/exemplars.test.ts +21 -0
  306. package/src/index.ts +4 -0
  307. package/src/internal/{annotations → Annotation}/annotations.test.ts +56 -7
  308. package/src/internal/{annotations → Annotation}/annotations.ts +84 -20
  309. package/src/internal/{annotations → Annotation}/index.ts +1 -0
  310. package/src/internal/{api → Annotation}/sorting.ts +2 -4
  311. package/src/internal/{annotations → Annotation}/util.ts +1 -1
  312. package/src/internal/{api/entity.ts → Entity/api.ts} +3 -2
  313. package/src/internal/{entities → Entity}/entity.ts +2 -2
  314. package/src/internal/{entities → Entity}/index.ts +2 -0
  315. package/src/internal/{entities → Entity}/model.ts +15 -42
  316. package/src/internal/{entities → Entity}/object.ts +2 -3
  317. package/src/internal/{entities → Entity}/relation.ts +19 -36
  318. package/src/internal/{api → Entity}/version.ts +2 -2
  319. package/src/internal/{formats → Format}/date.test.ts +1 -2
  320. package/src/internal/{formats → Format}/format.test.ts +1 -2
  321. package/src/internal/{formats → Format}/types.ts +2 -2
  322. package/src/internal/{json-schema → JsonSchema}/annotations.ts +3 -3
  323. package/src/internal/{json-schema → JsonSchema}/json-schema-type.ts +4 -4
  324. package/src/internal/{json-schema → JsonSchema}/json-schema.test.ts +48 -49
  325. package/src/internal/{json-schema → JsonSchema}/json-schema.ts +3 -4
  326. package/src/internal/{object → Obj}/clone.ts +3 -3
  327. package/src/internal/{object → Obj}/common.ts +2 -2
  328. package/src/internal/{object → Obj}/create-object.test.ts +5 -7
  329. package/src/internal/{object → Obj}/create-object.ts +5 -6
  330. package/src/internal/{object → Obj}/deleted.ts +2 -2
  331. package/src/internal/{object → Obj}/ids.ts +1 -1
  332. package/src/internal/{object → Obj}/inspect.ts +2 -2
  333. package/src/internal/{object → Obj}/json-serializer.test.ts +8 -9
  334. package/src/internal/{object → Obj}/json-serializer.ts +44 -26
  335. package/src/internal/{object → Obj}/schema-validator.ts +1 -1
  336. package/src/internal/{object → Obj}/set-value.test.ts +24 -24
  337. package/src/internal/{object → Obj}/set-value.ts +3 -3
  338. package/src/internal/{object → Obj}/snapshot.ts +14 -5
  339. package/src/internal/{object → Obj}/typed-object.test.ts +3 -3
  340. package/src/internal/{object → Obj}/typed-object.ts +2 -2
  341. package/src/internal/Query.ts +156 -0
  342. package/src/internal/{ref → Ref}/ref-array.ts +1 -2
  343. package/src/internal/{ref → Ref}/ref.test.ts +4 -5
  344. package/src/internal/{ref → Ref}/ref.ts +20 -3
  345. package/src/internal/{schema → Type}/compose.test.ts +5 -6
  346. package/src/internal/{schema → Type}/compose.ts +1 -1
  347. package/src/internal/{schema → Type}/echo-schema.ts +7 -8
  348. package/src/internal/{schema → Type}/manipulation.ts +1 -1
  349. package/src/internal/{schema → Type}/persistent-schema.ts +7 -7
  350. package/src/internal/{README.md → common/README.md} +1 -1
  351. package/src/internal/{api → common/api}/index.ts +0 -4
  352. package/src/internal/{api → common/api}/meta.ts +3 -3
  353. package/src/internal/common/index.ts +7 -0
  354. package/src/internal/{proxy → common/proxy}/change-context.ts +1 -1
  355. package/src/internal/{proxy → common/proxy}/change.test.ts +97 -97
  356. package/src/internal/{proxy → common/proxy}/errors.ts +2 -2
  357. package/src/internal/{proxy → common/proxy}/handler.test.ts +2 -4
  358. package/src/internal/{proxy → common/proxy}/json-serializer.ts +6 -3
  359. package/src/internal/{proxy → common/proxy}/make-object.ts +1 -2
  360. package/src/internal/{proxy → common/proxy}/ownership.ts +0 -1
  361. package/src/internal/{proxy → common/proxy}/reactive-array.ts +1 -1
  362. package/src/internal/common/proxy/reactive.test.ts +54 -0
  363. package/src/internal/{proxy → common/proxy}/reactive.ts +12 -4
  364. package/src/internal/{proxy → common/proxy}/schema.test.ts +10 -10
  365. package/src/internal/{proxy → common/proxy}/typed-handler.test.ts +6 -7
  366. package/src/internal/{proxy → common/proxy}/typed-handler.ts +10 -13
  367. package/src/internal/{proxy → common/proxy}/typed-object.test.ts +5 -6
  368. package/src/internal/{types → common/types}/entity.ts +1 -1
  369. package/src/internal/{types → common/types}/index.ts +1 -0
  370. package/src/internal/{types → common/types}/meta.ts +13 -2
  371. package/src/internal/common/types/model-symbols.ts +69 -0
  372. package/src/internal/index.ts +9 -31
  373. package/src/testing/api.test.ts +2 -3
  374. package/src/testing/test-data.ts +157 -98
  375. package/src/testing/test-schema.ts +9 -9
  376. package/dist/lib/neutral/chunk-5ELDDYWE.mjs.map +0 -7
  377. package/dist/lib/neutral/chunk-ALOGSVBP.mjs.map +0 -7
  378. package/dist/lib/neutral/chunk-AQP4QKYP.mjs.map +0 -7
  379. package/dist/lib/neutral/chunk-BRJSLACP.mjs.map +0 -7
  380. package/dist/lib/neutral/chunk-F7KMHDPJ.mjs.map +0 -7
  381. package/dist/lib/neutral/chunk-GAWKQ5DZ.mjs.map +0 -7
  382. package/dist/lib/neutral/chunk-GFNCSK7F.mjs +0 -101
  383. package/dist/lib/neutral/chunk-GFNCSK7F.mjs.map +0 -7
  384. package/dist/lib/neutral/chunk-KGV3QIRX.mjs.map +0 -7
  385. package/dist/lib/neutral/chunk-M2KVTHZM.mjs.map +0 -7
  386. package/dist/lib/neutral/chunk-MXQJZCPY.mjs.map +0 -7
  387. package/dist/lib/neutral/chunk-O3TZFQCT.mjs.map +0 -7
  388. package/dist/lib/neutral/chunk-OVUBTQLT.mjs.map +0 -7
  389. package/dist/lib/neutral/chunk-PP4DNUZU.mjs.map +0 -7
  390. package/dist/lib/neutral/chunk-QXF3LGN2.mjs.map +0 -7
  391. package/dist/lib/neutral/chunk-T4MPQJ7X.mjs.map +0 -7
  392. package/dist/lib/neutral/chunk-W7OP5HGZ.mjs.map +0 -7
  393. package/dist/lib/neutral/chunk-ZTUBYOGB.mjs.map +0 -7
  394. package/dist/lib/neutral/chunk-ZWKJ4LZJ.mjs.map +0 -7
  395. package/dist/types/src/internal/annotations/annotations.d.ts.map +0 -1
  396. package/dist/types/src/internal/annotations/annotations.test.d.ts.map +0 -1
  397. package/dist/types/src/internal/annotations/index.d.ts +0 -3
  398. package/dist/types/src/internal/annotations/index.d.ts.map +0 -1
  399. package/dist/types/src/internal/annotations/util.d.ts.map +0 -1
  400. package/dist/types/src/internal/api/annotations.d.ts +0 -23
  401. package/dist/types/src/internal/api/annotations.d.ts.map +0 -1
  402. package/dist/types/src/internal/api/entity.d.ts.map +0 -1
  403. package/dist/types/src/internal/api/index.d.ts.map +0 -1
  404. package/dist/types/src/internal/api/meta.d.ts.map +0 -1
  405. package/dist/types/src/internal/api/sorting.d.ts.map +0 -1
  406. package/dist/types/src/internal/api/version.d.ts.map +0 -1
  407. package/dist/types/src/internal/entities/entity.d.ts.map +0 -1
  408. package/dist/types/src/internal/entities/index.d.ts.map +0 -1
  409. package/dist/types/src/internal/entities/model.d.ts.map +0 -1
  410. package/dist/types/src/internal/entities/object.d.ts.map +0 -1
  411. package/dist/types/src/internal/entities/relation.d.ts.map +0 -1
  412. package/dist/types/src/internal/entities/util.d.ts.map +0 -1
  413. package/dist/types/src/internal/formats/date.d.ts.map +0 -1
  414. package/dist/types/src/internal/formats/date.test.d.ts.map +0 -1
  415. package/dist/types/src/internal/formats/format.d.ts.map +0 -1
  416. package/dist/types/src/internal/formats/format.test.d.ts.map +0 -1
  417. package/dist/types/src/internal/formats/index.d.ts.map +0 -1
  418. package/dist/types/src/internal/formats/number.d.ts.map +0 -1
  419. package/dist/types/src/internal/formats/object.d.ts.map +0 -1
  420. package/dist/types/src/internal/formats/select.d.ts.map +0 -1
  421. package/dist/types/src/internal/formats/string.d.ts.map +0 -1
  422. package/dist/types/src/internal/formats/types.d.ts.map +0 -1
  423. package/dist/types/src/internal/json-schema/annotations.d.ts.map +0 -1
  424. package/dist/types/src/internal/json-schema/effect-schema.test.d.ts.map +0 -1
  425. package/dist/types/src/internal/json-schema/index.d.ts.map +0 -1
  426. package/dist/types/src/internal/json-schema/json-schema-normalize.d.ts.map +0 -1
  427. package/dist/types/src/internal/json-schema/json-schema-type.d.ts.map +0 -1
  428. package/dist/types/src/internal/json-schema/json-schema.d.ts.map +0 -1
  429. package/dist/types/src/internal/json-schema/json-schema.test.d.ts.map +0 -1
  430. package/dist/types/src/internal/object/clone.d.ts.map +0 -1
  431. package/dist/types/src/internal/object/common.d.ts.map +0 -1
  432. package/dist/types/src/internal/object/create-object.d.ts.map +0 -1
  433. package/dist/types/src/internal/object/create-object.test.d.ts.map +0 -1
  434. package/dist/types/src/internal/object/deleted.d.ts.map +0 -1
  435. package/dist/types/src/internal/object/ids.d.ts.map +0 -1
  436. package/dist/types/src/internal/object/index.d.ts.map +0 -1
  437. package/dist/types/src/internal/object/inspect.d.ts.map +0 -1
  438. package/dist/types/src/internal/object/json-serializer.d.ts.map +0 -1
  439. package/dist/types/src/internal/object/json-serializer.test.d.ts.map +0 -1
  440. package/dist/types/src/internal/object/schema-validator.d.ts +0 -2
  441. package/dist/types/src/internal/object/schema-validator.d.ts.map +0 -1
  442. package/dist/types/src/internal/object/schema-validator.test.d.ts.map +0 -1
  443. package/dist/types/src/internal/object/set-value.d.ts.map +0 -1
  444. package/dist/types/src/internal/object/set-value.test.d.ts.map +0 -1
  445. package/dist/types/src/internal/object/snapshot.d.ts.map +0 -1
  446. package/dist/types/src/internal/object/typed-object.d.ts.map +0 -1
  447. package/dist/types/src/internal/object/typed-object.test.d.ts.map +0 -1
  448. package/dist/types/src/internal/proxy/change-context.d.ts.map +0 -1
  449. package/dist/types/src/internal/proxy/change.test.d.ts.map +0 -1
  450. package/dist/types/src/internal/proxy/define-hidden-property.d.ts.map +0 -1
  451. package/dist/types/src/internal/proxy/errors.d.ts.map +0 -1
  452. package/dist/types/src/internal/proxy/event-batch.d.ts.map +0 -1
  453. package/dist/types/src/internal/proxy/handler.test.d.ts.map +0 -1
  454. package/dist/types/src/internal/proxy/index.d.ts.map +0 -1
  455. package/dist/types/src/internal/proxy/json-serializer.d.ts.map +0 -1
  456. package/dist/types/src/internal/proxy/make-object.d.ts.map +0 -1
  457. package/dist/types/src/internal/proxy/ownership.d.ts.map +0 -1
  458. package/dist/types/src/internal/proxy/proxy-types.d.ts.map +0 -1
  459. package/dist/types/src/internal/proxy/proxy-utils.d.ts.map +0 -1
  460. package/dist/types/src/internal/proxy/reactive-array.d.ts.map +0 -1
  461. package/dist/types/src/internal/proxy/schema-validator.d.ts.map +0 -1
  462. package/dist/types/src/internal/proxy/schema.test.d.ts.map +0 -1
  463. package/dist/types/src/internal/proxy/symbols.d.ts.map +0 -1
  464. package/dist/types/src/internal/proxy/typed-handler.d.ts.map +0 -1
  465. package/dist/types/src/internal/proxy/typed-handler.test.d.ts.map +0 -1
  466. package/dist/types/src/internal/proxy/typed-object.test.d.ts.map +0 -1
  467. package/dist/types/src/internal/ref/index.d.ts.map +0 -1
  468. package/dist/types/src/internal/ref/ref-array.d.ts.map +0 -1
  469. package/dist/types/src/internal/ref/ref.d.ts.map +0 -1
  470. package/dist/types/src/internal/ref/ref.test.d.ts.map +0 -1
  471. package/dist/types/src/internal/schema/compose.d.ts.map +0 -1
  472. package/dist/types/src/internal/schema/compose.test.d.ts.map +0 -1
  473. package/dist/types/src/internal/schema/echo-schema.d.ts.map +0 -1
  474. package/dist/types/src/internal/schema/index.d.ts.map +0 -1
  475. package/dist/types/src/internal/schema/manipulation.d.ts.map +0 -1
  476. package/dist/types/src/internal/schema/persistent-schema.d.ts.map +0 -1
  477. package/dist/types/src/internal/types/base.d.ts.map +0 -1
  478. package/dist/types/src/internal/types/entity.d.ts.map +0 -1
  479. package/dist/types/src/internal/types/index.d.ts.map +0 -1
  480. package/dist/types/src/internal/types/meta.d.ts.map +0 -1
  481. package/dist/types/src/internal/types/typename.d.ts.map +0 -1
  482. package/dist/types/src/internal/types/version.d.ts.map +0 -1
  483. package/src/internal/api/annotations.ts +0 -60
  484. /package/dist/lib/neutral/{chunk-ANHVGJI4.mjs.map → chunk-7RVZT53K.mjs.map} +0 -0
  485. /package/dist/lib/neutral/{chunk-OMUPQMLR.mjs.map → chunk-V72DY6LU.mjs.map} +0 -0
  486. /package/dist/types/src/internal/{annotations → Annotation}/annotations.test.d.ts +0 -0
  487. /package/dist/types/src/internal/{entities → Entity}/util.d.ts +0 -0
  488. /package/dist/types/src/internal/{formats → Format}/date.d.ts +0 -0
  489. /package/dist/types/src/internal/{formats → Format}/date.test.d.ts +0 -0
  490. /package/dist/types/src/internal/{formats → Format}/format.d.ts +0 -0
  491. /package/dist/types/src/internal/{formats → Format}/format.test.d.ts +0 -0
  492. /package/dist/types/src/internal/{formats → Format}/index.d.ts +0 -0
  493. /package/dist/types/src/internal/{formats → Format}/number.d.ts +0 -0
  494. /package/dist/types/src/internal/{formats → Format}/object.d.ts +0 -0
  495. /package/dist/types/src/internal/{formats → Format}/select.d.ts +0 -0
  496. /package/dist/types/src/internal/{formats → Format}/string.d.ts +0 -0
  497. /package/dist/types/src/internal/{json-schema → JsonSchema}/effect-schema.test.d.ts +0 -0
  498. /package/dist/types/src/internal/{json-schema → JsonSchema}/index.d.ts +0 -0
  499. /package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema-normalize.d.ts +0 -0
  500. /package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema.test.d.ts +0 -0
  501. /package/dist/types/src/internal/{object → Obj}/clone.d.ts +0 -0
  502. /package/dist/types/src/internal/{object → Obj}/common.d.ts +0 -0
  503. /package/dist/types/src/internal/{object → Obj}/create-object.test.d.ts +0 -0
  504. /package/dist/types/src/internal/{object → Obj}/index.d.ts +0 -0
  505. /package/dist/types/src/internal/{object → Obj}/inspect.d.ts +0 -0
  506. /package/dist/types/src/internal/{object → Obj}/json-serializer.test.d.ts +0 -0
  507. /package/dist/types/src/internal/{object → Obj}/schema-validator.test.d.ts +0 -0
  508. /package/dist/types/src/internal/{object → Obj}/set-value.test.d.ts +0 -0
  509. /package/dist/types/src/internal/{object → Obj}/snapshot.d.ts +0 -0
  510. /package/dist/types/src/internal/{object → Obj}/typed-object.test.d.ts +0 -0
  511. /package/dist/types/src/internal/{ref → Ref}/index.d.ts +0 -0
  512. /package/dist/types/src/internal/{ref → Ref}/ref.test.d.ts +0 -0
  513. /package/dist/types/src/internal/{schema → Type}/compose.test.d.ts +0 -0
  514. /package/dist/types/src/internal/{schema → Type}/index.d.ts +0 -0
  515. /package/dist/types/src/internal/{schema → Type}/manipulation.d.ts +0 -0
  516. /package/dist/types/src/internal/{proxy → common/proxy}/change.test.d.ts +0 -0
  517. /package/dist/types/src/internal/{proxy → common/proxy}/define-hidden-property.d.ts +0 -0
  518. /package/dist/types/src/internal/{proxy → common/proxy}/event-batch.d.ts +0 -0
  519. /package/dist/types/src/internal/{proxy → common/proxy}/handler.test.d.ts +0 -0
  520. /package/dist/types/src/internal/{proxy → common/proxy}/index.d.ts +0 -0
  521. /package/dist/types/src/internal/{proxy → common/proxy}/json-serializer.d.ts +0 -0
  522. /package/dist/types/src/internal/{proxy → common/proxy}/make-object.d.ts +0 -0
  523. /package/dist/types/src/internal/{proxy → common/proxy}/ownership.d.ts +0 -0
  524. /package/dist/types/src/internal/{proxy → common/proxy}/proxy-types.d.ts +0 -0
  525. /package/dist/types/src/internal/{proxy → common/proxy}/proxy-utils.d.ts +0 -0
  526. /package/dist/types/src/internal/{proxy → common/proxy}/schema-validator.d.ts +0 -0
  527. /package/dist/types/src/internal/{proxy → common/proxy}/schema.test.d.ts +0 -0
  528. /package/dist/types/src/internal/{proxy → common/proxy}/symbols.d.ts +0 -0
  529. /package/dist/types/src/internal/{proxy → common/proxy}/typed-handler.d.ts +0 -0
  530. /package/dist/types/src/internal/{proxy → common/proxy}/typed-handler.test.d.ts +0 -0
  531. /package/dist/types/src/internal/{proxy → common/proxy}/typed-object.test.d.ts +0 -0
  532. /package/dist/types/src/internal/{types → common/types}/base.d.ts +0 -0
  533. /package/dist/types/src/internal/{types → common/types}/typename.d.ts +0 -0
  534. /package/src/internal/{entities → Entity}/util.ts +0 -0
  535. /package/src/internal/{formats → Format}/date.ts +0 -0
  536. /package/src/internal/{formats → Format}/format.ts +0 -0
  537. /package/src/internal/{formats → Format}/index.ts +0 -0
  538. /package/src/internal/{formats → Format}/number.ts +0 -0
  539. /package/src/internal/{formats → Format}/object.ts +0 -0
  540. /package/src/internal/{formats → Format}/select.ts +0 -0
  541. /package/src/internal/{formats → Format}/string.ts +0 -0
  542. /package/src/internal/{json-schema → JsonSchema}/effect-schema.test.ts +0 -0
  543. /package/src/internal/{json-schema → JsonSchema}/index.ts +0 -0
  544. /package/src/internal/{json-schema → JsonSchema}/json-schema-normalize.ts +0 -0
  545. /package/src/internal/{object → Obj}/index.ts +0 -0
  546. /package/src/internal/{object → Obj}/schema-validator.test.ts +0 -0
  547. /package/src/internal/{ref → Ref}/index.ts +0 -0
  548. /package/src/internal/{schema → Type}/index.ts +0 -0
  549. /package/src/internal/{proxy → common/proxy}/define-hidden-property.ts +0 -0
  550. /package/src/internal/{proxy → common/proxy}/event-batch.ts +0 -0
  551. /package/src/internal/{proxy → common/proxy}/index.ts +0 -0
  552. /package/src/internal/{proxy → common/proxy}/proxy-types.ts +0 -0
  553. /package/src/internal/{proxy → common/proxy}/proxy-utils.ts +0 -0
  554. /package/src/internal/{proxy → common/proxy}/schema-validator.ts +0 -0
  555. /package/src/internal/{proxy → common/proxy}/symbols.ts +0 -0
  556. /package/src/internal/{types → common/types}/base.ts +0 -0
  557. /package/src/internal/{types → common/types}/typename.ts +0 -0
  558. /package/src/internal/{types → common/types}/version.ts +0 -0
@@ -2,19 +2,17 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { inspect } from 'util';
6
-
7
5
  import * as Schema from 'effect/Schema';
6
+ import { inspect } from 'util';
8
7
  import { describe, expect, test } from 'vitest';
9
8
 
10
9
  import { DXN } from '@dxos/keys';
11
10
 
12
11
  import { Relation } from '../../index';
13
12
  import { TestSchema } from '../../testing';
14
- import { getSchemaDXN, getTypeDXN, isInstanceOf } from '../annotations';
15
- import { ATTR_RELATION_SOURCE, ATTR_RELATION_TARGET } from '../entities';
16
- import { ATTR_META, ATTR_TYPE, getSchema } from '../types';
17
-
13
+ import { getSchemaDXN, getTypeDXN, isInstanceOf } from '../Annotation';
14
+ import { ATTR_META, ATTR_TYPE, getSchema } from '../common/types';
15
+ import { ATTR_RELATION_SOURCE, ATTR_RELATION_TARGET } from '../Entity';
18
16
  import { createObject } from './create-object';
19
17
  import { objectToJSON } from './json-serializer';
20
18
 
@@ -110,7 +108,7 @@ describe('create (static version)', () => {
110
108
  const text = inspect(contact);
111
109
  expect(text).toContain('Bot');
112
110
  expect(text).toContain('bot@example.com');
113
- expect(text).toContain('example.com/type/Person');
111
+ expect(text).toContain('com.example.type.person');
114
112
  expect(text).toContain('0.1.0');
115
113
  });
116
114
  });
@@ -8,7 +8,9 @@ import { raise } from '@dxos/debug';
8
8
  import { assertArgument, failedInvariant } from '@dxos/invariant';
9
9
  import { ObjectId } from '@dxos/keys';
10
10
 
11
- import { getSchemaDXN, getTypeAnnotation, setTypename } from '../annotations';
11
+ import { getSchemaDXN, getTypeAnnotation, setTypename } from '../Annotation';
12
+ import { defineHiddenProperty } from '../common/proxy';
13
+ import { EntityKind, KindId, MetaId, setSchema } from '../common/types';
12
14
  import {
13
15
  RelationSourceDXNId,
14
16
  RelationSourceId,
@@ -16,10 +18,7 @@ import {
16
18
  RelationTargetId,
17
19
  assertObjectModel,
18
20
  getObjectDXN,
19
- } from '../entities';
20
- import { defineHiddenProperty } from '../proxy';
21
- import { EntityKind, KindId, MetaId, setSchema } from '../types';
22
-
21
+ } from '../Entity';
23
22
  import { attachedTypedObjectInspector } from './inspect';
24
23
  import { attachTypedJsonSerializer } from './json-serializer';
25
24
 
@@ -42,7 +41,7 @@ export type CreateObjectProps<T> = T extends { id: string } ? Omit<T, 'id' | Kin
42
41
  * name: Schema.String,
43
42
  * email: Schema.String,
44
43
  * }).pipe(Type.object({
45
- * typename: 'example.com/type/Person',
44
+ * typename: 'com.example.type.person',
46
45
  * version: '0.1.0',
47
46
  * }))
48
47
  *
@@ -2,8 +2,8 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { ObjectDeletedId } from '../entities';
6
- import { type AnyProperties } from '../types';
5
+ import { type AnyProperties } from '../common/types';
6
+ import { ObjectDeletedId } from '../Entity';
7
7
 
8
8
  /**
9
9
  * @returns `true` if the object has been marked as deleted.
@@ -5,7 +5,7 @@
5
5
  import { DXN, ObjectId, QueueSubspaceTags, SpaceId } from '@dxos/keys';
6
6
 
7
7
  /**
8
- * @deprecated Use `db.queues.create()`
8
+ * @deprecated Use `Feed.make(...)` + `db.add(feed)` then `Feed.getQueueDxn(feed)`.
9
9
  */
10
10
  // TODO(burdon): Move to @dxos/keys.
11
11
  export const createQueueDXN = (spaceId = SpaceId.random(), queueId = ObjectId.random()) =>
@@ -6,8 +6,8 @@ import type { InspectOptionsStylized, inspect as inspectFn } from 'node:util';
6
6
 
7
7
  import { type CustomInspectFunction, inspectCustom } from '@dxos/debug';
8
8
 
9
- import { getTypeDXN } from '../annotations';
10
- import { ATTR_META, ATTR_TYPE, type AnyEntity, MetaId } from '../types';
9
+ import { getTypeDXN } from '../Annotation';
10
+ import { ATTR_META, ATTR_TYPE, type AnyEntity, MetaId } from '../common/types';
11
11
 
12
12
  /*
13
13
  * @internal
@@ -8,21 +8,20 @@ import { DXN } from '@dxos/keys';
8
8
 
9
9
  import * as Obj from '../../Obj';
10
10
  import { TestSchema } from '../../testing';
11
- import { getSchemaDXN, getSchemaTypename, getTypeDXN, getTypename } from '../annotations';
12
- import { getMetaChecked } from '../api';
13
- import { RelationSourceId, RelationTargetId, getObjectDXN } from '../entities';
14
- import { makeObject } from '../proxy';
15
- import { Ref, StaticRefResolver } from '../ref';
16
- import { ATTR_TYPE, EntityKind, KindId, MetaId, TypeId, getSchema } from '../types';
17
-
11
+ import { getSchemaDXN, getSchemaTypename, getTypeDXN, getTypename } from '../Annotation';
12
+ import { getMetaChecked } from '../common/api';
13
+ import { makeObject } from '../common/proxy';
14
+ import { ATTR_TYPE, EntityKind, KindId, MetaId, TypeId, getSchema } from '../common/types';
15
+ import { RelationSourceId, RelationTargetId, getObjectDXN } from '../Entity';
16
+ import { Ref, StaticRefResolver } from '../Ref';
18
17
  import { createObject } from './create-object';
19
18
  import { objectFromJSON, objectToJSON } from './json-serializer';
20
19
 
21
20
  describe('Object JSON serializer', () => {
22
21
  test('should serialize and deserialize object', async () => {
23
22
  const contact = makeObject(TestSchema.Person, { name: 'Alice' });
24
- Obj.change(contact, (c) => {
25
- getMetaChecked(c).keys.push({ id: '12345', source: 'example.com' });
23
+ Obj.update(contact, (contact) => {
24
+ getMetaChecked(contact).keys.push({ id: '12345', source: 'example.com' });
26
25
  });
27
26
 
28
27
  const task = createObject(TestSchema.Task, {
@@ -10,13 +10,28 @@ import { assertArgument, invariant } from '@dxos/invariant';
10
10
  import { DXN, ObjectId } from '@dxos/keys';
11
11
  import { assumeType, deepMapValues, visitValues } from '@dxos/util';
12
12
 
13
+ import type * as Database from '../../Database';
13
14
  import type * as Obj from '../../Obj';
14
- import { getTypeDXN, setTypename } from '../annotations';
15
+ import { getTypeDXN, setTypename } from '../Annotation';
16
+ import { attachTypedJsonSerializer, defineHiddenProperty, typedJsonSerializer } from '../common/proxy';
17
+ import {
18
+ ATTR_META,
19
+ ATTR_PARENT,
20
+ ATTR_TYPE,
21
+ type AnyEntity,
22
+ EntityKind,
23
+ KindId,
24
+ MetaId,
25
+ ObjectMetaSchema,
26
+ ParentId,
27
+ setSchema,
28
+ } from '../common/types';
15
29
  import {
16
30
  ATTR_DELETED,
17
31
  ATTR_RELATION_SOURCE,
18
32
  ATTR_RELATION_TARGET,
19
33
  ATTR_SELF_DXN,
34
+ ObjectDatabaseId,
20
35
  type ObjectJSON,
21
36
  RelationSourceDXNId,
22
37
  RelationSourceId,
@@ -24,21 +39,8 @@ import {
24
39
  RelationTargetId,
25
40
  SelfDXNId,
26
41
  assertObjectModel,
27
- } from '../entities';
28
- import { attachTypedJsonSerializer, defineHiddenProperty, typedJsonSerializer } from '../proxy';
29
- import { Ref, type RefResolver, refFromEncodedReference, setRefResolver } from '../ref';
30
- import {
31
- ATTR_META,
32
- ATTR_PARENT,
33
- ATTR_TYPE,
34
- type AnyEntity,
35
- EntityKind,
36
- KindId,
37
- MetaId,
38
- ObjectMetaSchema,
39
- ParentId,
40
- setSchema,
41
- } from '../types';
42
+ } from '../Entity';
43
+ import { Ref, type RefResolver, refFromEncodedReference, setRefResolver } from '../Ref';
42
44
 
43
45
  // Re-export for backward compatibility.
44
46
  export { attachTypedJsonSerializer };
@@ -70,10 +72,20 @@ export const objectToJSON = <T extends AnyEntity>(obj: T): SerializedObject<T> =
70
72
  * Performs schema validation.
71
73
  * References and schema will be resolvable if the `refResolver` is provided.
72
74
  * The function need to be async to support resolving the schema as well as the relation endpoints.
75
+ *
76
+ * @param jsonData - JSON representation of the object.
77
+ * @param options.refResolver - Resolver for references.
78
+ * @param options.dxn - Override object DXN.
79
+ * @param options.database - Database to associate with the object.
73
80
  */
74
81
  export const objectFromJSON = async (
75
82
  jsonData: unknown,
76
- { refResolver, dxn }: { refResolver?: RefResolver; dxn?: DXN } = {},
83
+ {
84
+ refResolver,
85
+ dxn,
86
+ database,
87
+ parent,
88
+ }: { refResolver?: RefResolver; dxn?: DXN; database?: Database.Database; parent?: Obj.Unknown } = {},
77
89
  ): Promise<AnyEntity> => {
78
90
  assumeType<ObjectJSON>(jsonData);
79
91
  assertArgument(typeof jsonData === 'object' && jsonData !== null, 'jsonData', 'expect object');
@@ -104,15 +116,15 @@ export const objectFromJSON = async (
104
116
  const isRelation =
105
117
  typeof jsonData[ATTR_RELATION_SOURCE] === 'string' || typeof jsonData[ATTR_RELATION_TARGET] === 'string';
106
118
  if (isRelation) {
107
- const sourceDxn: DXN = DXN.parse(jsonData[ATTR_RELATION_SOURCE] ?? raise(new TypeError('Missing relation source')));
108
- const targetDxn: DXN = DXN.parse(jsonData[ATTR_RELATION_TARGET] ?? raise(new TypeError('Missing relation target')));
119
+ const sourceDXN: DXN = DXN.parse(jsonData[ATTR_RELATION_SOURCE] ?? raise(new TypeError('Missing relation source')));
120
+ const targetDXN: DXN = DXN.parse(jsonData[ATTR_RELATION_TARGET] ?? raise(new TypeError('Missing relation target')));
109
121
 
110
- const source = (await refResolver?.resolve(sourceDxn)) as AnyEntity | undefined;
111
- const target = (await refResolver?.resolve(targetDxn)) as AnyEntity | undefined;
122
+ const source = (await refResolver?.resolve(sourceDXN)) as AnyEntity | undefined;
123
+ const target = (await refResolver?.resolve(targetDXN)) as AnyEntity | undefined;
112
124
 
113
125
  defineHiddenProperty(obj, KindId, EntityKind.Relation);
114
- defineHiddenProperty(obj, RelationSourceDXNId, sourceDxn);
115
- defineHiddenProperty(obj, RelationTargetDXNId, targetDxn);
126
+ defineHiddenProperty(obj, RelationSourceDXNId, sourceDXN);
127
+ defineHiddenProperty(obj, RelationTargetDXNId, targetDXN);
116
128
  defineHiddenProperty(obj, RelationSourceId, source);
117
129
  defineHiddenProperty(obj, RelationTargetId, target);
118
130
  } else {
@@ -130,8 +142,10 @@ export const objectFromJSON = async (
130
142
  }
131
143
 
132
144
  if (jsonData[ATTR_PARENT]) {
133
- const parentDxn = DXN.parse(jsonData[ATTR_PARENT]);
134
- const parent = (await refResolver?.resolve(parentDxn)) as Obj.Unknown | undefined;
145
+ const parentDXN = DXN.parse(jsonData[ATTR_PARENT]);
146
+ const resolvedParent = (await refResolver?.resolve(parentDXN)) as Obj.Unknown | undefined;
147
+ defineHiddenProperty(obj, ParentId, resolvedParent);
148
+ } else if (parent) {
135
149
  defineHiddenProperty(obj, ParentId, parent);
136
150
  }
137
151
 
@@ -139,6 +153,10 @@ export const objectFromJSON = async (
139
153
  defineHiddenProperty(obj, SelfDXNId, dxn);
140
154
  }
141
155
 
156
+ if (database) {
157
+ defineHiddenProperty(obj, ObjectDatabaseId, database);
158
+ }
159
+
142
160
  assertObjectModel(obj);
143
161
  invariant((obj as any)[ATTR_TYPE] === undefined, 'Invalid object model');
144
162
  invariant((obj as any)[ATTR_META] === undefined, 'Invalid object model');
@@ -166,7 +184,7 @@ const stripInternalJsonKeys = (jsonData: unknown) => {
166
184
  [ATTR_TYPE]: _type,
167
185
  [ATTR_META]: _meta,
168
186
  [ATTR_DELETED]: _deleted,
169
- [ATTR_SELF_DXN]: _selfDxn,
187
+ [ATTR_SELF_DXN]: _selfDXN,
170
188
  [ATTR_RELATION_SOURCE]: _relationSource,
171
189
  [ATTR_RELATION_TARGET]: _relationTarget,
172
190
  ...props
@@ -3,4 +3,4 @@
3
3
  //
4
4
 
5
5
  // Re-export from proxy for backward compatibility.
6
- export { SchemaValidator, checkIdNotPresentOnSchema } from '../proxy';
6
+ export { SchemaValidator, checkIdNotPresentOnSchema } from '../common/proxy';
@@ -17,7 +17,7 @@ describe('Obj.setValue', () => {
17
17
  email: 'john@example.com',
18
18
  });
19
19
 
20
- Obj.change(person, (p) => Obj.setValue(p, ['address', 'city'], 'NYC'));
20
+ Obj.update(person, (person) => Obj.setValue(person, ['address', 'city'], 'NYC'));
21
21
 
22
22
  expect(person.address).toBeDefined();
23
23
  expect(person.address?.city).toBe('NYC');
@@ -30,7 +30,7 @@ describe('Obj.setValue', () => {
30
30
  email: 'john@example.com',
31
31
  });
32
32
 
33
- Obj.change(person, (p) => Obj.setValue(p, ['fields', 0, 'label'], 'Phone'));
33
+ Obj.update(person, (person) => Obj.setValue(person, ['fields', 0, 'label'], 'Phone'));
34
34
 
35
35
  expect(Array.isArray(person.fields)).toBe(true);
36
36
  expect(person.fields?.[0].label).toBe('Phone');
@@ -45,7 +45,7 @@ describe('Obj.setValue', () => {
45
45
  email: 'john@example.com',
46
46
  });
47
47
 
48
- Obj.change(person, (p) => Obj.setValue(p, ['address', 'coordinates', 'lat'], 40.7128));
48
+ Obj.update(person, (person) => Obj.setValue(person, ['address', 'coordinates', 'lat'], 40.7128));
49
49
 
50
50
  expect(person.address).toBeDefined();
51
51
  expect(person.address?.coordinates).toBeDefined();
@@ -69,10 +69,10 @@ describe('Obj.setValue', () => {
69
69
 
70
70
  const container = Obj.make(Container, { name: 'box' });
71
71
 
72
- Obj.change(container, (c) => {
73
- Obj.setValue(c, ['items', 0, 'value'], 10);
74
- Obj.setValue(c, ['items', 1, 'value'], 20);
75
- Obj.setValue(c, ['items', 2, 'value'], 30);
72
+ Obj.update(container, (container) => {
73
+ Obj.setValue(container, ['items', 0, 'value'], 10);
74
+ Obj.setValue(container, ['items', 1, 'value'], 20);
75
+ Obj.setValue(container, ['items', 2, 'value'], 30);
76
76
  });
77
77
 
78
78
  expect(container.items).toHaveLength(3);
@@ -88,7 +88,7 @@ describe('Obj.setValue', () => {
88
88
  email: 'john@example.com',
89
89
  });
90
90
 
91
- Obj.change(person, (p) => Obj.setValue(p, ['age'], 25));
91
+ Obj.update(person, (person) => Obj.setValue(person, ['age'], 25));
92
92
 
93
93
  expect(person.age).toBe(25);
94
94
  });
@@ -100,7 +100,7 @@ describe('Obj.setValue', () => {
100
100
  email: 'john@example.com',
101
101
  });
102
102
 
103
- Obj.change(person, (p) => Obj.setValue(p, ['address', 'city'], 'NYC'));
103
+ Obj.update(person, (person) => Obj.setValue(person, ['address', 'city'], 'NYC'));
104
104
 
105
105
  expect(person.address).toBeDefined();
106
106
  expect(person.address?.city).toBe('NYC');
@@ -114,8 +114,8 @@ describe('Obj.setValue', () => {
114
114
  });
115
115
 
116
116
  let result: any;
117
- Obj.change(person, (p) => {
118
- result = Obj.setValue(p, ['age'], 30);
117
+ Obj.update(person, (person) => {
118
+ result = Obj.setValue(person, ['age'], 30);
119
119
  });
120
120
 
121
121
  expect(result).toBe(30);
@@ -129,7 +129,7 @@ describe('Obj.setValue', () => {
129
129
  age: 25,
130
130
  });
131
131
 
132
- Obj.change(person, (p) => Obj.setValue(p, ['age'], 30));
132
+ Obj.update(person, (person) => Obj.setValue(person, ['age'], 30));
133
133
 
134
134
  expect(person.age).toBe(30);
135
135
  });
@@ -142,7 +142,7 @@ describe('Obj.setValue', () => {
142
142
  address: { city: 'Boston', state: 'MA', coordinates: {} },
143
143
  });
144
144
 
145
- Obj.change(person, (p) => Obj.setValue(p, ['address', 'city'], 'NYC'));
145
+ Obj.update(person, (person) => Obj.setValue(person, ['address', 'city'], 'NYC'));
146
146
 
147
147
  expect(person.address?.city).toBe('NYC');
148
148
  expect(person.address?.state).toBe('MA');
@@ -160,11 +160,11 @@ describe('Obj.setValue', () => {
160
160
 
161
161
  const matrix = Obj.make(Matrix, {});
162
162
 
163
- Obj.change(matrix, (m) => {
164
- Obj.setValue(m, ['values', 0, 0], 1);
165
- Obj.setValue(m, ['values', 0, 1], 2);
166
- Obj.setValue(m, ['values', 1, 0], 3);
167
- Obj.setValue(m, ['values', 1, 1], 4);
163
+ Obj.update(matrix, (matrix) => {
164
+ Obj.setValue(matrix, ['values', 0, 0], 1);
165
+ Obj.setValue(matrix, ['values', 0, 1], 2);
166
+ Obj.setValue(matrix, ['values', 1, 0], 3);
167
+ Obj.setValue(matrix, ['values', 1, 1], 4);
168
168
  });
169
169
 
170
170
  expect(matrix.values?.[0][0]).toBe(1);
@@ -180,8 +180,8 @@ describe('Obj.setValue', () => {
180
180
  email: 'john@example.com',
181
181
  });
182
182
 
183
- Obj.change(person, (p) => {
184
- expect(() => Obj.setValue(p, [], 'value')).toThrow('Path must not be empty');
183
+ Obj.update(person, (person) => {
184
+ expect(() => Obj.setValue(person, [], 'value')).toThrow('Path must not be empty');
185
185
  });
186
186
  });
187
187
 
@@ -192,7 +192,7 @@ describe('Obj.setValue', () => {
192
192
  email: 'john@example.com',
193
193
  });
194
194
 
195
- Obj.change(person, (p) => Obj.setValue(p, ['age'], 30));
195
+ Obj.update(person, (person) => Obj.setValue(person, ['age'], 30));
196
196
 
197
197
  expect(person.age).toBe(30);
198
198
  });
@@ -215,7 +215,7 @@ describe('Obj.setValue', () => {
215
215
  const container = Obj.make(Container, { name: 'box' });
216
216
 
217
217
  // Using string '0' for array index.
218
- Obj.change(container, (c) => Obj.setValue(c, ['items', '0', 'value'], 42));
218
+ Obj.update(container, (container) => Obj.setValue(container, ['items', '0', 'value'], 42));
219
219
 
220
220
  expect(container.items?.[0].value).toBe(42);
221
221
  });
@@ -243,7 +243,7 @@ describe('Obj.setValue', () => {
243
243
 
244
244
  // This should work: setting a nested property on an array element.
245
245
  // The required 'id' field should be initialized with a default value.
246
- Obj.change(todoList, (t) => Obj.setValue(t, ['tasks', 0, 'title'], 'Buy groceries'));
246
+ Obj.update(todoList, (todoList) => Obj.setValue(todoList, ['tasks', 0, 'title'], 'Buy groceries'));
247
247
 
248
248
  expect(todoList.tasks?.[0].id).toBe(''); // Default value for required String
249
249
  expect(todoList.tasks?.[0].title).toBe('Buy groceries');
@@ -270,7 +270,7 @@ describe('Obj.setValue', () => {
270
270
 
271
271
  const container = Obj.make(Container, { name: 'box' });
272
272
 
273
- Obj.change(container, (c) => Obj.setValue(c, ['items', 0, 'label'], 'First Item'));
273
+ Obj.update(container, (container) => Obj.setValue(container, ['items', 0, 'label'], 'First Item'));
274
274
 
275
275
  // All required primitive fields should have default values.
276
276
  expect(container.items?.[0].id).toBe('');
@@ -16,12 +16,12 @@ import {
16
16
  } from '@dxos/effect';
17
17
  import { invariant } from '@dxos/invariant';
18
18
 
19
- import { type Mutable } from '../proxy';
20
- import { getSchema } from '../types';
19
+ import { type Mutable } from '../common/proxy';
20
+ import { getSchema } from '../common/types';
21
21
 
22
22
  /**
23
23
  * Set a deeply nested property on an object.
24
- * Must be called within an Obj.change or Relation.change callback.
24
+ * Must be called within an Obj.update or Relation.update callback.
25
25
  */
26
26
  export const setValue = (obj: Mutable<any>, path: readonly (string | number)[], value: any): void => {
27
27
  invariant(path.length > 0, 'Path must not be empty');
@@ -5,11 +5,20 @@
5
5
  import { assertArgument } from '@dxos/invariant';
6
6
  import { deepMapValues } from '@dxos/util';
7
7
 
8
- import { ObjectDatabaseId, ObjectDeletedId, SelfDXNId } from '../entities/model';
9
- import { RelationSourceDXNId, RelationSourceId, RelationTargetDXNId, RelationTargetId } from '../entities/relation';
10
- import { KindId, SnapshotKindId } from '../types/entity';
11
- import { MetaId } from '../types/meta';
12
- import { SchemaId, TypeId } from '../types/typename';
8
+ import {
9
+ KindId,
10
+ MetaId,
11
+ ObjectDatabaseId,
12
+ ObjectDeletedId,
13
+ RelationSourceDXNId,
14
+ RelationSourceId,
15
+ RelationTargetDXNId,
16
+ RelationTargetId,
17
+ SchemaId,
18
+ SelfDXNId,
19
+ SnapshotKindId,
20
+ TypeId,
21
+ } from '../common/types';
13
22
 
14
23
  /**
15
24
  * Copy a Symbol-keyed property from source to target if it has a defined value.
@@ -6,13 +6,13 @@ import * as Schema from 'effect/Schema';
6
6
  import * as SchemaAST from 'effect/SchemaAST';
7
7
  import { describe, expect, test } from 'vitest';
8
8
 
9
- import { EchoObjectSchema } from '../entities';
9
+ import { EchoObjectSchema } from '../Entity';
10
10
 
11
11
  const Organization = Schema.Struct({
12
12
  name: Schema.String,
13
13
  }).pipe(
14
14
  EchoObjectSchema({
15
- typename: 'example.com/type/Organization',
15
+ typename: 'com.example.type.organization',
16
16
  version: '0.1.0',
17
17
  }),
18
18
  );
@@ -25,7 +25,7 @@ describe('EchoObjectSchema DSL', () => {
25
25
  });
26
26
 
27
27
  test('static typename accessor', async () => {
28
- expect(Organization.typename).to.eq('example.com/type/Organization');
28
+ expect(Organization.typename).to.eq('com.example.type.organization');
29
29
  });
30
30
 
31
31
  test('expect schema', async () => {
@@ -4,8 +4,8 @@
4
4
 
5
5
  import type * as Schema from 'effect/Schema';
6
6
 
7
- import { type TypeMeta } from '../annotations';
8
- import { type AnyEntity } from '../types';
7
+ import { type TypeMeta } from '../Annotation';
8
+ import { type AnyEntity } from '../common/types';
9
9
 
10
10
  /**
11
11
  * Definition for an object type that can be stored in an ECHO database.
@@ -0,0 +1,156 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type QueryAST } from '@dxos/echo-protocol';
6
+
7
+ /**
8
+ * Returns a human-readable string representation of a Filter AST.
9
+ */
10
+ export const prettyFilter = (filter: QueryAST.Filter): string => {
11
+ switch (filter.type) {
12
+ case 'object': {
13
+ // A type-less object filter with only a meta-key constraint is `Filter.key(...)`.
14
+ if (
15
+ filter.typename === null &&
16
+ (filter.id === undefined || filter.id.length === 0) &&
17
+ Object.keys(filter.props).length === 0 &&
18
+ (filter.foreignKeys === undefined || filter.foreignKeys.length === 0) &&
19
+ filter.metaKey !== undefined
20
+ ) {
21
+ return filter.metaVersion !== undefined
22
+ ? `Filter.key(${JSON.stringify(filter.metaKey)}, { version: ${JSON.stringify(filter.metaVersion)} })`
23
+ : `Filter.key(${JSON.stringify(filter.metaKey)})`;
24
+ }
25
+ const parts: string[] = [];
26
+ if (filter.typename !== null) {
27
+ parts.push(String(filter.typename));
28
+ }
29
+ if (filter.id !== undefined && filter.id.length > 0) {
30
+ parts.push(`id: [${filter.id.join(', ')}]`);
31
+ }
32
+ const propEntries = Object.entries(filter.props);
33
+ if (propEntries.length > 0) {
34
+ const propsStr = propEntries.map(([k, v]) => `${k}: ${prettyFilter(v)}`).join(', ');
35
+ parts.push(`{ ${propsStr} }`);
36
+ }
37
+ if (filter.foreignKeys !== undefined && filter.foreignKeys.length > 0) {
38
+ parts.push(`foreignKeys: [${filter.foreignKeys.map((fk) => JSON.stringify(fk)).join(', ')}]`);
39
+ }
40
+ if (filter.metaKey !== undefined) {
41
+ parts.push(
42
+ filter.metaVersion !== undefined
43
+ ? `metaKey: ${JSON.stringify(filter.metaKey)} (${filter.metaVersion})`
44
+ : `metaKey: ${JSON.stringify(filter.metaKey)}`,
45
+ );
46
+ }
47
+ return parts.length > 0 ? `Filter.type(${parts.join(', ')})` : 'Filter.everything()';
48
+ }
49
+ case 'compare':
50
+ return `Filter.${filter.operator}(${JSON.stringify(filter.value)})`;
51
+ case 'in':
52
+ return `Filter.in([${filter.values.map((v) => JSON.stringify(v)).join(', ')}])`;
53
+ case 'contains':
54
+ return `Filter.contains(${JSON.stringify(filter.value)})`;
55
+ case 'tag':
56
+ return `Filter.tag(${JSON.stringify(filter.tag)})`;
57
+ case 'range':
58
+ return `Filter.range(${JSON.stringify(filter.from)}, ${JSON.stringify(filter.to)})`;
59
+ case 'text-search':
60
+ return filter.searchKind
61
+ ? `Filter.textSearch(${JSON.stringify(filter.text)}, ${JSON.stringify(filter.searchKind)})`
62
+ : `Filter.textSearch(${JSON.stringify(filter.text)})`;
63
+ case 'timestamp':
64
+ return `Filter.${filter.field}.${filter.operator}(${filter.value})`;
65
+ case 'child-of':
66
+ return `Filter.childOf([${filter.parents.map((p) => JSON.stringify(p)).join(', ')}], { transitive: ${filter.transitive} })`;
67
+ case 'not':
68
+ return `Filter.not(${prettyFilter(filter.filter)})`;
69
+ case 'and':
70
+ return `Filter.and(${filter.filters.map(prettyFilter).join(', ')})`;
71
+ case 'or':
72
+ return `Filter.or(${filter.filters.map(prettyFilter).join(', ')})`;
73
+ }
74
+ };
75
+
76
+ /**
77
+ * Returns a human-readable string representation of a Query AST.
78
+ */
79
+ export const prettyQuery = (query: QueryAST.Query): string => {
80
+ switch (query.type) {
81
+ case 'select':
82
+ return `Query.select(${prettyFilter(query.filter)})`;
83
+ case 'filter':
84
+ return `${prettyQuery(query.selection)}.select(${prettyFilter(query.filter)})`;
85
+ case 'reference-traversal':
86
+ return `${prettyQuery(query.anchor)}.reference(${JSON.stringify(query.property)})`;
87
+ case 'incoming-references': {
88
+ const args: string[] = [];
89
+ if (query.typename !== null) {
90
+ args.push(String(query.typename));
91
+ }
92
+ if (query.property !== null) {
93
+ args.push(JSON.stringify(query.property));
94
+ }
95
+ return `${prettyQuery(query.anchor)}.referencedBy(${args.join(', ')})`;
96
+ }
97
+ case 'relation': {
98
+ const method =
99
+ query.direction === 'outgoing' ? 'sourceOf' : query.direction === 'incoming' ? 'targetOf' : 'relationOf';
100
+ const filterStr = query.filter !== undefined ? prettyFilter(query.filter) : '';
101
+ return `${prettyQuery(query.anchor)}.${method}(${filterStr})`;
102
+ }
103
+ case 'relation-traversal':
104
+ return `${prettyQuery(query.anchor)}.${query.direction}()`;
105
+ case 'hierarchy-traversal':
106
+ return query.direction === 'to-parent'
107
+ ? `${prettyQuery(query.anchor)}.parent()`
108
+ : `${prettyQuery(query.anchor)}.children()`;
109
+ case 'union':
110
+ return `Query.all(${query.queries.map(prettyQuery).join(', ')})`;
111
+ case 'set-difference':
112
+ return `Query.without(${prettyQuery(query.source)}, ${prettyQuery(query.exclude)})`;
113
+ case 'order': {
114
+ const orders = query.order.map((o) => {
115
+ if (o.kind === 'natural') {
116
+ return 'Order.natural()';
117
+ } else if (o.kind === 'rank') {
118
+ return `Order.rank(${JSON.stringify(o.direction)})`;
119
+ } else {
120
+ return `Order.property(${JSON.stringify(o.property)}, ${JSON.stringify(o.direction)})`;
121
+ }
122
+ });
123
+ return `${prettyQuery(query.query)}.orderBy(${orders.join(', ')})`;
124
+ }
125
+ case 'options': {
126
+ const opts = query.options;
127
+ const parts: string[] = [];
128
+ if (opts.deleted !== undefined) {
129
+ parts.push(`deleted: ${JSON.stringify(opts.deleted)}`);
130
+ }
131
+ if (opts.debugLabel !== undefined) {
132
+ parts.push(`debugLabel: ${JSON.stringify(opts.debugLabel)}`);
133
+ }
134
+ return `${prettyQuery(query.query)}.options({ ${parts.join(', ')} })`;
135
+ }
136
+ case 'from': {
137
+ if (query.from._tag === 'scope') {
138
+ const scope = query.from.scope;
139
+ const parts: string[] = [];
140
+ if (scope.spaceIds !== undefined) {
141
+ parts.push(`spaceIds: [${scope.spaceIds.map((s) => JSON.stringify(s)).join(', ')}]`);
142
+ }
143
+ if (scope.feeds !== undefined) {
144
+ parts.push(`feeds: [${scope.feeds.map(String).join(', ')}]`);
145
+ }
146
+ if (scope.allFeedsFromSpaces !== undefined) {
147
+ parts.push(`allFeedsFromSpaces: ${scope.allFeedsFromSpaces}`);
148
+ }
149
+ return `${prettyQuery(query.query)}.from({ ${parts.join(', ')} })`;
150
+ }
151
+ return `${prettyQuery(query.query)}.from(${prettyQuery(query.from.query)})`;
152
+ }
153
+ case 'limit':
154
+ return `${prettyQuery(query.query)}.limit(${query.limit})`;
155
+ }
156
+ };
@@ -5,8 +5,7 @@
5
5
  import { type ObjectId } from '@dxos/keys';
6
6
  import { isNonNullable } from '@dxos/util';
7
7
 
8
- import { type AnyEntity } from '../types';
9
-
8
+ import { type AnyEntity } from '../common/types';
10
9
  import { Ref } from './ref';
11
10
 
12
11
  /**