@payloadcms/richtext-lexical 3.77.0 → 3.78.0-internal-debug.f663370

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