@dxos/echo 0.8.4-main.d05673bc65 → 0.8.4-main.dfabb4ec29

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 (280) hide show
  1. package/README.md +2 -2
  2. package/dist/lib/neutral/Annotation.mjs +5 -3
  3. package/dist/lib/neutral/Database.mjs +8 -4
  4. package/dist/lib/neutral/Entity.mjs +16 -14
  5. package/dist/lib/neutral/Err.mjs +1 -1
  6. package/dist/lib/neutral/Extension.mjs +18 -0
  7. package/dist/lib/neutral/Extension.mjs.map +7 -0
  8. package/dist/lib/neutral/Feed.mjs +21 -17
  9. package/dist/lib/neutral/Filter.mjs +21 -13
  10. package/dist/lib/neutral/Format.mjs +3 -3
  11. package/dist/lib/neutral/JsonSchema.mjs +8 -8
  12. package/dist/lib/neutral/Key.mjs +1 -1
  13. package/dist/lib/neutral/Migration.mjs +17 -0
  14. package/dist/lib/neutral/Migration.mjs.map +7 -0
  15. package/dist/lib/neutral/Obj.mjs +16 -13
  16. package/dist/lib/neutral/Order.mjs +1 -1
  17. package/dist/lib/neutral/Query.mjs +19 -16
  18. package/dist/lib/neutral/QueryResult.mjs +1 -1
  19. package/dist/lib/neutral/Ref.mjs +7 -7
  20. package/dist/lib/neutral/Relation.mjs +15 -14
  21. package/dist/lib/neutral/SchemaRegistry.mjs +1 -1
  22. package/dist/lib/neutral/Tag.mjs +14 -13
  23. package/dist/lib/neutral/Type.mjs +10 -10
  24. package/dist/lib/neutral/{chunk-FZO7LQO7.mjs → chunk-44HT3MEC.mjs} +2 -2
  25. package/dist/lib/neutral/{chunk-OENWMTE6.mjs → chunk-5SL5LDLD.mjs} +4 -2
  26. package/dist/lib/neutral/chunk-5SL5LDLD.mjs.map +7 -0
  27. package/dist/lib/neutral/{chunk-YWXWXIE5.mjs → chunk-6VIJV543.mjs} +2 -2
  28. package/dist/lib/neutral/{chunk-YWXWXIE5.mjs.map → chunk-6VIJV543.mjs.map} +2 -2
  29. package/dist/lib/neutral/{chunk-ANHVGJI4.mjs → chunk-7RVZT53K.mjs} +1 -1
  30. package/dist/lib/neutral/{chunk-BNCCGLJN.mjs → chunk-BICZKPQG.mjs} +1 -1
  31. package/dist/lib/neutral/{chunk-NEGC54NE.mjs → chunk-FHYIM4RD.mjs} +17 -19
  32. package/dist/lib/neutral/chunk-FHYIM4RD.mjs.map +7 -0
  33. package/dist/lib/neutral/{chunk-RMLF7JOZ.mjs → chunk-FZHVQEHN.mjs} +6 -22
  34. package/dist/lib/neutral/{chunk-RMLF7JOZ.mjs.map → chunk-FZHVQEHN.mjs.map} +3 -3
  35. package/dist/lib/neutral/chunk-GWFFC34K.mjs +50 -0
  36. package/dist/lib/neutral/chunk-GWFFC34K.mjs.map +7 -0
  37. package/dist/lib/neutral/{chunk-724GQYEN.mjs → chunk-HPNQTEEQ.mjs} +4 -4
  38. package/dist/lib/neutral/{chunk-UFDK26FO.mjs → chunk-LVGOVFDV.mjs} +12 -8
  39. package/dist/lib/neutral/chunk-LVGOVFDV.mjs.map +7 -0
  40. package/dist/lib/neutral/{chunk-43Y5DOS6.mjs → chunk-MPAI2MHO.mjs} +16 -66
  41. package/dist/lib/neutral/chunk-MPAI2MHO.mjs.map +7 -0
  42. package/dist/lib/neutral/{chunk-WYOKA6AE.mjs → chunk-N4B7FHQT.mjs} +2 -2
  43. package/dist/lib/neutral/{chunk-WYOKA6AE.mjs.map → chunk-N4B7FHQT.mjs.map} +1 -1
  44. package/dist/lib/neutral/{chunk-BOZZPUXE.mjs → chunk-O5LRY6CO.mjs} +12 -65
  45. package/dist/lib/neutral/chunk-O5LRY6CO.mjs.map +7 -0
  46. package/dist/lib/neutral/{chunk-UTBRYVQC.mjs → chunk-QGMIH2SN.mjs} +2 -2
  47. package/dist/lib/neutral/{chunk-VA2F47ZC.mjs → chunk-QXIANHKU.mjs} +68 -14
  48. package/dist/lib/neutral/chunk-QXIANHKU.mjs.map +7 -0
  49. package/dist/lib/neutral/{chunk-NXMFBIT5.mjs → chunk-RF7ZBZ4A.mjs} +59 -4
  50. package/dist/lib/neutral/chunk-RF7ZBZ4A.mjs.map +7 -0
  51. package/dist/lib/neutral/{chunk-DYDJBZEG.mjs → chunk-S7IMFVTB.mjs} +51 -21
  52. package/dist/lib/neutral/chunk-S7IMFVTB.mjs.map +7 -0
  53. package/dist/lib/neutral/{chunk-TQQZLKB7.mjs → chunk-SJKBWMJY.mjs} +193 -469
  54. package/dist/lib/neutral/chunk-SJKBWMJY.mjs.map +7 -0
  55. package/dist/lib/neutral/chunk-SUZMWP3Y.mjs +36 -0
  56. package/dist/lib/neutral/chunk-SUZMWP3Y.mjs.map +7 -0
  57. package/dist/lib/neutral/{chunk-NQRLRYJM.mjs → chunk-SW5CUSBY.mjs} +119 -12
  58. package/dist/lib/neutral/chunk-SW5CUSBY.mjs.map +7 -0
  59. package/dist/lib/neutral/{chunk-SEMVAGBM.mjs → chunk-TNBK56IN.mjs} +19 -24
  60. package/dist/lib/neutral/chunk-TNBK56IN.mjs.map +7 -0
  61. package/dist/lib/neutral/{chunk-B5OXLWZL.mjs → chunk-TRPZU2HV.mjs} +2 -2
  62. package/dist/lib/neutral/{chunk-UI6MWK5W.mjs → chunk-TTCSATUD.mjs} +1 -1
  63. package/dist/lib/neutral/{chunk-OMUPQMLR.mjs → chunk-V72DY6LU.mjs} +1 -1
  64. package/dist/lib/neutral/{chunk-KTAWP7GI.mjs → chunk-VGKLHHRT.mjs} +42 -7
  65. package/dist/lib/neutral/chunk-VGKLHHRT.mjs.map +7 -0
  66. package/dist/lib/neutral/{chunk-FXEG7EOK.mjs → chunk-VYAGNFSJ.mjs} +3 -3
  67. package/dist/lib/neutral/{chunk-CIRHIEMW.mjs → chunk-WRVRDZDA.mjs} +18 -46
  68. package/dist/lib/neutral/chunk-WRVRDZDA.mjs.map +7 -0
  69. package/dist/lib/neutral/{chunk-UBEZSGXY.mjs → chunk-ZISMEVKD.mjs} +1 -1
  70. package/dist/lib/neutral/{chunk-UBEZSGXY.mjs.map → chunk-ZISMEVKD.mjs.map} +2 -2
  71. package/dist/lib/neutral/index.mjs +38 -28
  72. package/dist/lib/neutral/internal/index.mjs +15 -9
  73. package/dist/lib/neutral/meta.json +1 -1
  74. package/dist/lib/neutral/testing/index.mjs +185 -129
  75. package/dist/lib/neutral/testing/index.mjs.map +3 -3
  76. package/dist/types/src/Annotation.d.ts +1 -1
  77. package/dist/types/src/Annotation.d.ts.map +1 -1
  78. package/dist/types/src/Collection.d.ts.map +1 -1
  79. package/dist/types/src/Database.d.ts +13 -1
  80. package/dist/types/src/Database.d.ts.map +1 -1
  81. package/dist/types/src/Dataset.d.ts +2 -1
  82. package/dist/types/src/Dataset.d.ts.map +1 -1
  83. package/dist/types/src/Entity.d.ts +17 -11
  84. package/dist/types/src/Entity.d.ts.map +1 -1
  85. package/dist/types/src/Err.d.ts +18 -18
  86. package/dist/types/src/Err.d.ts.map +1 -1
  87. package/dist/types/src/Extension.d.ts +80 -0
  88. package/dist/types/src/Extension.d.ts.map +1 -0
  89. package/dist/types/src/Extension.test.d.ts +2 -0
  90. package/dist/types/src/Extension.test.d.ts.map +1 -0
  91. package/dist/types/src/Feed.d.ts +37 -20
  92. package/dist/types/src/Feed.d.ts.map +1 -1
  93. package/dist/types/src/Filter.d.ts +33 -4
  94. package/dist/types/src/Filter.d.ts.map +1 -1
  95. package/dist/types/src/Filter.test.d.ts +2 -0
  96. package/dist/types/src/Filter.test.d.ts.map +1 -0
  97. package/dist/types/src/Json.d.ts +33 -0
  98. package/dist/types/src/Json.d.ts.map +1 -0
  99. package/dist/types/src/Json.test.d.ts +2 -0
  100. package/dist/types/src/Json.test.d.ts.map +1 -0
  101. package/dist/types/src/JsonSchema.d.ts +1 -1
  102. package/dist/types/src/Migration.d.ts +57 -0
  103. package/dist/types/src/Migration.d.ts.map +1 -0
  104. package/dist/types/src/Obj.d.ts +41 -27
  105. package/dist/types/src/Obj.d.ts.map +1 -1
  106. package/dist/types/src/Order.d.ts.map +1 -1
  107. package/dist/types/src/Query.d.ts +13 -2
  108. package/dist/types/src/Query.d.ts.map +1 -1
  109. package/dist/types/src/Ref.d.ts.map +1 -1
  110. package/dist/types/src/Relation.d.ts +17 -18
  111. package/dist/types/src/Relation.d.ts.map +1 -1
  112. package/dist/types/src/Tag.d.ts +2 -2
  113. package/dist/types/src/Tag.d.ts.map +1 -1
  114. package/dist/types/src/Type.d.ts +3 -3
  115. package/dist/types/src/Type.d.ts.map +1 -1
  116. package/dist/types/src/View.d.ts +1 -1
  117. package/dist/types/src/View.d.ts.map +1 -1
  118. package/dist/types/src/exemplars.test.d.ts +2 -0
  119. package/dist/types/src/exemplars.test.d.ts.map +1 -0
  120. package/dist/types/src/index.d.ts +3 -0
  121. package/dist/types/src/index.d.ts.map +1 -1
  122. package/dist/types/src/internal/Annotation/annotations.d.ts +12 -2
  123. package/dist/types/src/internal/Annotation/annotations.d.ts.map +1 -1
  124. package/dist/types/src/internal/Annotation/sorting.d.ts.map +1 -1
  125. package/dist/types/src/internal/Annotation/util.d.ts +1 -1
  126. package/dist/types/src/internal/Annotation/util.d.ts.map +1 -1
  127. package/dist/types/src/internal/Entity/api.d.ts.map +1 -1
  128. package/dist/types/src/internal/Entity/object.d.ts.map +1 -1
  129. package/dist/types/src/internal/Entity/relation.d.ts.map +1 -1
  130. package/dist/types/src/internal/Entity/version.d.ts.map +1 -1
  131. package/dist/types/src/internal/Format/date.d.ts.map +1 -1
  132. package/dist/types/src/internal/Format/format.d.ts.map +1 -1
  133. package/dist/types/src/internal/Format/number.d.ts.map +1 -1
  134. package/dist/types/src/internal/Format/object.d.ts.map +1 -1
  135. package/dist/types/src/internal/Format/types.d.ts.map +1 -1
  136. package/dist/types/src/internal/JsonSchema/json-schema-normalize.d.ts.map +1 -1
  137. package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts +28 -28
  138. package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts.map +1 -1
  139. package/dist/types/src/internal/JsonSchema/json-schema.d.ts +1 -1
  140. package/dist/types/src/internal/JsonSchema/json-schema.d.ts.map +1 -1
  141. package/dist/types/src/internal/Obj/clone.d.ts.map +1 -1
  142. package/dist/types/src/internal/Obj/common.d.ts.map +1 -1
  143. package/dist/types/src/internal/Obj/create-object.d.ts.map +1 -1
  144. package/dist/types/src/internal/Obj/deleted.d.ts.map +1 -1
  145. package/dist/types/src/internal/Obj/ids.d.ts.map +1 -1
  146. package/dist/types/src/internal/Obj/json-serializer.d.ts +4 -3
  147. package/dist/types/src/internal/Obj/json-serializer.d.ts.map +1 -1
  148. package/dist/types/src/internal/Obj/set-value.d.ts +1 -1
  149. package/dist/types/src/internal/Obj/set-value.d.ts.map +1 -1
  150. package/dist/types/src/internal/Obj/snapshot.d.ts.map +1 -1
  151. package/dist/types/src/internal/Query.d.ts +10 -0
  152. package/dist/types/src/internal/Query.d.ts.map +1 -0
  153. package/dist/types/src/internal/Ref/ref-array.d.ts.map +1 -1
  154. package/dist/types/src/internal/Ref/ref.d.ts +14 -1
  155. package/dist/types/src/internal/Ref/ref.d.ts.map +1 -1
  156. package/dist/types/src/internal/Type/compose.d.ts.map +1 -1
  157. package/dist/types/src/internal/Type/echo-schema.d.ts +2 -2
  158. package/dist/types/src/internal/Type/echo-schema.d.ts.map +1 -1
  159. package/dist/types/src/internal/Type/manipulation.d.ts.map +1 -1
  160. package/dist/types/src/internal/common/api/meta.d.ts +3 -3
  161. package/dist/types/src/internal/common/api/meta.d.ts.map +1 -1
  162. package/dist/types/src/internal/common/proxy/change-context.d.ts +1 -1
  163. package/dist/types/src/internal/common/proxy/change-context.d.ts.map +1 -1
  164. package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts.map +1 -1
  165. package/dist/types/src/internal/common/proxy/errors.d.ts +1 -1
  166. package/dist/types/src/internal/common/proxy/errors.d.ts.map +1 -1
  167. package/dist/types/src/internal/common/proxy/event-batch.d.ts.map +1 -1
  168. package/dist/types/src/internal/common/proxy/json-serializer.d.ts.map +1 -1
  169. package/dist/types/src/internal/common/proxy/make-object.d.ts.map +1 -1
  170. package/dist/types/src/internal/common/proxy/ownership.d.ts.map +1 -1
  171. package/dist/types/src/internal/common/proxy/proxy-utils.d.ts.map +1 -1
  172. package/dist/types/src/internal/common/proxy/reactive-array.d.ts +1 -1
  173. package/dist/types/src/internal/common/proxy/reactive.d.ts +1 -1
  174. package/dist/types/src/internal/common/proxy/reactive.d.ts.map +1 -1
  175. package/dist/types/src/internal/common/proxy/reactive.test.d.ts +2 -0
  176. package/dist/types/src/internal/common/proxy/reactive.test.d.ts.map +1 -0
  177. package/dist/types/src/internal/common/proxy/schema-validator.d.ts.map +1 -1
  178. package/dist/types/src/internal/common/proxy/typed-handler.d.ts.map +1 -1
  179. package/dist/types/src/internal/common/types/base.d.ts.map +1 -1
  180. package/dist/types/src/internal/common/types/entity.d.ts +4 -4
  181. package/dist/types/src/internal/common/types/entity.d.ts.map +1 -1
  182. package/dist/types/src/internal/common/types/meta.d.ts.map +1 -1
  183. package/dist/types/src/internal/common/types/version.d.ts +1 -1
  184. package/dist/types/src/internal/index.d.ts +1 -0
  185. package/dist/types/src/internal/index.d.ts.map +1 -1
  186. package/dist/types/src/testing/test-data.d.ts +8 -8
  187. package/dist/types/src/testing/test-data.d.ts.map +1 -1
  188. package/dist/types/src/testing/test-schema.d.ts +53 -53
  189. package/dist/types/src/testing/test-schema.d.ts.map +1 -1
  190. package/dist/types/src/testing/util.d.ts.map +1 -1
  191. package/dist/types/tsconfig.tsbuildinfo +1 -1
  192. package/package.json +24 -14
  193. package/src/Annotation.ts +1 -0
  194. package/src/Collection.ts +5 -0
  195. package/src/Database.ts +49 -14
  196. package/src/Entity.ts +18 -12
  197. package/src/Extension.test.ts +235 -0
  198. package/src/Extension.ts +122 -0
  199. package/src/Feed.ts +79 -32
  200. package/src/Filter.test.ts +90 -0
  201. package/src/Filter.ts +66 -3
  202. package/src/Json.test.ts +175 -0
  203. package/src/Json.ts +102 -0
  204. package/src/Migration.ts +94 -0
  205. package/src/Obj.test.ts +105 -13
  206. package/src/Obj.ts +153 -33
  207. package/src/Query.test.ts +198 -8
  208. package/src/Query.ts +46 -1
  209. package/src/Relation.ts +24 -20
  210. package/src/Type.ts +1 -1
  211. package/src/View.ts +5 -0
  212. package/src/exemplars.test.ts +21 -0
  213. package/src/index.ts +4 -0
  214. package/src/internal/Annotation/annotations.test.ts +51 -2
  215. package/src/internal/Annotation/annotations.ts +33 -14
  216. package/src/internal/Annotation/sorting.ts +0 -1
  217. package/src/internal/Entity/api.ts +0 -1
  218. package/src/internal/Entity/object.ts +0 -1
  219. package/src/internal/Entity/version.ts +0 -1
  220. package/src/internal/Format/date.test.ts +0 -1
  221. package/src/internal/Format/format.test.ts +0 -1
  222. package/src/internal/JsonSchema/json-schema-type.ts +1 -1
  223. package/src/internal/JsonSchema/json-schema.test.ts +1 -2
  224. package/src/internal/JsonSchema/json-schema.ts +1 -2
  225. package/src/internal/Obj/clone.ts +1 -1
  226. package/src/internal/Obj/create-object.test.ts +2 -4
  227. package/src/internal/Obj/create-object.ts +2 -3
  228. package/src/internal/Obj/deleted.ts +1 -1
  229. package/src/internal/Obj/json-serializer.test.ts +4 -5
  230. package/src/internal/Obj/json-serializer.ts +22 -15
  231. package/src/internal/Obj/set-value.test.ts +24 -24
  232. package/src/internal/Obj/set-value.ts +1 -1
  233. package/src/internal/Query.ts +137 -0
  234. package/src/internal/Ref/ref-array.ts +0 -1
  235. package/src/internal/Ref/ref.test.ts +0 -1
  236. package/src/internal/Ref/ref.ts +18 -1
  237. package/src/internal/Type/compose.test.ts +0 -1
  238. package/src/internal/Type/echo-schema.ts +3 -4
  239. package/src/internal/Type/persistent-schema.ts +2 -2
  240. package/src/internal/common/README.md +1 -1
  241. package/src/internal/common/api/meta.ts +3 -3
  242. package/src/internal/common/proxy/change-context.ts +1 -1
  243. package/src/internal/common/proxy/change.test.ts +94 -94
  244. package/src/internal/common/proxy/errors.ts +2 -2
  245. package/src/internal/common/proxy/handler.test.ts +0 -2
  246. package/src/internal/common/proxy/make-object.ts +0 -1
  247. package/src/internal/common/proxy/ownership.ts +0 -1
  248. package/src/internal/common/proxy/reactive-array.ts +1 -1
  249. package/src/internal/common/proxy/reactive.test.ts +54 -0
  250. package/src/internal/common/proxy/reactive.ts +11 -3
  251. package/src/internal/common/proxy/typed-handler.test.ts +0 -1
  252. package/src/internal/common/proxy/typed-handler.ts +8 -10
  253. package/src/internal/common/proxy/typed-object.test.ts +2 -3
  254. package/src/internal/common/types/entity.ts +1 -1
  255. package/src/internal/common/types/meta.ts +0 -1
  256. package/src/internal/index.ts +1 -0
  257. package/src/testing/api.test.ts +0 -1
  258. package/src/testing/test-data.ts +157 -98
  259. package/dist/lib/neutral/chunk-43Y5DOS6.mjs.map +0 -7
  260. package/dist/lib/neutral/chunk-BOZZPUXE.mjs.map +0 -7
  261. package/dist/lib/neutral/chunk-CIRHIEMW.mjs.map +0 -7
  262. package/dist/lib/neutral/chunk-DYDJBZEG.mjs.map +0 -7
  263. package/dist/lib/neutral/chunk-KTAWP7GI.mjs.map +0 -7
  264. package/dist/lib/neutral/chunk-NEGC54NE.mjs.map +0 -7
  265. package/dist/lib/neutral/chunk-NQRLRYJM.mjs.map +0 -7
  266. package/dist/lib/neutral/chunk-NXMFBIT5.mjs.map +0 -7
  267. package/dist/lib/neutral/chunk-OENWMTE6.mjs.map +0 -7
  268. package/dist/lib/neutral/chunk-SEMVAGBM.mjs.map +0 -7
  269. package/dist/lib/neutral/chunk-TQQZLKB7.mjs.map +0 -7
  270. package/dist/lib/neutral/chunk-UFDK26FO.mjs.map +0 -7
  271. package/dist/lib/neutral/chunk-VA2F47ZC.mjs.map +0 -7
  272. /package/dist/lib/neutral/{chunk-FZO7LQO7.mjs.map → chunk-44HT3MEC.mjs.map} +0 -0
  273. /package/dist/lib/neutral/{chunk-ANHVGJI4.mjs.map → chunk-7RVZT53K.mjs.map} +0 -0
  274. /package/dist/lib/neutral/{chunk-BNCCGLJN.mjs.map → chunk-BICZKPQG.mjs.map} +0 -0
  275. /package/dist/lib/neutral/{chunk-724GQYEN.mjs.map → chunk-HPNQTEEQ.mjs.map} +0 -0
  276. /package/dist/lib/neutral/{chunk-UTBRYVQC.mjs.map → chunk-QGMIH2SN.mjs.map} +0 -0
  277. /package/dist/lib/neutral/{chunk-B5OXLWZL.mjs.map → chunk-TRPZU2HV.mjs.map} +0 -0
  278. /package/dist/lib/neutral/{chunk-UI6MWK5W.mjs.map → chunk-TTCSATUD.mjs.map} +0 -0
  279. /package/dist/lib/neutral/{chunk-OMUPQMLR.mjs.map → chunk-V72DY6LU.mjs.map} +0 -0
  280. /package/dist/lib/neutral/{chunk-FXEG7EOK.mjs.map → chunk-VYAGNFSJ.mjs.map} +0 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/Query.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\n// @import-as-namespace\n\nimport type * as EffectArray from 'effect/Array';\nimport type * as Schema from 'effect/Schema';\n\nimport { type QueryAST } from '@dxos/echo-protocol';\n\nimport type * as Collection from './Collection';\nimport * as Database from './Database';\nimport type * as Dataset from './Dataset';\nimport * as Feed from './Feed';\nimport * as Filter from './Filter';\nimport * as internal from './internal';\nimport * as Obj from './Obj';\nimport type * as Order from './Order';\nimport type * as Ref from './Ref';\nimport type * as Relation from './Relation';\nimport type * as View from './View';\n\n// TODO(dmaretskyi): Split up into interfaces for objects and relations so they can have separate verbs.\n// TODO(dmaretskyi): Undirected relation traversals.\n// TODO(wittjosiah): Make Filter & Query pipeable.\n\n/**\n * All property paths inside T that are references.\n */\n// TODO(dmaretskyi): Filter only properties that are references (or optional references, or unions that include references).\ntype RefPropKey<T> = keyof T & string;\n\n// TODO(burdon): Narrow T to Entity.Unknown?\nexport interface Query<T> {\n // TODO(dmaretskyi): See new effect-schema approach to variance.\n '~Query': { value: T };\n\n ast: QueryAST.Query;\n\n /**\n * Filter the current selection based on a filter.\n * @param filter - Filter to select the objects.\n * @returns Query for the selected objects.\n */\n 'select'(filter: Filter.Filter<T>): Query<T>;\n 'select'(props: Filter.Props<T>): Query<T>;\n\n /**\n * Traverse an outgoing reference.\n * @param key - Property path inside T that is a reference or optional reference.\n * @returns Query for the target of the reference.\n */\n 'reference'<K extends RefPropKey<T>>(\n key: K,\n ): Query<\n T[K] extends Ref.Unknown\n ? Ref.Target<T[K]>\n : T[K] extends Ref.Unknown | undefined\n ? Ref.Target<Exclude<T[K], undefined>>\n : never\n >;\n\n /**\n * Find objects referencing this object.\n * @param target - Schema of the referencing object. If not provided, matches any type.\n * @param key - Property path inside the referencing object that is a reference. If not provided, matches any property.\n * @returns Query for the referencing objects.\n */\n // TODO(dmaretskyi): any way to enforce `Ref.Target<Schema.Schema.Type<S>[key]> == T`?\n // TODO(dmaretskyi): Ability to go through arrays of references.\n 'referencedBy'<S extends Schema.Schema.All>(\n target: S | string,\n key: RefPropKey<Schema.Schema.Type<S>>,\n ): Query<Schema.Schema.Type<S>>;\n 'referencedBy'<S extends Schema.Schema.All>(target: S | string): Query<Schema.Schema.Type<S>>;\n 'referencedBy'(): Query<any>;\n\n /**\n * Find relations where this object is the source.\n * @returns Query for the relation objects.\n * @param relation - Schema of the relation.\n * @param predicates - Predicates to filter the relation objects.\n */\n 'sourceOf'<S extends Schema.Schema.All>(\n relation?: S | string,\n predicates?: Filter.Props<Schema.Schema.Type<S>>,\n ): Query<Schema.Schema.Type<S>>;\n\n /**\n * Find relations where this object is the target.\n * @returns Query for the relation objects.\n * @param relation - Schema of the relation.\n * @param predicates - Predicates to filter the relation objects.\n */\n 'targetOf'<S extends Schema.Schema.All>(\n relation?: S | string,\n predicates?: Filter.Props<Schema.Schema.Type<S>>,\n ): Query<Schema.Schema.Type<S>>;\n\n /**\n * For a query for relations, get the source objects.\n * @returns Query for the source objects.\n */\n 'source'(): Query<Relation.SourceOf<T>>;\n\n /**\n * For a query for relations, get the target objects.\n * @returns Query for the target objects.\n */\n 'target'(): Query<Relation.TargetOf<T>>;\n\n /**\n * Get the parent object of the current selection.\n * @returns Query for the parent objects.\n */\n 'parent'(): Query<any>;\n\n /**\n * Get all child objects of the current selection.\n * @returns Query for the child objects.\n */\n 'children'(): Query<any>;\n\n /**\n * Order the query results.\n * Orders are specified in priority order. The first order will be applied first, etc.\n * @param order - Order to sort the results.\n * @returns Query for the ordered results.\n */\n 'orderBy'(...order: EffectArray.NonEmptyArray<Order.Order<T>>): Query<T>;\n\n /**\n * Limit the number of results.\n * @param limit - Maximum number of results to return.\n * @returns Query for the limited results.\n */\n 'limit'(limit: number): Query<T>;\n\n /**\n * Query from selected databases only.\n *\n * Example:\n *\n * ```ts\n * Query.select(Filter.type(Person)).from(db);\n * ```\n *\n * @param options.includeFeeds [false] - Whether to include feeds in the query. Default is to query from automerge documents only.\n */\n 'from'(database: Database.Database | Database.Database[], options?: { includeFeeds?: boolean }): Query<T>;\n\n /**\n * Query from selected feeds only.\n *\n * Example:\n *\n * ```ts\n * Query.select(Filter.type(Person)).from(feed);\n * ```\n *\n */\n 'from'(feeds: Feed.Feed | Feed.Feed[]): Query<T>;\n\n /**\n * Query from all accessible spaces.\n *\n * Example:\n *\n * ```ts\n * Query.select(Filter.type(Person)).from('all-accessible-spaces');\n * ```\n *\n * @param options.includeFeeds [false] - Whether to include feeds in the query. Default is to query from automerge documents only.\n */\n 'from'(allSpaces: 'all-accessible-spaces', options?: { includeFeeds?: boolean }): Query<T>;\n\n /**\n * Query from a dataset.\n * Currently only feeds are supported.\n *\n * Example:\n *\n * ```ts\n * Query.type(Person).from(feed);\n * ```\n */\n 'from'(dataset: Dataset.Dataset): Query<T>;\n\n /**\n * Query from the results of another query.\n *\n * Example:\n *\n * ```ts\n * Query.select(Filter.props({ foo: 'foo' })).from(Query.select(Filter.type(Contact)).reference('org'));\n * ```\n */\n 'from'(query: Any): Query<T>;\n\n /**\n * Query from a raw scope specification.\n */\n 'from'(scope: QueryAST.Scope): Query<T>;\n\n /**\n * Add options to a query.\n */\n 'options'(options: QueryAST.QueryOptions): Query<T>;\n\n /**\n * Attach a diagnostic label for logs and tooling (execution semantics unchanged).\n */\n 'debugLabel'(label: string): Query<T>;\n}\n\nexport type Any = Query<any>;\n\nexport type Type<Q extends Any> = Q extends Query<infer T> ? T : never;\n\nclass QueryClass implements Any {\n private static 'variance': Any['~Query'] = {} as Any['~Query'];\n\n constructor(public readonly ast: QueryAST.Query) {}\n\n '~Query' = QueryClass.variance;\n\n select(filter: Filter.Any | Filter.Props<any>): Any {\n if (Filter.is(filter)) {\n return new QueryClass({\n type: 'filter',\n selection: this.ast,\n filter: filter.ast,\n });\n } else {\n return new QueryClass({\n type: 'filter',\n selection: this.ast,\n filter: Filter.props(filter).ast,\n });\n }\n }\n\n reference(key: string): Any {\n return new QueryClass({\n type: 'reference-traversal',\n anchor: this.ast,\n property: key,\n });\n }\n\n referencedBy(target?: Schema.Schema.All | string, key?: string): Any {\n const dxn = target !== undefined ? internal.getTypeDXNFromSpecifier(target) : null;\n return new QueryClass({\n type: 'incoming-references',\n anchor: this.ast,\n property: key ?? null,\n typename: dxn?.toString() ?? null,\n });\n }\n\n sourceOf(relation?: Schema.Schema.All | string, predicates?: Filter.Props<unknown> | undefined): Any {\n return new QueryClass({\n type: 'relation',\n anchor: this.ast,\n direction: 'outgoing',\n filter: relation !== undefined ? Filter.type(relation, predicates).ast : undefined,\n });\n }\n\n targetOf(relation?: Schema.Schema.All | string, predicates?: Filter.Props<unknown> | undefined): Any {\n return new QueryClass({\n type: 'relation',\n anchor: this.ast,\n direction: 'incoming',\n filter: relation !== undefined ? Filter.type(relation, predicates).ast : undefined,\n });\n }\n\n source(): Any {\n return new QueryClass({\n type: 'relation-traversal',\n anchor: this.ast,\n direction: 'source',\n });\n }\n\n target(): Any {\n return new QueryClass({\n type: 'relation-traversal',\n anchor: this.ast,\n direction: 'target',\n });\n }\n\n parent(): Any {\n return new QueryClass({\n type: 'hierarchy-traversal',\n anchor: this.ast,\n direction: 'to-parent',\n });\n }\n\n children(): Any {\n return new QueryClass({\n type: 'hierarchy-traversal',\n anchor: this.ast,\n direction: 'to-children',\n });\n }\n\n orderBy(...order: Order.Order<any>[]): Any {\n return new QueryClass({\n type: 'order',\n query: this.ast,\n order: order.map((o) => o.ast),\n });\n }\n\n limit(limit: number): Any {\n return new QueryClass({\n type: 'limit',\n query: this.ast,\n limit,\n });\n }\n\n from(\n arg:\n | Database.Database\n | Database.Database[]\n | Feed.Feed\n | Feed.Feed[]\n | Collection.Collection\n | View.View\n | Any\n | QueryAST.Scope\n | 'all-accessible-spaces',\n options?: { includeFeeds?: boolean },\n ): Any {\n if (arg == null) {\n throw new TypeError(\n 'Query.from() requires a valid data source argument (database, feed, query, scope, or \"all-accessible-spaces\").',\n );\n }\n\n if (is(arg)) {\n return new QueryClass({\n type: 'from',\n query: this.ast,\n from: { _tag: 'query', query: arg.ast },\n });\n }\n\n if (arg === 'all-accessible-spaces') {\n return new QueryClass({\n type: 'from',\n query: this.ast,\n from: {\n _tag: 'scope',\n scope: {\n ...(options?.includeFeeds ? { allQueuesFromSpaces: true } : {}),\n },\n },\n });\n }\n\n if (_isScope(arg)) {\n return new QueryClass({\n type: 'from',\n query: this.ast,\n from: { _tag: 'scope', scope: arg },\n });\n }\n\n const items = Array.isArray(arg) ? arg : [arg];\n\n if (items.length > 0 && Database.isDatabase(items[0])) {\n const databases = items as Database.Database[];\n return new QueryClass({\n type: 'from',\n query: this.ast,\n from: {\n _tag: 'scope',\n scope: {\n spaceIds: databases.map((db) => db.spaceId),\n ...(options?.includeFeeds ? { allQueuesFromSpaces: true } : {}),\n },\n },\n });\n }\n\n if (items.length > 0) {\n const typename = Obj.getTypename(items[0] as Obj.Unknown);\n // TODO(dmaretskyi): Support querying from views.\n if (typename === 'org.dxos.type.view') {\n throw new Error('Query.from(view) is not yet supported.');\n }\n // TODO(dmaretskyi): Support querying from collections.\n if (typename === 'org.dxos.type.collection') {\n throw new Error('Query.from(collection) is not yet supported.');\n }\n // Validate that the items are Feed.Feed instances.\n for (const item of items) {\n if (!Obj.instanceOf(Feed.Feed, item)) {\n throw new TypeError(\n `Query.from() expects Feed objects (org.dxos.type.feed), but received an object with typename '${typename ?? 'unknown'}'.`,\n );\n }\n }\n }\n\n const feeds = items as Feed.Feed[];\n const queueDxns = feeds.flatMap((feed) => {\n const dxn = Feed.getQueueDxn(feed);\n return dxn ? [dxn.toString()] : [];\n });\n return new QueryClass({\n type: 'from',\n query: this.ast,\n from: {\n _tag: 'scope',\n scope: {\n queues: queueDxns,\n },\n },\n });\n }\n\n options(options: QueryAST.QueryOptions): Any {\n return new QueryClass({\n type: 'options',\n query: this.ast,\n options,\n });\n }\n\n debugLabel(label: string): Any {\n if (this.ast.type === 'options') {\n return new QueryClass({\n type: 'options',\n query: this.ast.query,\n options: { ...this.ast.options, debugLabel: label },\n });\n }\n return new QueryClass({\n type: 'options',\n query: this.ast,\n options: { debugLabel: label },\n });\n }\n}\n\nexport const is = (value: unknown): value is Any => {\n return typeof value === 'object' && value !== null && '~Query' in value;\n};\n\n/** Construct a query from an ast. */\nexport const fromAst = (ast: QueryAST.Query): Any => {\n return new QueryClass(ast);\n};\n\n/**\n * Select objects based on a filter.\n * @param filter - Filter to select the objects.\n * @returns Query for the selected objects.\n */\nexport const select = <F extends Filter.Any>(filter: F): Query<Filter.Type<F>> => {\n return new QueryClass({\n type: 'select',\n filter: filter.ast,\n });\n};\n\n/**\n * Query for objects of a given schema.\n * @param schema - Schema of the objects.\n * @param predicates - Predicates to filter the objects.\n * @returns Query for the objects.\n *\n * Shorthand for: `Query.select(Filter.type(schema, predicates))`.\n */\nexport const type: {\n <S extends Schema.Schema.All>(\n schema: S,\n predicates?: Filter.Props<Schema.Schema.Type<S>>,\n ): Query<Schema.Schema.Type<S>>;\n (schema: string, predicates?: Filter.Props<unknown>): Query<any>;\n} = (schema: Schema.Schema.All | string, predicates?: Filter.Props<unknown>): Any => {\n return new QueryClass({\n type: 'select',\n filter: Filter.type(schema, predicates).ast,\n });\n};\n\n/**\n * Combine results of multiple queries.\n * @param queries - Queries to combine.\n * @returns Query for the combined results.\n */\n// TODO(dmaretskyi): Rename to `combine` or `union`.\nexport const all = (...queries: Any[]): Any => {\n if (queries.length === 0) {\n throw new TypeError(\n 'Query.all combines results of multiple queries, to query all objects use Query.select(Filter.everything())',\n );\n }\n return new QueryClass({\n type: 'union',\n queries: queries.map((q) => q.ast),\n });\n};\n\n/**\n * Subtract one query from another.\n * @param source - Query to subtract from.\n * @param exclude - Query to subtract.\n * @returns Query for the results of the source query minus the results of the exclude query.\n */\nexport const without = <T>(source: Query<T>, exclude: Query<T>): Query<T> => {\n return new QueryClass({\n type: 'set-difference',\n source: source.ast,\n exclude: exclude.ast,\n });\n};\n\n/**\n * Create a query scoped to a data source.\n * The returned query selects everything from the source; chain `.select()` to narrow results.\n *\n * @param source - Data source: database, feed, 'all-accessible-spaces', or another query.\n * @returns Query scoped to the given source.\n */\nexport const from = (\n source:\n | Database.Database\n | Database.Database[]\n | Feed.Feed\n | Feed.Feed[]\n | Any\n | QueryAST.Scope\n | 'all-accessible-spaces',\n options?: { includeFeeds?: boolean },\n): Any => {\n const baseQuery: QueryAST.Query = {\n type: 'select',\n filter: Filter.everything().ast,\n };\n const wrapper = new QueryClass(baseQuery);\n return wrapper.from(source as any, options);\n};\n\nconst SCOPE_KEYS = new Set(['spaceIds', 'queues', 'allQueuesFromSpaces']);\n\n/** Detect a raw Scope object (plain object with only Scope-valid keys). */\nconst _isScope = (value: unknown): value is QueryAST.Scope => {\n if (typeof value !== 'object' || value === null || Array.isArray(value)) {\n return false;\n }\n return Object.keys(value).every((key) => SCOPE_KEYS.has(key));\n};\n\n/**\n * Returns a human-readable string representation of a Query AST.\n */\nexport const pretty = (query: Any): string => internal.prettyQuery(query.ast);\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;YAAAA;EAAA;;cAAAC;EAAA;;AA4NA,IAAMC,aAAN,MAAMA,YAAAA;;EACJ,OAAe,aAA4B,CAAC;EAE5C,YAA4BC,KAAqB;SAArBA,MAAAA;EAAsB;EAElD,WAAWD,YAAWE;EAEtBC,OAAOC,QAA6C;AAClD,QAAWC,GAAGD,MAAAA,GAAS;AACrB,aAAO,IAAIJ,YAAW;QACpBM,MAAM;QACNC,WAAW,KAAKN;QAChBG,QAAQA,OAAOH;MACjB,CAAA;IACF,OAAO;AACL,aAAO,IAAID,YAAW;QACpBM,MAAM;QACNC,WAAW,KAAKN;QAChBG,QAAeI,MAAMJ,MAAAA,EAAQH;MAC/B,CAAA;IACF;EACF;EAEAQ,UAAUC,KAAkB;AAC1B,WAAO,IAAIV,YAAW;MACpBM,MAAM;MACNK,QAAQ,KAAKV;MACbW,UAAUF;IACZ,CAAA;EACF;EAEAG,aAAaC,QAAqCJ,KAAmB;AACnE,UAAMK,MAAMD,WAAWE,SAAqBC,wBAAwBH,MAAAA,IAAU;AAC9E,WAAO,IAAId,YAAW;MACpBM,MAAM;MACNK,QAAQ,KAAKV;MACbW,UAAUF,OAAO;MACjBQ,UAAUH,KAAKI,SAAAA,KAAc;IAC/B,CAAA;EACF;EAEAC,SAASC,UAAuCC,YAAqD;AACnG,WAAO,IAAItB,YAAW;MACpBM,MAAM;MACNK,QAAQ,KAAKV;MACbsB,WAAW;MACXnB,QAAQiB,aAAaL,SAAmBV,KAAKe,UAAUC,UAAAA,EAAYrB,MAAMe;IAC3E,CAAA;EACF;EAEAQ,SAASH,UAAuCC,YAAqD;AACnG,WAAO,IAAItB,YAAW;MACpBM,MAAM;MACNK,QAAQ,KAAKV;MACbsB,WAAW;MACXnB,QAAQiB,aAAaL,SAAmBV,KAAKe,UAAUC,UAAAA,EAAYrB,MAAMe;IAC3E,CAAA;EACF;EAEAS,SAAc;AACZ,WAAO,IAAIzB,YAAW;MACpBM,MAAM;MACNK,QAAQ,KAAKV;MACbsB,WAAW;IACb,CAAA;EACF;EAEAT,SAAc;AACZ,WAAO,IAAId,YAAW;MACpBM,MAAM;MACNK,QAAQ,KAAKV;MACbsB,WAAW;IACb,CAAA;EACF;EAEAG,SAAc;AACZ,WAAO,IAAI1B,YAAW;MACpBM,MAAM;MACNK,QAAQ,KAAKV;MACbsB,WAAW;IACb,CAAA;EACF;EAEAI,WAAgB;AACd,WAAO,IAAI3B,YAAW;MACpBM,MAAM;MACNK,QAAQ,KAAKV;MACbsB,WAAW;IACb,CAAA;EACF;EAEAK,WAAWC,OAAgC;AACzC,WAAO,IAAI7B,YAAW;MACpBM,MAAM;MACNwB,OAAO,KAAK7B;MACZ4B,OAAOA,MAAME,IAAI,CAACC,MAAMA,EAAE/B,GAAG;IAC/B,CAAA;EACF;EAEAgC,MAAMA,OAAoB;AACxB,WAAO,IAAIjC,YAAW;MACpBM,MAAM;MACNwB,OAAO,KAAK7B;MACZgC;IACF,CAAA;EACF;EAEAC,KACEC,KAUAC,SACK;AACL,QAAID,OAAO,MAAM;AACf,YAAM,IAAIE,UACR,gHAAA;IAEJ;AAEA,QAAIhC,IAAG8B,GAAAA,GAAM;AACX,aAAO,IAAInC,YAAW;QACpBM,MAAM;QACNwB,OAAO,KAAK7B;QACZiC,MAAM;UAAEI,MAAM;UAASR,OAAOK,IAAIlC;QAAI;MACxC,CAAA;IACF;AAEA,QAAIkC,QAAQ,yBAAyB;AACnC,aAAO,IAAInC,YAAW;QACpBM,MAAM;QACNwB,OAAO,KAAK7B;QACZiC,MAAM;UACJI,MAAM;UACNC,OAAO;YACL,GAAIH,SAASI,eAAe;cAAEC,qBAAqB;YAAK,IAAI,CAAC;UAC/D;QACF;MACF,CAAA;IACF;AAEA,QAAIC,SAASP,GAAAA,GAAM;AACjB,aAAO,IAAInC,YAAW;QACpBM,MAAM;QACNwB,OAAO,KAAK7B;QACZiC,MAAM;UAAEI,MAAM;UAASC,OAAOJ;QAAI;MACpC,CAAA;IACF;AAEA,UAAMQ,QAAQC,MAAMC,QAAQV,GAAAA,IAAOA,MAAM;MAACA;;AAE1C,QAAIQ,MAAMG,SAAS,KAAcC,WAAWJ,MAAM,CAAA,CAAE,GAAG;AACrD,YAAMK,YAAYL;AAClB,aAAO,IAAI3C,YAAW;QACpBM,MAAM;QACNwB,OAAO,KAAK7B;QACZiC,MAAM;UACJI,MAAM;UACNC,OAAO;YACLU,UAAUD,UAAUjB,IAAI,CAACmB,OAAOA,GAAGC,OAAO;YAC1C,GAAIf,SAASI,eAAe;cAAEC,qBAAqB;YAAK,IAAI,CAAC;UAC/D;QACF;MACF,CAAA;IACF;AAEA,QAAIE,MAAMG,SAAS,GAAG;AACpB,YAAM5B,WAAekC,YAAYT,MAAM,CAAA,CAAE;AAEzC,UAAIzB,aAAa,sBAAsB;AACrC,cAAM,IAAImC,MAAM,wCAAA;MAClB;AAEA,UAAInC,aAAa,4BAA4B;AAC3C,cAAM,IAAImC,MAAM,8CAAA;MAClB;AAEA,iBAAWC,QAAQX,OAAO;AACxB,YAAI,CAAKY,WAAgBC,MAAMF,IAAAA,GAAO;AACpC,gBAAM,IAAIjB,UACR,iGAAiGnB,YAAY,SAAA,IAAa;QAE9H;MACF;IACF;AAEA,UAAMuC,QAAQd;AACd,UAAMe,YAAYD,MAAME,QAAQ,CAACC,SAAAA;AAC/B,YAAM7C,MAAW8C,YAAYD,IAAAA;AAC7B,aAAO7C,MAAM;QAACA,IAAII,SAAQ;UAAM,CAAA;IAClC,CAAA;AACA,WAAO,IAAInB,YAAW;MACpBM,MAAM;MACNwB,OAAO,KAAK7B;MACZiC,MAAM;QACJI,MAAM;QACNC,OAAO;UACLuB,QAAQJ;QACV;MACF;IACF,CAAA;EACF;EAEAtB,QAAQA,SAAqC;AAC3C,WAAO,IAAIpC,YAAW;MACpBM,MAAM;MACNwB,OAAO,KAAK7B;MACZmC;IACF,CAAA;EACF;EAEA2B,WAAWC,OAAoB;AAC7B,QAAI,KAAK/D,IAAIK,SAAS,WAAW;AAC/B,aAAO,IAAIN,YAAW;QACpBM,MAAM;QACNwB,OAAO,KAAK7B,IAAI6B;QAChBM,SAAS;UAAE,GAAG,KAAKnC,IAAImC;UAAS2B,YAAYC;QAAM;MACpD,CAAA;IACF;AACA,WAAO,IAAIhE,YAAW;MACpBM,MAAM;MACNwB,OAAO,KAAK7B;MACZmC,SAAS;QAAE2B,YAAYC;MAAM;IAC/B,CAAA;EACF;AACF;AAEO,IAAM3D,MAAK,CAAC4D,UAAAA;AACjB,SAAO,OAAOA,UAAU,YAAYA,UAAU,QAAQ,YAAYA;AACpE;AAGO,IAAMC,UAAU,CAACjE,QAAAA;AACtB,SAAO,IAAID,WAAWC,GAAAA;AACxB;AAOO,IAAME,SAAS,CAAuBC,WAAAA;AAC3C,SAAO,IAAIJ,WAAW;IACpBM,MAAM;IACNF,QAAQA,OAAOH;EACjB,CAAA;AACF;AAUO,IAAMK,QAMT,CAAC6D,QAAoC7C,eAAAA;AACvC,SAAO,IAAItB,WAAW;IACpBM,MAAM;IACNF,QAAeE,KAAK6D,QAAQ7C,UAAAA,EAAYrB;EAC1C,CAAA;AACF;AAQO,IAAMmE,MAAM,IAAIC,YAAAA;AACrB,MAAIA,QAAQvB,WAAW,GAAG;AACxB,UAAM,IAAIT,UACR,4GAAA;EAEJ;AACA,SAAO,IAAIrC,WAAW;IACpBM,MAAM;IACN+D,SAASA,QAAQtC,IAAI,CAACuC,MAAMA,EAAErE,GAAG;EACnC,CAAA;AACF;AAQO,IAAMsE,UAAU,CAAI9C,QAAkB+C,YAAAA;AAC3C,SAAO,IAAIxE,WAAW;IACpBM,MAAM;IACNmB,QAAQA,OAAOxB;IACfuE,SAASA,QAAQvE;EACnB,CAAA;AACF;AASO,IAAMiC,OAAO,CAClBT,QAQAW,YAAAA;AAEA,QAAMqC,YAA4B;IAChCnE,MAAM;IACNF,QAAesE,WAAU,EAAGzE;EAC9B;AACA,QAAM0E,UAAU,IAAI3E,WAAWyE,SAAAA;AAC/B,SAAOE,QAAQzC,KAAKT,QAAeW,OAAAA;AACrC;AAEA,IAAMwC,aAAa,oBAAIC,IAAI;EAAC;EAAY;EAAU;CAAsB;AAGxE,IAAMnC,WAAW,CAACuB,UAAAA;AAChB,MAAI,OAAOA,UAAU,YAAYA,UAAU,QAAQrB,MAAMC,QAAQoB,KAAAA,GAAQ;AACvE,WAAO;EACT;AACA,SAAOa,OAAOC,KAAKd,KAAAA,EAAOe,MAAM,CAACtE,QAAQkE,WAAWK,IAAIvE,GAAAA,CAAAA;AAC1D;AAKO,IAAMwE,SAAS,CAACpD,UAAgCqD,YAAYrD,MAAM7B,GAAG;",
