@payloadcms/richtext-lexical 3.68.0-internal-debug.591ab42 → 3.68.0-internal.2b8df4a

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