payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
238 lines (237 loc) • 26.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "DocumentDrawerContent", {
enumerable: true,
get: function() {
return DocumentDrawerContent;
}
});
const _modal = require("@faceless-ui/modal");
const _qs = /*#__PURE__*/ _interop_require_default(require("qs"));
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reacti18next = require("react-i18next");
const _reacttoastify = require("react-toastify");
const _ = require(".");
const _getTranslation = require("../../../../utilities/getTranslation");
const _usePayloadAPI = /*#__PURE__*/ _interop_require_default(require("../../../hooks/usePayloadAPI"));
const _buildStateFromSchema = /*#__PURE__*/ _interop_require_default(require("../../forms/Form/buildStateFromSchema"));
const _fieldtypes = require("../../forms/field-types");
const _useRelatedCollections = require("../../forms/field-types/Relationship/AddNew/useRelatedCollections");
const _X = /*#__PURE__*/ _interop_require_default(require("../../icons/X"));
const _Auth = require("../../utilities/Auth");
const _Config = require("../../utilities/Config");
const _DocumentInfo = require("../../utilities/DocumentInfo");
const _FormQueryParams = require("../../utilities/FormQueryParams");
const _Locale = require("../../utilities/Locale");
const _RenderCustomComponent = /*#__PURE__*/ _interop_require_default(require("../../utilities/RenderCustomComponent"));
const _Default = /*#__PURE__*/ _interop_require_default(require("../../views/collections/Edit/Default"));
const _formatFields = /*#__PURE__*/ _interop_require_default(require("../../views/collections/Edit/formatFields"));
const _Button = /*#__PURE__*/ _interop_require_default(require("../Button"));
const _IDLabel = /*#__PURE__*/ _interop_require_default(require("../IDLabel"));
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
function _getRequireWildcardCache(nodeInterop) {
if (typeof WeakMap !== "function") return null;
var cacheBabelInterop = new WeakMap();
var cacheNodeInterop = new WeakMap();
return (_getRequireWildcardCache = function(nodeInterop) {
return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
})(nodeInterop);
}
function _interop_require_wildcard(obj, nodeInterop) {
if (!nodeInterop && obj && obj.__esModule) {
return obj;
}
if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
return {
default: obj
};
}
var cache = _getRequireWildcardCache(nodeInterop);
if (cache && cache.has(obj)) {
return cache.get(obj);
}
var newObj = {
__proto__: null
};
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
for(var key in obj){
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
if (desc && (desc.get || desc.set)) {
Object.defineProperty(newObj, key, desc);
} else {
newObj[key] = obj[key];
}
}
}
newObj.default = obj;
if (cache) {
cache.set(obj, newObj);
}
return newObj;
}
const Content = ({ collectionSlug, customHeader, drawerSlug, onSave })=>{
const { routes: { api }, serverURL } = (0, _Config.useConfig)();
const { closeModal, modalState, toggleModal } = (0, _modal.useModal)();
const { code: locale } = (0, _Locale.useLocale)();
const { user } = (0, _Auth.useAuth)();
const [internalState, setInternalState] = (0, _react.useState)();
const { i18n, t } = (0, _reacti18next.useTranslation)([
'fields',
'general'
]);
const hasInitializedState = (0, _react.useRef)(false);
const [isOpen, setIsOpen] = (0, _react.useState)(false);
const [collectionConfig] = (0, _useRelatedCollections.useRelatedCollections)(collectionSlug);
const config = (0, _Config.useConfig)();
const { formQueryParams } = (0, _FormQueryParams.useFormQueryParams)();
const formattedQueryParams = _qs.default.stringify(formQueryParams);
const { admin: { components: { views: { Edit } = {} } = {} } = {} } = collectionConfig;
const { id, docPermissions, getDocPreferences } = (0, _DocumentInfo.useDocumentInfo)();
// If they are replacing the entire edit view, use that.
// Else let the DefaultEdit determine what to render.
const CustomEditView = typeof Edit === 'function' ? Edit : undefined;
const [fields, setFields] = (0, _react.useState)(()=>(0, _formatFields.default)(collectionConfig, true));
// no need to an additional requests when creating new documents
const initialID = (0, _react.useRef)(id);
const [{ data, isError, isLoading: isLoadingDocument }] = (0, _usePayloadAPI.default)(initialID.current ? `${serverURL}${api}/${collectionSlug}/${initialID.current}` : null, {
initialParams: {
depth: 0,
draft: 'true',
'fallback-locale': 'null'
}
});
(0, _react.useEffect)(()=>{
setFields((0, _formatFields.default)(collectionConfig, true));
}, [
collectionSlug,
collectionConfig
]);
(0, _react.useEffect)(()=>{
if (isLoadingDocument || hasInitializedState.current) {
return;
}
const awaitInitialState = async ()=>{
const preferences = await getDocPreferences();
const state = await (0, _buildStateFromSchema.default)({
id,
config,
data,
fieldSchema: fields,
locale,
operation: id ? 'update' : 'create',
preferences,
t,
user
});
setInternalState(state);
};
awaitInitialState();
hasInitializedState.current = true;
}, [
data,
fields,
id,
user,
locale,
isLoadingDocument,
t,
getDocPreferences,
config
]);
(0, _react.useEffect)(()=>{
setIsOpen(Boolean(modalState[drawerSlug]?.isOpen));
}, [
modalState,
drawerSlug
]);
(0, _react.useEffect)(()=>{
if (isOpen && !isLoadingDocument && isError) {
closeModal(drawerSlug);
_reacttoastify.toast.error(data.errors?.[0].message || t('error:unspecific'));
}
}, [
isError,
t,
isOpen,
data,
drawerSlug,
closeModal,
isLoadingDocument
]);
if (isError) return null;
const isEditing = Boolean(id);
const apiURL = id ? `${serverURL}${api}/${collectionSlug}/${id}?locale=${locale}` : null;
const action = `${serverURL}${api}/${collectionSlug}${isEditing ? `/${id}` : ''}?${formattedQueryParams}`;
const hasSavePermission = isEditing && docPermissions?.update?.permission || !isEditing && docPermissions?.create?.permission;
const isLoading = !internalState || !docPermissions || isLoadingDocument;
return /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, {
CustomComponent: CustomEditView,
DefaultComponent: _Default.default,
componentProps: {
id,
action,
apiURL,
collection: collectionConfig,
customHeader: /*#__PURE__*/ _react.default.createElement("div", {
className: `${_.baseClass}__header`
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${_.baseClass}__header-content`
}, /*#__PURE__*/ _react.default.createElement("h2", {
className: `${_.baseClass}__header-text`
}, !customHeader ? t(!id ? 'fields:addNewLabel' : 'general:editLabel', {
label: (0, _getTranslation.getTranslation)(collectionConfig.labels.singular, i18n)
}) : customHeader), /*#__PURE__*/ _react.default.createElement(_Button.default, {
"aria-label": t('general:close'),
buttonStyle: "none",
className: `${_.baseClass}__header-close`,
onClick: ()=>toggleModal(drawerSlug)
}, /*#__PURE__*/ _react.default.createElement(_X.default, null))), id && /*#__PURE__*/ _react.default.createElement(_IDLabel.default, {
id: id.toString()
})),
data,
disableActions: true,
disableLeaveWithoutSaving: true,
disableRoutes: true,
fieldTypes: _fieldtypes.fieldTypes,
hasSavePermission,
internalState,
isEditing,
isLoading,
me: true,
onSave,
permissions: docPermissions
}
});
};
const DocumentDrawerContent = (props)=>{
const { id: idFromProps, collectionSlug, onSave: onSaveFromProps } = props;
const [collectionConfig] = (0, _useRelatedCollections.useRelatedCollections)(collectionSlug);
const [id, setId] = (0, _react.useState)(idFromProps);
const onSave = (0, _react.useCallback)((args)=>{
setId(args.doc.id);
if (typeof onSaveFromProps === 'function') {
onSaveFromProps({
...args,
collectionConfig
});
}
}, [
onSaveFromProps,
collectionConfig
]);
return /*#__PURE__*/ _react.default.createElement(_DocumentInfo.DocumentInfoProvider, {
collection: collectionConfig,
id: id
}, /*#__PURE__*/ _react.default.createElement(Content, {
...props,
onSave: onSave
}));
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/DocumentDrawer/DrawerContent.tsx"],"sourcesContent":["import { useModal } from '@faceless-ui/modal'\nimport queryString from 'qs'\nimport React, { useCallback, useEffect, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { toast } from 'react-toastify'\n\nimport type { CollectionPermission } from '../../../../auth'\nimport type { Fields } from '../../forms/Form/types'\nimport type { DocumentDrawerProps } from './types'\n\nimport { baseClass } from '.'\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport usePayloadAPI from '../../../hooks/usePayloadAPI'\nimport buildStateFromSchema from '../../forms/Form/buildStateFromSchema'\nimport { fieldTypes } from '../../forms/field-types'\nimport { useRelatedCollections } from '../../forms/field-types/Relationship/AddNew/useRelatedCollections'\nimport X from '../../icons/X'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport { DocumentInfoProvider, useDocumentInfo } from '../../utilities/DocumentInfo'\nimport { useFormQueryParams } from '../../utilities/FormQueryParams'\nimport { useLocale } from '../../utilities/Locale'\nimport RenderCustomComponent from '../../utilities/RenderCustomComponent'\nimport DefaultEdit from '../../views/collections/Edit/Default'\nimport formatFields from '../../views/collections/Edit/formatFields'\nimport Button from '../Button'\nimport IDLabel from '../IDLabel'\n\nconst Content: React.FC<DocumentDrawerProps> = ({\n  collectionSlug,\n  customHeader,\n  drawerSlug,\n  onSave,\n}) => {\n  const {\n    routes: { api },\n    serverURL,\n  } = useConfig()\n  const { closeModal, modalState, toggleModal } = useModal()\n  const { code: locale } = useLocale()\n  const { user } = useAuth()\n  const [internalState, setInternalState] = useState<Fields>()\n  const { i18n, t } = useTranslation(['fields', 'general'])\n  const hasInitializedState = useRef(false)\n  const [isOpen, setIsOpen] = useState(false)\n  const [collectionConfig] = useRelatedCollections(collectionSlug)\n  const config = useConfig()\n  const { formQueryParams } = useFormQueryParams()\n  const formattedQueryParams = queryString.stringify(formQueryParams)\n\n  const { admin: { components: { views: { Edit } = {} } = {} } = {} } = collectionConfig\n\n  const { id, docPermissions, getDocPreferences } = useDocumentInfo()\n\n  // If they are replacing the entire edit view, use that.\n  // Else let the DefaultEdit determine what to render.\n  const CustomEditView = typeof Edit === 'function' ? Edit : undefined\n\n  const [fields, setFields] = useState(() => formatFields(collectionConfig, true))\n\n  // no need to an additional requests when creating new documents\n  const initialID = useRef(id)\n  const [{ data, isError, isLoading: isLoadingDocument }] = usePayloadAPI(\n    initialID.current ? `${serverURL}${api}/${collectionSlug}/${initialID.current}` : null,\n    { initialParams: { depth: 0, draft: 'true', 'fallback-locale': 'null' } },\n  )\n\n  useEffect(() => {\n    setFields(formatFields(collectionConfig, true))\n  }, [collectionSlug, collectionConfig])\n\n  useEffect(() => {\n    if (isLoadingDocument || hasInitializedState.current) {\n      return\n    }\n\n    const awaitInitialState = async () => {\n      const preferences = await getDocPreferences()\n      const state = await buildStateFromSchema({\n        id,\n        config,\n        data,\n        fieldSchema: fields,\n        locale,\n        operation: id ? 'update' : 'create',\n        preferences,\n        t,\n        user,\n      })\n      setInternalState(state)\n    }\n\n    awaitInitialState()\n    hasInitializedState.current = true\n  }, [data, fields, id, user, locale, isLoadingDocument, t, getDocPreferences, config])\n\n  useEffect(() => {\n    setIsOpen(Boolean(modalState[drawerSlug]?.isOpen))\n  }, [modalState, drawerSlug])\n\n  useEffect(() => {\n    if (isOpen && !isLoadingDocument && isError) {\n      closeModal(drawerSlug)\n      toast.error(data.errors?.[0].message || t('error:unspecific'))\n    }\n  }, [isError, t, isOpen, data, drawerSlug, closeModal, isLoadingDocument])\n\n  if (isError) return null\n\n  const isEditing = Boolean(id)\n\n  const apiURL = id ? `${serverURL}${api}/${collectionSlug}/${id}?locale=${locale}` : null\n\n  const action = `${serverURL}${api}/${collectionSlug}${\n    isEditing ? `/${id}` : ''\n  }?${formattedQueryParams}`\n\n  const hasSavePermission =\n    (isEditing && docPermissions?.update?.permission) ||\n    (!isEditing && (docPermissions as CollectionPermission)?.create?.permission)\n\n  const isLoading = !internalState || !docPermissions || isLoadingDocument\n\n  return (\n    <RenderCustomComponent\n      CustomComponent={CustomEditView}\n      DefaultComponent={DefaultEdit}\n      componentProps={{\n        id,\n        action,\n        apiURL,\n        collection: collectionConfig,\n        customHeader: (\n          <div className={`${baseClass}__header`}>\n            <div className={`${baseClass}__header-content`}>\n              <h2 className={`${baseClass}__header-text`}>\n                {!customHeader\n                  ? t(!id ? 'fields:addNewLabel' : 'general:editLabel', {\n                      label: getTranslation(collectionConfig.labels.singular, i18n),\n                    })\n                  : customHeader}\n              </h2>\n              <Button\n                aria-label={t('general:close')}\n                buttonStyle=\"none\"\n                className={`${baseClass}__header-close`}\n                onClick={() => toggleModal(drawerSlug)}\n              >\n                <X />\n              </Button>\n            </div>\n            {id && <IDLabel id={id.toString()} />}\n          </div>\n        ),\n        data,\n        disableActions: true,\n        disableLeaveWithoutSaving: true,\n        disableRoutes: true,\n        fieldTypes,\n        hasSavePermission,\n        internalState,\n        isEditing,\n        isLoading,\n        me: true,\n        onSave,\n        permissions: docPermissions,\n      }}\n    />\n  )\n}\n\n// First provide the document context using `DocumentInfoProvider`\n// this is so we can utilize the `useDocumentInfo` hook in the `Content` component\n// this drawer is used for both creating and editing documents\n// this means that the `id` may be unknown until the document is created\nexport const DocumentDrawerContent: React.FC<DocumentDrawerProps> = (props) => {\n  const { id: idFromProps, collectionSlug, onSave: onSaveFromProps } = props\n  const [collectionConfig] = useRelatedCollections(collectionSlug)\n  const [id, setId] = useState<null | string>(idFromProps)\n\n  const onSave = useCallback<DocumentDrawerProps['onSave']>(\n    (args) => {\n      setId(args.doc.id)\n\n      if (typeof onSaveFromProps === 'function') {\n        onSaveFromProps({\n          ...args,\n          collectionConfig,\n        })\n      }\n    },\n    [onSaveFromProps, collectionConfig],\n  )\n\n  return (\n    <DocumentInfoProvider collection={collectionConfig} id={id}>\n      <Content {...props} onSave={onSave} />\n    </DocumentInfoProvider>\n  )\n}\n"],"names":["DocumentDrawerContent","Content","collectionSlug","customHeader","drawerSlug","onSave","routes","api","serverURL","useConfig","closeModal","modalState","toggleModal","useModal","code","locale","useLocale","user","useAuth","internalState","setInternalState","useState","i18n","t","useTranslation","hasInitializedState","useRef","isOpen","setIsOpen","collectionConfig","useRelatedCollections","config","formQueryParams","useFormQueryParams","formattedQueryParams","queryString","stringify","admin","components","views","Edit","id","docPermissions","getDocPreferences","useDocumentInfo","CustomEditView","undefined","fields","setFields","formatFields","initialID","data","isError","isLoading","isLoadingDocument","usePayloadAPI","current","initialParams","depth","draft","useEffect","awaitInitialState","preferences","state","buildStateFromSchema","fieldSchema","operation","Boolean","toast","error","errors","message","isEditing","apiURL","action","hasSavePermission","update","permission","create","RenderCustomComponent","CustomComponent","DefaultComponent","DefaultEdit","componentProps","collection","div","className","baseClass","h2","label","getTranslation","labels","singular","Button","aria-label","buttonStyle","onClick","X","IDLabel","toString","disableActions","disableLeaveWithoutSaving","disableRoutes","fieldTypes","me","permissions","props","idFromProps","onSaveFromProps","setId","useCallback","args","doc","DocumentInfoProvider"],"mappings":"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"}