6
+ "names": ["is", "type", "QueryClass", "ast", "variance", "select", "filter", "is", "type", "selection", "props", "reference", "key", "anchor", "property", "referencedBy", "target", "dxn", "undefined", "getTypeDXNFromSpecifier", "typename", "toString", "sourceOf", "relation", "predicates", "direction", "targetOf", "source", "parent", "children", "orderBy", "order", "query", "map", "o", "limit", "from", "arg", "options", "TypeError", "_tag", "scope", "includeFeeds", "allQueuesFromSpaces", "_isScope", "items", "Array", "isArray", "length", "isDatabase", "databases", "spaceIds", "db", "spaceId", "getTypename", "Error", "item", "instanceOf", "Feed", "feeds", "queueDxns", "flatMap", "feed", "getQueueDxn", "queues", "debugLabel", "label", "value", "fromAst", "schema", "all", "queries", "q", "without", "exclude", "baseQuery", "everything", "wrapper", "SCOPE_KEYS", "Set", "Object", "keys", "every", "has", "pretty", "prettyQuery"]
7
+ }
@@ -1,10 +1,10 @@
1
1
  import {
2
2
  RefArray
3
- } from "./chunk-YWXWXIE5.mjs";
3
+ } from "./chunk-6VIJV543.mjs";
4
4
  import {
5
5
  Ref,
6
6
  getSchemaReference
7
- } from "./chunk-43Y5DOS6.mjs";
7
+ } from "./chunk-MPAI2MHO.mjs";
8
8
  import {
9
9
  __export
10
10
  } from "./chunk-J5LGTIGS.mjs";
