@payloadcms/richtext-lexical 3.71.0-internal-debug.e053082 → 3.71.0-internal.49c4f67

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 (1047) hide show
  1. package/dist/cell/rscEntry.js +72 -74
  2. package/dist/cell/rscEntry.js.map +1 -1
  3. package/dist/dependencyChecker.spec.js +7 -8
  4. package/dist/dependencyChecker.spec.js.map +1 -1
  5. package/dist/exports/client/Component-DOSSWC76.js +2 -0
  6. package/dist/exports/client/Component-DOSSWC76.js.map +7 -0
  7. package/dist/exports/client/Component-MBLHTKDK.js +2 -0
  8. package/dist/exports/client/Component-MBLHTKDK.js.map +7 -0
  9. package/dist/exports/client/Field-2A2VQXKP.js +2 -0
  10. package/dist/exports/client/Field-2A2VQXKP.js.map +7 -0
  11. package/dist/exports/client/RelationshipComponent-BG3DPV3T.js +2 -0
  12. package/dist/exports/client/RelationshipComponent-BG3DPV3T.js.map +7 -0
  13. package/dist/exports/client/bundled.css +1 -0
  14. package/dist/exports/client/chunk-AFXLIYGL.js +12 -0
  15. package/dist/exports/client/chunk-AFXLIYGL.js.map +7 -0
  16. package/dist/exports/client/chunk-BZZVLW4U.js +2 -0
  17. package/dist/exports/client/chunk-BZZVLW4U.js.map +7 -0
  18. package/dist/exports/client/chunk-DBWINSQN.js +2 -0
  19. package/dist/exports/client/chunk-DBWINSQN.js.map +7 -0
  20. package/dist/exports/client/chunk-F26IQ5RE.js +2 -0
  21. package/dist/exports/client/chunk-F26IQ5RE.js.map +7 -0
  22. package/dist/exports/client/chunk-INBEEENE.js +2 -0
  23. package/dist/exports/client/chunk-INBEEENE.js.map +7 -0
  24. package/dist/exports/client/chunk-O6XRT2H3.js +2 -0
  25. package/dist/exports/client/chunk-O6XRT2H3.js.map +7 -0
  26. package/dist/exports/client/chunk-TRHFMZ3F.js +2 -0
  27. package/dist/exports/client/chunk-TRHFMZ3F.js.map +7 -0
  28. package/dist/exports/client/component-YQ22OGQW.js +2 -0
  29. package/dist/exports/client/component-YQ22OGQW.js.map +7 -0
  30. package/dist/exports/client/componentInline-5OVPQNQH.js +2 -0
  31. package/dist/exports/client/componentInline-5OVPQNQH.js.map +7 -0
  32. package/dist/exports/client/index.js +65 -85
  33. package/dist/exports/client/index.js.map +7 -1
  34. package/dist/exports/cssEntry.js +0 -1
  35. package/dist/exports/cssEntry.js.map +1 -1
  36. package/dist/exports/html/index.js +0 -1
  37. package/dist/exports/html/index.js.map +1 -1
  38. package/dist/exports/html-async/index.js +0 -1
  39. package/dist/exports/html-async/index.js.map +1 -1
  40. package/dist/exports/plaintext/index.js +0 -1
  41. package/dist/exports/plaintext/index.js.map +1 -1
  42. package/dist/exports/react/index.js +0 -1
  43. package/dist/exports/react/index.js.map +1 -1
  44. package/dist/exports/server/ast/mdx.js +35 -37
  45. package/dist/exports/server/ast/mdx.js.map +1 -1
  46. package/dist/exports/server/migrate.js +0 -1
  47. package/dist/exports/server/migrate.js.map +1 -1
  48. package/dist/exports/server/rsc.js +0 -1
  49. package/dist/exports/server/rsc.js.map +1 -1
  50. package/dist/exports/shared.js +0 -1
  51. package/dist/exports/shared.js.map +1 -1
  52. package/dist/features/align/client/index.js +195 -168
  53. package/dist/features/align/client/index.js.map +1 -1
  54. package/dist/features/align/client/toolbarAlignGroup.js +9 -9
  55. package/dist/features/align/client/toolbarAlignGroup.js.map +1 -1
  56. package/dist/features/align/server/i18n.js +222 -223
  57. package/dist/features/align/server/i18n.js.map +1 -1
  58. package/dist/features/align/server/index.js +5 -6
  59. package/dist/features/align/server/index.js.map +1 -1
  60. package/dist/features/blockquote/client/index.js +60 -65
  61. package/dist/features/blockquote/client/index.js.map +1 -1
  62. package/dist/features/blockquote/markdownTransformer.js +28 -33
  63. package/dist/features/blockquote/markdownTransformer.js.map +1 -1
  64. package/dist/features/blockquote/server/i18n.js +111 -112
  65. package/dist/features/blockquote/server/i18n.js.map +1 -1
  66. package/dist/features/blockquote/server/index.js +48 -47
  67. package/dist/features/blockquote/server/index.js.map +1 -1
  68. package/dist/features/blocks/client/component/BlockContent.js +69 -95
  69. package/dist/features/blocks/client/component/BlockContent.js.map +1 -1
  70. package/dist/features/blocks/client/component/components/BlockCollapsible.js +14 -13
  71. package/dist/features/blocks/client/component/components/BlockCollapsible.js.map +1 -1
  72. package/dist/features/blocks/client/component/components/BlockEditButton.js +17 -9
  73. package/dist/features/blocks/client/component/components/BlockEditButton.js.map +1 -1
  74. package/dist/features/blocks/client/component/components/BlockRemoveButton.js +17 -9
  75. package/dist/features/blocks/client/component/components/BlockRemoveButton.js.map +1 -1
  76. package/dist/features/blocks/client/component/index.js +410 -553
  77. package/dist/features/blocks/client/component/index.js.map +1 -1
  78. package/dist/features/blocks/client/component/removeEmptyArrayValues.js +11 -8
  79. package/dist/features/blocks/client/component/removeEmptyArrayValues.js.map +1 -1
  80. package/dist/features/blocks/client/componentInline/components/InlineBlockContainer.js +23 -11
  81. package/dist/features/blocks/client/componentInline/components/InlineBlockContainer.js.map +1 -1
  82. package/dist/features/blocks/client/componentInline/components/InlineBlockEditButton.js +17 -9
  83. package/dist/features/blocks/client/componentInline/components/InlineBlockEditButton.js.map +1 -1
  84. package/dist/features/blocks/client/componentInline/components/InlineBlockLabel.js +17 -9
  85. package/dist/features/blocks/client/componentInline/components/InlineBlockLabel.js.map +1 -1
  86. package/dist/features/blocks/client/componentInline/components/InlineBlockRemoveButton.js +17 -9
  87. package/dist/features/blocks/client/componentInline/components/InlineBlockRemoveButton.js.map +1 -1
  88. package/dist/features/blocks/client/componentInline/index.js +340 -468
  89. package/dist/features/blocks/client/componentInline/index.js.map +1 -1
  90. package/dist/features/blocks/client/getBlockImageComponent.js +12 -17
  91. package/dist/features/blocks/client/getBlockImageComponent.js.map +1 -1
  92. package/dist/features/blocks/client/index.js +146 -141
  93. package/dist/features/blocks/client/index.js.map +1 -1
  94. package/dist/features/blocks/client/markdown/getLexicalToMarkdown.js +18 -18
  95. package/dist/features/blocks/client/markdown/getLexicalToMarkdown.js.map +1 -1
  96. package/dist/features/blocks/client/markdown/getMarkdownToLexical.js +15 -14
  97. package/dist/features/blocks/client/markdown/getMarkdownToLexical.js.map +1 -1
  98. package/dist/features/blocks/client/markdown/markdownTransformer.js +330 -328
  99. package/dist/features/blocks/client/markdown/markdownTransformer.js.map +1 -1
  100. package/dist/features/blocks/client/nodes/BlocksNode.js +40 -44
  101. package/dist/features/blocks/client/nodes/BlocksNode.js.map +1 -1
  102. package/dist/features/blocks/client/nodes/InlineBlocksNode.js +33 -37
  103. package/dist/features/blocks/client/nodes/InlineBlocksNode.js.map +1 -1
  104. package/dist/features/blocks/client/plugin/commands.js +1 -1
  105. package/dist/features/blocks/client/plugin/commands.js.map +1 -1
  106. package/dist/features/blocks/client/plugin/index.js +87 -59
  107. package/dist/features/blocks/client/plugin/index.js.map +1 -1
  108. package/dist/features/blocks/premade/CodeBlock/Component/Block.js +101 -158
  109. package/dist/features/blocks/premade/CodeBlock/Component/Block.js.map +1 -1
  110. package/dist/features/blocks/premade/CodeBlock/Component/Code.js +93 -119
  111. package/dist/features/blocks/premade/CodeBlock/Component/Code.js.map +1 -1
  112. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.js +11 -19
  113. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.js.map +1 -1
  114. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.js +20 -32
  115. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.js.map +1 -1
  116. package/dist/features/blocks/premade/CodeBlock/Component/defaultLanguages.js +83 -84
  117. package/dist/features/blocks/premade/CodeBlock/Component/defaultLanguages.js.map +1 -1
  118. package/dist/features/blocks/premade/CodeBlock/converter.js +40 -36
  119. package/dist/features/blocks/premade/CodeBlock/converter.js.map +1 -1
  120. package/dist/features/blocks/premade/CodeBlock/converterClient.js +1 -1
  121. package/dist/features/blocks/premade/CodeBlock/converterClient.js.map +1 -1
  122. package/dist/features/blocks/premade/CodeBlock/index.js +49 -49
  123. package/dist/features/blocks/premade/CodeBlock/index.js.map +1 -1
  124. package/dist/features/blocks/server/graphQLPopulationPromise.js +44 -29
  125. package/dist/features/blocks/server/graphQLPopulationPromise.js.map +1 -1
  126. package/dist/features/blocks/server/i18n.js +333 -334
  127. package/dist/features/blocks/server/i18n.js.map +1 -1
  128. package/dist/features/blocks/server/index.js +218 -238
  129. package/dist/features/blocks/server/index.js.map +1 -1
  130. package/dist/features/blocks/server/markdown/linesFromMatchToContentAndPropsString.js +122 -123
  131. package/dist/features/blocks/server/markdown/linesFromMatchToContentAndPropsString.js.map +1 -1
  132. package/dist/features/blocks/server/markdown/markdownTransformer.js +349 -347
  133. package/dist/features/blocks/server/markdown/markdownTransformer.js.map +1 -1
  134. package/dist/features/blocks/server/nodes/BlocksNode.js +90 -86
  135. package/dist/features/blocks/server/nodes/BlocksNode.js.map +1 -1
  136. package/dist/features/blocks/server/nodes/InlineBlocksNode.js +87 -84
  137. package/dist/features/blocks/server/nodes/InlineBlocksNode.js.map +1 -1
  138. package/dist/features/blocks/server/validate.js +55 -42
  139. package/dist/features/blocks/server/validate.js.map +1 -1
  140. package/dist/features/converters/htmlToLexical/index.js +24 -21
  141. package/dist/features/converters/htmlToLexical/index.js.map +1 -1
  142. package/dist/features/converters/lexicalToHtml/async/converters/blockquote.js +10 -7
  143. package/dist/features/converters/lexicalToHtml/async/converters/blockquote.js.map +1 -1
  144. package/dist/features/converters/lexicalToHtml/async/converters/heading.js +10 -7
  145. package/dist/features/converters/lexicalToHtml/async/converters/heading.js.map +1 -1
  146. package/dist/features/converters/lexicalToHtml/async/converters/horizontalRule.js +1 -2
  147. package/dist/features/converters/lexicalToHtml/async/converters/horizontalRule.js.map +1 -1
  148. package/dist/features/converters/lexicalToHtml/async/converters/linebreak.js +1 -2
  149. package/dist/features/converters/lexicalToHtml/async/converters/linebreak.js.map +1 -1
  150. package/dist/features/converters/lexicalToHtml/async/converters/link.js +37 -28
  151. package/dist/features/converters/lexicalToHtml/async/converters/link.js.map +1 -1
  152. package/dist/features/converters/lexicalToHtml/async/converters/list.js +26 -18
  153. package/dist/features/converters/lexicalToHtml/async/converters/list.js.map +1 -1
  154. package/dist/features/converters/lexicalToHtml/async/converters/paragraph.js +12 -9
  155. package/dist/features/converters/lexicalToHtml/async/converters/paragraph.js.map +1 -1
  156. package/dist/features/converters/lexicalToHtml/async/converters/tab.js +1 -2
  157. package/dist/features/converters/lexicalToHtml/async/converters/tab.js.map +1 -1
  158. package/dist/features/converters/lexicalToHtml/async/converters/table.js +38 -27
  159. package/dist/features/converters/lexicalToHtml/async/converters/table.js.map +1 -1
  160. package/dist/features/converters/lexicalToHtml/async/converters/text.js +26 -25
  161. package/dist/features/converters/lexicalToHtml/async/converters/text.js.map +1 -1
  162. package/dist/features/converters/lexicalToHtml/async/converters/upload.js +44 -41
  163. package/dist/features/converters/lexicalToHtml/async/converters/upload.js.map +1 -1
  164. package/dist/features/converters/lexicalToHtml/async/defaultConverters.js +11 -12
  165. package/dist/features/converters/lexicalToHtml/async/defaultConverters.js.map +1 -1
  166. package/dist/features/converters/lexicalToHtml/async/field/index.js +56 -56
  167. package/dist/features/converters/lexicalToHtml/async/field/index.js.map +1 -1
  168. package/dist/features/converters/lexicalToHtml/async/index.js +97 -87
  169. package/dist/features/converters/lexicalToHtml/async/index.js.map +1 -1
  170. package/dist/features/converters/lexicalToHtml/async/types.js +1 -4
  171. package/dist/features/converters/lexicalToHtml/async/types.js.map +1 -1
  172. package/dist/features/converters/lexicalToHtml/shared/findConverterForNode.js +62 -57
  173. package/dist/features/converters/lexicalToHtml/shared/findConverterForNode.js.map +1 -1
  174. package/dist/features/converters/lexicalToHtml/shared/types.js +1 -2
  175. package/dist/features/converters/lexicalToHtml/shared/types.js.map +1 -1
  176. package/dist/features/converters/lexicalToHtml/sync/converters/blockquote.js +10 -7
  177. package/dist/features/converters/lexicalToHtml/sync/converters/blockquote.js.map +1 -1
  178. package/dist/features/converters/lexicalToHtml/sync/converters/heading.js +10 -7
  179. package/dist/features/converters/lexicalToHtml/sync/converters/heading.js.map +1 -1
  180. package/dist/features/converters/lexicalToHtml/sync/converters/horizontalRule.js +1 -2
  181. package/dist/features/converters/lexicalToHtml/sync/converters/horizontalRule.js.map +1 -1
  182. package/dist/features/converters/lexicalToHtml/sync/converters/linebreak.js +1 -2
  183. package/dist/features/converters/lexicalToHtml/sync/converters/linebreak.js.map +1 -1
  184. package/dist/features/converters/lexicalToHtml/sync/converters/link.js +35 -27
  185. package/dist/features/converters/lexicalToHtml/sync/converters/link.js.map +1 -1
  186. package/dist/features/converters/lexicalToHtml/sync/converters/list.js +26 -18
  187. package/dist/features/converters/lexicalToHtml/sync/converters/list.js.map +1 -1
  188. package/dist/features/converters/lexicalToHtml/sync/converters/paragraph.js +12 -9
  189. package/dist/features/converters/lexicalToHtml/sync/converters/paragraph.js.map +1 -1
  190. package/dist/features/converters/lexicalToHtml/sync/converters/tab.js +1 -2
  191. package/dist/features/converters/lexicalToHtml/sync/converters/tab.js.map +1 -1
  192. package/dist/features/converters/lexicalToHtml/sync/converters/table.js +38 -27
  193. package/dist/features/converters/lexicalToHtml/sync/converters/table.js.map +1 -1
  194. package/dist/features/converters/lexicalToHtml/sync/converters/text.js +26 -25
  195. package/dist/features/converters/lexicalToHtml/sync/converters/text.js.map +1 -1
  196. package/dist/features/converters/lexicalToHtml/sync/converters/upload.js +37 -35
  197. package/dist/features/converters/lexicalToHtml/sync/converters/upload.js.map +1 -1
  198. package/dist/features/converters/lexicalToHtml/sync/defaultConverters.js +11 -12
  199. package/dist/features/converters/lexicalToHtml/sync/defaultConverters.js.map +1 -1
  200. package/dist/features/converters/lexicalToHtml/sync/index.js +92 -84
  201. package/dist/features/converters/lexicalToHtml/sync/index.js.map +1 -1
  202. package/dist/features/converters/lexicalToHtml/sync/types.js +1 -4
  203. package/dist/features/converters/lexicalToHtml/sync/types.js.map +1 -1
  204. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/linebreak.js +4 -7
  205. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/linebreak.js.map +1 -1
  206. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/paragraph.js +34 -29
  207. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/paragraph.js.map +1 -1
  208. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/tab.js +6 -7
  209. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/tab.js.map +1 -1
  210. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/text.js +28 -29
  211. package/dist/features/converters/lexicalToHtml_deprecated/converter/converters/text.js.map +1 -1
  212. package/dist/features/converters/lexicalToHtml_deprecated/converter/defaultConverters.js +2 -7
  213. package/dist/features/converters/lexicalToHtml_deprecated/converter/defaultConverters.js.map +1 -1
  214. package/dist/features/converters/lexicalToHtml_deprecated/converter/index.js +84 -84
  215. package/dist/features/converters/lexicalToHtml_deprecated/converter/index.js.map +1 -1
  216. package/dist/features/converters/lexicalToHtml_deprecated/converter/types.js +1 -6
  217. package/dist/features/converters/lexicalToHtml_deprecated/converter/types.js.map +1 -1
  218. package/dist/features/converters/lexicalToHtml_deprecated/field/index.js +107 -107
  219. package/dist/features/converters/lexicalToHtml_deprecated/field/index.js.map +1 -1
  220. package/dist/features/converters/lexicalToHtml_deprecated/index.js +4 -4
  221. package/dist/features/converters/lexicalToHtml_deprecated/index.js.map +1 -1
  222. package/dist/features/converters/lexicalToJSX/Component/index.js +36 -46
  223. package/dist/features/converters/lexicalToJSX/Component/index.js.map +1 -1
  224. package/dist/features/converters/lexicalToJSX/converter/converters/blockquote.js +12 -14
  225. package/dist/features/converters/lexicalToJSX/converter/converters/blockquote.js.map +1 -1
  226. package/dist/features/converters/lexicalToJSX/converter/converters/heading.js +13 -15
  227. package/dist/features/converters/lexicalToJSX/converter/converters/heading.js.map +1 -1
  228. package/dist/features/converters/lexicalToJSX/converter/converters/horizontalRule.js +2 -7
  229. package/dist/features/converters/lexicalToJSX/converter/converters/horizontalRule.js.map +1 -1
  230. package/dist/features/converters/lexicalToJSX/converter/converters/linebreak.js +2 -7
  231. package/dist/features/converters/lexicalToJSX/converter/converters/linebreak.js.map +1 -1
  232. package/dist/features/converters/lexicalToJSX/converter/converters/link.js +47 -49
  233. package/dist/features/converters/lexicalToJSX/converter/converters/link.js.map +1 -1
  234. package/dist/features/converters/lexicalToJSX/converter/converters/list.js +56 -78
  235. package/dist/features/converters/lexicalToJSX/converter/converters/list.js.map +1 -1
  236. package/dist/features/converters/lexicalToJSX/converter/converters/paragraph.js +16 -26
  237. package/dist/features/converters/lexicalToJSX/converter/converters/paragraph.js.map +1 -1
  238. package/dist/features/converters/lexicalToJSX/converter/converters/tab.js +1 -2
  239. package/dist/features/converters/lexicalToJSX/converter/converters/tab.js.map +1 -1
  240. package/dist/features/converters/lexicalToJSX/converter/converters/table.js +59 -73
  241. package/dist/features/converters/lexicalToJSX/converter/converters/table.js.map +1 -1
  242. package/dist/features/converters/lexicalToJSX/converter/converters/text.js +47 -74
  243. package/dist/features/converters/lexicalToJSX/converter/converters/text.js.map +1 -1
  244. package/dist/features/converters/lexicalToJSX/converter/converters/upload.js +61 -77
  245. package/dist/features/converters/lexicalToJSX/converter/converters/upload.js.map +1 -1
  246. package/dist/features/converters/lexicalToJSX/converter/defaultConverters.js +11 -12
  247. package/dist/features/converters/lexicalToJSX/converter/defaultConverters.js.map +1 -1
  248. package/dist/features/converters/lexicalToJSX/converter/index.js +128 -123
  249. package/dist/features/converters/lexicalToJSX/converter/index.js.map +1 -1
  250. package/dist/features/converters/lexicalToJSX/converter/types.js +1 -4
  251. package/dist/features/converters/lexicalToJSX/converter/types.js.map +1 -1
  252. package/dist/features/converters/lexicalToMarkdown/index.js +19 -17
  253. package/dist/features/converters/lexicalToMarkdown/index.js.map +1 -1
  254. package/dist/features/converters/lexicalToPlaintext/convertLexicalToPlaintext.spec.js +146 -223
  255. package/dist/features/converters/lexicalToPlaintext/convertLexicalToPlaintext.spec.js.map +1 -1
  256. package/dist/features/converters/lexicalToPlaintext/shared/findConverterForNode.js +13 -11
  257. package/dist/features/converters/lexicalToPlaintext/shared/findConverterForNode.js.map +1 -1
  258. package/dist/features/converters/lexicalToPlaintext/shared/types.js +1 -2
  259. package/dist/features/converters/lexicalToPlaintext/shared/types.js.map +1 -1
  260. package/dist/features/converters/lexicalToPlaintext/sync/index.js +82 -83
  261. package/dist/features/converters/lexicalToPlaintext/sync/index.js.map +1 -1
  262. package/dist/features/converters/lexicalToPlaintext/sync/types.js +1 -3
  263. package/dist/features/converters/lexicalToPlaintext/sync/types.js.map +1 -1
  264. package/dist/features/converters/markdownToLexical/index.js +16 -14
  265. package/dist/features/converters/markdownToLexical/index.js.map +1 -1
  266. package/dist/features/converters/utilities/payloadPopulateFn.js +38 -37
  267. package/dist/features/converters/utilities/payloadPopulateFn.js.map +1 -1
  268. package/dist/features/converters/utilities/restPopulateFn.js +30 -24
  269. package/dist/features/converters/utilities/restPopulateFn.js.map +1 -1
  270. package/dist/features/debug/jsxConverter/client/index.js +5 -7
  271. package/dist/features/debug/jsxConverter/client/index.js.map +1 -1
  272. package/dist/features/debug/jsxConverter/client/plugin/index.js +47 -27
  273. package/dist/features/debug/jsxConverter/client/plugin/index.js.map +1 -1
  274. package/dist/features/debug/jsxConverter/server/index.js +4 -5
  275. package/dist/features/debug/jsxConverter/server/index.js.map +1 -1
  276. package/dist/features/debug/testRecorder/client/index.js +5 -7
  277. package/dist/features/debug/testRecorder/client/index.js.map +1 -1
  278. package/dist/features/debug/testRecorder/client/plugin/index.js +365 -456
  279. package/dist/features/debug/testRecorder/client/plugin/index.js.map +1 -1
  280. package/dist/features/debug/testRecorder/server/index.js +4 -5
  281. package/dist/features/debug/testRecorder/server/index.js.map +1 -1
  282. package/dist/features/debug/treeView/client/index.js +5 -7
  283. package/dist/features/debug/treeView/client/index.js.map +1 -1
  284. package/dist/features/debug/treeView/client/plugin/index.js +23 -18
  285. package/dist/features/debug/treeView/client/plugin/index.js.map +1 -1
  286. package/dist/features/debug/treeView/server/index.js +4 -5
  287. package/dist/features/debug/treeView/server/index.js.map +1 -1
  288. package/dist/features/experimental_table/client/index.js +42 -61
  289. package/dist/features/experimental_table/client/index.js.map +1 -1
  290. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.js +517 -752
  291. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.js.map +1 -1
  292. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.js +316 -350
  293. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.js.map +1 -1
  294. package/dist/features/experimental_table/client/plugins/TableHoverActionsPlugin/index.js +225 -215
  295. package/dist/features/experimental_table/client/plugins/TableHoverActionsPlugin/index.js.map +1 -1
  296. package/dist/features/experimental_table/client/plugins/TablePlugin/index.js +133 -104
  297. package/dist/features/experimental_table/client/plugins/TablePlugin/index.js.map +1 -1
  298. package/dist/features/experimental_table/client/utils/debounce.js +107 -89
  299. package/dist/features/experimental_table/client/utils/debounce.js.map +1 -1
  300. package/dist/features/experimental_table/client/utils/useDebounce.js +39 -21
  301. package/dist/features/experimental_table/client/utils/useDebounce.js.map +1 -1
  302. package/dist/features/experimental_table/markdownTransformer.js +118 -123
  303. package/dist/features/experimental_table/markdownTransformer.js.map +1 -1
  304. package/dist/features/experimental_table/server/index.js +143 -125
  305. package/dist/features/experimental_table/server/index.js.map +1 -1
  306. package/dist/features/format/bold/feature.client.js +35 -38
  307. package/dist/features/format/bold/feature.client.js.map +1 -1
  308. package/dist/features/format/bold/feature.server.js +14 -18
  309. package/dist/features/format/bold/feature.server.js.map +1 -1
  310. package/dist/features/format/bold/markdownTransformers.js +14 -25
  311. package/dist/features/format/bold/markdownTransformers.js.map +1 -1
  312. package/dist/features/format/inlineCode/feature.client.js +27 -31
  313. package/dist/features/format/inlineCode/feature.client.js.map +1 -1
  314. package/dist/features/format/inlineCode/feature.server.js +5 -8
  315. package/dist/features/format/inlineCode/feature.server.js.map +1 -1
  316. package/dist/features/format/inlineCode/markdownTransformers.js +3 -6
  317. package/dist/features/format/inlineCode/markdownTransformers.js.map +1 -1
  318. package/dist/features/format/italic/feature.client.js +27 -32
  319. package/dist/features/format/italic/feature.client.js.map +1 -1
  320. package/dist/features/format/italic/feature.server.js +5 -9
  321. package/dist/features/format/italic/feature.server.js.map +1 -1
  322. package/dist/features/format/italic/markdownTransformers.js +7 -12
  323. package/dist/features/format/italic/markdownTransformers.js.map +1 -1
  324. package/dist/features/format/shared/toolbarFormatGroup.js +8 -8
  325. package/dist/features/format/shared/toolbarFormatGroup.js.map +1 -1
  326. package/dist/features/format/strikethrough/feature.client.js +27 -31
  327. package/dist/features/format/strikethrough/feature.client.js.map +1 -1
  328. package/dist/features/format/strikethrough/feature.server.js +5 -8
  329. package/dist/features/format/strikethrough/feature.server.js.map +1 -1
  330. package/dist/features/format/strikethrough/markdownTransformers.js +3 -6
  331. package/dist/features/format/strikethrough/markdownTransformers.js.map +1 -1
  332. package/dist/features/format/subscript/feature.client.js +26 -28
  333. package/dist/features/format/subscript/feature.client.js.map +1 -1
  334. package/dist/features/format/subscript/feature.server.js +4 -5
  335. package/dist/features/format/subscript/feature.server.js.map +1 -1
  336. package/dist/features/format/superscript/feature.client.js +26 -28
  337. package/dist/features/format/superscript/feature.client.js.map +1 -1
  338. package/dist/features/format/superscript/feature.server.js +4 -5
  339. package/dist/features/format/superscript/feature.server.js.map +1 -1
  340. package/dist/features/format/underline/feature.client.js +26 -28
  341. package/dist/features/format/underline/feature.client.js.map +1 -1
  342. package/dist/features/format/underline/feature.server.js +4 -5
  343. package/dist/features/format/underline/feature.server.js.map +1 -1
  344. package/dist/features/heading/client/index.js +142 -121
  345. package/dist/features/heading/client/index.js.map +1 -1
  346. package/dist/features/heading/markdownTransformer.js +22 -25
  347. package/dist/features/heading/markdownTransformer.js.map +1 -1
  348. package/dist/features/heading/server/i18n.js +111 -112
  349. package/dist/features/heading/server/i18n.js.map +1 -1
  350. package/dist/features/heading/server/index.js +60 -62
  351. package/dist/features/heading/server/index.js.map +1 -1
  352. package/dist/features/horizontalRule/client/index.js +48 -57
  353. package/dist/features/horizontalRule/client/index.js.map +1 -1
  354. package/dist/features/horizontalRule/client/markdownTransformer.js +15 -18
  355. package/dist/features/horizontalRule/client/markdownTransformer.js.map +1 -1
  356. package/dist/features/horizontalRule/client/nodes/HorizontalRuleNode.js +27 -25
  357. package/dist/features/horizontalRule/client/nodes/HorizontalRuleNode.js.map +1 -1
  358. package/dist/features/horizontalRule/client/plugin/index.js +32 -21
  359. package/dist/features/horizontalRule/client/plugin/index.js.map +1 -1
  360. package/dist/features/horizontalRule/server/i18n.js +111 -112
  361. package/dist/features/horizontalRule/server/i18n.js.map +1 -1
  362. package/dist/features/horizontalRule/server/index.js +17 -24
  363. package/dist/features/horizontalRule/server/index.js.map +1 -1
  364. package/dist/features/horizontalRule/server/markdownTransformer.js +15 -18
  365. package/dist/features/horizontalRule/server/markdownTransformer.js.map +1 -1
  366. package/dist/features/horizontalRule/server/nodes/HorizontalRuleNode.js +72 -69
  367. package/dist/features/horizontalRule/server/nodes/HorizontalRuleNode.js.map +1 -1
  368. package/dist/features/indent/client/IndentPlugin.js +78 -78
  369. package/dist/features/indent/client/IndentPlugin.js.map +1 -1
  370. package/dist/features/indent/client/index.js +77 -68
  371. package/dist/features/indent/client/index.js.map +1 -1
  372. package/dist/features/indent/client/toolbarIndentGroup.js +8 -8
  373. package/dist/features/indent/client/toolbarIndentGroup.js.map +1 -1
  374. package/dist/features/indent/server/i18n.js +148 -149
  375. package/dist/features/indent/server/i18n.js.map +1 -1
  376. package/dist/features/indent/server/index.js +11 -18
  377. package/dist/features/indent/server/index.js.map +1 -1
  378. package/dist/features/link/client/index.js +80 -83
  379. package/dist/features/link/client/index.js.map +1 -1
  380. package/dist/features/link/client/plugins/autoLink/index.js +273 -280
  381. package/dist/features/link/client/plugins/autoLink/index.js.map +1 -1
  382. package/dist/features/link/client/plugins/clickableLink/index.js +4 -8
  383. package/dist/features/link/client/plugins/clickableLink/index.js.map +1 -1
  384. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/commands.js +1 -1
  385. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/commands.js.map +1 -1
  386. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/index.js +297 -378
  387. package/dist/features/link/client/plugins/floatingLinkEditor/LinkEditor/index.js.map +1 -1
  388. package/dist/features/link/client/plugins/floatingLinkEditor/index.js +9 -12
  389. package/dist/features/link/client/plugins/floatingLinkEditor/index.js.map +1 -1
  390. package/dist/features/link/client/plugins/floatingLinkEditor/types.js +1 -6
  391. package/dist/features/link/client/plugins/floatingLinkEditor/types.js.map +1 -1
  392. package/dist/features/link/client/plugins/link/index.js +68 -53
  393. package/dist/features/link/client/plugins/link/index.js.map +1 -1
  394. package/dist/features/link/markdownTransformer.js +33 -34
  395. package/dist/features/link/markdownTransformer.js.map +1 -1
  396. package/dist/features/link/nodes/AutoLinkNode.js +58 -56
  397. package/dist/features/link/nodes/AutoLinkNode.js.map +1 -1
  398. package/dist/features/link/nodes/LinkNode.js +288 -286
  399. package/dist/features/link/nodes/LinkNode.js.map +1 -1
  400. package/dist/features/link/nodes/types.js +1 -6
  401. package/dist/features/link/nodes/types.js.map +1 -1
  402. package/dist/features/link/server/baseFields.js +140 -115
  403. package/dist/features/link/server/baseFields.js.map +1 -1
  404. package/dist/features/link/server/graphQLPopulationPromise.js +45 -29
  405. package/dist/features/link/server/graphQLPopulationPromise.js.map +1 -1
  406. package/dist/features/link/server/i18n.js +148 -149
  407. package/dist/features/link/server/i18n.js.map +1 -1
  408. package/dist/features/link/server/index.js +143 -156
  409. package/dist/features/link/server/index.js.map +1 -1
  410. package/dist/features/link/server/transformExtraFields.js +15 -15
  411. package/dist/features/link/server/transformExtraFields.js.map +1 -1
  412. package/dist/features/link/server/validate.js +46 -35
  413. package/dist/features/link/server/validate.js.map +1 -1
  414. package/dist/features/lists/checklist/client/index.js +78 -86
  415. package/dist/features/lists/checklist/client/index.js.map +1 -1
  416. package/dist/features/lists/checklist/client/plugin/index.js +4 -8
  417. package/dist/features/lists/checklist/client/plugin/index.js.map +1 -1
  418. package/dist/features/lists/checklist/markdownTransformers.js +7 -11
  419. package/dist/features/lists/checklist/markdownTransformers.js.map +1 -1
  420. package/dist/features/lists/checklist/server/i18n.js +111 -112
  421. package/dist/features/lists/checklist/server/i18n.js.map +1 -1
  422. package/dist/features/lists/checklist/server/index.js +21 -26
  423. package/dist/features/lists/checklist/server/index.js.map +1 -1
  424. package/dist/features/lists/htmlConverter.js +62 -47
  425. package/dist/features/lists/htmlConverter.js.map +1 -1
  426. package/dist/features/lists/orderedList/client/index.js +72 -78
  427. package/dist/features/lists/orderedList/client/index.js.map +1 -1
  428. package/dist/features/lists/orderedList/markdownTransformer.js +7 -11
  429. package/dist/features/lists/orderedList/markdownTransformer.js.map +1 -1
  430. package/dist/features/lists/orderedList/server/i18n.js +111 -112
  431. package/dist/features/lists/orderedList/server/i18n.js.map +1 -1
  432. package/dist/features/lists/orderedList/server/index.js +21 -26
  433. package/dist/features/lists/orderedList/server/index.js.map +1 -1
  434. package/dist/features/lists/plugin/index.js +4 -8
  435. package/dist/features/lists/plugin/index.js.map +1 -1
  436. package/dist/features/lists/shared/markdown.js +48 -49
  437. package/dist/features/lists/shared/markdown.js.map +1 -1
  438. package/dist/features/lists/shared/shouldRegisterListBaseNodes.js +9 -10
  439. package/dist/features/lists/shared/shouldRegisterListBaseNodes.js.map +1 -1
  440. package/dist/features/lists/shared/slashMenuListGroup.js +9 -8
  441. package/dist/features/lists/shared/slashMenuListGroup.js.map +1 -1
  442. package/dist/features/lists/unorderedList/client/index.js +68 -76
  443. package/dist/features/lists/unorderedList/client/index.js.map +1 -1
  444. package/dist/features/lists/unorderedList/markdownTransformer.js +7 -11
  445. package/dist/features/lists/unorderedList/markdownTransformer.js.map +1 -1
  446. package/dist/features/lists/unorderedList/server/i18n.js +111 -112
  447. package/dist/features/lists/unorderedList/server/i18n.js.map +1 -1
  448. package/dist/features/lists/unorderedList/server/index.js +17 -24
  449. package/dist/features/lists/unorderedList/server/index.js.map +1 -1
  450. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/heading/converter.js +18 -17
  451. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/heading/converter.js.map +1 -1
  452. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/link/converter.js +30 -29
  453. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/link/converter.js.map +1 -1
  454. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/list/converter.js +21 -20
  455. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/list/converter.js.map +1 -1
  456. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/listItem/converter.js +21 -19
  457. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/listItem/converter.js.map +1 -1
  458. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/quote/converter.js +18 -17
  459. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/quote/converter.js.map +1 -1
  460. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/unknown/converter.js +24 -23
  461. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/unknown/converter.js.map +1 -1
  462. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/upload/converter.js +20 -21
  463. package/dist/features/migrations/lexicalPluginToLexical/converter/converters/upload/converter.js.map +1 -1
  464. package/dist/features/migrations/lexicalPluginToLexical/converter/defaultConverters.js +1 -10
  465. package/dist/features/migrations/lexicalPluginToLexical/converter/defaultConverters.js.map +1 -1
  466. package/dist/features/migrations/lexicalPluginToLexical/converter/index.js +70 -64
  467. package/dist/features/migrations/lexicalPluginToLexical/converter/index.js.map +1 -1
  468. package/dist/features/migrations/lexicalPluginToLexical/converter/types.js +1 -2
  469. package/dist/features/migrations/lexicalPluginToLexical/converter/types.js.map +1 -1
  470. package/dist/features/migrations/lexicalPluginToLexical/feature.client.js +5 -7
  471. package/dist/features/migrations/lexicalPluginToLexical/feature.client.js.map +1 -1
  472. package/dist/features/migrations/lexicalPluginToLexical/feature.server.js +42 -43
  473. package/dist/features/migrations/lexicalPluginToLexical/feature.server.js.map +1 -1
  474. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/Component.js +11 -21
  475. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/Component.js.map +1 -1
  476. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.js +66 -65
  477. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.js.map +1 -1
  478. package/dist/features/migrations/slateToLexical/converter/converters/blockquote/converter.js +19 -19
  479. package/dist/features/migrations/slateToLexical/converter/converters/blockquote/converter.js.map +1 -1
  480. package/dist/features/migrations/slateToLexical/converter/converters/heading/converter.js +20 -26
  481. package/dist/features/migrations/slateToLexical/converter/converters/heading/converter.js.map +1 -1
  482. package/dist/features/migrations/slateToLexical/converter/converters/indent/converter.js +28 -30
  483. package/dist/features/migrations/slateToLexical/converter/converters/indent/converter.js.map +1 -1
  484. package/dist/features/migrations/slateToLexical/converter/converters/link/converter.js +26 -27
  485. package/dist/features/migrations/slateToLexical/converter/converters/link/converter.js.map +1 -1
  486. package/dist/features/migrations/slateToLexical/converter/converters/listItem/converter.js +22 -21
  487. package/dist/features/migrations/slateToLexical/converter/converters/listItem/converter.js.map +1 -1
  488. package/dist/features/migrations/slateToLexical/converter/converters/orderedList/converter.js +22 -22
  489. package/dist/features/migrations/slateToLexical/converter/converters/orderedList/converter.js.map +1 -1
  490. package/dist/features/migrations/slateToLexical/converter/converters/relationship/converter.js +12 -13
  491. package/dist/features/migrations/slateToLexical/converter/converters/relationship/converter.js.map +1 -1
  492. package/dist/features/migrations/slateToLexical/converter/converters/unknown/converter.js +23 -23
  493. package/dist/features/migrations/slateToLexical/converter/converters/unknown/converter.js.map +1 -1
  494. package/dist/features/migrations/slateToLexical/converter/converters/unorderedList/converter.js +22 -22
  495. package/dist/features/migrations/slateToLexical/converter/converters/unorderedList/converter.js.map +1 -1
  496. package/dist/features/migrations/slateToLexical/converter/converters/upload/converter.js +15 -16
  497. package/dist/features/migrations/slateToLexical/converter/converters/upload/converter.js.map +1 -1
  498. package/dist/features/migrations/slateToLexical/converter/defaultConverters.js +1 -13
  499. package/dist/features/migrations/slateToLexical/converter/defaultConverters.js.map +1 -1
  500. package/dist/features/migrations/slateToLexical/converter/index.js +117 -110
  501. package/dist/features/migrations/slateToLexical/converter/index.js.map +1 -1
  502. package/dist/features/migrations/slateToLexical/converter/types.js +1 -2
  503. package/dist/features/migrations/slateToLexical/converter/types.js.map +1 -1
  504. package/dist/features/migrations/slateToLexical/feature.client.js +5 -7
  505. package/dist/features/migrations/slateToLexical/feature.client.js.map +1 -1
  506. package/dist/features/migrations/slateToLexical/feature.server.js +45 -54
  507. package/dist/features/migrations/slateToLexical/feature.server.js.map +1 -1
  508. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/Component.js +11 -21
  509. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/Component.js.map +1 -1
  510. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.js +66 -65
  511. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.js.map +1 -1
  512. package/dist/features/paragraph/client/index.js +58 -61
  513. package/dist/features/paragraph/client/index.js.map +1 -1
  514. package/dist/features/paragraph/server/i18n.js +148 -149
  515. package/dist/features/paragraph/server/i18n.js.map +1 -1
  516. package/dist/features/paragraph/server/index.js +6 -7
  517. package/dist/features/paragraph/server/index.js.map +1 -1
  518. package/dist/features/relationship/client/components/RelationshipComponent.js +118 -147
  519. package/dist/features/relationship/client/components/RelationshipComponent.js.map +1 -1
  520. package/dist/features/relationship/client/drawer/commands.js +0 -1
  521. package/dist/features/relationship/client/drawer/commands.js.map +1 -1
  522. package/dist/features/relationship/client/drawer/index.js +132 -81
  523. package/dist/features/relationship/client/drawer/index.js.map +1 -1
  524. package/dist/features/relationship/client/index.js +53 -59
  525. package/dist/features/relationship/client/index.js.map +1 -1
  526. package/dist/features/relationship/client/nodes/RelationshipNode.js +60 -64
  527. package/dist/features/relationship/client/nodes/RelationshipNode.js.map +1 -1
  528. package/dist/features/relationship/client/plugins/index.js +69 -39
  529. package/dist/features/relationship/client/plugins/index.js.map +1 -1
  530. package/dist/features/relationship/client/utils/useEnabledRelationships.js +58 -48
  531. package/dist/features/relationship/client/utils/useEnabledRelationships.js.map +1 -1
  532. package/dist/features/relationship/server/graphQLPopulationPromise.js +34 -26
  533. package/dist/features/relationship/server/graphQLPopulationPromise.js.map +1 -1
  534. package/dist/features/relationship/server/i18n.js +111 -112
  535. package/dist/features/relationship/server/i18n.js.map +1 -1
  536. package/dist/features/relationship/server/index.js +59 -64
  537. package/dist/features/relationship/server/index.js.map +1 -1
  538. package/dist/features/relationship/server/nodes/RelationshipNode.js +95 -92
  539. package/dist/features/relationship/server/nodes/RelationshipNode.js.map +1 -1
  540. package/dist/features/shared/slashMenu/basicGroup.js +9 -8
  541. package/dist/features/shared/slashMenu/basicGroup.js.map +1 -1
  542. package/dist/features/shared/toolbar/addDropdownGroup.js +8 -9
  543. package/dist/features/shared/toolbar/addDropdownGroup.js.map +1 -1
  544. package/dist/features/shared/toolbar/featureButtonsGroup.js +7 -8
  545. package/dist/features/shared/toolbar/featureButtonsGroup.js.map +1 -1
  546. package/dist/features/shared/toolbar/textDropdownGroup.js +8 -9
  547. package/dist/features/shared/toolbar/textDropdownGroup.js.map +1 -1
  548. package/dist/features/textState/defaultColors.js +370 -370
  549. package/dist/features/textState/defaultColors.js.map +1 -1
  550. package/dist/features/textState/feature.client.js +64 -77
  551. package/dist/features/textState/feature.client.js.map +1 -1
  552. package/dist/features/textState/feature.server.js +14 -46
  553. package/dist/features/textState/feature.server.js.map +1 -1
  554. package/dist/features/textState/i18n.js +111 -112
  555. package/dist/features/textState/i18n.js.map +1 -1
  556. package/dist/features/textState/textState.js +62 -64
  557. package/dist/features/textState/textState.js.map +1 -1
  558. package/dist/features/toolbars/fixed/client/Toolbar/index.js +297 -263
  559. package/dist/features/toolbars/fixed/client/Toolbar/index.js.map +1 -1
  560. package/dist/features/toolbars/fixed/client/index.js +5 -7
  561. package/dist/features/toolbars/fixed/client/index.js.map +1 -1
  562. package/dist/features/toolbars/fixed/server/index.js +16 -32
  563. package/dist/features/toolbars/fixed/server/index.js.map +1 -1
  564. package/dist/features/toolbars/inline/client/Toolbar/index.js +366 -343
  565. package/dist/features/toolbars/inline/client/Toolbar/index.js.map +1 -1
  566. package/dist/features/toolbars/inline/client/index.js +5 -7
  567. package/dist/features/toolbars/inline/client/index.js.map +1 -1
  568. package/dist/features/toolbars/inline/server/index.js +4 -5
  569. package/dist/features/toolbars/inline/server/index.js.map +1 -1
  570. package/dist/features/toolbars/shared/ToolbarButton/index.js +145 -103
  571. package/dist/features/toolbars/shared/ToolbarButton/index.js.map +1 -1
  572. package/dist/features/toolbars/shared/ToolbarDropdown/DropDown.js +208 -264
  573. package/dist/features/toolbars/shared/ToolbarDropdown/DropDown.js.map +1 -1
  574. package/dist/features/toolbars/shared/ToolbarDropdown/index.js +176 -172
  575. package/dist/features/toolbars/shared/ToolbarDropdown/index.js.map +1 -1
  576. package/dist/features/toolbars/types.js +1 -29
  577. package/dist/features/toolbars/types.js.map +1 -1
  578. package/dist/features/typeUtilities.js +2 -3
  579. package/dist/features/typeUtilities.js.map +1 -1
  580. package/dist/features/typesClient.js +1 -61
  581. package/dist/features/typesClient.js.map +1 -1
  582. package/dist/features/typesServer.js +1 -90
  583. package/dist/features/typesServer.js.map +1 -1
  584. package/dist/features/upload/client/component/index.js +189 -242
  585. package/dist/features/upload/client/component/index.js.map +1 -1
  586. package/dist/features/upload/client/component/pending/index.js +10 -19
  587. package/dist/features/upload/client/component/pending/index.js.map +1 -1
  588. package/dist/features/upload/client/drawer/commands.js +1 -1
  589. package/dist/features/upload/client/drawer/commands.js.map +1 -1
  590. package/dist/features/upload/client/drawer/index.js +132 -83
  591. package/dist/features/upload/client/drawer/index.js.map +1 -1
  592. package/dist/features/upload/client/index.js +51 -61
  593. package/dist/features/upload/client/index.js.map +1 -1
  594. package/dist/features/upload/client/nodes/UploadNode.js +61 -67
  595. package/dist/features/upload/client/nodes/UploadNode.js.map +1 -1
  596. package/dist/features/upload/client/plugin/index.js +331 -290
  597. package/dist/features/upload/client/plugin/index.js.map +1 -1
  598. package/dist/features/upload/server/graphQLPopulationPromise.js +63 -48
  599. package/dist/features/upload/server/graphQLPopulationPromise.js.map +1 -1
  600. package/dist/features/upload/server/i18n.js +111 -112
  601. package/dist/features/upload/server/i18n.js.map +1 -1
  602. package/dist/features/upload/server/index.js +207 -197
  603. package/dist/features/upload/server/index.js.map +1 -1
  604. package/dist/features/upload/server/nodes/UploadNode.js +99 -115
  605. package/dist/features/upload/server/nodes/UploadNode.js.map +1 -1
  606. package/dist/features/upload/server/nodes/conversions.js +40 -41
  607. package/dist/features/upload/server/nodes/conversions.js.map +1 -1
  608. package/dist/features/upload/server/validate.js +62 -48
  609. package/dist/features/upload/server/validate.js.map +1 -1
  610. package/dist/field/Diff/converters/link.js +41 -32
  611. package/dist/field/Diff/converters/link.js.map +1 -1
  612. package/dist/field/Diff/converters/listitem/index.js +55 -75
  613. package/dist/field/Diff/converters/listitem/index.js.map +1 -1
  614. package/dist/field/Diff/converters/relationship/index.js +63 -85
  615. package/dist/field/Diff/converters/relationship/index.js.map +1 -1
  616. package/dist/field/Diff/converters/unknown/index.js +41 -64
  617. package/dist/field/Diff/converters/unknown/index.js.map +1 -1
  618. package/dist/field/Diff/converters/upload/index.js +66 -122
  619. package/dist/field/Diff/converters/upload/index.js.map +1 -1
  620. package/dist/field/Diff/index.js +66 -59
  621. package/dist/field/Diff/index.js.map +1 -1
  622. package/dist/field/Field.js +167 -226
  623. package/dist/field/Field.js.map +1 -1
  624. package/dist/field/RenderLexical/index.js +119 -123
  625. package/dist/field/RenderLexical/index.js.map +1 -1
  626. package/dist/field/bundled.css +1 -0
  627. package/dist/field/index.js +97 -61
  628. package/dist/field/index.js.map +1 -1
  629. package/dist/field/rscEntry.js +84 -86
  630. package/dist/field/rscEntry.js.map +1 -1
  631. package/dist/i18n.js +222 -223
  632. package/dist/i18n.js.map +1 -1
  633. package/dist/index.js +704 -639
  634. package/dist/index.js.map +1 -1
  635. package/dist/lexical/EditorPlugin.js +17 -21
  636. package/dist/lexical/EditorPlugin.js.map +1 -1
  637. package/dist/lexical/LexicalEditor.js +171 -274
  638. package/dist/lexical/LexicalEditor.js.map +1 -1
  639. package/dist/lexical/LexicalProvider.js +86 -109
  640. package/dist/lexical/LexicalProvider.js.map +1 -1
  641. package/dist/lexical/config/client/EditorConfigProvider.js +81 -94
  642. package/dist/lexical/config/client/EditorConfigProvider.js.map +1 -1
  643. package/dist/lexical/config/client/default.js +3 -3
  644. package/dist/lexical/config/client/default.js.map +1 -1
  645. package/dist/lexical/config/client/loader.js +38 -30
  646. package/dist/lexical/config/client/loader.js.map +1 -1
  647. package/dist/lexical/config/client/sanitize.js +187 -188
  648. package/dist/lexical/config/client/sanitize.js.map +1 -1
  649. package/dist/lexical/config/server/default.js +5 -27
  650. package/dist/lexical/config/server/default.js.map +1 -1
  651. package/dist/lexical/config/server/loader.js +106 -105
  652. package/dist/lexical/config/server/loader.js.map +1 -1
  653. package/dist/lexical/config/server/sanitize.js +113 -114
  654. package/dist/lexical/config/server/sanitize.js.map +1 -1
  655. package/dist/lexical/config/types.js +1 -4
  656. package/dist/lexical/config/types.js.map +1 -1
  657. package/dist/lexical/nodes/index.js +15 -12
  658. package/dist/lexical/nodes/index.js.map +1 -1
  659. package/dist/lexical/plugins/ClipboardPlugin/index.js +70 -66
  660. package/dist/lexical/plugins/ClipboardPlugin/index.js.map +1 -1
  661. package/dist/lexical/plugins/DecoratorPlugin/index.js +225 -208
  662. package/dist/lexical/plugins/DecoratorPlugin/index.js.map +1 -1
  663. package/dist/lexical/plugins/InsertParagraphAtEnd/index.js +41 -42
  664. package/dist/lexical/plugins/InsertParagraphAtEnd/index.js.map +1 -1
  665. package/dist/lexical/plugins/MarkdownShortcut/index.js +23 -11
  666. package/dist/lexical/plugins/MarkdownShortcut/index.js.map +1 -1
  667. package/dist/lexical/plugins/NormalizeSelection/index.js +19 -21
  668. package/dist/lexical/plugins/NormalizeSelection/index.js.map +1 -1
  669. package/dist/lexical/plugins/SelectAllPlugin/index.js +17 -19
  670. package/dist/lexical/plugins/SelectAllPlugin/index.js.map +1 -1
  671. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/LexicalMenu.js +420 -399
  672. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/LexicalMenu.js.map +1 -1
  673. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/index.js +155 -164
  674. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/index.js.map +1 -1
  675. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/types.js +1 -10
  676. package/dist/lexical/plugins/SlashMenu/LexicalTypeaheadMenuPlugin/types.js.map +1 -1
  677. package/dist/lexical/plugins/SlashMenu/index.js +181 -204
  678. package/dist/lexical/plugins/SlashMenu/index.js.map +1 -1
  679. package/dist/lexical/plugins/SlashMenu/useMenuTriggerMatch.js +41 -28
  680. package/dist/lexical/plugins/SlashMenu/useMenuTriggerMatch.js.map +1 -1
  681. package/dist/lexical/plugins/TextPlugin/index.js +42 -27
  682. package/dist/lexical/plugins/TextPlugin/index.js.map +1 -1
  683. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.js +130 -145
  684. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.js.map +1 -1
  685. package/dist/lexical/plugins/handles/DraggableBlockPlugin/debounce.js +10 -10
  686. package/dist/lexical/plugins/handles/DraggableBlockPlugin/debounce.js.map +1 -1
  687. package/dist/lexical/plugins/handles/DraggableBlockPlugin/getBoundingRectWithoutTransform.js +10 -10
  688. package/dist/lexical/plugins/handles/DraggableBlockPlugin/getBoundingRectWithoutTransform.js.map +1 -1
  689. package/dist/lexical/plugins/handles/DraggableBlockPlugin/highlightElemOriginalPosition.js +26 -23
  690. package/dist/lexical/plugins/handles/DraggableBlockPlugin/highlightElemOriginalPosition.js.map +1 -1
  691. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.js +317 -325
  692. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.js.map +1 -1
  693. package/dist/lexical/plugins/handles/DraggableBlockPlugin/setTargetLine.js +98 -86
  694. package/dist/lexical/plugins/handles/DraggableBlockPlugin/setTargetLine.js.map +1 -1
  695. package/dist/lexical/plugins/handles/utils/calculateDistanceFromScrollerElem.js +22 -16
  696. package/dist/lexical/plugins/handles/utils/calculateDistanceFromScrollerElem.js.map +1 -1
  697. package/dist/lexical/plugins/handles/utils/doesLineHeightAffectElement.js +19 -29
  698. package/dist/lexical/plugins/handles/utils/doesLineHeightAffectElement.js.map +1 -1
  699. package/dist/lexical/plugins/handles/utils/getCollapsedMargins.js +14 -11
  700. package/dist/lexical/plugins/handles/utils/getCollapsedMargins.js.map +1 -1
  701. package/dist/lexical/plugins/handles/utils/getNodeCloseToPoint.js +133 -122
  702. package/dist/lexical/plugins/handles/utils/getNodeCloseToPoint.js.map +1 -1
  703. package/dist/lexical/plugins/handles/utils/getTopLevelNodeKeys.js +2 -2
  704. package/dist/lexical/plugins/handles/utils/getTopLevelNodeKeys.js.map +1 -1
  705. package/dist/lexical/plugins/handles/utils/isOnHandleElement.js +2 -2
  706. package/dist/lexical/plugins/handles/utils/isOnHandleElement.js.map +1 -1
  707. package/dist/lexical/plugins/handles/utils/setHandlePosition.js +24 -29
  708. package/dist/lexical/plugins/handles/utils/setHandlePosition.js.map +1 -1
  709. package/dist/lexical/theme/EditorTheme.js +65 -72
  710. package/dist/lexical/theme/EditorTheme.js.map +1 -1
  711. package/dist/lexical/ui/ContentEditable.js +35 -22
  712. package/dist/lexical/ui/ContentEditable.js.map +1 -1
  713. package/dist/lexical/ui/icons/AI/index.js +31 -58
  714. package/dist/lexical/ui/icons/AI/index.js.map +1 -1
  715. package/dist/lexical/ui/icons/Add/index.js +16 -31
  716. package/dist/lexical/ui/icons/Add/index.js.map +1 -1
  717. package/dist/lexical/ui/icons/AlignCenter/index.js +25 -45
  718. package/dist/lexical/ui/icons/AlignCenter/index.js.map +1 -1
  719. package/dist/lexical/ui/icons/AlignJustify/index.js +25 -45
  720. package/dist/lexical/ui/icons/AlignJustify/index.js.map +1 -1
  721. package/dist/lexical/ui/icons/AlignLeft/index.js +25 -45
  722. package/dist/lexical/ui/icons/AlignLeft/index.js.map +1 -1
  723. package/dist/lexical/ui/icons/AlignRight/index.js +25 -45
  724. package/dist/lexical/ui/icons/AlignRight/index.js.map +1 -1
  725. package/dist/lexical/ui/icons/Block/index.js +34 -54
  726. package/dist/lexical/ui/icons/Block/index.js.map +1 -1
  727. package/dist/lexical/ui/icons/Blockquote/index.js +16 -24
  728. package/dist/lexical/ui/icons/Blockquote/index.js.map +1 -1
  729. package/dist/lexical/ui/icons/Bold/index.js +16 -24
  730. package/dist/lexical/ui/icons/Bold/index.js.map +1 -1
  731. package/dist/lexical/ui/icons/Checklist/index.js +24 -39
  732. package/dist/lexical/ui/icons/Checklist/index.js.map +1 -1
  733. package/dist/lexical/ui/icons/Code/index.js +19 -34
  734. package/dist/lexical/ui/icons/Code/index.js.map +1 -1
  735. package/dist/lexical/ui/icons/CodeBlock/index.js +14 -22
  736. package/dist/lexical/ui/icons/CodeBlock/index.js.map +1 -1
  737. package/dist/lexical/ui/icons/Collapse/index.js +15 -23
  738. package/dist/lexical/ui/icons/Collapse/index.js.map +1 -1
  739. package/dist/lexical/ui/icons/H1/index.js +16 -24
  740. package/dist/lexical/ui/icons/H1/index.js.map +1 -1
  741. package/dist/lexical/ui/icons/H2/index.js +16 -24
  742. package/dist/lexical/ui/icons/H2/index.js.map +1 -1
  743. package/dist/lexical/ui/icons/H3/index.js +16 -24
  744. package/dist/lexical/ui/icons/H3/index.js.map +1 -1
  745. package/dist/lexical/ui/icons/H4/index.js +16 -24
  746. package/dist/lexical/ui/icons/H4/index.js.map +1 -1
  747. package/dist/lexical/ui/icons/H5/index.js +16 -24
  748. package/dist/lexical/ui/icons/H5/index.js.map +1 -1
  749. package/dist/lexical/ui/icons/H6/index.js +16 -24
  750. package/dist/lexical/ui/icons/H6/index.js.map +1 -1
  751. package/dist/lexical/ui/icons/HorizontalRule/index.js +19 -27
  752. package/dist/lexical/ui/icons/HorizontalRule/index.js.map +1 -1
  753. package/dist/lexical/ui/icons/IndentDecrease/index.js +28 -53
  754. package/dist/lexical/ui/icons/IndentDecrease/index.js.map +1 -1
  755. package/dist/lexical/ui/icons/IndentIncrease/index.js +28 -53
  756. package/dist/lexical/ui/icons/IndentIncrease/index.js.map +1 -1
  757. package/dist/lexical/ui/icons/InlineBlocks/index.js +18 -26
  758. package/dist/lexical/ui/icons/InlineBlocks/index.js.map +1 -1
  759. package/dist/lexical/ui/icons/Italic/index.js +16 -24
  760. package/dist/lexical/ui/icons/Italic/index.js.map +1 -1
  761. package/dist/lexical/ui/icons/Link/index.js +17 -25
  762. package/dist/lexical/ui/icons/Link/index.js.map +1 -1
  763. package/dist/lexical/ui/icons/Meatballs/index.js +19 -39
  764. package/dist/lexical/ui/icons/Meatballs/index.js.map +1 -1
  765. package/dist/lexical/ui/icons/OrderedList/index.js +31 -61
  766. package/dist/lexical/ui/icons/OrderedList/index.js.map +1 -1
  767. package/dist/lexical/ui/icons/Relationship/index.js +31 -58
  768. package/dist/lexical/ui/icons/Relationship/index.js.map +1 -1
  769. package/dist/lexical/ui/icons/Strikethrough/index.js +19 -34
  770. package/dist/lexical/ui/icons/Strikethrough/index.js.map +1 -1
  771. package/dist/lexical/ui/icons/Subscript/index.js +16 -24
  772. package/dist/lexical/ui/icons/Subscript/index.js.map +1 -1
  773. package/dist/lexical/ui/icons/Superscript/index.js +16 -24
  774. package/dist/lexical/ui/icons/Superscript/index.js.map +1 -1
  775. package/dist/lexical/ui/icons/Table/index.js +17 -25
  776. package/dist/lexical/ui/icons/Table/index.js.map +1 -1
  777. package/dist/lexical/ui/icons/Text/index.js +16 -24
  778. package/dist/lexical/ui/icons/Text/index.js.map +1 -1
  779. package/dist/lexical/ui/icons/TextState/index.js +19 -25
  780. package/dist/lexical/ui/icons/TextState/index.js.map +1 -1
  781. package/dist/lexical/ui/icons/Underline/index.js +19 -34
  782. package/dist/lexical/ui/icons/Underline/index.js.map +1 -1
  783. package/dist/lexical/ui/icons/UnorderedList/index.js +46 -81
  784. package/dist/lexical/ui/icons/UnorderedList/index.js.map +1 -1
  785. package/dist/lexical/ui/icons/Upload/index.js +28 -48
  786. package/dist/lexical/ui/icons/Upload/index.js.map +1 -1
  787. package/dist/lexical/utils/canUseDOM.js +1 -1
  788. package/dist/lexical/utils/canUseDOM.js.map +1 -1
  789. package/dist/lexical/utils/environment.js +1 -1
  790. package/dist/lexical/utils/environment.js.map +1 -1
  791. package/dist/lexical/utils/getDOMRangeRect.js +12 -12
  792. package/dist/lexical/utils/getDOMRangeRect.js.map +1 -1
  793. package/dist/lexical/utils/getSelectedNode.js +17 -13
  794. package/dist/lexical/utils/getSelectedNode.js.map +1 -1
  795. package/dist/lexical/utils/guard.js +4 -3
  796. package/dist/lexical/utils/guard.js.map +1 -1
  797. package/dist/lexical/utils/joinClasses.js +2 -2
  798. package/dist/lexical/utils/joinClasses.js.map +1 -1
  799. package/dist/lexical/utils/markdown/createBlockNode.js +9 -10
  800. package/dist/lexical/utils/markdown/createBlockNode.js.map +1 -1
  801. package/dist/lexical/utils/nodeFormat.js +58 -59
  802. package/dist/lexical/utils/nodeFormat.js.map +1 -1
  803. package/dist/lexical/utils/point.js +39 -32
  804. package/dist/lexical/utils/point.js.map +1 -1
  805. package/dist/lexical/utils/rect.js +166 -136
  806. package/dist/lexical/utils/rect.js.map +1 -1
  807. package/dist/lexical/utils/setFloatingElemPosition.js +56 -48
  808. package/dist/lexical/utils/setFloatingElemPosition.js.map +1 -1
  809. package/dist/lexical/utils/setFloatingElemPositionForLinkEditor.js +22 -22
  810. package/dist/lexical/utils/setFloatingElemPositionForLinkEditor.js.map +1 -1
  811. package/dist/lexical/utils/swipe.js +81 -83
  812. package/dist/lexical/utils/swipe.js.map +1 -1
  813. package/dist/lexical/utils/url.js +53 -53
  814. package/dist/lexical/utils/url.js.map +1 -1
  815. package/dist/lexical/utils/url.spec.js +98 -214
  816. package/dist/lexical/utils/url.spec.js.map +1 -1
  817. package/dist/lexical-proxy/@lexical-headless.js +0 -1
  818. package/dist/lexical-proxy/@lexical-headless.js.map +1 -1
  819. package/dist/lexical-proxy/@lexical-html.js +0 -1
  820. package/dist/lexical-proxy/@lexical-html.js.map +1 -1
  821. package/dist/lexical-proxy/@lexical-link.js +0 -1
  822. package/dist/lexical-proxy/@lexical-link.js.map +1 -1
  823. package/dist/lexical-proxy/@lexical-list.js +0 -1
  824. package/dist/lexical-proxy/@lexical-list.js.map +1 -1
  825. package/dist/lexical-proxy/@lexical-mark.js +0 -1
  826. package/dist/lexical-proxy/@lexical-mark.js.map +1 -1
  827. package/dist/lexical-proxy/@lexical-markdown.js +0 -1
  828. package/dist/lexical-proxy/@lexical-markdown.js.map +1 -1
  829. package/dist/lexical-proxy/@lexical-react/LexicalAutoEmbedPlugin.js +0 -1
  830. package/dist/lexical-proxy/@lexical-react/LexicalAutoEmbedPlugin.js.map +1 -1
  831. package/dist/lexical-proxy/@lexical-react/LexicalAutoFocusPlugin.js +0 -1
  832. package/dist/lexical-proxy/@lexical-react/LexicalAutoFocusPlugin.js.map +1 -1
  833. package/dist/lexical-proxy/@lexical-react/LexicalAutoLinkPlugin.js +0 -1
  834. package/dist/lexical-proxy/@lexical-react/LexicalAutoLinkPlugin.js.map +1 -1
  835. package/dist/lexical-proxy/@lexical-react/LexicalBlockWithAlignableContents.js +0 -1
  836. package/dist/lexical-proxy/@lexical-react/LexicalBlockWithAlignableContents.js.map +1 -1
  837. package/dist/lexical-proxy/@lexical-react/LexicalCharacterLimitPlugin.js +0 -1
  838. package/dist/lexical-proxy/@lexical-react/LexicalCharacterLimitPlugin.js.map +1 -1
  839. package/dist/lexical-proxy/@lexical-react/LexicalCheckListPlugin.js +0 -1
  840. package/dist/lexical-proxy/@lexical-react/LexicalCheckListPlugin.js.map +1 -1
  841. package/dist/lexical-proxy/@lexical-react/LexicalClearEditorPlugin.js +0 -1
  842. package/dist/lexical-proxy/@lexical-react/LexicalClearEditorPlugin.js.map +1 -1
  843. package/dist/lexical-proxy/@lexical-react/LexicalClickableLinkPlugin.js +0 -1
  844. package/dist/lexical-proxy/@lexical-react/LexicalClickableLinkPlugin.js.map +1 -1
  845. package/dist/lexical-proxy/@lexical-react/LexicalCollaborationContext.js +0 -1
  846. package/dist/lexical-proxy/@lexical-react/LexicalCollaborationContext.js.map +1 -1
  847. package/dist/lexical-proxy/@lexical-react/LexicalCollaborationPlugin.js +0 -1
  848. package/dist/lexical-proxy/@lexical-react/LexicalCollaborationPlugin.js.map +1 -1
  849. package/dist/lexical-proxy/@lexical-react/LexicalComposer.js +0 -1
  850. package/dist/lexical-proxy/@lexical-react/LexicalComposer.js.map +1 -1
  851. package/dist/lexical-proxy/@lexical-react/LexicalComposerContext.js +0 -1
  852. package/dist/lexical-proxy/@lexical-react/LexicalComposerContext.js.map +1 -1
  853. package/dist/lexical-proxy/@lexical-react/LexicalContentEditable.js +0 -1
  854. package/dist/lexical-proxy/@lexical-react/LexicalContentEditable.js.map +1 -1
  855. package/dist/lexical-proxy/@lexical-react/LexicalContextMenuPlugin.js +0 -1
  856. package/dist/lexical-proxy/@lexical-react/LexicalContextMenuPlugin.js.map +1 -1
  857. package/dist/lexical-proxy/@lexical-react/LexicalDecoratorBlockNode.js +0 -1
  858. package/dist/lexical-proxy/@lexical-react/LexicalDecoratorBlockNode.js.map +1 -1
  859. package/dist/lexical-proxy/@lexical-react/LexicalDraggableBlockPlugin.js +0 -1
  860. package/dist/lexical-proxy/@lexical-react/LexicalDraggableBlockPlugin.js.map +1 -1
  861. package/dist/lexical-proxy/@lexical-react/LexicalEditorRefPlugin.js +0 -1
  862. package/dist/lexical-proxy/@lexical-react/LexicalEditorRefPlugin.js.map +1 -1
  863. package/dist/lexical-proxy/@lexical-react/LexicalErrorBoundary.js +0 -1
  864. package/dist/lexical-proxy/@lexical-react/LexicalErrorBoundary.js.map +1 -1
  865. package/dist/lexical-proxy/@lexical-react/LexicalHashtagPlugin.js +0 -1
  866. package/dist/lexical-proxy/@lexical-react/LexicalHashtagPlugin.js.map +1 -1
  867. package/dist/lexical-proxy/@lexical-react/LexicalHistoryPlugin.js +0 -1
  868. package/dist/lexical-proxy/@lexical-react/LexicalHistoryPlugin.js.map +1 -1
  869. package/dist/lexical-proxy/@lexical-react/LexicalHorizontalRuleNode.js +0 -1
  870. package/dist/lexical-proxy/@lexical-react/LexicalHorizontalRuleNode.js.map +1 -1
  871. package/dist/lexical-proxy/@lexical-react/LexicalHorizontalRulePlugin.js +0 -1
  872. package/dist/lexical-proxy/@lexical-react/LexicalHorizontalRulePlugin.js.map +1 -1
  873. package/dist/lexical-proxy/@lexical-react/LexicalLinkPlugin.js +0 -1
  874. package/dist/lexical-proxy/@lexical-react/LexicalLinkPlugin.js.map +1 -1
  875. package/dist/lexical-proxy/@lexical-react/LexicalListPlugin.js +0 -1
  876. package/dist/lexical-proxy/@lexical-react/LexicalListPlugin.js.map +1 -1
  877. package/dist/lexical-proxy/@lexical-react/LexicalMarkdownShortcutPlugin.js +0 -1
  878. package/dist/lexical-proxy/@lexical-react/LexicalMarkdownShortcutPlugin.js.map +1 -1
  879. package/dist/lexical-proxy/@lexical-react/LexicalNestedComposer.js +0 -1
  880. package/dist/lexical-proxy/@lexical-react/LexicalNestedComposer.js.map +1 -1
  881. package/dist/lexical-proxy/@lexical-react/LexicalNodeContextMenuPlugin.js +0 -1
  882. package/dist/lexical-proxy/@lexical-react/LexicalNodeContextMenuPlugin.js.map +1 -1
  883. package/dist/lexical-proxy/@lexical-react/LexicalNodeEventPlugin.js +0 -1
  884. package/dist/lexical-proxy/@lexical-react/LexicalNodeEventPlugin.js.map +1 -1
  885. package/dist/lexical-proxy/@lexical-react/LexicalNodeMenuPlugin.js +0 -1
  886. package/dist/lexical-proxy/@lexical-react/LexicalNodeMenuPlugin.js.map +1 -1
  887. package/dist/lexical-proxy/@lexical-react/LexicalOnChangePlugin.js +0 -1
  888. package/dist/lexical-proxy/@lexical-react/LexicalOnChangePlugin.js.map +1 -1
  889. package/dist/lexical-proxy/@lexical-react/LexicalPlainTextPlugin.js +0 -1
  890. package/dist/lexical-proxy/@lexical-react/LexicalPlainTextPlugin.js.map +1 -1
  891. package/dist/lexical-proxy/@lexical-react/LexicalRichTextPlugin.js +0 -1
  892. package/dist/lexical-proxy/@lexical-react/LexicalRichTextPlugin.js.map +1 -1
  893. package/dist/lexical-proxy/@lexical-react/LexicalTabIndentationPlugin.js +0 -1
  894. package/dist/lexical-proxy/@lexical-react/LexicalTabIndentationPlugin.js.map +1 -1
  895. package/dist/lexical-proxy/@lexical-react/LexicalTableOfContentsPlugin.js +0 -1
  896. package/dist/lexical-proxy/@lexical-react/LexicalTableOfContentsPlugin.js.map +1 -1
  897. package/dist/lexical-proxy/@lexical-react/LexicalTablePlugin.js +0 -1
  898. package/dist/lexical-proxy/@lexical-react/LexicalTablePlugin.js.map +1 -1
  899. package/dist/lexical-proxy/@lexical-react/LexicalTreeView.js +0 -1
  900. package/dist/lexical-proxy/@lexical-react/LexicalTreeView.js.map +1 -1
  901. package/dist/lexical-proxy/@lexical-react/LexicalTypeaheadMenuPlugin.js +0 -1
  902. package/dist/lexical-proxy/@lexical-react/LexicalTypeaheadMenuPlugin.js.map +1 -1
  903. package/dist/lexical-proxy/@lexical-react/useLexicalEditable.js +0 -1
  904. package/dist/lexical-proxy/@lexical-react/useLexicalEditable.js.map +1 -1
  905. package/dist/lexical-proxy/@lexical-react/useLexicalIsTextContentEmpty.js +0 -1
  906. package/dist/lexical-proxy/@lexical-react/useLexicalIsTextContentEmpty.js.map +1 -1
  907. package/dist/lexical-proxy/@lexical-react/useLexicalNodeSelection.js +0 -1
  908. package/dist/lexical-proxy/@lexical-react/useLexicalNodeSelection.js.map +1 -1
  909. package/dist/lexical-proxy/@lexical-react/useLexicalSubscription.js +0 -1
  910. package/dist/lexical-proxy/@lexical-react/useLexicalSubscription.js.map +1 -1
  911. package/dist/lexical-proxy/@lexical-react/useLexicalTextEntity.js +0 -1
  912. package/dist/lexical-proxy/@lexical-react/useLexicalTextEntity.js.map +1 -1
  913. package/dist/lexical-proxy/@lexical-rich-text.js +0 -1
  914. package/dist/lexical-proxy/@lexical-rich-text.js.map +1 -1
  915. package/dist/lexical-proxy/@lexical-selection.js +0 -1
  916. package/dist/lexical-proxy/@lexical-selection.js.map +1 -1
  917. package/dist/lexical-proxy/@lexical-utils.js +0 -1
  918. package/dist/lexical-proxy/@lexical-utils.js.map +1 -1
  919. package/dist/lexical-proxy/lexical.js +0 -1
  920. package/dist/lexical-proxy/lexical.js.map +1 -1
  921. package/dist/nodeTypes.js +1 -35
  922. package/dist/nodeTypes.js.map +1 -1
  923. package/dist/packages/@lexical/markdown/MarkdownExport.js +179 -184
  924. package/dist/packages/@lexical/markdown/MarkdownExport.js.map +1 -1
  925. package/dist/packages/@lexical/markdown/MarkdownImport.js +169 -174
  926. package/dist/packages/@lexical/markdown/MarkdownImport.js.map +1 -1
  927. package/dist/packages/@lexical/markdown/MarkdownShortcuts.js +268 -258
  928. package/dist/packages/@lexical/markdown/MarkdownShortcuts.js.map +1 -1
  929. package/dist/packages/@lexical/markdown/MarkdownTransformers.js +209 -305
  930. package/dist/packages/@lexical/markdown/MarkdownTransformers.js.map +1 -1
  931. package/dist/packages/@lexical/markdown/importTextFormatTransformer.js +73 -76
  932. package/dist/packages/@lexical/markdown/importTextFormatTransformer.js.map +1 -1
  933. package/dist/packages/@lexical/markdown/importTextMatchTransformer.js +48 -59
  934. package/dist/packages/@lexical/markdown/importTextMatchTransformer.js.map +1 -1
  935. package/dist/packages/@lexical/markdown/importTextTransformers.js +45 -51
  936. package/dist/packages/@lexical/markdown/importTextTransformers.js.map +1 -1
  937. package/dist/packages/@lexical/markdown/index.js +14 -33
  938. package/dist/packages/@lexical/markdown/index.js.map +1 -1
  939. package/dist/packages/@lexical/markdown/utils.js +185 -217
  940. package/dist/packages/@lexical/markdown/utils.js.map +1 -1
  941. package/dist/populateGraphQL/defaultValue.js +24 -29
  942. package/dist/populateGraphQL/defaultValue.js.map +1 -1
  943. package/dist/populateGraphQL/populate.js +37 -26
  944. package/dist/populateGraphQL/populate.js.map +1 -1
  945. package/dist/populateGraphQL/populateLexicalPopulationPromises.js +50 -34
  946. package/dist/populateGraphQL/populateLexicalPopulationPromises.js.map +1 -1
  947. package/dist/populateGraphQL/recursivelyPopulateFieldsForGraphQL.js +42 -35
  948. package/dist/populateGraphQL/recursivelyPopulateFieldsForGraphQL.js.map +1 -1
  949. package/dist/types.js +1 -40
  950. package/dist/types.js.map +1 -1
  951. package/dist/utilities/applyBaseFilterToFields.js +84 -81
  952. package/dist/utilities/applyBaseFilterToFields.js.map +1 -1
  953. package/dist/utilities/buildEditorState.js +40 -39
  954. package/dist/utilities/buildEditorState.js.map +1 -1
  955. package/dist/utilities/buildInitialState.js +52 -51
  956. package/dist/utilities/buildInitialState.js.map +1 -1
  957. package/dist/utilities/createClientFeature.js +48 -42
  958. package/dist/utilities/createClientFeature.js.map +1 -1
  959. package/dist/utilities/createServerFeature.js +48 -38
  960. package/dist/utilities/createServerFeature.js.map +1 -1
  961. package/dist/utilities/editorConfigFactory.js +79 -78
  962. package/dist/utilities/editorConfigFactory.js.map +1 -1
  963. package/dist/utilities/fieldsDrawer/Drawer.js +70 -45
  964. package/dist/utilities/fieldsDrawer/Drawer.js.map +1 -1
  965. package/dist/utilities/fieldsDrawer/DrawerContent.js +120 -130
  966. package/dist/utilities/fieldsDrawer/DrawerContent.js.map +1 -1
  967. package/dist/utilities/fieldsDrawer/useLexicalDocumentDrawer.js +115 -64
  968. package/dist/utilities/fieldsDrawer/useLexicalDocumentDrawer.js.map +1 -1
  969. package/dist/utilities/fieldsDrawer/useLexicalDrawer.js +121 -76
  970. package/dist/utilities/fieldsDrawer/useLexicalDrawer.js.map +1 -1
  971. package/dist/utilities/fieldsDrawer/useLexicalListDrawer.js +141 -79
  972. package/dist/utilities/fieldsDrawer/useLexicalListDrawer.js.map +1 -1
  973. package/dist/utilities/forEachNodeRecursively.js +24 -19
  974. package/dist/utilities/forEachNodeRecursively.js.map +1 -1
  975. package/dist/utilities/generateImportMap.js +49 -43
  976. package/dist/utilities/generateImportMap.js.map +1 -1
  977. package/dist/utilities/generateSchemaMap.js +37 -32
  978. package/dist/utilities/generateSchemaMap.js.map +1 -1
  979. package/dist/utilities/getDefaultSanitizedEditorConfig.js +14 -12
  980. package/dist/utilities/getDefaultSanitizedEditorConfig.js.map +1 -1
  981. package/dist/utilities/initLexicalFeatures.js +65 -68
  982. package/dist/utilities/initLexicalFeatures.js.map +1 -1
  983. package/dist/utilities/jsx/collectTopLevelJSXInLines.js +29 -26
  984. package/dist/utilities/jsx/collectTopLevelJSXInLines.js.map +1 -1
  985. package/dist/utilities/jsx/declare.d.js.map +1 -1
  986. package/dist/utilities/jsx/extractPropsFromJSXPropsString.js +102 -100
  987. package/dist/utilities/jsx/extractPropsFromJSXPropsString.js.map +1 -1
  988. package/dist/utilities/jsx/jsx.js +80 -76
  989. package/dist/utilities/jsx/jsx.js.map +1 -1
  990. package/dist/utilities/jsx/jsx.spec.js +171 -225
  991. package/dist/utilities/jsx/jsx.spec.js.map +1 -1
  992. package/dist/utilities/migrateSlateToLexical/index.js +128 -112
  993. package/dist/utilities/migrateSlateToLexical/index.js.map +1 -1
  994. package/dist/utilities/migrateSlateToLexical/migrateDocumentFieldsRecursively.js +78 -74
  995. package/dist/utilities/migrateSlateToLexical/migrateDocumentFieldsRecursively.js.map +1 -1
  996. package/dist/utilities/recurseNodeTree.js +25 -22
  997. package/dist/utilities/recurseNodeTree.js.map +1 -1
  998. package/dist/utilities/upgradeLexicalData/index.js +102 -88
  999. package/dist/utilities/upgradeLexicalData/index.js.map +1 -1
  1000. package/dist/utilities/upgradeLexicalData/upgradeDocumentFieldsRecursively.js +80 -78
  1001. package/dist/utilities/upgradeLexicalData/upgradeDocumentFieldsRecursively.js.map +1 -1
  1002. package/dist/utilities/useLexicalFeature.js +16 -14
  1003. package/dist/utilities/useLexicalFeature.js.map +1 -1
  1004. package/dist/utilities/useRunDeprioritized.js +37 -41
  1005. package/dist/utilities/useRunDeprioritized.js.map +1 -1
  1006. package/dist/validate/hasText.js +20 -21
  1007. package/dist/validate/hasText.js.map +1 -1
  1008. package/dist/validate/index.js +28 -22
  1009. package/dist/validate/index.js.map +1 -1
  1010. package/dist/validate/validateNodes.js +31 -28
  1011. package/dist/validate/validateNodes.js.map +1 -1
  1012. package/package.json +7 -7
  1013. package/dist/features/blocks/client/component/index.scss +0 -188
  1014. package/dist/features/blocks/client/componentInline/index.scss +0 -100
  1015. package/dist/features/blocks/premade/CodeBlock/Component/Collapse/index.scss +0 -6
  1016. package/dist/features/blocks/premade/CodeBlock/Component/FloatingCollapse/index.scss +0 -29
  1017. package/dist/features/blocks/premade/CodeBlock/Component/index.scss +0 -97
  1018. package/dist/features/debug/jsxConverter/client/plugin/style.scss +0 -12
  1019. package/dist/features/debug/testRecorder/client/plugin/index.scss +0 -53
  1020. package/dist/features/debug/treeView/client/plugin/index.scss +0 -80
  1021. package/dist/features/experimental_table/client/plugins/TableActionMenuPlugin/index.scss +0 -87
  1022. package/dist/features/experimental_table/client/plugins/TableCellResizerPlugin/index.scss +0 -11
  1023. package/dist/features/experimental_table/client/plugins/TablePlugin/index.scss +0 -233
  1024. package/dist/features/horizontalRule/client/plugin/index.scss +0 -23
  1025. package/dist/features/link/client/plugins/floatingLinkEditor/index.scss +0 -92
  1026. package/dist/features/migrations/lexicalPluginToLexical/nodes/unknownConvertedNode/index.scss +0 -16
  1027. package/dist/features/migrations/slateToLexical/nodes/unknownConvertedNode/index.scss +0 -16
  1028. package/dist/features/relationship/client/components/index.scss +0 -95
  1029. package/dist/features/toolbars/fixed/client/Toolbar/index.scss +0 -113
  1030. package/dist/features/toolbars/inline/client/Toolbar/index.scss +0 -58
  1031. package/dist/features/toolbars/shared/ToolbarButton/index.scss +0 -46
  1032. package/dist/features/toolbars/shared/ToolbarDropdown/index.scss +0 -129
  1033. package/dist/features/upload/client/component/index.scss +0 -191
  1034. package/dist/field/Diff/converters/listitem/index.scss +0 -47
  1035. package/dist/field/Diff/converters/relationship/index.scss +0 -73
  1036. package/dist/field/Diff/converters/unknown/index.scss +0 -40
  1037. package/dist/field/Diff/converters/upload/index.scss +0 -115
  1038. package/dist/field/Diff/index.scss +0 -102
  1039. package/dist/field/index.scss +0 -41
  1040. package/dist/lexical/LexicalEditor.scss +0 -54
  1041. package/dist/lexical/plugins/DecoratorPlugin/index.scss +0 -13
  1042. package/dist/lexical/plugins/InsertParagraphAtEnd/index.scss +0 -54
  1043. package/dist/lexical/plugins/SlashMenu/index.scss +0 -68
  1044. package/dist/lexical/plugins/handles/AddBlockHandlePlugin/index.scss +0 -35
  1045. package/dist/lexical/plugins/handles/DraggableBlockPlugin/index.scss +0 -80
  1046. package/dist/lexical/theme/EditorTheme.scss +0 -357
  1047. package/dist/lexical/ui/ContentEditable.scss +0 -105
