UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

163 lines (162 loc) • 15.7 kB
"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 _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 = 'unpublish-many'; const UnpublishMany = (props)=>{ const { collection: { labels: { plural }, slug, versions } = {}, resetParams } = props; const { routes: { api }, serverURL } = (0, _Config.useConfig)(); const { permissions } = (0, _Auth.useAuth)(); const { toggleModal } = (0, _modal.useModal)(); const { i18n, t } = (0, _reacti18next.useTranslation)('version'); const { count, getQueryParams, selectAll } = (0, _SelectionProvider.useSelection)(); const [submitted, setSubmitted] = (0, _react.useState)(false); const collectionPermissions = permissions?.collections?.[slug]; const hasPermission = collectionPermissions?.update?.permission; const modalSlug = `unpublish-${slug}`; const addDefaultError = (0, _react.useCallback)(()=>{ _reacttoastify.toast.error(t('error:unknown')); }, [ t ]); const handleUnpublish = (0, _react.useCallback)(()=>{ setSubmitted(true); _api.requests.patch(`${serverURL}${api}/${slug}${getQueryParams({ _status: { not_equals: 'draft' } })}`, { body: JSON.stringify({ _status: 'draft' }), 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(t('general:updatedSuccessfully')); resetParams({ page: selectAll ? 1 : undefined }); return null; } if (json.errors) { json.errors.forEach((error)=>_reacttoastify.toast.error(error.message)); } else { addDefaultError(); } return false; } catch (e) { return addDefaultError(); } }); }, [ addDefaultError, api, getQueryParams, i18n.language, modalSlug, resetParams, selectAll, serverURL, slug, t, toggleModal ]); if (!versions?.drafts || selectAll === _SelectionProvider.SelectAllStatus.None || !hasPermission) { return null; } return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(_Pill.default, { className: `${baseClass}__toggle`, onClick: ()=>{ setSubmitted(false); toggleModal(modalSlug); } }, t('unpublish')), /*#__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('confirmUnpublish')), /*#__PURE__*/ _react.default.createElement("p", null, t('aboutToUnpublishSelection', { label: (0, _getTranslation.getTranslation)(plural, i18n) })), /*#__PURE__*/ _react.default.createElement(_Button.default, { buttonStyle: "secondary", id: "confirm-cancel", onClick: submitted ? undefined : ()=>toggleModal(modalSlug), type: "button" }, t('general:cancel')), /*#__PURE__*/ _react.default.createElement(_Button.default, { id: "confirm-unpublish", onClick: submitted ? undefined : handleUnpublish }, submitted ? t('unpublishing') : t('general:confirm'))))); }; const _default = UnpublishMany; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/UnpublishMany/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 = 'unpublish-many'\n\nconst UnpublishMany: React.FC<Props> = (props) => {\n  const { collection: { labels: { plural }, slug, versions } = {}, resetParams } = props\n\n  const {\n    routes: { api },\n    serverURL,\n  } = useConfig()\n  const { permissions } = useAuth()\n  const { toggleModal } = useModal()\n  const { i18n, t } = useTranslation('version')\n  const { count, getQueryParams, selectAll } = useSelection()\n  const [submitted, setSubmitted] = useState(false)\n\n  const collectionPermissions = permissions?.collections?.[slug]\n  const hasPermission = collectionPermissions?.update?.permission\n\n  const modalSlug = `unpublish-${slug}`\n\n  const addDefaultError = useCallback(() => {\n    toast.error(t('error:unknown'))\n  }, [t])\n\n  const handleUnpublish = useCallback(() => {\n    setSubmitted(true)\n    requests\n      .patch(`${serverURL}${api}/${slug}${getQueryParams({ _status: { not_equals: 'draft' } })}`, {\n        body: JSON.stringify({\n          _status: 'draft',\n        }),\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(t('general:updatedSuccessfully'))\n            resetParams({ page: selectAll ? 1 : undefined })\n            return null\n          }\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  }, [\n    addDefaultError,\n    api,\n    getQueryParams,\n    i18n.language,\n    modalSlug,\n    resetParams,\n    selectAll,\n    serverURL,\n    slug,\n    t,\n    toggleModal,\n  ])\n\n  if (!versions?.drafts || selectAll === SelectAllStatus.None || !hasPermission) {\n    return null\n  }\n\n  return (\n    <React.Fragment>\n      <Pill\n        className={`${baseClass}__toggle`}\n        onClick={() => {\n          setSubmitted(false)\n          toggleModal(modalSlug)\n        }}\n      >\n        {t('unpublish')}\n      </Pill>\n      <Modal className={baseClass} slug={modalSlug}>\n        <MinimalTemplate className={`${baseClass}__template`}>\n          <h1>{t('confirmUnpublish')}</h1>\n          <p>{t('aboutToUnpublishSelection', { label: getTranslation(plural, i18n) })}</p>\n          <Button\n            buttonStyle=\"secondary\"\n            id=\"confirm-cancel\"\n            onClick={submitted ? undefined : () => toggleModal(modalSlug)}\n            type=\"button\"\n          >\n            {t('general:cancel')}\n          </Button>\n          <Button id=\"confirm-unpublish\" onClick={submitted ? undefined : handleUnpublish}>\n            {submitted ? t('unpublishing') : t('general:confirm')}\n          </Button>\n        </MinimalTemplate>\n      </Modal>\n    </React.Fragment>\n  )\n}\n\nexport default UnpublishMany\n"],"names":["baseClass","UnpublishMany","props","collection","labels","plural","slug","versions","resetParams","routes","api","serverURL","useConfig","permissions","useAuth","toggleModal","useModal","i18n","t","useTranslation","count","getQueryParams","selectAll","useSelection","submitted","setSubmitted","useState","collectionPermissions","collections","hasPermission","update","permission","modalSlug","addDefaultError","useCallback","toast","error","handleUnpublish","requests","patch","_status","not_equals","body","JSON","stringify","headers","language","then","res","json","status","success","page","undefined","errors","forEach","message","e","drafts","SelectAllStatus","None","React","Fragment","Pill","className","onClick","Modal","MinimalTemplate","h1","p","label","getTranslation","Button","buttonStyle","id","type"],"mappings":"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"}