@payloadcms/richtext-lexical 3.70.0 → 3.71.0-internal-debug.80dab4c

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