@@ -42,4 +42,4 @@ export {
42
42
  isRefType,
43
43
  Ref_exports
44
44
  };
45
- //# sourceMappingURL=chunk-FXEG7EOK.mjs.map
45
+ //# sourceMappingURL=chunk-VYAGNFSJ.mjs.map
@@ -1,10 +1,10 @@
1
1
  import {
2
2
  Unknown
3
- } from "./chunk-NQRLRYJM.mjs";
3
+ } from "./chunk-SW5CUSBY.mjs";
4
4
  import {
5
5
  KindId,
6
6
  SnapshotKindId
7
- } from "./chunk-UFDK26FO.mjs";
7
+ } from "./chunk-LVGOVFDV.mjs";
8
8
  import {
9
9
  ATTR_RELATION_SOURCE,
10
10
  ATTR_RELATION_TARGET,
@@ -36,7 +36,7 @@ import {
36
36
  sortByTypename,
37
37
  subscribe,
38
38
  version
39
- } from "./chunk-TQQZLKB7.mjs";
39
+ } from "./chunk-SJKBWMJY.mjs";
40
40
  import {
41
41
  ParentId,
42
42
  getDescription,
@@ -47,11 +47,11 @@ import {
47
47
  getTypename,
48
48
  setDescription,
49
49
  setLabel
50
- } from "./chunk-SEMVAGBM.mjs";
50
+ } from "./chunk-TNBK56IN.mjs";
51
51
  import {
52
52
  EntityKind,
53
53
  SchemaKindId
54
- } from "./chunk-WYOKA6AE.mjs";
54
+ } from "./chunk-N4B7FHQT.mjs";
55
55
  import {
56
56
  __export
57
57
  } from "./chunk-J5LGTIGS.mjs";
