payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
206 lines (205 loc) • 23.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 _reacttoastify = require("react-toastify");
const _ = require("../..");
const _api = require("../../../api");
const _context = require("../../forms/Form/context");
const _Config = require("../../utilities/Config");
const _DocumentInfo = require("../../utilities/DocumentInfo");
const _Locale = require("../../utilities/Locale");
const _Button = /*#__PURE__*/ _interop_require_default(require("../Button"));
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 = 'status';
const Status = ()=>{
const { id, collection, docPermissions, getVersions, global, publishedDoc, unpublishedVersions } = (0, _DocumentInfo.useDocumentInfo)();
const { toggleModal } = (0, _modal.useModal)();
const { routes: { api }, serverURL } = (0, _Config.useConfig)();
const [processing, setProcessing] = (0, _react.useState)(false);
const { reset: resetForm } = (0, _context.useForm)();
const { code: locale } = (0, _Locale.useLocale)();
const { i18n, t } = (0, _reacti18next.useTranslation)('version');
const unPublishModalSlug = `confirm-un-publish-${id}`;
const revertModalSlug = `confirm-revert-${id}`;
let statusToRender;
if (unpublishedVersions?.docs?.length > 0 && publishedDoc) {
statusToRender = 'changed';
} else if (!publishedDoc) {
statusToRender = 'draft';
} else if (publishedDoc && unpublishedVersions?.docs?.length <= 1) {
statusToRender = 'published';
}
const performAction = (0, _react.useCallback)(async (action)=>{
let url;
let method;
let body;
setProcessing(true);
if (action === 'unpublish') {
body = {
_status: 'draft'
};
}
if (action === 'revert') {
body = publishedDoc;
}
if (collection) {
url = `${serverURL}${api}/${collection.slug}/${id}?locale=${locale}&fallback-locale=null`;
method = 'patch';
}
if (global) {
url = `${serverURL}${api}/globals/${global.slug}?locale=${locale}&fallback-locale=null`;
method = 'post';
}
const res = await _api.requests[method](url, {
body: JSON.stringify(body),
headers: {
'Accept-Language': i18n.language,
'Content-Type': 'application/json'
}
});
if (res.status === 200) {
let data;
let fields;
const json = await res.json();
if (global) {
data = json.result;
fields = global.fields;
}
if (collection) {
data = json.doc;
fields = collection.fields;
}
resetForm(fields, data);
_reacttoastify.toast.success(json.message);
getVersions();
} else {
_reacttoastify.toast.error(t('error:unPublishingDocument'));
}
setProcessing(false);
if (action === 'revert') {
toggleModal(revertModalSlug);
}
if (action === 'unpublish') {
toggleModal(unPublishModalSlug);
}
}, [
collection,
global,
publishedDoc,
serverURL,
api,
id,
i18n,
locale,
resetForm,
getVersions,
t,
toggleModal,
revertModalSlug,
unPublishModalSlug
]);
const canUpdate = docPermissions?.update?.permission;
if (statusToRender) {
return /*#__PURE__*/ _react.default.createElement("div", {
className: baseClass,
title: `${t('status')}: ${t(statusToRender)}`
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__value-wrap`
}, /*#__PURE__*/ _react.default.createElement("span", {
className: `${baseClass}__label`
}, t('status'), ": "), /*#__PURE__*/ _react.default.createElement("span", {
className: `${baseClass}__value`
}, t(statusToRender)), canUpdate && statusToRender === 'published' && /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, " — ", /*#__PURE__*/ _react.default.createElement(_Button.default, {
buttonStyle: "none",
className: `${baseClass}__action`,
onClick: ()=>toggleModal(unPublishModalSlug)
}, t('unpublish')), /*#__PURE__*/ _react.default.createElement(_modal.Modal, {
className: `${baseClass}__modal`,
slug: unPublishModalSlug
}, /*#__PURE__*/ _react.default.createElement(_.MinimalTemplate, {
className: `${baseClass}__modal-template`
}, /*#__PURE__*/ _react.default.createElement("h1", null, t('confirmUnpublish')), /*#__PURE__*/ _react.default.createElement("p", null, t('aboutToUnpublish')), /*#__PURE__*/ _react.default.createElement(_Button.default, {
buttonStyle: "secondary",
onClick: processing ? undefined : ()=>toggleModal(unPublishModalSlug),
type: "button"
}, t('general:cancel')), /*#__PURE__*/ _react.default.createElement(_Button.default, {
onClick: processing ? undefined : ()=>performAction('unpublish')
}, t(processing ? 'unpublishing' : 'general:confirm'))))), canUpdate && statusToRender === 'changed' && /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, " — ", /*#__PURE__*/ _react.default.createElement(_Button.default, {
buttonStyle: "none",
className: `${baseClass}__action`,
id: "action-revert-to-published",
onClick: ()=>toggleModal(revertModalSlug)
}, t('revertToPublished')), /*#__PURE__*/ _react.default.createElement(_modal.Modal, {
className: `${baseClass}__modal`,
slug: revertModalSlug
}, /*#__PURE__*/ _react.default.createElement(_.MinimalTemplate, {
className: `${baseClass}__modal-template`
}, /*#__PURE__*/ _react.default.createElement("h1", null, t('confirmRevertToSaved')), /*#__PURE__*/ _react.default.createElement("p", null, t('aboutToRevertToPublished')), /*#__PURE__*/ _react.default.createElement(_Button.default, {
buttonStyle: "secondary",
onClick: processing ? undefined : ()=>toggleModal(revertModalSlug),
type: "button"
}, t('general:cancel')), /*#__PURE__*/ _react.default.createElement(_Button.default, {
id: "action-revert-to-published-confirm",
onClick: processing ? undefined : ()=>performAction('revert')
}, t(processing ? 'reverting' : 'general:confirm')))))));
}
return null;
};
const _default = Status;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/Status/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 { Field } from '../../../../fields/config/types'\n\nimport { MinimalTemplate } from '../..'\nimport { requests } from '../../../api'\nimport { useForm } from '../../forms/Form/context'\nimport { useConfig } from '../../utilities/Config'\nimport { useDocumentInfo } from '../../utilities/DocumentInfo'\nimport { useLocale } from '../../utilities/Locale'\nimport Button from '../Button'\nimport './index.scss'\n\nconst baseClass = 'status'\n\nconst Status: React.FC = () => {\n  const { id, collection, docPermissions, getVersions, global, publishedDoc, unpublishedVersions } =\n    useDocumentInfo()\n  const { toggleModal } = useModal()\n  const {\n    routes: { api },\n    serverURL,\n  } = useConfig()\n  const [processing, setProcessing] = useState(false)\n  const { reset: resetForm } = useForm()\n  const { code: locale } = useLocale()\n  const { i18n, t } = useTranslation('version')\n\n  const unPublishModalSlug = `confirm-un-publish-${id}`\n  const revertModalSlug = `confirm-revert-${id}`\n\n  let statusToRender\n\n  if (unpublishedVersions?.docs?.length > 0 && publishedDoc) {\n    statusToRender = 'changed'\n  } else if (!publishedDoc) {\n    statusToRender = 'draft'\n  } else if (publishedDoc && unpublishedVersions?.docs?.length <= 1) {\n    statusToRender = 'published'\n  }\n\n  const performAction = useCallback(\n    async (action: 'revert' | 'unpublish') => {\n      let url\n      let method\n      let body\n\n      setProcessing(true)\n\n      if (action === 'unpublish') {\n        body = {\n          _status: 'draft',\n        }\n      }\n\n      if (action === 'revert') {\n        body = publishedDoc\n      }\n\n      if (collection) {\n        url = `${serverURL}${api}/${collection.slug}/${id}?locale=${locale}&fallback-locale=null`\n        method = 'patch'\n      }\n      if (global) {\n        url = `${serverURL}${api}/globals/${global.slug}?locale=${locale}&fallback-locale=null`\n        method = 'post'\n      }\n\n      const res = await requests[method](url, {\n        body: JSON.stringify(body),\n        headers: {\n          'Accept-Language': i18n.language,\n          'Content-Type': 'application/json',\n        },\n      })\n\n      if (res.status === 200) {\n        let data\n        let fields: Field[]\n        const json = await res.json()\n\n        if (global) {\n          data = json.result\n          fields = global.fields\n        }\n\n        if (collection) {\n          data = json.doc\n          fields = collection.fields\n        }\n\n        resetForm(fields, data)\n        toast.success(json.message)\n        getVersions()\n      } else {\n        toast.error(t('error:unPublishingDocument'))\n      }\n\n      setProcessing(false)\n      if (action === 'revert') {\n        toggleModal(revertModalSlug)\n      }\n\n      if (action === 'unpublish') {\n        toggleModal(unPublishModalSlug)\n      }\n    },\n    [\n      collection,\n      global,\n      publishedDoc,\n      serverURL,\n      api,\n      id,\n      i18n,\n      locale,\n      resetForm,\n      getVersions,\n      t,\n      toggleModal,\n      revertModalSlug,\n      unPublishModalSlug,\n    ],\n  )\n\n  const canUpdate = docPermissions?.update?.permission\n\n  if (statusToRender) {\n    return (\n      <div className={baseClass} title={`${t('status')}: ${t(statusToRender)}`}>\n        <div className={`${baseClass}__value-wrap`}>\n          <span className={`${baseClass}__label`}>{t('status')}:&nbsp;</span>\n          <span className={`${baseClass}__value`}>{t(statusToRender)}</span>\n          {canUpdate && statusToRender === 'published' && (\n            <React.Fragment>\n              &nbsp;&mdash;&nbsp;\n              <Button\n                buttonStyle=\"none\"\n                className={`${baseClass}__action`}\n                onClick={() => toggleModal(unPublishModalSlug)}\n              >\n                {t('unpublish')}\n              </Button>\n              <Modal className={`${baseClass}__modal`} slug={unPublishModalSlug}>\n                <MinimalTemplate className={`${baseClass}__modal-template`}>\n                  <h1>{t('confirmUnpublish')}</h1>\n                  <p>{t('aboutToUnpublish')}</p>\n                  <Button\n                    buttonStyle=\"secondary\"\n                    onClick={processing ? undefined : () => toggleModal(unPublishModalSlug)}\n                    type=\"button\"\n                  >\n                    {t('general:cancel')}\n                  </Button>\n                  <Button onClick={processing ? undefined : () => performAction('unpublish')}>\n                    {t(processing ? 'unpublishing' : 'general:confirm')}\n                  </Button>\n                </MinimalTemplate>\n              </Modal>\n            </React.Fragment>\n          )}\n          {canUpdate && statusToRender === 'changed' && (\n            <React.Fragment>\n              &nbsp;&mdash;&nbsp;\n              <Button\n                buttonStyle=\"none\"\n                className={`${baseClass}__action`}\n                id=\"action-revert-to-published\"\n                onClick={() => toggleModal(revertModalSlug)}\n              >\n                {t('revertToPublished')}\n              </Button>\n              <Modal className={`${baseClass}__modal`} slug={revertModalSlug}>\n                <MinimalTemplate className={`${baseClass}__modal-template`}>\n                  <h1>{t('confirmRevertToSaved')}</h1>\n                  <p>{t('aboutToRevertToPublished')}</p>\n                  <Button\n                    buttonStyle=\"secondary\"\n                    onClick={processing ? undefined : () => toggleModal(revertModalSlug)}\n                    type=\"button\"\n                  >\n                    {t('general:cancel')}\n                  </Button>\n                  <Button\n                    id=\"action-revert-to-published-confirm\"\n                    onClick={processing ? undefined : () => performAction('revert')}\n                  >\n                    {t(processing ? 'reverting' : 'general:confirm')}\n                  </Button>\n                </MinimalTemplate>\n              </Modal>\n            </React.Fragment>\n          )}\n        </div>\n      </div>\n    )\n  }\n\n  return null\n}\n\nexport default Status\n"],"names":["baseClass","Status","id","collection","docPermissions","getVersions","global","publishedDoc","unpublishedVersions","useDocumentInfo","toggleModal","useModal","routes","api","serverURL","useConfig","processing","setProcessing","useState","reset","resetForm","useForm","code","locale","useLocale","i18n","t","useTranslation","unPublishModalSlug","revertModalSlug","statusToRender","docs","length","performAction","useCallback","action","url","method","body","_status","slug","res","requests","JSON","stringify","headers","language","status","data","fields","json","result","doc","toast","success","message","error","canUpdate","update","permission","div","className","title","span","React","Fragment","Button","buttonStyle","onClick","Modal","MinimalTemplate","h1","p","undefined","type"],"mappings":"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"}