@payloadcms/richtext-lexical 3.68.0-internal-debug.654e4ad → 3.68.0-internal.10bf491

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 (1093) hide show
  1. package/dist/cell/rscEntry.js +70 -72
  2. package/dist/cell/rscEntry.js.map +1 -1
  3. package/dist/dependencyChecker.spec.js +7 -8
  4. package/dist/dependencyChecker.spec.js.map +1 -1
  5. package/dist/exports/client/Component-DOSSWC76.js +2 -0
  6. package/dist/exports/client/Component-DOSSWC76.js.map +7 -0
  7. package/dist/exports/client/Component-MBLHTKDK.js +2 -0
  8. package/dist/exports/client/Component-MBLHTKDK.js.map +7 -0
  9. package/dist/exports/client/Field-HJGV32KA.js +2 -0
  10. package/dist/exports/client/Field-HJGV32KA.js.map +7 -0
  11. package/dist/exports/client/RelationshipComponent-UCIWIEVD.js +2 -0
  12. package/dist/exports/client/RelationshipComponent-UCIWIEVD.js.map +7 -0
  13. package/dist/exports/client/bundled.css +1 -0
  14. package/dist/exports/client/chunk-BZZVLW4U.js +2 -0
  15. package/dist/exports/client/chunk-BZZVLW4U.js.map +7 -0
  16. package/dist/exports/client/chunk-DBWINSQN.js +2 -0
  17. package/dist/exports/client/chunk-DBWINSQN.js.map +7 -0
  18. package/dist/exports/client/chunk-EZX4YW7S.js +12 -0
  19. package/dist/exports/client/chunk-EZX4YW7S.js.map +7 -0
  20. package/dist/exports/client/chunk-F26IQ5RE.js +2 -0
  21. package/dist/exports/client/chunk-F26IQ5RE.js.map +7 -0
  22. package/dist/exports/client/chunk-INBEEENE.js +2 -0
  23. package/dist/exports/client/chunk-INBEEENE.js.map +7 -0
  24. package/dist/exports/client/chunk-O6XRT2H3.js +2 -0
  25. package/dist/exports/client/chunk-O6XRT2H3.js.map +7 -0
  26. package/dist/exports/client/chunk-TRHFMZ3F.js +2 -0
  27. package/dist/exports/client/chunk-TRHFMZ3F.js.map +7 -0
  28. package/dist/exports/client/component-5IW2M4GH.js +2 -0
  29. package/dist/exports/client/component-5IW2M4GH.js.map +7 -0
  30. package/dist/exports/client/componentInline-5OVPQNQH.js +2 -0
  31. package/dist/exports/client/componentInline-5OVPQNQH.js.map +7 -0
  32. package/dist/exports/client/index.d.ts +0 -1
  33. package/dist/exports/client/index.d.ts.map +1 -1
  34. package/dist/exports/client/index.js +65 -86
  35. package/dist/exports/client/index.js.map +7 -1
  36. package/dist/exports/cssEntry.js +0 -1
  37. package/dist/exports/cssEntry.js.map +1 -1
  38. package/dist/exports/html/index.js +0 -1
  39. package/dist/exports/html/index.js.map +1 -1
  40. package/dist/exports/html-async/index.js +0 -1
  41. package/dist/exports/html-async/index.js.map +1 -1
  42. package/dist/exports/plaintext/index.js +0 -1
  43. package/dist/exports/plaintext/index.js.map +1 -1
  44. package/dist/exports/react/index.d.ts +1 -1
  45. package/dist/exports/react/index.d.ts.map +1 -1
  46. package/dist/exports/react/index.js +0 -1
  47. package/dist/exports/react/index.js.map +1 -1
  48. package/dist/exports/server/ast/mdx.d.ts.map +1 -1
  49. package/dist/exports/server/ast/mdx.js +34 -37
  50. package/dist/exports/server/ast/mdx.js.map +1 -1
  51. package/dist/exports/server/migrate.js +0 -1
  52. package/dist/exports/server/migrate.js.map +1 -1
  53. package/dist/exports/server/rsc.js +0 -1
  54. package/dist/exports/server/rsc.js.map +1 -1
  55. package/dist/exports/shared.js +0 -1
  56. package/dist/exports/shared.js.map +1 -1
  57. package/dist/features/align/client/index.js +195 -168
  58. package/dist/features/align/client/index.js.map +1 -1
  59. package/dist/features/align/client/toolbarAlignGroup.js +9 -9
  60. package/dist/features/align/client/toolbarAlignGroup.js.map +1 -1
  61. package/dist/features/align/server/i18n.js +222 -223
  62. package/dist/features/align/server/i18n.js.map +1 -1
  63. package/dist/features/align/server/index.js +5 -6
  64. package/dist/features/align/server/index.js.map +1 -1
  65. package/dist/features/blockquote/client/index.js +60 -65
  66. package/dist/features/blockquote/client/index.js.map +1 -1
  67. package/dist/features/blockquote/markdownTransformer.js +28 -33
  68. package/dist/features/blockquote/markdownTransformer.js.map +1 -1
  69. package/dist/features/blockquote/server/i18n.js +111 -112
  70. package/dist/features/blockquote/server/i18n.js.map +1 -1
  71. package/dist/features/blockquote/server/index.js +48 -47
  72. package/dist/features/blockquote/server/index.js.map +1 -1
  73. package/dist/features/blocks/client/component/BlockContent.js +69 -95
  74. package/dist/features/blocks/client/component/BlockContent.js.map +1 -1
  75. package/dist/features/blocks/client/component/components/BlockCollapsible.js +14 -13
  76. package/dist/features/blocks/client/component/components/BlockCollapsible.js.map +1 -1
  77. package/dist/features/blocks/client/component/components/BlockEditButton.js +17 -9
  78. package/dist/features/blocks/client/component/components/BlockEditButton.js.map +1 -1
  79. package/dist/features/blocks/client/component/components/BlockRemoveButton.js +17 -9
  80. package/dist/features/blocks/client/component/components/BlockRemoveButton.js.map +1 -1
  81. package/dist/features/blocks/client/component/index.js +410 -553
  82. package/dist/features/blocks/client/component/index.js.map +1 -1
  83. package/dist/features/blocks/client/component/removeEmptyArrayValues.js +11 -8
  84. package/dist/features/blocks/client/component/removeEmptyArrayValues.js.map +1 -1
  85. package/dist/features/blocks/client/componentInline/components/InlineBlockContainer.js +23 -11
  86. package/dist/features/blocks/client/componentInline/components/InlineBlockContainer.js.map +1 -1
  87. package/dist/features/blocks/client/componentInline/components/InlineBlockEditButton.js +17 -9
  88. package/dist/features/blocks/client/componentInline/components/InlineBlockEditButton.js.map +1 -1
  89. package/dist/features/blocks/client/componentInline/components/InlineBlockLabel.js +17 -9
  90. package/dist/features/blocks/client/componentInline/components/InlineBlockLabel.js.map +1 -1
  91. package/dist/features/blocks/client/componentInline/components/InlineBlockRemoveButton.js +17 -9
  92. package/dist/features/blocks/client/componentInline/components/InlineBlockRemoveButton.js.map +1 -1
  93. package/dist/features/blocks/client/componentInline/index.js +340 -468
  94. package/dist/features/blocks/client/componentInline/index.js.map +1 -1
  95. package/dist/features/blocks/client/getBlockImageComponent.js +12 -17
  96. package/dist/features/blocks/client/getBlockImageComponent.js.map +1 -1
  97. package/dist/features/blocks/client/index.js +146 -141
  98. package/dist/features/blocks/client/index.js.map +1 -1
  99. package/dist/features/blocks/client/markdown/getLexicalToMarkdown.js +18 -18
  100. package/dist/features/blocks/client/markdown/getLexicalToMarkdown.js.map +1 -1
  101. package/dist/features/blocks/client/markdown/getMarkdownToLexical.js +15 -14
  102. package/dist/features/blocks/client/markdown/getMarkdownToLexical.js.map +1 -1
  103. package/dist/features/blocks/client/markdown/markdownTransformer.js +330 -328
  104. package/dist/features/blocks/client/markdown/markdownTransformer.js.map +1 -1
  105. package/dist/features/blocks/client/nodes/BlocksNode.js +40 -44
  106. package/dist/features/blocks/client/nodes/BlocksNode.js.map +1 -1
  107. package/dist/features/blocks/client/nodes/InlineBlocksNode.js +33 -37
  108. package/dist/features/blocks/client/nodes/InlineBlocksNode.js.map +1 -1
  109. package/dist/features/blocks/client/plugin/commands.js +1 -1
  110. package/dist/features/blocks/client/plugin/commands.js.map +1 -1
  111. package/dist/features/blocks/client/plugin/index.js +87 -59
  112. package/dist/features/blocks/client/plugin/index.js.map +1 -1
  113. package/dist/features/blocks/premade/CodeBlock/Component/Block.js +101 -158
  114. package/dist/features/blocks/premade/CodeBlock/Component/Block.js.map +1 -1
  115. package/dist/features/blocks/premade/CodeBlock/Component/Code.js +93 -119
  116. package/dist/features/blocks/premade/CodeBlock/Component/Code.js.map +1 -1
  117. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.js +11 -19
  118. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.js.map +1 -1
  119. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.js +20 -32
  120. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.js.map +1 -1
  121. package/dist/features/blocks/premade/CodeBlock/Component/defaultLanguages.js +83 -84
  122. package/dist/features/blocks/premade/CodeBlock/Component/defaultLanguages.js.map +1 -1
  123. package/dist/features/blocks/premade/CodeBlock/converter.js +40 -36
  124. package/dist/features/blocks/premade/CodeBlock/converter.js.map +1 -1
  125. package/dist/features/blocks/premade/CodeBlock/converterClient.js +1 -1
  126. package/dist/features/blocks/premade/CodeBlock/converterClient.js.map +1 -1
  127. package/dist/features/blocks/premade/CodeBlock/index.js +49 -49
  128. package/dist/features/blocks/premade/CodeBlock/index.js.map +1 -1
  129. package/dist/features/blocks/server/graphQLPopulationPromise.js +44 -29
  130. package/dist/features/blocks/server/graphQLPopulationPromise.js.map +1 -1
  131. package/dist/features/blocks/server/i18n.js +333 -334
  132. package/dist/features/blocks/server/i18n.js.map +1 -1
  133. package/dist/features/blocks/server/index.js +211 -215
  134. package/dist/features/blocks/server/index.js.map +1 -1
  135. package/dist/features/blocks/server/markdown/linesFromMatchToContentAndPropsString.js +122 -123
  136. package/dist/features/blocks/server/markdown/linesFromMatchToContentAndPropsString.js.map +1 -1
  137. package/dist/features/blocks/server/markdown/markdownTransformer.js +349 -347
  138. package/dist/features/blocks/server/markdown/markdownTransformer.js.map +1 -1
  139. package/dist/features/blocks/server/nodes/BlocksNode.js +90 -86
  140. package/dist/features/blocks/server/nodes/BlocksNode.js.map +1 -1
  141. package/dist/features/blocks/server/nodes/InlineBlocksNode.js +87 -84
  142. package/dist/features/blocks/server/nodes/InlineBlocksNode.js.map +1 -1
  143. package/dist/features/blocks/server/validate.js +55 -42
  144. package/dist/features/blocks/server/validate.js.map +1 -1
  145. package/dist/features/converters/htmlToLexical/index.js +24 -21
  146. package/dist/features/converters/htmlToLexical/index.js.map +1 -1
  147. package/dist/features/converters/lexicalToHtml/async/converters/blockquote.js +10 -7
  148. package/dist/features/converters/lexicalToHtml/async/converters/blockquote.js.map +1 -1
  149. package/dist/features/converters/lexicalToHtml/async/converters/heading.js +10 -7
  150. package/dist/features/converters/lexicalToHtml/async/converters/heading.js.map +1 -1
  151. package/dist/features/converters/lexicalToHtml/async/converters/horizontalRule.js +1 -2
  152. package/dist/features/converters/lexicalToHtml/async/converters/horizontalRule.js.map +1 -1
  153. package/dist/features/converters/lexicalToHtml/async/converters/linebreak.js +1 -2
  154. package/dist/features/converters/lexicalToHtml/async/converters/linebreak.js.map +1 -1
  155. package/dist/features/converters/lexicalToHtml/async/converters/link.js +37 -28
  156. package/dist/features/converters/lexicalToHtml/async/converters/link.js.map +1 -1
  157. package/dist/features/converters/lexicalToHtml/async/converters/list.js +26 -18
  158. package/dist/features/converters/lexicalToHtml/async/converters/list.js.map +1 -1
  159. package/dist/features/converters/lexicalToHtml/async/converters/paragraph.js +12 -9
  160. package/dist/features/converters/lexicalToHtml/async/converters/paragraph.js.map +1 -1
  161. package/dist/features/converters/lexicalToHtml/async/converters/tab.js +1 -2
  162. package/dist/features/converters/lexicalToHtml/async/converters/tab.js.map +1 -1
  163. package/dist/features/converters/lexicalToHtml/async/converters/table.js +38 -27
  164. package/dist/features/converters/lexicalToHtml/async/converters/table.js.map +1 -1
  165. package/dist/features/converters/lexicalToHtml/async/converters/text.js +26 -25
  166. package/dist/features/converters/lexicalToHtml/async/converters/text.js.map +1 -1
  167. package/dist/features/converters/lexicalToHtml/async/converters/upload.js +43 -40
  168. package/dist/features/converters/lexicalToHtml/async/converters/upload.js.map +1 -1
  169. package/dist/features/converters/lexicalToHtml/async/defaultConverters.js +11 -12
  170. package/dist/features/converters/lexicalToHtml/async/defaultConverters.js.map +1 -1
  171. package/dist/features/converters/lexicalToHtml/async/field/index.js +56 -56
  172. package/dist/features/converters/lexicalToHtml/async/field/index.js.map +1 -1
  173. package/dist/features/converters/lexicalToHtml/async/index.js +97 -87
  174. package/dist/features/converters/lexicalToHtml/async/index.js.map +1 -1
  175. package/dist/features/converters/lexicalToHtml/async/types.js +1 -4
  176. package/dist/features/converters/lexicalToHtml/async/types.js.map +1 -1
  177. package/dist/features/converters/lexicalToHtml/shared/findConverterForNode.js +62 -57
  178. package/dist/features/converters/lexicalToHtml/shared/findConverterForNode.js.map +1 -1
  179. package/dist/features/converters/lexicalToHtml/shared/types.js +1 -2
  180. package/dist/features/converters/lexicalToHtml/shared/types.js.map +1 -1
  181. package/dist/features/converters/lexicalToHtml/sync/converters/blockquote.js +10 -7
  182. package/dist/features/converters/lexicalToHtml/sync/converters/blockquote.js.map +1 -1
  183. package/dist/features/converters/lexicalToHtml/sync/converters/heading.js +10 -7
  184. package/dist/features/converters/lexicalToHtml/sync/converters/heading.js.map +1 -1
  185. package/dist/features/converters/lexicalToHtml/sync/converters/horizontalRule.js +1 -2
  186. package/dist/features/converters/lexicalToHtml/sync/converters/horizontalRule.js.map +1 -1
  187. package/dist/features/converters/lexicalToHtml/sync/converters/linebreak.js +1 -2
  188. package/dist/features/converters/lexicalToHtml/sync/converters/linebreak.js.map +1 -1
  189. package/dist/features/converters/lexicalToHtml/sync/converters/link.js +35 -27
  190. package/dist/features/converters/lexicalToHtml/sync/converters/link.js.map +1 -1
  191. package/dist/features/converters/lexicalToHtml/sync/converters/list.js +26 -18
  192. package/dist/features/converters/lexicalToHtml/sync/converters/list.js.map +1 -1
  193. package/dist/features/converters/lexicalToHtml/sync/converters/paragraph.js +12 -9
  194. package/dist/features/converters/lexicalToHtml/sync/converters/paragraph.js.map +1 -1
  195. package/dist/features/converters/lexicalToHtml/sync/converters/tab.js +1 -2
  196. package/dist/features/converters/lexicalToHtml/sync/converters/tab.js.map +1 -1
  197. package/dist/features/converters/lexicalToHtml/sync/converters/table.js +38 -27
  198. package/dist/features/converters/lexicalToHtml/sync/converters/table.js.map +1 -1
  199. package/dist/features/converters/lexicalToHtml/sync/converters/text.js +26 -25
  200. package/dist/features/converters/lexicalToHtml/sync/converters/text.js.map +1 -1
  201. package/dist/features/converters/lexicalToHtml/sync/converters/upload.js +36 -34
  202. package/dist/features/converters/lexicalToHtml/sync/converters/upload.js.map +1 -1
  203. package/dist/features/converters/lexicalToHtml/sync/defaultConverters.js +11 -12
  204. package/dist/features/converters/lexicalToHtml/sync/defaultConverters.js.map +1 -1
  205. package/dist/features/converters/lexicalToHtml/sync/index.js +92 -84
  206. package/dist/features/converters/lexicalToHtml/sync/index.js.map +1 -1
  207. package/dist/features/converters/lexicalToHtml/sync/types.js +1 -4
  208. package/dist/features/converters/lexicalToHtml/sync/types.js.map +1 -1
  209. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/linebreak.js +4 -7
  210. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/linebreak.js.map +1 -1
  211. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/paragraph.js +34 -29
  212. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/paragraph.js.map +1 -1
  213. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/tab.js +6 -7
  214. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/tab.js.map +1 -1
  215. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/text.js +28 -29
  216. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/text.js.map +1 -1
  217. package/dist/features/converters/lexicalToHtml_deprecated/converter/defaultConverters.js +2 -7
  218. package/dist/features/converters/lexicalToHtml_deprecated/converter/defaultConverters.js.map +1 -1
  219. package/dist/features/converters/lexicalToHtml_deprecated/converter/index.js +84 -84
  220. package/dist/features/converters/lexicalToHtml_deprecated/converter/index.js.map +1 -1
  221. package/dist/features/converters/lexicalToHtml_deprecated/converter/types.js +1 -6
  222. package/dist/features/converters/lexicalToHtml_deprecated/converter/types.js.map +1 -1
  223. package/dist/features/converters/lexicalToHtml_deprecated/field/index.js +107 -107
  224. package/dist/features/converters/lexicalToHtml_deprecated/field/index.js.map +1 -1
  225. package/dist/features/converters/lexicalToHtml_deprecated/index.js +4 -4
  226. package/dist/features/converters/lexicalToHtml_deprecated/index.js.map +1 -1
  227. package/dist/features/converters/lexicalToJSX/Component/index.d.ts +14 -2
  228. package/dist/features/converters/lexicalToJSX/Component/index.d.ts.map +1 -1
  229. package/dist/features/converters/lexicalToJSX/Component/index.js +36 -41
  230. package/dist/features/converters/lexicalToJSX/Component/index.js.map +1 -1
  231. package/dist/features/converters/lexicalToJSX/converter/converters/blockquote.js +12 -14
  232. package/dist/features/converters/lexicalToJSX/converter/converters/blockquote.js.map +1 -1
  233. package/dist/features/converters/lexicalToJSX/converter/converters/heading.js +13 -15
  234. package/dist/features/converters/lexicalToJSX/converter/converters/heading.js.map +1 -1
  235. package/dist/features/converters/lexicalToJSX/converter/converters/horizontalRule.js +2 -7
  236. package/dist/features/converters/lexicalToJSX/converter/converters/horizontalRule.js.map +1 -1
  237. package/dist/features/converters/lexicalToJSX/converter/converters/linebreak.js +2 -7
  238. package/dist/features/converters/lexicalToJSX/converter/converters/linebreak.js.map +1 -1
  239. package/dist/features/converters/lexicalToJSX/converter/converters/link.js +47 -49
  240. package/dist/features/converters/lexicalToJSX/converter/converters/link.js.map +1 -1
  241. package/dist/features/converters/lexicalToJSX/converter/converters/list.js +56 -78
  242. package/dist/features/converters/lexicalToJSX/converter/converters/list.js.map +1 -1
  243. package/dist/features/converters/lexicalToJSX/converter/converters/paragraph.js +16 -26
  244. package/dist/features/converters/lexicalToJSX/converter/converters/paragraph.js.map +1 -1
  245. package/dist/features/converters/lexicalToJSX/converter/converters/tab.js +1 -2
  246. package/dist/features/converters/lexicalToJSX/converter/converters/tab.js.map +1 -1
  247. package/dist/features/converters/lexicalToJSX/converter/converters/table.js +59 -73
  248. package/dist/features/converters/lexicalToJSX/converter/converters/table.js.map +1 -1
  249. package/dist/features/converters/lexicalToJSX/converter/converters/text.js +47 -74
  250. package/dist/features/converters/lexicalToJSX/converter/converters/text.js.map +1 -1
  251. package/dist/features/converters/lexicalToJSX/converter/converters/upload.js +60 -76
  252. package/dist/features/converters/lexicalToJSX/converter/converters/upload.js.map +1 -1
  253. package/dist/features/converters/lexicalToJSX/converter/defaultConverters.js +11 -12
  254. package/dist/features/converters/lexicalToJSX/converter/defaultConverters.js.map +1 -1
  255. package/dist/features/converters/lexicalToJSX/converter/index.d.ts +1 -16
  256. package/dist/features/converters/lexicalToJSX/converter/index.d.ts.map +1 -1
  257. package/dist/features/converters/lexicalToJSX/converter/index.js +125 -202
  258. package/dist/features/converters/lexicalToJSX/converter/index.js.map +1 -1
  259. package/dist/features/converters/lexicalToJSX/converter/types.d.ts +10 -14
  260. package/dist/features/converters/lexicalToJSX/converter/types.d.ts.map +1 -1
  261. package/dist/features/converters/lexicalToJSX/converter/types.js +1 -4
  262. package/dist/features/converters/lexicalToJSX/converter/types.js.map +1 -1
  263. package/dist/features/converters/lexicalToMarkdown/index.js +19 -17
  264. package/dist/features/converters/lexicalToMarkdown/index.js.map +1 -1
  265. package/dist/features/converters/lexicalToPlaintext/convertLexicalToPlaintext.spec.js +146 -223
  266. package/dist/features/converters/lexicalToPlaintext/convertLexicalToPlaintext.spec.js.map +1 -1
  267. package/dist/features/converters/lexicalToPlaintext/shared/findConverterForNode.js +13 -11
  268. package/dist/features/converters/lexicalToPlaintext/shared/findConverterForNode.js.map +1 -1
  269. package/dist/features/converters/lexicalToPlaintext/shared/types.js +1 -2
  270. package/dist/features/converters/lexicalToPlaintext/shared/types.js.map +1 -1
  271. package/dist/features/converters/lexicalToPlaintext/sync/index.js +82 -83
  272. package/dist/features/converters/lexicalToPlaintext/sync/index.js.map +1 -1
  273. package/dist/features/converters/lexicalToPlaintext/sync/types.js +1 -3
  274. package/dist/features/converters/lexicalToPlaintext/sync/types.js.map +1 -1
  275. package/dist/features/converters/markdownToLexical/index.js +16 -14
  276. package/dist/features/converters/markdownToLexical/index.js.map +1 -1
  277. package/dist/features/converters/utilities/payloadPopulateFn.js +38 -37
  278. package/dist/features/converters/utilities/payloadPopulateFn.js.map +1 -1
  279. package/dist/features/converters/utilities/restPopulateFn.js +30 -24
  280. package/dist/features/converters/utilities/restPopulateFn.js.map +1 -1
  281. package/dist/features/debug/jsxConverter/client/index.js +5 -7
  282. package/dist/features/debug/jsxConverter/client/index.js.map +1 -1
  283. package/dist/features/debug/jsxConverter/client/plugin/index.js +47 -27
  284. package/dist/features/debug/jsxConverter/client/plugin/index.js.map +1 -1
  285. package/dist/features/debug/jsxConverter/server/index.js +4 -5
  286. package/dist/features/debug/jsxConverter/server/index.js.map +1 -1
  287. package/dist/features/debug/testRecorder/client/index.js +5 -7
  288. package/dist/features/debug/testRecorder/client/index.js.map +1 -1
  289. package/dist/features/debug/testRecorder/client/plugin/index.js +365 -456
  290. package/dist/features/debug/testRecorder/client/plugin/index.js.map +1 -1
  291. package/dist/features/debug/testRecorder/server/index.js +4 -5
  292. package/dist/features/debug/testRecorder/server/index.js.map +1 -1
  293. package/dist/features/debug/treeView/client/index.js +5 -7
  294. package/dist/features/debug/treeView/client/index.js.map +1 -1
  295. package/dist/features/debug/treeView/client/plugin/index.js +23 -18
  296. package/dist/features/debug/treeView/client/plugin/index.js.map +1 -1
  297. package/dist/features/debug/treeView/server/index.js +4 -5
  298. package/dist/features/debug/treeView/server/index.js.map +1 -1
  299. package/dist/features/experimental_table/client/index.js +42 -61
  300. package/dist/features/experimental_table/client/index.js.map +1 -1
  301. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.js +517 -752
  302. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.js.map +1 -1
  303. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.js +316 -350
  304. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.js.map +1 -1
  305. package/dist/features/experimental_table/client/plugins/TableHoverActionsPlugin/index.js +225 -215
  306. package/dist/features/experimental_table/client/plugins/TableHoverActionsPlugin/index.js.map +1 -1
  307. package/dist/features/experimental_table/client/plugins/TablePlugin/index.js +133 -104
  308. package/dist/features/experimental_table/client/plugins/TablePlugin/index.js.map +1 -1
  309. package/dist/features/experimental_table/client/utils/debounce.js +107 -89
  310. package/dist/features/experimental_table/client/utils/debounce.js.map +1 -1
  311. package/dist/features/experimental_table/client/utils/useDebounce.js +39 -21
  312. package/dist/features/experimental_table/client/utils/useDebounce.js.map +1 -1
  313. package/dist/features/experimental_table/markdownTransformer.js +118 -123
  314. package/dist/features/experimental_table/markdownTransformer.js.map +1 -1
  315. package/dist/features/experimental_table/server/index.js +143 -125
  316. package/dist/features/experimental_table/server/index.js.map +1 -1
  317. package/dist/features/format/bold/feature.client.js +35 -38
  318. package/dist/features/format/bold/feature.client.js.map +1 -1
  319. package/dist/features/format/bold/feature.server.js +14 -18
  320. package/dist/features/format/bold/feature.server.js.map +1 -1
  321. package/dist/features/format/bold/markdownTransformers.js +14 -25
  322. package/dist/features/format/bold/markdownTransformers.js.map +1 -1
  323. package/dist/features/format/inlineCode/feature.client.js +27 -31
  324. package/dist/features/format/inlineCode/feature.client.js.map +1 -1
  325. package/dist/features/format/inlineCode/feature.server.js +5 -8
  326. package/dist/features/format/inlineCode/feature.server.js.map +1 -1
  327. package/dist/features/format/inlineCode/markdownTransformers.js +3 -6
  328. package/dist/features/format/inlineCode/markdownTransformers.js.map +1 -1
  329. package/dist/features/format/italic/feature.client.js +27 -32
  330. package/dist/features/format/italic/feature.client.js.map +1 -1
  331. package/dist/features/format/italic/feature.server.js +5 -9
  332. package/dist/features/format/italic/feature.server.js.map +1 -1
  333. package/dist/features/format/italic/markdownTransformers.js +7 -12
  334. package/dist/features/format/italic/markdownTransformers.js.map +1 -1
  335. package/dist/features/format/shared/toolbarFormatGroup.js +8 -8
  336. package/dist/features/format/shared/toolbarFormatGroup.js.map +1 -1
  337. package/dist/features/format/strikethrough/feature.client.js +27 -31
  338. package/dist/features/format/strikethrough/feature.client.js.map +1 -1
  339. package/dist/features/format/strikethrough/feature.server.js +5 -8
  340. package/dist/features/format/strikethrough/feature.server.js.map +1 -1
  341. package/dist/features/format/strikethrough/markdownTransformers.js +3 -6
  342. package/dist/features/format/strikethrough/markdownTransformers.js.map +1 -1
  343. package/dist/features/format/subscript/feature.client.js +26 -28
  344. package/dist/features/format/subscript/feature.client.js.map +1 -1
  345. package/dist/features/format/subscript/feature.server.js +4 -5
  346. package/dist/features/format/subscript/feature.server.js.map +1 -1
  347. package/dist/features/format/superscript/feature.client.js +26 -28
  348. package/dist/features/format/superscript/feature.client.js.map +1 -1
  349. package/dist/features/format/superscript/feature.server.js +4 -5
  350. package/dist/features/format/superscript/feature.server.js.map +1 -1
  351. package/dist/features/format/underline/feature.client.js +26 -28
  352. package/dist/features/format/underline/feature.client.js.map +1 -1
  353. package/dist/features/format/underline/feature.server.js +4 -5
  354. package/dist/features/format/underline/feature.server.js.map +1 -1
  355. package/dist/features/heading/client/index.js +142 -121
  356. package/dist/features/heading/client/index.js.map +1 -1
  357. package/dist/features/heading/markdownTransformer.js +22 -25
  358. package/dist/features/heading/markdownTransformer.js.map +1 -1
  359. package/dist/features/heading/server/i18n.js +111 -112
  360. package/dist/features/heading/server/i18n.js.map +1 -1
  361. package/dist/features/heading/server/index.js +60 -62
  362. package/dist/features/heading/server/index.js.map +1 -1
  363. package/dist/features/horizontalRule/client/index.js +48 -57
  364. package/dist/features/horizontalRule/client/index.js.map +1 -1
  365. package/dist/features/horizontalRule/client/markdownTransformer.js +15 -18
  366. package/dist/features/horizontalRule/client/markdownTransformer.js.map +1 -1
  367. package/dist/features/horizontalRule/client/nodes/HorizontalRuleNode.js +27 -25
  368. package/dist/features/horizontalRule/client/nodes/HorizontalRuleNode.js.map +1 -1
  369. package/dist/features/horizontalRule/client/plugin/index.js +32 -21
  370. package/dist/features/horizontalRule/client/plugin/index.js.map +1 -1
  371. package/dist/features/horizontalRule/server/i18n.js +111 -112
  372. package/dist/features/horizontalRule/server/i18n.js.map +1 -1
  373. package/dist/features/horizontalRule/server/index.js +17 -24
  374. package/dist/features/horizontalRule/server/index.js.map +1 -1
  375. package/dist/features/horizontalRule/server/markdownTransformer.js +15 -18
  376. package/dist/features/horizontalRule/server/markdownTransformer.js.map +1 -1
  377. package/dist/features/horizontalRule/server/nodes/HorizontalRuleNode.js +72 -69
  378. package/dist/features/horizontalRule/server/nodes/HorizontalRuleNode.js.map +1 -1
  379. package/dist/features/indent/client/IndentPlugin.js +78 -78
  380. package/dist/features/indent/client/IndentPlugin.js.map +1 -1
  381. package/dist/features/indent/client/index.js +77 -68
  382. package/dist/features/indent/client/index.js.map +1 -1
  383. package/dist/features/indent/client/toolbarIndentGroup.js +8 -8
  384. package/dist/features/indent/client/toolbarIndentGroup.js.map +1 -1
  385. package/dist/features/indent/server/i18n.js +148 -149
  386. package/dist/features/indent/server/i18n.js.map +1 -1
  387. package/dist/features/indent/server/index.js +11 -18
  388. package/dist/features/indent/server/index.js.map +1 -1
  389. package/dist/features/link/client/index.js +80 -83
  390. package/dist/features/link/client/index.js.map +1 -1
  391. package/dist/features/link/client/plugins/autoLink/index.js +273 -280
  392. package/dist/features/link/client/plugins/autoLink/index.js.map +1 -1
  393. package/dist/features/link/client/plugins/clickableLink/index.js +4 -8
  394. package/dist/features/link/client/plugins/clickableLink/index.js.map +1 -1
  395. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/commands.js +1 -1
  396. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/commands.js.map +1 -1
  397. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/index.js +293 -374
  398. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/index.js.map +1 -1
  399. package/dist/features/link/client/plugins/floatingLinkEditor/index.js +9 -12
  400. package/dist/features/link/client/plugins/floatingLinkEditor/index.js.map +1 -1
  401. package/dist/features/link/client/plugins/floatingLinkEditor/types.js +1 -6
  402. package/dist/features/link/client/plugins/floatingLinkEditor/types.js.map +1 -1
  403. package/dist/features/link/client/plugins/link/index.js +68 -53
  404. package/dist/features/link/client/plugins/link/index.js.map +1 -1
  405. package/dist/features/link/markdownTransformer.js +33 -34
  406. package/dist/features/link/markdownTransformer.js.map +1 -1
  407. package/dist/features/link/nodes/AutoLinkNode.js +58 -56
  408. package/dist/features/link/nodes/AutoLinkNode.js.map +1 -1
  409. package/dist/features/link/nodes/LinkNode.js +288 -286
  410. package/dist/features/link/nodes/LinkNode.js.map +1 -1
  411. package/dist/features/link/nodes/types.js +1 -6
  412. package/dist/features/link/nodes/types.js.map +1 -1
  413. package/dist/features/link/server/baseFields.js +140 -115
  414. package/dist/features/link/server/baseFields.js.map +1 -1
  415. package/dist/features/link/server/graphQLPopulationPromise.js +45 -29
  416. package/dist/features/link/server/graphQLPopulationPromise.js.map +1 -1
  417. package/dist/features/link/server/i18n.js +148 -149
  418. package/dist/features/link/server/i18n.js.map +1 -1
  419. package/dist/features/link/server/index.js +143 -156
  420. package/dist/features/link/server/index.js.map +1 -1
  421. package/dist/features/link/server/transformExtraFields.js +15 -15
  422. package/dist/features/link/server/transformExtraFields.js.map +1 -1
  423. package/dist/features/link/server/validate.js +46 -35
  424. package/dist/features/link/server/validate.js.map +1 -1
  425. package/dist/features/lists/checklist/client/index.js +78 -86
  426. package/dist/features/lists/checklist/client/index.js.map +1 -1
  427. package/dist/features/lists/checklist/client/plugin/index.js +4 -8
  428. package/dist/features/lists/checklist/client/plugin/index.js.map +1 -1
  429. package/dist/features/lists/checklist/markdownTransformers.js +7 -11
  430. package/dist/features/lists/checklist/markdownTransformers.js.map +1 -1
  431. package/dist/features/lists/checklist/server/i18n.js +111 -112
  432. package/dist/features/lists/checklist/server/i18n.js.map +1 -1
  433. package/dist/features/lists/checklist/server/index.js +21 -26
  434. package/dist/features/lists/checklist/server/index.js.map +1 -1
  435. package/dist/features/lists/htmlConverter.js +62 -47
  436. package/dist/features/lists/htmlConverter.js.map +1 -1
  437. package/dist/features/lists/orderedList/client/index.js +72 -78
  438. package/dist/features/lists/orderedList/client/index.js.map +1 -1
  439. package/dist/features/lists/orderedList/markdownTransformer.js +7 -11
  440. package/dist/features/lists/orderedList/markdownTransformer.js.map +1 -1
  441. package/dist/features/lists/orderedList/server/i18n.js +111 -112
  442. package/dist/features/lists/orderedList/server/i18n.js.map +1 -1
  443. package/dist/features/lists/orderedList/server/index.js +21 -26
  444. package/dist/features/lists/orderedList/server/index.js.map +1 -1
  445. package/dist/features/lists/plugin/index.js +4 -8
  446. package/dist/features/lists/plugin/index.js.map +1 -1
  447. package/dist/features/lists/shared/markdown.js +48 -49
  448. package/dist/features/lists/shared/markdown.js.map +1 -1
  449. package/dist/features/lists/shared/shouldRegisterListBaseNodes.js +9 -10
  450. package/dist/features/lists/shared/shouldRegisterListBaseNodes.js.map +1 -1
  451. package/dist/features/lists/shared/slashMenuListGroup.js +9 -8
  452. package/dist/features/lists/shared/slashMenuListGroup.js.map +1 -1
  453. package/dist/features/lists/unorderedList/client/index.js +68 -76
  454. package/dist/features/lists/unorderedList/client/index.js.map +1 -1
  455. package/dist/features/lists/unorderedList/markdownTransformer.js +7 -11
  456. package/dist/features/lists/unorderedList/markdownTransformer.js.map +1 -1
  457. package/dist/features/lists/unorderedList/server/i18n.js +111 -112
  458. package/dist/features/lists/unorderedList/server/i18n.js.map +1 -1
  459. package/dist/features/lists/unorderedList/server/index.js +17 -24
  460. package/dist/features/lists/unorderedList/server/index.js.map +1 -1
  461. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/heading/converter.js +18 -17
  462. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/heading/converter.js.map +1 -1
  463. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/link/converter.js +30 -29
  464. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/link/converter.js.map +1 -1
  465. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/list/converter.js +21 -20
  466. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/list/converter.js.map +1 -1
  467. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/listItem/converter.js +21 -19
  468. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/listItem/converter.js.map +1 -1
  469. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/quote/converter.js +18 -17
  470. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/quote/converter.js.map +1 -1
  471. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/unknown/converter.js +24 -23
  472. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/unknown/converter.js.map +1 -1
  473. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/upload/converter.js +20 -21
  474. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/upload/converter.js.map +1 -1
  475. package/dist/features/migrations/lexicalPluginToLexical/converter/defaultConverters.js +1 -10
  476. package/dist/features/migrations/lexicalPluginToLexical/converter/defaultConverters.js.map +1 -1
  477. package/dist/features/migrations/lexicalPluginToLexical/converter/index.js +70 -64
  478. package/dist/features/migrations/lexicalPluginToLexical/converter/index.js.map +1 -1
  479. package/dist/features/migrations/lexicalPluginToLexical/converter/types.js +1 -2
  480. package/dist/features/migrations/lexicalPluginToLexical/converter/types.js.map +1 -1
  481. package/dist/features/migrations/lexicalPluginToLexical/feature.client.js +5 -7
  482. package/dist/features/migrations/lexicalPluginToLexical/feature.client.js.map +1 -1
  483. package/dist/features/migrations/lexicalPluginToLexical/feature.server.js +42 -43
  484. package/dist/features/migrations/lexicalPluginToLexical/feature.server.js.map +1 -1
  485. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/Component.js +11 -21
  486. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/Component.js.map +1 -1
  487. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.js +66 -65
  488. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.js.map +1 -1
  489. package/dist/features/migrations/slateToLexical/converter/converters/blockquote/converter.js +19 -19
  490. package/dist/features/migrations/slateToLexical/converter/converters/blockquote/converter.js.map +1 -1
  491. package/dist/features/migrations/slateToLexical/converter/converters/heading/converter.js +20 -26
  492. package/dist/features/migrations/slateToLexical/converter/converters/heading/converter.js.map +1 -1
  493. package/dist/features/migrations/slateToLexical/converter/converters/indent/converter.js +28 -30
  494. package/dist/features/migrations/slateToLexical/converter/converters/indent/converter.js.map +1 -1
  495. package/dist/features/migrations/slateToLexical/converter/converters/link/converter.js +26 -27
  496. package/dist/features/migrations/slateToLexical/converter/converters/link/converter.js.map +1 -1
  497. package/dist/features/migrations/slateToLexical/converter/converters/listItem/converter.js +22 -21
  498. package/dist/features/migrations/slateToLexical/converter/converters/listItem/converter.js.map +1 -1
  499. package/dist/features/migrations/slateToLexical/converter/converters/orderedList/converter.js +22 -22
  500. package/dist/features/migrations/slateToLexical/converter/converters/orderedList/converter.js.map +1 -1
  501. package/dist/features/migrations/slateToLexical/converter/converters/relationship/converter.js +12 -13
  502. package/dist/features/migrations/slateToLexical/converter/converters/relationship/converter.js.map +1 -1
  503. package/dist/features/migrations/slateToLexical/converter/converters/unknown/converter.js +23 -23
  504. package/dist/features/migrations/slateToLexical/converter/converters/unknown/converter.js.map +1 -1
  505. package/dist/features/migrations/slateToLexical/converter/converters/unorderedList/converter.js +22 -22
  506. package/dist/features/migrations/slateToLexical/converter/converters/unorderedList/converter.js.map +1 -1
  507. package/dist/features/migrations/slateToLexical/converter/converters/upload/converter.js +15 -16
  508. package/dist/features/migrations/slateToLexical/converter/converters/upload/converter.js.map +1 -1
  509. package/dist/features/migrations/slateToLexical/converter/defaultConverters.js +1 -13
  510. package/dist/features/migrations/slateToLexical/converter/defaultConverters.js.map +1 -1
  511. package/dist/features/migrations/slateToLexical/converter/index.js +117 -110
  512. package/dist/features/migrations/slateToLexical/converter/index.js.map +1 -1
  513. package/dist/features/migrations/slateToLexical/converter/types.js +1 -2
  514. package/dist/features/migrations/slateToLexical/converter/types.js.map +1 -1
  515. package/dist/features/migrations/slateToLexical/feature.client.js +5 -7
  516. package/dist/features/migrations/slateToLexical/feature.client.js.map +1 -1
  517. package/dist/features/migrations/slateToLexical/feature.server.js +45 -54
  518. package/dist/features/migrations/slateToLexical/feature.server.js.map +1 -1
  519. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/Component.js +11 -21
  520. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/Component.js.map +1 -1
  521. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.js +66 -65
  522. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.js.map +1 -1
  523. package/dist/features/paragraph/client/index.js +58 -61
  524. package/dist/features/paragraph/client/index.js.map +1 -1
  525. package/dist/features/paragraph/server/i18n.js +148 -149
  526. package/dist/features/paragraph/server/i18n.js.map +1 -1
  527. package/dist/features/paragraph/server/index.js +6 -7
  528. package/dist/features/paragraph/server/index.js.map +1 -1
  529. package/dist/features/relationship/client/components/RelationshipComponent.js +114 -143
  530. package/dist/features/relationship/client/components/RelationshipComponent.js.map +1 -1
  531. package/dist/features/relationship/client/drawer/commands.js +0 -1
  532. package/dist/features/relationship/client/drawer/commands.js.map +1 -1
  533. package/dist/features/relationship/client/drawer/index.js +132 -81
  534. package/dist/features/relationship/client/drawer/index.js.map +1 -1
  535. package/dist/features/relationship/client/index.js +53 -59
  536. package/dist/features/relationship/client/index.js.map +1 -1
  537. package/dist/features/relationship/client/nodes/RelationshipNode.js +60 -64
  538. package/dist/features/relationship/client/nodes/RelationshipNode.js.map +1 -1
  539. package/dist/features/relationship/client/plugins/index.js +69 -39
  540. package/dist/features/relationship/client/plugins/index.js.map +1 -1
  541. package/dist/features/relationship/client/utils/useEnabledRelationships.js +58 -48
  542. package/dist/features/relationship/client/utils/useEnabledRelationships.js.map +1 -1
  543. package/dist/features/relationship/server/graphQLPopulationPromise.js +34 -26
  544. package/dist/features/relationship/server/graphQLPopulationPromise.js.map +1 -1
  545. package/dist/features/relationship/server/i18n.js +111 -112
  546. package/dist/features/relationship/server/i18n.js.map +1 -1
  547. package/dist/features/relationship/server/index.js +59 -64
  548. package/dist/features/relationship/server/index.js.map +1 -1
  549. package/dist/features/relationship/server/nodes/RelationshipNode.js +95 -92
  550. package/dist/features/relationship/server/nodes/RelationshipNode.js.map +1 -1
  551. package/dist/features/shared/slashMenu/basicGroup.js +9 -8
  552. package/dist/features/shared/slashMenu/basicGroup.js.map +1 -1
  553. package/dist/features/shared/toolbar/addDropdownGroup.js +8 -9
  554. package/dist/features/shared/toolbar/addDropdownGroup.js.map +1 -1
  555. package/dist/features/shared/toolbar/featureButtonsGroup.js +7 -8
  556. package/dist/features/shared/toolbar/featureButtonsGroup.js.map +1 -1
  557. package/dist/features/shared/toolbar/textDropdownGroup.js +8 -9
  558. package/dist/features/shared/toolbar/textDropdownGroup.js.map +1 -1
  559. package/dist/features/textState/defaultColors.js +370 -370
  560. package/dist/features/textState/defaultColors.js.map +1 -1
  561. package/dist/features/textState/feature.client.js +64 -77
  562. package/dist/features/textState/feature.client.js.map +1 -1
  563. package/dist/features/textState/feature.server.js +14 -46
  564. package/dist/features/textState/feature.server.js.map +1 -1
  565. package/dist/features/textState/i18n.js +111 -112
  566. package/dist/features/textState/i18n.js.map +1 -1
  567. package/dist/features/textState/textState.js +62 -64
  568. package/dist/features/textState/textState.js.map +1 -1
  569. package/dist/features/toolbars/fixed/client/Toolbar/index.js +297 -263
  570. package/dist/features/toolbars/fixed/client/Toolbar/index.js.map +1 -1
  571. package/dist/features/toolbars/fixed/client/index.js +5 -7
  572. package/dist/features/toolbars/fixed/client/index.js.map +1 -1
  573. package/dist/features/toolbars/fixed/server/index.js +16 -32
  574. package/dist/features/toolbars/fixed/server/index.js.map +1 -1
  575. package/dist/features/toolbars/inline/client/Toolbar/index.js +366 -343
  576. package/dist/features/toolbars/inline/client/Toolbar/index.js.map +1 -1
  577. package/dist/features/toolbars/inline/client/index.js +5 -7
  578. package/dist/features/toolbars/inline/client/index.js.map +1 -1
  579. package/dist/features/toolbars/inline/server/index.js +4 -5
  580. package/dist/features/toolbars/inline/server/index.js.map +1 -1
  581. package/dist/features/toolbars/shared/ToolbarButton/index.js +145 -103
  582. package/dist/features/toolbars/shared/ToolbarButton/index.js.map +1 -1
  583. package/dist/features/toolbars/shared/ToolbarDropdown/DropDown.js +208 -264
  584. package/dist/features/toolbars/shared/ToolbarDropdown/DropDown.js.map +1 -1
  585. package/dist/features/toolbars/shared/ToolbarDropdown/index.js +176 -172
  586. package/dist/features/toolbars/shared/ToolbarDropdown/index.js.map +1 -1
  587. package/dist/features/toolbars/types.js +1 -29
  588. package/dist/features/toolbars/types.js.map +1 -1
  589. package/dist/features/typeUtilities.js +2 -3
  590. package/dist/features/typeUtilities.js.map +1 -1
  591. package/dist/features/typesClient.js +1 -61
  592. package/dist/features/typesClient.js.map +1 -1
  593. package/dist/features/typesServer.js +1 -90
  594. package/dist/features/typesServer.js.map +1 -1
  595. package/dist/features/upload/client/component/index.js +185 -238
  596. package/dist/features/upload/client/component/index.js.map +1 -1
  597. package/dist/features/upload/client/component/pending/index.js +10 -19
  598. package/dist/features/upload/client/component/pending/index.js.map +1 -1
  599. package/dist/features/upload/client/drawer/commands.js +1 -1
  600. package/dist/features/upload/client/drawer/commands.js.map +1 -1
  601. package/dist/features/upload/client/drawer/index.js +132 -83
  602. package/dist/features/upload/client/drawer/index.js.map +1 -1
  603. package/dist/features/upload/client/index.js +51 -61
  604. package/dist/features/upload/client/index.js.map +1 -1
  605. package/dist/features/upload/client/nodes/UploadNode.js +61 -67
  606. package/dist/features/upload/client/nodes/UploadNode.js.map +1 -1
  607. package/dist/features/upload/client/plugin/index.js +331 -290
  608. package/dist/features/upload/client/plugin/index.js.map +1 -1
  609. package/dist/features/upload/server/graphQLPopulationPromise.js +63 -48
  610. package/dist/features/upload/server/graphQLPopulationPromise.js.map +1 -1
  611. package/dist/features/upload/server/i18n.js +111 -112
  612. package/dist/features/upload/server/i18n.js.map +1 -1
  613. package/dist/features/upload/server/index.js +206 -196
  614. package/dist/features/upload/server/index.js.map +1 -1
  615. package/dist/features/upload/server/nodes/UploadNode.js +99 -115
  616. package/dist/features/upload/server/nodes/UploadNode.js.map +1 -1
  617. package/dist/features/upload/server/nodes/conversions.js +40 -41
  618. package/dist/features/upload/server/nodes/conversions.js.map +1 -1
  619. package/dist/features/upload/server/validate.js +62 -48
  620. package/dist/features/upload/server/validate.js.map +1 -1
  621. package/dist/field/Diff/converters/link.js +41 -32
  622. package/dist/field/Diff/converters/link.js.map +1 -1
  623. package/dist/field/Diff/converters/listitem/index.js +55 -75
  624. package/dist/field/Diff/converters/listitem/index.js.map +1 -1
  625. package/dist/field/Diff/converters/relationship/index.js +63 -85
  626. package/dist/field/Diff/converters/relationship/index.js.map +1 -1
  627. package/dist/field/Diff/converters/unknown/index.js +41 -64
  628. package/dist/field/Diff/converters/unknown/index.js.map +1 -1
  629. package/dist/field/Diff/converters/upload/index.js +69 -122
  630. package/dist/field/Diff/converters/upload/index.js.map +1 -1
  631. package/dist/field/Diff/index.js +66 -59
  632. package/dist/field/Diff/index.js.map +1 -1
  633. package/dist/field/Field.d.ts.map +1 -1
  634. package/dist/field/Field.js +167 -242
  635. package/dist/field/Field.js.map +1 -1
  636. package/dist/field/RenderLexical/index.js +119 -123
  637. package/dist/field/RenderLexical/index.js.map +1 -1
  638. package/dist/field/bundled.css +1 -0
  639. package/dist/field/index.d.ts +0 -1
  640. package/dist/field/index.d.ts.map +1 -1
  641. package/dist/field/index.js +97 -86
  642. package/dist/field/index.js.map +1 -1
  643. package/dist/field/rscEntry.d.ts +1 -1
  644. package/dist/field/rscEntry.d.ts.map +1 -1
  645. package/dist/field/rscEntry.js +84 -98
  646. package/dist/field/rscEntry.js.map +1 -1
  647. package/dist/i18n.js +222 -223
  648. package/dist/i18n.js.map +1 -1
  649. package/dist/index.d.ts +1 -1
  650. package/dist/index.d.ts.map +1 -1
  651. package/dist/index.js +704 -641
  652. package/dist/index.js.map +1 -1
  653. package/dist/lexical/EditorPlugin.js +17 -21
  654. package/dist/lexical/EditorPlugin.js.map +1 -1
  655. package/dist/lexical/LexicalEditor.d.ts.map +1 -1
  656. package/dist/lexical/LexicalEditor.js +171 -280
  657. package/dist/lexical/LexicalEditor.js.map +1 -1
  658. package/dist/lexical/LexicalProvider.d.ts.map +1 -1
  659. package/dist/lexical/LexicalProvider.js +86 -117
  660. package/dist/lexical/LexicalProvider.js.map +1 -1
  661. package/dist/lexical/config/client/EditorConfigProvider.js +81 -94
  662. package/dist/lexical/config/client/EditorConfigProvider.js.map +1 -1
  663. package/dist/lexical/config/client/default.js +3 -3
  664. package/dist/lexical/config/client/default.js.map +1 -1
  665. package/dist/lexical/config/client/loader.js +38 -30
  666. package/dist/lexical/config/client/loader.js.map +1 -1
  667. package/dist/lexical/config/client/sanitize.d.ts +1 -1
  668. package/dist/lexical/config/client/sanitize.d.ts.map +1 -1
  669. package/dist/lexical/config/client/sanitize.js +188 -190
  670. package/dist/lexical/config/client/sanitize.js.map +1 -1
  671. package/dist/lexical/config/server/default.js +5 -27
  672. package/dist/lexical/config/server/default.js.map +1 -1
  673. package/dist/lexical/config/server/loader.js +106 -105
  674. package/dist/lexical/config/server/loader.js.map +1 -1
  675. package/dist/lexical/config/server/sanitize.js +113 -114
  676. package/dist/lexical/config/server/sanitize.js.map +1 -1
  677. package/dist/lexical/config/types.d.ts +0 -4
  678. package/dist/lexical/config/types.d.ts.map +1 -1
  679. package/dist/lexical/config/types.js +1 -6
  680. package/dist/lexical/config/types.js.map +1 -1
  681. package/dist/lexical/nodes/index.d.ts +2 -12
  682. package/dist/lexical/nodes/index.d.ts.map +1 -1
  683. package/dist/lexical/nodes/index.js +15 -197
  684. package/dist/lexical/nodes/index.js.map +1 -1
  685. package/dist/lexical/plugins/ClipboardPlugin/index.js +70 -66
  686. package/dist/lexical/plugins/ClipboardPlugin/index.js.map +1 -1
  687. package/dist/lexical/plugins/DecoratorPlugin/index.js +225 -208
  688. package/dist/lexical/plugins/DecoratorPlugin/index.js.map +1 -1
  689. package/dist/lexical/plugins/InsertParagraphAtEnd/index.js +41 -42
  690. package/dist/lexical/plugins/InsertParagraphAtEnd/index.js.map +1 -1
  691. package/dist/lexical/plugins/MarkdownShortcut/index.js +23 -11
  692. package/dist/lexical/plugins/MarkdownShortcut/index.js.map +1 -1
  693. package/dist/lexical/plugins/NormalizeSelection/index.js +19 -21
  694. package/dist/lexical/plugins/NormalizeSelection/index.js.map +1 -1
  695. package/dist/lexical/plugins/SelectAllPlugin/index.js +17 -19
  696. package/dist/lexical/plugins/SelectAllPlugin/index.js.map +1 -1
  697. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/LexicalMenu.js +420 -399
  698. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/LexicalMenu.js.map +1 -1
  699. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/index.js +155 -164
  700. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/index.js.map +1 -1
  701. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/types.js +1 -10
  702. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/types.js.map +1 -1
  703. package/dist/lexical/plugins/SlashMenu/index.js +181 -204
  704. package/dist/lexical/plugins/SlashMenu/index.js.map +1 -1
  705. package/dist/lexical/plugins/SlashMenu/useMenuTriggerMatch.js +41 -28
  706. package/dist/lexical/plugins/SlashMenu/useMenuTriggerMatch.js.map +1 -1
  707. package/dist/lexical/plugins/TextPlugin/index.js +42 -27
  708. package/dist/lexical/plugins/TextPlugin/index.js.map +1 -1
  709. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.js +130 -145
  710. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.js.map +1 -1
  711. package/dist/lexical/plugins/handles/DraggableBlockPlugin/debounce.js +10 -10
  712. package/dist/lexical/plugins/handles/DraggableBlockPlugin/debounce.js.map +1 -1
  713. package/dist/lexical/plugins/handles/DraggableBlockPlugin/getBoundingRectWithoutTransform.js +10 -10
  714. package/dist/lexical/plugins/handles/DraggableBlockPlugin/getBoundingRectWithoutTransform.js.map +1 -1
  715. package/dist/lexical/plugins/handles/DraggableBlockPlugin/highlightElemOriginalPosition.js +26 -23
  716. package/dist/lexical/plugins/handles/DraggableBlockPlugin/highlightElemOriginalPosition.js.map +1 -1
  717. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.js +317 -325
  718. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.js.map +1 -1
  719. package/dist/lexical/plugins/handles/DraggableBlockPlugin/setTargetLine.js +98 -86
  720. package/dist/lexical/plugins/handles/DraggableBlockPlugin/setTargetLine.js.map +1 -1
  721. package/dist/lexical/plugins/handles/utils/calculateDistanceFromScrollerElem.js +22 -16
  722. package/dist/lexical/plugins/handles/utils/calculateDistanceFromScrollerElem.js.map +1 -1
  723. package/dist/lexical/plugins/handles/utils/doesLineHeightAffectElement.js +19 -29
  724. package/dist/lexical/plugins/handles/utils/doesLineHeightAffectElement.js.map +1 -1
  725. package/dist/lexical/plugins/handles/utils/getCollapsedMargins.js +14 -11
  726. package/dist/lexical/plugins/handles/utils/getCollapsedMargins.js.map +1 -1
  727. package/dist/lexical/plugins/handles/utils/getNodeCloseToPoint.js +133 -122
  728. package/dist/lexical/plugins/handles/utils/getNodeCloseToPoint.js.map +1 -1
  729. package/dist/lexical/plugins/handles/utils/getTopLevelNodeKeys.js +2 -2
  730. package/dist/lexical/plugins/handles/utils/getTopLevelNodeKeys.js.map +1 -1
  731. package/dist/lexical/plugins/handles/utils/isOnHandleElement.js +2 -2
  732. package/dist/lexical/plugins/handles/utils/isOnHandleElement.js.map +1 -1
  733. package/dist/lexical/plugins/handles/utils/setHandlePosition.js +24 -29
  734. package/dist/lexical/plugins/handles/utils/setHandlePosition.js.map +1 -1
  735. package/dist/lexical/theme/EditorTheme.js +65 -72
  736. package/dist/lexical/theme/EditorTheme.js.map +1 -1
  737. package/dist/lexical/ui/ContentEditable.js +35 -22
  738. package/dist/lexical/ui/ContentEditable.js.map +1 -1
  739. package/dist/lexical/ui/icons/AI/index.js +31 -58
  740. package/dist/lexical/ui/icons/AI/index.js.map +1 -1
  741. package/dist/lexical/ui/icons/Add/index.js +16 -31
  742. package/dist/lexical/ui/icons/Add/index.js.map +1 -1
  743. package/dist/lexical/ui/icons/AlignCenter/index.js +25 -45
  744. package/dist/lexical/ui/icons/AlignCenter/index.js.map +1 -1
  745. package/dist/lexical/ui/icons/AlignJustify/index.js +25 -45
  746. package/dist/lexical/ui/icons/AlignJustify/index.js.map +1 -1
  747. package/dist/lexical/ui/icons/AlignLeft/index.js +25 -45
  748. package/dist/lexical/ui/icons/AlignLeft/index.js.map +1 -1
  749. package/dist/lexical/ui/icons/AlignRight/index.js +25 -45
  750. package/dist/lexical/ui/icons/AlignRight/index.js.map +1 -1
  751. package/dist/lexical/ui/icons/Block/index.js +34 -54
  752. package/dist/lexical/ui/icons/Block/index.js.map +1 -1
  753. package/dist/lexical/ui/icons/Blockquote/index.js +16 -24
  754. package/dist/lexical/ui/icons/Blockquote/index.js.map +1 -1
  755. package/dist/lexical/ui/icons/Bold/index.js +16 -24
  756. package/dist/lexical/ui/icons/Bold/index.js.map +1 -1
  757. package/dist/lexical/ui/icons/Checklist/index.js +24 -39
  758. package/dist/lexical/ui/icons/Checklist/index.js.map +1 -1
  759. package/dist/lexical/ui/icons/Code/index.js +19 -34
  760. package/dist/lexical/ui/icons/Code/index.js.map +1 -1
  761. package/dist/lexical/ui/icons/CodeBlock/index.js +14 -22
  762. package/dist/lexical/ui/icons/CodeBlock/index.js.map +1 -1
  763. package/dist/lexical/ui/icons/Collapse/index.js +15 -23
  764. package/dist/lexical/ui/icons/Collapse/index.js.map +1 -1
  765. package/dist/lexical/ui/icons/H1/index.js +16 -24
  766. package/dist/lexical/ui/icons/H1/index.js.map +1 -1
  767. package/dist/lexical/ui/icons/H2/index.js +16 -24
  768. package/dist/lexical/ui/icons/H2/index.js.map +1 -1
  769. package/dist/lexical/ui/icons/H3/index.js +16 -24
  770. package/dist/lexical/ui/icons/H3/index.js.map +1 -1
  771. package/dist/lexical/ui/icons/H4/index.js +16 -24
  772. package/dist/lexical/ui/icons/H4/index.js.map +1 -1
  773. package/dist/lexical/ui/icons/H5/index.js +16 -24
  774. package/dist/lexical/ui/icons/H5/index.js.map +1 -1
  775. package/dist/lexical/ui/icons/H6/index.js +16 -24
  776. package/dist/lexical/ui/icons/H6/index.js.map +1 -1
  777. package/dist/lexical/ui/icons/HorizontalRule/index.js +19 -27
  778. package/dist/lexical/ui/icons/HorizontalRule/index.js.map +1 -1
  779. package/dist/lexical/ui/icons/IndentDecrease/index.js +28 -53
  780. package/dist/lexical/ui/icons/IndentDecrease/index.js.map +1 -1
  781. package/dist/lexical/ui/icons/IndentIncrease/index.js +28 -53
  782. package/dist/lexical/ui/icons/IndentIncrease/index.js.map +1 -1
  783. package/dist/lexical/ui/icons/InlineBlocks/index.js +18 -26
  784. package/dist/lexical/ui/icons/InlineBlocks/index.js.map +1 -1
  785. package/dist/lexical/ui/icons/Italic/index.js +16 -24
  786. package/dist/lexical/ui/icons/Italic/index.js.map +1 -1
  787. package/dist/lexical/ui/icons/Link/index.js +17 -25
  788. package/dist/lexical/ui/icons/Link/index.js.map +1 -1
  789. package/dist/lexical/ui/icons/Meatballs/index.js +19 -39
  790. package/dist/lexical/ui/icons/Meatballs/index.js.map +1 -1
  791. package/dist/lexical/ui/icons/OrderedList/index.js +31 -61
  792. package/dist/lexical/ui/icons/OrderedList/index.js.map +1 -1
  793. package/dist/lexical/ui/icons/Relationship/index.js +31 -58
  794. package/dist/lexical/ui/icons/Relationship/index.js.map +1 -1
  795. package/dist/lexical/ui/icons/Strikethrough/index.js +19 -34
  796. package/dist/lexical/ui/icons/Strikethrough/index.js.map +1 -1
  797. package/dist/lexical/ui/icons/Subscript/index.js +16 -24
  798. package/dist/lexical/ui/icons/Subscript/index.js.map +1 -1
  799. package/dist/lexical/ui/icons/Superscript/index.js +16 -24
  800. package/dist/lexical/ui/icons/Superscript/index.js.map +1 -1
  801. package/dist/lexical/ui/icons/Table/index.js +17 -25
  802. package/dist/lexical/ui/icons/Table/index.js.map +1 -1
  803. package/dist/lexical/ui/icons/Text/index.js +16 -24
  804. package/dist/lexical/ui/icons/Text/index.js.map +1 -1
  805. package/dist/lexical/ui/icons/TextState/index.js +19 -25
  806. package/dist/lexical/ui/icons/TextState/index.js.map +1 -1
  807. package/dist/lexical/ui/icons/Underline/index.js +19 -34
  808. package/dist/lexical/ui/icons/Underline/index.js.map +1 -1
  809. package/dist/lexical/ui/icons/UnorderedList/index.js +46 -81
  810. package/dist/lexical/ui/icons/UnorderedList/index.js.map +1 -1
  811. package/dist/lexical/ui/icons/Upload/index.js +28 -48
  812. package/dist/lexical/ui/icons/Upload/index.js.map +1 -1
  813. package/dist/lexical/utils/canUseDOM.js +1 -1
  814. package/dist/lexical/utils/canUseDOM.js.map +1 -1
  815. package/dist/lexical/utils/environment.js +1 -1
  816. package/dist/lexical/utils/environment.js.map +1 -1
  817. package/dist/lexical/utils/getDOMRangeRect.js +12 -12
  818. package/dist/lexical/utils/getDOMRangeRect.js.map +1 -1
  819. package/dist/lexical/utils/getSelectedNode.js +17 -13
  820. package/dist/lexical/utils/getSelectedNode.js.map +1 -1
  821. package/dist/lexical/utils/guard.js +4 -3
  822. package/dist/lexical/utils/guard.js.map +1 -1
  823. package/dist/lexical/utils/joinClasses.js +2 -2
  824. package/dist/lexical/utils/joinClasses.js.map +1 -1
  825. package/dist/lexical/utils/markdown/createBlockNode.js +9 -10
  826. package/dist/lexical/utils/markdown/createBlockNode.js.map +1 -1
  827. package/dist/lexical/utils/nodeFormat.js +58 -59
  828. package/dist/lexical/utils/nodeFormat.js.map +1 -1
  829. package/dist/lexical/utils/point.js +39 -32
  830. package/dist/lexical/utils/point.js.map +1 -1
  831. package/dist/lexical/utils/rect.js +166 -136
  832. package/dist/lexical/utils/rect.js.map +1 -1
  833. package/dist/lexical/utils/setFloatingElemPosition.js +56 -48
  834. package/dist/lexical/utils/setFloatingElemPosition.js.map +1 -1
  835. package/dist/lexical/utils/setFloatingElemPositionForLinkEditor.js +22 -22
  836. package/dist/lexical/utils/setFloatingElemPositionForLinkEditor.js.map +1 -1
  837. package/dist/lexical/utils/swipe.js +81 -83
  838. package/dist/lexical/utils/swipe.js.map +1 -1
  839. package/dist/lexical/utils/url.js +53 -53
  840. package/dist/lexical/utils/url.js.map +1 -1
  841. package/dist/lexical/utils/url.spec.js +98 -214
  842. package/dist/lexical/utils/url.spec.js.map +1 -1
  843. package/dist/lexical-proxy/@lexical-headless.js +0 -1
  844. package/dist/lexical-proxy/@lexical-headless.js.map +1 -1
  845. package/dist/lexical-proxy/@lexical-html.js +0 -1
  846. package/dist/lexical-proxy/@lexical-html.js.map +1 -1
  847. package/dist/lexical-proxy/@lexical-link.js +0 -1
  848. package/dist/lexical-proxy/@lexical-link.js.map +1 -1
  849. package/dist/lexical-proxy/@lexical-list.js +0 -1
  850. package/dist/lexical-proxy/@lexical-list.js.map +1 -1
  851. package/dist/lexical-proxy/@lexical-mark.js +0 -1
  852. package/dist/lexical-proxy/@lexical-mark.js.map +1 -1
  853. package/dist/lexical-proxy/@lexical-markdown.js +0 -1
  854. package/dist/lexical-proxy/@lexical-markdown.js.map +1 -1
  855. package/dist/lexical-proxy/@lexical-react/LexicalAutoEmbedPlugin.js +0 -1
  856. package/dist/lexical-proxy/@lexical-react/LexicalAutoEmbedPlugin.js.map +1 -1
  857. package/dist/lexical-proxy/@lexical-react/LexicalAutoFocusPlugin.js +0 -1
  858. package/dist/lexical-proxy/@lexical-react/LexicalAutoFocusPlugin.js.map +1 -1
  859. package/dist/lexical-proxy/@lexical-react/LexicalAutoLinkPlugin.js +0 -1
  860. package/dist/lexical-proxy/@lexical-react/LexicalAutoLinkPlugin.js.map +1 -1
  861. package/dist/lexical-proxy/@lexical-react/LexicalBlockWithAlignableContents.js +0 -1
  862. package/dist/lexical-proxy/@lexical-react/LexicalBlockWithAlignableContents.js.map +1 -1
  863. package/dist/lexical-proxy/@lexical-react/LexicalCharacterLimitPlugin.js +0 -1
  864. package/dist/lexical-proxy/@lexical-react/LexicalCharacterLimitPlugin.js.map +1 -1
  865. package/dist/lexical-proxy/@lexical-react/LexicalCheckListPlugin.js +0 -1
  866. package/dist/lexical-proxy/@lexical-react/LexicalCheckListPlugin.js.map +1 -1
  867. package/dist/lexical-proxy/@lexical-react/LexicalClearEditorPlugin.js +0 -1
  868. package/dist/lexical-proxy/@lexical-react/LexicalClearEditorPlugin.js.map +1 -1
  869. package/dist/lexical-proxy/@lexical-react/LexicalClickableLinkPlugin.js +0 -1
  870. package/dist/lexical-proxy/@lexical-react/LexicalClickableLinkPlugin.js.map +1 -1
  871. package/dist/lexical-proxy/@lexical-react/LexicalCollaborationContext.js +0 -1
  872. package/dist/lexical-proxy/@lexical-react/LexicalCollaborationContext.js.map +1 -1
  873. package/dist/lexical-proxy/@lexical-react/LexicalCollaborationPlugin.js +0 -1
  874. package/dist/lexical-proxy/@lexical-react/LexicalCollaborationPlugin.js.map +1 -1
  875. package/dist/lexical-proxy/@lexical-react/LexicalComposer.js +0 -1
  876. package/dist/lexical-proxy/@lexical-react/LexicalComposer.js.map +1 -1
  877. package/dist/lexical-proxy/@lexical-react/LexicalComposerContext.js +0 -1
  878. package/dist/lexical-proxy/@lexical-react/LexicalComposerContext.js.map +1 -1
  879. package/dist/lexical-proxy/@lexical-react/LexicalContentEditable.js +0 -1
  880. package/dist/lexical-proxy/@lexical-react/LexicalContentEditable.js.map +1 -1
  881. package/dist/lexical-proxy/@lexical-react/LexicalContextMenuPlugin.js +0 -1
  882. package/dist/lexical-proxy/@lexical-react/LexicalContextMenuPlugin.js.map +1 -1
  883. package/dist/lexical-proxy/@lexical-react/LexicalDecoratorBlockNode.js +0 -1
  884. package/dist/lexical-proxy/@lexical-react/LexicalDecoratorBlockNode.js.map +1 -1
  885. package/dist/lexical-proxy/@lexical-react/LexicalDraggableBlockPlugin.js +0 -1
  886. package/dist/lexical-proxy/@lexical-react/LexicalDraggableBlockPlugin.js.map +1 -1
  887. package/dist/lexical-proxy/@lexical-react/LexicalEditorRefPlugin.js +0 -1
  888. package/dist/lexical-proxy/@lexical-react/LexicalEditorRefPlugin.js.map +1 -1
  889. package/dist/lexical-proxy/@lexical-react/LexicalErrorBoundary.js +0 -1
  890. package/dist/lexical-proxy/@lexical-react/LexicalErrorBoundary.js.map +1 -1
  891. package/dist/lexical-proxy/@lexical-react/LexicalHashtagPlugin.js +0 -1
  892. package/dist/lexical-proxy/@lexical-react/LexicalHashtagPlugin.js.map +1 -1
  893. package/dist/lexical-proxy/@lexical-react/LexicalHistoryPlugin.js +0 -1
  894. package/dist/lexical-proxy/@lexical-react/LexicalHistoryPlugin.js.map +1 -1
  895. package/dist/lexical-proxy/@lexical-react/LexicalHorizontalRuleNode.js +0 -1
  896. package/dist/lexical-proxy/@lexical-react/LexicalHorizontalRuleNode.js.map +1 -1
  897. package/dist/lexical-proxy/@lexical-react/LexicalHorizontalRulePlugin.js +0 -1
  898. package/dist/lexical-proxy/@lexical-react/LexicalHorizontalRulePlugin.js.map +1 -1
  899. package/dist/lexical-proxy/@lexical-react/LexicalLinkPlugin.js +0 -1
  900. package/dist/lexical-proxy/@lexical-react/LexicalLinkPlugin.js.map +1 -1
  901. package/dist/lexical-proxy/@lexical-react/LexicalListPlugin.js +0 -1
  902. package/dist/lexical-proxy/@lexical-react/LexicalListPlugin.js.map +1 -1
  903. package/dist/lexical-proxy/@lexical-react/LexicalMarkdownShortcutPlugin.js +0 -1
  904. package/dist/lexical-proxy/@lexical-react/LexicalMarkdownShortcutPlugin.js.map +1 -1
  905. package/dist/lexical-proxy/@lexical-react/LexicalNestedComposer.js +0 -1
  906. package/dist/lexical-proxy/@lexical-react/LexicalNestedComposer.js.map +1 -1
  907. package/dist/lexical-proxy/@lexical-react/LexicalNodeContextMenuPlugin.js +0 -1
  908. package/dist/lexical-proxy/@lexical-react/LexicalNodeContextMenuPlugin.js.map +1 -1
  909. package/dist/lexical-proxy/@lexical-react/LexicalNodeEventPlugin.js +0 -1
  910. package/dist/lexical-proxy/@lexical-react/LexicalNodeEventPlugin.js.map +1 -1
  911. package/dist/lexical-proxy/@lexical-react/LexicalNodeMenuPlugin.js +0 -1
  912. package/dist/lexical-proxy/@lexical-react/LexicalNodeMenuPlugin.js.map +1 -1
  913. package/dist/lexical-proxy/@lexical-react/LexicalOnChangePlugin.js +0 -1
  914. package/dist/lexical-proxy/@lexical-react/LexicalOnChangePlugin.js.map +1 -1
  915. package/dist/lexical-proxy/@lexical-react/LexicalPlainTextPlugin.js +0 -1
  916. package/dist/lexical-proxy/@lexical-react/LexicalPlainTextPlugin.js.map +1 -1
  917. package/dist/lexical-proxy/@lexical-react/LexicalRichTextPlugin.js +0 -1
  918. package/dist/lexical-proxy/@lexical-react/LexicalRichTextPlugin.js.map +1 -1
  919. package/dist/lexical-proxy/@lexical-react/LexicalTabIndentationPlugin.js +0 -1
  920. package/dist/lexical-proxy/@lexical-react/LexicalTabIndentationPlugin.js.map +1 -1
  921. package/dist/lexical-proxy/@lexical-react/LexicalTableOfContentsPlugin.js +0 -1
  922. package/dist/lexical-proxy/@lexical-react/LexicalTableOfContentsPlugin.js.map +1 -1
  923. package/dist/lexical-proxy/@lexical-react/LexicalTablePlugin.js +0 -1
  924. package/dist/lexical-proxy/@lexical-react/LexicalTablePlugin.js.map +1 -1
  925. package/dist/lexical-proxy/@lexical-react/LexicalTreeView.js +0 -1
  926. package/dist/lexical-proxy/@lexical-react/LexicalTreeView.js.map +1 -1
  927. package/dist/lexical-proxy/@lexical-react/LexicalTypeaheadMenuPlugin.js +0 -1
  928. package/dist/lexical-proxy/@lexical-react/LexicalTypeaheadMenuPlugin.js.map +1 -1
  929. package/dist/lexical-proxy/@lexical-react/useLexicalEditable.js +0 -1
  930. package/dist/lexical-proxy/@lexical-react/useLexicalEditable.js.map +1 -1
  931. package/dist/lexical-proxy/@lexical-react/useLexicalIsTextContentEmpty.js +0 -1
  932. package/dist/lexical-proxy/@lexical-react/useLexicalIsTextContentEmpty.js.map +1 -1
  933. package/dist/lexical-proxy/@lexical-react/useLexicalNodeSelection.js +0 -1
  934. package/dist/lexical-proxy/@lexical-react/useLexicalNodeSelection.js.map +1 -1
  935. package/dist/lexical-proxy/@lexical-react/useLexicalSubscription.js +0 -1
  936. package/dist/lexical-proxy/@lexical-react/useLexicalSubscription.js.map +1 -1
  937. package/dist/lexical-proxy/@lexical-react/useLexicalTextEntity.js +0 -1
  938. package/dist/lexical-proxy/@lexical-react/useLexicalTextEntity.js.map +1 -1
  939. package/dist/lexical-proxy/@lexical-rich-text.js +0 -1
  940. package/dist/lexical-proxy/@lexical-rich-text.js.map +1 -1
  941. package/dist/lexical-proxy/@lexical-selection.js +0 -1
  942. package/dist/lexical-proxy/@lexical-selection.js.map +1 -1
  943. package/dist/lexical-proxy/@lexical-utils.js +0 -1
  944. package/dist/lexical-proxy/@lexical-utils.js.map +1 -1
  945. package/dist/lexical-proxy/lexical.js +0 -1
  946. package/dist/lexical-proxy/lexical.js.map +1 -1
  947. package/dist/nodeTypes.js +1 -35
  948. package/dist/nodeTypes.js.map +1 -1
  949. package/dist/packages/@lexical/markdown/MarkdownExport.js +179 -184
  950. package/dist/packages/@lexical/markdown/MarkdownExport.js.map +1 -1
  951. package/dist/packages/@lexical/markdown/MarkdownImport.js +168 -174
  952. package/dist/packages/@lexical/markdown/MarkdownImport.js.map +1 -1
  953. package/dist/packages/@lexical/markdown/MarkdownShortcuts.js +268 -258
  954. package/dist/packages/@lexical/markdown/MarkdownShortcuts.js.map +1 -1
  955. package/dist/packages/@lexical/markdown/MarkdownTransformers.js +209 -305
  956. package/dist/packages/@lexical/markdown/MarkdownTransformers.js.map +1 -1
  957. package/dist/packages/@lexical/markdown/importTextFormatTransformer.js +73 -76
  958. package/dist/packages/@lexical/markdown/importTextFormatTransformer.js.map +1 -1
  959. package/dist/packages/@lexical/markdown/importTextMatchTransformer.js +48 -59
  960. package/dist/packages/@lexical/markdown/importTextMatchTransformer.js.map +1 -1
  961. package/dist/packages/@lexical/markdown/importTextTransformers.js +45 -51
  962. package/dist/packages/@lexical/markdown/importTextTransformers.js.map +1 -1
  963. package/dist/packages/@lexical/markdown/index.js +14 -33
  964. package/dist/packages/@lexical/markdown/index.js.map +1 -1
  965. package/dist/packages/@lexical/markdown/utils.js +185 -217
  966. package/dist/packages/@lexical/markdown/utils.js.map +1 -1
  967. package/dist/populateGraphQL/defaultValue.js +24 -29
  968. package/dist/populateGraphQL/defaultValue.js.map +1 -1
  969. package/dist/populateGraphQL/populate.js +37 -26
  970. package/dist/populateGraphQL/populate.js.map +1 -1
  971. package/dist/populateGraphQL/populateLexicalPopulationPromises.js +50 -34
  972. package/dist/populateGraphQL/populateLexicalPopulationPromises.js.map +1 -1
  973. package/dist/populateGraphQL/recursivelyPopulateFieldsForGraphQL.js +42 -35
  974. package/dist/populateGraphQL/recursivelyPopulateFieldsForGraphQL.js.map +1 -1
  975. package/dist/types.d.ts +2 -152
  976. package/dist/types.d.ts.map +1 -1
  977. package/dist/types.js +1 -95
  978. package/dist/types.js.map +1 -1
  979. package/dist/utilities/buildEditorState.js +40 -39
  980. package/dist/utilities/buildEditorState.js.map +1 -1
  981. package/dist/utilities/buildInitialState.js +52 -51
  982. package/dist/utilities/buildInitialState.js.map +1 -1
  983. package/dist/utilities/createClientFeature.js +48 -42
  984. package/dist/utilities/createClientFeature.js.map +1 -1
  985. package/dist/utilities/createServerFeature.js +48 -38
  986. package/dist/utilities/createServerFeature.js.map +1 -1
  987. package/dist/utilities/editorConfigFactory.js +79 -78
  988. package/dist/utilities/editorConfigFactory.js.map +1 -1
  989. package/dist/utilities/fieldsDrawer/Drawer.js +70 -45
  990. package/dist/utilities/fieldsDrawer/Drawer.js.map +1 -1
  991. package/dist/utilities/fieldsDrawer/DrawerContent.js +120 -130
  992. package/dist/utilities/fieldsDrawer/DrawerContent.js.map +1 -1
  993. package/dist/utilities/fieldsDrawer/useLexicalDocumentDrawer.js +115 -64
  994. package/dist/utilities/fieldsDrawer/useLexicalDocumentDrawer.js.map +1 -1
  995. package/dist/utilities/fieldsDrawer/useLexicalDrawer.js +121 -76
  996. package/dist/utilities/fieldsDrawer/useLexicalDrawer.js.map +1 -1
  997. package/dist/utilities/fieldsDrawer/useLexicalListDrawer.js +141 -79
  998. package/dist/utilities/fieldsDrawer/useLexicalListDrawer.js.map +1 -1
  999. package/dist/utilities/forEachNodeRecursively.js +24 -19
  1000. package/dist/utilities/forEachNodeRecursively.js.map +1 -1
  1001. package/dist/utilities/generateImportMap.d.ts.map +1 -1
  1002. package/dist/utilities/generateImportMap.js +49 -44
  1003. package/dist/utilities/generateImportMap.js.map +1 -1
  1004. package/dist/utilities/generateSchemaMap.js +37 -32
  1005. package/dist/utilities/generateSchemaMap.js.map +1 -1
  1006. package/dist/utilities/getDefaultSanitizedEditorConfig.js +14 -12
  1007. package/dist/utilities/getDefaultSanitizedEditorConfig.js.map +1 -1
  1008. package/dist/utilities/initLexicalFeatures.js +65 -68
  1009. package/dist/utilities/initLexicalFeatures.js.map +1 -1
  1010. package/dist/utilities/jsx/collectTopLevelJSXInLines.js +29 -26
  1011. package/dist/utilities/jsx/collectTopLevelJSXInLines.js.map +1 -1
  1012. package/dist/utilities/jsx/declare.d.js.map +1 -1
  1013. package/dist/utilities/jsx/extractPropsFromJSXPropsString.js +102 -100
  1014. package/dist/utilities/jsx/extractPropsFromJSXPropsString.js.map +1 -1
  1015. package/dist/utilities/jsx/jsx.js +80 -76
  1016. package/dist/utilities/jsx/jsx.js.map +1 -1
  1017. package/dist/utilities/jsx/jsx.spec.js +171 -225
  1018. package/dist/utilities/jsx/jsx.spec.js.map +1 -1
  1019. package/dist/utilities/migrateSlateToLexical/index.js +128 -112
  1020. package/dist/utilities/migrateSlateToLexical/index.js.map +1 -1
  1021. package/dist/utilities/migrateSlateToLexical/migrateDocumentFieldsRecursively.js +78 -74
  1022. package/dist/utilities/migrateSlateToLexical/migrateDocumentFieldsRecursively.js.map +1 -1
  1023. package/dist/utilities/recurseNodeTree.js +25 -22
  1024. package/dist/utilities/recurseNodeTree.js.map +1 -1
  1025. package/dist/utilities/upgradeLexicalData/index.js +102 -88
  1026. package/dist/utilities/upgradeLexicalData/index.js.map +1 -1
  1027. package/dist/utilities/upgradeLexicalData/upgradeDocumentFieldsRecursively.js +80 -78
  1028. package/dist/utilities/upgradeLexicalData/upgradeDocumentFieldsRecursively.js.map +1 -1
  1029. package/dist/utilities/useLexicalFeature.js +16 -14
  1030. package/dist/utilities/useLexicalFeature.js.map +1 -1
  1031. package/dist/utilities/useRunDeprioritized.js +37 -41
  1032. package/dist/utilities/useRunDeprioritized.js.map +1 -1
  1033. package/dist/validate/hasText.d.ts +1 -6
  1034. package/dist/validate/hasText.d.ts.map +1 -1
  1035. package/dist/validate/hasText.js +20 -27
  1036. package/dist/validate/hasText.js.map +1 -1
  1037. package/dist/validate/index.js +28 -22
  1038. package/dist/validate/index.js.map +1 -1
  1039. package/dist/validate/validateNodes.js +31 -28
  1040. package/dist/validate/validateNodes.js.map +1 -1
  1041. package/package.json +10 -16
  1042. package/dist/exports/client/internal-client.d.ts +0 -3
  1043. package/dist/exports/client/internal-client.d.ts.map +0 -1
  1044. package/dist/exports/client/internal-client.js +0 -4
  1045. package/dist/exports/client/internal-client.js.map +0 -1
  1046. package/dist/features/blocks/client/component/index.scss +0 -188
  1047. package/dist/features/blocks/client/componentInline/index.scss +0 -90
  1048. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.scss +0 -6
  1049. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.scss +0 -29
  1050. package/dist/features/blocks/premade/CodeBlock/Component/index.scss +0 -97
  1051. package/dist/features/debug/jsxConverter/client/plugin/style.scss +0 -12
  1052. package/dist/features/debug/testRecorder/client/plugin/index.scss +0 -53
  1053. package/dist/features/debug/treeView/client/plugin/index.scss +0 -80
  1054. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.scss +0 -87
  1055. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.scss +0 -11
  1056. package/dist/features/experimental_table/client/plugins/TablePlugin/index.scss +0 -233
  1057. package/dist/features/horizontalRule/client/plugin/index.scss +0 -23
  1058. package/dist/features/link/client/plugins/floatingLinkEditor/index.scss +0 -92
  1059. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.scss +0 -16
  1060. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.scss +0 -16
  1061. package/dist/features/relationship/client/components/index.scss +0 -95
  1062. package/dist/features/toolbars/fixed/client/Toolbar/index.scss +0 -113
  1063. package/dist/features/toolbars/inline/client/Toolbar/index.scss +0 -58
  1064. package/dist/features/toolbars/shared/ToolbarButton/index.scss +0 -46
  1065. package/dist/features/toolbars/shared/ToolbarDropdown/index.scss +0 -129
  1066. package/dist/features/upload/client/component/index.scss +0 -191
  1067. package/dist/field/Diff/converters/listitem/index.scss +0 -47
  1068. package/dist/field/Diff/converters/relationship/index.scss +0 -73
  1069. package/dist/field/Diff/converters/unknown/index.scss +0 -40
  1070. package/dist/field/Diff/converters/upload/index.scss +0 -115
  1071. package/dist/field/Diff/index.scss +0 -102
  1072. package/dist/field/RichTextViewProvider.d.ts +0 -83
  1073. package/dist/field/RichTextViewProvider.d.ts.map +0 -1
  1074. package/dist/field/RichTextViewProvider.js +0 -102
  1075. package/dist/field/RichTextViewProvider.js.map +0 -1
  1076. package/dist/field/ViewSelector.d.ts +0 -4
  1077. package/dist/field/ViewSelector.d.ts.map +0 -1
  1078. package/dist/field/ViewSelector.js +0 -90
  1079. package/dist/field/ViewSelector.js.map +0 -1
  1080. package/dist/field/ViewSelector.scss +0 -34
  1081. package/dist/field/index.scss +0 -53
  1082. package/dist/lexical/LexicalEditor.scss +0 -54
  1083. package/dist/lexical/plugins/DecoratorPlugin/index.scss +0 -13
  1084. package/dist/lexical/plugins/InsertParagraphAtEnd/index.scss +0 -54
  1085. package/dist/lexical/plugins/NodeViewOverridePlugin/index.d.ts +0 -2
  1086. package/dist/lexical/plugins/NodeViewOverridePlugin/index.d.ts.map +0 -1
  1087. package/dist/lexical/plugins/NodeViewOverridePlugin/index.js +0 -31
  1088. package/dist/lexical/plugins/NodeViewOverridePlugin/index.js.map +0 -1
  1089. package/dist/lexical/plugins/SlashMenu/index.scss +0 -68
  1090. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.scss +0 -35
  1091. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.scss +0 -80
  1092. package/dist/lexical/theme/EditorTheme.scss +0 -357
  1093. package/dist/lexical/ui/ContentEditable.scss +0 -105