@@ -65,7 +65,6 @@ __export(Relation_exports, {
65
65
  Unknown: () => Unknown3,
66
66
  VersionTypeId: () => VersionTypeId2,
67
67
  addTag: () => addTag2,
68
- change: () => change2,
69
68
  deleteKeys: () => deleteKeys2,
70
69
  getDXN: () => getDXN2,
71
70
  getDatabase: () => getDatabase2,
@@ -96,6 +95,7 @@ __export(Relation_exports, {
96
95
  sortByTypename: () => sortByTypename2,
97
96
  subscribe: () => subscribe2,
98
97
  toJSON: () => toJSON,
98
+ update: () => update,
99
99
  version: () => version2
100
100
  });
101
101
  import * as Schema from "effect/Schema";
@@ -116,7 +116,7 @@ var Unknown3 = Schema.Struct({
116
116
  // NOTE: The EchoRelationSchema annotation is required for Ref.Ref(Relation.Unknown) to work.
117
117
  // The typename/version/source/target only satisfy ECHO schema machinery for reference targets.
118
118
  EchoRelationSchema({
119
- typename: "org.dxos.schema.any-relation",
119
+ typename: "org.dxos.schema.anyRelation",
120
120
  version: "0.0.0",
121
121
  source: Unknown,
122
122
  target: Unknown
@@ -161,63 +161,35 @@ var getSourceDXN = (value) => {
161
161
  assertArgument(isRelation(value), "Expected a relation");
162
162
  assumeType(value);
163
163
  const dxn = value[RelationSourceDXNId];
164
- invariant(dxn instanceof DXN, void 0, {
165
- F: __dxlog_file,
166
- L: 214,
167
- S: void 0,
168
- A: [
169
- "dxn instanceof DXN",
170
- ""
171
- ]
172
- });
164
+ invariant(dxn instanceof DXN, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 100, S: void 0, A: ["dxn instanceof DXN", ""] });
173
165
  return dxn;
174
166
  };
175
167
  var getTargetDXN = (value) => {
176
168
  assertArgument(isRelation(value), "Expected a relation");
177
169
  assumeType(value);
178
170
  const dxn = value[RelationTargetDXNId];
179
- invariant(dxn instanceof DXN, void 0, {
180
- F: __dxlog_file,
181
- L: 227,
182
- S: void 0,
183
- A: [
184
- "dxn instanceof DXN",
185
- ""
186
- ]
187
- });
171
+ invariant(dxn instanceof DXN, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 111, S: void 0, A: ["dxn instanceof DXN", ""] });
188
172
  return dxn;
189
173
  };
190
174
  var getSource = (relation) => {
191
175
  assertArgument(isRelation(relation), "Expected a relation");
192
176
  assumeType(relation);
193
177
  const obj = relation[RelationSourceId];
194
- invariant(obj !== void 0, `Invalid source: ${relation.id}`, {
195
- F: __dxlog_file,
196
- L: 240,
197
- S: void 0,
198
- A: [
199
- "obj !== undefined",
200
- "`Invalid source: ${relation.id}`"
201
- ]
202
- });
178
+ if (obj === void 0) {
179
+ throw new Error(`Relation source could not be resolved.`);
180
+ }
203
181
  return obj;
204
182
  };
205
183
  var getTarget = (relation) => {
206
184
  assertArgument(isRelation(relation), "Expected a relation");
207
185
  assumeType(relation);
208
186
  const obj = relation[RelationTargetId];
209
- invariant(obj !== void 0, `Invalid target: ${relation.id}`, {
210
- F: __dxlog_file,
211
- L: 253,
212
- S: void 0,
213
- A: [
214
- "obj !== undefined",
215
- "`Invalid target: ${relation.id}`"
216
- ]
217
- });
187
+ if (obj === void 0) {
188
+ throw new Error(`Relation target could not be resolved.`);
189
+ }
218
190
  return obj;
219
191
  };
220
- var change2 = (relation, callback) => {
192
+ var update = (relation, callback) => {
221
193
  change(relation, callback);
222
194
  };
223
195
  var getSnapshot2 = getSnapshot;
@@ -265,7 +237,7 @@ export {
265
237
  getTargetDXN,
266
238
  getSource,
267
239
  getTarget,
268
- change2 as change,
240
+ update,
269
241
  getSnapshot2 as getSnapshot,
270
242
  subscribe2 as subscribe,
271
243
  getValue2 as getValue,
@@ -295,4 +267,4 @@ export {
295
267
  version2 as version,
296
268
  Relation_exports
297
269
  };
298
- //# sourceMappingURL=chunk-CIRHIEMW.mjs.map
270
+ //# sourceMappingURL=chunk-WRVRDZDA.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/Relation.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\n// @import-as-namespace\n\nimport * as Schema from 'effect/Schema';\n\nimport { raise } from '@dxos/debug';\nimport type { ForeignKey } from '@dxos/echo-protocol';\nimport { createJsonPath } from '@dxos/effect';\nimport { assertArgument, invariant } from '@dxos/invariant';\nimport { DXN, type ObjectId } from '@dxos/keys';\nimport { assumeType } from '@dxos/util';\n\nimport type * as Database from './Database';\nimport * as Entity from './Entity';\nimport * as internal from './internal';\nimport * as entityInternal from './internal/Entity';\nimport * as Obj from './Obj';\nimport type * as Type from './Type';\n\nexport type Endpoints<Source, Target> = {\n [Source]: Source;\n [Target]: Target;\n};\n\n/**\n * Base type for all ECHO relations.\n * @private\n */\ninterface BaseRelation<Source, Target>\n extends internal.AnyEntity, Endpoints<Source, Target>, Entity.OfKind<internal.EntityKind.Relation> {}\n\n/**\n * Relation with no known properties beyond id, kind, source, and target.\n * Use this when the relation's schema/properties are not known.\n *\n * NOTE: This is a TypeScript type only, not a schema.\n * To validate that a value is an ECHO relation, use `Relation.isRelation`.\n */\nexport interface Unknown extends BaseRelation<Obj.Unknown, Obj.Unknown> {}\n\n/**\n * Runtime Effect schema for any ECHO relation.\n * Use for validation, parsing, or as a reference target for collections.\n * A relation has `id`, source, and target fields plus any additional properties.\n *\n * NOTE: `Schema.is(Type.Relation)` does STRUCTURAL validation only (checks for `id` field).\n * Use `Relation.isRelation()` for proper ECHO instance type guards that check the KindId brand.\n *\n * @example\n * ```ts\n * // Structural type guard (accepts any object with id field)\n * if (Schema.is(Type.Relation)(unknownValue)) { ... }\n *\n * // ECHO instance type guard (checks KindId brand)\n * if (Relation.isRelation(unknownValue)) { ... }\n * ```\n */\n// TODO(dmaretskyi): Change ObjModule.Any to ObjModule.Unknown to have stricter types.\nexport const Unknown: Type.Relation<Unknown, Obj.Any, Obj.Any> = Schema.Struct({\n id: Schema.String,\n}).pipe(\n Schema.extend(Schema.Record({ key: Schema.String, value: Schema.Unknown })),\n // TODO(dmaretskyi): Clean this up.\n // NOTE: The EchoRelationSchema annotation is required for Ref.Ref(Relation.Unknown) to work.\n // The typename/version/source/target only satisfy ECHO schema machinery for reference targets.\n internal.EchoRelationSchema({\n typename: 'org.dxos.schema.anyRelation',\n version: '0.0.0',\n source: Obj.Unknown,\n target: Obj.Unknown,\n }),\n (schema) =>\n Object.assign(schema, {\n [internal.SchemaKindId]: (schema as any)[internal.SchemaKindId],\n }) as unknown as Type.Relation<Unknown, Obj.Any, Obj.Any>,\n);\n\n/**\n * Relation type with specific source and target types.\n */\nexport type OfShape<Source extends Obj.Unknown, Target extends Obj.Unknown, Props> = BaseRelation<Source, Target> &\n Props;\n\n/**\n * Base type for snapshot relations (has SnapshotKindId instead of KindId).\n */\ninterface BaseRelationSnapshot<Source, Target> extends internal.AnyEntity, Endpoints<Source, Target> {\n readonly [Entity.SnapshotKindId]: internal.EntityKind.Relation;\n readonly id: ObjectId;\n}\n\n/**\n * JSON-encoded properties for relations.\n */\nexport interface BaseRelationJson {\n id: string;\n [internal.ATTR_RELATION_SOURCE]: string;\n [internal.ATTR_RELATION_TARGET]: string;\n}\n\n/**\n * Immutable snapshot of an ECHO relation.\n * Branded with SnapshotKindId (not KindId).\n * Property values are frozen at the time the snapshot was created.\n * Returned by getSnapshot() and hooks.\n */\nexport type Snapshot<T extends Unknown = Unknown> = Omit<T, Entity.KindId> &\n BaseRelationSnapshot<Obj.Unknown, Obj.Unknown>;\n\nexport const Source: unique symbol = entityInternal.RelationSourceId as any;\nexport type Source = typeof Source;\n\nexport const Target: unique symbol = entityInternal.RelationTargetId as any;\nexport type Target = typeof Target;\n\n/**\n * Get relation source type.\n */\nexport type SourceOf<A> = A extends Endpoints<infer S, infer _T> ? S : never;\n\n/**\n * Get relation target type.\n */\nexport type TargetOf<A> = A extends Endpoints<infer _S, infer T> ? T : never;\n\n/**\n * Internal props type for relation instance creation.\n */\ntype MakePropsInternal<T extends Unknown> = {\n id?: ObjectId;\n [Meta]?: internal.ObjectMeta;\n [Source]: T[Source];\n [Target]: T[Target];\n} & Entity.Properties<T>;\n\n/**\n * Props type for relation creation with a given schema.\n * Takes a schema type (created with Type.Relation) and extracts the props type.\n */\nexport type MakeProps<S extends Type.AnyRelation> = MakePropsInternal<Schema.Schema.Type<S>>;\n\n/**\n * Creates new relation.\n * @param schema - Relation schema.\n * @param props - Relation properties. Endpoints are passed as [Relation.Source] and [Relation.Target] keys.\n * @param meta - Relation metadata. (deprecated; use [Obj.Meta] instead)\n * @returns\n */\n// NOTE: Writing the definition this way (with generic over schema) makes typescript perfer to infer the type from the first param (this schema) rather than the second param (the props).\n// TODO(dmaretskyi): Move meta into props.\nexport const make = <S extends Type.AnyRelation>(\n schema: S,\n props: NoInfer<MakeProps<S>>,\n): Schema.Schema.Type<S> & Entity.OfKind<typeof Entity.Kind.Relation> => {\n assertArgument(\n internal.getTypeAnnotation(schema)?.kind === internal.EntityKind.Relation,\n 'schema',\n 'Expected a relation schema',\n );\n assertArgument(props[internal.ParentId] === undefined, 'props', 'Parent is not allowed for relations');\n\n let meta: internal.ObjectMeta | undefined = undefined;\n\n if (props[internal.MetaId] != null) {\n meta = props[internal.MetaId] as any;\n delete props[internal.MetaId];\n }\n\n const sourceDXN = internal.getObjectDXN(props[Source]) ?? raise(new Error('Unresolved relation source'));\n const targetDXN = internal.getObjectDXN(props[Target]) ?? raise(new Error('Unresolved relation target'));\n\n (props as any)[internal.RelationSourceDXNId] = sourceDXN;\n (props as any)[internal.RelationTargetDXNId] = targetDXN;\n\n return internal.makeObject<Schema.Schema.Type<S>>(schema, props as any, meta);\n};\n\n/**\n * Type guard for relations.\n * Returns true for both reactive relations and relation snapshots.\n */\nexport const isRelation = (value: unknown): value is Unknown => {\n if (typeof value !== 'object' || value === null) {\n return false;\n }\n if (internal.ATTR_RELATION_SOURCE in value || internal.ATTR_RELATION_TARGET in value) {\n return true;\n }\n\n // Check for reactive relation (KindId) or snapshot (SnapshotKindId).\n const kind = (value as any)[Entity.KindId] ?? (value as any)[Entity.SnapshotKindId];\n return kind === internal.EntityKind.Relation;\n};\n\nexport const isSnapshot = (value: unknown): value is Snapshot => {\n if (typeof value !== 'object' || value === null) {\n return false;\n }\n return (value as any)[Entity.SnapshotKindId] === internal.EntityKind.Relation;\n};\n\n/**\n * @returns Relation source DXN.\n * Accepts both reactive relations and snapshots.\n * @throws If the object is not a relation.\n */\nexport const getSourceDXN = (value: Unknown | Snapshot): DXN => {\n assertArgument(isRelation(value), 'Expected a relation');\n assumeType<internal.InternalObjectProps>(value);\n const dxn = (value as internal.InternalObjectProps)[internal.RelationSourceDXNId];\n invariant(dxn instanceof DXN);\n return dxn;\n};\n\n/**\n * @returns Relation target DXN.\n * Accepts both reactive relations and snapshots.\n * @throws If the object is not a relation.\n */\nexport const getTargetDXN = (value: Unknown | Snapshot): DXN => {\n assertArgument(isRelation(value), 'Expected a relation');\n assumeType<internal.InternalObjectProps>(value);\n const dxn = (value as internal.InternalObjectProps)[internal.RelationTargetDXNId];\n invariant(dxn instanceof DXN);\n return dxn;\n};\n\n/**\n * @returns Relation source.\n * Accepts both reactive relations and snapshots.\n * @throws If the object is not a relation.\n */\nexport const getSource = <T extends Unknown | Snapshot>(relation: T): SourceOf<T> => {\n assertArgument(isRelation(relation), 'Expected a relation');\n assumeType<internal.InternalObjectProps>(relation);\n const obj = (relation as internal.InternalObjectProps)[internal.RelationSourceId];\n if (obj === undefined) {\n throw new Error(`Relation source could not be resolved.`);\n }\n return obj as SourceOf<T>;\n};\n\n/**\n * @returns Relation target.\n * Accepts both reactive relations and snapshots.\n * @throws If the object is not a relation.\n */\nexport const getTarget = <T extends Unknown | Snapshot>(relation: T): TargetOf<T> => {\n assertArgument(isRelation(relation), 'Expected a relation');\n assumeType<internal.InternalObjectProps>(relation);\n const obj = (relation as internal.InternalObjectProps)[internal.RelationTargetId];\n if (obj === undefined) {\n throw new Error(`Relation target could not be resolved.`);\n }\n return obj as TargetOf<T>;\n};\n\n//\n// Change\n//\n\n/**\n * Makes all properties mutable recursively.\n * Used to provide a mutable view of a relation within `Relation.update`.\n */\nexport type Mutable<T> = internal.Mutable<T>;\n\n/**\n * Perform mutations on an echo relation within a controlled context.\n *\n * All mutations within the callback are batched and trigger a single notification\n * when the callback completes. Direct mutations outside of `Relation.update` will throw\n * an error for echo relations.\n *\n * @param relation - The echo relation to mutate. Use `Obj.update` for objects.\n * @param callback - The callback that performs mutations on the relation.\n *\n * @example\n * ```ts\n * const worksFor = Relation.make(EmployedBy, {\n * [Relation.Source]: person,\n * [Relation.Target]: company,\n * role: 'Engineer',\n * });\n *\n * // Mutate within Relation.update\n * Relation.update(worksFor, (obj) => {\n * obj.role = 'Senior Engineer';\n * });\n * ```\n *\n * Note: Only accepts relations. Use `Obj.update` for objects.\n */\nexport const update = <T extends Unknown>(relation: T, callback: internal.ChangeCallback<T>): void => {\n internal.change(relation, callback);\n};\n\n//\n// Snapshot\n//\n\n/**\n * Returns an immutable snapshot of a relation.\n * The snapshot is branded with SnapshotKindId instead of KindId,\n * making it distinguishable from the reactive relation at the type level.\n */\nexport const getSnapshot: <T extends Unknown>(rel: T) => Snapshot<T> = internal.getSnapshot as any;\n\n//\n// Subscribe\n//\n\n/**\n * Subscribe to relation updates.\n * The callback is called synchronously when the relation is modified.\n * Only accepts reactive relations (not snapshots).\n * @returns Unsubscribe function.\n */\nexport const subscribe = (rel: Unknown, callback: () => void): (() => void) => {\n return internal.subscribe(rel, callback);\n};\n\n//\n// Property Access\n//\n\n/**\n * Get a deeply nested property from a relation.\n * Accepts both reactive relations and snapshots.\n */\nexport const getValue = (rel: Unknown | Snapshot, path: readonly (string | number)[]): any => {\n return internal.getValue(rel, createJsonPath(path));\n};\n\n/**\n * Set a deeply nested property on a relation.\n * Must be called within a `Relation.update` callback.\n *\n * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`\n * parameters, so there is no compile-time error. Enforcement is runtime-only.\n */\nexport const setValue: (rel: Mutable<Unknown>, path: readonly (string | number)[], value: any) => void =\n internal.setValue as any;\n\n//\n// Type\n//\n\n/**\n * Get the DXN of the relation.\n * Accepts both reactive relations and snapshots.\n */\nexport const getDXN = (entity: Unknown | Snapshot): DXN => internal.getDXN(entity);\n\n/**\n * @returns The DXN of the relation's type.\n */\nexport const getTypeDXN = internal.getTypeDXN;\n\n/**\n * Get the schema of the relation.\n * Returns the branded ECHO schema used to create the relation.\n */\nexport const getSchema: (rel: unknown | undefined) => Type.AnyEntity | undefined = internal.getSchema as any;\n\n/**\n * @returns The typename of the relation's type.\n * Accepts both reactive relations and snapshots.\n */\nexport const getTypename = (entity: Unknown | Snapshot): string | undefined => internal.getTypename(entity);\n\n//\n// Database\n//\n\n/**\n * Get the database the relation belongs to.\n * Accepts both reactive relations and snapshots.\n */\nexport const getDatabase = (entity: Unknown | Snapshot): Database.Database | undefined => internal.getDatabase(entity);\n\n//\n// Meta\n//\n\n/**\n * Property that accesses metadata for an entity.\n *\n * Alias for `Entity.Meta`.\n */\nexport const Meta = internal.MetaId;\n\n/**\n * Deeply read-only version of ObjectMeta.\n */\nexport type ReadonlyMeta = internal.ReadonlyMeta;\n\n/**\n * Mutable meta type returned by `Relation.getMeta` inside a `Relation.update` callback.\n */\nexport type Meta = internal.Meta;\n\n/**\n * Get the metadata for a relation.\n * Returns mutable meta when passed a mutable relation (inside `Relation.update` callback).\n * Returns read-only meta when passed a regular relation or snapshot.\n */\n// TODO(wittjosiah): When passed a Snapshot, should return a snapshot of meta, not the live meta proxy.\nexport function getMeta(entity: Mutable<Unknown>): Meta;\nexport function getMeta(entity: Unknown | Snapshot): ReadonlyMeta;\nexport function getMeta(entity: Unknown | Snapshot | Mutable<Unknown>): Meta | ReadonlyMeta {\n return internal.getMetaChecked(entity);\n}\n\n/**\n * @returns Foreign keys for the relation from the specified source.\n * Accepts both reactive relations and snapshots.\n */\nexport const getKeys = (entity: Unknown | Snapshot, source: string): ForeignKey[] => internal.getKeys(entity, source);\n\n/**\n * Delete all keys from the relation for the specified source.\n * Must be called within a `Relation.update` callback.\n *\n * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`\n * parameters, so there is no compile-time error. Enforcement is runtime-only.\n */\nexport const deleteKeys = (entity: Mutable<Unknown>, source: string): void => internal.deleteKeys(entity, source);\n\n/**\n * Add a tag to the relation.\n * Must be called within a `Relation.update` callback.\n *\n * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`\n * parameters, so there is no compile-time error. Enforcement is runtime-only.\n */\nexport const addTag = (entity: Mutable<Unknown>, tag: string): void => internal.addTag(entity, tag);\n\n/**\n * Remove a tag from the relation.\n * Must be called within a `Relation.update` callback.\n *\n * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`\n * parameters, so there is no compile-time error. Enforcement is runtime-only.\n */\nexport const removeTag = (entity: Mutable<Unknown>, tag: string): void => internal.removeTag(entity, tag);\n\n/**\n * Check if the relation is deleted.\n * Accepts both reactive relations and snapshots.\n */\nexport const isDeleted = (entity: Unknown | Snapshot): boolean => internal.isDeleted(entity);\n\n//\n// Annotations\n//\n\n/**\n * Get the label of the relation.\n * Accepts both reactive relations and snapshots.\n */\nexport const getLabel = (entity: Unknown | Snapshot): string | undefined => internal.getLabel(entity);\n\n/**\n * Set the label of the relation.\n * Must be called within a `Relation.update` callback.\n *\n * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`\n * parameters, so there is no compile-time error. Enforcement is runtime-only.\n */\nexport const setLabel = (entity: Mutable<Unknown>, label: string): void => internal.setLabel(entity, label);\n\n/**\n * Get the description of the relation.\n * Accepts both reactive relations and snapshots.\n */\nexport const getDescription = (entity: Unknown | Snapshot): string | undefined => internal.getDescription(entity);\n\n/**\n * Set the description of the relation.\n * Must be called within a `Relation.update` callback.\n *\n * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`\n * parameters, so there is no compile-time error. Enforcement is runtime-only.\n */\nexport const setDescription = (entity: Mutable<Unknown>, description: string): void =>\n internal.setDescription(entity, description);\n\n//\n// JSON\n//\n\n/**\n * JSON representation of a relation.\n */\nexport type JSON = internal.ObjectJSON;\n\n/**\n * Converts relation to its JSON representation.\n * Accepts both reactive relations and snapshots.\n */\nexport const toJSON = (entity: Unknown | Snapshot): JSON => internal.objectToJSON(entity);\n\n//\n// Sorting\n//\n\n/**\n * Comparator function type for sorting relations.\n * Accepts both reactive relations and snapshots.\n */\nexport type Comparator = internal.Comparator<Unknown | Snapshot>;\n\nexport const sortByLabel: Comparator = internal.sortByLabel as Comparator;\nexport const sortByTypename: Comparator = internal.sortByTypename as Comparator;\nexport const sort = (...comparators: Comparator[]): Comparator => internal.sort(...comparators) as Comparator;\n\n//\n// Version\n//\n\nexport const VersionTypeId = internal.VersionTypeId;\nexport const isVersion = internal.isVersion;\n\n/**\n * Represent relation version.\n */\nexport type Version = internal.EntityVersion;\n\n/**\n * Returns the version of the relation.\n * Accepts both reactive relations and snapshots.\n */\nexport const version = (entity: Unknown | Snapshot): Version => internal.version(entity);\n"],
5
+ "mappings": "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",
6
+ "names": ["Unknown", "VersionTypeId", "addTag", "deleteKeys", "getDXN", "getDatabase", "getDescription", "getKeys", "getLabel", "getSchema", "getSnapshot", "getTypeDXN", "getTypename", "getValue", "isDeleted", "isVersion", "removeTag", "setDescription", "setLabel", "setValue", "sort", "sortByLabel", "sortByTypename", "subscribe", "version", "Schema", "raise", "createJsonPath", "assertArgument", "invariant", "DXN", "assumeType", "Schema", "Record", "key", "version", "source", "Obj", "target", "Object", "internal", "Source", "entityInternal", "RelationSourceId", "assertArgument", "props", "ParentId", "undefined", "meta", "MetaId", "sourceDXN", "getObjectDXN", "RelationSourceDXNId", "RelationTargetDXNId", "targetDXN", "schema", "value", "assumeType", "invariant", "dxn", "relation", "obj", "RelationTargetId", "getSnapshot", "subscribe", "getValue", "setValue", "getTypename", "getDatabase", "getMetaChecked", "isDeleted", "sortByTypename", "sort", "comparators", "VersionTypeId"]
7
+ }
@@ -48,4 +48,4 @@ export {
48
48
  GetReactiveError,
49
49
  Err_exports
50
50
  };
51
- //# sourceMappingURL=chunk-UBEZSGXY.mjs.map
51
+ //# sourceMappingURL=chunk-ZISMEVKD.mjs.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/Err.ts"],
4
4
  "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\n// @import-as-namespace\n\nimport { BaseError, type BaseErrorOptions } from '@dxos/errors';\nimport { type DXN } from '@dxos/keys';\n\nexport class SchemaNotFoundError extends BaseError.extend('SchemaNotFoundError', 'Schema not found') {\n constructor(schema: string, options?: BaseErrorOptions) {\n super({ context: { schema }, ...options });\n }\n}\n\nexport class ObjectNotFoundError extends BaseError.extend('ObjectNotFoundError', 'Object not found') {\n constructor(dxn: DXN, options?: BaseErrorOptions) {\n super({ context: { dxn }, ...options });\n }\n}\n\n/**\n * Reason why getting a reactive object from a snapshot failed.\n * - `no-database`: The snapshot is not associated with a database.\n * - `object-not-found`: The object was removed or does not exist in the database.\n */\nexport type GetReactiveErrorReason = 'no-database' | 'object-not-found';\n\n/**\n * Error thrown when a reactive object cannot be resolved from a snapshot.\n * Extends `BaseError` with a `reason` and optional `snapshotId` in its context.\n */\nexport class GetReactiveError extends BaseError.extend(\n 'GetReactiveError',\n 'Failed to get reactive object from snapshot',\n) {\n constructor(options: { reason: GetReactiveErrorReason; snapshotId?: string } & BaseErrorOptions) {\n super({ context: { reason: options.reason, snapshotId: options.snapshotId }, ...options });\n }\n}\n"],
5
- "mappings": ";;;;;AAAA;;;;;;AAMA,SAASA,iBAAwC;AAG1C,IAAMC,sBAAN,cAAkCC,UAAUC,OAAO,uBAAuB,kBAAA,EAAA;EAC/E,YAAYC,QAAgBC,SAA4B;AACtD,UAAM;MAAEC,SAAS;QAAEF;MAAO;MAAG,GAAGC;IAAQ,CAAA;EAC1C;AACF;AAEO,IAAME,sBAAN,cAAkCL,UAAUC,OAAO,uBAAuB,kBAAA,EAAA;EAC/E,YAAYK,KAAUH,SAA4B;AAChD,UAAM;MAAEC,SAAS;QAAEE;MAAI;MAAG,GAAGH;IAAQ,CAAA;EACvC;AACF;AAaO,IAAMI,mBAAN,cAA+BP,UAAUC,OAC9C,oBACA,6CAAA,EAAA;EAEA,YAAYE,SAAqF;AAC/F,UAAM;MAAEC,SAAS;QAAEI,QAAQL,QAAQK;QAAQC,YAAYN,QAAQM;MAAW;MAAG,GAAGN;IAAQ,CAAA;EAC1F;AACF;",
6
- "names": ["BaseError", "SchemaNotFoundError", "BaseError", "extend", "schema", "options", "context", "ObjectNotFoundError", "dxn", "GetReactiveError", "reason", "snapshotId"]
5
+ "mappings": ";;;;;AAAA;;;;;;AAMA,SAASA,iBAAwC;AAG1C,IAAMC,sBAAN,cAAkCD,UAAUE,OAAO,uBAAuB,kBAAA,EAAA;EAC/E,YAAYC,QAAgBC,SAA4B;AACtD,UAAM;MAAEC,SAAS;QAAEF;MAAO;MAAG,GAAGC;IAAQ,CAAA;EAC1C;AACF;AAEO,IAAME,sBAAN,cAAkCN,UAAUE,OAAO,uBAAuB,kBAAA,EAAA;EAC/E,YAAYK,KAAUH,SAA4B;AAChD,UAAM;MAAEC,SAAS;QAAEE;MAAI;MAAG,GAAGH;IAAQ,CAAA;EACvC;AACF;AAaO,IAAMI,mBAAN,cAA+BR,UAAUE,OAC9C,oBACA,6CAAA,EAAA;EAEA,YAAYE,SAAqF;AAC/F,UAAM;MAAEC,SAAS;QAAEI,QAAQL,QAAQK;QAAQC,YAAYN,QAAQM;MAAW;MAAG,GAAGN;IAAQ,CAAA;EAC1F;AACF;",
6
+ "names": ["BaseError", "SchemaNotFoundError", "extend", "schema", "options", "context", "ObjectNotFoundError", "dxn", "GetReactiveError", "reason", "snapshotId"]
7
7
  }
@@ -3,70 +3,77 @@ import {
3
3
  DXN,
4
4
  Dataset_exports,
5
5
  Hypergraph_exports,
6
+ Json_exports,
6
7
  QueryAST,
7
8
  View_exports
8
- } from "./chunk-VA2F47ZC.mjs";
9
+ } from "./chunk-QXIANHKU.mjs";
9
10
  import {
10
11
  SchemaRegistry_exports
11
- } from "./chunk-BNCCGLJN.mjs";
12
+ } from "./chunk-BICZKPQG.mjs";
12
13
  import {
13
14
  Tag_exports
14
- } from "./chunk-724GQYEN.mjs";
15
+ } from "./chunk-HPNQTEEQ.mjs";
15
16
  import {
16
17
  Order_exports
17
- } from "./chunk-UI6MWK5W.mjs";
18
+ } from "./chunk-TTCSATUD.mjs";
18
19
  import {
19
20
  Key_exports
20
- } from "./chunk-ANHVGJI4.mjs";
21
+ } from "./chunk-7RVZT53K.mjs";
22
+ import {
23
+ Migration_exports
24
+ } from "./chunk-SUZMWP3Y.mjs";
25
+ import {
26
+ Extension_exports
27
+ } from "./chunk-GWFFC34K.mjs";
21
28
  import {
22
29
  Format_exports
23
- } from "./chunk-FZO7LQO7.mjs";
30
+ } from "./chunk-44HT3MEC.mjs";
24
31
  import {
25
32
  Relation_exports
26
- } from "./chunk-CIRHIEMW.mjs";
33
+ } from "./chunk-WRVRDZDA.mjs";
27
34
  import {
28
35
  JsonSchema_exports
29
- } from "./chunk-UTBRYVQC.mjs";
36
+ } from "./chunk-QGMIH2SN.mjs";
30
37
  import {
31
38
  QueryResult_exports
32
- } from "./chunk-OMUPQMLR.mjs";
39
+ } from "./chunk-V72DY6LU.mjs";
33
40
  import {
34
41
  Query_exports
35
- } from "./chunk-KTAWP7GI.mjs";
42
+ } from "./chunk-VGKLHHRT.mjs";
36
43
  import {
37
44
  Feed_exports
38
- } from "./chunk-DYDJBZEG.mjs";
45
+ } from "./chunk-S7IMFVTB.mjs";
39
46
  import {
40
47
  Type_exports
41
- } from "./chunk-RMLF7JOZ.mjs";
48
+ } from "./chunk-FZHVQEHN.mjs";
42
49
  import {
43
50
  Filter_exports
44
- } from "./chunk-NXMFBIT5.mjs";
45
- import {
46
- Ref_exports
47
- } from "./chunk-FXEG7EOK.mjs";
51
+ } from "./chunk-RF7ZBZ4A.mjs";
48
52
  import {
49
53
  Obj_exports
50
- } from "./chunk-NQRLRYJM.mjs";
54
+ } from "./chunk-SW5CUSBY.mjs";
55
+ import {
56
+ Ref_exports
57
+ } from "./chunk-VYAGNFSJ.mjs";
51
58
  import {
52
59
  Entity_exports
53
- } from "./chunk-UFDK26FO.mjs";
54
- import "./chunk-TQQZLKB7.mjs";
55
- import "./chunk-YWXWXIE5.mjs";
56
- import "./chunk-BOZZPUXE.mjs";
57
- import "./chunk-B5OXLWZL.mjs";
58
- import "./chunk-43Y5DOS6.mjs";
60
+ } from "./chunk-LVGOVFDV.mjs";
61
+ import "./chunk-SJKBWMJY.mjs";
62
+ import "./chunk-6VIJV543.mjs";
63
+ import "./chunk-O5LRY6CO.mjs";
64
+ import "./chunk-TRPZU2HV.mjs";
65
+ import "./chunk-MPAI2MHO.mjs";
59
66
  import {
60
67
  Annotation_exports
61
- } from "./chunk-OENWMTE6.mjs";
68
+ } from "./chunk-5SL5LDLD.mjs";
62
69
  import {
63
70
  Database_exports
64
- } from "./chunk-NEGC54NE.mjs";
65
- import "./chunk-SEMVAGBM.mjs";
66
- import "./chunk-WYOKA6AE.mjs";
71
+ } from "./chunk-FHYIM4RD.mjs";
72
+ import "./chunk-TNBK56IN.mjs";
73
+ import "./chunk-N4B7FHQT.mjs";
67
74
  import {
68
75
  Err_exports
69
- } from "./chunk-UBEZSGXY.mjs";
76
+ } from "./chunk-ZISMEVKD.mjs";
70
77
  import "./chunk-J5LGTIGS.mjs";
