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