@payloadcms/next 3.49.0 → 3.49.1
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/elements/DocumentHeader/Tabs/Tab/index.d.ts +12 -4
- package/dist/elements/DocumentHeader/Tabs/Tab/index.d.ts.map +1 -1
- package/dist/elements/DocumentHeader/Tabs/Tab/index.js +19 -22
- package/dist/elements/DocumentHeader/Tabs/Tab/index.js.map +1 -1
- package/dist/elements/DocumentHeader/Tabs/index.d.ts +2 -4
- package/dist/elements/DocumentHeader/Tabs/index.d.ts.map +1 -1
- package/dist/elements/DocumentHeader/Tabs/index.js +26 -22
- package/dist/elements/DocumentHeader/Tabs/index.js.map +1 -1
- package/dist/elements/DocumentHeader/index.d.ts +2 -4
- package/dist/elements/DocumentHeader/index.d.ts.map +1 -1
- package/dist/elements/DocumentHeader/index.js +4 -6
- package/dist/elements/DocumentHeader/index.js.map +1 -1
- package/dist/prod/styles.css +1 -1
- package/dist/views/Account/index.d.ts.map +1 -1
- package/dist/views/Account/index.js +2 -3
- package/dist/views/Account/index.js.map +1 -1
- package/dist/views/Document/index.js +4 -5
- package/dist/views/Document/index.js.map +1 -1
- package/dist/views/List/handleGroupBy.d.ts +2 -1
- package/dist/views/List/handleGroupBy.d.ts.map +1 -1
- package/dist/views/List/handleGroupBy.js +4 -1
- package/dist/views/List/handleGroupBy.js.map +1 -1
- package/dist/views/List/index.d.ts +1 -1
- package/dist/views/List/index.d.ts.map +1 -1
- package/dist/views/List/index.js +78 -68
- package/dist/views/List/index.js.map +1 -1
- package/package.json +10 -10
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Account/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAA+B,MAAM,SAAS,CAAA;AAMhF,OAAO,KAAK,MAAM,OAAO,CAAA;AAYzB,wBAAsB,OAAO,CAAC,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,oBAAoB,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Account/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAA+B,MAAM,SAAS,CAAA;AAMhF,OAAO,KAAK,MAAM,OAAO,CAAA;AAYzB,wBAAsB,OAAO,CAAC,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,oBAAoB,8BAsJ3F"}
|
|
@@ -144,9 +144,8 @@ export async function Account({
|
|
|
144
144
|
children: [/*#__PURE__*/_jsx(DocumentHeader, {
|
|
145
145
|
collectionConfig: collectionConfig,
|
|
146
146
|
hideTabs: true,
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
permissions: permissions
|
|
147
|
+
permissions: permissions,
|
|
148
|
+
req: req
|
|
150
149
|
}), /*#__PURE__*/_jsx(HydrateAuthProvider, {
|
|
151
150
|
permissions: permissions
|
|
152
151
|
}), RenderServerComponent({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["DocumentInfoProvider","EditDepthProvider","HydrateAuthProvider","RenderServerComponent","buildFormState","notFound","React","DocumentHeader","getDocPreferences","getDocumentData","getDocumentPermissions","getIsLocked","getVersions","EditView","AccountClient","Settings","Account","initPageResult","params","searchParams","languageOptions","locale","permissions","req","i18n","payload","config","user","admin","theme","userSlug","routes","api","serverURL","collectionConfig","collections","id","data","collectionSlug","slug","Error","docPreferences","docPermissions","hasPublishPermission","hasSavePermission","state","formState","code","operation","renderAllFields","schemaPath","skipValidation","currentEditor","isLocked","lastUpdateTime","isEditing","hasPublishedDoc","mostRecentVersionIsAutosaved","unpublishedVersionCount","versionCount","doc","_jsx","AfterFields","apiURL","initialData","initialState","_jsxs","hideTabs","Component","components","views","account","Fallback","importMap","serverProps","routeSegments"],"sources":["../../../src/views/Account/index.tsx"],"sourcesContent":["import type { AdminViewServerProps, DocumentViewServerPropsOnly } from 'payload'\n\nimport { DocumentInfoProvider, EditDepthProvider, HydrateAuthProvider } from '@payloadcms/ui'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { buildFormState } from '@payloadcms/ui/utilities/buildFormState'\nimport { notFound } from 'next/navigation.js'\nimport React from 'react'\n\nimport { DocumentHeader } from '../../elements/DocumentHeader/index.js'\nimport { getDocPreferences } from '../Document/getDocPreferences.js'\nimport { getDocumentData } from '../Document/getDocumentData.js'\nimport { getDocumentPermissions } from '../Document/getDocumentPermissions.js'\nimport { getIsLocked } from '../Document/getIsLocked.js'\nimport { getVersions } from '../Document/getVersions.js'\nimport { EditView } from '../Edit/index.js'\nimport { AccountClient } from './index.client.js'\nimport { Settings } from './Settings/index.js'\n\nexport async function Account({ initPageResult, params, searchParams }: AdminViewServerProps) {\n const {\n languageOptions,\n locale,\n permissions,\n req,\n req: {\n i18n,\n payload,\n payload: { config },\n user,\n },\n } = initPageResult\n\n const {\n admin: { theme, user: userSlug },\n routes: { api },\n serverURL,\n } = config\n\n const collectionConfig = payload?.collections?.[userSlug]?.config\n\n if (collectionConfig && user?.id) {\n // Fetch the data required for the view\n const data = await getDocumentData({\n id: user.id,\n collectionSlug: collectionConfig.slug,\n locale,\n payload,\n req,\n user,\n })\n\n if (!data) {\n throw new Error('not-found')\n }\n\n // Get document preferences\n const docPreferences = await getDocPreferences({\n id: user.id,\n collectionSlug: collectionConfig.slug,\n payload,\n user,\n })\n\n // Get permissions\n const { docPermissions, hasPublishPermission, hasSavePermission } =\n await getDocumentPermissions({\n id: user.id,\n collectionConfig,\n data,\n req,\n })\n\n // Build initial form state from data\n const { state: formState } = await buildFormState({\n id: user.id,\n collectionSlug: collectionConfig.slug,\n data,\n docPermissions,\n docPreferences,\n locale: locale?.code,\n operation: 'update',\n renderAllFields: true,\n req,\n schemaPath: collectionConfig.slug,\n skipValidation: true,\n })\n\n // Fetch document lock state\n const { currentEditor, isLocked, lastUpdateTime } = await getIsLocked({\n id: user.id,\n collectionConfig,\n isEditing: true,\n req,\n })\n\n // Get all versions required for UI\n const { hasPublishedDoc, mostRecentVersionIsAutosaved, unpublishedVersionCount, versionCount } =\n await getVersions({\n id: user.id,\n collectionConfig,\n doc: data,\n docPermissions,\n locale: locale?.code,\n payload,\n user,\n })\n\n return (\n <DocumentInfoProvider\n AfterFields={\n <Settings\n i18n={i18n}\n languageOptions={languageOptions}\n payload={payload}\n theme={theme}\n user={user}\n />\n }\n apiURL={`${serverURL}${api}/${userSlug}${user?.id ? `/${user.id}` : ''}`}\n collectionSlug={userSlug}\n currentEditor={currentEditor}\n docPermissions={docPermissions}\n hasPublishedDoc={hasPublishedDoc}\n hasPublishPermission={hasPublishPermission}\n hasSavePermission={hasSavePermission}\n id={user?.id}\n initialData={data}\n initialState={formState}\n isEditing\n isLocked={isLocked}\n lastUpdateTime={lastUpdateTime}\n mostRecentVersionIsAutosaved={mostRecentVersionIsAutosaved}\n unpublishedVersionCount={unpublishedVersionCount}\n versionCount={versionCount}\n >\n <EditDepthProvider>\n <DocumentHeader\n collectionConfig={collectionConfig}\n hideTabs\n
|
|
1
|
+
{"version":3,"file":"index.js","names":["DocumentInfoProvider","EditDepthProvider","HydrateAuthProvider","RenderServerComponent","buildFormState","notFound","React","DocumentHeader","getDocPreferences","getDocumentData","getDocumentPermissions","getIsLocked","getVersions","EditView","AccountClient","Settings","Account","initPageResult","params","searchParams","languageOptions","locale","permissions","req","i18n","payload","config","user","admin","theme","userSlug","routes","api","serverURL","collectionConfig","collections","id","data","collectionSlug","slug","Error","docPreferences","docPermissions","hasPublishPermission","hasSavePermission","state","formState","code","operation","renderAllFields","schemaPath","skipValidation","currentEditor","isLocked","lastUpdateTime","isEditing","hasPublishedDoc","mostRecentVersionIsAutosaved","unpublishedVersionCount","versionCount","doc","_jsx","AfterFields","apiURL","initialData","initialState","_jsxs","hideTabs","Component","components","views","account","Fallback","importMap","serverProps","routeSegments"],"sources":["../../../src/views/Account/index.tsx"],"sourcesContent":["import type { AdminViewServerProps, DocumentViewServerPropsOnly } from 'payload'\n\nimport { DocumentInfoProvider, EditDepthProvider, HydrateAuthProvider } from '@payloadcms/ui'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { buildFormState } from '@payloadcms/ui/utilities/buildFormState'\nimport { notFound } from 'next/navigation.js'\nimport React from 'react'\n\nimport { DocumentHeader } from '../../elements/DocumentHeader/index.js'\nimport { getDocPreferences } from '../Document/getDocPreferences.js'\nimport { getDocumentData } from '../Document/getDocumentData.js'\nimport { getDocumentPermissions } from '../Document/getDocumentPermissions.js'\nimport { getIsLocked } from '../Document/getIsLocked.js'\nimport { getVersions } from '../Document/getVersions.js'\nimport { EditView } from '../Edit/index.js'\nimport { AccountClient } from './index.client.js'\nimport { Settings } from './Settings/index.js'\n\nexport async function Account({ initPageResult, params, searchParams }: AdminViewServerProps) {\n const {\n languageOptions,\n locale,\n permissions,\n req,\n req: {\n i18n,\n payload,\n payload: { config },\n user,\n },\n } = initPageResult\n\n const {\n admin: { theme, user: userSlug },\n routes: { api },\n serverURL,\n } = config\n\n const collectionConfig = payload?.collections?.[userSlug]?.config\n\n if (collectionConfig && user?.id) {\n // Fetch the data required for the view\n const data = await getDocumentData({\n id: user.id,\n collectionSlug: collectionConfig.slug,\n locale,\n payload,\n req,\n user,\n })\n\n if (!data) {\n throw new Error('not-found')\n }\n\n // Get document preferences\n const docPreferences = await getDocPreferences({\n id: user.id,\n collectionSlug: collectionConfig.slug,\n payload,\n user,\n })\n\n // Get permissions\n const { docPermissions, hasPublishPermission, hasSavePermission } =\n await getDocumentPermissions({\n id: user.id,\n collectionConfig,\n data,\n req,\n })\n\n // Build initial form state from data\n const { state: formState } = await buildFormState({\n id: user.id,\n collectionSlug: collectionConfig.slug,\n data,\n docPermissions,\n docPreferences,\n locale: locale?.code,\n operation: 'update',\n renderAllFields: true,\n req,\n schemaPath: collectionConfig.slug,\n skipValidation: true,\n })\n\n // Fetch document lock state\n const { currentEditor, isLocked, lastUpdateTime } = await getIsLocked({\n id: user.id,\n collectionConfig,\n isEditing: true,\n req,\n })\n\n // Get all versions required for UI\n const { hasPublishedDoc, mostRecentVersionIsAutosaved, unpublishedVersionCount, versionCount } =\n await getVersions({\n id: user.id,\n collectionConfig,\n doc: data,\n docPermissions,\n locale: locale?.code,\n payload,\n user,\n })\n\n return (\n <DocumentInfoProvider\n AfterFields={\n <Settings\n i18n={i18n}\n languageOptions={languageOptions}\n payload={payload}\n theme={theme}\n user={user}\n />\n }\n apiURL={`${serverURL}${api}/${userSlug}${user?.id ? `/${user.id}` : ''}`}\n collectionSlug={userSlug}\n currentEditor={currentEditor}\n docPermissions={docPermissions}\n hasPublishedDoc={hasPublishedDoc}\n hasPublishPermission={hasPublishPermission}\n hasSavePermission={hasSavePermission}\n id={user?.id}\n initialData={data}\n initialState={formState}\n isEditing\n isLocked={isLocked}\n lastUpdateTime={lastUpdateTime}\n mostRecentVersionIsAutosaved={mostRecentVersionIsAutosaved}\n unpublishedVersionCount={unpublishedVersionCount}\n versionCount={versionCount}\n >\n <EditDepthProvider>\n <DocumentHeader\n collectionConfig={collectionConfig}\n hideTabs\n permissions={permissions}\n req={req}\n />\n <HydrateAuthProvider permissions={permissions} />\n {RenderServerComponent({\n Component: config.admin?.components?.views?.account?.Component,\n Fallback: EditView,\n importMap: payload.importMap,\n serverProps: {\n doc: data,\n hasPublishedDoc,\n i18n,\n initPageResult,\n locale,\n params,\n payload,\n permissions,\n routeSegments: [],\n searchParams,\n user,\n } satisfies DocumentViewServerPropsOnly,\n })}\n <AccountClient />\n </EditDepthProvider>\n </DocumentInfoProvider>\n )\n }\n\n return notFound()\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -75,7 +75,7 @@ export const renderDocument = async ({
|
|
|
75
75
|
globalSlug
|
|
76
76
|
});
|
|
77
77
|
// Fetch the doc required for the view
|
|
78
|
-
let doc = initialData ||
|
|
78
|
+
let doc = !idFromArgs && !globalSlug ? initialData || null : await getDocumentData({
|
|
79
79
|
id: idFromArgs,
|
|
80
80
|
collectionSlug,
|
|
81
81
|
globalSlug,
|
|
@@ -84,7 +84,7 @@ export const renderDocument = async ({
|
|
|
84
84
|
req,
|
|
85
85
|
segments,
|
|
86
86
|
user
|
|
87
|
-
})
|
|
87
|
+
});
|
|
88
88
|
if (isEditing && !doc) {
|
|
89
89
|
// If it's a collection document that doesn't exist, redirect to collection list
|
|
90
90
|
if (collectionSlug) {
|
|
@@ -316,9 +316,8 @@ export const renderDocument = async ({
|
|
|
316
316
|
children: [showHeader && !drawerSlug && /*#__PURE__*/_jsx(DocumentHeader, {
|
|
317
317
|
collectionConfig: collectionConfig,
|
|
318
318
|
globalConfig: globalConfig,
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
permissions: permissions
|
|
319
|
+
permissions: permissions,
|
|
320
|
+
req: req
|
|
322
321
|
}), /*#__PURE__*/_jsx(HydrateAuthProvider, {
|
|
323
322
|
permissions: permissions
|
|
324
323
|
}), /*#__PURE__*/_jsx(EditDepthProvider, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["DocumentInfoProvider","EditDepthProvider","HydrateAuthProvider","LivePreviewProvider","RenderServerComponent","isEditing","getIsEditing","buildFormState","notFound","redirect","logError","formatAdminURL","React","DocumentHeader","getPreferences","NotFoundView","getDocPreferences","getDocumentData","getDocumentPermissions","getDocumentView","getIsLocked","getMetaBySegment","getVersions","renderDocumentSlots","generateMetadata","args","renderDocument","disableActions","documentSubViewType","drawerSlug","importMap","initialData","initPageResult","overrideEntityVisibility","params","redirectAfterCreate","redirectAfterDelete","redirectAfterDuplicate","redirectAfterRestore","searchParams","versions","viewType","collectionConfig","docID","idFromArgs","globalConfig","locale","permissions","req","i18n","payload","config","routes","admin","adminRoute","api","apiRoute","serverURL","user","visibleEntities","segments","Array","isArray","collectionSlug","slug","undefined","globalSlug","id","doc","redirectURL","path","encodeURIComponent","Error","isTrashedDoc","deletedAt","docPreferences","docPermissions","hasPublishPermission","hasSavePermission","currentEditor","isLocked","lastUpdateTime","entityPreferences","Promise","all","data","collection","operation","hasPublishedDoc","mostRecentVersionIsAutosaved","unpublishedVersionCount","versionCount","state","formState","code","fallbackLocale","readOnly","renderAllFields","schemaPath","skipValidation","documentViewServerProps","routeSegments","collections","find","visibleSlug","globals","formattedParams","URLSearchParams","drafts","append","apiQueryParams","toString","apiURL","View","showHeader","RootViewOverride","components","views","edit","root","Component","shouldAutosave","autosave","validateDraftData","validate","create","depth","draft","documentSlots","clientProps","isLivePreviewEnabled","Boolean","livePreview","includes","livePreviewConfig","livePreviewURL","url","Document","_jsx","initialState","isTrashed","_jsxs","breakpoints","isLivePreviewing","value","editViewType","serverProps","props","RenderedDocument","error","message","err"],"sources":["../../../src/views/Document/index.tsx"],"sourcesContent":["import type {\n AdminViewServerProps,\n CollectionPreferences,\n Data,\n DocumentViewClientProps,\n DocumentViewServerProps,\n DocumentViewServerPropsOnly,\n EditViewComponent,\n LivePreviewConfig,\n PayloadComponent,\n RenderDocumentVersionsProperties,\n} from 'payload'\n\nimport {\n DocumentInfoProvider,\n EditDepthProvider,\n HydrateAuthProvider,\n LivePreviewProvider,\n} from '@payloadcms/ui'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { isEditing as getIsEditing } from '@payloadcms/ui/shared'\nimport { buildFormState } from '@payloadcms/ui/utilities/buildFormState'\nimport { notFound, redirect } from 'next/navigation.js'\nimport { logError } from 'payload'\nimport { formatAdminURL } from 'payload/shared'\nimport React from 'react'\n\nimport type { GenerateEditViewMetadata } from './getMetaBySegment.js'\n\nimport { DocumentHeader } from '../../elements/DocumentHeader/index.js'\nimport { getPreferences } from '../../utilities/getPreferences.js'\nimport { NotFoundView } from '../NotFound/index.js'\nimport { getDocPreferences } from './getDocPreferences.js'\nimport { getDocumentData } from './getDocumentData.js'\nimport { getDocumentPermissions } from './getDocumentPermissions.js'\nimport { getDocumentView } from './getDocumentView.js'\nimport { getIsLocked } from './getIsLocked.js'\nimport { getMetaBySegment } from './getMetaBySegment.js'\nimport { getVersions } from './getVersions.js'\nimport { renderDocumentSlots } from './renderDocumentSlots.js'\n\nexport const generateMetadata: GenerateEditViewMetadata = async (args) => getMetaBySegment(args)\n\nexport type ViewToRender =\n | EditViewComponent\n | PayloadComponent<DocumentViewServerProps>\n | React.FC\n | React.FC<DocumentViewClientProps>\n\n/**\n * This function is responsible for rendering\n * an Edit Document view on the server for both:\n * - default document edit views\n * - on-demand edit views within drawers\n */\nexport const renderDocument = async ({\n disableActions,\n documentSubViewType,\n drawerSlug,\n importMap,\n initialData,\n initPageResult,\n overrideEntityVisibility,\n params,\n redirectAfterCreate,\n redirectAfterDelete,\n redirectAfterDuplicate,\n redirectAfterRestore,\n searchParams,\n versions,\n viewType,\n}: {\n drawerSlug?: string\n overrideEntityVisibility?: boolean\n readonly redirectAfterCreate?: boolean\n readonly redirectAfterDelete?: boolean\n readonly redirectAfterDuplicate?: boolean\n readonly redirectAfterRestore?: boolean\n versions?: RenderDocumentVersionsProperties\n} & AdminViewServerProps): Promise<{\n data: Data\n Document: React.ReactNode\n}> => {\n const {\n collectionConfig,\n docID: idFromArgs,\n globalConfig,\n locale,\n permissions,\n req,\n req: {\n i18n,\n payload,\n payload: {\n config,\n config: {\n routes: { admin: adminRoute, api: apiRoute },\n serverURL,\n },\n },\n user,\n },\n visibleEntities,\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 let isEditing = getIsEditing({ id: idFromArgs, collectionSlug, globalSlug })\n\n // Fetch the doc required for the view\n let doc =\n initialData ||\n (await getDocumentData({\n id: idFromArgs,\n collectionSlug,\n globalSlug,\n locale,\n payload,\n req,\n segments,\n user,\n }))\n\n if (isEditing && !doc) {\n // If it's a collection document that doesn't exist, redirect to collection list\n if (collectionSlug) {\n const redirectURL = formatAdminURL({\n adminRoute,\n path: `/collections/${collectionSlug}?notFound=${encodeURIComponent(idFromArgs)}`,\n serverURL,\n })\n redirect(redirectURL)\n } else {\n // For globals or other cases, keep the 404 behavior\n throw new Error('not-found')\n }\n }\n\n const isTrashedDoc = typeof doc?.deletedAt === 'string'\n\n const [\n docPreferences,\n { docPermissions, hasPublishPermission, hasSavePermission },\n { currentEditor, isLocked, lastUpdateTime },\n entityPreferences,\n ] = await Promise.all([\n // Get document preferences\n getDocPreferences({\n id: idFromArgs,\n collectionSlug,\n globalSlug,\n payload,\n user,\n }),\n\n // Get permissions\n getDocumentPermissions({\n id: idFromArgs,\n collectionConfig,\n data: doc,\n globalConfig,\n req,\n }),\n\n // Fetch document lock state\n getIsLocked({\n id: idFromArgs,\n collectionConfig,\n globalConfig,\n isEditing,\n req,\n }),\n\n // get entity preferences\n getPreferences<CollectionPreferences>(\n collectionSlug ? `collection-${collectionSlug}` : `global-${globalSlug}`,\n payload,\n req.user.id,\n req.user.collection,\n ),\n ])\n\n const operation = (collectionSlug && idFromArgs) || globalSlug ? 'update' : 'create'\n\n const [\n { hasPublishedDoc, mostRecentVersionIsAutosaved, unpublishedVersionCount, versionCount },\n { state: formState },\n ] = await Promise.all([\n getVersions({\n id: idFromArgs,\n collectionConfig,\n doc,\n docPermissions,\n globalConfig,\n locale: locale?.code,\n payload,\n user,\n }),\n buildFormState({\n id: idFromArgs,\n collectionSlug,\n data: doc,\n docPermissions,\n docPreferences,\n fallbackLocale: false,\n globalSlug,\n locale: locale?.code,\n operation,\n readOnly: isTrashedDoc,\n renderAllFields: true,\n req,\n schemaPath: collectionSlug || globalSlug,\n skipValidation: true,\n }),\n ])\n\n const documentViewServerProps: DocumentViewServerPropsOnly = {\n doc,\n hasPublishedDoc,\n i18n,\n initPageResult,\n locale,\n params,\n payload,\n permissions,\n routeSegments: segments,\n searchParams,\n user,\n versions,\n }\n\n if (\n !overrideEntityVisibility &&\n ((collectionSlug &&\n !visibleEntities?.collections?.find((visibleSlug) => visibleSlug === collectionSlug)) ||\n (globalSlug && !visibleEntities?.globals?.find((visibleSlug) => visibleSlug === globalSlug)))\n ) {\n throw new Error('not-found')\n }\n\n const formattedParams = new URLSearchParams()\n\n if (collectionConfig?.versions?.drafts || globalConfig?.versions?.drafts) {\n formattedParams.append('draft', 'true')\n }\n\n if (locale?.code) {\n formattedParams.append('locale', locale.code)\n }\n\n const apiQueryParams = `?${formattedParams.toString()}`\n\n const apiURL = collectionSlug\n ? `${serverURL}${apiRoute}/${collectionSlug}/${idFromArgs}${apiQueryParams}`\n : globalSlug\n ? `${serverURL}${apiRoute}/${globalSlug}${apiQueryParams}`\n : ''\n\n let View: ViewToRender = null\n\n let showHeader = true\n\n const RootViewOverride =\n collectionConfig?.admin?.components?.views?.edit?.root &&\n 'Component' in collectionConfig.admin.components.views.edit.root\n ? collectionConfig?.admin?.components?.views?.edit?.root?.Component\n : globalConfig?.admin?.components?.views?.edit?.root &&\n 'Component' in globalConfig.admin.components.views.edit.root\n ? globalConfig?.admin?.components?.views?.edit?.root?.Component\n : null\n\n if (RootViewOverride) {\n View = RootViewOverride\n showHeader = false\n } else {\n ;({ View } = getDocumentView({\n collectionConfig,\n config,\n docPermissions,\n globalConfig,\n routeSegments: segments,\n }))\n }\n\n if (!View) {\n View = NotFoundView\n }\n\n /**\n * Handle case where autoSave is enabled and the document is being created\n * => create document and redirect\n */\n const shouldAutosave =\n hasSavePermission &&\n ((collectionConfig?.versions?.drafts && collectionConfig?.versions?.drafts?.autosave) ||\n (globalConfig?.versions?.drafts && globalConfig?.versions?.drafts?.autosave))\n\n const validateDraftData =\n collectionConfig?.versions?.drafts && collectionConfig?.versions?.drafts?.validate\n\n let id = idFromArgs\n\n if (shouldAutosave && !validateDraftData && !idFromArgs && collectionSlug) {\n doc = await payload.create({\n collection: collectionSlug,\n data: initialData || {},\n depth: 0,\n draft: true,\n fallbackLocale: false,\n locale: locale?.code,\n req,\n user,\n })\n\n if (doc?.id) {\n id = doc.id\n isEditing = getIsEditing({ id: doc.id, collectionSlug, globalSlug })\n\n if (!drawerSlug && redirectAfterCreate !== false) {\n const redirectURL = formatAdminURL({\n adminRoute,\n path: `/collections/${collectionSlug}/${doc.id}`,\n serverURL,\n })\n\n redirect(redirectURL)\n }\n } else {\n throw new Error('not-found')\n }\n }\n\n const documentSlots = renderDocumentSlots({\n collectionConfig,\n globalConfig,\n hasSavePermission,\n permissions: docPermissions,\n req,\n })\n\n const clientProps: DocumentViewClientProps = {\n formState,\n ...documentSlots,\n documentSubViewType,\n viewType,\n }\n\n const isLivePreviewEnabled = Boolean(\n config.admin?.livePreview?.collections?.includes(collectionSlug) ||\n config.admin?.livePreview?.globals?.includes(globalSlug) ||\n collectionConfig?.admin?.livePreview ||\n globalConfig?.admin?.livePreview,\n )\n\n const livePreviewConfig: LivePreviewConfig = {\n ...(isLivePreviewEnabled ? config.admin.livePreview : {}),\n ...(collectionConfig?.admin?.livePreview || {}),\n ...(globalConfig?.admin?.livePreview || {}),\n }\n\n const livePreviewURL =\n operation !== 'create'\n ? typeof livePreviewConfig?.url === 'function'\n ? await livePreviewConfig.url({\n collectionConfig,\n data: doc,\n globalConfig,\n locale,\n req,\n /**\n * @deprecated\n * Use `req.payload` instead. This will be removed in the next major version.\n */\n payload: initPageResult.req.payload,\n })\n : livePreviewConfig?.url\n : ''\n\n return {\n data: doc,\n Document: (\n <DocumentInfoProvider\n apiURL={apiURL}\n collectionSlug={collectionConfig?.slug}\n currentEditor={currentEditor}\n disableActions={disableActions ?? false}\n docPermissions={docPermissions}\n globalSlug={globalConfig?.slug}\n hasPublishedDoc={hasPublishedDoc}\n hasPublishPermission={hasPublishPermission}\n hasSavePermission={hasSavePermission}\n id={id}\n initialData={doc}\n initialState={formState}\n isEditing={isEditing}\n isLocked={isLocked}\n isTrashed={isTrashedDoc}\n key={locale?.code}\n lastUpdateTime={lastUpdateTime}\n mostRecentVersionIsAutosaved={mostRecentVersionIsAutosaved}\n redirectAfterCreate={redirectAfterCreate}\n redirectAfterDelete={redirectAfterDelete}\n redirectAfterDuplicate={redirectAfterDuplicate}\n redirectAfterRestore={redirectAfterRestore}\n unpublishedVersionCount={unpublishedVersionCount}\n versionCount={versionCount}\n >\n <LivePreviewProvider\n breakpoints={livePreviewConfig?.breakpoints}\n isLivePreviewEnabled={isLivePreviewEnabled && operation !== 'create'}\n isLivePreviewing={entityPreferences?.value?.editViewType === 'live-preview'}\n url={livePreviewURL}\n >\n {showHeader && !drawerSlug && (\n <DocumentHeader\n collectionConfig={collectionConfig}\n globalConfig={globalConfig}\n i18n={i18n}\n payload={payload}\n permissions={permissions}\n />\n )}\n <HydrateAuthProvider permissions={permissions} />\n <EditDepthProvider>\n {RenderServerComponent({\n clientProps,\n Component: View,\n importMap,\n serverProps: documentViewServerProps,\n })}\n </EditDepthProvider>\n </LivePreviewProvider>\n </DocumentInfoProvider>\n ),\n }\n}\n\nexport async function Document(props: AdminViewServerProps) {\n try {\n const { Document: RenderedDocument } = await renderDocument(props)\n return RenderedDocument\n } catch (error) {\n if (error?.message === 'NEXT_REDIRECT') {\n throw error\n }\n\n logError({ err: error, payload: props.initPageResult.req.payload })\n\n if (error.message === 'not-found') {\n notFound()\n }\n }\n}\n"],"mappings":";AAaA,SACEA,oBAAoB,EACpBC,iBAAiB,EACjBC,mBAAmB,EACnBC,mBAAmB,QACd;AACP,SAASC,qBAAqB,QAAQ;AACtC,SAASC,SAAA,IAAaC,YAAY,QAAQ;AAC1C,SAASC,cAAc,QAAQ;AAC/B,SAASC,QAAQ,EAAEC,QAAQ,QAAQ;AACnC,SAASC,QAAQ,QAAQ;AACzB,SAASC,cAAc,QAAQ;AAC/B,OAAOC,KAAA,MAAW;AAIlB,SAASC,cAAc,QAAQ;AAC/B,SAASC,cAAc,QAAQ;AAC/B,SAASC,YAAY,QAAQ;AAC7B,SAASC,iBAAiB,QAAQ;AAClC,SAASC,eAAe,QAAQ;AAChC,SAASC,sBAAsB,QAAQ;AACvC,SAASC,eAAe,QAAQ;AAChC,SAASC,WAAW,QAAQ;AAC5B,SAASC,gBAAgB,QAAQ;AACjC,SAASC,WAAW,QAAQ;AAC5B,SAASC,mBAAmB,QAAQ;AAEpC,OAAO,MAAMC,gBAAA,GAA6C,MAAOC,IAAA,IAASJ,gBAAA,CAAiBI,IAAA;AAQ3F;;;;;;AAMA,OAAO,MAAMC,cAAA,GAAiB,MAAAA,CAAO;EACnCC,cAAc;EACdC,mBAAmB;EACnBC,UAAU;EACVC,SAAS;EACTC,WAAW;EACXC,cAAc;EACdC,wBAAwB;EACxBC,MAAM;EACNC,mBAAmB;EACnBC,mBAAmB;EACnBC,sBAAsB;EACtBC,oBAAoB;EACpBC,YAAY;EACZC,QAAQ;EACRC;AAAQ,CASc;EAItB,MAAM;IACJC,gBAAgB;IAChBC,KAAA,EAAOC,UAAU;IACjBC,YAAY;IACZC,MAAM;IACNC,WAAW;IACXC,GAAG;IACHA,GAAA,EAAK;MACHC,IAAI;MACJC,OAAO;MACPA,OAAA,EAAS;QACPC,MAAM;QACNA,MAAA,EAAQ;UACNC,MAAA,EAAQ;YAAEC,KAAA,EAAOC,UAAU;YAAEC,GAAA,EAAKC;UAAQ,CAAE;UAC5CC;QAAS;MACV,CACF;MACDC;IAAI,CACL;IACDC;EAAe,CAChB,GAAG3B,cAAA;EAEJ,MAAM4B,QAAA,GAAWC,KAAA,CAAMC,OAAO,CAAC5B,MAAA,EAAQ0B,QAAA,IAAY1B,MAAA,CAAO0B,QAAQ,GAAG,EAAE;EACvE,MAAMG,cAAA,GAAiBrB,gBAAA,EAAkBsB,IAAA,IAAQC,SAAA;EACjD,MAAMC,UAAA,GAAarB,YAAA,EAAcmB,IAAA,IAAQC,SAAA;EACzC,IAAI5D,SAAA,GAAYC,YAAA,CAAa;IAAE6D,EAAA,EAAIvB,UAAA;IAAYmB,cAAA;IAAgBG;EAAW;EAE1E;EACA,IAAIE,GAAA,GACFrC,WAAA,KACC,MAAMd,eAAA,CAAgB;IACrBkD,EAAA,EAAIvB,UAAA;IACJmB,cAAA;IACAG,UAAA;IACApB,MAAA;IACAI,OAAA;IACAF,GAAA;IACAY,QAAA;IACAF;EACF;EAEF,IAAIrD,SAAA,IAAa,CAAC+D,GAAA,EAAK;IACrB;IACA,IAAIL,cAAA,EAAgB;MAClB,MAAMM,WAAA,GAAc1D,cAAA,CAAe;QACjC2C,UAAA;QACAgB,IAAA,EAAM,gBAAgBP,cAAA,aAA2BQ,kBAAA,CAAmB3B,UAAA,GAAa;QACjFa;MACF;MACAhD,QAAA,CAAS4D,WAAA;IACX,OAAO;MACL;MACA,MAAM,IAAIG,KAAA,CAAM;IAClB;EACF;EAEA,MAAMC,YAAA,GAAe,OAAOL,GAAA,EAAKM,SAAA,KAAc;EAE/C,MAAM,CACJC,cAAA,EACA;IAAEC,cAAc;IAAEC,oBAAoB;IAAEC;EAAiB,CAAE,EAC3D;IAAEC,aAAa;IAAEC,QAAQ;IAAEC;EAAc,CAAE,EAC3CC,iBAAA,CACD,GAAG,MAAMC,OAAA,CAAQC,GAAG,CAAC;EACpB;EACApE,iBAAA,CAAkB;IAChBmD,EAAA,EAAIvB,UAAA;IACJmB,cAAA;IACAG,UAAA;IACAhB,OAAA;IACAQ;EACF;EAEA;EACAxC,sBAAA,CAAuB;IACrBiD,EAAA,EAAIvB,UAAA;IACJF,gBAAA;IACA2C,IAAA,EAAMjB,GAAA;IACNvB,YAAA;IACAG;EACF;EAEA;EACA5B,WAAA,CAAY;IACV+C,EAAA,EAAIvB,UAAA;IACJF,gBAAA;IACAG,YAAA;IACAxC,SAAA;IACA2C;EACF;EAEA;EACAlC,cAAA,CACEiD,cAAA,GAAiB,cAAcA,cAAA,EAAgB,GAAG,UAAUG,UAAA,EAAY,EACxEhB,OAAA,EACAF,GAAA,CAAIU,IAAI,CAACS,EAAE,EACXnB,GAAA,CAAIU,IAAI,CAAC4B,UAAU,EAEtB;EAED,MAAMC,SAAA,GAAYxB,cAAC,IAAkBnB,UAAA,IAAesB,UAAA,GAAa,WAAW;EAE5E,MAAM,CACJ;IAAEsB,eAAe;IAAEC,4BAA4B;IAAEC,uBAAuB;IAAEC;EAAY,CAAE,EACxF;IAAEC,KAAA,EAAOC;EAAS,CAAE,CACrB,GAAG,MAAMV,OAAA,CAAQC,GAAG,CAAC,CACpB9D,WAAA,CAAY;IACV6C,EAAA,EAAIvB,UAAA;IACJF,gBAAA;IACA0B,GAAA;IACAQ,cAAA;IACA/B,YAAA;IACAC,MAAA,EAAQA,MAAA,EAAQgD,IAAA;IAChB5C,OAAA;IACAQ;EACF,IACAnD,cAAA,CAAe;IACb4D,EAAA,EAAIvB,UAAA;IACJmB,cAAA;IACAsB,IAAA,EAAMjB,GAAA;IACNQ,cAAA;IACAD,cAAA;IACAoB,cAAA,EAAgB;IAChB7B,UAAA;IACApB,MAAA,EAAQA,MAAA,EAAQgD,IAAA;IAChBP,SAAA;IACAS,QAAA,EAAUvB,YAAA;IACVwB,eAAA,EAAiB;IACjBjD,GAAA;IACAkD,UAAA,EAAYnC,cAAA,IAAkBG,UAAA;IAC9BiC,cAAA,EAAgB;EAClB,GACD;EAED,MAAMC,uBAAA,GAAuD;IAC3DhC,GAAA;IACAoB,eAAA;IACAvC,IAAA;IACAjB,cAAA;IACAc,MAAA;IACAZ,MAAA;IACAgB,OAAA;IACAH,WAAA;IACAsD,aAAA,EAAezC,QAAA;IACfrB,YAAA;IACAmB,IAAA;IACAlB;EACF;EAEA,IACE,CAACP,wBAAA,KACA8B,cAAC,IACA,CAACJ,eAAA,EAAiB2C,WAAA,EAAaC,IAAA,CAAMC,WAAA,IAAgBA,WAAA,KAAgBzC,cAAA,KACpEG,UAAA,IAAc,CAACP,eAAA,EAAiB8C,OAAA,EAASF,IAAA,CAAMC,WAAA,IAAgBA,WAAA,KAAgBtC,UAAA,CAAW,GAC7F;IACA,MAAM,IAAIM,KAAA,CAAM;EAClB;EAEA,MAAMkC,eAAA,GAAkB,IAAIC,eAAA;EAE5B,IAAIjE,gBAAA,EAAkBF,QAAA,EAAUoE,MAAA,IAAU/D,YAAA,EAAcL,QAAA,EAAUoE,MAAA,EAAQ;IACxEF,eAAA,CAAgBG,MAAM,CAAC,SAAS;EAClC;EAEA,IAAI/D,MAAA,EAAQgD,IAAA,EAAM;IAChBY,eAAA,CAAgBG,MAAM,CAAC,UAAU/D,MAAA,CAAOgD,IAAI;EAC9C;EAEA,MAAMgB,cAAA,GAAiB,IAAIJ,eAAA,CAAgBK,QAAQ,IAAI;EAEvD,MAAMC,MAAA,GAASjD,cAAA,GACX,GAAGN,SAAA,GAAYD,QAAA,IAAYO,cAAA,IAAkBnB,UAAA,GAAakE,cAAA,EAAgB,GAC1E5C,UAAA,GACE,GAAGT,SAAA,GAAYD,QAAA,IAAYU,UAAA,GAAa4C,cAAA,EAAgB,GACxD;EAEN,IAAIG,IAAA,GAAqB;EAEzB,IAAIC,UAAA,GAAa;EAEjB,MAAMC,gBAAA,GACJzE,gBAAA,EAAkBW,KAAA,EAAO+D,UAAA,EAAYC,KAAA,EAAOC,IAAA,EAAMC,IAAA,IAClD,eAAe7E,gBAAA,CAAiBW,KAAK,CAAC+D,UAAU,CAACC,KAAK,CAACC,IAAI,CAACC,IAAI,GAC5D7E,gBAAA,EAAkBW,KAAA,EAAO+D,UAAA,EAAYC,KAAA,EAAOC,IAAA,EAAMC,IAAA,EAAMC,SAAA,GACxD3E,YAAA,EAAcQ,KAAA,EAAO+D,UAAA,EAAYC,KAAA,EAAOC,IAAA,EAAMC,IAAA,IAC5C,eAAe1E,YAAA,CAAaQ,KAAK,CAAC+D,UAAU,CAACC,KAAK,CAACC,IAAI,CAACC,IAAI,GAC5D1E,YAAA,EAAcQ,KAAA,EAAO+D,UAAA,EAAYC,KAAA,EAAOC,IAAA,EAAMC,IAAA,EAAMC,SAAA,GACpD;EAER,IAAIL,gBAAA,EAAkB;IACpBF,IAAA,GAAOE,gBAAA;IACPD,UAAA,GAAa;EACf,OAAO;IACH;MAAED;IAAI,CAAE,GAAG9F,eAAA,CAAgB;MAC3BuB,gBAAA;MACAS,MAAA;MACAyB,cAAA;MACA/B,YAAA;MACAwD,aAAA,EAAezC;IACjB,EAAC;EACH;EAEA,IAAI,CAACqD,IAAA,EAAM;IACTA,IAAA,GAAOlG,YAAA;EACT;EAEA;;;;EAIA,MAAM0G,cAAA,GACJ3C,iBAAA,KACCpC,gBAAC,EAAkBF,QAAA,EAAUoE,MAAA,IAAUlE,gBAAA,EAAkBF,QAAA,EAAUoE,MAAA,EAAQc,QAAA,IACzE7E,YAAA,EAAcL,QAAA,EAAUoE,MAAA,IAAU/D,YAAA,EAAcL,QAAA,EAAUoE,MAAA,EAAQc,QAAQ;EAE/E,MAAMC,iBAAA,GACJjF,gBAAA,EAAkBF,QAAA,EAAUoE,MAAA,IAAUlE,gBAAA,EAAkBF,QAAA,EAAUoE,MAAA,EAAQgB,QAAA;EAE5E,IAAIzD,EAAA,GAAKvB,UAAA;EAET,IAAI6E,cAAA,IAAkB,CAACE,iBAAA,IAAqB,CAAC/E,UAAA,IAAcmB,cAAA,EAAgB;IACzEK,GAAA,GAAM,MAAMlB,OAAA,CAAQ2E,MAAM,CAAC;MACzBvC,UAAA,EAAYvB,cAAA;MACZsB,IAAA,EAAMtD,WAAA,IAAe,CAAC;MACtB+F,KAAA,EAAO;MACPC,KAAA,EAAO;MACPhC,cAAA,EAAgB;MAChBjD,MAAA,EAAQA,MAAA,EAAQgD,IAAA;MAChB9C,GAAA;MACAU;IACF;IAEA,IAAIU,GAAA,EAAKD,EAAA,EAAI;MACXA,EAAA,GAAKC,GAAA,CAAID,EAAE;MACX9D,SAAA,GAAYC,YAAA,CAAa;QAAE6D,EAAA,EAAIC,GAAA,CAAID,EAAE;QAAEJ,cAAA;QAAgBG;MAAW;MAElE,IAAI,CAACrC,UAAA,IAAcM,mBAAA,KAAwB,OAAO;QAChD,MAAMkC,WAAA,GAAc1D,cAAA,CAAe;UACjC2C,UAAA;UACAgB,IAAA,EAAM,gBAAgBP,cAAA,IAAkBK,GAAA,CAAID,EAAE,EAAE;UAChDV;QACF;QAEAhD,QAAA,CAAS4D,WAAA;MACX;IACF,OAAO;MACL,MAAM,IAAIG,KAAA,CAAM;IAClB;EACF;EAEA,MAAMwD,aAAA,GAAgBzG,mBAAA,CAAoB;IACxCmB,gBAAA;IACAG,YAAA;IACAiC,iBAAA;IACA/B,WAAA,EAAa6B,cAAA;IACb5B;EACF;EAEA,MAAMiF,WAAA,GAAuC;IAC3CpC,SAAA;IACA,GAAGmC,aAAa;IAChBpG,mBAAA;IACAa;EACF;EAEA,MAAMyF,oBAAA,GAAuBC,OAAA,CAC3BhF,MAAA,CAAOE,KAAK,EAAE+E,WAAA,EAAa9B,WAAA,EAAa+B,QAAA,CAAStE,cAAA,KAC/CZ,MAAA,CAAOE,KAAK,EAAE+E,WAAA,EAAa3B,OAAA,EAAS4B,QAAA,CAASnE,UAAA,KAC7CxB,gBAAA,EAAkBW,KAAA,EAAO+E,WAAA,IACzBvF,YAAA,EAAcQ,KAAA,EAAO+E,WAAA;EAGzB,MAAME,iBAAA,GAAuC;IAC3C,IAAIJ,oBAAA,GAAuB/E,MAAA,CAAOE,KAAK,CAAC+E,WAAW,GAAG,CAAC,CAAC;IACxD,IAAI1F,gBAAA,EAAkBW,KAAA,EAAO+E,WAAA,IAAe,CAAC,CAAC;IAC9C,IAAIvF,YAAA,EAAcQ,KAAA,EAAO+E,WAAA,IAAe,CAAC,CAAC;EAC5C;EAEA,MAAMG,cAAA,GACJhD,SAAA,KAAc,WACV,OAAO+C,iBAAA,EAAmBE,GAAA,KAAQ,aAChC,MAAMF,iBAAA,CAAkBE,GAAG,CAAC;IAC1B9F,gBAAA;IACA2C,IAAA,EAAMjB,GAAA;IACNvB,YAAA;IACAC,MAAA;IACAE,GAAA;IACA;;;;IAIAE,OAAA,EAASlB,cAAA,CAAegB,GAAG,CAACE;EAC9B,KACAoF,iBAAA,EAAmBE,GAAA,GACrB;EAEN,OAAO;IACLnD,IAAA,EAAMjB,GAAA;IACNqE,QAAA,eACEC,IAAA,CAAC1I,oBAAA;MACCgH,MAAA,EAAQA,MAAA;MACRjD,cAAA,EAAgBrB,gBAAA,EAAkBsB,IAAA;MAClCe,aAAA,EAAeA,aAAA;MACfpD,cAAA,EAAgBA,cAAA,IAAkB;MAClCiD,cAAA,EAAgBA,cAAA;MAChBV,UAAA,EAAYrB,YAAA,EAAcmB,IAAA;MAC1BwB,eAAA,EAAiBA,eAAA;MACjBX,oBAAA,EAAsBA,oBAAA;MACtBC,iBAAA,EAAmBA,iBAAA;MACnBX,EAAA,EAAIA,EAAA;MACJpC,WAAA,EAAaqC,GAAA;MACbuE,YAAA,EAAc9C,SAAA;MACdxF,SAAA,EAAWA,SAAA;MACX2E,QAAA,EAAUA,QAAA;MACV4D,SAAA,EAAWnE,YAAA;MAEXQ,cAAA,EAAgBA,cAAA;MAChBQ,4BAAA,EAA8BA,4BAAA;MAC9BtD,mBAAA,EAAqBA,mBAAA;MACrBC,mBAAA,EAAqBA,mBAAA;MACrBC,sBAAA,EAAwBA,sBAAA;MACxBC,oBAAA,EAAsBA,oBAAA;MACtBoD,uBAAA,EAAyBA,uBAAA;MACzBC,YAAA,EAAcA,YAAA;gBAEd,aAAAkD,KAAA,CAAC1I,mBAAA;QACC2I,WAAA,EAAaR,iBAAA,EAAmBQ,WAAA;QAChCZ,oBAAA,EAAsBA,oBAAA,IAAwB3C,SAAA,KAAc;QAC5DwD,gBAAA,EAAkB7D,iBAAA,EAAmB8D,KAAA,EAAOC,YAAA,KAAiB;QAC7DT,GAAA,EAAKD,cAAA;mBAEJrB,UAAA,IAAc,CAACrF,UAAA,iBACd6G,IAAA,CAAC7H,cAAA;UACC6B,gBAAA,EAAkBA,gBAAA;UAClBG,YAAA,EAAcA,YAAA;UACdI,IAAA,EAAMA,IAAA;UACNC,OAAA,EAASA,OAAA;UACTH,WAAA,EAAaA;yBAGjB2F,IAAA,CAACxI,mBAAA;UAAoB6C,WAAA,EAAaA;yBAClC2F,IAAA,CAACzI,iBAAA;oBACEG,qBAAA,CAAsB;YACrB6H,WAAA;YACAT,SAAA,EAAWP,IAAA;YACXnF,SAAA;YACAoH,WAAA,EAAa9C;UACf;;;OAhCCtD,MAAA,EAAQgD,IAAA;EAqCnB;AACF;AAEA,OAAO,eAAe2C,SAASU,KAA2B;EACxD,IAAI;IACF,MAAM;MAAEV,QAAA,EAAUW;IAAgB,CAAE,GAAG,MAAM1H,cAAA,CAAeyH,KAAA;IAC5D,OAAOC,gBAAA;EACT,EAAE,OAAOC,KAAA,EAAO;IACd,IAAIA,KAAA,EAAOC,OAAA,KAAY,iBAAiB;MACtC,MAAMD,KAAA;IACR;IAEA3I,QAAA,CAAS;MAAE6I,GAAA,EAAKF,KAAA;MAAOnG,OAAA,EAASiG,KAAA,CAAMnH,cAAc,CAACgB,GAAG,CAACE;IAAQ;IAEjE,IAAImG,KAAA,CAAMC,OAAO,KAAK,aAAa;MACjC9I,QAAA;IACF;EACF;AACF","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["DocumentInfoProvider","EditDepthProvider","HydrateAuthProvider","LivePreviewProvider","RenderServerComponent","isEditing","getIsEditing","buildFormState","notFound","redirect","logError","formatAdminURL","React","DocumentHeader","getPreferences","NotFoundView","getDocPreferences","getDocumentData","getDocumentPermissions","getDocumentView","getIsLocked","getMetaBySegment","getVersions","renderDocumentSlots","generateMetadata","args","renderDocument","disableActions","documentSubViewType","drawerSlug","importMap","initialData","initPageResult","overrideEntityVisibility","params","redirectAfterCreate","redirectAfterDelete","redirectAfterDuplicate","redirectAfterRestore","searchParams","versions","viewType","collectionConfig","docID","idFromArgs","globalConfig","locale","permissions","req","i18n","payload","config","routes","admin","adminRoute","api","apiRoute","serverURL","user","visibleEntities","segments","Array","isArray","collectionSlug","slug","undefined","globalSlug","id","doc","redirectURL","path","encodeURIComponent","Error","isTrashedDoc","deletedAt","docPreferences","docPermissions","hasPublishPermission","hasSavePermission","currentEditor","isLocked","lastUpdateTime","entityPreferences","Promise","all","data","collection","operation","hasPublishedDoc","mostRecentVersionIsAutosaved","unpublishedVersionCount","versionCount","state","formState","code","fallbackLocale","readOnly","renderAllFields","schemaPath","skipValidation","documentViewServerProps","routeSegments","collections","find","visibleSlug","globals","formattedParams","URLSearchParams","drafts","append","apiQueryParams","toString","apiURL","View","showHeader","RootViewOverride","components","views","edit","root","Component","shouldAutosave","autosave","validateDraftData","validate","create","depth","draft","documentSlots","clientProps","isLivePreviewEnabled","Boolean","livePreview","includes","livePreviewConfig","livePreviewURL","url","Document","_jsx","initialState","isTrashed","_jsxs","breakpoints","isLivePreviewing","value","editViewType","serverProps","props","RenderedDocument","error","message","err"],"sources":["../../../src/views/Document/index.tsx"],"sourcesContent":["import type {\n AdminViewServerProps,\n CollectionPreferences,\n Data,\n DocumentViewClientProps,\n DocumentViewServerProps,\n DocumentViewServerPropsOnly,\n EditViewComponent,\n LivePreviewConfig,\n PayloadComponent,\n RenderDocumentVersionsProperties,\n} from 'payload'\n\nimport {\n DocumentInfoProvider,\n EditDepthProvider,\n HydrateAuthProvider,\n LivePreviewProvider,\n} from '@payloadcms/ui'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { isEditing as getIsEditing } from '@payloadcms/ui/shared'\nimport { buildFormState } from '@payloadcms/ui/utilities/buildFormState'\nimport { notFound, redirect } from 'next/navigation.js'\nimport { logError } from 'payload'\nimport { formatAdminURL } from 'payload/shared'\nimport React from 'react'\n\nimport type { GenerateEditViewMetadata } from './getMetaBySegment.js'\n\nimport { DocumentHeader } from '../../elements/DocumentHeader/index.js'\nimport { getPreferences } from '../../utilities/getPreferences.js'\nimport { NotFoundView } from '../NotFound/index.js'\nimport { getDocPreferences } from './getDocPreferences.js'\nimport { getDocumentData } from './getDocumentData.js'\nimport { getDocumentPermissions } from './getDocumentPermissions.js'\nimport { getDocumentView } from './getDocumentView.js'\nimport { getIsLocked } from './getIsLocked.js'\nimport { getMetaBySegment } from './getMetaBySegment.js'\nimport { getVersions } from './getVersions.js'\nimport { renderDocumentSlots } from './renderDocumentSlots.js'\n\nexport const generateMetadata: GenerateEditViewMetadata = async (args) => getMetaBySegment(args)\n\nexport type ViewToRender =\n | EditViewComponent\n | PayloadComponent<DocumentViewServerProps>\n | React.FC\n | React.FC<DocumentViewClientProps>\n\n/**\n * This function is responsible for rendering\n * an Edit Document view on the server for both:\n * - default document edit views\n * - on-demand edit views within drawers\n */\nexport const renderDocument = async ({\n disableActions,\n documentSubViewType,\n drawerSlug,\n importMap,\n initialData,\n initPageResult,\n overrideEntityVisibility,\n params,\n redirectAfterCreate,\n redirectAfterDelete,\n redirectAfterDuplicate,\n redirectAfterRestore,\n searchParams,\n versions,\n viewType,\n}: {\n drawerSlug?: string\n overrideEntityVisibility?: boolean\n readonly redirectAfterCreate?: boolean\n readonly redirectAfterDelete?: boolean\n readonly redirectAfterDuplicate?: boolean\n readonly redirectAfterRestore?: boolean\n versions?: RenderDocumentVersionsProperties\n} & AdminViewServerProps): Promise<{\n data: Data\n Document: React.ReactNode\n}> => {\n const {\n collectionConfig,\n docID: idFromArgs,\n globalConfig,\n locale,\n permissions,\n req,\n req: {\n i18n,\n payload,\n payload: {\n config,\n config: {\n routes: { admin: adminRoute, api: apiRoute },\n serverURL,\n },\n },\n user,\n },\n visibleEntities,\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 let isEditing = getIsEditing({ id: idFromArgs, collectionSlug, globalSlug })\n\n // Fetch the doc required for the view\n let doc =\n !idFromArgs && !globalSlug\n ? initialData || null\n : await getDocumentData({\n id: idFromArgs,\n collectionSlug,\n globalSlug,\n locale,\n payload,\n req,\n segments,\n user,\n })\n\n if (isEditing && !doc) {\n // If it's a collection document that doesn't exist, redirect to collection list\n if (collectionSlug) {\n const redirectURL = formatAdminURL({\n adminRoute,\n path: `/collections/${collectionSlug}?notFound=${encodeURIComponent(idFromArgs)}`,\n serverURL,\n })\n redirect(redirectURL)\n } else {\n // For globals or other cases, keep the 404 behavior\n throw new Error('not-found')\n }\n }\n\n const isTrashedDoc = typeof doc?.deletedAt === 'string'\n\n const [\n docPreferences,\n { docPermissions, hasPublishPermission, hasSavePermission },\n { currentEditor, isLocked, lastUpdateTime },\n entityPreferences,\n ] = await Promise.all([\n // Get document preferences\n getDocPreferences({\n id: idFromArgs,\n collectionSlug,\n globalSlug,\n payload,\n user,\n }),\n\n // Get permissions\n getDocumentPermissions({\n id: idFromArgs,\n collectionConfig,\n data: doc,\n globalConfig,\n req,\n }),\n\n // Fetch document lock state\n getIsLocked({\n id: idFromArgs,\n collectionConfig,\n globalConfig,\n isEditing,\n req,\n }),\n\n // get entity preferences\n getPreferences<CollectionPreferences>(\n collectionSlug ? `collection-${collectionSlug}` : `global-${globalSlug}`,\n payload,\n req.user.id,\n req.user.collection,\n ),\n ])\n\n const operation = (collectionSlug && idFromArgs) || globalSlug ? 'update' : 'create'\n\n const [\n { hasPublishedDoc, mostRecentVersionIsAutosaved, unpublishedVersionCount, versionCount },\n { state: formState },\n ] = await Promise.all([\n getVersions({\n id: idFromArgs,\n collectionConfig,\n doc,\n docPermissions,\n globalConfig,\n locale: locale?.code,\n payload,\n user,\n }),\n buildFormState({\n id: idFromArgs,\n collectionSlug,\n data: doc,\n docPermissions,\n docPreferences,\n fallbackLocale: false,\n globalSlug,\n locale: locale?.code,\n operation,\n readOnly: isTrashedDoc,\n renderAllFields: true,\n req,\n schemaPath: collectionSlug || globalSlug,\n skipValidation: true,\n }),\n ])\n\n const documentViewServerProps: DocumentViewServerPropsOnly = {\n doc,\n hasPublishedDoc,\n i18n,\n initPageResult,\n locale,\n params,\n payload,\n permissions,\n routeSegments: segments,\n searchParams,\n user,\n versions,\n }\n\n if (\n !overrideEntityVisibility &&\n ((collectionSlug &&\n !visibleEntities?.collections?.find((visibleSlug) => visibleSlug === collectionSlug)) ||\n (globalSlug && !visibleEntities?.globals?.find((visibleSlug) => visibleSlug === globalSlug)))\n ) {\n throw new Error('not-found')\n }\n\n const formattedParams = new URLSearchParams()\n\n if (collectionConfig?.versions?.drafts || globalConfig?.versions?.drafts) {\n formattedParams.append('draft', 'true')\n }\n\n if (locale?.code) {\n formattedParams.append('locale', locale.code)\n }\n\n const apiQueryParams = `?${formattedParams.toString()}`\n\n const apiURL = collectionSlug\n ? `${serverURL}${apiRoute}/${collectionSlug}/${idFromArgs}${apiQueryParams}`\n : globalSlug\n ? `${serverURL}${apiRoute}/${globalSlug}${apiQueryParams}`\n : ''\n\n let View: ViewToRender = null\n\n let showHeader = true\n\n const RootViewOverride =\n collectionConfig?.admin?.components?.views?.edit?.root &&\n 'Component' in collectionConfig.admin.components.views.edit.root\n ? collectionConfig?.admin?.components?.views?.edit?.root?.Component\n : globalConfig?.admin?.components?.views?.edit?.root &&\n 'Component' in globalConfig.admin.components.views.edit.root\n ? globalConfig?.admin?.components?.views?.edit?.root?.Component\n : null\n\n if (RootViewOverride) {\n View = RootViewOverride\n showHeader = false\n } else {\n ;({ View } = getDocumentView({\n collectionConfig,\n config,\n docPermissions,\n globalConfig,\n routeSegments: segments,\n }))\n }\n\n if (!View) {\n View = NotFoundView\n }\n\n /**\n * Handle case where autoSave is enabled and the document is being created\n * => create document and redirect\n */\n const shouldAutosave =\n hasSavePermission &&\n ((collectionConfig?.versions?.drafts && collectionConfig?.versions?.drafts?.autosave) ||\n (globalConfig?.versions?.drafts && globalConfig?.versions?.drafts?.autosave))\n\n const validateDraftData =\n collectionConfig?.versions?.drafts && collectionConfig?.versions?.drafts?.validate\n\n let id = idFromArgs\n\n if (shouldAutosave && !validateDraftData && !idFromArgs && collectionSlug) {\n doc = await payload.create({\n collection: collectionSlug,\n data: initialData || {},\n depth: 0,\n draft: true,\n fallbackLocale: false,\n locale: locale?.code,\n req,\n user,\n })\n\n if (doc?.id) {\n id = doc.id\n isEditing = getIsEditing({ id: doc.id, collectionSlug, globalSlug })\n\n if (!drawerSlug && redirectAfterCreate !== false) {\n const redirectURL = formatAdminURL({\n adminRoute,\n path: `/collections/${collectionSlug}/${doc.id}`,\n serverURL,\n })\n\n redirect(redirectURL)\n }\n } else {\n throw new Error('not-found')\n }\n }\n\n const documentSlots = renderDocumentSlots({\n collectionConfig,\n globalConfig,\n hasSavePermission,\n permissions: docPermissions,\n req,\n })\n\n const clientProps: DocumentViewClientProps = {\n formState,\n ...documentSlots,\n documentSubViewType,\n viewType,\n }\n\n const isLivePreviewEnabled = Boolean(\n config.admin?.livePreview?.collections?.includes(collectionSlug) ||\n config.admin?.livePreview?.globals?.includes(globalSlug) ||\n collectionConfig?.admin?.livePreview ||\n globalConfig?.admin?.livePreview,\n )\n\n const livePreviewConfig: LivePreviewConfig = {\n ...(isLivePreviewEnabled ? config.admin.livePreview : {}),\n ...(collectionConfig?.admin?.livePreview || {}),\n ...(globalConfig?.admin?.livePreview || {}),\n }\n\n const livePreviewURL =\n operation !== 'create'\n ? typeof livePreviewConfig?.url === 'function'\n ? await livePreviewConfig.url({\n collectionConfig,\n data: doc,\n globalConfig,\n locale,\n req,\n /**\n * @deprecated\n * Use `req.payload` instead. This will be removed in the next major version.\n */\n payload: initPageResult.req.payload,\n })\n : livePreviewConfig?.url\n : ''\n\n return {\n data: doc,\n Document: (\n <DocumentInfoProvider\n apiURL={apiURL}\n collectionSlug={collectionConfig?.slug}\n currentEditor={currentEditor}\n disableActions={disableActions ?? false}\n docPermissions={docPermissions}\n globalSlug={globalConfig?.slug}\n hasPublishedDoc={hasPublishedDoc}\n hasPublishPermission={hasPublishPermission}\n hasSavePermission={hasSavePermission}\n id={id}\n initialData={doc}\n initialState={formState}\n isEditing={isEditing}\n isLocked={isLocked}\n isTrashed={isTrashedDoc}\n key={locale?.code}\n lastUpdateTime={lastUpdateTime}\n mostRecentVersionIsAutosaved={mostRecentVersionIsAutosaved}\n redirectAfterCreate={redirectAfterCreate}\n redirectAfterDelete={redirectAfterDelete}\n redirectAfterDuplicate={redirectAfterDuplicate}\n redirectAfterRestore={redirectAfterRestore}\n unpublishedVersionCount={unpublishedVersionCount}\n versionCount={versionCount}\n >\n <LivePreviewProvider\n breakpoints={livePreviewConfig?.breakpoints}\n isLivePreviewEnabled={isLivePreviewEnabled && operation !== 'create'}\n isLivePreviewing={entityPreferences?.value?.editViewType === 'live-preview'}\n url={livePreviewURL}\n >\n {showHeader && !drawerSlug && (\n <DocumentHeader\n collectionConfig={collectionConfig}\n globalConfig={globalConfig}\n permissions={permissions}\n req={req}\n />\n )}\n <HydrateAuthProvider permissions={permissions} />\n <EditDepthProvider>\n {RenderServerComponent({\n clientProps,\n Component: View,\n importMap,\n serverProps: documentViewServerProps,\n })}\n </EditDepthProvider>\n </LivePreviewProvider>\n </DocumentInfoProvider>\n ),\n }\n}\n\nexport async function Document(props: AdminViewServerProps) {\n try {\n const { Document: RenderedDocument } = await renderDocument(props)\n return RenderedDocument\n } catch (error) {\n if (error?.message === 'NEXT_REDIRECT') {\n throw error\n }\n\n logError({ err: error, payload: props.initPageResult.req.payload })\n\n if (error.message === 'not-found') {\n notFound()\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { ClientConfig, Column, ListQuery, PaginatedDocs, PayloadRequest, SanitizedCollectionConfig, Where } from 'payload';
|
|
2
|
-
export declare const handleGroupBy: ({ clientConfig, collectionConfig, collectionSlug, columns, customCellProps, drawerSlug, enableRowSelections, query, req, user, where: whereWithMergedSearch, }: {
|
|
2
|
+
export declare const handleGroupBy: ({ clientConfig, collectionConfig, collectionSlug, columns, customCellProps, drawerSlug, enableRowSelections, query, req, trash, user, where: whereWithMergedSearch, }: {
|
|
3
3
|
clientConfig: ClientConfig;
|
|
4
4
|
collectionConfig: SanitizedCollectionConfig;
|
|
5
5
|
collectionSlug: string;
|
|
@@ -9,6 +9,7 @@ export declare const handleGroupBy: ({ clientConfig, collectionConfig, collectio
|
|
|
9
9
|
enableRowSelections?: boolean;
|
|
10
10
|
query?: ListQuery;
|
|
11
11
|
req: PayloadRequest;
|
|
12
|
+
trash?: boolean;
|
|
12
13
|
user: any;
|
|
13
14
|
where: Where;
|
|
14
15
|
}) => Promise<{
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handleGroupBy.d.ts","sourceRoot":"","sources":["../../../src/views/List/handleGroupBy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,YAAY,EACZ,MAAM,EACN,SAAS,EACT,aAAa,EACb,cAAc,EACd,yBAAyB,EACzB,KAAK,EACN,MAAM,SAAS,CAAA;AAMhB,eAAO,MAAM,aAAa,
|
|
1
|
+
{"version":3,"file":"handleGroupBy.d.ts","sourceRoot":"","sources":["../../../src/views/List/handleGroupBy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,YAAY,EACZ,MAAM,EACN,SAAS,EACT,aAAa,EACb,cAAc,EACd,yBAAyB,EACzB,KAAK,EACN,MAAM,SAAS,CAAA;AAMhB,eAAO,MAAM,aAAa,0KAavB;IACD,YAAY,EAAE,YAAY,CAAA;IAC1B,gBAAgB,EAAE,yBAAyB,CAAA;IAC3C,cAAc,EAAE,MAAM,CAAA;IACtB,OAAO,EAAE,GAAG,EAAE,CAAA;IACd,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IACrC,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B,KAAK,CAAC,EAAE,SAAS,CAAA;IACjB,GAAG,EAAE,cAAc,CAAA;IACnB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,IAAI,EAAE,GAAG,CAAA;IACT,KAAK,EAAE,KAAK,CAAA;CACb,KAAG,OAAO,CAAC;IACV,WAAW,EAAE,MAAM,EAAE,CAAA;IACrB,IAAI,EAAE,aAAa,CAAA;IACnB,KAAK,EAAE,IAAI,GAAG,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,EAAE,CAAA;CAClD,CA+JA,CAAA"}
|
|
@@ -11,6 +11,7 @@ export const handleGroupBy = async ({
|
|
|
11
11
|
enableRowSelections,
|
|
12
12
|
query,
|
|
13
13
|
req,
|
|
14
|
+
trash = false,
|
|
14
15
|
user,
|
|
15
16
|
where: whereWithMergedSearch
|
|
16
17
|
}) => {
|
|
@@ -50,6 +51,7 @@ export const handleGroupBy = async ({
|
|
|
50
51
|
populate,
|
|
51
52
|
req,
|
|
52
53
|
sort: query?.groupBy,
|
|
54
|
+
trash,
|
|
53
55
|
where: whereWithMergedSearch
|
|
54
56
|
});
|
|
55
57
|
const data = {
|
|
@@ -74,6 +76,7 @@ export const handleGroupBy = async ({
|
|
|
74
76
|
// Note: if we wanted to enable table-by-table sorting, we could use this:
|
|
75
77
|
// sort: query?.queryByGroup?.[valueOrRelationshipID]?.sort,
|
|
76
78
|
sort: query?.sort,
|
|
79
|
+
trash,
|
|
77
80
|
user,
|
|
78
81
|
where: {
|
|
79
82
|
...(whereWithMergedSearch || {}),
|
|
@@ -83,7 +86,7 @@ export const handleGroupBy = async ({
|
|
|
83
86
|
}
|
|
84
87
|
});
|
|
85
88
|
let heading = valueOrRelationshipID || req.i18n.t('general:noValue');
|
|
86
|
-
if (groupByField?.type === 'relationship' && typeof potentiallyPopulatedRelationship === 'object') {
|
|
89
|
+
if (groupByField?.type === 'relationship' && potentiallyPopulatedRelationship && typeof potentiallyPopulatedRelationship === 'object') {
|
|
87
90
|
heading = potentiallyPopulatedRelationship[relationshipConfig.admin.useAsTitle || 'id'] || valueOrRelationshipID;
|
|
88
91
|
}
|
|
89
92
|
if (groupByField.type === 'date') {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handleGroupBy.js","names":["renderTable","formatDate","flattenAllFields","handleGroupBy","clientConfig","collectionConfig","collectionSlug","columns","customCellProps","drawerSlug","enableRowSelections","query","req","user","where","whereWithMergedSearch","Table","columnState","dataByGroup","clientCollectionConfig","collections","find","c","slug","flattenedFields","fields","groupByFieldPath","groupBy","replace","groupByField","f","name","relationshipConfig","type","relationTo","undefined","populate","Array","isArray","forEach","rel","admin","useAsTitle","distinct","payload","findDistinct","collection","depth","field","limit","Number","locale","overrideAccess","page","sort","data","docs","values","map","Promise","all","distinctValue","i","potentiallyPopulatedRelationship","valueOrRelationshipID","id","groupData","draft","fallbackLocale","includeLockStatus","queryByGroup","equals","heading","i18n","t","date","String","pattern","dateFormat","length","newColumnState","NewTable","groupByValue","key","orderableFieldName","orderable"],"sources":["../../../src/views/List/handleGroupBy.ts"],"sourcesContent":["import type {\n ClientConfig,\n Column,\n ListQuery,\n PaginatedDocs,\n PayloadRequest,\n SanitizedCollectionConfig,\n Where,\n} from 'payload'\n\nimport { renderTable } from '@payloadcms/ui/rsc'\nimport { formatDate } from '@payloadcms/ui/shared'\nimport { flattenAllFields } from 'payload'\n\nexport const handleGroupBy = async ({\n clientConfig,\n collectionConfig,\n collectionSlug,\n columns,\n customCellProps,\n drawerSlug,\n enableRowSelections,\n query,\n req,\n user,\n where: whereWithMergedSearch,\n}: {\n clientConfig: ClientConfig\n collectionConfig: SanitizedCollectionConfig\n collectionSlug: string\n columns: any[]\n customCellProps?: Record<string, any>\n drawerSlug?: string\n enableRowSelections?: boolean\n query?: ListQuery\n req: PayloadRequest\n user: any\n where: Where\n}): Promise<{\n columnState: Column[]\n data: PaginatedDocs\n Table: null | React.ReactNode | React.ReactNode[]\n}> => {\n let Table: React.ReactNode | React.ReactNode[] = null\n let columnState: Column[]\n\n const dataByGroup: Record<string, PaginatedDocs> = {}\n const clientCollectionConfig = clientConfig.collections.find((c) => c.slug === collectionSlug)\n\n // NOTE: is there a faster/better way to do this?\n const flattenedFields = flattenAllFields({ fields: collectionConfig.fields })\n\n const groupByFieldPath = query.groupBy.replace(/^-/, '')\n\n const groupByField = flattenedFields.find((f) => f.name === groupByFieldPath)\n\n const relationshipConfig =\n groupByField?.type === 'relationship'\n ? clientConfig.collections.find((c) => c.slug === groupByField.relationTo)\n : undefined\n\n let populate\n\n if (groupByField?.type === 'relationship' && groupByField.relationTo) {\n const relationTo =\n typeof groupByField.relationTo === 'string'\n ? [groupByField.relationTo]\n : groupByField.relationTo\n\n if (Array.isArray(relationTo)) {\n relationTo.forEach((rel) => {\n if (!populate) {\n populate = {}\n }\n populate[rel] = { [relationshipConfig?.admin.useAsTitle || 'id']: true }\n })\n }\n }\n\n const distinct = await req.payload.findDistinct({\n collection: collectionSlug,\n depth: 1,\n field: groupByFieldPath,\n limit: query?.limit ? Number(query.limit) : undefined,\n locale: req.locale,\n overrideAccess: false,\n page: query?.page ? Number(query.page) : undefined,\n populate,\n req,\n sort: query?.groupBy,\n where: whereWithMergedSearch,\n })\n\n const data = {\n ...distinct,\n docs: distinct.values?.map(() => ({})) || [],\n values: undefined,\n }\n\n await Promise.all(\n distinct.values.map(async (distinctValue, i) => {\n const potentiallyPopulatedRelationship = distinctValue[groupByFieldPath]\n\n const valueOrRelationshipID =\n groupByField?.type === 'relationship' &&\n potentiallyPopulatedRelationship &&\n typeof potentiallyPopulatedRelationship === 'object' &&\n 'id' in potentiallyPopulatedRelationship\n ? potentiallyPopulatedRelationship.id\n : potentiallyPopulatedRelationship\n\n const groupData = await req.payload.find({\n collection: collectionSlug,\n depth: 0,\n draft: true,\n fallbackLocale: false,\n includeLockStatus: true,\n limit: query?.queryByGroup?.[valueOrRelationshipID]?.limit\n ? Number(query.queryByGroup[valueOrRelationshipID].limit)\n : undefined,\n locale: req.locale,\n overrideAccess: false,\n page: query?.queryByGroup?.[valueOrRelationshipID]?.page\n ? Number(query.queryByGroup[valueOrRelationshipID].page)\n : undefined,\n req,\n // Note: if we wanted to enable table-by-table sorting, we could use this:\n // sort: query?.queryByGroup?.[valueOrRelationshipID]?.sort,\n sort: query?.sort,\n user,\n where: {\n ...(whereWithMergedSearch || {}),\n [groupByFieldPath]: {\n equals: valueOrRelationshipID,\n },\n },\n })\n\n let heading = valueOrRelationshipID || req.i18n.t('general:noValue')\n\n if (\n groupByField?.type === 'relationship' &&\n typeof potentiallyPopulatedRelationship === 'object'\n ) {\n heading =\n potentiallyPopulatedRelationship[relationshipConfig.admin.useAsTitle || 'id'] ||\n valueOrRelationshipID\n }\n\n if (groupByField.type === 'date') {\n heading = formatDate({\n date: String(heading),\n i18n: req.i18n,\n pattern: clientConfig.admin.dateFormat,\n })\n }\n\n if (groupData.docs && groupData.docs.length > 0) {\n const { columnState: newColumnState, Table: NewTable } = renderTable({\n clientCollectionConfig,\n collectionConfig,\n columns,\n customCellProps,\n data: groupData,\n drawerSlug,\n enableRowSelections,\n groupByFieldPath,\n groupByValue: valueOrRelationshipID,\n heading,\n i18n: req.i18n,\n key: `table-${valueOrRelationshipID}`,\n orderableFieldName: collectionConfig.orderable === true ? '_order' : undefined,\n payload: req.payload,\n query,\n useAsTitle: collectionConfig.admin.useAsTitle,\n })\n\n // Only need to set `columnState` once, using the first table's column state\n // This will avoid needing to generate column state explicitly for root context that wraps all tables\n if (!columnState) {\n columnState = newColumnState\n }\n\n if (!Table) {\n Table = []\n }\n\n dataByGroup[valueOrRelationshipID] = groupData\n ;(Table as Array<React.ReactNode>)[i] = NewTable\n }\n }),\n )\n\n return {\n columnState,\n data,\n Table,\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"handleGroupBy.js","names":["renderTable","formatDate","flattenAllFields","handleGroupBy","clientConfig","collectionConfig","collectionSlug","columns","customCellProps","drawerSlug","enableRowSelections","query","req","trash","user","where","whereWithMergedSearch","Table","columnState","dataByGroup","clientCollectionConfig","collections","find","c","slug","flattenedFields","fields","groupByFieldPath","groupBy","replace","groupByField","f","name","relationshipConfig","type","relationTo","undefined","populate","Array","isArray","forEach","rel","admin","useAsTitle","distinct","payload","findDistinct","collection","depth","field","limit","Number","locale","overrideAccess","page","sort","data","docs","values","map","Promise","all","distinctValue","i","potentiallyPopulatedRelationship","valueOrRelationshipID","id","groupData","draft","fallbackLocale","includeLockStatus","queryByGroup","equals","heading","i18n","t","date","String","pattern","dateFormat","length","newColumnState","NewTable","groupByValue","key","orderableFieldName","orderable"],"sources":["../../../src/views/List/handleGroupBy.ts"],"sourcesContent":["import type {\n ClientConfig,\n Column,\n ListQuery,\n PaginatedDocs,\n PayloadRequest,\n SanitizedCollectionConfig,\n Where,\n} from 'payload'\n\nimport { renderTable } from '@payloadcms/ui/rsc'\nimport { formatDate } from '@payloadcms/ui/shared'\nimport { flattenAllFields } from 'payload'\n\nexport const handleGroupBy = async ({\n clientConfig,\n collectionConfig,\n collectionSlug,\n columns,\n customCellProps,\n drawerSlug,\n enableRowSelections,\n query,\n req,\n trash = false,\n user,\n where: whereWithMergedSearch,\n}: {\n clientConfig: ClientConfig\n collectionConfig: SanitizedCollectionConfig\n collectionSlug: string\n columns: any[]\n customCellProps?: Record<string, any>\n drawerSlug?: string\n enableRowSelections?: boolean\n query?: ListQuery\n req: PayloadRequest\n trash?: boolean\n user: any\n where: Where\n}): Promise<{\n columnState: Column[]\n data: PaginatedDocs\n Table: null | React.ReactNode | React.ReactNode[]\n}> => {\n let Table: React.ReactNode | React.ReactNode[] = null\n let columnState: Column[]\n\n const dataByGroup: Record<string, PaginatedDocs> = {}\n const clientCollectionConfig = clientConfig.collections.find((c) => c.slug === collectionSlug)\n\n // NOTE: is there a faster/better way to do this?\n const flattenedFields = flattenAllFields({ fields: collectionConfig.fields })\n\n const groupByFieldPath = query.groupBy.replace(/^-/, '')\n\n const groupByField = flattenedFields.find((f) => f.name === groupByFieldPath)\n\n const relationshipConfig =\n groupByField?.type === 'relationship'\n ? clientConfig.collections.find((c) => c.slug === groupByField.relationTo)\n : undefined\n\n let populate\n\n if (groupByField?.type === 'relationship' && groupByField.relationTo) {\n const relationTo =\n typeof groupByField.relationTo === 'string'\n ? [groupByField.relationTo]\n : groupByField.relationTo\n\n if (Array.isArray(relationTo)) {\n relationTo.forEach((rel) => {\n if (!populate) {\n populate = {}\n }\n populate[rel] = { [relationshipConfig?.admin.useAsTitle || 'id']: true }\n })\n }\n }\n\n const distinct = await req.payload.findDistinct({\n collection: collectionSlug,\n depth: 1,\n field: groupByFieldPath,\n limit: query?.limit ? Number(query.limit) : undefined,\n locale: req.locale,\n overrideAccess: false,\n page: query?.page ? Number(query.page) : undefined,\n populate,\n req,\n sort: query?.groupBy,\n trash,\n where: whereWithMergedSearch,\n })\n\n const data = {\n ...distinct,\n docs: distinct.values?.map(() => ({})) || [],\n values: undefined,\n }\n\n await Promise.all(\n distinct.values.map(async (distinctValue, i) => {\n const potentiallyPopulatedRelationship = distinctValue[groupByFieldPath]\n\n const valueOrRelationshipID =\n groupByField?.type === 'relationship' &&\n potentiallyPopulatedRelationship &&\n typeof potentiallyPopulatedRelationship === 'object' &&\n 'id' in potentiallyPopulatedRelationship\n ? potentiallyPopulatedRelationship.id\n : potentiallyPopulatedRelationship\n\n const groupData = await req.payload.find({\n collection: collectionSlug,\n depth: 0,\n draft: true,\n fallbackLocale: false,\n includeLockStatus: true,\n limit: query?.queryByGroup?.[valueOrRelationshipID]?.limit\n ? Number(query.queryByGroup[valueOrRelationshipID].limit)\n : undefined,\n locale: req.locale,\n overrideAccess: false,\n page: query?.queryByGroup?.[valueOrRelationshipID]?.page\n ? Number(query.queryByGroup[valueOrRelationshipID].page)\n : undefined,\n req,\n // Note: if we wanted to enable table-by-table sorting, we could use this:\n // sort: query?.queryByGroup?.[valueOrRelationshipID]?.sort,\n sort: query?.sort,\n trash,\n user,\n where: {\n ...(whereWithMergedSearch || {}),\n [groupByFieldPath]: {\n equals: valueOrRelationshipID,\n },\n },\n })\n\n let heading = valueOrRelationshipID || req.i18n.t('general:noValue')\n\n if (\n groupByField?.type === 'relationship' &&\n potentiallyPopulatedRelationship &&\n typeof potentiallyPopulatedRelationship === 'object'\n ) {\n heading =\n potentiallyPopulatedRelationship[relationshipConfig.admin.useAsTitle || 'id'] ||\n valueOrRelationshipID\n }\n\n if (groupByField.type === 'date') {\n heading = formatDate({\n date: String(heading),\n i18n: req.i18n,\n pattern: clientConfig.admin.dateFormat,\n })\n }\n\n if (groupData.docs && groupData.docs.length > 0) {\n const { columnState: newColumnState, Table: NewTable } = renderTable({\n clientCollectionConfig,\n collectionConfig,\n columns,\n customCellProps,\n data: groupData,\n drawerSlug,\n enableRowSelections,\n groupByFieldPath,\n groupByValue: valueOrRelationshipID,\n heading,\n i18n: req.i18n,\n key: `table-${valueOrRelationshipID}`,\n orderableFieldName: collectionConfig.orderable === true ? '_order' : undefined,\n payload: req.payload,\n query,\n useAsTitle: collectionConfig.admin.useAsTitle,\n })\n\n // Only need to set `columnState` once, using the first table's column state\n // This will avoid needing to generate column state explicitly for root context that wraps all tables\n if (!columnState) {\n columnState = newColumnState\n }\n\n if (!Table) {\n Table = []\n }\n\n dataByGroup[valueOrRelationshipID] = groupData\n ;(Table as Array<React.ReactNode>)[i] = NewTable\n }\n }),\n )\n\n return {\n columnState,\n data,\n Table,\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/List/index.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/List/index.tsx"],"names":[],"mappings":"AAIA,OAAO,EACL,KAAK,oBAAoB,EAIzB,KAAK,SAAS,EAMf,MAAM,SAAS,CAAA;AAShB,OAAO,KAAmB,MAAM,OAAO,CAAA;AAOvC,KAAK,kBAAkB,GAAG;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IACrC,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,mBAAmB,EAAE,OAAO,CAAA;IAC5B,wBAAwB,CAAC,EAAE,OAAO,CAAA;IAClC,KAAK,EAAE,SAAS,CAAA;IAChB,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B,sBAAsB,CAAC,EAAE,OAAO,CAAA;CACjC,GAAG,oBAAoB,CAAA;AAExB;;;;;GAKG;AACH,eAAO,MAAM,cAAc,SACnB,kBAAkB,KACvB,OAAO,CAAC;IACT,IAAI,EAAE,KAAK,CAAC,SAAS,CAAA;CACtB,CA0TA,CAAA;AAED,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAWjD,CAAA"}
|
package/dist/views/List/index.js
CHANGED
|
@@ -91,20 +91,6 @@ export const renderListView = async args => {
|
|
|
91
91
|
sort: query.sort
|
|
92
92
|
});
|
|
93
93
|
}
|
|
94
|
-
let whereCondition = mergeListSearchAndWhere({
|
|
95
|
-
collectionConfig,
|
|
96
|
-
search: typeof query?.search === 'string' ? query.search : undefined,
|
|
97
|
-
where: combineWhereConstraints([query?.where, baseListFilter])
|
|
98
|
-
});
|
|
99
|
-
if (query?.trash === true) {
|
|
100
|
-
whereCondition = {
|
|
101
|
-
and: [whereCondition, {
|
|
102
|
-
deletedAt: {
|
|
103
|
-
exists: true
|
|
104
|
-
}
|
|
105
|
-
}]
|
|
106
|
-
};
|
|
107
|
-
}
|
|
108
94
|
let queryPreset;
|
|
109
95
|
let queryPresetPermissions;
|
|
110
96
|
let whereWithMergedSearch = mergeListSearchAndWhere({
|
|
@@ -144,62 +130,86 @@ export const renderListView = async args => {
|
|
|
144
130
|
req.payload.logger.error(`Error fetching query preset or preset permissions: ${err}`);
|
|
145
131
|
}
|
|
146
132
|
}
|
|
147
|
-
let data;
|
|
148
133
|
let Table = null;
|
|
149
134
|
let columnState = [];
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
135
|
+
let data = {
|
|
136
|
+
// no results default
|
|
137
|
+
docs: [],
|
|
138
|
+
hasNextPage: false,
|
|
139
|
+
hasPrevPage: false,
|
|
140
|
+
limit: query.limit,
|
|
141
|
+
nextPage: null,
|
|
142
|
+
page: 1,
|
|
143
|
+
pagingCounter: 0,
|
|
144
|
+
prevPage: null,
|
|
145
|
+
totalDocs: 0,
|
|
146
|
+
totalPages: 0
|
|
147
|
+
};
|
|
148
|
+
try {
|
|
149
|
+
if (collectionConfig.admin.groupBy && query.groupBy) {
|
|
150
|
+
({
|
|
151
|
+
columnState,
|
|
152
|
+
data,
|
|
153
|
+
Table
|
|
154
|
+
} = await handleGroupBy({
|
|
155
|
+
clientConfig,
|
|
156
|
+
collectionConfig,
|
|
157
|
+
collectionSlug,
|
|
158
|
+
columns: collectionPreferences?.columns,
|
|
159
|
+
customCellProps,
|
|
160
|
+
drawerSlug,
|
|
161
|
+
enableRowSelections,
|
|
162
|
+
query,
|
|
163
|
+
req,
|
|
164
|
+
trash: query?.trash === true,
|
|
165
|
+
user,
|
|
166
|
+
where: whereWithMergedSearch
|
|
167
|
+
}));
|
|
168
|
+
} else {
|
|
169
|
+
data = await req.payload.find({
|
|
170
|
+
collection: collectionSlug,
|
|
171
|
+
depth: 0,
|
|
172
|
+
draft: true,
|
|
173
|
+
fallbackLocale: false,
|
|
174
|
+
includeLockStatus: true,
|
|
175
|
+
limit: query?.limit ? Number(query.limit) : undefined,
|
|
176
|
+
locale: req.locale,
|
|
177
|
+
overrideAccess: false,
|
|
178
|
+
page: query?.page ? Number(query.page) : undefined,
|
|
179
|
+
req,
|
|
180
|
+
sort: query?.sort,
|
|
181
|
+
trash: query?.trash === true,
|
|
182
|
+
user,
|
|
183
|
+
where: whereWithMergedSearch
|
|
184
|
+
});
|
|
185
|
+
({
|
|
186
|
+
columnState,
|
|
187
|
+
Table
|
|
188
|
+
} = renderTable({
|
|
189
|
+
clientCollectionConfig: clientConfig.collections.find(c => c.slug === collectionSlug),
|
|
190
|
+
collectionConfig,
|
|
191
|
+
columns: collectionPreferences?.columns,
|
|
192
|
+
customCellProps,
|
|
193
|
+
data,
|
|
194
|
+
drawerSlug,
|
|
195
|
+
enableRowSelections,
|
|
196
|
+
i18n: req.i18n,
|
|
197
|
+
orderableFieldName: collectionConfig.orderable === true ? '_order' : undefined,
|
|
198
|
+
payload: req.payload,
|
|
199
|
+
query,
|
|
200
|
+
useAsTitle: collectionConfig.admin.useAsTitle,
|
|
201
|
+
viewType
|
|
202
|
+
}));
|
|
203
|
+
}
|
|
204
|
+
} catch (err) {
|
|
205
|
+
if (err.name !== 'QueryError') {
|
|
206
|
+
// QueryErrors are expected when a user filters by a field they do not have access to
|
|
207
|
+
req.payload.logger.error({
|
|
208
|
+
err,
|
|
209
|
+
msg: `There was an error fetching the list view data for collection ${collectionSlug}`
|
|
210
|
+
});
|
|
211
|
+
throw err;
|
|
212
|
+
}
|
|
203
213
|
}
|
|
204
214
|
const renderedFilters = renderFilters(collectionConfig.fields, req.payload.importMap);
|
|
205
215
|
const resolvedFilterOptions = await resolveAllFilterOptions({
|