@payloadcms/next 3.0.0-beta.34 → 3.0.0-beta.36

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 (178) hide show
  1. package/dist/cjs/withPayload.cjs +23 -0
  2. package/dist/cjs/withPayload.cjs.map +1 -1
  3. package/dist/elements/LeaveWithoutSaving/index.js +35 -15
  4. package/dist/elements/LeaveWithoutSaving/index.js.map +1 -1
  5. package/dist/exports/views.d.ts +2 -1
  6. package/dist/exports/views.d.ts.map +1 -1
  7. package/dist/exports/views.js +2 -1
  8. package/dist/exports/views.js.map +1 -1
  9. package/dist/fetchAPI-multipart/index.js.map +1 -1
  10. package/dist/layouts/Root/index.d.ts.map +1 -1
  11. package/dist/layouts/Root/index.js +31 -15
  12. package/dist/layouts/Root/index.js.map +1 -1
  13. package/dist/prod/styles.css +1 -1
  14. package/dist/routes/rest/auth/access.d.ts.map +1 -1
  15. package/dist/routes/rest/auth/access.js +17 -7
  16. package/dist/routes/rest/auth/access.js.map +1 -1
  17. package/dist/routes/rest/og/image.js +64 -50
  18. package/dist/routes/rest/og/image.js.map +1 -1
  19. package/dist/routes/rest/og/index.js +2 -1
  20. package/dist/routes/rest/og/index.js.map +1 -1
  21. package/dist/utilities/getRequestLanguage.d.ts.map +1 -1
  22. package/dist/utilities/getRequestLanguage.js +1 -1
  23. package/dist/utilities/getRequestLanguage.js.map +1 -1
  24. package/dist/utilities/getRequestTheme.d.ts +11 -0
  25. package/dist/utilities/getRequestTheme.d.ts.map +1 -0
  26. package/dist/utilities/getRequestTheme.js +19 -0
  27. package/dist/utilities/getRequestTheme.js.map +1 -0
  28. package/dist/utilities/initPage/index.d.ts.map +1 -1
  29. package/dist/utilities/initPage/index.js +1 -0
  30. package/dist/utilities/initPage/index.js.map +1 -1
  31. package/dist/views/API/RenderJSON/index.js +99 -70
  32. package/dist/views/API/RenderJSON/index.js.map +1 -1
  33. package/dist/views/API/index.client.js +128 -91
  34. package/dist/views/API/index.client.js.map +1 -1
  35. package/dist/views/API/index.js +2 -1
  36. package/dist/views/API/index.js.map +1 -1
  37. package/dist/views/Account/Settings/index.js +27 -15
  38. package/dist/views/Account/Settings/index.js.map +1 -1
  39. package/dist/views/Account/ToggleTheme/index.js +2 -1
  40. package/dist/views/Account/ToggleTheme/index.js.map +1 -1
  41. package/dist/views/Account/index.d.ts.map +1 -1
  42. package/dist/views/Account/index.js +53 -39
  43. package/dist/views/Account/index.js.map +1 -1
  44. package/dist/views/CreateFirstUser/index.client.js +29 -19
  45. package/dist/views/CreateFirstUser/index.client.js.map +1 -1
  46. package/dist/views/CreateFirstUser/index.js +16 -6
  47. package/dist/views/CreateFirstUser/index.js.map +1 -1
  48. package/dist/views/Dashboard/Default/index.client.js +67 -56
  49. package/dist/views/Dashboard/Default/index.client.js.map +1 -1
  50. package/dist/views/Dashboard/Default/index.js +28 -19
  51. package/dist/views/Dashboard/Default/index.js.map +1 -1
  52. package/dist/views/Dashboard/index.js +23 -17
  53. package/dist/views/Dashboard/index.js.map +1 -1
  54. package/dist/views/Document/getDocumentData.d.ts +10 -0
  55. package/dist/views/Document/getDocumentData.d.ts.map +1 -0
  56. package/dist/views/Document/getDocumentData.js +24 -0
  57. package/dist/views/Document/getDocumentData.js.map +1 -0
  58. package/dist/views/Document/getDocumentPermissions.d.ts +14 -0
  59. package/dist/views/Document/getDocumentPermissions.d.ts.map +1 -0
  60. package/dist/views/Document/getDocumentPermissions.js +83 -0
  61. package/dist/views/Document/getDocumentPermissions.js.map +1 -0
  62. package/dist/views/Document/index.d.ts.map +1 -1
  63. package/dist/views/Document/index.js +63 -64
  64. package/dist/views/Document/index.js.map +1 -1
  65. package/dist/views/Edit/Default/Auth/APIKey.js +41 -25
  66. package/dist/views/Edit/Default/Auth/APIKey.js.map +1 -1
  67. package/dist/views/Edit/Default/Auth/index.js +78 -50
  68. package/dist/views/Edit/Default/Auth/index.js.map +1 -1
  69. package/dist/views/Edit/Default/index.d.ts.map +1 -1
  70. package/dist/views/Edit/Default/index.js +84 -65
  71. package/dist/views/Edit/Default/index.js.map +1 -1
  72. package/dist/views/Edit/index.client.js +10 -4
  73. package/dist/views/Edit/index.client.js.map +1 -1
  74. package/dist/views/Edit/index.js +2 -1
  75. package/dist/views/Edit/index.js.map +1 -1
  76. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js +42 -20
  77. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js.map +1 -1
  78. package/dist/views/ForgotPassword/index.js +37 -17
  79. package/dist/views/ForgotPassword/index.js.map +1 -1
  80. package/dist/views/List/Default/index.js +151 -81
  81. package/dist/views/List/Default/index.js.map +1 -1
  82. package/dist/views/List/index.js +52 -43
  83. package/dist/views/List/index.js.map +1 -1
  84. package/dist/views/LivePreview/Context/context.d.ts +1 -1
  85. package/dist/views/LivePreview/Context/context.d.ts.map +1 -1
  86. package/dist/views/LivePreview/Context/context.js.map +1 -1
  87. package/dist/views/LivePreview/Context/index.js +9 -6
  88. package/dist/views/LivePreview/Context/index.js.map +1 -1
  89. package/dist/views/LivePreview/Device/index.js +5 -3
  90. package/dist/views/LivePreview/Device/index.js.map +1 -1
  91. package/dist/views/LivePreview/DeviceContainer/index.js +5 -3
  92. package/dist/views/LivePreview/DeviceContainer/index.js.map +1 -1
  93. package/dist/views/LivePreview/IFrame/index.js +2 -1
  94. package/dist/views/LivePreview/IFrame/index.js.map +1 -1
  95. package/dist/views/LivePreview/Preview/index.js +25 -14
  96. package/dist/views/LivePreview/Preview/index.js.map +1 -1
  97. package/dist/views/LivePreview/Toolbar/Controls/index.js +105 -57
  98. package/dist/views/LivePreview/Toolbar/Controls/index.js.map +1 -1
  99. package/dist/views/LivePreview/Toolbar/SizeInput/index.js +2 -1
  100. package/dist/views/LivePreview/Toolbar/SizeInput/index.js.map +1 -1
  101. package/dist/views/LivePreview/Toolbar/index.js +29 -14
  102. package/dist/views/LivePreview/Toolbar/index.js.map +1 -1
  103. package/dist/views/LivePreview/ToolbarArea/index.js +5 -3
  104. package/dist/views/LivePreview/ToolbarArea/index.js.map +1 -1
  105. package/dist/views/LivePreview/index.client.d.ts.map +1 -1
  106. package/dist/views/LivePreview/index.client.js +103 -76
  107. package/dist/views/LivePreview/index.client.js.map +1 -1
  108. package/dist/views/LivePreview/index.js +2 -1
  109. package/dist/views/LivePreview/index.js.map +1 -1
  110. package/dist/views/Login/LoginForm/index.js +62 -48
  111. package/dist/views/Login/LoginForm/index.js.map +1 -1
  112. package/dist/views/Login/index.js +26 -19
  113. package/dist/views/Login/index.js.map +1 -1
  114. package/dist/views/Logout/LogoutClient.js +21 -7
  115. package/dist/views/Logout/LogoutClient.js.map +1 -1
  116. package/dist/views/Logout/index.js +13 -10
  117. package/dist/views/Logout/index.js.map +1 -1
  118. package/dist/views/NotFound/index.client.js +22 -10
  119. package/dist/views/NotFound/index.client.js.map +1 -1
  120. package/dist/views/NotFound/index.js +21 -14
  121. package/dist/views/NotFound/index.js.map +1 -1
  122. package/dist/views/ResetPassword/index.client.js +17 -8
  123. package/dist/views/ResetPassword/index.client.js.map +1 -1
  124. package/dist/views/ResetPassword/index.js +46 -25
  125. package/dist/views/ResetPassword/index.js.map +1 -1
  126. package/dist/views/Root/index.d.ts.map +1 -1
  127. package/dist/views/Root/index.js +29 -13
  128. package/dist/views/Root/index.js.map +1 -1
  129. package/dist/views/Unauthorized/index.js +19 -8
  130. package/dist/views/Unauthorized/index.js.map +1 -1
  131. package/dist/views/Verify/index.js +20 -11
  132. package/dist/views/Verify/index.js.map +1 -1
  133. package/dist/views/Version/Default/index.js +83 -57
  134. package/dist/views/Version/Default/index.js.map +1 -1
  135. package/dist/views/Version/RenderFieldsToDiff/Label/index.js +5 -3
  136. package/dist/views/Version/RenderFieldsToDiff/Label/index.js.map +1 -1
  137. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js +65 -50
  138. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js.map +1 -1
  139. package/dist/views/Version/RenderFieldsToDiff/fields/Nested/index.js +30 -18
  140. package/dist/views/Version/RenderFieldsToDiff/fields/Nested/index.js.map +1 -1
  141. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js +23 -12
  142. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js.map +1 -1
  143. package/dist/views/Version/RenderFieldsToDiff/fields/Select/DiffViewer/index.js +2 -1
  144. package/dist/views/Version/RenderFieldsToDiff/fields/Select/DiffViewer/index.js.map +1 -1
  145. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js +22 -11
  146. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js.map +1 -1
  147. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js +31 -30
  148. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js.map +1 -1
  149. package/dist/views/Version/RenderFieldsToDiff/fields/Text/DiffViewer/index.js +2 -1
  150. package/dist/views/Version/RenderFieldsToDiff/fields/Text/DiffViewer/index.js.map +1 -1
  151. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js +22 -11
  152. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js.map +1 -1
  153. package/dist/views/Version/RenderFieldsToDiff/index.js +90 -87
  154. package/dist/views/Version/RenderFieldsToDiff/index.js.map +1 -1
  155. package/dist/views/Version/Restore/index.js +38 -18
  156. package/dist/views/Version/Restore/index.js.map +1 -1
  157. package/dist/views/Version/SelectComparison/index.js +32 -24
  158. package/dist/views/Version/SelectComparison/index.js.map +1 -1
  159. package/dist/views/Version/SelectLocales/index.js +17 -11
  160. package/dist/views/Version/SelectLocales/index.js.map +1 -1
  161. package/dist/views/Version/index.js +2 -1
  162. package/dist/views/Version/index.js.map +1 -1
  163. package/dist/views/Versions/buildColumns.js +7 -6
  164. package/dist/views/Versions/buildColumns.js.map +1 -1
  165. package/dist/views/Versions/cells/AutosaveCell/index.js +25 -3
  166. package/dist/views/Versions/cells/AutosaveCell/index.js.map +1 -1
  167. package/dist/views/Versions/cells/CreatedAt/index.js +9 -7
  168. package/dist/views/Versions/cells/CreatedAt/index.js.map +1 -1
  169. package/dist/views/Versions/cells/ID/index.js +4 -1
  170. package/dist/views/Versions/cells/ID/index.js.map +1 -1
  171. package/dist/views/Versions/index.client.js +61 -29
  172. package/dist/views/Versions/index.client.js.map +1 -1
  173. package/dist/views/Versions/index.js +31 -22
  174. package/dist/views/Versions/index.js.map +1 -1
  175. package/dist/withPayload.d.ts.map +1 -1
  176. package/dist/withPayload.js +23 -0
  177. package/dist/withPayload.js.map +1 -1
  178. package/package.json +14 -10
