@payloadcms/next 3.0.0-beta.80 → 3.0.0-beta.82

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,EACV,cAAc,EACd,oBAAoB,EACpB,gBAAgB,EAChB,gBAAgB,EAChB,yBAAyB,EACzB,eAAe,EACf,qBAAqB,EACrB,uBAAuB,EACxB,MAAM,SAAS,CAAA;AAChB,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAa9B,MAAM,MAAM,cAAc,CAAC,MAAM,SAAS,MAAM,IAAI;IAClD,SAAS,CAAC,EAAE,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,CAAA;IAC5B,gBAAgB,CAAC,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAA;CAC5C,CAAA;AAED,eAAO,MAAM,kBAAkB,+EAM5B;IACD,gBAAgB,CAAC,EAAE,yBAAyB,CAAA;IAC5C,MAAM,EAAE,eAAe,CAAA;IACvB,cAAc,EAAE,oBAAoB,GAAG,gBAAgB,CAAA;IACvD,YAAY,CAAC,EAAE,qBAAqB,CAAA;IACpC,aAAa,EAAE,MAAM,EAAE,CAAA;CACxB,KAAG;IACF,UAAU,EAAE,cAAc,CAAC,uBAAuB,CAAC,CAAA;IACnD,WAAW,EAAE,cAAc,CAAC,uBAAuB,CAAC,CAAA;IACpD;;OAEG;IACH,SAAS,EAAE,cAAc,CAAC,cAAc,CAAC,CAAA;CAC1C,GAAG,IA+TH,CAAA"}
1
+ {"version":3,"file":"getViewsFromConfig.d.ts","sourceRoot":"","sources":["../../../src/views/Document/getViewsFromConfig.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,cAAc,EACd,oBAAoB,EACpB,gBAAgB,EAChB,gBAAgB,EAChB,yBAAyB,EACzB,eAAe,EACf,qBAAqB,EACrB,uBAAuB,EACxB,MAAM,SAAS,CAAA;AAChB,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAa9B,MAAM,MAAM,cAAc,CAAC,MAAM,SAAS,MAAM,IAAI;IAClD,SAAS,CAAC,EAAE,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,CAAA;IAC5B,gBAAgB,CAAC,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAA;CAC5C,CAAA;AAED,eAAO,MAAM,kBAAkB,+EAM5B;IACD,gBAAgB,CAAC,EAAE,yBAAyB,CAAA;IAC5C,MAAM,EAAE,eAAe,CAAA;IACvB,cAAc,EAAE,oBAAoB,GAAG,gBAAgB,CAAA;IACvD,YAAY,CAAC,EAAE,qBAAqB,CAAA;IACpC,aAAa,EAAE,MAAM,EAAE,CAAA;CACxB,KAAG;IACF,UAAU,EAAE,cAAc,CAAC,uBAAuB,CAAC,CAAA;IACnD,WAAW,EAAE,cAAc,CAAC,uBAAuB,CAAC,CAAA;IACpD;;OAEG;IACH,SAAS,EAAE,cAAc,CAAC,cAAc,CAAC,CAAA;CAC1C,GAAG,IA6SH,CAAA"}
@@ -16,295 +16,281 @@ export const getViewsFromConfig = ({ collectionConfig, config, docPermissions, g
16
16
  const views = collectionConfig && collectionConfig?.admin?.components?.views || globalConfig && globalConfig?.admin?.components?.views;
17
17
  const livePreviewEnabled = collectionConfig && collectionConfig?.admin?.livePreview || config?.admin?.livePreview?.collections?.includes(collectionConfig?.slug) || globalConfig && globalConfig?.admin?.livePreview || config?.admin?.livePreview?.globals?.includes(globalConfig?.slug);
18
18
  if (collectionConfig) {
19
- const editConfig = collectionConfig?.admin?.components?.views?.edit;
20
- const EditOverride = typeof editConfig === 'function' ? editConfig : null;
21
- if (EditOverride) {
22
- CustomView = EditOverride;
23
- }
24
- if (!EditOverride) {
25
- const [collectionEntity, collectionSlug, segment3, segment4, segment5, ...remainingSegments] = routeSegments;
26
- if (!docPermissions?.read?.permission) {
27
- notFound();
28
- } else {
29
- // `../:id`, or `../create`
30
- switch(routeSegments.length){
31
- case 3:
32
- {
33
- switch(segment3){
34
- case 'create':
35
- {
36
- if ('create' in docPermissions && docPermissions?.create?.permission) {
37
- CustomView = {
38
- payloadComponent: getCustomViewByKey(views, 'default')
39
- };
40
- DefaultView = {
41
- Component: DefaultEditView
42
- };
43
- } else {
44
- ErrorView = {
45
- Component: UnauthorizedView
46
- };
47
- }
48
- break;
49
- }
50
- default:
51
- {
19
+ const [collectionEntity, collectionSlug, segment3, segment4, segment5, ...remainingSegments] = routeSegments;
20
+ if (!docPermissions?.read?.permission) {
21
+ notFound();
22
+ } else {
23
+ // `../:id`, or `../create`
24
+ switch(routeSegments.length){
25
+ case 3:
26
+ {
27
+ switch(segment3){
28
+ case 'create':
29
+ {
30
+ if ('create' in docPermissions && docPermissions?.create?.permission) {
52
31
  CustomView = {
53
32
  payloadComponent: getCustomViewByKey(views, 'default')
54
33
  };
55
34
  DefaultView = {
56
35
  Component: DefaultEditView
57
36
  };
58
- break;
37
+ } else {
38
+ ErrorView = {
39
+ Component: UnauthorizedView
40
+ };
59
41
  }
60
- }
61
- break;
42
+ break;
43
+ }
44
+ default:
45
+ {
46
+ CustomView = {
47
+ payloadComponent: getCustomViewByKey(views, 'default')
48
+ };
49
+ DefaultView = {
50
+ Component: DefaultEditView
51
+ };
52
+ break;
53
+ }
62
54
  }
63
- // `../:id/api`, `../:id/preview`, `../:id/versions`, etc
64
- case 4:
65
- {
66
- switch(segment4){
67
- case 'api':
68
- {
69
- if (collectionConfig?.admin?.hideAPIURL !== true) {
70
- CustomView = {
71
- payloadComponent: getCustomViewByKey(views, 'api')
72
- };
73
- DefaultView = {
74
- Component: DefaultAPIView
75
- };
76
- }
77
- break;
78
- }
79
- case 'preview':
80
- {
81
- if (livePreviewEnabled) {
82
- DefaultView = {
83
- Component: DefaultLivePreviewView
84
- };
85
- }
86
- break;
55
+ break;
56
+ }
57
+ // `../:id/api`, `../:id/preview`, `../:id/versions`, etc
58
+ case 4:
59
+ {
60
+ switch(segment4){
61
+ case 'api':
62
+ {
63
+ if (collectionConfig?.admin?.hideAPIURL !== true) {
64
+ CustomView = {
65
+ payloadComponent: getCustomViewByKey(views, 'api')
66
+ };
67
+ DefaultView = {
68
+ Component: DefaultAPIView
69
+ };
87
70
  }
88
- case 'versions':
89
- {
90
- if (docPermissions?.readVersions?.permission) {
91
- CustomView = {
92
- payloadComponent: getCustomViewByKey(views, 'versions')
93
- };
94
- DefaultView = {
95
- Component: DefaultVersionsView
96
- };
97
- } else {
98
- ErrorView = {
99
- Component: UnauthorizedView
100
- };
101
- }
102
- break;
71
+ break;
72
+ }
73
+ case 'preview':
74
+ {
75
+ if (livePreviewEnabled) {
76
+ DefaultView = {
77
+ Component: DefaultLivePreviewView
78
+ };
103
79
  }
104
- default:
105
- {
106
- const baseRoute = [
107
- adminRoute !== '/' && adminRoute,
108
- 'collections',
109
- collectionSlug,
110
- segment3
111
- ].filter(Boolean).join('/');
112
- const currentRoute = [
113
- baseRoute,
114
- segment4,
115
- segment5,
116
- ...remainingSegments
117
- ].filter(Boolean).join('/');
80
+ break;
81
+ }
82
+ case 'versions':
83
+ {
84
+ if (docPermissions?.readVersions?.permission) {
118
85
  CustomView = {
119
- payloadComponent: getCustomViewByRoute({
120
- baseRoute,
121
- currentRoute,
122
- views
123
- })
86
+ payloadComponent: getCustomViewByKey(views, 'versions')
87
+ };
88
+ DefaultView = {
89
+ Component: DefaultVersionsView
90
+ };
91
+ } else {
92
+ ErrorView = {
93
+ Component: UnauthorizedView
124
94
  };
125
- break;
126
95
  }
127
- }
128
- break;
129
- }
130
- // `../:id/versions/:version`, etc
131
- default:
132
- {
133
- if (segment4 === 'versions') {
134
- if (docPermissions?.readVersions?.permission) {
96
+ break;
97
+ }
98
+ default:
99
+ {
100
+ const baseRoute = [
101
+ adminRoute !== '/' && adminRoute,
102
+ 'collections',
103
+ collectionSlug,
104
+ segment3
105
+ ].filter(Boolean).join('/');
106
+ const currentRoute = [
107
+ baseRoute,
108
+ segment4,
109
+ segment5,
110
+ ...remainingSegments
111
+ ].filter(Boolean).join('/');
135
112
  CustomView = {
136
- payloadComponent: getCustomViewByKey(views, 'version')
137
- };
138
- DefaultView = {
139
- Component: DefaultVersionView
140
- };
141
- } else {
142
- ErrorView = {
143
- Component: UnauthorizedView
113
+ payloadComponent: getCustomViewByRoute({
114
+ baseRoute,
115
+ currentRoute,
116
+ views
117
+ })
144
118
  };
119
+ break;
145
120
  }
146
- } else {
147
- const baseRoute = [
148
- adminRoute !== '/' && adminRoute,
149
- collectionEntity,
150
- collectionSlug,
151
- segment3
152
- ].filter(Boolean).join('/');
153
- const currentRoute = [
154
- baseRoute,
155
- segment4,
156
- segment5,
157
- ...remainingSegments
158
- ].filter(Boolean).join('/');
121
+ }
122
+ break;
123
+ }
124
+ // `../:id/versions/:version`, etc
125
+ default:
126
+ {
127
+ if (segment4 === 'versions') {
128
+ if (docPermissions?.readVersions?.permission) {
159
129
  CustomView = {
160
- payloadComponent: getCustomViewByRoute({
161
- baseRoute,
162
- currentRoute,
163
- views
164
- })
130
+ payloadComponent: getCustomViewByKey(views, 'version')
131
+ };
132
+ DefaultView = {
133
+ Component: DefaultVersionView
134
+ };
135
+ } else {
136
+ ErrorView = {
137
+ Component: UnauthorizedView
165
138
  };
166
139
  }
167
- break;
140
+ } else {
141
+ const baseRoute = [
142
+ adminRoute !== '/' && adminRoute,
143
+ collectionEntity,
144
+ collectionSlug,
145
+ segment3
146
+ ].filter(Boolean).join('/');
147
+ const currentRoute = [
148
+ baseRoute,
149
+ segment4,
150
+ segment5,
151
+ ...remainingSegments
152
+ ].filter(Boolean).join('/');
153
+ CustomView = {
154
+ payloadComponent: getCustomViewByRoute({
155
+ baseRoute,
156
+ currentRoute,
157
+ views
158
+ })
159
+ };
168
160
  }
169
- }
161
+ break;
162
+ }
170
163
  }
171
164
  }
172
165
  }
173
166
  if (globalConfig) {
174
- const editConfig = globalConfig?.admin?.components?.views?.edit;
175
- const EditOverride = typeof editConfig === 'function' ? editConfig : null;
176
- if (EditOverride) {
177
- CustomView = EditOverride;
178
- }
179
- if (!EditOverride) {
180
- const [globalEntity, globalSlug, segment3, ...remainingSegments] = routeSegments;
181
- if (!docPermissions?.read?.permission) {
182
- notFound();
183
- } else {
184
- switch(routeSegments.length){
185
- case 2:
186
- {
187
- CustomView = {
188
- payloadComponent: getCustomViewByKey(views, 'default')
189
- };
190
- DefaultView = {
191
- Component: DefaultEditView
192
- };
193
- break;
194
- }
195
- case 3:
196
- {
197
- // `../:slug/api`, `../:slug/preview`, `../:slug/versions`, etc
198
- switch(segment3){
199
- case 'api':
200
- {
201
- if (globalConfig?.admin?.hideAPIURL !== true) {
202
- CustomView = {
203
- payloadComponent: getCustomViewByKey(views, 'api')
204
- };
205
- DefaultView = {
206
- Component: DefaultAPIView
207
- };
208
- }
209
- break;
167
+ const [globalEntity, globalSlug, segment3, ...remainingSegments] = routeSegments;
168
+ if (!docPermissions?.read?.permission) {
169
+ notFound();
170
+ } else {
171
+ switch(routeSegments.length){
172
+ case 2:
173
+ {
174
+ CustomView = {
175
+ payloadComponent: getCustomViewByKey(views, 'default')
176
+ };
177
+ DefaultView = {
178
+ Component: DefaultEditView
179
+ };
180
+ break;
181
+ }
182
+ case 3:
183
+ {
184
+ // `../:slug/api`, `../:slug/preview`, `../:slug/versions`, etc
185
+ switch(segment3){
186
+ case 'api':
187
+ {
188
+ if (globalConfig?.admin?.hideAPIURL !== true) {
189
+ CustomView = {
190
+ payloadComponent: getCustomViewByKey(views, 'api')
191
+ };
192
+ DefaultView = {
193
+ Component: DefaultAPIView
194
+ };
210
195
  }
211
- case 'preview':
212
- {
213
- if (livePreviewEnabled) {
214
- DefaultView = {
215
- Component: DefaultLivePreviewView
216
- };
217
- }
218
- break;
196
+ break;
197
+ }
198
+ case 'preview':
199
+ {
200
+ if (livePreviewEnabled) {
201
+ DefaultView = {
202
+ Component: DefaultLivePreviewView
203
+ };
219
204
  }
220
- case 'versions':
221
- {
222
- if (docPermissions?.readVersions?.permission) {
223
- CustomView = {
224
- payloadComponent: getCustomViewByKey(views, 'versions')
225
- };
226
- DefaultView = {
227
- Component: DefaultVersionsView
228
- };
229
- } else {
230
- ErrorView = {
231
- Component: UnauthorizedView
232
- };
233
- }
234
- break;
205
+ break;
206
+ }
207
+ case 'versions':
208
+ {
209
+ if (docPermissions?.readVersions?.permission) {
210
+ CustomView = {
211
+ payloadComponent: getCustomViewByKey(views, 'versions')
212
+ };
213
+ DefaultView = {
214
+ Component: DefaultVersionsView
215
+ };
216
+ } else {
217
+ ErrorView = {
218
+ Component: UnauthorizedView
219
+ };
235
220
  }
236
- default:
237
- {
238
- if (docPermissions?.read?.permission) {
239
- const baseRoute = [
240
- adminRoute,
241
- globalEntity,
242
- globalSlug,
243
- segment3
244
- ].filter(Boolean).join('/');
245
- const currentRoute = [
221
+ break;
222
+ }
223
+ default:
224
+ {
225
+ if (docPermissions?.read?.permission) {
226
+ const baseRoute = [
227
+ adminRoute,
228
+ globalEntity,
229
+ globalSlug,
230
+ segment3
231
+ ].filter(Boolean).join('/');
232
+ const currentRoute = [
233
+ baseRoute,
234
+ segment3,
235
+ ...remainingSegments
236
+ ].filter(Boolean).join('/');
237
+ CustomView = {
238
+ payloadComponent: getCustomViewByRoute({
246
239
  baseRoute,
247
- segment3,
248
- ...remainingSegments
249
- ].filter(Boolean).join('/');
250
- CustomView = {
251
- payloadComponent: getCustomViewByRoute({
252
- baseRoute,
253
- currentRoute,
254
- views
255
- })
256
- };
257
- DefaultView = {
258
- Component: DefaultEditView
259
- };
260
- } else {
261
- ErrorView = {
262
- Component: UnauthorizedView
263
- };
264
- }
265
- break;
240
+ currentRoute,
241
+ views
242
+ })
243
+ };
244
+ DefaultView = {
245
+ Component: DefaultEditView
246
+ };
247
+ } else {
248
+ ErrorView = {
249
+ Component: UnauthorizedView
250
+ };
266
251
  }
267
- }
268
- break;
269
- }
270
- default:
271
- {
272
- // `../:slug/versions/:version`, etc
273
- if (segment3 === 'versions') {
274
- if (docPermissions?.readVersions?.permission) {
275
- CustomView = {
276
- payloadComponent: getCustomViewByKey(views, 'version')
277
- };
278
- DefaultView = {
279
- Component: DefaultVersionView
280
- };
281
- } else {
282
- ErrorView = {
283
- Component: UnauthorizedView
284
- };
252
+ break;
285
253
  }
286
- } else {
287
- const baseRoute = [
288
- adminRoute !== '/' && adminRoute,
289
- 'globals',
290
- globalSlug
291
- ].filter(Boolean).join('/');
292
- const currentRoute = [
293
- baseRoute,
294
- segment3,
295
- ...remainingSegments
296
- ].filter(Boolean).join('/');
254
+ }
255
+ break;
256
+ }
257
+ default:
258
+ {
259
+ // `../:slug/versions/:version`, etc
260
+ if (segment3 === 'versions') {
261
+ if (docPermissions?.readVersions?.permission) {
297
262
  CustomView = {
298
- payloadComponent: getCustomViewByRoute({
299
- baseRoute,
300
- currentRoute,
301
- views
302
- })
263
+ payloadComponent: getCustomViewByKey(views, 'version')
264
+ };
265
+ DefaultView = {
266
+ Component: DefaultVersionView
267
+ };
268
+ } else {
269
+ ErrorView = {
270
+ Component: UnauthorizedView
303
271
  };
304
272
  }
305
- break;
273
+ } else {
274
+ const baseRoute = [
275
+ adminRoute !== '/' && adminRoute,
276
+ 'globals',
277
+ globalSlug
278
+ ].filter(Boolean).join('/');
279
+ const currentRoute = [
280
+ baseRoute,
281
+ segment3,
282
+ ...remainingSegments
283
+ ].filter(Boolean).join('/');
284
+ CustomView = {
285
+ payloadComponent: getCustomViewByRoute({
286
+ baseRoute,
287
+ currentRoute,
288
+ views
289
+ })
290
+ };
306
291
  }
307
- }
292
+ break;
293
+ }
308
294
  }
309
295
  }
310
296
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/views/Document/getViewsFromConfig.tsx"],"sourcesContent":["import type {\n AdminViewProps,\n CollectionPermission,\n GlobalPermission,\n PayloadComponent,\n SanitizedCollectionConfig,\n SanitizedConfig,\n SanitizedGlobalConfig,\n ServerSideEditViewProps,\n} from 'payload'\nimport type React from 'react'\n\nimport { notFound } from 'next/navigation.js'\n\nimport { APIView as DefaultAPIView } from '../API/index.js'\nimport { EditView as DefaultEditView } from '../Edit/index.js'\nimport { LivePreviewView as DefaultLivePreviewView } from '../LivePreview/index.js'\nimport { UnauthorizedView } from '../Unauthorized/index.js'\nimport { VersionView as DefaultVersionView } from '../Version/index.js'\nimport { VersionsView as DefaultVersionsView } from '../Versions/index.js'\nimport { getCustomViewByKey } from './getCustomViewByKey.js'\nimport { getCustomViewByRoute } from './getCustomViewByRoute.js'\n\nexport type ViewFromConfig<TProps extends object> = {\n Component?: React.FC<TProps>\n payloadComponent?: PayloadComponent<TProps>\n}\n\nexport const getViewsFromConfig = ({\n collectionConfig,\n config,\n docPermissions,\n globalConfig,\n routeSegments,\n}: {\n collectionConfig?: SanitizedCollectionConfig\n config: SanitizedConfig\n docPermissions: CollectionPermission | GlobalPermission\n globalConfig?: SanitizedGlobalConfig\n routeSegments: string[]\n}): {\n CustomView: ViewFromConfig<ServerSideEditViewProps>\n DefaultView: ViewFromConfig<ServerSideEditViewProps>\n /**\n * The error view to display if CustomView or DefaultView do not exist (could be either due to not found, or unauthorized). Can be null\n */\n ErrorView: ViewFromConfig<AdminViewProps>\n} | null => {\n // Conditionally import and lazy load the default view\n let DefaultView: ViewFromConfig<ServerSideEditViewProps> = null\n let CustomView: ViewFromConfig<ServerSideEditViewProps> = null\n let ErrorView: ViewFromConfig<AdminViewProps> = null\n\n const {\n routes: { admin: adminRoute },\n } = config\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 editConfig = collectionConfig?.admin?.components?.views?.edit\n const EditOverride = typeof editConfig === 'function' ? editConfig : null\n\n if (EditOverride) {\n CustomView = EditOverride\n }\n\n if (!EditOverride) {\n const [collectionEntity, collectionSlug, segment3, segment4, segment5, ...remainingSegments] =\n routeSegments\n\n if (!docPermissions?.read?.permission) {\n notFound()\n } else {\n // `../:id`, or `../create`\n switch (routeSegments.length) {\n case 3: {\n switch (segment3) {\n case 'create': {\n if ('create' in docPermissions && docPermissions?.create?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'default'),\n }\n DefaultView = {\n Component: DefaultEditView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n break\n }\n\n default: {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'default'),\n }\n DefaultView = {\n Component: DefaultEditView,\n }\n break\n }\n }\n break\n }\n\n // `../:id/api`, `../:id/preview`, `../:id/versions`, etc\n case 4: {\n switch (segment4) {\n case 'api': {\n if (collectionConfig?.admin?.hideAPIURL !== true) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'api'),\n }\n DefaultView = {\n Component: DefaultAPIView,\n }\n }\n break\n }\n\n case 'preview': {\n if (livePreviewEnabled) {\n DefaultView = {\n Component: DefaultLivePreviewView,\n }\n }\n break\n }\n\n case 'versions': {\n if (docPermissions?.readVersions?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'versions'),\n }\n DefaultView = {\n Component: DefaultVersionsView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n break\n }\n\n default: {\n const baseRoute = [\n adminRoute !== '/' && adminRoute,\n 'collections',\n collectionSlug,\n segment3,\n ]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment4, segment5, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = {\n payloadComponent: getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n }),\n }\n break\n }\n }\n break\n }\n\n // `../:id/versions/:version`, etc\n default: {\n if (segment4 === 'versions') {\n if (docPermissions?.readVersions?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'version'),\n }\n DefaultView = {\n Component: DefaultVersionView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n } else {\n const baseRoute = [\n adminRoute !== '/' && adminRoute,\n collectionEntity,\n collectionSlug,\n segment3,\n ]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment4, segment5, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = {\n payloadComponent: getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n }),\n }\n }\n break\n }\n }\n }\n }\n }\n\n if (globalConfig) {\n const editConfig = globalConfig?.admin?.components?.views?.edit\n const EditOverride = typeof editConfig === 'function' ? editConfig : null\n\n if (EditOverride) {\n CustomView = EditOverride\n }\n\n if (!EditOverride) {\n const [globalEntity, globalSlug, segment3, ...remainingSegments] = routeSegments\n\n if (!docPermissions?.read?.permission) {\n notFound()\n } else {\n switch (routeSegments.length) {\n case 2: {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'default'),\n }\n DefaultView = {\n Component: DefaultEditView,\n }\n break\n }\n\n case 3: {\n // `../:slug/api`, `../:slug/preview`, `../:slug/versions`, etc\n switch (segment3) {\n case 'api': {\n if (globalConfig?.admin?.hideAPIURL !== true) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'api'),\n }\n DefaultView = {\n Component: DefaultAPIView,\n }\n }\n break\n }\n\n case 'preview': {\n if (livePreviewEnabled) {\n DefaultView = {\n Component: DefaultLivePreviewView,\n }\n }\n break\n }\n\n case 'versions': {\n if (docPermissions?.readVersions?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'versions'),\n }\n DefaultView = {\n Component: DefaultVersionsView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n break\n }\n\n default: {\n if (docPermissions?.read?.permission) {\n const baseRoute = [adminRoute, globalEntity, globalSlug, segment3]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment3, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = {\n payloadComponent: getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n }),\n }\n DefaultView = {\n Component: DefaultEditView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n break\n }\n }\n break\n }\n\n default: {\n // `../:slug/versions/:version`, etc\n if (segment3 === 'versions') {\n if (docPermissions?.readVersions?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'version'),\n }\n DefaultView = {\n Component: DefaultVersionView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n } else {\n const baseRoute = [adminRoute !== '/' && adminRoute, 'globals', globalSlug]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment3, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = {\n payloadComponent: getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n }),\n }\n }\n break\n }\n }\n }\n }\n }\n\n return {\n CustomView,\n DefaultView,\n ErrorView,\n }\n}\n"],"names":["notFound","APIView","DefaultAPIView","EditView","DefaultEditView","LivePreviewView","DefaultLivePreviewView","UnauthorizedView","VersionView","DefaultVersionView","VersionsView","DefaultVersionsView","getCustomViewByKey","getCustomViewByRoute","getViewsFromConfig","collectionConfig","config","docPermissions","globalConfig","routeSegments","DefaultView","CustomView","ErrorView","routes","admin","adminRoute","views","components","livePreviewEnabled","livePreview","collections","includes","slug","globals","editConfig","edit","EditOverride","collectionEntity","collectionSlug","segment3","segment4","segment5","remainingSegments","read","permission","length","create","payloadComponent","Component","hideAPIURL","readVersions","baseRoute","filter","Boolean","join","currentRoute","globalEntity","globalSlug"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../src/views/Document/getViewsFromConfig.tsx"],"sourcesContent":["import type {\n AdminViewProps,\n CollectionPermission,\n GlobalPermission,\n PayloadComponent,\n SanitizedCollectionConfig,\n SanitizedConfig,\n SanitizedGlobalConfig,\n ServerSideEditViewProps,\n} from 'payload'\nimport type React from 'react'\n\nimport { notFound } from 'next/navigation.js'\n\nimport { APIView as DefaultAPIView } from '../API/index.js'\nimport { EditView as DefaultEditView } from '../Edit/index.js'\nimport { LivePreviewView as DefaultLivePreviewView } from '../LivePreview/index.js'\nimport { UnauthorizedView } from '../Unauthorized/index.js'\nimport { VersionView as DefaultVersionView } from '../Version/index.js'\nimport { VersionsView as DefaultVersionsView } from '../Versions/index.js'\nimport { getCustomViewByKey } from './getCustomViewByKey.js'\nimport { getCustomViewByRoute } from './getCustomViewByRoute.js'\n\nexport type ViewFromConfig<TProps extends object> = {\n Component?: React.FC<TProps>\n payloadComponent?: PayloadComponent<TProps>\n}\n\nexport const getViewsFromConfig = ({\n collectionConfig,\n config,\n docPermissions,\n globalConfig,\n routeSegments,\n}: {\n collectionConfig?: SanitizedCollectionConfig\n config: SanitizedConfig\n docPermissions: CollectionPermission | GlobalPermission\n globalConfig?: SanitizedGlobalConfig\n routeSegments: string[]\n}): {\n CustomView: ViewFromConfig<ServerSideEditViewProps>\n DefaultView: ViewFromConfig<ServerSideEditViewProps>\n /**\n * The error view to display if CustomView or DefaultView do not exist (could be either due to not found, or unauthorized). Can be null\n */\n ErrorView: ViewFromConfig<AdminViewProps>\n} | null => {\n // Conditionally import and lazy load the default view\n let DefaultView: ViewFromConfig<ServerSideEditViewProps> = null\n let CustomView: ViewFromConfig<ServerSideEditViewProps> = null\n let ErrorView: ViewFromConfig<AdminViewProps> = null\n\n const {\n routes: { admin: adminRoute },\n } = config\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, segment3, segment4, segment5, ...remainingSegments] =\n routeSegments\n\n if (!docPermissions?.read?.permission) {\n notFound()\n } else {\n // `../:id`, or `../create`\n switch (routeSegments.length) {\n case 3: {\n switch (segment3) {\n case 'create': {\n if ('create' in docPermissions && docPermissions?.create?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'default'),\n }\n DefaultView = {\n Component: DefaultEditView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n break\n }\n\n default: {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'default'),\n }\n DefaultView = {\n Component: DefaultEditView,\n }\n break\n }\n }\n break\n }\n\n // `../:id/api`, `../:id/preview`, `../:id/versions`, etc\n case 4: {\n switch (segment4) {\n case 'api': {\n if (collectionConfig?.admin?.hideAPIURL !== true) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'api'),\n }\n DefaultView = {\n Component: DefaultAPIView,\n }\n }\n break\n }\n\n case 'preview': {\n if (livePreviewEnabled) {\n DefaultView = {\n Component: DefaultLivePreviewView,\n }\n }\n break\n }\n\n case 'versions': {\n if (docPermissions?.readVersions?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'versions'),\n }\n DefaultView = {\n Component: DefaultVersionsView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n break\n }\n\n default: {\n const baseRoute = [\n adminRoute !== '/' && adminRoute,\n 'collections',\n collectionSlug,\n segment3,\n ]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment4, segment5, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = {\n payloadComponent: getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n }),\n }\n break\n }\n }\n break\n }\n\n // `../:id/versions/:version`, etc\n default: {\n if (segment4 === 'versions') {\n if (docPermissions?.readVersions?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'version'),\n }\n DefaultView = {\n Component: DefaultVersionView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n } else {\n const baseRoute = [\n adminRoute !== '/' && adminRoute,\n collectionEntity,\n collectionSlug,\n segment3,\n ]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment4, segment5, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = {\n payloadComponent: getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n }),\n }\n }\n break\n }\n }\n }\n }\n\n if (globalConfig) {\n const [globalEntity, globalSlug, segment3, ...remainingSegments] = routeSegments\n\n if (!docPermissions?.read?.permission) {\n notFound()\n } else {\n switch (routeSegments.length) {\n case 2: {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'default'),\n }\n DefaultView = {\n Component: DefaultEditView,\n }\n break\n }\n\n case 3: {\n // `../:slug/api`, `../:slug/preview`, `../:slug/versions`, etc\n switch (segment3) {\n case 'api': {\n if (globalConfig?.admin?.hideAPIURL !== true) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'api'),\n }\n DefaultView = {\n Component: DefaultAPIView,\n }\n }\n break\n }\n\n case 'preview': {\n if (livePreviewEnabled) {\n DefaultView = {\n Component: DefaultLivePreviewView,\n }\n }\n break\n }\n\n case 'versions': {\n if (docPermissions?.readVersions?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'versions'),\n }\n DefaultView = {\n Component: DefaultVersionsView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n break\n }\n\n default: {\n if (docPermissions?.read?.permission) {\n const baseRoute = [adminRoute, globalEntity, globalSlug, segment3]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment3, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = {\n payloadComponent: getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n }),\n }\n DefaultView = {\n Component: DefaultEditView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n break\n }\n }\n break\n }\n\n default: {\n // `../:slug/versions/:version`, etc\n if (segment3 === 'versions') {\n if (docPermissions?.readVersions?.permission) {\n CustomView = {\n payloadComponent: getCustomViewByKey(views, 'version'),\n }\n DefaultView = {\n Component: DefaultVersionView,\n }\n } else {\n ErrorView = {\n Component: UnauthorizedView,\n }\n }\n } else {\n const baseRoute = [adminRoute !== '/' && adminRoute, 'globals', globalSlug]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment3, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = {\n payloadComponent: getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n }),\n }\n }\n break\n }\n }\n }\n }\n\n return {\n CustomView,\n DefaultView,\n ErrorView,\n }\n}\n"],"names":["notFound","APIView","DefaultAPIView","EditView","DefaultEditView","LivePreviewView","DefaultLivePreviewView","UnauthorizedView","VersionView","DefaultVersionView","VersionsView","DefaultVersionsView","getCustomViewByKey","getCustomViewByRoute","getViewsFromConfig","collectionConfig","config","docPermissions","globalConfig","routeSegments","DefaultView","CustomView","ErrorView","routes","admin","adminRoute","views","components","livePreviewEnabled","livePreview","collections","includes","slug","globals","collectionEntity","collectionSlug","segment3","segment4","segment5","remainingSegments","read","permission","length","create","payloadComponent","Component","hideAPIURL","readVersions","baseRoute","filter","Boolean","join","currentRoute","globalEntity","globalSlug"],"mappings":"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"}