payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
186 lines (185 loc) • 17.3 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 _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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"}