payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
182 lines (181 loc) • 17.7 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 _usePayloadAPI = /*#__PURE__*/ _interop_require_default(require("../../../hooks/usePayloadAPI"));
const _buildStateFromSchema = /*#__PURE__*/ _interop_require_default(require("../../forms/Form/buildStateFromSchema"));
const _fieldtypes = require("../../forms/field-types");
const _Auth = require("../../utilities/Auth");
const _Config = require("../../utilities/Config");
const _DocumentEvents = require("../../utilities/DocumentEvents");
const _DocumentInfo = require("../../utilities/DocumentInfo");
const _EditDepth = require("../../utilities/EditDepth");
const _Locale = require("../../utilities/Locale");
const _Preferences = require("../../utilities/Preferences");
const _RenderCustomComponent = /*#__PURE__*/ _interop_require_default(require("../../utilities/RenderCustomComponent"));
const _Default = /*#__PURE__*/ _interop_require_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 GlobalView = (props)=>{
const { global } = props;
const { state: locationState } = (0, _reactrouterdom.useLocation)();
const { code: locale } = (0, _Locale.useLocale)();
const { permissions, user } = (0, _Auth.useAuth)();
const [initialState, setInitialState] = (0, _react.useState)();
const [updatedAt, setUpdatedAt] = (0, _react.useState)();
const { docPermissions, getDocPermissions, getDocPreferences, getVersions, preferencesKey } = (0, _DocumentInfo.useDocumentInfo)();
const { getPreference } = (0, _Preferences.usePreferences)();
const { t } = (0, _reacti18next.useTranslation)();
const config = (0, _Config.useConfig)();
const { routes: { api }, serverURL } = (0, _Config.useConfig)();
const { reportUpdate } = (0, _DocumentEvents.useDocumentEvents)();
const { slug, admin: { components: { views: { Edit: Edit } = {} } = {} } = {}, fields } = global;
const onSave = (0, _react.useCallback)(async (json)=>{
reportUpdate({
entitySlug: global.slug,
updatedAt: json?.result?.updatedAt || new Date().toISOString()
});
getVersions();
getDocPermissions();
setUpdatedAt(json?.result?.updatedAt);
const preferences = await getDocPreferences();
const state = await (0, _buildStateFromSchema.default)({
config,
data: json.result,
fieldSchema: fields,
locale,
operation: 'update',
preferences,
t,
user
});
setInitialState(state);
}, [
getVersions,
fields,
user,
locale,
t,
getDocPermissions,
getDocPreferences,
config,
global,
reportUpdate
]);
const [{ data, isLoading: isLoadingData }] = (0, _usePayloadAPI.default)(`${serverURL}${api}/globals/${slug}`, {
initialData: null,
initialParams: {
depth: 0,
draft: 'true',
'fallback-locale': 'null'
}
});
const dataToRender = locationState?.data || data;
(0, _react.useEffect)(()=>{
const awaitInitialState = async ()=>{
const preferences = await getDocPreferences();
const state = await (0, _buildStateFromSchema.default)({
config,
data: dataToRender,
fieldSchema: fields,
locale,
operation: 'update',
preferences,
t,
user
});
if (preferencesKey) {
await getPreference(preferencesKey);
}
setInitialState(state);
};
if (dataToRender) awaitInitialState();
}, [
dataToRender,
fields,
user,
locale,
getPreference,
preferencesKey,
t,
getDocPreferences,
config
]);
const isLoading = !initialState || !docPermissions || isLoadingData;
const componentProps = {
action: `${serverURL}${api}/globals/${slug}?locale=${locale}&fallback-locale=null`,
apiURL: `${serverURL}${api}/globals/${slug}?locale=${locale}${global.versions?.drafts ? '&draft=true' : ''}`,
canAccessAdmin: permissions?.canAccessAdmin,
data: dataToRender,
fieldTypes: _fieldtypes.fieldTypes,
global,
initialState,
isLoading,
onSave,
permissions: docPermissions,
updatedAt: updatedAt || dataToRender?.updatedAt,
user
};
return /*#__PURE__*/ _react.default.createElement(_EditDepth.EditDepthContext.Provider, {
value: 1
}, /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, {
CustomComponent: typeof Edit === 'function' ? Edit : undefined,
DefaultComponent: _Default.default,
componentProps: componentProps
}));
};
const _default = GlobalView;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/views/Global/index.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useLocation } from 'react-router-dom'\n\nimport type { Fields } from '../../forms/Form/types'\nimport type { DefaultGlobalViewProps } from './Default'\nimport type { IndexProps } from './types'\n\nimport usePayloadAPI from '../../../hooks/usePayloadAPI'\nimport buildStateFromSchema from '../../forms/Form/buildStateFromSchema'\nimport { fieldTypes } from '../../forms/field-types'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport { useDocumentEvents } from '../../utilities/DocumentEvents'\nimport { useDocumentInfo } from '../../utilities/DocumentInfo'\nimport { EditDepthContext } from '../../utilities/EditDepth'\nimport { useLocale } from '../../utilities/Locale'\nimport { usePreferences } from '../../utilities/Preferences'\nimport RenderCustomComponent from '../../utilities/RenderCustomComponent'\nimport DefaultGlobalView from './Default'\n\nconst GlobalView: React.FC<IndexProps> = (props) => {\n  const { global } = props\n\n  const { state: locationState } = useLocation<{ data?: Record<string, unknown> }>()\n  const { code: locale } = useLocale()\n  const { permissions, user } = useAuth()\n  const [initialState, setInitialState] = useState<Fields>()\n  const [updatedAt, setUpdatedAt] = useState<string>()\n  const { docPermissions, getDocPermissions, getDocPreferences, getVersions, preferencesKey } =\n    useDocumentInfo()\n  const { getPreference } = usePreferences()\n  const { t } = useTranslation()\n  const config = useConfig()\n\n  const {\n    routes: { api },\n    serverURL,\n  } = useConfig()\n\n  const { reportUpdate } = useDocumentEvents()\n\n  const { slug, admin: { components: { views: { Edit: Edit } = {} } = {} } = {}, fields } = global\n\n  const onSave = useCallback(\n    async (json) => {\n      reportUpdate({\n        entitySlug: global.slug,\n        updatedAt: json?.result?.updatedAt || new Date().toISOString(),\n      })\n\n      getVersions()\n      getDocPermissions()\n      setUpdatedAt(json?.result?.updatedAt)\n\n      const preferences = await getDocPreferences()\n\n      const state = await buildStateFromSchema({\n        config,\n        data: json.result,\n        fieldSchema: fields,\n        locale,\n        operation: 'update',\n        preferences,\n        t,\n        user,\n      })\n      setInitialState(state)\n    },\n    [\n      getVersions,\n      fields,\n      user,\n      locale,\n      t,\n      getDocPermissions,\n      getDocPreferences,\n      config,\n      global,\n      reportUpdate,\n    ],\n  )\n\n  const [{ data, isLoading: isLoadingData }] = usePayloadAPI(`${serverURL}${api}/globals/${slug}`, {\n    initialData: null,\n    initialParams: { depth: 0, draft: 'true', 'fallback-locale': 'null' },\n  })\n\n  const dataToRender = locationState?.data || data\n\n  useEffect(() => {\n    const awaitInitialState = async () => {\n      const preferences = await getDocPreferences()\n      const state = await buildStateFromSchema({\n        config,\n        data: dataToRender,\n        fieldSchema: fields,\n        locale,\n        operation: 'update',\n        preferences,\n        t,\n        user,\n      })\n\n      if (preferencesKey) {\n        await getPreference(preferencesKey)\n      }\n\n      setInitialState(state)\n    }\n\n    if (dataToRender) awaitInitialState()\n  }, [\n    dataToRender,\n    fields,\n    user,\n    locale,\n    getPreference,\n    preferencesKey,\n    t,\n    getDocPreferences,\n    config,\n  ])\n\n  const isLoading = !initialState || !docPermissions || isLoadingData\n\n  const componentProps: DefaultGlobalViewProps = {\n    action: `${serverURL}${api}/globals/${slug}?locale=${locale}&fallback-locale=null`,\n    apiURL: `${serverURL}${api}/globals/${slug}?locale=${locale}${\n      global.versions?.drafts ? '&draft=true' : ''\n    }`,\n    canAccessAdmin: permissions?.canAccessAdmin,\n    data: dataToRender,\n    fieldTypes,\n    global,\n    initialState,\n    isLoading,\n    onSave,\n    permissions: docPermissions,\n    updatedAt: updatedAt || dataToRender?.updatedAt,\n    user,\n  }\n\n  return (\n    <EditDepthContext.Provider value={1}>\n      <RenderCustomComponent\n        CustomComponent={typeof Edit === 'function' ? Edit : undefined}\n        DefaultComponent={DefaultGlobalView}\n        componentProps={componentProps}\n      />\n    </EditDepthContext.Provider>\n  )\n}\nexport default GlobalView\n"],"names":["GlobalView","props","global","state","locationState","useLocation","code","locale","useLocale","permissions","user","useAuth","initialState","setInitialState","useState","updatedAt","setUpdatedAt","docPermissions","getDocPermissions","getDocPreferences","getVersions","preferencesKey","useDocumentInfo","getPreference","usePreferences","t","useTranslation","config","useConfig","routes","api","serverURL","reportUpdate","useDocumentEvents","slug","admin","components","views","Edit","fields","onSave","useCallback","json","entitySlug","result","Date","toISOString","preferences","buildStateFromSchema","data","fieldSchema","operation","isLoading","isLoadingData","usePayloadAPI","initialData","initialParams","depth","draft","dataToRender","useEffect","awaitInitialState","componentProps","action","apiURL","versions","drafts","canAccessAdmin","fieldTypes","EditDepthContext","Provider","value","RenderCustomComponent","CustomComponent","undefined","DefaultComponent","DefaultGlobalView"],"mappings":"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"}