payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
220 lines (219 loc) • 22.1 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _modal = require("@faceless-ui/modal");
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reacti18next = require("react-i18next");
const _reactrouterdom = require("react-router-dom");
const _reacttoastify = require("react-toastify");
const _getTranslation = require("../../../../utilities/getTranslation");
const _api = require("../../../api");
const _context = require("../../forms/Form/context");
const _Minimal = /*#__PURE__*/ _interop_require_default(require("../../templates/Minimal"));
const _Config = require("../../utilities/Config");
const _Button = /*#__PURE__*/ _interop_require_default(require("../Button"));
const _PopupButtonList = /*#__PURE__*/ _interop_require_wildcard(require("../Popup/PopupButtonList"));
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 = 'duplicate';
const Duplicate = ({ id, collection, slug })=>{
const { push } = (0, _reactrouterdom.useHistory)();
const modified = (0, _context.useFormModified)();
const { toggleModal } = (0, _modal.useModal)();
const { setModified } = (0, _context.useForm)();
const { localization, routes: { api }, serverURL } = (0, _Config.useConfig)();
const { routes: { admin } } = (0, _Config.useConfig)();
const [hasClicked, setHasClicked] = (0, _react.useState)(false);
const { i18n, t } = (0, _reacti18next.useTranslation)('general');
const modalSlug = `duplicate-${id}`;
const handleClick = (0, _react.useCallback)(async (override = false)=>{
setHasClicked(true);
if (modified && !override) {
toggleModal(modalSlug);
return;
}
const saveDocument = async ({ id, duplicateID = '', locale = '' })=>{
const response = await _api.requests.get(`${serverURL}${api}/${slug}/${id}`, {
headers: {
'Accept-Language': i18n.language
},
params: {
depth: 0,
draft: true,
'fallback-locale': 'none',
locale
}
});
let data = await response.json();
if (typeof collection.admin.hooks?.beforeDuplicate === 'function') {
data = await collection.admin.hooks.beforeDuplicate({
collection,
data,
locale
});
}
if (!duplicateID) {
if ('createdAt' in data) delete data.createdAt;
if ('updatedAt' in data) delete data.updatedAt;
}
const result = await _api.requests[duplicateID ? 'patch' : 'post'](`${serverURL}${api}/${slug}/${duplicateID}?locale=${locale}&fallback-locale=none`, {
body: JSON.stringify(data),
headers: {
'Accept-Language': i18n.language,
'Content-Type': 'application/json'
}
});
const json = await result.json();
if (result.status === 201 || result.status === 200) {
return json.doc.id;
}
// only show the error if this is the initial request failing
if (!duplicateID) {
json.errors.forEach((error)=>_reacttoastify.toast.error(error.message));
}
return null;
};
let duplicateID;
let abort = false;
const localeErrors = [];
if (localization) {
await localization.localeCodes.reduce(async (priorLocalePatch, locale)=>{
await priorLocalePatch;
if (abort) return;
const localeResult = await saveDocument({
id,
duplicateID,
locale
});
duplicateID = localeResult || duplicateID;
if (duplicateID && !localeResult) {
localeErrors.push(locale);
}
if (!duplicateID) {
abort = true;
}
}, Promise.resolve());
} else {
duplicateID = await saveDocument({
id
});
}
if (!duplicateID) {
// document was not saved, error toast was displayed
return;
}
_reacttoastify.toast.success(t('successfullyDuplicated', {
label: (0, _getTranslation.getTranslation)(collection.labels.singular, i18n)
}), {
autoClose: 3000
});
if (localeErrors.length > 0) {
_reacttoastify.toast.error(`
${t('error:localesNotSaved', {
count: localeErrors.length
})}
${localeErrors.join(', ')}
`, {
autoClose: 5000
});
}
setModified(false);
setTimeout(()=>{
push({
pathname: `${admin}/collections/${slug}/${duplicateID}`
});
}, 10);
}, [
modified,
localization,
t,
i18n,
collection,
setModified,
toggleModal,
modalSlug,
serverURL,
api,
slug,
id,
push,
admin
]);
const confirm = (0, _react.useCallback)(async ()=>{
setHasClicked(false);
await handleClick(true);
}, [
handleClick
]);
return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(_PopupButtonList.Button, {
id: "action-duplicate",
onClick: ()=>handleClick(false)
}, t('duplicate')), modified && hasClicked && /*#__PURE__*/ _react.default.createElement(_modal.Modal, {
className: `${baseClass}__modal`,
slug: modalSlug
}, /*#__PURE__*/ _react.default.createElement(_Minimal.default, {
className: `${baseClass}__modal-template`
}, /*#__PURE__*/ _react.default.createElement("h1", null, t('confirmDuplication')), /*#__PURE__*/ _react.default.createElement("p", null, t('unsavedChangesDuplicate')), /*#__PURE__*/ _react.default.createElement(_Button.default, {
buttonStyle: "secondary",
id: "confirm-cancel",
onClick: ()=>toggleModal(modalSlug),
type: "button"
}, t('cancel')), /*#__PURE__*/ _react.default.createElement(_Button.default, {
id: "confirm-duplicate",
onClick: confirm
}, t('duplicateWithoutSaving')))));
};
const _default = Duplicate;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/DuplicateDocument/index.tsx"],"sourcesContent":["import { Modal, useModal } from '@faceless-ui/modal'\nimport React, { useCallback, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useHistory } from 'react-router-dom'\nimport { toast } from 'react-toastify'\n\nimport type { Props } from './types'\n\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport { requests } from '../../../api'\nimport { useForm, useFormModified } from '../../forms/Form/context'\nimport MinimalTemplate from '../../templates/Minimal'\nimport { useConfig } from '../../utilities/Config'\nimport Button from '../Button'\nimport * as PopupList from '../Popup/PopupButtonList'\nimport './index.scss'\n\nconst baseClass = 'duplicate'\n\nconst Duplicate: React.FC<Props> = ({ id, collection, slug }) => {\n  const { push } = useHistory()\n  const modified = useFormModified()\n  const { toggleModal } = useModal()\n  const { setModified } = useForm()\n  const {\n    localization,\n    routes: { api },\n    serverURL,\n  } = useConfig()\n  const {\n    routes: { admin },\n  } = useConfig()\n  const [hasClicked, setHasClicked] = useState<boolean>(false)\n  const { i18n, t } = useTranslation('general')\n\n  const modalSlug = `duplicate-${id}`\n\n  const handleClick = useCallback(\n    async (override = false) => {\n      setHasClicked(true)\n\n      if (modified && !override) {\n        toggleModal(modalSlug)\n        return\n      }\n\n      const saveDocument = async ({\n        id,\n        duplicateID = '',\n        locale = '',\n      }): Promise<null | string> => {\n        const response = await requests.get(`${serverURL}${api}/${slug}/${id}`, {\n          headers: {\n            'Accept-Language': i18n.language,\n          },\n          params: {\n            depth: 0,\n            draft: true,\n            'fallback-locale': 'none',\n            locale,\n          },\n        })\n        let data = await response.json()\n\n        if (typeof collection.admin.hooks?.beforeDuplicate === 'function') {\n          data = await collection.admin.hooks.beforeDuplicate({\n            collection,\n            data,\n            locale,\n          })\n        }\n\n        if (!duplicateID) {\n          if ('createdAt' in data) delete data.createdAt\n          if ('updatedAt' in data) delete data.updatedAt\n        }\n\n        const result = await requests[duplicateID ? 'patch' : 'post'](\n          `${serverURL}${api}/${slug}/${duplicateID}?locale=${locale}&fallback-locale=none`,\n          {\n            body: JSON.stringify(data),\n            headers: {\n              'Accept-Language': i18n.language,\n              'Content-Type': 'application/json',\n            },\n          },\n        )\n        const json = await result.json()\n\n        if (result.status === 201 || result.status === 200) {\n          return json.doc.id\n        }\n\n        // only show the error if this is the initial request failing\n        if (!duplicateID) {\n          json.errors.forEach((error) => toast.error(error.message))\n        }\n        return null\n      }\n\n      let duplicateID: string\n      let abort = false\n      const localeErrors = []\n\n      if (localization) {\n        await localization.localeCodes.reduce(async (priorLocalePatch, locale) => {\n          await priorLocalePatch\n          if (abort) return\n          const localeResult = await saveDocument({\n            id,\n            duplicateID,\n            locale,\n          })\n          duplicateID = localeResult || duplicateID\n          if (duplicateID && !localeResult) {\n            localeErrors.push(locale)\n          }\n          if (!duplicateID) {\n            abort = true\n          }\n        }, Promise.resolve())\n      } else {\n        duplicateID = await saveDocument({ id })\n      }\n\n      if (!duplicateID) {\n        // document was not saved, error toast was displayed\n        return\n      }\n\n      toast.success(\n        t('successfullyDuplicated', { label: getTranslation(collection.labels.singular, i18n) }),\n        { autoClose: 3000 },\n      )\n\n      if (localeErrors.length > 0) {\n        toast.error(\n          `\n          ${t('error:localesNotSaved', { count: localeErrors.length })}\n          ${localeErrors.join(', ')}\n          `,\n          { autoClose: 5000 },\n        )\n      }\n\n      setModified(false)\n\n      setTimeout(() => {\n        push({\n          pathname: `${admin}/collections/${slug}/${duplicateID}`,\n        })\n      }, 10)\n    },\n    [\n      modified,\n      localization,\n      t,\n      i18n,\n      collection,\n      setModified,\n      toggleModal,\n      modalSlug,\n      serverURL,\n      api,\n      slug,\n      id,\n      push,\n      admin,\n    ],\n  )\n\n  const confirm = useCallback(async () => {\n    setHasClicked(false)\n    await handleClick(true)\n  }, [handleClick])\n\n  return (\n    <React.Fragment>\n      <PopupList.Button id=\"action-duplicate\" onClick={() => handleClick(false)}>\n        {t('duplicate')}\n      </PopupList.Button>\n      {modified && hasClicked && (\n        <Modal className={`${baseClass}__modal`} slug={modalSlug}>\n          <MinimalTemplate className={`${baseClass}__modal-template`}>\n            <h1>{t('confirmDuplication')}</h1>\n            <p>{t('unsavedChangesDuplicate')}</p>\n            <Button\n              buttonStyle=\"secondary\"\n              id=\"confirm-cancel\"\n              onClick={() => toggleModal(modalSlug)}\n              type=\"button\"\n            >\n              {t('cancel')}\n            </Button>\n            <Button id=\"confirm-duplicate\" onClick={confirm}>\n              {t('duplicateWithoutSaving')}\n            </Button>\n          </MinimalTemplate>\n        </Modal>\n      )}\n    </React.Fragment>\n  )\n}\n\nexport default Duplicate\n"],"names":["baseClass","Duplicate","id","collection","slug","push","useHistory","modified","useFormModified","toggleModal","useModal","setModified","useForm","localization","routes","api","serverURL","useConfig","admin","hasClicked","setHasClicked","useState","i18n","t","useTranslation","modalSlug","handleClick","useCallback","override","saveDocument","duplicateID","locale","response","requests","get","headers","language","params","depth","draft","data","json","hooks","beforeDuplicate","createdAt","updatedAt","result","body","JSON","stringify","status","doc","errors","forEach","error","toast","message","abort","localeErrors","localeCodes","reduce","priorLocalePatch","localeResult","Promise","resolve","success","label","getTranslation","labels","singular","autoClose","length","count","join","setTimeout","pathname","confirm","React","Fragment","PopupList","Button","onClick","Modal","className","MinimalTemplate","h1","p","buttonStyle","type"],"mappings":"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"}