@payloadcms/next 3.81.0-internal-debug.1a0f4d0 → 3.81.0

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 (466) hide show
  1. package/dist/auth/login.js +58 -52
  2. package/dist/auth/login.js.map +1 -1
  3. package/dist/auth/logout.js +44 -39
  4. package/dist/auth/logout.js.map +1 -1
  5. package/dist/auth/refresh.js +47 -45
  6. package/dist/auth/refresh.js.map +1 -1
  7. package/dist/cjs/withPayload.cjs +27 -65
  8. package/dist/cjs/withPayload.cjs.map +3 -3
  9. package/dist/config.js +0 -1
  10. package/dist/config.js.map +1 -1
  11. package/dist/elements/DocumentHeader/Tabs/ShouldRenderTabs.js +15 -9
  12. package/dist/elements/DocumentHeader/Tabs/ShouldRenderTabs.js.map +1 -1
  13. package/dist/elements/DocumentHeader/Tabs/Tab/TabLink.js +71 -40
  14. package/dist/elements/DocumentHeader/Tabs/Tab/TabLink.js.map +1 -1
  15. package/dist/elements/DocumentHeader/Tabs/Tab/index.js +59 -65
  16. package/dist/elements/DocumentHeader/Tabs/Tab/index.js.map +1 -1
  17. package/dist/elements/DocumentHeader/Tabs/index.js +70 -80
  18. package/dist/elements/DocumentHeader/Tabs/index.js.map +1 -1
  19. package/dist/elements/DocumentHeader/Tabs/tabs/VersionsPill/index.js +23 -16
  20. package/dist/elements/DocumentHeader/Tabs/tabs/VersionsPill/index.js.map +1 -1
  21. package/dist/elements/DocumentHeader/Tabs/tabs/index.js +69 -61
  22. package/dist/elements/DocumentHeader/Tabs/tabs/index.js.map +1 -1
  23. package/dist/elements/DocumentHeader/index.js +28 -48
  24. package/dist/elements/DocumentHeader/index.js.map +1 -1
  25. package/dist/elements/FormHeader/index.js +16 -30
  26. package/dist/elements/FormHeader/index.js.map +1 -1
  27. package/dist/elements/Logo/index.js +34 -19
  28. package/dist/elements/Logo/index.js.map +1 -1
  29. package/dist/elements/Nav/NavHamburger/index.js +44 -23
  30. package/dist/elements/Nav/NavHamburger/index.js.map +1 -1
  31. package/dist/elements/Nav/NavWrapper/index.js +54 -28
  32. package/dist/elements/Nav/NavWrapper/index.js.map +1 -1
  33. package/dist/elements/Nav/SettingsMenuButton/index.js +39 -33
  34. package/dist/elements/Nav/SettingsMenuButton/index.js.map +1 -1
  35. package/dist/elements/Nav/getNavPrefs.js +22 -27
  36. package/dist/elements/Nav/getNavPrefs.js.map +1 -1
  37. package/dist/elements/Nav/index.client.js +118 -97
  38. package/dist/elements/Nav/index.client.js.map +1 -1
  39. package/dist/elements/Nav/index.js +170 -191
  40. package/dist/elements/Nav/index.js.map +1 -1
  41. package/dist/exports/auth.js +0 -1
  42. package/dist/exports/auth.js.map +1 -1
  43. package/dist/exports/client.js +1 -1
  44. package/dist/exports/client.js.map +1 -1
  45. package/dist/exports/layouts.js +0 -1
  46. package/dist/exports/layouts.js.map +1 -1
  47. package/dist/exports/routes.js +0 -1
  48. package/dist/exports/routes.js.map +1 -1
  49. package/dist/exports/rsc.js +0 -1
  50. package/dist/exports/rsc.js.map +1 -1
  51. package/dist/exports/templates.js +0 -1
  52. package/dist/exports/templates.js.map +1 -1
  53. package/dist/exports/utilities.js +12 -7
  54. package/dist/exports/utilities.js.map +1 -1
  55. package/dist/exports/views.js +0 -1
  56. package/dist/exports/views.js.map +1 -1
  57. package/dist/index.js +0 -1
  58. package/dist/index.js.map +1 -1
  59. package/dist/layouts/Root/NestProviders.js +20 -21
  60. package/dist/layouts/Root/NestProviders.js.map +1 -1
  61. package/dist/layouts/Root/checkDependencies.js +41 -49
  62. package/dist/layouts/Root/checkDependencies.js.map +1 -1
  63. package/dist/layouts/Root/index.d.ts +4 -2
  64. package/dist/layouts/Root/index.d.ts.map +1 -1
  65. package/dist/layouts/Root/index.js +125 -128
  66. package/dist/layouts/Root/index.js.map +1 -1
  67. package/dist/prod/styles.css +1 -5
  68. package/dist/routes/graphql/handler.js +122 -114
  69. package/dist/routes/graphql/handler.js.map +1 -1
  70. package/dist/routes/graphql/index.js +0 -1
  71. package/dist/routes/graphql/index.js.map +1 -1
  72. package/dist/routes/graphql/playground.js +27 -28
  73. package/dist/routes/graphql/playground.js.map +1 -1
  74. package/dist/routes/index.js +0 -1
  75. package/dist/routes/index.js.map +1 -1
  76. package/dist/routes/rest/index.js +22 -23
  77. package/dist/routes/rest/index.js.map +1 -1
  78. package/dist/routes/rest/og/image.js +79 -103
  79. package/dist/routes/rest/og/image.js.map +1 -1
  80. package/dist/routes/rest/og/index.js +54 -59
  81. package/dist/routes/rest/og/index.js.map +1 -1
  82. package/dist/templates/Default/NavHamburger/index.js +20 -12
  83. package/dist/templates/Default/NavHamburger/index.js.map +1 -1
  84. package/dist/templates/Default/Wrapper/index.js +44 -20
  85. package/dist/templates/Default/Wrapper/index.js.map +1 -1
  86. package/dist/templates/Default/index.js +116 -147
  87. package/dist/templates/Default/index.js.map +1 -1
  88. package/dist/templates/Minimal/index.js +17 -26
  89. package/dist/templates/Minimal/index.js.map +1 -1
  90. package/dist/utilities/getExistingAuthToken.js +2 -3
  91. package/dist/utilities/getExistingAuthToken.js.map +1 -1
  92. package/dist/utilities/getNextRequestI18n.js +13 -12
  93. package/dist/utilities/getNextRequestI18n.js.map +1 -1
  94. package/dist/utilities/getPayloadHMR.js +5 -5
  95. package/dist/utilities/getPayloadHMR.js.map +1 -1
  96. package/dist/utilities/getPreferences.js +22 -27
  97. package/dist/utilities/getPreferences.js.map +1 -1
  98. package/dist/utilities/getRequestLocale.js +14 -13
  99. package/dist/utilities/getRequestLocale.js.map +1 -1
  100. package/dist/utilities/getRequestTheme.js +19 -19
  101. package/dist/utilities/getRequestTheme.js.map +1 -1
  102. package/dist/utilities/getRouteWithoutAdmin.js +5 -3
  103. package/dist/utilities/getRouteWithoutAdmin.js.map +1 -1
  104. package/dist/utilities/handleAuthRedirect.js +36 -22
  105. package/dist/utilities/handleAuthRedirect.js.map +1 -1
  106. package/dist/utilities/handleServerFunctions.js +43 -33
  107. package/dist/utilities/handleServerFunctions.js.map +1 -1
  108. package/dist/utilities/initReq.js +96 -78
  109. package/dist/utilities/initReq.js.map +1 -1
  110. package/dist/utilities/isCustomAdminView.d.ts.map +1 -1
  111. package/dist/utilities/isCustomAdminView.js +26 -22
  112. package/dist/utilities/isCustomAdminView.js.map +1 -1
  113. package/dist/utilities/isCustomAdminView.spec.js +90 -0
  114. package/dist/utilities/isCustomAdminView.spec.js.map +1 -0
  115. package/dist/utilities/isPublicAdminRoute.js +20 -26
  116. package/dist/utilities/isPublicAdminRoute.js.map +1 -1
  117. package/dist/utilities/meta.js +63 -68
  118. package/dist/utilities/meta.js.map +1 -1
  119. package/dist/utilities/selectiveCache.js +26 -25
  120. package/dist/utilities/selectiveCache.js.map +1 -1
  121. package/dist/utilities/setPayloadAuthCookie.js +22 -19
  122. package/dist/utilities/setPayloadAuthCookie.js.map +1 -1
  123. package/dist/utilities/slugify.js +33 -24
  124. package/dist/utilities/slugify.js.map +1 -1
  125. package/dist/utilities/timestamp.js +6 -7
  126. package/dist/utilities/timestamp.js.map +1 -1
  127. package/dist/views/API/LocaleSelector/index.js +39 -17
  128. package/dist/views/API/LocaleSelector/index.js.map +1 -1
  129. package/dist/views/API/RenderJSON/index.js +126 -171
  130. package/dist/views/API/RenderJSON/index.js.map +1 -1
  131. package/dist/views/API/index.client.d.ts.map +1 -1
  132. package/dist/views/API/index.client.js +205 -290
  133. package/dist/views/API/index.client.js.map +1 -1
  134. package/dist/views/API/index.js +2 -7
  135. package/dist/views/API/index.js.map +1 -1
  136. package/dist/views/API/metadata.js +23 -18
  137. package/dist/views/API/metadata.js.map +1 -1
  138. package/dist/views/Account/ResetPreferences/index.js +100 -76
  139. package/dist/views/Account/ResetPreferences/index.js.map +1 -1
  140. package/dist/views/Account/Settings/LanguageSelector.js +47 -18
  141. package/dist/views/Account/Settings/LanguageSelector.js.map +1 -1
  142. package/dist/views/Account/Settings/index.js +25 -60
  143. package/dist/views/Account/Settings/index.js.map +1 -1
  144. package/dist/views/Account/ToggleTheme/index.js +55 -38
  145. package/dist/views/Account/ToggleTheme/index.js.map +1 -1
  146. package/dist/views/Account/index.client.js +32 -16
  147. package/dist/views/Account/index.client.js.map +1 -1
  148. package/dist/views/Account/index.js +162 -149
  149. package/dist/views/Account/index.js.map +1 -1
  150. package/dist/views/Account/metadata.js +12 -8
  151. package/dist/views/Account/metadata.js.map +1 -1
  152. package/dist/views/BrowseByFolder/buildView.js +157 -138
  153. package/dist/views/BrowseByFolder/buildView.js.map +1 -1
  154. package/dist/views/BrowseByFolder/index.js +16 -16
  155. package/dist/views/BrowseByFolder/index.js.map +1 -1
  156. package/dist/views/BrowseByFolder/metadata.js +15 -13
  157. package/dist/views/BrowseByFolder/metadata.js.map +1 -1
  158. package/dist/views/CollectionFolders/buildView.js +142 -122
  159. package/dist/views/CollectionFolders/buildView.js.map +1 -1
  160. package/dist/views/CollectionFolders/index.js +16 -16
  161. package/dist/views/CollectionFolders/index.js.map +1 -1
  162. package/dist/views/CollectionFolders/metadata.js +21 -18
  163. package/dist/views/CollectionFolders/metadata.js.map +1 -1
  164. package/dist/views/CollectionFolders/renderFolderViewSlots.js +61 -58
  165. package/dist/views/CollectionFolders/renderFolderViewSlots.js.map +1 -1
  166. package/dist/views/CollectionTrash/index.js +17 -17
  167. package/dist/views/CollectionTrash/index.js.map +1 -1
  168. package/dist/views/CollectionTrash/metadata.js +21 -18
  169. package/dist/views/CollectionTrash/metadata.js.map +1 -1
  170. package/dist/views/CreateFirstUser/index.client.js +103 -117
  171. package/dist/views/CreateFirstUser/index.client.js.map +1 -1
  172. package/dist/views/CreateFirstUser/index.js +81 -87
  173. package/dist/views/CreateFirstUser/index.js.map +1 -1
  174. package/dist/views/CreateFirstUser/metadata.js +12 -8
  175. package/dist/views/CreateFirstUser/metadata.js.map +1 -1
  176. package/dist/views/Dashboard/Default/ModularDashboard/DashboardStepNav.js +170 -145
  177. package/dist/views/Dashboard/Default/ModularDashboard/DashboardStepNav.js.map +1 -1
  178. package/dist/views/Dashboard/Default/ModularDashboard/WidgetConfigDrawer.js +118 -144
  179. package/dist/views/Dashboard/Default/ModularDashboard/WidgetConfigDrawer.js.map +1 -1
  180. package/dist/views/Dashboard/Default/ModularDashboard/WidgetEditControl.js +72 -59
  181. package/dist/views/Dashboard/Default/ModularDashboard/WidgetEditControl.js.map +1 -1
  182. package/dist/views/Dashboard/Default/ModularDashboard/index.client.js +414 -435
  183. package/dist/views/Dashboard/Default/ModularDashboard/index.client.js.map +1 -1
  184. package/dist/views/Dashboard/Default/ModularDashboard/index.js +63 -54
  185. package/dist/views/Dashboard/Default/ModularDashboard/index.js.map +1 -1
  186. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/RenderWidget.js +96 -65
  187. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/RenderWidget.js.map +1 -1
  188. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/getDefaultLayoutServerFn.js +54 -44
  189. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/getDefaultLayoutServerFn.js.map +1 -1
  190. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/renderWidgetServerFn.js +72 -65
  191. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/renderWidgetServerFn.js.map +1 -1
  192. package/dist/views/Dashboard/Default/ModularDashboard/useDashboardLayout.js +175 -193
  193. package/dist/views/Dashboard/Default/ModularDashboard/useDashboardLayout.js.map +1 -1
  194. package/dist/views/Dashboard/Default/ModularDashboard/utils/collisionDetection.js +30 -31
  195. package/dist/views/Dashboard/Default/ModularDashboard/utils/collisionDetection.js.map +1 -1
  196. package/dist/views/Dashboard/Default/ModularDashboard/utils/getItemsFromConfig.js +17 -18
  197. package/dist/views/Dashboard/Default/ModularDashboard/utils/getItemsFromConfig.js.map +1 -1
  198. package/dist/views/Dashboard/Default/ModularDashboard/utils/getItemsFromPreferences.js +5 -6
  199. package/dist/views/Dashboard/Default/ModularDashboard/utils/getItemsFromPreferences.js.map +1 -1
  200. package/dist/views/Dashboard/Default/ModularDashboard/utils/localeUtils.js +74 -69
  201. package/dist/views/Dashboard/Default/ModularDashboard/utils/localeUtils.js.map +1 -1
  202. package/dist/views/Dashboard/Default/ModularDashboard/utils/sensors.js +234 -228
  203. package/dist/views/Dashboard/Default/ModularDashboard/utils/sensors.js.map +1 -1
  204. package/dist/views/Dashboard/Default/index.js +45 -59
  205. package/dist/views/Dashboard/Default/index.js.map +1 -1
  206. package/dist/views/Dashboard/index.js +42 -46
  207. package/dist/views/Dashboard/index.js.map +1 -1
  208. package/dist/views/Dashboard/metadata.js +14 -10
  209. package/dist/views/Dashboard/metadata.js.map +1 -1
  210. package/dist/views/Document/getCustomDocumentViewByKey.js +2 -3
  211. package/dist/views/Document/getCustomDocumentViewByKey.js.map +1 -1
  212. package/dist/views/Document/getCustomViewByRoute.js +30 -27
  213. package/dist/views/Document/getCustomViewByRoute.js.map +1 -1
  214. package/dist/views/Document/getDocPreferences.js +41 -40
  215. package/dist/views/Document/getDocPreferences.js.map +1 -1
  216. package/dist/views/Document/getDocumentData.js +55 -44
  217. package/dist/views/Document/getDocumentData.js.map +1 -1
  218. package/dist/views/Document/getDocumentPermissions.js +117 -114
  219. package/dist/views/Document/getDocumentPermissions.js.map +1 -1
  220. package/dist/views/Document/getDocumentView.js +283 -313
  221. package/dist/views/Document/getDocumentView.js.map +1 -1
  222. package/dist/views/Document/getIsLocked.js +73 -73
  223. package/dist/views/Document/getIsLocked.js.map +1 -1
  224. package/dist/views/Document/getMetaBySegment.js +136 -130
  225. package/dist/views/Document/getMetaBySegment.js.map +1 -1
  226. package/dist/views/Document/getVersions.js +213 -220
  227. package/dist/views/Document/getVersions.js.map +1 -1
  228. package/dist/views/Document/handleServerFunction.js +127 -100
  229. package/dist/views/Document/handleServerFunction.js.map +1 -1
  230. package/dist/views/Document/index.js +359 -319
  231. package/dist/views/Document/index.js.map +1 -1
  232. package/dist/views/Document/metadata.js +1 -2
  233. package/dist/views/Document/metadata.js.map +1 -1
  234. package/dist/views/Document/renderDocumentSlots.js +155 -141
  235. package/dist/views/Document/renderDocumentSlots.js.map +1 -1
  236. package/dist/views/Edit/index.js +6 -10
  237. package/dist/views/Edit/index.js.map +1 -1
  238. package/dist/views/Edit/metadata.js +46 -36
  239. package/dist/views/Edit/metadata.js.map +1 -1
  240. package/dist/views/ForgotPassword/ForgotPasswordForm/index.d.ts.map +1 -1
  241. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js +169 -132
  242. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js.map +1 -1
  243. package/dist/views/ForgotPassword/index.js +62 -79
  244. package/dist/views/ForgotPassword/index.js.map +1 -1
  245. package/dist/views/ForgotPassword/metadata.js +12 -8
  246. package/dist/views/ForgotPassword/metadata.js.map +1 -1
  247. package/dist/views/List/createSerializableValue.js +11 -12
  248. package/dist/views/List/createSerializableValue.js.map +1 -1
  249. package/dist/views/List/enrichDocsWithVersionStatus.js +86 -86
  250. package/dist/views/List/enrichDocsWithVersionStatus.js.map +1 -1
  251. package/dist/views/List/extractRelationshipDisplayValue.js +14 -15
  252. package/dist/views/List/extractRelationshipDisplayValue.js.map +1 -1
  253. package/dist/views/List/extractValueOrRelationshipID.js +15 -16
  254. package/dist/views/List/extractValueOrRelationshipID.js.map +1 -1
  255. package/dist/views/List/handleGroupBy.js +150 -133
  256. package/dist/views/List/handleGroupBy.js.map +1 -1
  257. package/dist/views/List/handleServerFunction.js +122 -96
  258. package/dist/views/List/handleServerFunction.js.map +1 -1
  259. package/dist/views/List/index.js +325 -306
  260. package/dist/views/List/index.js.map +1 -1
  261. package/dist/views/List/metadata.js +20 -17
  262. package/dist/views/List/metadata.js.map +1 -1
  263. package/dist/views/List/renderListViewSlots.js +75 -82
  264. package/dist/views/List/renderListViewSlots.js.map +1 -1
  265. package/dist/views/List/resolveAllFilterOptions.js +45 -43
  266. package/dist/views/List/resolveAllFilterOptions.js.map +1 -1
  267. package/dist/views/List/transformColumnsToSelect.js +8 -9
  268. package/dist/views/List/transformColumnsToSelect.js.map +1 -1
  269. package/dist/views/Login/LoginField/index.js +89 -57
  270. package/dist/views/Login/LoginField/index.js.map +1 -1
  271. package/dist/views/Login/LoginForm/index.js +160 -107
  272. package/dist/views/Login/LoginForm/index.js.map +1 -1
  273. package/dist/views/Login/index.js +85 -82
  274. package/dist/views/Login/index.js.map +1 -1
  275. package/dist/views/Login/metadata.js +12 -8
  276. package/dist/views/Login/metadata.js.map +1 -1
  277. package/dist/views/Logout/LogoutClient.js +120 -84
  278. package/dist/views/Logout/LogoutClient.js.map +1 -1
  279. package/dist/views/Logout/index.js +29 -29
  280. package/dist/views/Logout/index.js.map +1 -1
  281. package/dist/views/Logout/metadata.js +11 -7
  282. package/dist/views/Logout/metadata.js.map +1 -1
  283. package/dist/views/NotFound/index.client.js +82 -71
  284. package/dist/views/NotFound/index.client.js.map +1 -1
  285. package/dist/views/NotFound/index.js +73 -72
  286. package/dist/views/NotFound/index.js.map +1 -1
  287. package/dist/views/NotFound/metadata.js +9 -7
  288. package/dist/views/NotFound/metadata.js.map +1 -1
  289. package/dist/views/ResetPassword/ResetPasswordForm/index.js +108 -97
  290. package/dist/views/ResetPassword/ResetPasswordForm/index.js.map +1 -1
  291. package/dist/views/ResetPassword/index.js +73 -93
  292. package/dist/views/ResetPassword/index.js.map +1 -1
  293. package/dist/views/ResetPassword/metadata.js +12 -8
  294. package/dist/views/ResetPassword/metadata.js.map +1 -1
  295. package/dist/views/Root/attachViewActions.js +23 -18
  296. package/dist/views/Root/attachViewActions.js.map +1 -1
  297. package/dist/views/Root/generateCustomViewMetadata.js +21 -19
  298. package/dist/views/Root/generateCustomViewMetadata.js.map +1 -1
  299. package/dist/views/Root/getCustomViewByKey.js +14 -12
  300. package/dist/views/Root/getCustomViewByKey.js.map +1 -1
  301. package/dist/views/Root/getCustomViewByRoute.js +42 -31
  302. package/dist/views/Root/getCustomViewByRoute.js.map +1 -1
  303. package/dist/views/Root/getDocumentViewInfo.js +23 -24
  304. package/dist/views/Root/getDocumentViewInfo.js.map +1 -1
  305. package/dist/views/Root/getRouteData.js +325 -333
  306. package/dist/views/Root/getRouteData.js.map +1 -1
  307. package/dist/views/Root/index.js +270 -248
  308. package/dist/views/Root/index.js.map +1 -1
  309. package/dist/views/Root/isPathMatchingRoute.js +26 -21
  310. package/dist/views/Root/isPathMatchingRoute.js.map +1 -1
  311. package/dist/views/Root/metadata.js +181 -176
  312. package/dist/views/Root/metadata.js.map +1 -1
  313. package/dist/views/Unauthorized/index.js +46 -54
  314. package/dist/views/Unauthorized/index.js.map +1 -1
  315. package/dist/views/Unauthorized/metadata.js +12 -8
  316. package/dist/views/Unauthorized/metadata.js.map +1 -1
  317. package/dist/views/Verify/index.client.js +43 -25
  318. package/dist/views/Verify/index.client.js.map +1 -1
  319. package/dist/views/Verify/index.js +64 -69
  320. package/dist/views/Verify/index.js.map +1 -1
  321. package/dist/views/Verify/metadata.js +12 -8
  322. package/dist/views/Verify/metadata.js.map +1 -1
  323. package/dist/views/Version/Default/SelectedLocalesContext.js +4 -4
  324. package/dist/views/Version/Default/SelectedLocalesContext.js.map +1 -1
  325. package/dist/views/Version/Default/SetStepNav.js +127 -86
  326. package/dist/views/Version/Default/SetStepNav.js.map +1 -1
  327. package/dist/views/Version/Default/index.js +236 -380
  328. package/dist/views/Version/Default/index.js.map +1 -1
  329. package/dist/views/Version/Default/types.js +1 -2
  330. package/dist/views/Version/Default/types.js.map +1 -1
  331. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js +119 -102
  332. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js.map +1 -1
  333. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js +73 -78
  334. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js.map +1 -1
  335. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js +408 -363
  336. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js.map +1 -1
  337. package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js +51 -40
  338. package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js.map +1 -1
  339. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.js +70 -38
  340. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.js.map +1 -1
  341. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js +56 -59
  342. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js.map +1 -1
  343. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js +117 -139
  344. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js.map +1 -1
  345. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.js +61 -56
  346. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.js.map +1 -1
  347. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js +206 -224
  348. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js.map +1 -1
  349. package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.js +11 -17
  350. package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.js.map +1 -1
  351. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js +74 -49
  352. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js.map +1 -1
  353. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js +146 -135
  354. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js.map +1 -1
  355. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js +82 -57
  356. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js.map +1 -1
  357. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.js +211 -252
  358. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.js.map +1 -1
  359. package/dist/views/Version/RenderFieldsToDiff/fields/index.js +22 -23
  360. package/dist/views/Version/RenderFieldsToDiff/fields/index.js.map +1 -1
  361. package/dist/views/Version/RenderFieldsToDiff/index.js +9 -12
  362. package/dist/views/Version/RenderFieldsToDiff/index.js.map +1 -1
  363. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.js +228 -213
  364. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.js.map +1 -1
  365. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.spec.js +826 -1005
  366. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.spec.js.map +1 -1
  367. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.js +1 -2
  368. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.js.map +1 -1
  369. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.spec.js +43 -44
  370. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.spec.js.map +1 -1
  371. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.js +36 -32
  372. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.js.map +1 -1
  373. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.spec.js +129 -145
  374. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.spec.js.map +1 -1
  375. package/dist/views/Version/Restore/index.js +92 -117
  376. package/dist/views/Version/Restore/index.js.map +1 -1
  377. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.js +50 -33
  378. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.js.map +1 -1
  379. package/dist/views/Version/SelectComparison/VersionDrawer/index.js +226 -170
  380. package/dist/views/Version/SelectComparison/VersionDrawer/index.js.map +1 -1
  381. package/dist/views/Version/SelectComparison/index.js +50 -73
  382. package/dist/views/Version/SelectComparison/index.js.map +1 -1
  383. package/dist/views/Version/SelectComparison/types.js +1 -2
  384. package/dist/views/Version/SelectComparison/types.js.map +1 -1
  385. package/dist/views/Version/SelectLocales/index.js +32 -34
  386. package/dist/views/Version/SelectLocales/index.js.map +1 -1
  387. package/dist/views/Version/VersionPillLabel/VersionPillLabel.js +100 -106
  388. package/dist/views/Version/VersionPillLabel/VersionPillLabel.js.map +1 -1
  389. package/dist/views/Version/VersionPillLabel/getVersionLabel.js +35 -30
  390. package/dist/views/Version/VersionPillLabel/getVersionLabel.js.map +1 -1
  391. package/dist/views/Version/fetchVersions.js +138 -113
  392. package/dist/views/Version/fetchVersions.js.map +1 -1
  393. package/dist/views/Version/index.js +326 -328
  394. package/dist/views/Version/index.js.map +1 -1
  395. package/dist/views/Version/metadata.js +50 -43
  396. package/dist/views/Version/metadata.js.map +1 -1
  397. package/dist/views/Versions/buildColumns.js +79 -95
  398. package/dist/views/Versions/buildColumns.js.map +1 -1
  399. package/dist/views/Versions/cells/AutosaveCell/index.js +38 -34
  400. package/dist/views/Versions/cells/AutosaveCell/index.js.map +1 -1
  401. package/dist/views/Versions/cells/CreatedAt/index.js +53 -32
  402. package/dist/views/Versions/cells/CreatedAt/index.js.map +1 -1
  403. package/dist/views/Versions/cells/ID/index.js +8 -10
  404. package/dist/views/Versions/cells/ID/index.js.map +1 -1
  405. package/dist/views/Versions/index.client.js +83 -106
  406. package/dist/views/Versions/index.client.js.map +1 -1
  407. package/dist/views/Versions/index.js +164 -164
  408. package/dist/views/Versions/index.js.map +1 -1
  409. package/dist/views/Versions/metadata.js +44 -37
  410. package/dist/views/Versions/metadata.js.map +1 -1
  411. package/dist/views/Versions/types.js +1 -2
  412. package/dist/views/Versions/types.js.map +1 -1
  413. package/dist/withPayload/withPayload.d.ts.map +1 -1
  414. package/dist/withPayload/withPayload.js +180 -236
  415. package/dist/withPayload/withPayload.js.map +1 -1
  416. package/dist/withPayload/withPayload.spec.js +35 -36
  417. package/dist/withPayload/withPayload.spec.js.map +1 -1
  418. package/dist/withPayload/withPayload.utils.js +73 -65
  419. package/dist/withPayload/withPayload.utils.js.map +1 -1
  420. package/dist/withPayload/withPayloadLegacy.js +40 -41
  421. package/dist/withPayload/withPayloadLegacy.js.map +1 -1
  422. package/package.json +8 -8
  423. package/dist/elements/DocumentHeader/Tabs/Tab/index.scss +0 -38
  424. package/dist/elements/DocumentHeader/Tabs/index.scss +0 -54
  425. package/dist/elements/DocumentHeader/Tabs/tabs/VersionsPill/index.scss +0 -10
  426. package/dist/elements/DocumentHeader/index.scss +0 -64
  427. package/dist/elements/FormHeader/index.scss +0 -8
  428. package/dist/elements/Nav/NavWrapper/index.scss +0 -27
  429. package/dist/elements/Nav/SettingsMenuButton/index.scss +0 -11
  430. package/dist/elements/Nav/index.scss +0 -173
  431. package/dist/esbuildEntry.d.ts +0 -5
  432. package/dist/esbuildEntry.d.ts.map +0 -1
  433. package/dist/esbuildEntry.js +0 -6
  434. package/dist/esbuildEntry.js.map +0 -1
  435. package/dist/templates/Default/Wrapper/index.scss +0 -58
  436. package/dist/templates/Default/index.scss +0 -79
  437. package/dist/templates/Minimal/index.scss +0 -30
  438. package/dist/views/API/RenderJSON/index.scss +0 -129
  439. package/dist/views/API/index.scss +0 -119
  440. package/dist/views/Account/Settings/index.scss +0 -48
  441. package/dist/views/CreateFirstUser/index.scss +0 -21
  442. package/dist/views/Dashboard/Default/ModularDashboard/index.scss +0 -318
  443. package/dist/views/Login/LoginForm/index.scss +0 -10
  444. package/dist/views/Login/index.scss +0 -10
  445. package/dist/views/Logout/index.scss +0 -25
  446. package/dist/views/NotFound/index.scss +0 -57
  447. package/dist/views/ResetPassword/index.scss +0 -11
  448. package/dist/views/Unauthorized/index.scss +0 -14
  449. package/dist/views/Verify/index.scss +0 -16
  450. package/dist/views/Version/Default/index.scss +0 -170
  451. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.scss +0 -81
  452. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.scss +0 -12
  453. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.scss +0 -9
  454. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.scss +0 -59
  455. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.scss +0 -91
  456. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.scss +0 -4
  457. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.scss +0 -9
  458. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.scss +0 -4
  459. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.scss +0 -121
  460. package/dist/views/Version/RenderFieldsToDiff/index.scss +0 -24
  461. package/dist/views/Version/Restore/index.scss +0 -84
  462. package/dist/views/Version/SelectComparison/VersionDrawer/index.scss +0 -18
  463. package/dist/views/Version/SelectComparison/index.scss +0 -9
  464. package/dist/views/Version/VersionPillLabel/index.scss +0 -26
  465. package/dist/views/Versions/cells/AutosaveCell/index.scss +0 -9
  466. package/dist/views/Versions/index.scss +0 -110