@@ -1 +1 @@
1
- {"version":3,"file":"access.d.ts","sourceRoot":"","sources":["../../../../src/routes/rest/auth/access.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA;AAInD,eAAO,MAAM,MAAM,EAAE,gBAYpB,CAAA"}
1
+ {"version":3,"file":"access.d.ts","sourceRoot":"","sources":["../../../../src/routes/rest/auth/access.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA;AAInD,eAAO,MAAM,MAAM,EAAE,gBA0BpB,CAAA"}
@@ -2,16 +2,26 @@ import httpStatus from 'http-status';
2
2
  import { accessOperation } from 'payload/operations';
3
3
  import { headersWithCors } from '../../../utilities/headersWithCors.js';
4
4
  export const access = async ({ req })=>{
5
- const results = await accessOperation({
5
+ const headers = headersWithCors({
6
+ headers: new Headers(),
6
7
  req
7
8
  });
8
- return Response.json(results, {
9
- headers: headersWithCors({
10
- headers: new Headers(),
9
+ try {
10
+ const results = await accessOperation({
11
11
  req
12
- }),
13
- status: httpStatus.OK
14
- });
12
+ });
13
+ return Response.json(results, {
14
+ headers,
15
+ status: httpStatus.OK
16
+ });
17
+ } catch (e) {
18
+ return Response.json({
19
+ error: e
20
+ }, {
21
+ headers,
22
+ status: httpStatus.INTERNAL_SERVER_ERROR
23
+ });
24
+ }
15
25
  };
16
26
 
17
27
  //# sourceMappingURL=access.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/routes/rest/auth/access.ts"],"sourcesContent":["import httpStatus from 'http-status'\nimport { accessOperation } from 'payload/operations'\n\nimport type { BaseRouteHandler } from '../types.js'\n\nimport { headersWithCors } from '../../../utilities/headersWithCors.js'\n\nexport const access: BaseRouteHandler = async ({ req }) => {\n const results = await accessOperation({\n req,\n })\n\n return Response.json(results, {\n headers: headersWithCors({\n headers: new Headers(),\n req,\n }),\n status: httpStatus.OK,\n })\n}\n"],"names":["httpStatus","accessOperation","headersWithCors","access","req","results","Response","json","headers","Headers","status","OK"],"rangeMappings":";;;;;;;;;;;;;;","mappings":"AAAA,OAAOA,gBAAgB,cAAa;AACpC,SAASC,eAAe,QAAQ,qBAAoB;AAIpD,SAASC,eAAe,QAAQ,wCAAuC;AAEvE,OAAO,MAAMC,SAA2B,OAAO,EAAEC,GAAG,EAAE;IACpD,MAAMC,UAAU,MAAMJ,gBAAgB;QACpCG;IACF;IAEA,OAAOE,SAASC,IAAI,CAACF,SAAS;QAC5BG,SAASN,gBAAgB;YACvBM,SAAS,IAAIC;YACbL;QACF;QACAM,QAAQV,WAAWW,EAAE;IACvB;AACF,EAAC"}
1
+ {"version":3,"sources":["../../../../src/routes/rest/auth/access.ts"],"sourcesContent":["import httpStatus from 'http-status'\nimport { accessOperation } from 'payload/operations'\n\nimport type { BaseRouteHandler } from '../types.js'\n\nimport { headersWithCors } from '../../../utilities/headersWithCors.js'\n\nexport const access: BaseRouteHandler = async ({ req }) => {\n const headers = headersWithCors({\n headers: new Headers(),\n req,\n })\n\n try {\n const results = await accessOperation({\n req,\n })\n\n return Response.json(results, {\n headers,\n status: httpStatus.OK,\n })\n } catch (e: unknown) {\n return Response.json(\n {\n error: e,\n },\n {\n headers,\n status: httpStatus.INTERNAL_SERVER_ERROR,\n },\n )\n }\n}\n"],"names":["httpStatus","accessOperation","headersWithCors","access","req","headers","Headers","results","Response","json","status","OK","e","error","INTERNAL_SERVER_ERROR"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,OAAOA,gBAAgB,cAAa;AACpC,SAASC,eAAe,QAAQ,qBAAoB;AAIpD,SAASC,eAAe,QAAQ,wCAAuC;AAEvE,OAAO,MAAMC,SAA2B,OAAO,EAAEC,GAAG,EAAE;IACpD,MAAMC,UAAUH,gBAAgB;QAC9BG,SAAS,IAAIC;QACbF;IACF;IAEA,IAAI;QACF,MAAMG,UAAU,MAAMN,gBAAgB;YACpCG;QACF;QAEA,OAAOI,SAASC,IAAI,CAACF,SAAS;YAC5BF;YACAK,QAAQV,WAAWW,EAAE;QACvB;IACF,EAAE,OAAOC,GAAY;QACnB,OAAOJ,SAASC,IAAI,CAClB;YACEI,OAAOD;QACT,GACA;YACEP;YACAK,QAAQV,WAAWc,qBAAqB;QAC1C;IAEJ;AACF,EAAC"}
@@ -1,6 +1,7 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
1
2
  import React from 'react';
2
3
  export const OGImage = ({ Icon, description, fontFamily = 'Arial, sans-serif', leader, title })=>{
3
- return /*#__PURE__*/ React.createElement("div", {
4
+ return /*#__PURE__*/ _jsxs("div", {
4
5
  style: {
5
6
  backgroundColor: '#000',
6
7
  color: '#fff',
@@ -11,55 +12,68 @@ export const OGImage = ({ Icon, description, fontFamily = 'Arial, sans-serif', l
11
12
  justifyContent: 'space-between',
12
13
  padding: '100px',
13
14
  width: '100%'
14
- }
15
- }, /*#__PURE__*/ React.createElement("div", {
16
- style: {
17
- display: 'flex',
18
- flexDirection: 'column',
19
- flexGrow: 1,
20
- fontSize: 50,
21
- height: '100%'
22
- }
23
- }, leader && /*#__PURE__*/ React.createElement("div", {
24
- style: {
25
- fontSize: 30,
26
- marginBottom: 10
27
- }
28
- }, leader), /*#__PURE__*/ React.createElement("p", {
29
- style: {
30
- WebkitBoxOrient: 'vertical',
31
- WebkitLineClamp: 2,
32
- display: '-webkit-box',
33
- fontSize: 90,
34
- lineHeight: 1,
35
- marginBottom: 0,
36
- marginTop: 0,
37
- textOverflow: 'ellipsis'
38
- }
39
- }, title), description && /*#__PURE__*/ React.createElement("p", {
40
- style: {
41
- WebkitBoxOrient: 'vertical',
42
- WebkitLineClamp: 2,
43
- display: '-webkit-box',
44
- flexGrow: 1,
45
- fontSize: 30,
46
- lineHeight: 1,
47
- marginBottom: 0,
48
- marginTop: 40,
49
- textOverflow: 'ellipsis'
50
- }
51
- }, description)), /*#__PURE__*/ React.createElement("div", {
52
- style: {
53
- alignItems: 'flex-end',
54
- display: 'flex',
55
- flexShrink: 0,
56
- height: '38px',
57
- justifyContent: 'center',
58
- width: '38px'
59
- }
60
- }, /*#__PURE__*/ React.createElement(Icon, {
61
- fill: "white"
62
- })));
15
+ },
16
+ children: [
17
+ /*#__PURE__*/ _jsxs("div", {
18
+ style: {
19
+ display: 'flex',
20
+ flexDirection: 'column',
21
+ flexGrow: 1,
22
+ fontSize: 50,
23
+ height: '100%'
24
+ },
25
+ children: [
26
+ leader && /*#__PURE__*/ _jsx("div", {
27
+ style: {
28
+ fontSize: 30,
29
+ marginBottom: 10
30
+ },
31
+ children: leader
32
+ }),
33
+ /*#__PURE__*/ _jsx("p", {
34
+ style: {
35
+ WebkitBoxOrient: 'vertical',
36
+ WebkitLineClamp: 2,
37
+ display: '-webkit-box',
38
+ fontSize: 90,
39
+ lineHeight: 1,
40
+ marginBottom: 0,
41
+ marginTop: 0,
42
+ textOverflow: 'ellipsis'
43
+ },
44
+ children: title
45
+ }),
46
+ description && /*#__PURE__*/ _jsx("p", {
47
+ style: {
48
+ WebkitBoxOrient: 'vertical',
49
+ WebkitLineClamp: 2,
50
+ display: '-webkit-box',
51
+ flexGrow: 1,
52
+ fontSize: 30,
53
+ lineHeight: 1,
54
+ marginBottom: 0,
55
+ marginTop: 40,
56
+ textOverflow: 'ellipsis'
57
+ },
58
+ children: description
59
+ })
60
+ ]
61
+ }),
62
+ /*#__PURE__*/ _jsx("div", {
63
+ style: {
64
+ alignItems: 'flex-end',
65
+ display: 'flex',
66
+ flexShrink: 0,
67
+ height: '38px',
68
+ justifyContent: 'center',
69
+ width: '38px'
70
+ },
71
+ children: /*#__PURE__*/ _jsx(Icon, {
72
+ fill: "white"
73
+ })
74
+ })
75
+ ]
76
+ });
63
77
  };
64
78
 
65
79
  //# sourceMappingURL=image.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/routes/rest/og/image.tsx"],"sourcesContent":["import React from 'react'\n\nexport const OGImage: React.FC<{\n Icon: React.ComponentType<any>\n description?: string\n fontFamily?: string\n leader?: string\n title?: string\n}> = ({ Icon, description, fontFamily = 'Arial, sans-serif', leader, title }) => {\n return (\n <div\n style={{\n backgroundColor: '#000',\n color: '#fff',\n display: 'flex',\n flexDirection: 'column',\n fontFamily,\n height: '100%',\n justifyContent: 'space-between',\n padding: '100px',\n width: '100%',\n }}\n >\n <div\n style={{\n display: 'flex',\n flexDirection: 'column',\n flexGrow: 1,\n fontSize: 50,\n height: '100%',\n }}\n >\n {leader && (\n <div\n style={{\n fontSize: 30,\n marginBottom: 10,\n }}\n >\n {leader}\n </div>\n )}\n <p\n style={{\n WebkitBoxOrient: 'vertical',\n WebkitLineClamp: 2,\n display: '-webkit-box',\n fontSize: 90,\n lineHeight: 1,\n marginBottom: 0,\n marginTop: 0,\n textOverflow: 'ellipsis',\n }}\n >\n {title}\n </p>\n {description && (\n <p\n style={{\n WebkitBoxOrient: 'vertical',\n WebkitLineClamp: 2,\n display: '-webkit-box',\n flexGrow: 1,\n fontSize: 30,\n lineHeight: 1,\n marginBottom: 0,\n marginTop: 40,\n textOverflow: 'ellipsis',\n }}\n >\n {description}\n </p>\n )}\n </div>\n <div\n style={{\n alignItems: 'flex-end',\n display: 'flex',\n flexShrink: 0,\n height: '38px',\n justifyContent: 'center',\n width: '38px',\n }}\n >\n <Icon fill=\"white\" />\n </div>\n </div>\n )\n}\n"],"names":["React","OGImage","Icon","description","fontFamily","leader","title","div","style","backgroundColor","color","display","flexDirection","height","justifyContent","padding","width","flexGrow","fontSize","marginBottom","p","WebkitBoxOrient","WebkitLineClamp","lineHeight","marginTop","textOverflow","alignItems","flexShrink","fill"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,OAAOA,WAAW,QAAO;AAEzB,OAAO,MAAMC,UAMR,CAAC,EAAEC,IAAI,EAAEC,WAAW,EAAEC,aAAa,mBAAmB,EAAEC,MAAM,EAAEC,KAAK,EAAE;IAC1E,qBACE,oBAACC;QACCC,OAAO;YACLC,iBAAiB;YACjBC,OAAO;YACPC,SAAS;YACTC,eAAe;YACfR;YACAS,QAAQ;YACRC,gBAAgB;YAChBC,SAAS;YACTC,OAAO;QACT;qBAEA,oBAACT;QACCC,OAAO;YACLG,SAAS;YACTC,eAAe;YACfK,UAAU;YACVC,UAAU;YACVL,QAAQ;QACV;OAECR,wBACC,oBAACE;QACCC,OAAO;YACLU,UAAU;YACVC,cAAc;QAChB;OAECd,uBAGL,oBAACe;QACCZ,OAAO;YACLa,iBAAiB;YACjBC,iBAAiB;YACjBX,SAAS;YACTO,UAAU;YACVK,YAAY;YACZJ,cAAc;YACdK,WAAW;YACXC,cAAc;QAChB;OAECnB,QAEFH,6BACC,oBAACiB;QACCZ,OAAO;YACLa,iBAAiB;YACjBC,iBAAiB;YACjBX,SAAS;YACTM,UAAU;YACVC,UAAU;YACVK,YAAY;YACZJ,cAAc;YACdK,WAAW;YACXC,cAAc;QAChB;OAECtB,6BAIP,oBAACI;QACCC,OAAO;YACLkB,YAAY;YACZf,SAAS;YACTgB,YAAY;YACZd,QAAQ;YACRC,gBAAgB;YAChBE,OAAO;QACT;qBAEA,oBAACd;QAAK0B,MAAK;;AAInB,EAAC"}
1
+ {"version":3,"sources":["../../../../src/routes/rest/og/image.tsx"],"sourcesContent":["import React from 'react'\n\nexport const OGImage: React.FC<{\n Icon: React.ComponentType<any>\n description?: string\n fontFamily?: string\n leader?: string\n title?: string\n}> = ({ Icon, description, fontFamily = 'Arial, sans-serif', leader, title }) => {\n return (\n <div\n style={{\n backgroundColor: '#000',\n color: '#fff',\n display: 'flex',\n flexDirection: 'column',\n fontFamily,\n height: '100%',\n justifyContent: 'space-between',\n padding: '100px',\n width: '100%',\n }}\n >\n <div\n style={{\n display: 'flex',\n flexDirection: 'column',\n flexGrow: 1,\n fontSize: 50,\n height: '100%',\n }}\n >\n {leader && (\n <div\n style={{\n fontSize: 30,\n marginBottom: 10,\n }}\n >\n {leader}\n </div>\n )}\n <p\n style={{\n WebkitBoxOrient: 'vertical',\n WebkitLineClamp: 2,\n display: '-webkit-box',\n fontSize: 90,\n lineHeight: 1,\n marginBottom: 0,\n marginTop: 0,\n textOverflow: 'ellipsis',\n }}\n >\n {title}\n </p>\n {description && (\n <p\n style={{\n WebkitBoxOrient: 'vertical',\n WebkitLineClamp: 2,\n display: '-webkit-box',\n flexGrow: 1,\n fontSize: 30,\n lineHeight: 1,\n marginBottom: 0,\n marginTop: 40,\n textOverflow: 'ellipsis',\n }}\n >\n {description}\n </p>\n )}\n </div>\n <div\n style={{\n alignItems: 'flex-end',\n display: 'flex',\n flexShrink: 0,\n height: '38px',\n justifyContent: 'center',\n width: '38px',\n }}\n >\n <Icon fill=\"white\" />\n </div>\n </div>\n )\n}\n"],"names":["React","OGImage","Icon","description","fontFamily","leader","title","div","style","backgroundColor","color","display","flexDirection","height","justifyContent","padding","width","flexGrow","fontSize","marginBottom","p","WebkitBoxOrient","WebkitLineClamp","lineHeight","marginTop","textOverflow","alignItems","flexShrink","fill"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";AAAA,OAAOA,WAAW,QAAO;AAEzB,OAAO,MAAMC,UAMR,CAAC,EAAEC,IAAI,EAAEC,WAAW,EAAEC,aAAa,mBAAmB,EAAEC,MAAM,EAAEC,KAAK,EAAE;IAC1E,qBACE,MAACC;QACCC,OAAO;YACLC,iBAAiB;YACjBC,OAAO;YACPC,SAAS;YACTC,eAAe;YACfR;YACAS,QAAQ;YACRC,gBAAgB;YAChBC,SAAS;YACTC,OAAO;QACT;;0BAEA,MAACT;gBACCC,OAAO;oBACLG,SAAS;oBACTC,eAAe;oBACfK,UAAU;oBACVC,UAAU;oBACVL,QAAQ;gBACV;;oBAECR,wBACC,KAACE;wBACCC,OAAO;4BACLU,UAAU;4BACVC,cAAc;wBAChB;kCAECd;;kCAGL,KAACe;wBACCZ,OAAO;4BACLa,iBAAiB;4BACjBC,iBAAiB;4BACjBX,SAAS;4BACTO,UAAU;4BACVK,YAAY;4BACZJ,cAAc;4BACdK,WAAW;4BACXC,cAAc;wBAChB;kCAECnB;;oBAEFH,6BACC,KAACiB;wBACCZ,OAAO;4BACLa,iBAAiB;4BACjBC,iBAAiB;4BACjBX,SAAS;4BACTM,UAAU;4BACVC,UAAU;4BACVK,YAAY;4BACZJ,cAAc;4BACdK,WAAW;4BACXC,cAAc;wBAChB;kCAECtB;;;;0BAIP,KAACI;gBACCC,OAAO;oBACLkB,YAAY;oBACZf,SAAS;oBACTgB,YAAY;oBACZd,QAAQ;oBACRC,gBAAgB;oBAChBE,OAAO;gBACT;0BAEA,cAAA,KAACd;oBAAK0B,MAAK;;;;;AAInB,EAAC"}
@@ -1,3 +1,4 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
1
2
  import { PayloadIcon } from '@payloadcms/ui/graphics/Icon';
2
3
  import fs from 'fs/promises';
3
4
  import { ImageResponse } from 'next/og.js';
@@ -38,7 +39,7 @@ export const generateOGImage = async ({ req })=>{
38
39
  ;
39
40
  }
40
41
  const fontFamily = 'Roboto, sans-serif';
41
- return new ImageResponse(/*#__PURE__*/ React.createElement(OGImage, {
42
+ return new ImageResponse(/*#__PURE__*/ _jsx(OGImage, {
42
43
  Icon: Icon,
43
44
  description: description,
44
45
  fontFamily: fontFamily,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/routes/rest/og/index.tsx"],"sourcesContent":["import type { PayloadRequestWithData } from 'payload/types'\n\nimport { PayloadIcon } from '@payloadcms/ui/graphics/Icon'\nimport fs from 'fs/promises'\nimport { ImageResponse } from 'next/og.js'\nimport { NextResponse } from 'next/server.js'\nimport path from 'path'\nimport React from 'react'\nimport { fileURLToPath } from 'url'\n\nimport { OGImage } from './image.js'\n\nconst filename = fileURLToPath(import.meta.url)\nconst dirname = path.dirname(filename)\n\nexport const runtime = 'nodejs'\n\nexport const contentType = 'image/png'\n\nexport const generateOGImage = async ({ req }: { req: PayloadRequestWithData }) => {\n const config = req.payload.config\n\n if (config.admin.meta.defaultOGImageType === 'off') {\n return NextResponse.json({ error: `Open Graph images are disabled` }, { status: 400 })\n }\n\n try {\n const { searchParams } = new URL(req.url)\n\n const hasTitle = searchParams.has('title')\n const title = hasTitle ? searchParams.get('title')?.slice(0, 100) : ''\n const hasLeader = searchParams.has('leader')\n const leader = hasLeader ? searchParams.get('leader')?.slice(0, 100).replace('-', ' ') : ''\n const description = searchParams.has('description') ? searchParams.get('description') : ''\n const Icon = config.admin?.components?.graphics?.Icon || PayloadIcon\n\n let fontData\n\n try {\n // TODO: replace with `.woff2` file when supported\n // See https://github.com/vercel/next.js/issues/63935\n // Or better yet, use a CDN like Google Fonts if ever supported\n fontData = fs.readFile(path.join(dirname, 'roboto-regular.woff'))\n } catch (e) {\n console.error(`Error reading font file or not readable: ${e.message}`) // eslint-disable-line no-console\n }\n\n const fontFamily = 'Roboto, sans-serif'\n\n return new ImageResponse(\n (\n <OGImage\n Icon={Icon}\n description={description}\n fontFamily={fontFamily}\n leader={leader}\n title={title}\n />\n ),\n {\n ...(fontData\n ? {\n fonts: [\n {\n name: 'Roboto',\n data: await fontData,\n style: 'normal',\n weight: 400,\n },\n ],\n }\n : {}),\n height: 630,\n width: 1200,\n },\n )\n } catch (e: any) {\n console.error(`${e.message}`) // eslint-disable-line no-console\n return NextResponse.json({ error: `Internal Server Error: ${e.message}` }, { status: 500 })\n }\n}\n"],"names":["PayloadIcon","fs","ImageResponse","NextResponse","path","React","fileURLToPath","OGImage","filename","url","dirname","runtime","contentType","generateOGImage","req","config","payload","admin","meta","defaultOGImageType","json","error","status","searchParams","URL","hasTitle","has","title","get","slice","hasLeader","leader","replace","description","Icon","components","graphics","fontData","readFile","join","e","console","message","fontFamily","fonts","name","data","style","weight","height","width"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAEA,SAASA,WAAW,QAAQ,+BAA8B;AAC1D,OAAOC,QAAQ,cAAa;AAC5B,SAASC,aAAa,QAAQ,aAAY;AAC1C,SAASC,YAAY,QAAQ,iBAAgB;AAC7C,OAAOC,UAAU,OAAM;AACvB,OAAOC,WAAW,QAAO;AACzB,SAASC,aAAa,QAAQ,MAAK;AAEnC,SAASC,OAAO,QAAQ,aAAY;AAEpC,MAAMC,WAAWF,cAAc,YAAYG,GAAG;AAC9C,MAAMC,UAAUN,KAAKM,OAAO,CAACF;AAE7B,OAAO,MAAMG,UAAU,SAAQ;AAE/B,OAAO,MAAMC,cAAc,YAAW;AAEtC,OAAO,MAAMC,kBAAkB,OAAO,EAAEC,GAAG,EAAmC;IAC5E,MAAMC,SAASD,IAAIE,OAAO,CAACD,MAAM;IAEjC,IAAIA,OAAOE,KAAK,CAACC,IAAI,CAACC,kBAAkB,KAAK,OAAO;QAClD,OAAOhB,aAAaiB,IAAI,CAAC;YAAEC,OAAO,CAAC,8BAA8B,CAAC;QAAC,GAAG;YAAEC,QAAQ;QAAI;IACtF;IAEA,IAAI;QACF,MAAM,EAAEC,YAAY,EAAE,GAAG,IAAIC,IAAIV,IAAIL,GAAG;QAExC,MAAMgB,WAAWF,aAAaG,GAAG,CAAC;QAClC,MAAMC,QAAQF,WAAWF,aAAaK,GAAG,CAAC,UAAUC,MAAM,GAAG,OAAO;QACpE,MAAMC,YAAYP,aAAaG,GAAG,CAAC;QACnC,MAAMK,SAASD,YAAYP,aAAaK,GAAG,CAAC,WAAWC,MAAM,GAAG,KAAKG,QAAQ,KAAK,OAAO;QACzF,MAAMC,cAAcV,aAAaG,GAAG,CAAC,iBAAiBH,aAAaK,GAAG,CAAC,iBAAiB;QACxF,MAAMM,OAAOnB,OAAOE,KAAK,EAAEkB,YAAYC,UAAUF,QAAQlC;QAEzD,IAAIqC;QAEJ,IAAI;YACF,kDAAkD;YAClD,qDAAqD;YACrD,+DAA+D;YAC/DA,WAAWpC,GAAGqC,QAAQ,CAAClC,KAAKmC,IAAI,CAAC7B,SAAS;QAC5C,EAAE,OAAO8B,GAAG;YACVC,QAAQpB,KAAK,CAAC,CAAC,yCAAyC,EAAEmB,EAAEE,OAAO,CAAC,CAAC,EAAE,iCAAiC;;QAC1G;QAEA,MAAMC,aAAa;QAEnB,OAAO,IAAIzC,4BAEP,oBAACK;YACC2B,MAAMA;YACND,aAAaA;YACbU,YAAYA;YACZZ,QAAQA;YACRJ,OAAOA;YAGX;YACE,GAAIU,WACA;gBACEO,OAAO;oBACL;wBACEC,MAAM;wBACNC,MAAM,MAAMT;wBACZU,OAAO;wBACPC,QAAQ;oBACV;iBACD;YACH,IACA,CAAC,CAAC;YACNC,QAAQ;YACRC,OAAO;QACT;IAEJ,EAAE,OAAOV,GAAQ;QACfC,QAAQpB,KAAK,CAAC,CAAC,EAAEmB,EAAEE,OAAO,CAAC,CAAC,EAAE,iCAAiC;;QAC/D,OAAOvC,aAAaiB,IAAI,CAAC;YAAEC,OAAO,CAAC,uBAAuB,EAAEmB,EAAEE,OAAO,CAAC,CAAC;QAAC,GAAG;YAAEpB,QAAQ;QAAI;IAC3F;AACF,EAAC"}
1
+ {"version":3,"sources":["../../../../src/routes/rest/og/index.tsx"],"sourcesContent":["import type { PayloadRequestWithData } from 'payload/types'\n\nimport { PayloadIcon } from '@payloadcms/ui/graphics/Icon'\nimport fs from 'fs/promises'\nimport { ImageResponse } from 'next/og.js'\nimport { NextResponse } from 'next/server.js'\nimport path from 'path'\nimport React from 'react'\nimport { fileURLToPath } from 'url'\n\nimport { OGImage } from './image.js'\n\nconst filename = fileURLToPath(import.meta.url)\nconst dirname = path.dirname(filename)\n\nexport const runtime = 'nodejs'\n\nexport const contentType = 'image/png'\n\nexport const generateOGImage = async ({ req }: { req: PayloadRequestWithData }) => {\n const config = req.payload.config\n\n if (config.admin.meta.defaultOGImageType === 'off') {\n return NextResponse.json({ error: `Open Graph images are disabled` }, { status: 400 })\n }\n\n try {\n const { searchParams } = new URL(req.url)\n\n const hasTitle = searchParams.has('title')\n const title = hasTitle ? searchParams.get('title')?.slice(0, 100) : ''\n const hasLeader = searchParams.has('leader')\n const leader = hasLeader ? searchParams.get('leader')?.slice(0, 100).replace('-', ' ') : ''\n const description = searchParams.has('description') ? searchParams.get('description') : ''\n const Icon = config.admin?.components?.graphics?.Icon || PayloadIcon\n\n let fontData\n\n try {\n // TODO: replace with `.woff2` file when supported\n // See https://github.com/vercel/next.js/issues/63935\n // Or better yet, use a CDN like Google Fonts if ever supported\n fontData = fs.readFile(path.join(dirname, 'roboto-regular.woff'))\n } catch (e) {\n console.error(`Error reading font file or not readable: ${e.message}`) // eslint-disable-line no-console\n }\n\n const fontFamily = 'Roboto, sans-serif'\n\n return new ImageResponse(\n (\n <OGImage\n Icon={Icon}\n description={description}\n fontFamily={fontFamily}\n leader={leader}\n title={title}\n />\n ),\n {\n ...(fontData\n ? {\n fonts: [\n {\n name: 'Roboto',\n data: await fontData,\n style: 'normal',\n weight: 400,\n },\n ],\n }\n : {}),\n height: 630,\n width: 1200,\n },\n )\n } catch (e: any) {\n console.error(`${e.message}`) // eslint-disable-line no-console\n return NextResponse.json({ error: `Internal Server Error: ${e.message}` }, { status: 500 })\n }\n}\n"],"names":["PayloadIcon","fs","ImageResponse","NextResponse","path","React","fileURLToPath","OGImage","filename","url","dirname","runtime","contentType","generateOGImage","req","config","payload","admin","meta","defaultOGImageType","json","error","status","searchParams","URL","hasTitle","has","title","get","slice","hasLeader","leader","replace","description","Icon","components","graphics","fontData","readFile","join","e","console","message","fontFamily","fonts","name","data","style","weight","height","width"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";AAEA,SAASA,WAAW,QAAQ,+BAA8B;AAC1D,OAAOC,QAAQ,cAAa;AAC5B,SAASC,aAAa,QAAQ,aAAY;AAC1C,SAASC,YAAY,QAAQ,iBAAgB;AAC7C,OAAOC,UAAU,OAAM;AACvB,OAAOC,WAAW,QAAO;AACzB,SAASC,aAAa,QAAQ,MAAK;AAEnC,SAASC,OAAO,QAAQ,aAAY;AAEpC,MAAMC,WAAWF,cAAc,YAAYG,GAAG;AAC9C,MAAMC,UAAUN,KAAKM,OAAO,CAACF;AAE7B,OAAO,MAAMG,UAAU,SAAQ;AAE/B,OAAO,MAAMC,cAAc,YAAW;AAEtC,OAAO,MAAMC,kBAAkB,OAAO,EAAEC,GAAG,EAAmC;IAC5E,MAAMC,SAASD,IAAIE,OAAO,CAACD,MAAM;IAEjC,IAAIA,OAAOE,KAAK,CAACC,IAAI,CAACC,kBAAkB,KAAK,OAAO;QAClD,OAAOhB,aAAaiB,IAAI,CAAC;YAAEC,OAAO,CAAC,8BAA8B,CAAC;QAAC,GAAG;YAAEC,QAAQ;QAAI;IACtF;IAEA,IAAI;QACF,MAAM,EAAEC,YAAY,EAAE,GAAG,IAAIC,IAAIV,IAAIL,GAAG;QAExC,MAAMgB,WAAWF,aAAaG,GAAG,CAAC;QAClC,MAAMC,QAAQF,WAAWF,aAAaK,GAAG,CAAC,UAAUC,MAAM,GAAG,OAAO;QACpE,MAAMC,YAAYP,aAAaG,GAAG,CAAC;QACnC,MAAMK,SAASD,YAAYP,aAAaK,GAAG,CAAC,WAAWC,MAAM,GAAG,KAAKG,QAAQ,KAAK,OAAO;QACzF,MAAMC,cAAcV,aAAaG,GAAG,CAAC,iBAAiBH,aAAaK,GAAG,CAAC,iBAAiB;QACxF,MAAMM,OAAOnB,OAAOE,KAAK,EAAEkB,YAAYC,UAAUF,QAAQlC;QAEzD,IAAIqC;QAEJ,IAAI;YACF,kDAAkD;YAClD,qDAAqD;YACrD,+DAA+D;YAC/DA,WAAWpC,GAAGqC,QAAQ,CAAClC,KAAKmC,IAAI,CAAC7B,SAAS;QAC5C,EAAE,OAAO8B,GAAG;YACVC,QAAQpB,KAAK,CAAC,CAAC,yCAAyC,EAAEmB,EAAEE,OAAO,CAAC,CAAC,EAAE,iCAAiC;;QAC1G;QAEA,MAAMC,aAAa;QAEnB,OAAO,IAAIzC,4BAEP,KAACK;YACC2B,MAAMA;YACND,aAAaA;YACbU,YAAYA;YACZZ,QAAQA;YACRJ,OAAOA;YAGX;YACE,GAAIU,WACA;gBACEO,OAAO;oBACL;wBACEC,MAAM;wBACNC,MAAM,MAAMT;wBACZU,OAAO;wBACPC,QAAQ;oBACV;iBACD;YACH,IACA,CAAC,CAAC;YACNC,QAAQ;YACRC,OAAO;QACT;IAEJ,EAAE,OAAOV,GAAQ;QACfC,QAAQpB,KAAK,CAAC,CAAC,EAAEmB,EAAEE,OAAO,CAAC,CAAC,EAAE,iCAAiC;;QAC/D,OAAOvC,aAAaiB,IAAI,CAAC;YAAEC,OAAO,CAAC,uBAAuB,EAAEmB,EAAEE,OAAO,CAAC,CAAC;QAAC,GAAG;YAAEpB,QAAQ;QAAI;IAC3F;AACF,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"getRequestLanguage.d.ts","sourceRoot":"","sources":["../../src/utilities/getRequestLanguage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAA;AACjE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iEAAiE,CAAA;AAC7G,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AAIrD,KAAK,sBAAsB,GAAG;IAC5B,MAAM,EAAE,eAAe,CAAA;IACvB,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,sBAAsB,CAAA;IACrD,eAAe,CAAC,EAAE,iBAAiB,CAAA;IACnC,OAAO,EAAE,OAAO,CAAC,SAAS,CAAC,CAAA;CAC5B,CAAA;AAED,eAAO,MAAM,kBAAkB,kCAI5B,sBAAsB,KAAG,iBAmB3B,CAAA"}
1
+ {"version":3,"file":"getRequestLanguage.d.ts","sourceRoot":"","sources":["../../src/utilities/getRequestLanguage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAA;AACjE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iEAAiE,CAAA;AAC7G,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AAIrD,KAAK,sBAAsB,GAAG;IAC5B,MAAM,EAAE,eAAe,CAAA;IACvB,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,sBAAsB,CAAA;IACrD,eAAe,CAAC,EAAE,iBAAiB,CAAA;IACnC,OAAO,EAAE,OAAO,CAAC,SAAS,CAAC,CAAA;CAC5B,CAAA;AAED,eAAO,MAAM,kBAAkB,kCAI5B,sBAAsB,KAAG,iBAqB3B,CAAA"}
@@ -3,10 +3,10 @@ export const getRequestLanguage = ({ config, cookies, headers })=>{
3
3
  const supportedLanguageKeys = Object.keys(config.i18n.supportedLanguages);
4
4
  const langCookie = cookies.get(`${config.cookiePrefix || 'payload'}-lng`);
5
5
  const languageFromCookie = typeof langCookie === 'string' ? langCookie : langCookie?.value;
6
- const languageFromHeader = headers.get('Accept-Language') ? extractHeaderLanguage(headers.get('Accept-Language')) : undefined;
7
6
  if (languageFromCookie && supportedLanguageKeys.includes(languageFromCookie)) {
8
7
  return languageFromCookie;
9
8
  }
9
+ const languageFromHeader = headers.get('Accept-Language') ? extractHeaderLanguage(headers.get('Accept-Language')) : undefined;
10
10
  if (languageFromHeader && supportedLanguageKeys.includes(languageFromHeader)) {
11
11
  return languageFromHeader;
12
12
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/getRequestLanguage.ts"],"sourcesContent":["import type { AcceptedLanguages } from '@payloadcms/translations'\nimport type { ReadonlyRequestCookies } from 'next/dist/server/web/spec-extension/adapters/request-cookies.js'\nimport type { SanitizedConfig } from 'payload/config'\n\nimport { extractHeaderLanguage } from '@payloadcms/translations'\n\ntype GetRequestLanguageArgs = {\n config: SanitizedConfig\n cookies: Map<string, string> | ReadonlyRequestCookies\n defaultLanguage?: AcceptedLanguages\n headers: Request['headers']\n}\n\nexport const getRequestLanguage = ({\n config,\n cookies,\n headers,\n}: GetRequestLanguageArgs): AcceptedLanguages => {\n const supportedLanguageKeys = <AcceptedLanguages[]>Object.keys(config.i18n.supportedLanguages)\n const langCookie = cookies.get(`${config.cookiePrefix || 'payload'}-lng`)\n const languageFromCookie: AcceptedLanguages = (\n typeof langCookie === 'string' ? langCookie : langCookie?.value\n ) as AcceptedLanguages\n const languageFromHeader = headers.get('Accept-Language')\n ? extractHeaderLanguage(headers.get('Accept-Language'))\n : undefined\n\n if (languageFromCookie && supportedLanguageKeys.includes(languageFromCookie)) {\n return languageFromCookie\n }\n\n if (languageFromHeader && supportedLanguageKeys.includes(languageFromHeader)) {\n return languageFromHeader\n }\n\n return config.i18n.fallbackLanguage\n}\n"],"names":["extractHeaderLanguage","getRequestLanguage","config","cookies","headers","supportedLanguageKeys","Object","keys","i18n","supportedLanguages","langCookie","get","cookiePrefix","languageFromCookie","value","languageFromHeader","undefined","includes","fallbackLanguage"],"rangeMappings":";;;;;;;;;;;;;","mappings":"AAIA,SAASA,qBAAqB,QAAQ,2BAA0B;AAShE,OAAO,MAAMC,qBAAqB,CAAC,EACjCC,MAAM,EACNC,OAAO,EACPC,OAAO,EACgB;IACvB,MAAMC,wBAA6CC,OAAOC,IAAI,CAACL,OAAOM,IAAI,CAACC,kBAAkB;IAC7F,MAAMC,aAAaP,QAAQQ,GAAG,CAAC,CAAC,EAAET,OAAOU,YAAY,IAAI,UAAU,IAAI,CAAC;IACxE,MAAMC,qBACJ,OAAOH,eAAe,WAAWA,aAAaA,YAAYI;IAE5D,MAAMC,qBAAqBX,QAAQO,GAAG,CAAC,qBACnCX,sBAAsBI,QAAQO,GAAG,CAAC,sBAClCK;IAEJ,IAAIH,sBAAsBR,sBAAsBY,QAAQ,CAACJ,qBAAqB;QAC5E,OAAOA;IACT;IAEA,IAAIE,sBAAsBV,sBAAsBY,QAAQ,CAACF,qBAAqB;QAC5E,OAAOA;IACT;IAEA,OAAOb,OAAOM,IAAI,CAACU,gBAAgB;AACrC,EAAC"}
1
+ {"version":3,"sources":["../../src/utilities/getRequestLanguage.ts"],"sourcesContent":["import type { AcceptedLanguages } from '@payloadcms/translations'\nimport type { ReadonlyRequestCookies } from 'next/dist/server/web/spec-extension/adapters/request-cookies.js'\nimport type { SanitizedConfig } from 'payload/config'\n\nimport { extractHeaderLanguage } from '@payloadcms/translations'\n\ntype GetRequestLanguageArgs = {\n config: SanitizedConfig\n cookies: Map<string, string> | ReadonlyRequestCookies\n defaultLanguage?: AcceptedLanguages\n headers: Request['headers']\n}\n\nexport const getRequestLanguage = ({\n config,\n cookies,\n headers,\n}: GetRequestLanguageArgs): AcceptedLanguages => {\n const supportedLanguageKeys = <AcceptedLanguages[]>Object.keys(config.i18n.supportedLanguages)\n const langCookie = cookies.get(`${config.cookiePrefix || 'payload'}-lng`)\n\n const languageFromCookie: AcceptedLanguages = (\n typeof langCookie === 'string' ? langCookie : langCookie?.value\n ) as AcceptedLanguages\n\n if (languageFromCookie && supportedLanguageKeys.includes(languageFromCookie)) {\n return languageFromCookie\n }\n\n const languageFromHeader = headers.get('Accept-Language')\n ? extractHeaderLanguage(headers.get('Accept-Language'))\n : undefined\n\n if (languageFromHeader && supportedLanguageKeys.includes(languageFromHeader)) {\n return languageFromHeader\n }\n\n return config.i18n.fallbackLanguage\n}\n"],"names":["extractHeaderLanguage","getRequestLanguage","config","cookies","headers","supportedLanguageKeys","Object","keys","i18n","supportedLanguages","langCookie","get","cookiePrefix","languageFromCookie","value","includes","languageFromHeader","undefined","fallbackLanguage"],"rangeMappings":";;;;;;;;;;;;;","mappings":"AAIA,SAASA,qBAAqB,QAAQ,2BAA0B;AAShE,OAAO,MAAMC,qBAAqB,CAAC,EACjCC,MAAM,EACNC,OAAO,EACPC,OAAO,EACgB;IACvB,MAAMC,wBAA6CC,OAAOC,IAAI,CAACL,OAAOM,IAAI,CAACC,kBAAkB;IAC7F,MAAMC,aAAaP,QAAQQ,GAAG,CAAC,CAAC,EAAET,OAAOU,YAAY,IAAI,UAAU,IAAI,CAAC;IAExE,MAAMC,qBACJ,OAAOH,eAAe,WAAWA,aAAaA,YAAYI;IAG5D,IAAID,sBAAsBR,sBAAsBU,QAAQ,CAACF,qBAAqB;QAC5E,OAAOA;IACT;IAEA,MAAMG,qBAAqBZ,QAAQO,GAAG,CAAC,qBACnCX,sBAAsBI,QAAQO,GAAG,CAAC,sBAClCM;IAEJ,IAAID,sBAAsBX,sBAAsBU,QAAQ,CAACC,qBAAqB;QAC5E,OAAOA;IACT;IAEA,OAAOd,OAAOM,IAAI,CAACU,gBAAgB;AACrC,EAAC"}
@@ -0,0 +1,11 @@
1
+ import type { Theme } from '@payloadcms/ui/providers/Theme';
2
+ import type { ReadonlyRequestCookies } from 'next/dist/server/web/spec-extension/adapters/request-cookies.js';
3
+ import type { SanitizedConfig } from 'payload/config';
4
+ type GetRequestLanguageArgs = {
5
+ config: SanitizedConfig;
6
+ cookies: Map<string, string> | ReadonlyRequestCookies;
7
+ headers: Request['headers'];
8
+ };
9
+ export declare const getRequestTheme: ({ config, cookies, headers }: GetRequestLanguageArgs) => Theme;
10
+ export {};
11
+ //# sourceMappingURL=getRequestTheme.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getRequestTheme.d.ts","sourceRoot":"","sources":["../../src/utilities/getRequestTheme.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAA;AAC3D,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iEAAiE,CAAA;AAC7G,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAA;AAIrD,KAAK,sBAAsB,GAAG;IAC5B,MAAM,EAAE,eAAe,CAAA;IACvB,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,sBAAsB,CAAA;IACrD,OAAO,EAAE,OAAO,CAAC,SAAS,CAAC,CAAA;CAC5B,CAAA;AAID,eAAO,MAAM,eAAe,iCAAkC,sBAAsB,KAAG,KAkBtF,CAAA"}
@@ -0,0 +1,19 @@
1
+ import { defaultTheme } from '@payloadcms/ui/providers/Theme';
2
+ const acceptedThemes = [
3
+ 'dark',
4
+ 'light'
5
+ ];
6
+ export const getRequestTheme = ({ config, cookies, headers })=>{
7
+ const themeCookie = cookies.get(`${config.cookiePrefix || 'payload'}-theme`);
8
+ const themeFromCookie = typeof themeCookie === 'string' ? themeCookie : themeCookie?.value;
9
+ if (themeFromCookie && acceptedThemes.includes(themeFromCookie)) {
10
+ return themeFromCookie;
11
+ }
12
+ const themeFromHeader = headers.get('Sec-CH-Prefers-Color-Scheme');
13
+ if (themeFromHeader && acceptedThemes.includes(themeFromHeader)) {
14
+ return themeFromHeader;
15
+ }
16
+ return defaultTheme;
17
+ };
18
+
19
+ //# sourceMappingURL=getRequestTheme.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utilities/getRequestTheme.ts"],"sourcesContent":["import type { Theme } from '@payloadcms/ui/providers/Theme'\nimport type { ReadonlyRequestCookies } from 'next/dist/server/web/spec-extension/adapters/request-cookies.js'\nimport type { SanitizedConfig } from 'payload/config'\n\nimport { defaultTheme } from '@payloadcms/ui/providers/Theme'\n\ntype GetRequestLanguageArgs = {\n config: SanitizedConfig\n cookies: Map<string, string> | ReadonlyRequestCookies\n headers: Request['headers']\n}\n\nconst acceptedThemes: Theme[] = ['dark', 'light']\n\nexport const getRequestTheme = ({ config, cookies, headers }: GetRequestLanguageArgs): Theme => {\n const themeCookie = cookies.get(`${config.cookiePrefix || 'payload'}-theme`)\n\n const themeFromCookie: Theme = (\n typeof themeCookie === 'string' ? themeCookie : themeCookie?.value\n ) as Theme\n\n if (themeFromCookie && acceptedThemes.includes(themeFromCookie)) {\n return themeFromCookie\n }\n\n const themeFromHeader = headers.get('Sec-CH-Prefers-Color-Scheme') as Theme\n\n if (themeFromHeader && acceptedThemes.includes(themeFromHeader)) {\n return themeFromHeader\n }\n\n return defaultTheme\n}\n"],"names":["defaultTheme","acceptedThemes","getRequestTheme","config","cookies","headers","themeCookie","get","cookiePrefix","themeFromCookie","value","includes","themeFromHeader"],"rangeMappings":";;;;;;;;;;;;;;;;","mappings":"AAIA,SAASA,YAAY,QAAQ,iCAAgC;AAQ7D,MAAMC,iBAA0B;IAAC;IAAQ;CAAQ;AAEjD,OAAO,MAAMC,kBAAkB,CAAC,EAAEC,MAAM,EAAEC,OAAO,EAAEC,OAAO,EAA0B;IAClF,MAAMC,cAAcF,QAAQG,GAAG,CAAC,CAAC,EAAEJ,OAAOK,YAAY,IAAI,UAAU,MAAM,CAAC;IAE3E,MAAMC,kBACJ,OAAOH,gBAAgB,WAAWA,cAAcA,aAAaI;IAG/D,IAAID,mBAAmBR,eAAeU,QAAQ,CAACF,kBAAkB;QAC/D,OAAOA;IACT;IAEA,MAAMG,kBAAkBP,QAAQE,GAAG,CAAC;IAEpC,IAAIK,mBAAmBX,eAAeU,QAAQ,CAACC,kBAAkB;QAC/D,OAAOA;IACT;IAEA,OAAOZ;AACT,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/utilities/initPage/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAA2C,MAAM,eAAe,CAAA;AAS5F,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;AAOtC,eAAO,MAAM,QAAQ,iFAKlB,IAAI,KAAG,QAAQ,cAAc,CAmF/B,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/utilities/initPage/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAA2C,MAAM,eAAe,CAAA;AAS5F,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;AAOtC,eAAO,MAAM,QAAQ,iFAKlB,IAAI,KAAG,QAAQ,cAAc,CAoF/B,CAAA"}
@@ -36,6 +36,7 @@ export const initPage = async ({ config: configPromise, redirectUnauthenticatedU
36
36
  fallbackLocale: null,
37
37
  locale: locale.code,
38
38
  req: {
39
+ host: headers.get('host'),
39
40
  i18n,
40
41
  query: qs.parse(queryString, {
41
42
  depth: 10,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/utilities/initPage/index.ts"],"sourcesContent":["import type { I18nClient } from '@payloadcms/translations'\nimport type { InitPageResult, PayloadRequestWithData, VisibleEntities } from 'payload/types'\n\nimport { initI18n } from '@payloadcms/translations'\nimport { findLocaleFromCode } from '@payloadcms/ui/utilities/findLocaleFromCode'\nimport { headers as getHeaders } from 'next/headers.js'\nimport { parseCookies } from 'payload/auth'\nimport { createLocalReq, isEntityHidden } from 'payload/utilities'\nimport qs from 'qs'\n\nimport type { Args } from './types.js'\n\nimport { getPayloadHMR } from '../getPayloadHMR.js'\nimport { getRequestLanguage } from '../getRequestLanguage.js'\nimport { handleAdminPage } from './handleAdminPage.js'\nimport { handleAuthRedirect } from './handleAuthRedirect.js'\n\nexport const initPage = async ({\n config: configPromise,\n redirectUnauthenticatedUser = false,\n route,\n searchParams,\n}: Args): Promise<InitPageResult> => {\n const headers = getHeaders()\n const localeParam = searchParams?.locale as string\n const payload = await getPayloadHMR({ config: configPromise })\n\n const {\n collections,\n globals,\n i18n: i18nConfig,\n localization,\n routes: { admin: adminRoute },\n } = payload.config\n\n const queryString = `${qs.stringify(searchParams ?? {}, { addQueryPrefix: true })}`\n const defaultLocale =\n localization && localization.defaultLocale ? localization.defaultLocale : 'en'\n const localeCode = localeParam || defaultLocale\n const locale = localization && findLocaleFromCode(localization, localeCode)\n const cookies = parseCookies(headers)\n const language = getRequestLanguage({ config: payload.config, cookies, headers })\n\n const i18n: I18nClient = await initI18n({\n config: i18nConfig,\n context: 'client',\n language,\n })\n\n const req = await createLocalReq(\n {\n fallbackLocale: null,\n locale: locale.code,\n req: {\n i18n,\n query: qs.parse(queryString, {\n depth: 10,\n ignoreQueryPrefix: true,\n }),\n url: `${payload.config.serverURL}${route}${searchParams ? queryString : ''}`,\n } as PayloadRequestWithData,\n },\n payload,\n )\n\n const { permissions, user } = await payload.auth({ headers, req })\n\n req.user = user\n\n const visibleEntities: VisibleEntities = {\n collections: collections\n .map(({ slug, admin: { hidden } }) => (!isEntityHidden({ hidden, user }) ? slug : null))\n .filter(Boolean),\n globals: globals\n .map(({ slug, admin: { hidden } }) => (!isEntityHidden({ hidden, user }) ? slug : null))\n .filter(Boolean),\n }\n\n if (redirectUnauthenticatedUser && !user) {\n handleAuthRedirect({\n config: payload.config,\n redirectUnauthenticatedUser,\n route,\n searchParams,\n })\n }\n\n const { collectionConfig, docID, globalConfig } = handleAdminPage({\n adminRoute,\n config: payload.config,\n permissions,\n route,\n })\n\n return {\n collectionConfig,\n cookies,\n docID,\n globalConfig,\n locale,\n permissions,\n req,\n translations: i18n.translations,\n visibleEntities,\n }\n}\n"],"names":["initI18n","findLocaleFromCode","headers","getHeaders","parseCookies","createLocalReq","isEntityHidden","qs","getPayloadHMR","getRequestLanguage","handleAdminPage","handleAuthRedirect","initPage","config","configPromise","redirectUnauthenticatedUser","route","searchParams","localeParam","locale","payload","collections","globals","i18n","i18nConfig","localization","routes","admin","adminRoute","queryString","stringify","addQueryPrefix","defaultLocale","localeCode","cookies","language","context","req","fallbackLocale","code","query","parse","depth","ignoreQueryPrefix","url","serverURL","permissions","user","auth","visibleEntities","map","slug","hidden","filter","Boolean","collectionConfig","docID","globalConfig","translations"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAGA,SAASA,QAAQ,QAAQ,2BAA0B;AACnD,SAASC,kBAAkB,QAAQ,8CAA6C;AAChF,SAASC,WAAWC,UAAU,QAAQ,kBAAiB;AACvD,SAASC,YAAY,QAAQ,eAAc;AAC3C,SAASC,cAAc,EAAEC,cAAc,QAAQ,oBAAmB;AAClE,OAAOC,QAAQ,KAAI;AAInB,SAASC,aAAa,QAAQ,sBAAqB;AACnD,SAASC,kBAAkB,QAAQ,2BAA0B;AAC7D,SAASC,eAAe,QAAQ,uBAAsB;AACtD,SAASC,kBAAkB,QAAQ,0BAAyB;AAE5D,OAAO,MAAMC,WAAW,OAAO,EAC7BC,QAAQC,aAAa,EACrBC,8BAA8B,KAAK,EACnCC,KAAK,EACLC,YAAY,EACP;IACL,MAAMf,UAAUC;IAChB,MAAMe,cAAcD,cAAcE;IAClC,MAAMC,UAAU,MAAMZ,cAAc;QAAEK,QAAQC;IAAc;IAE5D,MAAM,EACJO,WAAW,EACXC,OAAO,EACPC,MAAMC,UAAU,EAChBC,YAAY,EACZC,QAAQ,EAAEC,OAAOC,UAAU,EAAE,EAC9B,GAAGR,QAAQP,MAAM;IAElB,MAAMgB,cAAc,CAAC,EAAEtB,GAAGuB,SAAS,CAACb,gBAAgB,CAAC,GAAG;QAAEc,gBAAgB;IAAK,GAAG,CAAC;IACnF,MAAMC,gBACJP,gBAAgBA,aAAaO,aAAa,GAAGP,aAAaO,aAAa,GAAG;IAC5E,MAAMC,aAAaf,eAAec;IAClC,MAAMb,SAASM,gBAAgBxB,mBAAmBwB,cAAcQ;IAChE,MAAMC,UAAU9B,aAAaF;IAC7B,MAAMiC,WAAW1B,mBAAmB;QAAEI,QAAQO,QAAQP,MAAM;QAAEqB;QAAShC;IAAQ;IAE/E,MAAMqB,OAAmB,MAAMvB,SAAS;QACtCa,QAAQW;QACRY,SAAS;QACTD;IACF;IAEA,MAAME,MAAM,MAAMhC,eAChB;QACEiC,gBAAgB;QAChBnB,QAAQA,OAAOoB,IAAI;QACnBF,KAAK;YACHd;YACAiB,OAAOjC,GAAGkC,KAAK,CAACZ,aAAa;gBAC3Ba,OAAO;gBACPC,mBAAmB;YACrB;YACAC,KAAK,CAAC,EAAExB,QAAQP,MAAM,CAACgC,SAAS,CAAC,EAAE7B,MAAM,EAAEC,eAAeY,cAAc,GAAG,CAAC;QAC9E;IACF,GACAT;IAGF,MAAM,EAAE0B,WAAW,EAAEC,IAAI,EAAE,GAAG,MAAM3B,QAAQ4B,IAAI,CAAC;QAAE9C;QAASmC;IAAI;IAEhEA,IAAIU,IAAI,GAAGA;IAEX,MAAME,kBAAmC;QACvC5B,aAAaA,YACV6B,GAAG,CAAC,CAAC,EAAEC,IAAI,EAAExB,OAAO,EAAEyB,MAAM,EAAE,EAAE,GAAM,CAAC9C,eAAe;gBAAE8C;gBAAQL;YAAK,KAAKI,OAAO,MACjFE,MAAM,CAACC;QACVhC,SAASA,QACN4B,GAAG,CAAC,CAAC,EAAEC,IAAI,EAAExB,OAAO,EAAEyB,MAAM,EAAE,EAAE,GAAM,CAAC9C,eAAe;gBAAE8C;gBAAQL;YAAK,KAAKI,OAAO,MACjFE,MAAM,CAACC;IACZ;IAEA,IAAIvC,+BAA+B,CAACgC,MAAM;QACxCpC,mBAAmB;YACjBE,QAAQO,QAAQP,MAAM;YACtBE;YACAC;YACAC;QACF;IACF;IAEA,MAAM,EAAEsC,gBAAgB,EAAEC,KAAK,EAAEC,YAAY,EAAE,GAAG/C,gBAAgB;QAChEkB;QACAf,QAAQO,QAAQP,MAAM;QACtBiC;QACA9B;IACF;IAEA,OAAO;QACLuC;QACArB;QACAsB;QACAC;QACAtC;QACA2B;QACAT;QACAqB,cAAcnC,KAAKmC,YAAY;QAC/BT;IACF;AACF,EAAC"}
1
+ {"version":3,"sources":["../../../src/utilities/initPage/index.ts"],"sourcesContent":["import type { I18nClient } from '@payloadcms/translations'\nimport type { InitPageResult, PayloadRequestWithData, VisibleEntities } from 'payload/types'\n\nimport { initI18n } from '@payloadcms/translations'\nimport { findLocaleFromCode } from '@payloadcms/ui/utilities/findLocaleFromCode'\nimport { headers as getHeaders } from 'next/headers.js'\nimport { parseCookies } from 'payload/auth'\nimport { createLocalReq, isEntityHidden } from 'payload/utilities'\nimport qs from 'qs'\n\nimport type { Args } from './types.js'\n\nimport { getPayloadHMR } from '../getPayloadHMR.js'\nimport { getRequestLanguage } from '../getRequestLanguage.js'\nimport { handleAdminPage } from './handleAdminPage.js'\nimport { handleAuthRedirect } from './handleAuthRedirect.js'\n\nexport const initPage = async ({\n config: configPromise,\n redirectUnauthenticatedUser = false,\n route,\n searchParams,\n}: Args): Promise<InitPageResult> => {\n const headers = getHeaders()\n const localeParam = searchParams?.locale as string\n const payload = await getPayloadHMR({ config: configPromise })\n\n const {\n collections,\n globals,\n i18n: i18nConfig,\n localization,\n routes: { admin: adminRoute },\n } = payload.config\n\n const queryString = `${qs.stringify(searchParams ?? {}, { addQueryPrefix: true })}`\n const defaultLocale =\n localization && localization.defaultLocale ? localization.defaultLocale : 'en'\n const localeCode = localeParam || defaultLocale\n const locale = localization && findLocaleFromCode(localization, localeCode)\n const cookies = parseCookies(headers)\n const language = getRequestLanguage({ config: payload.config, cookies, headers })\n\n const i18n: I18nClient = await initI18n({\n config: i18nConfig,\n context: 'client',\n language,\n })\n\n const req = await createLocalReq(\n {\n fallbackLocale: null,\n locale: locale.code,\n req: {\n host: headers.get('host'),\n i18n,\n query: qs.parse(queryString, {\n depth: 10,\n ignoreQueryPrefix: true,\n }),\n url: `${payload.config.serverURL}${route}${searchParams ? queryString : ''}`,\n } as PayloadRequestWithData,\n },\n payload,\n )\n\n const { permissions, user } = await payload.auth({ headers, req })\n\n req.user = user\n\n const visibleEntities: VisibleEntities = {\n collections: collections\n .map(({ slug, admin: { hidden } }) => (!isEntityHidden({ hidden, user }) ? slug : null))\n .filter(Boolean),\n globals: globals\n .map(({ slug, admin: { hidden } }) => (!isEntityHidden({ hidden, user }) ? slug : null))\n .filter(Boolean),\n }\n\n if (redirectUnauthenticatedUser && !user) {\n handleAuthRedirect({\n config: payload.config,\n redirectUnauthenticatedUser,\n route,\n searchParams,\n })\n }\n\n const { collectionConfig, docID, globalConfig } = handleAdminPage({\n adminRoute,\n config: payload.config,\n permissions,\n route,\n })\n\n return {\n collectionConfig,\n cookies,\n docID,\n globalConfig,\n locale,\n permissions,\n req,\n translations: i18n.translations,\n visibleEntities,\n }\n}\n"],"names":["initI18n","findLocaleFromCode","headers","getHeaders","parseCookies","createLocalReq","isEntityHidden","qs","getPayloadHMR","getRequestLanguage","handleAdminPage","handleAuthRedirect","initPage","config","configPromise","redirectUnauthenticatedUser","route","searchParams","localeParam","locale","payload","collections","globals","i18n","i18nConfig","localization","routes","admin","adminRoute","queryString","stringify","addQueryPrefix","defaultLocale","localeCode","cookies","language","context","req","fallbackLocale","code","host","get","query","parse","depth","ignoreQueryPrefix","url","serverURL","permissions","user","auth","visibleEntities","map","slug","hidden","filter","Boolean","collectionConfig","docID","globalConfig","translations"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAGA,SAASA,QAAQ,QAAQ,2BAA0B;AACnD,SAASC,kBAAkB,QAAQ,8CAA6C;AAChF,SAASC,WAAWC,UAAU,QAAQ,kBAAiB;AACvD,SAASC,YAAY,QAAQ,eAAc;AAC3C,SAASC,cAAc,EAAEC,cAAc,QAAQ,oBAAmB;AAClE,OAAOC,QAAQ,KAAI;AAInB,SAASC,aAAa,QAAQ,sBAAqB;AACnD,SAASC,kBAAkB,QAAQ,2BAA0B;AAC7D,SAASC,eAAe,QAAQ,uBAAsB;AACtD,SAASC,kBAAkB,QAAQ,0BAAyB;AAE5D,OAAO,MAAMC,WAAW,OAAO,EAC7BC,QAAQC,aAAa,EACrBC,8BAA8B,KAAK,EACnCC,KAAK,EACLC,YAAY,EACP;IACL,MAAMf,UAAUC;IAChB,MAAMe,cAAcD,cAAcE;IAClC,MAAMC,UAAU,MAAMZ,cAAc;QAAEK,QAAQC;IAAc;IAE5D,MAAM,EACJO,WAAW,EACXC,OAAO,EACPC,MAAMC,UAAU,EAChBC,YAAY,EACZC,QAAQ,EAAEC,OAAOC,UAAU,EAAE,EAC9B,GAAGR,QAAQP,MAAM;IAElB,MAAMgB,cAAc,CAAC,EAAEtB,GAAGuB,SAAS,CAACb,gBAAgB,CAAC,GAAG;QAAEc,gBAAgB;IAAK,GAAG,CAAC;IACnF,MAAMC,gBACJP,gBAAgBA,aAAaO,aAAa,GAAGP,aAAaO,aAAa,GAAG;IAC5E,MAAMC,aAAaf,eAAec;IAClC,MAAMb,SAASM,gBAAgBxB,mBAAmBwB,cAAcQ;IAChE,MAAMC,UAAU9B,aAAaF;IAC7B,MAAMiC,WAAW1B,mBAAmB;QAAEI,QAAQO,QAAQP,MAAM;QAAEqB;QAAShC;IAAQ;IAE/E,MAAMqB,OAAmB,MAAMvB,SAAS;QACtCa,QAAQW;QACRY,SAAS;QACTD;IACF;IAEA,MAAME,MAAM,MAAMhC,eAChB;QACEiC,gBAAgB;QAChBnB,QAAQA,OAAOoB,IAAI;QACnBF,KAAK;YACHG,MAAMtC,QAAQuC,GAAG,CAAC;YAClBlB;YACAmB,OAAOnC,GAAGoC,KAAK,CAACd,aAAa;gBAC3Be,OAAO;gBACPC,mBAAmB;YACrB;YACAC,KAAK,CAAC,EAAE1B,QAAQP,MAAM,CAACkC,SAAS,CAAC,EAAE/B,MAAM,EAAEC,eAAeY,cAAc,GAAG,CAAC;QAC9E;IACF,GACAT;IAGF,MAAM,EAAE4B,WAAW,EAAEC,IAAI,EAAE,GAAG,MAAM7B,QAAQ8B,IAAI,CAAC;QAAEhD;QAASmC;IAAI;IAEhEA,IAAIY,IAAI,GAAGA;IAEX,MAAME,kBAAmC;QACvC9B,aAAaA,YACV+B,GAAG,CAAC,CAAC,EAAEC,IAAI,EAAE1B,OAAO,EAAE2B,MAAM,EAAE,EAAE,GAAM,CAAChD,eAAe;gBAAEgD;gBAAQL;YAAK,KAAKI,OAAO,MACjFE,MAAM,CAACC;QACVlC,SAASA,QACN8B,GAAG,CAAC,CAAC,EAAEC,IAAI,EAAE1B,OAAO,EAAE2B,MAAM,EAAE,EAAE,GAAM,CAAChD,eAAe;gBAAEgD;gBAAQL;YAAK,KAAKI,OAAO,MACjFE,MAAM,CAACC;IACZ;IAEA,IAAIzC,+BAA+B,CAACkC,MAAM;QACxCtC,mBAAmB;YACjBE,QAAQO,QAAQP,MAAM;YACtBE;YACAC;YACAC;QACF;IACF;IAEA,MAAM,EAAEwC,gBAAgB,EAAEC,KAAK,EAAEC,YAAY,EAAE,GAAGjD,gBAAgB;QAChEkB;QACAf,QAAQO,QAAQP,MAAM;QACtBmC;QACAhC;IACF;IAEA,OAAO;QACLyC;QACAvB;QACAwB;QACAC;QACAxC;QACA6B;QACAX;QACAuB,cAAcrC,KAAKqC,YAAY;QAC/BT;IACF;AACF,EAAC"}
@@ -1,4 +1,5 @@
1
1
  'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
3
  import { Chevron } from '@payloadcms/ui/icons/Chevron';
3
4
  import * as React from 'react';
4
5
  const chars = {
@@ -12,82 +13,110 @@ const Bracket = ({ type, comma = false, position })=>{
12
13
  const rightBracket = type === 'object' ? chars.rightCurlyBracket : chars.rightSquareBracket;
13
14
  const leftBracket = type === 'object' ? chars.leftCurlyBracket : chars.leftSquareBracket;
14
15
  const bracketToRender = position === 'end' ? rightBracket : leftBracket;
15
- return /*#__PURE__*/ React.createElement("span", {
16
- className: `${baseClass}__bracket ${baseClass}__bracket--position-${position}`
17
- }, bracketToRender, position === 'end' && comma ? ',' : null);
16
+ return /*#__PURE__*/ _jsxs("span", {
17
+ className: `${baseClass}__bracket ${baseClass}__bracket--position-${position}`,
18
+ children: [
19
+ bracketToRender,
20
+ position === 'end' && comma ? ',' : null
21
+ ]
22
+ });
18
23
  };
19
24
  export const RenderJSON = ({ isEmpty = false, object, objectKey, parentType = 'object', trailingComma = false })=>{
20
25
  const objectKeys = object ? Object.keys(object) : [];
21
26
  const objectLength = objectKeys.length;
22
27
  const [isOpen, setIsOpen] = React.useState(true);
23
28
  const isNestedAndEmpty = isEmpty && (parentType === 'object' || parentType === 'array');
24
- return /*#__PURE__*/ React.createElement("li", {
25
- className: isNestedAndEmpty ? `${baseClass}__row-line--nested` : ''
26
- }, /*#__PURE__*/ React.createElement("button", {
27
- "aria-label": "toggle",
28
- className: `${baseClass}__list-toggle ${isEmpty ? `${baseClass}__list-toggle--empty` : ''}`,
29
- onClick: ()=>setIsOpen(!isOpen),
30
- type: "button"
31
- }, isEmpty ? null : /*#__PURE__*/ React.createElement(Chevron, {
32
- className: `${baseClass}__toggle-row-icon ${baseClass}__toggle-row-icon--${isOpen ? 'open' : 'closed'}`
33
- }), /*#__PURE__*/ React.createElement("span", null, objectKey && `"${objectKey}": `, /*#__PURE__*/ React.createElement(Bracket, {
34
- position: "start",
35
- type: parentType
36
- }), isEmpty ? /*#__PURE__*/ React.createElement(Bracket, {
37
- comma: trailingComma,
38
- position: "end",
39
- type: parentType
40
- }) : null)), /*#__PURE__*/ React.createElement("ul", {
41
- className: `${baseClass}__json-children`
42
- }, isOpen && objectKeys.map((key, keyIndex)=>{
43
- let value = object[key];
44
- let type = 'string';
45
- const isLastKey = keyIndex === objectLength - 1;
46
- if (value === null) {
47
- type = 'null';
48
- } else if (value instanceof Date) {
49
- type = 'date';
50
- value = value.toISOString();
51
- } else if (Array.isArray(value)) {
52
- type = 'array';
53
- } else if (typeof value === 'object') {
54
- type = 'object';
55
- } else if (typeof value === 'number') {
56
- type = 'number';
57
- } else if (typeof value === 'boolean') {
58
- type = 'boolean';
59
- } else {
60
- type = 'string';
61
- }
62
- if (type === 'object' || type === 'array') {
63
- return /*#__PURE__*/ React.createElement(RenderJSON, {
64
- isEmpty: value.length === 0 || Object.keys(value).length === 0,
65
- key: `${key}-${keyIndex}`,
66
- object: value,
67
- objectKey: parentType === 'object' ? key : undefined,
68
- parentType: type,
69
- trailingComma: !isLastKey
70
- });
71
- }
72
- if (type === 'date' || type === 'string' || type === 'null' || type === 'number' || type === 'boolean') {
73
- const parentHasKey = Boolean(parentType === 'object' && key);
74
- const rowClasses = [
75
- `${baseClass}__row-line`,
76
- `${baseClass}__value-type--${type}`,
77
- `${baseClass}__row-line--${objectKey ? 'nested' : 'top'}`
78
- ].filter(Boolean).join(' ');
79
- return /*#__PURE__*/ React.createElement("li", {
80
- className: rowClasses,
81
- key: `${key}-${keyIndex}`
82
- }, parentHasKey ? /*#__PURE__*/ React.createElement("span", null, `"${key}": `) : null, /*#__PURE__*/ React.createElement("span", {
83
- className: `${baseClass}__value`
84
- }, JSON.stringify(value)), isLastKey ? '' : ',');
85
- }
86
- })), !isEmpty && /*#__PURE__*/ React.createElement("span", null, /*#__PURE__*/ React.createElement(Bracket, {
87
- comma: trailingComma,
88
- position: "end",
89
- type: parentType
90
- })));
29
+ return /*#__PURE__*/ _jsxs("li", {
30
+ className: isNestedAndEmpty ? `${baseClass}__row-line--nested` : '',
31
+ children: [
32
+ /*#__PURE__*/ _jsxs("button", {
33
+ "aria-label": "toggle",
34
+ className: `${baseClass}__list-toggle ${isEmpty ? `${baseClass}__list-toggle--empty` : ''}`,
35
+ onClick: ()=>setIsOpen(!isOpen),
36
+ type: "button",
37
+ children: [
38
+ isEmpty ? null : /*#__PURE__*/ _jsx(Chevron, {
39
+ className: `${baseClass}__toggle-row-icon ${baseClass}__toggle-row-icon--${isOpen ? 'open' : 'closed'}`
40
+ }),
41
+ /*#__PURE__*/ _jsxs("span", {
42
+ children: [
43
+ objectKey && `"${objectKey}": `,
44
+ /*#__PURE__*/ _jsx(Bracket, {
45
+ position: "start",
46
+ type: parentType
47
+ }),
48
+ isEmpty ? /*#__PURE__*/ _jsx(Bracket, {
49
+ comma: trailingComma,
50
+ position: "end",
51
+ type: parentType
52
+ }) : null
53
+ ]
54
+ })
55
+ ]
56
+ }),
57
+ /*#__PURE__*/ _jsx("ul", {
58
+ className: `${baseClass}__json-children`,
59
+ children: isOpen && objectKeys.map((key, keyIndex)=>{
60
+ let value = object[key];
61
+ let type = 'string';
62
+ const isLastKey = keyIndex === objectLength - 1;
63
+ if (value === null) {
64
+ type = 'null';
65
+ } else if (value instanceof Date) {
66
+ type = 'date';
67
+ value = value.toISOString();
68
+ } else if (Array.isArray(value)) {
69
+ type = 'array';
70
+ } else if (typeof value === 'object') {
71
+ type = 'object';
72
+ } else if (typeof value === 'number') {
73
+ type = 'number';
74
+ } else if (typeof value === 'boolean') {
75
+ type = 'boolean';
76
+ } else {
77
+ type = 'string';
78
+ }
79
+ if (type === 'object' || type === 'array') {
80
+ return /*#__PURE__*/ _jsx(RenderJSON, {
81
+ isEmpty: value.length === 0 || Object.keys(value).length === 0,
82
+ object: value,
83
+ objectKey: parentType === 'object' ? key : undefined,
84
+ parentType: type,
85
+ trailingComma: !isLastKey
86
+ }, `${key}-${keyIndex}`);
87
+ }
88
+ if (type === 'date' || type === 'string' || type === 'null' || type === 'number' || type === 'boolean') {
89
+ const parentHasKey = Boolean(parentType === 'object' && key);
90
+ const rowClasses = [
91
+ `${baseClass}__row-line`,
92
+ `${baseClass}__value-type--${type}`,
93
+ `${baseClass}__row-line--${objectKey ? 'nested' : 'top'}`
94
+ ].filter(Boolean).join(' ');
95
+ return /*#__PURE__*/ _jsxs("li", {
96
+ className: rowClasses,
97
+ children: [
98
+ parentHasKey ? /*#__PURE__*/ _jsx("span", {
99
+ children: `"${key}": `
100
+ }) : null,
101
+ /*#__PURE__*/ _jsx("span", {
102
+ className: `${baseClass}__value`,
103
+ children: JSON.stringify(value)
104
+ }),
105
+ isLastKey ? '' : ','
106
+ ]
107
+ }, `${key}-${keyIndex}`);
108
+ }
109
+ })
110
+ }),
111
+ !isEmpty && /*#__PURE__*/ _jsx("span", {
112
+ children: /*#__PURE__*/ _jsx(Bracket, {
113
+ comma: trailingComma,
114
+ position: "end",
115
+ type: parentType
116
+ })
117
+ })
118
+ ]
119
+ });
91
120
  };
92
121
 
93
122
  //# sourceMappingURL=index.js.map