@payloadcms/next 3.0.0-alpha.21 → 3.0.0-alpha.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/utilities/initPage.d.ts.map +1 -1
- package/dist/utilities/initPage.js +8 -2
- package/dist/views/Document/getMetaBySegment.d.ts.map +1 -1
- package/dist/views/Document/getMetaBySegment.js +4 -6
- package/dist/views/Document/index.d.ts.map +1 -1
- package/dist/views/Document/index.js +27 -19
- package/dist/views/NotFound/index.client.d.ts +6 -0
- package/dist/views/NotFound/index.client.d.ts.map +1 -0
- package/dist/views/NotFound/index.client.js +37 -0
- package/dist/views/NotFound/index.d.ts +10 -5
- package/dist/views/NotFound/index.d.ts.map +1 -1
- package/dist/views/NotFound/index.js +17 -33
- package/dist/views/NotFound/meta.d.ts +7 -0
- package/dist/views/NotFound/meta.d.ts.map +1 -0
- package/dist/views/NotFound/meta.js +11 -0
- package/dist/views/Root/index.d.ts +9 -10
- package/dist/views/Root/index.d.ts.map +1 -1
- package/dist/views/Root/index.js +47 -84
- package/dist/views/Root/meta.d.ts.map +1 -1
- package/dist/views/Root/meta.js +8 -1
- package/package.json +6 -6
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"initPage.d.ts","sourceRoot":"","sources":["../../src/utilities/initPage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,cAAc,EAGd,eAAe,EAEhB,MAAM,eAAe,CAAA;AActB,KAAK,IAAI,GAAG;IACV,MAAM,EAAE,OAAO,CAAC,eAAe,CAAC,GAAG,eAAe,CAAA;IAClD,2BAA2B,CAAC,EAAE,OAAO,CAAA;IACrC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,YAAY,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;CAChE,CAAA;AAED,eAAO,MAAM,QAAQ,iFAKlB,IAAI,KAAG,QAAQ,cAAc,
|
|
1
|
+
{"version":3,"file":"initPage.d.ts","sourceRoot":"","sources":["../../src/utilities/initPage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,cAAc,EAGd,eAAe,EAEhB,MAAM,eAAe,CAAA;AActB,KAAK,IAAI,GAAG;IACV,MAAM,EAAE,OAAO,CAAC,eAAe,CAAC,GAAG,eAAe,CAAA;IAClD,2BAA2B,CAAC,EAAE,OAAO,CAAA;IACrC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,YAAY,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;CAChE,CAAA;AAED,eAAO,MAAM,QAAQ,iFAKlB,IAAI,KAAG,QAAQ,cAAc,CAkF/B,CAAA"}
|
|
@@ -2,7 +2,7 @@ import { initI18n } from '@payloadcms/translations';
|
|
|
2
2
|
import { translations } from '@payloadcms/translations/client';
|
|
3
3
|
import { findLocaleFromCode } from '@payloadcms/ui';
|
|
4
4
|
import { headers as getHeaders } from 'next/headers';
|
|
5
|
-
import { redirect } from 'next/navigation';
|
|
5
|
+
import { notFound, redirect } from 'next/navigation';
|
|
6
6
|
import { createLocalReq } from 'payload/utilities';
|
|
7
7
|
import qs from 'qs';
|
|
8
8
|
import { getPayload } from '../utilities/getPayload';
|
|
@@ -54,9 +54,15 @@ export const initPage = async ({ config: configPromise, redirectUnauthenticatedU
|
|
|
54
54
|
let globalConfig;
|
|
55
55
|
if (collectionSlug) {
|
|
56
56
|
collectionConfig = collections.find((collection)=>collection.slug === collectionSlug);
|
|
57
|
+
if (!collectionConfig) {
|
|
58
|
+
notFound();
|
|
59
|
+
}
|
|
57
60
|
}
|
|
58
61
|
if (globalSlug) {
|
|
59
62
|
globalConfig = globals.find((global)=>global.slug === globalSlug);
|
|
63
|
+
if (!globalConfig) {
|
|
64
|
+
notFound();
|
|
65
|
+
}
|
|
60
66
|
}
|
|
61
67
|
return {
|
|
62
68
|
collectionConfig,
|
|
@@ -70,4 +76,4 @@ export const initPage = async ({ config: configPromise, redirectUnauthenticatedU
|
|
|
70
76
|
};
|
|
71
77
|
};
|
|
72
78
|
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/initPage.ts"],"sourcesContent":["import type {\n  InitPageResult,\n  PayloadRequest,\n  SanitizedCollectionConfig,\n  SanitizedConfig,\n  SanitizedGlobalConfig,\n} from 'payload/types'\n\nimport { initI18n } from '@payloadcms/translations'\nimport { translations } from '@payloadcms/translations/client'\nimport { findLocaleFromCode } from '@payloadcms/ui'\nimport { headers as getHeaders } from 'next/headers'\nimport { notFound, redirect } from 'next/navigation'\nimport { createLocalReq } from 'payload/utilities'\nimport qs from 'qs'\n\nimport { getPayload } from '../utilities/getPayload'\nimport { auth } from './auth'\nimport { getRequestLanguage } from './getRequestLanguage'\n\ntype Args = {\n  config: Promise<SanitizedConfig> | SanitizedConfig\n  redirectUnauthenticatedUser?: boolean\n  route?: string\n  searchParams?: { [key: string]: string | string[] | undefined }\n}\n\nexport const initPage = async ({\n  config: configPromise,\n  redirectUnauthenticatedUser = false,\n  route,\n  searchParams,\n}: Args): Promise<InitPageResult> => {\n  const headers = getHeaders()\n  const localeParam = searchParams?.locale as string\n  const payload = await getPayload({ config: configPromise })\n\n  const { cookies, permissions, user } = await auth({\n    headers,\n    payload,\n  })\n\n  const routeSegments = route.replace(payload.config.routes.admin, '').split('/').filter(Boolean)\n  const [entityType, entitySlug, createOrID] = routeSegments\n  const collectionSlug = entityType === 'collections' ? entitySlug : undefined\n  const globalSlug = entityType === 'globals' ? entitySlug : undefined\n  const docID = collectionSlug && createOrID !== 'create' ? createOrID : undefined\n\n  const { collections, globals, localization, routes } = payload.config\n\n  if (redirectUnauthenticatedUser && !user && route !== '/login') {\n    if ('redirect' in searchParams) delete searchParams.redirect\n\n    const stringifiedSearchParams = Object.keys(searchParams ?? {}).length\n      ? `?${qs.stringify(searchParams)}`\n      : ''\n\n    redirect(`${routes.admin}/login?redirect=${route + stringifiedSearchParams}`)\n  }\n\n  const defaultLocale =\n    localization && localization.defaultLocale ? localization.defaultLocale : 'en'\n  const localeCode = localeParam || defaultLocale\n  const locale = localization && findLocaleFromCode(localization, localeCode)\n  const language = getRequestLanguage({ cookies, headers })\n\n  const i18n = initI18n({\n    config: payload.config.i18n,\n    context: 'client',\n    language,\n    translations,\n  })\n\n  const req = await createLocalReq(\n    {\n      fallbackLocale: null,\n      locale: locale.code,\n      req: {\n        i18n,\n      } as PayloadRequest,\n      user,\n    },\n    payload,\n  )\n\n  let collectionConfig: SanitizedCollectionConfig\n  let globalConfig: SanitizedGlobalConfig\n\n  if (collectionSlug) {\n    collectionConfig = collections.find((collection) => collection.slug === collectionSlug)\n\n    if (!collectionConfig) {\n      notFound()\n    }\n  }\n\n  if (globalSlug) {\n    globalConfig = globals.find((global) => global.slug === globalSlug)\n\n    if (!globalConfig) {\n      notFound()\n    }\n  }\n\n  return {\n    collectionConfig,\n    cookies,\n    docID,\n    globalConfig,\n    locale,\n    permissions,\n    req,\n    translations: i18n.translations,\n  }\n}\n"],"names":["initI18n","translations","findLocaleFromCode","headers","getHeaders","notFound","redirect","createLocalReq","qs","getPayload","auth","getRequestLanguage","initPage","config","configPromise","redirectUnauthenticatedUser","route","searchParams","localeParam","locale","payload","cookies","permissions","user","routeSegments","replace","routes","admin","split","filter","Boolean","entityType","entitySlug","createOrID","collectionSlug","undefined","globalSlug","docID","collections","globals","localization","stringifiedSearchParams","Object","keys","length","stringify","defaultLocale","localeCode","language","i18n","context","req","fallbackLocale","code","collectionConfig","globalConfig","find","collection","slug","global"],"mappings":"AAQA,SAASA,QAAQ,QAAQ,2BAA0B;AACnD,SAASC,YAAY,QAAQ,kCAAiC;AAC9D,SAASC,kBAAkB,QAAQ,iBAAgB;AACnD,SAASC,WAAWC,UAAU,QAAQ,eAAc;AACpD,SAASC,QAAQ,EAAEC,QAAQ,QAAQ,kBAAiB;AACpD,SAASC,cAAc,QAAQ,oBAAmB;AAClD,OAAOC,QAAQ,KAAI;AAEnB,SAASC,UAAU,QAAQ,0BAAyB;AACpD,SAASC,IAAI,QAAQ,SAAQ;AAC7B,SAASC,kBAAkB,QAAQ,uBAAsB;AASzD,OAAO,MAAMC,WAAW,OAAO,EAC7BC,QAAQC,aAAa,EACrBC,8BAA8B,KAAK,EACnCC,KAAK,EACLC,YAAY,EACP;IACL,MAAMd,UAAUC;IAChB,MAAMc,cAAcD,cAAcE;IAClC,MAAMC,UAAU,MAAMX,WAAW;QAAEI,QAAQC;IAAc;IAEzD,MAAM,EAAEO,OAAO,EAAEC,WAAW,EAAEC,IAAI,EAAE,GAAG,MAAMb,KAAK;QAChDP;QACAiB;IACF;IAEA,MAAMI,gBAAgBR,MAAMS,OAAO,CAACL,QAAQP,MAAM,CAACa,MAAM,CAACC,KAAK,EAAE,IAAIC,KAAK,CAAC,KAAKC,MAAM,CAACC;IACvF,MAAM,CAACC,YAAYC,YAAYC,WAAW,GAAGT;IAC7C,MAAMU,iBAAiBH,eAAe,gBAAgBC,aAAaG;IACnE,MAAMC,aAAaL,eAAe,YAAYC,aAAaG;IAC3D,MAAME,QAAQH,kBAAkBD,eAAe,WAAWA,aAAaE;IAEvE,MAAM,EAAEG,WAAW,EAAEC,OAAO,EAAEC,YAAY,EAAEd,MAAM,EAAE,GAAGN,QAAQP,MAAM;IAErE,IAAIE,+BAA+B,CAACQ,QAAQP,UAAU,UAAU;QAC9D,IAAI,cAAcC,cAAc,OAAOA,aAAaX,QAAQ;QAE5D,MAAMmC,0BAA0BC,OAAOC,IAAI,CAAC1B,gBAAgB,CAAC,GAAG2B,MAAM,GAClE,CAAC,CAAC,EAAEpC,GAAGqC,SAAS,CAAC5B,cAAc,CAAC,GAChC;QAEJX,SAAS,CAAC,EAAEoB,OAAOC,KAAK,CAAC,gBAAgB,EAAEX,QAAQyB,wBAAwB,CAAC;IAC9E;IAEA,MAAMK,gBACJN,gBAAgBA,aAAaM,aAAa,GAAGN,aAAaM,aAAa,GAAG;IAC5E,MAAMC,aAAa7B,eAAe4B;IAClC,MAAM3B,SAASqB,gBAAgBtC,mBAAmBsC,cAAcO;IAChE,MAAMC,WAAWrC,mBAAmB;QAAEU;QAASlB;IAAQ;IAEvD,MAAM8C,OAAOjD,SAAS;QACpBa,QAAQO,QAAQP,MAAM,CAACoC,IAAI;QAC3BC,SAAS;QACTF;QACA/C;IACF;IAEA,MAAMkD,MAAM,MAAM5C,eAChB;QACE6C,gBAAgB;QAChBjC,QAAQA,OAAOkC,IAAI;QACnBF,KAAK;YACHF;QACF;QACA1B;IACF,GACAH;IAGF,IAAIkC;IACJ,IAAIC;IAEJ,IAAIrB,gBAAgB;QAClBoB,mBAAmBhB,YAAYkB,IAAI,CAAC,CAACC,aAAeA,WAAWC,IAAI,KAAKxB;QAExE,IAAI,CAACoB,kBAAkB;YACrBjD;QACF;IACF;IAEA,IAAI+B,YAAY;QACdmB,eAAehB,QAAQiB,IAAI,CAAC,CAACG,SAAWA,OAAOD,IAAI,KAAKtB;QAExD,IAAI,CAACmB,cAAc;YACjBlD;QACF;IACF;IAEA,OAAO;QACLiD;QACAjC;QACAgB;QACAkB;QACApC;QACAG;QACA6B;QACAlD,cAAcgD,KAAKhD,YAAY;IACjC;AACF,EAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getMetaBySegment.d.ts","sourceRoot":"","sources":["../../../src/views/Document/getMetaBySegment.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAA;AACpC,OAAO,KAAK,EAAE,yBAAyB,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAA;
|
|
1
|
+
{"version":3,"file":"getMetaBySegment.d.ts","sourceRoot":"","sources":["../../../src/views/Document/getMetaBySegment.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAA;AACpC,OAAO,KAAK,EAAE,yBAAyB,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAA;AAQrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAA;AAG9C,MAAM,MAAM,wBAAwB,GAAG,CACrC,IAAI,EAAE,UAAU,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,GAAG;IAC1C,gBAAgB,CAAC,EAAE,yBAAyB,GAAG,IAAI,CAAA;IACnD,YAAY,CAAC,EAAE,qBAAqB,GAAG,IAAI,CAAA;IAC3C,SAAS,EAAE,OAAO,CAAA;CACnB,KACE,OAAO,CAAC,QAAQ,CAAC,CAAA;AAEtB,eAAO,MAAM,gBAAgB,EAAE,wBAqF9B,CAAA"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { getNextI18n } from '../../utilities/getNextI18n';
|
|
2
|
-
import { meta } from '../../utilities/meta';
|
|
3
2
|
import { generateMetadata as apiMeta } from '../API/meta';
|
|
4
3
|
import { generateMetadata as editMeta } from '../Edit/meta';
|
|
5
4
|
import { generateMetadata as livePreviewMeta } from '../LivePreview/meta';
|
|
6
5
|
import { generateMetadata as versionMeta } from '../Version/meta';
|
|
7
6
|
import { generateMetadata as versionsMeta } from '../Versions/meta';
|
|
7
|
+
import { generateNotFoundMeta } from '../NotFound/meta';
|
|
8
8
|
export const getMetaBySegment = async ({ config, params, collectionConfig, globalConfig })=>{
|
|
9
9
|
const { segments } = params;
|
|
10
10
|
let fn = null;
|
|
@@ -68,12 +68,10 @@ export const getMetaBySegment = async ({ config, params, collectionConfig, globa
|
|
|
68
68
|
isEditing
|
|
69
69
|
});
|
|
70
70
|
}
|
|
71
|
-
return
|
|
71
|
+
return generateNotFoundMeta({
|
|
72
72
|
config,
|
|
73
|
-
|
|
74
|
-
keywords: '',
|
|
75
|
-
title: ''
|
|
73
|
+
i18n
|
|
76
74
|
});
|
|
77
75
|
};
|
|
78
76
|
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy92aWV3cy9Eb2N1bWVudC9nZXRNZXRhQnlTZWdtZW50LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE1ldGFkYXRhIH0gZnJvbSAnbmV4dCdcbmltcG9ydCB0eXBlIHsgU2FuaXRpemVkQ29sbGVjdGlvbkNvbmZpZywgU2FuaXRpemVkR2xvYmFsQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgZ2V0TmV4dEkxOG4gfSBmcm9tICcuLi8uLi91dGlsaXRpZXMvZ2V0TmV4dEkxOG4nXG5pbXBvcnQgeyBnZW5lcmF0ZU1ldGFkYXRhIGFzIGFwaU1ldGEgfSBmcm9tICcuLi9BUEkvbWV0YSdcbmltcG9ydCB7IGdlbmVyYXRlTWV0YWRhdGEgYXMgZWRpdE1ldGEgfSBmcm9tICcuLi9FZGl0L21ldGEnXG5pbXBvcnQgeyBnZW5lcmF0ZU1ldGFkYXRhIGFzIGxpdmVQcmV2aWV3TWV0YSB9IGZyb20gJy4uL0xpdmVQcmV2aWV3L21ldGEnXG5pbXBvcnQgeyBnZW5lcmF0ZU1ldGFkYXRhIGFzIHZlcnNpb25NZXRhIH0gZnJvbSAnLi4vVmVyc2lvbi9tZXRhJ1xuaW1wb3J0IHsgZ2VuZXJhdGVNZXRhZGF0YSBhcyB2ZXJzaW9uc01ldGEgfSBmcm9tICcuLi9WZXJzaW9ucy9tZXRhJ1xuaW1wb3J0IHsgR2VuZXJhdGVWaWV3TWV0YWRhdGEgfSBmcm9tICcuLi9Sb290J1xuaW1wb3J0IHsgZ2VuZXJhdGVOb3RGb3VuZE1ldGEgfSBmcm9tICcuLi9Ob3RGb3VuZC9tZXRhJ1xuXG5leHBvcnQgdHlwZSBHZW5lcmF0ZUVkaXRWaWV3TWV0YWRhdGEgPSAoXG4gIGFyZ3M6IFBhcmFtZXRlcnM8R2VuZXJhdGVWaWV3TWV0YWRhdGE+WzBdICYge1xuICAgIGNvbGxlY3Rpb25Db25maWc/OiBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIHwgbnVsbFxuICAgIGdsb2JhbENvbmZpZz86IFNhbml0aXplZEdsb2JhbENvbmZpZyB8IG51bGxcbiAgICBpc0VkaXRpbmc6IGJvb2xlYW5cbiAgfSxcbikgPT4gUHJvbWlzZTxNZXRhZGF0YT5cblxuZXhwb3J0IGNvbnN0IGdldE1ldGFCeVNlZ21lbnQ6IEdlbmVyYXRlRWRpdFZpZXdNZXRhZGF0YSA9IGFzeW5jICh7XG4gIGNvbmZpZyxcbiAgcGFyYW1zLFxuICBjb2xsZWN0aW9uQ29uZmlnLFxuICBnbG9iYWxDb25maWcsXG59KSA9PiB7XG4gIGNvbnN0IHsgc2VnbWVudHMgfSA9IHBhcmFtc1xuXG4gIGxldCBmbjogR2VuZXJhdGVFZGl0Vmlld01ldGFkYXRhIHwgbnVsbCA9IG51bGxcblxuICBjb25zdCBbc2VnbWVudE9uZV0gPSBzZWdtZW50c1xuICBjb25zdCBpc0NvbGxlY3Rpb24gPSBzZWdtZW50T25lID09PSAnY29sbGVjdGlvbnMnXG4gIGNvbnN0IGlzR2xvYmFsID0gc2VnbWVudE9uZSA9PT0gJ2dsb2JhbHMnXG5cbiAgY29uc3QgaXNFZGl0aW5nID0gQm9vbGVhbihpc0NvbGxlY3Rpb24gJiYgc2VnbWVudHM/Lmxlbmd0aCA+IDIgJiYgc2VnbWVudHNbMl0gIT09ICdjcmVhdGUnKVxuXG4gIGlmIChpc0NvbGxlY3Rpb24pIHtcbiAgICAvLyBgLzppZGBcbiAgICBpZiAocGFyYW1zLnNlZ21lbnRzLmxlbmd0aCA9PT0gMykge1xuICAgICAgZm4gPSBlZGl0TWV0YVxuICAgIH1cblxuICAgIC8vIGAvOmlkL2FwaWBcbiAgICBpZiAocGFyYW1zLnNlZ21lbnRzLmxlbmd0aCA9PT0gNCAmJiBwYXJhbXMuc2VnbWVudHNbM10gPT09ICdhcGknKSB7XG4gICAgICBmbiA9IGFwaU1ldGFcbiAgICB9XG5cbiAgICAvLyBgLzppZC9wcmV2aWV3YFxuICAgIGlmIChwYXJhbXMuc2VnbWVudHMubGVuZ3RoID09PSA0ICYmIHBhcmFtcy5zZWdtZW50c1szXSA9PT0gJ3ByZXZpZXcnKSB7XG4gICAgICBmbiA9IGxpdmVQcmV2aWV3TWV0YVxuICAgIH1cblxuICAgIC8vIGAvOmlkL3ZlcnNpb25zYFxuICAgIGlmIChwYXJhbXMuc2VnbWVudHMubGVuZ3RoID09PSA0ICYmIHBhcmFtcy5zZWdtZW50c1szXSA9PT0gJ3ZlcnNpb25zJykge1xuICAgICAgZm4gPSB2ZXJzaW9uc01ldGFcbiAgICB9XG5cbiAgICAvLyBgLzppZC92ZXJzaW9ucy86dmVyc2lvbmBcbiAgICBpZiAocGFyYW1zLnNlZ21lbnRzLmxlbmd0aCA9PT0gNSAmJiBwYXJhbXMuc2VnbWVudHNbM10gPT09ICd2ZXJzaW9ucycpIHtcbiAgICAgIGZuID0gdmVyc2lvbk1ldGFcbiAgICB9XG4gIH1cblxuICBpZiAoaXNHbG9iYWwpIHtcbiAgICAvLyBgLzpzbHVnYFxuICAgIGlmIChwYXJhbXMuc2VnbWVudHM/Lmxlbmd0aCA9PT0gMikge1xuICAgICAgZm4gPSBlZGl0TWV0YVxuICAgIH1cblxuICAgIC8vIGAvOnNsdWcvYXBpYFxuICAgIGlmIChwYXJhbXMuc2VnbWVudHM/Lmxlbmd0aCA9PT0gMyAmJiBwYXJhbXMuc2VnbWVudHNbMl0gPT09ICdhcGknKSB7XG4gICAgICBmbiA9IGFwaU1ldGFcbiAgICB9XG5cbiAgICAvLyBgLzpzbHVnL3ByZXZpZXdgXG4gICAgaWYgKHBhcmFtcy5zZWdtZW50cz8ubGVuZ3RoID09PSAzICYmIHBhcmFtcy5zZWdtZW50c1syXSA9PT0gJ3ByZXZpZXcnKSB7XG4gICAgICBmbiA9IGxpdmVQcmV2aWV3TWV0YVxuICAgIH1cblxuICAgIC8vIGAvOnNsdWcvdmVyc2lvbnNgXG4gICAgaWYgKHBhcmFtcy5zZWdtZW50cz8ubGVuZ3RoID09PSAzICYmIHBhcmFtcy5zZWdtZW50c1syXSA9PT0gJ3ZlcnNpb25zJykge1xuICAgICAgZm4gPSB2ZXJzaW9uc01ldGFcbiAgICB9XG5cbiAgICAvLyBgLzpzbHVnL3ZlcnNpb25zLzp2ZXJzaW9uYFxuICAgIGlmIChwYXJhbXMuc2VnbWVudHM/Lmxlbmd0aCA9PT0gNCAmJiBwYXJhbXMuc2VnbWVudHNbMl0gPT09ICd2ZXJzaW9ucycpIHtcbiAgICAgIGZuID0gdmVyc2lvbk1ldGFcbiAgICB9XG4gIH1cblxuICBjb25zdCBpMThuID0gYXdhaXQgZ2V0TmV4dEkxOG4oe1xuICAgIGNvbmZpZyxcbiAgfSlcblxuICBpZiAodHlwZW9mIGZuID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcmV0dXJuIGZuKHtcbiAgICAgIGNvbGxlY3Rpb25Db25maWcsXG4gICAgICBjb25maWcsXG4gICAgICBnbG9iYWxDb25maWcsXG4gICAgICBpMThuLFxuICAgICAgaXNFZGl0aW5nLFxuICAgIH0pXG4gIH1cblxuICByZXR1cm4gZ2VuZXJhdGVOb3RGb3VuZE1ldGEoeyBjb25maWcsIGkxOG4gfSlcbn1cbiJdLCJuYW1lcyI6WyJnZXROZXh0STE4biIsImdlbmVyYXRlTWV0YWRhdGEiLCJhcGlNZXRhIiwiZWRpdE1ldGEiLCJsaXZlUHJldmlld01ldGEiLCJ2ZXJzaW9uTWV0YSIsInZlcnNpb25zTWV0YSIsImdlbmVyYXRlTm90Rm91bmRNZXRhIiwiZ2V0TWV0YUJ5U2VnbWVudCIsImNvbmZpZyIsInBhcmFtcyIsImNvbGxlY3Rpb25Db25maWciLCJnbG9iYWxDb25maWciLCJzZWdtZW50cyIsImZuIiwic2VnbWVudE9uZSIsImlzQ29sbGVjdGlvbiIsImlzR2xvYmFsIiwiaXNFZGl0aW5nIiwiQm9vbGVhbiIsImxlbmd0aCIsImkxOG4iXSwibWFwcGluZ3MiOiJBQUdBLFNBQVNBLFdBQVcsUUFBUSw4QkFBNkI7QUFDekQsU0FBU0Msb0JBQW9CQyxPQUFPLFFBQVEsY0FBYTtBQUN6RCxTQUFTRCxvQkFBb0JFLFFBQVEsUUFBUSxlQUFjO0FBQzNELFNBQVNGLG9CQUFvQkcsZUFBZSxRQUFRLHNCQUFxQjtBQUN6RSxTQUFTSCxvQkFBb0JJLFdBQVcsUUFBUSxrQkFBaUI7QUFDakUsU0FBU0osb0JBQW9CSyxZQUFZLFFBQVEsbUJBQWtCO0FBRW5FLFNBQVNDLG9CQUFvQixRQUFRLG1CQUFrQjtBQVV2RCxPQUFPLE1BQU1DLG1CQUE2QyxPQUFPLEVBQy9EQyxNQUFNLEVBQ05DLE1BQU0sRUFDTkMsZ0JBQWdCLEVBQ2hCQyxZQUFZLEVBQ2I7SUFDQyxNQUFNLEVBQUVDLFFBQVEsRUFBRSxHQUFHSDtJQUVyQixJQUFJSSxLQUFzQztJQUUxQyxNQUFNLENBQUNDLFdBQVcsR0FBR0Y7SUFDckIsTUFBTUcsZUFBZUQsZUFBZTtJQUNwQyxNQUFNRSxXQUFXRixlQUFlO0lBRWhDLE1BQU1HLFlBQVlDLFFBQVFILGdCQUFnQkgsVUFBVU8sU0FBUyxLQUFLUCxRQUFRLENBQUMsRUFBRSxLQUFLO0lBRWxGLElBQUlHLGNBQWM7UUFDaEIsU0FBUztRQUNULElBQUlOLE9BQU9HLFFBQVEsQ0FBQ08sTUFBTSxLQUFLLEdBQUc7WUFDaENOLEtBQUtYO1FBQ1A7UUFFQSxhQUFhO1FBQ2IsSUFBSU8sT0FBT0csUUFBUSxDQUFDTyxNQUFNLEtBQUssS0FBS1YsT0FBT0csUUFBUSxDQUFDLEVBQUUsS0FBSyxPQUFPO1lBQ2hFQyxLQUFLWjtRQUNQO1FBRUEsaUJBQWlCO1FBQ2pCLElBQUlRLE9BQU9HLFFBQVEsQ0FBQ08sTUFBTSxLQUFLLEtBQUtWLE9BQU9HLFFBQVEsQ0FBQyxFQUFFLEtBQUssV0FBVztZQUNwRUMsS0FBS1Y7UUFDUDtRQUVBLGtCQUFrQjtRQUNsQixJQUFJTSxPQUFPRyxRQUFRLENBQUNPLE1BQU0sS0FBSyxLQUFLVixPQUFPRyxRQUFRLENBQUMsRUFBRSxLQUFLLFlBQVk7WUFDckVDLEtBQUtSO1FBQ1A7UUFFQSwyQkFBMkI7UUFDM0IsSUFBSUksT0FBT0csUUFBUSxDQUFDTyxNQUFNLEtBQUssS0FBS1YsT0FBT0csUUFBUSxDQUFDLEVBQUUsS0FBSyxZQUFZO1lBQ3JFQyxLQUFLVDtRQUNQO0lBQ0Y7SUFFQSxJQUFJWSxVQUFVO1FBQ1osV0FBVztRQUNYLElBQUlQLE9BQU9HLFFBQVEsRUFBRU8sV0FBVyxHQUFHO1lBQ2pDTixLQUFLWDtRQUNQO1FBRUEsZUFBZTtRQUNmLElBQUlPLE9BQU9HLFFBQVEsRUFBRU8sV0FBVyxLQUFLVixPQUFPRyxRQUFRLENBQUMsRUFBRSxLQUFLLE9BQU87WUFDakVDLEtBQUtaO1FBQ1A7UUFFQSxtQkFBbUI7UUFDbkIsSUFBSVEsT0FBT0csUUFBUSxFQUFFTyxXQUFXLEtBQUtWLE9BQU9HLFFBQVEsQ0FBQyxFQUFFLEtBQUssV0FBVztZQUNyRUMsS0FBS1Y7UUFDUDtRQUVBLG9CQUFvQjtRQUNwQixJQUFJTSxPQUFPRyxRQUFRLEVBQUVPLFdBQVcsS0FBS1YsT0FBT0csUUFBUSxDQUFDLEVBQUUsS0FBSyxZQUFZO1lBQ3RFQyxLQUFLUjtRQUNQO1FBRUEsNkJBQTZCO1FBQzdCLElBQUlJLE9BQU9HLFFBQVEsRUFBRU8sV0FBVyxLQUFLVixPQUFPRyxRQUFRLENBQUMsRUFBRSxLQUFLLFlBQVk7WUFDdEVDLEtBQUtUO1FBQ1A7SUFDRjtJQUVBLE1BQU1nQixPQUFPLE1BQU1yQixZQUFZO1FBQzdCUztJQUNGO0lBRUEsSUFBSSxPQUFPSyxPQUFPLFlBQVk7UUFDNUIsT0FBT0EsR0FBRztZQUNSSDtZQUNBRjtZQUNBRztZQUNBUztZQUNBSDtRQUNGO0lBQ0Y7SUFFQSxPQUFPWCxxQkFBcUI7UUFBRUU7UUFBUVk7SUFBSztBQUM3QyxFQUFDIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Document/index.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Document/index.tsx"],"names":[],"mappings":"AAqBA,OAAO,KAAmB,MAAM,OAAO,CAAA;AAEvC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AAC7C,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,oBAAoB,CAAA;AAMlE,eAAO,MAAM,gBAAgB,EAAE,wBAAiE,CAAA;AAEhG,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAoM7C,CAAA"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { DocumentHeader, EditDepthProvider, FormQueryParamsProvider, HydrateClientUser, RenderCustomComponent, SetDocumentInfo, buildStateFromSchema, formatFields } from '@payloadcms/ui';
|
|
2
|
-
import { notFound } from 'next/navigation';
|
|
3
2
|
import queryString from 'qs';
|
|
4
3
|
import React, { Fragment } from 'react';
|
|
5
4
|
import { getMetaBySegment } from './getMetaBySegment';
|
|
6
5
|
import { getViewsFromConfig } from './getViewsFromConfig';
|
|
6
|
+
import { NotFoundClient } from '../NotFound/index.client';
|
|
7
7
|
export const generateMetadata = async (args)=>getMetaBySegment(args);
|
|
8
8
|
export const Document = async ({ initPageResult, params, searchParams })=>{
|
|
9
9
|
const { collectionConfig, docID: id, globalConfig, locale, permissions, req, req: { i18n, payload, payload: { config, config: { routes: { api: apiRoute }, serverURL } }, user } } = initPageResult;
|
|
@@ -36,18 +36,21 @@ export const Document = async ({ initPageResult, params, searchParams })=>{
|
|
|
36
36
|
CustomView = collectionViews?.CustomView;
|
|
37
37
|
DefaultView = collectionViews?.DefaultView;
|
|
38
38
|
if (!CustomView && !DefaultView) {
|
|
39
|
-
return
|
|
39
|
+
return /*#__PURE__*/ React.createElement(NotFoundClient, null);
|
|
40
40
|
}
|
|
41
|
-
try {
|
|
42
|
-
data = await payload.findByID({
|
|
43
|
-
id,
|
|
44
|
-
collection: collectionSlug,
|
|
45
|
-
depth: 0,
|
|
46
|
-
locale: locale.code,
|
|
47
|
-
user
|
|
48
|
-
});
|
|
49
|
-
} catch (error) {} // eslint-disable-line no-empty
|
|
50
41
|
if (id) {
|
|
42
|
+
try {
|
|
43
|
+
data = await payload.findByID({
|
|
44
|
+
id,
|
|
45
|
+
collection: collectionSlug,
|
|
46
|
+
depth: 0,
|
|
47
|
+
locale: locale.code,
|
|
48
|
+
user
|
|
49
|
+
});
|
|
50
|
+
} catch (error) {} // eslint-disable-line no-empty
|
|
51
|
+
if (!data) {
|
|
52
|
+
return /*#__PURE__*/ React.createElement(NotFoundClient, null);
|
|
53
|
+
}
|
|
51
54
|
preferencesKey = `collection-${collectionSlug}-${id}`;
|
|
52
55
|
}
|
|
53
56
|
}
|
|
@@ -67,14 +70,19 @@ export const Document = async ({ initPageResult, params, searchParams })=>{
|
|
|
67
70
|
CustomView = globalViews?.CustomView;
|
|
68
71
|
DefaultView = globalViews?.DefaultView;
|
|
69
72
|
if (!CustomView && !DefaultView) {
|
|
70
|
-
return
|
|
73
|
+
return /*#__PURE__*/ React.createElement(NotFoundClient, null);
|
|
74
|
+
}
|
|
75
|
+
try {
|
|
76
|
+
data = await payload.findGlobal({
|
|
77
|
+
slug: globalSlug,
|
|
78
|
+
depth: 0,
|
|
79
|
+
locale: locale.code,
|
|
80
|
+
user
|
|
81
|
+
});
|
|
82
|
+
} catch (error) {} // eslint-disable-line no-empty
|
|
83
|
+
if (!data) {
|
|
84
|
+
return /*#__PURE__*/ React.createElement(NotFoundClient, null);
|
|
71
85
|
}
|
|
72
|
-
data = await payload.findGlobal({
|
|
73
|
-
slug: globalSlug,
|
|
74
|
-
depth: 0,
|
|
75
|
-
locale: locale.code,
|
|
76
|
-
user
|
|
77
|
-
});
|
|
78
86
|
preferencesKey = `global-${globalSlug}`;
|
|
79
87
|
}
|
|
80
88
|
const { docs: [{ value: docPreferences } = {
|
|
@@ -141,4 +149,4 @@ export const Document = async ({ initPageResult, params, searchParams })=>{
|
|
|
141
149
|
}))));
|
|
142
150
|
};
|
|
143
151
|
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/views/Document/index.tsx"],"sourcesContent":["import type { QueryParamTypes } from '@payloadcms/ui'\nimport type { EditViewComponent } from 'payload/config'\nimport type {\n  DocumentPreferences,\n  Document as DocumentType,\n  Field,\n  ServerSideEditViewProps,\n} from 'payload/types'\nimport type { DocumentPermissions } from 'payload/types'\n\nimport {\n  DocumentHeader,\n  EditDepthProvider,\n  FormQueryParamsProvider,\n  HydrateClientUser,\n  RenderCustomComponent,\n  SetDocumentInfo,\n  buildStateFromSchema,\n  formatFields,\n} from '@payloadcms/ui'\nimport { notFound } from 'next/navigation'\nimport queryString from 'qs'\nimport React, { Fragment } from 'react'\n\nimport type { AdminViewProps } from '../Root'\nimport type { GenerateEditViewMetadata } from './getMetaBySegment'\n\nimport { getMetaBySegment } from './getMetaBySegment'\nimport { getViewsFromConfig } from './getViewsFromConfig'\n\nexport const generateMetadata: GenerateEditViewMetadata = async (args) => getMetaBySegment(args)\n\nexport const Document: React.FC<AdminViewProps> = async ({\n  initPageResult,\n  params,\n  searchParams,\n}) => {\n  const {\n    collectionConfig,\n    docID: id,\n    globalConfig,\n    locale,\n    permissions,\n    req,\n    req: {\n      i18n,\n      payload,\n      payload: {\n        config,\n        config: {\n          routes: { api: apiRoute },\n          serverURL,\n        },\n      },\n      user,\n    },\n  } = initPageResult\n\n  const segments = Array.isArray(params?.segments) ? params.segments : []\n  const collectionSlug = collectionConfig?.slug || undefined\n  const globalSlug = globalConfig?.slug || undefined\n\n  const isEditing = Boolean(globalSlug || (collectionSlug && !!id))\n\n  let CustomView: EditViewComponent\n  let DefaultView: EditViewComponent\n  let data: DocumentType\n  let docPermissions: DocumentPermissions\n  let preferencesKey: string\n  let fields: Field[]\n  let hasSavePermission: boolean\n  let apiURL: string\n  let action: string\n\n  if (collectionConfig) {\n    docPermissions = permissions?.collections?.[collectionSlug]\n    fields = collectionConfig.fields\n    action = `${serverURL}${apiRoute}/${collectionSlug}${isEditing ? `/${id}` : ''}`\n\n    hasSavePermission =\n      (isEditing && permissions?.collections?.[collectionSlug]?.update?.permission) ||\n      (!isEditing && permissions?.collections?.[collectionSlug]?.create?.permission)\n\n    apiURL = `${serverURL}${apiRoute}/${collectionSlug}/${id}?locale=${locale.code}${\n      collectionConfig.versions?.drafts ? '&draft=true' : ''\n    }`\n\n    const collectionViews = await getViewsFromConfig({\n      collectionConfig,\n      config,\n      docPermissions,\n      routeSegments: segments,\n      user,\n    })\n\n    CustomView = collectionViews?.CustomView\n    DefaultView = collectionViews?.DefaultView\n\n    if (!CustomView && !DefaultView) {\n      return notFound()\n    }\n\n    try {\n      data = await payload.findByID({\n        id,\n        collection: collectionSlug,\n        depth: 0,\n        locale: locale.code,\n        user,\n      })\n    } catch (error) {} // eslint-disable-line no-empty\n\n    if (id) {\n      preferencesKey = `collection-${collectionSlug}-${id}`\n    }\n  }\n\n  if (globalConfig) {\n    docPermissions = permissions?.globals?.[globalSlug]\n    fields = globalConfig.fields\n    hasSavePermission = isEditing && docPermissions?.update?.permission\n    action = `${serverURL}${apiRoute}/${globalSlug}`\n\n    apiURL = `${serverURL}${apiRoute}/${globalSlug}?locale=${locale.code}${\n      globalConfig.versions?.drafts ? '&draft=true' : ''\n    }`\n\n    const globalViews = await getViewsFromConfig({\n      config,\n      docPermissions,\n      globalConfig,\n      routeSegments: segments,\n      user,\n    })\n\n    CustomView = globalViews?.CustomView\n    DefaultView = globalViews?.DefaultView\n\n    if (!CustomView && !DefaultView) {\n      return notFound()\n    }\n\n    data = await payload.findGlobal({\n      slug: globalSlug,\n      depth: 0,\n      locale: locale.code,\n      user,\n    })\n\n    preferencesKey = `global-${globalSlug}`\n  }\n\n  const { docs: [{ value: docPreferences } = { value: null }] = [] } = (await payload.find({\n    collection: 'payload-preferences',\n    depth: 0,\n    limit: 1,\n    where: {\n      key: {\n        equals: preferencesKey,\n      },\n    },\n  })) as any as { docs: { value: DocumentPreferences }[] } // eslint-disable-line @typescript-eslint/no-explicit-any\n\n  const initialState = await buildStateFromSchema({\n    id,\n    data: data || {},\n    fieldSchema: formatFields(fields, isEditing),\n    operation: isEditing ? 'update' : 'create',\n    preferences: docPreferences,\n    req,\n  })\n\n  const formQueryParams: QueryParamTypes = {\n    depth: 0,\n    'fallback-locale': 'null',\n    locale: locale.code,\n    uploadEdits: undefined,\n  }\n\n  const serverSideProps: ServerSideEditViewProps = {\n    initPageResult,\n    routeSegments: segments,\n    searchParams,\n  }\n\n  return (\n    <Fragment>\n      <DocumentHeader\n        collectionConfig={collectionConfig}\n        config={payload.config}\n        globalConfig={globalConfig}\n        i18n={i18n}\n      />\n      <HydrateClientUser permissions={permissions} user={user} />\n      <SetDocumentInfo\n        action={`${action}?${queryString.stringify(formQueryParams)}`}\n        apiURL={apiURL}\n        collectionSlug={collectionConfig?.slug}\n        disableActions={false}\n        docPermissions={docPermissions}\n        docPreferences={docPreferences}\n        globalSlug={globalConfig?.slug}\n        hasSavePermission={hasSavePermission}\n        id={id}\n        initialData={data}\n        initialState={initialState}\n      />\n      <EditDepthProvider depth={1} key={`${collectionSlug || globalSlug}-${locale.code}`}>\n        <FormQueryParamsProvider formQueryParams={formQueryParams}>\n          <RenderCustomComponent\n            CustomComponent={typeof CustomView === 'function' ? CustomView : undefined}\n            DefaultComponent={DefaultView}\n            componentProps={serverSideProps}\n          />\n        </FormQueryParamsProvider>\n      </EditDepthProvider>\n    </Fragment>\n  )\n}\n"],"names":["DocumentHeader","EditDepthProvider","FormQueryParamsProvider","HydrateClientUser","RenderCustomComponent","SetDocumentInfo","buildStateFromSchema","formatFields","notFound","queryString","React","Fragment","getMetaBySegment","getViewsFromConfig","generateMetadata","args","Document","initPageResult","params","searchParams","collectionConfig","docID","id","globalConfig","locale","permissions","req","i18n","payload","config","routes","api","apiRoute","serverURL","user","segments","Array","isArray","collectionSlug","slug","undefined","globalSlug","isEditing","Boolean","CustomView","DefaultView","data","docPermissions","preferencesKey","fields","hasSavePermission","apiURL","action","collections","update","permission","create","code","versions","drafts","collectionViews","routeSegments","findByID","collection","depth","error","globals","globalViews","findGlobal","docs","value","docPreferences","find","limit","where","key","equals","initialState","fieldSchema","operation","preferences","formQueryParams","uploadEdits","serverSideProps","stringify","disableActions","initialData","CustomComponent","DefaultComponent","componentProps"],"mappings":"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"}
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/views/Document/index.tsx"],"sourcesContent":["import type { QueryParamTypes } from '@payloadcms/ui'\nimport type { EditViewComponent } from 'payload/config'\nimport type {\n  DocumentPreferences,\n  Document as DocumentType,\n  Field,\n  ServerSideEditViewProps,\n} from 'payload/types'\nimport type { DocumentPermissions } from 'payload/types'\n\nimport {\n  DocumentHeader,\n  EditDepthProvider,\n  FormQueryParamsProvider,\n  HydrateClientUser,\n  RenderCustomComponent,\n  SetDocumentInfo,\n  buildStateFromSchema,\n  formatFields,\n} from '@payloadcms/ui'\nimport queryString from 'qs'\nimport React, { Fragment } from 'react'\n\nimport type { AdminViewProps } from '../Root'\nimport type { GenerateEditViewMetadata } from './getMetaBySegment'\n\nimport { getMetaBySegment } from './getMetaBySegment'\nimport { getViewsFromConfig } from './getViewsFromConfig'\nimport { NotFoundClient } from '../NotFound/index.client'\n\nexport const generateMetadata: GenerateEditViewMetadata = async (args) => getMetaBySegment(args)\n\nexport const Document: React.FC<AdminViewProps> = async ({\n  initPageResult,\n  params,\n  searchParams,\n}) => {\n  const {\n    collectionConfig,\n    docID: id,\n    globalConfig,\n    locale,\n    permissions,\n    req,\n    req: {\n      i18n,\n      payload,\n      payload: {\n        config,\n        config: {\n          routes: { api: apiRoute },\n          serverURL,\n        },\n      },\n      user,\n    },\n  } = initPageResult\n\n  const segments = Array.isArray(params?.segments) ? params.segments : []\n  const collectionSlug = collectionConfig?.slug || undefined\n  const globalSlug = globalConfig?.slug || undefined\n\n  const isEditing = Boolean(globalSlug || (collectionSlug && !!id))\n\n  let CustomView: EditViewComponent\n  let DefaultView: EditViewComponent\n  let data: DocumentType\n  let docPermissions: DocumentPermissions\n  let preferencesKey: string\n  let fields: Field[]\n  let hasSavePermission: boolean\n  let apiURL: string\n  let action: string\n\n  if (collectionConfig) {\n    docPermissions = permissions?.collections?.[collectionSlug]\n    fields = collectionConfig.fields\n    action = `${serverURL}${apiRoute}/${collectionSlug}${isEditing ? `/${id}` : ''}`\n\n    hasSavePermission =\n      (isEditing && permissions?.collections?.[collectionSlug]?.update?.permission) ||\n      (!isEditing && permissions?.collections?.[collectionSlug]?.create?.permission)\n\n    apiURL = `${serverURL}${apiRoute}/${collectionSlug}/${id}?locale=${locale.code}${\n      collectionConfig.versions?.drafts ? '&draft=true' : ''\n    }`\n\n    const collectionViews = await getViewsFromConfig({\n      collectionConfig,\n      config,\n      docPermissions,\n      routeSegments: segments,\n      user,\n    })\n\n    CustomView = collectionViews?.CustomView\n    DefaultView = collectionViews?.DefaultView\n\n    if (!CustomView && !DefaultView) {\n      return <NotFoundClient />\n    }\n\n    if (id) {\n      try {\n        data = await payload.findByID({\n          id,\n          collection: collectionSlug,\n          depth: 0,\n          locale: locale.code,\n          user,\n        })\n      } catch (error) {} // eslint-disable-line no-empty\n\n      if (!data) {\n        return <NotFoundClient />\n      }\n\n      preferencesKey = `collection-${collectionSlug}-${id}`\n    }\n  }\n\n  if (globalConfig) {\n    docPermissions = permissions?.globals?.[globalSlug]\n    fields = globalConfig.fields\n    hasSavePermission = isEditing && docPermissions?.update?.permission\n    action = `${serverURL}${apiRoute}/${globalSlug}`\n\n    apiURL = `${serverURL}${apiRoute}/${globalSlug}?locale=${locale.code}${\n      globalConfig.versions?.drafts ? '&draft=true' : ''\n    }`\n\n    const globalViews = await getViewsFromConfig({\n      config,\n      docPermissions,\n      globalConfig,\n      routeSegments: segments,\n      user,\n    })\n\n    CustomView = globalViews?.CustomView\n    DefaultView = globalViews?.DefaultView\n\n    if (!CustomView && !DefaultView) {\n      return <NotFoundClient />\n    }\n\n    try {\n      data = await payload.findGlobal({\n        slug: globalSlug,\n        depth: 0,\n        locale: locale.code,\n        user,\n      })\n    } catch (error) {} // eslint-disable-line no-empty\n\n    if (!data) {\n      return <NotFoundClient />\n    }\n\n    preferencesKey = `global-${globalSlug}`\n  }\n\n  const { docs: [{ value: docPreferences } = { value: null }] = [] } = (await payload.find({\n    collection: 'payload-preferences',\n    depth: 0,\n    limit: 1,\n    where: {\n      key: {\n        equals: preferencesKey,\n      },\n    },\n  })) as any as { docs: { value: DocumentPreferences }[] } // eslint-disable-line @typescript-eslint/no-explicit-any\n\n  const initialState = await buildStateFromSchema({\n    id,\n    data: data || {},\n    fieldSchema: formatFields(fields, isEditing),\n    operation: isEditing ? 'update' : 'create',\n    preferences: docPreferences,\n    req,\n  })\n\n  const formQueryParams: QueryParamTypes = {\n    depth: 0,\n    'fallback-locale': 'null',\n    locale: locale.code,\n    uploadEdits: undefined,\n  }\n\n  const serverSideProps: ServerSideEditViewProps = {\n    initPageResult,\n    routeSegments: segments,\n    searchParams,\n  }\n\n  return (\n    <Fragment>\n      <DocumentHeader\n        collectionConfig={collectionConfig}\n        config={payload.config}\n        globalConfig={globalConfig}\n        i18n={i18n}\n      />\n      <HydrateClientUser permissions={permissions} user={user} />\n      <SetDocumentInfo\n        action={`${action}?${queryString.stringify(formQueryParams)}`}\n        apiURL={apiURL}\n        collectionSlug={collectionConfig?.slug}\n        disableActions={false}\n        docPermissions={docPermissions}\n        docPreferences={docPreferences}\n        globalSlug={globalConfig?.slug}\n        hasSavePermission={hasSavePermission}\n        id={id}\n        initialData={data}\n        initialState={initialState}\n      />\n      <EditDepthProvider depth={1} key={`${collectionSlug || globalSlug}-${locale.code}`}>\n        <FormQueryParamsProvider formQueryParams={formQueryParams}>\n          <RenderCustomComponent\n            CustomComponent={typeof CustomView === 'function' ? CustomView : undefined}\n            DefaultComponent={DefaultView}\n            componentProps={serverSideProps}\n          />\n        </FormQueryParamsProvider>\n      </EditDepthProvider>\n    </Fragment>\n  )\n}\n"],"names":["DocumentHeader","EditDepthProvider","FormQueryParamsProvider","HydrateClientUser","RenderCustomComponent","SetDocumentInfo","buildStateFromSchema","formatFields","queryString","React","Fragment","getMetaBySegment","getViewsFromConfig","NotFoundClient","generateMetadata","args","Document","initPageResult","params","searchParams","collectionConfig","docID","id","globalConfig","locale","permissions","req","i18n","payload","config","routes","api","apiRoute","serverURL","user","segments","Array","isArray","collectionSlug","slug","undefined","globalSlug","isEditing","Boolean","CustomView","DefaultView","data","docPermissions","preferencesKey","fields","hasSavePermission","apiURL","action","collections","update","permission","create","code","versions","drafts","collectionViews","routeSegments","findByID","collection","depth","error","globals","globalViews","findGlobal","docs","value","docPreferences","find","limit","where","key","equals","initialState","fieldSchema","operation","preferences","formQueryParams","uploadEdits","serverSideProps","stringify","disableActions","initialData","CustomComponent","DefaultComponent","componentProps"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.client.d.ts","sourceRoot":"","sources":["../../../src/views/NotFound/index.client.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAoB,MAAM,OAAO,CAAA;AAExC,OAAO,cAAc,CAAA;AAIrB,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC;IACpC,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,CAiCA,CAAA"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { Button, Gutter, useConfig, useStepNav, useTranslation } from '@payloadcms/ui';
|
|
3
|
+
import Link from 'next/link';
|
|
4
|
+
import React, { useEffect } from 'react';
|
|
5
|
+
import './index.scss';
|
|
6
|
+
const baseClass = 'not-found';
|
|
7
|
+
export const NotFoundClient = (props)=>{
|
|
8
|
+
const { marginTop = 'large' } = props;
|
|
9
|
+
const { setStepNav } = useStepNav();
|
|
10
|
+
const { t } = useTranslation();
|
|
11
|
+
const { routes: { admin } } = useConfig();
|
|
12
|
+
useEffect(()=>{
|
|
13
|
+
setStepNav([
|
|
14
|
+
{
|
|
15
|
+
label: t('general:notFound')
|
|
16
|
+
}
|
|
17
|
+
]);
|
|
18
|
+
}, [
|
|
19
|
+
setStepNav,
|
|
20
|
+
t
|
|
21
|
+
]);
|
|
22
|
+
return /*#__PURE__*/ React.createElement("div", {
|
|
23
|
+
className: [
|
|
24
|
+
baseClass,
|
|
25
|
+
marginTop && `${baseClass}--margin-top-${marginTop}`
|
|
26
|
+
].filter(Boolean).join(' ')
|
|
27
|
+
}, /*#__PURE__*/ React.createElement(Gutter, {
|
|
28
|
+
className: `${baseClass}__wrap`
|
|
29
|
+
}, /*#__PURE__*/ React.createElement("h1", null, t('general:nothingFound')), /*#__PURE__*/ React.createElement("p", null, t('general:sorryNotFound')), /*#__PURE__*/ React.createElement(Button, {
|
|
30
|
+
Link: Link,
|
|
31
|
+
className: `${baseClass}__button`,
|
|
32
|
+
el: "link",
|
|
33
|
+
to: `${admin}`
|
|
34
|
+
}, t('general:backToDashboard'))));
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy92aWV3cy9Ob3RGb3VuZC9pbmRleC5jbGllbnQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuaW1wb3J0IHsgQnV0dG9uLCBHdXR0ZXIsIHVzZUNvbmZpZywgdXNlU3RlcE5hdiwgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdAcGF5bG9hZGNtcy91aSdcbmltcG9ydCBMaW5rIGZyb20gJ25leHQvbGluaydcbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QgfSBmcm9tICdyZWFjdCdcblxuaW1wb3J0ICcuL2luZGV4LnNjc3MnXG5cbmNvbnN0IGJhc2VDbGFzcyA9ICdub3QtZm91bmQnXG5cbmV4cG9ydCBjb25zdCBOb3RGb3VuZENsaWVudDogUmVhY3QuRkM8e1xuICBtYXJnaW5Ub3A/OiAnbGFyZ2UnXG59PiA9IChwcm9wcykgPT4ge1xuICBjb25zdCB7IG1hcmdpblRvcCA9ICdsYXJnZScgfSA9IHByb3BzXG5cbiAgY29uc3QgeyBzZXRTdGVwTmF2IH0gPSB1c2VTdGVwTmF2KClcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpXG5cbiAgY29uc3Qge1xuICAgIHJvdXRlczogeyBhZG1pbiB9LFxuICB9ID0gdXNlQ29uZmlnKClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIHNldFN0ZXBOYXYoW1xuICAgICAge1xuICAgICAgICBsYWJlbDogdCgnZ2VuZXJhbDpub3RGb3VuZCcpLFxuICAgICAgfSxcbiAgICBdKVxuICB9LCBbc2V0U3RlcE5hdiwgdF0pXG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjbGFzc05hbWU9e1tiYXNlQ2xhc3MsIG1hcmdpblRvcCAmJiBgJHtiYXNlQ2xhc3N9LS1tYXJnaW4tdG9wLSR7bWFyZ2luVG9wfWBdXG4gICAgICAgIC5maWx0ZXIoQm9vbGVhbilcbiAgICAgICAgLmpvaW4oJyAnKX1cbiAgICA+XG4gICAgICA8R3V0dGVyIGNsYXNzTmFtZT17YCR7YmFzZUNsYXNzfV9fd3JhcGB9PlxuICAgICAgICA8aDE+e3QoJ2dlbmVyYWw6bm90aGluZ0ZvdW5kJyl9PC9oMT5cbiAgICAgICAgPHA+e3QoJ2dlbmVyYWw6c29ycnlOb3RGb3VuZCcpfTwvcD5cbiAgICAgICAgPEJ1dHRvbiBMaW5rPXtMaW5rfSBjbGFzc05hbWU9e2Ake2Jhc2VDbGFzc31fX2J1dHRvbmB9IGVsPVwibGlua1wiIHRvPXtgJHthZG1pbn1gfT5cbiAgICAgICAgICB7dCgnZ2VuZXJhbDpiYWNrVG9EYXNoYm9hcmQnKX1cbiAgICAgICAgPC9CdXR0b24+XG4gICAgICA8L0d1dHRlcj5cbiAgICA8L2Rpdj5cbiAgKVxufVxuIl0sIm5hbWVzIjpbIkJ1dHRvbiIsIkd1dHRlciIsInVzZUNvbmZpZyIsInVzZVN0ZXBOYXYiLCJ1c2VUcmFuc2xhdGlvbiIsIkxpbmsiLCJSZWFjdCIsInVzZUVmZmVjdCIsImJhc2VDbGFzcyIsIk5vdEZvdW5kQ2xpZW50IiwicHJvcHMiLCJtYXJnaW5Ub3AiLCJzZXRTdGVwTmF2IiwidCIsInJvdXRlcyIsImFkbWluIiwibGFiZWwiLCJkaXYiLCJjbGFzc05hbWUiLCJmaWx0ZXIiLCJCb29sZWFuIiwiam9pbiIsImgxIiwicCIsImVsIiwidG8iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0EsU0FBU0EsTUFBTSxFQUFFQyxNQUFNLEVBQUVDLFNBQVMsRUFBRUMsVUFBVSxFQUFFQyxjQUFjLFFBQVEsaUJBQWdCO0FBQ3RGLE9BQU9DLFVBQVUsWUFBVztBQUM1QixPQUFPQyxTQUFTQyxTQUFTLFFBQVEsUUFBTztBQUV4QyxPQUFPLGVBQWM7QUFFckIsTUFBTUMsWUFBWTtBQUVsQixPQUFPLE1BQU1DLGlCQUVSLENBQUNDO0lBQ0osTUFBTSxFQUFFQyxZQUFZLE9BQU8sRUFBRSxHQUFHRDtJQUVoQyxNQUFNLEVBQUVFLFVBQVUsRUFBRSxHQUFHVDtJQUN2QixNQUFNLEVBQUVVLENBQUMsRUFBRSxHQUFHVDtJQUVkLE1BQU0sRUFDSlUsUUFBUSxFQUFFQyxLQUFLLEVBQUUsRUFDbEIsR0FBR2I7SUFFSkssVUFBVTtRQUNSSyxXQUFXO1lBQ1Q7Z0JBQ0VJLE9BQU9ILEVBQUU7WUFDWDtTQUNEO0lBQ0gsR0FBRztRQUFDRDtRQUFZQztLQUFFO0lBRWxCLHFCQUNFLG9CQUFDSTtRQUNDQyxXQUFXO1lBQUNWO1lBQVdHLGFBQWEsQ0FBQyxFQUFFSCxVQUFVLGFBQWEsRUFBRUcsVUFBVSxDQUFDO1NBQUMsQ0FDekVRLE1BQU0sQ0FBQ0MsU0FDUEMsSUFBSSxDQUFDO3FCQUVSLG9CQUFDcEI7UUFBT2lCLFdBQVcsQ0FBQyxFQUFFVixVQUFVLE1BQU0sQ0FBQztxQkFDckMsb0JBQUNjLFlBQUlULEVBQUUsd0NBQ1Asb0JBQUNVLFdBQUdWLEVBQUUseUNBQ04sb0JBQUNiO1FBQU9LLE1BQU1BO1FBQU1hLFdBQVcsQ0FBQyxFQUFFVixVQUFVLFFBQVEsQ0FBQztRQUFFZ0IsSUFBRztRQUFPQyxJQUFJLENBQUMsRUFBRVYsTUFBTSxDQUFDO09BQzVFRixFQUFFO0FBS2IsRUFBQyJ9
|
|
@@ -1,7 +1,12 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import '
|
|
3
|
-
declare const
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
2
|
+
import { SanitizedConfig } from 'payload/types';
|
|
3
|
+
export declare const NotFoundView: ({ config: configPromise, params, searchParams, }: {
|
|
4
|
+
config: Promise<SanitizedConfig>;
|
|
5
|
+
params: {
|
|
6
|
+
[key: string]: string | string[];
|
|
7
|
+
};
|
|
8
|
+
searchParams: {
|
|
9
|
+
[key: string]: string | string[];
|
|
10
|
+
};
|
|
11
|
+
}) => Promise<React.JSX.Element>;
|
|
7
12
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/NotFound/index.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/NotFound/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAIzB,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAG/C,eAAO,MAAM,YAAY;YAKf,QAAQ,eAAe,CAAC;;;;;;;gCA0BjC,CAAA"}
|
|
@@ -1,36 +1,20 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
import { Button, Gutter, useConfig, useStepNav, useTranslation } from '@payloadcms/ui';
|
|
3
|
-
import Link from 'next/link';
|
|
4
1
|
import React from 'react';
|
|
5
|
-
|
|
6
|
-
import '
|
|
7
|
-
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
const
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
className: [
|
|
22
|
-
baseClass,
|
|
23
|
-
marginTop && `${baseClass}--margin-top-${marginTop}`
|
|
24
|
-
].filter(Boolean).join(' ')
|
|
25
|
-
}, /*#__PURE__*/ React.createElement(Gutter, {
|
|
26
|
-
className: `${baseClass}__wrap`
|
|
27
|
-
}, /*#__PURE__*/ React.createElement("h1", null, t('general:nothingFound')), /*#__PURE__*/ React.createElement("p", null, t('general:sorryNotFound')), /*#__PURE__*/ React.createElement(Button, {
|
|
28
|
-
Link: Link,
|
|
29
|
-
className: `${baseClass}__button`,
|
|
30
|
-
el: "link",
|
|
31
|
-
to: `${admin}`
|
|
32
|
-
}, t('general:backToDashboard'))));
|
|
2
|
+
import { NotFoundClient } from './index.client';
|
|
3
|
+
import { DefaultTemplate } from '@payloadcms/ui';
|
|
4
|
+
import { initPage } from '../../utilities/initPage';
|
|
5
|
+
export const NotFoundView = async ({ config: configPromise, params, searchParams })=>{
|
|
6
|
+
const config = await configPromise;
|
|
7
|
+
const initPageResult = await initPage({
|
|
8
|
+
config,
|
|
9
|
+
searchParams,
|
|
10
|
+
route: ''
|
|
11
|
+
});
|
|
12
|
+
return /*#__PURE__*/ React.createElement(DefaultTemplate, {
|
|
13
|
+
config: initPageResult.req.payload.config,
|
|
14
|
+
i18n: initPageResult.req.i18n,
|
|
15
|
+
permissions: initPageResult.permissions,
|
|
16
|
+
user: initPageResult.req.user
|
|
17
|
+
}, /*#__PURE__*/ React.createElement(NotFoundClient, null));
|
|
33
18
|
};
|
|
34
|
-
export default NotFound;
|
|
35
19
|
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy92aWV3cy9Ob3RGb3VuZC9pbmRleC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuXG5pbXBvcnQgeyBOb3RGb3VuZENsaWVudCB9IGZyb20gJy4vaW5kZXguY2xpZW50J1xuaW1wb3J0IHsgRGVmYXVsdFRlbXBsYXRlIH0gZnJvbSAnQHBheWxvYWRjbXMvdWknXG5pbXBvcnQgeyBTYW5pdGl6ZWRDb25maWcgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuaW1wb3J0IHsgaW5pdFBhZ2UgfSBmcm9tICcuLi8uLi91dGlsaXRpZXMvaW5pdFBhZ2UnXG5cbmV4cG9ydCBjb25zdCBOb3RGb3VuZFZpZXcgPSBhc3luYyAoe1xuICBjb25maWc6IGNvbmZpZ1Byb21pc2UsXG4gIHBhcmFtcyxcbiAgc2VhcmNoUGFyYW1zLFxufToge1xuICBjb25maWc6IFByb21pc2U8U2FuaXRpemVkQ29uZmlnPlxuICBwYXJhbXM6IHtcbiAgICBba2V5OiBzdHJpbmddOiBzdHJpbmcgfCBzdHJpbmdbXVxuICB9XG4gIHNlYXJjaFBhcmFtczoge1xuICAgIFtrZXk6IHN0cmluZ106IHN0cmluZyB8IHN0cmluZ1tdXG4gIH1cbn0pID0+IHtcbiAgY29uc3QgY29uZmlnID0gYXdhaXQgY29uZmlnUHJvbWlzZVxuXG4gIGNvbnN0IGluaXRQYWdlUmVzdWx0ID0gYXdhaXQgaW5pdFBhZ2Uoe1xuICAgIGNvbmZpZyxcbiAgICBzZWFyY2hQYXJhbXMsXG4gICAgcm91dGU6ICcnLFxuICB9KVxuXG4gIHJldHVybiAoXG4gICAgPERlZmF1bHRUZW1wbGF0ZVxuICAgICAgY29uZmlnPXtpbml0UGFnZVJlc3VsdC5yZXEucGF5bG9hZC5jb25maWd9XG4gICAgICBpMThuPXtpbml0UGFnZVJlc3VsdC5yZXEuaTE4bn1cbiAgICAgIHBlcm1pc3Npb25zPXtpbml0UGFnZVJlc3VsdC5wZXJtaXNzaW9uc31cbiAgICAgIHVzZXI9e2luaXRQYWdlUmVzdWx0LnJlcS51c2VyfVxuICAgID5cbiAgICAgIDxOb3RGb3VuZENsaWVudCAvPlxuICAgIDwvRGVmYXVsdFRlbXBsYXRlPlxuICApXG59XG4iXSwibmFtZXMiOlsiUmVhY3QiLCJOb3RGb3VuZENsaWVudCIsIkRlZmF1bHRUZW1wbGF0ZSIsImluaXRQYWdlIiwiTm90Rm91bmRWaWV3IiwiY29uZmlnIiwiY29uZmlnUHJvbWlzZSIsInBhcmFtcyIsInNlYXJjaFBhcmFtcyIsImluaXRQYWdlUmVzdWx0Iiwicm91dGUiLCJyZXEiLCJwYXlsb2FkIiwiaTE4biIsInBlcm1pc3Npb25zIiwidXNlciJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsV0FBVyxRQUFPO0FBRXpCLFNBQVNDLGNBQWMsUUFBUSxpQkFBZ0I7QUFDL0MsU0FBU0MsZUFBZSxRQUFRLGlCQUFnQjtBQUVoRCxTQUFTQyxRQUFRLFFBQVEsMkJBQTBCO0FBRW5ELE9BQU8sTUFBTUMsZUFBZSxPQUFPLEVBQ2pDQyxRQUFRQyxhQUFhLEVBQ3JCQyxNQUFNLEVBQ05DLFlBQVksRUFTYjtJQUNDLE1BQU1ILFNBQVMsTUFBTUM7SUFFckIsTUFBTUcsaUJBQWlCLE1BQU1OLFNBQVM7UUFDcENFO1FBQ0FHO1FBQ0FFLE9BQU87SUFDVDtJQUVBLHFCQUNFLG9CQUFDUjtRQUNDRyxRQUFRSSxlQUFlRSxHQUFHLENBQUNDLE9BQU8sQ0FBQ1AsTUFBTTtRQUN6Q1EsTUFBTUosZUFBZUUsR0FBRyxDQUFDRSxJQUFJO1FBQzdCQyxhQUFhTCxlQUFlSyxXQUFXO1FBQ3ZDQyxNQUFNTixlQUFlRSxHQUFHLENBQUNJLElBQUk7cUJBRTdCLG9CQUFDZDtBQUdQLEVBQUMifQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { I18n } from '@payloadcms/translations';
|
|
2
|
+
import { SanitizedConfig } from 'payload/types';
|
|
3
|
+
export declare const generateNotFoundMeta: ({ config, i18n }: {
|
|
4
|
+
config: SanitizedConfig;
|
|
5
|
+
i18n: I18n;
|
|
6
|
+
}) => Promise<import("next/dist/lib/metadata/types/metadata-interface").Metadata>;
|
|
7
|
+
//# sourceMappingURL=meta.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"meta.d.ts","sourceRoot":"","sources":["../../../src/views/NotFound/meta.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAA;AAE/C,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAE/C,eAAO,MAAM,oBAAoB;YAAgC,eAAe;UAAQ,IAAI;iFAO3F,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { meta } from '../../utilities/meta';
|
|
2
|
+
export const generateNotFoundMeta = ({ config, i18n })=>{
|
|
3
|
+
return meta({
|
|
4
|
+
config,
|
|
5
|
+
description: i18n.t('general:pageNotFound'),
|
|
6
|
+
keywords: `404 ${i18n.t('general:notFound')}`,
|
|
7
|
+
title: i18n.t('general:notFound')
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy92aWV3cy9Ob3RGb3VuZC9tZXRhLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEkxOG4gfSBmcm9tICdAcGF5bG9hZGNtcy90cmFuc2xhdGlvbnMnXG5pbXBvcnQgeyBtZXRhIH0gZnJvbSAnLi4vLi4vdXRpbGl0aWVzL21ldGEnXG5pbXBvcnQgeyBTYW5pdGl6ZWRDb25maWcgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5leHBvcnQgY29uc3QgZ2VuZXJhdGVOb3RGb3VuZE1ldGEgPSAoeyBjb25maWcsIGkxOG4gfTogeyBjb25maWc6IFNhbml0aXplZENvbmZpZzsgaTE4bjogSTE4biB9KSA9PiB7XG4gIHJldHVybiBtZXRhKHtcbiAgICBjb25maWcsXG4gICAgZGVzY3JpcHRpb246IGkxOG4udCgnZ2VuZXJhbDpwYWdlTm90Rm91bmQnKSxcbiAgICBrZXl3b3JkczogYDQwNCAke2kxOG4udCgnZ2VuZXJhbDpub3RGb3VuZCcpfWAsXG4gICAgdGl0bGU6IGkxOG4udCgnZ2VuZXJhbDpub3RGb3VuZCcpLFxuICB9KVxufVxuIl0sIm5hbWVzIjpbIm1ldGEiLCJnZW5lcmF0ZU5vdEZvdW5kTWV0YSIsImNvbmZpZyIsImkxOG4iLCJkZXNjcmlwdGlvbiIsInQiLCJrZXl3b3JkcyIsInRpdGxlIl0sIm1hcHBpbmdzIjoiQUFDQSxTQUFTQSxJQUFJLFFBQVEsdUJBQXNCO0FBRzNDLE9BQU8sTUFBTUMsdUJBQXVCLENBQUMsRUFBRUMsTUFBTSxFQUFFQyxJQUFJLEVBQTJDO0lBQzVGLE9BQU9ILEtBQUs7UUFDVkU7UUFDQUUsYUFBYUQsS0FBS0UsQ0FBQyxDQUFDO1FBQ3BCQyxVQUFVLENBQUMsSUFBSSxFQUFFSCxLQUFLRSxDQUFDLENBQUMsb0JBQW9CLENBQUM7UUFDN0NFLE9BQU9KLEtBQUtFLENBQUMsQ0FBQztJQUNoQjtBQUNGLEVBQUMifQ==
|
|
@@ -3,15 +3,6 @@ import type { Metadata } from 'next';
|
|
|
3
3
|
import type { InitPageResult, SanitizedConfig } from 'payload/types';
|
|
4
4
|
import React from 'react';
|
|
5
5
|
export { generatePageMetadata } from './meta';
|
|
6
|
-
type Args = {
|
|
7
|
-
config: Promise<SanitizedConfig>;
|
|
8
|
-
params: {
|
|
9
|
-
[key: string]: string | string[];
|
|
10
|
-
};
|
|
11
|
-
searchParams: {
|
|
12
|
-
[key: string]: string | string[];
|
|
13
|
-
};
|
|
14
|
-
};
|
|
15
6
|
export type GenerateViewMetadata = (args: {
|
|
16
7
|
config: SanitizedConfig;
|
|
17
8
|
i18n: I18n;
|
|
@@ -28,5 +19,13 @@ export type AdminViewProps = {
|
|
|
28
19
|
[key: string]: string | string[] | undefined;
|
|
29
20
|
};
|
|
30
21
|
};
|
|
31
|
-
export declare const RootPage: ({ config: configPromise, params, searchParams }:
|
|
22
|
+
export declare const RootPage: ({ config: configPromise, params, searchParams, }: {
|
|
23
|
+
config: Promise<SanitizedConfig>;
|
|
24
|
+
params: {
|
|
25
|
+
[key: string]: string | string[];
|
|
26
|
+
};
|
|
27
|
+
searchParams: {
|
|
28
|
+
[key: string]: string | string[];
|
|
29
|
+
};
|
|
30
|
+
}) => Promise<React.JSX.Element>;
|
|
32
31
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Root/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAA;AACpC,OAAO,KAAK,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAIpE,OAAO,KAAK,MAAM,OAAO,CAAA;AAezB,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAAA;AAE7C,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Root/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAA;AACpC,OAAO,KAAK,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAIpE,OAAO,KAAK,MAAM,OAAO,CAAA;AAezB,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAAA;AAE7C,MAAM,MAAM,oBAAoB,GAAG,CAAC,IAAI,EAAE;IACxC,MAAM,EAAE,eAAe,CAAA;IACvB,IAAI,EAAE,IAAI,CAAA;IACV,MAAM,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,CAAA;KAAE,CAAA;CAC9C,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAA;AAEvB,MAAM,MAAM,cAAc,GAAG;IAC3B,cAAc,EAAE,cAAc,CAAA;IAC9B,MAAM,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;IACzD,YAAY,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;CAC/D,CAAA;AAkBD,eAAO,MAAM,QAAQ;YAKX,QAAQ,eAAe,CAAC;;;;;;;gCAsKjC,CAAA"}
|
package/dist/views/Root/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { DefaultTemplate, MinimalTemplate } from '@payloadcms/ui';
|
|
2
|
-
import { redirect } from 'next/navigation';
|
|
2
|
+
import { notFound, redirect } from 'next/navigation';
|
|
3
3
|
import React from 'react';
|
|
4
4
|
import { initPage } from '../../utilities/initPage';
|
|
5
5
|
import { Account } from '../Account';
|
|
@@ -33,7 +33,6 @@ export const RootPage = async ({ config: configPromise, params, searchParams })=
|
|
|
33
33
|
const { admin: { user: userSlug }, routes: { admin: adminRoute } } = config;
|
|
34
34
|
let ViewToRender;
|
|
35
35
|
let templateClassName;
|
|
36
|
-
let initPageResult;
|
|
37
36
|
let templateType = 'default';
|
|
38
37
|
let route = adminRoute;
|
|
39
38
|
if (Array.isArray(params.segments)) {
|
|
@@ -43,6 +42,11 @@ export const RootPage = async ({ config: configPromise, params, searchParams })=
|
|
|
43
42
|
const [segmentOne, segmentTwo] = segments;
|
|
44
43
|
const isGlobal = segmentOne === 'globals';
|
|
45
44
|
const isCollection = segmentOne === 'collections';
|
|
45
|
+
let initPageOptions = {
|
|
46
|
+
config,
|
|
47
|
+
searchParams,
|
|
48
|
+
route
|
|
49
|
+
};
|
|
46
50
|
// TODO: handle custom routes
|
|
47
51
|
switch(segments.length){
|
|
48
52
|
case 0:
|
|
@@ -50,12 +54,7 @@ export const RootPage = async ({ config: configPromise, params, searchParams })=
|
|
|
50
54
|
ViewToRender = Dashboard;
|
|
51
55
|
templateClassName = 'dashboard';
|
|
52
56
|
templateType = 'default';
|
|
53
|
-
|
|
54
|
-
config,
|
|
55
|
-
redirectUnauthenticatedUser: true,
|
|
56
|
-
route,
|
|
57
|
-
searchParams
|
|
58
|
-
});
|
|
57
|
+
initPageOptions.redirectUnauthenticatedUser = true;
|
|
59
58
|
break;
|
|
60
59
|
}
|
|
61
60
|
case 1:
|
|
@@ -67,22 +66,12 @@ export const RootPage = async ({ config: configPromise, params, searchParams })=
|
|
|
67
66
|
// --> /logout
|
|
68
67
|
// --> /logout-inactivity
|
|
69
68
|
// --> /unauthorized
|
|
70
|
-
initPageResult = await initPage({
|
|
71
|
-
config,
|
|
72
|
-
route,
|
|
73
|
-
searchParams
|
|
74
|
-
});
|
|
75
69
|
ViewToRender = oneSegmentViews[segmentOne];
|
|
76
70
|
templateClassName = baseClasses[segmentOne];
|
|
77
71
|
templateType = 'minimal';
|
|
78
72
|
} else if (segmentOne === 'account') {
|
|
79
73
|
// --> /account
|
|
80
|
-
|
|
81
|
-
config,
|
|
82
|
-
redirectUnauthenticatedUser: true,
|
|
83
|
-
route,
|
|
84
|
-
searchParams
|
|
85
|
-
});
|
|
74
|
+
initPageOptions.redirectUnauthenticatedUser = true;
|
|
86
75
|
ViewToRender = Account;
|
|
87
76
|
templateClassName = 'account';
|
|
88
77
|
templateType = 'default';
|
|
@@ -93,34 +82,19 @@ export const RootPage = async ({ config: configPromise, params, searchParams })=
|
|
|
93
82
|
{
|
|
94
83
|
if (segmentOne === 'reset') {
|
|
95
84
|
// --> /reset/:token
|
|
96
|
-
initPageResult = await initPage({
|
|
97
|
-
config,
|
|
98
|
-
route,
|
|
99
|
-
searchParams
|
|
100
|
-
});
|
|
101
85
|
ViewToRender = ResetPassword;
|
|
102
86
|
templateClassName = baseClasses[segmentTwo];
|
|
103
87
|
templateType = 'minimal';
|
|
104
88
|
}
|
|
105
89
|
if (isCollection) {
|
|
106
90
|
// --> /collections/:collectionSlug
|
|
107
|
-
|
|
108
|
-
config,
|
|
109
|
-
redirectUnauthenticatedUser: true,
|
|
110
|
-
route,
|
|
111
|
-
searchParams
|
|
112
|
-
});
|
|
91
|
+
initPageOptions.redirectUnauthenticatedUser = true;
|
|
113
92
|
ViewToRender = ListView;
|
|
114
93
|
templateClassName = `${segmentTwo}-list`;
|
|
115
94
|
templateType = 'default';
|
|
116
95
|
} else if (isGlobal) {
|
|
117
96
|
// --> /globals/:globalSlug
|
|
118
|
-
|
|
119
|
-
config,
|
|
120
|
-
redirectUnauthenticatedUser: true,
|
|
121
|
-
route,
|
|
122
|
-
searchParams
|
|
123
|
-
});
|
|
97
|
+
initPageOptions.redirectUnauthenticatedUser = true;
|
|
124
98
|
ViewToRender = DocumentView;
|
|
125
99
|
templateClassName = 'global-edit';
|
|
126
100
|
templateType = 'default';
|
|
@@ -130,11 +104,6 @@ export const RootPage = async ({ config: configPromise, params, searchParams })=
|
|
|
130
104
|
default:
|
|
131
105
|
if (segmentTwo === 'verify') {
|
|
132
106
|
// --> /:collectionSlug/verify/:token
|
|
133
|
-
initPageResult = await initPage({
|
|
134
|
-
config,
|
|
135
|
-
route,
|
|
136
|
-
searchParams
|
|
137
|
-
});
|
|
138
107
|
ViewToRender = Verify;
|
|
139
108
|
templateClassName = 'verify';
|
|
140
109
|
templateType = 'minimal';
|
|
@@ -145,12 +114,7 @@ export const RootPage = async ({ config: configPromise, params, searchParams })=
|
|
|
145
114
|
// --> /collections/:collectionSlug/:id/versions
|
|
146
115
|
// --> /collections/:collectionSlug/:id/versions/:versionId
|
|
147
116
|
// --> /collections/:collectionSlug/:id/api
|
|
148
|
-
|
|
149
|
-
config,
|
|
150
|
-
redirectUnauthenticatedUser: true,
|
|
151
|
-
route,
|
|
152
|
-
searchParams
|
|
153
|
-
});
|
|
117
|
+
initPageOptions.redirectUnauthenticatedUser = true;
|
|
154
118
|
ViewToRender = DocumentView;
|
|
155
119
|
templateClassName = `collection-default-edit`;
|
|
156
120
|
templateType = 'default';
|
|
@@ -160,52 +124,51 @@ export const RootPage = async ({ config: configPromise, params, searchParams })=
|
|
|
160
124
|
// --> /globals/:globalSlug/preview
|
|
161
125
|
// --> /globals/:globalSlug/versions/:versionId
|
|
162
126
|
// --> /globals/:globalSlug/api
|
|
163
|
-
|
|
164
|
-
config,
|
|
165
|
-
redirectUnauthenticatedUser: true,
|
|
166
|
-
route,
|
|
167
|
-
searchParams
|
|
168
|
-
});
|
|
127
|
+
initPageOptions.redirectUnauthenticatedUser = true;
|
|
169
128
|
ViewToRender = DocumentView;
|
|
170
129
|
templateClassName = `global-edit`;
|
|
171
130
|
templateType = 'default';
|
|
172
131
|
}
|
|
173
132
|
break;
|
|
174
133
|
}
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
})?.then((doc)=>!!doc);
|
|
179
|
-
const createFirstUserRoute = `${adminRoute}/create-first-user`;
|
|
180
|
-
if (!dbHasUser && route !== createFirstUserRoute) {
|
|
181
|
-
redirect(createFirstUserRoute);
|
|
182
|
-
}
|
|
183
|
-
if (dbHasUser && route === createFirstUserRoute) {
|
|
184
|
-
redirect(adminRoute);
|
|
134
|
+
let dbHasUser = false;
|
|
135
|
+
if (!ViewToRender) {
|
|
136
|
+
notFound();
|
|
185
137
|
}
|
|
138
|
+
const initPageResult = await initPage(initPageOptions);
|
|
186
139
|
if (initPageResult) {
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
config: config,
|
|
198
|
-
i18n: initPageResult.req.i18n,
|
|
199
|
-
permissions: initPageResult.permissions,
|
|
200
|
-
user: initPageResult.req.user
|
|
201
|
-
}, /*#__PURE__*/ React.createElement(ViewToRender, {
|
|
202
|
-
initPageResult: initPageResult,
|
|
203
|
-
params: params,
|
|
204
|
-
searchParams: searchParams
|
|
205
|
-
}));
|
|
140
|
+
dbHasUser = await initPageResult?.req.payload.db.findOne({
|
|
141
|
+
collection: userSlug,
|
|
142
|
+
req: initPageResult?.req
|
|
143
|
+
})?.then((doc)=>!!doc);
|
|
144
|
+
const createFirstUserRoute = `${adminRoute}/create-first-user`;
|
|
145
|
+
if (!dbHasUser && route !== createFirstUserRoute) {
|
|
146
|
+
redirect(createFirstUserRoute);
|
|
147
|
+
}
|
|
148
|
+
if (dbHasUser && route === createFirstUserRoute) {
|
|
149
|
+
redirect(adminRoute);
|
|
206
150
|
}
|
|
207
151
|
}
|
|
208
|
-
|
|
152
|
+
if (templateType === 'minimal') {
|
|
153
|
+
return /*#__PURE__*/ React.createElement(MinimalTemplate, {
|
|
154
|
+
className: templateClassName
|
|
155
|
+
}, /*#__PURE__*/ React.createElement(ViewToRender, {
|
|
156
|
+
initPageResult: initPageResult,
|
|
157
|
+
params: params,
|
|
158
|
+
searchParams: searchParams
|
|
159
|
+
}));
|
|
160
|
+
} else {
|
|
161
|
+
return /*#__PURE__*/ React.createElement(DefaultTemplate, {
|
|
162
|
+
config: config,
|
|
163
|
+
i18n: initPageResult.req.i18n,
|
|
164
|
+
permissions: initPageResult.permissions,
|
|
165
|
+
user: initPageResult.req.user
|
|
166
|
+
}, /*#__PURE__*/ React.createElement(ViewToRender, {
|
|
167
|
+
initPageResult: initPageResult,
|
|
168
|
+
params: params,
|
|
169
|
+
searchParams: searchParams
|
|
170
|
+
}));
|
|
171
|
+
}
|
|
209
172
|
};
|
|
210
173
|
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/views/Root/index.tsx"],"sourcesContent":["import type { I18n } from '@payloadcms/translations'\nimport type { Metadata } from 'next'\nimport type { InitPageResult, SanitizedConfig } from 'payload/types'\n\nimport { DefaultTemplate, MinimalTemplate } from '@payloadcms/ui'\nimport { redirect } from 'next/navigation'\nimport React from 'react'\n\nimport { initPage } from '../../utilities/initPage'\nimport { Account } from '../Account'\nimport { CreateFirstUser } from '../CreateFirstUser'\nimport { Dashboard } from '../Dashboard'\nimport { Document as DocumentView } from '../Document'\nimport { ForgotPassword, forgotPasswordBaseClass } from '../ForgotPassword'\nimport { ListView } from '../List'\nimport { Login, loginBaseClass } from '../Login'\nimport { Logout, LogoutInactivity } from '../Logout'\nimport { ResetPassword, resetPasswordBaseClass } from '../ResetPassword'\nimport { Unauthorized } from '../Unauthorized'\nimport { Verify, verifyBaseClass } from '../Verify'\n\nexport { generatePageMetadata } from './meta'\n\ntype Args = {\n  config: Promise<SanitizedConfig>\n  params: {\n    [key: string]: string | string[]\n  }\n  searchParams: {\n    [key: string]: string | string[]\n  }\n}\n\nexport type GenerateViewMetadata = (args: {\n  config: SanitizedConfig\n  i18n: I18n\n  params?: { [key: string]: string | string[] }\n}) => Promise<Metadata>\n\nexport type AdminViewProps = {\n  initPageResult: InitPageResult\n  params?: { [key: string]: string | string[] | undefined }\n  searchParams: { [key: string]: string | string[] | undefined }\n}\n\nconst baseClasses = {\n  forgot: forgotPasswordBaseClass,\n  login: loginBaseClass,\n  reset: resetPasswordBaseClass,\n  verify: verifyBaseClass,\n}\n\nconst oneSegmentViews = {\n  'create-first-user': CreateFirstUser,\n  forgot: ForgotPassword,\n  login: Login,\n  logout: Logout,\n  'logout-inactivity': LogoutInactivity,\n  unauthorized: Unauthorized,\n}\n\nexport const RootPage = async ({ config: configPromise, params, searchParams }: Args) => {\n  const config = await configPromise\n\n  const {\n    admin: { user: userSlug },\n    routes: { admin: adminRoute },\n  } = config\n\n  let ViewToRender: React.FC<AdminViewProps>\n  let templateClassName\n  let initPageResult: InitPageResult\n  let templateType: 'default' | 'minimal' = 'default'\n\n  let route = adminRoute\n\n  if (Array.isArray(params.segments)) {\n    route = route + '/' + params.segments.join('/')\n  }\n\n  const segments = Array.isArray(params.segments) ? params.segments : []\n\n  const [segmentOne, segmentTwo] = segments\n\n  const isGlobal = segmentOne === 'globals'\n  const isCollection = segmentOne === 'collections'\n\n  // TODO: handle custom routes\n\n  switch (segments.length) {\n    case 0: {\n      ViewToRender = Dashboard\n      templateClassName = 'dashboard'\n      templateType = 'default'\n      initPageResult = await initPage({\n        config,\n        redirectUnauthenticatedUser: true,\n        route,\n        searchParams,\n      })\n      break\n    }\n    case 1: {\n      if (oneSegmentViews[segmentOne] && segmentOne !== 'account') {\n        // --> /create-first-user\n        // --> /forgot\n        // --> /login\n        // --> /logout\n        // --> /logout-inactivity\n        // --> /unauthorized\n        initPageResult = await initPage({ config, route, searchParams })\n        ViewToRender = oneSegmentViews[segmentOne]\n        templateClassName = baseClasses[segmentOne]\n        templateType = 'minimal'\n      } else if (segmentOne === 'account') {\n        // --> /account\n        initPageResult = await initPage({\n          config,\n          redirectUnauthenticatedUser: true,\n          route,\n          searchParams,\n        })\n        ViewToRender = Account\n        templateClassName = 'account'\n        templateType = 'default'\n      }\n      break\n    }\n    case 2: {\n      if (segmentOne === 'reset') {\n        // --> /reset/:token\n        initPageResult = await initPage({ config, route, searchParams })\n        ViewToRender = ResetPassword\n        templateClassName = baseClasses[segmentTwo]\n        templateType = 'minimal'\n      }\n      if (isCollection) {\n        // --> /collections/:collectionSlug\n        initPageResult = await initPage({\n          config,\n          redirectUnauthenticatedUser: true,\n          route,\n          searchParams,\n        })\n        ViewToRender = ListView\n        templateClassName = `${segmentTwo}-list`\n        templateType = 'default'\n      } else if (isGlobal) {\n        // --> /globals/:globalSlug\n        initPageResult = await initPage({\n          config,\n          redirectUnauthenticatedUser: true,\n          route,\n          searchParams,\n        })\n        ViewToRender = DocumentView\n        templateClassName = 'global-edit'\n        templateType = 'default'\n      }\n      break\n    }\n    default:\n      if (segmentTwo === 'verify') {\n        // --> /:collectionSlug/verify/:token\n        initPageResult = await initPage({ config, route, searchParams })\n        ViewToRender = Verify\n        templateClassName = 'verify'\n        templateType = 'minimal'\n      } else if (isCollection) {\n        // Custom Views\n        // --> /collections/:collectionSlug/:id\n        // --> /collections/:collectionSlug/:id/preview\n        // --> /collections/:collectionSlug/:id/versions\n        // --> /collections/:collectionSlug/:id/versions/:versionId\n        // --> /collections/:collectionSlug/:id/api\n        initPageResult = await initPage({\n          config,\n          redirectUnauthenticatedUser: true,\n          route,\n          searchParams,\n        })\n        ViewToRender = DocumentView\n        templateClassName = `collection-default-edit`\n        templateType = 'default'\n      } else if (isGlobal) {\n        // Custom Views\n        // --> /globals/:globalSlug/versions\n        // --> /globals/:globalSlug/preview\n        // --> /globals/:globalSlug/versions/:versionId\n        // --> /globals/:globalSlug/api\n        initPageResult = await initPage({\n          config,\n          redirectUnauthenticatedUser: true,\n          route,\n          searchParams,\n        })\n        ViewToRender = DocumentView\n        templateClassName = `global-edit`\n        templateType = 'default'\n      }\n      break\n  }\n\n  const dbHasUser = await initPageResult.req.payload.db\n    .findOne({\n      collection: userSlug,\n      req: initPageResult.req,\n    })\n    ?.then((doc) => !!doc)\n\n  const createFirstUserRoute = `${adminRoute}/create-first-user`\n\n  if (!dbHasUser && route !== createFirstUserRoute) {\n    redirect(createFirstUserRoute)\n  }\n\n  if (dbHasUser && route === createFirstUserRoute) {\n    redirect(adminRoute)\n  }\n\n  if (initPageResult) {\n    if (templateType === 'minimal') {\n      return (\n        <MinimalTemplate className={templateClassName}>\n          <ViewToRender\n            initPageResult={initPageResult}\n            params={params}\n            searchParams={searchParams}\n          />\n        </MinimalTemplate>\n      )\n    } else {\n      return (\n        <DefaultTemplate\n          config={config}\n          i18n={initPageResult.req.i18n}\n          permissions={initPageResult.permissions}\n          user={initPageResult.req.user}\n        >\n          <ViewToRender\n            initPageResult={initPageResult}\n            params={params}\n            searchParams={searchParams}\n          />\n        </DefaultTemplate>\n      )\n    }\n  }\n\n  return null\n}\n"],"names":["DefaultTemplate","MinimalTemplate","redirect","React","initPage","Account","CreateFirstUser","Dashboard","Document","DocumentView","ForgotPassword","forgotPasswordBaseClass","ListView","Login","loginBaseClass","Logout","LogoutInactivity","ResetPassword","resetPasswordBaseClass","Unauthorized","Verify","verifyBaseClass","generatePageMetadata","baseClasses","forgot","login","reset","verify","oneSegmentViews","logout","unauthorized","RootPage","config","configPromise","params","searchParams","admin","user","userSlug","routes","adminRoute","ViewToRender","templateClassName","initPageResult","templateType","route","Array","isArray","segments","join","segmentOne","segmentTwo","isGlobal","isCollection","length","redirectUnauthenticatedUser","dbHasUser","req","payload","db","findOne","collection","then","doc","createFirstUserRoute","className","i18n","permissions"],"mappings":"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"}
|
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/views/Root/index.tsx"],"sourcesContent":["import type { I18n } from '@payloadcms/translations'\nimport type { Metadata } from 'next'\nimport type { InitPageResult, SanitizedConfig } from 'payload/types'\n\nimport { DefaultTemplate, MinimalTemplate } from '@payloadcms/ui'\nimport { notFound, redirect } from 'next/navigation'\nimport React from 'react'\n\nimport { initPage } from '../../utilities/initPage'\nimport { Account } from '../Account'\nimport { CreateFirstUser } from '../CreateFirstUser'\nimport { Dashboard } from '../Dashboard'\nimport { Document as DocumentView } from '../Document'\nimport { ForgotPassword, forgotPasswordBaseClass } from '../ForgotPassword'\nimport { ListView } from '../List'\nimport { Login, loginBaseClass } from '../Login'\nimport { Logout, LogoutInactivity } from '../Logout'\nimport { ResetPassword, resetPasswordBaseClass } from '../ResetPassword'\nimport { Unauthorized } from '../Unauthorized'\nimport { Verify, verifyBaseClass } from '../Verify'\n\nexport { generatePageMetadata } from './meta'\n\nexport type GenerateViewMetadata = (args: {\n  config: SanitizedConfig\n  i18n: I18n\n  params?: { [key: string]: string | string[] }\n}) => Promise<Metadata>\n\nexport type AdminViewProps = {\n  initPageResult: InitPageResult\n  params?: { [key: string]: string | string[] | undefined }\n  searchParams: { [key: string]: string | string[] | undefined }\n}\n\nconst baseClasses = {\n  forgot: forgotPasswordBaseClass,\n  login: loginBaseClass,\n  reset: resetPasswordBaseClass,\n  verify: verifyBaseClass,\n}\n\nconst oneSegmentViews = {\n  'create-first-user': CreateFirstUser,\n  forgot: ForgotPassword,\n  login: Login,\n  logout: Logout,\n  'logout-inactivity': LogoutInactivity,\n  unauthorized: Unauthorized,\n}\n\nexport const RootPage = async ({\n  config: configPromise,\n  params,\n  searchParams,\n}: {\n  config: Promise<SanitizedConfig>\n  params: {\n    [key: string]: string | string[]\n  }\n  searchParams: {\n    [key: string]: string | string[]\n  }\n}) => {\n  const config = await configPromise\n\n  const {\n    admin: { user: userSlug },\n    routes: { admin: adminRoute },\n  } = config\n\n  let ViewToRender: React.FC<AdminViewProps>\n  let templateClassName\n  let templateType: 'default' | 'minimal' = 'default'\n\n  let route = adminRoute\n\n  if (Array.isArray(params.segments)) {\n    route = route + '/' + params.segments.join('/')\n  }\n\n  const segments = Array.isArray(params.segments) ? params.segments : []\n\n  const [segmentOne, segmentTwo] = segments\n\n  const isGlobal = segmentOne === 'globals'\n  const isCollection = segmentOne === 'collections'\n\n  let initPageOptions: Parameters<typeof initPage>[0] = {\n    config,\n    searchParams,\n    route,\n  }\n\n  // TODO: handle custom routes\n\n  switch (segments.length) {\n    case 0: {\n      ViewToRender = Dashboard\n      templateClassName = 'dashboard'\n      templateType = 'default'\n      initPageOptions.redirectUnauthenticatedUser = true\n      break\n    }\n    case 1: {\n      if (oneSegmentViews[segmentOne] && segmentOne !== 'account') {\n        // --> /create-first-user\n        // --> /forgot\n        // --> /login\n        // --> /logout\n        // --> /logout-inactivity\n        // --> /unauthorized\n        ViewToRender = oneSegmentViews[segmentOne]\n        templateClassName = baseClasses[segmentOne]\n        templateType = 'minimal'\n      } else if (segmentOne === 'account') {\n        // --> /account\n        initPageOptions.redirectUnauthenticatedUser = true\n        ViewToRender = Account\n        templateClassName = 'account'\n        templateType = 'default'\n      }\n      break\n    }\n    case 2: {\n      if (segmentOne === 'reset') {\n        // --> /reset/:token\n        ViewToRender = ResetPassword\n        templateClassName = baseClasses[segmentTwo]\n        templateType = 'minimal'\n      }\n      if (isCollection) {\n        // --> /collections/:collectionSlug\n        initPageOptions.redirectUnauthenticatedUser = true\n        ViewToRender = ListView\n        templateClassName = `${segmentTwo}-list`\n        templateType = 'default'\n      } else if (isGlobal) {\n        // --> /globals/:globalSlug\n        initPageOptions.redirectUnauthenticatedUser = true\n        ViewToRender = DocumentView\n        templateClassName = 'global-edit'\n        templateType = 'default'\n      }\n      break\n    }\n    default:\n      if (segmentTwo === 'verify') {\n        // --> /:collectionSlug/verify/:token\n        ViewToRender = Verify\n        templateClassName = 'verify'\n        templateType = 'minimal'\n      } else if (isCollection) {\n        // Custom Views\n        // --> /collections/:collectionSlug/:id\n        // --> /collections/:collectionSlug/:id/preview\n        // --> /collections/:collectionSlug/:id/versions\n        // --> /collections/:collectionSlug/:id/versions/:versionId\n        // --> /collections/:collectionSlug/:id/api\n        initPageOptions.redirectUnauthenticatedUser = true\n        ViewToRender = DocumentView\n        templateClassName = `collection-default-edit`\n        templateType = 'default'\n      } else if (isGlobal) {\n        // Custom Views\n        // --> /globals/:globalSlug/versions\n        // --> /globals/:globalSlug/preview\n        // --> /globals/:globalSlug/versions/:versionId\n        // --> /globals/:globalSlug/api\n        initPageOptions.redirectUnauthenticatedUser = true\n        ViewToRender = DocumentView\n        templateClassName = `global-edit`\n        templateType = 'default'\n      }\n      break\n  }\n\n  let dbHasUser = false\n\n  if (!ViewToRender) {\n    notFound()\n  }\n\n  const initPageResult = await initPage(initPageOptions)\n\n  if (initPageResult) {\n    dbHasUser = await initPageResult?.req.payload.db\n      .findOne({\n        collection: userSlug,\n        req: initPageResult?.req,\n      })\n      ?.then((doc) => !!doc)\n\n    const createFirstUserRoute = `${adminRoute}/create-first-user`\n\n    if (!dbHasUser && route !== createFirstUserRoute) {\n      redirect(createFirstUserRoute)\n    }\n\n    if (dbHasUser && route === createFirstUserRoute) {\n      redirect(adminRoute)\n    }\n  }\n\n  if (templateType === 'minimal') {\n    return (\n      <MinimalTemplate className={templateClassName}>\n        <ViewToRender initPageResult={initPageResult} params={params} searchParams={searchParams} />\n      </MinimalTemplate>\n    )\n  } else {\n    return (\n      <DefaultTemplate\n        config={config}\n        i18n={initPageResult.req.i18n}\n        permissions={initPageResult.permissions}\n        user={initPageResult.req.user}\n      >\n        <ViewToRender initPageResult={initPageResult} params={params} searchParams={searchParams} />\n      </DefaultTemplate>\n    )\n  }\n}\n"],"names":["DefaultTemplate","MinimalTemplate","notFound","redirect","React","initPage","Account","CreateFirstUser","Dashboard","Document","DocumentView","ForgotPassword","forgotPasswordBaseClass","ListView","Login","loginBaseClass","Logout","LogoutInactivity","ResetPassword","resetPasswordBaseClass","Unauthorized","Verify","verifyBaseClass","generatePageMetadata","baseClasses","forgot","login","reset","verify","oneSegmentViews","logout","unauthorized","RootPage","config","configPromise","params","searchParams","admin","user","userSlug","routes","adminRoute","ViewToRender","templateClassName","templateType","route","Array","isArray","segments","join","segmentOne","segmentTwo","isGlobal","isCollection","initPageOptions","length","redirectUnauthenticatedUser","dbHasUser","initPageResult","req","payload","db","findOne","collection","then","doc","createFirstUserRoute","className","i18n","permissions"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta.d.ts","sourceRoot":"","sources":["../../../src/views/Root/meta.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAA;AAG/B,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;
|
|
1
|
+
{"version":3,"file":"meta.d.ts","sourceRoot":"","sources":["../../../src/views/Root/meta.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAA;AAG/B,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAY/C,KAAK,IAAI,GAAG;IACV,MAAM,EAAE,OAAO,CAAC,eAAe,CAAC,CAAA;IAChC,MAAM,EAAE;QACN,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,CAAA;KACjC,CAAA;IACD,YAAY,EAAE;QACZ,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,CAAA;KACjC,CAAA;CACF,CAAA;AAED,eAAO,MAAM,oBAAoB,sCAA6C,IAAI,sBAyGjF,CAAA"}
|
package/dist/views/Root/meta.js
CHANGED
|
@@ -9,6 +9,7 @@ import { generateUnauthorizedMetadata } from '../Unauthorized';
|
|
|
9
9
|
import { generateVerifyMetadata } from '../Verify';
|
|
10
10
|
import { generateDocumentMetadata } from '../Document/meta';
|
|
11
11
|
import { getNextI18n } from '../../utilities/getNextI18n';
|
|
12
|
+
import { generateNotFoundMeta } from '../NotFound/meta';
|
|
12
13
|
const oneSegmentMeta = {
|
|
13
14
|
'create-first-user': generateCreateFirstUserMetadata,
|
|
14
15
|
forgot: generateForgotPasswordMetadata,
|
|
@@ -146,7 +147,13 @@ export const generatePageMetadata = async ({ config: configPromise, params })=>{
|
|
|
146
147
|
break;
|
|
147
148
|
}
|
|
148
149
|
}
|
|
150
|
+
if (!meta) {
|
|
151
|
+
meta = await generateNotFoundMeta({
|
|
152
|
+
config,
|
|
153
|
+
i18n
|
|
154
|
+
});
|
|
155
|
+
}
|
|
149
156
|
return meta;
|
|
150
157
|
};
|
|
151
158
|
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/views/Root/meta.ts"],"sourcesContent":["import { generateAccountMetadata } from '../Account'\nimport { generateCreateFirstUserMetadata } from '../CreateFirstUser'\nimport { generateDashboardMetadata } from '../Dashboard'\nimport { generateForgotPasswordMetadata } from '../ForgotPassword'\nimport { generateListMetadata } from '../List'\nimport { generateLoginMetadata } from '../Login'\nimport { generateResetPasswordMetadata } from '../ResetPassword'\nimport { generateUnauthorizedMetadata } from '../Unauthorized'\nimport { generateVerifyMetadata } from '../Verify'\nimport { Metadata } from 'next'\nimport { generateDocumentMetadata } from '../Document/meta'\nimport { getNextI18n } from '../../utilities/getNextI18n'\nimport { SanitizedConfig } from 'payload/types'\n\nconst oneSegmentMeta = {\n  'create-first-user': generateCreateFirstUserMetadata,\n  forgot: generateForgotPasswordMetadata,\n  login: generateLoginMetadata,\n  logout: generateUnauthorizedMetadata,\n  'logout-inactivity': generateUnauthorizedMetadata,\n  unauthorized: generateUnauthorizedMetadata,\n}\n\ntype Args = {\n  config: Promise<SanitizedConfig>\n  params: {\n    [key: string]: string | string[]\n  }\n  searchParams: {\n    [key: string]: string | string[]\n  }\n}\n\nexport const generatePageMetadata = async ({ config: configPromise, params }: Args) => {\n  const config = await configPromise\n\n  let route = config.routes.admin\n\n  if (Array.isArray(params.segments)) {\n    route = route + '/' + params.segments.join('/')\n  }\n\n  const segments = Array.isArray(params.segments) ? params.segments : []\n\n  const [segmentOne, segmentTwo] = segments\n\n  const isGlobal = segmentOne === 'globals'\n  const isCollection = segmentOne === 'collections'\n\n  const i18n = await getNextI18n({\n    config,\n  })\n\n  let meta: Metadata\n\n  // TODO: handle custom routes\n\n  const collectionConfig =\n    isCollection &&\n    segments.length > 1 &&\n    config?.collections?.find((collection) => collection.slug === segmentTwo)\n\n  const globalConfig =\n    isGlobal && segments.length > 1 && config?.globals?.find((global) => global.slug === segmentTwo)\n\n  switch (segments.length) {\n    case 0: {\n      meta = await generateDashboardMetadata({ config, i18n })\n      break\n    }\n    case 1: {\n      if (oneSegmentMeta[segmentOne] && segmentOne !== 'account') {\n        // --> /create-first-user\n        // --> /forgot\n        // --> /login\n        // --> /logout\n        // --> /logout-inactivity\n        // --> /unauthorized\n        meta = await oneSegmentMeta[segmentOne]({ config, i18n })\n        break\n      } else if (segmentOne === 'account') {\n        // --> /account\n        meta = await generateAccountMetadata({ config, i18n })\n        break\n      }\n      break\n    }\n    case 2: {\n      if (segmentOne === 'reset') {\n        // --> /reset/:token\n        meta = await generateResetPasswordMetadata({ config, i18n })\n      }\n      if (isCollection) {\n        // --> /collections/:collectionSlug\n        meta = await generateListMetadata({ config, i18n, collectionConfig })\n      } else if (isGlobal) {\n        // --> /globals/:globalSlug\n        meta = await generateDocumentMetadata({\n          config,\n          i18n,\n          globalConfig,\n          isEditing: false,\n          params,\n        })\n      }\n      break\n    }\n    default: {\n      if (segmentTwo === 'verify') {\n        // --> /:collectionSlug/verify/:token\n        meta = await generateVerifyMetadata({ config, i18n })\n      } else if (isCollection) {\n        // Custom Views\n        // --> /collections/:collectionSlug/:id\n        // --> /collections/:collectionSlug/:id/preview\n        // --> /collections/:collectionSlug/:id/versions\n        // --> /collections/:collectionSlug/:id/versions/:version\n        // --> /collections/:collectionSlug/:id/api\n        const isEditing = ['preview', 'versions', 'api', 'create'].includes(segmentTwo)\n        meta = await generateDocumentMetadata({ config, i18n, collectionConfig, isEditing, params })\n      } else if (isGlobal) {\n        // Custom Views\n        // --> /globals/:globalSlug/versions\n        // --> /globals/:globalSlug/versions/:version\n        // --> /globals/:globalSlug/preview\n        // --> /globals/:globalSlug/api\n        const isEditing = ['preview', 'versions', 'api', 'create'].includes(segmentTwo)\n        meta = await generateDocumentMetadata({ config, i18n, globalConfig, isEditing, params })\n      }\n      break\n    }\n  }\n\n  return meta\n}\n"],"names":["generateAccountMetadata","generateCreateFirstUserMetadata","generateDashboardMetadata","generateForgotPasswordMetadata","generateListMetadata","generateLoginMetadata","generateResetPasswordMetadata","generateUnauthorizedMetadata","generateVerifyMetadata","generateDocumentMetadata","getNextI18n","oneSegmentMeta","forgot","login","logout","unauthorized","generatePageMetadata","config","configPromise","params","route","routes","admin","Array","isArray","segments","join","segmentOne","segmentTwo","isGlobal","isCollection","i18n","meta","collectionConfig","length","collections","find","collection","slug","globalConfig","globals","global","isEditing","includes"],"mappings":"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"}
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/views/Root/meta.ts"],"sourcesContent":["import { generateAccountMetadata } from '../Account'\nimport { generateCreateFirstUserMetadata } from '../CreateFirstUser'\nimport { generateDashboardMetadata } from '../Dashboard'\nimport { generateForgotPasswordMetadata } from '../ForgotPassword'\nimport { generateListMetadata } from '../List'\nimport { generateLoginMetadata } from '../Login'\nimport { generateResetPasswordMetadata } from '../ResetPassword'\nimport { generateUnauthorizedMetadata } from '../Unauthorized'\nimport { generateVerifyMetadata } from '../Verify'\nimport { Metadata } from 'next'\nimport { generateDocumentMetadata } from '../Document/meta'\nimport { getNextI18n } from '../../utilities/getNextI18n'\nimport { SanitizedConfig } from 'payload/types'\nimport { generateNotFoundMeta } from '../NotFound/meta'\n\nconst oneSegmentMeta = {\n  'create-first-user': generateCreateFirstUserMetadata,\n  forgot: generateForgotPasswordMetadata,\n  login: generateLoginMetadata,\n  logout: generateUnauthorizedMetadata,\n  'logout-inactivity': generateUnauthorizedMetadata,\n  unauthorized: generateUnauthorizedMetadata,\n}\n\ntype Args = {\n  config: Promise<SanitizedConfig>\n  params: {\n    [key: string]: string | string[]\n  }\n  searchParams: {\n    [key: string]: string | string[]\n  }\n}\n\nexport const generatePageMetadata = async ({ config: configPromise, params }: Args) => {\n  const config = await configPromise\n\n  let route = config.routes.admin\n\n  if (Array.isArray(params.segments)) {\n    route = route + '/' + params.segments.join('/')\n  }\n\n  const segments = Array.isArray(params.segments) ? params.segments : []\n\n  const [segmentOne, segmentTwo] = segments\n\n  const isGlobal = segmentOne === 'globals'\n  const isCollection = segmentOne === 'collections'\n\n  const i18n = await getNextI18n({\n    config,\n  })\n\n  let meta: Metadata\n\n  // TODO: handle custom routes\n\n  const collectionConfig =\n    isCollection &&\n    segments.length > 1 &&\n    config?.collections?.find((collection) => collection.slug === segmentTwo)\n\n  const globalConfig =\n    isGlobal && segments.length > 1 && config?.globals?.find((global) => global.slug === segmentTwo)\n\n  switch (segments.length) {\n    case 0: {\n      meta = await generateDashboardMetadata({ config, i18n })\n      break\n    }\n    case 1: {\n      if (oneSegmentMeta[segmentOne] && segmentOne !== 'account') {\n        // --> /create-first-user\n        // --> /forgot\n        // --> /login\n        // --> /logout\n        // --> /logout-inactivity\n        // --> /unauthorized\n        meta = await oneSegmentMeta[segmentOne]({ config, i18n })\n        break\n      } else if (segmentOne === 'account') {\n        // --> /account\n        meta = await generateAccountMetadata({ config, i18n })\n        break\n      }\n      break\n    }\n    case 2: {\n      if (segmentOne === 'reset') {\n        // --> /reset/:token\n        meta = await generateResetPasswordMetadata({ config, i18n })\n      }\n      if (isCollection) {\n        // --> /collections/:collectionSlug\n        meta = await generateListMetadata({ config, i18n, collectionConfig })\n      } else if (isGlobal) {\n        // --> /globals/:globalSlug\n        meta = await generateDocumentMetadata({\n          config,\n          i18n,\n          globalConfig,\n          isEditing: false,\n          params,\n        })\n      }\n      break\n    }\n    default: {\n      if (segmentTwo === 'verify') {\n        // --> /:collectionSlug/verify/:token\n        meta = await generateVerifyMetadata({ config, i18n })\n      } else if (isCollection) {\n        // Custom Views\n        // --> /collections/:collectionSlug/:id\n        // --> /collections/:collectionSlug/:id/preview\n        // --> /collections/:collectionSlug/:id/versions\n        // --> /collections/:collectionSlug/:id/versions/:version\n        // --> /collections/:collectionSlug/:id/api\n        const isEditing = ['preview', 'versions', 'api', 'create'].includes(segmentTwo)\n        meta = await generateDocumentMetadata({ config, i18n, collectionConfig, isEditing, params })\n      } else if (isGlobal) {\n        // Custom Views\n        // --> /globals/:globalSlug/versions\n        // --> /globals/:globalSlug/versions/:version\n        // --> /globals/:globalSlug/preview\n        // --> /globals/:globalSlug/api\n        const isEditing = ['preview', 'versions', 'api', 'create'].includes(segmentTwo)\n        meta = await generateDocumentMetadata({ config, i18n, globalConfig, isEditing, params })\n      }\n      break\n    }\n  }\n\n  if (!meta) {\n    meta = await generateNotFoundMeta({ config, i18n })\n  }\n\n  return meta\n}\n"],"names":["generateAccountMetadata","generateCreateFirstUserMetadata","generateDashboardMetadata","generateForgotPasswordMetadata","generateListMetadata","generateLoginMetadata","generateResetPasswordMetadata","generateUnauthorizedMetadata","generateVerifyMetadata","generateDocumentMetadata","getNextI18n","generateNotFoundMeta","oneSegmentMeta","forgot","login","logout","unauthorized","generatePageMetadata","config","configPromise","params","route","routes","admin","Array","isArray","segments","join","segmentOne","segmentTwo","isGlobal","isCollection","i18n","meta","collectionConfig","length","collections","find","collection","slug","globalConfig","globals","global","isEditing","includes"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@payloadcms/next",
|
|
3
|
-
"version": "3.0.0-alpha.
|
|
3
|
+
"version": "3.0.0-alpha.23",
|
|
4
4
|
"main": "./dist/exports/index.js",
|
|
5
5
|
"types": "./dist/exports/index.d.ts",
|
|
6
6
|
"type": "module",
|
|
@@ -63,7 +63,7 @@
|
|
|
63
63
|
"webpack": "^5.78.0",
|
|
64
64
|
"webpack-cli": "^5.1.4",
|
|
65
65
|
"@payloadcms/eslint-config": "1.1.1",
|
|
66
|
-
"payload": "3.0.0-alpha.
|
|
66
|
+
"payload": "3.0.0-alpha.23"
|
|
67
67
|
},
|
|
68
68
|
"dependencies": {
|
|
69
69
|
"@dnd-kit/core": "6.0.8",
|
|
@@ -78,14 +78,14 @@
|
|
|
78
78
|
"react-toastify": "8.2.0",
|
|
79
79
|
"sass": "^1.71.1",
|
|
80
80
|
"ws": "^8.16.0",
|
|
81
|
-
"@payloadcms/graphql": "3.0.0-alpha.
|
|
82
|
-
"@payloadcms/
|
|
83
|
-
"@payloadcms/
|
|
81
|
+
"@payloadcms/graphql": "3.0.0-alpha.23",
|
|
82
|
+
"@payloadcms/translations": "3.0.0-alpha.23",
|
|
83
|
+
"@payloadcms/ui": "3.0.0-alpha.23"
|
|
84
84
|
},
|
|
85
85
|
"peerDependencies": {
|
|
86
86
|
"http-status": "1.6.2",
|
|
87
87
|
"next": "14.1.1-canary.26",
|
|
88
|
-
"payload": "3.0.0-alpha.
|
|
88
|
+
"payload": "3.0.0-alpha.23"
|
|
89
89
|
},
|
|
90
90
|
"publishConfig": {
|
|
91
91
|
"registry": "https://registry.npmjs.org/"
|