@payloadcms/richtext-lexical
Advanced tools
Comparing version 0.1.6 to 0.1.7
@@ -12,4 +12,9 @@ import type { Block } from 'payload/types'; | ||
}; | ||
/** | ||
* The actual content of the Block. This should be INSIDE a Form component, | ||
* scoped to the block. All format operations in here are thus scoped to the block's form, and | ||
* not the whole document. | ||
*/ | ||
export declare const BlockContent: React.FC<Props>; | ||
export {}; | ||
//# sourceMappingURL=BlockContent.d.ts.map |
@@ -189,2 +189,2 @@ "use strict"; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/field/features/Blocks/component/BlockContent.tsx"],"sourcesContent":["import type { Block, Data, Fields } from 'payload/types'\n\nimport { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext'\nimport { $getNodeByKey } from 'lexical'\nimport { Button, ErrorPill, Pill } from 'payload/components'\nimport { Collapsible } from 'payload/components/elements'\nimport { SectionTitle } from 'payload/components/fields/Blocks'\nimport { RenderFields, createNestedFieldPath, useFormSubmitted } from 'payload/components/forms'\nimport { useDocumentInfo } from 'payload/components/utilities'\nimport { getTranslation } from 'payload/utilities'\nimport React, { useCallback, useEffect } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { FieldProps } from '../../../../types'\nimport type { BlockFields, BlockNode } from '../nodes/BlocksNode'\n\nimport { FormSavePlugin } from './FormSavePlugin'\n\ntype Props = {\n  baseClass: string\n  block: Block\n  field: FieldProps\n  fields: BlockFields\n  nodeKey: string\n}\n\nexport const BlockContent: React.FC<Props> = (props) => {\n  const { baseClass, block, field, fields, nodeKey } = props\n  const { i18n } = useTranslation()\n  const [editor] = useLexicalComposerContext()\n  // Used for saving collapsed to preferences (and gettin' it from there again)\n  // Remember, these preferences are scoped to the whole document, not just this form. This\n  // is important to consider for the data path used in setDocFieldPreferences\n  const { getDocPreferences, setDocFieldPreferences } = useDocumentInfo()\n\n  const [collapsed, setCollapsed] = React.useState<boolean>(() => {\n    let initialState = false\n\n    getDocPreferences().then((currentDocPreferences) => {\n      const currentFieldPreferences = currentDocPreferences?.fields[field.name]\n\n      const collapsedMap: { [key: string]: boolean } = currentFieldPreferences?.collapsed\n\n      if (collapsedMap && collapsedMap[fields.data.id] !== undefined) {\n        setCollapsed(collapsedMap[fields.data.id])\n        initialState = collapsedMap[fields.data.id]\n      }\n    })\n    return initialState\n  })\n  const hasSubmitted = useFormSubmitted()\n\n  const [errorCount, setErrorCount] = React.useState(0)\n\n  const fieldHasErrors = hasSubmitted && errorCount > 0\n\n  const classNames = [\n    `${baseClass}__row`,\n    fieldHasErrors ? `${baseClass}__row--has-errors` : `${baseClass}__row--no-errors`,\n  ]\n    .filter(Boolean)\n    .join(' ')\n\n  const path = '' as const\n\n  const onFormChange = useCallback(\n    ({ fields: formFields, formData }: { fields: Fields; formData: Data }) => {\n      editor.update(() => {\n        const node: BlockNode = $getNodeByKey(nodeKey)\n        if (node) {\n          node.setFields({\n            data: formData as any,\n          })\n        }\n      })\n\n      // update error count\n      if (hasSubmitted) {\n        let rowErrorCount = 0\n        for (const formField of Object.values(formFields)) {\n          if (formField?.valid === false) {\n            rowErrorCount++\n          }\n        }\n        setErrorCount(rowErrorCount)\n      }\n    },\n    [editor, nodeKey, hasSubmitted],\n  )\n\n  const onCollapsedChange = useCallback(() => {\n    getDocPreferences().then((currentDocPreferences) => {\n      const currentFieldPreferences = currentDocPreferences?.fields[field.name]\n\n      const collapsedMap: { [key: string]: boolean } = currentFieldPreferences?.collapsed\n\n      const newCollapsed: { [key: string]: boolean } =\n        collapsedMap && collapsedMap?.size ? collapsedMap : {}\n\n      newCollapsed[fields.data.id] = !collapsed\n\n      setDocFieldPreferences(field.name, {\n        collapsed: newCollapsed,\n      })\n    })\n  }, [collapsed, getDocPreferences, field.name, setDocFieldPreferences, fields.data.id])\n\n  const removeBlock = useCallback(() => {\n    editor.update(() => {\n      $getNodeByKey(nodeKey).remove()\n    })\n  }, [editor, nodeKey])\n\n  return (\n    <React.Fragment>\n      <Collapsible\n        className={classNames}\n        collapsed={collapsed}\n        collapsibleStyle={fieldHasErrors ? 'error' : 'default'}\n        header={\n          <div className={`${baseClass}__block-header`}>\n            <div>\n              <Pill\n                className={`${baseClass}__block-pill ${baseClass}__block-pill-${fields?.data?.blockType}`}\n                pillStyle=\"white\"\n              >\n                {getTranslation(block.labels.singular, i18n)}\n              </Pill>\n              <SectionTitle path={`${path}blockName`} readOnly={field?.admin?.readOnly} />\n              {fieldHasErrors && <ErrorPill count={errorCount} withMessage />}\n            </div>\n            {editor.isEditable() && (\n              <Button\n                buttonStyle=\"icon-label\"\n                className={`${baseClass}__removeButton`}\n                disabled={field?.admin?.readOnly}\n                icon=\"x\"\n                onClick={(e) => {\n                  e.preventDefault()\n                  removeBlock()\n                }}\n                round\n                tooltip=\"Remove Block\"\n              />\n            )}\n          </div>\n        }\n        key={0}\n        onToggle={(collapsed) => {\n          setCollapsed(collapsed)\n          onCollapsedChange()\n        }}\n      >\n        <RenderFields\n          className={`${baseClass}__fields`}\n          fieldSchema={block.fields.map((field) => ({\n            ...field,\n            path: createNestedFieldPath(null, field),\n          }))}\n          fieldTypes={field.fieldTypes}\n          margins=\"small\"\n          permissions={field.permissions?.blocks?.[fields?.data?.blockType]?.fields}\n          readOnly={field.admin.readOnly}\n        />\n      </Collapsible>\n\n      <FormSavePlugin\n        fieldSchema={block.fields.map((field) => ({\n          ...field,\n          path: createNestedFieldPath(null, field),\n        }))}\n        onChange={onFormChange}\n      />\n    </React.Fragment>\n  )\n}\n"],"names":["BlockContent","props","baseClass","block","field","fields","nodeKey","i18n","useTranslation","editor","useLexicalComposerContext","getDocPreferences","setDocFieldPreferences","useDocumentInfo","collapsed","setCollapsed","React","useState","initialState","then","currentDocPreferences","currentFieldPreferences","name","collapsedMap","data","id","undefined","hasSubmitted","useFormSubmitted","errorCount","setErrorCount","fieldHasErrors","classNames","filter","Boolean","join","path","onFormChange","useCallback","formFields","formData","update","node","$getNodeByKey","setFields","rowErrorCount","formField","Object","values","valid","onCollapsedChange","newCollapsed","size","removeBlock","remove","Fragment","Collapsible","className","collapsibleStyle","header","div","Pill","blockType","pillStyle","getTranslation","labels","singular","SectionTitle","readOnly","admin","ErrorPill","count","withMessage","isEditable","Button","buttonStyle","disabled","icon","onClick","e","preventDefault","round","tooltip","key","onToggle","RenderFields","fieldSchema","map","createNestedFieldPath","fieldTypes","margins","permissions","blocks","FormSavePlugin","onChange"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/field/features/Blocks/component/BlockContent.tsx"],"sourcesContent":["import type { Block, Data, Fields } from 'payload/types'\n\nimport { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext'\nimport { $getNodeByKey } from 'lexical'\nimport { Button, ErrorPill, Pill } from 'payload/components'\nimport { Collapsible } from 'payload/components/elements'\nimport { SectionTitle } from 'payload/components/fields/Blocks'\nimport { RenderFields, createNestedFieldPath, useFormSubmitted } from 'payload/components/forms'\nimport { useDocumentInfo } from 'payload/components/utilities'\nimport { getTranslation } from 'payload/utilities'\nimport React, { useCallback, useEffect } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { FieldProps } from '../../../../types'\nimport type { BlockFields, BlockNode } from '../nodes/BlocksNode'\n\nimport { FormSavePlugin } from './FormSavePlugin'\n\ntype Props = {\n  baseClass: string\n  block: Block\n  field: FieldProps\n  fields: BlockFields\n  nodeKey: string\n}\n\n/**\n * The actual content of the Block. This should be INSIDE a Form component,\n * scoped to the block. All format operations in here are thus scoped to the block's form, and\n * not the whole document.\n */\nexport const BlockContent: React.FC<Props> = (props) => {\n  const { baseClass, block, field, fields, nodeKey } = props\n  const { i18n } = useTranslation()\n  const [editor] = useLexicalComposerContext()\n  // Used for saving collapsed to preferences (and gettin' it from there again)\n  // Remember, these preferences are scoped to the whole document, not just this form. This\n  // is important to consider for the data path used in setDocFieldPreferences\n  const { getDocPreferences, setDocFieldPreferences } = useDocumentInfo()\n\n  const [collapsed, setCollapsed] = React.useState<boolean>(() => {\n    let initialState = false\n\n    getDocPreferences().then((currentDocPreferences) => {\n      const currentFieldPreferences = currentDocPreferences?.fields[field.name]\n\n      const collapsedMap: { [key: string]: boolean } = currentFieldPreferences?.collapsed\n\n      if (collapsedMap && collapsedMap[fields.data.id] !== undefined) {\n        setCollapsed(collapsedMap[fields.data.id])\n        initialState = collapsedMap[fields.data.id]\n      }\n    })\n    return initialState\n  })\n  const hasSubmitted = useFormSubmitted()\n\n  const [errorCount, setErrorCount] = React.useState(0)\n\n  const fieldHasErrors = hasSubmitted && errorCount > 0\n\n  const classNames = [\n    `${baseClass}__row`,\n    fieldHasErrors ? `${baseClass}__row--has-errors` : `${baseClass}__row--no-errors`,\n  ]\n    .filter(Boolean)\n    .join(' ')\n\n  const path = '' as const\n\n  const onFormChange = useCallback(\n    ({ fields: formFields, formData }: { fields: Fields; formData: Data }) => {\n      editor.update(() => {\n        const node: BlockNode = $getNodeByKey(nodeKey)\n        if (node) {\n          node.setFields({\n            data: formData as any,\n          })\n        }\n      })\n\n      // update error count\n      if (hasSubmitted) {\n        let rowErrorCount = 0\n        for (const formField of Object.values(formFields)) {\n          if (formField?.valid === false) {\n            rowErrorCount++\n          }\n        }\n        setErrorCount(rowErrorCount)\n      }\n    },\n    [editor, nodeKey, hasSubmitted],\n  )\n\n  const onCollapsedChange = useCallback(() => {\n    getDocPreferences().then((currentDocPreferences) => {\n      const currentFieldPreferences = currentDocPreferences?.fields[field.name]\n\n      const collapsedMap: { [key: string]: boolean } = currentFieldPreferences?.collapsed\n\n      const newCollapsed: { [key: string]: boolean } =\n        collapsedMap && collapsedMap?.size ? collapsedMap : {}\n\n      newCollapsed[fields.data.id] = !collapsed\n\n      setDocFieldPreferences(field.name, {\n        collapsed: newCollapsed,\n      })\n    })\n  }, [collapsed, getDocPreferences, field.name, setDocFieldPreferences, fields.data.id])\n\n  const removeBlock = useCallback(() => {\n    editor.update(() => {\n      $getNodeByKey(nodeKey).remove()\n    })\n  }, [editor, nodeKey])\n\n  return (\n    <React.Fragment>\n      <Collapsible\n        className={classNames}\n        collapsed={collapsed}\n        collapsibleStyle={fieldHasErrors ? 'error' : 'default'}\n        header={\n          <div className={`${baseClass}__block-header`}>\n            <div>\n              <Pill\n                className={`${baseClass}__block-pill ${baseClass}__block-pill-${fields?.data?.blockType}`}\n                pillStyle=\"white\"\n              >\n                {getTranslation(block.labels.singular, i18n)}\n              </Pill>\n              <SectionTitle path={`${path}blockName`} readOnly={field?.admin?.readOnly} />\n              {fieldHasErrors && <ErrorPill count={errorCount} withMessage />}\n            </div>\n            {editor.isEditable() && (\n              <Button\n                buttonStyle=\"icon-label\"\n                className={`${baseClass}__removeButton`}\n                disabled={field?.admin?.readOnly}\n                icon=\"x\"\n                onClick={(e) => {\n                  e.preventDefault()\n                  removeBlock()\n                }}\n                round\n                tooltip=\"Remove Block\"\n              />\n            )}\n          </div>\n        }\n        key={0}\n        onToggle={(collapsed) => {\n          setCollapsed(collapsed)\n          onCollapsedChange()\n        }}\n      >\n        <RenderFields\n          className={`${baseClass}__fields`}\n          fieldSchema={block.fields.map((field) => ({\n            ...field,\n            path: createNestedFieldPath(null, field),\n          }))}\n          fieldTypes={field.fieldTypes}\n          margins=\"small\"\n          permissions={field.permissions?.blocks?.[fields?.data?.blockType]?.fields}\n          readOnly={field.admin.readOnly}\n        />\n      </Collapsible>\n\n      <FormSavePlugin\n        fieldSchema={block.fields.map((field) => ({\n          ...field,\n          path: createNestedFieldPath(null, field),\n        }))}\n        onChange={onFormChange}\n      />\n    </React.Fragment>\n  )\n}\n"],"names":["BlockContent","props","baseClass","block","field","fields","nodeKey","i18n","useTranslation","editor","useLexicalComposerContext","getDocPreferences","setDocFieldPreferences","useDocumentInfo","collapsed","setCollapsed","React","useState","initialState","then","currentDocPreferences","currentFieldPreferences","name","collapsedMap","data","id","undefined","hasSubmitted","useFormSubmitted","errorCount","setErrorCount","fieldHasErrors","classNames","filter","Boolean","join","path","onFormChange","useCallback","formFields","formData","update","node","$getNodeByKey","setFields","rowErrorCount","formField","Object","values","valid","onCollapsedChange","newCollapsed","size","removeBlock","remove","Fragment","Collapsible","className","collapsibleStyle","header","div","Pill","blockType","pillStyle","getTranslation","labels","singular","SectionTitle","readOnly","admin","ErrorPill","count","withMessage","isEditable","Button","buttonStyle","disabled","icon","onClick","e","preventDefault","round","tooltip","key","onToggle","RenderFields","fieldSchema","map","createNestedFieldPath","fieldTypes","margins","permissions","blocks","FormSavePlugin","onChange"],"mappings":"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"} |
@@ -15,2 +15,3 @@ "use strict"; | ||
const _config = require("payload/config"); | ||
const _reacti18next = require("react-i18next"); | ||
const _EditorConfigProvider = require("../../../lexical/config/EditorConfigProvider"); | ||
@@ -72,8 +73,46 @@ const _BlockContent = require("./BlockContent"); | ||
}); | ||
const initialDataRef = _react.default.useRef((0, _forms.buildInitialState)(fields.data || {})) // Store initial value in a ref, so it doesn't change on re-render and only gets initialized once | ||
const initialStateRef = _react.default.useRef((0, _forms.buildInitialState)(fields.data || {})) // Store initial value in a ref, so it doesn't change on re-render and only gets initialized once | ||
; | ||
const config = (0, _utilities.useConfig)(); | ||
const { t } = (0, _reacti18next.useTranslation)('general'); | ||
const { code: locale } = (0, _utilities.useLocale)(); | ||
const { getDocPreferences } = (0, _utilities.useDocumentInfo)(); | ||
// initialState State | ||
const [initialState, setInitialState] = _react.default.useState(null); | ||
(0, _react.useEffect)(()=>{ | ||
async function buildInitialState() { | ||
const preferences = await getDocPreferences(); | ||
const stateFromSchema = await (0, _utilities.buildStateFromSchema)({ | ||
config, | ||
data: fields.data, | ||
fieldSchema: block.fields, | ||
locale, | ||
operation: 'update', | ||
preferences, | ||
t | ||
}); | ||
// We have to merge the output of buildInitialState (above this useEffect) with the output of buildStateFromSchema. | ||
// That's because the output of buildInitialState provides important properties necessary for THIS block, | ||
// like blockName, blockType and id, while buildStateFromSchema provides the correct output of this block's data, | ||
// e.g. if this block has a sub-block (like the `rows` property) | ||
setInitialState({ | ||
...initialStateRef?.current, | ||
...stateFromSchema | ||
}); | ||
} | ||
void buildInitialState(); | ||
}, [ | ||
setInitialState, | ||
config, | ||
block, | ||
locale, | ||
getDocPreferences, | ||
t | ||
]) // do not add fields here, it causes an endless loop | ||
; | ||
// Memoized Form JSX | ||
const formContent = (0, _react.useMemo)(()=>{ | ||
return block && /*#__PURE__*/ _react.default.createElement(_forms.Form, { | ||
initialState: initialDataRef?.current, | ||
return block && initialState && /*#__PURE__*/ _react.default.createElement(_forms.Form, { | ||
fields: block.fields, | ||
initialState: initialState, | ||
submitted: submitted | ||
@@ -91,3 +130,4 @@ }, /*#__PURE__*/ _react.default.createElement(_BlockContent.BlockContent, { | ||
nodeKey, | ||
submitted | ||
submitted, | ||
initialState | ||
]); | ||
@@ -99,2 +139,2 @@ return /*#__PURE__*/ _react.default.createElement("div", { | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9maWVsZC9mZWF0dXJlcy9CbG9ja3MvY29tcG9uZW50L2luZGV4LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0eXBlIEVsZW1lbnRGb3JtYXRUeXBlIH0gZnJvbSAnbGV4aWNhbCdcbmltcG9ydCB7IEZvcm0sIGJ1aWxkSW5pdGlhbFN0YXRlLCB1c2VGb3JtU3VibWl0dGVkIH0gZnJvbSAncGF5bG9hZC9jb21wb25lbnRzL2Zvcm1zJ1xuaW1wb3J0IFJlYWN0LCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcblxuaW1wb3J0IHsgdHlwZSBCbG9ja0ZpZWxkcyB9IGZyb20gJy4uL25vZGVzL0Jsb2Nrc05vZGUnXG5jb25zdCBiYXNlQ2xhc3MgPSAnbGV4aWNhbC1ibG9jaydcblxuaW1wb3J0IHR5cGUgeyBEYXRhIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgdXNlQ29uZmlnIH0gZnJvbSAncGF5bG9hZC9jb21wb25lbnRzL3V0aWxpdGllcydcbmltcG9ydCB7IHNhbml0aXplRmllbGRzIH0gZnJvbSAncGF5bG9hZC9jb25maWcnXG5cbmltcG9ydCB0eXBlIHsgQmxvY2tzRmVhdHVyZVByb3BzIH0gZnJvbSAnLi4nXG5cbmltcG9ydCB7IHVzZUVkaXRvckNvbmZpZ0NvbnRleHQgfSBmcm9tICcuLi8uLi8uLi9sZXhpY2FsL2NvbmZpZy9FZGl0b3JDb25maWdQcm92aWRlcidcbmltcG9ydCB7IEJsb2NrQ29udGVudCB9IGZyb20gJy4vQmxvY2tDb250ZW50J1xuaW1wb3J0ICcuL2luZGV4LnNjc3MnXG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBmaWVsZHM6IEJsb2NrRmllbGRzXG4gIGZvcm1hdD86IEVsZW1lbnRGb3JtYXRUeXBlXG4gIG5vZGVLZXk/OiBzdHJpbmdcbn1cblxuZXhwb3J0IGNvbnN0IEJsb2NrQ29tcG9uZW50OiBSZWFjdC5GQzxQcm9wcz4gPSAocHJvcHMpID0+IHtcbiAgY29uc3QgeyBjaGlsZHJlbiwgY2xhc3NOYW1lLCBmaWVsZHMsIGZvcm1hdCwgbm9kZUtleSB9ID0gcHJvcHNcbiAgY29uc3QgcGF5bG9hZENvbmZpZyA9IHVzZUNvbmZpZygpXG4gIGNvbnN0IHN1Ym1pdHRlZCA9IHVzZUZvcm1TdWJtaXR0ZWQoKVxuXG4gIGNvbnN0IHsgZWRpdG9yQ29uZmlnLCBmaWVsZCB9ID0gdXNlRWRpdG9yQ29uZmlnQ29udGV4dCgpXG5cbiAgY29uc3QgYmxvY2sgPSAoXG4gICAgZWRpdG9yQ29uZmlnPy5yZXNvbHZlZEZlYXR1cmVNYXA/LmdldCgnYmxvY2tzJyk/LnByb3BzIGFzIEJsb2Nrc0ZlYXR1cmVQcm9wc1xuICApPy5ibG9ja3M/LmZpbmQoKGJsb2NrKSA9PiBibG9jay5zbHVnID09PSBmaWVsZHM/LmRhdGE/LmJsb2NrVHlwZSlcblxuICAvLyBTYW5pdGl6ZSBibG9jaydzIGZpZWxkcyBoZXJlLiBUaGlzIGlzIGRvbmUgaGVyZSBhbmQgbm90IGluIHRoZSBmZWF0dXJlLCBiZWNhdXNlIHRoZSBwYXlsb2FkIGNvbmZpZyBpcyBhdmFpbGFibGUgaGVyZVxuICBjb25zdCB2YWxpZFJlbGF0aW9uc2hpcHMgPSBwYXlsb2FkQ29uZmlnLmNvbGxlY3Rpb25zLm1hcCgoYykgPT4gYy5zbHVnKSB8fCBbXVxuICBibG9jay5maWVsZHMgPSBzYW5pdGl6ZUZpZWxkcyh7XG4gICAgY29uZmlnOiBwYXlsb2FkQ29uZmlnLFxuICAgIGZpZWxkczogYmxvY2suZmllbGRzLFxuICAgIHZhbGlkUmVsYXRpb25zaGlwcyxcbiAgfSlcblxuICBjb25zdCBpbml0aWFsRGF0YVJlZiA9IFJlYWN0LnVzZVJlZjxEYXRhPihidWlsZEluaXRpYWxTdGF0ZShmaWVsZHMuZGF0YSB8fCB7fSkpIC8vIFN0b3JlIGluaXRpYWwgdmFsdWUgaW4gYSByZWYsIHNvIGl0IGRvZXNuJ3QgY2hhbmdlIG9uIHJlLXJlbmRlciBhbmQgb25seSBnZXRzIGluaXRpYWxpemVkIG9uY2VcblxuICAvLyBNZW1vaXplZCBGb3JtIEpTWFxuICBjb25zdCBmb3JtQ29udGVudCA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIHJldHVybiAoXG4gICAgICBibG9jayAmJiAoXG4gICAgICAgIDxGb3JtIGluaXRpYWxTdGF0ZT17aW5pdGlhbERhdGFSZWY/LmN1cnJlbnR9IHN1Ym1pdHRlZD17c3VibWl0dGVkfT5cbiAgICAgICAgICA8QmxvY2tDb250ZW50XG4gICAgICAgICAgICBiYXNlQ2xhc3M9e2Jhc2VDbGFzc31cbiAgICAgICAgICAgIGJsb2NrPXtibG9ja31cbiAgICAgICAgICAgIGZpZWxkPXtmaWVsZH1cbiAgICAgICAgICAgIGZpZWxkcz17ZmllbGRzfVxuICAgICAgICAgICAgbm9kZUtleT17bm9kZUtleX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L0Zvcm0+XG4gICAgICApXG4gICAgKVxuICB9LCBbYmxvY2ssIGZpZWxkLCBub2RlS2V5LCBzdWJtaXR0ZWRdKVxuXG4gIHJldHVybiA8ZGl2IGNsYXNzTmFtZT17YmFzZUNsYXNzfT57Zm9ybUNvbnRlbnR9PC9kaXY+XG59XG4iXSwibmFtZXMiOlsiQmxvY2tDb21wb25lbnQiLCJiYXNlQ2xhc3MiLCJwcm9wcyIsImNoaWxkcmVuIiwiY2xhc3NOYW1lIiwiZmllbGRzIiwiZm9ybWF0Iiwibm9kZUtleSIsInBheWxvYWRDb25maWciLCJ1c2VDb25maWciLCJzdWJtaXR0ZWQiLCJ1c2VGb3JtU3VibWl0dGVkIiwiZWRpdG9yQ29uZmlnIiwiZmllbGQiLCJ1c2VFZGl0b3JDb25maWdDb250ZXh0IiwiYmxvY2siLCJyZXNvbHZlZEZlYXR1cmVNYXAiLCJnZXQiLCJibG9ja3MiLCJmaW5kIiwic2x1ZyIsImRhdGEiLCJibG9ja1R5cGUiLCJ2YWxpZFJlbGF0aW9uc2hpcHMiLCJjb2xsZWN0aW9ucyIsIm1hcCIsImMiLCJzYW5pdGl6ZUZpZWxkcyIsImNvbmZpZyIsImluaXRpYWxEYXRhUmVmIiwiUmVhY3QiLCJ1c2VSZWYiLCJidWlsZEluaXRpYWxTdGF0ZSIsImZvcm1Db250ZW50IiwidXNlTWVtbyIsIkZvcm0iLCJpbml0aWFsU3RhdGUiLCJjdXJyZW50IiwiQmxvY2tDb250ZW50IiwiZGl2Il0sIm1hcHBpbmdzIjoiOzs7OytCQTBCYUE7OztlQUFBQTs7O3VCQXpCNkM7K0RBQzNCOzJCQU9MO3dCQUNLO3NDQUlROzhCQUNWO1FBQ3RCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBWFAsTUFBTUMsWUFBWTtBQXFCWCxNQUFNRCxpQkFBa0MsQ0FBQ0U7SUFDOUMsTUFBTSxFQUFFQyxRQUFRLEVBQUVDLFNBQVMsRUFBRUMsTUFBTSxFQUFFQyxNQUFNLEVBQUVDLE9BQU8sRUFBRSxHQUFHTDtJQUN6RCxNQUFNTSxnQkFBZ0JDLElBQUFBLG9CQUFTO0lBQy9CLE1BQU1DLFlBQVlDLElBQUFBLHVCQUFnQjtJQUVsQyxNQUFNLEVBQUVDLFlBQVksRUFBRUMsS0FBSyxFQUFFLEdBQUdDLElBQUFBLDRDQUFzQjtJQUV0RCxNQUFNQyxRQUFRLENBQ1pILGNBQWNJLG9CQUFvQkMsSUFBSSxXQUFXZixLQUNuRCxHQUFHZ0IsUUFBUUMsS0FBSyxDQUFDSixRQUFVQSxNQUFNSyxJQUFJLEtBQUtmLFFBQVFnQixNQUFNQztJQUV4RCx1SEFBdUg7SUFDdkgsTUFBTUMscUJBQXFCZixjQUFjZ0IsV0FBVyxDQUFDQyxHQUFHLENBQUMsQ0FBQ0MsSUFBTUEsRUFBRU4sSUFBSSxLQUFLLEVBQUU7SUFDN0VMLE1BQU1WLE1BQU0sR0FBR3NCLElBQUFBLHNCQUFjLEVBQUM7UUFDNUJDLFFBQVFwQjtRQUNSSCxRQUFRVSxNQUFNVixNQUFNO1FBQ3BCa0I7SUFDRjtJQUVBLE1BQU1NLGlCQUFpQkMsY0FBSyxDQUFDQyxNQUFNLENBQU9DLElBQUFBLHdCQUFpQixFQUFDM0IsT0FBT2dCLElBQUksSUFBSSxDQUFDLElBQUksaUdBQWlHOztJQUVqTCxvQkFBb0I7SUFDcEIsTUFBTVksY0FBY0MsSUFBQUEsY0FBTyxFQUFDO1FBQzFCLE9BQ0VuQix1QkFDRSw2QkFBQ29CLFdBQUk7WUFBQ0MsY0FBY1AsZ0JBQWdCUTtZQUFTM0IsV0FBV0E7eUJBQ3RELDZCQUFDNEIsMEJBQVk7WUFDWHJDLFdBQVdBO1lBQ1hjLE9BQU9BO1lBQ1BGLE9BQU9BO1lBQ1BSLFFBQVFBO1lBQ1JFLFNBQVNBOztJQUtuQixHQUFHO1FBQUNRO1FBQU9GO1FBQU9OO1FBQVNHO0tBQVU7SUFFckMscUJBQU8sNkJBQUM2QjtRQUFJbkMsV0FBV0g7T0FBWWdDO0FBQ3JDIn0= | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/field/features/Blocks/component/index.tsx"],"sourcesContent":["import { type ElementFormatType } from 'lexical'\nimport { Form, buildInitialState, useFormSubmitted } from 'payload/components/forms'\nimport React, { useEffect, useMemo } from 'react'\n\nimport { type BlockFields } from '../nodes/BlocksNode'\nconst baseClass = 'lexical-block'\n\nimport type { Data } from 'payload/types'\n\nimport {\n  buildStateFromSchema,\n  useConfig,\n  useDocumentInfo,\n  useLocale,\n} from 'payload/components/utilities'\nimport { sanitizeFields } from 'payload/config'\nimport { useTranslation } from 'react-i18next'\n\nimport type { BlocksFeatureProps } from '..'\n\nimport { useEditorConfigContext } from '../../../lexical/config/EditorConfigProvider'\nimport { BlockContent } from './BlockContent'\nimport './index.scss'\n\ntype Props = {\n  children?: React.ReactNode\n  className?: string\n  fields: BlockFields\n  format?: ElementFormatType\n  nodeKey?: string\n}\n\nexport const BlockComponent: React.FC<Props> = (props) => {\n  const { children, className, fields, format, nodeKey } = props\n  const payloadConfig = useConfig()\n  const submitted = useFormSubmitted()\n\n  const { editorConfig, field } = useEditorConfigContext()\n\n  const block = (\n    editorConfig?.resolvedFeatureMap?.get('blocks')?.props as BlocksFeatureProps\n  )?.blocks?.find((block) => block.slug === fields?.data?.blockType)\n\n  // Sanitize block's fields here. This is done here and not in the feature, because the payload config is available here\n  const validRelationships = payloadConfig.collections.map((c) => c.slug) || []\n  block.fields = sanitizeFields({\n    config: payloadConfig,\n    fields: block.fields,\n    validRelationships,\n  })\n\n  const initialStateRef = React.useRef<Data>(buildInitialState(fields.data || {})) // Store initial value in a ref, so it doesn't change on re-render and only gets initialized once\n\n  const config = useConfig()\n  const { t } = useTranslation('general')\n  const { code: locale } = useLocale()\n  const { getDocPreferences } = useDocumentInfo()\n\n  // initialState State\n\n  const [initialState, setInitialState] = React.useState<Data>(null)\n\n  useEffect(() => {\n    async function buildInitialState() {\n      const preferences = await getDocPreferences()\n\n      const stateFromSchema = await buildStateFromSchema({\n        config,\n        data: fields.data,\n        fieldSchema: block.fields,\n        locale,\n        operation: 'update',\n        preferences,\n        t,\n      })\n\n      // We have to merge the output of buildInitialState (above this useEffect) with the output of buildStateFromSchema.\n      // That's because the output of buildInitialState provides important properties necessary for THIS block,\n      // like blockName, blockType and id, while buildStateFromSchema provides the correct output of this block's data,\n      // e.g. if this block has a sub-block (like the `rows` property)\n      setInitialState({\n        ...initialStateRef?.current,\n        ...stateFromSchema,\n      })\n    }\n    void buildInitialState()\n  }, [setInitialState, config, block, locale, getDocPreferences, t]) // do not add fields here, it causes an endless loop\n\n  // Memoized Form JSX\n  const formContent = useMemo(() => {\n    return (\n      block &&\n      initialState && (\n        <Form fields={block.fields} initialState={initialState} submitted={submitted}>\n          <BlockContent\n            baseClass={baseClass}\n            block={block}\n            field={field}\n            fields={fields}\n            nodeKey={nodeKey}\n          />\n        </Form>\n      )\n    )\n  }, [block, field, nodeKey, submitted, initialState])\n\n  return <div className={baseClass}>{formContent}</div>\n}\n"],"names":["BlockComponent","baseClass","props","children","className","fields","format","nodeKey","payloadConfig","useConfig","submitted","useFormSubmitted","editorConfig","field","useEditorConfigContext","block","resolvedFeatureMap","get","blocks","find","slug","data","blockType","validRelationships","collections","map","c","sanitizeFields","config","initialStateRef","React","useRef","buildInitialState","t","useTranslation","code","locale","useLocale","getDocPreferences","useDocumentInfo","initialState","setInitialState","useState","useEffect","preferences","stateFromSchema","buildStateFromSchema","fieldSchema","operation","current","formContent","useMemo","Form","BlockContent","div"],"mappings":";;;;+BAgCaA;;;eAAAA;;;uBA/B6C;+DAChB;2BAYnC;wBACwB;8BACA;sCAIQ;8BACV;QACtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAjBP,MAAMC,YAAY;AA2BX,MAAMD,iBAAkC,CAACE;IAC9C,MAAM,EAAEC,QAAQ,EAAEC,SAAS,EAAEC,MAAM,EAAEC,MAAM,EAAEC,OAAO,EAAE,GAAGL;IACzD,MAAMM,gBAAgBC,IAAAA,oBAAS;IAC/B,MAAMC,YAAYC,IAAAA,uBAAgB;IAElC,MAAM,EAAEC,YAAY,EAAEC,KAAK,EAAE,GAAGC,IAAAA,4CAAsB;IAEtD,MAAMC,QAAQ,CACZH,cAAcI,oBAAoBC,IAAI,WAAWf,KACnD,GAAGgB,QAAQC,KAAK,CAACJ,QAAUA,MAAMK,IAAI,KAAKf,QAAQgB,MAAMC;IAExD,uHAAuH;IACvH,MAAMC,qBAAqBf,cAAcgB,WAAW,CAACC,GAAG,CAAC,CAACC,IAAMA,EAAEN,IAAI,KAAK,EAAE;IAC7EL,MAAMV,MAAM,GAAGsB,IAAAA,sBAAc,EAAC;QAC5BC,QAAQpB;QACRH,QAAQU,MAAMV,MAAM;QACpBkB;IACF;IAEA,MAAMM,kBAAkBC,cAAK,CAACC,MAAM,CAAOC,IAAAA,wBAAiB,EAAC3B,OAAOgB,IAAI,IAAI,CAAC,IAAI,iGAAiG;;IAElL,MAAMO,SAASnB,IAAAA,oBAAS;IACxB,MAAM,EAAEwB,CAAC,EAAE,GAAGC,IAAAA,4BAAc,EAAC;IAC7B,MAAM,EAAEC,MAAMC,MAAM,EAAE,GAAGC,IAAAA,oBAAS;IAClC,MAAM,EAAEC,iBAAiB,EAAE,GAAGC,IAAAA,0BAAe;IAE7C,qBAAqB;IAErB,MAAM,CAACC,cAAcC,gBAAgB,GAAGX,cAAK,CAACY,QAAQ,CAAO;IAE7DC,IAAAA,gBAAS,EAAC;QACR,eAAeX;YACb,MAAMY,cAAc,MAAMN;YAE1B,MAAMO,kBAAkB,MAAMC,IAAAA,+BAAoB,EAAC;gBACjDlB;gBACAP,MAAMhB,OAAOgB,IAAI;gBACjB0B,aAAahC,MAAMV,MAAM;gBACzB+B;gBACAY,WAAW;gBACXJ;gBACAX;YACF;YAEA,mHAAmH;YACnH,yGAAyG;YACzG,iHAAiH;YACjH,gEAAgE;YAChEQ,gBAAgB;gBACd,GAAGZ,iBAAiBoB,OAAO;gBAC3B,GAAGJ,eAAe;YACpB;QACF;QACA,KAAKb;IACP,GAAG;QAACS;QAAiBb;QAAQb;QAAOqB;QAAQE;QAAmBL;KAAE,EAAE,oDAAoD;;IAEvH,oBAAoB;IACpB,MAAMiB,cAAcC,IAAAA,cAAO,EAAC;QAC1B,OACEpC,SACAyB,8BACE,6BAACY,WAAI;YAAC/C,QAAQU,MAAMV,MAAM;YAAEmC,cAAcA;YAAc9B,WAAWA;yBACjE,6BAAC2C,0BAAY;YACXpD,WAAWA;YACXc,OAAOA;YACPF,OAAOA;YACPR,QAAQA;YACRE,SAASA;;IAKnB,GAAG;QAACQ;QAAOF;QAAON;QAASG;QAAW8B;KAAa;IAEnD,qBAAO,6BAACc;QAAIlD,WAAWH;OAAYiD;AACrC"} |
{ | ||
"name": "@payloadcms/richtext-lexical", | ||
"version": "0.1.6", | ||
"version": "0.1.7", | ||
"description": "The officially supported Lexical richtext adapter for Payload", | ||
@@ -46,4 +46,4 @@ "repository": "https://github.com/payloadcms/payload", | ||
"@types/react": "18.2.15", | ||
"@payloadcms/eslint-config": "0.0.1", | ||
"payload": "2.0.5" | ||
"payload": "2.0.5", | ||
"@payloadcms/eslint-config": "0.0.1" | ||
}, | ||
@@ -50,0 +50,0 @@ "exports": null, |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
1429164
13438