payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
315 lines (314 loc) • 29.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
function _export(target, all) {
for(var name in all)Object.defineProperty(target, name, {
enumerable: true,
get: all[name]
});
}
_export(exports, {
DocumentInfoProvider: function() {
return DocumentInfoProvider;
},
useDocumentInfo: function() {
return useDocumentInfo;
}
});
const _qs = /*#__PURE__*/ _interop_require_default(require("qs"));
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reacti18next = require("react-i18next");
const _reactrouterdom = require("react-router-dom");
const _Auth = require("../Auth");
const _Config = require("../Config");
const _Locale = require("../Locale");
const _Preferences = require("../Preferences");
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 Context = /*#__PURE__*/ (0, _react.createContext)({});
const useDocumentInfo = ()=>(0, _react.useContext)(Context);
const DocumentInfoProvider = ({ id: idFromProps, children, collection, global, idFromParams: getIDFromParams })=>{
const { id: idFromParams } = (0, _reactrouterdom.useParams)();
const id = idFromProps || (getIDFromParams ? idFromParams : null);
const { routes: { api }, serverURL } = (0, _Config.useConfig)();
const { getPreference, setPreference } = (0, _Preferences.usePreferences)();
const { i18n } = (0, _reacti18next.useTranslation)();
const { permissions } = (0, _Auth.useAuth)();
const { code } = (0, _Locale.useLocale)();
const [publishedDoc, setPublishedDoc] = (0, _react.useState)(null);
const [versions, setVersions] = (0, _react.useState)(null);
const [unpublishedVersions, setUnpublishedVersions] = (0, _react.useState)(null);
const baseURL = `${serverURL}${api}`;
let slug;
let pluralType;
let preferencesKey;
if (global) {
slug = global.slug;
pluralType = 'globals';
preferencesKey = `global-${slug}`;
}
if (collection) {
slug = collection.slug;
pluralType = 'collections';
if (id) {
preferencesKey = `collection-${slug}-${id}`;
}
}
const [docPermissions, setDocPermissions] = (0, _react.useState)(permissions[pluralType][slug]);
const getVersions = (0, _react.useCallback)(async ()=>{
let versionFetchURL;
let publishedFetchURL;
let draftsEnabled = false;
let shouldFetchVersions = false;
let unpublishedVersionJSON = null;
let versionJSON = null;
let shouldFetch = true;
const versionParams = {
depth: 0,
where: {
and: []
}
};
const publishedVersionParams = {
depth: 0,
locale: code || undefined,
where: {
and: [
{
or: [
{
_status: {
equals: 'published'
}
},
{
_status: {
exists: false
}
}
]
}
]
}
};
if (global) {
draftsEnabled = Boolean(global?.versions?.drafts);
shouldFetchVersions = Boolean(global?.versions);
versionFetchURL = `${baseURL}/globals/${global.slug}/versions`;
publishedFetchURL = `${baseURL}/globals/${global.slug}?${_qs.default.stringify(publishedVersionParams)}`;
}
if (collection) {
draftsEnabled = Boolean(collection?.versions?.drafts);
shouldFetchVersions = Boolean(collection?.versions);
versionFetchURL = `${baseURL}/${collection.slug}/versions`;
publishedVersionParams.where.and.push({
id: {
equals: id
}
});
publishedFetchURL = `${baseURL}/${collection.slug}?${_qs.default.stringify(publishedVersionParams)}`;
if (!id) {
shouldFetch = false;
}
versionParams.where.and.push({
parent: {
equals: id
}
});
}
if (shouldFetch) {
let publishedJSON;
if (draftsEnabled) {
publishedJSON = await fetch(publishedFetchURL, {
credentials: 'include',
headers: {
'Accept-Language': i18n.language
}
}).then((res)=>res.json());
if (collection) {
publishedJSON = publishedJSON?.docs?.[0];
}
}
if (shouldFetchVersions) {
versionJSON = await fetch(`${versionFetchURL}?${_qs.default.stringify(versionParams)}`, {
credentials: 'include',
headers: {
'Accept-Language': i18n.language
}
}).then((res)=>res.json());
if (publishedJSON?.updatedAt) {
const newerVersionParams = {
...versionParams,
where: {
...versionParams.where,
and: [
...versionParams.where.and,
{
updatedAt: {
greater_than: publishedJSON?.updatedAt
}
}
]
}
};
// Get any newer versions available
const newerVersionRes = await fetch(`${versionFetchURL}?${_qs.default.stringify(newerVersionParams)}`, {
credentials: 'include',
headers: {
'Accept-Language': i18n.language
}
});
if (newerVersionRes.status === 200) {
unpublishedVersionJSON = await newerVersionRes.json();
}
}
}
setPublishedDoc(publishedJSON);
setVersions(versionJSON);
setUnpublishedVersions(unpublishedVersionJSON);
}
}, [
i18n,
global,
collection,
id,
baseURL,
code
]);
const getDocPermissions = _react.default.useCallback(async ()=>{
let docAccessURL;
const params = {
locale: code || undefined
};
if (pluralType === 'globals') {
docAccessURL = `/globals/${slug}/access`;
} else if (pluralType === 'collections' && id) {
docAccessURL = `/${slug}/access/${id}`;
}
if (docAccessURL) {
const res = await fetch(`${serverURL}${api}${docAccessURL}?${_qs.default.stringify(params)}`, {
credentials: 'include',
headers: {
'Accept-Language': i18n.language
}
});
try {
const json = await res.json();
setDocPermissions(json);
} catch (e) {
console.error('Unable to fetch document permissions', e);
}
}
}, [
serverURL,
api,
pluralType,
slug,
id,
i18n.language,
code
]);
const getDocPreferences = (0, _react.useCallback)(async ()=>{
return getPreference(preferencesKey);
}, [
getPreference,
preferencesKey
]);
const setDocFieldPreferences = (0, _react.useCallback)(async (path, fieldPreferences)=>{
const allPreferences = await getDocPreferences();
if (preferencesKey) {
try {
await setPreference(preferencesKey, {
...allPreferences,
fields: {
...allPreferences?.fields || {},
[path]: {
...allPreferences?.fields?.[path],
...fieldPreferences
}
}
});
} catch (e) {
console.error(e);
}
}
}, [
setPreference,
preferencesKey,
getDocPreferences
]);
(0, _react.useEffect)(()=>{
getVersions();
}, [
getVersions
]);
(0, _react.useEffect)(()=>{
getDocPermissions();
}, [
getDocPermissions
]);
const value = {
id,
slug,
collection,
docPermissions,
getDocPermissions,
getDocPreferences,
getVersions,
global,
preferencesKey,
publishedDoc,
setDocFieldPreferences,
unpublishedVersions,
versions
};
return /*#__PURE__*/ _react.default.createElement(Context.Provider, {
value: value
}, children);
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/utilities/DocumentInfo/index.tsx"],"sourcesContent":["import qs from 'qs'\nimport React, { createContext, useCallback, useContext, useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useParams } from 'react-router-dom'\n\nimport type { TypeWithTimestamps } from '../../../../collections/config/types'\nimport type { PaginatedDocs } from '../../../../database/types'\nimport type { TypeWithID } from '../../../../globals/config/types'\nimport type { DocumentPreferences } from '../../../../preferences/types'\nimport type { Where } from '../../../../types'\nimport type { ContextType, DocumentPermissions, Props, Version } from './types'\n\nimport { useAuth } from '../Auth'\nimport { useConfig } from '../Config'\nimport { useLocale } from '../Locale'\nimport { usePreferences } from '../Preferences'\n\nconst Context = createContext({} as ContextType)\n\nexport const useDocumentInfo = (): ContextType => useContext(Context)\n\nexport const DocumentInfoProvider: React.FC<Props> = ({\n  id: idFromProps,\n  children,\n  collection,\n  global,\n  idFromParams: getIDFromParams,\n}) => {\n  const { id: idFromParams } = useParams<{ id: string }>()\n  const id = idFromProps || (getIDFromParams ? idFromParams : null)\n\n  const {\n    routes: { api },\n    serverURL,\n  } = useConfig()\n  const { getPreference, setPreference } = usePreferences()\n  const { i18n } = useTranslation()\n  const { permissions } = useAuth()\n  const { code } = useLocale()\n  const [publishedDoc, setPublishedDoc] = useState<TypeWithID & TypeWithTimestamps>(null)\n  const [versions, setVersions] = useState<PaginatedDocs<Version>>(null)\n  const [unpublishedVersions, setUnpublishedVersions] = useState<PaginatedDocs<Version>>(null)\n\n  const baseURL = `${serverURL}${api}`\n  let slug: string\n  let pluralType: 'collections' | 'globals'\n  let preferencesKey: string\n\n  if (global) {\n    slug = global.slug\n    pluralType = 'globals'\n    preferencesKey = `global-${slug}`\n  }\n\n  if (collection) {\n    slug = collection.slug\n    pluralType = 'collections'\n\n    if (id) {\n      preferencesKey = `collection-${slug}-${id}`\n    }\n  }\n\n  const [docPermissions, setDocPermissions] = useState<DocumentPermissions>(\n    permissions[pluralType][slug],\n  )\n\n  const getVersions = useCallback(async () => {\n    let versionFetchURL\n    let publishedFetchURL\n    let draftsEnabled = false\n    let shouldFetchVersions = false\n    let unpublishedVersionJSON = null\n    let versionJSON = null\n    let shouldFetch = true\n\n    const versionParams = {\n      depth: 0,\n      where: {\n        and: [],\n      },\n    }\n\n    const publishedVersionParams: { depth: number; locale: string; where: Where } = {\n      depth: 0,\n      locale: code || undefined,\n      where: {\n        and: [\n          {\n            or: [\n              {\n                _status: {\n                  equals: 'published',\n                },\n              },\n              {\n                _status: {\n                  exists: false,\n                },\n              },\n            ],\n          },\n        ],\n      },\n    }\n\n    if (global) {\n      draftsEnabled = Boolean(global?.versions?.drafts)\n      shouldFetchVersions = Boolean(global?.versions)\n      versionFetchURL = `${baseURL}/globals/${global.slug}/versions`\n      publishedFetchURL = `${baseURL}/globals/${global.slug}?${qs.stringify(\n        publishedVersionParams,\n      )}`\n    }\n\n    if (collection) {\n      draftsEnabled = Boolean(collection?.versions?.drafts)\n      shouldFetchVersions = Boolean(collection?.versions)\n      versionFetchURL = `${baseURL}/${collection.slug}/versions`\n\n      publishedVersionParams.where.and.push({\n        id: {\n          equals: id,\n        },\n      })\n\n      publishedFetchURL = `${baseURL}/${collection.slug}?${qs.stringify(publishedVersionParams)}`\n\n      if (!id) {\n        shouldFetch = false\n      }\n\n      versionParams.where.and.push({\n        parent: {\n          equals: id,\n        },\n      })\n    }\n\n    if (shouldFetch) {\n      let publishedJSON\n\n      if (draftsEnabled) {\n        publishedJSON = await fetch(publishedFetchURL, {\n          credentials: 'include',\n          headers: {\n            'Accept-Language': i18n.language,\n          },\n        }).then((res) => res.json())\n\n        if (collection) {\n          publishedJSON = publishedJSON?.docs?.[0]\n        }\n      }\n\n      if (shouldFetchVersions) {\n        versionJSON = await fetch(`${versionFetchURL}?${qs.stringify(versionParams)}`, {\n          credentials: 'include',\n          headers: {\n            'Accept-Language': i18n.language,\n          },\n        }).then((res) => res.json())\n\n        if (publishedJSON?.updatedAt) {\n          const newerVersionParams = {\n            ...versionParams,\n            where: {\n              ...versionParams.where,\n              and: [\n                ...versionParams.where.and,\n                {\n                  updatedAt: {\n                    greater_than: publishedJSON?.updatedAt,\n                  },\n                },\n              ],\n            },\n          }\n\n          // Get any newer versions available\n          const newerVersionRes = await fetch(\n            `${versionFetchURL}?${qs.stringify(newerVersionParams)}`,\n            {\n              credentials: 'include',\n              headers: {\n                'Accept-Language': i18n.language,\n              },\n            },\n          )\n\n          if (newerVersionRes.status === 200) {\n            unpublishedVersionJSON = await newerVersionRes.json()\n          }\n        }\n      }\n\n      setPublishedDoc(publishedJSON)\n      setVersions(versionJSON)\n      setUnpublishedVersions(unpublishedVersionJSON)\n    }\n  }, [i18n, global, collection, id, baseURL, code])\n\n  const getDocPermissions = React.useCallback(async () => {\n    let docAccessURL: string\n    const params = {\n      locale: code || undefined,\n    }\n    if (pluralType === 'globals') {\n      docAccessURL = `/globals/${slug}/access`\n    } else if (pluralType === 'collections' && id) {\n      docAccessURL = `/${slug}/access/${id}`\n    }\n\n    if (docAccessURL) {\n      const res = await fetch(`${serverURL}${api}${docAccessURL}?${qs.stringify(params)}`, {\n        credentials: 'include',\n        headers: {\n          'Accept-Language': i18n.language,\n        },\n      })\n      try {\n        const json = await res.json()\n        setDocPermissions(json)\n      } catch (e) {\n        console.error('Unable to fetch document permissions', e)\n      }\n    }\n  }, [serverURL, api, pluralType, slug, id, i18n.language, code])\n\n  const getDocPreferences = useCallback(async () => {\n    return getPreference<DocumentPreferences>(preferencesKey)\n  }, [getPreference, preferencesKey])\n\n  const setDocFieldPreferences = useCallback<ContextType['setDocFieldPreferences']>(\n    async (path, fieldPreferences) => {\n      const allPreferences = await getDocPreferences()\n\n      if (preferencesKey) {\n        try {\n          await setPreference(preferencesKey, {\n            ...allPreferences,\n            fields: {\n              ...(allPreferences?.fields || {}),\n              [path]: {\n                ...allPreferences?.fields?.[path],\n                ...fieldPreferences,\n              },\n            },\n          })\n        } catch (e) {\n          console.error(e)\n        }\n      }\n    },\n    [setPreference, preferencesKey, getDocPreferences],\n  )\n\n  useEffect(() => {\n    getVersions()\n  }, [getVersions])\n\n  useEffect(() => {\n    getDocPermissions()\n  }, [getDocPermissions])\n\n  const value: ContextType = {\n    id,\n    slug,\n    collection,\n    docPermissions,\n    getDocPermissions,\n    getDocPreferences,\n    getVersions,\n    global,\n    preferencesKey,\n    publishedDoc,\n    setDocFieldPreferences,\n    unpublishedVersions,\n    versions,\n  }\n\n  return <Context.Provider value={value}>{children}</Context.Provider>\n}\n"],"names":["DocumentInfoProvider","useDocumentInfo","Context","createContext","useContext","id","idFromProps","children","collection","global","idFromParams","getIDFromParams","useParams","routes","api","serverURL","useConfig","getPreference","setPreference","usePreferences","i18n","useTranslation","permissions","useAuth","code","useLocale","publishedDoc","setPublishedDoc","useState","versions","setVersions","unpublishedVersions","setUnpublishedVersions","baseURL","slug","pluralType","preferencesKey","docPermissions","setDocPermissions","getVersions","useCallback","versionFetchURL","publishedFetchURL","draftsEnabled","shouldFetchVersions","unpublishedVersionJSON","versionJSON","shouldFetch","versionParams","depth","where","and","publishedVersionParams","locale","undefined","or","_status","equals","exists","Boolean","drafts","qs","stringify","push","parent","publishedJSON","fetch","credentials","headers","language","then","res","json","docs","updatedAt","newerVersionParams","greater_than","newerVersionRes","status","getDocPermissions","React","docAccessURL","params","e","console","error","getDocPreferences","setDocFieldPreferences","path","fieldPreferences","allPreferences","fields","useEffect","value","Provider"],"mappings":"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"}