UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

194 lines (193 loc) • 19.8 kB
"use strict"; 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 _getTranslation = require("../../../../utilities/getTranslation"); const _usePayloadAPI = /*#__PURE__*/ _interop_require_default(require("../../../hooks/usePayloadAPI")); const _ActionsProvider = require("../../utilities/ActionsProvider"); const _Auth = require("../../utilities/Auth"); const _Config = require("../../utilities/Config"); const _EditDepth = require("../../utilities/EditDepth"); const _RenderCustomComponent = /*#__PURE__*/ _interop_require_default(require("../../utilities/RenderCustomComponent")); const _SearchParams = require("../../utilities/SearchParams"); const _Default = require("./Default"); 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 VersionsView = (props)=>{ const { id, collection, global } = props; const { permissions, user } = (0, _Auth.useAuth)(); const [fetchURL, setFetchURL] = (0, _react.useState)(''); const { setViewActions } = (0, _ActionsProvider.useActions)(); const { routes: { admin, api }, serverURL } = (0, _Config.useConfig)(); const { i18n } = (0, _reacti18next.useTranslation)('version'); const { limit, page, sort } = (0, _SearchParams.useSearchParams)(); let CustomVersionsView = null; let docURL; let entityLabel; let slug; let editURL; if (collection) { ({ slug } = collection); docURL = `${serverURL}${api}/${slug}/${id}`; entityLabel = (0, _getTranslation.getTranslation)(collection.labels.singular, i18n); editURL = `${admin}/collections/${collection.slug}/${id}`; // The component definition could come from multiple places in the config // we need to cascade into the proper component from the top-down // 1. "components.Edit" // 2. "components.Edit.Versions" // 3. "components.Edit.Versions.Component" const EditCollection = collection?.admin?.components?.views?.Edit; if (typeof EditCollection === 'function') { CustomVersionsView = EditCollection; } else if (typeof EditCollection === 'object' && typeof EditCollection.Versions === 'function') { CustomVersionsView = EditCollection.Versions; } else if (typeof EditCollection?.Versions === 'object' && 'Component' in EditCollection.Versions && typeof EditCollection.Versions.Component === 'function') { CustomVersionsView = EditCollection.Versions.Component; } } if (global) { ({ slug } = global); docURL = `${serverURL}${api}/globals/${slug}`; entityLabel = (0, _getTranslation.getTranslation)(global.label, i18n); editURL = `${admin}/globals/${global.slug}`; // See note above about cascading component definitions const EditGlobal = global?.admin?.components?.views?.Edit; if (typeof EditGlobal === 'function') { CustomVersionsView = EditGlobal; } else if (typeof EditGlobal === 'object' && typeof EditGlobal.Versions === 'function') { CustomVersionsView = EditGlobal.Versions; } else if (typeof EditGlobal?.Versions === 'object' && 'Component' in EditGlobal.Versions && typeof EditGlobal.Versions.Component === 'function') { CustomVersionsView = EditGlobal.Versions.Component; } } const [{ data, isLoading }] = (0, _usePayloadAPI.default)(docURL, { initialParams: { draft: 'true' } }); const [{ data: versionsData, isLoading: isLoadingVersions }, { setParams }] = (0, _usePayloadAPI.default)(fetchURL); (0, _react.useEffect)(()=>{ const params = { depth: 1, limit, page: undefined, sort: undefined, where: {} }; if (page) params.page = page; if (sort) params.sort = sort; let fetchURLToSet; if (collection) { fetchURLToSet = `${serverURL}${api}/${collection.slug}/versions`; params.where = { parent: { equals: id } }; } if (global) { fetchURLToSet = `${serverURL}${api}/globals/${global.slug}/versions`; } // Performance enhancement // Setting the Fetch URL this way // prevents a double-fetch setFetchURL(fetchURLToSet); setParams(params); }, [ setParams, page, sort, limit, serverURL, api, id, global, collection ]); (0, _react.useEffect)(()=>{ const editConfig = (collection || global)?.admin?.components?.views?.Edit; const versionsActions = editConfig && 'Versions' in editConfig && 'actions' in editConfig.Versions ? editConfig.Versions.actions : []; setViewActions(versionsActions); return ()=>{ setViewActions([]); }; }, [ collection, global, setViewActions ]); return /*#__PURE__*/ _react.default.createElement(_EditDepth.EditDepthContext.Provider, { value: 1 }, /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, { CustomComponent: CustomVersionsView, DefaultComponent: _Default.DefaultVersionsView, componentProps: { id, canAccessAdmin: permissions?.canAccessAdmin, collection, data, editURL, entityLabel, fetchURL, global, isLoading, isLoadingVersions, user, versionsData } })); }; const _default = VersionsView; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/views/Versions/index.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { IndexProps } from './types'\n\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport usePayloadAPI from '../../../hooks/usePayloadAPI'\nimport { useActions } from '../../utilities/ActionsProvider'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport { EditDepthContext } from '../../utilities/EditDepth'\nimport RenderCustomComponent from '../../utilities/RenderCustomComponent'\nimport { useSearchParams } from '../../utilities/SearchParams'\nimport { DefaultVersionsView } from './Default'\n\nconst VersionsView: React.FC<IndexProps> = (props) => {\n  const { id, collection, global } = props\n\n  const { permissions, user } = useAuth()\n\n  const [fetchURL, setFetchURL] = useState('')\n\n  const { setViewActions } = useActions()\n\n  const {\n    routes: { admin, api },\n    serverURL,\n  } = useConfig()\n\n  const { i18n } = useTranslation('version')\n\n  const { limit, page, sort } = useSearchParams()\n\n  let CustomVersionsView: React.ComponentType | null = null\n  let docURL: string\n  let entityLabel: string\n  let slug: string\n  let editURL: string\n\n  if (collection) {\n    ;({ slug } = collection)\n    docURL = `${serverURL}${api}/${slug}/${id}`\n    entityLabel = getTranslation(collection.labels.singular, i18n)\n    editURL = `${admin}/collections/${collection.slug}/${id}`\n\n    // The component definition could come from multiple places in the config\n    // we need to cascade into the proper component from the top-down\n    // 1. \"components.Edit\"\n    // 2. \"components.Edit.Versions\"\n    // 3. \"components.Edit.Versions.Component\"\n    const EditCollection = collection?.admin?.components?.views?.Edit\n\n    if (typeof EditCollection === 'function') {\n      CustomVersionsView = EditCollection\n    } else if (\n      typeof EditCollection === 'object' &&\n      typeof EditCollection.Versions === 'function'\n    ) {\n      CustomVersionsView = EditCollection.Versions\n    } else if (\n      typeof EditCollection?.Versions === 'object' &&\n      'Component' in EditCollection.Versions &&\n      typeof EditCollection.Versions.Component === 'function'\n    ) {\n      CustomVersionsView = EditCollection.Versions.Component\n    }\n  }\n\n  if (global) {\n    ;({ slug } = global)\n    docURL = `${serverURL}${api}/globals/${slug}`\n    entityLabel = getTranslation(global.label, i18n)\n    editURL = `${admin}/globals/${global.slug}`\n\n    // See note above about cascading component definitions\n    const EditGlobal = global?.admin?.components?.views?.Edit\n\n    if (typeof EditGlobal === 'function') {\n      CustomVersionsView = EditGlobal\n    } else if (typeof EditGlobal === 'object' && typeof EditGlobal.Versions === 'function') {\n      CustomVersionsView = EditGlobal.Versions\n    } else if (\n      typeof EditGlobal?.Versions === 'object' &&\n      'Component' in EditGlobal.Versions &&\n      typeof EditGlobal.Versions.Component === 'function'\n    ) {\n      CustomVersionsView = EditGlobal.Versions.Component\n    }\n  }\n\n  const [{ data, isLoading }] = usePayloadAPI(docURL, { initialParams: { draft: 'true' } })\n  const [{ data: versionsData, isLoading: isLoadingVersions }, { setParams }] =\n    usePayloadAPI(fetchURL)\n\n  useEffect(() => {\n    const params = {\n      depth: 1,\n      limit,\n      page: undefined,\n      sort: undefined,\n      where: {},\n    }\n\n    if (page) params.page = page\n    if (sort) params.sort = sort\n\n    let fetchURLToSet: string\n\n    if (collection) {\n      fetchURLToSet = `${serverURL}${api}/${collection.slug}/versions`\n      params.where = {\n        parent: {\n          equals: id,\n        },\n      }\n    }\n\n    if (global) {\n      fetchURLToSet = `${serverURL}${api}/globals/${global.slug}/versions`\n    }\n\n    // Performance enhancement\n    // Setting the Fetch URL this way\n    // prevents a double-fetch\n\n    setFetchURL(fetchURLToSet)\n\n    setParams(params)\n  }, [setParams, page, sort, limit, serverURL, api, id, global, collection])\n\n  useEffect(() => {\n    const editConfig = (collection || global)?.admin?.components?.views?.Edit\n    const versionsActions =\n      editConfig && 'Versions' in editConfig && 'actions' in editConfig.Versions\n        ? editConfig.Versions.actions\n        : []\n\n    setViewActions(versionsActions)\n\n    return () => {\n      setViewActions([])\n    }\n  }, [collection, global, setViewActions])\n\n  return (\n    <EditDepthContext.Provider value={1}>\n      <RenderCustomComponent\n        CustomComponent={CustomVersionsView}\n        DefaultComponent={DefaultVersionsView}\n        componentProps={{\n          id,\n          canAccessAdmin: permissions?.canAccessAdmin,\n          collection,\n          data,\n          editURL,\n          entityLabel,\n          fetchURL,\n          global,\n          isLoading,\n          isLoadingVersions,\n          user,\n          versionsData,\n        }}\n      />\n    </EditDepthContext.Provider>\n  )\n}\nexport default VersionsView\n"],"names":["VersionsView","props","id","collection","global","permissions","user","useAuth","fetchURL","setFetchURL","useState","setViewActions","useActions","routes","admin","api","serverURL","useConfig","i18n","useTranslation","limit","page","sort","useSearchParams","CustomVersionsView","docURL","entityLabel","slug","editURL","getTranslation","labels","singular","EditCollection","components","views","Edit","Versions","Component","label","EditGlobal","data","isLoading","usePayloadAPI","initialParams","draft","versionsData","isLoadingVersions","setParams","useEffect","params","depth","undefined","where","fetchURLToSet","parent","equals","editConfig","versionsActions","actions","EditDepthContext","Provider","value","RenderCustomComponent","CustomComponent","DefaultComponent","DefaultVersionsView","componentProps","canAccessAdmin"],"mappings":"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"}