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

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 (559) hide show
  1. package/README.md +3 -4
  2. package/dist/lib/neutral/Annotation.mjs +37 -0
  3. package/dist/lib/neutral/Database.mjs +45 -0
  4. package/dist/lib/neutral/Entity.mjs +56 -0
  5. package/dist/lib/neutral/Err.mjs +12 -0
  6. package/dist/lib/neutral/Feed.mjs +43 -0
  7. package/dist/lib/neutral/Filter.mjs +61 -0
  8. package/dist/lib/neutral/Format.mjs +66 -0
  9. package/dist/lib/neutral/Format.mjs.map +7 -0
  10. package/dist/lib/neutral/JsonSchema.mjs +18 -0
  11. package/dist/lib/neutral/JsonSchema.mjs.map +7 -0
  12. package/dist/lib/neutral/Key.mjs +12 -0
  13. package/dist/lib/neutral/Key.mjs.map +7 -0
  14. package/dist/lib/neutral/Obj.mjs +107 -0
  15. package/dist/lib/neutral/Obj.mjs.map +7 -0
  16. package/dist/lib/neutral/Order.mjs +12 -0
  17. package/dist/lib/neutral/Order.mjs.map +7 -0
  18. package/dist/lib/neutral/Query.mjs +32 -0
  19. package/dist/lib/neutral/Query.mjs.map +7 -0
  20. package/dist/lib/neutral/QueryResult.mjs +2 -0
  21. package/dist/lib/neutral/QueryResult.mjs.map +7 -0
  22. package/dist/lib/neutral/Ref.mjs +24 -0
  23. package/dist/lib/neutral/Ref.mjs.map +7 -0
  24. package/dist/lib/neutral/Relation.mjs +90 -0
  25. package/dist/lib/neutral/Relation.mjs.map +7 -0
  26. package/dist/lib/neutral/SchemaRegistry.mjs +2 -0
  27. package/dist/lib/neutral/SchemaRegistry.mjs.map +7 -0
  28. package/dist/lib/neutral/Tag.mjs +25 -0
  29. package/dist/lib/neutral/Tag.mjs.map +7 -0
  30. package/dist/lib/neutral/Type.mjs +34 -0
  31. package/dist/lib/neutral/Type.mjs.map +7 -0
  32. package/dist/lib/neutral/chunk-4KG6IGL4.mjs +67 -0
  33. package/dist/lib/neutral/chunk-4KG6IGL4.mjs.map +7 -0
  34. package/dist/lib/neutral/chunk-5ELDDYWE.mjs +130 -0
  35. package/dist/lib/neutral/chunk-5ELDDYWE.mjs.map +7 -0
  36. package/dist/lib/neutral/chunk-ALOGSVBP.mjs +299 -0
  37. package/dist/lib/neutral/chunk-ALOGSVBP.mjs.map +7 -0
  38. package/dist/lib/neutral/chunk-ANHVGJI4.mjs +21 -0
  39. package/dist/lib/neutral/chunk-ANHVGJI4.mjs.map +7 -0
  40. package/dist/lib/neutral/chunk-AQP4QKYP.mjs +283 -0
  41. package/dist/lib/neutral/chunk-AQP4QKYP.mjs.map +7 -0
  42. package/dist/lib/neutral/chunk-BRJSLACP.mjs +152 -0
  43. package/dist/lib/neutral/chunk-BRJSLACP.mjs.map +7 -0
  44. package/dist/lib/neutral/chunk-DZQSL6RW.mjs +73 -0
  45. package/dist/lib/neutral/chunk-DZQSL6RW.mjs.map +7 -0
  46. package/dist/lib/neutral/chunk-F7KMHDPJ.mjs +327 -0
  47. package/dist/lib/neutral/chunk-F7KMHDPJ.mjs.map +7 -0
  48. package/dist/lib/neutral/chunk-GAWKQ5DZ.mjs +56 -0
  49. package/dist/lib/neutral/chunk-GAWKQ5DZ.mjs.map +7 -0
  50. package/dist/lib/neutral/chunk-GFNCSK7F.mjs +101 -0
  51. package/dist/lib/neutral/chunk-GFNCSK7F.mjs.map +7 -0
  52. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  53. package/dist/lib/neutral/chunk-J5LGTIGS.mjs.map +7 -0
  54. package/dist/lib/neutral/chunk-KGV3QIRX.mjs +313 -0
  55. package/dist/lib/neutral/chunk-KGV3QIRX.mjs.map +7 -0
  56. package/dist/lib/neutral/chunk-M2KVTHZM.mjs +402 -0
  57. package/dist/lib/neutral/chunk-M2KVTHZM.mjs.map +7 -0
  58. package/dist/lib/neutral/chunk-MXQJZCPY.mjs +51 -0
  59. package/dist/lib/neutral/chunk-MXQJZCPY.mjs.map +7 -0
  60. package/dist/lib/neutral/chunk-O3TZFQCT.mjs +27 -0
  61. package/dist/lib/neutral/chunk-O3TZFQCT.mjs.map +7 -0
  62. package/dist/lib/neutral/chunk-OMUPQMLR.mjs +7 -0
  63. package/dist/lib/neutral/chunk-OMUPQMLR.mjs.map +7 -0
  64. package/dist/lib/neutral/chunk-OVUBTQLT.mjs +45 -0
  65. package/dist/lib/neutral/chunk-OVUBTQLT.mjs.map +7 -0
  66. package/dist/lib/neutral/chunk-PP4DNUZU.mjs +3919 -0
  67. package/dist/lib/neutral/chunk-PP4DNUZU.mjs.map +7 -0
  68. package/dist/lib/neutral/chunk-QXF3LGN2.mjs +43 -0
  69. package/dist/lib/neutral/chunk-QXF3LGN2.mjs.map +7 -0
  70. package/dist/lib/neutral/chunk-T4MPQJ7X.mjs +97 -0
  71. package/dist/lib/neutral/chunk-T4MPQJ7X.mjs.map +7 -0
  72. package/dist/lib/neutral/chunk-T6JEFNP6.mjs +7 -0
  73. package/dist/lib/neutral/chunk-T6JEFNP6.mjs.map +7 -0
  74. package/dist/lib/neutral/chunk-W7OP5HGZ.mjs +121 -0
  75. package/dist/lib/neutral/chunk-W7OP5HGZ.mjs.map +7 -0
  76. package/dist/lib/neutral/chunk-ZTUBYOGB.mjs +42 -0
  77. package/dist/lib/neutral/chunk-ZTUBYOGB.mjs.map +7 -0
  78. package/dist/lib/neutral/chunk-ZWKJ4LZJ.mjs +298 -0
  79. package/dist/lib/neutral/chunk-ZWKJ4LZJ.mjs.map +7 -0
  80. package/dist/lib/neutral/index.mjs +94 -0
  81. package/dist/lib/neutral/index.mjs.map +7 -0
  82. package/dist/lib/{node-esm → neutral}/internal/index.mjs +260 -122
  83. package/dist/lib/neutral/internal/index.mjs.map +7 -0
  84. package/dist/lib/neutral/meta.json +1 -0
  85. package/dist/lib/neutral/testing/index.mjs +369 -0
  86. package/dist/lib/neutral/testing/index.mjs.map +7 -0
  87. package/dist/types/src/Annotation.d.ts +24 -0
  88. package/dist/types/src/Annotation.d.ts.map +1 -0
  89. package/dist/types/src/Collection.d.ts +16 -0
  90. package/dist/types/src/Collection.d.ts.map +1 -0
  91. package/dist/types/src/Database.d.ts +189 -0
  92. package/dist/types/src/Database.d.ts.map +1 -0
  93. package/dist/types/src/Dataset.d.ts +18 -0
  94. package/dist/types/src/Dataset.d.ts.map +1 -0
  95. package/dist/types/src/Entity.d.ts +168 -0
  96. package/dist/types/src/Entity.d.ts.map +1 -0
  97. package/dist/types/src/Entity.test.d.ts +2 -0
  98. package/dist/types/src/Entity.test.d.ts.map +1 -0
  99. package/dist/types/src/Err.d.ts +107 -0
  100. package/dist/types/src/Err.d.ts.map +1 -0
  101. package/dist/types/src/Feed.d.ts +165 -0
  102. package/dist/types/src/Feed.d.ts.map +1 -0
  103. package/dist/types/src/Filter.d.ts +120 -0
  104. package/dist/types/src/Filter.d.ts.map +1 -0
  105. package/dist/types/src/Format.d.ts +4 -0
  106. package/dist/types/src/Format.d.ts.map +1 -0
  107. package/dist/types/src/Hypergraph.d.ts +60 -0
  108. package/dist/types/src/Hypergraph.d.ts.map +1 -0
  109. package/dist/types/src/JsonSchema.d.ts +16 -0
  110. package/dist/types/src/JsonSchema.d.ts.map +1 -0
  111. package/dist/types/src/Key.d.ts +1 -0
  112. package/dist/types/src/Key.d.ts.map +1 -1
  113. package/dist/types/src/Obj.d.ts +423 -95
  114. package/dist/types/src/Obj.d.ts.map +1 -1
  115. package/dist/types/src/Obj.test.d.ts +2 -0
  116. package/dist/types/src/Obj.test.d.ts.map +1 -0
  117. package/dist/types/src/Order.d.ts +16 -0
  118. package/dist/types/src/Order.d.ts.map +1 -0
  119. package/dist/types/src/Query.d.ts +202 -0
  120. package/dist/types/src/Query.d.ts.map +1 -0
  121. package/dist/types/src/Query.test.d.ts +2 -0
  122. package/dist/types/src/Query.test.d.ts.map +1 -0
  123. package/dist/types/src/QueryResult.d.ts +80 -0
  124. package/dist/types/src/QueryResult.d.ts.map +1 -0
  125. package/dist/types/src/Ref.d.ts +61 -11
  126. package/dist/types/src/Ref.d.ts.map +1 -1
  127. package/dist/types/src/Relation.d.ts +287 -21
  128. package/dist/types/src/Relation.d.ts.map +1 -1
  129. package/dist/types/src/Relation.test.d.ts +2 -0
  130. package/dist/types/src/Relation.test.d.ts.map +1 -0
  131. package/dist/types/src/SchemaRegistry.d.ts +84 -0
  132. package/dist/types/src/SchemaRegistry.d.ts.map +1 -0
  133. package/dist/types/src/Tag.d.ts +18 -0
  134. package/dist/types/src/Tag.d.ts.map +1 -0
  135. package/dist/types/src/Type.d.ts +120 -97
  136. package/dist/types/src/Type.d.ts.map +1 -1
  137. package/dist/types/src/Type.test.d.ts +2 -0
  138. package/dist/types/src/Type.test.d.ts.map +1 -0
  139. package/dist/types/src/View.d.ts +68 -0
  140. package/dist/types/src/View.d.ts.map +1 -0
  141. package/dist/types/src/hierarchy.test.d.ts +2 -0
  142. package/dist/types/src/hierarchy.test.d.ts.map +1 -0
  143. package/dist/types/src/index.d.ts +19 -5
  144. package/dist/types/src/index.d.ts.map +1 -1
  145. package/dist/types/src/internal/annotations/annotations.d.ts +209 -0
  146. package/dist/types/src/internal/annotations/annotations.d.ts.map +1 -0
  147. package/dist/types/src/internal/annotations/annotations.test.d.ts.map +1 -0
  148. package/dist/types/src/internal/annotations/index.d.ts +3 -0
  149. package/dist/types/src/internal/annotations/index.d.ts.map +1 -0
  150. package/dist/types/src/internal/annotations/util.d.ts +39 -0
  151. package/dist/types/src/internal/annotations/util.d.ts.map +1 -0
  152. package/dist/types/src/internal/api/annotations.d.ts +23 -0
  153. package/dist/types/src/internal/api/annotations.d.ts.map +1 -0
  154. package/dist/types/src/internal/api/entity.d.ts +13 -0
  155. package/dist/types/src/internal/api/entity.d.ts.map +1 -0
  156. package/dist/types/src/internal/api/index.d.ts +15 -0
  157. package/dist/types/src/internal/api/index.d.ts.map +1 -0
  158. package/dist/types/src/internal/api/meta.d.ts +42 -0
  159. package/dist/types/src/internal/api/meta.d.ts.map +1 -0
  160. package/dist/types/src/internal/api/sorting.d.ts +24 -0
  161. package/dist/types/src/internal/api/sorting.d.ts.map +1 -0
  162. package/dist/types/src/internal/api/version.d.ts +42 -0
  163. package/dist/types/src/internal/api/version.d.ts.map +1 -0
  164. package/dist/types/src/internal/entities/entity.d.ts +20 -0
  165. package/dist/types/src/internal/entities/entity.d.ts.map +1 -0
  166. package/dist/types/src/internal/entities/index.d.ts +6 -0
  167. package/dist/types/src/internal/entities/index.d.ts.map +1 -0
  168. package/dist/types/src/internal/entities/model.d.ts +79 -0
  169. package/dist/types/src/internal/entities/model.d.ts.map +1 -0
  170. package/dist/types/src/internal/entities/object.d.ts +18 -0
  171. package/dist/types/src/internal/entities/object.d.ts.map +1 -0
  172. package/dist/types/src/internal/entities/relation.d.ts +62 -0
  173. package/dist/types/src/internal/entities/relation.d.ts.map +1 -0
  174. package/dist/types/src/internal/entities/util.d.ts +2 -0
  175. package/dist/types/src/internal/entities/util.d.ts.map +1 -0
  176. package/dist/types/src/internal/formats/format.d.ts +4 -2
  177. package/dist/types/src/internal/formats/format.d.ts.map +1 -1
  178. package/dist/types/src/internal/formats/select.d.ts +6 -4
  179. package/dist/types/src/internal/formats/select.d.ts.map +1 -1
  180. package/dist/types/src/internal/formats/string.d.ts +4 -0
  181. package/dist/types/src/internal/formats/string.d.ts.map +1 -1
  182. package/dist/types/src/internal/formats/types.d.ts +13 -9
  183. package/dist/types/src/internal/formats/types.d.ts.map +1 -1
  184. package/dist/types/src/internal/index.d.ts +7 -10
  185. package/dist/types/src/internal/index.d.ts.map +1 -1
  186. package/dist/types/src/internal/json-schema/annotations.d.ts.map +1 -0
  187. package/dist/types/src/internal/json-schema/effect-schema.test.d.ts.map +1 -0
  188. package/dist/types/src/internal/json-schema/index.d.ts +2 -0
  189. package/dist/types/src/internal/json-schema/index.d.ts.map +1 -1
  190. package/dist/types/src/internal/json-schema/json-schema-normalize.d.ts.map +1 -1
  191. package/dist/types/src/internal/json-schema/json-schema-type.d.ts +130 -29
  192. package/dist/types/src/internal/json-schema/json-schema-type.d.ts.map +1 -1
  193. package/dist/types/src/internal/{json → json-schema}/json-schema.d.ts +4 -6
  194. package/dist/types/src/internal/json-schema/json-schema.d.ts.map +1 -0
  195. package/dist/types/src/internal/json-schema/json-schema.test.d.ts.map +1 -0
  196. package/dist/types/src/internal/object/clone.d.ts +8 -0
  197. package/dist/types/src/internal/object/clone.d.ts.map +1 -0
  198. package/dist/types/src/internal/object/common.d.ts.map +1 -1
  199. package/dist/types/src/internal/object/{create.d.ts → create-object.d.ts} +10 -11
  200. package/dist/types/src/internal/object/create-object.d.ts.map +1 -0
  201. package/dist/types/src/internal/object/create-object.test.d.ts +2 -0
  202. package/dist/types/src/internal/object/create-object.test.d.ts.map +1 -0
  203. package/dist/types/src/internal/object/deleted.d.ts +2 -2
  204. package/dist/types/src/internal/object/deleted.d.ts.map +1 -1
  205. package/dist/types/src/internal/object/ids.d.ts.map +1 -1
  206. package/dist/types/src/internal/object/index.d.ts +6 -12
  207. package/dist/types/src/internal/object/index.d.ts.map +1 -1
  208. package/dist/types/src/internal/object/json-serializer.d.ts +14 -9
  209. package/dist/types/src/internal/object/json-serializer.d.ts.map +1 -1
  210. package/dist/types/src/internal/object/schema-validator.d.ts +1 -14
  211. package/dist/types/src/internal/object/schema-validator.d.ts.map +1 -1
  212. package/dist/types/src/internal/object/set-value.d.ts +7 -0
  213. package/dist/types/src/internal/object/set-value.d.ts.map +1 -0
  214. package/dist/types/src/internal/object/set-value.test.d.ts +2 -0
  215. package/dist/types/src/internal/object/set-value.test.d.ts.map +1 -0
  216. package/dist/types/src/internal/object/snapshot.d.ts +6 -0
  217. package/dist/types/src/internal/object/snapshot.d.ts.map +1 -0
  218. package/dist/types/src/internal/object/typed-object.d.ts +8 -14
  219. package/dist/types/src/internal/object/typed-object.d.ts.map +1 -1
  220. package/dist/types/src/internal/proxy/change-context.d.ts +55 -0
  221. package/dist/types/src/internal/proxy/change-context.d.ts.map +1 -0
  222. package/dist/types/src/internal/proxy/change.test.d.ts +2 -0
  223. package/dist/types/src/internal/proxy/change.test.d.ts.map +1 -0
  224. package/dist/types/src/internal/proxy/define-hidden-property.d.ts +5 -0
  225. package/dist/types/src/internal/proxy/define-hidden-property.d.ts.map +1 -0
  226. package/dist/types/src/internal/proxy/errors.d.ts +19 -0
  227. package/dist/types/src/internal/proxy/errors.d.ts.map +1 -0
  228. package/dist/types/src/internal/proxy/event-batch.d.ts +10 -0
  229. package/dist/types/src/internal/proxy/event-batch.d.ts.map +1 -0
  230. package/dist/types/src/internal/proxy/index.d.ts +14 -0
  231. package/dist/types/src/internal/proxy/index.d.ts.map +1 -0
  232. package/dist/types/src/internal/proxy/json-serializer.d.ts +6 -0
  233. package/dist/types/src/internal/proxy/json-serializer.d.ts.map +1 -0
  234. package/dist/types/src/internal/proxy/make-object.d.ts +14 -0
  235. package/dist/types/src/internal/proxy/make-object.d.ts.map +1 -0
  236. package/dist/types/src/internal/proxy/ownership.d.ts +57 -0
  237. package/dist/types/src/internal/proxy/ownership.d.ts.map +1 -0
  238. package/dist/types/src/internal/proxy/proxy-types.d.ts +18 -0
  239. package/dist/types/src/internal/proxy/proxy-types.d.ts.map +1 -0
  240. package/dist/types/src/internal/proxy/proxy-utils.d.ts +47 -0
  241. package/dist/types/src/internal/proxy/proxy-utils.d.ts.map +1 -0
  242. package/dist/types/src/internal/proxy/reactive-array.d.ts +8 -0
  243. package/dist/types/src/internal/proxy/reactive-array.d.ts.map +1 -0
  244. package/dist/types/src/internal/proxy/reactive.d.ts +39 -0
  245. package/dist/types/src/internal/proxy/reactive.d.ts.map +1 -0
  246. package/dist/types/src/internal/proxy/schema-validator.d.ts +15 -0
  247. package/dist/types/src/internal/proxy/schema-validator.d.ts.map +1 -0
  248. package/dist/types/src/internal/proxy/symbols.d.ts +3 -0
  249. package/dist/types/src/internal/proxy/symbols.d.ts.map +1 -0
  250. package/dist/types/src/internal/proxy/typed-handler.d.ts +16 -12
  251. package/dist/types/src/internal/proxy/typed-handler.d.ts.map +1 -1
  252. package/dist/types/src/internal/ref/ref-array.d.ts +4 -4
  253. package/dist/types/src/internal/ref/ref-array.d.ts.map +1 -1
  254. package/dist/types/src/internal/ref/ref.d.ts +43 -18
  255. package/dist/types/src/internal/ref/ref.d.ts.map +1 -1
  256. package/dist/types/src/internal/schema/compose.d.ts +7 -0
  257. package/dist/types/src/internal/schema/compose.d.ts.map +1 -0
  258. package/dist/types/src/internal/schema/compose.test.d.ts.map +1 -0
  259. package/dist/types/src/internal/schema/echo-schema.d.ts +25 -12
  260. package/dist/types/src/internal/schema/echo-schema.d.ts.map +1 -1
  261. package/dist/types/src/internal/schema/index.d.ts +1 -4
  262. package/dist/types/src/internal/schema/index.d.ts.map +1 -1
  263. package/dist/types/src/internal/schema/manipulation.d.ts.map +1 -1
  264. package/dist/types/src/internal/schema/persistent-schema.d.ts +20 -0
  265. package/dist/types/src/internal/schema/persistent-schema.d.ts.map +1 -0
  266. package/dist/types/src/internal/types/base.d.ts +27 -0
  267. package/dist/types/src/internal/types/base.d.ts.map +1 -0
  268. package/dist/types/src/internal/types/entity.d.ts +37 -0
  269. package/dist/types/src/internal/types/entity.d.ts.map +1 -0
  270. package/dist/types/src/internal/types/index.d.ts +5 -2
  271. package/dist/types/src/internal/types/index.d.ts.map +1 -1
  272. package/dist/types/src/internal/{object → types}/meta.d.ts +16 -14
  273. package/dist/types/src/internal/types/meta.d.ts.map +1 -0
  274. package/dist/types/src/internal/types/typename.d.ts +21 -0
  275. package/dist/types/src/internal/types/typename.d.ts.map +1 -0
  276. package/dist/types/src/internal/types/version.d.ts +15 -0
  277. package/dist/types/src/internal/types/version.d.ts.map +1 -0
  278. package/dist/types/src/{test → testing}/api.test.d.ts.map +1 -1
  279. package/dist/types/src/testing/index.d.ts +3 -3
  280. package/dist/types/src/testing/index.d.ts.map +1 -1
  281. package/dist/types/src/testing/test-data.d.ts +18 -0
  282. package/dist/types/src/testing/test-data.d.ts.map +1 -0
  283. package/dist/types/src/testing/test-schema.d.ts +304 -0
  284. package/dist/types/src/testing/test-schema.d.ts.map +1 -0
  285. package/dist/types/src/testing/util.d.ts +21 -0
  286. package/dist/types/src/testing/util.d.ts.map +1 -0
  287. package/dist/types/tsconfig.tsbuildinfo +1 -1
  288. package/package.json +106 -65
  289. package/src/Annotation.ts +46 -0
  290. package/src/Collection.ts +30 -0
  291. package/src/Database.ts +315 -0
  292. package/src/Dataset.ts +24 -0
  293. package/src/Entity.test.ts +22 -0
  294. package/src/Entity.ts +234 -0
  295. package/src/Err.ts +38 -0
  296. package/src/Feed.ts +254 -0
  297. package/src/Filter.ts +389 -0
  298. package/src/Format.ts +9 -0
  299. package/src/Hypergraph.ts +74 -0
  300. package/src/JsonSchema.ts +24 -0
  301. package/src/Key.ts +3 -0
  302. package/src/Obj.test.ts +447 -0
  303. package/src/Obj.ts +588 -248
  304. package/src/Order.ts +44 -0
  305. package/src/Query.test.ts +632 -0
  306. package/src/Query.ts +520 -0
  307. package/src/QueryResult.ts +106 -0
  308. package/src/Ref.ts +77 -9
  309. package/src/Relation.test.ts +88 -0
  310. package/src/Relation.ts +440 -58
  311. package/src/SchemaRegistry.ts +106 -0
  312. package/src/Tag.ts +39 -0
  313. package/src/Type.test.ts +52 -0
  314. package/src/Type.ts +162 -151
  315. package/src/View.ts +100 -0
  316. package/src/hierarchy.test.ts +33 -0
  317. package/src/index.ts +20 -6
  318. package/src/internal/README.md +102 -0
  319. package/src/internal/{ast → annotations}/annotations.test.ts +18 -20
  320. package/src/internal/annotations/annotations.ts +526 -0
  321. package/src/internal/annotations/index.ts +6 -0
  322. package/src/internal/annotations/util.ts +85 -0
  323. package/src/internal/api/annotations.ts +60 -0
  324. package/src/internal/api/entity.ts +29 -0
  325. package/src/internal/api/index.ts +19 -0
  326. package/src/internal/api/meta.ts +88 -0
  327. package/src/internal/api/sorting.ts +53 -0
  328. package/src/internal/api/version.ts +96 -0
  329. package/src/internal/entities/entity.ts +128 -0
  330. package/src/internal/entities/index.ts +9 -0
  331. package/src/internal/entities/model.ts +138 -0
  332. package/src/internal/entities/object.ts +58 -0
  333. package/src/internal/entities/relation.ts +171 -0
  334. package/src/internal/entities/util.ts +33 -0
  335. package/src/internal/formats/date.test.ts +1 -1
  336. package/src/internal/formats/date.ts +5 -5
  337. package/src/internal/formats/format.test.ts +6 -6
  338. package/src/internal/formats/format.ts +8 -6
  339. package/src/internal/formats/number.ts +5 -5
  340. package/src/internal/formats/object.ts +4 -4
  341. package/src/internal/formats/select.ts +6 -4
  342. package/src/internal/formats/string.ts +14 -9
  343. package/src/internal/formats/types.ts +53 -42
  344. package/src/internal/index.ts +30 -13
  345. package/src/internal/{json → json-schema}/annotations.ts +1 -1
  346. package/src/internal/json-schema/index.ts +2 -0
  347. package/src/internal/json-schema/json-schema-normalize.ts +4 -2
  348. package/src/internal/json-schema/json-schema-type.ts +35 -35
  349. package/src/internal/{json → json-schema}/json-schema.test.ts +232 -97
  350. package/src/internal/{json → json-schema}/json-schema.ts +79 -93
  351. package/src/internal/object/clone.ts +48 -0
  352. package/src/internal/object/common.ts +3 -4
  353. package/src/internal/object/{create.test.ts → create-object.test.ts} +31 -33
  354. package/src/internal/object/{create.ts → create-object.ts} +36 -37
  355. package/src/internal/object/deleted.ts +6 -6
  356. package/src/internal/object/ids.ts +1 -1
  357. package/src/internal/object/index.ts +6 -12
  358. package/src/internal/object/inspect.ts +5 -7
  359. package/src/internal/object/json-serializer.test.ts +59 -37
  360. package/src/internal/object/json-serializer.ts +87 -108
  361. package/src/internal/object/schema-validator.test.ts +3 -7
  362. package/src/internal/object/schema-validator.ts +2 -237
  363. package/src/internal/object/set-value.test.ts +281 -0
  364. package/src/internal/object/set-value.ts +165 -0
  365. package/src/internal/object/snapshot.ts +96 -0
  366. package/src/internal/object/typed-object.test.ts +11 -11
  367. package/src/internal/object/typed-object.ts +8 -59
  368. package/src/internal/proxy/change-context.ts +138 -0
  369. package/src/internal/proxy/change.test.ts +519 -0
  370. package/src/internal/proxy/define-hidden-property.ts +14 -0
  371. package/src/internal/proxy/errors.ts +42 -0
  372. package/src/internal/proxy/event-batch.ts +44 -0
  373. package/src/internal/proxy/handler.test.ts +51 -91
  374. package/src/internal/proxy/index.ts +17 -0
  375. package/src/internal/proxy/json-serializer.ts +87 -0
  376. package/src/internal/proxy/make-object.ts +106 -0
  377. package/src/internal/proxy/ownership.ts +253 -0
  378. package/src/internal/proxy/proxy-types.ts +23 -0
  379. package/src/internal/proxy/proxy-utils.ts +150 -0
  380. package/src/internal/proxy/reactive-array.ts +71 -0
  381. package/src/internal/proxy/reactive.ts +69 -0
  382. package/src/internal/proxy/schema-validator.ts +244 -0
  383. package/src/internal/proxy/schema.test.ts +27 -18
  384. package/src/internal/proxy/symbols.ts +7 -0
  385. package/src/internal/proxy/typed-handler.test.ts +260 -48
  386. package/src/internal/proxy/typed-handler.ts +283 -61
  387. package/src/internal/proxy/typed-object.test.ts +54 -38
  388. package/src/internal/ref/ref-array.ts +4 -4
  389. package/src/internal/ref/ref.test.ts +10 -9
  390. package/src/internal/ref/ref.ts +107 -56
  391. package/src/internal/{projection → schema}/compose.test.ts +8 -9
  392. package/src/internal/{projection → schema}/compose.ts +13 -8
  393. package/src/internal/schema/echo-schema.ts +74 -33
  394. package/src/internal/schema/index.ts +1 -4
  395. package/src/internal/schema/manipulation.ts +7 -1
  396. package/src/internal/schema/persistent-schema.ts +33 -0
  397. package/src/internal/types/base.ts +43 -0
  398. package/src/internal/types/entity.ts +54 -0
  399. package/src/internal/types/index.ts +5 -2
  400. package/src/internal/types/meta.ts +68 -0
  401. package/src/internal/types/typename.ts +55 -0
  402. package/src/internal/types/version.ts +19 -0
  403. package/src/testing/api.test.ts +126 -0
  404. package/src/testing/index.ts +3 -3
  405. package/src/testing/test-data.ts +130 -0
  406. package/src/testing/test-schema.ts +240 -0
  407. package/src/testing/util.ts +85 -0
  408. package/dist/lib/browser/chunk-MWLA34S5.mjs +0 -3843
  409. package/dist/lib/browser/chunk-MWLA34S5.mjs.map +0 -7
  410. package/dist/lib/browser/chunk-OAZJQHVO.mjs +0 -453
  411. package/dist/lib/browser/chunk-OAZJQHVO.mjs.map +0 -7
  412. package/dist/lib/browser/chunk-ORIE2FMS.mjs +0 -514
  413. package/dist/lib/browser/chunk-ORIE2FMS.mjs.map +0 -7
  414. package/dist/lib/browser/index.mjs +0 -43
  415. package/dist/lib/browser/internal/index.mjs +0 -326
  416. package/dist/lib/browser/meta.json +0 -1
  417. package/dist/lib/browser/query/index.mjs +0 -23
  418. package/dist/lib/browser/testing/index.mjs +0 -298
  419. package/dist/lib/browser/testing/index.mjs.map +0 -7
  420. package/dist/lib/node-esm/chunk-AXWVDOP7.mjs +0 -453
  421. package/dist/lib/node-esm/chunk-AXWVDOP7.mjs.map +0 -7
  422. package/dist/lib/node-esm/chunk-L4PBAJDP.mjs +0 -514
  423. package/dist/lib/node-esm/chunk-L4PBAJDP.mjs.map +0 -7
  424. package/dist/lib/node-esm/chunk-YTNLFBIK.mjs +0 -3843
  425. package/dist/lib/node-esm/chunk-YTNLFBIK.mjs.map +0 -7
  426. package/dist/lib/node-esm/index.mjs +0 -43
  427. package/dist/lib/node-esm/meta.json +0 -1
  428. package/dist/lib/node-esm/query/index.mjs +0 -23
  429. package/dist/lib/node-esm/testing/index.mjs +0 -298
  430. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  431. package/dist/types/src/errors.d.ts +0 -72
  432. package/dist/types/src/errors.d.ts.map +0 -1
  433. package/dist/types/src/internal/ast/annotation-helper.d.ts +0 -8
  434. package/dist/types/src/internal/ast/annotation-helper.d.ts.map +0 -1
  435. package/dist/types/src/internal/ast/annotations.d.ts +0 -119
  436. package/dist/types/src/internal/ast/annotations.d.ts.map +0 -1
  437. package/dist/types/src/internal/ast/annotations.test.d.ts.map +0 -1
  438. package/dist/types/src/internal/ast/entity-kind.d.ts +0 -10
  439. package/dist/types/src/internal/ast/entity-kind.d.ts.map +0 -1
  440. package/dist/types/src/internal/ast/index.d.ts +0 -5
  441. package/dist/types/src/internal/ast/index.d.ts.map +0 -1
  442. package/dist/types/src/internal/ast/types.d.ts +0 -6
  443. package/dist/types/src/internal/ast/types.d.ts.map +0 -1
  444. package/dist/types/src/internal/json/annotations.d.ts.map +0 -1
  445. package/dist/types/src/internal/json/effect-schema.test.d.ts.map +0 -1
  446. package/dist/types/src/internal/json/index.d.ts +0 -2
  447. package/dist/types/src/internal/json/index.d.ts.map +0 -1
  448. package/dist/types/src/internal/json/json-schema.d.ts.map +0 -1
  449. package/dist/types/src/internal/json/json-schema.test.d.ts.map +0 -1
  450. package/dist/types/src/internal/object/accessors.d.ts +0 -29
  451. package/dist/types/src/internal/object/accessors.d.ts.map +0 -1
  452. package/dist/types/src/internal/object/create.d.ts.map +0 -1
  453. package/dist/types/src/internal/object/create.test.d.ts +0 -2
  454. package/dist/types/src/internal/object/create.test.d.ts.map +0 -1
  455. package/dist/types/src/internal/object/entity.d.ts +0 -22
  456. package/dist/types/src/internal/object/entity.d.ts.map +0 -1
  457. package/dist/types/src/internal/object/expando.d.ts +0 -14
  458. package/dist/types/src/internal/object/expando.d.ts.map +0 -1
  459. package/dist/types/src/internal/object/meta.d.ts.map +0 -1
  460. package/dist/types/src/internal/object/model.d.ts +0 -117
  461. package/dist/types/src/internal/object/model.d.ts.map +0 -1
  462. package/dist/types/src/internal/object/relation.d.ts +0 -17
  463. package/dist/types/src/internal/object/relation.d.ts.map +0 -1
  464. package/dist/types/src/internal/object/typed-relation.d.ts +0 -32
  465. package/dist/types/src/internal/object/typed-relation.d.ts.map +0 -1
  466. package/dist/types/src/internal/object/typename.d.ts +0 -15
  467. package/dist/types/src/internal/object/typename.d.ts.map +0 -1
  468. package/dist/types/src/internal/object/version.d.ts +0 -14
  469. package/dist/types/src/internal/object/version.d.ts.map +0 -1
  470. package/dist/types/src/internal/projection/compose.d.ts +0 -6
  471. package/dist/types/src/internal/projection/compose.d.ts.map +0 -1
  472. package/dist/types/src/internal/projection/compose.test.d.ts.map +0 -1
  473. package/dist/types/src/internal/projection/index.d.ts +0 -2
  474. package/dist/types/src/internal/projection/index.d.ts.map +0 -1
  475. package/dist/types/src/internal/proxy/reactive-object.d.ts +0 -15
  476. package/dist/types/src/internal/proxy/reactive-object.d.ts.map +0 -1
  477. package/dist/types/src/internal/query/index.d.ts +0 -2
  478. package/dist/types/src/internal/query/index.d.ts.map +0 -1
  479. package/dist/types/src/internal/query/query.d.ts +0 -17
  480. package/dist/types/src/internal/query/query.d.ts.map +0 -1
  481. package/dist/types/src/internal/schema/runtime-schema-registry.d.ts +0 -18
  482. package/dist/types/src/internal/schema/runtime-schema-registry.d.ts.map +0 -1
  483. package/dist/types/src/internal/schema/snapshot.d.ts +0 -6
  484. package/dist/types/src/internal/schema/snapshot.d.ts.map +0 -1
  485. package/dist/types/src/internal/schema/stored-schema.d.ts +0 -13
  486. package/dist/types/src/internal/schema/stored-schema.d.ts.map +0 -1
  487. package/dist/types/src/internal/testing/index.d.ts +0 -3
  488. package/dist/types/src/internal/testing/index.d.ts.map +0 -1
  489. package/dist/types/src/internal/testing/types.d.ts +0 -455
  490. package/dist/types/src/internal/testing/types.d.ts.map +0 -1
  491. package/dist/types/src/internal/testing/utils.d.ts +0 -10
  492. package/dist/types/src/internal/testing/utils.d.ts.map +0 -1
  493. package/dist/types/src/internal/types/types.d.ts +0 -79
  494. package/dist/types/src/internal/types/types.d.ts.map +0 -1
  495. package/dist/types/src/internal/types/types.test.d.ts +0 -2
  496. package/dist/types/src/internal/types/types.test.d.ts.map +0 -1
  497. package/dist/types/src/internal/types/util.d.ts +0 -5
  498. package/dist/types/src/internal/types/util.d.ts.map +0 -1
  499. package/dist/types/src/query/index.d.ts +0 -3
  500. package/dist/types/src/query/index.d.ts.map +0 -1
  501. package/dist/types/src/query/query.d.ts +0 -247
  502. package/dist/types/src/query/query.d.ts.map +0 -1
  503. package/dist/types/src/query/query.test.d.ts +0 -2
  504. package/dist/types/src/query/query.test.d.ts.map +0 -1
  505. package/dist/types/src/query/tag.d.ts +0 -18
  506. package/dist/types/src/query/tag.d.ts.map +0 -1
  507. package/dist/types/src/testing/echo-schema.d.ts +0 -7
  508. package/dist/types/src/testing/echo-schema.d.ts.map +0 -1
  509. package/dist/types/src/testing/types.d.ts +0 -113
  510. package/dist/types/src/testing/types.d.ts.map +0 -1
  511. package/src/errors.ts +0 -18
  512. package/src/internal/ast/annotation-helper.ts +0 -22
  513. package/src/internal/ast/annotations.ts +0 -212
  514. package/src/internal/ast/entity-kind.ts +0 -15
  515. package/src/internal/ast/index.ts +0 -8
  516. package/src/internal/ast/types.ts +0 -17
  517. package/src/internal/json/index.ts +0 -5
  518. package/src/internal/object/accessors.ts +0 -115
  519. package/src/internal/object/entity.ts +0 -204
  520. package/src/internal/object/expando.ts +0 -21
  521. package/src/internal/object/meta.ts +0 -62
  522. package/src/internal/object/model.ts +0 -170
  523. package/src/internal/object/relation.ts +0 -24
  524. package/src/internal/object/typed-relation.ts +0 -85
  525. package/src/internal/object/typename.ts +0 -61
  526. package/src/internal/object/version.ts +0 -22
  527. package/src/internal/projection/index.ts +0 -5
  528. package/src/internal/proxy/reactive-object.ts +0 -108
  529. package/src/internal/query/index.ts +0 -5
  530. package/src/internal/query/query.ts +0 -23
  531. package/src/internal/schema/runtime-schema-registry.ts +0 -78
  532. package/src/internal/schema/snapshot.ts +0 -25
  533. package/src/internal/schema/stored-schema.ts +0 -26
  534. package/src/internal/testing/index.ts +0 -6
  535. package/src/internal/testing/types.ts +0 -211
  536. package/src/internal/testing/utils.ts +0 -54
  537. package/src/internal/types/types.test.ts +0 -48
  538. package/src/internal/types/types.ts +0 -176
  539. package/src/internal/types/util.ts +0 -9
  540. package/src/query/index.ts +0 -6
  541. package/src/query/query.test.ts +0 -362
  542. package/src/query/query.ts +0 -784
  543. package/src/query/tag.ts +0 -35
  544. package/src/test/api.test.ts +0 -180
  545. package/src/testing/echo-schema.ts +0 -39
  546. package/src/testing/types.ts +0 -91
  547. /package/dist/lib/{browser/index.mjs.map → neutral/Annotation.mjs.map} +0 -0
  548. /package/dist/lib/{browser/internal/index.mjs.map → neutral/Database.mjs.map} +0 -0
  549. /package/dist/lib/{browser/query/index.mjs.map → neutral/Entity.mjs.map} +0 -0
  550. /package/dist/lib/{node-esm/index.mjs.map → neutral/Err.mjs.map} +0 -0
  551. /package/dist/lib/{node-esm/internal/index.mjs.map → neutral/Feed.mjs.map} +0 -0
  552. /package/dist/lib/{node-esm/query/index.mjs.map → neutral/Filter.mjs.map} +0 -0
  553. /package/dist/types/src/internal/{ast → annotations}/annotations.test.d.ts +0 -0
  554. /package/dist/types/src/internal/{json → json-schema}/annotations.d.ts +0 -0
  555. /package/dist/types/src/internal/{json → json-schema}/effect-schema.test.d.ts +0 -0
  556. /package/dist/types/src/internal/{json → json-schema}/json-schema.test.d.ts +0 -0
  557. /package/dist/types/src/internal/{projection → schema}/compose.test.d.ts +0 -0
  558. /package/dist/types/src/{test → testing}/api.test.d.ts +0 -0
  559. /package/src/internal/{json → json-schema}/effect-schema.test.ts +0 -0
