UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

238 lines (237 loc) • 26.8 kB
"use strict"; 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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"}