@payloadcms/next 3.0.0-beta.37 → 3.0.0-beta.39

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.
Files changed (105) hide show
  1. package/dist/cjs/withPayload.cjs +3 -0
  2. package/dist/cjs/withPayload.cjs.map +1 -1
  3. package/dist/exports/utilities.d.ts +0 -1
  4. package/dist/exports/utilities.d.ts.map +1 -1
  5. package/dist/exports/utilities.js +0 -1
  6. package/dist/exports/utilities.js.map +1 -1
  7. package/dist/layouts/Root/index.d.ts.map +1 -1
  8. package/dist/layouts/Root/index.js.map +1 -1
  9. package/dist/prod/styles.css +1 -1
  10. package/dist/routes/rest/buildFormState.d.ts +0 -2
  11. package/dist/routes/rest/buildFormState.d.ts.map +1 -1
  12. package/dist/routes/rest/buildFormState.js +16 -166
  13. package/dist/routes/rest/buildFormState.js.map +1 -1
  14. package/dist/utilities/initPage/index.d.ts.map +1 -1
  15. package/dist/utilities/initPage/index.js +10 -0
  16. package/dist/utilities/initPage/index.js.map +1 -1
  17. package/dist/utilities/initPage/shared.d.ts.map +1 -1
  18. package/dist/utilities/initPage/shared.js +0 -1
  19. package/dist/utilities/initPage/shared.js.map +1 -1
  20. package/dist/views/API/LocaleSelector/index.d.ts +9 -0
  21. package/dist/views/API/LocaleSelector/index.d.ts.map +1 -0
  22. package/dist/views/API/LocaleSelector/index.js +16 -0
  23. package/dist/views/API/LocaleSelector/index.js.map +1 -0
  24. package/dist/views/API/index.client.d.ts.map +1 -1
  25. package/dist/views/API/index.client.js +4 -7
  26. package/dist/views/API/index.client.js.map +1 -1
  27. package/dist/views/Account/Settings/LanguageSelector.d.ts +6 -0
  28. package/dist/views/Account/Settings/LanguageSelector.d.ts.map +1 -0
  29. package/dist/views/Account/Settings/LanguageSelector.js +19 -0
  30. package/dist/views/Account/Settings/LanguageSelector.js.map +1 -0
  31. package/dist/views/Account/Settings/index.d.ts +4 -0
  32. package/dist/views/Account/Settings/index.d.ts.map +1 -1
  33. package/dist/views/Account/Settings/index.js +6 -14
  34. package/dist/views/Account/Settings/index.js.map +1 -1
  35. package/dist/views/Account/index.d.ts.map +1 -1
  36. package/dist/views/Account/index.js +14 -2
  37. package/dist/views/Account/index.js.map +1 -1
  38. package/dist/views/Dashboard/Default/index.d.ts +2 -0
  39. package/dist/views/Dashboard/Default/index.d.ts.map +1 -1
  40. package/dist/views/Dashboard/Default/index.js +73 -7
  41. package/dist/views/Dashboard/Default/index.js.map +1 -1
  42. package/dist/views/Dashboard/index.d.ts.map +1 -1
  43. package/dist/views/Dashboard/index.js +20 -0
  44. package/dist/views/Dashboard/index.js.map +1 -1
  45. package/dist/views/Document/getDocumentData.d.ts +2 -3
  46. package/dist/views/Document/getDocumentData.d.ts.map +1 -1
  47. package/dist/views/Document/getDocumentData.js +25 -18
  48. package/dist/views/Document/getDocumentData.js.map +1 -1
  49. package/dist/views/Document/getViewsFromConfig.d.ts.map +1 -1
  50. package/dist/views/Document/getViewsFromConfig.js +172 -171
  51. package/dist/views/Document/getViewsFromConfig.js.map +1 -1
  52. package/dist/views/Document/index.d.ts.map +1 -1
  53. package/dist/views/Document/index.js +3 -2
  54. package/dist/views/Document/index.js.map +1 -1
  55. package/dist/views/Edit/Default/Auth/APIKey.js +1 -1
  56. package/dist/views/Edit/Default/Auth/APIKey.js.map +1 -1
  57. package/dist/views/Edit/Default/Auth/index.d.ts.map +1 -1
  58. package/dist/views/Edit/Default/Auth/index.js +11 -5
  59. package/dist/views/Edit/Default/Auth/index.js.map +1 -1
  60. package/dist/views/Edit/Default/SetDocumentStepNav/index.d.ts.map +1 -1
  61. package/dist/views/Edit/Default/SetDocumentStepNav/index.js +25 -22
  62. package/dist/views/Edit/Default/SetDocumentStepNav/index.js.map +1 -1
  63. package/dist/views/Edit/Default/index.d.ts.map +1 -1
  64. package/dist/views/Edit/Default/index.js +4 -13
  65. package/dist/views/Edit/Default/index.js.map +1 -1
  66. package/dist/views/Edit/index.client.d.ts.map +1 -1
  67. package/dist/views/Edit/index.client.js +2 -4
  68. package/dist/views/Edit/index.client.js.map +1 -1
  69. package/dist/views/List/index.d.ts.map +1 -1
  70. package/dist/views/List/index.js +1 -5
  71. package/dist/views/List/index.js.map +1 -1
  72. package/dist/views/LivePreview/index.client.d.ts.map +1 -1
  73. package/dist/views/LivePreview/index.client.js +23 -15
  74. package/dist/views/LivePreview/index.client.js.map +1 -1
  75. package/dist/views/Login/LoginForm/index.d.ts.map +1 -1
  76. package/dist/views/Login/LoginForm/index.js +0 -5
  77. package/dist/views/Login/LoginForm/index.js.map +1 -1
  78. package/dist/views/Logout/index.d.ts.map +1 -1
  79. package/dist/views/Logout/index.js +6 -10
  80. package/dist/views/Logout/index.js.map +1 -1
  81. package/dist/views/ResetPassword/index.client.js +1 -3
  82. package/dist/views/ResetPassword/index.client.js.map +1 -1
  83. package/dist/views/Version/SelectLocales/index.d.ts.map +1 -1
  84. package/dist/views/Version/SelectLocales/index.js +1 -0
  85. package/dist/views/Version/SelectLocales/index.js.map +1 -1
  86. package/dist/withPayload.d.ts.map +1 -1
  87. package/dist/withPayload.js +3 -0
  88. package/dist/withPayload.js.map +1 -1
  89. package/package.json +7 -7
  90. package/dist/utilities/buildFieldSchemaMap/index.d.ts +0 -4
  91. package/dist/utilities/buildFieldSchemaMap/index.d.ts.map +0 -1
  92. package/dist/utilities/buildFieldSchemaMap/index.js +0 -28
  93. package/dist/utilities/buildFieldSchemaMap/index.js.map +0 -1
  94. package/dist/utilities/buildFieldSchemaMap/traverseFields.d.ts +0 -14
  95. package/dist/utilities/buildFieldSchemaMap/traverseFields.d.ts.map +0 -1
  96. package/dist/utilities/buildFieldSchemaMap/traverseFields.js +0 -75
  97. package/dist/utilities/buildFieldSchemaMap/traverseFields.js.map +0 -1
  98. package/dist/utilities/buildFieldSchemaMap/types.d.ts +0 -3
  99. package/dist/utilities/buildFieldSchemaMap/types.d.ts.map +0 -1
  100. package/dist/utilities/buildFieldSchemaMap/types.js +0 -3
  101. package/dist/utilities/buildFieldSchemaMap/types.js.map +0 -1
  102. package/dist/views/Dashboard/Default/index.client.d.ts +0 -10
  103. package/dist/views/Dashboard/Default/index.client.d.ts.map +0 -1
  104. package/dist/views/Dashboard/Default/index.client.js +0 -114
  105. package/dist/views/Dashboard/Default/index.client.js.map +0 -1
