@payloadcms/richtext-lexical 3.68.0-internal-debug.56c9b68 → 3.68.0-internal-debug.185cc5f

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