@fluidframework/tree 2.41.0-337492 → 2.41.0-338401

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 (491) hide show
  1. package/api-report/tree.alpha.api.md +165 -5
  2. package/dist/alpha.d.ts +2 -0
  3. package/dist/codec/codec.d.ts +42 -7
  4. package/dist/codec/codec.d.ts.map +1 -1
  5. package/dist/codec/codec.js +50 -8
  6. package/dist/codec/codec.js.map +1 -1
  7. package/dist/core/change-family/editBuilder.d.ts.map +1 -1
  8. package/dist/core/change-family/editBuilder.js.map +1 -1
  9. package/dist/core/forest/forest.d.ts.map +1 -1
  10. package/dist/core/forest/forest.js.map +1 -1
  11. package/dist/core/schema-stored/schema.d.ts.map +1 -1
  12. package/dist/core/schema-stored/schema.js.map +1 -1
  13. package/dist/core/schema-stored/storedSchemaRepository.d.ts +1 -1
  14. package/dist/core/schema-stored/storedSchemaRepository.d.ts.map +1 -1
  15. package/dist/core/schema-stored/storedSchemaRepository.js +1 -1
  16. package/dist/core/schema-stored/storedSchemaRepository.js.map +1 -1
  17. package/dist/core/tree/anchorSet.d.ts.map +1 -1
  18. package/dist/core/tree/anchorSet.js +2 -2
  19. package/dist/core/tree/anchorSet.js.map +1 -1
  20. package/dist/core/tree/chunk.d.ts.map +1 -1
  21. package/dist/core/tree/chunk.js.map +1 -1
  22. package/dist/core/tree/delta.d.ts.map +1 -1
  23. package/dist/core/tree/delta.js.map +1 -1
  24. package/dist/core/tree/deltaUtil.d.ts.map +1 -1
  25. package/dist/core/tree/deltaUtil.js.map +1 -1
  26. package/dist/core/tree/detachedFieldIndex.d.ts +1 -1
  27. package/dist/core/tree/detachedFieldIndex.d.ts.map +1 -1
  28. package/dist/core/tree/detachedFieldIndex.js.map +1 -1
  29. package/dist/core/tree/detachedFieldIndexCodec.d.ts +1 -1
  30. package/dist/core/tree/detachedFieldIndexCodec.d.ts.map +1 -1
  31. package/dist/core/tree/detachedFieldIndexCodec.js +1 -1
  32. package/dist/core/tree/detachedFieldIndexCodec.js.map +1 -1
  33. package/dist/core/tree/pathTree.d.ts.map +1 -1
  34. package/dist/core/tree/pathTree.js.map +1 -1
  35. package/dist/core/tree/treeTextFormat.d.ts.map +1 -1
  36. package/dist/core/tree/treeTextFormat.js.map +1 -1
  37. package/dist/core/tree/visitDelta.d.ts +1 -1
  38. package/dist/core/tree/visitDelta.d.ts.map +1 -1
  39. package/dist/core/tree/visitDelta.js.map +1 -1
  40. package/dist/core/tree/visitorUtils.d.ts +2 -2
  41. package/dist/core/tree/visitorUtils.d.ts.map +1 -1
  42. package/dist/core/tree/visitorUtils.js.map +1 -1
  43. package/dist/feature-libraries/chunked-forest/chunkTree.d.ts +1 -1
  44. package/dist/feature-libraries/chunked-forest/chunkTree.d.ts.map +1 -1
  45. package/dist/feature-libraries/chunked-forest/chunkTree.js +1 -1
  46. package/dist/feature-libraries/chunked-forest/chunkTree.js.map +1 -1
  47. package/dist/feature-libraries/chunked-forest/chunkedForest.d.ts +1 -1
  48. package/dist/feature-libraries/chunked-forest/chunkedForest.d.ts.map +1 -1
  49. package/dist/feature-libraries/chunked-forest/chunkedForest.js +1 -1
  50. package/dist/feature-libraries/chunked-forest/chunkedForest.js.map +1 -1
  51. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts +1 -1
  52. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts.map +1 -1
  53. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.js.map +1 -1
  54. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts +2 -2
  55. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts.map +1 -1
  56. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js.map +1 -1
  57. package/dist/feature-libraries/chunked-forest/codec/chunkEncodingGeneric.d.ts.map +1 -1
  58. package/dist/feature-libraries/chunked-forest/codec/chunkEncodingGeneric.js.map +1 -1
  59. package/dist/feature-libraries/chunked-forest/codec/codecs.d.ts +8 -2
  60. package/dist/feature-libraries/chunked-forest/codec/codecs.d.ts.map +1 -1
  61. package/dist/feature-libraries/chunked-forest/codec/codecs.js +12 -1
  62. package/dist/feature-libraries/chunked-forest/codec/codecs.js.map +1 -1
  63. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.d.ts +1 -1
  64. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.d.ts.map +1 -1
  65. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
  66. package/dist/feature-libraries/chunked-forest/codec/index.d.ts +1 -1
  67. package/dist/feature-libraries/chunked-forest/codec/index.d.ts.map +1 -1
  68. package/dist/feature-libraries/chunked-forest/codec/index.js +2 -1
  69. package/dist/feature-libraries/chunked-forest/codec/index.js.map +1 -1
  70. package/dist/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +1 -1
  71. package/dist/feature-libraries/chunked-forest/codec/nodeShape.js +1 -1
  72. package/dist/feature-libraries/chunked-forest/codec/nodeShape.js.map +1 -1
  73. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts +1 -1
  74. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts.map +1 -1
  75. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.js.map +1 -1
  76. package/dist/feature-libraries/chunked-forest/emptyChunk.d.ts.map +1 -1
  77. package/dist/feature-libraries/chunked-forest/emptyChunk.js.map +1 -1
  78. package/dist/feature-libraries/chunked-forest/index.d.ts +1 -1
  79. package/dist/feature-libraries/chunked-forest/index.d.ts.map +1 -1
  80. package/dist/feature-libraries/chunked-forest/index.js +2 -1
  81. package/dist/feature-libraries/chunked-forest/index.js.map +1 -1
  82. package/dist/feature-libraries/chunked-forest/sequenceChunk.d.ts +1 -1
  83. package/dist/feature-libraries/chunked-forest/sequenceChunk.d.ts.map +1 -1
  84. package/dist/feature-libraries/chunked-forest/sequenceChunk.js +4 -4
  85. package/dist/feature-libraries/chunked-forest/sequenceChunk.js.map +1 -1
  86. package/dist/feature-libraries/chunked-forest/uniformChunk.d.ts +1 -1
  87. package/dist/feature-libraries/chunked-forest/uniformChunk.d.ts.map +1 -1
  88. package/dist/feature-libraries/chunked-forest/uniformChunk.js +1 -1
  89. package/dist/feature-libraries/chunked-forest/uniformChunk.js.map +1 -1
  90. package/dist/feature-libraries/default-schema/defaultEditBuilder.js.map +1 -1
  91. package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  92. package/dist/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  93. package/dist/feature-libraries/default-schema/index.d.ts +1 -1
  94. package/dist/feature-libraries/default-schema/index.d.ts.map +1 -1
  95. package/dist/feature-libraries/default-schema/index.js +2 -1
  96. package/dist/feature-libraries/default-schema/index.js.map +1 -1
  97. package/dist/feature-libraries/default-schema/mappedEditBuilder.d.ts.map +1 -1
  98. package/dist/feature-libraries/default-schema/mappedEditBuilder.js.map +1 -1
  99. package/dist/feature-libraries/default-schema/schemaChecker.d.ts +4 -0
  100. package/dist/feature-libraries/default-schema/schemaChecker.d.ts.map +1 -1
  101. package/dist/feature-libraries/default-schema/schemaChecker.js +35 -26
  102. package/dist/feature-libraries/default-schema/schemaChecker.js.map +1 -1
  103. package/dist/feature-libraries/flex-tree/context.d.ts +16 -14
  104. package/dist/feature-libraries/flex-tree/context.d.ts.map +1 -1
  105. package/dist/feature-libraries/flex-tree/context.js +12 -18
  106. package/dist/feature-libraries/flex-tree/context.js.map +1 -1
  107. package/dist/feature-libraries/flex-tree/index.d.ts +1 -1
  108. package/dist/feature-libraries/flex-tree/index.d.ts.map +1 -1
  109. package/dist/feature-libraries/flex-tree/index.js +1 -2
  110. package/dist/feature-libraries/flex-tree/index.js.map +1 -1
  111. package/dist/feature-libraries/flex-tree/lazyField.d.ts +1 -5
  112. package/dist/feature-libraries/flex-tree/lazyField.d.ts.map +1 -1
  113. package/dist/feature-libraries/flex-tree/lazyField.js +2 -16
  114. package/dist/feature-libraries/flex-tree/lazyField.js.map +1 -1
  115. package/dist/feature-libraries/flex-tree/utilities.d.ts +6 -6
  116. package/dist/feature-libraries/flex-tree/utilities.d.ts.map +1 -1
  117. package/dist/feature-libraries/flex-tree/utilities.js +6 -7
  118. package/dist/feature-libraries/flex-tree/utilities.js.map +1 -1
  119. package/dist/feature-libraries/index.d.ts +3 -3
  120. package/dist/feature-libraries/index.d.ts.map +1 -1
  121. package/dist/feature-libraries/index.js +3 -2
  122. package/dist/feature-libraries/index.js.map +1 -1
  123. package/dist/feature-libraries/initializeForest.d.ts.map +1 -1
  124. package/dist/feature-libraries/initializeForest.js.map +1 -1
  125. package/dist/feature-libraries/treeCursorUtils.d.ts.map +1 -1
  126. package/dist/feature-libraries/treeCursorUtils.js +1 -1
  127. package/dist/feature-libraries/treeCursorUtils.js.map +1 -1
  128. package/dist/feature-libraries/valueUtilities.d.ts.map +1 -1
  129. package/dist/feature-libraries/valueUtilities.js +6 -6
  130. package/dist/feature-libraries/valueUtilities.js.map +1 -1
  131. package/dist/jsonDomainSchema.d.ts.map +1 -1
  132. package/dist/jsonDomainSchema.js.map +1 -1
  133. package/dist/packageVersion.d.ts +1 -1
  134. package/dist/packageVersion.js +1 -1
  135. package/dist/packageVersion.js.map +1 -1
  136. package/dist/serializableDomainSchema.d.ts.map +1 -1
  137. package/dist/serializableDomainSchema.js.map +1 -1
  138. package/dist/shared-tree/checkoutFlexTreeView.d.ts +7 -3
  139. package/dist/shared-tree/checkoutFlexTreeView.d.ts.map +1 -1
  140. package/dist/shared-tree/checkoutFlexTreeView.js +11 -2
  141. package/dist/shared-tree/checkoutFlexTreeView.js.map +1 -1
  142. package/dist/shared-tree/schematizingTreeView.d.ts +3 -0
  143. package/dist/shared-tree/schematizingTreeView.d.ts.map +1 -1
  144. package/dist/shared-tree/schematizingTreeView.js +10 -5
  145. package/dist/shared-tree/schematizingTreeView.js.map +1 -1
  146. package/dist/shared-tree/treeAlpha.d.ts +9 -4
  147. package/dist/shared-tree/treeAlpha.d.ts.map +1 -1
  148. package/dist/shared-tree/treeAlpha.js +20 -8
  149. package/dist/shared-tree/treeAlpha.js.map +1 -1
  150. package/dist/sharedTreeAttributes.d.ts.map +1 -1
  151. package/dist/sharedTreeAttributes.js.map +1 -1
  152. package/dist/simple-tree/api/create.d.ts +5 -1
  153. package/dist/simple-tree/api/create.d.ts.map +1 -1
  154. package/dist/simple-tree/api/create.js +11 -12
  155. package/dist/simple-tree/api/create.js.map +1 -1
  156. package/dist/simple-tree/api/index.d.ts +3 -3
  157. package/dist/simple-tree/api/index.d.ts.map +1 -1
  158. package/dist/simple-tree/api/index.js +4 -2
  159. package/dist/simple-tree/api/index.js.map +1 -1
  160. package/dist/simple-tree/api/storedSchema.d.ts +1 -8
  161. package/dist/simple-tree/api/storedSchema.d.ts.map +1 -1
  162. package/dist/simple-tree/api/storedSchema.js +3 -14
  163. package/dist/simple-tree/api/storedSchema.js.map +1 -1
  164. package/dist/simple-tree/api/treeNodeApi.d.ts +8 -0
  165. package/dist/simple-tree/api/treeNodeApi.d.ts.map +1 -1
  166. package/dist/simple-tree/api/treeNodeApi.js +3 -1
  167. package/dist/simple-tree/api/treeNodeApi.js.map +1 -1
  168. package/dist/simple-tree/arrayNode.d.ts.map +1 -1
  169. package/dist/simple-tree/arrayNode.js +3 -9
  170. package/dist/simple-tree/arrayNode.js.map +1 -1
  171. package/dist/simple-tree/core/getOrCreateNode.js +1 -1
  172. package/dist/simple-tree/core/getOrCreateNode.js.map +1 -1
  173. package/dist/simple-tree/core/treeNodeKernel.d.ts +5 -17
  174. package/dist/simple-tree/core/treeNodeKernel.d.ts.map +1 -1
  175. package/dist/simple-tree/core/treeNodeKernel.js +17 -48
  176. package/dist/simple-tree/core/treeNodeKernel.js.map +1 -1
  177. package/dist/simple-tree/core/unhydratedFlexTree.d.ts +4 -4
  178. package/dist/simple-tree/core/unhydratedFlexTree.js +4 -4
  179. package/dist/simple-tree/core/unhydratedFlexTree.js.map +1 -1
  180. package/dist/simple-tree/getTreeNodeForField.d.ts +12 -0
  181. package/dist/simple-tree/getTreeNodeForField.d.ts.map +1 -0
  182. package/dist/simple-tree/getTreeNodeForField.js +39 -0
  183. package/dist/simple-tree/getTreeNodeForField.js.map +1 -0
  184. package/dist/simple-tree/index.d.ts +3 -2
  185. package/dist/simple-tree/index.d.ts.map +1 -1
  186. package/dist/simple-tree/index.js +10 -6
  187. package/dist/simple-tree/index.js.map +1 -1
  188. package/dist/simple-tree/mapNode.d.ts.map +1 -1
  189. package/dist/simple-tree/mapNode.js +21 -24
  190. package/dist/simple-tree/mapNode.js.map +1 -1
  191. package/dist/simple-tree/objectNode.d.ts.map +1 -1
  192. package/dist/simple-tree/objectNode.js +5 -7
  193. package/dist/simple-tree/objectNode.js.map +1 -1
  194. package/dist/simple-tree/prepareForInsertion.d.ts +42 -0
  195. package/dist/simple-tree/prepareForInsertion.d.ts.map +1 -0
  196. package/dist/simple-tree/prepareForInsertion.js +166 -0
  197. package/dist/simple-tree/prepareForInsertion.js.map +1 -0
  198. package/dist/simple-tree/toMapTree.d.ts +4 -9
  199. package/dist/simple-tree/toMapTree.d.ts.map +1 -1
  200. package/dist/simple-tree/toMapTree.js +4 -23
  201. package/dist/simple-tree/toMapTree.js.map +1 -1
  202. package/dist/tableSchema.d.ts +201 -104
  203. package/dist/tableSchema.d.ts.map +1 -1
  204. package/dist/tableSchema.js +155 -58
  205. package/dist/tableSchema.js.map +1 -1
  206. package/dist/treeFactory.d.ts.map +1 -1
  207. package/dist/treeFactory.js +2 -2
  208. package/dist/treeFactory.js.map +1 -1
  209. package/lib/alpha.d.ts +2 -0
  210. package/lib/codec/codec.d.ts +42 -7
  211. package/lib/codec/codec.d.ts.map +1 -1
  212. package/lib/codec/codec.js +50 -8
  213. package/lib/codec/codec.js.map +1 -1
  214. package/lib/core/change-family/editBuilder.d.ts.map +1 -1
  215. package/lib/core/change-family/editBuilder.js.map +1 -1
  216. package/lib/core/forest/forest.d.ts.map +1 -1
  217. package/lib/core/forest/forest.js.map +1 -1
  218. package/lib/core/schema-stored/schema.d.ts.map +1 -1
  219. package/lib/core/schema-stored/schema.js.map +1 -1
  220. package/lib/core/schema-stored/storedSchemaRepository.d.ts +1 -1
  221. package/lib/core/schema-stored/storedSchemaRepository.d.ts.map +1 -1
  222. package/lib/core/schema-stored/storedSchemaRepository.js +1 -1
  223. package/lib/core/schema-stored/storedSchemaRepository.js.map +1 -1
  224. package/lib/core/tree/anchorSet.d.ts.map +1 -1
  225. package/lib/core/tree/anchorSet.js +2 -2
  226. package/lib/core/tree/anchorSet.js.map +1 -1
  227. package/lib/core/tree/chunk.d.ts.map +1 -1
  228. package/lib/core/tree/chunk.js.map +1 -1
  229. package/lib/core/tree/delta.d.ts.map +1 -1
  230. package/lib/core/tree/delta.js.map +1 -1
  231. package/lib/core/tree/deltaUtil.d.ts.map +1 -1
  232. package/lib/core/tree/deltaUtil.js.map +1 -1
  233. package/lib/core/tree/detachedFieldIndex.d.ts +1 -1
  234. package/lib/core/tree/detachedFieldIndex.d.ts.map +1 -1
  235. package/lib/core/tree/detachedFieldIndex.js.map +1 -1
  236. package/lib/core/tree/detachedFieldIndexCodec.d.ts +1 -1
  237. package/lib/core/tree/detachedFieldIndexCodec.d.ts.map +1 -1
  238. package/lib/core/tree/detachedFieldIndexCodec.js +1 -1
  239. package/lib/core/tree/detachedFieldIndexCodec.js.map +1 -1
  240. package/lib/core/tree/pathTree.d.ts.map +1 -1
  241. package/lib/core/tree/pathTree.js.map +1 -1
  242. package/lib/core/tree/treeTextFormat.d.ts.map +1 -1
  243. package/lib/core/tree/treeTextFormat.js.map +1 -1
  244. package/lib/core/tree/visitDelta.d.ts +1 -1
  245. package/lib/core/tree/visitDelta.d.ts.map +1 -1
  246. package/lib/core/tree/visitDelta.js.map +1 -1
  247. package/lib/core/tree/visitorUtils.d.ts +2 -2
  248. package/lib/core/tree/visitorUtils.d.ts.map +1 -1
  249. package/lib/core/tree/visitorUtils.js.map +1 -1
  250. package/lib/feature-libraries/chunked-forest/chunkTree.d.ts +1 -1
  251. package/lib/feature-libraries/chunked-forest/chunkTree.d.ts.map +1 -1
  252. package/lib/feature-libraries/chunked-forest/chunkTree.js +1 -1
  253. package/lib/feature-libraries/chunked-forest/chunkTree.js.map +1 -1
  254. package/lib/feature-libraries/chunked-forest/chunkedForest.d.ts +1 -1
  255. package/lib/feature-libraries/chunked-forest/chunkedForest.d.ts.map +1 -1
  256. package/lib/feature-libraries/chunked-forest/chunkedForest.js +1 -1
  257. package/lib/feature-libraries/chunked-forest/chunkedForest.js.map +1 -1
  258. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts +1 -1
  259. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts.map +1 -1
  260. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.js.map +1 -1
  261. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts +2 -2
  262. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts.map +1 -1
  263. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js.map +1 -1
  264. package/lib/feature-libraries/chunked-forest/codec/chunkEncodingGeneric.d.ts.map +1 -1
  265. package/lib/feature-libraries/chunked-forest/codec/chunkEncodingGeneric.js.map +1 -1
  266. package/lib/feature-libraries/chunked-forest/codec/codecs.d.ts +8 -2
  267. package/lib/feature-libraries/chunked-forest/codec/codecs.d.ts.map +1 -1
  268. package/lib/feature-libraries/chunked-forest/codec/codecs.js +10 -0
  269. package/lib/feature-libraries/chunked-forest/codec/codecs.js.map +1 -1
  270. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts +1 -1
  271. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts.map +1 -1
  272. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
  273. package/lib/feature-libraries/chunked-forest/codec/index.d.ts +1 -1
  274. package/lib/feature-libraries/chunked-forest/codec/index.d.ts.map +1 -1
  275. package/lib/feature-libraries/chunked-forest/codec/index.js +1 -1
  276. package/lib/feature-libraries/chunked-forest/codec/index.js.map +1 -1
  277. package/lib/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +1 -1
  278. package/lib/feature-libraries/chunked-forest/codec/nodeShape.js +1 -1
  279. package/lib/feature-libraries/chunked-forest/codec/nodeShape.js.map +1 -1
  280. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts +1 -1
  281. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts.map +1 -1
  282. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.js.map +1 -1
  283. package/lib/feature-libraries/chunked-forest/emptyChunk.d.ts.map +1 -1
  284. package/lib/feature-libraries/chunked-forest/emptyChunk.js.map +1 -1
  285. package/lib/feature-libraries/chunked-forest/index.d.ts +1 -1
  286. package/lib/feature-libraries/chunked-forest/index.d.ts.map +1 -1
  287. package/lib/feature-libraries/chunked-forest/index.js +1 -1
  288. package/lib/feature-libraries/chunked-forest/index.js.map +1 -1
  289. package/lib/feature-libraries/chunked-forest/sequenceChunk.d.ts +1 -1
  290. package/lib/feature-libraries/chunked-forest/sequenceChunk.d.ts.map +1 -1
  291. package/lib/feature-libraries/chunked-forest/sequenceChunk.js +1 -1
  292. package/lib/feature-libraries/chunked-forest/sequenceChunk.js.map +1 -1
  293. package/lib/feature-libraries/chunked-forest/uniformChunk.d.ts +1 -1
  294. package/lib/feature-libraries/chunked-forest/uniformChunk.d.ts.map +1 -1
  295. package/lib/feature-libraries/chunked-forest/uniformChunk.js +1 -1
  296. package/lib/feature-libraries/chunked-forest/uniformChunk.js.map +1 -1
  297. package/lib/feature-libraries/default-schema/defaultEditBuilder.js.map +1 -1
  298. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  299. package/lib/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  300. package/lib/feature-libraries/default-schema/index.d.ts +1 -1
  301. package/lib/feature-libraries/default-schema/index.d.ts.map +1 -1
  302. package/lib/feature-libraries/default-schema/index.js +1 -1
  303. package/lib/feature-libraries/default-schema/index.js.map +1 -1
  304. package/lib/feature-libraries/default-schema/mappedEditBuilder.d.ts.map +1 -1
  305. package/lib/feature-libraries/default-schema/mappedEditBuilder.js.map +1 -1
  306. package/lib/feature-libraries/default-schema/schemaChecker.d.ts +4 -0
  307. package/lib/feature-libraries/default-schema/schemaChecker.d.ts.map +1 -1
  308. package/lib/feature-libraries/default-schema/schemaChecker.js +33 -25
  309. package/lib/feature-libraries/default-schema/schemaChecker.js.map +1 -1
  310. package/lib/feature-libraries/flex-tree/context.d.ts +16 -14
  311. package/lib/feature-libraries/flex-tree/context.d.ts.map +1 -1
  312. package/lib/feature-libraries/flex-tree/context.js +11 -16
  313. package/lib/feature-libraries/flex-tree/context.js.map +1 -1
  314. package/lib/feature-libraries/flex-tree/index.d.ts +1 -1
  315. package/lib/feature-libraries/flex-tree/index.d.ts.map +1 -1
  316. package/lib/feature-libraries/flex-tree/index.js +1 -1
  317. package/lib/feature-libraries/flex-tree/index.js.map +1 -1
  318. package/lib/feature-libraries/flex-tree/lazyField.d.ts +1 -5
  319. package/lib/feature-libraries/flex-tree/lazyField.d.ts.map +1 -1
  320. package/lib/feature-libraries/flex-tree/lazyField.js +1 -14
  321. package/lib/feature-libraries/flex-tree/lazyField.js.map +1 -1
  322. package/lib/feature-libraries/flex-tree/utilities.d.ts +6 -6
  323. package/lib/feature-libraries/flex-tree/utilities.d.ts.map +1 -1
  324. package/lib/feature-libraries/flex-tree/utilities.js +6 -7
  325. package/lib/feature-libraries/flex-tree/utilities.js.map +1 -1
  326. package/lib/feature-libraries/index.d.ts +3 -3
  327. package/lib/feature-libraries/index.d.ts.map +1 -1
  328. package/lib/feature-libraries/index.js +3 -3
  329. package/lib/feature-libraries/index.js.map +1 -1
  330. package/lib/feature-libraries/initializeForest.d.ts.map +1 -1
  331. package/lib/feature-libraries/initializeForest.js.map +1 -1
  332. package/lib/feature-libraries/treeCursorUtils.d.ts.map +1 -1
  333. package/lib/feature-libraries/treeCursorUtils.js +1 -1
  334. package/lib/feature-libraries/treeCursorUtils.js.map +1 -1
  335. package/lib/feature-libraries/valueUtilities.d.ts.map +1 -1
  336. package/lib/feature-libraries/valueUtilities.js +1 -1
  337. package/lib/feature-libraries/valueUtilities.js.map +1 -1
  338. package/lib/jsonDomainSchema.d.ts.map +1 -1
  339. package/lib/jsonDomainSchema.js.map +1 -1
  340. package/lib/packageVersion.d.ts +1 -1
  341. package/lib/packageVersion.js +1 -1
  342. package/lib/packageVersion.js.map +1 -1
  343. package/lib/serializableDomainSchema.d.ts.map +1 -1
  344. package/lib/serializableDomainSchema.js.map +1 -1
  345. package/lib/shared-tree/checkoutFlexTreeView.d.ts +7 -3
  346. package/lib/shared-tree/checkoutFlexTreeView.d.ts.map +1 -1
  347. package/lib/shared-tree/checkoutFlexTreeView.js +12 -3
  348. package/lib/shared-tree/checkoutFlexTreeView.js.map +1 -1
  349. package/lib/shared-tree/schematizingTreeView.d.ts +3 -0
  350. package/lib/shared-tree/schematizingTreeView.d.ts.map +1 -1
  351. package/lib/shared-tree/schematizingTreeView.js +11 -6
  352. package/lib/shared-tree/schematizingTreeView.js.map +1 -1
  353. package/lib/shared-tree/treeAlpha.d.ts +9 -4
  354. package/lib/shared-tree/treeAlpha.d.ts.map +1 -1
  355. package/lib/shared-tree/treeAlpha.js +22 -10
  356. package/lib/shared-tree/treeAlpha.js.map +1 -1
  357. package/lib/sharedTreeAttributes.d.ts.map +1 -1
  358. package/lib/sharedTreeAttributes.js.map +1 -1
  359. package/lib/simple-tree/api/create.d.ts +5 -1
  360. package/lib/simple-tree/api/create.d.ts.map +1 -1
  361. package/lib/simple-tree/api/create.js +9 -11
  362. package/lib/simple-tree/api/create.js.map +1 -1
  363. package/lib/simple-tree/api/index.d.ts +3 -3
  364. package/lib/simple-tree/api/index.d.ts.map +1 -1
  365. package/lib/simple-tree/api/index.js +3 -3
  366. package/lib/simple-tree/api/index.js.map +1 -1
  367. package/lib/simple-tree/api/storedSchema.d.ts +1 -8
  368. package/lib/simple-tree/api/storedSchema.d.ts.map +1 -1
  369. package/lib/simple-tree/api/storedSchema.js +2 -12
  370. package/lib/simple-tree/api/storedSchema.js.map +1 -1
  371. package/lib/simple-tree/api/treeNodeApi.d.ts +8 -0
  372. package/lib/simple-tree/api/treeNodeApi.d.ts.map +1 -1
  373. package/lib/simple-tree/api/treeNodeApi.js +2 -2
  374. package/lib/simple-tree/api/treeNodeApi.js.map +1 -1
  375. package/lib/simple-tree/arrayNode.d.ts.map +1 -1
  376. package/lib/simple-tree/arrayNode.js +4 -10
  377. package/lib/simple-tree/arrayNode.js.map +1 -1
  378. package/lib/simple-tree/core/getOrCreateNode.js +2 -2
  379. package/lib/simple-tree/core/getOrCreateNode.js.map +1 -1
  380. package/lib/simple-tree/core/treeNodeKernel.d.ts +5 -17
  381. package/lib/simple-tree/core/treeNodeKernel.d.ts.map +1 -1
  382. package/lib/simple-tree/core/treeNodeKernel.js +16 -47
  383. package/lib/simple-tree/core/treeNodeKernel.js.map +1 -1
  384. package/lib/simple-tree/core/unhydratedFlexTree.d.ts +4 -4
  385. package/lib/simple-tree/core/unhydratedFlexTree.js +4 -4
  386. package/lib/simple-tree/core/unhydratedFlexTree.js.map +1 -1
  387. package/lib/simple-tree/getTreeNodeForField.d.ts +12 -0
  388. package/lib/simple-tree/getTreeNodeForField.d.ts.map +1 -0
  389. package/lib/simple-tree/getTreeNodeForField.js +35 -0
  390. package/lib/simple-tree/getTreeNodeForField.js.map +1 -0
  391. package/lib/simple-tree/index.d.ts +3 -2
  392. package/lib/simple-tree/index.d.ts.map +1 -1
  393. package/lib/simple-tree/index.js +3 -2
  394. package/lib/simple-tree/index.js.map +1 -1
  395. package/lib/simple-tree/mapNode.d.ts.map +1 -1
  396. package/lib/simple-tree/mapNode.js +3 -6
  397. package/lib/simple-tree/mapNode.js.map +1 -1
  398. package/lib/simple-tree/objectNode.d.ts.map +1 -1
  399. package/lib/simple-tree/objectNode.js +4 -6
  400. package/lib/simple-tree/objectNode.js.map +1 -1
  401. package/lib/simple-tree/prepareForInsertion.d.ts +42 -0
  402. package/lib/simple-tree/prepareForInsertion.d.ts.map +1 -0
  403. package/lib/simple-tree/prepareForInsertion.js +160 -0
  404. package/lib/simple-tree/prepareForInsertion.js.map +1 -0
  405. package/lib/simple-tree/toMapTree.d.ts +4 -9
  406. package/lib/simple-tree/toMapTree.d.ts.map +1 -1
  407. package/lib/simple-tree/toMapTree.js +4 -22
  408. package/lib/simple-tree/toMapTree.js.map +1 -1
  409. package/lib/tableSchema.d.ts +201 -104
  410. package/lib/tableSchema.d.ts.map +1 -1
  411. package/lib/tableSchema.js +156 -59
  412. package/lib/tableSchema.js.map +1 -1
  413. package/lib/treeFactory.d.ts.map +1 -1
  414. package/lib/treeFactory.js +2 -2
  415. package/lib/treeFactory.js.map +1 -1
  416. package/lib/tsdoc-metadata.json +1 -1
  417. package/package.json +25 -25
  418. package/src/codec/codec.ts +54 -8
  419. package/src/core/change-family/editBuilder.ts +1 -0
  420. package/src/core/forest/forest.ts +1 -1
  421. package/src/core/schema-stored/schema.ts +2 -0
  422. package/src/core/schema-stored/storedSchemaRepository.ts +2 -2
  423. package/src/core/tree/anchorSet.ts +4 -4
  424. package/src/core/tree/chunk.ts +2 -1
  425. package/src/core/tree/delta.ts +1 -0
  426. package/src/core/tree/deltaUtil.ts +1 -1
  427. package/src/core/tree/detachedFieldIndex.ts +1 -1
  428. package/src/core/tree/detachedFieldIndexCodec.ts +2 -2
  429. package/src/core/tree/pathTree.ts +1 -1
  430. package/src/core/tree/treeTextFormat.ts +1 -0
  431. package/src/core/tree/visitDelta.ts +1 -1
  432. package/src/core/tree/visitorUtils.ts +3 -2
  433. package/src/feature-libraries/chunked-forest/chunkTree.ts +2 -2
  434. package/src/feature-libraries/chunked-forest/chunkedForest.ts +3 -3
  435. package/src/feature-libraries/chunked-forest/codec/chunkDecoding.ts +5 -5
  436. package/src/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.ts +2 -2
  437. package/src/feature-libraries/chunked-forest/codec/chunkEncodingGeneric.ts +1 -0
  438. package/src/feature-libraries/chunked-forest/codec/codecs.ts +15 -1
  439. package/src/feature-libraries/chunked-forest/codec/compressedEncode.ts +1 -1
  440. package/src/feature-libraries/chunked-forest/codec/index.ts +1 -0
  441. package/src/feature-libraries/chunked-forest/codec/nodeShape.ts +1 -1
  442. package/src/feature-libraries/chunked-forest/codec/schemaBasedEncode.ts +1 -1
  443. package/src/feature-libraries/chunked-forest/emptyChunk.ts +1 -0
  444. package/src/feature-libraries/chunked-forest/index.ts +1 -0
  445. package/src/feature-libraries/chunked-forest/sequenceChunk.ts +1 -1
  446. package/src/feature-libraries/chunked-forest/uniformChunk.ts +2 -3
  447. package/src/feature-libraries/default-schema/defaultEditBuilder.ts +1 -1
  448. package/src/feature-libraries/default-schema/defaultFieldKinds.ts +1 -0
  449. package/src/feature-libraries/default-schema/index.ts +6 -1
  450. package/src/feature-libraries/default-schema/mappedEditBuilder.ts +1 -0
  451. package/src/feature-libraries/default-schema/schemaChecker.ts +37 -26
  452. package/src/feature-libraries/flex-tree/context.ts +18 -20
  453. package/src/feature-libraries/flex-tree/index.ts +0 -1
  454. package/src/feature-libraries/flex-tree/lazyField.ts +2 -14
  455. package/src/feature-libraries/flex-tree/utilities.ts +8 -8
  456. package/src/feature-libraries/index.ts +2 -1
  457. package/src/feature-libraries/initializeForest.ts +1 -1
  458. package/src/feature-libraries/treeCursorUtils.ts +1 -1
  459. package/src/feature-libraries/valueUtilities.ts +1 -1
  460. package/src/jsonDomainSchema.ts +0 -1
  461. package/src/packageVersion.ts +1 -1
  462. package/src/serializableDomainSchema.ts +1 -0
  463. package/src/shared-tree/checkoutFlexTreeView.ts +10 -6
  464. package/src/shared-tree/schematizingTreeView.ts +11 -12
  465. package/src/shared-tree/treeAlpha.ts +50 -13
  466. package/src/sharedTreeAttributes.ts +1 -0
  467. package/src/simple-tree/api/create.ts +17 -16
  468. package/src/simple-tree/api/index.ts +13 -3
  469. package/src/simple-tree/api/storedSchema.ts +2 -19
  470. package/src/simple-tree/api/treeNodeApi.ts +2 -2
  471. package/src/simple-tree/arrayNode.ts +9 -20
  472. package/src/simple-tree/core/getOrCreateNode.ts +2 -2
  473. package/src/simple-tree/core/treeNodeKernel.ts +22 -53
  474. package/src/simple-tree/core/unhydratedFlexTree.ts +4 -4
  475. package/src/simple-tree/getTreeNodeForField.ts +46 -0
  476. package/src/simple-tree/index.ts +8 -5
  477. package/src/simple-tree/mapNode.ts +8 -12
  478. package/src/simple-tree/objectNode.ts +3 -12
  479. package/src/simple-tree/prepareForInsertion.ts +276 -0
  480. package/src/simple-tree/toMapTree.ts +3 -27
  481. package/src/tableSchema.ts +351 -138
  482. package/src/treeFactory.ts +2 -4
  483. package/dist/simple-tree/proxies.d.ts +0 -23
  484. package/dist/simple-tree/proxies.d.ts.map +0 -1
  485. package/dist/simple-tree/proxies.js +0 -135
  486. package/dist/simple-tree/proxies.js.map +0 -1
  487. package/lib/simple-tree/proxies.d.ts +0 -23
  488. package/lib/simple-tree/proxies.d.ts.map +0 -1
  489. package/lib/simple-tree/proxies.js +0 -130
  490. package/lib/simple-tree/proxies.js.map +0 -1
  491. package/src/simple-tree/proxies.ts +0 -191