@@ -5,90 +5,93 @@ import { combineWhereConstraints } from 'payload/shared';
5
5
  * collection-level filters like multi-tenant filtering.
6
6
  *
7
7
  * Based on the fix from PR #13229 for LinkFeature
8
- */ export function applyBaseFilterToFields(fields, config) {
9
- return fields.map((field)=>{
10
- // Handle relationship fields
11
- if (field.type === 'relationship') {
12
- const relationshipField = field;
13
- // Store the original filterOptions
14
- const originalFilterOptions = relationshipField.filterOptions;
15
- // Create new filterOptions that includes baseFilter
16
- relationshipField.filterOptions = async (args)=>{
17
- const { relationTo, req, user } = args;
18
- // Call original filterOptions if it exists
19
- const originalResult = typeof originalFilterOptions === 'function' ? await originalFilterOptions(args) : originalFilterOptions ?? true;
20
- // If original filter returns false, respect that
21
- if (originalResult === false) {
22
- return false;
23
- }
24
- // Get the collection's admin config
25
- const admin = config.collections.find(({ slug })=>slug === relationTo)?.admin;
26
- // Check if collection is hidden
27
- const hidden = admin?.hidden;
28
- if (typeof hidden === 'function' && hidden({
29
- user
30
- })) {
31
- return false;
32
- }
33
- // Apply baseFilter (with backwards compatibility for baseListFilter)
34
- const baseFilter = admin?.baseFilter ?? admin?.baseListFilter;
35
- const baseFilterResult = await baseFilter?.({
36
- limit: 0,
37
- page: 1,
38
- req,
39
- sort: 'id'
40
- });
41
- // If no baseFilter, return original result
42
- if (!baseFilterResult) {
43
- return originalResult;
44
- }
45
- // If original result is true, just return the baseFilter
46
- if (originalResult === true) {
47
- return baseFilterResult;
48
- }
49
- // Combine original and baseFilter results
50
- return combineWhereConstraints([
51
- originalResult,
52
- baseFilterResult
53
- ], 'and');
54
- };
55
- return relationshipField;
8
+ */
9
+ export function applyBaseFilterToFields(fields, config) {
10
+ return fields.map(field => {
11
+ // Handle relationship fields
12
+ if (field.type === 'relationship') {
13
+ const relationshipField = field;
14
+ // Store the original filterOptions
15
+ const originalFilterOptions = relationshipField.filterOptions;
16
+ // Create new filterOptions that includes baseFilter
17
+ relationshipField.filterOptions = async args => {
18
+ const {
19
+ relationTo,
20
+ req,
21
+ user
22
+ } = args;
23
+ // Call original filterOptions if it exists
24
+ const originalResult = typeof originalFilterOptions === 'function' ? await originalFilterOptions(args) : originalFilterOptions ?? true;
25
+ // If original filter returns false, respect that
26
+ if (originalResult === false) {
27
+ return false;
56
28
  }
57
- // Recursively process nested fields
58
- if ('fields' in field && field.fields) {
59
- return {
60
- ...field,
61
- fields: applyBaseFilterToFields(field.fields, config)
62
- };
29
+ // Get the collection's admin config
30
+ const admin = config.collections.find(({
31
+ slug
32
+ }) => slug === relationTo)?.admin;
33
+ // Check if collection is hidden
34
+ const hidden = admin?.hidden;
35
+ if (typeof hidden === 'function' && hidden({
36
+ user
37
+ })) {
38
+ return false;
63
39
  }
64
- // Handle tabs
65
- if (field.type === 'tabs' && 'tabs' in field) {
66
- return {
67
- ...field,
68
- tabs: field.tabs.map((tab)=>({
69
- ...tab,
70
- fields: applyBaseFilterToFields(tab.fields, config)
71
- }))
72
- };
40
+ // Apply baseFilter (with backwards compatibility for baseListFilter)
41
+ const baseFilter = admin?.baseFilter ?? admin?.baseListFilter;
42
+ const baseFilterResult = await baseFilter?.({
43
+ limit: 0,
44
+ page: 1,
45
+ req,
46
+ sort: 'id'
47
+ });
48
+ // If no baseFilter, return original result
49
+ if (!baseFilterResult) {
50
+ return originalResult;
73
51
  }
74
- // Handle blocks
75
- if (field.type === 'blocks') {
76
- const blocks = field.blockReferences ?? field.blocks ?? [];
77
- return {
78
- ...field,
79
- blocks: blocks.map((block)=>{
80
- if (typeof block === 'string') {
81
- return block;
82
- }
83
- return {
84
- ...block,
85
- fields: applyBaseFilterToFields(block.fields, config)
86
- };
87
- })
88
- };
52
+ // If original result is true, just return the baseFilter
53
+ if (originalResult === true) {
54
+ return baseFilterResult;
89
55
  }
90
- return field;
91
- });
56
+ // Combine original and baseFilter results
57
+ return combineWhereConstraints([originalResult, baseFilterResult], 'and');
58
+ };
59
+ return relationshipField;
60
+ }
61
+ // Recursively process nested fields
62
+ if ('fields' in field && field.fields) {
63
+ return {
64
+ ...field,
65
+ fields: applyBaseFilterToFields(field.fields, config)
66
+ };
67
+ }
68
+ // Handle tabs
69
+ if (field.type === 'tabs' && 'tabs' in field) {
70
+ return {
71
+ ...field,
72
+ tabs: field.tabs.map(tab => ({
73
+ ...tab,
74
+ fields: applyBaseFilterToFields(tab.fields, config)
75
+ }))
76
+ };
77
+ }
78
+ // Handle blocks
79
+ if (field.type === 'blocks') {
80
+ const blocks = field.blockReferences ?? field.blocks ?? [];
81
+ return {
82
+ ...field,
83
+ blocks: blocks.map(block => {
84
+ if (typeof block === 'string') {
85
+ return block;
86
+ }
87
+ return {
88
+ ...block,
89
+ fields: applyBaseFilterToFields(block.fields, config)
90
+ };
91
+ })
92
+ };
93
+ }
94
+ return field;
95
+ });
92
96
  }
93
-
94
97
  //# sourceMappingURL=applyBaseFilterToFields.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/applyBaseFilterToFields.ts"],"sourcesContent":["import type { Block, Field, SanitizedConfig, TypedUser } from 'payload'\n\nimport { combineWhereConstraints } from 'payload/shared'\n\n/**\n * Recursively applies baseFilter from collection config to relationship fields\n * within blocks. This ensures that relationship drawers in blocks respect\n * collection-level filters like multi-tenant filtering.\n *\n * Based on the fix from PR #13229 for LinkFeature\n */\nexport function applyBaseFilterToFields(fields: Field[], config: SanitizedConfig): Field[] {\n return fields.map((field) => {\n // Handle relationship fields\n if (field.type === 'relationship') {\n const relationshipField = field\n\n // Store the original filterOptions\n const originalFilterOptions = relationshipField.filterOptions\n\n // Create new filterOptions that includes baseFilter\n relationshipField.filterOptions = async (args) => {\n const { relationTo, req, user } = args\n\n // Call original filterOptions if it exists\n const originalResult =\n typeof originalFilterOptions === 'function'\n ? await originalFilterOptions(args)\n : (originalFilterOptions ?? true)\n\n // If original filter returns false, respect that\n if (originalResult === false) {\n return false\n }\n\n // Get the collection's admin config\n const admin = config.collections.find(({ slug }) => slug === relationTo)?.admin\n\n // Check if collection is hidden\n const hidden = admin?.hidden\n if (typeof hidden === 'function' && hidden({ user } as { user: TypedUser })) {\n return false\n }\n\n // Apply baseFilter (with backwards compatibility for baseListFilter)\n const baseFilter = admin?.baseFilter ?? admin?.baseListFilter\n const baseFilterResult = await baseFilter?.({\n limit: 0,\n page: 1,\n req,\n sort: 'id',\n })\n\n // If no baseFilter, return original result\n if (!baseFilterResult) {\n return originalResult\n }\n\n // If original result is true, just return the baseFilter\n if (originalResult === true) {\n return baseFilterResult\n }\n\n // Combine original and baseFilter results\n return combineWhereConstraints([originalResult, baseFilterResult], 'and')\n }\n\n return relationshipField\n }\n\n // Recursively process nested fields\n if ('fields' in field && field.fields) {\n return {\n ...field,\n fields: applyBaseFilterToFields(field.fields, config),\n }\n }\n\n // Handle tabs\n if (field.type === 'tabs' && 'tabs' in field) {\n return {\n ...field,\n tabs: field.tabs.map((tab) => ({\n ...tab,\n fields: applyBaseFilterToFields(tab.fields, config),\n })),\n }\n }\n\n // Handle blocks\n if (field.type === 'blocks') {\n const blocks = (field.blockReferences ?? field.blocks ?? []) as Block[]\n return {\n ...field,\n blocks: blocks.map((block) => {\n if (typeof block === 'string') {\n return block\n }\n return {\n ...block,\n fields: applyBaseFilterToFields(block.fields, config),\n }\n }),\n }\n }\n\n return field\n })\n}\n"],"names":["combineWhereConstraints","applyBaseFilterToFields","fields","config","map","field","type","relationshipField","originalFilterOptions","filterOptions","args","relationTo","req","user","originalResult","admin","collections","find","slug","hidden","baseFilter","baseListFilter","baseFilterResult","limit","page","sort","tabs","tab","blocks","blockReferences","block"],"mappings":"AAEA,SAASA,uBAAuB,QAAQ,iBAAgB;AAExD;;;;;;CAMC,GACD,OAAO,SAASC,wBAAwBC,MAAe,EAAEC,MAAuB;IAC9E,OAAOD,OAAOE,GAAG,CAAC,CAACC;QACjB,6BAA6B;QAC7B,IAAIA,MAAMC,IAAI,KAAK,gBAAgB;YACjC,MAAMC,oBAAoBF;YAE1B,mCAAmC;YACnC,MAAMG,wBAAwBD,kBAAkBE,aAAa;YAE7D,oDAAoD;YACpDF,kBAAkBE,aAAa,GAAG,OAAOC;gBACvC,MAAM,EAAEC,UAAU,EAAEC,GAAG,EAAEC,IAAI,EAAE,GAAGH;gBAElC,2CAA2C;gBAC3C,MAAMI,iBACJ,OAAON,0BAA0B,aAC7B,MAAMA,sBAAsBE,QAC3BF,yBAAyB;gBAEhC,iDAAiD;gBACjD,IAAIM,mBAAmB,OAAO;oBAC5B,OAAO;gBACT;gBAEA,oCAAoC;gBACpC,MAAMC,QAAQZ,OAAOa,WAAW,CAACC,IAAI,CAAC,CAAC,EAAEC,IAAI,EAAE,GAAKA,SAASP,aAAaI;gBAE1E,gCAAgC;gBAChC,MAAMI,SAASJ,OAAOI;gBACtB,IAAI,OAAOA,WAAW,cAAcA,OAAO;oBAAEN;gBAAK,IAA2B;oBAC3E,OAAO;gBACT;gBAEA,qEAAqE;gBACrE,MAAMO,aAAaL,OAAOK,cAAcL,OAAOM;gBAC/C,MAAMC,mBAAmB,MAAMF,aAAa;oBAC1CG,OAAO;oBACPC,MAAM;oBACNZ;oBACAa,MAAM;gBACR;gBAEA,2CAA2C;gBAC3C,IAAI,CAACH,kBAAkB;oBACrB,OAAOR;gBACT;gBAEA,yDAAyD;gBACzD,IAAIA,mBAAmB,MAAM;oBAC3B,OAAOQ;gBACT;gBAEA,0CAA0C;gBAC1C,OAAOtB,wBAAwB;oBAACc;oBAAgBQ;iBAAiB,EAAE;YACrE;YAEA,OAAOf;QACT;QAEA,oCAAoC;QACpC,IAAI,YAAYF,SAASA,MAAMH,MAAM,EAAE;YACrC,OAAO;gBACL,GAAGG,KAAK;gBACRH,QAAQD,wBAAwBI,MAAMH,MAAM,EAAEC;YAChD;QACF;QAEA,cAAc;QACd,IAAIE,MAAMC,IAAI,KAAK,UAAU,UAAUD,OAAO;YAC5C,OAAO;gBACL,GAAGA,KAAK;gBACRqB,MAAMrB,MAAMqB,IAAI,CAACtB,GAAG,CAAC,CAACuB,MAAS,CAAA;wBAC7B,GAAGA,GAAG;wBACNzB,QAAQD,wBAAwB0B,IAAIzB,MAAM,EAAEC;oBAC9C,CAAA;YACF;QACF;QAEA,gBAAgB;QAChB,IAAIE,MAAMC,IAAI,KAAK,UAAU;YAC3B,MAAMsB,SAAUvB,MAAMwB,eAAe,IAAIxB,MAAMuB,MAAM,IAAI,EAAE;YAC3D,OAAO;gBACL,GAAGvB,KAAK;gBACRuB,QAAQA,OAAOxB,GAAG,CAAC,CAAC0B;oBAClB,IAAI,OAAOA,UAAU,UAAU;wBAC7B,OAAOA;oBACT;oBACA,OAAO;wBACL,GAAGA,KAAK;wBACR5B,QAAQD,wBAAwB6B,MAAM5B,MAAM,EAAEC;oBAChD;gBACF;YACF;QACF;QAEA,OAAOE;IACT;AACF"}
1
+ {"version":3,"file":"applyBaseFilterToFields.js","names":["combineWhereConstraints","applyBaseFilterToFields","fields","config","map","field","type","relationshipField","originalFilterOptions","filterOptions","args","relationTo","req","user","originalResult","admin","collections","find","slug","hidden","baseFilter","baseListFilter","baseFilterResult","limit","page","sort","tabs","tab","blocks","blockReferences","block"],"sources":["../../src/utilities/applyBaseFilterToFields.ts"],"sourcesContent":["import type { Block, Field, SanitizedConfig, TypedUser } from 'payload'\n\nimport { combineWhereConstraints } from 'payload/shared'\n\n/**\n * Recursively applies baseFilter from collection config to relationship fields\n * within blocks. This ensures that relationship drawers in blocks respect\n * collection-level filters like multi-tenant filtering.\n *\n * Based on the fix from PR #13229 for LinkFeature\n */\nexport function applyBaseFilterToFields(fields: Field[], config: SanitizedConfig): Field[] {\n return fields.map((field) => {\n // Handle relationship fields\n if (field.type === 'relationship') {\n const relationshipField = field\n\n // Store the original filterOptions\n const originalFilterOptions = relationshipField.filterOptions\n\n // Create new filterOptions that includes baseFilter\n relationshipField.filterOptions = async (args) => {\n const { relationTo, req, user } = args\n\n // Call original filterOptions if it exists\n const originalResult =\n typeof originalFilterOptions === 'function'\n ? await originalFilterOptions(args)\n : (originalFilterOptions ?? true)\n\n // If original filter returns false, respect that\n if (originalResult === false) {\n return false\n }\n\n // Get the collection's admin config\n const admin = config.collections.find(({ slug }) => slug === relationTo)?.admin\n\n // Check if collection is hidden\n const hidden = admin?.hidden\n if (typeof hidden === 'function' && hidden({ user } as { user: TypedUser })) {\n return false\n }\n\n // Apply baseFilter (with backwards compatibility for baseListFilter)\n const baseFilter = admin?.baseFilter ?? admin?.baseListFilter\n const baseFilterResult = await baseFilter?.({\n limit: 0,\n page: 1,\n req,\n sort: 'id',\n })\n\n // If no baseFilter, return original result\n if (!baseFilterResult) {\n return originalResult\n }\n\n // If original result is true, just return the baseFilter\n if (originalResult === true) {\n return baseFilterResult\n }\n\n // Combine original and baseFilter results\n return combineWhereConstraints([originalResult, baseFilterResult], 'and')\n }\n\n return relationshipField\n }\n\n // Recursively process nested fields\n if ('fields' in field && field.fields) {\n return {\n ...field,\n fields: applyBaseFilterToFields(field.fields, config),\n }\n }\n\n // Handle tabs\n if (field.type === 'tabs' && 'tabs' in field) {\n return {\n ...field,\n tabs: field.tabs.map((tab) => ({\n ...tab,\n fields: applyBaseFilterToFields(tab.fields, config),\n })),\n }\n }\n\n // Handle blocks\n if (field.type === 'blocks') {\n const blocks = (field.blockReferences ?? field.blocks ?? []) as Block[]\n return {\n ...field,\n blocks: blocks.map((block) => {\n if (typeof block === 'string') {\n return block\n }\n return {\n ...block,\n fields: applyBaseFilterToFields(block.fields, config),\n }\n }),\n }\n }\n\n return field\n })\n}\n"],"mappings":"AAEA,SAASA,uBAAuB,QAAQ;AAExC;;;;;;;AAOA,OAAO,SAASC,wBAAwBC,MAAe,EAAEC,MAAuB;EAC9E,OAAOD,MAAA,CAAOE,GAAG,CAAEC,KAAA;IACjB;IACA,IAAIA,KAAA,CAAMC,IAAI,KAAK,gBAAgB;MACjC,MAAMC,iBAAA,GAAoBF,KAAA;MAE1B;MACA,MAAMG,qBAAA,GAAwBD,iBAAA,CAAkBE,aAAa;MAE7D;MACAF,iBAAA,CAAkBE,aAAa,GAAG,MAAOC,IAAA;QACvC,MAAM;UAAEC,UAAU;UAAEC,GAAG;UAAEC;QAAI,CAAE,GAAGH,IAAA;QAElC;QACA,MAAMI,cAAA,GACJ,OAAON,qBAAA,KAA0B,aAC7B,MAAMA,qBAAA,CAAsBE,IAAA,IAC3BF,qBAAA,IAAyB;QAEhC;QACA,IAAIM,cAAA,KAAmB,OAAO;UAC5B,OAAO;QACT;QAEA;QACA,MAAMC,KAAA,GAAQZ,MAAA,CAAOa,WAAW,CAACC,IAAI,CAAC,CAAC;UAAEC;QAAI,CAAE,KAAKA,IAAA,KAASP,UAAA,GAAaI,KAAA;QAE1E;QACA,MAAMI,MAAA,GAASJ,KAAA,EAAOI,MAAA;QACtB,IAAI,OAAOA,MAAA,KAAW,cAAcA,MAAA,CAAO;UAAEN;QAAK,IAA2B;UAC3E,OAAO;QACT;QAEA;QACA,MAAMO,UAAA,GAAaL,KAAA,EAAOK,UAAA,IAAcL,KAAA,EAAOM,cAAA;QAC/C,MAAMC,gBAAA,GAAmB,MAAMF,UAAA,GAAa;UAC1CG,KAAA,EAAO;UACPC,IAAA,EAAM;UACNZ,GAAA;UACAa,IAAA,EAAM;QACR;QAEA;QACA,IAAI,CAACH,gBAAA,EAAkB;UACrB,OAAOR,cAAA;QACT;QAEA;QACA,IAAIA,cAAA,KAAmB,MAAM;UAC3B,OAAOQ,gBAAA;QACT;QAEA;QACA,OAAOtB,uBAAA,CAAwB,CAACc,cAAA,EAAgBQ,gBAAA,CAAiB,EAAE;MACrE;MAEA,OAAOf,iBAAA;IACT;IAEA;IACA,IAAI,YAAYF,KAAA,IAASA,KAAA,CAAMH,MAAM,EAAE;MACrC,OAAO;QACL,GAAGG,KAAK;QACRH,MAAA,EAAQD,uBAAA,CAAwBI,KAAA,CAAMH,MAAM,EAAEC,MAAA;MAChD;IACF;IAEA;IACA,IAAIE,KAAA,CAAMC,IAAI,KAAK,UAAU,UAAUD,KAAA,EAAO;MAC5C,OAAO;QACL,GAAGA,KAAK;QACRqB,IAAA,EAAMrB,KAAA,CAAMqB,IAAI,CAACtB,GAAG,CAAEuB,GAAA,KAAS;UAC7B,GAAGA,GAAG;UACNzB,MAAA,EAAQD,uBAAA,CAAwB0B,GAAA,CAAIzB,MAAM,EAAEC,MAAA;QAC9C;MACF;IACF;IAEA;IACA,IAAIE,KAAA,CAAMC,IAAI,KAAK,UAAU;MAC3B,MAAMsB,MAAA,GAAUvB,KAAA,CAAMwB,eAAe,IAAIxB,KAAA,CAAMuB,MAAM,IAAI,EAAE;MAC3D,OAAO;QACL,GAAGvB,KAAK;QACRuB,MAAA,EAAQA,MAAA,CAAOxB,GAAG,CAAE0B,KAAA;UAClB,IAAI,OAAOA,KAAA,KAAU,UAAU;YAC7B,OAAOA,KAAA;UACT;UACA,OAAO;YACL,GAAGA,KAAK;YACR5B,MAAA,EAAQD,uBAAA,CAAwB6B,KAAA,CAAM5B,MAAM,EAAEC,MAAA;UAChD;QACF;MACF;IACF;IAEA,OAAOE,KAAA;EACT;AACF","ignoreList":[]}
@@ -34,44 +34,45 @@
34
34
  * ],
35
35
  * })
36
36
  * ```
37
- */ export function buildEditorState({ nodes, text }) {
38
- const editorJSON = {
39
- root: {
40
- type: 'root',
41
- children: [],
42
- direction: 'ltr',
43
- format: '',
44
- indent: 0,
45
- version: 1
46
- }
47
- };
48
- if (text) {
49
- editorJSON.root.children.push({
50
- type: 'paragraph',
51
- children: [
52
- {
53
- type: 'text',
54
- detail: 0,
55
- format: 0,
56
- mode: 'normal',
57
- style: '',
58
- text,
59
- version: 1
60
- }
61
- ],
62
- direction: 'ltr',
63
- format: '',
64
- indent: 0,
65
- textFormat: 0,
66
- textStyle: '',
67
- version: 1
68
- });
37
+ */export function buildEditorState({
38
+ nodes,
39
+ text
40
+ }) {
41
+ const editorJSON = {
42
+ root: {
43
+ type: 'root',
44
+ children: [],
45
+ direction: 'ltr',
46
+ format: '',
47
+ indent: 0,
48
+ version: 1
69
49
  }
70
- if (nodes?.length) {
71
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
72
- editorJSON.root.children.push(...nodes);
73
- }
74
- return editorJSON;
50
+ };
51
+ if (text) {
52
+ editorJSON.root.children.push({
53
+ type: 'paragraph',
54
+ children: [{
55
+ type: 'text',
56
+ detail: 0,
57
+ format: 0,
58
+ mode: 'normal',
59
+ style: '',
60
+ text,
61
+ version: 1
62
+ }],
63
+ direction: 'ltr',
64
+ format: '',
65
+ indent: 0,
66
+ textFormat: 0,
67
+ textStyle: '',
68
+ version: 1
69
+ });
70
+ }
71
+ if (nodes?.length) {
72
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
73
+ editorJSON.root.children.push(...nodes);
74
+ }
75
+ return editorJSON;
75
76
  }
76
77
  /**
77
78
  *
@@ -79,6 +80,6 @@
79
80
  *
80
81
  * @experimental this API may change or be removed in a minor release
81
82
  * @internal
82
- */ export const buildDefaultEditorState = buildEditorState;
83
-
83
+ */
84
+ export const buildDefaultEditorState = buildEditorState;
84
85
  //# sourceMappingURL=buildEditorState.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/buildEditorState.ts"],"sourcesContent":["import type { SerializedLexicalNode } from 'lexical'\n\nimport type { DefaultNodeTypes, DefaultTypedEditorState, TypedEditorState } from '../nodeTypes.js'\n\n/**\n * Helper to build lexical editor state JSON from text and/or nodes.\n *\n * @param nodes - The nodes to include in the editor state. If you pass the `text` argument, this will append your nodes after the first paragraph node.\n * @param text - The text content to include in the editor state. This will create a paragraph node with a text node for you and set that as the first node.\n * @returns The constructed editor state JSON.\n *\n * @example\n *\n * just passing text:\n *\n * ```ts\n * const editorState = buildEditorState<DefaultNodeTypes>({ text: 'Hello world' }) // result typed as DefaultTypedEditorState\n * ```\n *\n * @example\n *\n * passing nodes:\n *\n * ```ts\n * const editorState = // result typed as TypedEditorState<DefaultNodeTypes | SerializedBlockNode> (or TypedEditorState<SerializedBlockNode>)\n * buildEditorState<DefaultNodeTypes | SerializedBlockNode>({ // or just buildEditorState<SerializedBlockNode> if you *only* want to allow block nodes\n * nodes: [\n * {\n * type: 'block',\n * fields: {\n * id: 'id',\n * blockName: 'Cool block',\n * blockType: 'myBlock',\n * },\n * format: 'left',\n * version: 1,\n * }\n * ],\n * })\n * ```\n */\nexport function buildEditorState<T extends SerializedLexicalNode>({\n nodes,\n text,\n}: {\n nodes?: TypedEditorState<T>['root']['children']\n text?: string\n}): TypedEditorState<T> {\n const editorJSON: DefaultTypedEditorState = {\n root: {\n type: 'root',\n children: [],\n direction: 'ltr',\n format: '',\n indent: 0,\n version: 1,\n },\n }\n\n if (text) {\n editorJSON.root.children.push({\n type: 'paragraph',\n children: [\n {\n type: 'text',\n detail: 0,\n format: 0,\n mode: 'normal',\n style: '',\n text,\n version: 1,\n },\n ],\n direction: 'ltr',\n format: '',\n indent: 0,\n textFormat: 0,\n textStyle: '',\n version: 1,\n })\n }\n\n if (nodes?.length) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n editorJSON.root.children.push(...(nodes as any))\n }\n\n return editorJSON as TypedEditorState<T>\n}\n\n/**\n *\n * Alias for `buildEditorState<DefaultNodeTypes>`\n *\n * @experimental this API may change or be removed in a minor release\n * @internal\n */\nexport const buildDefaultEditorState: typeof buildEditorState<DefaultNodeTypes> =\n buildEditorState<DefaultNodeTypes>\n"],"names":["buildEditorState","nodes","text","editorJSON","root","type","children","direction","format","indent","version","push","detail","mode","style","textFormat","textStyle","length","buildDefaultEditorState"],"mappings":"AAIA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAoCC,GACD,OAAO,SAASA,iBAAkD,EAChEC,KAAK,EACLC,IAAI,EAIL;IACC,MAAMC,aAAsC;QAC1CC,MAAM;YACJC,MAAM;YACNC,UAAU,EAAE;YACZC,WAAW;YACXC,QAAQ;YACRC,QAAQ;YACRC,SAAS;QACX;IACF;IAEA,IAAIR,MAAM;QACRC,WAAWC,IAAI,CAACE,QAAQ,CAACK,IAAI,CAAC;YAC5BN,MAAM;YACNC,UAAU;gBACR;oBACED,MAAM;oBACNO,QAAQ;oBACRJ,QAAQ;oBACRK,MAAM;oBACNC,OAAO;oBACPZ;oBACAQ,SAAS;gBACX;aACD;YACDH,WAAW;YACXC,QAAQ;YACRC,QAAQ;YACRM,YAAY;YACZC,WAAW;YACXN,SAAS;QACX;IACF;IAEA,IAAIT,OAAOgB,QAAQ;QACjB,8DAA8D;QAC9Dd,WAAWC,IAAI,CAACE,QAAQ,CAACK,IAAI,IAAKV;IACpC;IAEA,OAAOE;AACT;AAEA;;;;;;CAMC,GACD,OAAO,MAAMe,0BACXlB,iBAAkC"}
1
+ {"version":3,"file":"buildEditorState.js","names":["buildEditorState","nodes","text","editorJSON","root","type","children","direction","format","indent","version","push","detail","mode","style","textFormat","textStyle","length","buildDefaultEditorState"],"sources":["../../src/utilities/buildEditorState.ts"],"sourcesContent":["import type { SerializedLexicalNode } from 'lexical'\n\nimport type { DefaultNodeTypes, DefaultTypedEditorState, TypedEditorState } from '../nodeTypes.js'\n\n/**\n * Helper to build lexical editor state JSON from text and/or nodes.\n *\n * @param nodes - The nodes to include in the editor state. If you pass the `text` argument, this will append your nodes after the first paragraph node.\n * @param text - The text content to include in the editor state. This will create a paragraph node with a text node for you and set that as the first node.\n * @returns The constructed editor state JSON.\n *\n * @example\n *\n * just passing text:\n *\n * ```ts\n * const editorState = buildEditorState<DefaultNodeTypes>({ text: 'Hello world' }) // result typed as DefaultTypedEditorState\n * ```\n *\n * @example\n *\n * passing nodes:\n *\n * ```ts\n * const editorState = // result typed as TypedEditorState<DefaultNodeTypes | SerializedBlockNode> (or TypedEditorState<SerializedBlockNode>)\n * buildEditorState<DefaultNodeTypes | SerializedBlockNode>({ // or just buildEditorState<SerializedBlockNode> if you *only* want to allow block nodes\n * nodes: [\n * {\n * type: 'block',\n * fields: {\n * id: 'id',\n * blockName: 'Cool block',\n * blockType: 'myBlock',\n * },\n * format: 'left',\n * version: 1,\n * }\n * ],\n * })\n * ```\n */\nexport function buildEditorState<T extends SerializedLexicalNode>({\n nodes,\n text,\n}: {\n nodes?: TypedEditorState<T>['root']['children']\n text?: string\n}): TypedEditorState<T> {\n const editorJSON: DefaultTypedEditorState = {\n root: {\n type: 'root',\n children: [],\n direction: 'ltr',\n format: '',\n indent: 0,\n version: 1,\n },\n }\n\n if (text) {\n editorJSON.root.children.push({\n type: 'paragraph',\n children: [\n {\n type: 'text',\n detail: 0,\n format: 0,\n mode: 'normal',\n style: '',\n text,\n version: 1,\n },\n ],\n direction: 'ltr',\n format: '',\n indent: 0,\n textFormat: 0,\n textStyle: '',\n version: 1,\n })\n }\n\n if (nodes?.length) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n editorJSON.root.children.push(...(nodes as any))\n }\n\n return editorJSON as TypedEditorState<T>\n}\n\n/**\n *\n * Alias for `buildEditorState<DefaultNodeTypes>`\n *\n * @experimental this API may change or be removed in a minor release\n * @internal\n */\nexport const buildDefaultEditorState: typeof buildEditorState<DefaultNodeTypes> =\n buildEditorState<DefaultNodeTypes>\n"],"mappings":"AAIA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCA,OAAO,SAASA,iBAAkD;EAChEC,KAAK;EACLC;AAAI,CAIL;EACC,MAAMC,UAAA,GAAsC;IAC1CC,IAAA,EAAM;MACJC,IAAA,EAAM;MACNC,QAAA,EAAU,EAAE;MACZC,SAAA,EAAW;MACXC,MAAA,EAAQ;MACRC,MAAA,EAAQ;MACRC,OAAA,EAAS;IACX;EACF;EAEA,IAAIR,IAAA,EAAM;IACRC,UAAA,CAAWC,IAAI,CAACE,QAAQ,CAACK,IAAI,CAAC;MAC5BN,IAAA,EAAM;MACNC,QAAA,EAAU,CACR;QACED,IAAA,EAAM;QACNO,MAAA,EAAQ;QACRJ,MAAA,EAAQ;QACRK,IAAA,EAAM;QACNC,KAAA,EAAO;QACPZ,IAAA;QACAQ,OAAA,EAAS;MACX,EACD;MACDH,SAAA,EAAW;MACXC,MAAA,EAAQ;MACRC,MAAA,EAAQ;MACRM,UAAA,EAAY;MACZC,SAAA,EAAW;MACXN,OAAA,EAAS;IACX;EACF;EAEA,IAAIT,KAAA,EAAOgB,MAAA,EAAQ;IACjB;IACAd,UAAA,CAAWC,IAAI,CAACE,QAAQ,CAACK,IAAI,IAAKV,KAAA;EACpC;EAEA,OAAOE,UAAA;AACT;AAEA;;;;;;;AAOA,OAAO,MAAMe,uBAAA,GACXlB,gBAAA","ignoreList":[]}
@@ -1,56 +1,57 @@
1
1
  import { fieldSchemasToFormState } from '@payloadcms/ui/forms/fieldSchemasToFormState';
2
- export async function buildInitialState({ context, initialState: initialStateFromArgs, nodeData }) {
3
- let initialState = initialStateFromArgs ?? {};
4
- for (const node of nodeData){
5
- if ('children' in node) {
6
- initialState = await buildInitialState({
7
- context,
8
- initialState,
9
- nodeData: node.children
10
- });
11
- }
12
- if (node.type === 'block' || node.type === 'inlineBlock') {
13
- const blockNode = node;
14
- const id = blockNode?.fields?.id;
15
- if (!id) {
16
- continue;
17
- }
18
- const schemaFieldsPath = node.type === 'block' ? `${context.lexicalFieldSchemaPath}.lexical_internal_feature.blocks.lexical_blocks.${blockNode.fields.blockType}.fields` : `${context.lexicalFieldSchemaPath}.lexical_internal_feature.blocks.lexical_inline_blocks.${blockNode.fields.blockType}.fields`;
19
- // Build form state for the block
20
- const formStateResult = await fieldSchemasToFormState({
21
- id: context.id,
22
- clientFieldSchemaMap: context.clientFieldSchemaMap,
23
- collectionSlug: context.collectionSlug,
24
- data: blockNode.fields,
25
- documentData: context.documentData,
26
- fields: context.fieldSchemaMap.get(schemaFieldsPath)?.fields,
27
- fieldSchemaMap: context.fieldSchemaMap,
28
- initialBlockData: blockNode.fields,
29
- operation: context.operation,
30
- // TODO: Type
31
- permissions: true,
32
- preferences: context.preferences,
33
- readOnly: context.disabled,
34
- renderAllFields: true,
35
- // If this function runs, the parent lexical field is being re-rendered => thus we can assume all its sub-fields need to be re-rendered
36
- renderFieldFn: context.renderFieldFn,
37
- req: context.req,
38
- schemaPath: schemaFieldsPath
39
- });
40
- if (!initialState[id]) {
41
- initialState[id] = {};
42
- }
43
- initialState[id].formState = formStateResult;
44
- if (node.type === 'block') {
45
- const currentFieldPreferences = context.preferences?.fields?.[context.field.name];
46
- const collapsedArray = currentFieldPreferences?.collapsed;
47
- if (Array.isArray(collapsedArray) && collapsedArray.includes(id)) {
48
- initialState[id].collapsed = true;
49
- }
50
- }
2
+ export async function buildInitialState({
3
+ context,
4
+ initialState: initialStateFromArgs,
5
+ nodeData
6
+ }) {
7
+ let initialState = initialStateFromArgs ?? {};
8
+ for (const node of nodeData) {
9
+ if ('children' in node) {
10
+ initialState = await buildInitialState({
11
+ context,
12
+ initialState,
13
+ nodeData: node.children
14
+ });
15
+ }
16
+ if (node.type === 'block' || node.type === 'inlineBlock') {
17
+ const blockNode = node;
18
+ const id = blockNode?.fields?.id;
19
+ if (!id) {
20
+ continue;
21
+ }
22
+ const schemaFieldsPath = node.type === 'block' ? `${context.lexicalFieldSchemaPath}.lexical_internal_feature.blocks.lexical_blocks.${blockNode.fields.blockType}.fields` : `${context.lexicalFieldSchemaPath}.lexical_internal_feature.blocks.lexical_inline_blocks.${blockNode.fields.blockType}.fields`;
23
+ // Build form state for the block
24
+ const formStateResult = await fieldSchemasToFormState({
25
+ id: context.id,
26
+ clientFieldSchemaMap: context.clientFieldSchemaMap,
27
+ collectionSlug: context.collectionSlug,
28
+ data: blockNode.fields,
29
+ documentData: context.documentData,
30
+ fields: context.fieldSchemaMap.get(schemaFieldsPath)?.fields,
31
+ fieldSchemaMap: context.fieldSchemaMap,
32
+ initialBlockData: blockNode.fields,
33
+ operation: context.operation,
34
+ permissions: true,
35
+ preferences: context.preferences,
36
+ readOnly: context.disabled,
37
+ renderAllFields: true,
38
+ renderFieldFn: context.renderFieldFn,
39
+ req: context.req,
40
+ schemaPath: schemaFieldsPath
41
+ });
42
+ if (!initialState[id]) {
43
+ initialState[id] = {};
44
+ }
45
+ initialState[id].formState = formStateResult;
46
+ if (node.type === 'block') {
47
+ const currentFieldPreferences = context.preferences?.fields?.[context.field.name];
48
+ const collapsedArray = currentFieldPreferences?.collapsed;
49
+ if (Array.isArray(collapsedArray) && collapsedArray.includes(id)) {
50
+ initialState[id].collapsed = true;
51
51
  }
52
+ }
52
53
  }
53
- return initialState;
54
+ }
55
+ return initialState;
54
56
  }
55
-
56
57
  //# sourceMappingURL=buildInitialState.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/buildInitialState.ts"],"sourcesContent":["import type { SerializedLexicalNode } from 'lexical'\nimport type {\n ClientFieldSchemaMap,\n DocumentPreferences,\n FieldSchemaMap,\n FormState,\n Operation,\n PayloadRequest,\n RichTextField,\n SanitizedFieldPermissions,\n} from 'payload'\n\nimport { fieldSchemasToFormState } from '@payloadcms/ui/forms/fieldSchemasToFormState'\n\nimport type { SerializedBlockNode } from '../nodeTypes.js'\n\nexport type InitialLexicalFormState = {\n [nodeID: string]: {\n [key: string]: any\n formState?: FormState\n }\n}\n\ntype Props = {\n context: {\n clientFieldSchemaMap: ClientFieldSchemaMap\n collectionSlug: string\n disabled?: boolean\n documentData?: any\n field: RichTextField\n fieldSchemaMap: FieldSchemaMap\n id?: number | string\n lexicalFieldSchemaPath: string\n operation: Operation\n permissions?: SanitizedFieldPermissions\n preferences: DocumentPreferences\n renderFieldFn: any\n req: PayloadRequest\n }\n initialState?: InitialLexicalFormState\n nodeData: SerializedLexicalNode[]\n}\n\nexport async function buildInitialState({\n context,\n initialState: initialStateFromArgs,\n nodeData,\n}: Props): Promise<InitialLexicalFormState> {\n let initialState: InitialLexicalFormState = initialStateFromArgs ?? {}\n for (const node of nodeData) {\n if ('children' in node) {\n initialState = await buildInitialState({\n context,\n initialState,\n nodeData: node.children as SerializedLexicalNode[],\n })\n }\n\n if (node.type === 'block' || node.type === 'inlineBlock') {\n const blockNode = node as SerializedBlockNode\n const id = blockNode?.fields?.id\n if (!id) {\n continue\n }\n\n const schemaFieldsPath =\n node.type === 'block'\n ? `${context.lexicalFieldSchemaPath}.lexical_internal_feature.blocks.lexical_blocks.${blockNode.fields.blockType}.fields`\n : `${context.lexicalFieldSchemaPath}.lexical_internal_feature.blocks.lexical_inline_blocks.${blockNode.fields.blockType}.fields`\n\n // Build form state for the block\n\n const formStateResult = await fieldSchemasToFormState({\n id: context.id,\n clientFieldSchemaMap: context.clientFieldSchemaMap,\n collectionSlug: context.collectionSlug,\n data: blockNode.fields,\n documentData: context.documentData,\n fields: (context.fieldSchemaMap.get(schemaFieldsPath) as any)?.fields,\n fieldSchemaMap: context.fieldSchemaMap,\n initialBlockData: blockNode.fields,\n operation: context.operation as any, // TODO: Type\n permissions: true,\n preferences: context.preferences,\n readOnly: context.disabled,\n renderAllFields: true, // If this function runs, the parent lexical field is being re-rendered => thus we can assume all its sub-fields need to be re-rendered\n renderFieldFn: context.renderFieldFn,\n req: context.req,\n schemaPath: schemaFieldsPath,\n })\n\n if (!initialState[id]) {\n initialState[id] = {}\n }\n\n initialState[id].formState = formStateResult\n\n if (node.type === 'block') {\n const currentFieldPreferences = context.preferences?.fields?.[context.field.name]\n const collapsedArray = currentFieldPreferences?.collapsed\n if (Array.isArray(collapsedArray) && collapsedArray.includes(id)) {\n initialState[id].collapsed = true\n }\n }\n }\n }\n return initialState\n}\n"],"names":["fieldSchemasToFormState","buildInitialState","context","initialState","initialStateFromArgs","nodeData","node","children","type","blockNode","id","fields","schemaFieldsPath","lexicalFieldSchemaPath","blockType","formStateResult","clientFieldSchemaMap","collectionSlug","data","documentData","fieldSchemaMap","get","initialBlockData","operation","permissions","preferences","readOnly","disabled","renderAllFields","renderFieldFn","req","schemaPath","formState","currentFieldPreferences","field","name","collapsedArray","collapsed","Array","isArray","includes"],"mappings":"AAYA,SAASA,uBAAuB,QAAQ,+CAA8C;AA+BtF,OAAO,eAAeC,kBAAkB,EACtCC,OAAO,EACPC,cAAcC,oBAAoB,EAClCC,QAAQ,EACF;IACN,IAAIF,eAAwCC,wBAAwB,CAAC;IACrE,KAAK,MAAME,QAAQD,SAAU;QAC3B,IAAI,cAAcC,MAAM;YACtBH,eAAe,MAAMF,kBAAkB;gBACrCC;gBACAC;gBACAE,UAAUC,KAAKC,QAAQ;YACzB;QACF;QAEA,IAAID,KAAKE,IAAI,KAAK,WAAWF,KAAKE,IAAI,KAAK,eAAe;YACxD,MAAMC,YAAYH;YAClB,MAAMI,KAAKD,WAAWE,QAAQD;YAC9B,IAAI,CAACA,IAAI;gBACP;YACF;YAEA,MAAME,mBACJN,KAAKE,IAAI,KAAK,UACV,GAAGN,QAAQW,sBAAsB,CAAC,gDAAgD,EAAEJ,UAAUE,MAAM,CAACG,SAAS,CAAC,OAAO,CAAC,GACvH,GAAGZ,QAAQW,sBAAsB,CAAC,uDAAuD,EAAEJ,UAAUE,MAAM,CAACG,SAAS,CAAC,OAAO,CAAC;YAEpI,iCAAiC;YAEjC,MAAMC,kBAAkB,MAAMf,wBAAwB;gBACpDU,IAAIR,QAAQQ,EAAE;gBACdM,sBAAsBd,QAAQc,oBAAoB;gBAClDC,gBAAgBf,QAAQe,cAAc;gBACtCC,MAAMT,UAAUE,MAAM;gBACtBQ,cAAcjB,QAAQiB,YAAY;gBAClCR,QAAST,QAAQkB,cAAc,CAACC,GAAG,CAACT,mBAA2BD;gBAC/DS,gBAAgBlB,QAAQkB,cAAc;gBACtCE,kBAAkBb,UAAUE,MAAM;gBAClCY,WAAWrB,QAAQqB,SAAS;gBAAS,aAAa;gBAClDC,aAAa;gBACbC,aAAavB,QAAQuB,WAAW;gBAChCC,UAAUxB,QAAQyB,QAAQ;gBAC1BC,iBAAiB;gBAAM,uIAAuI;gBAC9JC,eAAe3B,QAAQ2B,aAAa;gBACpCC,KAAK5B,QAAQ4B,GAAG;gBAChBC,YAAYnB;YACd;YAEA,IAAI,CAACT,YAAY,CAACO,GAAG,EAAE;gBACrBP,YAAY,CAACO,GAAG,GAAG,CAAC;YACtB;YAEAP,YAAY,CAACO,GAAG,CAACsB,SAAS,GAAGjB;YAE7B,IAAIT,KAAKE,IAAI,KAAK,SAAS;gBACzB,MAAMyB,0BAA0B/B,QAAQuB,WAAW,EAAEd,QAAQ,CAACT,QAAQgC,KAAK,CAACC,IAAI,CAAC;gBACjF,MAAMC,iBAAiBH,yBAAyBI;gBAChD,IAAIC,MAAMC,OAAO,CAACH,mBAAmBA,eAAeI,QAAQ,CAAC9B,KAAK;oBAChEP,YAAY,CAACO,GAAG,CAAC2B,SAAS,GAAG;gBAC/B;YACF;QACF;IACF;IACA,OAAOlC;AACT"}
1
+ {"version":3,"file":"buildInitialState.js","names":["fieldSchemasToFormState","buildInitialState","context","initialState","initialStateFromArgs","nodeData","node","children","type","blockNode","id","fields","schemaFieldsPath","lexicalFieldSchemaPath","blockType","formStateResult","clientFieldSchemaMap","collectionSlug","data","documentData","fieldSchemaMap","get","initialBlockData","operation","permissions","preferences","readOnly","disabled","renderAllFields","renderFieldFn","req","schemaPath","formState","currentFieldPreferences","field","name","collapsedArray","collapsed","Array","isArray","includes"],"sources":["../../src/utilities/buildInitialState.ts"],"sourcesContent":["import type { SerializedLexicalNode } from 'lexical'\nimport type {\n ClientFieldSchemaMap,\n DocumentPreferences,\n FieldSchemaMap,\n FormState,\n Operation,\n PayloadRequest,\n RichTextField,\n SanitizedFieldPermissions,\n} from 'payload'\n\nimport { fieldSchemasToFormState } from '@payloadcms/ui/forms/fieldSchemasToFormState'\n\nimport type { SerializedBlockNode } from '../nodeTypes.js'\n\nexport type InitialLexicalFormState = {\n [nodeID: string]: {\n [key: string]: any\n formState?: FormState\n }\n}\n\ntype Props = {\n context: {\n clientFieldSchemaMap: ClientFieldSchemaMap\n collectionSlug: string\n disabled?: boolean\n documentData?: any\n field: RichTextField\n fieldSchemaMap: FieldSchemaMap\n id?: number | string\n lexicalFieldSchemaPath: string\n operation: Operation\n permissions?: SanitizedFieldPermissions\n preferences: DocumentPreferences\n renderFieldFn: any\n req: PayloadRequest\n }\n initialState?: InitialLexicalFormState\n nodeData: SerializedLexicalNode[]\n}\n\nexport async function buildInitialState({\n context,\n initialState: initialStateFromArgs,\n nodeData,\n}: Props): Promise<InitialLexicalFormState> {\n let initialState: InitialLexicalFormState = initialStateFromArgs ?? {}\n for (const node of nodeData) {\n if ('children' in node) {\n initialState = await buildInitialState({\n context,\n initialState,\n nodeData: node.children as SerializedLexicalNode[],\n })\n }\n\n if (node.type === 'block' || node.type === 'inlineBlock') {\n const blockNode = node as SerializedBlockNode\n const id = blockNode?.fields?.id\n if (!id) {\n continue\n }\n\n const schemaFieldsPath =\n node.type === 'block'\n ? `${context.lexicalFieldSchemaPath}.lexical_internal_feature.blocks.lexical_blocks.${blockNode.fields.blockType}.fields`\n : `${context.lexicalFieldSchemaPath}.lexical_internal_feature.blocks.lexical_inline_blocks.${blockNode.fields.blockType}.fields`\n\n // Build form state for the block\n\n const formStateResult = await fieldSchemasToFormState({\n id: context.id,\n clientFieldSchemaMap: context.clientFieldSchemaMap,\n collectionSlug: context.collectionSlug,\n data: blockNode.fields,\n documentData: context.documentData,\n fields: (context.fieldSchemaMap.get(schemaFieldsPath) as any)?.fields,\n fieldSchemaMap: context.fieldSchemaMap,\n initialBlockData: blockNode.fields,\n operation: context.operation as any, // TODO: Type\n permissions: true,\n preferences: context.preferences,\n readOnly: context.disabled,\n renderAllFields: true, // If this function runs, the parent lexical field is being re-rendered => thus we can assume all its sub-fields need to be re-rendered\n renderFieldFn: context.renderFieldFn,\n req: context.req,\n schemaPath: schemaFieldsPath,\n })\n\n if (!initialState[id]) {\n initialState[id] = {}\n }\n\n initialState[id].formState = formStateResult\n\n if (node.type === 'block') {\n const currentFieldPreferences = context.preferences?.fields?.[context.field.name]\n const collapsedArray = currentFieldPreferences?.collapsed\n if (Array.isArray(collapsedArray) && collapsedArray.includes(id)) {\n initialState[id].collapsed = true\n }\n }\n }\n }\n return initialState\n}\n"],"mappings":"AAYA,SAASA,uBAAuB,QAAQ;AA+BxC,OAAO,eAAeC,kBAAkB;EACtCC,OAAO;EACPC,YAAA,EAAcC,oBAAoB;EAClCC;AAAQ,CACF;EACN,IAAIF,YAAA,GAAwCC,oBAAA,IAAwB,CAAC;EACrE,KAAK,MAAME,IAAA,IAAQD,QAAA,EAAU;IAC3B,IAAI,cAAcC,IAAA,EAAM;MACtBH,YAAA,GAAe,MAAMF,iBAAA,CAAkB;QACrCC,OAAA;QACAC,YAAA;QACAE,QAAA,EAAUC,IAAA,CAAKC;MACjB;IACF;IAEA,IAAID,IAAA,CAAKE,IAAI,KAAK,WAAWF,IAAA,CAAKE,IAAI,KAAK,eAAe;MACxD,MAAMC,SAAA,GAAYH,IAAA;MAClB,MAAMI,EAAA,GAAKD,SAAA,EAAWE,MAAA,EAAQD,EAAA;MAC9B,IAAI,CAACA,EAAA,EAAI;QACP;MACF;MAEA,MAAME,gBAAA,GACJN,IAAA,CAAKE,IAAI,KAAK,UACV,GAAGN,OAAA,CAAQW,sBAAsB,mDAAmDJ,SAAA,CAAUE,MAAM,CAACG,SAAS,SAAS,GACvH,GAAGZ,OAAA,CAAQW,sBAAsB,0DAA0DJ,SAAA,CAAUE,MAAM,CAACG,SAAS,SAAS;MAEpI;MAEA,MAAMC,eAAA,GAAkB,MAAMf,uBAAA,CAAwB;QACpDU,EAAA,EAAIR,OAAA,CAAQQ,EAAE;QACdM,oBAAA,EAAsBd,OAAA,CAAQc,oBAAoB;QAClDC,cAAA,EAAgBf,OAAA,CAAQe,cAAc;QACtCC,IAAA,EAAMT,SAAA,CAAUE,MAAM;QACtBQ,YAAA,EAAcjB,OAAA,CAAQiB,YAAY;QAClCR,MAAA,EAAST,OAAA,CAAQkB,cAAc,CAACC,GAAG,CAACT,gBAAA,GAA2BD,MAAA;QAC/DS,cAAA,EAAgBlB,OAAA,CAAQkB,cAAc;QACtCE,gBAAA,EAAkBb,SAAA,CAAUE,MAAM;QAClCY,SAAA,EAAWrB,OAAA,CAAQqB,SAAS;QAC5BC,WAAA,EAAa;QACbC,WAAA,EAAavB,OAAA,CAAQuB,WAAW;QAChCC,QAAA,EAAUxB,OAAA,CAAQyB,QAAQ;QAC1BC,eAAA,EAAiB;QACjBC,aAAA,EAAe3B,OAAA,CAAQ2B,aAAa;QACpCC,GAAA,EAAK5B,OAAA,CAAQ4B,GAAG;QAChBC,UAAA,EAAYnB;MACd;MAEA,IAAI,CAACT,YAAY,CAACO,EAAA,CAAG,EAAE;QACrBP,YAAY,CAACO,EAAA,CAAG,GAAG,CAAC;MACtB;MAEAP,YAAY,CAACO,EAAA,CAAG,CAACsB,SAAS,GAAGjB,eAAA;MAE7B,IAAIT,IAAA,CAAKE,IAAI,KAAK,SAAS;QACzB,MAAMyB,uBAAA,GAA0B/B,OAAA,CAAQuB,WAAW,EAAEd,MAAA,GAAST,OAAA,CAAQgC,KAAK,CAACC,IAAI,CAAC;QACjF,MAAMC,cAAA,GAAiBH,uBAAA,EAAyBI,SAAA;QAChD,IAAIC,KAAA,CAAMC,OAAO,CAACH,cAAA,KAAmBA,cAAA,CAAeI,QAAQ,CAAC9B,EAAA,GAAK;UAChEP,YAAY,CAACO,EAAA,CAAG,CAAC2B,SAAS,GAAG;QAC/B;MACF;IACF;EACF;EACA,OAAOlC,YAAA;AACT","ignoreList":[]}
@@ -1,45 +1,51 @@
1
- /** unSanitizedEditorConfig.features, but mapped */ // other resolved features, which have been loaded before this one. All features declared in 'dependencies' should be available here
2
- // unSanitized EditorConfig,
3
- export const createClientFeature = (feature)=>{
4
- const featureProviderProvideClient = (props)=>{
5
- const featureProviderClient = {
6
- clientFeatureProps: props
7
- };
8
- if (typeof feature === 'function') {
9
- featureProviderClient.feature = ({ config, featureClientImportMap, featureClientSchemaMap, featureProviderMap, field, resolvedFeatures, schemaPath, unSanitizedEditorConfig })=>{
10
- const toReturn = feature({
11
- config,
12
- featureClientImportMap,
13
- featureClientSchemaMap,
14
- featureProviderMap,
15
- field,
16
- props,
17
- resolvedFeatures,
18
- schemaPath,
19
- unSanitizedEditorConfig
20
- });
21
- if (toReturn.sanitizedClientFeatureProps === null) {
22
- toReturn.sanitizedClientFeatureProps = props;
23
- }
24
- return toReturn;
25
- };
26
- } else {
27
- // We have to spread feature here! Otherwise, if the arg of createClientFeature is not a function, and 2
28
- // richText editors have the same feature (even if both call it, e.g. both call UploadFeature()),
29
- // the second richText editor here will override sanitizedClientFeatureProps of the first feature, as both richText
30
- // editor features share the same reference to the feature object.
31
- // Example: richText editor 1 and 2 both have UploadFeature. richText editor 1 calls UploadFeature() with custom fields,
32
- // richText editor 2 calls UploadFeature() with NO custom fields. If we don't spread feature here, richText editor 1
33
- // will not have any custom fields, as richText editor 2 will override the feature object.
34
- const newFeature = {
35
- ...feature
36
- };
37
- newFeature.sanitizedClientFeatureProps = props;
38
- featureProviderClient.feature = newFeature;
39
- }
40
- return featureProviderClient;
1
+ export const createClientFeature = feature => {
2
+ const featureProviderProvideClient = props => {
3
+ const featureProviderClient = {
4
+ clientFeatureProps: props
41
5
  };
42
- return featureProviderProvideClient;
6
+ if (typeof feature === 'function') {
7
+ featureProviderClient.feature = ({
8
+ config,
9
+ featureClientImportMap,
10
+ featureClientSchemaMap,
11
+ featureProviderMap,
12
+ field,
13
+ resolvedFeatures,
14
+ schemaPath,
15
+ unSanitizedEditorConfig
16
+ }) => {
17
+ const toReturn = feature({
18
+ config,
19
+ featureClientImportMap,
20
+ featureClientSchemaMap,
21
+ featureProviderMap,
22
+ field,
23
+ props,
24
+ resolvedFeatures,
25
+ schemaPath,
26
+ unSanitizedEditorConfig
27
+ });
28
+ if (toReturn.sanitizedClientFeatureProps === null) {
29
+ toReturn.sanitizedClientFeatureProps = props;
30
+ }
31
+ return toReturn;
32
+ };
33
+ } else {
34
+ // We have to spread feature here! Otherwise, if the arg of createClientFeature is not a function, and 2
35
+ // richText editors have the same feature (even if both call it, e.g. both call UploadFeature()),
36
+ // the second richText editor here will override sanitizedClientFeatureProps of the first feature, as both richText
37
+ // editor features share the same reference to the feature object.
38
+ // Example: richText editor 1 and 2 both have UploadFeature. richText editor 1 calls UploadFeature() with custom fields,
39
+ // richText editor 2 calls UploadFeature() with NO custom fields. If we don't spread feature here, richText editor 1
40
+ // will not have any custom fields, as richText editor 2 will override the feature object.
41
+ const newFeature = {
42
+ ...feature
43
+ };
44
+ newFeature.sanitizedClientFeatureProps = props;
45
+ featureProviderClient.feature = newFeature;
46
+ }
47
+ return featureProviderClient;
48
+ };
49
+ return featureProviderProvideClient;
43
50
  };
44
-
45
51
  //# sourceMappingURL=createClientFeature.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/createClientFeature.ts"],"sourcesContent":["import type { ClientConfig, RichTextFieldClient } from 'payload'\n\nimport type {\n BaseClientFeatureProps,\n ClientFeature,\n ClientFeatureProviderMap,\n FeatureProviderClient,\n FeatureProviderProviderClient,\n ResolvedClientFeatureMap,\n} from '../features/typesClient.js'\nimport type { ClientEditorConfig } from '../lexical/config/types.js'\nimport type { FeatureClientSchemaMap } from '../types.js'\n\nexport type CreateClientFeatureArgs<UnSanitizedClientProps, ClientProps> =\n | ((props: {\n config: ClientConfig\n featureClientImportMap: Record<string, any>\n featureClientSchemaMap: FeatureClientSchemaMap\n /** unSanitizedEditorConfig.features, but mapped */\n featureProviderMap: ClientFeatureProviderMap\n field?: RichTextFieldClient\n props: BaseClientFeatureProps<UnSanitizedClientProps>\n // other resolved features, which have been loaded before this one. All features declared in 'dependencies' should be available here\n resolvedFeatures: ResolvedClientFeatureMap\n schemaPath: string\n // unSanitized EditorConfig,\n unSanitizedEditorConfig: ClientEditorConfig\n }) => ClientFeature<ClientProps>)\n | Omit<ClientFeature<ClientProps>, 'sanitizedClientFeatureProps'>\n\nexport const createClientFeature: <\n UnSanitizedClientProps = undefined,\n ClientProps = UnSanitizedClientProps,\n>(\n args: CreateClientFeatureArgs<UnSanitizedClientProps, ClientProps>,\n) => FeatureProviderProviderClient<UnSanitizedClientProps, ClientProps> = (feature) => {\n const featureProviderProvideClient: FeatureProviderProviderClient<any, any> = (props) => {\n const featureProviderClient: Partial<FeatureProviderClient<any, any>> = {\n clientFeatureProps: props,\n }\n\n if (typeof feature === 'function') {\n featureProviderClient.feature = ({\n config,\n featureClientImportMap,\n featureClientSchemaMap,\n featureProviderMap,\n field,\n resolvedFeatures,\n schemaPath,\n unSanitizedEditorConfig,\n }) => {\n const toReturn = feature({\n config,\n featureClientImportMap,\n featureClientSchemaMap,\n featureProviderMap,\n field,\n props,\n resolvedFeatures,\n schemaPath,\n unSanitizedEditorConfig,\n })\n\n if (toReturn.sanitizedClientFeatureProps === null) {\n toReturn.sanitizedClientFeatureProps = props\n }\n\n return toReturn\n }\n } else {\n // We have to spread feature here! Otherwise, if the arg of createClientFeature is not a function, and 2\n // richText editors have the same feature (even if both call it, e.g. both call UploadFeature()),\n // the second richText editor here will override sanitizedClientFeatureProps of the first feature, as both richText\n // editor features share the same reference to the feature object.\n // Example: richText editor 1 and 2 both have UploadFeature. richText editor 1 calls UploadFeature() with custom fields,\n // richText editor 2 calls UploadFeature() with NO custom fields. If we don't spread feature here, richText editor 1\n // will not have any custom fields, as richText editor 2 will override the feature object.\n const newFeature: ClientFeature<any> = { ...feature }\n newFeature.sanitizedClientFeatureProps = props\n featureProviderClient.feature = newFeature\n }\n return featureProviderClient as FeatureProviderClient<any, any>\n }\n\n return featureProviderProvideClient\n}\n"],"names":["createClientFeature","feature","featureProviderProvideClient","props","featureProviderClient","clientFeatureProps","config","featureClientImportMap","featureClientSchemaMap","featureProviderMap","field","resolvedFeatures","schemaPath","unSanitizedEditorConfig","toReturn","sanitizedClientFeatureProps","newFeature"],"mappings":"AAkBM,iDAAiD,GAIjD,oIAAoI;AAGpI,4BAA4B;AAKlC,OAAO,MAAMA,sBAK6D,CAACC;IACzE,MAAMC,+BAAwE,CAACC;QAC7E,MAAMC,wBAAkE;YACtEC,oBAAoBF;QACtB;QAEA,IAAI,OAAOF,YAAY,YAAY;YACjCG,sBAAsBH,OAAO,GAAG,CAAC,EAC/BK,MAAM,EACNC,sBAAsB,EACtBC,sBAAsB,EACtBC,kBAAkB,EAClBC,KAAK,EACLC,gBAAgB,EAChBC,UAAU,EACVC,uBAAuB,EACxB;gBACC,MAAMC,WAAWb,QAAQ;oBACvBK;oBACAC;oBACAC;oBACAC;oBACAC;oBACAP;oBACAQ;oBACAC;oBACAC;gBACF;gBAEA,IAAIC,SAASC,2BAA2B,KAAK,MAAM;oBACjDD,SAASC,2BAA2B,GAAGZ;gBACzC;gBAEA,OAAOW;YACT;QACF,OAAO;YACL,wGAAwG;YACxG,iGAAiG;YACjG,mHAAmH;YACnH,kEAAkE;YAClE,wHAAwH;YACxH,oHAAoH;YACpH,0FAA0F;YAC1F,MAAME,aAAiC;gBAAE,GAAGf,OAAO;YAAC;YACpDe,WAAWD,2BAA2B,GAAGZ;YACzCC,sBAAsBH,OAAO,GAAGe;QAClC;QACA,OAAOZ;IACT;IAEA,OAAOF;AACT,EAAC"}
1
+ {"version":3,"file":"createClientFeature.js","names":["createClientFeature","feature","featureProviderProvideClient","props","featureProviderClient","clientFeatureProps","config","featureClientImportMap","featureClientSchemaMap","featureProviderMap","field","resolvedFeatures","schemaPath","unSanitizedEditorConfig","toReturn","sanitizedClientFeatureProps","newFeature"],"sources":["../../src/utilities/createClientFeature.ts"],"sourcesContent":["import type { ClientConfig, RichTextFieldClient } from 'payload'\n\nimport type {\n BaseClientFeatureProps,\n ClientFeature,\n ClientFeatureProviderMap,\n FeatureProviderClient,\n FeatureProviderProviderClient,\n ResolvedClientFeatureMap,\n} from '../features/typesClient.js'\nimport type { ClientEditorConfig } from '../lexical/config/types.js'\nimport type { FeatureClientSchemaMap } from '../types.js'\n\nexport type CreateClientFeatureArgs<UnSanitizedClientProps, ClientProps> =\n | ((props: {\n config: ClientConfig\n featureClientImportMap: Record<string, any>\n featureClientSchemaMap: FeatureClientSchemaMap\n /** unSanitizedEditorConfig.features, but mapped */\n featureProviderMap: ClientFeatureProviderMap\n field?: RichTextFieldClient\n props: BaseClientFeatureProps<UnSanitizedClientProps>\n // other resolved features, which have been loaded before this one. All features declared in 'dependencies' should be available here\n resolvedFeatures: ResolvedClientFeatureMap\n schemaPath: string\n // unSanitized EditorConfig,\n unSanitizedEditorConfig: ClientEditorConfig\n }) => ClientFeature<ClientProps>)\n | Omit<ClientFeature<ClientProps>, 'sanitizedClientFeatureProps'>\n\nexport const createClientFeature: <\n UnSanitizedClientProps = undefined,\n ClientProps = UnSanitizedClientProps,\n>(\n args: CreateClientFeatureArgs<UnSanitizedClientProps, ClientProps>,\n) => FeatureProviderProviderClient<UnSanitizedClientProps, ClientProps> = (feature) => {\n const featureProviderProvideClient: FeatureProviderProviderClient<any, any> = (props) => {\n const featureProviderClient: Partial<FeatureProviderClient<any, any>> = {\n clientFeatureProps: props,\n }\n\n if (typeof feature === 'function') {\n featureProviderClient.feature = ({\n config,\n featureClientImportMap,\n featureClientSchemaMap,\n featureProviderMap,\n field,\n resolvedFeatures,\n schemaPath,\n unSanitizedEditorConfig,\n }) => {\n const toReturn = feature({\n config,\n featureClientImportMap,\n featureClientSchemaMap,\n featureProviderMap,\n field,\n props,\n resolvedFeatures,\n schemaPath,\n unSanitizedEditorConfig,\n })\n\n if (toReturn.sanitizedClientFeatureProps === null) {\n toReturn.sanitizedClientFeatureProps = props\n }\n\n return toReturn\n }\n } else {\n // We have to spread feature here! Otherwise, if the arg of createClientFeature is not a function, and 2\n // richText editors have the same feature (even if both call it, e.g. both call UploadFeature()),\n // the second richText editor here will override sanitizedClientFeatureProps of the first feature, as both richText\n // editor features share the same reference to the feature object.\n // Example: richText editor 1 and 2 both have UploadFeature. richText editor 1 calls UploadFeature() with custom fields,\n // richText editor 2 calls UploadFeature() with NO custom fields. If we don't spread feature here, richText editor 1\n // will not have any custom fields, as richText editor 2 will override the feature object.\n const newFeature: ClientFeature<any> = { ...feature }\n newFeature.sanitizedClientFeatureProps = props\n featureProviderClient.feature = newFeature\n }\n return featureProviderClient as FeatureProviderClient<any, any>\n }\n\n return featureProviderProvideClient\n}\n"],"mappings":"AA8BA,OAAO,MAAMA,mBAAA,GAK8DC,OAAA;EACzE,MAAMC,4BAAA,GAAyEC,KAAA;IAC7E,MAAMC,qBAAA,GAAkE;MACtEC,kBAAA,EAAoBF;IACtB;IAEA,IAAI,OAAOF,OAAA,KAAY,YAAY;MACjCG,qBAAA,CAAsBH,OAAO,GAAG,CAAC;QAC/BK,MAAM;QACNC,sBAAsB;QACtBC,sBAAsB;QACtBC,kBAAkB;QAClBC,KAAK;QACLC,gBAAgB;QAChBC,UAAU;QACVC;MAAuB,CACxB;QACC,MAAMC,QAAA,GAAWb,OAAA,CAAQ;UACvBK,MAAA;UACAC,sBAAA;UACAC,sBAAA;UACAC,kBAAA;UACAC,KAAA;UACAP,KAAA;UACAQ,gBAAA;UACAC,UAAA;UACAC;QACF;QAEA,IAAIC,QAAA,CAASC,2BAA2B,KAAK,MAAM;UACjDD,QAAA,CAASC,2BAA2B,GAAGZ,KAAA;QACzC;QAEA,OAAOW,QAAA;MACT;IACF,OAAO;MACL;MACA;MACA;MACA;MACA;MACA;MACA;MACA,MAAME,UAAA,GAAiC;QAAE,GAAGf;MAAQ;MACpDe,UAAA,CAAWD,2BAA2B,GAAGZ,KAAA;MACzCC,qBAAA,CAAsBH,OAAO,GAAGe,UAAA;IAClC;IACA,OAAOZ,qBAAA;EACT;EAEA,OAAOF,4BAAA;AACT","ignoreList":[]}