UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

171 lines (170 loc) • 14.8 kB
"use strict"; 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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"}