payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
180 lines (179 loc) • 17.3 kB
JavaScript
"use strict";
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 _useTitle = /*#__PURE__*/ _interop_require_default(require("../../../hooks/useTitle"));
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 = 'delete-document';
const DeleteDocument = (props)=>{
const { id, buttonId, collection: { labels: { singular } = {}, slug } = {}, collection, title: titleFromProps } = props;
const { routes: { admin, api }, serverURL } = (0, _Config.useConfig)();
const { setModified } = (0, _context.useForm)();
const [deleting, setDeleting] = (0, _react.useState)(false);
const { toggleModal } = (0, _modal.useModal)();
const history = (0, _reactrouterdom.useHistory)();
const { i18n, t } = (0, _reacti18next.useTranslation)('general');
const title = (0, _useTitle.default)({
collection
});
const titleToRender = titleFromProps || title || id;
const modalSlug = `delete-${id}`;
const addDefaultError = (0, _react.useCallback)(()=>{
setDeleting(false);
_reacttoastify.toast.error(t('error:deletingTitle', {
title
}));
}, [
t,
title
]);
const handleDelete = (0, _react.useCallback)(async ()=>{
setDeleting(true);
setModified(false);
try {
await _api.requests.delete(`${serverURL}${api}/${slug}/${id}`, {
headers: {
'Accept-Language': i18n.language,
'Content-Type': 'application/json'
}
}).then(async (res)=>{
try {
const json = await res.json();
if (res.status < 400) {
setDeleting(false);
toggleModal(modalSlug);
_reacttoastify.toast.success(json.message || t('titleDeleted', {
label: (0, _getTranslation.getTranslation)(singular, i18n),
title
}));
return history.push(`${admin}/collections/${slug}`);
}
toggleModal(modalSlug);
if (json.errors) {
json.errors.forEach((error)=>_reacttoastify.toast.error(error.message));
} else {
addDefaultError();
}
return false;
} catch (e) {
return addDefaultError();
}
});
} catch (e) {
addDefaultError();
}
}, [
setModified,
serverURL,
api,
slug,
id,
toggleModal,
modalSlug,
t,
singular,
i18n,
title,
history,
admin,
addDefaultError
]);
if (id) {
return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(_PopupButtonList.Button, {
id: buttonId,
onClick: ()=>{
setDeleting(false);
toggleModal(modalSlug);
}
}, t('delete')), /*#__PURE__*/ _react.default.createElement(_modal.Modal, {
className: baseClass,
slug: modalSlug
}, /*#__PURE__*/ _react.default.createElement(_Minimal.default, {
className: `${baseClass}__template`
}, /*#__PURE__*/ _react.default.createElement("h1", null, t('confirmDeletion')), /*#__PURE__*/ _react.default.createElement("p", null, /*#__PURE__*/ _react.default.createElement(_reacti18next.Trans, {
i18nKey: "aboutToDelete",
t: t,
values: {
label: (0, _getTranslation.getTranslation)(singular, i18n),
title: titleToRender
}
}, "aboutToDelete", /*#__PURE__*/ _react.default.createElement("strong", null, titleToRender))), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__actions`
}, /*#__PURE__*/ _react.default.createElement(_Button.default, {
buttonStyle: "secondary",
id: "confirm-cancel",
onClick: deleting ? undefined : ()=>toggleModal(modalSlug),
type: "button"
}, t('cancel')), /*#__PURE__*/ _react.default.createElement(_Button.default, {
id: "confirm-delete",
onClick: deleting ? undefined : handleDelete
}, deleting ? t('deleting') : t('confirm'))))));
}
return null;
};
const _default = DeleteDocument;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/DeleteDocument/index.tsx"],"sourcesContent":["import { Modal, useModal } from '@faceless-ui/modal'\nimport React, { useCallback, useState } from 'react'\nimport { Trans, 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 useTitle from '../../../hooks/useTitle'\nimport { useForm } 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 = 'delete-document'\n\nconst DeleteDocument: React.FC<Props> = (props) => {\n  const {\n    id,\n    buttonId,\n    collection: { labels: { singular } = {}, slug } = {},\n    collection,\n    title: titleFromProps,\n  } = props\n\n  const {\n    routes: { admin, api },\n    serverURL,\n  } = useConfig()\n\n  const { setModified } = useForm()\n  const [deleting, setDeleting] = useState(false)\n  const { toggleModal } = useModal()\n  const history = useHistory()\n  const { i18n, t } = useTranslation('general')\n  const title = useTitle({ collection })\n  const titleToRender = titleFromProps || title || id\n\n  const modalSlug = `delete-${id}`\n\n  const addDefaultError = useCallback(() => {\n    setDeleting(false)\n    toast.error(t('error:deletingTitle', { title }))\n  }, [t, title])\n\n  const handleDelete = useCallback(async () => {\n    setDeleting(true)\n    setModified(false)\n    try {\n      await requests\n        .delete(`${serverURL}${api}/${slug}/${id}`, {\n          headers: {\n            'Accept-Language': i18n.language,\n            'Content-Type': 'application/json',\n          },\n        })\n        .then(async (res) => {\n          try {\n            const json = await res.json()\n            if (res.status < 400) {\n              setDeleting(false)\n              toggleModal(modalSlug)\n              toast.success(json.message || t('titleDeleted', { label: getTranslation(singular, i18n), title }))\n              return history.push(`${admin}/collections/${slug}`)\n            }\n\n            toggleModal(modalSlug)\n\n            if (json.errors) {\n              json.errors.forEach((error) => toast.error(error.message))\n            } else {\n              addDefaultError()\n            }\n            return false\n          } catch (e) {\n            return addDefaultError()\n          }\n        })\n    } catch (e) {\n      addDefaultError()\n    }\n  }, [\n    setModified,\n    serverURL,\n    api,\n    slug,\n    id,\n    toggleModal,\n    modalSlug,\n    t,\n    singular,\n    i18n,\n    title,\n    history,\n    admin,\n    addDefaultError,\n  ])\n\n  if (id) {\n    return (\n      <React.Fragment>\n        <PopupList.Button\n          id={buttonId}\n          onClick={() => {\n            setDeleting(false)\n            toggleModal(modalSlug)\n          }}\n        >\n          {t('delete')}\n        </PopupList.Button>\n        <Modal className={baseClass} slug={modalSlug}>\n          <MinimalTemplate className={`${baseClass}__template`}>\n            <h1>{t('confirmDeletion')}</h1>\n            <p>\n              <Trans\n                i18nKey=\"aboutToDelete\"\n                t={t}\n                values={{ label: getTranslation(singular, i18n), title: titleToRender }}\n              >\n                aboutToDelete\n                <strong>{titleToRender}</strong>\n              </Trans>\n            </p>\n            <div className={`${baseClass}__actions`}>\n              <Button\n                buttonStyle=\"secondary\"\n                id=\"confirm-cancel\"\n                onClick={deleting ? undefined : () => toggleModal(modalSlug)}\n                type=\"button\"\n              >\n                {t('cancel')}\n              </Button>\n              <Button id=\"confirm-delete\" onClick={deleting ? undefined : handleDelete}>\n                {deleting ? t('deleting') : t('confirm')}\n              </Button>\n            </div>\n          </MinimalTemplate>\n        </Modal>\n      </React.Fragment>\n    )\n  }\n\n  return null\n}\n\nexport default DeleteDocument\n"],"names":["baseClass","DeleteDocument","props","id","buttonId","collection","labels","singular","slug","title","titleFromProps","routes","admin","api","serverURL","useConfig","setModified","useForm","deleting","setDeleting","useState","toggleModal","useModal","history","useHistory","i18n","t","useTranslation","useTitle","titleToRender","modalSlug","addDefaultError","useCallback","toast","error","handleDelete","requests","delete","headers","language","then","res","json","status","success","message","label","getTranslation","push","errors","forEach","e","React","Fragment","PopupList","Button","onClick","Modal","className","MinimalTemplate","h1","p","Trans","i18nKey","values","strong","div","buttonStyle","undefined","type"],"mappings":"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"}