@fluidframework/tree 2.5.0-302463 → 2.10.0-304831

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 (378) hide show
  1. package/.vscode/settings.json +1 -0
  2. package/CHANGELOG.md +371 -0
  3. package/api-report/tree.alpha.api.md +161 -69
  4. package/api-report/tree.beta.api.md +36 -37
  5. package/api-report/tree.legacy.alpha.api.md +35 -36
  6. package/api-report/tree.legacy.public.api.md +35 -36
  7. package/api-report/tree.public.api.md +35 -36
  8. package/dist/alpha.d.ts +15 -0
  9. package/dist/codec/codec.d.ts +24 -0
  10. package/dist/codec/codec.d.ts.map +1 -1
  11. package/dist/codec/codec.js +26 -1
  12. package/dist/codec/codec.js.map +1 -1
  13. package/dist/codec/index.d.ts +1 -1
  14. package/dist/codec/index.d.ts.map +1 -1
  15. package/dist/codec/index.js +2 -1
  16. package/dist/codec/index.js.map +1 -1
  17. package/dist/core/rebase/index.d.ts +2 -2
  18. package/dist/core/rebase/index.d.ts.map +1 -1
  19. package/dist/core/rebase/index.js +2 -2
  20. package/dist/core/rebase/index.js.map +1 -1
  21. package/dist/core/rebase/types.d.ts +3 -7
  22. package/dist/core/rebase/types.d.ts.map +1 -1
  23. package/dist/core/rebase/types.js +4 -10
  24. package/dist/core/rebase/types.js.map +1 -1
  25. package/dist/core/rebase/utils.d.ts +1 -0
  26. package/dist/core/rebase/utils.d.ts.map +1 -1
  27. package/dist/core/rebase/utils.js +29 -4
  28. package/dist/core/rebase/utils.js.map +1 -1
  29. package/dist/core/revertible.d.ts +1 -1
  30. package/dist/core/revertible.js.map +1 -1
  31. package/dist/feature-libraries/flex-tree/flexTreeTypes.d.ts +8 -1
  32. package/dist/feature-libraries/flex-tree/flexTreeTypes.d.ts.map +1 -1
  33. package/dist/feature-libraries/flex-tree/flexTreeTypes.js.map +1 -1
  34. package/dist/feature-libraries/flex-tree/lazyNode.d.ts +2 -1
  35. package/dist/feature-libraries/flex-tree/lazyNode.d.ts.map +1 -1
  36. package/dist/feature-libraries/flex-tree/lazyNode.js +3 -0
  37. package/dist/feature-libraries/flex-tree/lazyNode.js.map +1 -1
  38. package/dist/index.d.ts +3 -3
  39. package/dist/index.d.ts.map +1 -1
  40. package/dist/index.js +12 -6
  41. package/dist/index.js.map +1 -1
  42. package/dist/internalTypes.d.ts +1 -1
  43. package/dist/internalTypes.d.ts.map +1 -1
  44. package/dist/internalTypes.js.map +1 -1
  45. package/dist/packageVersion.d.ts +1 -1
  46. package/dist/packageVersion.d.ts.map +1 -1
  47. package/dist/packageVersion.js +1 -1
  48. package/dist/packageVersion.js.map +1 -1
  49. package/dist/shared-tree/independentView.d.ts +57 -0
  50. package/dist/shared-tree/independentView.d.ts.map +1 -0
  51. package/dist/shared-tree/independentView.js +89 -0
  52. package/dist/shared-tree/independentView.js.map +1 -0
  53. package/dist/shared-tree/index.d.ts +3 -1
  54. package/dist/shared-tree/index.d.ts.map +1 -1
  55. package/dist/shared-tree/index.js +6 -1
  56. package/dist/shared-tree/index.js.map +1 -1
  57. package/dist/shared-tree/schematizingTreeView.d.ts +13 -9
  58. package/dist/shared-tree/schematizingTreeView.d.ts.map +1 -1
  59. package/dist/shared-tree/schematizingTreeView.js +32 -1
  60. package/dist/shared-tree/schematizingTreeView.js.map +1 -1
  61. package/dist/shared-tree/sharedTree.d.ts +10 -7
  62. package/dist/shared-tree/sharedTree.d.ts.map +1 -1
  63. package/dist/shared-tree/sharedTree.js.map +1 -1
  64. package/dist/shared-tree/treeApiAlpha.d.ts +147 -0
  65. package/dist/shared-tree/treeApiAlpha.d.ts.map +1 -0
  66. package/dist/shared-tree/treeApiAlpha.js +122 -0
  67. package/dist/shared-tree/treeApiAlpha.js.map +1 -0
  68. package/dist/shared-tree/treeCheckout.d.ts +19 -17
  69. package/dist/shared-tree/treeCheckout.d.ts.map +1 -1
  70. package/dist/shared-tree/treeCheckout.js +16 -7
  71. package/dist/shared-tree/treeCheckout.js.map +1 -1
  72. package/dist/shared-tree-core/editManager.d.ts +13 -6
  73. package/dist/shared-tree-core/editManager.d.ts.map +1 -1
  74. package/dist/shared-tree-core/editManager.js +70 -28
  75. package/dist/shared-tree-core/editManager.js.map +1 -1
  76. package/dist/shared-tree-core/sharedTreeCore.d.ts +1 -0
  77. package/dist/shared-tree-core/sharedTreeCore.d.ts.map +1 -1
  78. package/dist/shared-tree-core/sharedTreeCore.js +28 -3
  79. package/dist/shared-tree-core/sharedTreeCore.js.map +1 -1
  80. package/dist/simple-tree/api/conciseTree.d.ts +2 -1
  81. package/dist/simple-tree/api/conciseTree.d.ts.map +1 -1
  82. package/dist/simple-tree/api/conciseTree.js.map +1 -1
  83. package/dist/simple-tree/api/create.d.ts +5 -23
  84. package/dist/simple-tree/api/create.d.ts.map +1 -1
  85. package/dist/simple-tree/api/create.js +4 -19
  86. package/dist/simple-tree/api/create.js.map +1 -1
  87. package/dist/simple-tree/api/customTree.d.ts +1 -0
  88. package/dist/simple-tree/api/customTree.d.ts.map +1 -1
  89. package/dist/simple-tree/api/customTree.js.map +1 -1
  90. package/dist/simple-tree/api/index.d.ts +5 -5
  91. package/dist/simple-tree/api/index.d.ts.map +1 -1
  92. package/dist/simple-tree/api/index.js +10 -1
  93. package/dist/simple-tree/api/index.js.map +1 -1
  94. package/dist/simple-tree/api/schemaCreationUtilities.d.ts +6 -16
  95. package/dist/simple-tree/api/schemaCreationUtilities.d.ts.map +1 -1
  96. package/dist/simple-tree/api/schemaCreationUtilities.js.map +1 -1
  97. package/dist/simple-tree/api/schemaFactory.d.ts +11 -11
  98. package/dist/simple-tree/api/schemaFactory.d.ts.map +1 -1
  99. package/dist/simple-tree/api/schemaFactory.js.map +1 -1
  100. package/dist/simple-tree/api/storedSchema.js +2 -2
  101. package/dist/simple-tree/api/storedSchema.js.map +1 -1
  102. package/dist/simple-tree/api/testRecursiveDomain.d.ts +5 -5
  103. package/dist/simple-tree/api/tree.d.ts +125 -7
  104. package/dist/simple-tree/api/tree.d.ts.map +1 -1
  105. package/dist/simple-tree/api/tree.js +12 -4
  106. package/dist/simple-tree/api/tree.js.map +1 -1
  107. package/dist/simple-tree/api/treeApiBeta.d.ts +8 -5
  108. package/dist/simple-tree/api/treeApiBeta.d.ts.map +1 -1
  109. package/dist/simple-tree/api/treeApiBeta.js +3 -15
  110. package/dist/simple-tree/api/treeApiBeta.js.map +1 -1
  111. package/dist/simple-tree/api/typesUnsafe.d.ts +3 -3
  112. package/dist/simple-tree/api/typesUnsafe.d.ts.map +1 -1
  113. package/dist/simple-tree/api/typesUnsafe.js.map +1 -1
  114. package/dist/simple-tree/api/verboseTree.d.ts +3 -0
  115. package/dist/simple-tree/api/verboseTree.d.ts.map +1 -1
  116. package/dist/simple-tree/api/verboseTree.js.map +1 -1
  117. package/dist/simple-tree/arrayNode.d.ts +9 -15
  118. package/dist/simple-tree/arrayNode.d.ts.map +1 -1
  119. package/dist/simple-tree/arrayNode.js +1 -1
  120. package/dist/simple-tree/arrayNode.js.map +1 -1
  121. package/dist/simple-tree/core/getOrCreateNode.js.map +1 -1
  122. package/dist/simple-tree/core/treeNodeSchema.d.ts +45 -9
  123. package/dist/simple-tree/core/treeNodeSchema.d.ts.map +1 -1
  124. package/dist/simple-tree/core/treeNodeSchema.js.map +1 -1
  125. package/dist/simple-tree/core/unhydratedFlexTree.d.ts +2 -1
  126. package/dist/simple-tree/core/unhydratedFlexTree.d.ts.map +1 -1
  127. package/dist/simple-tree/core/unhydratedFlexTree.js +3 -0
  128. package/dist/simple-tree/core/unhydratedFlexTree.js.map +1 -1
  129. package/dist/simple-tree/core/withType.d.ts +1 -2
  130. package/dist/simple-tree/core/withType.d.ts.map +1 -1
  131. package/dist/simple-tree/core/withType.js.map +1 -1
  132. package/dist/simple-tree/createContext.js +2 -2
  133. package/dist/simple-tree/createContext.js.map +1 -1
  134. package/dist/simple-tree/index.d.ts +5 -5
  135. package/dist/simple-tree/index.d.ts.map +1 -1
  136. package/dist/simple-tree/index.js +15 -4
  137. package/dist/simple-tree/index.js.map +1 -1
  138. package/dist/simple-tree/leafNodeSchema.d.ts +6 -5
  139. package/dist/simple-tree/leafNodeSchema.d.ts.map +1 -1
  140. package/dist/simple-tree/leafNodeSchema.js +3 -0
  141. package/dist/simple-tree/leafNodeSchema.js.map +1 -1
  142. package/dist/simple-tree/mapNode.d.ts +1 -1
  143. package/dist/simple-tree/mapNode.d.ts.map +1 -1
  144. package/dist/simple-tree/mapNode.js +3 -0
  145. package/dist/simple-tree/mapNode.js.map +1 -1
  146. package/dist/simple-tree/schemaTypes.d.ts +45 -7
  147. package/dist/simple-tree/schemaTypes.d.ts.map +1 -1
  148. package/dist/simple-tree/schemaTypes.js +61 -1
  149. package/dist/simple-tree/schemaTypes.js.map +1 -1
  150. package/dist/simple-tree/{toFlexSchema.d.ts → toStoredSchema.d.ts} +1 -1
  151. package/dist/simple-tree/toStoredSchema.d.ts.map +1 -0
  152. package/dist/simple-tree/{toFlexSchema.js → toStoredSchema.js} +1 -1
  153. package/dist/simple-tree/toStoredSchema.js.map +1 -0
  154. package/dist/simple-tree/treeNodeValid.d.ts +5 -1
  155. package/dist/simple-tree/treeNodeValid.d.ts.map +1 -1
  156. package/dist/simple-tree/treeNodeValid.js +7 -1
  157. package/dist/simple-tree/treeNodeValid.js.map +1 -1
  158. package/dist/util/index.d.ts +1 -1
  159. package/dist/util/index.d.ts.map +1 -1
  160. package/dist/util/index.js.map +1 -1
  161. package/dist/util/typeCheck.d.ts +9 -0
  162. package/dist/util/typeCheck.d.ts.map +1 -1
  163. package/dist/util/typeCheck.js.map +1 -1
  164. package/dist/util/utils.d.ts +7 -3
  165. package/dist/util/utils.d.ts.map +1 -1
  166. package/dist/util/utils.js +13 -3
  167. package/dist/util/utils.js.map +1 -1
  168. package/lib/alpha.d.ts +15 -0
  169. package/lib/codec/codec.d.ts +24 -0
  170. package/lib/codec/codec.d.ts.map +1 -1
  171. package/lib/codec/codec.js +25 -0
  172. package/lib/codec/codec.js.map +1 -1
  173. package/lib/codec/index.d.ts +1 -1
  174. package/lib/codec/index.d.ts.map +1 -1
  175. package/lib/codec/index.js +1 -1
  176. package/lib/codec/index.js.map +1 -1
  177. package/lib/core/rebase/index.d.ts +2 -2
  178. package/lib/core/rebase/index.d.ts.map +1 -1
  179. package/lib/core/rebase/index.js +2 -2
  180. package/lib/core/rebase/index.js.map +1 -1
  181. package/lib/core/rebase/types.d.ts +3 -7
  182. package/lib/core/rebase/types.d.ts.map +1 -1
  183. package/lib/core/rebase/types.js +3 -8
  184. package/lib/core/rebase/types.js.map +1 -1
  185. package/lib/core/rebase/utils.d.ts +1 -0
  186. package/lib/core/rebase/utils.d.ts.map +1 -1
  187. package/lib/core/rebase/utils.js +27 -3
  188. package/lib/core/rebase/utils.js.map +1 -1
  189. package/lib/core/revertible.d.ts +1 -1
  190. package/lib/core/revertible.js.map +1 -1
  191. package/lib/feature-libraries/flex-tree/flexTreeTypes.d.ts +8 -1
  192. package/lib/feature-libraries/flex-tree/flexTreeTypes.d.ts.map +1 -1
  193. package/lib/feature-libraries/flex-tree/flexTreeTypes.js.map +1 -1
  194. package/lib/feature-libraries/flex-tree/lazyNode.d.ts +2 -1
  195. package/lib/feature-libraries/flex-tree/lazyNode.d.ts.map +1 -1
  196. package/lib/feature-libraries/flex-tree/lazyNode.js +3 -0
  197. package/lib/feature-libraries/flex-tree/lazyNode.js.map +1 -1
  198. package/lib/index.d.ts +3 -3
  199. package/lib/index.d.ts.map +1 -1
  200. package/lib/index.js +3 -2
  201. package/lib/index.js.map +1 -1
  202. package/lib/internalTypes.d.ts +1 -1
  203. package/lib/internalTypes.d.ts.map +1 -1
  204. package/lib/internalTypes.js.map +1 -1
  205. package/lib/packageVersion.d.ts +1 -1
  206. package/lib/packageVersion.d.ts.map +1 -1
  207. package/lib/packageVersion.js +1 -1
  208. package/lib/packageVersion.js.map +1 -1
  209. package/lib/shared-tree/independentView.d.ts +57 -0
  210. package/lib/shared-tree/independentView.d.ts.map +1 -0
  211. package/lib/shared-tree/independentView.js +84 -0
  212. package/lib/shared-tree/independentView.js.map +1 -0
  213. package/lib/shared-tree/index.d.ts +3 -1
  214. package/lib/shared-tree/index.d.ts.map +1 -1
  215. package/lib/shared-tree/index.js +2 -0
  216. package/lib/shared-tree/index.js.map +1 -1
  217. package/lib/shared-tree/schematizingTreeView.d.ts +13 -9
  218. package/lib/shared-tree/schematizingTreeView.d.ts.map +1 -1
  219. package/lib/shared-tree/schematizingTreeView.js +33 -2
  220. package/lib/shared-tree/schematizingTreeView.js.map +1 -1
  221. package/lib/shared-tree/sharedTree.d.ts +10 -7
  222. package/lib/shared-tree/sharedTree.d.ts.map +1 -1
  223. package/lib/shared-tree/sharedTree.js.map +1 -1
  224. package/lib/shared-tree/treeApiAlpha.d.ts +147 -0
  225. package/lib/shared-tree/treeApiAlpha.d.ts.map +1 -0
  226. package/lib/shared-tree/treeApiAlpha.js +119 -0
  227. package/lib/shared-tree/treeApiAlpha.js.map +1 -0
  228. package/lib/shared-tree/treeCheckout.d.ts +19 -17
  229. package/lib/shared-tree/treeCheckout.d.ts.map +1 -1
  230. package/lib/shared-tree/treeCheckout.js +16 -7
  231. package/lib/shared-tree/treeCheckout.js.map +1 -1
  232. package/lib/shared-tree-core/editManager.d.ts +13 -6
  233. package/lib/shared-tree-core/editManager.d.ts.map +1 -1
  234. package/lib/shared-tree-core/editManager.js +70 -28
  235. package/lib/shared-tree-core/editManager.js.map +1 -1
  236. package/lib/shared-tree-core/sharedTreeCore.d.ts +1 -0
  237. package/lib/shared-tree-core/sharedTreeCore.d.ts.map +1 -1
  238. package/lib/shared-tree-core/sharedTreeCore.js +29 -4
  239. package/lib/shared-tree-core/sharedTreeCore.js.map +1 -1
  240. package/lib/simple-tree/api/conciseTree.d.ts +2 -1
  241. package/lib/simple-tree/api/conciseTree.d.ts.map +1 -1
  242. package/lib/simple-tree/api/conciseTree.js.map +1 -1
  243. package/lib/simple-tree/api/create.d.ts +5 -23
  244. package/lib/simple-tree/api/create.d.ts.map +1 -1
  245. package/lib/simple-tree/api/create.js +2 -16
  246. package/lib/simple-tree/api/create.js.map +1 -1
  247. package/lib/simple-tree/api/customTree.d.ts +1 -0
  248. package/lib/simple-tree/api/customTree.d.ts.map +1 -1
  249. package/lib/simple-tree/api/customTree.js.map +1 -1
  250. package/lib/simple-tree/api/index.d.ts +5 -5
  251. package/lib/simple-tree/api/index.d.ts.map +1 -1
  252. package/lib/simple-tree/api/index.js +5 -3
  253. package/lib/simple-tree/api/index.js.map +1 -1
  254. package/lib/simple-tree/api/schemaCreationUtilities.d.ts +6 -16
  255. package/lib/simple-tree/api/schemaCreationUtilities.d.ts.map +1 -1
  256. package/lib/simple-tree/api/schemaCreationUtilities.js.map +1 -1
  257. package/lib/simple-tree/api/schemaFactory.d.ts +11 -11
  258. package/lib/simple-tree/api/schemaFactory.d.ts.map +1 -1
  259. package/lib/simple-tree/api/schemaFactory.js.map +1 -1
  260. package/lib/simple-tree/api/storedSchema.js +1 -1
  261. package/lib/simple-tree/api/storedSchema.js.map +1 -1
  262. package/lib/simple-tree/api/testRecursiveDomain.d.ts +5 -5
  263. package/lib/simple-tree/api/tree.d.ts +125 -7
  264. package/lib/simple-tree/api/tree.d.ts.map +1 -1
  265. package/lib/simple-tree/api/tree.js +9 -2
  266. package/lib/simple-tree/api/tree.js.map +1 -1
  267. package/lib/simple-tree/api/treeApiBeta.d.ts +8 -5
  268. package/lib/simple-tree/api/treeApiBeta.d.ts.map +1 -1
  269. package/lib/simple-tree/api/treeApiBeta.js +4 -16
  270. package/lib/simple-tree/api/treeApiBeta.js.map +1 -1
  271. package/lib/simple-tree/api/typesUnsafe.d.ts +3 -3
  272. package/lib/simple-tree/api/typesUnsafe.d.ts.map +1 -1
  273. package/lib/simple-tree/api/typesUnsafe.js.map +1 -1
  274. package/lib/simple-tree/api/verboseTree.d.ts +3 -0
  275. package/lib/simple-tree/api/verboseTree.d.ts.map +1 -1
  276. package/lib/simple-tree/api/verboseTree.js.map +1 -1
  277. package/lib/simple-tree/arrayNode.d.ts +9 -15
  278. package/lib/simple-tree/arrayNode.d.ts.map +1 -1
  279. package/lib/simple-tree/arrayNode.js +1 -1
  280. package/lib/simple-tree/arrayNode.js.map +1 -1
  281. package/lib/simple-tree/core/getOrCreateNode.js.map +1 -1
  282. package/lib/simple-tree/core/treeNodeSchema.d.ts +45 -9
  283. package/lib/simple-tree/core/treeNodeSchema.d.ts.map +1 -1
  284. package/lib/simple-tree/core/treeNodeSchema.js.map +1 -1
  285. package/lib/simple-tree/core/unhydratedFlexTree.d.ts +2 -1
  286. package/lib/simple-tree/core/unhydratedFlexTree.d.ts.map +1 -1
  287. package/lib/simple-tree/core/unhydratedFlexTree.js +4 -1
  288. package/lib/simple-tree/core/unhydratedFlexTree.js.map +1 -1
  289. package/lib/simple-tree/core/withType.d.ts +1 -2
  290. package/lib/simple-tree/core/withType.d.ts.map +1 -1
  291. package/lib/simple-tree/core/withType.js.map +1 -1
  292. package/lib/simple-tree/createContext.js +1 -1
  293. package/lib/simple-tree/createContext.js.map +1 -1
  294. package/lib/simple-tree/index.d.ts +5 -5
  295. package/lib/simple-tree/index.d.ts.map +1 -1
  296. package/lib/simple-tree/index.js +4 -4
  297. package/lib/simple-tree/index.js.map +1 -1
  298. package/lib/simple-tree/leafNodeSchema.d.ts +6 -5
  299. package/lib/simple-tree/leafNodeSchema.d.ts.map +1 -1
  300. package/lib/simple-tree/leafNodeSchema.js +3 -0
  301. package/lib/simple-tree/leafNodeSchema.js.map +1 -1
  302. package/lib/simple-tree/mapNode.d.ts +1 -1
  303. package/lib/simple-tree/mapNode.d.ts.map +1 -1
  304. package/lib/simple-tree/mapNode.js +3 -0
  305. package/lib/simple-tree/mapNode.js.map +1 -1
  306. package/lib/simple-tree/schemaTypes.d.ts +45 -7
  307. package/lib/simple-tree/schemaTypes.d.ts.map +1 -1
  308. package/lib/simple-tree/schemaTypes.js +59 -1
  309. package/lib/simple-tree/schemaTypes.js.map +1 -1
  310. package/lib/simple-tree/{toFlexSchema.d.ts → toStoredSchema.d.ts} +1 -1
  311. package/lib/simple-tree/toStoredSchema.d.ts.map +1 -0
  312. package/lib/simple-tree/{toFlexSchema.js → toStoredSchema.js} +1 -1
  313. package/lib/simple-tree/toStoredSchema.js.map +1 -0
  314. package/lib/simple-tree/treeNodeValid.d.ts +5 -1
  315. package/lib/simple-tree/treeNodeValid.d.ts.map +1 -1
  316. package/lib/simple-tree/treeNodeValid.js +7 -1
  317. package/lib/simple-tree/treeNodeValid.js.map +1 -1
  318. package/lib/util/index.d.ts +1 -1
  319. package/lib/util/index.d.ts.map +1 -1
  320. package/lib/util/index.js.map +1 -1
  321. package/lib/util/typeCheck.d.ts +9 -0
  322. package/lib/util/typeCheck.d.ts.map +1 -1
  323. package/lib/util/typeCheck.js.map +1 -1
  324. package/lib/util/utils.d.ts +7 -3
  325. package/lib/util/utils.d.ts.map +1 -1
  326. package/lib/util/utils.js +13 -3
  327. package/lib/util/utils.js.map +1 -1
  328. package/package.json +26 -53
  329. package/src/codec/codec.ts +25 -0
  330. package/src/codec/index.ts +1 -0
  331. package/src/core/rebase/index.ts +1 -1
  332. package/src/core/rebase/types.ts +3 -15
  333. package/src/core/rebase/utils.ts +35 -3
  334. package/src/core/revertible.ts +1 -1
  335. package/src/feature-libraries/flex-tree/flexTreeTypes.ts +9 -0
  336. package/src/feature-libraries/flex-tree/lazyNode.ts +5 -0
  337. package/src/index.ts +20 -5
  338. package/src/internalTypes.ts +0 -1
  339. package/src/packageVersion.ts +1 -1
  340. package/src/shared-tree/independentView.ts +176 -0
  341. package/src/shared-tree/index.ts +9 -1
  342. package/src/shared-tree/schematizingTreeView.ts +66 -17
  343. package/src/shared-tree/sharedTree.ts +29 -11
  344. package/src/shared-tree/treeApiAlpha.ts +401 -0
  345. package/src/shared-tree/treeCheckout.ts +39 -19
  346. package/src/shared-tree-core/editManager.ts +112 -54
  347. package/src/shared-tree-core/sharedTreeCore.ts +37 -8
  348. package/src/simple-tree/api/conciseTree.ts +2 -1
  349. package/src/simple-tree/api/create.ts +21 -58
  350. package/src/simple-tree/api/customTree.ts +1 -0
  351. package/src/simple-tree/api/index.ts +13 -7
  352. package/src/simple-tree/api/schemaCreationUtilities.ts +4 -5
  353. package/src/simple-tree/api/schemaFactory.ts +24 -12
  354. package/src/simple-tree/api/storedSchema.ts +1 -1
  355. package/src/simple-tree/api/tree.ts +148 -14
  356. package/src/simple-tree/api/treeApiBeta.ts +35 -35
  357. package/src/simple-tree/api/typesUnsafe.ts +4 -4
  358. package/src/simple-tree/api/verboseTree.ts +3 -0
  359. package/src/simple-tree/arrayNode.ts +21 -23
  360. package/src/simple-tree/core/getOrCreateNode.ts +1 -1
  361. package/src/simple-tree/core/treeNodeSchema.ts +99 -31
  362. package/src/simple-tree/core/unhydratedFlexTree.ts +6 -0
  363. package/src/simple-tree/core/withType.ts +1 -9
  364. package/src/simple-tree/createContext.ts +1 -1
  365. package/src/simple-tree/index.ts +15 -2
  366. package/src/simple-tree/leafNodeSchema.ts +6 -1
  367. package/src/simple-tree/mapNode.ts +7 -1
  368. package/src/simple-tree/schemaTypes.ts +128 -14
  369. package/src/simple-tree/treeNodeValid.ts +11 -1
  370. package/src/util/index.ts +1 -0
  371. package/src/util/typeCheck.ts +13 -0
  372. package/src/util/utils.ts +20 -7
  373. package/dist/simple-tree/toFlexSchema.d.ts.map +0 -1
  374. package/dist/simple-tree/toFlexSchema.js.map +0 -1
  375. package/lib/simple-tree/toFlexSchema.d.ts.map +0 -1
  376. package/lib/simple-tree/toFlexSchema.js.map +0 -1
  377. /package/docs/{main → user-facing}/merge-semantics.md +0 -0
  378. /package/src/simple-tree/{toFlexSchema.ts → toStoredSchema.ts} +0 -0
