@payloadcms/next 3.71.0-internal-debug.80dab4c → 3.71.0-internal.27e1e08

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 (448) 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 +23 -61
  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/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 +127 -148
  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.js +103 -128
  64. package/dist/layouts/Root/index.js.map +1 -1
  65. package/dist/prod/styles.css +1 -5
  66. package/dist/routes/graphql/handler.js +122 -114
  67. package/dist/routes/graphql/handler.js.map +1 -1
  68. package/dist/routes/graphql/index.js +0 -1
  69. package/dist/routes/graphql/index.js.map +1 -1
  70. package/dist/routes/graphql/playground.js +27 -28
  71. package/dist/routes/graphql/playground.js.map +1 -1
  72. package/dist/routes/index.js +0 -1
  73. package/dist/routes/index.js.map +1 -1
  74. package/dist/routes/rest/index.js +22 -23
  75. package/dist/routes/rest/index.js.map +1 -1
  76. package/dist/routes/rest/og/image.js +79 -103
  77. package/dist/routes/rest/og/image.js.map +1 -1
  78. package/dist/routes/rest/og/index.js +54 -59
  79. package/dist/routes/rest/og/index.js.map +1 -1
  80. package/dist/templates/Default/NavHamburger/index.js +20 -12
  81. package/dist/templates/Default/NavHamburger/index.js.map +1 -1
  82. package/dist/templates/Default/Wrapper/index.js +44 -20
  83. package/dist/templates/Default/Wrapper/index.js.map +1 -1
  84. package/dist/templates/Default/index.js +116 -147
  85. package/dist/templates/Default/index.js.map +1 -1
  86. package/dist/templates/Minimal/index.js +17 -26
  87. package/dist/templates/Minimal/index.js.map +1 -1
  88. package/dist/utilities/getExistingAuthToken.js +2 -3
  89. package/dist/utilities/getExistingAuthToken.js.map +1 -1
  90. package/dist/utilities/getNextRequestI18n.js +13 -12
  91. package/dist/utilities/getNextRequestI18n.js.map +1 -1
  92. package/dist/utilities/getPayloadHMR.js +5 -5
  93. package/dist/utilities/getPayloadHMR.js.map +1 -1
  94. package/dist/utilities/getPreferences.js +22 -27
  95. package/dist/utilities/getPreferences.js.map +1 -1
  96. package/dist/utilities/getRequestLocale.js +14 -13
  97. package/dist/utilities/getRequestLocale.js.map +1 -1
  98. package/dist/utilities/getRequestTheme.js +19 -19
  99. package/dist/utilities/getRequestTheme.js.map +1 -1
  100. package/dist/utilities/getRouteWithoutAdmin.js +5 -3
  101. package/dist/utilities/getRouteWithoutAdmin.js.map +1 -1
  102. package/dist/utilities/handleAuthRedirect.js +36 -22
  103. package/dist/utilities/handleAuthRedirect.js.map +1 -1
  104. package/dist/utilities/handleServerFunctions.js +41 -34
  105. package/dist/utilities/handleServerFunctions.js.map +1 -1
  106. package/dist/utilities/initReq.js +96 -78
  107. package/dist/utilities/initReq.js.map +1 -1
  108. package/dist/utilities/isCustomAdminView.js +26 -22
  109. package/dist/utilities/isCustomAdminView.js.map +1 -1
  110. package/dist/utilities/isPublicAdminRoute.js +20 -26
  111. package/dist/utilities/isPublicAdminRoute.js.map +1 -1
  112. package/dist/utilities/meta.js +63 -68
  113. package/dist/utilities/meta.js.map +1 -1
  114. package/dist/utilities/selectiveCache.js +26 -25
  115. package/dist/utilities/selectiveCache.js.map +1 -1
  116. package/dist/utilities/setPayloadAuthCookie.js +22 -19
  117. package/dist/utilities/setPayloadAuthCookie.js.map +1 -1
  118. package/dist/utilities/slugify.js +33 -24
  119. package/dist/utilities/slugify.js.map +1 -1
  120. package/dist/utilities/timestamp.js +6 -7
  121. package/dist/utilities/timestamp.js.map +1 -1
  122. package/dist/views/API/LocaleSelector/index.js +39 -17
  123. package/dist/views/API/LocaleSelector/index.js.map +1 -1
  124. package/dist/views/API/RenderJSON/index.js +126 -171
  125. package/dist/views/API/RenderJSON/index.js.map +1 -1
  126. package/dist/views/API/index.client.js +197 -290
  127. package/dist/views/API/index.client.js.map +1 -1
  128. package/dist/views/API/index.js +2 -7
  129. package/dist/views/API/index.js.map +1 -1
  130. package/dist/views/API/metadata.js +23 -18
  131. package/dist/views/API/metadata.js.map +1 -1
  132. package/dist/views/Account/ResetPreferences/index.js +102 -78
  133. package/dist/views/Account/ResetPreferences/index.js.map +1 -1
  134. package/dist/views/Account/Settings/LanguageSelector.js +47 -18
  135. package/dist/views/Account/Settings/LanguageSelector.js.map +1 -1
  136. package/dist/views/Account/Settings/index.js +25 -60
  137. package/dist/views/Account/Settings/index.js.map +1 -1
  138. package/dist/views/Account/ToggleTheme/index.js +55 -38
  139. package/dist/views/Account/ToggleTheme/index.js.map +1 -1
  140. package/dist/views/Account/index.client.js +32 -16
  141. package/dist/views/Account/index.client.js.map +1 -1
  142. package/dist/views/Account/index.js +158 -147
  143. package/dist/views/Account/index.js.map +1 -1
  144. package/dist/views/Account/metadata.js +12 -8
  145. package/dist/views/Account/metadata.js.map +1 -1
  146. package/dist/views/BrowseByFolder/buildView.js +157 -138
  147. package/dist/views/BrowseByFolder/buildView.js.map +1 -1
  148. package/dist/views/BrowseByFolder/index.js +16 -16
  149. package/dist/views/BrowseByFolder/index.js.map +1 -1
  150. package/dist/views/BrowseByFolder/metadata.js +15 -13
  151. package/dist/views/BrowseByFolder/metadata.js.map +1 -1
  152. package/dist/views/CollectionFolders/buildView.js +142 -122
  153. package/dist/views/CollectionFolders/buildView.js.map +1 -1
  154. package/dist/views/CollectionFolders/index.js +16 -16
  155. package/dist/views/CollectionFolders/index.js.map +1 -1
  156. package/dist/views/CollectionFolders/metadata.js +21 -18
  157. package/dist/views/CollectionFolders/metadata.js.map +1 -1
  158. package/dist/views/CollectionFolders/renderFolderViewSlots.js +61 -58
  159. package/dist/views/CollectionFolders/renderFolderViewSlots.js.map +1 -1
  160. package/dist/views/CollectionTrash/index.js +17 -17
  161. package/dist/views/CollectionTrash/index.js.map +1 -1
  162. package/dist/views/CollectionTrash/metadata.js +21 -18
  163. package/dist/views/CollectionTrash/metadata.js.map +1 -1
  164. package/dist/views/CreateFirstUser/index.client.js +103 -117
  165. package/dist/views/CreateFirstUser/index.client.js.map +1 -1
  166. package/dist/views/CreateFirstUser/index.js +81 -87
  167. package/dist/views/CreateFirstUser/index.js.map +1 -1
  168. package/dist/views/CreateFirstUser/metadata.js +12 -8
  169. package/dist/views/CreateFirstUser/metadata.js.map +1 -1
  170. package/dist/views/Dashboard/Default/ModularDashboard/DashboardStepNav.js +138 -147
  171. package/dist/views/Dashboard/Default/ModularDashboard/DashboardStepNav.js.map +1 -1
  172. package/dist/views/Dashboard/Default/ModularDashboard/index.client.js +405 -423
  173. package/dist/views/Dashboard/Default/ModularDashboard/index.client.js.map +1 -1
  174. package/dist/views/Dashboard/Default/ModularDashboard/index.js +75 -72
  175. package/dist/views/Dashboard/Default/ModularDashboard/index.js.map +1 -1
  176. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/RenderWidget.js +89 -62
  177. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/RenderWidget.js.map +1 -1
  178. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/getDefaultLayoutServerFn.js +47 -40
  179. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/getDefaultLayoutServerFn.js.map +1 -1
  180. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/renderWidgetServerFn.js +65 -64
  181. package/dist/views/Dashboard/Default/ModularDashboard/renderWidget/renderWidgetServerFn.js.map +1 -1
  182. package/dist/views/Dashboard/Default/ModularDashboard/useDashboardLayout.js +147 -164
  183. package/dist/views/Dashboard/Default/ModularDashboard/useDashboardLayout.js.map +1 -1
  184. package/dist/views/Dashboard/Default/ModularDashboard/utils/collisionDetection.js +30 -31
  185. package/dist/views/Dashboard/Default/ModularDashboard/utils/collisionDetection.js.map +1 -1
  186. package/dist/views/Dashboard/Default/ModularDashboard/utils/sensors.js +229 -223
  187. package/dist/views/Dashboard/Default/ModularDashboard/utils/sensors.js.map +1 -1
  188. package/dist/views/Dashboard/Default/index.js +45 -59
  189. package/dist/views/Dashboard/Default/index.js.map +1 -1
  190. package/dist/views/Dashboard/index.js +42 -46
  191. package/dist/views/Dashboard/index.js.map +1 -1
  192. package/dist/views/Dashboard/metadata.js +14 -10
  193. package/dist/views/Dashboard/metadata.js.map +1 -1
  194. package/dist/views/Document/getCustomDocumentViewByKey.js +2 -3
  195. package/dist/views/Document/getCustomDocumentViewByKey.js.map +1 -1
  196. package/dist/views/Document/getCustomViewByRoute.js +30 -27
  197. package/dist/views/Document/getCustomViewByRoute.js.map +1 -1
  198. package/dist/views/Document/getDocPreferences.js +41 -40
  199. package/dist/views/Document/getDocPreferences.js.map +1 -1
  200. package/dist/views/Document/getDocumentData.js +55 -44
  201. package/dist/views/Document/getDocumentData.js.map +1 -1
  202. package/dist/views/Document/getDocumentPermissions.js +80 -77
  203. package/dist/views/Document/getDocumentPermissions.js.map +1 -1
  204. package/dist/views/Document/getDocumentView.js +283 -313
  205. package/dist/views/Document/getDocumentView.js.map +1 -1
  206. package/dist/views/Document/getIsLocked.js +66 -66
  207. package/dist/views/Document/getIsLocked.js.map +1 -1
  208. package/dist/views/Document/getMetaBySegment.js +136 -130
  209. package/dist/views/Document/getMetaBySegment.js.map +1 -1
  210. package/dist/views/Document/getVersions.js +195 -205
  211. package/dist/views/Document/getVersions.js.map +1 -1
  212. package/dist/views/Document/handleServerFunction.js +128 -103
  213. package/dist/views/Document/handleServerFunction.js.map +1 -1
  214. package/dist/views/Document/index.js +355 -316
  215. package/dist/views/Document/index.js.map +1 -1
  216. package/dist/views/Document/metadata.js +1 -2
  217. package/dist/views/Document/metadata.js.map +1 -1
  218. package/dist/views/Document/renderDocumentSlots.js +132 -121
  219. package/dist/views/Document/renderDocumentSlots.js.map +1 -1
  220. package/dist/views/Edit/index.js +6 -10
  221. package/dist/views/Edit/index.js.map +1 -1
  222. package/dist/views/Edit/metadata.js +46 -36
  223. package/dist/views/Edit/metadata.js.map +1 -1
  224. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js +164 -130
  225. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js.map +1 -1
  226. package/dist/views/ForgotPassword/index.js +62 -79
  227. package/dist/views/ForgotPassword/index.js.map +1 -1
  228. package/dist/views/ForgotPassword/metadata.js +12 -8
  229. package/dist/views/ForgotPassword/metadata.js.map +1 -1
  230. package/dist/views/List/createSerializableValue.js +11 -12
  231. package/dist/views/List/createSerializableValue.js.map +1 -1
  232. package/dist/views/List/enrichDocsWithVersionStatus.js +86 -86
  233. package/dist/views/List/enrichDocsWithVersionStatus.js.map +1 -1
  234. package/dist/views/List/extractRelationshipDisplayValue.js +14 -15
  235. package/dist/views/List/extractRelationshipDisplayValue.js.map +1 -1
  236. package/dist/views/List/extractValueOrRelationshipID.js +15 -16
  237. package/dist/views/List/extractValueOrRelationshipID.js.map +1 -1
  238. package/dist/views/List/handleGroupBy.js +150 -133
  239. package/dist/views/List/handleGroupBy.js.map +1 -1
  240. package/dist/views/List/handleServerFunction.js +121 -98
  241. package/dist/views/List/handleServerFunction.js.map +1 -1
  242. package/dist/views/List/index.js +323 -305
  243. package/dist/views/List/index.js.map +1 -1
  244. package/dist/views/List/metadata.js +20 -17
  245. package/dist/views/List/metadata.js.map +1 -1
  246. package/dist/views/List/renderListViewSlots.js +75 -82
  247. package/dist/views/List/renderListViewSlots.js.map +1 -1
  248. package/dist/views/List/resolveAllFilterOptions.js +45 -43
  249. package/dist/views/List/resolveAllFilterOptions.js.map +1 -1
  250. package/dist/views/List/transformColumnsToSelect.js +8 -9
  251. package/dist/views/List/transformColumnsToSelect.js.map +1 -1
  252. package/dist/views/Login/LoginField/index.js +89 -57
  253. package/dist/views/Login/LoginField/index.js.map +1 -1
  254. package/dist/views/Login/LoginForm/index.js +160 -107
  255. package/dist/views/Login/LoginForm/index.js.map +1 -1
  256. package/dist/views/Login/index.js +85 -82
  257. package/dist/views/Login/index.js.map +1 -1
  258. package/dist/views/Login/metadata.js +12 -8
  259. package/dist/views/Login/metadata.js.map +1 -1
  260. package/dist/views/Logout/LogoutClient.js +120 -84
  261. package/dist/views/Logout/LogoutClient.js.map +1 -1
  262. package/dist/views/Logout/index.js +29 -29
  263. package/dist/views/Logout/index.js.map +1 -1
  264. package/dist/views/Logout/metadata.js +11 -7
  265. package/dist/views/Logout/metadata.js.map +1 -1
  266. package/dist/views/NotFound/index.client.js +82 -71
  267. package/dist/views/NotFound/index.client.js.map +1 -1
  268. package/dist/views/NotFound/index.js +73 -72
  269. package/dist/views/NotFound/index.js.map +1 -1
  270. package/dist/views/NotFound/metadata.js +9 -7
  271. package/dist/views/NotFound/metadata.js.map +1 -1
  272. package/dist/views/ResetPassword/ResetPasswordForm/index.js +108 -97
  273. package/dist/views/ResetPassword/ResetPasswordForm/index.js.map +1 -1
  274. package/dist/views/ResetPassword/index.js +73 -93
  275. package/dist/views/ResetPassword/index.js.map +1 -1
  276. package/dist/views/ResetPassword/metadata.js +12 -8
  277. package/dist/views/ResetPassword/metadata.js.map +1 -1
  278. package/dist/views/Root/attachViewActions.js +23 -18
  279. package/dist/views/Root/attachViewActions.js.map +1 -1
  280. package/dist/views/Root/generateCustomViewMetadata.js +21 -19
  281. package/dist/views/Root/generateCustomViewMetadata.js.map +1 -1
  282. package/dist/views/Root/getCustomViewByKey.js +14 -12
  283. package/dist/views/Root/getCustomViewByKey.js.map +1 -1
  284. package/dist/views/Root/getCustomViewByRoute.js +42 -31
  285. package/dist/views/Root/getCustomViewByRoute.js.map +1 -1
  286. package/dist/views/Root/getDocumentViewInfo.js +23 -24
  287. package/dist/views/Root/getDocumentViewInfo.js.map +1 -1
  288. package/dist/views/Root/getRouteData.js +325 -333
  289. package/dist/views/Root/getRouteData.js.map +1 -1
  290. package/dist/views/Root/index.js +270 -248
  291. package/dist/views/Root/index.js.map +1 -1
  292. package/dist/views/Root/isPathMatchingRoute.js +26 -21
  293. package/dist/views/Root/isPathMatchingRoute.js.map +1 -1
  294. package/dist/views/Root/metadata.js +181 -176
  295. package/dist/views/Root/metadata.js.map +1 -1
  296. package/dist/views/Unauthorized/index.js +46 -54
  297. package/dist/views/Unauthorized/index.js.map +1 -1
  298. package/dist/views/Unauthorized/metadata.js +12 -8
  299. package/dist/views/Unauthorized/metadata.js.map +1 -1
  300. package/dist/views/Verify/index.client.js +43 -25
  301. package/dist/views/Verify/index.client.js.map +1 -1
  302. package/dist/views/Verify/index.js +64 -69
  303. package/dist/views/Verify/index.js.map +1 -1
  304. package/dist/views/Verify/metadata.js +12 -8
  305. package/dist/views/Verify/metadata.js.map +1 -1
  306. package/dist/views/Version/Default/SelectedLocalesContext.js +4 -4
  307. package/dist/views/Version/Default/SelectedLocalesContext.js.map +1 -1
  308. package/dist/views/Version/Default/SetStepNav.js +127 -86
  309. package/dist/views/Version/Default/SetStepNav.js.map +1 -1
  310. package/dist/views/Version/Default/index.js +236 -380
  311. package/dist/views/Version/Default/index.js.map +1 -1
  312. package/dist/views/Version/Default/types.js +1 -2
  313. package/dist/views/Version/Default/types.js.map +1 -1
  314. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js +119 -102
  315. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js.map +1 -1
  316. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js +73 -78
  317. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js.map +1 -1
  318. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js +408 -363
  319. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js.map +1 -1
  320. package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js +51 -40
  321. package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js.map +1 -1
  322. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.js +67 -35
  323. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.js.map +1 -1
  324. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js +56 -59
  325. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js.map +1 -1
  326. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js +117 -139
  327. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js.map +1 -1
  328. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.js +41 -36
  329. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.js.map +1 -1
  330. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js +178 -192
  331. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js.map +1 -1
  332. package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.js +11 -17
  333. package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.js.map +1 -1
  334. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js +73 -48
  335. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js.map +1 -1
  336. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js +143 -132
  337. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js.map +1 -1
  338. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js +81 -56
  339. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js.map +1 -1
  340. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.js +211 -252
  341. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.js.map +1 -1
  342. package/dist/views/Version/RenderFieldsToDiff/fields/index.js +22 -23
  343. package/dist/views/Version/RenderFieldsToDiff/fields/index.js.map +1 -1
  344. package/dist/views/Version/RenderFieldsToDiff/index.js +9 -12
  345. package/dist/views/Version/RenderFieldsToDiff/index.js.map +1 -1
  346. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.js +228 -213
  347. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.js.map +1 -1
  348. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.spec.js +826 -1005
  349. package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.spec.js.map +1 -1
  350. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.js +1 -2
  351. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.js.map +1 -1
  352. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.spec.js +43 -44
  353. package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.spec.js.map +1 -1
  354. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldPathsModified.js +22 -25
  355. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldPathsModified.js.map +1 -1
  356. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.js +36 -32
  357. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.js.map +1 -1
  358. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.spec.js +129 -145
  359. package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.spec.js.map +1 -1
  360. package/dist/views/Version/Restore/index.js +93 -117
  361. package/dist/views/Version/Restore/index.js.map +1 -1
  362. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.js +50 -33
  363. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.js.map +1 -1
  364. package/dist/views/Version/SelectComparison/VersionDrawer/index.js +226 -170
  365. package/dist/views/Version/SelectComparison/VersionDrawer/index.js.map +1 -1
  366. package/dist/views/Version/SelectComparison/index.js +50 -73
  367. package/dist/views/Version/SelectComparison/index.js.map +1 -1
  368. package/dist/views/Version/SelectComparison/types.js +1 -2
  369. package/dist/views/Version/SelectComparison/types.js.map +1 -1
  370. package/dist/views/Version/SelectLocales/index.js +32 -34
  371. package/dist/views/Version/SelectLocales/index.js.map +1 -1
  372. package/dist/views/Version/VersionPillLabel/VersionPillLabel.js +95 -104
  373. package/dist/views/Version/VersionPillLabel/VersionPillLabel.js.map +1 -1
  374. package/dist/views/Version/VersionPillLabel/getVersionLabel.js +27 -23
  375. package/dist/views/Version/VersionPillLabel/getVersionLabel.js.map +1 -1
  376. package/dist/views/Version/fetchVersions.js +138 -113
  377. package/dist/views/Version/fetchVersions.js.map +1 -1
  378. package/dist/views/Version/index.js +323 -325
  379. package/dist/views/Version/index.js.map +1 -1
  380. package/dist/views/Version/metadata.js +50 -43
  381. package/dist/views/Version/metadata.js.map +1 -1
  382. package/dist/views/Versions/buildColumns.js +79 -95
  383. package/dist/views/Versions/buildColumns.js.map +1 -1
  384. package/dist/views/Versions/cells/AutosaveCell/index.js +38 -34
  385. package/dist/views/Versions/cells/AutosaveCell/index.js.map +1 -1
  386. package/dist/views/Versions/cells/CreatedAt/index.js +53 -32
  387. package/dist/views/Versions/cells/CreatedAt/index.js.map +1 -1
  388. package/dist/views/Versions/cells/ID/index.js +8 -10
  389. package/dist/views/Versions/cells/ID/index.js.map +1 -1
  390. package/dist/views/Versions/index.client.js +83 -106
  391. package/dist/views/Versions/index.client.js.map +1 -1
  392. package/dist/views/Versions/index.js +143 -143
  393. package/dist/views/Versions/index.js.map +1 -1
  394. package/dist/views/Versions/metadata.js +44 -37
  395. package/dist/views/Versions/metadata.js.map +1 -1
  396. package/dist/views/Versions/types.js +1 -2
  397. package/dist/views/Versions/types.js.map +1 -1
  398. package/dist/withPayload/withPayload.js +143 -198
  399. package/dist/withPayload/withPayload.js.map +1 -1
  400. package/dist/withPayload/withPayload.utils.js +95 -92
  401. package/dist/withPayload/withPayload.utils.js.map +1 -1
  402. package/dist/withPayload/withPayloadLegacy.js +40 -42
  403. package/dist/withPayload/withPayloadLegacy.js.map +1 -1
  404. package/package.json +7 -7
  405. package/dist/elements/DocumentHeader/Tabs/Tab/index.scss +0 -38
  406. package/dist/elements/DocumentHeader/Tabs/index.scss +0 -54
  407. package/dist/elements/DocumentHeader/Tabs/tabs/VersionsPill/index.scss +0 -9
  408. package/dist/elements/DocumentHeader/index.scss +0 -64
  409. package/dist/elements/FormHeader/index.scss +0 -8
  410. package/dist/elements/Nav/NavWrapper/index.scss +0 -27
  411. package/dist/elements/Nav/SettingsMenuButton/index.scss +0 -11
  412. package/dist/elements/Nav/index.scss +0 -173
  413. package/dist/esbuildEntry.d.ts +0 -5
  414. package/dist/esbuildEntry.d.ts.map +0 -1
  415. package/dist/esbuildEntry.js +0 -6
  416. package/dist/esbuildEntry.js.map +0 -1
  417. package/dist/templates/Default/Wrapper/index.scss +0 -58
  418. package/dist/templates/Default/index.scss +0 -79
  419. package/dist/templates/Minimal/index.scss +0 -30
  420. package/dist/views/API/RenderJSON/index.scss +0 -129
  421. package/dist/views/API/index.scss +0 -119
  422. package/dist/views/Account/Settings/index.scss +0 -48
  423. package/dist/views/CreateFirstUser/index.scss +0 -21
  424. package/dist/views/Dashboard/Default/ModularDashboard/index.scss +0 -316
  425. package/dist/views/Login/LoginForm/index.scss +0 -10
  426. package/dist/views/Login/index.scss +0 -10
  427. package/dist/views/Logout/index.scss +0 -25
  428. package/dist/views/NotFound/index.scss +0 -57
  429. package/dist/views/ResetPassword/index.scss +0 -11
  430. package/dist/views/Unauthorized/index.scss +0 -14
  431. package/dist/views/Verify/index.scss +0 -16
  432. package/dist/views/Version/Default/index.scss +0 -170
  433. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.scss +0 -81
  434. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.scss +0 -12
  435. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.scss +0 -9
  436. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.scss +0 -59
  437. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.scss +0 -91
  438. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.scss +0 -4
  439. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.scss +0 -9
  440. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.scss +0 -4
  441. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.scss +0 -121
  442. package/dist/views/Version/RenderFieldsToDiff/index.scss +0 -24
  443. package/dist/views/Version/Restore/index.scss +0 -84
  444. package/dist/views/Version/SelectComparison/VersionDrawer/index.scss +0 -18
  445. package/dist/views/Version/SelectComparison/index.scss +0 -9
  446. package/dist/views/Version/VersionPillLabel/index.scss +0 -26
  447. package/dist/views/Versions/cells/AutosaveCell/index.scss +0 -9
  448. package/dist/views/Versions/index.scss +0 -110
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../src/views/Dashboard/Default/ModularDashboard/renderWidget/getDefaultLayoutServerFn.ts"],"sourcesContent":["import type {\n DashboardConfig,\n PayloadRequest,\n ServerFunction,\n Widget,\n WidgetServerProps,\n} from 'payload'\n\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\n\nimport type { WidgetInstanceClient, WidgetItem } from '../index.client.js'\n\nexport type GetDefaultLayoutServerFnArgs = Record<string, never>\n\nexport type GetDefaultLayoutServerFnReturnType = {\n layout: WidgetInstanceClient[]\n}\n\n/**\n * Server function to get the default dashboard layout on-demand.\n * Used when resetting the dashboard to its default configuration.\n */\nexport const getDefaultLayoutHandler: ServerFunction<\n GetDefaultLayoutServerFnArgs,\n Promise<GetDefaultLayoutServerFnReturnType>\n> = async ({ req }) => {\n if (!req.user) {\n throw new Error('Unauthorized')\n }\n\n const { defaultLayout = [], widgets = [] } = req.payload.config.admin.dashboard || {}\n const { importMap } = req.payload\n\n const layoutItems = await getItemsFromConfig(defaultLayout, req, widgets)\n\n const layout: WidgetInstanceClient[] = layoutItems.map((layoutItem) => {\n const widgetSlug = layoutItem.id.slice(0, layoutItem.id.lastIndexOf('-'))\n return {\n component: RenderServerComponent({\n Component: widgets.find((widget) => widget.slug === widgetSlug)?.ComponentPath,\n importMap,\n serverProps: {\n req,\n widgetSlug,\n } satisfies WidgetServerProps,\n }),\n item: layoutItem,\n }\n })\n\n return { layout }\n}\n\nasync function getItemsFromConfig(\n defaultLayout: NonNullable<DashboardConfig['defaultLayout']>,\n req: PayloadRequest,\n widgets: Widget[],\n): Promise<WidgetItem[]> {\n // Handle function format\n let widgetInstances\n if (typeof defaultLayout === 'function') {\n widgetInstances = await defaultLayout({ req })\n } else {\n widgetInstances = defaultLayout\n }\n\n return widgetInstances.map((widgetInstance, index) => {\n const widget = widgets.find((w) => w.slug === widgetInstance.widgetSlug)\n return {\n id: `${widgetInstance.widgetSlug}-${index}`,\n maxWidth: widget?.maxWidth ?? 'full',\n minWidth: widget?.minWidth ?? 'x-small',\n width: widgetInstance.width || 'x-small',\n }\n })\n}\n"],"names":["RenderServerComponent","getDefaultLayoutHandler","req","user","Error","defaultLayout","widgets","payload","config","admin","dashboard","importMap","layoutItems","getItemsFromConfig","layout","map","layoutItem","widgetSlug","id","slice","lastIndexOf","component","Component","find","widget","slug","ComponentPath","serverProps","item","widgetInstances","widgetInstance","index","w","maxWidth","minWidth","width"],"mappings":"AAQA,SAASA,qBAAqB,QAAQ,gDAA+C;AAUrF;;;CAGC,GACD,OAAO,MAAMC,0BAGT,OAAO,EAAEC,GAAG,EAAE;IAChB,IAAI,CAACA,IAAIC,IAAI,EAAE;QACb,MAAM,IAAIC,MAAM;IAClB;IAEA,MAAM,EAAEC,gBAAgB,EAAE,EAAEC,UAAU,EAAE,EAAE,GAAGJ,IAAIK,OAAO,CAACC,MAAM,CAACC,KAAK,CAACC,SAAS,IAAI,CAAC;IACpF,MAAM,EAAEC,SAAS,EAAE,GAAGT,IAAIK,OAAO;IAEjC,MAAMK,cAAc,MAAMC,mBAAmBR,eAAeH,KAAKI;IAEjE,MAAMQ,SAAiCF,YAAYG,GAAG,CAAC,CAACC;QACtD,MAAMC,aAAaD,WAAWE,EAAE,CAACC,KAAK,CAAC,GAAGH,WAAWE,EAAE,CAACE,WAAW,CAAC;QACpE,OAAO;YACLC,WAAWrB,sBAAsB;gBAC/BsB,WAAWhB,QAAQiB,IAAI,CAAC,CAACC,SAAWA,OAAOC,IAAI,KAAKR,aAAaS;gBACjEf;gBACAgB,aAAa;oBACXzB;oBACAe;gBACF;YACF;YACAW,MAAMZ;QACR;IACF;IAEA,OAAO;QAAEF;IAAO;AAClB,EAAC;AAED,eAAeD,mBACbR,aAA4D,EAC5DH,GAAmB,EACnBI,OAAiB;IAEjB,yBAAyB;IACzB,IAAIuB;IACJ,IAAI,OAAOxB,kBAAkB,YAAY;QACvCwB,kBAAkB,MAAMxB,cAAc;YAAEH;QAAI;IAC9C,OAAO;QACL2B,kBAAkBxB;IACpB;IAEA,OAAOwB,gBAAgBd,GAAG,CAAC,CAACe,gBAAgBC;QAC1C,MAAMP,SAASlB,QAAQiB,IAAI,CAAC,CAACS,IAAMA,EAAEP,IAAI,KAAKK,eAAeb,UAAU;QACvE,OAAO;YACLC,IAAI,GAAGY,eAAeb,UAAU,CAAC,CAAC,EAAEc,OAAO;YAC3CE,UAAUT,QAAQS,YAAY;YAC9BC,UAAUV,QAAQU,YAAY;YAC9BC,OAAOL,eAAeK,KAAK,IAAI;QACjC;IACF;AACF"}
1
+ {"version":3,"file":"getDefaultLayoutServerFn.js","names":["RenderServerComponent","getDefaultLayoutHandler","req","user","Error","defaultLayout","widgets","payload","config","admin","dashboard","importMap","layoutItems","getItemsFromConfig","layout","map","layoutItem","widgetSlug","id","slice","lastIndexOf","component","Component","find","widget","slug","ComponentPath","serverProps","item","widgetInstances","widgetInstance","index","w","maxWidth","minWidth","width"],"sources":["../../../../../../src/views/Dashboard/Default/ModularDashboard/renderWidget/getDefaultLayoutServerFn.ts"],"sourcesContent":["import type {\n DashboardConfig,\n PayloadRequest,\n ServerFunction,\n Widget,\n WidgetServerProps,\n} from 'payload'\n\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\n\nimport type { WidgetInstanceClient, WidgetItem } from '../index.client.js'\n\nexport type GetDefaultLayoutServerFnArgs = Record<string, never>\n\nexport type GetDefaultLayoutServerFnReturnType = {\n layout: WidgetInstanceClient[]\n}\n\n/**\n * Server function to get the default dashboard layout on-demand.\n * Used when resetting the dashboard to its default configuration.\n */\nexport const getDefaultLayoutHandler: ServerFunction<\n GetDefaultLayoutServerFnArgs,\n Promise<GetDefaultLayoutServerFnReturnType>\n> = async ({ req }) => {\n if (!req.user) {\n throw new Error('Unauthorized')\n }\n\n const { defaultLayout = [], widgets = [] } = req.payload.config.admin.dashboard || {}\n const { importMap } = req.payload\n\n const layoutItems = await getItemsFromConfig(defaultLayout, req, widgets)\n\n const layout: WidgetInstanceClient[] = layoutItems.map((layoutItem) => {\n const widgetSlug = layoutItem.id.slice(0, layoutItem.id.lastIndexOf('-'))\n return {\n component: RenderServerComponent({\n Component: widgets.find((widget) => widget.slug === widgetSlug)?.ComponentPath,\n importMap,\n serverProps: {\n req,\n widgetSlug,\n } satisfies WidgetServerProps,\n }),\n item: layoutItem,\n }\n })\n\n return { layout }\n}\n\nasync function getItemsFromConfig(\n defaultLayout: NonNullable<DashboardConfig['defaultLayout']>,\n req: PayloadRequest,\n widgets: Widget[],\n): Promise<WidgetItem[]> {\n // Handle function format\n let widgetInstances\n if (typeof defaultLayout === 'function') {\n widgetInstances = await defaultLayout({ req })\n } else {\n widgetInstances = defaultLayout\n }\n\n return widgetInstances.map((widgetInstance, index) => {\n const widget = widgets.find((w) => w.slug === widgetInstance.widgetSlug)\n return {\n id: `${widgetInstance.widgetSlug}-${index}`,\n maxWidth: widget?.maxWidth ?? 'full',\n minWidth: widget?.minWidth ?? 'x-small',\n width: widgetInstance.width || 'x-small',\n }\n })\n}\n"],"mappings":"AAQA,SAASA,qBAAqB,QAAQ;AAUtC;;;;AAIA,OAAO,MAAMC,uBAAA,GAGT,MAAAA,CAAO;EAAEC;AAAG,CAAE;EAChB,IAAI,CAACA,GAAA,CAAIC,IAAI,EAAE;IACb,MAAM,IAAIC,KAAA,CAAM;EAClB;EAEA,MAAM;IAAEC,aAAA,GAAgB,EAAE;IAAEC,OAAA,GAAU;EAAE,CAAE,GAAGJ,GAAA,CAAIK,OAAO,CAACC,MAAM,CAACC,KAAK,CAACC,SAAS,IAAI,CAAC;EACpF,MAAM;IAAEC;EAAS,CAAE,GAAGT,GAAA,CAAIK,OAAO;EAEjC,MAAMK,WAAA,GAAc,MAAMC,kBAAA,CAAmBR,aAAA,EAAeH,GAAA,EAAKI,OAAA;EAEjE,MAAMQ,MAAA,GAAiCF,WAAA,CAAYG,GAAG,CAAEC,UAAA;IACtD,MAAMC,UAAA,GAAaD,UAAA,CAAWE,EAAE,CAACC,KAAK,CAAC,GAAGH,UAAA,CAAWE,EAAE,CAACE,WAAW,CAAC;IACpE,OAAO;MACLC,SAAA,EAAWrB,qBAAA,CAAsB;QAC/BsB,SAAA,EAAWhB,OAAA,CAAQiB,IAAI,CAAEC,MAAA,IAAWA,MAAA,CAAOC,IAAI,KAAKR,UAAA,GAAaS,aAAA;QACjEf,SAAA;QACAgB,WAAA,EAAa;UACXzB,GAAA;UACAe;QACF;MACF;MACAW,IAAA,EAAMZ;IACR;EACF;EAEA,OAAO;IAAEF;EAAO;AAClB;AAEA,eAAeD,mBACbR,aAA4D,EAC5DH,GAAmB,EACnBI,OAAiB;EAEjB;EACA,IAAIuB,eAAA;EACJ,IAAI,OAAOxB,aAAA,KAAkB,YAAY;IACvCwB,eAAA,GAAkB,MAAMxB,aAAA,CAAc;MAAEH;IAAI;EAC9C,OAAO;IACL2B,eAAA,GAAkBxB,aAAA;EACpB;EAEA,OAAOwB,eAAA,CAAgBd,GAAG,CAAC,CAACe,cAAA,EAAgBC,KAAA;IAC1C,MAAMP,MAAA,GAASlB,OAAA,CAAQiB,IAAI,CAAES,CAAA,IAAMA,CAAA,CAAEP,IAAI,KAAKK,cAAA,CAAeb,UAAU;IACvE,OAAO;MACLC,EAAA,EAAI,GAAGY,cAAA,CAAeb,UAAU,IAAIc,KAAA,EAAO;MAC3CE,QAAA,EAAUT,MAAA,EAAQS,QAAA,IAAY;MAC9BC,QAAA,EAAUV,MAAA,EAAQU,QAAA,IAAY;MAC9BC,KAAA,EAAOL,cAAA,CAAeK,KAAK,IAAI;IACjC;EACF;AACF","ignoreList":[]}
@@ -1,71 +1,72 @@
1
1
  import { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent';
2
2
  import React from 'react';
3
3
  /**
4
- * Instance-specific data for this widget
5
- */ // TODO: widgets will support state in the future
6
- // widgetData?: Record<string, unknown>
7
- /**
8
- * The slug of the widget to render
9
- */ /**
10
4
  * Server function to render a widget on-demand.
11
5
  * Similar to render-field but specifically for dashboard widgets.
12
- */ export const renderWidgetHandler = ({ req, /* widgetData, */ widgetSlug })=>{
13
- if (!req.user) {
14
- throw new Error('Unauthorized');
15
- }
16
- const { widgets } = req.payload.config.admin.dashboard;
17
- const { importMap } = req.payload;
18
- // Find the widget configuration
19
- const widgetConfig = widgets.find((widget)=>widget.slug === widgetSlug);
20
- if (!widgetConfig) {
21
- return {
22
- component: React.createElement('div', {
23
- style: {
24
- background: 'var(--theme-elevation-50)',
25
- border: '1px solid var(--theme-elevation-200)',
26
- borderRadius: '4px',
27
- color: 'var(--theme-text)',
28
- padding: '20px',
29
- textAlign: 'center'
30
- }
31
- }, `Widget "${widgetSlug}" not found`)
32
- };
33
- }
34
- try {
35
- // Create server props for the widget
36
- const serverProps = {
37
- req,
38
- // TODO: widgetData: widgetData || {},
39
- widgetSlug
40
- };
41
- // Render the widget server component
42
- const component = RenderServerComponent({
43
- Component: widgetConfig.ComponentPath,
44
- importMap,
45
- serverProps
46
- });
47
- return {
48
- component
49
- };
50
- } catch (error) {
51
- const errorMessage = error instanceof Error ? error.message : String(error);
52
- req.payload.logger.error({
53
- err: error,
54
- msg: `Error rendering widget "${widgetSlug}": ${errorMessage}`
55
- });
56
- return {
57
- component: React.createElement('div', {
58
- style: {
59
- background: 'var(--theme-error-50)',
60
- border: '1px solid var(--theme-error-200)',
61
- borderRadius: '4px',
62
- color: 'var(--theme-error-text)',
63
- padding: '20px',
64
- textAlign: 'center'
65
- }
66
- }, 'Error loading widget')
67
- };
68
- }
6
+ */
7
+ export const renderWidgetHandler = ({
8
+ req,
9
+ /* widgetData, */widgetSlug
10
+ }) => {
11
+ if (!req.user) {
12
+ throw new Error('Unauthorized');
13
+ }
14
+ const {
15
+ widgets
16
+ } = req.payload.config.admin.dashboard;
17
+ const {
18
+ importMap
19
+ } = req.payload;
20
+ // Find the widget configuration
21
+ const widgetConfig = widgets.find(widget => widget.slug === widgetSlug);
22
+ if (!widgetConfig) {
23
+ return {
24
+ component: React.createElement('div', {
25
+ style: {
26
+ background: 'var(--theme-elevation-50)',
27
+ border: '1px solid var(--theme-elevation-200)',
28
+ borderRadius: '4px',
29
+ color: 'var(--theme-text)',
30
+ padding: '20px',
31
+ textAlign: 'center'
32
+ }
33
+ }, `Widget "${widgetSlug}" not found`)
34
+ };
35
+ }
36
+ try {
37
+ // Create server props for the widget
38
+ const serverProps = {
39
+ req,
40
+ // TODO: widgetData: widgetData || {},
41
+ widgetSlug
42
+ };
43
+ // Render the widget server component
44
+ const component = RenderServerComponent({
45
+ Component: widgetConfig.ComponentPath,
46
+ importMap,
47
+ serverProps
48
+ });
49
+ return {
50
+ component
51
+ };
52
+ } catch (error) {
53
+ const errorMessage = error instanceof Error ? error.message : String(error);
54
+ req.payload.logger.error({
55
+ err: error,
56
+ msg: `Error rendering widget "${widgetSlug}": ${errorMessage}`
57
+ });
58
+ return {
59
+ component: React.createElement('div', {
60
+ style: {
61
+ background: 'var(--theme-error-50)',
62
+ border: '1px solid var(--theme-error-200)',
63
+ borderRadius: '4px',
64
+ color: 'var(--theme-error-text)',
65
+ padding: '20px',
66
+ textAlign: 'center'
67
+ }
68
+ }, 'Error loading widget')
69
+ };
70
+ }
69
71
  };
70
-
71
72
  //# sourceMappingURL=renderWidgetServerFn.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../src/views/Dashboard/Default/ModularDashboard/renderWidget/renderWidgetServerFn.ts"],"sourcesContent":["import type { ServerFunction, WidgetServerProps } from 'payload'\n\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport React from 'react'\n\nexport type RenderWidgetServerFnArgs = {\n /**\n * Instance-specific data for this widget\n */\n // TODO: widgets will support state in the future\n // widgetData?: Record<string, unknown>\n /**\n * The slug of the widget to render\n */\n widgetSlug: string\n}\n\nexport type RenderWidgetServerFnReturnType = {\n component: React.ReactNode\n}\n\n/**\n * Server function to render a widget on-demand.\n * Similar to render-field but specifically for dashboard widgets.\n */\nexport const renderWidgetHandler: ServerFunction<\n RenderWidgetServerFnArgs,\n RenderWidgetServerFnReturnType\n> = ({ req, /* widgetData, */ widgetSlug }) => {\n if (!req.user) {\n throw new Error('Unauthorized')\n }\n\n const { widgets } = req.payload.config.admin.dashboard\n const { importMap } = req.payload\n\n // Find the widget configuration\n const widgetConfig = widgets.find((widget) => widget.slug === widgetSlug)\n\n if (!widgetConfig) {\n return {\n component: React.createElement(\n 'div',\n {\n style: {\n background: 'var(--theme-elevation-50)',\n border: '1px solid var(--theme-elevation-200)',\n borderRadius: '4px',\n color: 'var(--theme-text)',\n padding: '20px',\n textAlign: 'center',\n },\n },\n `Widget \"${widgetSlug}\" not found`,\n ),\n }\n }\n\n try {\n // Create server props for the widget\n const serverProps: WidgetServerProps = {\n req,\n // TODO: widgetData: widgetData || {},\n widgetSlug,\n }\n\n // Render the widget server component\n const component = RenderServerComponent({\n Component: widgetConfig.ComponentPath,\n importMap,\n serverProps,\n })\n\n return { component }\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error)\n\n req.payload.logger.error({\n err: error,\n msg: `Error rendering widget \"${widgetSlug}\": ${errorMessage}`,\n })\n\n return {\n component: React.createElement(\n 'div',\n {\n style: {\n background: 'var(--theme-error-50)',\n border: '1px solid var(--theme-error-200)',\n borderRadius: '4px',\n color: 'var(--theme-error-text)',\n padding: '20px',\n textAlign: 'center',\n },\n },\n 'Error loading widget',\n ),\n }\n }\n}\n"],"names":["RenderServerComponent","React","renderWidgetHandler","req","widgetSlug","user","Error","widgets","payload","config","admin","dashboard","importMap","widgetConfig","find","widget","slug","component","createElement","style","background","border","borderRadius","color","padding","textAlign","serverProps","Component","ComponentPath","error","errorMessage","message","String","logger","err","msg"],"mappings":"AAEA,SAASA,qBAAqB,QAAQ,gDAA+C;AACrF,OAAOC,WAAW,QAAO;AAGvB;;GAEC,GACD,iDAAiD;AACjD,uCAAuC;AACvC;;GAEC,GAQH;;;CAGC,GACD,OAAO,MAAMC,sBAGT,CAAC,EAAEC,GAAG,EAAE,eAAe,GAAGC,UAAU,EAAE;IACxC,IAAI,CAACD,IAAIE,IAAI,EAAE;QACb,MAAM,IAAIC,MAAM;IAClB;IAEA,MAAM,EAAEC,OAAO,EAAE,GAAGJ,IAAIK,OAAO,CAACC,MAAM,CAACC,KAAK,CAACC,SAAS;IACtD,MAAM,EAAEC,SAAS,EAAE,GAAGT,IAAIK,OAAO;IAEjC,gCAAgC;IAChC,MAAMK,eAAeN,QAAQO,IAAI,CAAC,CAACC,SAAWA,OAAOC,IAAI,KAAKZ;IAE9D,IAAI,CAACS,cAAc;QACjB,OAAO;YACLI,WAAWhB,MAAMiB,aAAa,CAC5B,OACA;gBACEC,OAAO;oBACLC,YAAY;oBACZC,QAAQ;oBACRC,cAAc;oBACdC,OAAO;oBACPC,SAAS;oBACTC,WAAW;gBACb;YACF,GACA,CAAC,QAAQ,EAAErB,WAAW,WAAW,CAAC;QAEtC;IACF;IAEA,IAAI;QACF,qCAAqC;QACrC,MAAMsB,cAAiC;YACrCvB;YACA,sCAAsC;YACtCC;QACF;QAEA,qCAAqC;QACrC,MAAMa,YAAYjB,sBAAsB;YACtC2B,WAAWd,aAAae,aAAa;YACrChB;YACAc;QACF;QAEA,OAAO;YAAET;QAAU;IACrB,EAAE,OAAOY,OAAO;QACd,MAAMC,eAAeD,iBAAiBvB,QAAQuB,MAAME,OAAO,GAAGC,OAAOH;QAErE1B,IAAIK,OAAO,CAACyB,MAAM,CAACJ,KAAK,CAAC;YACvBK,KAAKL;YACLM,KAAK,CAAC,wBAAwB,EAAE/B,WAAW,GAAG,EAAE0B,cAAc;QAChE;QAEA,OAAO;YACLb,WAAWhB,MAAMiB,aAAa,CAC5B,OACA;gBACEC,OAAO;oBACLC,YAAY;oBACZC,QAAQ;oBACRC,cAAc;oBACdC,OAAO;oBACPC,SAAS;oBACTC,WAAW;gBACb;YACF,GACA;QAEJ;IACF;AACF,EAAC"}
1
+ {"version":3,"file":"renderWidgetServerFn.js","names":["RenderServerComponent","React","renderWidgetHandler","req","widgetSlug","user","Error","widgets","payload","config","admin","dashboard","importMap","widgetConfig","find","widget","slug","component","createElement","style","background","border","borderRadius","color","padding","textAlign","serverProps","Component","ComponentPath","error","errorMessage","message","String","logger","err","msg"],"sources":["../../../../../../src/views/Dashboard/Default/ModularDashboard/renderWidget/renderWidgetServerFn.ts"],"sourcesContent":["import type { ServerFunction, WidgetServerProps } from 'payload'\n\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport React from 'react'\n\nexport type RenderWidgetServerFnArgs = {\n /**\n * Instance-specific data for this widget\n */\n // TODO: widgets will support state in the future\n // widgetData?: Record<string, unknown>\n /**\n * The slug of the widget to render\n */\n widgetSlug: string\n}\n\nexport type RenderWidgetServerFnReturnType = {\n component: React.ReactNode\n}\n\n/**\n * Server function to render a widget on-demand.\n * Similar to render-field but specifically for dashboard widgets.\n */\nexport const renderWidgetHandler: ServerFunction<\n RenderWidgetServerFnArgs,\n RenderWidgetServerFnReturnType\n> = ({ req, /* widgetData, */ widgetSlug }) => {\n if (!req.user) {\n throw new Error('Unauthorized')\n }\n\n const { widgets } = req.payload.config.admin.dashboard\n const { importMap } = req.payload\n\n // Find the widget configuration\n const widgetConfig = widgets.find((widget) => widget.slug === widgetSlug)\n\n if (!widgetConfig) {\n return {\n component: React.createElement(\n 'div',\n {\n style: {\n background: 'var(--theme-elevation-50)',\n border: '1px solid var(--theme-elevation-200)',\n borderRadius: '4px',\n color: 'var(--theme-text)',\n padding: '20px',\n textAlign: 'center',\n },\n },\n `Widget \"${widgetSlug}\" not found`,\n ),\n }\n }\n\n try {\n // Create server props for the widget\n const serverProps: WidgetServerProps = {\n req,\n // TODO: widgetData: widgetData || {},\n widgetSlug,\n }\n\n // Render the widget server component\n const component = RenderServerComponent({\n Component: widgetConfig.ComponentPath,\n importMap,\n serverProps,\n })\n\n return { component }\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error)\n\n req.payload.logger.error({\n err: error,\n msg: `Error rendering widget \"${widgetSlug}\": ${errorMessage}`,\n })\n\n return {\n component: React.createElement(\n 'div',\n {\n style: {\n background: 'var(--theme-error-50)',\n border: '1px solid var(--theme-error-200)',\n borderRadius: '4px',\n color: 'var(--theme-error-text)',\n padding: '20px',\n textAlign: 'center',\n },\n },\n 'Error loading widget',\n ),\n }\n }\n}\n"],"mappings":"AAEA,SAASA,qBAAqB,QAAQ;AACtC,OAAOC,KAAA,MAAW;AAkBlB;;;;AAIA,OAAO,MAAMC,mBAAA,GAGTA,CAAC;EAAEC,GAAG;EAAE,iBAAkBC;AAAU,CAAE;EACxC,IAAI,CAACD,GAAA,CAAIE,IAAI,EAAE;IACb,MAAM,IAAIC,KAAA,CAAM;EAClB;EAEA,MAAM;IAAEC;EAAO,CAAE,GAAGJ,GAAA,CAAIK,OAAO,CAACC,MAAM,CAACC,KAAK,CAACC,SAAS;EACtD,MAAM;IAAEC;EAAS,CAAE,GAAGT,GAAA,CAAIK,OAAO;EAEjC;EACA,MAAMK,YAAA,GAAeN,OAAA,CAAQO,IAAI,CAAEC,MAAA,IAAWA,MAAA,CAAOC,IAAI,KAAKZ,UAAA;EAE9D,IAAI,CAACS,YAAA,EAAc;IACjB,OAAO;MACLI,SAAA,EAAWhB,KAAA,CAAMiB,aAAa,CAC5B,OACA;QACEC,KAAA,EAAO;UACLC,UAAA,EAAY;UACZC,MAAA,EAAQ;UACRC,YAAA,EAAc;UACdC,KAAA,EAAO;UACPC,OAAA,EAAS;UACTC,SAAA,EAAW;QACb;MACF,GACA,WAAWrB,UAAA,aAAuB;IAEtC;EACF;EAEA,IAAI;IACF;IACA,MAAMsB,WAAA,GAAiC;MACrCvB,GAAA;MACA;MACAC;IACF;IAEA;IACA,MAAMa,SAAA,GAAYjB,qBAAA,CAAsB;MACtC2B,SAAA,EAAWd,YAAA,CAAae,aAAa;MACrChB,SAAA;MACAc;IACF;IAEA,OAAO;MAAET;IAAU;EACrB,EAAE,OAAOY,KAAA,EAAO;IACd,MAAMC,YAAA,GAAeD,KAAA,YAAiBvB,KAAA,GAAQuB,KAAA,CAAME,OAAO,GAAGC,MAAA,CAAOH,KAAA;IAErE1B,GAAA,CAAIK,OAAO,CAACyB,MAAM,CAACJ,KAAK,CAAC;MACvBK,GAAA,EAAKL,KAAA;MACLM,GAAA,EAAK,2BAA2B/B,UAAA,MAAgB0B,YAAA;IAClD;IAEA,OAAO;MACLb,SAAA,EAAWhB,KAAA,CAAMiB,aAAa,CAC5B,OACA;QACEC,KAAA,EAAO;UACLC,UAAA,EAAY;UACZC,MAAA,EAAQ;UACRC,YAAA,EAAc;UACdC,KAAA,EAAO;UACPC,OAAA,EAAS;UACTC,SAAA,EAAW;QACb;MACF,GACA;IAEJ;EACF;AACF","ignoreList":[]}
@@ -3,173 +3,156 @@ import { ConfirmationModal, toast, useConfig, useModal, usePreferences, useServe
3
3
  import React, { useCallback, useState } from 'react';
4
4
  import { RenderWidget } from './renderWidget/RenderWidget.js';
5
5
  export function useDashboardLayout(initialLayout) {
6
- const setLayoutPreference = useSetLayoutPreference();
7
- const [isEditing, setIsEditing] = useState(false);
8
- const { widgets = [] } = useConfig().config.admin.dashboard ?? {};
9
- const [currentLayout, setCurrentLayout] = useState(initialLayout);
10
- const { openModal } = useModal();
11
- const cancelModalSlug = 'cancel-dashboard-changes';
12
- const { serverFunction } = useServerFunctions();
13
- const saveLayout = useCallback(async ()=>{
14
- try {
15
- const layoutData = currentLayout.map((item)=>item.item);
16
- setIsEditing(false);
17
- await setLayoutPreference(layoutData);
18
- } catch {
19
- setIsEditing(true);
20
- toast.error('Failed to save layout');
21
- }
22
- }, [
23
- setLayoutPreference,
24
- currentLayout
25
- ]);
26
- const resetLayout = useCallback(async ()=>{
27
- try {
28
- await setLayoutPreference(null);
29
- const result = await serverFunction({
30
- name: 'get-default-layout',
31
- args: {}
32
- });
33
- setCurrentLayout(result.layout);
34
- setIsEditing(false);
35
- } catch {
36
- toast.error('Failed to reset layout');
37
- }
38
- }, [
39
- setLayoutPreference,
40
- serverFunction
41
- ]);
42
- const performCancel = useCallback(()=>{
43
- setCurrentLayout(initialLayout);
44
- setIsEditing(false);
45
- }, [
46
- initialLayout
47
- ]);
48
- const cancel = useCallback(()=>{
49
- // Check if layout has changed
50
- const hasChanges = currentLayout.length !== initialLayout.length || currentLayout.some((widget, index)=>{
51
- const initialWidget = initialLayout[index];
52
- return !initialWidget || widget.item.id !== initialWidget.item.id || widget.item.width !== initialWidget.item.width;
53
- });
54
- // If there are changes, show confirmation modal
55
- if (hasChanges) {
56
- openModal(cancelModalSlug);
57
- } else {
58
- performCancel();
59
- }
60
- }, [
61
- currentLayout,
62
- initialLayout,
63
- openModal,
64
- cancelModalSlug,
65
- performCancel
66
- ]);
67
- const moveWidget = useCallback(({ moveFromIndex, moveToIndex })=>{
68
- if (moveFromIndex === moveToIndex || moveFromIndex < 0 || moveToIndex < 0) {
69
- return;
70
- }
71
- setCurrentLayout((prev)=>{
72
- return arrayMove(prev, moveFromIndex, moveToIndex);
73
- });
74
- }, []);
75
- const addWidget = useCallback((widgetSlug)=>{
76
- if (!isEditing) {
77
- return;
78
- }
79
- const widgetId = `${widgetSlug}-${Date.now()}`;
80
- const widget = widgets.find((widget)=>widget.slug === widgetSlug);
81
- // Create a new widget instance using RenderWidget
82
- const newWidgetInstance = {
83
- component: React.createElement(RenderWidget, {
84
- widgetId
85
- }),
86
- // TODO: widgetData can be added here for custom props
87
- item: {
88
- id: widgetId,
89
- maxWidth: widget?.maxWidth ?? 'full',
90
- minWidth: widget?.minWidth ?? 'x-small',
91
- width: widget?.minWidth ?? 'x-small'
92
- }
93
- };
94
- setCurrentLayout((prev)=>[
95
- ...prev,
96
- newWidgetInstance
97
- ]);
98
- // Scroll to the newly added widget after it's rendered and highlight it
99
- setTimeout(()=>{
100
- const element = document.getElementById(widgetId);
101
- if (element) {
102
- element.scrollIntoView({
103
- behavior: 'smooth',
104
- block: 'center'
105
- });
106
- // Add highlight animation to the widget element
107
- const widget = element.closest('.widget');
108
- if (widget) {
109
- widget.classList.add('widget--highlight');
110
- // Remove the class after animation completes (1.5s fade out)
111
- setTimeout(()=>{
112
- widget.classList.remove('widget--highlight');
113
- }, 1500);
114
- }
115
- }
116
- }, 100);
117
- }, [
118
- isEditing,
119
- widgets
120
- ]);
121
- const deleteWidget = useCallback((widgetId)=>{
122
- if (!isEditing) {
123
- return;
124
- }
125
- setCurrentLayout((prev)=>prev.filter((item)=>item.item.id !== widgetId));
126
- }, [
127
- isEditing
128
- ]);
129
- const resizeWidget = useCallback((widgetId, newWidth)=>{
130
- if (!isEditing) {
131
- return;
132
- }
133
- setCurrentLayout((prev)=>prev.map((item)=>item.item.id === widgetId ? {
134
- ...item,
135
- item: {
136
- ...item.item,
137
- width: newWidth
138
- }
139
- } : item));
140
- }, [
141
- isEditing
142
- ]);
143
- const cancelModal = React.createElement(ConfirmationModal, {
144
- body: 'You have unsaved changes to your dashboard layout. Are you sure you want to discard them?',
145
- confirmLabel: 'Discard',
146
- heading: 'Discard changes?',
147
- modalSlug: cancelModalSlug,
148
- onConfirm: performCancel
6
+ const setLayoutPreference = useSetLayoutPreference();
7
+ const [isEditing, setIsEditing] = useState(false);
8
+ const {
9
+ widgets = []
10
+ } = useConfig().config.admin.dashboard ?? {};
11
+ const [currentLayout, setCurrentLayout] = useState(initialLayout);
12
+ const {
13
+ openModal
14
+ } = useModal();
15
+ const cancelModalSlug = 'cancel-dashboard-changes';
16
+ const {
17
+ serverFunction
18
+ } = useServerFunctions();
19
+ const saveLayout = useCallback(async () => {
20
+ try {
21
+ const layoutData = currentLayout.map(item => item.item);
22
+ setIsEditing(false);
23
+ await setLayoutPreference(layoutData);
24
+ } catch {
25
+ setIsEditing(true);
26
+ toast.error('Failed to save layout');
27
+ }
28
+ }, [setLayoutPreference, currentLayout]);
29
+ const resetLayout = useCallback(async () => {
30
+ try {
31
+ await setLayoutPreference(null);
32
+ const result = await serverFunction({
33
+ name: 'get-default-layout',
34
+ args: {}
35
+ });
36
+ setCurrentLayout(result.layout);
37
+ setIsEditing(false);
38
+ } catch {
39
+ toast.error('Failed to reset layout');
40
+ }
41
+ }, [setLayoutPreference, serverFunction]);
42
+ const performCancel = useCallback(() => {
43
+ setCurrentLayout(initialLayout);
44
+ setIsEditing(false);
45
+ }, [initialLayout]);
46
+ const cancel = useCallback(() => {
47
+ // Check if layout has changed
48
+ const hasChanges = currentLayout.length !== initialLayout.length || currentLayout.some((widget, index) => {
49
+ const initialWidget = initialLayout[index];
50
+ return !initialWidget || widget.item.id !== initialWidget.item.id || widget.item.width !== initialWidget.item.width;
149
51
  });
150
- return {
151
- addWidget,
152
- cancel,
153
- cancelModal,
154
- currentLayout,
155
- deleteWidget,
156
- isEditing,
157
- moveWidget,
158
- resetLayout,
159
- resizeWidget,
160
- saveLayout,
161
- setIsEditing
52
+ // If there are changes, show confirmation modal
53
+ if (hasChanges) {
54
+ openModal(cancelModalSlug);
55
+ } else {
56
+ performCancel();
57
+ }
58
+ }, [currentLayout, initialLayout, openModal, cancelModalSlug, performCancel]);
59
+ const moveWidget = useCallback(({
60
+ moveFromIndex,
61
+ moveToIndex
62
+ }) => {
63
+ if (moveFromIndex === moveToIndex || moveFromIndex < 0 || moveToIndex < 0) {
64
+ return;
65
+ }
66
+ setCurrentLayout(prev => {
67
+ return arrayMove(prev, moveFromIndex, moveToIndex);
68
+ });
69
+ }, []);
70
+ const addWidget = useCallback(widgetSlug => {
71
+ if (!isEditing) {
72
+ return;
73
+ }
74
+ const widgetId = `${widgetSlug}-${Date.now()}`;
75
+ const widget = widgets.find(widget => widget.slug === widgetSlug);
76
+ // Create a new widget instance using RenderWidget
77
+ const newWidgetInstance = {
78
+ component: React.createElement(RenderWidget, {
79
+ widgetId
80
+ }),
81
+ item: {
82
+ id: widgetId,
83
+ maxWidth: widget?.maxWidth ?? 'full',
84
+ minWidth: widget?.minWidth ?? 'x-small',
85
+ width: widget?.minWidth ?? 'x-small'
86
+ }
162
87
  };
88
+ setCurrentLayout(prev => [...prev, newWidgetInstance]);
89
+ // Scroll to the newly added widget after it's rendered and highlight it
90
+ setTimeout(() => {
91
+ const element = document.getElementById(widgetId);
92
+ if (element) {
93
+ element.scrollIntoView({
94
+ behavior: 'smooth',
95
+ block: 'center'
96
+ });
97
+ // Add highlight animation to the widget element
98
+ const widget = element.closest('.widget');
99
+ if (widget) {
100
+ widget.classList.add('widget--highlight');
101
+ // Remove the class after animation completes (1.5s fade out)
102
+ setTimeout(() => {
103
+ widget.classList.remove('widget--highlight');
104
+ }, 1500);
105
+ }
106
+ }
107
+ }, 100);
108
+ }, [isEditing, widgets]);
109
+ const deleteWidget = useCallback(widgetId => {
110
+ if (!isEditing) {
111
+ return;
112
+ }
113
+ setCurrentLayout(prev => prev.filter(item => item.item.id !== widgetId));
114
+ }, [isEditing]);
115
+ const resizeWidget = useCallback((widgetId, newWidth) => {
116
+ if (!isEditing) {
117
+ return;
118
+ }
119
+ setCurrentLayout(prev => prev.map(item => item.item.id === widgetId ? {
120
+ ...item,
121
+ item: {
122
+ ...item.item,
123
+ width: newWidth
124
+ }
125
+ } : item));
126
+ }, [isEditing]);
127
+ const cancelModal = React.createElement(ConfirmationModal, {
128
+ body: 'You have unsaved changes to your dashboard layout. Are you sure you want to discard them?',
129
+ confirmLabel: 'Discard',
130
+ heading: 'Discard changes?',
131
+ modalSlug: cancelModalSlug,
132
+ onConfirm: performCancel
133
+ });
134
+ return {
135
+ addWidget,
136
+ cancel,
137
+ cancelModal,
138
+ currentLayout,
139
+ deleteWidget,
140
+ isEditing,
141
+ moveWidget,
142
+ resetLayout,
143
+ resizeWidget,
144
+ saveLayout,
145
+ setIsEditing
146
+ };
163
147
  }
164
148
  function useSetLayoutPreference() {
165
- const { setPreference } = usePreferences();
166
- return useCallback(async (layout)=>{
167
- await setPreference('dashboard-layout', {
168
- layouts: layout
169
- }, false);
170
- }, [
171
- setPreference
172
- ]);
149
+ const {
150
+ setPreference
151
+ } = usePreferences();
152
+ return useCallback(async layout => {
153
+ await setPreference('dashboard-layout', {
154
+ layouts: layout
155
+ }, false);
156
+ }, [setPreference]);
173
157
  }
174
-
175
158
  //# sourceMappingURL=useDashboardLayout.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/views/Dashboard/Default/ModularDashboard/useDashboardLayout.ts"],"sourcesContent":["import type { WidgetWidth } from 'payload'\n\nimport { arrayMove } from '@dnd-kit/sortable'\nimport {\n ConfirmationModal,\n toast,\n useConfig,\n useModal,\n usePreferences,\n useServerFunctions,\n} from '@payloadcms/ui'\nimport React, { useCallback, useState } from 'react'\n\nimport type { WidgetInstanceClient, WidgetItem } from './index.client.js'\nimport type { GetDefaultLayoutServerFnReturnType } from './renderWidget/getDefaultLayoutServerFn.js'\n\nimport { RenderWidget } from './renderWidget/RenderWidget.js'\n\nexport function useDashboardLayout(initialLayout: WidgetInstanceClient[]) {\n const setLayoutPreference = useSetLayoutPreference()\n const [isEditing, setIsEditing] = useState(false)\n const { widgets = [] } = useConfig().config.admin.dashboard ?? {}\n const [currentLayout, setCurrentLayout] = useState<WidgetInstanceClient[]>(initialLayout)\n const { openModal } = useModal()\n const cancelModalSlug = 'cancel-dashboard-changes'\n const { serverFunction } = useServerFunctions()\n\n const saveLayout = useCallback(async () => {\n try {\n const layoutData: WidgetItem[] = currentLayout.map((item) => item.item)\n setIsEditing(false)\n await setLayoutPreference(layoutData)\n } catch {\n setIsEditing(true)\n toast.error('Failed to save layout')\n }\n }, [setLayoutPreference, currentLayout])\n\n const resetLayout = useCallback(async () => {\n try {\n await setLayoutPreference(null)\n\n const result = (await serverFunction({\n name: 'get-default-layout',\n args: {},\n })) as GetDefaultLayoutServerFnReturnType\n\n setCurrentLayout(result.layout)\n setIsEditing(false)\n } catch {\n toast.error('Failed to reset layout')\n }\n }, [setLayoutPreference, serverFunction])\n\n const performCancel = useCallback(() => {\n setCurrentLayout(initialLayout)\n setIsEditing(false)\n }, [initialLayout])\n\n const cancel = useCallback(() => {\n // Check if layout has changed\n const hasChanges =\n currentLayout.length !== initialLayout.length ||\n currentLayout.some((widget, index) => {\n const initialWidget = initialLayout[index]\n return (\n !initialWidget ||\n widget.item.id !== initialWidget.item.id ||\n widget.item.width !== initialWidget.item.width\n )\n })\n\n // If there are changes, show confirmation modal\n if (hasChanges) {\n openModal(cancelModalSlug)\n } else {\n performCancel()\n }\n }, [currentLayout, initialLayout, openModal, cancelModalSlug, performCancel])\n\n const moveWidget = useCallback(\n ({ moveFromIndex, moveToIndex }: { moveFromIndex: number; moveToIndex: number }) => {\n if (moveFromIndex === moveToIndex || moveFromIndex < 0 || moveToIndex < 0) {\n return\n }\n\n setCurrentLayout((prev) => {\n return arrayMove(prev, moveFromIndex, moveToIndex)\n })\n },\n [],\n )\n\n const addWidget = useCallback(\n (widgetSlug: string) => {\n if (!isEditing) {\n return\n }\n\n const widgetId = `${widgetSlug}-${Date.now()}`\n const widget = widgets.find((widget) => widget.slug === widgetSlug)\n\n // Create a new widget instance using RenderWidget\n const newWidgetInstance: WidgetInstanceClient = {\n component: React.createElement(RenderWidget, {\n widgetId,\n // TODO: widgetData can be added here for custom props\n }),\n item: {\n id: widgetId,\n maxWidth: widget?.maxWidth ?? 'full',\n minWidth: widget?.minWidth ?? 'x-small',\n width: widget?.minWidth ?? 'x-small',\n },\n }\n\n setCurrentLayout((prev) => [...prev, newWidgetInstance])\n\n // Scroll to the newly added widget after it's rendered and highlight it\n setTimeout(() => {\n const element = document.getElementById(widgetId)\n if (element) {\n element.scrollIntoView({\n behavior: 'smooth',\n block: 'center',\n })\n\n // Add highlight animation to the widget element\n const widget = element.closest('.widget')\n if (widget) {\n widget.classList.add('widget--highlight')\n // Remove the class after animation completes (1.5s fade out)\n setTimeout(() => {\n widget.classList.remove('widget--highlight')\n }, 1500)\n }\n }\n }, 100)\n },\n [isEditing, widgets],\n )\n\n const deleteWidget = useCallback(\n (widgetId: string) => {\n if (!isEditing) {\n return\n }\n setCurrentLayout((prev) => prev.filter((item) => item.item.id !== widgetId))\n },\n [isEditing],\n )\n\n const resizeWidget = useCallback(\n (widgetId: string, newWidth: WidgetWidth) => {\n if (!isEditing) {\n return\n }\n setCurrentLayout((prev) =>\n prev.map((item) =>\n item.item.id === widgetId\n ? {\n ...item,\n item: {\n ...item.item,\n width: newWidth,\n } satisfies WidgetItem,\n }\n : item,\n ),\n )\n },\n [isEditing],\n )\n\n const cancelModal = React.createElement(ConfirmationModal, {\n body: 'You have unsaved changes to your dashboard layout. Are you sure you want to discard them?',\n confirmLabel: 'Discard',\n heading: 'Discard changes?',\n modalSlug: cancelModalSlug,\n onConfirm: performCancel,\n })\n\n return {\n addWidget,\n cancel,\n cancelModal,\n currentLayout,\n deleteWidget,\n isEditing,\n moveWidget,\n resetLayout,\n resizeWidget,\n saveLayout,\n setIsEditing,\n }\n}\n\nfunction useSetLayoutPreference() {\n const { setPreference } = usePreferences()\n return useCallback(\n async (layout: null | WidgetItem[]) => {\n await setPreference('dashboard-layout', { layouts: layout }, false)\n },\n [setPreference],\n )\n}\n"],"names":["arrayMove","ConfirmationModal","toast","useConfig","useModal","usePreferences","useServerFunctions","React","useCallback","useState","RenderWidget","useDashboardLayout","initialLayout","setLayoutPreference","useSetLayoutPreference","isEditing","setIsEditing","widgets","config","admin","dashboard","currentLayout","setCurrentLayout","openModal","cancelModalSlug","serverFunction","saveLayout","layoutData","map","item","error","resetLayout","result","name","args","layout","performCancel","cancel","hasChanges","length","some","widget","index","initialWidget","id","width","moveWidget","moveFromIndex","moveToIndex","prev","addWidget","widgetSlug","widgetId","Date","now","find","slug","newWidgetInstance","component","createElement","maxWidth","minWidth","setTimeout","element","document","getElementById","scrollIntoView","behavior","block","closest","classList","add","remove","deleteWidget","filter","resizeWidget","newWidth","cancelModal","body","confirmLabel","heading","modalSlug","onConfirm","setPreference","layouts"],"mappings":"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"}
1
+ {"version":3,"file":"useDashboardLayout.js","names":["arrayMove","ConfirmationModal","toast","useConfig","useModal","usePreferences","useServerFunctions","React","useCallback","useState","RenderWidget","useDashboardLayout","initialLayout","setLayoutPreference","useSetLayoutPreference","isEditing","setIsEditing","widgets","config","admin","dashboard","currentLayout","setCurrentLayout","openModal","cancelModalSlug","serverFunction","saveLayout","layoutData","map","item","error","resetLayout","result","name","args","layout","performCancel","cancel","hasChanges","length","some","widget","index","initialWidget","id","width","moveWidget","moveFromIndex","moveToIndex","prev","addWidget","widgetSlug","widgetId","Date","now","find","slug","newWidgetInstance","component","createElement","maxWidth","minWidth","setTimeout","element","document","getElementById","scrollIntoView","behavior","block","closest","classList","add","remove","deleteWidget","filter","resizeWidget","newWidth","cancelModal","body","confirmLabel","heading","modalSlug","onConfirm","setPreference","layouts"],"sources":["../../../../../src/views/Dashboard/Default/ModularDashboard/useDashboardLayout.ts"],"sourcesContent":["import type { WidgetWidth } from 'payload'\n\nimport { arrayMove } from '@dnd-kit/sortable'\nimport {\n ConfirmationModal,\n toast,\n useConfig,\n useModal,\n usePreferences,\n useServerFunctions,\n} from '@payloadcms/ui'\nimport React, { useCallback, useState } from 'react'\n\nimport type { WidgetInstanceClient, WidgetItem } from './index.client.js'\nimport type { GetDefaultLayoutServerFnReturnType } from './renderWidget/getDefaultLayoutServerFn.js'\n\nimport { RenderWidget } from './renderWidget/RenderWidget.js'\n\nexport function useDashboardLayout(initialLayout: WidgetInstanceClient[]) {\n const setLayoutPreference = useSetLayoutPreference()\n const [isEditing, setIsEditing] = useState(false)\n const { widgets = [] } = useConfig().config.admin.dashboard ?? {}\n const [currentLayout, setCurrentLayout] = useState<WidgetInstanceClient[]>(initialLayout)\n const { openModal } = useModal()\n const cancelModalSlug = 'cancel-dashboard-changes'\n const { serverFunction } = useServerFunctions()\n\n const saveLayout = useCallback(async () => {\n try {\n const layoutData: WidgetItem[] = currentLayout.map((item) => item.item)\n setIsEditing(false)\n await setLayoutPreference(layoutData)\n } catch {\n setIsEditing(true)\n toast.error('Failed to save layout')\n }\n }, [setLayoutPreference, currentLayout])\n\n const resetLayout = useCallback(async () => {\n try {\n await setLayoutPreference(null)\n\n const result = (await serverFunction({\n name: 'get-default-layout',\n args: {},\n })) as GetDefaultLayoutServerFnReturnType\n\n setCurrentLayout(result.layout)\n setIsEditing(false)\n } catch {\n toast.error('Failed to reset layout')\n }\n }, [setLayoutPreference, serverFunction])\n\n const performCancel = useCallback(() => {\n setCurrentLayout(initialLayout)\n setIsEditing(false)\n }, [initialLayout])\n\n const cancel = useCallback(() => {\n // Check if layout has changed\n const hasChanges =\n currentLayout.length !== initialLayout.length ||\n currentLayout.some((widget, index) => {\n const initialWidget = initialLayout[index]\n return (\n !initialWidget ||\n widget.item.id !== initialWidget.item.id ||\n widget.item.width !== initialWidget.item.width\n )\n })\n\n // If there are changes, show confirmation modal\n if (hasChanges) {\n openModal(cancelModalSlug)\n } else {\n performCancel()\n }\n }, [currentLayout, initialLayout, openModal, cancelModalSlug, performCancel])\n\n const moveWidget = useCallback(\n ({ moveFromIndex, moveToIndex }: { moveFromIndex: number; moveToIndex: number }) => {\n if (moveFromIndex === moveToIndex || moveFromIndex < 0 || moveToIndex < 0) {\n return\n }\n\n setCurrentLayout((prev) => {\n return arrayMove(prev, moveFromIndex, moveToIndex)\n })\n },\n [],\n )\n\n const addWidget = useCallback(\n (widgetSlug: string) => {\n if (!isEditing) {\n return\n }\n\n const widgetId = `${widgetSlug}-${Date.now()}`\n const widget = widgets.find((widget) => widget.slug === widgetSlug)\n\n // Create a new widget instance using RenderWidget\n const newWidgetInstance: WidgetInstanceClient = {\n component: React.createElement(RenderWidget, {\n widgetId,\n // TODO: widgetData can be added here for custom props\n }),\n item: {\n id: widgetId,\n maxWidth: widget?.maxWidth ?? 'full',\n minWidth: widget?.minWidth ?? 'x-small',\n width: widget?.minWidth ?? 'x-small',\n },\n }\n\n setCurrentLayout((prev) => [...prev, newWidgetInstance])\n\n // Scroll to the newly added widget after it's rendered and highlight it\n setTimeout(() => {\n const element = document.getElementById(widgetId)\n if (element) {\n element.scrollIntoView({\n behavior: 'smooth',\n block: 'center',\n })\n\n // Add highlight animation to the widget element\n const widget = element.closest('.widget')\n if (widget) {\n widget.classList.add('widget--highlight')\n // Remove the class after animation completes (1.5s fade out)\n setTimeout(() => {\n widget.classList.remove('widget--highlight')\n }, 1500)\n }\n }\n }, 100)\n },\n [isEditing, widgets],\n )\n\n const deleteWidget = useCallback(\n (widgetId: string) => {\n if (!isEditing) {\n return\n }\n setCurrentLayout((prev) => prev.filter((item) => item.item.id !== widgetId))\n },\n [isEditing],\n )\n\n const resizeWidget = useCallback(\n (widgetId: string, newWidth: WidgetWidth) => {\n if (!isEditing) {\n return\n }\n setCurrentLayout((prev) =>\n prev.map((item) =>\n item.item.id === widgetId\n ? {\n ...item,\n item: {\n ...item.item,\n width: newWidth,\n } satisfies WidgetItem,\n }\n : item,\n ),\n )\n },\n [isEditing],\n )\n\n const cancelModal = React.createElement(ConfirmationModal, {\n body: 'You have unsaved changes to your dashboard layout. Are you sure you want to discard them?',\n confirmLabel: 'Discard',\n heading: 'Discard changes?',\n modalSlug: cancelModalSlug,\n onConfirm: performCancel,\n })\n\n return {\n addWidget,\n cancel,\n cancelModal,\n currentLayout,\n deleteWidget,\n isEditing,\n moveWidget,\n resetLayout,\n resizeWidget,\n saveLayout,\n setIsEditing,\n }\n}\n\nfunction useSetLayoutPreference() {\n const { setPreference } = usePreferences()\n return useCallback(\n async (layout: null | WidgetItem[]) => {\n await setPreference('dashboard-layout', { layouts: layout }, false)\n },\n [setPreference],\n )\n}\n"],"mappings":"AAEA,SAASA,SAAS,QAAQ;AAC1B,SACEC,iBAAiB,EACjBC,KAAK,EACLC,SAAS,EACTC,QAAQ,EACRC,cAAc,EACdC,kBAAkB,QACb;AACP,OAAOC,KAAA,IAASC,WAAW,EAAEC,QAAQ,QAAQ;AAK7C,SAASC,YAAY,QAAQ;AAE7B,OAAO,SAASC,mBAAmBC,aAAqC;EACtE,MAAMC,mBAAA,GAAsBC,sBAAA;EAC5B,MAAM,CAACC,SAAA,EAAWC,YAAA,CAAa,GAAGP,QAAA,CAAS;EAC3C,MAAM;IAAEQ,OAAA,GAAU;EAAE,CAAE,GAAGd,SAAA,GAAYe,MAAM,CAACC,KAAK,CAACC,SAAS,IAAI,CAAC;EAChE,MAAM,CAACC,aAAA,EAAeC,gBAAA,CAAiB,GAAGb,QAAA,CAAiCG,aAAA;EAC3E,MAAM;IAAEW;EAAS,CAAE,GAAGnB,QAAA;EACtB,MAAMoB,eAAA,GAAkB;EACxB,MAAM;IAAEC;EAAc,CAAE,GAAGnB,kBAAA;EAE3B,MAAMoB,UAAA,GAAalB,WAAA,CAAY;IAC7B,IAAI;MACF,MAAMmB,UAAA,GAA2BN,aAAA,CAAcO,GAAG,CAAEC,IAAA,IAASA,IAAA,CAAKA,IAAI;MACtEb,YAAA,CAAa;MACb,MAAMH,mBAAA,CAAoBc,UAAA;IAC5B,EAAE,MAAM;MACNX,YAAA,CAAa;MACbd,KAAA,CAAM4B,KAAK,CAAC;IACd;EACF,GAAG,CAACjB,mBAAA,EAAqBQ,aAAA,CAAc;EAEvC,MAAMU,WAAA,GAAcvB,WAAA,CAAY;IAC9B,IAAI;MACF,MAAMK,mBAAA,CAAoB;MAE1B,MAAMmB,MAAA,GAAU,MAAMP,cAAA,CAAe;QACnCQ,IAAA,EAAM;QACNC,IAAA,EAAM,CAAC;MACT;MAEAZ,gBAAA,CAAiBU,MAAA,CAAOG,MAAM;MAC9BnB,YAAA,CAAa;IACf,EAAE,MAAM;MACNd,KAAA,CAAM4B,KAAK,CAAC;IACd;EACF,GAAG,CAACjB,mBAAA,EAAqBY,cAAA,CAAe;EAExC,MAAMW,aAAA,GAAgB5B,WAAA,CAAY;IAChCc,gBAAA,CAAiBV,aAAA;IACjBI,YAAA,CAAa;EACf,GAAG,CAACJ,aAAA,CAAc;EAElB,MAAMyB,MAAA,GAAS7B,WAAA,CAAY;IACzB;IACA,MAAM8B,UAAA,GACJjB,aAAA,CAAckB,MAAM,KAAK3B,aAAA,CAAc2B,MAAM,IAC7ClB,aAAA,CAAcmB,IAAI,CAAC,CAACC,MAAA,EAAQC,KAAA;MAC1B,MAAMC,aAAA,GAAgB/B,aAAa,CAAC8B,KAAA,CAAM;MAC1C,OACE,CAACC,aAAA,IACDF,MAAA,CAAOZ,IAAI,CAACe,EAAE,KAAKD,aAAA,CAAcd,IAAI,CAACe,EAAE,IACxCH,MAAA,CAAOZ,IAAI,CAACgB,KAAK,KAAKF,aAAA,CAAcd,IAAI,CAACgB,KAAK;IAElD;IAEF;IACA,IAAIP,UAAA,EAAY;MACdf,SAAA,CAAUC,eAAA;IACZ,OAAO;MACLY,aAAA;IACF;EACF,GAAG,CAACf,aAAA,EAAeT,aAAA,EAAeW,SAAA,EAAWC,eAAA,EAAiBY,aAAA,CAAc;EAE5E,MAAMU,UAAA,GAAatC,WAAA,CACjB,CAAC;IAAEuC,aAAa;IAAEC;EAAW,CAAkD;IAC7E,IAAID,aAAA,KAAkBC,WAAA,IAAeD,aAAA,GAAgB,KAAKC,WAAA,GAAc,GAAG;MACzE;IACF;IAEA1B,gBAAA,CAAkB2B,IAAA;MAChB,OAAOjD,SAAA,CAAUiD,IAAA,EAAMF,aAAA,EAAeC,WAAA;IACxC;EACF,GACA,EAAE;EAGJ,MAAME,SAAA,GAAY1C,WAAA,CACf2C,UAAA;IACC,IAAI,CAACpC,SAAA,EAAW;MACd;IACF;IAEA,MAAMqC,QAAA,GAAW,GAAGD,UAAA,IAAcE,IAAA,CAAKC,GAAG,IAAI;IAC9C,MAAMb,MAAA,GAASxB,OAAA,CAAQsC,IAAI,CAAEd,MAAA,IAAWA,MAAA,CAAOe,IAAI,KAAKL,UAAA;IAExD;IACA,MAAMM,iBAAA,GAA0C;MAC9CC,SAAA,EAAWnD,KAAA,CAAMoD,aAAa,CAACjD,YAAA,EAAc;QAC3C0C;MAEF;MACAvB,IAAA,EAAM;QACJe,EAAA,EAAIQ,QAAA;QACJQ,QAAA,EAAUnB,MAAA,EAAQmB,QAAA,IAAY;QAC9BC,QAAA,EAAUpB,MAAA,EAAQoB,QAAA,IAAY;QAC9BhB,KAAA,EAAOJ,MAAA,EAAQoB,QAAA,IAAY;MAC7B;IACF;IAEAvC,gBAAA,CAAkB2B,IAAA,IAAS,C,GAAIA,IAAA,EAAMQ,iBAAA,CAAkB;IAEvD;IACAK,UAAA,CAAW;MACT,MAAMC,OAAA,GAAUC,QAAA,CAASC,cAAc,CAACb,QAAA;MACxC,IAAIW,OAAA,EAAS;QACXA,OAAA,CAAQG,cAAc,CAAC;UACrBC,QAAA,EAAU;UACVC,KAAA,EAAO;QACT;QAEA;QACA,MAAM3B,MAAA,GAASsB,OAAA,CAAQM,OAAO,CAAC;QAC/B,IAAI5B,MAAA,EAAQ;UACVA,MAAA,CAAO6B,SAAS,CAACC,GAAG,CAAC;UACrB;UACAT,UAAA,CAAW;YACTrB,MAAA,CAAO6B,SAAS,CAACE,MAAM,CAAC;UAC1B,GAAG;QACL;MACF;IACF,GAAG;EACL,GACA,CAACzD,SAAA,EAAWE,OAAA,CAAQ;EAGtB,MAAMwD,YAAA,GAAejE,WAAA,CAClB4C,QAAA;IACC,IAAI,CAACrC,SAAA,EAAW;MACd;IACF;IACAO,gBAAA,CAAkB2B,IAAA,IAASA,IAAA,CAAKyB,MAAM,CAAE7C,IAAA,IAASA,IAAA,CAAKA,IAAI,CAACe,EAAE,KAAKQ,QAAA;EACpE,GACA,CAACrC,SAAA,CAAU;EAGb,MAAM4D,YAAA,GAAenE,WAAA,CACnB,CAAC4C,QAAA,EAAkBwB,QAAA;IACjB,IAAI,CAAC7D,SAAA,EAAW;MACd;IACF;IACAO,gBAAA,CAAkB2B,IAAA,IAChBA,IAAA,CAAKrB,GAAG,CAAEC,IAAA,IACRA,IAAA,CAAKA,IAAI,CAACe,EAAE,KAAKQ,QAAA,GACb;MACE,GAAGvB,IAAI;MACPA,IAAA,EAAM;QACJ,GAAGA,IAAA,CAAKA,IAAI;QACZgB,KAAA,EAAO+B;MACT;IACF,IACA/C,IAAA;EAGV,GACA,CAACd,SAAA,CAAU;EAGb,MAAM8D,WAAA,GAActE,KAAA,CAAMoD,aAAa,CAAC1D,iBAAA,EAAmB;IACzD6E,IAAA,EAAM;IACNC,YAAA,EAAc;IACdC,OAAA,EAAS;IACTC,SAAA,EAAWzD,eAAA;IACX0D,SAAA,EAAW9C;EACb;EAEA,OAAO;IACLc,SAAA;IACAb,MAAA;IACAwC,WAAA;IACAxD,aAAA;IACAoD,YAAA;IACA1D,SAAA;IACA+B,UAAA;IACAf,WAAA;IACA4C,YAAA;IACAjD,UAAA;IACAV;EACF;AACF;AAEA,SAASF,uBAAA;EACP,MAAM;IAAEqE;EAAa,CAAE,GAAG9E,cAAA;EAC1B,OAAOG,WAAA,CACL,MAAO2B,MAAA;IACL,MAAMgD,aAAA,CAAc,oBAAoB;MAAEC,OAAA,EAASjD;IAAO,GAAG;EAC/D,GACA,CAACgD,aAAA,CAAc;AAEnB","ignoreList":[]}
@@ -1,39 +1,38 @@
1
1
  /**
2
2
  * Collision detection that considers the X
3
3
  * axis only with respect to the position of the pointer (or collisionRect for keyboard)
4
- */ export const closestInXAxis = (args)=>{
5
- const collisions = [];
6
- // Use pointer coordinates if available (mouse/touch), otherwise use collisionRect center (keyboard)
7
- let x;
8
- let y;
9
- if (args.pointerCoordinates) {
10
- x = args.pointerCoordinates.x;
11
- y = args.pointerCoordinates.y;
12
- } else if (args.collisionRect) {
13
- // For keyboard navigation, use the center of the collisionRect
14
- x = args.collisionRect.left + args.collisionRect.width / 2;
15
- y = args.collisionRect.top + args.collisionRect.height / 2;
16
- } else {
17
- return [];
4
+ */export const closestInXAxis = args => {
5
+ const collisions = [];
6
+ // Use pointer coordinates if available (mouse/touch), otherwise use collisionRect center (keyboard)
7
+ let x;
8
+ let y;
9
+ if (args.pointerCoordinates) {
10
+ x = args.pointerCoordinates.x;
11
+ y = args.pointerCoordinates.y;
12
+ } else if (args.collisionRect) {
13
+ // For keyboard navigation, use the center of the collisionRect
14
+ x = args.collisionRect.left + args.collisionRect.width / 2;
15
+ y = args.collisionRect.top + args.collisionRect.height / 2;
16
+ } else {
17
+ return [];
18
+ }
19
+ for (const container of args.droppableContainers) {
20
+ const rect = args.droppableRects.get(container.id);
21
+ if (!rect) {
22
+ continue;
18
23
  }
19
- for (const container of args.droppableContainers){
20
- const rect = args.droppableRects.get(container.id);
21
- if (!rect) {
22
- continue;
23
- }
24
- // Only consider widgets in the same row (same Y axis)
25
- if (y >= rect.top && y <= rect.bottom) {
26
- const centerX = rect.left + rect.width / 2;
27
- const distance = Math.abs(x - centerX);
28
- collisions.push({
29
- id: String(container.id),
30
- data: {
31
- value: distance
32
- }
33
- });
24
+ // Only consider widgets in the same row (same Y axis)
25
+ if (y >= rect.top && y <= rect.bottom) {
26
+ const centerX = rect.left + rect.width / 2;
27
+ const distance = Math.abs(x - centerX);
28
+ collisions.push({
29
+ id: String(container.id),
30
+ data: {
31
+ value: distance
34
32
  }
33
+ });
35
34
  }
36
- return collisions.sort((a, b)=>a.data.value - b.data.value);
35
+ }
36
+ return collisions.sort((a, b) => a.data.value - b.data.value);
37
37
  };
38
-
39
38
  //# sourceMappingURL=collisionDetection.js.map