payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
160 lines (159 loc) • 16.6 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reacti18next = require("react-i18next");
const _reactrouterdom = require("react-router-dom");
const _getTranslation = require("../../../../../utilities/getTranslation");
const _DocumentHeader = require("../../../elements/DocumentHeader");
const _Loading = require("../../../elements/Loading");
const _Form = /*#__PURE__*/ _interop_require_default(require("../../../forms/Form"));
const _ActionsProvider = require("../../../utilities/ActionsProvider");
const _Auth = require("../../../utilities/Auth");
const _DocumentEvents = require("../../../utilities/DocumentEvents");
const _OperationProvider = require("../../../utilities/OperationProvider");
const _Routes = require("./Routes");
const _CustomComponent = require("./Routes/CustomComponent");
require("./index.scss");
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 baseClass = 'collection-edit';
const DefaultEditView = (props)=>{
const { i18n } = (0, _reacti18next.useTranslation)('general');
const { refreshCookieAsync, user } = (0, _Auth.useAuth)();
const { id, action, apiURL, collection, customHeader, data, disableRoutes, fieldTypes, hasSavePermission, internalState, isEditing, isLoading, onSave: onSaveFromProps } = props;
const { setViewActions } = (0, _ActionsProvider.useActions)();
const { reportUpdate } = (0, _DocumentEvents.useDocumentEvents)();
const { auth } = collection;
const classes = [
baseClass,
isEditing && `${baseClass}--is-editing`
].filter(Boolean).join(' ');
const location = (0, _reactrouterdom.useLocation)();
const onSave = (0, _react.useCallback)(async (json)=>{
reportUpdate({
id,
entitySlug: collection.slug,
updatedAt: json?.result?.updatedAt || new Date().toISOString()
});
if (auth && id === user.id) {
await refreshCookieAsync();
}
if (typeof onSaveFromProps === 'function') {
onSaveFromProps({
...json,
operation: id ? 'update' : 'create'
});
}
}, [
id,
onSaveFromProps,
auth,
user,
refreshCookieAsync,
collection,
reportUpdate
]);
const operation = isEditing ? 'update' : 'create';
(0, _react.useEffect)(()=>{
const path = location.pathname;
if (!(path.endsWith(id) || path.endsWith('/create'))) {
return;
}
const editConfig = collection?.admin?.components?.views?.Edit;
const defaultActions = editConfig && 'Default' in editConfig && 'actions' in editConfig.Default ? editConfig.Default.actions : [];
setViewActions(defaultActions);
return ()=>{
setViewActions([]);
};
}, [
id,
location.pathname,
collection?.admin?.components?.views?.Edit,
setViewActions
]);
return /*#__PURE__*/ _react.default.createElement("main", {
className: classes
}, /*#__PURE__*/ _react.default.createElement(_OperationProvider.OperationContext.Provider, {
value: operation
}, /*#__PURE__*/ _react.default.createElement(_Form.default, {
action: action,
className: `${baseClass}__form`,
disabled: !hasSavePermission,
initialState: internalState,
method: id ? 'patch' : 'post',
onSuccess: onSave
}, /*#__PURE__*/ _react.default.createElement(_Loading.FormLoadingOverlayToggle, {
action: isLoading ? 'loading' : operation,
formIsLoading: isLoading,
loadingSuffix: (0, _getTranslation.getTranslation)(collection.labels.singular, i18n),
name: `collection-edit--${typeof collection?.labels?.singular === 'string' ? collection.labels.singular : 'document'}`,
type: "withoutNav"
}), !isLoading && /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(_DocumentHeader.DocumentHeader, {
apiURL: apiURL,
collection: collection,
customHeader: customHeader,
data: data,
id: id,
isEditing: isEditing
}), disableRoutes ? /*#__PURE__*/ _react.default.createElement(_CustomComponent.CustomCollectionComponent, {
view: "Default",
...props
}) : /*#__PURE__*/ _react.default.createElement(_Routes.CollectionRoutes, {
...props,
fieldTypes: fieldTypes
})))));
};
const _default = DefaultEditView;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/admin/components/views/collections/Edit/Default.tsx"],"sourcesContent":["import React, { useCallback, useEffect } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useLocation } from 'react-router-dom'\n\nimport type { FieldTypes } from '../../../forms/field-types'\nimport type { CollectionEditViewProps } from '../../types'\n\nimport { getTranslation } from '../../../../../utilities/getTranslation'\nimport { DocumentHeader } from '../../../elements/DocumentHeader'\nimport { FormLoadingOverlayToggle } from '../../../elements/Loading'\nimport Form from '../../../forms/Form'\nimport { useActions } from '../../../utilities/ActionsProvider'\nimport { useAuth } from '../../../utilities/Auth'\nimport { useDocumentEvents } from '../../../utilities/DocumentEvents'\nimport { OperationContext } from '../../../utilities/OperationProvider'\nimport { CollectionRoutes } from './Routes'\nimport { CustomCollectionComponent } from './Routes/CustomComponent'\nimport './index.scss'\n\nconst baseClass = 'collection-edit'\n\nexport type DefaultEditViewProps = CollectionEditViewProps & {\n  customHeader?: React.ReactNode\n  disableRoutes?: boolean\n  fieldTypes: FieldTypes\n}\n\nconst DefaultEditView: React.FC<DefaultEditViewProps> = (props) => {\n  const { i18n } = useTranslation('general')\n  const { refreshCookieAsync, user } = useAuth()\n\n  const {\n    id,\n    action,\n    apiURL,\n    collection,\n    customHeader,\n    data,\n    disableRoutes,\n    fieldTypes,\n    hasSavePermission,\n    internalState,\n    isEditing,\n    isLoading,\n    onSave: onSaveFromProps,\n  } = props\n\n  const { setViewActions } = useActions()\n\n  const { reportUpdate } = useDocumentEvents()\n\n  const { auth } = collection\n\n  const classes = [baseClass, isEditing && `${baseClass}--is-editing`].filter(Boolean).join(' ')\n\n  const location = useLocation()\n\n  const onSave = useCallback(\n    async (json) => {\n      reportUpdate({\n        id,\n        entitySlug: collection.slug,\n        updatedAt: json?.result?.updatedAt || new Date().toISOString(),\n      })\n      if (auth && id === user.id) {\n        await refreshCookieAsync()\n      }\n\n      if (typeof onSaveFromProps === 'function') {\n        onSaveFromProps({\n          ...json,\n          operation: id ? 'update' : 'create',\n        })\n      }\n    },\n    [id, onSaveFromProps, auth, user, refreshCookieAsync, collection, reportUpdate],\n  )\n\n  const operation = isEditing ? 'update' : 'create'\n\n  useEffect(() => {\n    const path = location.pathname\n\n    if (!(path.endsWith(id) || path.endsWith('/create'))) {\n      return\n    }\n    const editConfig = collection?.admin?.components?.views?.Edit\n    const defaultActions =\n      editConfig && 'Default' in editConfig && 'actions' in editConfig.Default\n        ? editConfig.Default.actions\n        : []\n\n    setViewActions(defaultActions)\n\n    return () => {\n      setViewActions([])\n    }\n  }, [id, location.pathname, collection?.admin?.components?.views?.Edit, setViewActions])\n\n  return (\n    <main className={classes}>\n      <OperationContext.Provider value={operation}>\n        <Form\n          action={action}\n          className={`${baseClass}__form`}\n          disabled={!hasSavePermission}\n          initialState={internalState}\n          method={id ? 'patch' : 'post'}\n          onSuccess={onSave}\n        >\n          <FormLoadingOverlayToggle\n            action={isLoading ? 'loading' : operation}\n            formIsLoading={isLoading}\n            loadingSuffix={getTranslation(collection.labels.singular, i18n)}\n            name={`collection-edit--${\n              typeof collection?.labels?.singular === 'string'\n                ? collection.labels.singular\n                : 'document'\n            }`}\n            type=\"withoutNav\"\n          />\n          {!isLoading && (\n            <React.Fragment>\n              <DocumentHeader\n                apiURL={apiURL}\n                collection={collection}\n                customHeader={customHeader}\n                data={data}\n                id={id}\n                isEditing={isEditing}\n              />\n              {disableRoutes ? (\n                <CustomCollectionComponent view=\"Default\" {...props} />\n              ) : (\n                <CollectionRoutes {...props} fieldTypes={fieldTypes} />\n              )}\n            </React.Fragment>\n          )}\n        </Form>\n      </OperationContext.Provider>\n    </main>\n  )\n}\n\nexport default DefaultEditView\n"],"names":["baseClass","DefaultEditView","props","i18n","useTranslation","refreshCookieAsync","user","useAuth","id","action","apiURL","collection","customHeader","data","disableRoutes","fieldTypes","hasSavePermission","internalState","isEditing","isLoading","onSave","onSaveFromProps","setViewActions","useActions","reportUpdate","useDocumentEvents","auth","classes","filter","Boolean","join","location","useLocation","useCallback","json","entitySlug","slug","updatedAt","result","Date","toISOString","operation","useEffect","path","pathname","endsWith","editConfig","admin","components","views","Edit","defaultActions","Default","actions","main","className","OperationContext","Provider","value","Form","disabled","initialState","method","onSuccess","FormLoadingOverlayToggle","formIsLoading","loadingSuffix","getTranslation","labels","singular","name","type","React","Fragment","DocumentHeader","CustomCollectionComponent","view","CollectionRoutes"],"mappings":"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"}