@payloadcms/next 3.80.0-internal-debug.7019cc9 → 3.80.0-internal.0311fce

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 (523) 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 +24 -65
  8. package/dist/cjs/withPayload.cjs.map +2 -2
  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/HierarchyTypeField/index.d.ts +9 -0
  28. package/dist/elements/HierarchyTypeField/index.d.ts.map +1 -0
  29. package/dist/elements/HierarchyTypeField/index.js +114 -0
  30. package/dist/elements/HierarchyTypeField/index.js.map +1 -0
  31. package/dist/elements/HierarchyTypeField/index.server.d.ts +9 -0
  32. package/dist/elements/HierarchyTypeField/index.server.d.ts.map +1 -0
  33. package/dist/elements/HierarchyTypeField/index.server.js +32 -0
  34. package/dist/elements/HierarchyTypeField/index.server.js.map +1 -0
  35. package/dist/elements/Logo/index.js +34 -19
  36. package/dist/elements/Logo/index.js.map +1 -1
  37. package/dist/elements/Nav/NavHamburger/index.js +44 -23
  38. package/dist/elements/Nav/NavHamburger/index.js.map +1 -1
  39. package/dist/elements/Nav/NavWrapper/index.js +54 -28
  40. package/dist/elements/Nav/NavWrapper/index.js.map +1 -1
  41. package/dist/elements/Nav/SettingsMenuButton/index.js +39 -33
  42. package/dist/elements/Nav/SettingsMenuButton/index.js.map +1 -1
  43. package/dist/elements/Nav/SidebarTabs/TabError/index.d.ts +8 -0
  44. package/dist/elements/Nav/SidebarTabs/TabError/index.d.ts.map +1 -0
  45. package/dist/elements/Nav/SidebarTabs/TabError/index.js +42 -0
  46. package/dist/elements/Nav/SidebarTabs/TabError/index.js.map +1 -0
  47. package/dist/elements/Nav/SidebarTabs/constants.d.ts +2 -0
  48. package/dist/elements/Nav/SidebarTabs/constants.d.ts.map +1 -0
  49. package/dist/elements/Nav/SidebarTabs/constants.js +2 -0
  50. package/dist/elements/Nav/SidebarTabs/constants.js.map +1 -0
  51. package/dist/elements/Nav/SidebarTabs/index.client.d.ts +20 -0
  52. package/dist/elements/Nav/SidebarTabs/index.client.d.ts.map +1 -0
  53. package/dist/elements/Nav/SidebarTabs/index.client.js +155 -0
  54. package/dist/elements/Nav/SidebarTabs/index.client.js.map +1 -0
  55. package/dist/elements/Nav/SidebarTabs/index.d.ts +17 -0
  56. package/dist/elements/Nav/SidebarTabs/index.d.ts.map +1 -0
  57. package/dist/elements/Nav/SidebarTabs/index.js +80 -0
  58. package/dist/elements/Nav/SidebarTabs/index.js.map +1 -0
  59. package/dist/elements/Nav/SidebarTabs/renderTabServerFn.d.ts +10 -0
  60. package/dist/elements/Nav/SidebarTabs/renderTabServerFn.d.ts.map +1 -0
  61. package/dist/elements/Nav/SidebarTabs/renderTabServerFn.js +53 -0
  62. package/dist/elements/Nav/SidebarTabs/renderTabServerFn.js.map +1 -0
  63. package/dist/elements/Nav/getNavPrefs.d.ts.map +1 -1
  64. package/dist/elements/Nav/getNavPrefs.js +56 -27
  65. package/dist/elements/Nav/getNavPrefs.js.map +1 -1
  66. package/dist/elements/Nav/index.client.d.ts.map +1 -1
  67. package/dist/elements/Nav/index.client.js +104 -100
  68. package/dist/elements/Nav/index.client.js.map +1 -1
  69. package/dist/elements/Nav/index.d.ts.map +1 -1
  70. package/dist/elements/Nav/index.js +199 -193
  71. package/dist/elements/Nav/index.js.map +1 -1
  72. package/dist/exports/auth.js +0 -1
  73. package/dist/exports/auth.js.map +1 -1
  74. package/dist/exports/client.d.ts +2 -1
  75. package/dist/exports/client.d.ts.map +1 -1
  76. package/dist/exports/client.js +3 -2
  77. package/dist/exports/client.js.map +1 -1
  78. package/dist/exports/layouts.js +0 -1
  79. package/dist/exports/layouts.js.map +1 -1
  80. package/dist/exports/routes.js +0 -1
  81. package/dist/exports/routes.js.map +1 -1
  82. package/dist/exports/rsc.d.ts +2 -1
  83. package/dist/exports/rsc.d.ts.map +1 -1
  84. package/dist/exports/rsc.js +2 -2
  85. package/dist/exports/rsc.js.map +1 -1
  86. package/dist/exports/templates.js +0 -1
  87. package/dist/exports/templates.js.map +1 -1
  88. package/dist/exports/utilities.d.ts +2 -0
  89. package/dist/exports/utilities.d.ts.map +1 -1
  90. package/dist/exports/utilities.js +13 -7
  91. package/dist/exports/utilities.js.map +1 -1
  92. package/dist/exports/views.js +0 -1
  93. package/dist/exports/views.js.map +1 -1
  94. package/dist/index.js +0 -1
  95. package/dist/index.js.map +1 -1
  96. package/dist/layouts/Root/NestProviders.js +20 -21
  97. package/dist/layouts/Root/NestProviders.js.map +1 -1
  98. package/dist/layouts/Root/checkDependencies.js +41 -49
  99. package/dist/layouts/Root/checkDependencies.js.map +1 -1
  100. package/dist/layouts/Root/index.js +103 -128
  101. package/dist/layouts/Root/index.js.map +1 -1
  102. package/dist/prod/styles.css +1 -5
  103. package/dist/routes/graphql/handler.js +122 -114
  104. package/dist/routes/graphql/handler.js.map +1 -1
  105. package/dist/routes/graphql/index.js +0 -1
  106. package/dist/routes/graphql/index.js.map +1 -1
  107. package/dist/routes/graphql/playground.js +27 -28
  108. package/dist/routes/graphql/playground.js.map +1 -1
  109. package/dist/routes/index.js +0 -1
  110. package/dist/routes/index.js.map +1 -1
  111. package/dist/routes/rest/index.js +22 -23
  112. package/dist/routes/rest/index.js.map +1 -1
  113. package/dist/routes/rest/og/image.js +79 -103
  114. package/dist/routes/rest/og/image.js.map +1 -1
  115. package/dist/routes/rest/og/index.js +54 -59
  116. package/dist/routes/rest/og/index.js.map +1 -1
  117. package/dist/templates/Default/NavHamburger/index.js +20 -12
  118. package/dist/templates/Default/NavHamburger/index.js.map +1 -1
  119. package/dist/templates/Default/Wrapper/index.js +44 -20
  120. package/dist/templates/Default/Wrapper/index.js.map +1 -1
  121. package/dist/templates/Default/index.js +116 -147
  122. package/dist/templates/Default/index.js.map +1 -1
  123. package/dist/templates/Minimal/index.js +17 -26
  124. package/dist/templates/Minimal/index.js.map +1 -1
  125. package/dist/utilities/getExistingAuthToken.js +2 -3
  126. package/dist/utilities/getExistingAuthToken.js.map +1 -1
  127. package/dist/utilities/getHierarchyAncestry.d.ts +24 -0
  128. package/dist/utilities/getHierarchyAncestry.d.ts.map +1 -0
  129. package/dist/utilities/getHierarchyAncestry.js +103 -0
  130. package/dist/utilities/getHierarchyAncestry.js.map +1 -0
  131. package/dist/utilities/getNextRequestI18n.js +13 -12
  132. package/dist/utilities/getNextRequestI18n.js.map +1 -1
  133. package/dist/utilities/getPayloadHMR.js +5 -5
  134. package/dist/utilities/getPayloadHMR.js.map +1 -1
  135. package/dist/utilities/getPreferences.js +22 -27
  136. package/dist/utilities/getPreferences.js.map +1 -1
  137. package/dist/utilities/getRequestLocale.js +14 -13
  138. package/dist/utilities/getRequestLocale.js.map +1 -1
  139. package/dist/utilities/getRequestTheme.js +19 -19
  140. package/dist/utilities/getRequestTheme.js.map +1 -1
  141. package/dist/utilities/getRouteWithoutAdmin.js +5 -3
  142. package/dist/utilities/getRouteWithoutAdmin.js.map +1 -1
  143. package/dist/utilities/handleAuthRedirect.js +36 -22
  144. package/dist/utilities/handleAuthRedirect.js.map +1 -1
  145. package/dist/utilities/handleServerFunctions.js +44 -34
  146. package/dist/utilities/handleServerFunctions.js.map +1 -1
  147. package/dist/utilities/initReq.js +96 -78
  148. package/dist/utilities/initReq.js.map +1 -1
  149. package/dist/utilities/isCustomAdminView.js +26 -22
  150. package/dist/utilities/isCustomAdminView.js.map +1 -1
  151. package/dist/utilities/isPublicAdminRoute.js +20 -26
  152. package/dist/utilities/isPublicAdminRoute.js.map +1 -1
  153. package/dist/utilities/meta.js +63 -68
  154. package/dist/utilities/meta.js.map +1 -1
  155. package/dist/utilities/selectiveCache.js +26 -25
  156. package/dist/utilities/selectiveCache.js.map +1 -1
  157. package/dist/utilities/setPayloadAuthCookie.js +22 -19
  158. package/dist/utilities/setPayloadAuthCookie.js.map +1 -1
  159. package/dist/utilities/slugify.js +33 -24
  160. package/dist/utilities/slugify.js.map +1 -1
  161. package/dist/utilities/timestamp.js +6 -7
  162. package/dist/utilities/timestamp.js.map +1 -1
  163. package/dist/views/API/LocaleSelector/index.js +39 -17
  164. package/dist/views/API/LocaleSelector/index.js.map +1 -1
  165. package/dist/views/API/RenderJSON/index.js +126 -171
  166. package/dist/views/API/RenderJSON/index.js.map +1 -1
  167. package/dist/views/API/index.client.js +199 -291
  168. package/dist/views/API/index.client.js.map +1 -1
  169. package/dist/views/API/index.js +2 -7
  170. package/dist/views/API/index.js.map +1 -1
  171. package/dist/views/API/metadata.js +23 -18
  172. package/dist/views/API/metadata.js.map +1 -1
  173. package/dist/views/Account/ResetPreferences/index.js +102 -78
  174. package/dist/views/Account/ResetPreferences/index.js.map +1 -1
  175. package/dist/views/Account/Settings/LanguageSelector.js +47 -18
  176. package/dist/views/Account/Settings/LanguageSelector.js.map +1 -1
  177. package/dist/views/Account/Settings/index.js +25 -60
  178. package/dist/views/Account/Settings/index.js.map +1 -1
  179. package/dist/views/Account/ToggleTheme/index.js +55 -38
  180. package/dist/views/Account/ToggleTheme/index.js.map +1 -1
  181. package/dist/views/Account/index.client.js +32 -16
  182. package/dist/views/Account/index.client.js.map +1 -1
  183. package/dist/views/Account/index.js +162 -149
  184. package/dist/views/Account/index.js.map +1 -1
  185. package/dist/views/Account/metadata.js +12 -8
  186. package/dist/views/Account/metadata.js.map +1 -1
  187. package/dist/views/CollectionTrash/index.js +17 -17
  188. package/dist/views/CollectionTrash/index.js.map +1 -1
  189. package/dist/views/CollectionTrash/metadata.js +21 -18
  190. package/dist/views/CollectionTrash/metadata.js.map +1 -1
  191. package/dist/views/CreateFirstUser/index.client.js +103 -117
  192. package/dist/views/CreateFirstUser/index.client.js.map +1 -1
  193. package/dist/views/CreateFirstUser/index.js +81 -87
  194. package/dist/views/CreateFirstUser/index.js.map +1 -1
  195. package/dist/views/CreateFirstUser/metadata.js +12 -8
  196. package/dist/views/CreateFirstUser/metadata.js.map +1 -1
  197. package/dist/views/Dashboard/Default/ModularDashboard/DashboardStepNav.js +170 -145
  198. package/dist/views/Dashboard/Default/ModularDashboard/DashboardStepNav.js.map +1 -1
  199. package/dist/views/Dashboard/Default/ModularDashboard/WidgetConfigDrawer.js +118 -144
  200. package/dist/views/Dashboard/Default/ModularDashboard/WidgetConfigDrawer.js.map +1 -1
  201. package/dist/views/Dashboard/Default/ModularDashboard/WidgetEditControl.js +72 -59
  202. package/dist/views/Dashboard/Default/ModularDashboard/WidgetEditControl.js.map +1 -1
  203. package/dist/views/Dashboard/Default/ModularDashboard/index.client.js +414 -435
  204. package/dist/views/Dashboard/Default/ModularDashboard/index.client.js.map +1 -1
  205. package/dist/views/Dashboard/Default/ModularDashboard/index.js +63 -54
  206. package/dist/views/Dashboard/Default/ModularDashboard/index.js.map +1 -1
  207. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/RenderWidget.js +96 -65
  208. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/RenderWidget.js.map +1 -1
  209. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/getDefaultLayoutServerFn.js +54 -44
  210. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/getDefaultLayoutServerFn.js.map +1 -1
  211. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/renderWidgetServerFn.js +72 -65
  212. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/renderWidgetServerFn.js.map +1 -1
  213. package/dist/views/Dashboard/Default/ModularDashboard/useDashboardLayout.js +175 -193
  214. package/dist/views/Dashboard/Default/ModularDashboard/useDashboardLayout.js.map +1 -1
  215. package/dist/views/Dashboard/Default/ModularDashboard/utils/collisionDetection.js +30 -31
  216. package/dist/views/Dashboard/Default/ModularDashboard/utils/collisionDetection.js.map +1 -1
  217. package/dist/views/Dashboard/Default/ModularDashboard/utils/getItemsFromConfig.js +17 -18
  218. package/dist/views/Dashboard/Default/ModularDashboard/utils/getItemsFromConfig.js.map +1 -1
  219. package/dist/views/Dashboard/Default/ModularDashboard/utils/getItemsFromPreferences.js +5 -6
  220. package/dist/views/Dashboard/Default/ModularDashboard/utils/getItemsFromPreferences.js.map +1 -1
  221. package/dist/views/Dashboard/Default/ModularDashboard/utils/localeUtils.js +74 -69
  222. package/dist/views/Dashboard/Default/ModularDashboard/utils/localeUtils.js.map +1 -1
  223. package/dist/views/Dashboard/Default/ModularDashboard/utils/sensors.js +234 -228
  224. package/dist/views/Dashboard/Default/ModularDashboard/utils/sensors.js.map +1 -1
  225. package/dist/views/Dashboard/Default/index.js +45 -59
  226. package/dist/views/Dashboard/Default/index.js.map +1 -1
  227. package/dist/views/Dashboard/index.js +42 -46
  228. package/dist/views/Dashboard/index.js.map +1 -1
  229. package/dist/views/Dashboard/metadata.js +14 -10
  230. package/dist/views/Dashboard/metadata.js.map +1 -1
  231. package/dist/views/Document/getCustomDocumentViewByKey.js +2 -3
  232. package/dist/views/Document/getCustomDocumentViewByKey.js.map +1 -1
  233. package/dist/views/Document/getCustomViewByRoute.js +30 -27
  234. package/dist/views/Document/getCustomViewByRoute.js.map +1 -1
  235. package/dist/views/Document/getDocPreferences.js +41 -40
  236. package/dist/views/Document/getDocPreferences.js.map +1 -1
  237. package/dist/views/Document/getDocumentData.js +55 -44
  238. package/dist/views/Document/getDocumentData.js.map +1 -1
  239. package/dist/views/Document/getDocumentPermissions.js +117 -114
  240. package/dist/views/Document/getDocumentPermissions.js.map +1 -1
  241. package/dist/views/Document/getDocumentView.js +283 -313
  242. package/dist/views/Document/getDocumentView.js.map +1 -1
  243. package/dist/views/Document/getIsLocked.js +73 -73
  244. package/dist/views/Document/getIsLocked.js.map +1 -1
  245. package/dist/views/Document/getMetaBySegment.js +136 -130
  246. package/dist/views/Document/getMetaBySegment.js.map +1 -1
  247. package/dist/views/Document/getVersions.js +213 -220
  248. package/dist/views/Document/getVersions.js.map +1 -1
  249. package/dist/views/Document/handleServerFunction.js +127 -100
  250. package/dist/views/Document/handleServerFunction.js.map +1 -1
  251. package/dist/views/Document/index.js +359 -319
  252. package/dist/views/Document/index.js.map +1 -1
  253. package/dist/views/Document/metadata.js +1 -2
  254. package/dist/views/Document/metadata.js.map +1 -1
  255. package/dist/views/Document/renderDocumentSlots.d.ts.map +1 -1
  256. package/dist/views/Document/renderDocumentSlots.js +163 -141
  257. package/dist/views/Document/renderDocumentSlots.js.map +1 -1
  258. package/dist/views/Edit/index.js +6 -10
  259. package/dist/views/Edit/index.js.map +1 -1
  260. package/dist/views/Edit/metadata.js +46 -36
  261. package/dist/views/Edit/metadata.js.map +1 -1
  262. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js +164 -130
  263. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js.map +1 -1
  264. package/dist/views/ForgotPassword/index.js +62 -79
  265. package/dist/views/ForgotPassword/index.js.map +1 -1
  266. package/dist/views/ForgotPassword/metadata.js +12 -8
  267. package/dist/views/ForgotPassword/metadata.js.map +1 -1
  268. package/dist/views/List/createSerializableValue.js +11 -12
  269. package/dist/views/List/createSerializableValue.js.map +1 -1
  270. package/dist/views/List/enrichDocsWithVersionStatus.js +86 -86
  271. package/dist/views/List/enrichDocsWithVersionStatus.js.map +1 -1
  272. package/dist/views/List/extractRelationshipDisplayValue.js +14 -15
  273. package/dist/views/List/extractRelationshipDisplayValue.js.map +1 -1
  274. package/dist/views/List/extractValueOrRelationshipID.js +15 -16
  275. package/dist/views/List/extractValueOrRelationshipID.js.map +1 -1
  276. package/dist/views/List/handleGroupBy.js +150 -133
  277. package/dist/views/List/handleGroupBy.js.map +1 -1
  278. package/dist/views/List/handleHierarchy.d.ts +17 -0
  279. package/dist/views/List/handleHierarchy.d.ts.map +1 -0
  280. package/dist/views/List/handleHierarchy.js +243 -0
  281. package/dist/views/List/handleHierarchy.js.map +1 -0
  282. package/dist/views/List/handleServerFunction.js +122 -96
  283. package/dist/views/List/handleServerFunction.js.map +1 -1
  284. package/dist/views/List/index.d.ts.map +1 -1
  285. package/dist/views/List/index.js +382 -310
  286. package/dist/views/List/index.js.map +1 -1
  287. package/dist/views/List/metadata.js +20 -17
  288. package/dist/views/List/metadata.js.map +1 -1
  289. package/dist/views/List/renderListViewSlots.js +75 -82
  290. package/dist/views/List/renderListViewSlots.js.map +1 -1
  291. package/dist/views/List/resolveAllFilterOptions.js +45 -43
  292. package/dist/views/List/resolveAllFilterOptions.js.map +1 -1
  293. package/dist/views/List/transformColumnsToSelect.js +8 -9
  294. package/dist/views/List/transformColumnsToSelect.js.map +1 -1
  295. package/dist/views/Login/LoginField/index.js +89 -57
  296. package/dist/views/Login/LoginField/index.js.map +1 -1
  297. package/dist/views/Login/LoginForm/index.js +160 -107
  298. package/dist/views/Login/LoginForm/index.js.map +1 -1
  299. package/dist/views/Login/index.js +85 -82
  300. package/dist/views/Login/index.js.map +1 -1
  301. package/dist/views/Login/metadata.js +12 -8
  302. package/dist/views/Login/metadata.js.map +1 -1
  303. package/dist/views/Logout/LogoutClient.js +120 -84
  304. package/dist/views/Logout/LogoutClient.js.map +1 -1
  305. package/dist/views/Logout/index.js +29 -29
  306. package/dist/views/Logout/index.js.map +1 -1
  307. package/dist/views/Logout/metadata.js +11 -7
  308. package/dist/views/Logout/metadata.js.map +1 -1
  309. package/dist/views/NotFound/index.client.js +82 -71
  310. package/dist/views/NotFound/index.client.js.map +1 -1
  311. package/dist/views/NotFound/index.js +73 -72
  312. package/dist/views/NotFound/index.js.map +1 -1
  313. package/dist/views/NotFound/metadata.js +9 -7
  314. package/dist/views/NotFound/metadata.js.map +1 -1
  315. package/dist/views/ResetPassword/ResetPasswordForm/index.js +108 -97
  316. package/dist/views/ResetPassword/ResetPasswordForm/index.js.map +1 -1
  317. package/dist/views/ResetPassword/index.js +73 -93
  318. package/dist/views/ResetPassword/index.js.map +1 -1
  319. package/dist/views/ResetPassword/metadata.js +12 -8
  320. package/dist/views/ResetPassword/metadata.js.map +1 -1
  321. package/dist/views/Root/attachViewActions.js +23 -18
  322. package/dist/views/Root/attachViewActions.js.map +1 -1
  323. package/dist/views/Root/generateCustomViewMetadata.js +21 -19
  324. package/dist/views/Root/generateCustomViewMetadata.js.map +1 -1
  325. package/dist/views/Root/getCustomViewByKey.js +14 -12
  326. package/dist/views/Root/getCustomViewByKey.js.map +1 -1
  327. package/dist/views/Root/getCustomViewByRoute.js +42 -31
  328. package/dist/views/Root/getCustomViewByRoute.js.map +1 -1
  329. package/dist/views/Root/getDocumentViewInfo.js +23 -24
  330. package/dist/views/Root/getDocumentViewInfo.js.map +1 -1
  331. package/dist/views/Root/getRouteData.d.ts +1 -4
  332. package/dist/views/Root/getRouteData.d.ts.map +1 -1
  333. package/dist/views/Root/getRouteData.js +264 -336
  334. package/dist/views/Root/getRouteData.js.map +1 -1
  335. package/dist/views/Root/index.d.ts.map +1 -1
  336. package/dist/views/Root/index.js +265 -249
  337. package/dist/views/Root/index.js.map +1 -1
  338. package/dist/views/Root/isPathMatchingRoute.js +26 -21
  339. package/dist/views/Root/isPathMatchingRoute.js.map +1 -1
  340. package/dist/views/Root/metadata.d.ts.map +1 -1
  341. package/dist/views/Root/metadata.js +148 -179
  342. package/dist/views/Root/metadata.js.map +1 -1
  343. package/dist/views/Unauthorized/index.js +46 -54
  344. package/dist/views/Unauthorized/index.js.map +1 -1
  345. package/dist/views/Unauthorized/metadata.js +12 -8
  346. package/dist/views/Unauthorized/metadata.js.map +1 -1
  347. package/dist/views/Verify/index.client.js +43 -25
  348. package/dist/views/Verify/index.client.js.map +1 -1
  349. package/dist/views/Verify/index.js +64 -69
  350. package/dist/views/Verify/index.js.map +1 -1
  351. package/dist/views/Verify/metadata.js +12 -8
  352. package/dist/views/Verify/metadata.js.map +1 -1
  353. package/dist/views/Version/Default/SelectedLocalesContext.js +4 -4
  354. package/dist/views/Version/Default/SelectedLocalesContext.js.map +1 -1
  355. package/dist/views/Version/Default/SetStepNav.js +127 -86
  356. package/dist/views/Version/Default/SetStepNav.js.map +1 -1
  357. package/dist/views/Version/Default/index.js +236 -380
  358. package/dist/views/Version/Default/index.js.map +1 -1
  359. package/dist/views/Version/Default/types.js +1 -2
  360. package/dist/views/Version/Default/types.js.map +1 -1
  361. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js +119 -102
  362. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js.map +1 -1
  363. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js +73 -78
  364. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js.map +1 -1
  365. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js +408 -363
  366. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js.map +1 -1
  367. package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js +51 -40
  368. package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js.map +1 -1
  369. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.js +70 -38
  370. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.js.map +1 -1
  371. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js +56 -59
  372. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js.map +1 -1
  373. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js +117 -139
  374. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js.map +1 -1
  375. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.js +61 -56
  376. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.js.map +1 -1
  377. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js +206 -224
  378. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js.map +1 -1
  379. package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.js +11 -17
  380. package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.js.map +1 -1
  381. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js +74 -49
  382. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js.map +1 -1
  383. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js +146 -135
  384. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js.map +1 -1
  385. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js +82 -57
  386. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js.map +1 -1
  387. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.js +211 -252
  388. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.js.map +1 -1
  389. package/dist/views/Version/RenderFieldsToDiff/fields/index.js +22 -23
  390. package/dist/views/Version/RenderFieldsToDiff/fields/index.js.map +1 -1
  391. package/dist/views/Version/RenderFieldsToDiff/index.js +9 -12
  392. package/dist/views/Version/RenderFieldsToDiff/index.js.map +1 -1
  393. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.js +228 -213
  394. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.js.map +1 -1
  395. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.spec.js +826 -1005
  396. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.spec.js.map +1 -1
  397. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.js +1 -2
  398. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.js.map +1 -1
  399. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.spec.js +43 -44
  400. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.spec.js.map +1 -1
  401. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.js +36 -32
  402. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.js.map +1 -1
  403. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.spec.js +129 -145
  404. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.spec.js.map +1 -1
  405. package/dist/views/Version/Restore/index.js +92 -117
  406. package/dist/views/Version/Restore/index.js.map +1 -1
  407. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.js +50 -33
  408. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.js.map +1 -1
  409. package/dist/views/Version/SelectComparison/VersionDrawer/index.js +226 -170
  410. package/dist/views/Version/SelectComparison/VersionDrawer/index.js.map +1 -1
  411. package/dist/views/Version/SelectComparison/index.js +50 -73
  412. package/dist/views/Version/SelectComparison/index.js.map +1 -1
  413. package/dist/views/Version/SelectComparison/types.js +1 -2
  414. package/dist/views/Version/SelectComparison/types.js.map +1 -1
  415. package/dist/views/Version/SelectLocales/index.js +32 -34
  416. package/dist/views/Version/SelectLocales/index.js.map +1 -1
  417. package/dist/views/Version/VersionPillLabel/VersionPillLabel.js +100 -106
  418. package/dist/views/Version/VersionPillLabel/VersionPillLabel.js.map +1 -1
  419. package/dist/views/Version/VersionPillLabel/getVersionLabel.js +35 -30
  420. package/dist/views/Version/VersionPillLabel/getVersionLabel.js.map +1 -1
  421. package/dist/views/Version/fetchVersions.js +138 -113
  422. package/dist/views/Version/fetchVersions.js.map +1 -1
  423. package/dist/views/Version/index.js +326 -328
  424. package/dist/views/Version/index.js.map +1 -1
  425. package/dist/views/Version/metadata.js +50 -43
  426. package/dist/views/Version/metadata.js.map +1 -1
  427. package/dist/views/Versions/buildColumns.js +79 -95
  428. package/dist/views/Versions/buildColumns.js.map +1 -1
  429. package/dist/views/Versions/cells/AutosaveCell/index.js +38 -34
  430. package/dist/views/Versions/cells/AutosaveCell/index.js.map +1 -1
  431. package/dist/views/Versions/cells/CreatedAt/index.js +53 -32
  432. package/dist/views/Versions/cells/CreatedAt/index.js.map +1 -1
  433. package/dist/views/Versions/cells/ID/index.js +8 -10
  434. package/dist/views/Versions/cells/ID/index.js.map +1 -1
  435. package/dist/views/Versions/index.client.js +83 -106
  436. package/dist/views/Versions/index.client.js.map +1 -1
  437. package/dist/views/Versions/index.js +164 -164
  438. package/dist/views/Versions/index.js.map +1 -1
  439. package/dist/views/Versions/metadata.js +44 -37
  440. package/dist/views/Versions/metadata.js.map +1 -1
  441. package/dist/views/Versions/types.js +1 -2
  442. package/dist/views/Versions/types.js.map +1 -1
  443. package/dist/withPayload/withPayload.js +177 -236
  444. package/dist/withPayload/withPayload.js.map +1 -1
  445. package/dist/withPayload/withPayload.spec.js +35 -36
  446. package/dist/withPayload/withPayload.spec.js.map +1 -1
  447. package/dist/withPayload/withPayload.utils.js +73 -65
  448. package/dist/withPayload/withPayload.utils.js.map +1 -1
  449. package/dist/withPayload/withPayloadLegacy.js +40 -41
  450. package/dist/withPayload/withPayloadLegacy.js.map +1 -1
  451. package/package.json +6 -6
  452. package/dist/elements/DocumentHeader/Tabs/Tab/index.scss +0 -38
  453. package/dist/elements/DocumentHeader/Tabs/index.scss +0 -54
  454. package/dist/elements/DocumentHeader/Tabs/tabs/VersionsPill/index.scss +0 -10
  455. package/dist/elements/DocumentHeader/index.scss +0 -64
  456. package/dist/elements/FormHeader/index.scss +0 -8
  457. package/dist/elements/Nav/NavWrapper/index.scss +0 -27
  458. package/dist/elements/Nav/SettingsMenuButton/index.scss +0 -11
  459. package/dist/elements/Nav/index.scss +0 -173
  460. package/dist/esbuildEntry.d.ts +0 -5
  461. package/dist/esbuildEntry.d.ts.map +0 -1
  462. package/dist/esbuildEntry.js +0 -6
  463. package/dist/esbuildEntry.js.map +0 -1
  464. package/dist/templates/Default/Wrapper/index.scss +0 -58
  465. package/dist/templates/Default/index.scss +0 -79
  466. package/dist/templates/Minimal/index.scss +0 -30
  467. package/dist/views/API/RenderJSON/index.scss +0 -129
  468. package/dist/views/API/index.scss +0 -119
  469. package/dist/views/Account/Settings/index.scss +0 -48
  470. package/dist/views/BrowseByFolder/buildView.d.ts +0 -13
  471. package/dist/views/BrowseByFolder/buildView.d.ts.map +0 -1
  472. package/dist/views/BrowseByFolder/buildView.js +0 -151
  473. package/dist/views/BrowseByFolder/buildView.js.map +0 -1
  474. package/dist/views/BrowseByFolder/index.d.ts +0 -4
  475. package/dist/views/BrowseByFolder/index.d.ts.map +0 -1
  476. package/dist/views/BrowseByFolder/index.js +0 -20
  477. package/dist/views/BrowseByFolder/index.js.map +0 -1
  478. package/dist/views/BrowseByFolder/metadata.d.ts +0 -4
  479. package/dist/views/BrowseByFolder/metadata.d.ts.map +0 -1
  480. package/dist/views/BrowseByFolder/metadata.js +0 -16
  481. package/dist/views/BrowseByFolder/metadata.js.map +0 -1
  482. package/dist/views/CollectionFolders/buildView.d.ts +0 -15
  483. package/dist/views/CollectionFolders/buildView.d.ts.map +0 -1
  484. package/dist/views/CollectionFolders/buildView.js +0 -136
  485. package/dist/views/CollectionFolders/buildView.js.map +0 -1
  486. package/dist/views/CollectionFolders/index.d.ts +0 -4
  487. package/dist/views/CollectionFolders/index.d.ts.map +0 -1
  488. package/dist/views/CollectionFolders/index.js +0 -20
  489. package/dist/views/CollectionFolders/index.js.map +0 -1
  490. package/dist/views/CollectionFolders/metadata.d.ts +0 -7
  491. package/dist/views/CollectionFolders/metadata.d.ts.map +0 -1
  492. package/dist/views/CollectionFolders/metadata.js +0 -22
  493. package/dist/views/CollectionFolders/metadata.js.map +0 -1
  494. package/dist/views/CollectionFolders/renderFolderViewSlots.d.ts +0 -11
  495. package/dist/views/CollectionFolders/renderFolderViewSlots.d.ts.map +0 -1
  496. package/dist/views/CollectionFolders/renderFolderViewSlots.js +0 -61
  497. package/dist/views/CollectionFolders/renderFolderViewSlots.js.map +0 -1
  498. package/dist/views/CreateFirstUser/index.scss +0 -21
  499. package/dist/views/Dashboard/Default/ModularDashboard/index.scss +0 -318
  500. package/dist/views/Login/LoginForm/index.scss +0 -10
  501. package/dist/views/Login/index.scss +0 -10
  502. package/dist/views/Logout/index.scss +0 -25
  503. package/dist/views/NotFound/index.scss +0 -57
  504. package/dist/views/ResetPassword/index.scss +0 -11
  505. package/dist/views/Unauthorized/index.scss +0 -14
  506. package/dist/views/Verify/index.scss +0 -16
  507. package/dist/views/Version/Default/index.scss +0 -170
  508. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.scss +0 -81
  509. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.scss +0 -12
  510. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.scss +0 -9
  511. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.scss +0 -59
  512. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.scss +0 -91
  513. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.scss +0 -4
  514. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.scss +0 -9
  515. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.scss +0 -4
  516. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.scss +0 -121
  517. package/dist/views/Version/RenderFieldsToDiff/index.scss +0 -24
  518. package/dist/views/Version/Restore/index.scss +0 -84
  519. package/dist/views/Version/SelectComparison/VersionDrawer/index.scss +0 -18
  520. package/dist/views/Version/SelectComparison/index.scss +0 -9
  521. package/dist/views/Version/VersionPillLabel/index.scss +0 -26
  522. package/dist/views/Versions/cells/AutosaveCell/index.scss +0 -9
  523. package/dist/views/Versions/index.scss +0 -110
