@payloadcms/next 3.0.0-alpha.17 → 3.0.0-alpha.18

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.
@@ -1 +1 @@
1
- {"version":3,"file":"getViewsFromConfig.d.ts","sourceRoot":"","sources":["../../../src/views/Document/getViewsFromConfig.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AAChF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AACvD,OAAO,KAAK,EACV,yBAAyB,EACzB,eAAe,EACf,qBAAqB,EACtB,MAAM,eAAe,CAAA;AAYtB,eAAO,MAAM,kBAAkB;uBAQV,yBAAyB;YACpC,eAAe;oBACP,oBAAoB,GAAG,gBAAgB;mBACxC,qBAAqB;mBACrB,MAAM,EAAE;UACjB,IAAI;;gBAEE,iBAAiB;iBAChB,iBAAiB;EA6J/B,CAAA"}
1
+ {"version":3,"file":"getViewsFromConfig.d.ts","sourceRoot":"","sources":["../../../src/views/Document/getViewsFromConfig.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,IAAI,EAAE,MAAM,cAAc,CAAA;AAChF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AACvD,OAAO,KAAK,EACV,yBAAyB,EACzB,eAAe,EACf,qBAAqB,EACtB,MAAM,eAAe,CAAA;AAYtB,eAAO,MAAM,kBAAkB;uBAQV,yBAAyB;YACpC,eAAe;oBACP,oBAAoB,GAAG,gBAAgB;mBACxC,qBAAqB;mBACrB,MAAM,EAAE;UACjB,IAAI;;gBAEE,iBAAiB;iBAChB,iBAAiB;EAgK/B,CAAA"}
@@ -10,10 +10,10 @@ export const getViewsFromConfig = async ({ collectionConfig, config, docPermissi
10
10
  // Conditionally import and lazy load the default view
11
11
  let DefaultView = null;
12
12
  let CustomView = null;
13
- const [entityType, entitySlug, createOrID, tabViewName, segmentFive] = routeSegments;
14
13
  const views = collectionConfig && collectionConfig?.admin?.components?.views || globalConfig && globalConfig?.admin?.components?.views;
15
14
  const livePreviewEnabled = collectionConfig && collectionConfig?.admin?.livePreview || config?.admin?.livePreview?.collections?.includes(collectionConfig?.slug) || globalConfig && globalConfig?.admin?.livePreview || config?.admin?.livePreview?.globals?.includes(globalConfig?.slug);
16
15
  if (collectionConfig) {
16
+ const [collectionEntity, collectionSlug, createOrID, nestedViewSlug, segmentFive] = routeSegments;
17
17
  const { admin: { hidden } } = collectionConfig;
18
18
  if (isEntityHidden({
19
19
  hidden,
@@ -22,7 +22,7 @@ export const getViewsFromConfig = async ({ collectionConfig, config, docPermissi
22
22
  return null;
23
23
  }
24
24
  // `../:id`, or `../create`
25
- if (!tabViewName) {
25
+ if (!nestedViewSlug) {
26
26
  switch(createOrID){
27
27
  case 'create':
28
28
  {
@@ -41,10 +41,10 @@ export const getViewsFromConfig = async ({ collectionConfig, config, docPermissi
41
41
  }
42
42
  }
43
43
  }
44
- if (tabViewName) {
44
+ if (nestedViewSlug) {
45
45
  // `../:id/versions/:version`, etc
46
46
  if (segmentFive) {
47
- if (tabViewName === 'versions') {
47
+ if (nestedViewSlug === 'versions') {
48
48
  if (docPermissions?.readVersions?.permission) {
49
49
  CustomView = getCustomViewByKey(views, 'Version');
50
50
  DefaultView = DefaultVersionView;
@@ -53,7 +53,7 @@ export const getViewsFromConfig = async ({ collectionConfig, config, docPermissi
53
53
  }
54
54
  // `../:id/api`, `../:id/preview`, `../:id/versions`, etc
55
55
  if (routeSegments?.length === 4) {
56
- switch(tabViewName){
56
+ switch(nestedViewSlug){
57
57
  case 'api':
58
58
  {
59
59
  if (collectionConfig?.admin?.hideAPIURL !== true) {
@@ -79,7 +79,7 @@ export const getViewsFromConfig = async ({ collectionConfig, config, docPermissi
79
79
  }
80
80
  default:
81
81
  {
82
- const path = `/${tabViewName}`;
82
+ const path = `/${nestedViewSlug}`;
83
83
  CustomView = getCustomViewByPath(views, path);
84
84
  break;
85
85
  }
@@ -88,6 +88,7 @@ export const getViewsFromConfig = async ({ collectionConfig, config, docPermissi
88
88
  }
89
89
  }
90
90
  if (globalConfig) {
91
+ const [globalEntity, globalSlug, nestedViewSlug] = routeSegments;
91
92
  const { admin: { hidden } } = globalConfig;
92
93
  if (isEntityHidden({
93
94
  hidden,
@@ -95,14 +96,14 @@ export const getViewsFromConfig = async ({ collectionConfig, config, docPermissi
95
96
  })) {
96
97
  return null;
97
98
  }
98
- if (!routeSegments?.length) {
99
+ if (routeSegments?.length === 2) {
99
100
  if (docPermissions?.read?.permission) {
100
101
  CustomView = getCustomViewByKey(views, 'Default');
101
102
  DefaultView = DefaultEditView;
102
103
  }
103
- } else if (routeSegments?.length === 1) {
104
+ } else if (routeSegments?.length === 3) {
104
105
  // `../:slug/api`, `../:slug/preview`, `../:slug/versions`, etc
105
- switch(tabViewName){
106
+ switch(nestedViewSlug){
106
107
  case 'api':
107
108
  {
108
109
  if (globalConfig?.admin?.hideAPIURL !== true) {
@@ -137,7 +138,7 @@ export const getViewsFromConfig = async ({ collectionConfig, config, docPermissi
137
138
  }
138
139
  } else if (routeSegments?.length === 2) {
139
140
  // `../:slug/versions/:version`, etc
140
- if (tabViewName === 'versions') {
141
+ if (nestedViewSlug === 'versions') {
141
142
  if (docPermissions?.readVersions?.permission) {
142
143
  CustomView = getCustomViewByKey(views, 'Version');
143
144
  DefaultView = DefaultVersionView;
@@ -151,4 +152,4 @@ export const getViewsFromConfig = async ({ collectionConfig, config, docPermissi
151
152
  };
152
153
  };
153
154
 
154
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/views/Document/getViewsFromConfig.tsx"],"sourcesContent":["import type { CollectionPermission, GlobalPermission, User } from 'payload/auth'\nimport type { EditViewComponent } from 'payload/config'\nimport type {\n  SanitizedCollectionConfig,\n  SanitizedConfig,\n  SanitizedGlobalConfig,\n} from 'payload/types'\n\nimport { isEntityHidden } from 'payload/utilities'\n\nimport { APIView as DefaultAPIView } from '../API'\nimport { EditView as DefaultEditView } from '../Edit'\nimport { LivePreviewView as DefaultLivePreviewView } from '../LivePreview'\nimport { VersionView as DefaultVersionView } from '../Version'\nimport { VersionsView as DefaultVersionsView } from '../Versions'\nimport { getCustomViewByKey } from './getCustomViewByKey'\nimport { getCustomViewByPath } from './getCustomViewByPath'\n\nexport const getViewsFromConfig = async ({\n  collectionConfig,\n  config,\n  docPermissions,\n  globalConfig,\n  routeSegments,\n  user,\n}: {\n  collectionConfig?: SanitizedCollectionConfig\n  config: SanitizedConfig\n  docPermissions: CollectionPermission | GlobalPermission\n  globalConfig?: SanitizedGlobalConfig\n  routeSegments: string[]\n  user: User\n}): Promise<{\n  CustomView: EditViewComponent\n  DefaultView: EditViewComponent\n} | null> => {\n  // Conditionally import and lazy load the default view\n  let DefaultView: EditViewComponent = null\n  let CustomView: EditViewComponent = null\n\n  const [entityType, entitySlug, createOrID, tabViewName, segmentFive] = routeSegments\n\n  const views =\n    (collectionConfig && collectionConfig?.admin?.components?.views) ||\n    (globalConfig && globalConfig?.admin?.components?.views)\n\n  const livePreviewEnabled =\n    (collectionConfig && collectionConfig?.admin?.livePreview) ||\n    config?.admin?.livePreview?.collections?.includes(collectionConfig?.slug) ||\n    (globalConfig && globalConfig?.admin?.livePreview) ||\n    config?.admin?.livePreview?.globals?.includes(globalConfig?.slug)\n\n  if (collectionConfig) {\n    const {\n      admin: { hidden },\n    } = collectionConfig\n\n    if (isEntityHidden({ hidden, user })) {\n      return null\n    }\n\n    // `../:id`, or `../create`\n    if (!tabViewName) {\n      switch (createOrID) {\n        case 'create': {\n          if ('create' in docPermissions && docPermissions?.create?.permission) {\n            CustomView = getCustomViewByKey(views, 'Default')\n            DefaultView = DefaultEditView\n          }\n          break\n        }\n\n        default: {\n          if (docPermissions?.read?.permission) {\n            CustomView = getCustomViewByKey(views, 'Default')\n            DefaultView = DefaultEditView\n          }\n        }\n      }\n    }\n\n    if (tabViewName) {\n      // `../:id/versions/:version`, etc\n      if (segmentFive) {\n        if (tabViewName === 'versions') {\n          if (docPermissions?.readVersions?.permission) {\n            CustomView = getCustomViewByKey(views, 'Version')\n            DefaultView = DefaultVersionView\n          }\n        }\n      }\n\n      // `../:id/api`, `../:id/preview`, `../:id/versions`, etc\n      if (routeSegments?.length === 4) {\n        switch (tabViewName) {\n          case 'api': {\n            if (collectionConfig?.admin?.hideAPIURL !== true) {\n              CustomView = getCustomViewByKey(views, 'API')\n              DefaultView = DefaultAPIView\n            }\n            break\n          }\n\n          case 'preview': {\n            if (livePreviewEnabled) {\n              DefaultView = DefaultLivePreviewView\n            }\n            break\n          }\n\n          case 'versions': {\n            if (docPermissions?.readVersions?.permission) {\n              CustomView = getCustomViewByKey(views, 'Versions')\n              DefaultView = DefaultVersionsView\n            }\n            break\n          }\n\n          default: {\n            const path = `/${tabViewName}`\n            CustomView = getCustomViewByPath(views, path)\n            break\n          }\n        }\n      }\n    }\n  }\n\n  if (globalConfig) {\n    const {\n      admin: { hidden },\n    } = globalConfig\n\n    if (isEntityHidden({ hidden, user })) {\n      return null\n    }\n\n    if (!routeSegments?.length) {\n      if (docPermissions?.read?.permission) {\n        CustomView = getCustomViewByKey(views, 'Default')\n        DefaultView = DefaultEditView\n      }\n    } else if (routeSegments?.length === 1) {\n      // `../:slug/api`, `../:slug/preview`, `../:slug/versions`, etc\n      switch (tabViewName) {\n        case 'api': {\n          if (globalConfig?.admin?.hideAPIURL !== true) {\n            CustomView = getCustomViewByKey(views, 'API')\n            DefaultView = DefaultAPIView\n          }\n          break\n        }\n\n        case 'preview': {\n          if (livePreviewEnabled) {\n            DefaultView = DefaultLivePreviewView\n          }\n          break\n        }\n\n        case 'versions': {\n          if (docPermissions?.readVersions?.permission) {\n            CustomView = getCustomViewByKey(views, 'Versions')\n            DefaultView = DefaultVersionsView\n          }\n          break\n        }\n\n        default: {\n          if (docPermissions?.read?.permission) {\n            CustomView = getCustomViewByKey(views, 'Default')\n            DefaultView = DefaultEditView\n          }\n          break\n        }\n      }\n    } else if (routeSegments?.length === 2) {\n      // `../:slug/versions/:version`, etc\n      if (tabViewName === 'versions') {\n        if (docPermissions?.readVersions?.permission) {\n          CustomView = getCustomViewByKey(views, 'Version')\n          DefaultView = DefaultVersionView\n        }\n      }\n    }\n  }\n\n  return {\n    CustomView,\n    DefaultView,\n  }\n}\n"],"names":["isEntityHidden","APIView","DefaultAPIView","EditView","DefaultEditView","LivePreviewView","DefaultLivePreviewView","VersionView","DefaultVersionView","VersionsView","DefaultVersionsView","getCustomViewByKey","getCustomViewByPath","getViewsFromConfig","collectionConfig","config","docPermissions","globalConfig","routeSegments","user","DefaultView","CustomView","entityType","entitySlug","createOrID","tabViewName","segmentFive","views","admin","components","livePreviewEnabled","livePreview","collections","includes","slug","globals","hidden","create","permission","read","readVersions","length","hideAPIURL","path"],"mappings":"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"}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/views/Document/getViewsFromConfig.tsx"],"sourcesContent":["import type { CollectionPermission, GlobalPermission, User } from 'payload/auth'\nimport type { EditViewComponent } from 'payload/config'\nimport type {\n  SanitizedCollectionConfig,\n  SanitizedConfig,\n  SanitizedGlobalConfig,\n} from 'payload/types'\n\nimport { isEntityHidden } from 'payload/utilities'\n\nimport { APIView as DefaultAPIView } from '../API'\nimport { EditView as DefaultEditView } from '../Edit'\nimport { LivePreviewView as DefaultLivePreviewView } from '../LivePreview'\nimport { VersionView as DefaultVersionView } from '../Version'\nimport { VersionsView as DefaultVersionsView } from '../Versions'\nimport { getCustomViewByKey } from './getCustomViewByKey'\nimport { getCustomViewByPath } from './getCustomViewByPath'\n\nexport const getViewsFromConfig = async ({\n  collectionConfig,\n  config,\n  docPermissions,\n  globalConfig,\n  routeSegments,\n  user,\n}: {\n  collectionConfig?: SanitizedCollectionConfig\n  config: SanitizedConfig\n  docPermissions: CollectionPermission | GlobalPermission\n  globalConfig?: SanitizedGlobalConfig\n  routeSegments: string[]\n  user: User\n}): Promise<{\n  CustomView: EditViewComponent\n  DefaultView: EditViewComponent\n} | null> => {\n  // Conditionally import and lazy load the default view\n  let DefaultView: EditViewComponent = null\n  let CustomView: EditViewComponent = null\n\n  const views =\n    (collectionConfig && collectionConfig?.admin?.components?.views) ||\n    (globalConfig && globalConfig?.admin?.components?.views)\n\n  const livePreviewEnabled =\n    (collectionConfig && collectionConfig?.admin?.livePreview) ||\n    config?.admin?.livePreview?.collections?.includes(collectionConfig?.slug) ||\n    (globalConfig && globalConfig?.admin?.livePreview) ||\n    config?.admin?.livePreview?.globals?.includes(globalConfig?.slug)\n\n  if (collectionConfig) {\n    const [collectionEntity, collectionSlug, createOrID, nestedViewSlug, segmentFive] =\n      routeSegments\n\n    const {\n      admin: { hidden },\n    } = collectionConfig\n\n    if (isEntityHidden({ hidden, user })) {\n      return null\n    }\n\n    // `../:id`, or `../create`\n    if (!nestedViewSlug) {\n      switch (createOrID) {\n        case 'create': {\n          if ('create' in docPermissions && docPermissions?.create?.permission) {\n            CustomView = getCustomViewByKey(views, 'Default')\n            DefaultView = DefaultEditView\n          }\n          break\n        }\n\n        default: {\n          if (docPermissions?.read?.permission) {\n            CustomView = getCustomViewByKey(views, 'Default')\n            DefaultView = DefaultEditView\n          }\n        }\n      }\n    }\n\n    if (nestedViewSlug) {\n      // `../:id/versions/:version`, etc\n      if (segmentFive) {\n        if (nestedViewSlug === 'versions') {\n          if (docPermissions?.readVersions?.permission) {\n            CustomView = getCustomViewByKey(views, 'Version')\n            DefaultView = DefaultVersionView\n          }\n        }\n      }\n\n      // `../:id/api`, `../:id/preview`, `../:id/versions`, etc\n      if (routeSegments?.length === 4) {\n        switch (nestedViewSlug) {\n          case 'api': {\n            if (collectionConfig?.admin?.hideAPIURL !== true) {\n              CustomView = getCustomViewByKey(views, 'API')\n              DefaultView = DefaultAPIView\n            }\n            break\n          }\n\n          case 'preview': {\n            if (livePreviewEnabled) {\n              DefaultView = DefaultLivePreviewView\n            }\n            break\n          }\n\n          case 'versions': {\n            if (docPermissions?.readVersions?.permission) {\n              CustomView = getCustomViewByKey(views, 'Versions')\n              DefaultView = DefaultVersionsView\n            }\n            break\n          }\n\n          default: {\n            const path = `/${nestedViewSlug}`\n            CustomView = getCustomViewByPath(views, path)\n            break\n          }\n        }\n      }\n    }\n  }\n\n  if (globalConfig) {\n    const [globalEntity, globalSlug, nestedViewSlug] = routeSegments\n\n    const {\n      admin: { hidden },\n    } = globalConfig\n\n    if (isEntityHidden({ hidden, user })) {\n      return null\n    }\n\n    if (routeSegments?.length === 2) {\n      if (docPermissions?.read?.permission) {\n        CustomView = getCustomViewByKey(views, 'Default')\n        DefaultView = DefaultEditView\n      }\n    } else if (routeSegments?.length === 3) {\n      // `../:slug/api`, `../:slug/preview`, `../:slug/versions`, etc\n      switch (nestedViewSlug) {\n        case 'api': {\n          if (globalConfig?.admin?.hideAPIURL !== true) {\n            CustomView = getCustomViewByKey(views, 'API')\n            DefaultView = DefaultAPIView\n          }\n          break\n        }\n\n        case 'preview': {\n          if (livePreviewEnabled) {\n            DefaultView = DefaultLivePreviewView\n          }\n          break\n        }\n\n        case 'versions': {\n          if (docPermissions?.readVersions?.permission) {\n            CustomView = getCustomViewByKey(views, 'Versions')\n            DefaultView = DefaultVersionsView\n          }\n          break\n        }\n\n        default: {\n          if (docPermissions?.read?.permission) {\n            CustomView = getCustomViewByKey(views, 'Default')\n            DefaultView = DefaultEditView\n          }\n          break\n        }\n      }\n    } else if (routeSegments?.length === 2) {\n      // `../:slug/versions/:version`, etc\n      if (nestedViewSlug === 'versions') {\n        if (docPermissions?.readVersions?.permission) {\n          CustomView = getCustomViewByKey(views, 'Version')\n          DefaultView = DefaultVersionView\n        }\n      }\n    }\n  }\n\n  return {\n    CustomView,\n    DefaultView,\n  }\n}\n"],"names":["isEntityHidden","APIView","DefaultAPIView","EditView","DefaultEditView","LivePreviewView","DefaultLivePreviewView","VersionView","DefaultVersionView","VersionsView","DefaultVersionsView","getCustomViewByKey","getCustomViewByPath","getViewsFromConfig","collectionConfig","config","docPermissions","globalConfig","routeSegments","user","DefaultView","CustomView","views","admin","components","livePreviewEnabled","livePreview","collections","includes","slug","globals","collectionEntity","collectionSlug","createOrID","nestedViewSlug","segmentFive","hidden","create","permission","read","readVersions","length","hideAPIURL","path","globalEntity","globalSlug"],"mappings":"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"}
@@ -10,7 +10,7 @@ export const Document = async ({ initPageResult, params, searchParams })=>{
10
10
  const segments = Array.isArray(params?.segments) ? params.segments : [];
11
11
  const [entityType, entitySlug, createOrID] = segments;
12
12
  const collectionSlug = entityType === 'collections' ? entitySlug : undefined;
13
- const globalSlug = entitySlug === 'globals' ? entitySlug : undefined;
13
+ const globalSlug = entityType === 'globals' ? entitySlug : undefined;
14
14
  const isCreating = createOrID === 'create';
15
15
  const id = collectionSlug && !isCreating && createOrID || undefined;
16
16
  const isEditing = Boolean(globalSlug || collectionSlug && !!id);
@@ -157,4 +157,4 @@ export const Document = async ({ initPageResult, params, searchParams })=>{
157
157
  }))));
158
158
  };
159
159
 
160
- //# 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  SanitizedConfig,\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    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 [entityType, entitySlug, createOrID] = segments\n  const collectionSlug = entityType === 'collections' ? entitySlug : undefined\n  const globalSlug = entitySlug === 'globals' ? entitySlug : undefined\n  const isCreating = createOrID === 'create'\n  const id = (collectionSlug && !isCreating && createOrID) || 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 componentProps: ServerSideEditViewProps = {\n    id,\n    action: `${action}?${queryString.stringify(formQueryParams)}`,\n    apiURL,\n    canAccessAdmin: permissions?.canAccessAdmin,\n    collectionSlug,\n    data,\n    docPermissions,\n    docPreferences,\n    globalSlug,\n    hasSavePermission,\n    initPageResult,\n    initialState,\n    isEditing,\n    params,\n    searchParams,\n    updatedAt: data?.updatedAt?.toString(),\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={componentProps}\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","globalConfig","locale","permissions","req","i18n","payload","config","routes","api","apiRoute","serverURL","user","segments","Array","isArray","entityType","entitySlug","createOrID","collectionSlug","undefined","globalSlug","isCreating","id","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","slug","docs","value","docPreferences","find","limit","where","key","equals","initialState","fieldSchema","operation","preferences","formQueryParams","uploadEdits","componentProps","stringify","canAccessAdmin","updatedAt","toString","disableActions","initialData","CustomComponent","DefaultComponent"],"mappings":"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"}
160
+ //# 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  SanitizedConfig,\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    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 [entityType, entitySlug, createOrID] = segments\n  const collectionSlug = entityType === 'collections' ? entitySlug : undefined\n  const globalSlug = entityType === 'globals' ? entitySlug : undefined\n  const isCreating = createOrID === 'create'\n  const id = (collectionSlug && !isCreating && createOrID) || 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 componentProps: ServerSideEditViewProps = {\n    id,\n    action: `${action}?${queryString.stringify(formQueryParams)}`,\n    apiURL,\n    canAccessAdmin: permissions?.canAccessAdmin,\n    collectionSlug,\n    data,\n    docPermissions,\n    docPreferences,\n    globalSlug,\n    hasSavePermission,\n    initPageResult,\n    initialState,\n    isEditing,\n    params,\n    searchParams,\n    updatedAt: data?.updatedAt?.toString(),\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={componentProps}\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","globalConfig","locale","permissions","req","i18n","payload","config","routes","api","apiRoute","serverURL","user","segments","Array","isArray","entityType","entitySlug","createOrID","collectionSlug","undefined","globalSlug","isCreating","id","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","slug","docs","value","docPreferences","find","limit","where","key","equals","initialState","fieldSchema","operation","preferences","formQueryParams","uploadEdits","componentProps","stringify","canAccessAdmin","updatedAt","toString","disableActions","initialData","CustomComponent","DefaultComponent"],"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.17",
3
+ "version": "3.0.0-alpha.18",
4
4
  "main": "./dist/exports/index.js",
5
5
  "types": "./dist/exports/index.d.ts",
6
6
  "bin": {
@@ -61,8 +61,8 @@
61
61
  "url-loader": "^4.1.1",
62
62
  "webpack": "^5.78.0",
63
63
  "webpack-cli": "^5.1.4",
64
- "@payloadcms/eslint-config": "1.1.1",
65
- "payload": "3.0.0-alpha.17"
64
+ "payload": "3.0.0-alpha.18",
65
+ "@payloadcms/eslint-config": "1.1.1"
66
66
  },
67
67
  "dependencies": {
68
68
  "@dnd-kit/core": "6.0.8",
@@ -77,14 +77,14 @@
77
77
  "react-toastify": "8.2.0",
78
78
  "sass": "^1.71.1",
79
79
  "ws": "^8.16.0",
80
- "@payloadcms/graphql": "3.0.0-alpha.17",
81
- "@payloadcms/ui": "3.0.0-alpha.17",
82
- "@payloadcms/translations": "3.0.0-alpha.17"
80
+ "@payloadcms/graphql": "3.0.0-alpha.18",
81
+ "@payloadcms/translations": "3.0.0-alpha.18",
82
+ "@payloadcms/ui": "3.0.0-alpha.18"
83
83
  },
84
84
  "peerDependencies": {
85
85
  "http-status": "1.6.2",
86
86
  "next": "14.1.1-canary.26",
87
- "payload": "3.0.0-alpha.17"
87
+ "payload": "3.0.0-alpha.18"
88
88
  },
89
89
  "publishConfig": {
90
90
  "registry": "https://registry.npmjs.org/"