71
78
  export {
72
79
  Annotation_exports as Annotation,
@@ -76,12 +83,15 @@ export {
76
83
  Dataset_exports as Dataset,
77
84
  Entity_exports as Entity,
78
85
  Err_exports as Err,
86
+ Extension_exports as Extension,
79
87
  Feed_exports as Feed,
80
88
  Filter_exports as Filter,
81
89
  Format_exports as Format,
82
90
  Hypergraph_exports as Hypergraph,
91
+ Json_exports as Json,
83
92
  JsonSchema_exports as JsonSchema,
84
93
  Key_exports as Key,
94
+ Migration_exports as Migration,
85
95
  Obj_exports as Obj,
86
96
  Order_exports as Order,
87
97
  Query_exports as Query,
@@ -85,6 +85,8 @@ import {
85
85
  objectStructureToJson,
86
86
  objectToJSON,
87
87
  prepareTypedTarget,
88
+ prettyFilter,
89
+ prettyQuery,
88
90
  queueNotification,
89
91
  queueOwnerNotification,
90
92
  removeFieldsFromSchema,
@@ -104,10 +106,10 @@ import {
104
106
  updateFieldsInSchema,
105
107
  version,
106
108
  versionValid
107
- } from "../chunk-TQQZLKB7.mjs";
109
+ } from "../chunk-SJKBWMJY.mjs";
108
110
  import {
109
111
  RefArray
110
- } from "../chunk-YWXWXIE5.mjs";
112
+ } from "../chunk-6VIJV543.mjs";
111
113
  import {
112
114
  CustomAnnotations,
113
115
  DecodedAnnotations,
@@ -124,7 +126,7 @@ import {
124
126
  toEffectSchema,
125
127
  toJsonSchema,
126
128
  toPropType
127
- } from "../chunk-BOZZPUXE.mjs";
129
+ } from "../chunk-O5LRY6CO.mjs";
128
130
  import {
129
131
  Currency,
130
132
  CurrencyAnnotationId,
@@ -155,7 +157,7 @@ import {
155
157
  getOptionsAnnotation,
156
158
  getTypeEnum,
157
159
  typeToFormat
158
- } from "../chunk-B5OXLWZL.mjs";
160
+ } from "../chunk-TRPZU2HV.mjs";
159
161
  import {
160
162
  JSON_SCHEMA_ECHO_REF_ID,
161
163
  Ref,
@@ -169,8 +171,8 @@ import {
169
171
  getSchemaReference,
170
172
  refFromEncodedReference,
171
173
  setRefResolver
172
- } from "../chunk-43Y5DOS6.mjs";
173
- import "../chunk-NEGC54NE.mjs";
174
+ } from "../chunk-MPAI2MHO.mjs";
175
+ import "../chunk-FHYIM4RD.mjs";
174
176
  import {
175
177
  ATTR_PARENT,
176
178
  ATTR_TYPE,
@@ -184,6 +186,7 @@ import {
184
186
  GeneratorAnnotation,
185
187
  GeneratorAnnotationId,
186
188
  IconAnnotation,
189
+ IconFromRefAnnotation,
187
190
  LabelAnnotation,
188
191
  LabelAnnotationId,
189
192
  ParentId,
@@ -225,7 +228,7 @@ import {
225
228
  setLabelWithSchema,
226
229
  setSchema,
227
230
  setTypename
228
- } from "../chunk-SEMVAGBM.mjs";
231
+ } from "../chunk-TNBK56IN.mjs";
229
232
  import {
230
233
  ANY_OBJECT_TYPENAME,
231
234
  ANY_OBJECT_VERSION,
@@ -237,8 +240,8 @@ import {
237
240
  createAnnotationHelper,
238
241
  makeTypeJsonSchemaAnnotation,
239
242
  unwrapOptional
240
- } from "../chunk-WYOKA6AE.mjs";
241
- import "../chunk-UBEZSGXY.mjs";
243
+ } from "../chunk-N4B7FHQT.mjs";
244
+ import "../chunk-ZISMEVKD.mjs";
242
245
  import "../chunk-J5LGTIGS.mjs";
243
246
  export {
244
247
  ANY_OBJECT_TYPENAME,
@@ -284,6 +287,7 @@ export {
284
287
  GeoPoint,
285
288
  Hostname,
286
289
  IconAnnotation,
290
+ IconFromRefAnnotation,
287
291
  ImmutableSchema,
288
292
  JSON,
289
293
  JSON_SCHEMA_ECHO_REF_ID,
@@ -433,6 +437,8 @@ export {
433
437
  objectStructureToJson,
434
438
  objectToJSON,
435
439
  prepareTypedTarget,
440
+ prettyFilter,
441
+ prettyQuery,
436
442
  queueNotification,
437
443
  queueOwnerNotification,
438
444
  refFromEncodedReference,