@@ -1,5 +1,5 @@
1
- import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
2
- import { DefaultListView, HydrateAuthProvider, ListQueryProvider } from '@payloadcms/ui';
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { DefaultListView, HierarchyListView, HydrateAuthProvider, HydrateHierarchyProvider, ListQueryProvider } from '@payloadcms/ui';
3
3
  import { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent';
4
4
  import { getColumns, renderFilters, renderTable, upsertPreferences } from '@payloadcms/ui/rsc';
5
5
  import { notFound } from 'next/navigation.js';
@@ -8,337 +8,409 @@ import React, { Fragment } from 'react';
8
8
  import { getDocumentPermissions } from '../Document/getDocumentPermissions.js';
9
9
  import { enrichDocsWithVersionStatus } from './enrichDocsWithVersionStatus.js';
10
10
  import { handleGroupBy } from './handleGroupBy.js';
11
+ import { handleHierarchy } from './handleHierarchy.js';
11
12
  import { renderListViewSlots } from './renderListViewSlots.js';
12
13
  import { resolveAllFilterOptions } from './resolveAllFilterOptions.js';
13
14
  import { transformColumnsToSelect } from './transformColumnsToSelect.js';
14
15
  /**
15
- * @internal
16
- */ /**
17
- * Allows providing your own list view component. This will override the default list view component and
18
- * the collection's configured list view component (if any).
19
- */ /**
20
- * If not ListQuery is provided, `req.query` will be used.
21
- */ /**
22
- * @experimental This prop is subject to change in future releases.
23
- */ /**
24
16
  * This function is responsible for rendering
25
17
  * the list view on the server for both:
26
18
  * - default list view
27
19
  * - list view within drawers
28
20
  *
29
21
  * @internal
30
- */ export const renderListView = async (args)=>{
31
- const { clientConfig, ComponentOverride, customCellProps, disableBulkDelete, disableBulkEdit, disableQueryPresets, drawerSlug, enableRowSelections, initPageResult, overrideEntityVisibility, params, query: queryFromArgs, searchParams, trash, viewType } = args;
32
- const { collectionConfig, collectionConfig: { slug: collectionSlug }, locale: fullLocale, permissions, req, req: { i18n, payload, payload: { config }, query: queryFromReq, user }, visibleEntities } = initPageResult;
33
- const { routes: { admin: adminRoute } } = config;
34
- if (!collectionConfig || !permissions?.collections?.[collectionSlug]?.read || !visibleEntities.collections.includes(collectionSlug) && !overrideEntityVisibility) {
35
- throw new Error('not-found');
36
- }
37
- const query = queryFromArgs || queryFromReq;
38
- const columnsFromQuery = transformColumnsToPreferences(query?.columns);
39
- query.queryByGroup = query?.queryByGroup && typeof query.queryByGroup === 'string' ? JSON.parse(query.queryByGroup) : query?.queryByGroup;
40
- const collectionPreferences = await upsertPreferences({
41
- key: `collection-${collectionSlug}`,
42
- req,
43
- value: {
44
- columns: columnsFromQuery,
45
- groupBy: query?.groupBy,
46
- limit: isNumber(query?.limit) ? Number(query.limit) : undefined,
47
- preset: query?.preset,
48
- sort: query?.sort
49
- }
50
- });
51
- let queryPreset;
52
- let queryPresetPermissions;
53
- if (collectionPreferences?.preset) {
54
- try {
55
- queryPreset = await payload.findByID({
56
- id: collectionPreferences?.preset,
57
- collection: 'payload-query-presets',
58
- depth: 0,
59
- overrideAccess: false,
60
- user
61
- });
62
- if (queryPreset) {
63
- queryPresetPermissions = (await getDocumentPermissions({
64
- id: queryPreset.id,
65
- collectionConfig: req.payload.collections['payload-query-presets'].config,
66
- data: queryPreset,
67
- req
68
- }))?.docPermissions;
69
- }
70
- } catch (err) {
71
- req.payload.logger.error(`Error fetching query preset or preset permissions: ${err}`);
72
- }
22
+ */
23
+ export const renderListView = async args => {
24
+ const {
25
+ clientConfig,
26
+ ComponentOverride,
27
+ customCellProps,
28
+ disableBulkDelete,
29
+ disableBulkEdit,
30
+ disableQueryPresets,
31
+ drawerSlug,
32
+ enableRowSelections,
33
+ initPageResult,
34
+ overrideEntityVisibility,
35
+ params,
36
+ query: queryFromArgs,
37
+ searchParams,
38
+ trash,
39
+ viewType
40
+ } = args;
41
+ const {
42
+ collectionConfig,
43
+ collectionConfig: {
44
+ slug: collectionSlug
45
+ },
46
+ locale: fullLocale,
47
+ permissions,
48
+ req,
49
+ req: {
50
+ i18n,
51
+ payload,
52
+ payload: {
53
+ config
54
+ },
55
+ query: queryFromReq,
56
+ user
57
+ },
58
+ visibleEntities
59
+ } = initPageResult;
60
+ const {
61
+ routes: {
62
+ admin: adminRoute
73
63
  }
74
- query.preset = queryPreset?.id;
75
- if (queryPreset?.where && !query.where) {
76
- query.where = queryPreset.where;
64
+ } = config;
65
+ if (!collectionConfig || !permissions?.collections?.[collectionSlug]?.read || !visibleEntities.collections.includes(collectionSlug) && !overrideEntityVisibility) {
66
+ throw new Error('not-found');
67
+ }
68
+ const query = queryFromArgs || queryFromReq;
69
+ const columnsFromQuery = transformColumnsToPreferences(query?.columns);
70
+ query.queryByGroup = query?.queryByGroup && typeof query.queryByGroup === 'string' ? JSON.parse(query.queryByGroup) : query?.queryByGroup;
71
+ const collectionPreferences = await upsertPreferences({
72
+ key: `collection-${collectionSlug}`,
73
+ req,
74
+ value: {
75
+ columns: columnsFromQuery,
76
+ groupBy: query?.groupBy,
77
+ limit: isNumber(query?.limit) ? Number(query.limit) : undefined,
78
+ preset: query?.preset,
79
+ sort: query?.sort
77
80
  }
78
- query.groupBy = query.groupBy ?? queryPreset?.groupBy ?? collectionPreferences?.groupBy;
79
- const columnPreference = query.columns ? transformColumnsToPreferences(query.columns) : queryPreset?.columns ?? collectionPreferences?.columns;
80
- query.columns = transformColumnsToSearchParams(columnPreference);
81
- query.page = isNumber(query?.page) ? Number(query.page) : 0;
82
- query.limit = collectionPreferences?.limit || collectionConfig.admin.pagination.defaultLimit;
83
- query.sort = collectionPreferences?.sort || (typeof collectionConfig.defaultSort === 'string' ? collectionConfig.defaultSort : undefined);
84
- const baseFilterConstraint = await (collectionConfig.admin?.baseFilter ?? collectionConfig.admin?.baseListFilter)?.({
85
- limit: query.limit,
86
- page: query.page,
87
- req,
88
- sort: query.sort
89
- });
90
- let whereWithMergedSearch = mergeListSearchAndWhere({
91
- collectionConfig,
92
- search: typeof query?.search === 'string' ? query.search : undefined,
93
- where: combineWhereConstraints([
94
- query?.where,
95
- baseFilterConstraint
96
- ])
97
- });
98
- if (trash === true) {
99
- whereWithMergedSearch = {
100
- and: [
101
- whereWithMergedSearch,
102
- {
103
- deletedAt: {
104
- exists: true
105
- }
106
- }
107
- ]
108
- };
81
+ });
82
+ let queryPreset;
83
+ let queryPresetPermissions;
84
+ if (collectionPreferences?.preset) {
85
+ try {
86
+ queryPreset = await payload.findByID({
87
+ id: collectionPreferences?.preset,
88
+ collection: 'payload-query-presets',
89
+ depth: 0,
90
+ overrideAccess: false,
91
+ user
92
+ });
93
+ if (queryPreset) {
94
+ queryPresetPermissions = (await getDocumentPermissions({
95
+ id: queryPreset.id,
96
+ collectionConfig: req.payload.collections['payload-query-presets'].config,
97
+ data: queryPreset,
98
+ req
99
+ }))?.docPermissions;
100
+ }
101
+ } catch (err) {
102
+ req.payload.logger.error(`Error fetching query preset or preset permissions: ${err}`);
109
103
  }
110
- let Table = null;
111
- let columnState = [];
112
- let data = {
113
- // no results default
114
- docs: [],
115
- hasNextPage: false,
116
- hasPrevPage: false,
117
- limit: query.limit,
118
- nextPage: null,
119
- page: 1,
120
- pagingCounter: 0,
121
- prevPage: null,
122
- totalDocs: 0,
123
- totalPages: 0
104
+ }
105
+ query.preset = queryPreset?.id;
106
+ if (queryPreset?.where && !query.where) {
107
+ query.where = queryPreset.where;
108
+ }
109
+ query.groupBy = query.groupBy ?? queryPreset?.groupBy ?? collectionPreferences?.groupBy;
110
+ const columnPreference = query.columns ? transformColumnsToPreferences(query.columns) : queryPreset?.columns ?? collectionPreferences?.columns;
111
+ query.columns = transformColumnsToSearchParams(columnPreference);
112
+ query.page = isNumber(query?.page) ? Number(query.page) : 0;
113
+ query.limit = collectionPreferences?.limit || collectionConfig.admin.pagination.defaultLimit;
114
+ query.sort = collectionPreferences?.sort || (typeof collectionConfig.defaultSort === 'string' ? collectionConfig.defaultSort : undefined);
115
+ const baseFilterConstraint = await (collectionConfig.admin?.baseFilter ?? collectionConfig.admin?.baseListFilter)?.({
116
+ limit: query.limit,
117
+ page: query.page,
118
+ req,
119
+ sort: query.sort
120
+ });
121
+ let whereWithMergedSearch = mergeListSearchAndWhere({
122
+ collectionConfig,
123
+ search: typeof query?.search === 'string' ? query.search : undefined,
124
+ where: combineWhereConstraints([query?.where, baseFilterConstraint])
125
+ });
126
+ if (trash === true) {
127
+ whereWithMergedSearch = {
128
+ and: [whereWithMergedSearch, {
129
+ deletedAt: {
130
+ exists: true
131
+ }
132
+ }]
124
133
  };
125
- const clientCollectionConfig = clientConfig.collections.find((c)=>c.slug === collectionSlug);
126
- const columns = getColumns({
134
+ }
135
+ let Table = null;
136
+ let columnState = [];
137
+ let data = {
138
+ // no results default
139
+ docs: [],
140
+ hasNextPage: false,
141
+ hasPrevPage: false,
142
+ limit: query.limit,
143
+ nextPage: null,
144
+ page: 1,
145
+ pagingCounter: 0,
146
+ prevPage: null,
147
+ totalDocs: 0,
148
+ totalPages: 0
149
+ };
150
+ const clientCollectionConfig = clientConfig.collections.find(c => c.slug === collectionSlug);
151
+ const columns = getColumns({
152
+ clientConfig,
153
+ collectionConfig: clientCollectionConfig,
154
+ collectionSlug,
155
+ columns: columnPreference,
156
+ i18n,
157
+ permissions
158
+ });
159
+ const select = collectionConfig.admin.enableListViewSelectAPI ? transformColumnsToSelect(columns) : undefined;
160
+ /** Force select image fields for list view thumbnails */
161
+ appendUploadSelectFields({
162
+ collectionConfig,
163
+ select
164
+ });
165
+ // Check for hierarchy parent param
166
+ const isHierarchyCollection = Boolean(collectionConfig.hierarchy);
167
+ let hierarchyParentId = null;
168
+ if (isHierarchyCollection) {
169
+ if (searchParams?.parent === 'null' || searchParams?.parent === undefined) {
170
+ hierarchyParentId = null;
171
+ } else if (typeof searchParams?.parent === 'string') {
172
+ hierarchyParentId = payload.db.defaultIDType === 'number' && isNumber(searchParams.parent) ? Number(searchParams.parent) : searchParams.parent;
173
+ }
174
+ }
175
+ // Hierarchy data for client-side rendering
176
+ let hierarchyData;
177
+ try {
178
+ if (collectionConfig.admin.groupBy && query.groupBy) {
179
+ ({
180
+ columnState,
181
+ data,
182
+ Table
183
+ } = await handleGroupBy({
184
+ clientCollectionConfig,
127
185
  clientConfig,
128
- collectionConfig: clientCollectionConfig,
186
+ collectionConfig,
129
187
  collectionSlug,
130
- columns: columnPreference,
131
- i18n,
132
- permissions
133
- });
134
- const select = collectionConfig.admin.enableListViewSelectAPI ? transformColumnsToSelect(columns) : undefined;
135
- /** Force select image fields for list view thumbnails */ appendUploadSelectFields({
188
+ columns,
189
+ customCellProps,
190
+ drawerSlug,
191
+ enableRowSelections,
192
+ fieldPermissions: permissions?.collections?.[collectionSlug]?.fields,
193
+ query,
194
+ req,
195
+ select,
196
+ trash,
197
+ user,
198
+ viewType,
199
+ where: whereWithMergedSearch
200
+ }));
201
+ // Enrich documents with correct display status for drafts
202
+ data = await enrichDocsWithVersionStatus({
136
203
  collectionConfig,
137
- select
138
- });
139
- try {
140
- if (collectionConfig.admin.groupBy && query.groupBy) {
141
- ;
142
- ({ columnState, data, Table } = await handleGroupBy({
143
- clientCollectionConfig,
144
- clientConfig,
145
- collectionConfig,
146
- collectionSlug,
147
- columns,
148
- customCellProps,
149
- drawerSlug,
150
- enableRowSelections,
151
- fieldPermissions: permissions?.collections?.[collectionSlug]?.fields,
152
- query,
153
- req,
154
- select,
155
- trash,
156
- user,
157
- viewType,
158
- where: whereWithMergedSearch
159
- }));
160
- // Enrich documents with correct display status for drafts
161
- data = await enrichDocsWithVersionStatus({
162
- collectionConfig,
163
- data,
164
- req
165
- });
166
- } else {
167
- data = await req.payload.find({
168
- collection: collectionSlug,
169
- depth: 0,
170
- draft: true,
171
- fallbackLocale: false,
172
- includeLockStatus: true,
173
- limit: query?.limit ? Number(query.limit) : undefined,
174
- locale: req.locale,
175
- overrideAccess: false,
176
- page: query?.page ? Number(query.page) : undefined,
177
- req,
178
- select,
179
- sort: query?.sort,
180
- trash,
181
- user,
182
- where: whereWithMergedSearch
183
- });
184
- // Enrich documents with correct display status for drafts
185
- data = await enrichDocsWithVersionStatus({
186
- collectionConfig,
187
- data,
188
- req
189
- });
190
- ({ columnState, Table } = renderTable({
191
- clientCollectionConfig,
192
- collectionConfig,
193
- columns,
194
- customCellProps,
195
- data,
196
- drawerSlug,
197
- enableRowSelections,
198
- fieldPermissions: permissions?.collections?.[collectionSlug]?.fields,
199
- i18n: req.i18n,
200
- orderableFieldName: collectionConfig.orderable === true ? '_order' : undefined,
201
- payload: req.payload,
202
- query,
203
- req,
204
- useAsTitle: collectionConfig.admin.useAsTitle,
205
- viewType
206
- }));
207
- }
208
- } catch (err) {
209
- if (err.name !== 'QueryError') {
210
- // QueryErrors are expected when a user filters by a field they do not have access to
211
- req.payload.logger.error({
212
- err,
213
- msg: `There was an error fetching the list view data for collection ${collectionSlug}`
214
- });
215
- throw err;
216
- }
217
- }
218
- const renderedFilters = renderFilters(collectionConfig.fields, req.payload.importMap);
219
- const resolvedFilterOptions = await resolveAllFilterOptions({
220
- fields: collectionConfig.fields,
204
+ data,
221
205
  req
222
- });
223
- const staticDescription = typeof collectionConfig.admin.description === 'function' ? collectionConfig.admin.description({
224
- t: i18n.t
225
- }) : collectionConfig.admin.description;
226
- const newDocumentURL = formatAdminURL({
227
- adminRoute,
228
- path: `/collections/${collectionSlug}/create`
229
- });
230
- const hasCreatePermission = permissions?.collections?.[collectionSlug]?.create;
231
- const { hasDeletePermission, hasTrashPermission } = await getDocumentPermissions({
206
+ });
207
+ } else {
208
+ data = await req.payload.find({
209
+ collection: collectionSlug,
210
+ depth: 0,
211
+ draft: true,
212
+ fallbackLocale: false,
213
+ includeLockStatus: true,
214
+ limit: query?.limit ? Number(query.limit) : undefined,
215
+ locale: req.locale,
216
+ overrideAccess: false,
217
+ page: query?.page ? Number(query.page) : undefined,
218
+ req,
219
+ select,
220
+ sort: query?.sort,
221
+ trash,
222
+ user,
223
+ where: whereWithMergedSearch
224
+ });
225
+ // Enrich documents with correct display status for drafts
226
+ data = await enrichDocsWithVersionStatus({
232
227
  collectionConfig,
233
- // Empty object serves as base for computing differentiated trash/delete permissions
234
- data: {},
228
+ data,
235
229
  req
236
- });
237
- // Check if there's a notFound query parameter (document ID that wasn't found)
238
- const notFoundDocId = typeof searchParams?.notFound === 'string' ? searchParams.notFound : null;
239
- const serverProps = {
230
+ });
231
+ ({
232
+ columnState,
233
+ Table
234
+ } = renderTable({
235
+ clientCollectionConfig,
240
236
  collectionConfig,
237
+ columns,
238
+ customCellProps,
241
239
  data,
242
- i18n,
243
- limit: query.limit,
244
- listPreferences: collectionPreferences,
245
- listSearchableFields: collectionConfig.admin.listSearchableFields,
246
- locale: fullLocale,
247
- params,
248
- payload,
249
- permissions,
250
- searchParams,
251
- user
252
- };
253
- const listViewSlots = renderListViewSlots({
254
- clientProps: {
255
- collectionSlug,
256
- hasCreatePermission,
257
- hasDeletePermission,
258
- hasTrashPermission,
259
- newDocumentURL
260
- },
261
- collectionConfig,
262
- description: staticDescription,
263
- notFoundDocId,
264
- payload,
265
- serverProps
240
+ drawerSlug,
241
+ enableRowSelections,
242
+ fieldPermissions: permissions?.collections?.[collectionSlug]?.fields,
243
+ i18n: req.i18n,
244
+ orderableFieldName: collectionConfig.orderable === true ? '_order' : undefined,
245
+ payload: req.payload,
246
+ query,
247
+ req,
248
+ useAsTitle: collectionConfig.admin.useAsTitle,
249
+ viewType
250
+ }));
251
+ }
252
+ } catch (err) {
253
+ if (err.name !== 'QueryError') {
254
+ // QueryErrors are expected when a user filters by a field they do not have access to
255
+ req.payload.logger.error({
256
+ err,
257
+ msg: `There was an error fetching the list view data for collection ${collectionSlug}`
258
+ });
259
+ throw err;
260
+ }
261
+ }
262
+ // Fetch hierarchy data for hierarchy collections
263
+ let HierarchyIcon;
264
+ if (isHierarchyCollection) {
265
+ // Extract typeFilter from searchParams (comma-separated list of collection slugs)
266
+ const typeFilterParam = searchParams?.typeFilter;
267
+ const typeFilter = typeof typeFilterParam === 'string' && typeFilterParam.length > 0 ? typeFilterParam.split(',') : undefined;
268
+ hierarchyData = await handleHierarchy({
269
+ collectionConfig,
270
+ collectionSlug,
271
+ parentId: hierarchyParentId,
272
+ permissions,
273
+ req,
274
+ search: typeof query?.search === 'string' ? query.search : undefined,
275
+ typeFilter,
276
+ user
266
277
  });
267
- const isInDrawer = Boolean(drawerSlug);
268
- // Needed to prevent: Only plain objects can be passed to Client Components from Server Components. Objects with toJSON methods are not supported. Convert it manually to a simple value before passing it to props.
269
- // Is there a way to avoid this? The `where` object is already seemingly plain, but is not bc it originates from the params.
270
- query.where = query?.where ? JSON.parse(JSON.stringify(query?.where || {})) : undefined;
271
- return {
272
- List: /*#__PURE__*/ _jsxDEV(Fragment, {
273
- children: [
274
- /*#__PURE__*/ _jsxDEV(HydrateAuthProvider, {
275
- permissions: permissions
276
- }, void 0, false, {
277
- fileName: "src/views/List/index.tsx",
278
- lineNumber: 407,
279
- columnNumber: 9
280
- }, this),
281
- /*#__PURE__*/ _jsxDEV(ListQueryProvider, {
282
- collectionSlug: collectionSlug,
283
- data: data,
284
- modifySearchParams: !isInDrawer,
285
- orderableFieldName: collectionConfig.orderable === true ? '_order' : undefined,
286
- query: query,
287
- children: RenderServerComponent({
288
- clientProps: {
289
- ...listViewSlots,
290
- collectionSlug,
291
- columnState,
292
- disableBulkDelete,
293
- disableBulkEdit: collectionConfig.disableBulkEdit ?? disableBulkEdit,
294
- disableQueryPresets,
295
- enableRowSelections,
296
- hasCreatePermission,
297
- hasDeletePermission,
298
- hasTrashPermission,
299
- listPreferences: collectionPreferences,
300
- newDocumentURL,
301
- queryPreset,
302
- queryPresetPermissions,
303
- renderedFilters,
304
- resolvedFilterOptions,
305
- Table,
306
- viewType
307
- },
308
- Component: ComponentOverride ?? collectionConfig?.admin?.components?.views?.list?.Component,
309
- Fallback: DefaultListView,
310
- importMap: payload.importMap,
311
- serverProps
312
- })
313
- }, void 0, false, {
314
- fileName: "src/views/List/index.tsx",
315
- lineNumber: 408,
316
- columnNumber: 9
317
- }, this)
318
- ]
319
- }, void 0, true, {
320
- fileName: "src/views/List/index.tsx",
321
- lineNumber: 406,
322
- columnNumber: 7
323
- }, this)
324
- };
278
+ data = hierarchyData.childrenData;
279
+ // Resolve hierarchy icon from collection config
280
+ const hierarchyConfig = typeof collectionConfig.hierarchy === 'object' ? collectionConfig.hierarchy : undefined;
281
+ HierarchyIcon = RenderServerComponent({
282
+ Component: hierarchyConfig?.admin?.components?.Icon,
283
+ importMap: payload.importMap,
284
+ key: `hierarchy-icon-${collectionSlug}`
285
+ });
286
+ }
287
+ const renderedFilters = renderFilters(collectionConfig.fields, req.payload.importMap);
288
+ const resolvedFilterOptions = await resolveAllFilterOptions({
289
+ fields: collectionConfig.fields,
290
+ req
291
+ });
292
+ const staticDescription = typeof collectionConfig.admin.description === 'function' ? collectionConfig.admin.description({
293
+ t: i18n.t
294
+ }) : collectionConfig.admin.description;
295
+ const newDocumentURL = formatAdminURL({
296
+ adminRoute,
297
+ path: `/collections/${collectionSlug}/create`
298
+ });
299
+ const hasCreatePermission = permissions?.collections?.[collectionSlug]?.create;
300
+ const {
301
+ hasDeletePermission,
302
+ hasTrashPermission
303
+ } = await getDocumentPermissions({
304
+ collectionConfig,
305
+ // Empty object serves as base for computing differentiated trash/delete permissions
306
+ data: {},
307
+ req
308
+ });
309
+ // Check if there's a notFound query parameter (document ID that wasn't found)
310
+ const notFoundDocId = typeof searchParams?.notFound === 'string' ? searchParams.notFound : null;
311
+ const serverProps = {
312
+ collectionConfig,
313
+ data,
314
+ i18n,
315
+ limit: query.limit,
316
+ listPreferences: collectionPreferences,
317
+ listSearchableFields: collectionConfig.admin.listSearchableFields,
318
+ locale: fullLocale,
319
+ params,
320
+ payload,
321
+ permissions,
322
+ searchParams,
323
+ user
324
+ };
325
+ const listViewSlots = renderListViewSlots({
326
+ clientProps: {
327
+ collectionSlug,
328
+ hasCreatePermission,
329
+ hasDeletePermission,
330
+ hasTrashPermission,
331
+ newDocumentURL
332
+ },
333
+ collectionConfig,
334
+ description: staticDescription,
335
+ notFoundDocId,
336
+ payload,
337
+ serverProps
338
+ });
339
+ const isInDrawer = Boolean(drawerSlug);
340
+ // Needed to prevent: Only plain objects can be passed to Client Components from Server Components. Objects with toJSON methods are not supported. Convert it manually to a simple value before passing it to props.
341
+ // Is there a way to avoid this? The `where` object is already seemingly plain, but is not bc it originates from the params.
342
+ query.where = query?.where ? JSON.parse(JSON.stringify(query?.where || {})) : undefined;
343
+ const RenderedListViewComponent = RenderServerComponent({
344
+ clientProps: {
345
+ ...listViewSlots,
346
+ collectionSlug,
347
+ columnState,
348
+ disableBulkDelete,
349
+ disableBulkEdit: collectionConfig.disableBulkEdit ?? disableBulkEdit,
350
+ disableQueryPresets,
351
+ enableRowSelections,
352
+ hasCreatePermission,
353
+ hasDeletePermission,
354
+ hasTrashPermission,
355
+ hierarchyData,
356
+ HierarchyIcon,
357
+ listPreferences: collectionPreferences,
358
+ newDocumentURL,
359
+ queryPreset,
360
+ queryPresetPermissions,
361
+ renderedFilters,
362
+ resolvedFilterOptions,
363
+ Table,
364
+ viewType
365
+ },
366
+ Component: ComponentOverride ?? collectionConfig?.admin?.components?.views?.list?.Component,
367
+ Fallback: isHierarchyCollection ? HierarchyListView : DefaultListView,
368
+ importMap: payload.importMap,
369
+ serverProps
370
+ });
371
+ return {
372
+ List: /*#__PURE__*/_jsxs(Fragment, {
373
+ children: [/*#__PURE__*/_jsx(HydrateAuthProvider, {
374
+ permissions: permissions
375
+ }), isHierarchyCollection ? /*#__PURE__*/_jsxs(Fragment, {
376
+ children: [/*#__PURE__*/_jsx(HydrateHierarchyProvider, {
377
+ allowedCollections: hierarchyData?.allowedCollections,
378
+ collectionSlug: collectionSlug,
379
+ expandedNodes: hierarchyData?.breadcrumbs?.slice(0, -1).map(b => b.id),
380
+ parent: hierarchyData?.parent,
381
+ parentFieldName: typeof collectionConfig.hierarchy === 'object' ? collectionConfig.hierarchy?.parentFieldName : undefined,
382
+ tableData: data,
383
+ treeLimit: typeof collectionConfig.hierarchy === 'object' ? collectionConfig.hierarchy?.admin?.treeLimit : undefined,
384
+ typeFieldName: typeof collectionConfig.hierarchy === 'object' && collectionConfig.hierarchy?.collectionSpecific && typeof collectionConfig.hierarchy.collectionSpecific === 'object' ? collectionConfig.hierarchy.collectionSpecific.fieldName : undefined,
385
+ viewCollectionSlug: collectionSlug
386
+ }), RenderedListViewComponent]
387
+ }) : /*#__PURE__*/_jsx(ListQueryProvider, {
388
+ collectionSlug: collectionSlug,
389
+ data: data,
390
+ modifySearchParams: !isInDrawer,
391
+ orderableFieldName: collectionConfig.orderable === true ? '_order' : undefined,
392
+ query: query,
393
+ children: RenderedListViewComponent
394
+ })]
395
+ })
396
+ };
325
397
  };
326
- export const ListView = async (args)=>{
327
- try {
328
- const { List: RenderedList } = await renderListView({
329
- ...args,
330
- enableRowSelections: true
331
- });
332
- return RenderedList;
333
- } catch (error) {
334
- // Pass through Next.js errors
335
- if (error.message === 'not-found') {
336
- notFound();
337
- } else {
338
- console.error(error);
339
- }
398
+ export const ListView = async args => {
399
+ try {
400
+ const {
401
+ List: RenderedList
402
+ } = await renderListView({
403
+ ...args,
404
+ enableRowSelections: true
405
+ });
406
+ return RenderedList;
407
+ } catch (error) {
408
+ // Pass through Next.js errors
409
+ if (error.message === 'not-found') {
410
+ notFound();
411
+ } else {
412
+ console.error(error); // eslint-disable-line no-console
340
413
  }
341
- } // eslint-disable-line no-console
342
- ;
343
-
414
+ }
415
+ };
344
416
  //# sourceMappingURL=index.js.map