@@ -1,3 +1,4 @@
1
+ import { notFound } from 'next/navigation.js';
1
2
  import { APIView as DefaultAPIView } from '../API/index.js';
2
3
  import { EditView as DefaultEditView } from '../Edit/index.js';
3
4
  import { LivePreviewView as DefaultLivePreviewView } from '../LivePreview/index.js';
@@ -22,118 +23,118 @@ export const getViewsFromConfig = ({ collectionConfig, config, docPermissions, g
22
23
  }
23
24
  if (!EditOverride) {
24
25
  const [collectionEntity, collectionSlug, segment3, segment4, segment5, ...remainingSegments] = routeSegments;
25
- // `../:id`, or `../create`
26
- switch(routeSegments.length){
27
- case 3:
28
- {
29
- switch(segment3){
30
- case 'create':
31
- {
32
- if ('create' in docPermissions && docPermissions?.create?.permission) {
33
- CustomView = getCustomViewByKey(views, 'Default');
34
- DefaultView = DefaultEditView;
35
- } else {
36
- ErrorView = UnauthorizedView;
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 = getCustomViewByKey(views, 'Default');
38
+ DefaultView = DefaultEditView;
39
+ } else {
40
+ ErrorView = UnauthorizedView;
41
+ }
42
+ break;
37
43
  }
38
- break;
39
- }
40
- default:
41
- {
42
- if (docPermissions?.read?.permission) {
44
+ default:
45
+ {
43
46
  CustomView = getCustomViewByKey(views, 'Default');
44
47
  DefaultView = DefaultEditView;
45
- } else {
46
- ErrorView = UnauthorizedView;
48
+ break;
47
49
  }
48
- break;
49
- }
50
+ }
51
+ break;
50
52
  }
51
- break;
52
- }
53
- // `../:id/api`, `../:id/preview`, `../:id/versions`, etc
54
- case 4:
55
- {
56
- switch(segment4){
57
- case 'api':
58
- {
59
- if (collectionConfig?.admin?.hideAPIURL !== true) {
60
- CustomView = getCustomViewByKey(views, 'API');
61
- DefaultView = DefaultAPIView;
53
+ // `../:id/api`, `../:id/preview`, `../:id/versions`, etc
54
+ case 4:
55
+ {
56
+ switch(segment4){
57
+ case 'api':
58
+ {
59
+ if (collectionConfig?.admin?.hideAPIURL !== true) {
60
+ CustomView = getCustomViewByKey(views, 'API');
61
+ DefaultView = DefaultAPIView;
62
+ }
63
+ break;
62
64
  }
63
- break;
64
- }
65
- case 'preview':
66
- {
67
- if (livePreviewEnabled) {
68
- DefaultView = DefaultLivePreviewView;
65
+ case 'preview':
66
+ {
67
+ if (livePreviewEnabled) {
68
+ DefaultView = DefaultLivePreviewView;
69
+ }
70
+ break;
69
71
  }
70
- break;
71
- }
72
- case 'versions':
73
- {
74
- if (docPermissions?.readVersions?.permission) {
75
- CustomView = getCustomViewByKey(views, 'Versions');
76
- DefaultView = DefaultVersionsView;
77
- } else {
78
- ErrorView = UnauthorizedView;
72
+ case 'versions':
73
+ {
74
+ if (docPermissions?.readVersions?.permission) {
75
+ CustomView = getCustomViewByKey(views, 'Versions');
76
+ DefaultView = DefaultVersionsView;
77
+ } else {
78
+ ErrorView = UnauthorizedView;
79
+ }
80
+ break;
79
81
  }
80
- break;
81
- }
82
- default:
83
- {
84
- const baseRoute = [
85
- adminRoute,
86
- 'collections',
87
- collectionSlug,
88
- segment3
89
- ].filter(Boolean).join('/');
90
- const currentRoute = [
91
- baseRoute,
92
- segment4,
93
- segment5,
94
- ...remainingSegments
95
- ].filter(Boolean).join('/');
96
- CustomView = getCustomViewByRoute({
97
- baseRoute,
98
- currentRoute,
99
- views
100
- });
101
- break;
102
- }
82
+ default:
83
+ {
84
+ const baseRoute = [
85
+ adminRoute,
86
+ 'collections',
87
+ collectionSlug,
88
+ segment3
89
+ ].filter(Boolean).join('/');
90
+ const currentRoute = [
91
+ baseRoute,
92
+ segment4,
93
+ segment5,
94
+ ...remainingSegments
95
+ ].filter(Boolean).join('/');
96
+ CustomView = getCustomViewByRoute({
97
+ baseRoute,
98
+ currentRoute,
99
+ views
100
+ });
101
+ break;
102
+ }
103
+ }
104
+ break;
103
105
  }
104
- break;
105
- }
106
- // `../:id/versions/:version`, etc
107
- default:
108
- {
109
- if (segment4 === 'versions') {
110
- if (docPermissions?.readVersions?.permission) {
111
- CustomView = getCustomViewByKey(views, 'Version');
112
- DefaultView = DefaultVersionView;
106
+ // `../:id/versions/:version`, etc
107
+ default:
108
+ {
109
+ if (segment4 === 'versions') {
110
+ if (docPermissions?.readVersions?.permission) {
111
+ CustomView = getCustomViewByKey(views, 'Version');
112
+ DefaultView = DefaultVersionView;
113
+ } else {
114
+ ErrorView = UnauthorizedView;
115
+ }
113
116
  } else {
114
- ErrorView = UnauthorizedView;
117
+ const baseRoute = [
118
+ adminRoute,
119
+ collectionEntity,
120
+ collectionSlug,
121
+ segment3
122
+ ].filter(Boolean).join('/');
123
+ const currentRoute = [
124
+ baseRoute,
125
+ segment4,
126
+ segment5,
127
+ ...remainingSegments
128
+ ].filter(Boolean).join('/');
129
+ CustomView = getCustomViewByRoute({
130
+ baseRoute,
131
+ currentRoute,
132
+ views
133
+ });
115
134
  }
116
- } else {
117
- const baseRoute = [
118
- adminRoute,
119
- collectionEntity,
120
- collectionSlug,
121
- segment3
122
- ].filter(Boolean).join('/');
123
- const currentRoute = [
124
- baseRoute,
125
- segment4,
126
- segment5,
127
- ...remainingSegments
128
- ].filter(Boolean).join('/');
129
- CustomView = getCustomViewByRoute({
130
- baseRoute,
131
- currentRoute,
132
- views
133
- });
135
+ break;
134
136
  }
135
- break;
136
- }
137
+ }
137
138
  }
138
139
  }
139
140
  }
@@ -146,88 +147,88 @@ export const getViewsFromConfig = ({ collectionConfig, config, docPermissions, g
146
147
  if (!EditOverride) {
147
148
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
148
149
  const [globalEntity, globalSlug, segment3, ...remainingSegments] = routeSegments;
149
- switch(routeSegments.length){
150
- case 2:
151
- {
152
- if (docPermissions?.read?.permission) {
150
+ if (!docPermissions?.read?.permission) {
151
+ notFound();
152
+ } else {
153
+ switch(routeSegments.length){
154
+ case 2:
155
+ {
153
156
  CustomView = getCustomViewByKey(views, 'Default');
154
157
  DefaultView = DefaultEditView;
155
- } else {
156
- ErrorView = UnauthorizedView;
158
+ break;
157
159
  }
158
- break;
159
- }
160
- case 3:
161
- {
162
- // `../:slug/api`, `../:slug/preview`, `../:slug/versions`, etc
163
- switch(segment3){
164
- case 'api':
165
- {
166
- if (globalConfig?.admin?.hideAPIURL !== true) {
167
- CustomView = getCustomViewByKey(views, 'API');
168
- DefaultView = DefaultAPIView;
160
+ case 3:
161
+ {
162
+ // `../:slug/api`, `../:slug/preview`, `../:slug/versions`, etc
163
+ switch(segment3){
164
+ case 'api':
165
+ {
166
+ if (globalConfig?.admin?.hideAPIURL !== true) {
167
+ CustomView = getCustomViewByKey(views, 'API');
168
+ DefaultView = DefaultAPIView;
169
+ }
170
+ break;
169
171
  }
170
- break;
171
- }
172
- case 'preview':
173
- {
174
- if (livePreviewEnabled) {
175
- DefaultView = DefaultLivePreviewView;
172
+ case 'preview':
173
+ {
174
+ if (livePreviewEnabled) {
175
+ DefaultView = DefaultLivePreviewView;
176
+ }
177
+ break;
176
178
  }
177
- break;
178
- }
179
- case 'versions':
180
- {
181
- if (docPermissions?.readVersions?.permission) {
182
- CustomView = getCustomViewByKey(views, 'Versions');
183
- DefaultView = DefaultVersionsView;
184
- } else {
185
- ErrorView = UnauthorizedView;
179
+ case 'versions':
180
+ {
181
+ if (docPermissions?.readVersions?.permission) {
182
+ CustomView = getCustomViewByKey(views, 'Versions');
183
+ DefaultView = DefaultVersionsView;
184
+ } else {
185
+ ErrorView = UnauthorizedView;
186
+ }
187
+ break;
186
188
  }
187
- break;
188
- }
189
- default:
190
- {
191
- if (docPermissions?.read?.permission) {
192
- CustomView = getCustomViewByKey(views, 'Default');
193
- DefaultView = DefaultEditView;
194
- } else {
195
- ErrorView = UnauthorizedView;
189
+ default:
190
+ {
191
+ if (docPermissions?.read?.permission) {
192
+ CustomView = getCustomViewByKey(views, 'Default');
193
+ DefaultView = DefaultEditView;
194
+ } else {
195
+ ErrorView = UnauthorizedView;
196
+ }
197
+ break;
196
198
  }
197
- break;
198
- }
199
+ }
200
+ break;
199
201
  }
200
- break;
201
- }
202
- default:
203
- {
204
- // `../:slug/versions/:version`, etc
205
- if (segment3 === 'versions') {
206
- if (docPermissions?.readVersions?.permission) {
207
- CustomView = getCustomViewByKey(views, 'Version');
208
- DefaultView = DefaultVersionView;
202
+ default:
203
+ {
204
+ // `../:slug/versions/:version`, etc
205
+ if (segment3 === 'versions') {
206
+ if (docPermissions?.readVersions?.permission) {
207
+ CustomView = getCustomViewByKey(views, 'Version');
208
+ DefaultView = DefaultVersionView;
209
+ } else {
210
+ ErrorView = UnauthorizedView;
211
+ }
209
212
  } else {
210
- ErrorView = UnauthorizedView;
213
+ const baseRoute = [
214
+ adminRoute,
215
+ 'globals',
216
+ globalSlug
217
+ ].filter(Boolean).join('/');
218
+ const currentRoute = [
219
+ baseRoute,
220
+ segment3,
221
+ ...remainingSegments
222
+ ].filter(Boolean).join('/');
223
+ CustomView = getCustomViewByRoute({
224
+ baseRoute,
225
+ currentRoute,
226
+ views
227
+ });
211
228
  }
212
- } else {
213
- const baseRoute = [
214
- adminRoute,
215
- 'globals',
216
- globalSlug
217
- ].filter(Boolean).join('/');
218
- const currentRoute = [
219
- baseRoute,
220
- segment3,
221
- ...remainingSegments
222
- ].filter(Boolean).join('/');
223
- CustomView = getCustomViewByRoute({
224
- baseRoute,
225
- currentRoute,
226
- views
227
- });
229
+ break;
228
230
  }
229
- break;
230
- }
231
+ }
231
232
  }
232
233
  }
233
234
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/views/Document/getViewsFromConfig.tsx"],"sourcesContent":["import type { CollectionPermission, GlobalPermission } from 'payload/auth'\nimport type { EditViewComponent } from 'payload/config'\nimport type {\n AdminViewComponent,\n SanitizedCollectionConfig,\n SanitizedConfig,\n SanitizedGlobalConfig,\n} from 'payload/types'\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 const getViewsFromConfig = ({\n collectionConfig,\n config,\n docPermissions,\n globalConfig,\n routeSegments,\n}: {\n collectionConfig?: SanitizedCollectionConfig\n config: SanitizedConfig\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n docPermissions: CollectionPermission | GlobalPermission\n globalConfig?: SanitizedGlobalConfig\n routeSegments: string[]\n}): {\n CustomView: EditViewComponent\n DefaultView: EditViewComponent\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: AdminViewComponent\n} | null => {\n // Conditionally import and lazy load the default view\n let DefaultView: EditViewComponent = null\n let CustomView: EditViewComponent = null\n let ErrorView: AdminViewComponent = 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 // `../: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 = getCustomViewByKey(views, 'Default')\n DefaultView = DefaultEditView\n } else {\n ErrorView = UnauthorizedView\n }\n break\n }\n\n default: {\n if (docPermissions?.read?.permission) {\n CustomView = getCustomViewByKey(views, 'Default')\n DefaultView = DefaultEditView\n } else {\n ErrorView = UnauthorizedView\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 = 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 } else {\n ErrorView = UnauthorizedView\n }\n break\n }\n\n default: {\n const baseRoute = [adminRoute, 'collections', collectionSlug, segment3]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment4, segment5, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\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 = getCustomViewByKey(views, 'Version')\n DefaultView = DefaultVersionView\n } else {\n ErrorView = UnauthorizedView\n }\n } else {\n const baseRoute = [adminRoute, collectionEntity, collectionSlug, segment3]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment4, segment5, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n })\n }\n break\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 // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const [globalEntity, globalSlug, segment3, ...remainingSegments] = routeSegments\n\n switch (routeSegments.length) {\n case 2: {\n if (docPermissions?.read?.permission) {\n CustomView = getCustomViewByKey(views, 'Default')\n DefaultView = DefaultEditView\n } else {\n ErrorView = UnauthorizedView\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 = 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 } else {\n ErrorView = UnauthorizedView\n }\n break\n }\n\n default: {\n if (docPermissions?.read?.permission) {\n CustomView = getCustomViewByKey(views, 'Default')\n DefaultView = DefaultEditView\n } else {\n ErrorView = UnauthorizedView\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 = getCustomViewByKey(views, 'Version')\n DefaultView = DefaultVersionView\n } else {\n ErrorView = UnauthorizedView\n }\n } else {\n const baseRoute = [adminRoute, 'globals', globalSlug].filter(Boolean).join('/')\n\n const currentRoute = [baseRoute, segment3, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\n })\n }\n break\n }\n }\n }\n }\n\n return {\n CustomView,\n DefaultView,\n ErrorView,\n }\n}\n"],"names":["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","length","create","permission","read","hideAPIURL","readVersions","baseRoute","filter","Boolean","join","currentRoute","globalEntity","globalSlug"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../../src/views/Document/getViewsFromConfig.tsx"],"sourcesContent":["import type { CollectionPermission, GlobalPermission } from 'payload/auth'\nimport type { EditViewComponent } from 'payload/config'\nimport type {\n AdminViewComponent,\n SanitizedCollectionConfig,\n SanitizedConfig,\n SanitizedGlobalConfig,\n} from 'payload/types'\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 const getViewsFromConfig = ({\n collectionConfig,\n config,\n docPermissions,\n globalConfig,\n routeSegments,\n}: {\n collectionConfig?: SanitizedCollectionConfig\n config: SanitizedConfig\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n docPermissions: CollectionPermission | GlobalPermission\n globalConfig?: SanitizedGlobalConfig\n routeSegments: string[]\n}): {\n CustomView: EditViewComponent\n DefaultView: EditViewComponent\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: AdminViewComponent\n} | null => {\n // Conditionally import and lazy load the default view\n let DefaultView: EditViewComponent = null\n let CustomView: EditViewComponent = null\n let ErrorView: AdminViewComponent = 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 = getCustomViewByKey(views, 'Default')\n DefaultView = DefaultEditView\n } else {\n ErrorView = UnauthorizedView\n }\n break\n }\n\n default: {\n CustomView = getCustomViewByKey(views, 'Default')\n DefaultView = DefaultEditView\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 = 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 } else {\n ErrorView = UnauthorizedView\n }\n break\n }\n\n default: {\n const baseRoute = [adminRoute, 'collections', collectionSlug, segment3]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment4, segment5, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\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 = getCustomViewByKey(views, 'Version')\n DefaultView = DefaultVersionView\n } else {\n ErrorView = UnauthorizedView\n }\n } else {\n const baseRoute = [adminRoute, collectionEntity, collectionSlug, segment3]\n .filter(Boolean)\n .join('/')\n\n const currentRoute = [baseRoute, segment4, segment5, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\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 // eslint-disable-next-line @typescript-eslint/no-unused-vars\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 = getCustomViewByKey(views, 'Default')\n DefaultView = DefaultEditView\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 = 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 } else {\n ErrorView = UnauthorizedView\n }\n break\n }\n\n default: {\n if (docPermissions?.read?.permission) {\n CustomView = getCustomViewByKey(views, 'Default')\n DefaultView = DefaultEditView\n } else {\n ErrorView = UnauthorizedView\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 = getCustomViewByKey(views, 'Version')\n DefaultView = DefaultVersionView\n } else {\n ErrorView = UnauthorizedView\n }\n } else {\n const baseRoute = [adminRoute, 'globals', globalSlug].filter(Boolean).join('/')\n\n const currentRoute = [baseRoute, segment3, ...remainingSegments]\n .filter(Boolean)\n .join('/')\n\n CustomView = getCustomViewByRoute({\n baseRoute,\n currentRoute,\n views,\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","hideAPIURL","readVersions","baseRoute","filter","Boolean","join","currentRoute","globalEntity","globalSlug"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Document/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAUnD,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAA;AAQrE,eAAO,MAAM,gBAAgB,EAAE,wBAAiE,CAAA;AAEhG,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAoN7C,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Document/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAUnD,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAA;AAQrE,eAAO,MAAM,gBAAgB,EAAE,wBAAiE,CAAA;AAEhG,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAqN7C,CAAA"}
@@ -30,12 +30,11 @@ export const Document = async ({ initPageResult, params, searchParams })=>{
30
30
  let ErrorView;
31
31
  let apiURL;
32
32
  let action;
33
- const data = await getDocumentData({
33
+ const { data, formState } = await getDocumentData({
34
34
  id,
35
35
  collectionConfig,
36
36
  globalConfig,
37
37
  locale,
38
- payload,
39
38
  req
40
39
  });
41
40
  const { docPermissions, hasPublishPermission, hasSavePermission } = await getDocumentPermissions({
@@ -129,6 +128,8 @@ export const Document = async ({ initPageResult, params, searchParams })=>{
129
128
  hasPublishPermission: hasPublishPermission,
130
129
  hasSavePermission: hasSavePermission,
131
130
  id: id,
131
+ initialData: data,
132
+ initialState: formState,
132
133
  isEditing: isEditing,
133
134
  children: [
134
135
  !ViewOverride && /*#__PURE__*/ _jsx(DocumentHeader, {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/views/Document/index.tsx"],"sourcesContent":["import type { EditViewComponent } from 'payload/config'\nimport type { AdminViewComponent, ServerSideEditViewProps } from 'payload/types'\nimport type { AdminViewProps } from 'payload/types'\n\nimport { DocumentHeader } from '@payloadcms/ui/elements/DocumentHeader'\nimport { HydrateClientUser } from '@payloadcms/ui/elements/HydrateClientUser'\nimport { RenderCustomComponent } from '@payloadcms/ui/elements/RenderCustomComponent'\nimport { DocumentInfoProvider } from '@payloadcms/ui/providers/DocumentInfo'\nimport { EditDepthProvider } from '@payloadcms/ui/providers/EditDepth'\nimport { FormQueryParamsProvider } from '@payloadcms/ui/providers/FormQueryParams'\nimport { isEditing as getIsEditing } from '@payloadcms/ui/utilities/isEditing'\nimport { notFound, redirect } from 'next/navigation.js'\nimport React from 'react'\n\nimport type { GenerateEditViewMetadata } from './getMetaBySegment.js'\n\nimport { NotFoundView } from '../NotFound/index.js'\nimport { getDocumentData } from './getDocumentData.js'\nimport { getDocumentPermissions } from './getDocumentPermissions.js'\nimport { getMetaBySegment } from './getMetaBySegment.js'\nimport { getViewsFromConfig } from './getViewsFromConfig.js'\n\nexport const generateMetadata: GenerateEditViewMetadata = async (args) => getMetaBySegment(args)\n\nexport const Document: React.FC<AdminViewProps> = async ({\n initPageResult,\n params,\n searchParams,\n}) => {\n const {\n collectionConfig,\n docID: id,\n globalConfig,\n locale,\n permissions,\n req,\n req: {\n i18n,\n payload,\n payload: {\n config,\n config: {\n routes: { 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\n const isEditing = getIsEditing({ id, collectionSlug, globalSlug })\n\n let ViewOverride: EditViewComponent\n let CustomView: EditViewComponent\n let DefaultView: EditViewComponent\n let ErrorView: AdminViewComponent\n\n let apiURL: string\n let action: string\n\n const data = await getDocumentData({\n id,\n collectionConfig,\n globalConfig,\n locale,\n payload,\n req,\n })\n\n const { docPermissions, hasPublishPermission, hasSavePermission } = await getDocumentPermissions({\n id,\n collectionConfig,\n data,\n globalConfig,\n req,\n })\n\n if (collectionConfig) {\n if (!visibleEntities?.collections?.find((visibleSlug) => visibleSlug === collectionSlug)) {\n notFound()\n }\n\n action = `${serverURL}${apiRoute}/${collectionSlug}${isEditing ? `/${id}` : ''}`\n\n apiURL = `${serverURL}${apiRoute}/${collectionSlug}/${id}?locale=${locale.code}${\n collectionConfig.versions?.drafts ? '&draft=true' : ''\n }`\n\n const editConfig = collectionConfig?.admin?.components?.views?.Edit\n ViewOverride = typeof editConfig === 'function' ? editConfig : null\n\n if (!ViewOverride) {\n const collectionViews = getViewsFromConfig({\n collectionConfig,\n config,\n docPermissions,\n routeSegments: segments,\n })\n\n CustomView = collectionViews?.CustomView\n DefaultView = collectionViews?.DefaultView\n ErrorView = collectionViews?.ErrorView\n }\n\n if (!CustomView && !DefaultView && !ViewOverride && !ErrorView) {\n ErrorView = NotFoundView\n }\n }\n\n if (globalConfig) {\n if (!visibleEntities?.globals?.find((visibleSlug) => visibleSlug === globalSlug)) {\n notFound()\n }\n\n action = `${serverURL}${apiRoute}/globals/${globalSlug}`\n\n apiURL = `${serverURL}${apiRoute}/${globalSlug}?locale=${locale.code}${\n globalConfig.versions?.drafts ? '&draft=true' : ''\n }`\n\n const editConfig = globalConfig?.admin?.components?.views?.Edit\n ViewOverride = typeof editConfig === 'function' ? editConfig : null\n\n if (!ViewOverride) {\n const globalViews = getViewsFromConfig({\n config,\n docPermissions,\n globalConfig,\n routeSegments: segments,\n })\n\n CustomView = globalViews?.CustomView\n DefaultView = globalViews?.DefaultView\n ErrorView = globalViews?.ErrorView\n\n if (!CustomView && !DefaultView && !ViewOverride && !ErrorView) {\n ErrorView = NotFoundView\n }\n }\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 if (shouldAutosave && !id && collectionSlug) {\n const doc = await payload.create({\n collection: collectionSlug,\n data: {},\n depth: 0,\n draft: true,\n fallbackLocale: null,\n locale: locale.code,\n req,\n user,\n })\n\n if (doc?.id) {\n const redirectURL = `${serverURL}${adminRoute}/collections/${collectionSlug}/${doc.id}`\n redirect(redirectURL)\n } else {\n notFound()\n }\n }\n\n const viewComponentProps: ServerSideEditViewProps = {\n initPageResult,\n params,\n routeSegments: segments,\n searchParams,\n }\n\n return (\n <DocumentInfoProvider\n action={action}\n apiURL={apiURL}\n collectionSlug={collectionConfig?.slug}\n disableActions={false}\n docPermissions={docPermissions}\n globalSlug={globalConfig?.slug}\n hasPublishPermission={hasPublishPermission}\n hasSavePermission={hasSavePermission}\n id={id}\n isEditing={isEditing}\n >\n {!ViewOverride && (\n <DocumentHeader\n collectionConfig={collectionConfig}\n config={payload.config}\n globalConfig={globalConfig}\n i18n={i18n}\n permissions={permissions}\n />\n )}\n <HydrateClientUser permissions={permissions} user={user} />\n <EditDepthProvider depth={1} key={`${collectionSlug || globalSlug}-${locale.code}`}>\n <FormQueryParamsProvider\n initialParams={{\n depth: 0,\n 'fallback-locale': 'null',\n locale: locale.code,\n uploadEdits: undefined,\n }}\n >\n {ErrorView ? (\n <ErrorView initPageResult={initPageResult} searchParams={searchParams} />\n ) : (\n <RenderCustomComponent\n CustomComponent={ViewOverride || CustomView}\n DefaultComponent={DefaultView}\n componentProps={viewComponentProps}\n serverOnlyProps={{\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user,\n }}\n />\n )}\n </FormQueryParamsProvider>\n </EditDepthProvider>\n </DocumentInfoProvider>\n )\n}\n"],"names":["DocumentHeader","HydrateClientUser","RenderCustomComponent","DocumentInfoProvider","EditDepthProvider","FormQueryParamsProvider","isEditing","getIsEditing","notFound","redirect","React","NotFoundView","getDocumentData","getDocumentPermissions","getMetaBySegment","getViewsFromConfig","generateMetadata","args","Document","initPageResult","params","searchParams","collectionConfig","docID","id","globalConfig","locale","permissions","req","i18n","payload","config","routes","admin","adminRoute","api","apiRoute","serverURL","user","visibleEntities","segments","Array","isArray","collectionSlug","slug","undefined","globalSlug","ViewOverride","CustomView","DefaultView","ErrorView","apiURL","action","data","docPermissions","hasPublishPermission","hasSavePermission","collections","find","visibleSlug","code","versions","drafts","editConfig","components","views","Edit","collectionViews","routeSegments","globals","globalViews","shouldAutosave","autosave","doc","create","collection","depth","draft","fallbackLocale","redirectURL","viewComponentProps","disableActions","initialParams","uploadEdits","CustomComponent","DefaultComponent","componentProps","serverOnlyProps"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
1
+ {"version":3,"sources":["../../../src/views/Document/index.tsx"],"sourcesContent":["import type { EditViewComponent } from 'payload/config'\nimport type { AdminViewComponent, ServerSideEditViewProps } from 'payload/types'\nimport type { AdminViewProps } from 'payload/types'\n\nimport { DocumentHeader } from '@payloadcms/ui/elements/DocumentHeader'\nimport { HydrateClientUser } from '@payloadcms/ui/elements/HydrateClientUser'\nimport { RenderCustomComponent } from '@payloadcms/ui/elements/RenderCustomComponent'\nimport { DocumentInfoProvider } from '@payloadcms/ui/providers/DocumentInfo'\nimport { EditDepthProvider } from '@payloadcms/ui/providers/EditDepth'\nimport { FormQueryParamsProvider } from '@payloadcms/ui/providers/FormQueryParams'\nimport { isEditing as getIsEditing } from '@payloadcms/ui/utilities/isEditing'\nimport { notFound, redirect } from 'next/navigation.js'\nimport React from 'react'\n\nimport type { GenerateEditViewMetadata } from './getMetaBySegment.js'\n\nimport { NotFoundView } from '../NotFound/index.js'\nimport { getDocumentData } from './getDocumentData.js'\nimport { getDocumentPermissions } from './getDocumentPermissions.js'\nimport { getMetaBySegment } from './getMetaBySegment.js'\nimport { getViewsFromConfig } from './getViewsFromConfig.js'\n\nexport const generateMetadata: GenerateEditViewMetadata = async (args) => getMetaBySegment(args)\n\nexport const Document: React.FC<AdminViewProps> = async ({\n initPageResult,\n params,\n searchParams,\n}) => {\n const {\n collectionConfig,\n docID: id,\n globalConfig,\n locale,\n permissions,\n req,\n req: {\n i18n,\n payload,\n payload: {\n config,\n config: {\n routes: { 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\n const isEditing = getIsEditing({ id, collectionSlug, globalSlug })\n\n let ViewOverride: EditViewComponent\n let CustomView: EditViewComponent\n let DefaultView: EditViewComponent\n let ErrorView: AdminViewComponent\n\n let apiURL: string\n let action: string\n\n const { data, formState } = await getDocumentData({\n id,\n collectionConfig,\n globalConfig,\n locale,\n req,\n })\n\n const { docPermissions, hasPublishPermission, hasSavePermission } = await getDocumentPermissions({\n id,\n collectionConfig,\n data,\n globalConfig,\n req,\n })\n\n if (collectionConfig) {\n if (!visibleEntities?.collections?.find((visibleSlug) => visibleSlug === collectionSlug)) {\n notFound()\n }\n\n action = `${serverURL}${apiRoute}/${collectionSlug}${isEditing ? `/${id}` : ''}`\n\n apiURL = `${serverURL}${apiRoute}/${collectionSlug}/${id}?locale=${locale.code}${\n collectionConfig.versions?.drafts ? '&draft=true' : ''\n }`\n\n const editConfig = collectionConfig?.admin?.components?.views?.Edit\n ViewOverride = typeof editConfig === 'function' ? editConfig : null\n\n if (!ViewOverride) {\n const collectionViews = getViewsFromConfig({\n collectionConfig,\n config,\n docPermissions,\n routeSegments: segments,\n })\n\n CustomView = collectionViews?.CustomView\n DefaultView = collectionViews?.DefaultView\n ErrorView = collectionViews?.ErrorView\n }\n\n if (!CustomView && !DefaultView && !ViewOverride && !ErrorView) {\n ErrorView = NotFoundView\n }\n }\n\n if (globalConfig) {\n if (!visibleEntities?.globals?.find((visibleSlug) => visibleSlug === globalSlug)) {\n notFound()\n }\n\n action = `${serverURL}${apiRoute}/globals/${globalSlug}`\n\n apiURL = `${serverURL}${apiRoute}/${globalSlug}?locale=${locale.code}${\n globalConfig.versions?.drafts ? '&draft=true' : ''\n }`\n\n const editConfig = globalConfig?.admin?.components?.views?.Edit\n ViewOverride = typeof editConfig === 'function' ? editConfig : null\n\n if (!ViewOverride) {\n const globalViews = getViewsFromConfig({\n config,\n docPermissions,\n globalConfig,\n routeSegments: segments,\n })\n\n CustomView = globalViews?.CustomView\n DefaultView = globalViews?.DefaultView\n ErrorView = globalViews?.ErrorView\n\n if (!CustomView && !DefaultView && !ViewOverride && !ErrorView) {\n ErrorView = NotFoundView\n }\n }\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 if (shouldAutosave && !id && collectionSlug) {\n const doc = await payload.create({\n collection: collectionSlug,\n data: {},\n depth: 0,\n draft: true,\n fallbackLocale: null,\n locale: locale.code,\n req,\n user,\n })\n\n if (doc?.id) {\n const redirectURL = `${serverURL}${adminRoute}/collections/${collectionSlug}/${doc.id}`\n redirect(redirectURL)\n } else {\n notFound()\n }\n }\n\n const viewComponentProps: ServerSideEditViewProps = {\n initPageResult,\n params,\n routeSegments: segments,\n searchParams,\n }\n\n return (\n <DocumentInfoProvider\n action={action}\n apiURL={apiURL}\n collectionSlug={collectionConfig?.slug}\n disableActions={false}\n docPermissions={docPermissions}\n globalSlug={globalConfig?.slug}\n hasPublishPermission={hasPublishPermission}\n hasSavePermission={hasSavePermission}\n id={id}\n initialData={data}\n initialState={formState}\n isEditing={isEditing}\n >\n {!ViewOverride && (\n <DocumentHeader\n collectionConfig={collectionConfig}\n config={payload.config}\n globalConfig={globalConfig}\n i18n={i18n}\n permissions={permissions}\n />\n )}\n <HydrateClientUser permissions={permissions} user={user} />\n <EditDepthProvider depth={1} key={`${collectionSlug || globalSlug}-${locale.code}`}>\n <FormQueryParamsProvider\n initialParams={{\n depth: 0,\n 'fallback-locale': 'null',\n locale: locale.code,\n uploadEdits: undefined,\n }}\n >\n {ErrorView ? (\n <ErrorView initPageResult={initPageResult} searchParams={searchParams} />\n ) : (\n <RenderCustomComponent\n CustomComponent={ViewOverride || CustomView}\n DefaultComponent={DefaultView}\n componentProps={viewComponentProps}\n serverOnlyProps={{\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user,\n }}\n />\n )}\n </FormQueryParamsProvider>\n </EditDepthProvider>\n </DocumentInfoProvider>\n )\n}\n"],"names":["DocumentHeader","HydrateClientUser","RenderCustomComponent","DocumentInfoProvider","EditDepthProvider","FormQueryParamsProvider","isEditing","getIsEditing","notFound","redirect","React","NotFoundView","getDocumentData","getDocumentPermissions","getMetaBySegment","getViewsFromConfig","generateMetadata","args","Document","initPageResult","params","searchParams","collectionConfig","docID","id","globalConfig","locale","permissions","req","i18n","payload","config","routes","admin","adminRoute","api","apiRoute","serverURL","user","visibleEntities","segments","Array","isArray","collectionSlug","slug","undefined","globalSlug","ViewOverride","CustomView","DefaultView","ErrorView","apiURL","action","data","formState","docPermissions","hasPublishPermission","hasSavePermission","collections","find","visibleSlug","code","versions","drafts","editConfig","components","views","Edit","collectionViews","routeSegments","globals","globalViews","shouldAutosave","autosave","doc","create","collection","depth","draft","fallbackLocale","redirectURL","viewComponentProps","disableActions","initialData","initialState","initialParams","uploadEdits","CustomComponent","DefaultComponent","componentProps","serverOnlyProps"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -18,7 +18,7 @@ export const APIKey = ({ enabled, readOnly })=>{
18
18
  const [highlightedField, setHighlightedField] = useState(false);
19
19
  const { t } = useTranslation();
20
20
  const config = useConfig();
21
- const apiKey = useFormFields(([fields])=>fields[path]);
21
+ const apiKey = useFormFields(([fields])=>fields && fields[path] || null);
22
22
  const validate = (val)=>text(val, {
23
23
  name: 'apiKey',
24
24
  type: 'text',
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/views/Edit/Default/Auth/APIKey.tsx"],"sourcesContent":["'use client'\nimport type { PayloadRequestWithData } from 'payload/types'\n\nimport { CopyToClipboard } from '@payloadcms/ui/elements/CopyToClipboard'\nimport { GenerateConfirmation } from '@payloadcms/ui/elements/GenerateConfirmation'\nimport { FieldLabel } from '@payloadcms/ui/forms/FieldLabel'\nimport { useFormFields } from '@payloadcms/ui/forms/Form'\nimport { useField } from '@payloadcms/ui/forms/useField'\nimport { useConfig } from '@payloadcms/ui/providers/Config'\nimport { useTranslation } from '@payloadcms/ui/providers/Translation'\nimport { text } from 'payload/fields/validations'\nimport React, { useEffect, useMemo, useState } from 'react'\nimport { v4 as uuidv4 } from 'uuid'\n\nconst path = 'apiKey'\nconst baseClass = 'api-key'\nconst fieldBaseClass = 'field-type'\n\nexport const APIKey: React.FC<{ enabled: boolean; readOnly?: boolean }> = ({\n enabled,\n readOnly,\n}) => {\n const [initialAPIKey] = useState(uuidv4())\n const [highlightedField, setHighlightedField] = useState(false)\n const { t } = useTranslation()\n const config = useConfig()\n\n const apiKey = useFormFields(([fields]) => fields[path])\n\n const validate = (val) =>\n text(val, {\n name: 'apiKey',\n type: 'text',\n data: {},\n maxLength: 48,\n minLength: 24,\n preferences: { fields: {} },\n req: {\n payload: {\n config,\n },\n t,\n } as PayloadRequestWithData,\n siblingData: {},\n })\n\n const apiKeyValue = apiKey?.value\n\n const APIKeyLabel = useMemo(\n () => (\n <div className={`${baseClass}__label`}>\n <span>API Key</span>\n <CopyToClipboard value={apiKeyValue as string} />\n </div>\n ),\n [apiKeyValue],\n )\n\n const fieldType = useField({\n path: 'apiKey',\n validate,\n })\n\n const highlightField = () => {\n if (highlightedField) {\n setHighlightedField(false)\n }\n setTimeout(() => {\n setHighlightedField(true)\n }, 1)\n }\n\n const { setValue, value } = fieldType\n\n useEffect(() => {\n if (!apiKeyValue && enabled) {\n setValue(initialAPIKey)\n }\n if (!enabled) {\n setValue(null)\n }\n }, [apiKeyValue, enabled, setValue, initialAPIKey])\n\n useEffect(() => {\n if (highlightedField) {\n setTimeout(() => {\n setHighlightedField(false)\n }, 10000)\n }\n }, [highlightedField])\n\n if (!enabled) {\n return null\n }\n\n return (\n <React.Fragment>\n <div className={[fieldBaseClass, 'api-key', 'read-only'].filter(Boolean).join(' ')}>\n <FieldLabel CustomLabel={APIKeyLabel} htmlFor={path} />\n <input\n className={highlightedField ? 'highlight' : undefined}\n disabled\n id=\"apiKey\"\n name=\"apiKey\"\n type=\"text\"\n value={(value as string) || ''}\n />\n </div>\n {!readOnly && (\n <GenerateConfirmation highlightField={highlightField} setKey={() => setValue(uuidv4())} />\n )}\n </React.Fragment>\n )\n}\n"],"names":["CopyToClipboard","GenerateConfirmation","FieldLabel","useFormFields","useField","useConfig","useTranslation","text","React","useEffect","useMemo","useState","v4","uuidv4","path","baseClass","fieldBaseClass","APIKey","enabled","readOnly","initialAPIKey","highlightedField","setHighlightedField","t","config","apiKey","fields","validate","val","name","type","data","maxLength","minLength","preferences","req","payload","siblingData","apiKeyValue","value","APIKeyLabel","div","className","span","fieldType","highlightField","setTimeout","setValue","Fragment","filter","Boolean","join","CustomLabel","htmlFor","input","undefined","disabled","id","setKey"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA;;AAGA,SAASA,eAAe,QAAQ,0CAAyC;AACzE,SAASC,oBAAoB,QAAQ,+CAA8C;AACnF,SAASC,UAAU,QAAQ,kCAAiC;AAC5D,SAASC,aAAa,QAAQ,4BAA2B;AACzD,SAASC,QAAQ,QAAQ,gCAA+B;AACxD,SAASC,SAAS,QAAQ,kCAAiC;AAC3D,SAASC,cAAc,QAAQ,uCAAsC;AACrE,SAASC,IAAI,QAAQ,6BAA4B;AACjD,OAAOC,SAASC,SAAS,EAAEC,OAAO,EAAEC,QAAQ,QAAQ,QAAO;AAC3D,SAASC,MAAMC,MAAM,QAAQ,OAAM;AAEnC,MAAMC,OAAO;AACb,MAAMC,YAAY;AAClB,MAAMC,iBAAiB;AAEvB,OAAO,MAAMC,SAA6D,CAAC,EACzEC,OAAO,EACPC,QAAQ,EACT;IACC,MAAM,CAACC,cAAc,GAAGT,SAASE;IACjC,MAAM,CAACQ,kBAAkBC,oBAAoB,GAAGX,SAAS;IACzD,MAAM,EAAEY,CAAC,EAAE,GAAGjB;IACd,MAAMkB,SAASnB;IAEf,MAAMoB,SAAStB,cAAc,CAAC,CAACuB,OAAO,GAAKA,MAAM,CAACZ,KAAK;IAEvD,MAAMa,WAAW,CAACC,MAChBrB,KAAKqB,KAAK;YACRC,MAAM;YACNC,MAAM;YACNC,MAAM,CAAC;YACPC,WAAW;YACXC,WAAW;YACXC,aAAa;gBAAER,QAAQ,CAAC;YAAE;YAC1BS,KAAK;gBACHC,SAAS;oBACPZ;gBACF;gBACAD;YACF;YACAc,aAAa,CAAC;QAChB;IAEF,MAAMC,cAAcb,QAAQc;IAE5B,MAAMC,cAAc9B,QAClB,kBACE,MAAC+B;YAAIC,WAAW,CAAC,EAAE3B,UAAU,OAAO,CAAC;;8BACnC,KAAC4B;8BAAK;;8BACN,KAAC3C;oBAAgBuC,OAAOD;;;YAG5B;QAACA;KAAY;IAGf,MAAMM,YAAYxC,SAAS;QACzBU,MAAM;QACNa;IACF;IAEA,MAAMkB,iBAAiB;QACrB,IAAIxB,kBAAkB;YACpBC,oBAAoB;QACtB;QACAwB,WAAW;YACTxB,oBAAoB;QACtB,GAAG;IACL;IAEA,MAAM,EAAEyB,QAAQ,EAAER,KAAK,EAAE,GAAGK;IAE5BnC,UAAU;QACR,IAAI,CAAC6B,eAAepB,SAAS;YAC3B6B,SAAS3B;QACX;QACA,IAAI,CAACF,SAAS;YACZ6B,SAAS;QACX;IACF,GAAG;QAACT;QAAapB;QAAS6B;QAAU3B;KAAc;IAElDX,UAAU;QACR,IAAIY,kBAAkB;YACpByB,WAAW;gBACTxB,oBAAoB;YACtB,GAAG;QACL;IACF,GAAG;QAACD;KAAiB;IAErB,IAAI,CAACH,SAAS;QACZ,OAAO;IACT;IAEA,qBACE,MAACV,MAAMwC,QAAQ;;0BACb,MAACP;gBAAIC,WAAW;oBAAC1B;oBAAgB;oBAAW;iBAAY,CAACiC,MAAM,CAACC,SAASC,IAAI,CAAC;;kCAC5E,KAACjD;wBAAWkD,aAAaZ;wBAAaa,SAASvC;;kCAC/C,KAACwC;wBACCZ,WAAWrB,mBAAmB,cAAckC;wBAC5CC,QAAQ;wBACRC,IAAG;wBACH5B,MAAK;wBACLC,MAAK;wBACLS,OAAO,AAACA,SAAoB;;;;YAG/B,CAACpB,0BACA,KAAClB;gBAAqB4C,gBAAgBA;gBAAgBa,QAAQ,IAAMX,SAASlC;;;;AAIrF,EAAC"}
1
+ {"version":3,"sources":["../../../../../src/views/Edit/Default/Auth/APIKey.tsx"],"sourcesContent":["'use client'\nimport type { PayloadRequestWithData } from 'payload/types'\n\nimport { CopyToClipboard } from '@payloadcms/ui/elements/CopyToClipboard'\nimport { GenerateConfirmation } from '@payloadcms/ui/elements/GenerateConfirmation'\nimport { FieldLabel } from '@payloadcms/ui/forms/FieldLabel'\nimport { useFormFields } from '@payloadcms/ui/forms/Form'\nimport { useField } from '@payloadcms/ui/forms/useField'\nimport { useConfig } from '@payloadcms/ui/providers/Config'\nimport { useTranslation } from '@payloadcms/ui/providers/Translation'\nimport { text } from 'payload/fields/validations'\nimport React, { useEffect, useMemo, useState } from 'react'\nimport { v4 as uuidv4 } from 'uuid'\n\nconst path = 'apiKey'\nconst baseClass = 'api-key'\nconst fieldBaseClass = 'field-type'\n\nexport const APIKey: React.FC<{ enabled: boolean; readOnly?: boolean }> = ({\n enabled,\n readOnly,\n}) => {\n const [initialAPIKey] = useState(uuidv4())\n const [highlightedField, setHighlightedField] = useState(false)\n const { t } = useTranslation()\n const config = useConfig()\n\n const apiKey = useFormFields(([fields]) => (fields && fields[path]) || null)\n\n const validate = (val) =>\n text(val, {\n name: 'apiKey',\n type: 'text',\n data: {},\n maxLength: 48,\n minLength: 24,\n preferences: { fields: {} },\n req: {\n payload: {\n config,\n },\n t,\n } as PayloadRequestWithData,\n siblingData: {},\n })\n\n const apiKeyValue = apiKey?.value\n\n const APIKeyLabel = useMemo(\n () => (\n <div className={`${baseClass}__label`}>\n <span>API Key</span>\n <CopyToClipboard value={apiKeyValue as string} />\n </div>\n ),\n [apiKeyValue],\n )\n\n const fieldType = useField({\n path: 'apiKey',\n validate,\n })\n\n const highlightField = () => {\n if (highlightedField) {\n setHighlightedField(false)\n }\n setTimeout(() => {\n setHighlightedField(true)\n }, 1)\n }\n\n const { setValue, value } = fieldType\n\n useEffect(() => {\n if (!apiKeyValue && enabled) {\n setValue(initialAPIKey)\n }\n if (!enabled) {\n setValue(null)\n }\n }, [apiKeyValue, enabled, setValue, initialAPIKey])\n\n useEffect(() => {\n if (highlightedField) {\n setTimeout(() => {\n setHighlightedField(false)\n }, 10000)\n }\n }, [highlightedField])\n\n if (!enabled) {\n return null\n }\n\n return (\n <React.Fragment>\n <div className={[fieldBaseClass, 'api-key', 'read-only'].filter(Boolean).join(' ')}>\n <FieldLabel CustomLabel={APIKeyLabel} htmlFor={path} />\n <input\n className={highlightedField ? 'highlight' : undefined}\n disabled\n id=\"apiKey\"\n name=\"apiKey\"\n type=\"text\"\n value={(value as string) || ''}\n />\n </div>\n {!readOnly && (\n <GenerateConfirmation highlightField={highlightField} setKey={() => setValue(uuidv4())} />\n )}\n </React.Fragment>\n )\n}\n"],"names":["CopyToClipboard","GenerateConfirmation","FieldLabel","useFormFields","useField","useConfig","useTranslation","text","React","useEffect","useMemo","useState","v4","uuidv4","path","baseClass","fieldBaseClass","APIKey","enabled","readOnly","initialAPIKey","highlightedField","setHighlightedField","t","config","apiKey","fields","validate","val","name","type","data","maxLength","minLength","preferences","req","payload","siblingData","apiKeyValue","value","APIKeyLabel","div","className","span","fieldType","highlightField","setTimeout","setValue","Fragment","filter","Boolean","join","CustomLabel","htmlFor","input","undefined","disabled","id","setKey"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA;;AAGA,SAASA,eAAe,QAAQ,0CAAyC;AACzE,SAASC,oBAAoB,QAAQ,+CAA8C;AACnF,SAASC,UAAU,QAAQ,kCAAiC;AAC5D,SAASC,aAAa,QAAQ,4BAA2B;AACzD,SAASC,QAAQ,QAAQ,gCAA+B;AACxD,SAASC,SAAS,QAAQ,kCAAiC;AAC3D,SAASC,cAAc,QAAQ,uCAAsC;AACrE,SAASC,IAAI,QAAQ,6BAA4B;AACjD,OAAOC,SAASC,SAAS,EAAEC,OAAO,EAAEC,QAAQ,QAAQ,QAAO;AAC3D,SAASC,MAAMC,MAAM,QAAQ,OAAM;AAEnC,MAAMC,OAAO;AACb,MAAMC,YAAY;AAClB,MAAMC,iBAAiB;AAEvB,OAAO,MAAMC,SAA6D,CAAC,EACzEC,OAAO,EACPC,QAAQ,EACT;IACC,MAAM,CAACC,cAAc,GAAGT,SAASE;IACjC,MAAM,CAACQ,kBAAkBC,oBAAoB,GAAGX,SAAS;IACzD,MAAM,EAAEY,CAAC,EAAE,GAAGjB;IACd,MAAMkB,SAASnB;IAEf,MAAMoB,SAAStB,cAAc,CAAC,CAACuB,OAAO,GAAK,AAACA,UAAUA,MAAM,CAACZ,KAAK,IAAK;IAEvE,MAAMa,WAAW,CAACC,MAChBrB,KAAKqB,KAAK;YACRC,MAAM;YACNC,MAAM;YACNC,MAAM,CAAC;YACPC,WAAW;YACXC,WAAW;YACXC,aAAa;gBAAER,QAAQ,CAAC;YAAE;YAC1BS,KAAK;gBACHC,SAAS;oBACPZ;gBACF;gBACAD;YACF;YACAc,aAAa,CAAC;QAChB;IAEF,MAAMC,cAAcb,QAAQc;IAE5B,MAAMC,cAAc9B,QAClB,kBACE,MAAC+B;YAAIC,WAAW,CAAC,EAAE3B,UAAU,OAAO,CAAC;;8BACnC,KAAC4B;8BAAK;;8BACN,KAAC3C;oBAAgBuC,OAAOD;;;YAG5B;QAACA;KAAY;IAGf,MAAMM,YAAYxC,SAAS;QACzBU,MAAM;QACNa;IACF;IAEA,MAAMkB,iBAAiB;QACrB,IAAIxB,kBAAkB;YACpBC,oBAAoB;QACtB;QACAwB,WAAW;YACTxB,oBAAoB;QACtB,GAAG;IACL;IAEA,MAAM,EAAEyB,QAAQ,EAAER,KAAK,EAAE,GAAGK;IAE5BnC,UAAU;QACR,IAAI,CAAC6B,eAAepB,SAAS;YAC3B6B,SAAS3B;QACX;QACA,IAAI,CAACF,SAAS;YACZ6B,SAAS;QACX;IACF,GAAG;QAACT;QAAapB;QAAS6B;QAAU3B;KAAc;IAElDX,UAAU;QACR,IAAIY,kBAAkB;YACpByB,WAAW;gBACTxB,oBAAoB;YACtB,GAAG;QACL;IACF,GAAG;QAACD;KAAiB;IAErB,IAAI,CAACH,SAAS;QACZ,OAAO;IACT;IAEA,qBACE,MAACV,MAAMwC,QAAQ;;0BACb,MAACP;gBAAIC,WAAW;oBAAC1B;oBAAgB;oBAAW;iBAAY,CAACiC,MAAM,CAACC,SAASC,IAAI,CAAC;;kCAC5E,KAACjD;wBAAWkD,aAAaZ;wBAAaa,SAASvC;;kCAC/C,KAACwC;wBACCZ,WAAWrB,mBAAmB,cAAckC;wBAC5CC,QAAQ;wBACRC,IAAG;wBACH5B,MAAK;wBACLC,MAAK;wBACLS,OAAO,AAACA,SAAoB;;;;YAG/B,CAACpB,0BACA,KAAClB;gBAAqB4C,gBAAgBA;gBAAgBa,QAAQ,IAAMX,SAASlC;;;;AAIrF,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/views/Edit/Default/Auth/index.tsx"],"names":[],"mappings":"AAUA,OAAO,KAA2C,MAAM,OAAO,CAAA;AAG/D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAGvC,OAAO,cAAc,CAAA;AAIrB,eAAO,MAAM,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CA6IhC,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/views/Edit/Default/Auth/index.tsx"],"names":[],"mappings":"AAWA,OAAO,KAA2C,MAAM,OAAO,CAAA;AAG/D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAGvC,OAAO,cAAc,CAAA;AAIrB,eAAO,MAAM,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAsJhC,CAAA"}