UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

186 lines (185 loc) • 17.3 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 _StepNav = require("../../elements/StepNav"); 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 _DocumentInfo = require("../../utilities/DocumentInfo"); 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 AccountView = ()=>{ const { state: locationState } = (0, _reactrouterdom.useLocation)(); const { code: locale } = (0, _Locale.useLocale)(); const { setStepNav } = (0, _StepNav.useStepNav)(); const { user } = (0, _Auth.useAuth)(); const userRef = (0, _react.useRef)(user); const [internalState, setInternalState] = (0, _react.useState)(); const { id, slug, collection, docPermissions, getDocPermissions, getDocPreferences, preferencesKey } = (0, _DocumentInfo.useDocumentInfo)(); const { getPreference } = (0, _Preferences.usePreferences)(); const config = (0, _Config.useConfig)(); const { admin: { components: { views: { Account: CustomAccountComponent } = {} } = {} }, routes: { api }, serverURL } = (0, _Config.useConfig)(); const { t } = (0, _reacti18next.useTranslation)('authentication'); const { fields } = collection || {}; const [{ data, isLoading: isLoadingData }] = (0, _usePayloadAPI.default)(`${serverURL}${api}/${slug}/${id}`, { initialData: null, initialParams: { depth: 0, 'fallback-locale': 'null' } }); const hasSavePermission = docPermissions?.update?.permission; const dataToRender = locationState?.data || data; const apiURL = `${serverURL}${api}/${slug}/${data?.id}?locale=${locale}`; const action = `${serverURL}${api}/${slug}/${data?.id}?locale=${locale}`; const onSave = _react.default.useCallback(async (json)=>{ await getDocPermissions(); const preferences = await getDocPreferences(); const state = await (0, _buildStateFromSchema.default)({ id, config, data: json.doc, fieldSchema: collection?.fields, locale, operation: 'update', preferences, t, user }); setInternalState(state); }, [ collection, user, id, t, locale, getDocPermissions, getDocPreferences, config ]); (0, _react.useEffect)(()=>{ const nav = [ { label: t('account') } ]; setStepNav(nav); }, [ setStepNav, t ]); (0, _react.useEffect)(()=>{ const awaitInternalState = async ()=>{ const preferences = await getDocPreferences(); const state = await (0, _buildStateFromSchema.default)({ id, config, data: dataToRender, fieldSchema: fields, locale, operation: 'update', preferences, t, user: userRef.current }); if (preferencesKey) { await getPreference(preferencesKey); } setInternalState(state); }; if (dataToRender) awaitInternalState(); }, [ dataToRender, fields, id, locale, preferencesKey, getPreference, t, getDocPreferences, config ]); const isLoading = !internalState || !docPermissions || isLoadingData; const componentProps = { id: id.toString(), action, apiURL, collection, data, fieldTypes: _fieldtypes.fieldTypes, hasSavePermission, initialState: internalState, isLoading, onSave, permissions: docPermissions, updatedAt: data?.updatedAt, user }; return /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, { CustomComponent: typeof CustomAccountComponent === 'function' ? CustomAccountComponent : undefined, DefaultComponent: _Default.default, componentProps: componentProps }); }; const _default = AccountView; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/views/Account/index.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useLocation } from 'react-router-dom'\n\nimport type { CollectionPermission } from '../../../../auth'\nimport type { Fields } from '../../forms/Form/types'\nimport type { DefaultAccountViewProps } from './Default'\n\nimport usePayloadAPI from '../../../hooks/usePayloadAPI'\nimport { useStepNav } from '../../elements/StepNav'\nimport buildStateFromSchema from '../../forms/Form/buildStateFromSchema'\nimport { fieldTypes } from '../../forms/field-types'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport { useDocumentInfo } from '../../utilities/DocumentInfo'\nimport { useLocale } from '../../utilities/Locale'\nimport { usePreferences } from '../../utilities/Preferences'\nimport RenderCustomComponent from '../../utilities/RenderCustomComponent'\nimport DefaultAccount from './Default'\n\nconst AccountView: React.FC = () => {\n  const { state: locationState } = useLocation<{ data: unknown }>()\n  const { code: locale } = useLocale()\n  const { setStepNav } = useStepNav()\n  const { user } = useAuth()\n  const userRef = useRef(user)\n  const [internalState, setInternalState] = useState<Fields>()\n  const {\n    id,\n    slug,\n    collection,\n    docPermissions,\n    getDocPermissions,\n    getDocPreferences,\n    preferencesKey,\n  } = useDocumentInfo()\n  const { getPreference } = usePreferences()\n\n  const config = useConfig()\n\n  const {\n    admin: { components: { views: { Account: CustomAccountComponent } = {} } = {} },\n    routes: { api },\n    serverURL,\n  } = useConfig()\n\n  const { t } = useTranslation('authentication')\n\n  const { fields } = collection || {}\n\n  const [{ data, isLoading: isLoadingData }] = usePayloadAPI(`${serverURL}${api}/${slug}/${id}`, {\n    initialData: null,\n    initialParams: {\n      depth: 0,\n      'fallback-locale': 'null',\n    },\n  })\n\n  const hasSavePermission = docPermissions?.update?.permission\n  const dataToRender = locationState?.data || data\n  const apiURL = `${serverURL}${api}/${slug}/${data?.id}?locale=${locale}`\n\n  const action = `${serverURL}${api}/${slug}/${data?.id}?locale=${locale}`\n\n  const onSave = React.useCallback(\n    async (json: any) => {\n      await getDocPermissions()\n\n      const preferences = await getDocPreferences()\n\n      const state = await buildStateFromSchema({\n        id,\n        config,\n        data: json.doc,\n        fieldSchema: collection?.fields,\n        locale,\n        operation: 'update',\n        preferences,\n        t,\n        user,\n      })\n      setInternalState(state)\n    },\n    [collection, user, id, t, locale, getDocPermissions, getDocPreferences, config],\n  )\n\n  useEffect(() => {\n    const nav = [\n      {\n        label: t('account'),\n      },\n    ]\n\n    setStepNav(nav)\n  }, [setStepNav, t])\n\n  useEffect(() => {\n    const awaitInternalState = async () => {\n      const preferences = await getDocPreferences()\n\n      const state = await buildStateFromSchema({\n        id,\n        config,\n        data: dataToRender,\n        fieldSchema: fields,\n        locale,\n        operation: 'update',\n        preferences,\n        t,\n        user: userRef.current,\n      })\n\n      if (preferencesKey) {\n        await getPreference(preferencesKey)\n      }\n\n      setInternalState(state)\n    }\n\n    if (dataToRender) awaitInternalState()\n  }, [\n    dataToRender,\n    fields,\n    id,\n    locale,\n    preferencesKey,\n    getPreference,\n    t,\n    getDocPreferences,\n    config,\n  ])\n\n  const isLoading = !internalState || !docPermissions || isLoadingData\n\n  const componentProps: DefaultAccountViewProps = {\n    id: id.toString(),\n    action,\n    apiURL,\n    collection,\n    data,\n    fieldTypes,\n    hasSavePermission,\n    initialState: internalState,\n    isLoading,\n    onSave,\n    permissions: docPermissions as CollectionPermission,\n    updatedAt: data?.updatedAt,\n    user,\n  }\n\n  return (\n    <RenderCustomComponent\n      CustomComponent={\n        typeof CustomAccountComponent === 'function' ? CustomAccountComponent : undefined\n      }\n      DefaultComponent={DefaultAccount}\n      componentProps={componentProps}\n    />\n  )\n}\n\nexport default AccountView\n"],"names":["AccountView","state","locationState","useLocation","code","locale","useLocale","setStepNav","useStepNav","user","useAuth","userRef","useRef","internalState","setInternalState","useState","id","slug","collection","docPermissions","getDocPermissions","getDocPreferences","preferencesKey","useDocumentInfo","getPreference","usePreferences","config","useConfig","admin","components","views","Account","CustomAccountComponent","routes","api","serverURL","t","useTranslation","fields","data","isLoading","isLoadingData","usePayloadAPI","initialData","initialParams","depth","hasSavePermission","update","permission","dataToRender","apiURL","action","onSave","React","useCallback","json","preferences","buildStateFromSchema","doc","fieldSchema","operation","useEffect","nav","label","awaitInternalState","current","componentProps","toString","fieldTypes","initialState","permissions","updatedAt","RenderCustomComponent","CustomComponent","undefined","DefaultComponent","DefaultAccount"],"mappings":"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"}