@@ -0,0 +1,90 @@
1
+ import { describe, expect, it } from 'vitest';
2
+ import { isCustomAdminView } from './isCustomAdminView.js';
3
+ describe('isCustomAdminView', () => {
4
+ const adminRoute = '/admin';
5
+ const configWithCustomDashboard = {
6
+ admin: {
7
+ components: {
8
+ views: {
9
+ dashboard: {
10
+ path: '/'
11
+ }
12
+ }
13
+ }
14
+ }
15
+ };
16
+ it('should not bypass admin access for the root admin route even with a custom dashboard view', () => {
17
+ // The root path '/' maps to the dashboard — it is not a public custom view.
18
+ // canAccessAdmin must still be enforced for the admin root.
19
+ const result = isCustomAdminView({
20
+ adminRoute,
21
+ config: configWithCustomDashboard,
22
+ route: '/admin'
23
+ });
24
+ expect(result).toBe(false);
25
+ });
26
+ it('should not match collection routes as custom dashboard views when dashboard path is "/"', () => {
27
+ const result = isCustomAdminView({
28
+ adminRoute,
29
+ config: configWithCustomDashboard,
30
+ route: '/admin/collections/tickets'
31
+ });
32
+ expect(result).toBe(false);
33
+ });
34
+ it('should not match document routes as custom dashboard views when dashboard path is "/"', () => {
35
+ const result = isCustomAdminView({
36
+ adminRoute,
37
+ config: configWithCustomDashboard,
38
+ route: '/admin/collections/tickets/123'
39
+ });
40
+ expect(result).toBe(false);
41
+ });
42
+ it('should return false when no custom views are configured', () => {
43
+ const config = {};
44
+ const result = isCustomAdminView({
45
+ adminRoute,
46
+ config,
47
+ route: '/admin/collections/tickets'
48
+ });
49
+ expect(result).toBe(false);
50
+ });
51
+ it('should return true for a custom view with a non-root path', () => {
52
+ const config = {
53
+ admin: {
54
+ components: {
55
+ views: {
56
+ myCustomView: {
57
+ path: '/my-custom-view'
58
+ }
59
+ }
60
+ }
61
+ }
62
+ };
63
+ const result = isCustomAdminView({
64
+ adminRoute,
65
+ config,
66
+ route: '/admin/my-custom-view'
67
+ });
68
+ expect(result).toBe(true);
69
+ });
70
+ it('should not match collection routes when a non-root custom view path is set', () => {
71
+ const config = {
72
+ admin: {
73
+ components: {
74
+ views: {
75
+ myCustomView: {
76
+ path: '/my-custom-view'
77
+ }
78
+ }
79
+ }
80
+ }
81
+ };
82
+ const result = isCustomAdminView({
83
+ adminRoute,
84
+ config,
85
+ route: '/admin/collections/tickets'
86
+ });
87
+ expect(result).toBe(false);
88
+ });
89
+ });
90
+ //# sourceMappingURL=isCustomAdminView.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isCustomAdminView.spec.js","names":["describe","expect","it","isCustomAdminView","adminRoute","configWithCustomDashboard","admin","components","views","dashboard","path","result","config","route","toBe","myCustomView"],"sources":["../../src/utilities/isCustomAdminView.spec.ts"],"sourcesContent":["import type { SanitizedConfig } from 'payload'\n\nimport { describe, expect, it } from 'vitest'\n\nimport { isCustomAdminView } from './isCustomAdminView.js'\n\ndescribe('isCustomAdminView', () => {\n const adminRoute = '/admin'\n\n const configWithCustomDashboard = {\n admin: {\n components: {\n views: {\n dashboard: {\n path: '/',\n },\n },\n },\n },\n } as unknown as SanitizedConfig\n\n it('should not bypass admin access for the root admin route even with a custom dashboard view', () => {\n // The root path '/' maps to the dashboard — it is not a public custom view.\n // canAccessAdmin must still be enforced for the admin root.\n const result = isCustomAdminView({\n adminRoute,\n config: configWithCustomDashboard,\n route: '/admin',\n })\n\n expect(result).toBe(false)\n })\n\n it('should not match collection routes as custom dashboard views when dashboard path is \"/\"', () => {\n const result = isCustomAdminView({\n adminRoute,\n config: configWithCustomDashboard,\n route: '/admin/collections/tickets',\n })\n\n expect(result).toBe(false)\n })\n\n it('should not match document routes as custom dashboard views when dashboard path is \"/\"', () => {\n const result = isCustomAdminView({\n adminRoute,\n config: configWithCustomDashboard,\n route: '/admin/collections/tickets/123',\n })\n\n expect(result).toBe(false)\n })\n\n it('should return false when no custom views are configured', () => {\n const config = {} as SanitizedConfig\n\n const result = isCustomAdminView({\n adminRoute,\n config,\n route: '/admin/collections/tickets',\n })\n\n expect(result).toBe(false)\n })\n\n it('should return true for a custom view with a non-root path', () => {\n const config = {\n admin: {\n components: {\n views: {\n myCustomView: {\n path: '/my-custom-view',\n },\n },\n },\n },\n } as unknown as SanitizedConfig\n\n const result = isCustomAdminView({\n adminRoute,\n config,\n route: '/admin/my-custom-view',\n })\n\n expect(result).toBe(true)\n })\n\n it('should not match collection routes when a non-root custom view path is set', () => {\n const config = {\n admin: {\n components: {\n views: {\n myCustomView: {\n path: '/my-custom-view',\n },\n },\n },\n },\n } as unknown as SanitizedConfig\n\n const result = isCustomAdminView({\n adminRoute,\n config,\n route: '/admin/collections/tickets',\n })\n\n expect(result).toBe(false)\n })\n})\n"],"mappings":"AAEA,SAASA,QAAQ,EAAEC,MAAM,EAAEC,EAAE,QAAQ;AAErC,SAASC,iBAAiB,QAAQ;AAElCH,QAAA,CAAS,qBAAqB;EAC5B,MAAMI,UAAA,GAAa;EAEnB,MAAMC,yBAAA,GAA4B;IAChCC,KAAA,EAAO;MACLC,UAAA,EAAY;QACVC,KAAA,EAAO;UACLC,SAAA,EAAW;YACTC,IAAA,EAAM;UACR;QACF;MACF;IACF;EACF;EAEAR,EAAA,CAAG,6FAA6F;IAC9F;IACA;IACA,MAAMS,MAAA,GAASR,iBAAA,CAAkB;MAC/BC,UAAA;MACAQ,MAAA,EAAQP,yBAAA;MACRQ,KAAA,EAAO;IACT;IAEAZ,MAAA,CAAOU,MAAA,EAAQG,IAAI,CAAC;EACtB;EAEAZ,EAAA,CAAG,2FAA2F;IAC5F,MAAMS,MAAA,GAASR,iBAAA,CAAkB;MAC/BC,UAAA;MACAQ,MAAA,EAAQP,yBAAA;MACRQ,KAAA,EAAO;IACT;IAEAZ,MAAA,CAAOU,MAAA,EAAQG,IAAI,CAAC;EACtB;EAEAZ,EAAA,CAAG,yFAAyF;IAC1F,MAAMS,MAAA,GAASR,iBAAA,CAAkB;MAC/BC,UAAA;MACAQ,MAAA,EAAQP,yBAAA;MACRQ,KAAA,EAAO;IACT;IAEAZ,MAAA,CAAOU,MAAA,EAAQG,IAAI,CAAC;EACtB;EAEAZ,EAAA,CAAG,2DAA2D;IAC5D,MAAMU,MAAA,GAAS,CAAC;IAEhB,MAAMD,MAAA,GAASR,iBAAA,CAAkB;MAC/BC,UAAA;MACAQ,MAAA;MACAC,KAAA,EAAO;IACT;IAEAZ,MAAA,CAAOU,MAAA,EAAQG,IAAI,CAAC;EACtB;EAEAZ,EAAA,CAAG,6DAA6D;IAC9D,MAAMU,MAAA,GAAS;MACbN,KAAA,EAAO;QACLC,UAAA,EAAY;UACVC,KAAA,EAAO;YACLO,YAAA,EAAc;cACZL,IAAA,EAAM;YACR;UACF;QACF;MACF;IACF;IAEA,MAAMC,MAAA,GAASR,iBAAA,CAAkB;MAC/BC,UAAA;MACAQ,MAAA;MACAC,KAAA,EAAO;IACT;IAEAZ,MAAA,CAAOU,MAAA,EAAQG,IAAI,CAAC;EACtB;EAEAZ,EAAA,CAAG,8EAA8E;IAC/E,MAAMU,MAAA,GAAS;MACbN,KAAA,EAAO;QACLC,UAAA,EAAY;UACVC,KAAA,EAAO;YACLO,YAAA,EAAc;cACZL,IAAA,EAAM;YACR;UACF;QACF;MACF;IACF;IAEA,MAAMC,MAAA,GAASR,iBAAA,CAAkB;MAC/BC,UAAA;MACAQ,MAAA;MACAC,KAAA,EAAO;IACT;IAEAZ,MAAA,CAAOU,MAAA,EAAQG,IAAI,CAAC;EACtB;AACF","ignoreList":[]}
@@ -1,31 +1,25 @@
1
1
  import { getRouteWithoutAdmin } from './getRouteWithoutAdmin.js';