package/dist/index.js CHANGED
@@ -11,455 +11,541 @@ import { richTextValidateHOC } from './validate/index.js';
11
11
  let checkedDependencies = false;
12
12
  export const lexicalTargetVersion = '0.35.0';
13
13
  export function lexicalEditor(args) {
14
- if (process.env.NODE_ENV !== 'production' && process.env.PAYLOAD_DISABLE_DEPENDENCY_CHECKER !== 'true' && !checkedDependencies) {
15
- checkedDependencies = true;
16
- void checkDependencies({
17
- dependencyGroups: [
18
- {
19
- name: 'lexical',
20
- dependencies: [
21
- 'lexical',
22
- '@lexical/headless',
23
- '@lexical/link',
24
- '@lexical/list',
25
- '@lexical/mark',
26
- '@lexical/react',
27
- '@lexical/rich-text',
28
- '@lexical/selection',
29
- '@lexical/utils'
30
- ],
31
- targetVersion: lexicalTargetVersion
32
- }
33
- ]
34
- });
14
+ if (process.env.NODE_ENV !== 'production' && process.env.PAYLOAD_DISABLE_DEPENDENCY_CHECKER !== 'true' && !checkedDependencies) {
15
+ checkedDependencies = true;
16
+ void checkDependencies({
17
+ dependencyGroups: [{
18
+ name: 'lexical',
19
+ dependencies: ['lexical', '@lexical/headless', '@lexical/link', '@lexical/list', '@lexical/mark', '@lexical/react', '@lexical/rich-text', '@lexical/selection', '@lexical/utils'],
20
+ targetVersion: lexicalTargetVersion
21
+ }]
22
+ });
23
+ }
24
+ return async ({
25
+ config,
26
+ isRoot,
27
+ parentIsLocalized
28
+ }) => {
29
+ let features = [];
30
+ let resolvedFeatureMap;
31
+ let finalSanitizedEditorConfig // For server only
32
+ ;
33
+ if (!args || !args.features && !args.lexical) {
34
+ finalSanitizedEditorConfig = await getDefaultSanitizedEditorConfig({
35
+ config,
36
+ parentIsLocalized
37
+ });
38
+ features = defaultEditorFeatures;
39
+ resolvedFeatureMap = finalSanitizedEditorConfig.resolvedFeatureMap;
40
+ } else {
41
+ const result = await featuresInputToEditorConfig({
42
+ config,
43
+ features: args?.features,
44
+ isRoot,
45
+ lexical: args?.lexical,
46
+ parentIsLocalized
47
+ });
48
+ finalSanitizedEditorConfig = result.sanitizedConfig;
49
+ features = result.features;
50
+ resolvedFeatureMap = result.resolvedFeatureMap;
35
51
  }
36
- return async ({ config, isRoot, parentIsLocalized })=>{
37
- let features = [];
38
- let resolvedFeatureMap;
39
- let finalSanitizedEditorConfig;
40
- // For server only
41
- if (!args || !args.features && !args.lexical) {
42
- finalSanitizedEditorConfig = await getDefaultSanitizedEditorConfig({
43
- config,
44
- parentIsLocalized
45
- });
46
- features = defaultEditorFeatures;
47
- resolvedFeatureMap = finalSanitizedEditorConfig.resolvedFeatureMap;
48
- } else {
49
- const result = await featuresInputToEditorConfig({
50
- config,
51
- features: args?.features,
52
- isRoot,
53
- lexical: args?.lexical,
54
- parentIsLocalized
55
- });
56
- finalSanitizedEditorConfig = result.sanitizedConfig;
57
- features = result.features;
58
- resolvedFeatureMap = result.resolvedFeatureMap;
52
+ const featureI18n = finalSanitizedEditorConfig.features.i18n;
53
+ for (const _lang in i18n) {
54
+ const lang = _lang;
55
+ const lexicalI18nForLang = (featureI18n[lang] ??= {}).lexical ??= {};
56
+ lexicalI18nForLang.general = i18n[lang] ?? {};
57
+ }
58
+ config.i18n.translations = deepMergeSimple(config.i18n.translations, featureI18n);
59
+ return {
60
+ CellComponent: '@payloadcms/richtext-lexical/rsc#RscEntryLexicalCell',
61
+ DiffComponent: '@payloadcms/richtext-lexical/rsc#LexicalDiffComponent',
62
+ editorConfig: finalSanitizedEditorConfig,
63
+ features,
64
+ FieldComponent: {
65
+ path: '@payloadcms/richtext-lexical/rsc#RscEntryLexicalField',
66
+ serverProps: {
67
+ admin: args?.admin
59
68
  }
60
- const featureI18n = finalSanitizedEditorConfig.features.i18n;
61
- for(const _lang in i18n){
62
- const lang = _lang;
63
- const lexicalI18nForLang = (featureI18n[lang] ??= {}).lexical ??= {};
64
- lexicalI18nForLang.general = i18n[lang] ?? {};
69
+ },
70
+ generateImportMap: getGenerateImportMap({
71
+ resolvedFeatureMap
72
+ }),
73
+ generateSchemaMap: getGenerateSchemaMap({
74
+ resolvedFeatureMap
75
+ }),
76
+ graphQLPopulationPromises({
77
+ context,
78
+ currentDepth,
79
+ depth,
80
+ draft,
81
+ field,
82
+ fieldPromises,
83
+ findMany,
84
+ flattenLocales,
85
+ overrideAccess,
86
+ parentIsLocalized,
87
+ populationPromises,
88
+ req,
89
+ showHiddenFields,
90
+ siblingDoc
91
+ }) {
92
+ // check if there are any features with nodes which have populationPromises for this field
93
+ if (finalSanitizedEditorConfig?.features?.graphQLPopulationPromises?.size) {
94
+ populateLexicalPopulationPromises({
95
+ context,
96
+ currentDepth: currentDepth ?? 0,
97
+ depth,
98
+ draft,
99
+ editorPopulationPromises: finalSanitizedEditorConfig.features.graphQLPopulationPromises,
100
+ field,
101
+ fieldPromises,
102
+ findMany,
103
+ flattenLocales,
104
+ overrideAccess,
105
+ parentIsLocalized,
106
+ populationPromises,
107
+ req,
108
+ showHiddenFields,
109
+ siblingDoc
110
+ });
65
111
  }
66
- config.i18n.translations = deepMergeSimple(config.i18n.translations, featureI18n);
67
- return {
68
- CellComponent: '@payloadcms/richtext-lexical/rsc#RscEntryLexicalCell',
69
- DiffComponent: '@payloadcms/richtext-lexical/rsc#LexicalDiffComponent',
70
- editorConfig: finalSanitizedEditorConfig,
71
- features,
72
- FieldComponent: {
73
- path: '@payloadcms/richtext-lexical/rsc#RscEntryLexicalField',
74
- serverProps: {
75
- admin: args?.admin,
76
- views: args?.views
112
+ },
113
+ hooks: {
114
+ afterChange: [async args => {
115
+ const {
116
+ collection,
117
+ context: _context,
118
+ data,
119
+ field,
120
+ global,
121
+ indexPath,
122
+ operation,
123
+ originalDoc,
124
+ parentIsLocalized,
125
+ path,
126
+ previousDoc,
127
+ previousValue,
128
+ req,
129
+ schemaPath
130
+ } = args;
131
+ let {
132
+ value
133
+ } = args;
134
+ if (finalSanitizedEditorConfig?.features?.hooks?.afterChange?.length) {
135
+ for (const hook of finalSanitizedEditorConfig.features.hooks.afterChange) {
136
+ value = await hook(args);
137
+ }
138
+ }
139
+ if (!finalSanitizedEditorConfig.features.nodeHooks?.afterChange?.size && !finalSanitizedEditorConfig.features.getSubFields?.size) {
140
+ return value;
141
+ }
142
+ // TO-DO: We should not use context, as it is intended for external use only
143
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
144
+ const context = _context;
145
+ const nodeIDMap = {};
146
+ const previousNodeIDMap = {};
147
+ /**
148
+ * Get the originalNodeIDMap from the beforeValidate hook, which is always run before this hook.
149
+ */
150
+ const originalNodeIDMap = context?.internal?.richText?.[path.join('.')]?.originalNodeIDMap;
151
+ if (!originalNodeIDMap || !Object.keys(originalNodeIDMap).length || !value) {
152
+ return value;
153
+ }
154
+ recurseNodeTree({
155
+ nodeIDMap,
156
+ nodes: value?.root?.children ?? []
157
+ });
158
+ recurseNodeTree({
159
+ nodeIDMap: previousNodeIDMap,
160
+ nodes: previousValue?.root?.children ?? []
161
+ });
162
+ // eslint-disable-next-line prefer-const
163
+ for (let [id, node] of Object.entries(nodeIDMap)) {
164
+ const afterChangeHooks = finalSanitizedEditorConfig.features.nodeHooks?.afterChange;
165
+ const afterChangeHooksForNode = afterChangeHooks?.get(node.type);
166
+ if (afterChangeHooksForNode) {
167
+ for (const hook of afterChangeHooksForNode) {
168
+ if (!originalNodeIDMap[id]) {
169
+ console.warn('(afterChange) No original node found for node with id', id, 'node:', node, 'path', path.join('.'));
170
+ continue;
77
171
  }
78
- },
79
- // SanitizedEditorConfig is manually passed by `renderField` in `fieldSchemasToFormState/renderField.tsx`
80
- // in order to reduce the size of the field schema
81
- generateImportMap: getGenerateImportMap({
82
- lexicalEditorArgs: args,
83
- resolvedFeatureMap
84
- }),
85
- generateSchemaMap: getGenerateSchemaMap({
86
- resolvedFeatureMap
87
- }),
88
- graphQLPopulationPromises ({ context, currentDepth, depth, draft, field, fieldPromises, findMany, flattenLocales, overrideAccess, parentIsLocalized, populationPromises, req, showHiddenFields, siblingDoc }) {
89
- // check if there are any features with nodes which have populationPromises for this field
90
- if (finalSanitizedEditorConfig?.features?.graphQLPopulationPromises?.size) {
91
- populateLexicalPopulationPromises({
92
- context,
93
- currentDepth: currentDepth ?? 0,
94
- depth,
95
- draft,
96
- editorPopulationPromises: finalSanitizedEditorConfig.features.graphQLPopulationPromises,
97
- field,
98
- fieldPromises,
99
- findMany,
100
- flattenLocales,
101
- overrideAccess,
102
- parentIsLocalized,
103
- populationPromises,
104
- req,
105
- showHiddenFields,
106
- siblingDoc
107
- });
172
+ node = await hook({
173
+ context,
174
+ node,
175
+ operation,
176
+ originalNode: originalNodeIDMap[id],
177
+ parentRichTextFieldPath: path,
178
+ parentRichTextFieldSchemaPath: schemaPath,
179
+ previousNode: previousNodeIDMap[id],
180
+ req
181
+ });
182
+ }
183
+ }
184
+ const subFieldFn = finalSanitizedEditorConfig.features.getSubFields?.get(node.type);
185
+ const subFieldDataFn = finalSanitizedEditorConfig.features.getSubFieldsData?.get(node.type);
186
+ if (subFieldFn && subFieldDataFn) {
187
+ const subFields = subFieldFn({
188
+ node,
189
+ req
190
+ });
191
+ const nodeSiblingData = subFieldDataFn({
192
+ node,
193
+ req
194
+ }) ?? {};
195
+ const nodeSiblingDoc = subFieldDataFn({
196
+ node: originalNodeIDMap[id],
197
+ req
198
+ }) ?? {};
199
+ const nodePreviousSiblingDoc = subFieldDataFn({
200
+ node: previousNodeIDMap[id],
201
+ req
202
+ }) ?? {};
203
+ if (subFields?.length) {
204
+ await afterChangeTraverseFields({
205
+ blockData: nodeSiblingData,
206
+ collection,
207
+ context,
208
+ data: data ?? {},
209
+ doc: originalDoc,
210
+ fields: subFields,
211
+ global,
212
+ operation,
213
+ parentIndexPath: indexPath.join('-'),
214
+ parentIsLocalized: parentIsLocalized || field.localized || false,
215
+ parentPath: path.join('.'),
216
+ parentSchemaPath: schemaPath.join('.'),
217
+ previousDoc,
218
+ previousSiblingDoc: {
219
+ ...nodePreviousSiblingDoc
220
+ },
221
+ req,
222
+ siblingData: nodeSiblingData || {},
223
+ siblingDoc: {
224
+ ...nodeSiblingDoc
225
+ }
226
+ });
227
+ }
228
+ }
229
+ }
230
+ return value;
231
+ }],
232
+ afterRead: [
233
+ /**
234
+ * afterRead hooks do not receive the originalNode. Thus, they can run on all nodes, not just nodes with an ID.
235
+ */
236
+ async args => {
237
+ const {
238
+ collection,
239
+ context: context,
240
+ currentDepth,
241
+ depth,
242
+ draft,
243
+ fallbackLocale,
244
+ field,
245
+ fieldPromises,
246
+ findMany,
247
+ flattenLocales,
248
+ global,
249
+ indexPath,
250
+ locale,
251
+ originalDoc,
252
+ overrideAccess,
253
+ parentIsLocalized,
254
+ path,
255
+ populate,
256
+ populationPromises,
257
+ req,
258
+ schemaPath,
259
+ showHiddenFields,
260
+ triggerAccessControl,
261
+ triggerHooks
262
+ } = args;
263
+ let {
264
+ value
265
+ } = args;
266
+ if (finalSanitizedEditorConfig?.features?.hooks?.afterRead?.length) {
267
+ for (const hook of finalSanitizedEditorConfig.features.hooks.afterRead) {
268
+ value = await hook(args);
269
+ }
270
+ }
271
+ if (!finalSanitizedEditorConfig.features.nodeHooks?.afterRead?.size && !finalSanitizedEditorConfig.features.getSubFields?.size) {
272
+ return value;
273
+ }
274
+ const flattenedNodes = [];
275
+ recurseNodeTree({
276
+ flattenedNodes,
277
+ nodes: value?.root?.children ?? []
278
+ });
279
+ for (let node of flattenedNodes) {
280
+ const afterReadHooks = finalSanitizedEditorConfig.features.nodeHooks?.afterRead;
281
+ const afterReadHooksForNode = afterReadHooks?.get(node.type);
282
+ if (afterReadHooksForNode) {
283
+ for (const hook of afterReadHooksForNode) {
284
+ node = await hook({
285
+ context,
286
+ currentDepth: currentDepth,
287
+ depth: depth,
288
+ draft: draft,
289
+ fallbackLocale: fallbackLocale,
290
+ fieldPromises: fieldPromises,
291
+ findMany: findMany,
292
+ flattenLocales: flattenLocales,
293
+ locale: locale,
294
+ node,
295
+ overrideAccess: overrideAccess,
296
+ parentRichTextFieldPath: path,
297
+ parentRichTextFieldSchemaPath: schemaPath,
298
+ populateArg: populate,
299
+ populationPromises: populationPromises,
300
+ req,
301
+ showHiddenFields: showHiddenFields,
302
+ triggerAccessControl: triggerAccessControl,
303
+ triggerHooks: triggerHooks
304
+ });
305
+ }
306
+ }
307
+ const subFieldFn = finalSanitizedEditorConfig.features.getSubFields?.get(node.type);
308
+ const subFieldDataFn = finalSanitizedEditorConfig.features.getSubFieldsData?.get(node.type);
309
+ if (subFieldFn && subFieldDataFn) {
310
+ const subFields = subFieldFn({
311
+ node,
312
+ req
313
+ });
314
+ const nodeSiblingData = subFieldDataFn({
315
+ node,
316
+ req
317
+ }) ?? {};
318
+ if (subFields?.length) {
319
+ afterReadTraverseFields({
320
+ blockData: nodeSiblingData,
321
+ collection,
322
+ context,
323
+ currentDepth: currentDepth,
324
+ depth: depth,
325
+ doc: originalDoc,
326
+ draft: draft,
327
+ fallbackLocale: fallbackLocale,
328
+ fieldPromises: fieldPromises,
329
+ fields: subFields,
330
+ findMany: findMany,
331
+ flattenLocales: flattenLocales,
332
+ global,
333
+ locale: locale,
334
+ overrideAccess: overrideAccess,
335
+ parentIndexPath: indexPath.join('-'),
336
+ parentIsLocalized: parentIsLocalized || field.localized || false,
337
+ parentPath: path.join('.'),
338
+ parentSchemaPath: schemaPath.join('.'),
339
+ populate,
340
+ populationPromises: populationPromises,
341
+ req,
342
+ showHiddenFields: showHiddenFields,
343
+ siblingDoc: nodeSiblingData,
344
+ triggerAccessControl,
345
+ triggerHooks
346
+ });
347
+ }
348
+ }
349
+ }
350
+ return value;
351
+ }],
352
+ beforeChange: [async args => {
353
+ const {
354
+ collection,
355
+ context: _context,
356
+ data,
357
+ docWithLocales,
358
+ errors,
359
+ field,
360
+ fieldLabelPath,
361
+ global,
362
+ indexPath,
363
+ mergeLocaleActions,
364
+ operation,
365
+ originalDoc,
366
+ overrideAccess,
367
+ parentIsLocalized,
368
+ path,
369
+ previousValue,
370
+ req,
371
+ schemaPath,
372
+ siblingData,
373
+ siblingDocWithLocales,
374
+ skipValidation
375
+ } = args;
376
+ let {
377
+ value
378
+ } = args;
379
+ if (finalSanitizedEditorConfig?.features?.hooks?.beforeChange?.length) {
380
+ for (const hook of finalSanitizedEditorConfig.features.hooks.beforeChange) {
381
+ value = await hook(args);
382
+ }
383
+ }
384
+ if (!finalSanitizedEditorConfig.features.nodeHooks?.beforeChange?.size && !finalSanitizedEditorConfig.features.getSubFields?.size) {
385
+ return value;
386
+ }
387
+ // TO-DO: We should not use context, as it is intended for external use only
388
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
389
+ const context = _context;
390
+ const nodeIDMap = {};
391
+ /**
392
+ * Get the originalNodeIDMap from the beforeValidate hook, which is always run before this hook.
393
+ */
394
+ const originalNodeIDMap = context?.internal?.richText?.[path.join('.')]?.originalNodeIDMap;
395
+ if (!originalNodeIDMap || !Object.keys(originalNodeIDMap).length || !value) {
396
+ return value;
397
+ }
398
+ const previousNodeIDMap = {};
399
+ const originalNodeWithLocalesIDMap = {};
400
+ recurseNodeTree({
401
+ nodeIDMap,
402
+ nodes: value?.root?.children ?? []
403
+ });
404
+ recurseNodeTree({
405
+ nodeIDMap: previousNodeIDMap,
406
+ nodes: previousValue?.root?.children ?? []
407
+ });
408
+ if (field.name && siblingDocWithLocales?.[field.name]) {
409
+ recurseNodeTree({
410
+ nodeIDMap: originalNodeWithLocalesIDMap,
411
+ nodes: siblingDocWithLocales[field.name]?.root?.children ?? []
412
+ });
413
+ }
414
+ // eslint-disable-next-line prefer-const
415
+ for (let [id, node] of Object.entries(nodeIDMap)) {
416
+ const beforeChangeHooks = finalSanitizedEditorConfig.features.nodeHooks?.beforeChange;
417
+ const beforeChangeHooksForNode = beforeChangeHooks?.get(node.type);
418
+ if (beforeChangeHooksForNode) {
419
+ for (const hook of beforeChangeHooksForNode) {
420
+ if (!originalNodeIDMap[id]) {
421
+ console.warn('(beforeChange) No original node found for node with id', id, 'node:', node, 'path', path.join('.'));
422
+ continue;
108
423
  }
109
- },
110
- hooks: {
111
- afterChange: [
112
- async (args)=>{
113
- const { collection, context: _context, data, field, global, indexPath, operation, originalDoc, parentIsLocalized, path, previousDoc, previousValue, req, schemaPath } = args;
114
- let { value } = args;
115
- if (finalSanitizedEditorConfig?.features?.hooks?.afterChange?.length) {
116
- for (const hook of finalSanitizedEditorConfig.features.hooks.afterChange){
117
- value = await hook(args);
118
- }
119
- }
120
- if (!finalSanitizedEditorConfig.features.nodeHooks?.afterChange?.size && !finalSanitizedEditorConfig.features.getSubFields?.size) {
121
- return value;
122
- }
123
- // TO-DO: We should not use context, as it is intended for external use only
124
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
125
- const context = _context;
126
- const nodeIDMap = {};
127
- const previousNodeIDMap = {};
128
- /**
129
- * Get the originalNodeIDMap from the beforeValidate hook, which is always run before this hook.
130
- */ const originalNodeIDMap = context?.internal?.richText?.[path.join('.')]?.originalNodeIDMap;
131
- if (!originalNodeIDMap || !Object.keys(originalNodeIDMap).length || !value) {
132
- return value;
133
- }
134
- recurseNodeTree({
135
- nodeIDMap,
136
- nodes: value?.root?.children ?? []
137
- });
138
- recurseNodeTree({
139
- nodeIDMap: previousNodeIDMap,
140
- nodes: previousValue?.root?.children ?? []
141
- });
142
- // eslint-disable-next-line prefer-const
143
- for (let [id, node] of Object.entries(nodeIDMap)){
144
- const afterChangeHooks = finalSanitizedEditorConfig.features.nodeHooks?.afterChange;
145
- const afterChangeHooksForNode = afterChangeHooks?.get(node.type);
146
- if (afterChangeHooksForNode) {
147
- for (const hook of afterChangeHooksForNode){
148
- if (!originalNodeIDMap[id]) {
149
- console.warn('(afterChange) No original node found for node with id', id, 'node:', node, 'path', path.join('.'));
150
- continue;
151
- }
152
- node = await hook({
153
- context,
154
- node,
155
- operation,
156
- originalNode: originalNodeIDMap[id],
157
- parentRichTextFieldPath: path,
158
- parentRichTextFieldSchemaPath: schemaPath,
159
- previousNode: previousNodeIDMap[id],
160
- req
161
- });
162
- }
163
- }
164
- const subFieldFn = finalSanitizedEditorConfig.features.getSubFields?.get(node.type);
165
- const subFieldDataFn = finalSanitizedEditorConfig.features.getSubFieldsData?.get(node.type);
166
- if (subFieldFn && subFieldDataFn) {
167
- const subFields = subFieldFn({
168
- node,
169
- req
170
- });
171
- const nodeSiblingData = subFieldDataFn({
172
- node,
173
- req
174
- }) ?? {};
175
- const nodeSiblingDoc = subFieldDataFn({
176
- node: originalNodeIDMap[id],
177
- req
178
- }) ?? {};
179
- const nodePreviousSiblingDoc = subFieldDataFn({
180
- node: previousNodeIDMap[id],
181
- req
182
- }) ?? {};
183
- if (subFields?.length) {
184
- await afterChangeTraverseFields({
185
- blockData: nodeSiblingData,
186
- collection,
187
- context,
188
- data: data ?? {},
189
- doc: originalDoc,
190
- fields: subFields,
191
- global,
192
- operation,
193
- parentIndexPath: indexPath.join('-'),
194
- parentIsLocalized: parentIsLocalized || field.localized || false,
195
- parentPath: path.join('.'),
196
- parentSchemaPath: schemaPath.join('.'),
197
- previousDoc,
198
- previousSiblingDoc: {
199
- ...nodePreviousSiblingDoc
200
- },
201
- req,
202
- siblingData: nodeSiblingData || {},
203
- siblingDoc: {
204
- ...nodeSiblingDoc
205
- }
206
- });
207
- }
208
- }
209
- }
210
- return value;
211
- }
212
- ],
213
- afterRead: [
214
- /**
215
- * afterRead hooks do not receive the originalNode. Thus, they can run on all nodes, not just nodes with an ID.
216
- */ async (args)=>{
217
- const { collection, context: context, currentDepth, depth, draft, fallbackLocale, field, fieldPromises, findMany, flattenLocales, global, indexPath, locale, originalDoc, overrideAccess, parentIsLocalized, path, populate, populationPromises, req, schemaPath, showHiddenFields, triggerAccessControl, triggerHooks } = args;
218
- let { value } = args;
219
- if (finalSanitizedEditorConfig?.features?.hooks?.afterRead?.length) {
220
- for (const hook of finalSanitizedEditorConfig.features.hooks.afterRead){
221
- value = await hook(args);
222
- }
223
- }
224
- if (!finalSanitizedEditorConfig.features.nodeHooks?.afterRead?.size && !finalSanitizedEditorConfig.features.getSubFields?.size) {
225
- return value;
226
- }
227
- const flattenedNodes = [];
228
- recurseNodeTree({
229
- flattenedNodes,
230
- nodes: value?.root?.children ?? []
231
- });
232
- for (let node of flattenedNodes){
233
- const afterReadHooks = finalSanitizedEditorConfig.features.nodeHooks?.afterRead;
234
- const afterReadHooksForNode = afterReadHooks?.get(node.type);
235
- if (afterReadHooksForNode) {
236
- for (const hook of afterReadHooksForNode){
237
- node = await hook({
238
- context,
239
- currentDepth: currentDepth,
240
- depth: depth,
241
- draft: draft,
242
- fallbackLocale: fallbackLocale,
243
- fieldPromises: fieldPromises,
244
- findMany: findMany,
245
- flattenLocales: flattenLocales,
246
- locale: locale,
247
- node,
248
- overrideAccess: overrideAccess,
249
- parentRichTextFieldPath: path,
250
- parentRichTextFieldSchemaPath: schemaPath,
251
- populateArg: populate,
252
- populationPromises: populationPromises,
253
- req,
254
- showHiddenFields: showHiddenFields,
255
- triggerAccessControl: triggerAccessControl,
256
- triggerHooks: triggerHooks
257
- });
258
- }
259
- }
260
- const subFieldFn = finalSanitizedEditorConfig.features.getSubFields?.get(node.type);
261
- const subFieldDataFn = finalSanitizedEditorConfig.features.getSubFieldsData?.get(node.type);
262
- if (subFieldFn && subFieldDataFn) {
263
- const subFields = subFieldFn({
264
- node,
265
- req
266
- });
267
- const nodeSiblingData = subFieldDataFn({
268
- node,
269
- req
270
- }) ?? {};
271
- if (subFields?.length) {
272
- afterReadTraverseFields({
273
- blockData: nodeSiblingData,
274
- collection,
275
- context,
276
- currentDepth: currentDepth,
277
- depth: depth,
278
- doc: originalDoc,
279
- draft: draft,
280
- fallbackLocale: fallbackLocale,
281
- fieldPromises: fieldPromises,
282
- fields: subFields,
283
- findMany: findMany,
284
- flattenLocales: flattenLocales,
285
- global,
286
- locale: locale,
287
- overrideAccess: overrideAccess,
288
- parentIndexPath: indexPath.join('-'),
289
- parentIsLocalized: parentIsLocalized || field.localized || false,
290
- parentPath: path.join('.'),
291
- parentSchemaPath: schemaPath.join('.'),
292
- populate,
293
- populationPromises: populationPromises,
294
- req,
295
- showHiddenFields: showHiddenFields,
296
- siblingDoc: nodeSiblingData,
297
- triggerAccessControl,
298
- triggerHooks
299
- });
300
- }
301
- }
302
- }
303
- return value;
304
- }
305
- ],
306
- beforeChange: [
307
- async (args)=>{
308
- const { collection, context: _context, data, docWithLocales, errors, field, fieldLabelPath, global, indexPath, mergeLocaleActions, operation, originalDoc, overrideAccess, parentIsLocalized, path, previousValue, req, schemaPath, siblingData, siblingDocWithLocales, skipValidation } = args;
309
- let { value } = args;
310
- if (finalSanitizedEditorConfig?.features?.hooks?.beforeChange?.length) {
311
- for (const hook of finalSanitizedEditorConfig.features.hooks.beforeChange){
312
- value = await hook(args);
313
- }
314
- }
315
- if (!finalSanitizedEditorConfig.features.nodeHooks?.beforeChange?.size && !finalSanitizedEditorConfig.features.getSubFields?.size) {
316
- return value;
317
- }
318
- // TO-DO: We should not use context, as it is intended for external use only
319
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
320
- const context = _context;
321
- const nodeIDMap = {};
322
- /**
323
- * Get the originalNodeIDMap from the beforeValidate hook, which is always run before this hook.
324
- */ const originalNodeIDMap = context?.internal?.richText?.[path.join('.')]?.originalNodeIDMap;
325
- if (!originalNodeIDMap || !Object.keys(originalNodeIDMap).length || !value) {
326
- return value;
327
- }
328
- const previousNodeIDMap = {};
329
- const originalNodeWithLocalesIDMap = {};
330
- recurseNodeTree({
331
- nodeIDMap,
332
- nodes: value?.root?.children ?? []
333
- });
334
- recurseNodeTree({
335
- nodeIDMap: previousNodeIDMap,
336
- nodes: previousValue?.root?.children ?? []
337
- });
338
- if (field.name && siblingDocWithLocales?.[field.name]) {
339
- recurseNodeTree({
340
- nodeIDMap: originalNodeWithLocalesIDMap,
341
- nodes: siblingDocWithLocales[field.name]?.root?.children ?? []
342
- });
343
- }
344
- // eslint-disable-next-line prefer-const
345
- for (let [id, node] of Object.entries(nodeIDMap)){
346
- const beforeChangeHooks = finalSanitizedEditorConfig.features.nodeHooks?.beforeChange;
347
- const beforeChangeHooksForNode = beforeChangeHooks?.get(node.type);
348
- if (beforeChangeHooksForNode) {
349
- for (const hook of beforeChangeHooksForNode){
350
- if (!originalNodeIDMap[id]) {
351
- console.warn('(beforeChange) No original node found for node with id', id, 'node:', node, 'path', path.join('.'));
352
- continue;
353
- }
354
- node = await hook({
355
- context,
356
- errors: errors,
357
- mergeLocaleActions: mergeLocaleActions,
358
- node,
359
- operation: operation,
360
- originalNode: originalNodeIDMap[id],
361
- originalNodeWithLocales: originalNodeWithLocalesIDMap[id],
362
- parentRichTextFieldPath: path,
363
- parentRichTextFieldSchemaPath: schemaPath,
364
- previousNode: previousNodeIDMap[id],
365
- req,
366
- skipValidation: skipValidation
367
- });
368
- }
369
- }
370
- const subFieldFn = finalSanitizedEditorConfig.features.getSubFields?.get(node.type);
371
- const subFieldDataFn = finalSanitizedEditorConfig.features.getSubFieldsData?.get(node.type);
372
- if (subFieldFn && subFieldDataFn) {
373
- const subFields = subFieldFn({
374
- node,
375
- req
376
- });
377
- const nodeSiblingData = subFieldDataFn({
378
- node,
379
- req
380
- }) ?? {};
381
- const nodeSiblingDocWithLocales = subFieldDataFn({
382
- node: originalNodeWithLocalesIDMap[id],
383
- req
384
- }) ?? {};
385
- const nodePreviousSiblingDoc = subFieldDataFn({
386
- node: previousNodeIDMap[id],
387
- req
388
- }) ?? {};
389
- if (subFields?.length) {
390
- await beforeChangeTraverseFields({
391
- id,
392
- blockData: nodeSiblingData,
393
- collection,
394
- context,
395
- data: data ?? {},
396
- doc: originalDoc ?? {},
397
- docWithLocales: docWithLocales ?? {},
398
- errors: errors,
399
- fieldLabelPath,
400
- fields: subFields,
401
- global,
402
- mergeLocaleActions: mergeLocaleActions,
403
- operation: operation,
404
- overrideAccess,
405
- parentIndexPath: indexPath.join('-'),
406
- parentIsLocalized: parentIsLocalized || field.localized || false,
407
- parentPath: path.join('.'),
408
- parentSchemaPath: schemaPath.join('.'),
409
- req,
410
- siblingData: nodeSiblingData,
411
- siblingDoc: nodePreviousSiblingDoc,
412
- siblingDocWithLocales: nodeSiblingDocWithLocales ?? {},
413
- skipValidation
414
- });
415
- }
416
- }
417
- }
418
- /**
419
- * within the beforeChange hook, id's may be re-generated.
420
- * Example:
421
- * 1. Seed data contains IDs for block feature blocks.
422
- * 2. Those are used in beforeValidate
423
- * 3. in beforeChange, those IDs are regenerated, because you cannot provide IDs during document creation. See baseIDField beforeChange hook for reasoning
424
- * 4. Thus, in order for all post-beforeChange hooks to receive the correct ID, we need to update the originalNodeIDMap with the new ID's, by regenerating the nodeIDMap.
425
- * The reason this is not generated for every hook, is to save on performance. We know we only really have to generate it in beforeValidate, which is the first hook,
426
- * and in beforeChange, which is where modifications to the provided IDs can occur.
427
- */ const newOriginalNodeIDMap = {};
428
- const previousOriginalValue = siblingData[field.name];
429
- recurseNodeTree({
430
- nodeIDMap: newOriginalNodeIDMap,
431
- nodes: previousOriginalValue?.root?.children ?? []
432
- });
433
- if (!context.internal) {
434
- // Add to context, for other hooks to use
435
- context.internal = {};
436
- }
437
- if (!context.internal.richText) {
438
- context.internal.richText = {};
439
- }
440
- context.internal.richText[path.join('.')] = {
441
- originalNodeIDMap: newOriginalNodeIDMap
442
- };
443
- return value;
444
- }
445
- ],
446
- beforeValidate: [
447
- async (args)=>{
448
- const { collection, context, data, field, global, indexPath, operation, originalDoc, overrideAccess, parentIsLocalized, path, previousValue, req, schemaPath } = args;
449
- let { value } = args;
450
- if (finalSanitizedEditorConfig?.features?.hooks?.beforeValidate?.length) {
451
- for (const hook of finalSanitizedEditorConfig.features.hooks.beforeValidate){
452
- value = await hook(args);
453
- }
454
- }
455
- // return value if there are NO hooks
456
- if (!finalSanitizedEditorConfig.features.nodeHooks?.beforeValidate?.size && !finalSanitizedEditorConfig.features.nodeHooks?.afterChange?.size && !finalSanitizedEditorConfig.features.nodeHooks?.beforeChange?.size && !finalSanitizedEditorConfig.features.getSubFields?.size) {
457
- return value;
458
- }
459
- /**
460
- * beforeValidate is the first field hook which runs. This is where we can create the node map, which can then be used in the other hooks.
461
- *
462
- */ /**
424
+ node = await hook({
425
+ context,
426
+ errors: errors,
427
+ mergeLocaleActions: mergeLocaleActions,
428
+ node,
429
+ operation: operation,
430
+ originalNode: originalNodeIDMap[id],
431
+ originalNodeWithLocales: originalNodeWithLocalesIDMap[id],
432
+ parentRichTextFieldPath: path,
433
+ parentRichTextFieldSchemaPath: schemaPath,
434
+ previousNode: previousNodeIDMap[id],
435
+ req,
436
+ skipValidation: skipValidation
437
+ });
438
+ }
439
+ }
440
+ const subFieldFn = finalSanitizedEditorConfig.features.getSubFields?.get(node.type);
441
+ const subFieldDataFn = finalSanitizedEditorConfig.features.getSubFieldsData?.get(node.type);
442
+ if (subFieldFn && subFieldDataFn) {
443
+ const subFields = subFieldFn({
444
+ node,
445
+ req
446
+ });
447
+ const nodeSiblingData = subFieldDataFn({
448
+ node,
449
+ req
450
+ }) ?? {};
451
+ const nodeSiblingDocWithLocales = subFieldDataFn({
452
+ node: originalNodeWithLocalesIDMap[id],
453
+ req
454
+ }) ?? {};
455
+ const nodePreviousSiblingDoc = subFieldDataFn({
456
+ node: previousNodeIDMap[id],
457
+ req
458
+ }) ?? {};
459
+ if (subFields?.length) {
460
+ await beforeChangeTraverseFields({
461
+ id,
462
+ blockData: nodeSiblingData,
463
+ collection,
464
+ context,
465
+ data: data ?? {},
466
+ doc: originalDoc ?? {},
467
+ docWithLocales: docWithLocales ?? {},
468
+ errors: errors,
469
+ fieldLabelPath,
470
+ fields: subFields,
471
+ global,
472
+ mergeLocaleActions: mergeLocaleActions,
473
+ operation: operation,
474
+ overrideAccess,
475
+ parentIndexPath: indexPath.join('-'),
476
+ parentIsLocalized: parentIsLocalized || field.localized || false,
477
+ parentPath: path.join('.'),
478
+ parentSchemaPath: schemaPath.join('.'),
479
+ req,
480
+ siblingData: nodeSiblingData,
481
+ siblingDoc: nodePreviousSiblingDoc,
482
+ siblingDocWithLocales: nodeSiblingDocWithLocales ?? {},
483
+ skipValidation
484
+ });
485
+ }
486
+ }
487
+ }
488
+ /**
489
+ * within the beforeChange hook, id's may be re-generated.
490
+ * Example:
491
+ * 1. Seed data contains IDs for block feature blocks.
492
+ * 2. Those are used in beforeValidate
493
+ * 3. in beforeChange, those IDs are regenerated, because you cannot provide IDs during document creation. See baseIDField beforeChange hook for reasoning
494
+ * 4. Thus, in order for all post-beforeChange hooks to receive the correct ID, we need to update the originalNodeIDMap with the new ID's, by regenerating the nodeIDMap.
495
+ * The reason this is not generated for every hook, is to save on performance. We know we only really have to generate it in beforeValidate, which is the first hook,
496
+ * and in beforeChange, which is where modifications to the provided IDs can occur.
497
+ */
498
+ const newOriginalNodeIDMap = {};
499
+ const previousOriginalValue = siblingData[field.name];
500
+ recurseNodeTree({
501
+ nodeIDMap: newOriginalNodeIDMap,
502
+ nodes: previousOriginalValue?.root?.children ?? []
503
+ });
504
+ if (!context.internal) {
505
+ // Add to context, for other hooks to use
506
+ context.internal = {};
507
+ }
508
+ if (!context.internal.richText) {
509
+ context.internal.richText = {};
510
+ }
511
+ context.internal.richText[path.join('.')] = {
512
+ originalNodeIDMap: newOriginalNodeIDMap
513
+ };
514
+ return value;
515
+ }],
516
+ beforeValidate: [async args => {
517
+ const {
518
+ collection,
519
+ context,
520
+ data,
521
+ field,
522
+ global,
523
+ indexPath,
524
+ operation,
525
+ originalDoc,
526
+ overrideAccess,
527
+ parentIsLocalized,
528
+ path,
529
+ previousValue,
530
+ req,
531
+ schemaPath
532
+ } = args;
533
+ let {
534
+ value
535
+ } = args;
536
+ if (finalSanitizedEditorConfig?.features?.hooks?.beforeValidate?.length) {
537
+ for (const hook of finalSanitizedEditorConfig.features.hooks.beforeValidate) {
538
+ value = await hook(args);
539
+ }
540
+ }
541
+ // return value if there are NO hooks
542
+ if (!finalSanitizedEditorConfig.features.nodeHooks?.beforeValidate?.size && !finalSanitizedEditorConfig.features.nodeHooks?.afterChange?.size && !finalSanitizedEditorConfig.features.nodeHooks?.beforeChange?.size && !finalSanitizedEditorConfig.features.getSubFields?.size) {
543
+ return value;
544
+ }
545
+ /**
546
+ * beforeValidate is the first field hook which runs. This is where we can create the node map, which can then be used in the other hooks.
547
+ *
548
+ */ /**
463
549
  * flattenedNodes contains all nodes in the editor, in the order they appear in the editor. They will be used for the following hooks:
464
550
  * - afterRead
465
551
  *
@@ -467,205 +553,184 @@ export function lexicalEditor(args) {
467
553
  * thus require a reliable way to match new node data to old node data. Given that node positions can change in between hooks, this is only reliably possible for nodes which are saved with
468
554
  * an ID.
469
555
  */ //const flattenedNodes: SerializedLexicalNode[] = []
470
- /**
471
- * Only nodes with id's (so, nodes with hooks added to them) will be added to the nodeIDMap. They will be used for the following hooks:
472
- * - afterChange
473
- * - beforeChange
474
- * - beforeValidate
475
- *
476
- * Other hooks are handled by the flattenedNodes. All nodes in the nodeIDMap are part of flattenedNodes.
477
- */ const originalNodeIDMap = {};
478
- recurseNodeTree({
479
- nodeIDMap: originalNodeIDMap,
480
- nodes: previousValue?.root?.children ?? []
481
- });
482
- if (!context.internal) {
483
- // Add to context, for other hooks to use
484
- context.internal = {};
485
- }
486
- if (!context.internal.richText) {
487
- ;
488
- context.internal.richText = {};
489
- }
490
- ;
491
- context.internal.richText[path.join('.')] = {
492
- originalNodeIDMap
493
- };
494
- /**
495
- * Now that the maps for all hooks are set up, we can run the validate hook
496
- */ if (!finalSanitizedEditorConfig.features.nodeHooks?.beforeValidate?.size) {
497
- return value;
498
- }
499
- const nodeIDMap = {};
500
- recurseNodeTree({
501
- //flattenedNodes,
502
- nodeIDMap,
503
- nodes: value?.root?.children ?? []
504
- });
505
- // eslint-disable-next-line prefer-const
506
- for (let [id, node] of Object.entries(nodeIDMap)){
507
- const beforeValidateHooks = finalSanitizedEditorConfig.features.nodeHooks.beforeValidate;
508
- const beforeValidateHooksForNode = beforeValidateHooks?.get(node.type);
509
- if (beforeValidateHooksForNode) {
510
- for (const hook of beforeValidateHooksForNode){
511
- if (!originalNodeIDMap[id]) {
512
- console.warn('(beforeValidate) No original node found for node with id', id, 'node:', node, 'path', path.join('.'));
513
- continue;
514
- }
515
- node = await hook({
516
- context,
517
- node,
518
- operation,
519
- originalNode: originalNodeIDMap[id],
520
- overrideAccess: overrideAccess,
521
- parentRichTextFieldPath: path,
522
- parentRichTextFieldSchemaPath: schemaPath,
523
- req
524
- });
525
- }
526
- }
527
- const subFieldFn = finalSanitizedEditorConfig.features.getSubFields?.get(node.type);
528
- const subFieldDataFn = finalSanitizedEditorConfig.features.getSubFieldsData?.get(node.type);
529
- if (subFieldFn && subFieldDataFn) {
530
- const subFields = subFieldFn({
531
- node,
532
- req
533
- });
534
- const nodeSiblingData = subFieldDataFn({
535
- node,
536
- req
537
- }) ?? {};
538
- const nodeSiblingDoc = subFieldDataFn({
539
- node: originalNodeIDMap[id],
540
- req
541
- }) ?? {};
542
- if (subFields?.length) {
543
- await beforeValidateTraverseFields({
544
- id,
545
- blockData: nodeSiblingData,
546
- collection,
547
- context,
548
- data,
549
- doc: originalDoc,
550
- fields: subFields,
551
- global,
552
- operation,
553
- overrideAccess: overrideAccess,
554
- parentIndexPath: indexPath.join('-'),
555
- parentIsLocalized: parentIsLocalized || field.localized || false,
556
- parentPath: path.join('.'),
557
- parentSchemaPath: schemaPath.join('.'),
558
- req,
559
- siblingData: nodeSiblingData,
560
- siblingDoc: nodeSiblingDoc
561
- });
562
- }
563
- }
564
- }
565
- return value;
566
- }
567
- ]
568
- },
569
- outputSchema: ({ collectionIDFieldTypes, config, field, i18n, interfaceNameDefinitions, isRequired })=>{
570
- let outputSchema = {
571
- // This schema matches the SerializedEditorState type so far, that it's possible to cast SerializedEditorState to this schema without any errors.
572
- // In the future, we should
573
- // 1) allow recursive children
574
- // 2) Pass in all the different types for every node added to the editorconfig. This can be done with refs in the schema.
575
- type: withNullableJSONSchemaType('object', isRequired),
556
+ /**
557
+ * Only nodes with id's (so, nodes with hooks added to them) will be added to the nodeIDMap. They will be used for the following hooks:
558
+ * - afterChange
559
+ * - beforeChange
560
+ * - beforeValidate
561
+ *
562
+ * Other hooks are handled by the flattenedNodes. All nodes in the nodeIDMap are part of flattenedNodes.
563
+ */
564
+ const originalNodeIDMap = {};
565
+ recurseNodeTree({
566
+ nodeIDMap: originalNodeIDMap,
567
+ nodes: previousValue?.root?.children ?? []
568
+ });
569
+ if (!context.internal) {
570
+ // Add to context, for other hooks to use
571
+ context.internal = {};
572
+ }
573
+ if (!context.internal.richText) {
574
+ context.internal.richText = {};
575
+ }
576
+ context.internal.richText[path.join('.')] = {
577
+ originalNodeIDMap
578
+ };
579
+ /**
580
+ * Now that the maps for all hooks are set up, we can run the validate hook
581
+ */
582
+ if (!finalSanitizedEditorConfig.features.nodeHooks?.beforeValidate?.size) {
583
+ return value;
584
+ }
585
+ const nodeIDMap = {};
586
+ recurseNodeTree({
587
+ //flattenedNodes,
588
+ nodeIDMap,
589
+ nodes: value?.root?.children ?? []
590
+ });
591
+ // eslint-disable-next-line prefer-const
592
+ for (let [id, node] of Object.entries(nodeIDMap)) {
593
+ const beforeValidateHooks = finalSanitizedEditorConfig.features.nodeHooks.beforeValidate;
594
+ const beforeValidateHooksForNode = beforeValidateHooks?.get(node.type);
595
+ if (beforeValidateHooksForNode) {
596
+ for (const hook of beforeValidateHooksForNode) {
597
+ if (!originalNodeIDMap[id]) {
598
+ console.warn('(beforeValidate) No original node found for node with id', id, 'node:', node, 'path', path.join('.'));
599
+ continue;
600
+ }
601
+ node = await hook({
602
+ context,
603
+ node,
604
+ operation,
605
+ originalNode: originalNodeIDMap[id],
606
+ overrideAccess: overrideAccess,
607
+ parentRichTextFieldPath: path,
608
+ parentRichTextFieldSchemaPath: schemaPath,
609
+ req
610
+ });
611
+ }
612
+ }
613
+ const subFieldFn = finalSanitizedEditorConfig.features.getSubFields?.get(node.type);
614
+ const subFieldDataFn = finalSanitizedEditorConfig.features.getSubFieldsData?.get(node.type);
615
+ if (subFieldFn && subFieldDataFn) {
616
+ const subFields = subFieldFn({
617
+ node,
618
+ req
619
+ });
620
+ const nodeSiblingData = subFieldDataFn({
621
+ node,
622
+ req
623
+ }) ?? {};
624
+ const nodeSiblingDoc = subFieldDataFn({
625
+ node: originalNodeIDMap[id],
626
+ req
627
+ }) ?? {};
628
+ if (subFields?.length) {
629
+ await beforeValidateTraverseFields({
630
+ id,
631
+ blockData: nodeSiblingData,
632
+ collection,
633
+ context,
634
+ data,
635
+ doc: originalDoc,
636
+ fields: subFields,
637
+ global,
638
+ operation,
639
+ overrideAccess: overrideAccess,
640
+ parentIndexPath: indexPath.join('-'),
641
+ parentIsLocalized: parentIsLocalized || field.localized || false,
642
+ parentPath: path.join('.'),
643
+ parentSchemaPath: schemaPath.join('.'),
644
+ req,
645
+ siblingData: nodeSiblingData,
646
+ siblingDoc: nodeSiblingDoc
647
+ });
648
+ }
649
+ }
650
+ }
651
+ return value;
652
+ }]
653
+ },
654
+ outputSchema: ({
655
+ collectionIDFieldTypes,
656
+ config,
657
+ field,
658
+ i18n,
659
+ interfaceNameDefinitions,
660
+ isRequired
661
+ }) => {
662
+ let outputSchema = {
663
+ // This schema matches the SerializedEditorState type so far, that it's possible to cast SerializedEditorState to this schema without any errors.
664
+ // In the future, we should
665
+ // 1) allow recursive children
666
+ // 2) Pass in all the different types for every node added to the editorconfig. This can be done with refs in the schema.
667
+ type: withNullableJSONSchemaType('object', isRequired),
668
+ properties: {
669
+ root: {
670
+ type: 'object',
671
+ additionalProperties: false,
672
+ properties: {
673
+ type: {
674
+ type: 'string'
675
+ },
676
+ children: {
677
+ type: 'array',
678
+ items: {
679
+ type: 'object',
680
+ additionalProperties: true,
576
681
  properties: {
577
- root: {
578
- type: 'object',
579
- additionalProperties: false,
580
- properties: {
581
- type: {
582
- type: 'string'
583
- },
584
- children: {
585
- type: 'array',
586
- items: {
587
- type: 'object',
588
- additionalProperties: true,
589
- properties: {
590
- type: {
591
- type: 'string',
592
- tsType: 'any'
593
- },
594
- version: {
595
- type: 'integer'
596
- }
597
- },
598
- required: [
599
- 'type',
600
- 'version'
601
- ]
602
- }
603
- },
604
- direction: {
605
- oneOf: [
606
- {
607
- enum: [
608
- 'ltr',
609
- 'rtl'
610
- ]
611
- },
612
- {
613
- type: 'null'
614
- }
615
- ]
616
- },
617
- format: {
618
- type: 'string',
619
- enum: [
620
- 'left',
621
- 'start',
622
- 'center',
623
- 'right',
624
- 'end',
625
- 'justify',
626
- ''
627
- ]
628
- },
629
- // ElementFormatType, since the root node is an element
630
- indent: {
631
- type: 'integer'
632
- },
633
- version: {
634
- type: 'integer'
635
- }
636
- },
637
- required: [
638
- 'children',
639
- 'direction',
640
- 'format',
641
- 'indent',
642
- 'type',
643
- 'version'
644
- ]
645
- }
682
+ type: {
683
+ type: 'string',
684
+ tsType: 'any'
685
+ },
686
+ version: {
687
+ type: 'integer'
688
+ }
646
689
  },
647
- required: [
648
- 'root'
649
- ]
650
- };
651
- for (const modifyOutputSchema of finalSanitizedEditorConfig.features.generatedTypes.modifyOutputSchemas){
652
- outputSchema = modifyOutputSchema({
653
- collectionIDFieldTypes,
654
- config,
655
- currentSchema: outputSchema,
656
- field,
657
- i18n,
658
- interfaceNameDefinitions,
659
- isRequired
660
- });
690
+ required: ['type', 'version']
691
+ }
692
+ },
693
+ direction: {
694
+ oneOf: [{
695
+ enum: ['ltr', 'rtl']
696
+ }, {
697
+ type: 'null'
698
+ }]
699
+ },
700
+ format: {
701
+ type: 'string',
702
+ enum: ['left', 'start', 'center', 'right', 'end', 'justify', '']
703
+ },
704
+ indent: {
705
+ type: 'integer'
706
+ },
707
+ version: {
708
+ type: 'integer'
661
709
  }
662
- return outputSchema;
663
- },
664
- validate: richTextValidateHOC({
665
- editorConfig: finalSanitizedEditorConfig
666
- })
710
+ },
711
+ required: ['children', 'direction', 'format', 'indent', 'type', 'version']
712
+ }
713
+ },
714
+ required: ['root']
667
715
  };
716
+ for (const modifyOutputSchema of finalSanitizedEditorConfig.features.generatedTypes.modifyOutputSchemas) {
717
+ outputSchema = modifyOutputSchema({
718
+ collectionIDFieldTypes,
719
+ config,
720
+ currentSchema: outputSchema,
721
+ field,
722
+ i18n,
723
+ interfaceNameDefinitions,
724
+ isRequired
725
+ });
726
+ }
727
+ return outputSchema;
728
+ },
729
+ validate: richTextValidateHOC({
730
+ editorConfig: finalSanitizedEditorConfig
731
+ })
668
732
  };
733
+ };
669
734
  }
670
735
  export { AlignFeature } from './features/align/server/index.js';
671
736
  export { BlockquoteFeature } from './features/blockquote/server/index.js';
@@ -714,8 +779,7 @@ export { defaultColors } from './features/textState/defaultColors.js';
714
779
  export { TextStateFeature } from './features/textState/feature.server.js';
715
780
  export { FixedToolbarFeature } from './features/toolbars/fixed/server/index.js';
716
781
  export { InlineToolbarFeature } from './features/toolbars/inline/server/index.js';
717
- export { createNode } from './features/typeUtilities.js';
718
- // Only useful in feature.server.ts
782
+ export { createNode } from './features/typeUtilities.js'; // Only useful in feature.server.ts
719
783
  export { UploadFeature } from './features/upload/server/index.js';
720
784
  export { UploadServerNode } from './features/upload/server/nodes/UploadNode.js';
721
785
  export { defaultEditorConfig, defaultEditorFeatures, defaultEditorLexicalConfig } from './lexical/config/server/default.js';
@@ -733,5 +797,4 @@ export { editorConfigFactory } from './utilities/editorConfigFactory.js';
733
797
  export { extractPropsFromJSXPropsString } from './utilities/jsx/extractPropsFromJSXPropsString.js';
734
798
  export { extractFrontmatter, frontmatterToObject, objectToFrontmatter, propsToJSXString } from './utilities/jsx/jsx.js';
735
799
  export { upgradeLexicalData } from './utilities/upgradeLexicalData/index.js';
736
-
737
800
  //# sourceMappingURL=index.js.map