@@ -167,7 +167,6 @@ declare namespace InternalTypes {
167
167
  ApplyKindInput,
168
168
  NodeBuilderData,
169
169
  FieldHasDefault,
170
- TreeArrayNodeBase,
171
170
  ScopedSchemaName,
172
171
  DefaultProvider,
173
172
  typeNameSymbol,
@@ -242,7 +241,7 @@ export interface MakeNominal {
242
241
  export type MapNodeInsertableData<T extends ImplicitAllowedTypes> = Iterable<readonly [string, InsertableTreeNodeFromImplicitAllowedTypes<T>]> | RestrictiveStringRecord<InsertableTreeNodeFromImplicitAllowedTypes<T>>;
243
242
 
244
243
  // @public
245
- type NodeBuilderData<T extends TreeNodeSchema> = T extends TreeNodeSchema<string, NodeKind, TreeNode | TreeLeafValue, infer TBuild> ? TBuild : never;
244
+ type NodeBuilderData<T extends TreeNodeSchemaCore<string, NodeKind, boolean>> = T extends TreeNodeSchemaCore<string, NodeKind, boolean, unknown, infer TBuild> ? TBuild : never;
246
245
 
247
246
  // @public
248
247
  type NodeBuilderDataUnsafe<T extends Unenforced<TreeNodeSchema>> = T extends TreeNodeSchemaUnsafe<string, NodeKind, unknown, infer TBuild> ? TBuild : never;
@@ -362,24 +361,24 @@ export interface SchemaCompatibilityStatus {
362
361
  // @public @sealed
363
362
  export class SchemaFactory<out TScope extends string | undefined = string | undefined, TName extends number | string = string> {
364
363
  constructor(scope: TScope);
365
- array<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T>;
366
- array<const Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T>;
364
+ array<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T, undefined>;
365
+ array<const Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T, undefined>;
367
366
  arrayRecursive<const Name extends TName, const T extends Unenforced<ImplicitAllowedTypes>>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Array, TreeArrayNodeUnsafe<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Array, unknown>, {
368
367
  [Symbol.iterator](): Iterator<InsertableTreeNodeFromImplicitAllowedTypesUnsafe<T>>;
369
- }, false, T>;
370
- readonly boolean: TreeNodeSchema<"com.fluidframework.leaf.boolean", NodeKind.Leaf, boolean, boolean>;
371
- readonly handle: TreeNodeSchema<"com.fluidframework.leaf.handle", NodeKind.Leaf, IFluidHandle<unknown>, IFluidHandle<unknown>>;
368
+ }, false, T, undefined>;
369
+ readonly boolean: TreeNodeSchemaNonClass<"com.fluidframework.leaf.boolean", NodeKind.Leaf, boolean, boolean, true, unknown, never>;
370
+ readonly handle: TreeNodeSchemaNonClass<"com.fluidframework.leaf.handle", NodeKind.Leaf, IFluidHandle<unknown>, IFluidHandle<unknown>, true, unknown, never>;
372
371
  get identifier(): FieldSchema<FieldKind.Identifier, typeof SchemaFactory.string>;
373
- map<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map>, MapNodeInsertableData<T>, true, T>;
374
- map<Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Map>, MapNodeInsertableData<T>, true, T>;
372
+ map<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map>, MapNodeInsertableData<T>, true, T, undefined>;
373
+ map<Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Map>, MapNodeInsertableData<T>, true, T, undefined>;
375
374
  mapRecursive<Name extends TName, const T extends Unenforced<ImplicitAllowedTypes>>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Map, TreeMapNodeUnsafe<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Map, unknown>, {
376
375
  [Symbol.iterator](): Iterator<[
377
376
  string,
378
377
  InsertableTreeNodeFromImplicitAllowedTypesUnsafe<T>
379
378
  ]>;
380
- }, false, T>;
381
- readonly null: TreeNodeSchema<"com.fluidframework.leaf.null", NodeKind.Leaf, null, null>;
382
- readonly number: TreeNodeSchema<"com.fluidframework.leaf.number", NodeKind.Leaf, number, number>;
379
+ }, false, T, undefined>;
380
+ readonly null: TreeNodeSchemaNonClass<"com.fluidframework.leaf.null", NodeKind.Leaf, null, null, true, unknown, never>;
381
+ readonly number: TreeNodeSchemaNonClass<"com.fluidframework.leaf.number", NodeKind.Leaf, number, number, true, unknown, never>;
383
382
  object<const Name extends TName, const T extends RestrictiveStringRecord<ImplicitFieldSchema>>(name: Name, fields: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Object, TreeObjectNode<T, ScopedSchemaName<TScope, Name>>, object & InsertableObjectFromSchemaRecord<T>, true, T>;
384
383
  objectRecursive<const Name extends TName, const T extends Unenforced<RestrictiveStringRecord<ImplicitFieldSchema>>>(name: Name, t: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Object, TreeObjectNodeUnsafe<T, ScopedSchemaName<TScope, Name>>, object & { readonly [Property in keyof T as FieldHasDefaultUnsafe<T[Property]> extends false ? Property : never]: InsertableTreeFieldFromImplicitFieldUnsafe<T[Property], UnionToIntersection_2<T[Property]>>; } & { readonly [Property_1 in keyof T as FieldHasDefaultUnsafe<T[Property_1]> extends true ? Property_1 : never]?: InsertableTreeFieldFromImplicitFieldUnsafe<T[Property_1], UnionToIntersection_2<T[Property_1]>> | undefined; }, false, T>;
385
384
  optional<const T extends ImplicitAllowedTypes, const TCustomMetadata = unknown>(t: T, props?: Omit<FieldProps<TCustomMetadata>, "defaultProvider">): FieldSchema<FieldKind.Optional, T, TCustomMetadata>;
@@ -388,7 +387,7 @@ export class SchemaFactory<out TScope extends string | undefined = string | unde
388
387
  requiredRecursive<const T extends Unenforced<ImplicitAllowedTypes>>(t: T, props?: Omit<FieldProps, "defaultProvider">): FieldSchemaUnsafe<FieldKind.Required, T>;
389
388
  // (undocumented)
390
389
  readonly scope: TScope;
391
- readonly string: TreeNodeSchema<"com.fluidframework.leaf.string", NodeKind.Leaf, string, string>;
390
+ readonly string: TreeNodeSchemaNonClass<"com.fluidframework.leaf.string", NodeKind.Leaf, string, string, true, unknown, never>;
392
391
  }
393
392
 
394
393
  // @public
@@ -410,16 +409,7 @@ interface TreeApi extends TreeNodeApi {
410
409
  }
411
410
 
412
411
  // @public @sealed
413
- export interface TreeArrayNode<TAllowedTypes extends ImplicitAllowedTypes = ImplicitAllowedTypes> extends TreeArrayNodeBase<TreeNodeFromImplicitAllowedTypes<TAllowedTypes>, InsertableTreeNodeFromImplicitAllowedTypes<TAllowedTypes>> {
414
- }
415
-
416
- // @public
417
- export const TreeArrayNode: {
418
- readonly spread: <T>(content: Iterable<T>) => IterableTreeArrayContent<T>;
419
- };
420
-
421
- // @public @sealed
422
- interface TreeArrayNodeBase<out T, in TNew, in TMoveFrom = ReadonlyArrayNode> extends ReadonlyArrayNode<T> {
412
+ export interface TreeArrayNode<TAllowedTypes extends Unenforced<ImplicitAllowedTypes> = ImplicitAllowedTypes, out T = [TAllowedTypes] extends [ImplicitAllowedTypes] ? TreeNodeFromImplicitAllowedTypes<TAllowedTypes> : TreeNodeFromImplicitAllowedTypes<ImplicitAllowedTypes>, in TNew = [TAllowedTypes] extends [ImplicitAllowedTypes] ? InsertableTreeNodeFromImplicitAllowedTypes<TAllowedTypes> : InsertableTreeNodeFromImplicitAllowedTypes<ImplicitAllowedTypes>, in TMoveFrom = ReadonlyArrayNode> extends ReadonlyArrayNode<T> {
423
413
  insertAt(index: number, ...value: readonly (TNew | IterableTreeArrayContent<TNew>)[]): void;
424
414
  insertAtEnd(...value: readonly (TNew | IterableTreeArrayContent<TNew>)[]): void;
425
415
  insertAtStart(...value: readonly (TNew | IterableTreeArrayContent<TNew>)[]): void;
@@ -440,8 +430,13 @@ interface TreeArrayNodeBase<out T, in TNew, in TMoveFrom = ReadonlyArrayNode> ex
440
430
  values(): IterableIterator<T>;
441
431
  }
442
432
 
433
+ // @public
434
+ export const TreeArrayNode: {
435
+ readonly spread: <T>(content: Iterable<T>) => IterableTreeArrayContent<T>;
436
+ };
437
+
443
438
  // @public @sealed
444
- export interface TreeArrayNodeUnsafe<TAllowedTypes extends Unenforced<ImplicitAllowedTypes>> extends TreeArrayNodeBase<TreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>, InsertableTreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>> {
439
+ export interface TreeArrayNodeUnsafe<TAllowedTypes extends Unenforced<ImplicitAllowedTypes>> extends TreeArrayNode<TAllowedTypes, TreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>, InsertableTreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>> {
445
440
  }
446
441
 
447
442
  // @public @sealed
@@ -503,23 +498,26 @@ export type TreeNodeFromImplicitAllowedTypes<TSchema extends ImplicitAllowedType
503
498
  type TreeNodeFromImplicitAllowedTypesUnsafe<TSchema extends Unenforced<ImplicitAllowedTypes>> = TSchema extends TreeNodeSchemaUnsafe ? NodeFromSchemaUnsafe<TSchema> : TSchema extends AllowedTypesUnsafe ? NodeFromSchemaUnsafe<FlexListToUnion<TSchema>> : unknown;
504
499
 
505
500
  // @public @sealed
506
- export type TreeNodeSchema<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, TBuild = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown> = TreeNodeSchemaClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info> | TreeNodeSchemaNonClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info>;
501
+ export type TreeNodeSchema<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, TBuild = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown> = (TNode extends TreeNode ? TreeNodeSchemaClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info> : never) | TreeNodeSchemaNonClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info>;
507
502
 
508
503
  // @public @sealed
509
- export interface TreeNodeSchemaClass<out Name extends string = string, out Kind extends NodeKind = NodeKind, out TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, in TInsertable = never, out ImplicitlyConstructable extends boolean = boolean, out Info = unknown> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
510
- // @sealed
511
- new (data: TInsertable | InternalTreeNode): Unhydrated<TNode>;
512
- }
504
+ export type TreeNodeSchemaClass<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode = TreeNode, TInsertable = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown, TConstructorExtra = never> = TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info, TInsertable> & (undefined extends TConstructorExtra ? {
505
+ new (data?: TInsertable | InternalTreeNode | TConstructorExtra): Unhydrated<TNode>;
506
+ } : {
507
+ new (data: TInsertable | InternalTreeNode | TConstructorExtra): Unhydrated<TNode>;
508
+ });
513
509
 
514
510
  // @public
515
- export interface TreeNodeSchemaClassUnsafe<out Name extends string, out Kind extends NodeKind, out TNode extends Unenforced<TreeNode | TreeLeafValue>, in TInsertable, out ImplicitlyConstructable extends boolean, out Info> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
511
+ export interface TreeNodeSchemaClassUnsafe<out Name extends string, out Kind extends NodeKind, out TNode extends Unenforced<TreeNode>, in TInsertable, out ImplicitlyConstructable extends boolean, out Info> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
516
512
  // @sealed
517
513
  new (data: TInsertable | InternalTreeNode): Unhydrated<TNode>;
518
514
  }
519
515
 
520
516
  // @public @sealed
521
- export interface TreeNodeSchemaCore<out Name extends string, out Kind extends NodeKind, out ImplicitlyConstructable extends boolean, out Info = unknown> {
517
+ export interface TreeNodeSchemaCore<out Name extends string, out Kind extends NodeKind, out ImplicitlyConstructable extends boolean, out Info = unknown, out TInsertable = never> {
522
518
  readonly childTypes: ReadonlySet<TreeNodeSchema>;
519
+ // @sealed
520
+ createFromInsertable(data: TInsertable): Unhydrated<TreeNode | TreeLeafValue>;
523
521
  readonly identifier: Name;
524
522
  readonly implicitlyConstructable: ImplicitlyConstructable;
525
523
  readonly info: Info;
@@ -528,10 +526,11 @@ export interface TreeNodeSchemaCore<out Name extends string, out Kind extends No
528
526
  }
529
527
 
530
528
  // @public @sealed
531
- export interface TreeNodeSchemaNonClass<out Name extends string = string, out Kind extends NodeKind = NodeKind, out TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, in TInsertable = never, out ImplicitlyConstructable extends boolean = boolean, out Info = unknown> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
532
- // (undocumented)
533
- create(data: TInsertable): TNode;
534
- }
529
+ export type TreeNodeSchemaNonClass<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, TInsertable = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown, TConstructorExtra = never> = TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info, TInsertable> & (undefined extends TConstructorExtra ? {
530
+ create(data?: TInsertable | TConstructorExtra): TNode;
531
+ } : {
532
+ create(data: TInsertable | TConstructorExtra): TNode;
533
+ });
535
534
 
536
535
  // @public
537
536
  interface TreeNodeSchemaNonClassUnsafe<out Name extends string, out Kind extends NodeKind, out TNode extends Unenforced<TreeNode | TreeLeafValue>, in TInsertable, out ImplicitlyConstructable extends boolean, out Info = unknown> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
@@ -619,7 +618,7 @@ export interface ViewableTree {
619
618
  export interface WithType<out TName extends string = string, out TKind extends NodeKind = NodeKind, out TInfo = unknown> {
620
619
  // @deprecated
621
620
  get [typeNameSymbol](): TName;
622
- get [typeSchemaSymbol](): TreeNodeSchemaClass<TName, TKind, TreeNode | TreeLeafValue, never, boolean, TInfo>;
621
+ get [typeSchemaSymbol](): TreeNodeSchemaClass<TName, TKind, TreeNode, never, boolean, TInfo>;
623
622
  }
624
623
 
625
624
  // (No @packageDocumentation comment for this package)
@@ -167,7 +167,6 @@ declare namespace InternalTypes {
167
167
  ApplyKindInput,
168
168
  NodeBuilderData,
169
169
  FieldHasDefault,
170
- TreeArrayNodeBase,
171
170
  ScopedSchemaName,
172
171
  DefaultProvider,
173
172
  typeNameSymbol,
@@ -242,7 +241,7 @@ export interface MakeNominal {
242
241
  export type MapNodeInsertableData<T extends ImplicitAllowedTypes> = Iterable<readonly [string, InsertableTreeNodeFromImplicitAllowedTypes<T>]> | RestrictiveStringRecord<InsertableTreeNodeFromImplicitAllowedTypes<T>>;
243
242
 
244
243
  // @public
245
- type NodeBuilderData<T extends TreeNodeSchema> = T extends TreeNodeSchema<string, NodeKind, TreeNode | TreeLeafValue, infer TBuild> ? TBuild : never;
244
+ type NodeBuilderData<T extends TreeNodeSchemaCore<string, NodeKind, boolean>> = T extends TreeNodeSchemaCore<string, NodeKind, boolean, unknown, infer TBuild> ? TBuild : never;
246
245
 
247
246
  // @public
248
247
  type NodeBuilderDataUnsafe<T extends Unenforced<TreeNodeSchema>> = T extends TreeNodeSchemaUnsafe<string, NodeKind, unknown, infer TBuild> ? TBuild : never;
@@ -362,24 +361,24 @@ export interface SchemaCompatibilityStatus {
362
361
  // @public @sealed
363
362
  export class SchemaFactory<out TScope extends string | undefined = string | undefined, TName extends number | string = string> {
364
363
  constructor(scope: TScope);
365
- array<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T>;
366
- array<const Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T>;
364
+ array<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T, undefined>;
365
+ array<const Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T, undefined>;
367
366
  arrayRecursive<const Name extends TName, const T extends Unenforced<ImplicitAllowedTypes>>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Array, TreeArrayNodeUnsafe<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Array, unknown>, {
368
367
  [Symbol.iterator](): Iterator<InsertableTreeNodeFromImplicitAllowedTypesUnsafe<T>>;
369
- }, false, T>;
370
- readonly boolean: TreeNodeSchema<"com.fluidframework.leaf.boolean", NodeKind.Leaf, boolean, boolean>;
371
- readonly handle: TreeNodeSchema<"com.fluidframework.leaf.handle", NodeKind.Leaf, IFluidHandle<unknown>, IFluidHandle<unknown>>;
368
+ }, false, T, undefined>;
369
+ readonly boolean: TreeNodeSchemaNonClass<"com.fluidframework.leaf.boolean", NodeKind.Leaf, boolean, boolean, true, unknown, never>;
370
+ readonly handle: TreeNodeSchemaNonClass<"com.fluidframework.leaf.handle", NodeKind.Leaf, IFluidHandle<unknown>, IFluidHandle<unknown>, true, unknown, never>;
372
371
  get identifier(): FieldSchema<FieldKind.Identifier, typeof SchemaFactory.string>;
373
- map<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map>, MapNodeInsertableData<T>, true, T>;
374
- map<Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Map>, MapNodeInsertableData<T>, true, T>;
372
+ map<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map>, MapNodeInsertableData<T>, true, T, undefined>;
373
+ map<Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Map>, MapNodeInsertableData<T>, true, T, undefined>;
375
374
  mapRecursive<Name extends TName, const T extends Unenforced<ImplicitAllowedTypes>>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Map, TreeMapNodeUnsafe<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Map, unknown>, {
376
375
  [Symbol.iterator](): Iterator<[
377
376
  string,
378
377
  InsertableTreeNodeFromImplicitAllowedTypesUnsafe<T>
379
378
  ]>;
380
- }, false, T>;
381
- readonly null: TreeNodeSchema<"com.fluidframework.leaf.null", NodeKind.Leaf, null, null>;
382
- readonly number: TreeNodeSchema<"com.fluidframework.leaf.number", NodeKind.Leaf, number, number>;
379
+ }, false, T, undefined>;
380
+ readonly null: TreeNodeSchemaNonClass<"com.fluidframework.leaf.null", NodeKind.Leaf, null, null, true, unknown, never>;
381
+ readonly number: TreeNodeSchemaNonClass<"com.fluidframework.leaf.number", NodeKind.Leaf, number, number, true, unknown, never>;
383
382
  object<const Name extends TName, const T extends RestrictiveStringRecord<ImplicitFieldSchema>>(name: Name, fields: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Object, TreeObjectNode<T, ScopedSchemaName<TScope, Name>>, object & InsertableObjectFromSchemaRecord<T>, true, T>;
384
383
  objectRecursive<const Name extends TName, const T extends Unenforced<RestrictiveStringRecord<ImplicitFieldSchema>>>(name: Name, t: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Object, TreeObjectNodeUnsafe<T, ScopedSchemaName<TScope, Name>>, object & { readonly [Property in keyof T as FieldHasDefaultUnsafe<T[Property]> extends false ? Property : never]: InsertableTreeFieldFromImplicitFieldUnsafe<T[Property], UnionToIntersection_2<T[Property]>>; } & { readonly [Property_1 in keyof T as FieldHasDefaultUnsafe<T[Property_1]> extends true ? Property_1 : never]?: InsertableTreeFieldFromImplicitFieldUnsafe<T[Property_1], UnionToIntersection_2<T[Property_1]>> | undefined; }, false, T>;
385
384
  optional<const T extends ImplicitAllowedTypes, const TCustomMetadata = unknown>(t: T, props?: Omit<FieldProps<TCustomMetadata>, "defaultProvider">): FieldSchema<FieldKind.Optional, T, TCustomMetadata>;
@@ -388,7 +387,7 @@ export class SchemaFactory<out TScope extends string | undefined = string | unde
388
387
  requiredRecursive<const T extends Unenforced<ImplicitAllowedTypes>>(t: T, props?: Omit<FieldProps, "defaultProvider">): FieldSchemaUnsafe<FieldKind.Required, T>;
389
388
  // (undocumented)
390
389
  readonly scope: TScope;
391
- readonly string: TreeNodeSchema<"com.fluidframework.leaf.string", NodeKind.Leaf, string, string>;
390
+ readonly string: TreeNodeSchemaNonClass<"com.fluidframework.leaf.string", NodeKind.Leaf, string, string, true, unknown, never>;
392
391
  }
393
392
 
394
393
  // @public
@@ -407,16 +406,7 @@ interface TreeApi extends TreeNodeApi {
407
406
  }
408
407
 
409
408
  // @public @sealed
410
- export interface TreeArrayNode<TAllowedTypes extends ImplicitAllowedTypes = ImplicitAllowedTypes> extends TreeArrayNodeBase<TreeNodeFromImplicitAllowedTypes<TAllowedTypes>, InsertableTreeNodeFromImplicitAllowedTypes<TAllowedTypes>> {
411
- }
412
-
413
- // @public
414
- export const TreeArrayNode: {
415
- readonly spread: <T>(content: Iterable<T>) => IterableTreeArrayContent<T>;
416
- };
417
-
418
- // @public @sealed
419
- interface TreeArrayNodeBase<out T, in TNew, in TMoveFrom = ReadonlyArrayNode> extends ReadonlyArrayNode<T> {
409
+ export interface TreeArrayNode<TAllowedTypes extends Unenforced<ImplicitAllowedTypes> = ImplicitAllowedTypes, out T = [TAllowedTypes] extends [ImplicitAllowedTypes] ? TreeNodeFromImplicitAllowedTypes<TAllowedTypes> : TreeNodeFromImplicitAllowedTypes<ImplicitAllowedTypes>, in TNew = [TAllowedTypes] extends [ImplicitAllowedTypes] ? InsertableTreeNodeFromImplicitAllowedTypes<TAllowedTypes> : InsertableTreeNodeFromImplicitAllowedTypes<ImplicitAllowedTypes>, in TMoveFrom = ReadonlyArrayNode> extends ReadonlyArrayNode<T> {
420
410
  insertAt(index: number, ...value: readonly (TNew | IterableTreeArrayContent<TNew>)[]): void;
421
411
  insertAtEnd(...value: readonly (TNew | IterableTreeArrayContent<TNew>)[]): void;
422
412
  insertAtStart(...value: readonly (TNew | IterableTreeArrayContent<TNew>)[]): void;
@@ -437,8 +427,13 @@ interface TreeArrayNodeBase<out T, in TNew, in TMoveFrom = ReadonlyArrayNode> ex
437
427
  values(): IterableIterator<T>;
438
428
  }
439
429
 
430
+ // @public
431
+ export const TreeArrayNode: {
432
+ readonly spread: <T>(content: Iterable<T>) => IterableTreeArrayContent<T>;
433
+ };
434
+
440
435
  // @public @sealed
441
- export interface TreeArrayNodeUnsafe<TAllowedTypes extends Unenforced<ImplicitAllowedTypes>> extends TreeArrayNodeBase<TreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>, InsertableTreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>> {
436
+ export interface TreeArrayNodeUnsafe<TAllowedTypes extends Unenforced<ImplicitAllowedTypes>> extends TreeArrayNode<TAllowedTypes, TreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>, InsertableTreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>> {
442
437
  }
443
438
 
444
439
  // @public @sealed
@@ -500,23 +495,26 @@ export type TreeNodeFromImplicitAllowedTypes<TSchema extends ImplicitAllowedType
500
495
  type TreeNodeFromImplicitAllowedTypesUnsafe<TSchema extends Unenforced<ImplicitAllowedTypes>> = TSchema extends TreeNodeSchemaUnsafe ? NodeFromSchemaUnsafe<TSchema> : TSchema extends AllowedTypesUnsafe ? NodeFromSchemaUnsafe<FlexListToUnion<TSchema>> : unknown;
501
496
 
502
497
  // @public @sealed
503
- export type TreeNodeSchema<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, TBuild = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown> = TreeNodeSchemaClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info> | TreeNodeSchemaNonClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info>;
498
+ export type TreeNodeSchema<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, TBuild = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown> = (TNode extends TreeNode ? TreeNodeSchemaClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info> : never) | TreeNodeSchemaNonClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info>;
504
499
 
505
500
  // @public @sealed
506
- export interface TreeNodeSchemaClass<out Name extends string = string, out Kind extends NodeKind = NodeKind, out TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, in TInsertable = never, out ImplicitlyConstructable extends boolean = boolean, out Info = unknown> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
507
- // @sealed
508
- new (data: TInsertable | InternalTreeNode): Unhydrated<TNode>;
509
- }
501
+ export type TreeNodeSchemaClass<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode = TreeNode, TInsertable = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown, TConstructorExtra = never> = TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info, TInsertable> & (undefined extends TConstructorExtra ? {
502
+ new (data?: TInsertable | InternalTreeNode | TConstructorExtra): Unhydrated<TNode>;
503
+ } : {
504
+ new (data: TInsertable | InternalTreeNode | TConstructorExtra): Unhydrated<TNode>;
505
+ });
510
506
 
511
507
  // @public
512
- export interface TreeNodeSchemaClassUnsafe<out Name extends string, out Kind extends NodeKind, out TNode extends Unenforced<TreeNode | TreeLeafValue>, in TInsertable, out ImplicitlyConstructable extends boolean, out Info> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
508
+ export interface TreeNodeSchemaClassUnsafe<out Name extends string, out Kind extends NodeKind, out TNode extends Unenforced<TreeNode>, in TInsertable, out ImplicitlyConstructable extends boolean, out Info> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
513
509
  // @sealed
514
510
  new (data: TInsertable | InternalTreeNode): Unhydrated<TNode>;
515
511
  }
516
512
 
517
513
  // @public @sealed
518
- export interface TreeNodeSchemaCore<out Name extends string, out Kind extends NodeKind, out ImplicitlyConstructable extends boolean, out Info = unknown> {
514
+ export interface TreeNodeSchemaCore<out Name extends string, out Kind extends NodeKind, out ImplicitlyConstructable extends boolean, out Info = unknown, out TInsertable = never> {
519
515
  readonly childTypes: ReadonlySet<TreeNodeSchema>;
516
+ // @sealed
517
+ createFromInsertable(data: TInsertable): Unhydrated<TreeNode | TreeLeafValue>;
520
518
  readonly identifier: Name;
521
519
  readonly implicitlyConstructable: ImplicitlyConstructable;
522
520
  readonly info: Info;
@@ -525,10 +523,11 @@ export interface TreeNodeSchemaCore<out Name extends string, out Kind extends No
525
523
  }
526
524
 
527
525
  // @public @sealed
528
- export interface TreeNodeSchemaNonClass<out Name extends string = string, out Kind extends NodeKind = NodeKind, out TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, in TInsertable = never, out ImplicitlyConstructable extends boolean = boolean, out Info = unknown> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
529
- // (undocumented)
530
- create(data: TInsertable): TNode;
531
- }
526
+ export type TreeNodeSchemaNonClass<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, TInsertable = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown, TConstructorExtra = never> = TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info, TInsertable> & (undefined extends TConstructorExtra ? {
527
+ create(data?: TInsertable | TConstructorExtra): TNode;
528
+ } : {
529
+ create(data: TInsertable | TConstructorExtra): TNode;
530
+ });
532
531
 
533
532
  // @public
534
533
  interface TreeNodeSchemaNonClassUnsafe<out Name extends string, out Kind extends NodeKind, out TNode extends Unenforced<TreeNode | TreeLeafValue>, in TInsertable, out ImplicitlyConstructable extends boolean, out Info = unknown> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
@@ -616,7 +615,7 @@ export interface ViewableTree {
616
615
  export interface WithType<out TName extends string = string, out TKind extends NodeKind = NodeKind, out TInfo = unknown> {
617
616
  // @deprecated
618
617
  get [typeNameSymbol](): TName;
619
- get [typeSchemaSymbol](): TreeNodeSchemaClass<TName, TKind, TreeNode | TreeLeafValue, never, boolean, TInfo>;
618
+ get [typeSchemaSymbol](): TreeNodeSchemaClass<TName, TKind, TreeNode, never, boolean, TInfo>;
620
619
  }
621
620
 
622
621
  // (No @packageDocumentation comment for this package)
@@ -167,7 +167,6 @@ declare namespace InternalTypes {
167
167
  ApplyKindInput,
168
168
  NodeBuilderData,
169
169
  FieldHasDefault,
170
- TreeArrayNodeBase,
171
170
  ScopedSchemaName,
172
171
  DefaultProvider,
173
172
  typeNameSymbol,
@@ -242,7 +241,7 @@ export interface MakeNominal {
242
241
  export type MapNodeInsertableData<T extends ImplicitAllowedTypes> = Iterable<readonly [string, InsertableTreeNodeFromImplicitAllowedTypes<T>]> | RestrictiveStringRecord<InsertableTreeNodeFromImplicitAllowedTypes<T>>;
243
242
 
244
243
  // @public
245
- type NodeBuilderData<T extends TreeNodeSchema> = T extends TreeNodeSchema<string, NodeKind, TreeNode | TreeLeafValue, infer TBuild> ? TBuild : never;
244
+ type NodeBuilderData<T extends TreeNodeSchemaCore<string, NodeKind, boolean>> = T extends TreeNodeSchemaCore<string, NodeKind, boolean, unknown, infer TBuild> ? TBuild : never;
246
245
 
247
246
  // @public
248
247
  type NodeBuilderDataUnsafe<T extends Unenforced<TreeNodeSchema>> = T extends TreeNodeSchemaUnsafe<string, NodeKind, unknown, infer TBuild> ? TBuild : never;
@@ -362,24 +361,24 @@ export interface SchemaCompatibilityStatus {
362
361
  // @public @sealed
363
362
  export class SchemaFactory<out TScope extends string | undefined = string | undefined, TName extends number | string = string> {
364
363
  constructor(scope: TScope);
365
- array<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T>;
366
- array<const Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T>;
364
+ array<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, `Array<${string}>`>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T, undefined>;
365
+ array<const Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Array, TreeArrayNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Array>, Iterable<InsertableTreeNodeFromImplicitAllowedTypes<T>>, true, T, undefined>;
367
366
  arrayRecursive<const Name extends TName, const T extends Unenforced<ImplicitAllowedTypes>>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Array, TreeArrayNodeUnsafe<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Array, unknown>, {
368
367
  [Symbol.iterator](): Iterator<InsertableTreeNodeFromImplicitAllowedTypesUnsafe<T>>;
369
- }, false, T>;
370
- readonly boolean: TreeNodeSchema<"com.fluidframework.leaf.boolean", NodeKind.Leaf, boolean, boolean>;
371
- readonly handle: TreeNodeSchema<"com.fluidframework.leaf.handle", NodeKind.Leaf, IFluidHandle<unknown>, IFluidHandle<unknown>>;
368
+ }, false, T, undefined>;
369
+ readonly boolean: TreeNodeSchemaNonClass<"com.fluidframework.leaf.boolean", NodeKind.Leaf, boolean, boolean, true, unknown, never>;
370
+ readonly handle: TreeNodeSchemaNonClass<"com.fluidframework.leaf.handle", NodeKind.Leaf, IFluidHandle<unknown>, IFluidHandle<unknown>, true, unknown, never>;
372
371
  get identifier(): FieldSchema<FieldKind.Identifier, typeof SchemaFactory.string>;
373
- map<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map>, MapNodeInsertableData<T>, true, T>;
374
- map<Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Map>, MapNodeInsertableData<T>, true, T>;
372
+ map<const T extends TreeNodeSchema | readonly TreeNodeSchema[]>(allowedTypes: T): TreeNodeSchemaNonClass<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, `Map<${string}>`>, NodeKind.Map>, MapNodeInsertableData<T>, true, T, undefined>;
373
+ map<Name extends TName, const T extends ImplicitAllowedTypes>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Map, TreeMapNode<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Map>, MapNodeInsertableData<T>, true, T, undefined>;
375
374
  mapRecursive<Name extends TName, const T extends Unenforced<ImplicitAllowedTypes>>(name: Name, allowedTypes: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Map, TreeMapNodeUnsafe<T> & WithType<ScopedSchemaName<TScope, Name>, NodeKind.Map, unknown>, {
376
375
  [Symbol.iterator](): Iterator<[
377
376
  string,
378
377
  InsertableTreeNodeFromImplicitAllowedTypesUnsafe<T>
379
378
  ]>;
380
- }, false, T>;
381
- readonly null: TreeNodeSchema<"com.fluidframework.leaf.null", NodeKind.Leaf, null, null>;
382
- readonly number: TreeNodeSchema<"com.fluidframework.leaf.number", NodeKind.Leaf, number, number>;
379
+ }, false, T, undefined>;
380
+ readonly null: TreeNodeSchemaNonClass<"com.fluidframework.leaf.null", NodeKind.Leaf, null, null, true, unknown, never>;
381
+ readonly number: TreeNodeSchemaNonClass<"com.fluidframework.leaf.number", NodeKind.Leaf, number, number, true, unknown, never>;
383
382
  object<const Name extends TName, const T extends RestrictiveStringRecord<ImplicitFieldSchema>>(name: Name, fields: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Object, TreeObjectNode<T, ScopedSchemaName<TScope, Name>>, object & InsertableObjectFromSchemaRecord<T>, true, T>;
384
383
  objectRecursive<const Name extends TName, const T extends Unenforced<RestrictiveStringRecord<ImplicitFieldSchema>>>(name: Name, t: T): TreeNodeSchemaClass<ScopedSchemaName<TScope, Name>, NodeKind.Object, TreeObjectNodeUnsafe<T, ScopedSchemaName<TScope, Name>>, object & { readonly [Property in keyof T as FieldHasDefaultUnsafe<T[Property]> extends false ? Property : never]: InsertableTreeFieldFromImplicitFieldUnsafe<T[Property], UnionToIntersection_2<T[Property]>>; } & { readonly [Property_1 in keyof T as FieldHasDefaultUnsafe<T[Property_1]> extends true ? Property_1 : never]?: InsertableTreeFieldFromImplicitFieldUnsafe<T[Property_1], UnionToIntersection_2<T[Property_1]>> | undefined; }, false, T>;
385
384
  optional<const T extends ImplicitAllowedTypes, const TCustomMetadata = unknown>(t: T, props?: Omit<FieldProps<TCustomMetadata>, "defaultProvider">): FieldSchema<FieldKind.Optional, T, TCustomMetadata>;
@@ -388,7 +387,7 @@ export class SchemaFactory<out TScope extends string | undefined = string | unde
388
387
  requiredRecursive<const T extends Unenforced<ImplicitAllowedTypes>>(t: T, props?: Omit<FieldProps, "defaultProvider">): FieldSchemaUnsafe<FieldKind.Required, T>;
389
388
  // (undocumented)
390
389
  readonly scope: TScope;
391
- readonly string: TreeNodeSchema<"com.fluidframework.leaf.string", NodeKind.Leaf, string, string>;
390
+ readonly string: TreeNodeSchemaNonClass<"com.fluidframework.leaf.string", NodeKind.Leaf, string, string, true, unknown, never>;
392
391
  }
393
392
 
394
393
  // @public
@@ -407,16 +406,7 @@ interface TreeApi extends TreeNodeApi {
407
406
  }
408
407
 
409
408
  // @public @sealed
410
- export interface TreeArrayNode<TAllowedTypes extends ImplicitAllowedTypes = ImplicitAllowedTypes> extends TreeArrayNodeBase<TreeNodeFromImplicitAllowedTypes<TAllowedTypes>, InsertableTreeNodeFromImplicitAllowedTypes<TAllowedTypes>> {
411
- }
412
-
413
- // @public
414
- export const TreeArrayNode: {
415
- readonly spread: <T>(content: Iterable<T>) => IterableTreeArrayContent<T>;
416
- };
417
-
418
- // @public @sealed
419
- interface TreeArrayNodeBase<out T, in TNew, in TMoveFrom = ReadonlyArrayNode> extends ReadonlyArrayNode<T> {
409
+ export interface TreeArrayNode<TAllowedTypes extends Unenforced<ImplicitAllowedTypes> = ImplicitAllowedTypes, out T = [TAllowedTypes] extends [ImplicitAllowedTypes] ? TreeNodeFromImplicitAllowedTypes<TAllowedTypes> : TreeNodeFromImplicitAllowedTypes<ImplicitAllowedTypes>, in TNew = [TAllowedTypes] extends [ImplicitAllowedTypes] ? InsertableTreeNodeFromImplicitAllowedTypes<TAllowedTypes> : InsertableTreeNodeFromImplicitAllowedTypes<ImplicitAllowedTypes>, in TMoveFrom = ReadonlyArrayNode> extends ReadonlyArrayNode<T> {
420
410
  insertAt(index: number, ...value: readonly (TNew | IterableTreeArrayContent<TNew>)[]): void;
421
411
  insertAtEnd(...value: readonly (TNew | IterableTreeArrayContent<TNew>)[]): void;
422
412
  insertAtStart(...value: readonly (TNew | IterableTreeArrayContent<TNew>)[]): void;
@@ -437,8 +427,13 @@ interface TreeArrayNodeBase<out T, in TNew, in TMoveFrom = ReadonlyArrayNode> ex
437
427
  values(): IterableIterator<T>;
438
428
  }
439
429
 
430
+ // @public
431
+ export const TreeArrayNode: {
432
+ readonly spread: <T>(content: Iterable<T>) => IterableTreeArrayContent<T>;
433
+ };
434
+
440
435
  // @public @sealed
441
- export interface TreeArrayNodeUnsafe<TAllowedTypes extends Unenforced<ImplicitAllowedTypes>> extends TreeArrayNodeBase<TreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>, InsertableTreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>> {
436
+ export interface TreeArrayNodeUnsafe<TAllowedTypes extends Unenforced<ImplicitAllowedTypes>> extends TreeArrayNode<TAllowedTypes, TreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>, InsertableTreeNodeFromImplicitAllowedTypesUnsafe<TAllowedTypes>> {
442
437
  }
443
438
 
444
439
  // @public @sealed
@@ -500,23 +495,26 @@ export type TreeNodeFromImplicitAllowedTypes<TSchema extends ImplicitAllowedType
500
495
  type TreeNodeFromImplicitAllowedTypesUnsafe<TSchema extends Unenforced<ImplicitAllowedTypes>> = TSchema extends TreeNodeSchemaUnsafe ? NodeFromSchemaUnsafe<TSchema> : TSchema extends AllowedTypesUnsafe ? NodeFromSchemaUnsafe<FlexListToUnion<TSchema>> : unknown;
501
496
 
502
497
  // @public @sealed
503
- export type TreeNodeSchema<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, TBuild = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown> = TreeNodeSchemaClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info> | TreeNodeSchemaNonClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info>;
498
+ export type TreeNodeSchema<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, TBuild = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown> = (TNode extends TreeNode ? TreeNodeSchemaClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info> : never) | TreeNodeSchemaNonClass<Name, Kind, TNode, TBuild, ImplicitlyConstructable, Info>;
504
499
 
505
500
  // @public @sealed
506
- export interface TreeNodeSchemaClass<out Name extends string = string, out Kind extends NodeKind = NodeKind, out TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, in TInsertable = never, out ImplicitlyConstructable extends boolean = boolean, out Info = unknown> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
507
- // @sealed
508
- new (data: TInsertable | InternalTreeNode): Unhydrated<TNode>;
509
- }
501
+ export type TreeNodeSchemaClass<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode = TreeNode, TInsertable = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown, TConstructorExtra = never> = TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info, TInsertable> & (undefined extends TConstructorExtra ? {
502
+ new (data?: TInsertable | InternalTreeNode | TConstructorExtra): Unhydrated<TNode>;
503
+ } : {
504
+ new (data: TInsertable | InternalTreeNode | TConstructorExtra): Unhydrated<TNode>;
505
+ });
510
506
 
511
507
  // @public
512
- export interface TreeNodeSchemaClassUnsafe<out Name extends string, out Kind extends NodeKind, out TNode extends Unenforced<TreeNode | TreeLeafValue>, in TInsertable, out ImplicitlyConstructable extends boolean, out Info> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
508
+ export interface TreeNodeSchemaClassUnsafe<out Name extends string, out Kind extends NodeKind, out TNode extends Unenforced<TreeNode>, in TInsertable, out ImplicitlyConstructable extends boolean, out Info> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
513
509
  // @sealed
514
510
  new (data: TInsertable | InternalTreeNode): Unhydrated<TNode>;
515
511
  }
516
512
 
517
513
  // @public @sealed
518
- export interface TreeNodeSchemaCore<out Name extends string, out Kind extends NodeKind, out ImplicitlyConstructable extends boolean, out Info = unknown> {
514
+ export interface TreeNodeSchemaCore<out Name extends string, out Kind extends NodeKind, out ImplicitlyConstructable extends boolean, out Info = unknown, out TInsertable = never> {
519
515
  readonly childTypes: ReadonlySet<TreeNodeSchema>;
516
+ // @sealed
517
+ createFromInsertable(data: TInsertable): Unhydrated<TreeNode | TreeLeafValue>;
520
518
  readonly identifier: Name;
521
519
  readonly implicitlyConstructable: ImplicitlyConstructable;
522
520
  readonly info: Info;
@@ -525,10 +523,11 @@ export interface TreeNodeSchemaCore<out Name extends string, out Kind extends No
525
523
  }
526
524
 
527
525
  // @public @sealed
528
- export interface TreeNodeSchemaNonClass<out Name extends string = string, out Kind extends NodeKind = NodeKind, out TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, in TInsertable = never, out ImplicitlyConstructable extends boolean = boolean, out Info = unknown> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
529
- // (undocumented)
530
- create(data: TInsertable): TNode;
531
- }
526
+ export type TreeNodeSchemaNonClass<Name extends string = string, Kind extends NodeKind = NodeKind, TNode extends TreeNode | TreeLeafValue = TreeNode | TreeLeafValue, TInsertable = never, ImplicitlyConstructable extends boolean = boolean, Info = unknown, TConstructorExtra = never> = TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info, TInsertable> & (undefined extends TConstructorExtra ? {
527
+ create(data?: TInsertable | TConstructorExtra): TNode;
528
+ } : {
529
+ create(data: TInsertable | TConstructorExtra): TNode;
530
+ });
532
531
 
533
532
  // @public
534
533
  interface TreeNodeSchemaNonClassUnsafe<out Name extends string, out Kind extends NodeKind, out TNode extends Unenforced<TreeNode | TreeLeafValue>, in TInsertable, out ImplicitlyConstructable extends boolean, out Info = unknown> extends TreeNodeSchemaCore<Name, Kind, ImplicitlyConstructable, Info> {
@@ -616,7 +615,7 @@ export interface ViewableTree {
616
615
  export interface WithType<out TName extends string = string, out TKind extends NodeKind = NodeKind, out TInfo = unknown> {
617
616
  // @deprecated
618
617
  get [typeNameSymbol](): TName;
619
- get [typeSchemaSymbol](): TreeNodeSchemaClass<TName, TKind, TreeNode | TreeLeafValue, never, boolean, TInfo>;
618
+ get [typeSchemaSymbol](): TreeNodeSchemaClass<TName, TKind, TreeNode, never, boolean, TInfo>;
620
619
  }
621
620
 
622
621
  // (No @packageDocumentation comment for this package)
package/dist/alpha.d.ts CHANGED
@@ -94,9 +94,13 @@ export {
94
94
  TreeChangeEventsBeta,
95
95
 
96
96
  // @alpha APIs
97
+ BranchableTree,
98
+ ConciseTree,
99
+ EncodeOptions,
97
100
  FactoryContent,
98
101
  FactoryContentObject,
99
102
  FixRecursiveArraySchema,
103
+ FluidClientVersion,
100
104
  ForestOptions,
101
105
  ForestType,
102
106
  ICodecOptions,
@@ -120,23 +124,34 @@ export {
120
124
  JsonSchemaType,
121
125
  JsonTreeSchema,
122
126
  JsonValidator,
127
+ ParseOptions,
123
128
  PopUnion,
129
+ ReadSchema,
130
+ ReadableField,
124
131
  SchemaValidationFunction,
125
132
  SharedTreeFormatOptions,
126
133
  SharedTreeFormatVersion,
127
134
  SharedTreeOptions,
135
+ TreeAlpha,
128
136
  TreeBranch,
137
+ TreeBranchEvents,
129
138
  TreeBranchFork,
130
139
  TreeCompressionStrategy,
131
140
  TreeViewAlpha,
132
141
  UnionToTuple,
133
142
  UnsafeUnknownSchema,
143
+ VerboseTree,
144
+ VerboseTreeNode,
145
+ ViewContent,
134
146
  adaptEnum,
147
+ asTreeViewAlpha,
135
148
  comparePersistedSchema,
136
149
  enumFromStrings,
137
150
  extractPersistedSchema,
138
151
  getBranch,
139
152
  getJsonSchema,
153
+ independentInitializedView,
154
+ independentView,
140
155
  noopValidator,
141
156
  singletonSchema,
142
157
  typeboxValidator
@@ -180,4 +180,28 @@ export declare const unitCodec: IMultiFormatCodec<0, JsonCompatibleReadOnly, Jso
180
180
  * @returns An {@link IJsonCodec} which validates the data it encodes and decodes matches the provided schema.
181
181
  */
182
182
  export declare function withSchemaValidation<TInMemoryFormat, EncodedSchema extends TSchema, TEncodedFormat = JsonCompatibleReadOnly, TValidate = TEncodedFormat, TContext = ChangeEncodingContext>(schema: EncodedSchema, codec: IJsonCodec<TInMemoryFormat, TEncodedFormat, TValidate, TContext>, validator?: JsonValidator): IJsonCodec<TInMemoryFormat, TEncodedFormat, TValidate, TContext>;
183
+ /**
184
+ * Versions of Fluid Framework client packages.
185
+ * @remarks
186
+ * Used to express compatibility requirements by indicating the oldest version with which compatibility must be maintained.
187
+ * @privateRemarks
188
+ * This scheme assumes a single version will always be enough to communicate compatibility.
189
+ * For this to work, compatibility has to be strictly increasing.
190
+ * If this is violated (for example a subset of incompatible features from 3.x that are not in 3.0 are back ported to 2.x),
191
+ * a more complex scheme may be needed to allow safely opting into incompatible features in those cases:
192
+ * such a system can be added if/when its needed since it will be opt in and thus non-breaking.
193
+ *
194
+ * TODO: this should likely be defined higher in the stack and specified when creating the container, possibly as part of its schema.
195
+ * @alpha
196
+ */
197
+ export declare enum FluidClientVersion {
198
+ /** Fluid Framework Client 2.0 and newer. */
199
+ v2_0 = "v2_0",
200
+ /** Fluid Framework Client 2.1 and newer. */
201
+ v2_1 = "v2_1",
202
+ /** Fluid Framework Client 2.2 and newer. */
203
+ v2_2 = "v2_2",
204
+ /** Fluid Framework Client 2.4 and newer. */
205
+ v2_3 = "v2_3"
206
+ }
183
207
  //# sourceMappingURL=codec.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"codec.d.ts","sourceRoot":"","sources":["../../src/codec/codec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"codec.d.ts","sourceRoot":"","sources":["../../src/codec/codec.ts"],"names":[],"mappings":"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"}