@payloadcms/richtext-lexical 3.13.0 → 3.14.1-canary.549a973

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/dist/exports/client/{Field-DTQOXLGX.js → Field-7ROJ5JAM.js} +2 -2
  2. package/dist/exports/client/Field-7ROJ5JAM.js.map +7 -0
  3. package/dist/exports/client/chunk-QNRPT52J.js +2 -0
  4. package/dist/exports/client/chunk-QNRPT52J.js.map +7 -0
  5. package/dist/exports/client/componentInline-TPGMZRGQ.js +2 -0
  6. package/dist/exports/client/index.js +11 -11
  7. package/dist/exports/client/index.js.map +4 -4
  8. package/dist/features/align/server/i18n.d.ts.map +1 -1
  9. package/dist/features/align/server/i18n.js +12 -0
  10. package/dist/features/align/server/i18n.js.map +1 -1
  11. package/dist/features/blockquote/server/i18n.d.ts.map +1 -1
  12. package/dist/features/blockquote/server/i18n.js +6 -0
  13. package/dist/features/blockquote/server/i18n.js.map +1 -1
  14. package/dist/features/blocks/client/componentInline/index.d.ts.map +1 -1
  15. package/dist/features/blocks/client/componentInline/index.js +9 -0
  16. package/dist/features/blocks/client/componentInline/index.js.map +1 -1
  17. package/dist/features/blocks/server/i18n.d.ts.map +1 -1
  18. package/dist/features/blocks/server/i18n.js +18 -0
  19. package/dist/features/blocks/server/i18n.js.map +1 -1
  20. package/dist/features/heading/server/i18n.d.ts.map +1 -1
  21. package/dist/features/heading/server/i18n.js +6 -0
  22. package/dist/features/heading/server/i18n.js.map +1 -1
  23. package/dist/features/horizontalRule/server/i18n.d.ts.map +1 -1
  24. package/dist/features/horizontalRule/server/i18n.js +6 -0
  25. package/dist/features/horizontalRule/server/i18n.js.map +1 -1
  26. package/dist/features/indent/client/index.js +2 -2
  27. package/dist/features/indent/client/index.js.map +1 -1
  28. package/dist/features/indent/server/i18n.d.ts.map +1 -1
  29. package/dist/features/indent/server/i18n.js +8 -0
  30. package/dist/features/indent/server/i18n.js.map +1 -1
  31. package/dist/features/link/server/i18n.d.ts.map +1 -1
  32. package/dist/features/link/server/i18n.js +8 -0
  33. package/dist/features/link/server/i18n.js.map +1 -1
  34. package/dist/features/lists/checklist/server/i18n.d.ts.map +1 -1
  35. package/dist/features/lists/checklist/server/i18n.js +6 -0
  36. package/dist/features/lists/checklist/server/i18n.js.map +1 -1
  37. package/dist/features/lists/orderedList/server/i18n.d.ts.map +1 -1
  38. package/dist/features/lists/orderedList/server/i18n.js +6 -0
  39. package/dist/features/lists/orderedList/server/i18n.js.map +1 -1
  40. package/dist/features/lists/unorderedList/server/i18n.d.ts.map +1 -1
  41. package/dist/features/lists/unorderedList/server/i18n.js +6 -0
  42. package/dist/features/lists/unorderedList/server/i18n.js.map +1 -1
  43. package/dist/features/paragraph/server/i18n.d.ts.map +1 -1
  44. package/dist/features/paragraph/server/i18n.js +8 -0
  45. package/dist/features/paragraph/server/i18n.js.map +1 -1
  46. package/dist/features/relationship/client/drawer/index.d.ts.map +1 -1
  47. package/dist/features/relationship/client/drawer/index.js +9 -30
  48. package/dist/features/relationship/client/drawer/index.js.map +1 -1
  49. package/dist/features/relationship/server/i18n.d.ts.map +1 -1
  50. package/dist/features/relationship/server/i18n.js +6 -0
  51. package/dist/features/relationship/server/i18n.js.map +1 -1
  52. package/dist/features/upload/server/i18n.d.ts.map +1 -1
  53. package/dist/features/upload/server/i18n.js +6 -0
  54. package/dist/features/upload/server/i18n.js.map +1 -1
  55. package/dist/i18n.d.ts.map +1 -1
  56. package/dist/i18n.js +12 -0
  57. package/dist/i18n.js.map +1 -1
  58. package/dist/lexical/LexicalEditor.js +0 -1
  59. package/dist/lexical/LexicalEditor.js.map +1 -1
  60. package/package.json +6 -6
  61. package/dist/exports/client/Field-DTQOXLGX.js.map +0 -7
  62. package/dist/exports/client/chunk-4J2ONJMB.js +0 -2
  63. package/dist/exports/client/chunk-4J2ONJMB.js.map +0 -7
  64. package/dist/exports/client/componentInline-B5YNOX32.js +0 -2
  65. package/dist/features/indent/client/plugins/index.d.ts +0 -3
  66. package/dist/features/indent/client/plugins/index.d.ts.map +0 -1
  67. package/dist/features/indent/client/plugins/index.js +0 -73
  68. package/dist/features/indent/client/plugins/index.js.map +0 -1
  69. /package/dist/exports/client/{componentInline-B5YNOX32.js.map → componentInline-TPGMZRGQ.js.map} +0 -0
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/features/blocks/client/componentInline/index.tsx", "../../../src/features/blocks/client/nodes/InlineBlocksNode.tsx", "../../../src/features/blocks/server/nodes/InlineBlocksNode.tsx"],
4
- "sourcesContent": ["'use client'\n\nimport React, { createContext, useCallback, useEffect, useMemo, useRef } from 'react'\nconst baseClass = 'inline-block'\n\nimport type { BlocksFieldClient, FormState } from 'payload'\n\nimport { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext'\nimport { useLexicalNodeSelection } from '@lexical/react/useLexicalNodeSelection'\nimport { mergeRegister } from '@lexical/utils'\nimport { getTranslation } from '@payloadcms/translations'\nimport {\n Button,\n Drawer,\n EditDepthProvider,\n Form,\n formatDrawerSlug,\n FormSubmit,\n RenderFields,\n ShimmerEffect,\n useDocumentInfo,\n useEditDepth,\n useServerFunctions,\n useTranslation,\n} from '@payloadcms/ui'\nimport { abortAndIgnore } from '@payloadcms/ui/shared'\nimport {\n $getNodeByKey,\n $getSelection,\n $isNodeSelection,\n CLICK_COMMAND,\n COMMAND_PRIORITY_LOW,\n KEY_BACKSPACE_COMMAND,\n KEY_DELETE_COMMAND,\n} from 'lexical'\nimport { reduceFieldsToValues } from 'payload/shared'\n\nimport './index.scss'\n\nimport { v4 as uuid } from 'uuid'\n\nimport type { InlineBlockFields } from '../../server/nodes/InlineBlocksNode.js'\n\nimport { useEditorConfigContext } from '../../../../lexical/config/client/EditorConfigProvider.js'\nimport { useLexicalDrawer } from '../../../../utilities/fieldsDrawer/useLexicalDrawer.js'\nimport { $isInlineBlockNode } from '../nodes/InlineBlocksNode.js'\n\ntype Props = {\n readonly formData: InlineBlockFields\n readonly nodeKey: string\n}\n\ntype InlineBlockComponentContextType = {\n EditButton?: React.FC\n initialState: false | FormState | undefined\n InlineBlockContainer?: React.FC<{ children: React.ReactNode }>\n Label?: React.FC\n nodeKey?: string\n RemoveButton?: React.FC\n}\n\nconst InlineBlockComponentContext = createContext<InlineBlockComponentContextType>({\n initialState: false,\n})\n\nexport const useInlineBlockComponentContext = () => React.useContext(InlineBlockComponentContext)\n\nexport const InlineBlockComponent: React.FC<Props> = (props) => {\n const { formData, nodeKey } = props\n const [editor] = useLexicalComposerContext()\n const { i18n, t } = useTranslation<object, string>()\n const {\n fieldProps: {\n featureClientSchemaMap,\n initialLexicalFormState,\n permissions,\n readOnly,\n schemaPath,\n },\n uuid: uuidFromContext,\n } = useEditorConfigContext()\n const { getFormState } = useServerFunctions()\n const editDepth = useEditDepth()\n\n const [initialState, setInitialState] = React.useState<false | FormState | undefined>(\n initialLexicalFormState?.[formData.id]?.formState,\n )\n\n const [CustomLabel, setCustomLabel] = React.useState<React.ReactNode | undefined>(\n // @ts-expect-error - vestiges of when tsconfig was not strict. Feel free to improve\n initialState?.['_components']?.customComponents?.BlockLabel,\n )\n\n const [CustomBlock, setCustomBlock] = React.useState<React.ReactNode | undefined>(\n // @ts-expect-error - vestiges of when tsconfig was not strict. Feel free to improve\n initialState?.['_components']?.customComponents?.Block,\n )\n\n const drawerSlug = formatDrawerSlug({\n slug: `lexical-inlineBlocks-create-${uuidFromContext}-${formData.id}`,\n depth: editDepth,\n })\n const { toggleDrawer } = useLexicalDrawer(drawerSlug, true)\n\n const inlineBlockElemElemRef = useRef<HTMLDivElement | null>(null)\n const [isSelected, setSelected, clearSelection] = useLexicalNodeSelection(nodeKey)\n const { id, collectionSlug, getDocPreferences, globalSlug } = useDocumentInfo()\n\n const componentMapRenderedBlockPath = `${schemaPath}.lexical_internal_feature.blocks.lexical_inline_blocks.${formData.blockType}`\n\n const clientSchemaMap = featureClientSchemaMap['blocks']\n\n const blocksField: BlocksFieldClient = clientSchemaMap[\n componentMapRenderedBlockPath\n ][0] as BlocksFieldClient\n\n const clientBlock = blocksField.blocks[0]\n\n const removeInlineBlock = useCallback(() => {\n editor.update(() => {\n $getNodeByKey(nodeKey)?.remove()\n })\n }, [editor, nodeKey])\n\n const $onDelete = useCallback(\n (event: KeyboardEvent) => {\n const deleteSelection = $getSelection()\n if (isSelected && $isNodeSelection(deleteSelection)) {\n event.preventDefault()\n editor.update(() => {\n deleteSelection.getNodes().forEach((node) => {\n if ($isInlineBlockNode(node)) {\n node.remove()\n }\n })\n })\n }\n return false\n },\n [editor, isSelected],\n )\n const onClick = useCallback(\n (payload: MouseEvent) => {\n const event = payload\n // Check if inlineBlockElemElemRef.target or anything WITHIN inlineBlockElemElemRef.target was clicked\n if (\n event.target === inlineBlockElemElemRef.current ||\n inlineBlockElemElemRef.current?.contains(event.target as Node)\n ) {\n if (event.shiftKey) {\n setSelected(!isSelected)\n } else {\n if (!isSelected) {\n clearSelection()\n setSelected(true)\n }\n }\n return true\n }\n\n return false\n },\n [isSelected, setSelected, clearSelection],\n )\n\n useEffect(() => {\n return mergeRegister(\n editor.registerCommand<MouseEvent>(CLICK_COMMAND, onClick, COMMAND_PRIORITY_LOW),\n\n editor.registerCommand(KEY_DELETE_COMMAND, $onDelete, COMMAND_PRIORITY_LOW),\n editor.registerCommand(KEY_BACKSPACE_COMMAND, $onDelete, COMMAND_PRIORITY_LOW),\n )\n }, [clearSelection, editor, isSelected, nodeKey, $onDelete, setSelected, onClick])\n\n const blockDisplayName = clientBlock?.labels?.singular\n ? getTranslation(clientBlock.labels.singular, i18n)\n : clientBlock?.slug\n\n const onChangeAbortControllerRef = useRef(new AbortController())\n const schemaFieldsPath = `${schemaPath}.lexical_internal_feature.blocks.lexical_inline_blocks.${clientBlock?.slug}.fields`\n\n // Initial state for newly created blocks\n useEffect(() => {\n const abortController = new AbortController()\n\n const awaitInitialState = async () => {\n /*\n * This will only run if a new block is created. For all existing blocks that are loaded when the document is loaded, or when the form is saved,\n * this is not run, as the lexical field RSC will fetch the state server-side and pass it to the client. That way, we avoid unnecessary client-side\n * requests. Though for newly created blocks, we need to fetch the state client-side, as the server doesn't know about the block yet.\n */\n const { state } = await getFormState({\n id,\n collectionSlug,\n data: formData,\n docPermissions: { fields: true },\n docPreferences: await getDocPreferences(),\n globalSlug,\n operation: 'update',\n renderAllFields: true,\n schemaPath: schemaFieldsPath,\n signal: abortController.signal,\n })\n\n if (state) {\n setInitialState(state)\n setCustomLabel(state['_components']?.customComponents?.BlockLabel)\n setCustomBlock(state['_components']?.customComponents?.Block)\n }\n }\n\n if (formData && !initialState) {\n void awaitInitialState()\n }\n\n return () => {\n abortAndIgnore(abortController)\n }\n }, [\n getFormState,\n schemaFieldsPath,\n id,\n formData,\n initialState,\n collectionSlug,\n globalSlug,\n getDocPreferences,\n ])\n\n /**\n * HANDLE ONCHANGE\n */\n const onChange = useCallback(\n async ({ formState: prevFormState, submit }: { formState: FormState; submit?: boolean }) => {\n abortAndIgnore(onChangeAbortControllerRef.current)\n\n const controller = new AbortController()\n onChangeAbortControllerRef.current = controller\n\n const { state } = await getFormState({\n id,\n collectionSlug,\n docPermissions: {\n fields: true,\n },\n docPreferences: await getDocPreferences(),\n formState: prevFormState,\n globalSlug,\n operation: 'update',\n renderAllFields: submit ? true : false,\n schemaPath: schemaFieldsPath,\n signal: controller.signal,\n })\n\n if (!state) {\n return prevFormState\n }\n\n if (submit) {\n setCustomLabel(state['_components']?.customComponents?.BlockLabel)\n setCustomBlock(state['_components']?.customComponents?.Block)\n }\n\n return state\n },\n [getFormState, id, collectionSlug, getDocPreferences, globalSlug, schemaFieldsPath],\n )\n // cleanup effect\n useEffect(() => {\n return () => {\n abortAndIgnore(onChangeAbortControllerRef.current)\n }\n }, [])\n\n /**\n * HANDLE FORM SUBMIT\n */\n const onFormSubmit = useCallback(\n (formState: FormState) => {\n const newData: any = reduceFieldsToValues(formState)\n newData.blockType = formData.blockType\n editor.update(() => {\n const node = $getNodeByKey(nodeKey)\n if (node && $isInlineBlockNode(node)) {\n node.setFields(newData)\n }\n })\n },\n [editor, nodeKey, formData],\n )\n\n const RemoveButton = useMemo(\n () => () => (\n <Button\n buttonStyle=\"icon-label\"\n className={`${baseClass}__removeButton`}\n disabled={readOnly}\n icon=\"x\"\n onClick={(e) => {\n e.preventDefault()\n removeInlineBlock()\n }}\n round\n size=\"small\"\n tooltip={t('lexical:blocks:inlineBlocks:remove', { label: blockDisplayName })}\n />\n ),\n [blockDisplayName, readOnly, removeInlineBlock, t],\n )\n\n const EditButton = useMemo(\n () => () => (\n <Button\n buttonStyle=\"icon-label\"\n className={`${baseClass}__editButton`}\n disabled={readOnly}\n el=\"button\"\n icon=\"edit\"\n onClick={() => {\n toggleDrawer()\n }}\n round\n size=\"small\"\n tooltip={t('lexical:blocks:inlineBlocks:edit', { label: blockDisplayName })}\n />\n ),\n [blockDisplayName, readOnly, t, toggleDrawer],\n )\n\n const InlineBlockContainer = useMemo(\n () =>\n ({ children }: { children: React.ReactNode }) => (\n <div\n className={[\n baseClass,\n baseClass + '-' + formData.blockType,\n isSelected && `${baseClass}--selected`,\n ]\n .filter(Boolean)\n .join(' ')}\n ref={inlineBlockElemElemRef}\n >\n {children}\n </div>\n ),\n [formData.blockType, isSelected],\n )\n\n const Label = useMemo(() => {\n if (CustomLabel) {\n return () => CustomLabel\n } else {\n return () => <div>{getTranslation(clientBlock.labels!.singular, i18n)}</div>\n }\n }, [CustomLabel, clientBlock.labels, i18n])\n\n return (\n <Form\n beforeSubmit={[\n async ({ formState }) => {\n // This is only called when form is submitted from drawer\n return await onChange({ formState, submit: true })\n },\n ]}\n disableValidationOnSubmit\n fields={clientBlock.fields}\n initialState={initialState || {}}\n onChange={[onChange]}\n onSubmit={(formState) => {\n onFormSubmit(formState)\n toggleDrawer()\n }}\n uuid={uuid()}\n >\n <EditDepthProvider>\n <Drawer\n className={''}\n slug={drawerSlug}\n title={t(`lexical:blocks:inlineBlocks:${formData?.id ? 'edit' : 'create'}`, {\n label: blockDisplayName ?? t('lexical:blocks:inlineBlocks:label'),\n })}\n >\n {initialState ? (\n <>\n <RenderFields\n fields={clientBlock.fields}\n forceRender\n parentIndexPath=\"\"\n parentPath=\"\" // See Blocks feature path for details as for why this is empty\n parentSchemaPath={schemaFieldsPath}\n permissions={permissions}\n readOnly={false}\n />\n <FormSubmit programmaticSubmit={true}>{t('fields:saveChanges')}</FormSubmit>\n </>\n ) : null}\n </Drawer>\n </EditDepthProvider>\n {CustomBlock ? (\n <InlineBlockComponentContext.Provider\n value={{\n EditButton,\n initialState,\n InlineBlockContainer,\n Label,\n nodeKey,\n RemoveButton,\n }}\n >\n {CustomBlock}\n </InlineBlockComponentContext.Provider>\n ) : (\n <InlineBlockContainer>\n {initialState ? <Label /> : <ShimmerEffect height=\"15px\" width=\"40px\" />}\n {editor.isEditable() ? (\n <div className={`${baseClass}__actions`}>\n <EditButton />\n <RemoveButton />\n </div>\n ) : null}\n </InlineBlockContainer>\n )}\n </Form>\n )\n}\n", "'use client'\nimport type { EditorConfig, LexicalEditor, LexicalNode } from 'lexical'\n\nimport ObjectID from 'bson-objectid'\nimport React, { type JSX } from 'react'\n\nimport type {\n InlineBlockFields,\n SerializedInlineBlockNode,\n} from '../../server/nodes/InlineBlocksNode.js'\n\nimport { ServerInlineBlockNode } from '../../server/nodes/InlineBlocksNode.js'\n\nconst InlineBlockComponent = React.lazy(() =>\n import('../componentInline/index.js').then((module) => ({\n default: module.InlineBlockComponent,\n })),\n)\n\nexport class InlineBlockNode extends ServerInlineBlockNode {\n static clone(node: ServerInlineBlockNode): ServerInlineBlockNode {\n return super.clone(node)\n }\n\n static getType(): string {\n return super.getType()\n }\n\n static importJSON(serializedNode: SerializedInlineBlockNode): InlineBlockNode {\n const node = $createInlineBlockNode(serializedNode.fields)\n return node\n }\n\n decorate(editor: LexicalEditor, config: EditorConfig): JSX.Element {\n return <InlineBlockComponent formData={this.getFields()} nodeKey={this.getKey()} />\n }\n\n exportJSON(): SerializedInlineBlockNode {\n return super.exportJSON()\n }\n}\n\nexport function $createInlineBlockNode(fields: Exclude<InlineBlockFields, 'id'>): InlineBlockNode {\n return new InlineBlockNode({\n fields: {\n ...fields,\n id: fields?.id || new ObjectID.default().toHexString(),\n },\n })\n}\n\nexport function $isInlineBlockNode(\n node: InlineBlockNode | LexicalNode | null | undefined,\n): node is InlineBlockNode {\n return node instanceof InlineBlockNode\n}\n", "import type {\n DOMConversionMap,\n DOMExportOutput,\n EditorConfig,\n LexicalEditor,\n LexicalNode,\n NodeKey,\n SerializedLexicalNode,\n Spread,\n} from 'lexical'\nimport type { JsonObject } from 'payload'\nimport type React from 'react'\nimport type { JSX } from 'react'\n\nimport ObjectID from 'bson-objectid'\nimport { DecoratorNode } from 'lexical'\n\nexport type InlineBlockFields<TInlineBlockFields extends JsonObject = JsonObject> = {\n blockType: string\n id: string\n} & TInlineBlockFields\n\nexport type SerializedInlineBlockNode<TBlockFields extends JsonObject = JsonObject> = Spread<\n {\n children?: never // required so that our typed editor state doesn't automatically add children\n fields: InlineBlockFields<TBlockFields>\n type: 'inlineBlock'\n },\n SerializedLexicalNode\n>\n\nexport class ServerInlineBlockNode extends DecoratorNode<null | React.ReactElement> {\n __fields: InlineBlockFields\n\n constructor({ fields, key }: { fields: InlineBlockFields; key?: NodeKey }) {\n super(key)\n this.__fields = fields\n }\n\n static clone(node: ServerInlineBlockNode): ServerInlineBlockNode {\n return new this({\n fields: node.__fields,\n key: node.__key,\n })\n }\n\n static getType(): string {\n return 'inlineBlock'\n }\n\n static importDOM(): DOMConversionMap<HTMLDivElement> | null {\n return {}\n }\n\n static importJSON(serializedNode: SerializedInlineBlockNode): ServerInlineBlockNode {\n const node = $createServerInlineBlockNode(serializedNode.fields)\n return node\n }\n\n static isInline(): false {\n return false\n }\n\n canIndent() {\n return true\n }\n createDOM() {\n const element = document.createElement('span')\n element.classList.add('inline-block-container')\n\n return element\n }\n\n decorate(editor: LexicalEditor, config: EditorConfig): JSX.Element | null {\n return null\n }\n\n exportDOM(): DOMExportOutput {\n const element = document.createElement('span')\n element.classList.add('inline-block-container')\n\n const text = document.createTextNode(this.getTextContent())\n element.append(text)\n return { element }\n }\n\n exportJSON(): SerializedInlineBlockNode {\n return {\n type: 'inlineBlock',\n fields: this.getFields(),\n version: 1,\n }\n }\n\n getFields(): InlineBlockFields {\n return this.getLatest().__fields\n }\n\n getTextContent(): string {\n return `Block Field`\n }\n\n isInline() {\n return true\n }\n\n setFields(fields: InlineBlockFields): void {\n const writable = this.getWritable()\n writable.__fields = fields\n }\n\n updateDOM(): boolean {\n return false\n }\n}\n\nexport function $createServerInlineBlockNode(\n fields: Exclude<InlineBlockFields, 'id'>,\n): ServerInlineBlockNode {\n return new ServerInlineBlockNode({\n fields: {\n ...fields,\n id: fields?.id || new ObjectID.default().toHexString(),\n },\n })\n}\n\nexport function $isServerInlineBlockNode(\n node: LexicalNode | null | ServerInlineBlockNode | undefined,\n): node is ServerInlineBlockNode {\n return node instanceof ServerInlineBlockNode\n}\n"],
5
- "mappings": "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",
6
- "names": ["React", "createContext", "useCallback", "useEffect", "useMemo", "useRef", "useLexicalComposerContext", "useLexicalNodeSelection", "mergeRegister", "getTranslation", "Button", "Drawer", "EditDepthProvider", "Form", "formatDrawerSlug", "FormSubmit", "RenderFields", "ShimmerEffect", "useDocumentInfo", "useEditDepth", "useServerFunctions", "useTranslation", "abortAndIgnore", "$getNodeByKey", "$getSelection", "$isNodeSelection", "CLICK_COMMAND", "COMMAND_PRIORITY_LOW", "KEY_BACKSPACE_COMMAND", "KEY_DELETE_COMMAND", "reduceFieldsToValues", "v4", "uuid", "ObjectID", "React", "ObjectID", "DecoratorNode", "ServerInlineBlockNode", "__fields", "constructor", "fields", "key", "clone", "node", "__key", "getType", "importDOM", "importJSON", "serializedNode", "$createServerInlineBlockNode", "isInline", "canIndent", "createDOM", "element", "document", "createElement", "classList", "add", "decorate", "editor", "config", "exportDOM", "text", "createTextNode", "getTextContent", "append", "exportJSON", "type", "getFields", "version", "getLatest", "setFields", "writable", "getWritable", "updateDOM", "id", "default", "toHexString", "InlineBlockComponent", "React", "lazy", "then", "module", "default", "InlineBlockNode", "ServerInlineBlockNode", "clone", "node", "getType", "importJSON", "serializedNode", "$createInlineBlockNode", "fields", "decorate", "editor", "config", "_jsx", "formData", "getFields", "nodeKey", "getKey", "exportJSON", "id", "ObjectID", "toHexString", "$isInlineBlockNode", "baseClass", "InlineBlockComponentContext", "createContext", "initialState", "useInlineBlockComponentContext", "React", "useContext", "InlineBlockComponent", "props", "formData", "nodeKey", "editor", "useLexicalComposerContext", "i18n", "t", "useTranslation", "fieldProps", "featureClientSchemaMap", "initialLexicalFormState", "permissions", "readOnly", "schemaPath", "uuid", "uuidFromContext", "useEditorConfigContext", "getFormState", "useServerFunctions", "editDepth", "useEditDepth", "setInitialState", "useState", "id", "formState", "CustomLabel", "setCustomLabel", "customComponents", "BlockLabel", "CustomBlock", "setCustomBlock", "Block", "drawerSlug", "formatDrawerSlug", "slug", "depth", "toggleDrawer", "useLexicalDrawer", "inlineBlockElemElemRef", "useRef", "isSelected", "setSelected", "clearSelection", "useLexicalNodeSelection", "collectionSlug", "getDocPreferences", "globalSlug", "useDocumentInfo", "componentMapRenderedBlockPath", "blockType", "clientBlock", "blocks", "removeInlineBlock", "useCallback", "update", "$getNodeByKey", "remove", "$onDelete", "event", "deleteSelection", "$getSelection", "$isNodeSelection", "preventDefault", "getNodes", "forEach", "node", "$isInlineBlockNode", "onClick", "payload", "target", "current", "contains", "shiftKey", "useEffect", "mergeRegister", "registerCommand", "CLICK_COMMAND", "COMMAND_PRIORITY_LOW", "KEY_DELETE_COMMAND", "KEY_BACKSPACE_COMMAND", "blockDisplayName", "labels", "singular", "getTranslation", "onChangeAbortControllerRef", "AbortController", "schemaFieldsPath", "abortController", "state", "data", "docPermissions", "fields", "docPreferences", "operation", "renderAllFields", "signal", "abortAndIgnore", "onChange", "prevFormState", "submit", "controller", "onFormSubmit", "newData", "reduceFieldsToValues", "setFields", "RemoveButton", "useMemo", "_jsx", "Button", "buttonStyle", "className", "disabled", "icon", "e", "round", "size", "tooltip", "label", "EditButton", "el", "InlineBlockContainer", "children", "filter", "Boolean", "join", "ref", "Label", "_jsxs", "Form", "beforeSubmit", "disableValidationOnSubmit", "onSubmit", "EditDepthProvider", "Drawer", "title", "_Fragment", "RenderFields", "forceRender", "parentIndexPath", "parentPath", "parentSchemaPath", "FormSubmit", "programmaticSubmit", "Provider", "value", "ShimmerEffect", "height", "width", "isEditable"]
7
- }
@@ -1,2 +0,0 @@
1
- "use client";import{a,b}from"./chunk-4J2ONJMB.js";import"./chunk-INBEEENE.js";import"./chunk-CUIBIFW2.js";export{b as InlineBlockComponent,a as useInlineBlockComponentContext};
2
- //# sourceMappingURL=componentInline-B5YNOX32.js.map
@@ -1,3 +0,0 @@
1
- import type { PluginComponent } from '../../../typesClient.js';
2
- export declare const IndentPlugin: PluginComponent<undefined>;
3
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/features/indent/client/plugins/index.tsx"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AAE9D,eAAO,MAAM,YAAY,EAAE,eAAe,CAAC,SAAS,CAkDnD,CAAA"}
@@ -1,73 +0,0 @@
1
- 'use client';
2
-
3
- import { c as _c } from "react/compiler-runtime";
4
- import { jsx as _jsx } from "react/jsx-runtime";
5
- import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext.js';
6
- import { TabIndentationPlugin } from '@lexical/react/LexicalTabIndentationPlugin';
7
- import { mergeRegister } from '@lexical/utils';
8
- import { COMMAND_PRIORITY_NORMAL, FOCUS_COMMAND, KEY_ESCAPE_COMMAND } from 'lexical';
9
- import { useEffect, useState } from 'react';
10
- export const IndentPlugin = () => {
11
- const $ = _c(8);
12
- const [editor] = useLexicalComposerContext();
13
- const [firefoxFlag, setFirefoxFlag] = useState(false);
14
- let t0;
15
- let t1;
16
- if ($[0] !== editor) {
17
- t0 = () => mergeRegister(editor.registerCommand(FOCUS_COMMAND, () => {
18
- setFirefoxFlag(false);
19
- return true;
20
- }, COMMAND_PRIORITY_NORMAL), editor.registerCommand(KEY_ESCAPE_COMMAND, () => {
21
- setFirefoxFlag(true);
22
- editor.getRootElement()?.blur();
23
- return true;
24
- }, COMMAND_PRIORITY_NORMAL));
25
- t1 = [editor, setFirefoxFlag];
26
- $[0] = editor;
27
- $[1] = t0;
28
- $[2] = t1;
29
- } else {
30
- t0 = $[1];
31
- t1 = $[2];
32
- }
33
- useEffect(t0, t1);
34
- let t2;
35
- let t3;
36
- if ($[3] !== editor || $[4] !== firefoxFlag) {
37
- t2 = () => {
38
- if (!firefoxFlag) {
39
- return;
40
- }
41
- const handleKeyDown = e => {
42
- if (!["Escape", "Shift"].includes(e.key)) {
43
- setFirefoxFlag(false);
44
- }
45
- if (e.shiftKey && e.key === "Tab") {
46
- editor.getRootElement()?.parentElement?.focus();
47
- }
48
- };
49
- document.addEventListener("keydown", handleKeyDown);
50
- return () => {
51
- document.removeEventListener("keydown", handleKeyDown);
52
- };
53
- };
54
- t3 = [editor, firefoxFlag];
55
- $[3] = editor;
56
- $[4] = firefoxFlag;
57
- $[5] = t2;
58
- $[6] = t3;
59
- } else {
60
- t2 = $[5];
61
- t3 = $[6];
62
- }
63
- useEffect(t2, t3);
64
- let t4;
65
- if ($[7] === Symbol.for("react.memo_cache_sentinel")) {
66
- t4 = _jsx(TabIndentationPlugin, {});
67
- $[7] = t4;
68
- } else {
69
- t4 = $[7];
70
- }
71
- return t4;
72
- };
73
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","names":["c","_c","useLexicalComposerContext","TabIndentationPlugin","mergeRegister","COMMAND_PRIORITY_NORMAL","FOCUS_COMMAND","KEY_ESCAPE_COMMAND","useEffect","useState","IndentPlugin","$","editor","firefoxFlag","setFirefoxFlag","t0","t1","registerCommand","getRootElement","blur","t2","t3","handleKeyDown","e","includes","key","shiftKey","parentElement","focus","document","addEventListener","removeEventListener","t4","Symbol","for","_jsx"],"sources":["../../../../../src/features/indent/client/plugins/index.tsx"],"sourcesContent":["'use client'\n\nimport { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext.js'\nimport { TabIndentationPlugin } from '@lexical/react/LexicalTabIndentationPlugin'\nimport { mergeRegister } from '@lexical/utils'\nimport { COMMAND_PRIORITY_NORMAL, FOCUS_COMMAND, KEY_ESCAPE_COMMAND } from 'lexical'\nimport { useEffect, useState } from 'react'\n\nimport type { PluginComponent } from '../../../typesClient.js'\n\nexport const IndentPlugin: PluginComponent<undefined> = () => {\n const [editor] = useLexicalComposerContext()\n\n const [firefoxFlag, setFirefoxFlag] = useState<boolean>(false)\n\n useEffect(() => {\n return mergeRegister(\n editor.registerCommand<MouseEvent>(\n FOCUS_COMMAND,\n () => {\n setFirefoxFlag(false)\n return true\n },\n COMMAND_PRIORITY_NORMAL,\n ),\n editor.registerCommand(\n KEY_ESCAPE_COMMAND,\n () => {\n setFirefoxFlag(true)\n editor.getRootElement()?.blur()\n return true\n },\n COMMAND_PRIORITY_NORMAL,\n ),\n )\n }, [editor, setFirefoxFlag])\n\n useEffect(() => {\n if (!firefoxFlag) {\n return\n }\n\n const handleKeyDown = (e: KeyboardEvent) => {\n if (!['Escape', 'Shift'].includes(e.key)) {\n setFirefoxFlag(false)\n }\n // Pressing Shift+Tab after blurring refocuses the editor in Firefox\n // we focus parent to allow exiting the editor\n if (e.shiftKey && e.key === 'Tab') {\n editor.getRootElement()?.parentElement?.focus()\n }\n }\n\n document.addEventListener('keydown', handleKeyDown)\n return () => {\n document.removeEventListener('keydown', handleKeyDown)\n }\n }, [editor, firefoxFlag])\n\n return <TabIndentationPlugin />\n}\n"],"mappings":"AAAA;;AAAA,SAAAA,CAAA,IAAAC,EAAA;;AAEA,SAASC,yBAAyB,QAAQ;AAC1C,SAASC,oBAAoB,QAAQ;AACrC,SAASC,aAAa,QAAQ;AAC9B,SAASC,uBAAuB,EAAEC,aAAa,EAAEC,kBAAkB,QAAQ;AAC3E,SAASC,SAAS,EAAEC,QAAQ,QAAQ;AAIpC,OAAO,MAAMC,YAAA,GAA2CA,CAAA;EAAA,MAAAC,CAAA,GAAAV,EAAA;EACtD,OAAAW,MAAA,IAAiBV,yBAAA;EAEjB,OAAAW,WAAA,EAAAC,cAAA,IAAsCL,QAAA,MAAkB;EAAA,IAAAM,EAAA;EAAA,IAAAC,EAAA;EAAA,IAAAL,CAAA,QAAAC,MAAA;IAE9CG,EAAA,GAAAA,CAAA,KACDX,aAAA,CACLQ,MAAA,CAAAK,eAAA,CAAAX,aAAA;MAGIQ,cAAA,MAAe;MAAA;IAAA,GAAAT,uBAGjB,GAEFO,MAAA,CAAAK,eAAA,CAAAV,kBAAA;MAGIO,cAAA,KAAe;MACfF,MAAA,CAAAM,cAAA,CAAqB,GAAAC,IAAA;MAAA;IAAA,GAAAd,uBAGvB;IAGHW,EAAA,IAACJ,MAAA,EAAQE,cAAA;IAAeH,CAAA,MAAAC,MAAA;IAAAD,CAAA,MAAAI,EAAA;IAAAJ,CAAA,MAAAK,EAAA;EAAA;IAAAD,EAAA,GAAAJ,CAAA;IAAAK,EAAA,GAAAL,CAAA;EAAA;EApB3BH,SAAA,CAAUO,EAoBV,EAAGC,EAAwB;EAAA,IAAAI,EAAA;EAAA,IAAAC,EAAA;EAAA,IAAAV,CAAA,QAAAC,MAAA,IAAAD,CAAA,QAAAE,WAAA;IAEjBO,EAAA,GAAAA,CAAA;MAAA,KACHP,WAAA;QAAA;MAAA;MAIL,MAAAS,aAAA,GAAAC,CAAA;QAAA,KACO,CAAC,UAAU,SAAAC,QAAA,CAAkBD,CAAA,CAAAE,GAAK;UACrCX,cAAA,MAAe;QAAA;QAAA,IAIbS,CAAA,CAAAG,QAAA,IAAcH,CAAA,CAAAE,GAAA,KAAU;UAC1Bb,MAAA,CAAAM,cAAA,CAAqB,GAAAS,aAAA,EAAAC,KAAA;QAAA;MAAA;MAIzBC,QAAA,CAAAC,gBAAA,CAA0B,WAAWR,aAAA;MAAA;QAEnCO,QAAA,CAAAE,mBAAA,CAA6B,WAAWT,aAAA;MAAA;IAAA;IAEzCD,EAAA,IAACT,MAAA,EAAQC,WAAA;IAAYF,CAAA,MAAAC,MAAA;IAAAD,CAAA,MAAAE,WAAA;IAAAF,CAAA,MAAAS,EAAA;IAAAT,CAAA,MAAAU,EAAA;EAAA;IAAAD,EAAA,GAAAT,CAAA;IAAAU,EAAA,GAAAV,CAAA;EAAA;EApBxBH,SAAA,CAAUY,EAoBV,EAAGC,EAAqB;EAAA,IAAAW,EAAA;EAAA,IAAArB,CAAA,QAAAsB,MAAA,CAAAC,GAAA;IAEjBF,EAAA,GAAAG,IAAA,CAAAhC,oBAAA,IAAC;IAAAQ,CAAA,MAAAqB,EAAA;EAAA;IAAAA,EAAA,GAAArB,CAAA;EAAA;EAAA,OAADqB,EAAC;AAAA,CACV","ignoreList":[]}