@@ -0,0 +1,526 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import * as Function from 'effect/Function';
6
+ import * as Option from 'effect/Option';
7
+ import * as Schema from 'effect/Schema';
8
+ import * as SchemaAST from 'effect/SchemaAST';
9
+
10
+ import { raise } from '@dxos/debug';
11
+ import { type JsonPath, getField } from '@dxos/effect';
12
+ import { assertArgument, invariant } from '@dxos/invariant';
13
+ import { DXN } from '@dxos/keys';
14
+ import { type Primitive } from '@dxos/util';
15
+
16
+ import { type AnyProperties, EntityKind, TypeId, getSchema } from '../types';
17
+
18
+ import { type AnnotationHelper, createAnnotationHelper } from './util';
19
+
20
+ /**
21
+ * @internal
22
+ */
23
+ export const FIELD_PATH_ANNOTATION = 'path';
24
+
25
+ /**
26
+ * Sets the path for the field.
27
+ * @param path Data source path in the json path format. This is the field path in the source object.
28
+ */
29
+ // TODO(burdon): Field, vs. path vs. property.
30
+ export const FieldPath = (path: string) => PropertyMeta(FIELD_PATH_ANNOTATION, path);
31
+
32
+ //
33
+ // Type
34
+ //
35
+
36
+ /**
37
+ * ECHO identifier (for a stored schema).
38
+ * Must be a `dxn:echo:` URI.
39
+ */
40
+ export const TypeIdentifierAnnotationId = Symbol.for('@dxos/schema/annotation/TypeIdentifier');
41
+
42
+ export const getTypeIdentifierAnnotation = (schema: Schema.Schema.All) =>
43
+ Function.flow(
44
+ SchemaAST.getAnnotation<string>(TypeIdentifierAnnotationId),
45
+ Option.getOrElse(() => undefined),
46
+ )(schema.ast);
47
+
48
+ /**
49
+ * @returns DXN of the schema.
50
+ *
51
+ * For non-stored schema returns `dxn:type:`.
52
+ * For stored schema returns `dxn:echo:`.
53
+ */
54
+ export const getSchemaDXN = (schema: Schema.Schema.All): DXN | undefined => {
55
+ assertArgument(Schema.isSchema(schema), 'schema', 'invalid schema');
56
+ const id = getTypeIdentifierAnnotation(schema);
57
+ if (id) {
58
+ return DXN.parse(id);
59
+ }
60
+
61
+ // TODO(dmaretskyi): Add support for dynamic schema.
62
+ const objectAnnotation = getTypeAnnotation(schema);
63
+ if (!objectAnnotation) {
64
+ return undefined;
65
+ }
66
+
67
+ return DXN.fromTypenameAndVersion(objectAnnotation.typename, objectAnnotation.version);
68
+ };
69
+
70
+ /**
71
+ * @param input schema or a typename string.
72
+ * @return type DXN.
73
+ */
74
+ export const getTypeDXNFromSpecifier = (input: Schema.Schema.All | string): DXN => {
75
+ if (Schema.isSchema(input)) {
76
+ return getSchemaDXN(input) ?? raise(new TypeError('Schema has no DXN'));
77
+ } else {
78
+ assertArgument(typeof input === 'string', 'input');
79
+ assertArgument(!input.startsWith('dxn:'), 'input');
80
+ return DXN.fromTypename(input);
81
+ }
82
+ };
83
+
84
+ //
85
+ // TypeAnnotation
86
+ //
87
+
88
+ /**
89
+ * Fully qualified globally unique typename.
90
+ * Example: `dxos.org/type/Message`
91
+ */
92
+ // TODO(burdon): Reconcile with short DXN format.
93
+ // TODO(burdon): Change "/type" => "/schema" throughout.
94
+ export const TypenameSchema = Schema.String.pipe(Schema.pattern(/^[a-zA-Z]\w+\.[a-zA-Z]\w{1,}\/[\w/_-]+$/)).annotations(
95
+ {
96
+ description: 'Fully qualified globally unique typename',
97
+ example: 'dxos.org/type/Message',
98
+ },
99
+ );
100
+
101
+ /**
102
+ * Semantic version format: `major.minor.patch`
103
+ * Example: `1.0.0`
104
+ */
105
+ export const VersionSchema = Schema.String.pipe(Schema.pattern(/^\d+.\d+.\d+$/)).annotations({
106
+ description: 'Semantic version format: `major.minor.patch`',
107
+ example: '1.0.0',
108
+ });
109
+
110
+ export const TypeMeta = Schema.Struct({
111
+ typename: TypenameSchema,
112
+ version: VersionSchema,
113
+ });
114
+
115
+ export interface TypeMeta extends Schema.Schema.Type<typeof TypeMeta> {}
116
+
117
+ /**
118
+ * Entity type.
119
+ */
120
+ export const TypeAnnotationId = Symbol.for('@dxos/schema/annotation/Type');
121
+
122
+ /**
123
+ * Payload stored under {@link TypeAnnotationId}.
124
+ */
125
+ export const TypeAnnotation = Schema.extend(
126
+ TypeMeta,
127
+ Schema.Struct({
128
+ kind: Schema.Enums(EntityKind),
129
+
130
+ /**
131
+ * If this is a relation, the schema of the source object.
132
+ * Must be present if entity kind is {@link EntityKind.Relation}.
133
+ */
134
+ sourceSchema: Schema.optional(DXN.Schema),
135
+
136
+ /**
137
+ * If this is a relation, the schema of the target object.
138
+ * Must be present if entity kind is {@link EntityKind.Relation}.
139
+ */
140
+ targetSchema: Schema.optional(DXN.Schema),
141
+ }),
142
+ );
143
+
144
+ export interface TypeAnnotation extends Schema.Schema.Type<typeof TypeAnnotation> {}
145
+
146
+ /**
147
+ * @returns {@link TypeAnnotation} from a schema.
148
+ * Schema must have been created with {@link TypedObject} or {@link TypedLink} or manually assigned an appropriate annotation.
149
+ */
150
+ export const getTypeAnnotation = (schema: Schema.Schema.All): TypeAnnotation | undefined => {
151
+ assertArgument(schema != null && schema.ast != null, 'schema', 'invalid schema');
152
+ return Function.flow(
153
+ SchemaAST.getAnnotation<TypeAnnotation>(TypeAnnotationId),
154
+ Option.getOrElse(() => undefined),
155
+ )(schema.ast);
156
+ };
157
+
158
+ /**
159
+ * @returns {@link EntityKind} from a schema.
160
+ */
161
+ export const getEntityKind = (schema: Schema.Schema.All): EntityKind | undefined => getTypeAnnotation(schema)?.kind;
162
+
163
+ /**
164
+ * @internal
165
+ * @returns Schema typename (without dxn: prefix or version number).
166
+ */
167
+ export const getSchemaTypename = (schema: Schema.Schema.All): string | undefined => getTypeAnnotation(schema)?.typename;
168
+
169
+ /**
170
+ * @internal
171
+ * @returns Schema version in semver format.
172
+ */
173
+ export const getSchemaVersion = (schema: Schema.Schema.All): string | undefined => getTypeAnnotation(schema)?.version;
174
+
175
+ /**
176
+ * Gets the typename of the object without the version.
177
+ * Returns only the name portion, not the DXN.
178
+ * @example "example.org/type/Contact"
179
+ *
180
+ * @internal (use Obj.getTypename)
181
+ */
182
+ export const getTypename = (obj: AnyProperties): string | undefined => {
183
+ const schema = getSchema(obj);
184
+ if (schema != null) {
185
+ // Try to extract typename from DXN.
186
+ return getSchemaTypename(schema);
187
+ } else {
188
+ const type = getTypeDXN(obj);
189
+ return type?.asTypeDXN()?.type;
190
+ }
191
+ };
192
+
193
+ /**
194
+ * @internal (use Type.setTypename)
195
+ */
196
+ // TODO(dmaretskyi): Rename setTypeDXN.
197
+ export const setTypename = (obj: any, typename: DXN): void => {
198
+ invariant(typename instanceof DXN, 'Invalid type.');
199
+ Object.defineProperty(obj, TypeId, {
200
+ value: typename,
201
+ writable: false,
202
+ enumerable: false,
203
+ configurable: false,
204
+ });
205
+ };
206
+
207
+ /**
208
+ * @returns Object type as {@link DXN}.
209
+ * @returns undefined if the object doesn't have a type.
210
+ * @example `dxn:example.com/type/Person:1.0.0`
211
+ *
212
+ * @internal (use Obj.getTypeDXN)
213
+ */
214
+ // TODO(burdon): Narrow type.
215
+ export const getTypeDXN = (obj: AnyProperties): DXN | undefined => {
216
+ if (!obj) {
217
+ return undefined;
218
+ }
219
+
220
+ const type = (obj as any)[TypeId];
221
+ if (!type) {
222
+ return undefined;
223
+ }
224
+
225
+ invariant(type instanceof DXN, 'Invalid object.');
226
+ return type;
227
+ };
228
+
229
+ /**
230
+ * Checks if the object is an instance of the schema.
231
+ * Only typename is compared, the schema version is ignored.
232
+ *
233
+ * The following cases are considered to mean that the object is an instance of the schema:
234
+ * - Object was created with this exact schema.
235
+ * - Object was created with a different version of this schema.
236
+ * - Object was created with a different schema (maybe dynamic) that has the same typename.
237
+ */
238
+ // TODO(burdon): Can we use `Schema.is`?
239
+ export const isInstanceOf = <Schema extends Schema.Schema.AnyNoContext>(
240
+ schema: Schema,
241
+ object: any,
242
+ ): object is Schema.Schema.Type<Schema> => {
243
+ if (object == null) {
244
+ return false;
245
+ }
246
+
247
+ const schemaDXN = getSchemaDXN(schema);
248
+ if (!schemaDXN) {
249
+ throw new Error('Schema must have an object annotation.');
250
+ }
251
+
252
+ const type = getTypeDXN(object);
253
+ if (type && DXN.equals(type, schemaDXN)) {
254
+ return true;
255
+ }
256
+
257
+ const typename = getTypename(object);
258
+ if (!typename) {
259
+ return false;
260
+ }
261
+
262
+ const typeDXN = schemaDXN.asTypeDXN();
263
+ if (!typeDXN) {
264
+ return false;
265
+ }
266
+
267
+ return typeDXN.type === typename;
268
+ };
269
+
270
+ //
271
+ // PropertyMeta
272
+ //
273
+
274
+ /**
275
+ * PropertyMeta (metadata for dynamic schema properties).
276
+ * For user-defined annotations.
277
+ */
278
+ export const PropertyMetaAnnotationId = Symbol.for('@dxos/schema/annotation/PropertyMeta');
279
+
280
+ export type PropertyMetaValue = Primitive | Record<string, Primitive> | Primitive[];
281
+
282
+ export type PropertyMetaAnnotation = {
283
+ [name: string]: PropertyMetaValue;
284
+ };
285
+
286
+ // TODO(wittjosiah): Align with other annotations.
287
+ // TODO(wittjosiah): Why is this separate from FormatAnnotation?
288
+ export const PropertyMeta = (name: string, value: PropertyMetaValue) => {
289
+ return <A, I, R>(self: Schema.Schema<A, I, R>): Schema.Schema<A, I, R> => {
290
+ const existingMeta = self.ast.annotations[PropertyMetaAnnotationId] as PropertyMetaAnnotation;
291
+ return self.annotations({
292
+ [PropertyMetaAnnotationId]: {
293
+ ...existingMeta,
294
+ [name]: value,
295
+ },
296
+ });
297
+ };
298
+ };
299
+
300
+ export const getPropertyMetaAnnotation = <T>(prop: SchemaAST.PropertySignature, name: string) =>
301
+ Function.pipe(
302
+ SchemaAST.getAnnotation<PropertyMetaAnnotation>(PropertyMetaAnnotationId)(prop.type),
303
+ Option.map((meta) => meta[name] as T),
304
+ Option.getOrElse(() => undefined),
305
+ );
306
+
307
+ //
308
+ // Reference
309
+ //
310
+
311
+ /**
312
+ * Schema reference.
313
+ */
314
+ export const ReferenceAnnotationId = Symbol.for('@dxos/schema/annotation/Reference');
315
+ export type ReferenceAnnotationValue = TypeAnnotation;
316
+ export const ReferenceAnnotation = createAnnotationHelper<ReferenceAnnotationValue>(ReferenceAnnotationId);
317
+
318
+ /**
319
+ * SchemaMeta.
320
+ */
321
+ export const SchemaMetaSymbol = Symbol.for('@dxos/schema/SchemaMeta');
322
+ export type SchemaMeta = TypeMeta & { id: string };
323
+
324
+ /**
325
+ * Identifies a schema as a schema for a hidden system type.
326
+ */
327
+ export const SystemTypeAnnotationId = Symbol.for('@dxos/schema/annotation/SystemType');
328
+ export const SystemTypeAnnotation = createAnnotationHelper<boolean>(SystemTypeAnnotationId);
329
+
330
+ /**
331
+ * Identifies label property or JSON path expression.
332
+ * Either a string or an array of strings representing field accessors each matched in priority order.
333
+ */
334
+ export const LabelAnnotationId = Symbol.for('@dxos/schema/annotation/Label');
335
+ export const LabelAnnotation = createAnnotationHelper<string[]>(LabelAnnotationId);
336
+
337
+ /**
338
+ * Returns the label for a given object based on {@link LabelAnnotationId}.
339
+ * Lower-level version that requires explicit schema parameter.
340
+ */
341
+ // TODO(burdon): Convert to JsonPath?
342
+ export const getLabelWithSchema = <S extends Schema.Schema.Any>(
343
+ schema: S,
344
+ object: Schema.Schema.Type<S>,
345
+ ): string | undefined => {
346
+ const annotation = LabelAnnotation.get(schema).pipe(Option.getOrElse(() => ['name']));
347
+ for (const accessor of annotation) {
348
+ assertArgument(
349
+ typeof accessor === 'string',
350
+ 'accessor',
351
+ 'Label annotation must be a string or an array of strings',
352
+ );
353
+ const value = getField(object, accessor as JsonPath);
354
+ switch (typeof value) {
355
+ case 'string':
356
+ case 'number':
357
+ case 'boolean':
358
+ case 'bigint':
359
+ case 'symbol':
360
+ return value.toString();
361
+ case 'undefined':
362
+ case 'object':
363
+ case 'function':
364
+ continue;
365
+ }
366
+ }
367
+
368
+ return undefined;
369
+ };
370
+
371
+ /**
372
+ * Sets the label for a given object based on {@link LabelAnnotationId}.
373
+ * Lower-level version that requires explicit schema parameter.
374
+ */
375
+ export const setLabelWithSchema = <S extends Schema.Schema.Any>(
376
+ schema: S,
377
+ object: Schema.Schema.Type<S>,
378
+ label: string,
379
+ ) => {
380
+ const annotation = LabelAnnotation.get(schema).pipe(
381
+ Option.map((field) => field[0]),
382
+ Option.getOrElse(() => 'name'),
383
+ );
384
+ object[annotation] = label;
385
+ };
386
+
387
+ /**
388
+ * Identifies description property or JSON path expression.
389
+ * A string representing field accessor.
390
+ */
391
+ export const DescriptionAnnotationId = Symbol.for('@dxos/schema/annotation/Description');
392
+ export const DescriptionAnnotation = createAnnotationHelper<string>(DescriptionAnnotationId);
393
+
394
+ /**
395
+ * Returns the description for a given object based on {@link DescriptionAnnotationId}.
396
+ * Lower-level version that requires explicit schema parameter.
397
+ */
398
+ // TODO(burdon): Convert to JsonPath?
399
+ export const getDescriptionWithSchema = <S extends Schema.Schema.Any>(
400
+ schema: S,
401
+ object: Schema.Schema.Type<S>,
402
+ ): string | undefined => {
403
+ const accessor = DescriptionAnnotation.get(schema).pipe(Option.getOrElse(() => 'description'));
404
+ assertArgument(typeof accessor === 'string', 'accessor', 'Description annotation must be a string');
405
+ const value = getField(object, accessor as JsonPath);
406
+ switch (typeof value) {
407
+ case 'string':
408
+ case 'number':
409
+ case 'boolean':
410
+ case 'bigint':
411
+ case 'symbol':
412
+ return value.toString();
413
+ case 'undefined':
414
+ case 'object':
415
+ case 'function':
416
+ default:
417
+ return undefined;
418
+ }
419
+ };
420
+
421
+ /**
422
+ * Sets the description for a given object based on {@link DescriptionAnnotationId}.
423
+ * Lower-level version that requires explicit schema parameter.
424
+ */
425
+ export const setDescriptionWithSchema = <S extends Schema.Schema.Any>(
426
+ schema: S,
427
+ object: Schema.Schema.Type<S>,
428
+ description: string,
429
+ ) => {
430
+ const accessor = DescriptionAnnotation.get(schema).pipe(Option.getOrElse(() => 'description'));
431
+ object[accessor] = description;
432
+ };
433
+
434
+ /**
435
+ * Identifies if a property should be included in a form or not.
436
+ * By default, all properties are included in forms, so this is opt-out.
437
+ */
438
+ // TODO(burdon): UI concern.
439
+ export const FormInputAnnotationId = Symbol.for('@dxos/schema/annotation/FormInput');
440
+ export const FormInputAnnotation = createAnnotationHelper<boolean>(FormInputAnnotationId);
441
+
442
+ /**
443
+ * Default field to be used on referenced schema to lookup the value.
444
+ */
445
+ export const FieldLookupAnnotationId = Symbol.for('@dxos/schema/annotation/FieldLookup');
446
+
447
+ /**
448
+ * Generate test data.
449
+ */
450
+ export const GeneratorAnnotationId = Symbol.for('@dxos/schema/annotation/Generator');
451
+
452
+ export type GeneratorAnnotationValue =
453
+ | string
454
+ | {
455
+ generator: string;
456
+ args?: any[];
457
+ probability?: number;
458
+ };
459
+
460
+ export const GeneratorAnnotation = createAnnotationHelper<GeneratorAnnotationValue>(GeneratorAnnotationId);
461
+
462
+ interface MakeAnnoationsProps<T> {
463
+ id: string;
464
+ schema: Schema.Schema<T, any, never>;
465
+ }
466
+
467
+ // TODO(wittjosiah): Comment.
468
+ export const makeUserAnnotation = <T>(props: MakeAnnoationsProps<T>): AnnotationHelper<T> => {
469
+ assertArgument(
470
+ /[a-zA-Z0-9]+\.[a-zA-Z.]+\/[a-zA-Z/]+/.test(props.id),
471
+ 'id',
472
+ 'Annotation id must be in the FQN format (dxos.org/annotation/Example).',
473
+ );
474
+
475
+ const getFromAst = (ast: SchemaAST.AST) =>
476
+ SchemaAST.getAnnotation<PropertyMetaAnnotation>(PropertyMetaAnnotationId)(ast).pipe(
477
+ Option.map((meta) => meta[props.id] as unknown),
478
+ Option.map(Schema.decodeUnknownSync(props.schema)),
479
+ );
480
+
481
+ return {
482
+ get: (schema) => getFromAst(schema.ast),
483
+ getFromAst: (ast) => getFromAst(ast),
484
+ set: (value) =>
485
+ PropertyMeta(props.id, Schema.encodeSync(props.schema)(value)) as <S extends Schema.Schema.Any>(schema: S) => S,
486
+ };
487
+ };
488
+
489
+ const IconAnnotationSchema = Schema.Struct({
490
+ /**
491
+ * Phosphor icon name (e.g., 'ph--user--regular', 'ph--cube--regular', 'ph--link--regular ', etc.)
492
+ */
493
+ icon: Schema.String.pipe(Schema.pattern(/^ph--[a-z-]+--[a-z]+$/)),
494
+
495
+ /**
496
+ * Color name.
497
+ *
498
+ * List of colors:
499
+ * - 'red'
500
+ * - 'orange'
501
+ * - 'amber'
502
+ * - 'yellow'
503
+ * - 'lime'
504
+ * - 'green'
505
+ * - 'emerald'
506
+ * - 'teal'
507
+ * - 'cyan'
508
+ * - 'violet'
509
+ * - 'purple'
510
+ * - 'fuchsia'
511
+ * - 'pink'
512
+ * - 'rose'
513
+ */
514
+
515
+ hue: Schema.optional(Schema.String),
516
+ });
517
+
518
+ export interface IconAnnotation extends Schema.Schema.Type<typeof IconAnnotationSchema> {}
519
+
520
+ /**
521
+ * Icon to render in the UI.
522
+ */
523
+ export const IconAnnotation = makeUserAnnotation<IconAnnotation>({
524
+ id: 'dxos.org/annotation/Icon',
525
+ schema: IconAnnotationSchema,
526
+ });
@@ -0,0 +1,6 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ export * from './annotations';
6
+ export * from './util';
@@ -0,0 +1,85 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import type * as Option from 'effect/Option';
6
+ import type * as Schema from 'effect/Schema';
7
+ import * as SchemaAST from 'effect/SchemaAST';
8
+
9
+ import { assertArgument } from '@dxos/invariant';
10
+ import { DXN } from '@dxos/keys';
11
+
12
+ import { EntityKind } from '../types';
13
+
14
+ export interface AnnotationHelper<T> {
15
+ /**
16
+ * Get the annotation value from the schema.
17
+ */
18
+ get: (schema: Schema.Schema.Any) => Option.Option<T>;
19
+ /**
20
+ * Get the annotation value from the AST.
21
+ */
22
+ getFromAst: (ast: SchemaAST.AST) => Option.Option<T>;
23
+ /**
24
+ * Set the annotation value on the schema.
25
+ */
26
+ set: (value: T) => <S extends Schema.Schema.Any>(schema: S) => S;
27
+ }
28
+
29
+ /**
30
+ * Note: only for system annotations.
31
+ */
32
+ // TODO(dmaretskyi): Rename to createSystemAnnotationHelper.
33
+ export const createAnnotationHelper = <T>(id: symbol): AnnotationHelper<T> => {
34
+ return {
35
+ get: (schema) => SchemaAST.getAnnotation(schema.ast, id),
36
+ getFromAst: (ast) => SchemaAST.getAnnotation(ast, id),
37
+ set:
38
+ (value) =>
39
+ <S extends Schema.Schema.Any>(schema: S) =>
40
+ schema.annotations({ [id]: value }) as S,
41
+ };
42
+ };
43
+
44
+ /**
45
+ * If property is optional returns the nested property, otherwise returns the property.
46
+ */
47
+ // TODO(wittjosiah): Is there a way to do this as a generic?
48
+ export const unwrapOptional = (property: SchemaAST.PropertySignature) => {
49
+ if (!property.isOptional || !SchemaAST.isUnion(property.type)) {
50
+ return property;
51
+ }
52
+
53
+ return property.type.types[0];
54
+ };
55
+
56
+ /**
57
+ * @see JSONSchemaAnnotationId
58
+ * @returns JSON-schema annotation so that the schema can be serialized with correct parameters.
59
+ */
60
+ // TODO(burdon): Required type.
61
+ export const makeTypeJsonSchemaAnnotation = (options: {
62
+ identifier?: string;
63
+ kind: EntityKind;
64
+ typename: string;
65
+ version: string;
66
+ relationSource?: string;
67
+ relationTarget?: string;
68
+ }) => {
69
+ assertArgument(!!options.relationSource === (options.kind === EntityKind.Relation), 'relationSource');
70
+ assertArgument(!!options.relationTarget === (options.kind === EntityKind.Relation), 'relationTarget');
71
+
72
+ const obj = {
73
+ // TODO(dmaretskyi): Should this include the version?
74
+ $id: options.identifier ?? DXN.fromTypename(options.typename).toString(),
75
+ entityKind: options.kind,
76
+ version: options.version,
77
+ typename: options.typename,
78
+ } as any;
79
+ if (options.kind === EntityKind.Relation) {
80
+ obj.relationSource = { $ref: options.relationSource };
81
+ obj.relationTarget = { $ref: options.relationTarget };
82
+ }
83
+
84
+ return obj;
85
+ };
@@ -0,0 +1,60 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ /**
6
+ * Common annotation helpers shared by Obj and Relation modules.
7
+ */
8
+
9
+ import {
10
+ getDescriptionWithSchema,
11
+ getLabelWithSchema,
12
+ setDescriptionWithSchema,
13
+ setLabelWithSchema,
14
+ } from '../annotations';
15
+ import { type Mutable } from '../proxy';
16
+ import { type AnyProperties, getSchema as getSchema$ } from '../types';
17
+
18
+ /**
19
+ * Get the label of an entity.
20
+ * Accepts both reactive entities and snapshots.
21
+ */
22
+ export const getLabel = (entity: AnyProperties): string | undefined => {
23
+ const schema = getSchema$(entity);
24
+ if (schema != null) {
25
+ return getLabelWithSchema(schema, entity);
26
+ }
27
+ };
28
+
29
+ /**
30
+ * Set the label of an entity.
31
+ * Must be called within an Obj.change or Relation.change callback.
32
+ */
33
+ export const setLabel = (entity: Mutable<AnyProperties>, label: string) => {
34
+ const schema = getSchema$(entity);
35
+ if (schema != null) {
36
+ setLabelWithSchema(schema, entity, label);
37
+ }
38
+ };
39
+
40
+ /**
41
+ * Get the description of an entity.
42
+ * Accepts both reactive entities and snapshots.
43
+ */
44
+ export const getDescription = (entity: AnyProperties): string | undefined => {
45
+ const schema = getSchema$(entity);
46
+ if (schema != null) {
47
+ return getDescriptionWithSchema(schema, entity);
48
+ }
49
+ };
50
+
51
+ /**
52
+ * Set the description of an entity.
53
+ * Must be called within an Obj.change or Relation.change callback.
54
+ */
55
+ export const setDescription = (entity: Mutable<AnyProperties>, description: string) => {
56
+ const schema = getSchema$(entity);
57
+ if (schema != null) {
58
+ setDescriptionWithSchema(schema, entity, description);
59
+ }
60
+ };
@@ -0,0 +1,29 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { invariant } from '@dxos/invariant';
6
+ import { type DXN } from '@dxos/keys';
7
+ import { assumeType } from '@dxos/util';
8
+
9
+ import { type InternalObjectProps, ObjectDatabaseId, getObjectDXN } from '../entities';
10
+ import type { AnyEntity } from '../types';
11
+
12
+ /**
13
+ * Get the DXN of an entity.
14
+ * Accepts both reactive entities and snapshots.
15
+ */
16
+ export const getDXN = (entity: AnyEntity): DXN => {
17
+ const dxn = getObjectDXN(entity);
18
+ invariant(dxn != null, 'Invalid entity.');
19
+ return dxn;
20
+ };
21
+
22
+ /**
23
+ * Get the database the entity belongs to.
24
+ * Accepts both reactive entities and snapshots.
25
+ */
26
+ export const getDatabase = (entity: AnyEntity): any | undefined => {
27
+ assumeType<InternalObjectProps>(entity);
28
+ return entity[ObjectDatabaseId];
29
+ };