UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

182 lines (181 loc) • 17.7 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 _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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"}