2
2
  // Routes that require admin authentication
3
- const publicAdminRoutes = [
4
- 'createFirstUser',
5
- 'forgot',
6
- 'login',
7
- 'logout',
8
- 'forgot',
9
- 'inactivity',
10
- 'unauthorized',
11
- 'reset'
12
- ];
13
- export const isPublicAdminRoute = ({ adminRoute, config, route })=>{
14
- const isPublicAdminRoute = publicAdminRoutes.some((routeSegment)=>{
15
- const segment = config.admin?.routes?.[routeSegment] || routeSegment;
16
- const routeWithoutAdmin = getRouteWithoutAdmin({
17
- adminRoute,
18
- route
19
- });
20
- if (routeWithoutAdmin.startsWith(segment)) {
21
- return true;
22
- } else if (routeWithoutAdmin.includes('/verify/')) {
23
- return true;
24
- } else {
25
- return false;
26
- }
3
+ const publicAdminRoutes = ['createFirstUser', 'forgot', 'login', 'logout', 'forgot', 'inactivity', 'unauthorized', 'reset'];
4
+ export const isPublicAdminRoute = ({
5
+ adminRoute,
6
+ config,
7
+ route
8
+ }) => {
9
+ const isPublicAdminRoute = publicAdminRoutes.some(routeSegment => {
10
+ const segment = config.admin?.routes?.[routeSegment] || routeSegment;
11
+ const routeWithoutAdmin = getRouteWithoutAdmin({
12
+ adminRoute,
13
+ route
27
14
  });
28
- return isPublicAdminRoute;
15
+ if (routeWithoutAdmin.startsWith(segment)) {
16
+ return true;
17
+ } else if (routeWithoutAdmin.includes('/verify/')) {
18
+ return true;
19
+ } else {
20
+ return false;
21
+ }
22
+ });
23
+ return isPublicAdminRoute;
29
24
  };
30
-
31
25
  //# sourceMappingURL=isPublicAdminRoute.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/isPublicAdminRoute.ts"],"sourcesContent":["import type { SanitizedConfig } from 'payload'\n\nimport { getRouteWithoutAdmin } from './getRouteWithoutAdmin.js'\n\n// Routes that require admin authentication\nconst publicAdminRoutes: (keyof Pick<\n SanitizedConfig['admin']['routes'],\n 'createFirstUser' | 'forgot' | 'inactivity' | 'login' | 'logout' | 'reset' | 'unauthorized'\n>)[] = [\n 'createFirstUser',\n 'forgot',\n 'login',\n 'logout',\n 'forgot',\n 'inactivity',\n 'unauthorized',\n 'reset',\n]\n\nexport const isPublicAdminRoute = ({\n adminRoute,\n config,\n route,\n}: {\n adminRoute: string\n config: SanitizedConfig\n route: string\n}): boolean => {\n const isPublicAdminRoute = publicAdminRoutes.some((routeSegment) => {\n const segment = config.admin?.routes?.[routeSegment] || routeSegment\n const routeWithoutAdmin = getRouteWithoutAdmin({ adminRoute, route })\n\n if (routeWithoutAdmin.startsWith(segment)) {\n return true\n } else if (routeWithoutAdmin.includes('/verify/')) {\n return true\n } else {\n return false\n }\n })\n\n return isPublicAdminRoute\n}\n"],"names":["getRouteWithoutAdmin","publicAdminRoutes","isPublicAdminRoute","adminRoute","config","route","some","routeSegment","segment","admin","routes","routeWithoutAdmin","startsWith","includes"],"mappings":"AAEA,SAASA,oBAAoB,QAAQ,4BAA2B;AAEhE,2CAA2C;AAC3C,MAAMC,oBAGC;IACL;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD;AAED,OAAO,MAAMC,qBAAqB,CAAC,EACjCC,UAAU,EACVC,MAAM,EACNC,KAAK,EAKN;IACC,MAAMH,qBAAqBD,kBAAkBK,IAAI,CAAC,CAACC;QACjD,MAAMC,UAAUJ,OAAOK,KAAK,EAAEC,QAAQ,CAACH,aAAa,IAAIA;QACxD,MAAMI,oBAAoBX,qBAAqB;YAAEG;YAAYE;QAAM;QAEnE,IAAIM,kBAAkBC,UAAU,CAACJ,UAAU;YACzC,OAAO;QACT,OAAO,IAAIG,kBAAkBE,QAAQ,CAAC,aAAa;YACjD,OAAO;QACT,OAAO;YACL,OAAO;QACT;IACF;IAEA,OAAOX;AACT,EAAC"}
1
+ {"version":3,"file":"isPublicAdminRoute.js","names":["getRouteWithoutAdmin","publicAdminRoutes","isPublicAdminRoute","adminRoute","config","route","some","routeSegment","segment","admin","routes","routeWithoutAdmin","startsWith","includes"],"sources":["../../src/utilities/isPublicAdminRoute.ts"],"sourcesContent":["import type { SanitizedConfig } from 'payload'\n\nimport { getRouteWithoutAdmin } from './getRouteWithoutAdmin.js'\n\n// Routes that require admin authentication\nconst publicAdminRoutes: (keyof Pick<\n SanitizedConfig['admin']['routes'],\n 'createFirstUser' | 'forgot' | 'inactivity' | 'login' | 'logout' | 'reset' | 'unauthorized'\n>)[] = [\n 'createFirstUser',\n 'forgot',\n 'login',\n 'logout',\n 'forgot',\n 'inactivity',\n 'unauthorized',\n 'reset',\n]\n\nexport const isPublicAdminRoute = ({\n adminRoute,\n config,\n route,\n}: {\n adminRoute: string\n config: SanitizedConfig\n route: string\n}): boolean => {\n const isPublicAdminRoute = publicAdminRoutes.some((routeSegment) => {\n const segment = config.admin?.routes?.[routeSegment] || routeSegment\n const routeWithoutAdmin = getRouteWithoutAdmin({ adminRoute, route })\n\n if (routeWithoutAdmin.startsWith(segment)) {\n return true\n } else if (routeWithoutAdmin.includes('/verify/')) {\n return true\n } else {\n return false\n }\n })\n\n return isPublicAdminRoute\n}\n"],"mappings":"AAEA,SAASA,oBAAoB,QAAQ;AAErC;AACA,MAAMC,iBAAA,GAGC,CACL,mBACA,UACA,SACA,UACA,UACA,cACA,gBACA,QACD;AAED,OAAO,MAAMC,kBAAA,GAAqBA,CAAC;EACjCC,UAAU;EACVC,MAAM;EACNC;AAAK,CAKN;EACC,MAAMH,kBAAA,GAAqBD,iBAAA,CAAkBK,IAAI,CAAEC,YAAA;IACjD,MAAMC,OAAA,GAAUJ,MAAA,CAAOK,KAAK,EAAEC,MAAA,GAASH,YAAA,CAAa,IAAIA,YAAA;IACxD,MAAMI,iBAAA,GAAoBX,oBAAA,CAAqB;MAAEG,UAAA;MAAYE;IAAM;IAEnE,IAAIM,iBAAA,CAAkBC,UAAU,CAACJ,OAAA,GAAU;MACzC,OAAO;IACT,OAAO,IAAIG,iBAAA,CAAkBE,QAAQ,CAAC,aAAa;MACjD,OAAO;IACT,OAAO;MACL,OAAO;IACT;EACF;EAEA,OAAOX,kBAAA;AACT","ignoreList":[]}
@@ -1,74 +1,69 @@
1
1
  import { payloadFaviconDark, payloadFaviconLight, staticOGImage } from '@payloadcms/ui/assets';
2
2
  import * as qs from 'qs-esm';
3
3
  const defaultOpenGraph = {
4
- description: 'Payload is a headless CMS and application framework built with TypeScript, Node.js, and React.',
5
- siteName: 'Payload App',
6
- title: 'Payload App'
4
+ description: 'Payload is a headless CMS and application framework built with TypeScript, Node.js, and React.',
5
+ siteName: 'Payload App',
6
+ title: 'Payload App'
7
7
  };
8
- export const generateMetadata = async (args)=>{
9
- const { defaultOGImageType, serverURL, titleSuffix, ...rest } = args;
10
- /**
11
- * @todo find a way to remove the type assertion here.
12
- * It is a result of needing to `DeepCopy` the `MetaConfig` type from Payload.
13
- * This is required for the `DeepRequired` from `Config` to `SanitizedConfig`.
14
- */ const incomingMetadata = rest;
15
- const icons = incomingMetadata.icons || [
16
- {
17
- type: 'image/png',
18
- rel: 'icon',
19
- sizes: '32x32',
20
- url: typeof payloadFaviconDark === 'object' ? payloadFaviconDark?.src : payloadFaviconDark
21
- },
22
- {
23
- type: 'image/png',
24
- media: '(prefers-color-scheme: dark)',
25
- rel: 'icon',
26
- sizes: '32x32',
27
- url: typeof payloadFaviconLight === 'object' ? payloadFaviconLight?.src : payloadFaviconLight
28
- }
29
- ];
30
- const metaTitle = [
31
- incomingMetadata.title,
32
- titleSuffix
33
- ].filter(Boolean).join(' ');
34
- const ogTitle = `${typeof incomingMetadata.openGraph?.title === 'string' ? incomingMetadata.openGraph.title : incomingMetadata.title} ${titleSuffix}`;
35
- const mergedOpenGraph = {
36
- ...defaultOpenGraph || {},
37
- ...defaultOGImageType === 'dynamic' ? {
38
- images: [
39
- {
40
- alt: ogTitle,
41
- height: 630,
42
- url: `/api/og${qs.stringify({
43
- description: incomingMetadata.openGraph?.description || defaultOpenGraph.description,
44
- title: ogTitle
45
- }, {
46
- addQueryPrefix: true
47
- })}`,
48
- width: 1200
49
- }
50
- ]
51
- } : {},
52
- ...defaultOGImageType === 'static' ? {
53
- images: [
54
- {
55
- alt: ogTitle,
56
- height: 480,
57
- url: typeof staticOGImage === 'object' ? staticOGImage?.src : staticOGImage,
58
- width: 640
59
- }
60
- ]
61
- } : {},
62
- title: ogTitle,
63
- ...incomingMetadata.openGraph || {}
64
- };
65
- return Promise.resolve({
66
- ...incomingMetadata,
67
- icons,
68
- metadataBase: new URL(serverURL || process.env.PAYLOAD_PUBLIC_SERVER_URL || `http://localhost:${process.env.PORT || 3000}`),
69
- openGraph: mergedOpenGraph,
70
- title: metaTitle
71
- });
8
+ export const generateMetadata = async args => {
9
+ const {
10
+ defaultOGImageType,
11
+ serverURL,
12
+ titleSuffix,
13
+ ...rest
14
+ } = args;
15
+ /**
16
+ * @todo find a way to remove the type assertion here.
17
+ * It is a result of needing to `DeepCopy` the `MetaConfig` type from Payload.
18
+ * This is required for the `DeepRequired` from `Config` to `SanitizedConfig`.
19
+ */
20
+ const incomingMetadata = rest;
21
+ const icons = incomingMetadata.icons || [{
22
+ type: 'image/png',
23
+ rel: 'icon',
24
+ sizes: '32x32',
25
+ url: typeof payloadFaviconDark === 'object' ? payloadFaviconDark?.src : payloadFaviconDark
26
+ }, {
27
+ type: 'image/png',
28
+ media: '(prefers-color-scheme: dark)',
29
+ rel: 'icon',
30
+ sizes: '32x32',
31
+ url: typeof payloadFaviconLight === 'object' ? payloadFaviconLight?.src : payloadFaviconLight
32
+ }];
33
+ const metaTitle = [incomingMetadata.title, titleSuffix].filter(Boolean).join(' ');
34
+ const ogTitle = `${typeof incomingMetadata.openGraph?.title === 'string' ? incomingMetadata.openGraph.title : incomingMetadata.title} ${titleSuffix}`;
35
+ const mergedOpenGraph = {
36
+ ...(defaultOpenGraph || {}),
37
+ ...(defaultOGImageType === 'dynamic' ? {
38
+ images: [{
39
+ alt: ogTitle,
40
+ height: 630,
41
+ url: `/api/og${qs.stringify({
42
+ description: incomingMetadata.openGraph?.description || defaultOpenGraph.description,
43
+ title: ogTitle
44
+ }, {
45
+ addQueryPrefix: true
46
+ })}`,
47
+ width: 1200
48
+ }]
49
+ } : {}),
50
+ ...(defaultOGImageType === 'static' ? {
51
+ images: [{
52
+ alt: ogTitle,
53
+ height: 480,
54
+ url: typeof staticOGImage === 'object' ? staticOGImage?.src : staticOGImage,
55
+ width: 640
56
+ }]
57
+ } : {}),
58
+ title: ogTitle,
59
+ ...(incomingMetadata.openGraph || {})
60
+ };
61
+ return Promise.resolve({
62
+ ...incomingMetadata,
63
+ icons,
64
+ metadataBase: new URL(serverURL || process.env.PAYLOAD_PUBLIC_SERVER_URL || `http://localhost:${process.env.PORT || 3000}`),
65
+ openGraph: mergedOpenGraph,
66
+ title: metaTitle
67
+ });
72
68
  };
73
-
74
69
  //# sourceMappingURL=meta.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/meta.ts"],"sourcesContent":["import type { Metadata } from 'next'\nimport type { Icon } from 'next/dist/lib/metadata/types/metadata-types.js'\nimport type { MetaConfig } from 'payload'\n\nimport { payloadFaviconDark, payloadFaviconLight, staticOGImage } from '@payloadcms/ui/assets'\nimport * as qs from 'qs-esm'\n\nconst defaultOpenGraph: Metadata['openGraph'] = {\n description:\n 'Payload is a headless CMS and application framework built with TypeScript, Node.js, and React.',\n siteName: 'Payload App',\n title: 'Payload App',\n}\n\nexport const generateMetadata = async (\n args: { serverURL: string } & MetaConfig,\n): Promise<Metadata> => {\n const { defaultOGImageType, serverURL, titleSuffix, ...rest } = args\n\n /**\n * @todo find a way to remove the type assertion here.\n * It is a result of needing to `DeepCopy` the `MetaConfig` type from Payload.\n * This is required for the `DeepRequired` from `Config` to `SanitizedConfig`.\n */\n const incomingMetadata = rest as Metadata\n\n const icons: Metadata['icons'] =\n incomingMetadata.icons ||\n ([\n {\n type: 'image/png',\n rel: 'icon',\n sizes: '32x32',\n url: typeof payloadFaviconDark === 'object' ? payloadFaviconDark?.src : payloadFaviconDark,\n },\n {\n type: 'image/png',\n media: '(prefers-color-scheme: dark)',\n rel: 'icon',\n sizes: '32x32',\n url:\n typeof payloadFaviconLight === 'object' ? payloadFaviconLight?.src : payloadFaviconLight,\n },\n ] satisfies Array<Icon>)\n\n const metaTitle: Metadata['title'] = [incomingMetadata.title, titleSuffix]\n .filter(Boolean)\n .join(' ')\n\n const ogTitle = `${typeof incomingMetadata.openGraph?.title === 'string' ? incomingMetadata.openGraph.title : incomingMetadata.title} ${titleSuffix}`\n\n const mergedOpenGraph: Metadata['openGraph'] = {\n ...(defaultOpenGraph || {}),\n ...(defaultOGImageType === 'dynamic'\n ? {\n images: [\n {\n alt: ogTitle,\n height: 630,\n url: `/api/og${qs.stringify(\n {\n description:\n incomingMetadata.openGraph?.description || defaultOpenGraph.description,\n title: ogTitle,\n },\n {\n addQueryPrefix: true,\n },\n )}`,\n width: 1200,\n },\n ],\n }\n : {}),\n ...(defaultOGImageType === 'static'\n ? {\n images: [\n {\n alt: ogTitle,\n height: 480,\n url: typeof staticOGImage === 'object' ? staticOGImage?.src : staticOGImage,\n width: 640,\n },\n ],\n }\n : {}),\n title: ogTitle,\n ...(incomingMetadata.openGraph || {}),\n }\n\n return Promise.resolve({\n ...incomingMetadata,\n icons,\n metadataBase: new URL(\n serverURL ||\n process.env.PAYLOAD_PUBLIC_SERVER_URL ||\n `http://localhost:${process.env.PORT || 3000}`,\n ),\n openGraph: mergedOpenGraph,\n title: metaTitle,\n })\n}\n"],"names":["payloadFaviconDark","payloadFaviconLight","staticOGImage","qs","defaultOpenGraph","description","siteName","title","generateMetadata","args","defaultOGImageType","serverURL","titleSuffix","rest","incomingMetadata","icons","type","rel","sizes","url","src","media","metaTitle","filter","Boolean","join","ogTitle","openGraph","mergedOpenGraph","images","alt","height","stringify","addQueryPrefix","width","Promise","resolve","metadataBase","URL","process","env","PAYLOAD_PUBLIC_SERVER_URL","PORT"],"mappings":"AAIA,SAASA,kBAAkB,EAAEC,mBAAmB,EAAEC,aAAa,QAAQ,wBAAuB;AAC9F,YAAYC,QAAQ,SAAQ;AAE5B,MAAMC,mBAA0C;IAC9CC,aACE;IACFC,UAAU;IACVC,OAAO;AACT;AAEA,OAAO,MAAMC,mBAAmB,OAC9BC;IAEA,MAAM,EAAEC,kBAAkB,EAAEC,SAAS,EAAEC,WAAW,EAAE,GAAGC,MAAM,GAAGJ;IAEhE;;;;GAIC,GACD,MAAMK,mBAAmBD;IAEzB,MAAME,QACJD,iBAAiBC,KAAK,IACrB;QACC;YACEC,MAAM;YACNC,KAAK;YACLC,OAAO;YACPC,KAAK,OAAOnB,uBAAuB,WAAWA,oBAAoBoB,MAAMpB;QAC1E;QACA;YACEgB,MAAM;YACNK,OAAO;YACPJ,KAAK;YACLC,OAAO;YACPC,KACE,OAAOlB,wBAAwB,WAAWA,qBAAqBmB,MAAMnB;QACzE;KACD;IAEH,MAAMqB,YAA+B;QAACR,iBAAiBP,KAAK;QAAEK;KAAY,CACvEW,MAAM,CAACC,SACPC,IAAI,CAAC;IAER,MAAMC,UAAU,GAAG,OAAOZ,iBAAiBa,SAAS,EAAEpB,UAAU,WAAWO,iBAAiBa,SAAS,CAACpB,KAAK,GAAGO,iBAAiBP,KAAK,CAAC,CAAC,EAAEK,aAAa;IAErJ,MAAMgB,kBAAyC;QAC7C,GAAIxB,oBAAoB,CAAC,CAAC;QAC1B,GAAIM,uBAAuB,YACvB;YACEmB,QAAQ;gBACN;oBACEC,KAAKJ;oBACLK,QAAQ;oBACRZ,KAAK,CAAC,OAAO,EAAEhB,GAAG6B,SAAS,CACzB;wBACE3B,aACES,iBAAiBa,SAAS,EAAEtB,eAAeD,iBAAiBC,WAAW;wBACzEE,OAAOmB;oBACT,GACA;wBACEO,gBAAgB;oBAClB,IACC;oBACHC,OAAO;gBACT;aACD;QACH,IACA,CAAC,CAAC;QACN,GAAIxB,uBAAuB,WACvB;YACEmB,QAAQ;gBACN;oBACEC,KAAKJ;oBACLK,QAAQ;oBACRZ,KAAK,OAAOjB,kBAAkB,WAAWA,eAAekB,MAAMlB;oBAC9DgC,OAAO;gBACT;aACD;QACH,IACA,CAAC,CAAC;QACN3B,OAAOmB;QACP,GAAIZ,iBAAiBa,SAAS,IAAI,CAAC,CAAC;IACtC;IAEA,OAAOQ,QAAQC,OAAO,CAAC;QACrB,GAAGtB,gBAAgB;QACnBC;QACAsB,cAAc,IAAIC,IAChB3B,aACE4B,QAAQC,GAAG,CAACC,yBAAyB,IACrC,CAAC,iBAAiB,EAAEF,QAAQC,GAAG,CAACE,IAAI,IAAI,MAAM;QAElDf,WAAWC;QACXrB,OAAOe;IACT;AACF,EAAC"}
1
+ {"version":3,"file":"meta.js","names":["payloadFaviconDark","payloadFaviconLight","staticOGImage","qs","defaultOpenGraph","description","siteName","title","generateMetadata","args","defaultOGImageType","serverURL","titleSuffix","rest","incomingMetadata","icons","type","rel","sizes","url","src","media","metaTitle","filter","Boolean","join","ogTitle","openGraph","mergedOpenGraph","images","alt","height","stringify","addQueryPrefix","width","Promise","resolve","metadataBase","URL","process","env","PAYLOAD_PUBLIC_SERVER_URL","PORT"],"sources":["../../src/utilities/meta.ts"],"sourcesContent":["import type { Metadata } from 'next'\nimport type { Icon } from 'next/dist/lib/metadata/types/metadata-types.js'\nimport type { MetaConfig } from 'payload'\n\nimport { payloadFaviconDark, payloadFaviconLight, staticOGImage } from '@payloadcms/ui/assets'\nimport * as qs from 'qs-esm'\n\nconst defaultOpenGraph: Metadata['openGraph'] = {\n description:\n 'Payload is a headless CMS and application framework built with TypeScript, Node.js, and React.',\n siteName: 'Payload App',\n title: 'Payload App',\n}\n\nexport const generateMetadata = async (\n args: { serverURL: string } & MetaConfig,\n): Promise<Metadata> => {\n const { defaultOGImageType, serverURL, titleSuffix, ...rest } = args\n\n /**\n * @todo find a way to remove the type assertion here.\n * It is a result of needing to `DeepCopy` the `MetaConfig` type from Payload.\n * This is required for the `DeepRequired` from `Config` to `SanitizedConfig`.\n */\n const incomingMetadata = rest as Metadata\n\n const icons: Metadata['icons'] =\n incomingMetadata.icons ||\n ([\n {\n type: 'image/png',\n rel: 'icon',\n sizes: '32x32',\n url: typeof payloadFaviconDark === 'object' ? payloadFaviconDark?.src : payloadFaviconDark,\n },\n {\n type: 'image/png',\n media: '(prefers-color-scheme: dark)',\n rel: 'icon',\n sizes: '32x32',\n url:\n typeof payloadFaviconLight === 'object' ? payloadFaviconLight?.src : payloadFaviconLight,\n },\n ] satisfies Array<Icon>)\n\n const metaTitle: Metadata['title'] = [incomingMetadata.title, titleSuffix]\n .filter(Boolean)\n .join(' ')\n\n const ogTitle = `${typeof incomingMetadata.openGraph?.title === 'string' ? incomingMetadata.openGraph.title : incomingMetadata.title} ${titleSuffix}`\n\n const mergedOpenGraph: Metadata['openGraph'] = {\n ...(defaultOpenGraph || {}),\n ...(defaultOGImageType === 'dynamic'\n ? {\n images: [\n {\n alt: ogTitle,\n height: 630,\n url: `/api/og${qs.stringify(\n {\n description:\n incomingMetadata.openGraph?.description || defaultOpenGraph.description,\n title: ogTitle,\n },\n {\n addQueryPrefix: true,\n },\n )}`,\n width: 1200,\n },\n ],\n }\n : {}),\n ...(defaultOGImageType === 'static'\n ? {\n images: [\n {\n alt: ogTitle,\n height: 480,\n url: typeof staticOGImage === 'object' ? staticOGImage?.src : staticOGImage,\n width: 640,\n },\n ],\n }\n : {}),\n title: ogTitle,\n ...(incomingMetadata.openGraph || {}),\n }\n\n return Promise.resolve({\n ...incomingMetadata,\n icons,\n metadataBase: new URL(\n serverURL ||\n process.env.PAYLOAD_PUBLIC_SERVER_URL ||\n `http://localhost:${process.env.PORT || 3000}`,\n ),\n openGraph: mergedOpenGraph,\n title: metaTitle,\n })\n}\n"],"mappings":"AAIA,SAASA,kBAAkB,EAAEC,mBAAmB,EAAEC,aAAa,QAAQ;AACvE,YAAYC,EAAA,MAAQ;AAEpB,MAAMC,gBAAA,GAA0C;EAC9CC,WAAA,EACE;EACFC,QAAA,EAAU;EACVC,KAAA,EAAO;AACT;AAEA,OAAO,MAAMC,gBAAA,GAAmB,MAC9BC,IAAA;EAEA,MAAM;IAAEC,kBAAkB;IAAEC,SAAS;IAAEC,WAAW;IAAE,GAAGC;EAAA,CAAM,GAAGJ,IAAA;EAEhE;;;;;EAKA,MAAMK,gBAAA,GAAmBD,IAAA;EAEzB,MAAME,KAAA,GACJD,gBAAA,CAAiBC,KAAK,IACrB,CACC;IACEC,IAAA,EAAM;IACNC,GAAA,EAAK;IACLC,KAAA,EAAO;IACPC,GAAA,EAAK,OAAOnB,kBAAA,KAAuB,WAAWA,kBAAA,EAAoBoB,GAAA,GAAMpB;EAC1E,GACA;IACEgB,IAAA,EAAM;IACNK,KAAA,EAAO;IACPJ,GAAA,EAAK;IACLC,KAAA,EAAO;IACPC,GAAA,EACE,OAAOlB,mBAAA,KAAwB,WAAWA,mBAAA,EAAqBmB,GAAA,GAAMnB;EACzE,EACD;EAEH,MAAMqB,SAAA,GAA+B,CAACR,gBAAA,CAAiBP,KAAK,EAAEK,WAAA,CAAY,CACvEW,MAAM,CAACC,OAAA,EACPC,IAAI,CAAC;EAER,MAAMC,OAAA,GAAU,GAAG,OAAOZ,gBAAA,CAAiBa,SAAS,EAAEpB,KAAA,KAAU,WAAWO,gBAAA,CAAiBa,SAAS,CAACpB,KAAK,GAAGO,gBAAA,CAAiBP,KAAK,IAAIK,WAAA,EAAa;EAErJ,MAAMgB,eAAA,GAAyC;IAC7C,IAAIxB,gBAAA,IAAoB,CAAC,CAAC;IAC1B,IAAIM,kBAAA,KAAuB,YACvB;MACEmB,MAAA,EAAQ,CACN;QACEC,GAAA,EAAKJ,OAAA;QACLK,MAAA,EAAQ;QACRZ,GAAA,EAAK,UAAUhB,EAAA,CAAG6B,SAAS,CACzB;UACE3B,WAAA,EACES,gBAAA,CAAiBa,SAAS,EAAEtB,WAAA,IAAeD,gBAAA,CAAiBC,WAAW;UACzEE,KAAA,EAAOmB;QACT,GACA;UACEO,cAAA,EAAgB;QAClB,IACC;QACHC,KAAA,EAAO;MACT;IAEJ,IACA,CAAC,CAAC;IACN,IAAIxB,kBAAA,KAAuB,WACvB;MACEmB,MAAA,EAAQ,CACN;QACEC,GAAA,EAAKJ,OAAA;QACLK,MAAA,EAAQ;QACRZ,GAAA,EAAK,OAAOjB,aAAA,KAAkB,WAAWA,aAAA,EAAekB,GAAA,GAAMlB,aAAA;QAC9DgC,KAAA,EAAO;MACT;IAEJ,IACA,CAAC,CAAC;IACN3B,KAAA,EAAOmB,OAAA;IACP,IAAIZ,gBAAA,CAAiBa,SAAS,IAAI,CAAC,CAAC;EACtC;EAEA,OAAOQ,OAAA,CAAQC,OAAO,CAAC;IACrB,GAAGtB,gBAAgB;IACnBC,KAAA;IACAsB,YAAA,EAAc,IAAIC,GAAA,CAChB3B,SAAA,IACE4B,OAAA,CAAQC,GAAG,CAACC,yBAAyB,IACrC,oBAAoBF,OAAA,CAAQC,GAAG,CAACE,IAAI,IAAI,MAAM;IAElDf,SAAA,EAAWC,eAAA;IACXrB,KAAA,EAAOe;EACT;AACF","ignoreList":[]}
@@ -7,31 +7,32 @@ const globalCacheContainer = {};
7
7
  *
8
8
  * @param namespace - A namespace to group related cached values
9
9
  * @returns A function that manages cached values within the specified namespace
10
- */ export function selectiveCache(namespace) {
11
- // Create a stable namespace container if it doesn't exist
12
- if (!globalCacheContainer[namespace]) {
13
- globalCacheContainer[namespace] = cache((...args)=>({
14
- value: null
15
- }));
10
+ */
11
+ export function selectiveCache(namespace) {
12
+ // Create a stable namespace container if it doesn't exist
13
+ if (!globalCacheContainer[namespace]) {
14
+ globalCacheContainer[namespace] = cache((...args) => ({
15
+ value: null
16
+ }));
17
+ }
18
+ /**
19
+ * Gets or creates a cached value for a specific key within the namespace
20
+ *
21
+ * @param key - The key to identify the cached value
22
+ * @param factory - A function that produces the value if not cached
23
+ * @returns The cached or newly created value
24
+ */
25
+ const getCached = async (factory, ...cacheArgs) => {
26
+ const stableObjectFn = globalCacheContainer[namespace];
27
+ const stableObject = stableObjectFn(...cacheArgs);
28
+ if (stableObject?.value && 'then' in stableObject.value && typeof stableObject.value?.then === 'function') {
29
+ return await stableObject.value;
16
30
  }
17
- /**
18
- * Gets or creates a cached value for a specific key within the namespace
19
- *
20
- * @param key - The key to identify the cached value
21
- * @param factory - A function that produces the value if not cached
22
- * @returns The cached or newly created value
23
- */ const getCached = async (factory, ...cacheArgs)=>{
24
- const stableObjectFn = globalCacheContainer[namespace];
25
- const stableObject = stableObjectFn(...cacheArgs);
26
- if (stableObject?.value && 'then' in stableObject.value && typeof stableObject.value?.then === 'function') {
27
- return await stableObject.value;
28
- }
29
- stableObject.value = factory();
30
- return await stableObject.value;
31
- };
32
- return {
33
- get: getCached
34
- };
31
+ stableObject.value = factory();
32
+ return await stableObject.value;
33
+ };
34
+ return {
35
+ get: getCached
36
+ };
35
37
  }
36
-
37
38
  //# sourceMappingURL=selectiveCache.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/selectiveCache.ts"],"sourcesContent":["import { cache } from 'react'\n\ntype CachedValue = object\n\n// Module-scoped cache container that holds all cached, stable containers\n// - these may hold the stable value, or a promise to the stable value\nconst globalCacheContainer: Record<\n string,\n <TValue extends object = CachedValue>(\n ...args: unknown[]\n ) => {\n value: null | Promise<TValue> | TValue\n }\n> = {}\n\n/**\n * Creates a selective cache function that provides more control over React's request-level caching behavior.\n *\n * @param namespace - A namespace to group related cached values\n * @returns A function that manages cached values within the specified namespace\n */\nexport function selectiveCache<TValue extends object = CachedValue>(namespace: string) {\n // Create a stable namespace container if it doesn't exist\n if (!globalCacheContainer[namespace]) {\n globalCacheContainer[namespace] = cache((...args) => ({\n value: null,\n }))\n }\n\n /**\n * Gets or creates a cached value for a specific key within the namespace\n *\n * @param key - The key to identify the cached value\n * @param factory - A function that produces the value if not cached\n * @returns The cached or newly created value\n */\n const getCached = async (factory: () => Promise<TValue>, ...cacheArgs): Promise<TValue> => {\n const stableObjectFn = globalCacheContainer[namespace]\n const stableObject = stableObjectFn<TValue>(...cacheArgs)\n\n if (\n stableObject?.value &&\n 'then' in stableObject.value &&\n typeof stableObject.value?.then === 'function'\n ) {\n return await stableObject.value\n }\n\n stableObject.value = factory()\n\n return await stableObject.value\n }\n\n return {\n get: getCached,\n }\n}\n"],"names":["cache","globalCacheContainer","selectiveCache","namespace","args","value","getCached","factory","cacheArgs","stableObjectFn","stableObject","then","get"],"mappings":"AAAA,SAASA,KAAK,QAAQ,QAAO;AAI7B,yEAAyE;AACzE,sEAAsE;AACtE,MAAMC,uBAOF,CAAC;AAEL;;;;;CAKC,GACD,OAAO,SAASC,eAAoDC,SAAiB;IACnF,0DAA0D;IAC1D,IAAI,CAACF,oBAAoB,CAACE,UAAU,EAAE;QACpCF,oBAAoB,CAACE,UAAU,GAAGH,MAAM,CAAC,GAAGI,OAAU,CAAA;gBACpDC,OAAO;YACT,CAAA;IACF;IAEA;;;;;;GAMC,GACD,MAAMC,YAAY,OAAOC,SAAgC,GAAGC;QAC1D,MAAMC,iBAAiBR,oBAAoB,CAACE,UAAU;QACtD,MAAMO,eAAeD,kBAA0BD;QAE/C,IACEE,cAAcL,SACd,UAAUK,aAAaL,KAAK,IAC5B,OAAOK,aAAaL,KAAK,EAAEM,SAAS,YACpC;YACA,OAAO,MAAMD,aAAaL,KAAK;QACjC;QAEAK,aAAaL,KAAK,GAAGE;QAErB,OAAO,MAAMG,aAAaL,KAAK;IACjC;IAEA,OAAO;QACLO,KAAKN;IACP;AACF"}
1
+ {"version":3,"file":"selectiveCache.js","names":["cache","globalCacheContainer","selectiveCache","namespace","args","value","getCached","factory","cacheArgs","stableObjectFn","stableObject","then","get"],"sources":["../../src/utilities/selectiveCache.ts"],"sourcesContent":["import { cache } from 'react'\n\ntype CachedValue = object\n\n// Module-scoped cache container that holds all cached, stable containers\n// - these may hold the stable value, or a promise to the stable value\nconst globalCacheContainer: Record<\n string,\n <TValue extends object = CachedValue>(\n ...args: unknown[]\n ) => {\n value: null | Promise<TValue> | TValue\n }\n> = {}\n\n/**\n * Creates a selective cache function that provides more control over React's request-level caching behavior.\n *\n * @param namespace - A namespace to group related cached values\n * @returns A function that manages cached values within the specified namespace\n */\nexport function selectiveCache<TValue extends object = CachedValue>(namespace: string) {\n // Create a stable namespace container if it doesn't exist\n if (!globalCacheContainer[namespace]) {\n globalCacheContainer[namespace] = cache((...args) => ({\n value: null,\n }))\n }\n\n /**\n * Gets or creates a cached value for a specific key within the namespace\n *\n * @param key - The key to identify the cached value\n * @param factory - A function that produces the value if not cached\n * @returns The cached or newly created value\n */\n const getCached = async (factory: () => Promise<TValue>, ...cacheArgs): Promise<TValue> => {\n const stableObjectFn = globalCacheContainer[namespace]\n const stableObject = stableObjectFn<TValue>(...cacheArgs)\n\n if (\n stableObject?.value &&\n 'then' in stableObject.value &&\n typeof stableObject.value?.then === 'function'\n ) {\n return await stableObject.value\n }\n\n stableObject.value = factory()\n\n return await stableObject.value\n }\n\n return {\n get: getCached,\n }\n}\n"],"mappings":"AAAA,SAASA,KAAK,QAAQ;AAItB;AACA;AACA,MAAMC,oBAAA,GAOF,CAAC;AAEL;;;;;;AAMA,OAAO,SAASC,eAAoDC,SAAiB;EACnF;EACA,IAAI,CAACF,oBAAoB,CAACE,SAAA,CAAU,EAAE;IACpCF,oBAAoB,CAACE,SAAA,CAAU,GAAGH,KAAA,CAAM,CAAC,GAAGI,IAAA,MAAU;MACpDC,KAAA,EAAO;IACT;EACF;EAEA;;;;;;;EAOA,MAAMC,SAAA,GAAY,MAAAA,CAAOC,OAAA,EAAgC,GAAGC,SAAA;IAC1D,MAAMC,cAAA,GAAiBR,oBAAoB,CAACE,SAAA,CAAU;IACtD,MAAMO,YAAA,GAAeD,cAAA,IAA0BD,SAAA;IAE/C,IACEE,YAAA,EAAcL,KAAA,IACd,UAAUK,YAAA,CAAaL,KAAK,IAC5B,OAAOK,YAAA,CAAaL,KAAK,EAAEM,IAAA,KAAS,YACpC;MACA,OAAO,MAAMD,YAAA,CAAaL,KAAK;IACjC;IAEAK,YAAA,CAAaL,KAAK,GAAGE,OAAA;IAErB,OAAO,MAAMG,YAAA,CAAaL,KAAK;EACjC;EAEA,OAAO;IACLO,GAAA,EAAKN;EACP;AACF","ignoreList":[]}
@@ -1,24 +1,27 @@
1
1
  import { cookies as getCookies } from 'next/headers.js';
2
2
  import { generatePayloadCookie } from 'payload';
3
- export async function setPayloadAuthCookie({ authConfig, cookiePrefix, token }) {
4
- const cookies = await getCookies();
5
- const cookieExpiration = authConfig.tokenExpiration ? new Date(Date.now() + authConfig.tokenExpiration) : undefined;
6
- const payloadCookie = generatePayloadCookie({
7
- collectionAuthConfig: authConfig,
8
- cookiePrefix,
9
- expires: cookieExpiration,
10
- returnCookieAsObject: true,
11
- token
3
+ export async function setPayloadAuthCookie({
4
+ authConfig,
5
+ cookiePrefix,
6
+ token
7
+ }) {
8
+ const cookies = await getCookies();
9
+ const cookieExpiration = authConfig.tokenExpiration ? new Date(Date.now() + authConfig.tokenExpiration) : undefined;
10
+ const payloadCookie = generatePayloadCookie({
11
+ collectionAuthConfig: authConfig,
12
+ cookiePrefix,
13
+ expires: cookieExpiration,
14
+ returnCookieAsObject: true,
15
+ token
16
+ });
17
+ if (payloadCookie.value) {
18
+ cookies.set(payloadCookie.name, payloadCookie.value, {
19
+ domain: authConfig.cookies.domain,
20
+ expires: payloadCookie.expires ? new Date(payloadCookie.expires) : undefined,
21
+ httpOnly: true,
22
+ sameSite: typeof authConfig.cookies.sameSite === 'string' ? authConfig.cookies.sameSite.toLowerCase() : 'lax',
23
+ secure: authConfig.cookies.secure || false
12
24
  });
13
- if (payloadCookie.value) {
14
- cookies.set(payloadCookie.name, payloadCookie.value, {
15
- domain: authConfig.cookies.domain,
16
- expires: payloadCookie.expires ? new Date(payloadCookie.expires) : undefined,
17
- httpOnly: true,
18
- sameSite: typeof authConfig.cookies.sameSite === 'string' ? authConfig.cookies.sameSite.toLowerCase() : 'lax',
19
- secure: authConfig.cookies.secure || false
20
- });
21
- }
25
+ }
22
26
  }
23
-
24
27
  //# sourceMappingURL=setPayloadAuthCookie.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/setPayloadAuthCookie.ts"],"sourcesContent":["import type { Auth } from 'payload'\n\nimport { cookies as getCookies } from 'next/headers.js'\nimport { generatePayloadCookie } from 'payload'\n\ntype SetPayloadAuthCookieArgs = {\n authConfig: Auth\n cookiePrefix: string\n token: string\n}\n\nexport async function setPayloadAuthCookie({\n authConfig,\n cookiePrefix,\n token,\n}: SetPayloadAuthCookieArgs): Promise<void> {\n const cookies = await getCookies()\n\n const cookieExpiration = authConfig.tokenExpiration\n ? new Date(Date.now() + authConfig.tokenExpiration)\n : undefined\n\n const payloadCookie = generatePayloadCookie({\n collectionAuthConfig: authConfig,\n cookiePrefix,\n expires: cookieExpiration,\n returnCookieAsObject: true,\n token,\n })\n\n if (payloadCookie.value) {\n cookies.set(payloadCookie.name, payloadCookie.value, {\n domain: authConfig.cookies.domain,\n expires: payloadCookie.expires ? new Date(payloadCookie.expires) : undefined,\n httpOnly: true,\n sameSite: (typeof authConfig.cookies.sameSite === 'string'\n ? authConfig.cookies.sameSite.toLowerCase()\n : 'lax') as 'lax' | 'none' | 'strict',\n secure: authConfig.cookies.secure || false,\n })\n }\n}\n"],"names":["cookies","getCookies","generatePayloadCookie","setPayloadAuthCookie","authConfig","cookiePrefix","token","cookieExpiration","tokenExpiration","Date","now","undefined","payloadCookie","collectionAuthConfig","expires","returnCookieAsObject","value","set","name","domain","httpOnly","sameSite","toLowerCase","secure"],"mappings":"AAEA,SAASA,WAAWC,UAAU,QAAQ,kBAAiB;AACvD,SAASC,qBAAqB,QAAQ,UAAS;AAQ/C,OAAO,eAAeC,qBAAqB,EACzCC,UAAU,EACVC,YAAY,EACZC,KAAK,EACoB;IACzB,MAAMN,UAAU,MAAMC;IAEtB,MAAMM,mBAAmBH,WAAWI,eAAe,GAC/C,IAAIC,KAAKA,KAAKC,GAAG,KAAKN,WAAWI,eAAe,IAChDG;IAEJ,MAAMC,gBAAgBV,sBAAsB;QAC1CW,sBAAsBT;QACtBC;QACAS,SAASP;QACTQ,sBAAsB;QACtBT;IACF;IAEA,IAAIM,cAAcI,KAAK,EAAE;QACvBhB,QAAQiB,GAAG,CAACL,cAAcM,IAAI,EAAEN,cAAcI,KAAK,EAAE;YACnDG,QAAQf,WAAWJ,OAAO,CAACmB,MAAM;YACjCL,SAASF,cAAcE,OAAO,GAAG,IAAIL,KAAKG,cAAcE,OAAO,IAAIH;YACnES,UAAU;YACVC,UAAW,OAAOjB,WAAWJ,OAAO,CAACqB,QAAQ,KAAK,WAC9CjB,WAAWJ,OAAO,CAACqB,QAAQ,CAACC,WAAW,KACvC;YACJC,QAAQnB,WAAWJ,OAAO,CAACuB,MAAM,IAAI;QACvC;IACF;AACF"}
1
+ {"version":3,"file":"setPayloadAuthCookie.js","names":["cookies","getCookies","generatePayloadCookie","setPayloadAuthCookie","authConfig","cookiePrefix","token","cookieExpiration","tokenExpiration","Date","now","undefined","payloadCookie","collectionAuthConfig","expires","returnCookieAsObject","value","set","name","domain","httpOnly","sameSite","toLowerCase","secure"],"sources":["../../src/utilities/setPayloadAuthCookie.ts"],"sourcesContent":["import type { Auth } from 'payload'\n\nimport { cookies as getCookies } from 'next/headers.js'\nimport { generatePayloadCookie } from 'payload'\n\ntype SetPayloadAuthCookieArgs = {\n authConfig: Auth\n cookiePrefix: string\n token: string\n}\n\nexport async function setPayloadAuthCookie({\n authConfig,\n cookiePrefix,\n token,\n}: SetPayloadAuthCookieArgs): Promise<void> {\n const cookies = await getCookies()\n\n const cookieExpiration = authConfig.tokenExpiration\n ? new Date(Date.now() + authConfig.tokenExpiration)\n : undefined\n\n const payloadCookie = generatePayloadCookie({\n collectionAuthConfig: authConfig,\n cookiePrefix,\n expires: cookieExpiration,\n returnCookieAsObject: true,\n token,\n })\n\n if (payloadCookie.value) {\n cookies.set(payloadCookie.name, payloadCookie.value, {\n domain: authConfig.cookies.domain,\n expires: payloadCookie.expires ? new Date(payloadCookie.expires) : undefined,\n httpOnly: true,\n sameSite: (typeof authConfig.cookies.sameSite === 'string'\n ? authConfig.cookies.sameSite.toLowerCase()\n : 'lax') as 'lax' | 'none' | 'strict',\n secure: authConfig.cookies.secure || false,\n })\n }\n}\n"],"mappings":"AAEA,SAASA,OAAA,IAAWC,UAAU,QAAQ;AACtC,SAASC,qBAAqB,QAAQ;AAQtC,OAAO,eAAeC,qBAAqB;EACzCC,UAAU;EACVC,YAAY;EACZC;AAAK,CACoB;EACzB,MAAMN,OAAA,GAAU,MAAMC,UAAA;EAEtB,MAAMM,gBAAA,GAAmBH,UAAA,CAAWI,eAAe,GAC/C,IAAIC,IAAA,CAAKA,IAAA,CAAKC,GAAG,KAAKN,UAAA,CAAWI,eAAe,IAChDG,SAAA;EAEJ,MAAMC,aAAA,GAAgBV,qBAAA,CAAsB;IAC1CW,oBAAA,EAAsBT,UAAA;IACtBC,YAAA;IACAS,OAAA,EAASP,gBAAA;IACTQ,oBAAA,EAAsB;IACtBT;EACF;EAEA,IAAIM,aAAA,CAAcI,KAAK,EAAE;IACvBhB,OAAA,CAAQiB,GAAG,CAACL,aAAA,CAAcM,IAAI,EAAEN,aAAA,CAAcI,KAAK,EAAE;MACnDG,MAAA,EAAQf,UAAA,CAAWJ,OAAO,CAACmB,MAAM;MACjCL,OAAA,EAASF,aAAA,CAAcE,OAAO,GAAG,IAAIL,IAAA,CAAKG,aAAA,CAAcE,OAAO,IAAIH,SAAA;MACnES,QAAA,EAAU;MACVC,QAAA,EAAW,OAAOjB,UAAA,CAAWJ,OAAO,CAACqB,QAAQ,KAAK,WAC9CjB,UAAA,CAAWJ,OAAO,CAACqB,QAAQ,CAACC,WAAW,KACvC;MACJC,MAAA,EAAQnB,UAAA,CAAWJ,OAAO,CAACuB,MAAM,IAAI;IACvC;EACF;AACF","ignoreList":[]}
@@ -10,29 +10,38 @@ import { slugify as defaultSlugify } from 'payload/shared';
10
10
  * The only way to pass server functions to the client (that contain non-serializable data) is if it is globally defined.
11
11
  * But we also cannot define this function alongside the server component, as we will not have access to their custom slugify function.
12
12
  * See `ServerFunctionsProvider` for more details.
13
- */ export const slugifyHandler = async (args)=>{
14
- const { collectionSlug, data, globalSlug, path, req, valueToSlugify } = args;
15
- if (!req.user) {
16
- throw new UnauthorizedError();
17
- }
18
- const docConfig = collectionSlug ? req.payload.collections[collectionSlug]?.config : globalSlug ? req.payload.config.globals.find((g)=>g.slug === globalSlug) : null;
19
- if (!docConfig) {
20
- throw new Error();
21
- }
22
- const { field } = getFieldByPath({
23
- config: req.payload.config,
24
- fields: flattenAllFields({
25
- fields: docConfig.fields
26
- }),
27
- path
28
- });
29
- const customSlugify = typeof field?.custom?.slugify === 'function' ? field.custom.slugify : undefined;
30
- const result = customSlugify ? await customSlugify({
31
- data,
32
- req,
33
- valueToSlugify
34
- }) : defaultSlugify(valueToSlugify);
35
- return result;
13
+ */
14
+ export const slugifyHandler = async args => {
15
+ const {
16
+ collectionSlug,
17
+ data,
18
+ globalSlug,
19
+ path,
20
+ req,
21
+ valueToSlugify
22
+ } = args;
23
+ if (!req.user) {
24
+ throw new UnauthorizedError();
25
+ }
26
+ const docConfig = collectionSlug ? req.payload.collections[collectionSlug]?.config : globalSlug ? req.payload.config.globals.find(g => g.slug === globalSlug) : null;
27
+ if (!docConfig) {
28
+ throw new Error();
29
+ }
30
+ const {
31
+ field
32
+ } = getFieldByPath({
33
+ config: req.payload.config,
34
+ fields: flattenAllFields({
35
+ fields: docConfig.fields
36
+ }),
37
+ path
38
+ });
39
+ const customSlugify = typeof field?.custom?.slugify === 'function' ? field.custom.slugify : undefined;
40
+ const result = customSlugify ? await customSlugify({
41
+ data,
42
+ req,
43
+ valueToSlugify
44
+ }) : defaultSlugify(valueToSlugify);
45
+ return result;
36
46
  };
37
-
38
47
  //# sourceMappingURL=slugify.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/slugify.ts"],"sourcesContent":["import type { Slugify } from 'payload/shared'\n\nimport {\n flattenAllFields,\n getFieldByPath,\n type ServerFunction,\n type SlugifyServerFunctionArgs,\n UnauthorizedError,\n} from 'payload'\nimport { slugify as defaultSlugify } from 'payload/shared'\n\n/**\n * This server function is directly related to the {@link https://payloadcms.com/docs/fields/text#slug-field | Slug Field}.\n * This is a server function that is used to invoke the user's custom slugify function from the client.\n * This pattern is required, as there is no other way for us to pass their function across the client-server boundary.\n * - Not through props\n * - Not from a server function defined within a server component (see below)\n * When a server function contains non-serializable data within its closure, it gets passed through the boundary (and breaks).\n * The only way to pass server functions to the client (that contain non-serializable data) is if it is globally defined.\n * But we also cannot define this function alongside the server component, as we will not have access to their custom slugify function.\n * See `ServerFunctionsProvider` for more details.\n */\nexport const slugifyHandler: ServerFunction<\n SlugifyServerFunctionArgs,\n Promise<ReturnType<Slugify>>\n> = async (args) => {\n const { collectionSlug, data, globalSlug, path, req, valueToSlugify } = args\n\n if (!req.user) {\n throw new UnauthorizedError()\n }\n\n const docConfig = collectionSlug\n ? req.payload.collections[collectionSlug]?.config\n : globalSlug\n ? req.payload.config.globals.find((g) => g.slug === globalSlug)\n : null\n\n if (!docConfig) {\n throw new Error()\n }\n\n const { field } = getFieldByPath({\n config: req.payload.config,\n fields: flattenAllFields({ fields: docConfig.fields }),\n path,\n })\n\n const customSlugify = (\n typeof field?.custom?.slugify === 'function' ? field.custom.slugify : undefined\n ) as Slugify\n\n const result = customSlugify\n ? await customSlugify({ data, req, valueToSlugify })\n : defaultSlugify(valueToSlugify)\n\n return result\n}\n"],"names":["flattenAllFields","getFieldByPath","UnauthorizedError","slugify","defaultSlugify","slugifyHandler","args","collectionSlug","data","globalSlug","path","req","valueToSlugify","user","docConfig","payload","collections","config","globals","find","g","slug","Error","field","fields","customSlugify","custom","undefined","result"],"mappings":"AAEA,SACEA,gBAAgB,EAChBC,cAAc,EAGdC,iBAAiB,QACZ,UAAS;AAChB,SAASC,WAAWC,cAAc,QAAQ,iBAAgB;AAE1D;;;;;;;;;;CAUC,GACD,OAAO,MAAMC,iBAGT,OAAOC;IACT,MAAM,EAAEC,cAAc,EAAEC,IAAI,EAAEC,UAAU,EAAEC,IAAI,EAAEC,GAAG,EAAEC,cAAc,EAAE,GAAGN;IAExE,IAAI,CAACK,IAAIE,IAAI,EAAE;QACb,MAAM,IAAIX;IACZ;IAEA,MAAMY,YAAYP,iBACdI,IAAII,OAAO,CAACC,WAAW,CAACT,eAAe,EAAEU,SACzCR,aACEE,IAAII,OAAO,CAACE,MAAM,CAACC,OAAO,CAACC,IAAI,CAAC,CAACC,IAAMA,EAAEC,IAAI,KAAKZ,cAClD;IAEN,IAAI,CAACK,WAAW;QACd,MAAM,IAAIQ;IACZ;IAEA,MAAM,EAAEC,KAAK,EAAE,GAAGtB,eAAe;QAC/BgB,QAAQN,IAAII,OAAO,CAACE,MAAM;QAC1BO,QAAQxB,iBAAiB;YAAEwB,QAAQV,UAAUU,MAAM;QAAC;QACpDd;IACF;IAEA,MAAMe,gBACJ,OAAOF,OAAOG,QAAQvB,YAAY,aAAaoB,MAAMG,MAAM,CAACvB,OAAO,GAAGwB;IAGxE,MAAMC,SAASH,gBACX,MAAMA,cAAc;QAAEjB;QAAMG;QAAKC;IAAe,KAChDR,eAAeQ;IAEnB,OAAOgB;AACT,EAAC"}
1
+ {"version":3,"file":"slugify.js","names":["flattenAllFields","getFieldByPath","UnauthorizedError","slugify","defaultSlugify","slugifyHandler","args","collectionSlug","data","globalSlug","path","req","valueToSlugify","user","docConfig","payload","collections","config","globals","find","g","slug","Error","field","fields","customSlugify","custom","undefined","result"],"sources":["../../src/utilities/slugify.ts"],"sourcesContent":["import type { Slugify } from 'payload/shared'\n\nimport {\n flattenAllFields,\n getFieldByPath,\n type ServerFunction,\n type SlugifyServerFunctionArgs,\n UnauthorizedError,\n} from 'payload'\nimport { slugify as defaultSlugify } from 'payload/shared'\n\n/**\n * This server function is directly related to the {@link https://payloadcms.com/docs/fields/text#slug-field | Slug Field}.\n * This is a server function that is used to invoke the user's custom slugify function from the client.\n * This pattern is required, as there is no other way for us to pass their function across the client-server boundary.\n * - Not through props\n * - Not from a server function defined within a server component (see below)\n * When a server function contains non-serializable data within its closure, it gets passed through the boundary (and breaks).\n * The only way to pass server functions to the client (that contain non-serializable data) is if it is globally defined.\n * But we also cannot define this function alongside the server component, as we will not have access to their custom slugify function.\n * See `ServerFunctionsProvider` for more details.\n */\nexport const slugifyHandler: ServerFunction<\n SlugifyServerFunctionArgs,\n Promise<ReturnType<Slugify>>\n> = async (args) => {\n const { collectionSlug, data, globalSlug, path, req, valueToSlugify } = args\n\n if (!req.user) {\n throw new UnauthorizedError()\n }\n\n const docConfig = collectionSlug\n ? req.payload.collections[collectionSlug]?.config\n : globalSlug\n ? req.payload.config.globals.find((g) => g.slug === globalSlug)\n : null\n\n if (!docConfig) {\n throw new Error()\n }\n\n const { field } = getFieldByPath({\n config: req.payload.config,\n fields: flattenAllFields({ fields: docConfig.fields }),\n path,\n })\n\n const customSlugify = (\n typeof field?.custom?.slugify === 'function' ? field.custom.slugify : undefined\n ) as Slugify\n\n const result = customSlugify\n ? await customSlugify({ data, req, valueToSlugify })\n : defaultSlugify(valueToSlugify)\n\n return result\n}\n"],"mappings":"AAEA,SACEA,gBAAgB,EAChBC,cAAc,EAGdC,iBAAiB,QACZ;AACP,SAASC,OAAA,IAAWC,cAAc,QAAQ;AAE1C;;;;;;;;;;;AAWA,OAAO,MAAMC,cAAA,GAGT,MAAOC,IAAA;EACT,MAAM;IAAEC,cAAc;IAAEC,IAAI;IAAEC,UAAU;IAAEC,IAAI;IAAEC,GAAG;IAAEC;EAAc,CAAE,GAAGN,IAAA;EAExE,IAAI,CAACK,GAAA,CAAIE,IAAI,EAAE;IACb,MAAM,IAAIX,iBAAA;EACZ;EAEA,MAAMY,SAAA,GAAYP,cAAA,GACdI,GAAA,CAAII,OAAO,CAACC,WAAW,CAACT,cAAA,CAAe,EAAEU,MAAA,GACzCR,UAAA,GACEE,GAAA,CAAII,OAAO,CAACE,MAAM,CAACC,OAAO,CAACC,IAAI,CAAEC,CAAA,IAAMA,CAAA,CAAEC,IAAI,KAAKZ,UAAA,IAClD;EAEN,IAAI,CAACK,SAAA,EAAW;IACd,MAAM,IAAIQ,KAAA;EACZ;EAEA,MAAM;IAAEC;EAAK,CAAE,GAAGtB,cAAA,CAAe;IAC/BgB,MAAA,EAAQN,GAAA,CAAII,OAAO,CAACE,MAAM;IAC1BO,MAAA,EAAQxB,gBAAA,CAAiB;MAAEwB,MAAA,EAAQV,SAAA,CAAUU;IAAO;IACpDd;EACF;EAEA,MAAMe,aAAA,GACJ,OAAOF,KAAA,EAAOG,MAAA,EAAQvB,OAAA,KAAY,aAAaoB,KAAA,CAAMG,MAAM,CAACvB,OAAO,GAAGwB,SAAA;EAGxE,MAAMC,MAAA,GAASH,aAAA,GACX,MAAMA,aAAA,CAAc;IAAEjB,IAAA;IAAMG,GAAA;IAAKC;EAAe,KAChDR,cAAA,CAAeQ,cAAA;EAEnB,OAAOgB,MAAA;AACT","ignoreList":[]}
@@ -1,9 +1,8 @@
1
- export const timestamp = (label)=>{
2
- if (!process.env.PAYLOAD_TIME) {
3
- process.env.PAYLOAD_TIME = String(new Date().getTime());
4
- }
5
- const now = new Date();
6
- console.log(`[${now.getTime() - Number(process.env.PAYLOAD_TIME)}ms] ${label}`);
1
+ export const timestamp = label => {
2
+ if (!process.env.PAYLOAD_TIME) {
3
+ process.env.PAYLOAD_TIME = String(new Date().getTime());
4
+ }
5
+ const now = new Date();
6
+ console.log(`[${now.getTime() - Number(process.env.PAYLOAD_TIME)}ms] ${label}`);
7
7
  };
8
-
9
8
  //# sourceMappingURL=timestamp.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utilities/timestamp.ts"],"sourcesContent":["export const timestamp = (label: string) => {\n if (!process.env.PAYLOAD_TIME) {\n process.env.PAYLOAD_TIME = String(new Date().getTime())\n }\n const now = new Date()\n console.log(`[${now.getTime() - Number(process.env.PAYLOAD_TIME)}ms] ${label}`)\n}\n"],"names":["timestamp","label","process","env","PAYLOAD_TIME","String","Date","getTime","now","console","log","Number"],"mappings":"AAAA,OAAO,MAAMA,YAAY,CAACC;IACxB,IAAI,CAACC,QAAQC,GAAG,CAACC,YAAY,EAAE;QAC7BF,QAAQC,GAAG,CAACC,YAAY,GAAGC,OAAO,IAAIC,OAAOC,OAAO;IACtD;IACA,MAAMC,MAAM,IAAIF;IAChBG,QAAQC,GAAG,CAAC,CAAC,CAAC,EAAEF,IAAID,OAAO,KAAKI,OAAOT,QAAQC,GAAG,CAACC,YAAY,EAAE,IAAI,EAAEH,OAAO;AAChF,EAAC"}
1
+ {"version":3,"file":"timestamp.js","names":["timestamp","label","process","env","PAYLOAD_TIME","String","Date","getTime","now","console","log","Number"],"sources":["../../src/utilities/timestamp.ts"],"sourcesContent":["export const timestamp = (label: string) => {\n if (!process.env.PAYLOAD_TIME) {\n process.env.PAYLOAD_TIME = String(new Date().getTime())\n }\n const now = new Date()\n console.log(`[${now.getTime() - Number(process.env.PAYLOAD_TIME)}ms] ${label}`)\n}\n"],"mappings":"AAAA,OAAO,MAAMA,SAAA,GAAaC,KAAA;EACxB,IAAI,CAACC,OAAA,CAAQC,GAAG,CAACC,YAAY,EAAE;IAC7BF,OAAA,CAAQC,GAAG,CAACC,YAAY,GAAGC,MAAA,CAAO,IAAIC,IAAA,GAAOC,OAAO;EACtD;EACA,MAAMC,GAAA,GAAM,IAAIF,IAAA;EAChBG,OAAA,CAAQC,GAAG,CAAC,IAAIF,GAAA,CAAID,OAAO,KAAKI,MAAA,CAAOT,OAAA,CAAQC,GAAG,CAACC,YAAY,QAAQH,KAAA,EAAO;AAChF","ignoreList":[]}