payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
228 lines (227 loc) • 23.1 kB
JavaScript
;
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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"}