UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

228 lines (227 loc) • 23.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _qs = /*#__PURE__*/ _interop_require_default(require("qs")); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _reacti18next = require("react-i18next"); const _reactrouterdom = require("react-router-dom"); 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 _Auth = require("../../../utilities/Auth"); const _Config = require("../../../utilities/Config"); const _DocumentInfo = require("../../../utilities/DocumentInfo"); const _EditDepth = require("../../../utilities/EditDepth"); const _FormQueryParams = require("../../../utilities/FormQueryParams"); const _Locale = require("../../../utilities/Locale"); const _RenderCustomComponent = /*#__PURE__*/ _interop_require_default(require("../../../utilities/RenderCustomComponent")); const _NotFound = /*#__PURE__*/ _interop_require_default(require("../../NotFound")); const _Default = /*#__PURE__*/ _interop_require_default(require("./Default")); const _formatFields = /*#__PURE__*/ _interop_require_default(require("./formatFields")); 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 EditView = (props)=>{ const { collection: incomingCollection, isEditing } = props; const { slug: collectionSlug, admin: { components: { views: { Edit } = {} } = {} } = {} } = incomingCollection; const [fields] = (0, _react.useState)(()=>(0, _formatFields.default)(incomingCollection, isEditing)); const [collection] = (0, _react.useState)(()=>({ ...incomingCollection, fields })); const [redirect, setRedirect] = (0, _react.useState)(); const [formQueryParams, setFormQueryParams] = (0, _react.useState)({ depth: 0, 'fallback-locale': 'null', locale: '', uploadEdits: undefined }); const formattedQueryParams = _qs.default.stringify(formQueryParams); const { code: locale } = (0, _Locale.useLocale)(); const config = (0, _Config.useConfig)(); const { routes: { admin, api }, serverURL } = config; const { params: { id } = {} } = (0, _reactrouterdom.useRouteMatch)(); const history = (0, _reactrouterdom.useHistory)(); const [internalState, setInternalState] = (0, _react.useState)(); const [updatedAt, setUpdatedAt] = (0, _react.useState)(); const { permissions, user } = (0, _Auth.useAuth)(); const userRef = (0, _react.useRef)(user); const { docPermissions, getDocPermissions, getDocPreferences, getVersions } = (0, _DocumentInfo.useDocumentInfo)(); const { t } = (0, _reacti18next.useTranslation)('general'); const [{ data, isError, isLoading: isLoadingData }] = (0, _usePayloadAPI.default)(isEditing ? `${serverURL}${api}/${collectionSlug}/${id}` : '', { initialData: null, initialParams: { depth: 0, draft: 'true', 'fallback-locale': 'null' } }); const buildState = (0, _react.useCallback)(async (doc, overrides)=>{ const preferences = await getDocPreferences(); const state = await (0, _buildStateFromSchema.default)({ id, config, data: doc || {}, fieldSchema: overrides?.fieldSchema, locale, operation: 'update', preferences, t, user: userRef.current, ...overrides }); setInternalState(state); }, [ getDocPreferences, id, locale, t, config ]); const onSave = (0, _react.useCallback)(async (json)=>{ getVersions(); getDocPermissions(); setUpdatedAt(json?.doc?.updatedAt); if (!isEditing) { setRedirect(`${admin}/collections/${collection.slug}/${json?.doc?.id}`); } else { buildState(json.doc, { fieldSchema: collection.fields }); setFormQueryParams((params)=>({ ...params, uploadEdits: undefined })); } }, [ admin, getVersions, isEditing, buildState, getDocPermissions, collection ]); (0, _react.useEffect)(()=>{ if (fields && (isEditing ? data : true)) { const awaitInternalState = async ()=>{ setUpdatedAt(data?.updatedAt); buildState(data, { fieldSchema: fields, operation: isEditing ? 'update' : 'create' }); }; awaitInternalState(); } }, [ isEditing, data, buildState, fields ]); (0, _react.useEffect)(()=>{ if (redirect) { history.push(redirect); } }, [ history, redirect ]); (0, _react.useEffect)(()=>{ setFormQueryParams((params)=>({ ...params, locale: locale })); }, [ locale ]); if (isError) { return /*#__PURE__*/ _react.default.createElement(_NotFound.default, { marginTop: "large" }); } const apiURL = `${serverURL}${api}/${collectionSlug}/${id}?locale=${locale}${collection.versions.drafts ? '&draft=true' : ''}`; const action = `${serverURL}${api}/${collectionSlug}${isEditing ? `/${id}` : ''}?${formattedQueryParams}`; const hasSavePermission = isEditing && docPermissions?.update?.permission || !isEditing && docPermissions?.create?.permission; const isLoading = !internalState || !docPermissions || isLoadingData; const componentProps = { id, action, apiURL, canAccessAdmin: permissions?.canAccessAdmin, collection, data, fieldTypes: _fieldtypes.fieldTypes, hasSavePermission, internalState, isEditing, isLoading, onSave, permissions: docPermissions, updatedAt: updatedAt || data?.updatedAt, user }; return /*#__PURE__*/ _react.default.createElement(_EditDepth.EditDepthContext.Provider, { value: 1 }, /*#__PURE__*/ _react.default.createElement(_FormQueryParams.FormQueryParams.Provider, { value: { formQueryParams, setFormQueryParams } }, /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, { CustomComponent: typeof Edit === 'function' ? Edit : undefined, DefaultComponent: _Default.default, componentProps: componentProps }))); }; const _default = EditView; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/admin/components/views/collections/Edit/index.tsx"],"sourcesContent":["import queryString from 'qs'\nimport React, { useCallback, useEffect, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useHistory, useRouteMatch } from 'react-router-dom'\n\nimport type { CollectionPermission } from '../../../../../auth'\nimport type { Fields } from '../../../forms/Form/types'\nimport type { QueryParamTypes } from '../../../utilities/FormQueryParams'\nimport type { DefaultEditViewProps } from './Default'\nimport type { IndexProps } from './types'\n\nimport usePayloadAPI from '../../../../hooks/usePayloadAPI'\nimport buildStateFromSchema from '../../../forms/Form/buildStateFromSchema'\nimport { fieldTypes } from '../../../forms/field-types'\nimport { useAuth } from '../../../utilities/Auth'\nimport { useConfig } from '../../../utilities/Config'\nimport { useDocumentInfo } from '../../../utilities/DocumentInfo'\nimport { EditDepthContext } from '../../../utilities/EditDepth'\nimport { FormQueryParams } from '../../../utilities/FormQueryParams'\nimport { useLocale } from '../../../utilities/Locale'\nimport RenderCustomComponent from '../../../utilities/RenderCustomComponent'\nimport NotFound from '../../NotFound'\nimport DefaultEdit from './Default'\nimport formatFields from './formatFields'\n\nconst EditView: React.FC<IndexProps> = (props) => {\n  const { collection: incomingCollection, isEditing } = props\n\n  const { slug: collectionSlug, admin: { components: { views: { Edit } = {} } = {} } = {} } =\n    incomingCollection\n\n  const [fields] = useState(() => formatFields(incomingCollection, isEditing))\n  const [collection] = useState(() => ({ ...incomingCollection, fields }))\n  const [redirect, setRedirect] = useState<string>()\n  const [formQueryParams, setFormQueryParams] = useState<QueryParamTypes>({\n    depth: 0,\n    'fallback-locale': 'null',\n    locale: '',\n    uploadEdits: undefined,\n  })\n\n  const formattedQueryParams = queryString.stringify(formQueryParams)\n\n  const { code: locale } = useLocale()\n\n  const config = useConfig()\n  const {\n    routes: { admin, api },\n    serverURL,\n  } = config\n\n  const { params: { id } = {} } = useRouteMatch<Record<string, string>>()\n  const history = useHistory()\n  const [internalState, setInternalState] = useState<Fields>()\n  const [updatedAt, setUpdatedAt] = useState<string>()\n  const { permissions, user } = useAuth()\n  const userRef = useRef(user)\n  const { docPermissions, getDocPermissions, getDocPreferences, getVersions } = useDocumentInfo()\n  const { t } = useTranslation('general')\n\n  const [{ data, isError, isLoading: isLoadingData }] = usePayloadAPI(\n    isEditing ? `${serverURL}${api}/${collectionSlug}/${id}` : '',\n    { initialData: null, initialParams: { depth: 0, draft: 'true', 'fallback-locale': 'null' } },\n  )\n\n  const buildState = useCallback(\n    async (doc, overrides?: Partial<Parameters<typeof buildStateFromSchema>[0]>) => {\n      const preferences = await getDocPreferences()\n\n      const state = await buildStateFromSchema({\n        id,\n        config,\n        data: doc || {},\n        fieldSchema: overrides?.fieldSchema,\n        locale,\n        operation: 'update',\n        preferences,\n        t,\n        user: userRef.current,\n        ...overrides,\n      })\n\n      setInternalState(state)\n    },\n    [getDocPreferences, id, locale, t, config],\n  )\n\n  const onSave = useCallback(\n    async (json: { doc }) => {\n      getVersions()\n      getDocPermissions()\n      setUpdatedAt(json?.doc?.updatedAt)\n      if (!isEditing) {\n        setRedirect(`${admin}/collections/${collection.slug}/${json?.doc?.id}`)\n      } else {\n        buildState(json.doc, {\n          fieldSchema: collection.fields,\n        })\n        setFormQueryParams((params) => ({\n          ...params,\n          uploadEdits: undefined,\n        }))\n      }\n    },\n    [admin, getVersions, isEditing, buildState, getDocPermissions, collection],\n  )\n\n  useEffect(() => {\n    if (fields && (isEditing ? data : true)) {\n      const awaitInternalState = async () => {\n        setUpdatedAt(data?.updatedAt)\n        buildState(data, {\n          fieldSchema: fields,\n          operation: isEditing ? 'update' : 'create',\n        })\n      }\n\n      awaitInternalState()\n    }\n  }, [isEditing, data, buildState, fields])\n\n  useEffect(() => {\n    if (redirect) {\n      history.push(redirect)\n    }\n  }, [history, redirect])\n\n  useEffect(() => {\n    setFormQueryParams((params) => ({\n      ...params,\n      locale: locale,\n    }))\n  }, [locale])\n\n  if (isError) {\n    return <NotFound marginTop=\"large\" />\n  }\n\n  const apiURL = `${serverURL}${api}/${collectionSlug}/${id}?locale=${locale}${\n    collection.versions.drafts ? '&draft=true' : ''\n  }`\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 || isLoadingData\n\n  const componentProps: DefaultEditViewProps = {\n    id,\n    action,\n    apiURL,\n    canAccessAdmin: permissions?.canAccessAdmin,\n    collection,\n    data,\n    fieldTypes,\n    hasSavePermission,\n    internalState,\n    isEditing,\n    isLoading,\n    onSave,\n    permissions: docPermissions as CollectionPermission,\n    updatedAt: updatedAt || data?.updatedAt,\n    user,\n  }\n\n  return (\n    <EditDepthContext.Provider value={1}>\n      <FormQueryParams.Provider value={{ formQueryParams, setFormQueryParams }}>\n        <RenderCustomComponent\n          CustomComponent={typeof Edit === 'function' ? Edit : undefined}\n          DefaultComponent={DefaultEdit}\n          componentProps={componentProps}\n        />\n      </FormQueryParams.Provider>\n    </EditDepthContext.Provider>\n  )\n}\nexport default EditView\n"],"names":["EditView","props","collection","incomingCollection","isEditing","slug","collectionSlug","admin","components","views","Edit","fields","useState","formatFields","redirect","setRedirect","formQueryParams","setFormQueryParams","depth","locale","uploadEdits","undefined","formattedQueryParams","queryString","stringify","code","useLocale","config","useConfig","routes","api","serverURL","params","id","useRouteMatch","history","useHistory","internalState","setInternalState","updatedAt","setUpdatedAt","permissions","user","useAuth","userRef","useRef","docPermissions","getDocPermissions","getDocPreferences","getVersions","useDocumentInfo","t","useTranslation","data","isError","isLoading","isLoadingData","usePayloadAPI","initialData","initialParams","draft","buildState","useCallback","doc","overrides","preferences","state","buildStateFromSchema","fieldSchema","operation","current","onSave","json","useEffect","awaitInternalState","push","NotFound","marginTop","apiURL","versions","drafts","action","hasSavePermission","update","permission","create","componentProps","canAccessAdmin","fieldTypes","EditDepthContext","Provider","value","FormQueryParams","RenderCustomComponent","CustomComponent","DefaultComponent","DefaultEdit"],"mappings":"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"}