@@ -79,6 +79,9 @@ export const ContextSlot = anchorSlot<Context>();
79
79
  * Implementation of `FlexTreeContext`.
80
80
  *
81
81
  * @remarks An editor is required to edit the FlexTree.
82
+ *
83
+ * A {@link FlexTreeContext} which is used to manage the cursors and anchors within the FlexTrees:
84
+ * This is necessary for supporting using this tree across edits to the forest, and not leaking memory.
82
85
  */
83
86
  export class Context implements FlexTreeHydratedContext, IDisposable {
84
87
  public readonly withCursors: Set<LazyEntity> = new Set();
@@ -88,13 +91,19 @@ export class Context implements FlexTreeHydratedContext, IDisposable {
88
91
  private disposed = false;
89
92
 
90
93
  /**
91
- * @param flexSchema - Schema to use when working with the tree.
92
- * @param checkout - The checkout.
93
- * @param nodeKeyManager - An object which handles node key generation and conversion
94
+ * Stores the last accessed version of the root.
95
+ * @remarks
96
+ * Anything which can delete this field must clear it.
97
+ * Currently "clear" is the only case.
94
98
  */
99
+ private lazyRootCache: FlexTreeField | undefined;
100
+
95
101
  public constructor(
96
102
  public readonly schemaPolicy: SchemaPolicy,
97
103
  public readonly checkout: ITreeCheckout,
104
+ /**
105
+ * An object which handles node key generation and conversion
106
+ */
98
107
  public readonly nodeKeyManager: NodeIdentifierManager,
99
108
  ) {
100
109
  this.eventUnregister = [
@@ -158,16 +167,22 @@ export class Context implements FlexTreeHydratedContext, IDisposable {
158
167
  for (const target of this.withAnchors) {
159
168
  target[disposeSymbol]();
160
169
  }
170
+ this.lazyRootCache = undefined;
161
171
  assert(this.withCursors.size === 0, 0x774 /* free should remove all cursors */);
162
172
  assert(this.withAnchors.size === 0, 0x775 /* free should remove all anchors */);
163
173
  }
164
174
 
165
175
  public get root(): FlexTreeField {
166
176
  assert(this.disposed === false, 0x804 /* use after dispose */);
177
+ if (this.lazyRootCache !== undefined) {
178
+ return this.lazyRootCache;
179
+ }
180
+
167
181
  const cursor = this.checkout.forest.allocateCursor("root");
168
182
  moveToDetachedField(this.checkout.forest, cursor);
169
183
  const field = makeField(this, this.schema.rootFieldSchema.kind, cursor);
170
184
  cursor.free();
185
+ this.lazyRootCache = field;
171
186
  return field;
172
187
  }
173
188
 
@@ -175,20 +190,3 @@ export class Context implements FlexTreeHydratedContext, IDisposable {
175
190
  return this.checkout.forest.events;
176
191
  }
177
192
  }
178
-
179
- /**
180
- * A simple API for a Forest to interact with the tree.
181
- *
182
- * @param forest - the Forest
183
- * @param editor - an editor that makes changes to the forest.
184
- * @param nodeKeyManager - an object which handles node key generation and conversion.
185
- * @returns {@link FlexTreeContext} which is used to manage the cursors and anchors within the FlexTrees:
186
- * This is necessary for supporting using this tree across edits to the forest, and not leaking memory.
187
- */
188
- export function getTreeContext(
189
- schema: SchemaPolicy,
190
- checkout: ITreeCheckout,
191
- nodeKeyManager: NodeIdentifierManager,
192
- ): Context {
193
- return new Context(schema, checkout, nodeKeyManager);
194
- }
@@ -28,7 +28,6 @@ export {
28
28
  } from "./navigation.js";
29
29
 
30
30
  export {
31
- getTreeContext,
32
31
  type FlexTreeContext,
33
32
  type FlexTreeHydratedContext,
34
33
  Context,
@@ -278,20 +278,8 @@ export class LazySequence extends LazyField implements FlexTreeSequenceField {
278
278
  }
279
279
  }
280
280
 
281
- export class ReadonlyLazyValueField extends LazyField implements FlexTreeRequiredField {
281
+ export class LazyValueField extends LazyField implements FlexTreeRequiredField {
282
282
  public editor: ValueFieldEditBuilder<ExclusiveMapTree> = {
283
- set: (newContent) => {
284
- assert(false, 0xa0c /* Unexpected set of readonly field */);
285
- },
286
- };
287
-
288
- public get content(): FlexTreeUnknownUnboxed {
289
- return this.atIndex(0);
290
- }
291
- }
292
-
293
- export class LazyValueField extends ReadonlyLazyValueField implements FlexTreeRequiredField {
294
- public override editor: ValueFieldEditBuilder<ExclusiveMapTree> = {
295
283
  set: (newContent) => {
296
284
  this.valueFieldEditor().set(cursorForMapTreeField([newContent]));
297
285
  },
@@ -303,7 +291,7 @@ export class LazyValueField extends ReadonlyLazyValueField implements FlexTreeRe
303
291
  return fieldEditor;
304
292
  }
305
293
 
306
- public override get content(): FlexTreeUnknownUnboxed {
294
+ public get content(): FlexTreeUnknownUnboxed {
307
295
  return this.atIndex(0);
308
296
  }
309
297
  }
@@ -11,8 +11,9 @@ import {
11
11
  rootField,
12
12
  type SchemaAndPolicy,
13
13
  } from "../../core/index.js";
14
+ import type { FlexTreeContext } from "./context.js";
14
15
 
15
- import { TreeStatus, type FlexTreeEntity } from "./flexTreeTypes.js";
16
+ import { TreeStatus } from "./flexTreeTypes.js";
16
17
  /**
17
18
  * Checks the detached field and returns the TreeStatus based on whether or not the detached field is a root field.
18
19
  * @param detachedField - the detached field you want to check.
@@ -75,15 +76,14 @@ export interface DetachedFieldCache {
75
76
  }
76
77
 
77
78
  /**
78
- * Utility function to get a {@link SchemaAndPolicy} object from a {@link FlexTreeNode} or {@link FlexTreeField}.
79
- * @param nodeOrField - {@link FlexTreeNode} or {@link FlexTreeField} to get the schema and policy from.
80
- * @returns A {@link SchemaAndPolicy} object with the stored schema and policy from the node or field provided.
81
- * For {@link Unhydrated} nodes this schema may only describe the types allowed subtree for this particular entity.
79
+ * Utility function to get a {@link SchemaAndPolicy} object from a {@link FlexTreeContext}.
80
+ * @returns A {@link SchemaAndPolicy} object with the stored schema and policy from the context provided.
81
+ * For {@link Unhydrated} contexts this schema may only describe the types allowed subtree for this particular entity.
82
82
  */
83
- export function getSchemaAndPolicy(nodeOrField: FlexTreeEntity): SchemaAndPolicy {
83
+ export function getSchemaAndPolicy(context: FlexTreeContext): SchemaAndPolicy {
84
84
  return {
85
- schema: nodeOrField.context.schema,
86
- policy: nodeOrField.context.schemaPolicy,
85
+ schema: context.schema,
86
+ policy: context.schemaPolicy,
87
87
  };
88
88
  }
89
89
 
@@ -109,6 +109,7 @@ export {
109
109
  type FieldBatchCodec,
110
110
  makeTreeChunker,
111
111
  makeFieldBatchCodec,
112
+ fluidVersionToFieldBatchCodecWriteVersion,
112
113
  type FieldBatchEncodingContext,
113
114
  } from "./chunked-forest/index.js";
114
115
 
@@ -145,6 +146,7 @@ export {
145
146
  SchemaValidationErrors,
146
147
  isNodeInSchema,
147
148
  isFieldInSchema,
149
+ inSchemaOrThrow,
148
150
  } from "./default-schema/index.js";
149
151
 
150
152
  export {
@@ -158,7 +160,6 @@ export {
158
160
  type FlexTreeEntity,
159
161
  type FlexTreeField,
160
162
  type FlexTreeNode,
161
- getTreeContext,
162
163
  TreeStatus,
163
164
  Context,
164
165
  type FlexTreeNodeEvents,
@@ -3,8 +3,8 @@
3
3
  * Licensed under the MIT License.
4
4
  */
5
5
 
6
- import type { SessionSpaceCompressedId, IIdCompressor } from "@fluidframework/id-compressor";
7
6
  import { assert } from "@fluidframework/core-utils/internal";
7
+ import type { SessionSpaceCompressedId, IIdCompressor } from "@fluidframework/id-compressor";
8
8
 
9
9
  import {
10
10
  type DeltaRoot,
@@ -4,6 +4,7 @@
4
4
  */
5
5
 
6
6
  import { assert, oob, debugAssert, fail } from "@fluidframework/core-utils/internal";
7
+ import { UsageError } from "@fluidframework/telemetry-utils/internal";
7
8
 
8
9
  import {
9
10
  CursorLocationType,
@@ -19,7 +20,6 @@ import {
19
20
  detachedFieldAsKey,
20
21
  rootField,
21
22
  } from "../core/index.js";
22
- import { UsageError } from "@fluidframework/telemetry-utils/internal";
23
23
 
24
24
  /**
25
25
  * {@link ITreeCursorSynchronous} that can return the underlying node objects.
@@ -3,9 +3,9 @@
3
3
  * Licensed under the MIT License.
4
4
  */
5
5
 
6
- import { isFluidHandle } from "@fluidframework/runtime-utils/internal";
7
6
  import type { IFluidHandle } from "@fluidframework/core-interfaces";
8
7
  import { assert, unreachableCase } from "@fluidframework/core-utils/internal";
8
+ import { isFluidHandle } from "@fluidframework/runtime-utils/internal";
9
9
 
10
10
  import { type TreeValue, type Value, ValueSchema } from "../core/index.js";
11
11
 
@@ -4,7 +4,6 @@
4
4
  */
5
5
 
6
6
  import { SchemaFactory } from "./simple-tree/index.js";
7
-
8
7
  import type {
9
8
  AllowedTypes,
10
9
  FixRecursiveArraySchema,
@@ -6,4 +6,4 @@
6
6
  */
7
7
 
8
8
  export const pkgName = "@fluidframework/tree";
9
- export const pkgVersion = "2.41.0-337492";
9
+ export const pkgVersion = "2.41.0-338401";
@@ -4,6 +4,7 @@
4
4
  */
5
5
 
6
6
  import type { IFluidHandle } from "@fluidframework/core-interfaces";
7
+
7
8
  import {
8
9
  SchemaFactory,
9
10
  type FixRecursiveArraySchema,
@@ -5,10 +5,9 @@
5
5
 
6
6
  import { assert } from "@fluidframework/core-utils/internal";
7
7
  import {
8
- type Context,
8
+ Context,
9
9
  type FlexTreeField,
10
10
  type NodeIdentifierManager,
11
- getTreeContext,
12
11
  type FlexTreeHydratedContext,
13
12
  type FullSchemaPolicy,
14
13
  } from "../feature-libraries/index.js";
@@ -19,6 +18,10 @@ import type { ITreeCheckout, ITreeCheckoutFork } from "./treeCheckout.js";
19
18
 
20
19
  /**
21
20
  * An editable view of a (version control style) branch of a shared tree.
21
+ * @remarks
22
+ * Does not depend on stored schema, and thus can live across schema changes.
23
+ * @privateRemarks
24
+ * This has no state beyond the context, so it likely should be replaced with just the context.
22
25
  */
23
26
  export class CheckoutFlexTreeView<out TCheckout extends ITreeCheckout = ITreeCheckout> {
24
27
  /**
@@ -30,9 +33,11 @@ export class CheckoutFlexTreeView<out TCheckout extends ITreeCheckout = ITreeChe
30
33
  public readonly context: Context;
31
34
 
32
35
  /**
33
- * Get a typed view of the tree content using the flex-tree API.
36
+ * Get a view of the tree content using the flex-tree API.
34
37
  */
35
- public readonly flexTree: FlexTreeField;
38
+ public get flexTree(): FlexTreeField {
39
+ return this.context.root;
40
+ }
36
41
 
37
42
  private disposed = false;
38
43
 
@@ -48,9 +53,8 @@ export class CheckoutFlexTreeView<out TCheckout extends ITreeCheckout = ITreeChe
48
53
  public readonly nodeKeyManager: NodeIdentifierManager,
49
54
  private readonly onDispose?: () => void,
50
55
  ) {
51
- this.context = getTreeContext(schema, this.checkout, nodeKeyManager);
56
+ this.context = new Context(schema, this.checkout, nodeKeyManager);
52
57
  contextToTreeViewMap.set(this.context, this);
53
- this.flexTree = this.context.root;
54
58
  }
55
59
 
56
60
  public [disposeSymbol](): void {
@@ -33,9 +33,6 @@ import {
33
33
  SchemaCompatibilityTester,
34
34
  type InsertableContent,
35
35
  type TreeViewConfiguration,
36
- mapTreeFromNodeData,
37
- prepareContentForHydration,
38
- comparePersistedSchemaInternal,
39
36
  type TreeViewAlpha,
40
37
  type InsertableField,
41
38
  type ReadableField,
@@ -55,6 +52,7 @@ import {
55
52
  SimpleContextSlot,
56
53
  areImplicitFieldSchemaEqual,
57
54
  createUnknownOptionalFieldPolicy,
55
+ prepareForInsertionContextless,
58
56
  } from "../simple-tree/index.js";
59
57
  import {
60
58
  type Breakable,
@@ -99,6 +97,9 @@ export class SchematizingSimpleTreeView<
99
97
 
100
98
  private readonly viewSchema: SchemaCompatibilityTester;
101
99
 
100
+ /**
101
+ * Events to unregister upon disposal.
102
+ */
102
103
  private readonly unregisterCallbacks = new Set<() => void>();
103
104
 
104
105
  public disposed = false;
@@ -174,17 +175,16 @@ export class SchematizingSimpleTreeView<
174
175
 
175
176
  this.runSchemaEdit(() => {
176
177
  const schema = this.viewSchema.viewSchemaAsStored;
177
- const mapTree = mapTreeFromNodeData(
178
+ const mapTree = prepareForInsertionContextless(
178
179
  content as InsertableContent | undefined,
179
180
  this.rootFieldSchema,
180
- this.nodeKeyManager,
181
181
  {
182
182
  schema,
183
183
  policy: this.schemaPolicy,
184
184
  },
185
+ this,
185
186
  );
186
187
 
187
- prepareContentForHydration(mapTree, this.checkout.forest);
188
188
  initialize(this.checkout, {
189
189
  schema,
190
190
  initialTree: mapTree === undefined ? undefined : cursorForMapTreeNode(mapTree),
@@ -324,15 +324,14 @@ export class SchematizingSimpleTreeView<
324
324
  private update(): void {
325
325
  this.disposeView();
326
326
 
327
- const compatibility = comparePersistedSchemaInternal(
328
- this.checkout.storedSchema,
329
- this.viewSchema,
330
- canInitialize(this.checkout),
331
- );
327
+ const compatibility = this.viewSchema.checkCompatibility(this.checkout.storedSchema);
332
328
 
333
329
  let lastRoot =
334
330
  this.compatibility.canView && this.view !== undefined ? this.root : undefined;
335
- this.currentCompatibility = compatibility;
331
+ this.currentCompatibility = {
332
+ ...compatibility,
333
+ canInitialize: canInitialize(this.checkout),
334
+ };
336
335
 
337
336
  if (compatibility.canView) {
338
337
  // Trigger "rootChanged" if the root changes in the future.
@@ -36,6 +36,10 @@ import {
36
36
  extractPersistedSchema,
37
37
  type TreeBranch,
38
38
  TreeViewConfigurationAlpha,
39
+ getStoredKey,
40
+ getPropertyKeyFromStoredKey,
41
+ treeNodeApi,
42
+ mapTreeFromNodeData,
39
43
  } from "../simple-tree/index.js";
40
44
  import type { JsonCompatible } from "../util/index.js";
41
45
  import { noopValidator, type FluidClientVersion, type ICodecOptions } from "../codec/index.js";
@@ -49,10 +53,12 @@ import {
49
53
  TreeCompressionStrategy,
50
54
  type FieldBatch,
51
55
  type FieldBatchEncodingContext,
56
+ fluidVersionToFieldBatchCodecWriteVersion,
52
57
  } from "../feature-libraries/index.js";
53
58
  import { independentInitializedView, type ViewContent } from "./independentView.js";
54
59
  import { SchematizingSimpleTreeView, ViewSlot } from "./schematizingTreeView.js";
55
60
  import { currentVersion } from "../codec/index.js";
61
+ import { createFromMapTree } from "../simple-tree/index.js";
56
62
 
57
63
  /**
58
64
  * Extensions to {@link (Tree:interface)} and {@link (TreeBeta:interface)} which are not yet stable.
@@ -80,11 +86,8 @@ export interface TreeAlpha {
80
86
  * When providing a {@link TreeNodeSchemaClass}, this is the same as invoking its constructor except that an unhydrated node can also be provided.
81
87
  * This function exists as a generalization that can be used in other cases as well,
82
88
  * such as when `undefined` might be allowed (for an optional field), or when the type should be inferred from the data when more than one type is possible.
83
- *
84
- * Like with {@link TreeNodeSchemaClass}'s constructor, it's an error to provide an existing node to this API.
85
- * For that case, use {@link (TreeBeta:interface).clone}.
86
89
  * @privateRemarks
87
- * There should be a way to provide a source for defaulted identifiers, wither via this API or some way to add them to its output later.
90
+ * There should be a way to provide a source for defaulted identifiers, either via this API or some way to add them to its output later.
88
91
  */
89
92
  create<const TSchema extends ImplicitFieldSchema | UnsafeUnknownSchema>(
90
93
  schema: UnsafeUnknownSchema extends TSchema
@@ -208,6 +211,15 @@ export interface TreeAlpha {
208
211
  compressedData: JsonCompatible<IFluidHandle>,
209
212
  options: { idCompressor?: IIdCompressor } & ICodecOptions,
210
213
  ): Unhydrated<TreeFieldFromImplicitField<TSchema>>;
214
+
215
+ /**
216
+ * The key of the given node under its parent.
217
+ * @remarks
218
+ * If `node` is an element in a {@link (TreeArrayNode:interface)}, this returns the index of `node` in the array node (a `number`).
219
+ * If `node` is the root node, this returns undefined.
220
+ * Otherwise, this returns the key of the field that it is under (a `string`).
221
+ */
222
+ key2(node: TreeNode): string | number | undefined;
211
223
  }
212
224
 
213
225
  /**
@@ -229,7 +241,24 @@ export const TreeAlpha: TreeAlpha = {
229
241
  return view;
230
242
  },
231
243
 
232
- create: createFromInsertable,
244
+ create<const TSchema extends ImplicitFieldSchema | UnsafeUnknownSchema>(
245
+ schema: UnsafeUnknownSchema extends TSchema
246
+ ? ImplicitFieldSchema
247
+ : TSchema & ImplicitFieldSchema,
248
+ data: InsertableField<TSchema>,
249
+ ): Unhydrated<
250
+ TSchema extends ImplicitFieldSchema
251
+ ? TreeFieldFromImplicitField<TSchema>
252
+ : TreeNode | TreeLeafValue | undefined
253
+ > {
254
+ const mapTree = mapTreeFromNodeData(data as InsertableField<UnsafeUnknownSchema>, schema);
255
+ const result = mapTree === undefined ? undefined : createFromMapTree(schema, mapTree);
256
+ return result as Unhydrated<
257
+ TSchema extends ImplicitFieldSchema
258
+ ? TreeFieldFromImplicitField<TSchema>
259
+ : TreeNode | TreeLeafValue | undefined
260
+ >;
261
+ },
233
262
 
234
263
  importConcise<TSchema extends ImplicitFieldSchema | UnsafeUnknownSchema>(
235
264
  schema: UnsafeUnknownSchema extends TSchema
@@ -291,7 +320,7 @@ export const TreeAlpha: TreeAlpha = {
291
320
  },
292
321
  ): JsonCompatible<IFluidHandle> {
293
322
  const schema = tryGetSchema(node) ?? fail(0xacf /* invalid input */);
294
- const format = versionToFormat[options.oldestCompatibleClient];
323
+ const format = fluidVersionToFieldBatchCodecWriteVersion(options.oldestCompatibleClient);
295
324
  const codec = makeFieldBatchCodec({ jsonValidator: noopValidator }, format);
296
325
  const cursor = borrowFieldCursorFromTreeNodeOrValue(node);
297
326
  const batch: FieldBatch = [cursor];
@@ -323,6 +352,21 @@ export const TreeAlpha: TreeAlpha = {
323
352
  const view = independentInitializedView(config, options, content);
324
353
  return TreeBeta.clone<TSchema>(view.root);
325
354
  },
355
+
356
+ key2(node: TreeNode): string | number | undefined {
357
+ // If the parent is undefined, then this node is under the root field,
358
+ const parent = treeNodeApi.parent(node);
359
+ if (parent === undefined) {
360
+ return undefined;
361
+ }
362
+
363
+ // The flex-domain strictly operates in terms of "stored keys".
364
+ // To find the associated developer-facing "property key", we need to look up the field associated with
365
+ // the stored key from the flex-domain, and get property key its simple-domain counterpart was created with.
366
+ const storedKey = getStoredKey(node);
367
+ const parentSchema = treeNodeApi.schema(parent);
368
+ return getPropertyKeyFromStoredKey(parentSchema, storedKey);
369
+ },
326
370
  };
327
371
 
328
372
  function exportConcise(
@@ -374,10 +418,3 @@ function borrowFieldCursorFromTreeNodeOrValue(
374
418
  const mapTree = mapTreeFromCursor(cursor);
375
419
  return cursorForMapTreeField([mapTree]);
376
420
  }
377
-
378
- const versionToFormat = {
379
- v2_0: 1,
380
- v2_1: 1,
381
- v2_2: 1,
382
- v2_3: 1,
383
- };
@@ -4,6 +4,7 @@
4
4
  */
5
5
 
6
6
  import type { IChannelAttributes } from "@fluidframework/datastore-definitions/internal";
7
+
7
8
  import { pkgVersion } from "./packageVersion.js";
8
9
 
9
10
  /**
@@ -5,7 +5,11 @@
5
5
 
6
6
  import { assert } from "@fluidframework/core-utils/internal";
7
7
 
8
- import type { ITreeCursorSynchronous, SchemaAndPolicy } from "../../core/index.js";
8
+ import type {
9
+ ExclusiveMapTree,
10
+ ITreeCursorSynchronous,
11
+ SchemaAndPolicy,
12
+ } from "../../core/index.js";
9
13
  import type {
10
14
  ImplicitFieldSchema,
11
15
  TreeFieldFromImplicitField,
@@ -24,13 +28,12 @@ import {
24
28
  import {
25
29
  cursorForMapTreeNode,
26
30
  defaultSchemaPolicy,
27
- FieldKinds,
31
+ inSchemaOrThrow,
28
32
  mapTreeFromCursor,
29
33
  type NodeIdentifierManager,
30
34
  } from "../../feature-libraries/index.js";
31
35
  import { isFieldInSchema } from "../../feature-libraries/index.js";
32
- import { toStoredSchema } from "../toStoredSchema.js";
33
- import { inSchemaOrThrow, mapTreeFromNodeData } from "../toMapTree.js";
36
+ import { mapTreeFromNodeData } from "../toMapTree.js";
34
37
  import { getUnhydratedContext } from "../createContext.js";
35
38
  import { createUnknownOptionalFieldPolicy } from "../objectNode.js";
36
39
 
@@ -88,24 +91,12 @@ export function cursorFromInsertable<
88
91
  ):
89
92
  | ITreeCursorSynchronous
90
93
  | (TSchema extends FieldSchema<FieldKind.Optional> ? undefined : never) {
91
- const storedSchema = toStoredSchema(schema);
92
- const schemaValidationPolicy: SchemaAndPolicy = {
93
- policy: defaultSchemaPolicy,
94
- // TODO: optimize: This isn't the most efficient operation since its not cached, and has to convert all the schema.
95
- schema: storedSchema,
96
- };
97
-
98
94
  const mapTree = mapTreeFromNodeData(
99
95
  data as InsertableField<UnsafeUnknownSchema>,
100
96
  schema,
101
97
  context,
102
- schemaValidationPolicy,
103
98
  );
104
99
  if (mapTree === undefined) {
105
- assert(
106
- storedSchema.rootFieldSchema.kind === FieldKinds.optional.identifier,
107
- 0xa10 /* missing non-optional field */,
108
- );
109
100
  return undefined as TSchema extends FieldSchema<FieldKind.Optional> ? undefined : never;
110
101
  }
111
102
  return cursorForMapTreeNode(mapTree);
@@ -144,6 +135,16 @@ export function createFromCursor<const TSchema extends ImplicitFieldSchema>(
144
135
  // Length asserted above, so this is safe. This assert is done instead of checking for undefined after indexing to ensure a length greater than 1 also errors.
145
136
  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
146
137
  const mapTree = mapTrees[0]!;
138
+ return createFromMapTree(schema, mapTree);
139
+ }
140
+
141
+ /**
142
+ * Creates an unhydrated simple-tree field from an ExclusiveMapTree.
143
+ */
144
+ export function createFromMapTree<const TSchema extends ImplicitFieldSchema>(
145
+ schema: TSchema,
146
+ mapTree: ExclusiveMapTree,
147
+ ): Unhydrated<TreeFieldFromImplicitField<TSchema>> {
147
148
  const mapTreeNode = UnhydratedFlexTreeNode.getOrCreate(
148
149
  getUnhydratedContext(schema),
149
150
  mapTree,
@@ -44,8 +44,19 @@ export {
44
44
  enumFromStrings,
45
45
  singletonSchema,
46
46
  } from "./schemaCreationUtilities.js";
47
- export { treeNodeApi, type TreeNodeApi, tryGetSchema } from "./treeNodeApi.js";
48
- export { createFromInsertable, cursorFromInsertable, createFromCursor } from "./create.js";
47
+ export {
48
+ treeNodeApi,
49
+ type TreeNodeApi,
50
+ tryGetSchema,
51
+ getStoredKey,
52
+ getPropertyKeyFromStoredKey,
53
+ } from "./treeNodeApi.js";
54
+ export {
55
+ createFromInsertable,
56
+ cursorFromInsertable,
57
+ createFromCursor,
58
+ createFromMapTree,
59
+ } from "./create.js";
49
60
  export {
50
61
  type JsonSchemaId,
51
62
  type JsonSchemaType,
@@ -107,7 +118,6 @@ export {
107
118
 
108
119
  export {
109
120
  extractPersistedSchema,
110
- comparePersistedSchemaInternal,
111
121
  comparePersistedSchema,
112
122
  } from "./storedSchema.js";
113
123
 
@@ -4,7 +4,6 @@
4
4
  */
5
5
 
6
6
  import type { FluidClientVersion, ICodecOptions } from "../../codec/index.js";
7
- import type { TreeStoredSchema } from "../../core/index.js";
8
7
  import {
9
8
  defaultSchemaPolicy,
10
9
  encodeTreeSchema,
@@ -96,8 +95,7 @@ export function comparePersistedSchema(
96
95
  persisted: JsonCompatible,
97
96
  view: ImplicitFieldSchema,
98
97
  options: ICodecOptions,
99
- canInitialize: boolean,
100
- ): SchemaCompatibilityStatus {
98
+ ): Omit<SchemaCompatibilityStatus, "canInitialize"> {
101
99
  // Any version can be passed down to makeSchemaCodec here.
102
100
  // We only use the decode part, which always dispatches to the correct codec based on the version in the data, not the version passed to `makeSchemaCodec`.
103
101
  const schemaCodec = makeSchemaCodec(options, SchemaCodecVersion.v1);
@@ -107,20 +105,5 @@ export function comparePersistedSchema(
107
105
  {},
108
106
  normalizeFieldSchema(view),
109
107
  );
110
- return comparePersistedSchemaInternal(stored, viewSchema, canInitialize);
111
- }
112
-
113
- /**
114
- * Compute compatibility for viewing a document with `stored` schema using `viewSchema`.
115
- * `canInitialize` is passed through to the return value unchanged and otherwise unused.
116
- */
117
- export function comparePersistedSchemaInternal(
118
- stored: TreeStoredSchema,
119
- viewSchema: SchemaCompatibilityTester,
120
- canInitialize: boolean,
121
- ): SchemaCompatibilityStatus {
122
- return {
123
- ...viewSchema.checkCompatibility(stored),
124
- canInitialize,
125
- };
108
+ return viewSchema.checkCompatibility(stored);
126
109
  }
@@ -288,7 +288,7 @@ export function tryGetSchema(value: unknown): undefined | TreeNodeSchema {
288
288
  /**
289
289
  * Gets the stored key with which the provided node is associated in the parent.
290
290
  */
291
- function getStoredKey(node: TreeNode): string | number {
291
+ export function getStoredKey(node: TreeNode): string | number {
292
292
  // Note: the flex domain strictly works with "stored keys", and knows nothing about the developer-facing
293
293
  // "property keys".
294
294
  const parentField = getOrCreateInnerNode(node).parentField;
@@ -309,7 +309,7 @@ function getStoredKey(node: TreeNode): string | number {
309
309
  /**
310
310
  * Given a node schema, gets the property key corresponding with the provided {@link FieldProps.key | stored key}.
311
311
  */
312
- function getPropertyKeyFromStoredKey(
312
+ export function getPropertyKeyFromStoredKey(
313
313
  schema: TreeNodeSchema,
314
314
  storedKey: string | number,
315
315
  ): string | number {