payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
171 lines (170 loc) • 14.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _qs = /*#__PURE__*/ _interop_require_default(require("qs"));
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reacti18next = require("react-i18next");
const _formatDate = require("../../../../utilities/formatDate");
const _ReactSelect = /*#__PURE__*/ _interop_require_default(require("../../../elements/ReactSelect"));
const _shared = require("../../../forms/field-types/shared");
const _Config = require("../../../utilities/Config");
const _shared1 = require("../shared");
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 = 'compare-version';
const maxResultsPerRequest = 10;
const baseOptions = [
_shared1.mostRecentVersionOption
];
const CompareVersion = (props)=>{
const { baseURL, onChange, parentID, publishedDoc, value, versionID } = props;
const { admin: { dateFormat } } = (0, _Config.useConfig)();
const [options, setOptions] = (0, _react.useState)(baseOptions);
const [lastLoadedPage, setLastLoadedPage] = (0, _react.useState)(1);
const [errorLoading, setErrorLoading] = (0, _react.useState)('');
const { i18n, t } = (0, _reacti18next.useTranslation)('version');
const getResults = (0, _react.useCallback)(async ({ lastLoadedPage: lastLoadedPageArg })=>{
const query = {
depth: 0,
limit: maxResultsPerRequest,
page: lastLoadedPageArg,
where: {
and: [
{
id: {
not_equals: versionID
}
}
]
}
};
if (parentID) {
query.where.and.push({
parent: {
equals: parentID
}
});
}
const search = _qs.default.stringify(query);
const response = await fetch(`${baseURL}?${search}`, {
credentials: 'include',
headers: {
'Accept-Language': i18n.language
}
});
if (response.ok) {
const data = await response.json();
if (data.docs.length > 0) {
setOptions((existingOptions)=>[
...existingOptions,
...data.docs.map((doc)=>({
label: (0, _formatDate.formatDate)(doc.updatedAt, dateFormat, i18n?.language),
value: doc.id
}))
]);
setLastLoadedPage(data.page);
}
} else {
setErrorLoading(t('error:unspecific'));
}
}, [
dateFormat,
baseURL,
parentID,
versionID,
t,
i18n
]);
(0, _react.useEffect)(()=>{
getResults({
lastLoadedPage: 1
});
}, [
getResults
]);
(0, _react.useEffect)(()=>{
if (publishedDoc?._status === 'published') setOptions((currentOptions)=>[
_shared1.publishedVersionOption,
...currentOptions
]);
}, [
publishedDoc
]);
return /*#__PURE__*/ _react.default.createElement("div", {
className: [
_shared.fieldBaseClass,
baseClass,
errorLoading && 'error-loading'
].filter(Boolean).join(' ')
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__label`
}, t('compareVersion')), !errorLoading && /*#__PURE__*/ _react.default.createElement(_ReactSelect.default, {
isClearable: false,
isSearchable: false,
onChange: onChange,
onMenuScrollToBottom: ()=>{
getResults({
lastLoadedPage: lastLoadedPage + 1
});
},
options: options,
placeholder: t('selectVersionToCompare'),
value: value
}), errorLoading && /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__error-loading`
}, errorLoading));
};
const _default = CompareVersion;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/admin/components/views/Version/Compare/index.tsx"],"sourcesContent":["import qs from 'qs'\nimport React, { useCallback, useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { PaginatedDocs } from '../../../../../database/types'\nimport type { Where } from '../../../../../types'\nimport type { Props } from './types'\n\nimport { formatDate } from '../../../../utilities/formatDate'\nimport ReactSelect from '../../../elements/ReactSelect'\nimport { fieldBaseClass } from '../../../forms/field-types/shared'\nimport { useConfig } from '../../../utilities/Config'\nimport { mostRecentVersionOption, publishedVersionOption } from '../shared'\nimport './index.scss'\n\nconst baseClass = 'compare-version'\n\nconst maxResultsPerRequest = 10\n\nconst baseOptions = [mostRecentVersionOption]\n\nconst CompareVersion: React.FC<Props> = (props) => {\n  const { baseURL, onChange, parentID, publishedDoc, value, versionID } = props\n\n  const {\n    admin: { dateFormat },\n  } = useConfig()\n\n  const [options, setOptions] = useState(baseOptions)\n  const [lastLoadedPage, setLastLoadedPage] = useState(1)\n  const [errorLoading, setErrorLoading] = useState('')\n  const { i18n, t } = useTranslation('version')\n\n  const getResults = useCallback(\n    async ({ lastLoadedPage: lastLoadedPageArg }) => {\n      const query: {\n        [key: string]: unknown\n        where: Where\n      } = {\n        depth: 0,\n        limit: maxResultsPerRequest,\n        page: lastLoadedPageArg,\n        where: {\n          and: [\n            {\n              id: {\n                not_equals: versionID,\n              },\n            },\n          ],\n        },\n      }\n\n      if (parentID) {\n        query.where.and.push({\n          parent: {\n            equals: parentID,\n          },\n        })\n      }\n\n      const search = qs.stringify(query)\n      const response = await fetch(`${baseURL}?${search}`, {\n        credentials: 'include',\n        headers: {\n          'Accept-Language': i18n.language,\n        },\n      })\n\n      if (response.ok) {\n        const data: PaginatedDocs = await response.json()\n        if (data.docs.length > 0) {\n          setOptions((existingOptions) => [\n            ...existingOptions,\n            ...data.docs.map((doc) => ({\n              label: formatDate(doc.updatedAt, dateFormat, i18n?.language),\n              value: doc.id,\n            })),\n          ])\n          setLastLoadedPage(data.page)\n        }\n      } else {\n        setErrorLoading(t('error:unspecific'))\n      }\n    },\n    [dateFormat, baseURL, parentID, versionID, t, i18n],\n  )\n\n  useEffect(() => {\n    getResults({ lastLoadedPage: 1 })\n  }, [getResults])\n\n  useEffect(() => {\n    if (publishedDoc?._status === 'published')\n      setOptions((currentOptions) => [publishedVersionOption, ...currentOptions])\n  }, [publishedDoc])\n\n  return (\n    <div\n      className={[fieldBaseClass, baseClass, errorLoading && 'error-loading']\n        .filter(Boolean)\n        .join(' ')}\n    >\n      <div className={`${baseClass}__label`}>{t('compareVersion')}</div>\n      {!errorLoading && (\n        <ReactSelect\n          isClearable={false}\n          isSearchable={false}\n          onChange={onChange}\n          onMenuScrollToBottom={() => {\n            getResults({ lastLoadedPage: lastLoadedPage + 1 })\n          }}\n          options={options}\n          placeholder={t('selectVersionToCompare')}\n          value={value}\n        />\n      )}\n      {errorLoading && <div className={`${baseClass}__error-loading`}>{errorLoading}</div>}\n    </div>\n  )\n}\n\nexport default CompareVersion\n"],"names":["baseClass","maxResultsPerRequest","baseOptions","mostRecentVersionOption","CompareVersion","props","baseURL","onChange","parentID","publishedDoc","value","versionID","admin","dateFormat","useConfig","options","setOptions","useState","lastLoadedPage","setLastLoadedPage","errorLoading","setErrorLoading","i18n","t","useTranslation","getResults","useCallback","lastLoadedPageArg","query","depth","limit","page","where","and","id","not_equals","push","parent","equals","search","qs","stringify","response","fetch","credentials","headers","language","ok","data","json","docs","length","existingOptions","map","doc","label","formatDate","updatedAt","useEffect","_status","currentOptions","publishedVersionOption","div","className","fieldBaseClass","filter","Boolean","join","ReactSelect","isClearable","isSearchable","onMenuScrollToBottom","placeholder"],"mappings":"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"}