Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@payloadcms/richtext-lexical

Package Overview
Dependencies
Maintainers
6
Versions
387
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@payloadcms/richtext-lexical - npm Package Compare versions

Comparing version 0.1.6 to 0.1.7

5

dist/field/features/Blocks/component/BlockContent.d.ts

@@ -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

2

dist/field/features/Blocks/component/BlockContent.js

@@ -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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc