payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
161 lines (160 loc) • 15.2 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 _reacttoastify = require("react-toastify");
const _getTranslation = require("../../../../utilities/getTranslation");
const _api = require("../../../api");
const _Minimal = /*#__PURE__*/ _interop_require_default(require("../../templates/Minimal"));
const _Auth = require("../../utilities/Auth");
const _Config = require("../../utilities/Config");
const _SelectionProvider = require("../../views/collections/List/SelectionProvider");
const _Button = /*#__PURE__*/ _interop_require_default(require("../Button"));
const _Pill = /*#__PURE__*/ _interop_require_default(require("../Pill"));
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-documents';
const DeleteMany = (props)=>{
const { collection: { labels: { plural }, slug } = {}, resetParams } = props;
const { permissions } = (0, _Auth.useAuth)();
const { routes: { api }, serverURL } = (0, _Config.useConfig)();
const { toggleModal } = (0, _modal.useModal)();
const { count, getQueryParams, selectAll, toggleAll } = (0, _SelectionProvider.useSelection)();
const { i18n, t } = (0, _reacti18next.useTranslation)('general');
const [deleting, setDeleting] = (0, _react.useState)(false);
const collectionPermissions = permissions?.collections?.[slug];
const hasDeletePermission = collectionPermissions?.delete?.permission;
const modalSlug = `delete-${slug}`;
const addDefaultError = (0, _react.useCallback)(()=>{
_reacttoastify.toast.error(t('error:unknown'));
}, [
t
]);
const handleDelete = (0, _react.useCallback)(()=>{
setDeleting(true);
_api.requests.delete(`${serverURL}${api}/${slug}${getQueryParams()}`, {
headers: {
'Accept-Language': i18n.language,
'Content-Type': 'application/json'
}
}).then(async (res)=>{
try {
const json = await res.json();
toggleModal(modalSlug);
if (res.status < 400) {
_reacttoastify.toast.success(json.message || t('deletedSuccessfully'), {
autoClose: 3000
});
toggleAll();
resetParams({
page: selectAll ? 1 : undefined
});
return null;
}
if (json.errors) {
_reacttoastify.toast.error(json.message);
} else {
addDefaultError();
}
return false;
} catch (e) {
return addDefaultError();
}
});
}, [
addDefaultError,
api,
getQueryParams,
i18n.language,
modalSlug,
resetParams,
selectAll,
serverURL,
slug,
t,
toggleAll,
toggleModal
]);
if (selectAll === _SelectionProvider.SelectAllStatus.None || !hasDeletePermission) {
return null;
}
return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(_Pill.default, {
className: `${baseClass}__toggle`,
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, t('aboutToDeleteCount', {
count,
label: (0, _getTranslation.getTranslation)(plural, i18n)
})), /*#__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')))));
};
const _default = DeleteMany;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/DeleteMany/index.tsx"],"sourcesContent":["import { Modal, useModal } from '@faceless-ui/modal'\nimport React, { useCallback, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { toast } from 'react-toastify'\n\nimport type { Props } from './types'\n\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport { requests } from '../../../api'\nimport MinimalTemplate from '../../templates/Minimal'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport { SelectAllStatus, useSelection } from '../../views/collections/List/SelectionProvider'\nimport Button from '../Button'\nimport Pill from '../Pill'\nimport './index.scss'\n\nconst baseClass = 'delete-documents'\n\nconst DeleteMany: React.FC<Props> = (props) => {\n  const { collection: { labels: { plural }, slug } = {}, resetParams } = props\n\n  const { permissions } = useAuth()\n  const {\n    routes: { api },\n    serverURL,\n  } = useConfig()\n  const { toggleModal } = useModal()\n  const { count, getQueryParams, selectAll, toggleAll } = useSelection()\n  const { i18n, t } = useTranslation('general')\n  const [deleting, setDeleting] = useState(false)\n\n  const collectionPermissions = permissions?.collections?.[slug]\n  const hasDeletePermission = collectionPermissions?.delete?.permission\n\n  const modalSlug = `delete-${slug}`\n\n  const addDefaultError = useCallback(() => {\n    toast.error(t('error:unknown'))\n  }, [t])\n\n  const handleDelete = useCallback(() => {\n    setDeleting(true)\n    requests\n      .delete(`${serverURL}${api}/${slug}${getQueryParams()}`, {\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          toggleModal(modalSlug)\n          if (res.status < 400) {\n            toast.success(json.message || t('deletedSuccessfully'), { autoClose: 3000 })\n            toggleAll()\n            resetParams({ page: selectAll ? 1 : undefined })\n            return null\n          }\n\n          if (json.errors) {\n            toast.error(json.message)\n          } else {\n            addDefaultError()\n          }\n          return false\n        } catch (e) {\n          return addDefaultError()\n        }\n      })\n  }, [\n    addDefaultError,\n    api,\n    getQueryParams,\n    i18n.language,\n    modalSlug,\n    resetParams,\n    selectAll,\n    serverURL,\n    slug,\n    t,\n    toggleAll,\n    toggleModal,\n  ])\n\n  if (selectAll === SelectAllStatus.None || !hasDeletePermission) {\n    return null\n  }\n\n  return (\n    <React.Fragment>\n      <Pill\n        className={`${baseClass}__toggle`}\n        onClick={() => {\n          setDeleting(false)\n          toggleModal(modalSlug)\n        }}\n      >\n        {t('delete')}\n      </Pill>\n      <Modal className={baseClass} slug={modalSlug}>\n        <MinimalTemplate className={`${baseClass}__template`}>\n          <h1>{t('confirmDeletion')}</h1>\n          <p>{t('aboutToDeleteCount', { count, label: getTranslation(plural, i18n) })}</p>\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        </MinimalTemplate>\n      </Modal>\n    </React.Fragment>\n  )\n}\n\nexport default DeleteMany\n"],"names":["baseClass","DeleteMany","props","collection","labels","plural","slug","resetParams","permissions","useAuth","routes","api","serverURL","useConfig","toggleModal","useModal","count","getQueryParams","selectAll","toggleAll","useSelection","i18n","t","useTranslation","deleting","setDeleting","useState","collectionPermissions","collections","hasDeletePermission","delete","permission","modalSlug","addDefaultError","useCallback","toast","error","handleDelete","requests","headers","language","then","res","json","status","success","message","autoClose","page","undefined","errors","e","SelectAllStatus","None","React","Fragment","Pill","className","onClick","Modal","MinimalTemplate","h1","p","label","getTranslation","Button","buttonStyle","id","type"],"mappings":"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"}