payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
311 lines (310 loc) • 35.1 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reacti18next = require("react-i18next");
const _reactrouterdom = require("react-router-dom");
const _types = require("../../../../fields/config/types");
const _getTranslation = require("../../../../utilities/getTranslation");
const _usePayloadAPI = /*#__PURE__*/ _interop_require_default(require("../../../hooks/usePayloadAPI"));
const _formatDate = require("../../../utilities/formatDate");
const _Gutter = require("../../elements/Gutter");
const _StepNav = require("../../elements/StepNav");
const _ActionsProvider = require("../../utilities/ActionsProvider");
const _Auth = require("../../utilities/Auth");
const _Config = require("../../utilities/Config");
const _DocumentInfo = require("../../utilities/DocumentInfo");
const _Locale = require("../../utilities/Locale");
const _Meta = /*#__PURE__*/ _interop_require_default(require("../../utilities/Meta"));
const _NotFound = /*#__PURE__*/ _interop_require_default(require("../NotFound"));
const _Compare = /*#__PURE__*/ _interop_require_default(require("./Compare"));
const _RenderFieldsToDiff = /*#__PURE__*/ _interop_require_default(require("./RenderFieldsToDiff"));
const _fields = /*#__PURE__*/ _interop_require_default(require("./RenderFieldsToDiff/fields"));
const _Restore = /*#__PURE__*/ _interop_require_default(require("./Restore"));
const _SelectLocales = /*#__PURE__*/ _interop_require_default(require("./SelectLocales"));
require("./index.scss");
const _shared = require("./shared");
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 = 'view-version';
const VersionView = ({ collection, global })=>{
const { admin: { dateFormat }, localization, routes: { admin, api }, serverURL } = (0, _Config.useConfig)();
const { setStepNav } = (0, _StepNav.useStepNav)();
const { setViewActions } = (0, _ActionsProvider.useActions)();
const { params: { id, versionID } } = (0, _reactrouterdom.useRouteMatch)();
const [compareValue, setCompareValue] = (0, _react.useState)(_shared.mostRecentVersionOption);
const [localeOptions] = (0, _react.useState)(()=>{
if (localization && localization?.locales) {
return localization.locales.map(({ code, label })=>({
label: label,
value: code
}));
}
return [];
});
const [locales, setLocales] = (0, _react.useState)(localeOptions);
const { permissions } = (0, _Auth.useAuth)();
const { code: locale } = (0, _Locale.useLocale)();
const { i18n, t } = (0, _reacti18next.useTranslation)('version');
const { docPermissions } = (0, _DocumentInfo.useDocumentInfo)();
let originalDocFetchURL;
let versionFetchURL;
let entityLabel;
let fields;
let fieldPermissions;
let compareBaseURL;
let slug;
let parentID;
if (collection) {
({ slug } = collection);
originalDocFetchURL = `${serverURL}${api}/${slug}/${id}`;
versionFetchURL = `${serverURL}${api}/${slug}/versions/${versionID}`;
compareBaseURL = `${serverURL}${api}/${slug}/versions`;
entityLabel = (0, _getTranslation.getTranslation)(collection.labels.singular, i18n);
parentID = id;
fields = collection.fields;
fieldPermissions = permissions.collections[collection.slug].fields;
}
if (global) {
({ slug } = global);
originalDocFetchURL = `${serverURL}${api}/globals/${slug}`;
versionFetchURL = `${serverURL}${api}/globals/${slug}/versions/${versionID}`;
compareBaseURL = `${serverURL}${api}/globals/${slug}/versions`;
entityLabel = (0, _getTranslation.getTranslation)(global.label, i18n);
fields = global.fields;
fieldPermissions = permissions.globals[global.slug].fields;
}
const compareFetchURL = compareValue?.value === 'mostRecent' || compareValue?.value === 'published' ? originalDocFetchURL : `${compareBaseURL}/${compareValue.value}`;
const [{ data: doc, isError }] = (0, _usePayloadAPI.default)(versionFetchURL, {
initialParams: {
depth: 1,
locale: '*'
}
});
const [{ data: publishedDoc }] = (0, _usePayloadAPI.default)(originalDocFetchURL, {
initialParams: {
depth: 1,
locale: '*'
}
});
const [{ data: mostRecentDoc }] = (0, _usePayloadAPI.default)(originalDocFetchURL, {
initialParams: {
depth: 1,
draft: true,
locale: '*'
}
});
const [{ data: compareDoc }] = (0, _usePayloadAPI.default)(compareFetchURL, {
initialParams: {
depth: 1,
draft: 'true',
locale: '*'
}
});
(0, _react.useEffect)(()=>{
let nav = [];
if (collection) {
let docLabel = '';
if (mostRecentDoc) {
const { useAsTitle } = collection.admin;
if (useAsTitle !== 'id') {
const titleField = collection.fields.find((field)=>(0, _types.fieldAffectsData)(field) && field.name === useAsTitle);
if (titleField && mostRecentDoc[useAsTitle]) {
if (titleField.localized) {
docLabel = mostRecentDoc[useAsTitle]?.[locale];
} else {
docLabel = mostRecentDoc[useAsTitle];
}
} else {
docLabel = `[${t('general:untitled')}]`;
}
} else {
docLabel = mostRecentDoc.id;
}
}
nav = [
{
label: (0, _getTranslation.getTranslation)(collection.labels.plural, i18n),
url: `${admin}/collections/${collection.slug}`
},
{
label: docLabel,
url: `${admin}/collections/${collection.slug}/${id}`
},
{
label: 'Versions',
url: `${admin}/collections/${collection.slug}/${id}/versions`
},
{
label: doc?.createdAt ? (0, _formatDate.formatDate)(doc.createdAt, dateFormat, i18n?.language) : ''
}
];
}
if (global) {
nav = [
{
label: global.label,
url: `${admin}/globals/${global.slug}`
},
{
label: 'Versions',
url: `${admin}/globals/${global.slug}/versions`
},
{
label: doc?.createdAt ? (0, _formatDate.formatDate)(doc.createdAt, dateFormat, i18n?.language) : ''
}
];
}
setStepNav(nav);
}, [
setStepNav,
collection,
global,
dateFormat,
doc,
mostRecentDoc,
admin,
id,
locale,
t,
i18n
]);
(0, _react.useEffect)(()=>{
const editConfig = (collection || global)?.admin?.components?.views?.Edit;
const versionActions = editConfig && 'Version' in editConfig && 'actions' in editConfig.Version ? editConfig.Version.actions : [];
setViewActions(versionActions);
return ()=>{
setViewActions([]);
};
}, [
collection,
global,
setViewActions
]);
let metaTitle;
let metaDesc;
const formattedCreatedAt = doc?.createdAt ? (0, _formatDate.formatDate)(doc.createdAt, dateFormat, i18n?.language) : '';
if (collection) {
const useAsTitle = collection?.admin?.useAsTitle || 'id';
metaTitle = `${t('version')} - ${formattedCreatedAt} - ${doc[useAsTitle]} - ${entityLabel}`;
metaDesc = t('viewingVersion', {
documentTitle: doc[useAsTitle],
entityLabel
});
}
if (global) {
metaTitle = `${t('version')} - ${formattedCreatedAt} - ${entityLabel}`;
metaDesc = t('viewingVersionGlobal', {
entityLabel
});
}
let comparison = compareDoc?.version;
if (compareValue?.value === 'mostRecent') {
comparison = mostRecentDoc;
}
if (compareValue?.value === 'published') {
comparison = publishedDoc;
}
const canUpdate = docPermissions?.update?.permission;
if (isError) {
return /*#__PURE__*/ _react.default.createElement(_NotFound.default, {
marginTop: "large"
});
}
return /*#__PURE__*/ _react.default.createElement("main", {
className: baseClass
}, /*#__PURE__*/ _react.default.createElement(_Meta.default, {
description: metaDesc,
title: metaTitle
}), /*#__PURE__*/ _react.default.createElement(_Gutter.Gutter, {
className: `${baseClass}__wrap`
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__header-wrap`
}, /*#__PURE__*/ _react.default.createElement("p", {
className: `${baseClass}__created-at`
}, t('versionCreatedOn', {
version: t(doc?.autosave ? 'autosavedVersion' : 'version')
})), /*#__PURE__*/ _react.default.createElement("header", {
className: `${baseClass}__header`
}, /*#__PURE__*/ _react.default.createElement("h2", null, formattedCreatedAt), canUpdate && /*#__PURE__*/ _react.default.createElement(_Restore.default, {
className: `${baseClass}__restore`,
collection: collection,
global: global,
originalDocID: id,
versionDate: formattedCreatedAt,
versionID: versionID
}))), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__controls`
}, /*#__PURE__*/ _react.default.createElement(_Compare.default, {
baseURL: compareBaseURL,
onChange: setCompareValue,
parentID: parentID,
publishedDoc: publishedDoc,
value: compareValue,
versionID: versionID
}), localization && /*#__PURE__*/ _react.default.createElement(_SelectLocales.default, {
onChange: setLocales,
options: localeOptions,
value: locales
})), doc?.version && /*#__PURE__*/ _react.default.createElement(_RenderFieldsToDiff.default, {
comparison: comparison,
fieldComponents: _fields.default,
fieldPermissions: fieldPermissions,
fields: fields,
locales: locales ? locales.map(({ label })=>typeof label === 'string' ? label : undefined) : [],
version: doc?.version
})));
};
const _default = VersionView;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/views/Version/Version.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useRouteMatch } from 'react-router-dom'\n\nimport type { FieldPermissions } from '../../../../auth'\nimport type { Field, FieldAffectingData } from '../../../../fields/config/types'\nimport type { Option } from '../../elements/ReactSelect/types'\nimport type { StepNavItem } from '../../elements/StepNav/types'\nimport type { CompareOption, Props } from './types'\n\nimport { fieldAffectsData } from '../../../../fields/config/types'\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport usePayloadAPI from '../../../hooks/usePayloadAPI'\nimport { formatDate } from '../../../utilities/formatDate'\nimport { Gutter } from '../../elements/Gutter'\nimport { useStepNav } from '../../elements/StepNav'\nimport { useActions } from '../../utilities/ActionsProvider'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport { useDocumentInfo } from '../../utilities/DocumentInfo'\nimport { useLocale } from '../../utilities/Locale'\nimport Meta from '../../utilities/Meta'\nimport NotFound from '../NotFound'\nimport CompareVersion from './Compare'\nimport RenderFieldsToDiff from './RenderFieldsToDiff'\nimport fieldComponents from './RenderFieldsToDiff/fields'\nimport Restore from './Restore'\nimport SelectLocales from './SelectLocales'\nimport './index.scss'\nimport { mostRecentVersionOption } from './shared'\n\nconst baseClass = 'view-version'\n\nconst VersionView: React.FC<Props> = ({ collection, global }) => {\n  const {\n    admin: { dateFormat },\n    localization,\n    routes: { admin, api },\n    serverURL,\n  } = useConfig()\n  const { setStepNav } = useStepNav()\n\n  const { setViewActions } = useActions()\n\n  const {\n    params: { id, versionID },\n  } = useRouteMatch<{ id?: string; versionID: string }>()\n\n  const [compareValue, setCompareValue] = useState<CompareOption>(mostRecentVersionOption)\n  const [localeOptions] = useState<Option[]>(() => {\n    if (localization && localization?.locales) {\n      return localization.locales.map(({ code, label }) => ({\n        label: label,\n        value: code,\n      }))\n    }\n    return []\n  })\n  const [locales, setLocales] = useState<Option[]>(localeOptions)\n  const { permissions } = useAuth()\n  const { code: locale } = useLocale()\n  const { i18n, t } = useTranslation('version')\n  const { docPermissions } = useDocumentInfo()\n\n  let originalDocFetchURL: string\n  let versionFetchURL: string\n  let entityLabel: string\n  let fields: Field[]\n  let fieldPermissions: Record<string, FieldPermissions>\n  let compareBaseURL: string\n  let slug: string\n  let parentID: string\n\n  if (collection) {\n    ;({ slug } = collection)\n    originalDocFetchURL = `${serverURL}${api}/${slug}/${id}`\n    versionFetchURL = `${serverURL}${api}/${slug}/versions/${versionID}`\n    compareBaseURL = `${serverURL}${api}/${slug}/versions`\n    entityLabel = getTranslation(collection.labels.singular, i18n)\n    parentID = id\n    fields = collection.fields\n    fieldPermissions = permissions.collections[collection.slug].fields\n  }\n\n  if (global) {\n    ;({ slug } = global)\n    originalDocFetchURL = `${serverURL}${api}/globals/${slug}`\n    versionFetchURL = `${serverURL}${api}/globals/${slug}/versions/${versionID}`\n    compareBaseURL = `${serverURL}${api}/globals/${slug}/versions`\n    entityLabel = getTranslation(global.label, i18n)\n    fields = global.fields\n    fieldPermissions = permissions.globals[global.slug].fields\n  }\n\n  const compareFetchURL =\n    compareValue?.value === 'mostRecent' || compareValue?.value === 'published'\n      ? originalDocFetchURL\n      : `${compareBaseURL}/${compareValue.value}`\n\n  const [{ data: doc, isError }] = usePayloadAPI(versionFetchURL, {\n    initialParams: { depth: 1, locale: '*' },\n  })\n  const [{ data: publishedDoc }] = usePayloadAPI(originalDocFetchURL, {\n    initialParams: { depth: 1, locale: '*' },\n  })\n  const [{ data: mostRecentDoc }] = usePayloadAPI(originalDocFetchURL, {\n    initialParams: { depth: 1, draft: true, locale: '*' },\n  })\n  const [{ data: compareDoc }] = usePayloadAPI(compareFetchURL, {\n    initialParams: { depth: 1, draft: 'true', locale: '*' },\n  })\n\n  useEffect(() => {\n    let nav: StepNavItem[] = []\n\n    if (collection) {\n      let docLabel = ''\n\n      if (mostRecentDoc) {\n        const { useAsTitle } = collection.admin\n\n        if (useAsTitle !== 'id') {\n          const titleField = collection.fields.find(\n            (field) => fieldAffectsData(field) && field.name === useAsTitle,\n          ) as FieldAffectingData\n\n          if (titleField && mostRecentDoc[useAsTitle]) {\n            if (titleField.localized) {\n              docLabel = mostRecentDoc[useAsTitle]?.[locale]\n            } else {\n              docLabel = mostRecentDoc[useAsTitle]\n            }\n          } else {\n            docLabel = `[${t('general:untitled')}]`\n          }\n        } else {\n          docLabel = mostRecentDoc.id\n        }\n      }\n\n      nav = [\n        {\n          label: getTranslation(collection.labels.plural, i18n),\n          url: `${admin}/collections/${collection.slug}`,\n        },\n        {\n          label: docLabel,\n          url: `${admin}/collections/${collection.slug}/${id}`,\n        },\n        {\n          label: 'Versions',\n          url: `${admin}/collections/${collection.slug}/${id}/versions`,\n        },\n        {\n          label: doc?.createdAt ? formatDate(doc.createdAt, dateFormat, i18n?.language) : '',\n        },\n      ]\n    }\n\n    if (global) {\n      nav = [\n        {\n          label: global.label,\n          url: `${admin}/globals/${global.slug}`,\n        },\n        {\n          label: 'Versions',\n          url: `${admin}/globals/${global.slug}/versions`,\n        },\n        {\n          label: doc?.createdAt ? formatDate(doc.createdAt, dateFormat, i18n?.language) : '',\n        },\n      ]\n    }\n\n    setStepNav(nav)\n  }, [setStepNav, collection, global, dateFormat, doc, mostRecentDoc, admin, id, locale, t, i18n])\n\n  useEffect(() => {\n    const editConfig = (collection || global)?.admin?.components?.views?.Edit\n    const versionActions =\n      editConfig && 'Version' in editConfig && 'actions' in editConfig.Version\n        ? editConfig.Version.actions\n        : []\n\n    setViewActions(versionActions)\n\n    return () => {\n      setViewActions([])\n    }\n  }, [collection, global, setViewActions])\n\n  let metaTitle: string\n  let metaDesc: string\n  const formattedCreatedAt = doc?.createdAt\n    ? formatDate(doc.createdAt, dateFormat, i18n?.language)\n    : ''\n\n  if (collection) {\n    const useAsTitle = collection?.admin?.useAsTitle || 'id'\n    metaTitle = `${t('version')} - ${formattedCreatedAt} - ${doc[useAsTitle]} - ${entityLabel}`\n    metaDesc = t('viewingVersion', { documentTitle: doc[useAsTitle], entityLabel })\n  }\n\n  if (global) {\n    metaTitle = `${t('version')} - ${formattedCreatedAt} - ${entityLabel}`\n    metaDesc = t('viewingVersionGlobal', { entityLabel })\n  }\n\n  let comparison = compareDoc?.version\n\n  if (compareValue?.value === 'mostRecent') {\n    comparison = mostRecentDoc\n  }\n\n  if (compareValue?.value === 'published') {\n    comparison = publishedDoc\n  }\n\n  const canUpdate = docPermissions?.update?.permission\n\n  if (isError) {\n    return <NotFound marginTop=\"large\" />\n  }\n\n  return (\n    <main className={baseClass}>\n      <Meta description={metaDesc} title={metaTitle} />\n      <Gutter className={`${baseClass}__wrap`}>\n        <div className={`${baseClass}__header-wrap`}>\n          <p className={`${baseClass}__created-at`}>\n            {t('versionCreatedOn', {\n              version: t(doc?.autosave ? 'autosavedVersion' : 'version'),\n            })}\n          </p>\n          <header className={`${baseClass}__header`}>\n            <h2>{formattedCreatedAt}</h2>\n            {canUpdate && (\n              <Restore\n                className={`${baseClass}__restore`}\n                collection={collection}\n                global={global}\n                originalDocID={id}\n                versionDate={formattedCreatedAt}\n                versionID={versionID}\n              />\n            )}\n          </header>\n        </div>\n        <div className={`${baseClass}__controls`}>\n          <CompareVersion\n            baseURL={compareBaseURL}\n            onChange={setCompareValue}\n            parentID={parentID}\n            publishedDoc={publishedDoc}\n            value={compareValue}\n            versionID={versionID}\n          />\n          {localization && (\n            <SelectLocales onChange={setLocales} options={localeOptions} value={locales} />\n          )}\n        </div>\n\n        {doc?.version && (\n          <RenderFieldsToDiff\n            comparison={comparison}\n            fieldComponents={fieldComponents}\n            fieldPermissions={fieldPermissions}\n            fields={fields}\n            locales={\n              locales\n                ? locales.map(({ label }) => (typeof label === 'string' ? label : undefined))\n                : []\n            }\n            version={doc?.version}\n          />\n        )}\n      </Gutter>\n    </main>\n  )\n}\n\nexport default VersionView\n"],"names":["baseClass","VersionView","collection","global","admin","dateFormat","localization","routes","api","serverURL","useConfig","setStepNav","useStepNav","setViewActions","useActions","params","id","versionID","useRouteMatch","compareValue","setCompareValue","useState","mostRecentVersionOption","localeOptions","locales","map","code","label","value","setLocales","permissions","useAuth","locale","useLocale","i18n","t","useTranslation","docPermissions","useDocumentInfo","originalDocFetchURL","versionFetchURL","entityLabel","fields","fieldPermissions","compareBaseURL","slug","parentID","getTranslation","labels","singular","collections","globals","compareFetchURL","data","doc","isError","usePayloadAPI","initialParams","depth","publishedDoc","mostRecentDoc","draft","compareDoc","useEffect","nav","docLabel","useAsTitle","titleField","find","field","fieldAffectsData","name","localized","plural","url","createdAt","formatDate","language","editConfig","components","views","Edit","versionActions","Version","actions","metaTitle","metaDesc","formattedCreatedAt","documentTitle","comparison","version","canUpdate","update","permission","NotFound","marginTop","main","className","Meta","description","title","Gutter","div","p","autosave","header","h2","Restore","originalDocID","versionDate","CompareVersion","baseURL","onChange","SelectLocales","options","RenderFieldsToDiff","fieldComponents","undefined"],"mappings":"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"}