@payloadcms/next 3.0.0-beta.107 → 3.0.0-beta.109

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 (126) hide show
  1. package/dist/cjs/withPayload.js +4 -4
  2. package/dist/cjs/withPayload.js.map +1 -1
  3. package/dist/elements/DocumentHeader/Tabs/tabs/VersionsPill/index.d.ts.map +1 -1
  4. package/dist/elements/DocumentHeader/Tabs/tabs/VersionsPill/index.js +28 -24
  5. package/dist/elements/DocumentHeader/Tabs/tabs/VersionsPill/index.js.map +1 -1
  6. package/dist/elements/DocumentLocked/index.d.ts +12 -0
  7. package/dist/elements/DocumentLocked/index.d.ts.map +1 -0
  8. package/dist/elements/DocumentLocked/index.js +142 -0
  9. package/dist/elements/DocumentLocked/index.js.map +1 -0
  10. package/dist/elements/DocumentLocked/index.scss +37 -0
  11. package/dist/elements/DocumentTakeOver/index.d.ts +8 -0
  12. package/dist/elements/DocumentTakeOver/index.d.ts.map +1 -0
  13. package/dist/elements/DocumentTakeOver/index.js +98 -0
  14. package/dist/elements/DocumentTakeOver/index.js.map +1 -0
  15. package/dist/elements/DocumentTakeOver/index.scss +37 -0
  16. package/dist/elements/Nav/NavWrapper/index.scss +5 -0
  17. package/dist/elements/Nav/index.scss +5 -1
  18. package/dist/layouts/Root/index.d.ts.map +1 -1
  19. package/dist/layouts/Root/index.js +52 -20
  20. package/dist/layouts/Root/index.js.map +1 -1
  21. package/dist/prod/styles.css +1 -1
  22. package/dist/routes/graphql/handler.d.ts.map +1 -1
  23. package/dist/routes/graphql/handler.js +23 -11
  24. package/dist/routes/graphql/handler.js.map +1 -1
  25. package/dist/routes/rest/collections/find.d.ts.map +1 -1
  26. package/dist/routes/rest/collections/find.js +3 -0
  27. package/dist/routes/rest/collections/find.js.map +1 -1
  28. package/dist/routes/rest/collections/findByID.d.ts.map +1 -1
  29. package/dist/routes/rest/collections/findByID.js +2 -0
  30. package/dist/routes/rest/collections/findByID.js.map +1 -1
  31. package/dist/routes/rest/collections/updateByID.d.ts.map +1 -1
  32. package/dist/routes/rest/collections/updateByID.js +2 -0
  33. package/dist/routes/rest/collections/updateByID.js.map +1 -1
  34. package/dist/routes/rest/globals/update.d.ts.map +1 -1
  35. package/dist/routes/rest/globals/update.js +2 -0
  36. package/dist/routes/rest/globals/update.js.map +1 -1
  37. package/dist/routes/rest/routeError.d.ts +2 -7
  38. package/dist/routes/rest/routeError.d.ts.map +1 -1
  39. package/dist/routes/rest/routeError.js +33 -19
  40. package/dist/routes/rest/routeError.js.map +1 -1
  41. package/dist/routes/rest/utilities/sanitizeJoinParams.d.ts +13 -0
  42. package/dist/routes/rest/utilities/sanitizeJoinParams.d.ts.map +1 -0
  43. package/dist/routes/rest/utilities/sanitizeJoinParams.js +17 -0
  44. package/dist/routes/rest/utilities/sanitizeJoinParams.js.map +1 -0
  45. package/dist/templates/Default/index.d.ts.map +1 -1
  46. package/dist/templates/Default/index.js +7 -3
  47. package/dist/templates/Default/index.js.map +1 -1
  48. package/dist/templates/Default/index.scss +6 -1
  49. package/dist/utilities/getRequestTheme.d.ts.map +1 -1
  50. package/dist/utilities/getRequestTheme.js +3 -0
  51. package/dist/utilities/getRequestTheme.js.map +1 -1
  52. package/dist/utilities/initPage/index.d.ts.map +1 -1
  53. package/dist/utilities/initPage/index.js +22 -32
  54. package/dist/utilities/initPage/index.js.map +1 -1
  55. package/dist/utilities/initReq.d.ts +11 -0
  56. package/dist/utilities/initReq.d.ts.map +1 -0
  57. package/dist/utilities/initReq.js +46 -0
  58. package/dist/utilities/initReq.js.map +1 -0
  59. package/dist/views/Account/Settings/index.d.ts +2 -1
  60. package/dist/views/Account/Settings/index.d.ts.map +1 -1
  61. package/dist/views/Account/Settings/index.js +3 -2
  62. package/dist/views/Account/Settings/index.js.map +1 -1
  63. package/dist/views/Account/index.d.ts.map +1 -1
  64. package/dist/views/Account/index.js +3 -1
  65. package/dist/views/Account/index.js.map +1 -1
  66. package/dist/views/CreateFirstUser/index.client.d.ts.map +1 -1
  67. package/dist/views/CreateFirstUser/index.client.js +35 -16
  68. package/dist/views/CreateFirstUser/index.client.js.map +1 -1
  69. package/dist/views/Dashboard/Default/index.d.ts +8 -1
  70. package/dist/views/Dashboard/Default/index.d.ts.map +1 -1
  71. package/dist/views/Dashboard/Default/index.js +14 -2
  72. package/dist/views/Dashboard/Default/index.js.map +1 -1
  73. package/dist/views/Dashboard/Default/index.scss +5 -0
  74. package/dist/views/Dashboard/index.d.ts.map +1 -1
  75. package/dist/views/Dashboard/index.js +16 -1
  76. package/dist/views/Dashboard/index.js.map +1 -1
  77. package/dist/views/Document/getDocumentData.d.ts +5 -2
  78. package/dist/views/Document/getDocumentData.d.ts.map +1 -1
  79. package/dist/views/Document/getDocumentData.js +13 -2
  80. package/dist/views/Document/getDocumentData.js.map +1 -1
  81. package/dist/views/Edit/Default/index.d.ts.map +1 -1
  82. package/dist/views/Edit/Default/index.js +127 -14
  83. package/dist/views/Edit/Default/index.js.map +1 -1
  84. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js +3 -0
  85. package/dist/views/ForgotPassword/ForgotPasswordForm/index.js.map +1 -1
  86. package/dist/views/ForgotPassword/index.js +2 -2
  87. package/dist/views/ForgotPassword/index.js.map +1 -1
  88. package/dist/views/List/Default/index.d.ts.map +1 -1
  89. package/dist/views/List/Default/index.js +62 -58
  90. package/dist/views/List/Default/index.js.map +1 -1
  91. package/dist/views/List/Default/index.scss +1 -1
  92. package/dist/views/List/index.d.ts.map +1 -1
  93. package/dist/views/List/index.js +1 -0
  94. package/dist/views/List/index.js.map +1 -1
  95. package/dist/views/LivePreview/index.client.d.ts.map +1 -1
  96. package/dist/views/LivePreview/index.client.js +214 -200
  97. package/dist/views/LivePreview/index.client.js.map +1 -1
  98. package/dist/views/LivePreview/usePopupWindow.js +119 -74
  99. package/dist/views/LivePreview/usePopupWindow.js.map +1 -1
  100. package/dist/views/Login/LoginForm/index.js +2 -2
  101. package/dist/views/Login/LoginForm/index.js.map +1 -1
  102. package/dist/views/Version/Default/index.d.ts.map +1 -1
  103. package/dist/views/Version/Default/index.js +2 -0
  104. package/dist/views/Version/Default/index.js.map +1 -1
  105. package/dist/views/Version/Restore/index.d.ts.map +1 -1
  106. package/dist/views/Version/Restore/index.js +8 -14
  107. package/dist/views/Version/Restore/index.js.map +1 -1
  108. package/dist/views/Version/SelectComparison/index.d.ts.map +1 -1
  109. package/dist/views/Version/SelectComparison/index.js +24 -3
  110. package/dist/views/Version/SelectComparison/index.js.map +1 -1
  111. package/dist/views/Version/SelectComparison/types.d.ts +1 -0
  112. package/dist/views/Version/SelectComparison/types.d.ts.map +1 -1
  113. package/dist/views/Version/SelectComparison/types.js.map +1 -1
  114. package/dist/views/Versions/buildColumns.d.ts.map +1 -1
  115. package/dist/views/Versions/buildColumns.js +63 -48
  116. package/dist/views/Versions/buildColumns.js.map +1 -1
  117. package/dist/views/Versions/cells/AutosaveCell/index.d.ts.map +1 -1
  118. package/dist/views/Versions/cells/AutosaveCell/index.js +48 -20
  119. package/dist/views/Versions/cells/AutosaveCell/index.js.map +1 -1
  120. package/dist/views/Versions/index.d.ts.map +1 -1
  121. package/dist/views/Versions/index.js +23 -6
  122. package/dist/views/Versions/index.js.map +1 -1
  123. package/dist/withPayload.d.ts.map +1 -1
  124. package/dist/withPayload.js +4 -4
  125. package/dist/withPayload.js.map +1 -1
  126. package/package.json +23 -15
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["getTranslation","Button","Card","Gutter","SetStepNav","SetViewActions","EntityType","formatAdminURL","getCreateMappedComponent","RenderComponent","React","Fragment","baseClass","DefaultDashboard","props","i18n","t","Link","locale","navGroups","params","payload","config","admin","components","afterDashboard","beforeDashboard","routes","adminRoute","permissions","searchParams","user","createMappedComponent","importMap","serverProps","mappedBeforeDashboards","undefined","mappedAfterDashboards","_jsxs","className","_jsx","nav","actions","mappedComponent","length","map","entities","label","groupIndex","type","entity","entityIndex","title","buttonAriaLabel","createHREF","href","hasCreatePermission","collection","labels","plural","path","slug","collections","create","permission","global","singular","buttonStyle","el","icon","iconStyle","round","to","id","titleAs"],"sources":["../../../../src/views/Dashboard/Default/index.tsx"],"sourcesContent":["import type { groupNavItems } from '@payloadcms/ui/shared'\nimport type { Permissions, ServerProps, VisibleEntities } from 'payload'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport { Button, Card, Gutter, SetStepNav, SetViewActions } from '@payloadcms/ui'\nimport {\n EntityType,\n formatAdminURL,\n getCreateMappedComponent,\n RenderComponent,\n} from '@payloadcms/ui/shared'\nimport React, { Fragment } from 'react'\n\nimport './index.scss'\n\nconst baseClass = 'dashboard'\n\nexport type DashboardProps = {\n Link: React.ComponentType<any>\n navGroups?: ReturnType<typeof groupNavItems>\n permissions: Permissions\n visibleEntities: VisibleEntities\n} & ServerProps\n\nexport const DefaultDashboard: React.FC<DashboardProps> = (props) => {\n const {\n i18n,\n i18n: { t },\n Link,\n locale,\n navGroups,\n params,\n payload: {\n config: {\n admin: {\n components: { afterDashboard, beforeDashboard },\n },\n routes: { admin: adminRoute },\n },\n },\n payload,\n permissions,\n searchParams,\n user,\n } = props\n\n const createMappedComponent = getCreateMappedComponent({\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user,\n },\n })\n\n const mappedBeforeDashboards = createMappedComponent(\n beforeDashboard,\n undefined,\n undefined,\n 'beforeDashboard',\n )\n\n const mappedAfterDashboards = createMappedComponent(\n afterDashboard,\n undefined,\n undefined,\n 'afterDashboard',\n )\n\n return (\n <div className={baseClass}>\n <SetStepNav nav={[]} />\n <SetViewActions actions={[]} />\n <Gutter className={`${baseClass}__wrap`}>\n <RenderComponent mappedComponent={mappedBeforeDashboards} />\n <Fragment>\n <SetViewActions actions={[]} />\n {!navGroups || navGroups?.length === 0 ? (\n <p>no nav groups....</p>\n ) : (\n navGroups.map(({ entities, label }, groupIndex) => {\n return (\n <div className={`${baseClass}__group`} key={groupIndex}>\n <h2 className={`${baseClass}__label`}>{label}</h2>\n <ul className={`${baseClass}__card-list`}>\n {entities.map(({ type, entity }, entityIndex) => {\n let title: string\n let buttonAriaLabel: string\n let createHREF: string\n let href: string\n let hasCreatePermission: boolean\n\n if (type === EntityType.collection) {\n title = getTranslation(entity.labels.plural, i18n)\n\n buttonAriaLabel = t('general:showAllLabel', { label: title })\n\n href = formatAdminURL({ adminRoute, path: `/collections/${entity.slug}` })\n\n createHREF = formatAdminURL({\n adminRoute,\n path: `/collections/${entity.slug}/create`,\n })\n\n hasCreatePermission =\n permissions?.collections?.[entity.slug]?.create?.permission\n }\n\n if (type === EntityType.global) {\n title = getTranslation(entity.label, i18n)\n\n buttonAriaLabel = t('general:editLabel', {\n label: getTranslation(entity.label, i18n),\n })\n\n href = formatAdminURL({\n adminRoute,\n path: `/globals/${entity.slug}`,\n })\n }\n\n return (\n <li key={entityIndex}>\n <Card\n actions={\n hasCreatePermission && type === EntityType.collection ? (\n <Button\n aria-label={t('general:createNewLabel', {\n label: getTranslation(entity.labels.singular, i18n),\n })}\n buttonStyle=\"icon-label\"\n el=\"link\"\n icon=\"plus\"\n iconStyle=\"with-border\"\n Link={Link}\n round\n to={createHREF}\n />\n ) : undefined\n }\n buttonAriaLabel={buttonAriaLabel}\n href={href}\n id={`card-${entity.slug}`}\n Link={Link}\n title={title}\n titleAs=\"h3\"\n />\n </li>\n )\n })}\n </ul>\n </div>\n )\n })\n )}\n </Fragment>\n <RenderComponent mappedComponent={mappedAfterDashboards} />\n </Gutter>\n </div>\n )\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["getTranslation","Button","Card","Gutter","Locked","SetStepNav","SetViewActions","EntityType","formatAdminURL","getCreateMappedComponent","RenderComponent","React","Fragment","baseClass","DefaultDashboard","props","globalData","i18n","t","Link","locale","navGroups","params","payload","config","admin","components","afterDashboard","beforeDashboard","routes","adminRoute","permissions","searchParams","user","createMappedComponent","importMap","serverProps","mappedBeforeDashboards","undefined","mappedAfterDashboards","_jsxs","className","_jsx","nav","actions","mappedComponent","length","map","entities","label","groupIndex","type","entity","entityIndex","title","buttonAriaLabel","createHREF","href","hasCreatePermission","lockStatus","userEditing","collection","labels","plural","path","slug","collections","create","permission","global","globalLockData","find","data","_isLocked","_userEditing","id","singular","buttonStyle","el","icon","iconStyle","round","to","titleAs"],"sources":["../../../../src/views/Dashboard/Default/index.tsx"],"sourcesContent":["import type { groupNavItems } from '@payloadcms/ui/shared'\nimport type { ClientUser, Permissions, ServerProps, VisibleEntities } from 'payload'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport { Button, Card, Gutter, Locked, SetStepNav, SetViewActions } from '@payloadcms/ui'\nimport {\n EntityType,\n formatAdminURL,\n getCreateMappedComponent,\n RenderComponent,\n} from '@payloadcms/ui/shared'\nimport React, { Fragment } from 'react'\n\nimport './index.scss'\n\nconst baseClass = 'dashboard'\n\nexport type DashboardProps = {\n globalData: Array<{ data: { _isLocked: boolean; _userEditing: ClientUser | null }; slug: string }>\n Link: React.ComponentType<any>\n navGroups?: ReturnType<typeof groupNavItems>\n permissions: Permissions\n visibleEntities: VisibleEntities\n} & ServerProps\n\nexport const DefaultDashboard: React.FC<DashboardProps> = (props) => {\n const {\n globalData,\n i18n,\n i18n: { t },\n Link,\n locale,\n navGroups,\n params,\n payload: {\n config: {\n admin: {\n components: { afterDashboard, beforeDashboard },\n },\n routes: { admin: adminRoute },\n },\n },\n payload,\n permissions,\n searchParams,\n user,\n } = props\n\n const createMappedComponent = getCreateMappedComponent({\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user,\n },\n })\n\n const mappedBeforeDashboards = createMappedComponent(\n beforeDashboard,\n undefined,\n undefined,\n 'beforeDashboard',\n )\n\n const mappedAfterDashboards = createMappedComponent(\n afterDashboard,\n undefined,\n undefined,\n 'afterDashboard',\n )\n\n return (\n <div className={baseClass}>\n <SetStepNav nav={[]} />\n <SetViewActions actions={[]} />\n <Gutter className={`${baseClass}__wrap`}>\n <RenderComponent mappedComponent={mappedBeforeDashboards} />\n <Fragment>\n <SetViewActions actions={[]} />\n {!navGroups || navGroups?.length === 0 ? (\n <p>no nav groups....</p>\n ) : (\n navGroups.map(({ entities, label }, groupIndex) => {\n return (\n <div className={`${baseClass}__group`} key={groupIndex}>\n <h2 className={`${baseClass}__label`}>{label}</h2>\n <ul className={`${baseClass}__card-list`}>\n {entities.map(({ type, entity }, entityIndex) => {\n let title: string\n let buttonAriaLabel: string\n let createHREF: string\n let href: string\n let hasCreatePermission: boolean\n let lockStatus = null\n let userEditing = null\n\n if (type === EntityType.collection) {\n title = getTranslation(entity.labels.plural, i18n)\n\n buttonAriaLabel = t('general:showAllLabel', { label: title })\n\n href = formatAdminURL({ adminRoute, path: `/collections/${entity.slug}` })\n\n createHREF = formatAdminURL({\n adminRoute,\n path: `/collections/${entity.slug}/create`,\n })\n\n hasCreatePermission =\n permissions?.collections?.[entity.slug]?.create?.permission\n }\n\n if (type === EntityType.global) {\n title = getTranslation(entity.label, i18n)\n\n buttonAriaLabel = t('general:editLabel', {\n label: getTranslation(entity.label, i18n),\n })\n\n href = formatAdminURL({\n adminRoute,\n path: `/globals/${entity.slug}`,\n })\n\n // Find the lock status for the global\n const globalLockData = globalData.find(\n (global) => global.slug === entity.slug,\n )\n if (globalLockData) {\n lockStatus = globalLockData.data._isLocked\n userEditing = globalLockData.data._userEditing\n }\n }\n\n return (\n <li key={entityIndex}>\n <Card\n actions={\n lockStatus && user?.id !== userEditing?.id ? (\n <Locked className={`${baseClass}__locked`} user={userEditing} />\n ) : hasCreatePermission && type === EntityType.collection ? (\n <Button\n aria-label={t('general:createNewLabel', {\n label: getTranslation(entity.labels.singular, i18n),\n })}\n buttonStyle=\"icon-label\"\n el=\"link\"\n icon=\"plus\"\n iconStyle=\"with-border\"\n Link={Link}\n round\n to={createHREF}\n />\n ) : undefined\n }\n buttonAriaLabel={buttonAriaLabel}\n href={href}\n id={`card-${entity.slug}`}\n Link={Link}\n title={title}\n titleAs=\"h3\"\n />\n </li>\n )\n })}\n </ul>\n </div>\n )\n })\n )}\n </Fragment>\n <RenderComponent mappedComponent={mappedAfterDashboards} />\n </Gutter>\n </div>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -35,6 +35,11 @@
35
35
  }
36
36
  }
37
37
 
38
+ &__locked.locked {
39
+ align-items: unset;
40
+ justify-content: unset;
41
+ }
42
+
38
43
  @include large-break {
39
44
  --cols: 4;
40
45
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Dashboard/index.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AAU7C,OAAO,KAAmB,MAAM,OAAO,CAAA;AAIvC,OAAO,EAAE,yBAAyB,EAAE,MAAM,WAAW,CAAA;AAIrD,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAqF9C,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Dashboard/index.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AAU7C,OAAO,KAAmB,MAAM,OAAO,CAAA;AAIvC,OAAO,EAAE,yBAAyB,EAAE,MAAM,WAAW,CAAA;AAIrD,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAiH9C,CAAA"}
@@ -6,7 +6,7 @@ import React, { Fragment } from 'react';
6
6
  import { DefaultDashboard } from './Default/index.js';
7
7
  export { generateDashboardMetadata } from './meta.js';
8
8
  const Link = LinkImport.default || LinkImport;
9
- export const Dashboard = ({
9
+ export const Dashboard = async ({
10
10
  initPageResult,
11
11
  params,
12
12
  searchParams
@@ -27,6 +27,20 @@ export const Dashboard = ({
27
27
  const CustomDashboardComponent = config.admin.components?.views?.Dashboard;
28
28
  const collections = config.collections.filter(collection => permissions?.collections?.[collection.slug]?.read?.permission && visibleEntities.collections.includes(collection.slug));
29
29
  const globals = config.globals.filter(global => permissions?.globals?.[global.slug]?.read?.permission && visibleEntities.globals.includes(global.slug));
30
+ const globalSlugs = config.globals.map(global => global.slug);
31
+ // Filter the slugs based on permissions and visibility
32
+ const filteredGlobalSlugs = globalSlugs.filter(slug => permissions?.globals?.[slug]?.read?.permission && visibleEntities.globals.includes(slug));
33
+ const globalData = await Promise.all(filteredGlobalSlugs.map(async slug => {
34
+ const data = await payload.findGlobal({
35
+ slug,
36
+ depth: 0,
37
+ includeLockStatus: true
38
+ });
39
+ return {
40
+ slug,
41
+ data
42
+ };
43
+ }));
30
44
  const navGroups = groupNavItems([...(collections.map(collection => {
31
45
  const entityToGroup = {
32
46
  type: EntityType.collection,
@@ -43,6 +57,7 @@ export const Dashboard = ({
43
57
  const createMappedComponent = getCreateMappedComponent({
44
58
  importMap: payload.importMap,
45
59
  serverProps: {
60
+ globalData,
46
61
  i18n,
47
62
  Link,
48
63
  locale,
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["HydrateAuthProvider","EntityType","getCreateMappedComponent","groupNavItems","RenderComponent","LinkImport","React","Fragment","DefaultDashboard","generateDashboardMetadata","Link","default","Dashboard","initPageResult","params","searchParams","locale","permissions","req","i18n","payload","config","user","visibleEntities","CustomDashboardComponent","admin","components","views","collections","filter","collection","slug","read","permission","includes","globals","global","navGroups","map","entityToGroup","type","entity","createMappedComponent","importMap","serverProps","mappedDashboardComponent","Component","undefined","_jsxs","_jsx","clientProps","mappedComponent"],"sources":["../../../src/views/Dashboard/index.tsx"],"sourcesContent":["import type { EntityToGroup } from '@payloadcms/ui/shared'\nimport type { AdminViewProps } from 'payload'\n\nimport { HydrateAuthProvider } from '@payloadcms/ui'\nimport {\n EntityType,\n getCreateMappedComponent,\n groupNavItems,\n RenderComponent,\n} from '@payloadcms/ui/shared'\nimport LinkImport from 'next/link.js'\nimport React, { Fragment } from 'react'\n\nimport { DefaultDashboard } from './Default/index.js'\n\nexport { generateDashboardMetadata } from './meta.js'\n\nconst Link = (LinkImport.default || LinkImport) as unknown as typeof LinkImport.default\n\nexport const Dashboard: React.FC<AdminViewProps> = ({ initPageResult, params, searchParams }) => {\n const {\n locale,\n permissions,\n req: {\n i18n,\n payload: { config },\n payload,\n user,\n },\n visibleEntities,\n } = initPageResult\n\n const CustomDashboardComponent = config.admin.components?.views?.Dashboard\n\n const collections = config.collections.filter(\n (collection) =>\n permissions?.collections?.[collection.slug]?.read?.permission &&\n visibleEntities.collections.includes(collection.slug),\n )\n\n const globals = config.globals.filter(\n (global) =>\n permissions?.globals?.[global.slug]?.read?.permission &&\n visibleEntities.globals.includes(global.slug),\n )\n\n const navGroups = groupNavItems(\n [\n ...(collections.map((collection) => {\n const entityToGroup: EntityToGroup = {\n type: EntityType.collection,\n entity: collection,\n }\n\n return entityToGroup\n }) ?? []),\n ...(globals.map((global) => {\n const entityToGroup: EntityToGroup = {\n type: EntityType.global,\n entity: global,\n }\n\n return entityToGroup\n }) ?? []),\n ],\n permissions,\n i18n,\n )\n\n const createMappedComponent = getCreateMappedComponent({\n importMap: payload.importMap,\n serverProps: {\n i18n,\n Link,\n locale,\n navGroups,\n params,\n payload,\n permissions,\n searchParams,\n user,\n visibleEntities,\n },\n })\n\n const mappedDashboardComponent = createMappedComponent(\n CustomDashboardComponent?.Component,\n undefined,\n DefaultDashboard,\n 'CustomDashboardComponent.Component',\n )\n\n return (\n <Fragment>\n <HydrateAuthProvider permissions={permissions} />\n <RenderComponent\n clientProps={{\n Link,\n locale,\n }}\n mappedComponent={mappedDashboardComponent}\n />\n </Fragment>\n )\n}\n"],"mappings":";AAGA,SAASA,mBAAmB,QAAQ;AACpC,SACEC,UAAU,EACVC,wBAAwB,EACxBC,aAAa,EACbC,eAAe,QACV;AACP,OAAOC,UAAA,MAAgB;AACvB,OAAOC,KAAA,IAASC,QAAQ,QAAQ;AAEhC,SAASC,gBAAgB,QAAQ;AAEjC,SAASC,yBAAyB,QAAQ;AAE1C,MAAMC,IAAA,GAAQL,UAAA,CAAWM,OAAO,IAAIN,UAAA;AAEpC,OAAO,MAAMO,SAAA,GAAsCA,CAAC;EAAEC,cAAc;EAAEC,MAAM;EAAEC;AAAY,CAAE;EAC1F,MAAM;IACJC,MAAM;IACNC,WAAW;IACXC,GAAA,EAAK;MACHC,IAAI;MACJC,OAAA,EAAS;QAAEC;MAAM,CAAE;MACnBD,OAAO;MACPE;IAAI,CACL;IACDC;EAAe,CAChB,GAAGV,cAAA;EAEJ,MAAMW,wBAAA,GAA2BH,MAAA,CAAOI,KAAK,CAACC,UAAU,EAAEC,KAAA,EAAOf,SAAA;EAEjE,MAAMgB,WAAA,GAAcP,MAAA,CAAOO,WAAW,CAACC,MAAM,CAC1CC,UAAA,IACCb,WAAA,EAAaW,WAAA,GAAcE,UAAA,CAAWC,IAAI,CAAC,EAAEC,IAAA,EAAMC,UAAA,IACnDV,eAAA,CAAgBK,WAAW,CAACM,QAAQ,CAACJ,UAAA,CAAWC,IAAI;EAGxD,MAAMI,OAAA,GAAUd,MAAA,CAAOc,OAAO,CAACN,MAAM,CAClCO,MAAA,IACCnB,WAAA,EAAakB,OAAA,GAAUC,MAAA,CAAOL,IAAI,CAAC,EAAEC,IAAA,EAAMC,UAAA,IAC3CV,eAAA,CAAgBY,OAAO,CAACD,QAAQ,CAACE,MAAA,CAAOL,IAAI;EAGhD,MAAMM,SAAA,GAAYlC,aAAA,CAChB,C,IACMyB,WAAA,CAAYU,GAAG,CAAER,UAAA;IACnB,MAAMS,aAAA,GAA+B;MACnCC,IAAA,EAAMvC,UAAA,CAAW6B,UAAU;MAC3BW,MAAA,EAAQX;IACV;IAEA,OAAOS,aAAA;EACT,MAAM,EAAE,G,IACJJ,OAAA,CAAQG,GAAG,CAAEF,MAAA;IACf,MAAMG,aAAA,GAA+B;MACnCC,IAAA,EAAMvC,UAAA,CAAWmC,MAAM;MACvBK,MAAA,EAAQL;IACV;IAEA,OAAOG,aAAA;EACT,MAAM,EAAE,EACT,EACDtB,WAAA,EACAE,IAAA;EAGF,MAAMuB,qBAAA,GAAwBxC,wBAAA,CAAyB;IACrDyC,SAAA,EAAWvB,OAAA,CAAQuB,SAAS;IAC5BC,WAAA,EAAa;MACXzB,IAAA;MACAT,IAAA;MACAM,MAAA;MACAqB,SAAA;MACAvB,MAAA;MACAM,OAAA;MACAH,WAAA;MACAF,YAAA;MACAO,IAAA;MACAC;IACF;EACF;EAEA,MAAMsB,wBAAA,GAA2BH,qBAAA,CAC/BlB,wBAAA,EAA0BsB,SAAA,EAC1BC,SAAA,EACAvC,gBAAA,EACA;EAGF,oBACEwC,KAAA,CAACzC,QAAA;4BACC0C,IAAA,CAACjD,mBAAA;MAAoBiB,WAAA,EAAaA;qBAClCgC,IAAA,CAAC7C,eAAA;MACC8C,WAAA,EAAa;QACXxC,IAAA;QACAM;MACF;MACAmC,eAAA,EAAiBN;;;AAIzB","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["HydrateAuthProvider","EntityType","getCreateMappedComponent","groupNavItems","RenderComponent","LinkImport","React","Fragment","DefaultDashboard","generateDashboardMetadata","Link","default","Dashboard","initPageResult","params","searchParams","locale","permissions","req","i18n","payload","config","user","visibleEntities","CustomDashboardComponent","admin","components","views","collections","filter","collection","slug","read","permission","includes","globals","global","globalSlugs","map","filteredGlobalSlugs","globalData","Promise","all","data","findGlobal","depth","includeLockStatus","navGroups","entityToGroup","type","entity","createMappedComponent","importMap","serverProps","mappedDashboardComponent","Component","undefined","_jsxs","_jsx","clientProps","mappedComponent"],"sources":["../../../src/views/Dashboard/index.tsx"],"sourcesContent":["import type { EntityToGroup } from '@payloadcms/ui/shared'\nimport type { AdminViewProps } from 'payload'\n\nimport { HydrateAuthProvider } from '@payloadcms/ui'\nimport {\n EntityType,\n getCreateMappedComponent,\n groupNavItems,\n RenderComponent,\n} from '@payloadcms/ui/shared'\nimport LinkImport from 'next/link.js'\nimport React, { Fragment } from 'react'\n\nimport { DefaultDashboard } from './Default/index.js'\n\nexport { generateDashboardMetadata } from './meta.js'\n\nconst Link = (LinkImport.default || LinkImport) as unknown as typeof LinkImport.default\n\nexport const Dashboard: React.FC<AdminViewProps> = async ({\n initPageResult,\n params,\n searchParams,\n}) => {\n const {\n locale,\n permissions,\n req: {\n i18n,\n payload: { config },\n payload,\n user,\n },\n visibleEntities,\n } = initPageResult\n\n const CustomDashboardComponent = config.admin.components?.views?.Dashboard\n\n const collections = config.collections.filter(\n (collection) =>\n permissions?.collections?.[collection.slug]?.read?.permission &&\n visibleEntities.collections.includes(collection.slug),\n )\n\n const globals = config.globals.filter(\n (global) =>\n permissions?.globals?.[global.slug]?.read?.permission &&\n visibleEntities.globals.includes(global.slug),\n )\n\n const globalSlugs = config.globals.map((global) => global.slug)\n\n // Filter the slugs based on permissions and visibility\n const filteredGlobalSlugs = globalSlugs.filter(\n (slug) =>\n permissions?.globals?.[slug]?.read?.permission && visibleEntities.globals.includes(slug),\n )\n\n const globalData = await Promise.all(\n filteredGlobalSlugs.map(async (slug) => {\n const data = await payload.findGlobal({\n slug,\n depth: 0,\n includeLockStatus: true,\n })\n\n return {\n slug,\n data,\n }\n }),\n )\n\n const navGroups = groupNavItems(\n [\n ...(collections.map((collection) => {\n const entityToGroup: EntityToGroup = {\n type: EntityType.collection,\n entity: collection,\n }\n\n return entityToGroup\n }) ?? []),\n ...(globals.map((global) => {\n const entityToGroup: EntityToGroup = {\n type: EntityType.global,\n entity: global,\n }\n\n return entityToGroup\n }) ?? []),\n ],\n permissions,\n i18n,\n )\n\n const createMappedComponent = getCreateMappedComponent({\n importMap: payload.importMap,\n serverProps: {\n globalData,\n i18n,\n Link,\n locale,\n navGroups,\n params,\n payload,\n permissions,\n searchParams,\n user,\n visibleEntities,\n },\n })\n\n const mappedDashboardComponent = createMappedComponent(\n CustomDashboardComponent?.Component,\n undefined,\n DefaultDashboard,\n 'CustomDashboardComponent.Component',\n )\n\n return (\n <Fragment>\n <HydrateAuthProvider permissions={permissions} />\n <RenderComponent\n clientProps={{\n Link,\n locale,\n }}\n mappedComponent={mappedDashboardComponent}\n />\n </Fragment>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,4 +1,4 @@
1
- import type { Data, Locale, PayloadRequest, SanitizedCollectionConfig, SanitizedGlobalConfig } from 'payload';
1
+ import type { Data, FormState, Locale, PayloadRequest, SanitizedCollectionConfig, SanitizedGlobalConfig } from 'payload';
2
2
  export declare const getDocumentData: (args: {
3
3
  collectionConfig?: SanitizedCollectionConfig;
4
4
  globalConfig?: SanitizedGlobalConfig;
@@ -6,5 +6,8 @@ export declare const getDocumentData: (args: {
6
6
  locale: Locale;
7
7
  req: PayloadRequest;
8
8
  schemaPath?: string;
9
- }) => Promise<Data>;
9
+ }) => Promise<{
10
+ data: Data;
11
+ formState: FormState;
12
+ }>;
10
13
  //# sourceMappingURL=getDocumentData.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"getDocumentData.d.ts","sourceRoot":"","sources":["../../../src/views/Document/getDocumentData.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,IAAI,EACJ,MAAM,EACN,cAAc,EACd,yBAAyB,EACzB,qBAAqB,EACtB,MAAM,SAAS,CAAA;AAKhB,eAAO,MAAM,eAAe,SAAgB;IAC1C,gBAAgB,CAAC,EAAE,yBAAyB,CAAA;IAC5C,YAAY,CAAC,EAAE,qBAAqB,CAAA;IACpC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACpB,MAAM,EAAE,MAAM,CAAA;IACd,GAAG,EAAE,cAAc,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB,KAAG,OAAO,CAAC,IAAI,CA8Bf,CAAA"}
1
+ {"version":3,"file":"getDocumentData.d.ts","sourceRoot":"","sources":["../../../src/views/Document/getDocumentData.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,IAAI,EACJ,SAAS,EACT,MAAM,EACN,cAAc,EACd,yBAAyB,EACzB,qBAAqB,EACtB,MAAM,SAAS,CAAA;AAKhB,eAAO,MAAM,eAAe,SAAgB;IAC1C,gBAAgB,CAAC,EAAE,yBAAyB,CAAA;IAC5C,YAAY,CAAC,EAAE,qBAAqB,CAAA;IACpC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACpB,MAAM,EAAE,MAAM,CAAA;IACd,GAAG,EAAE,cAAc,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB,KAAG,OAAO,CAAC;IACV,IAAI,EAAE,IAAI,CAAA;IACV,SAAS,EAAE,SAAS,CAAA;CACrB,CAuCA,CAAA"}
@@ -11,7 +11,9 @@ export const getDocumentData = async args => {
11
11
  } = args;
12
12
  const schemaPath = schemaPathFromProps || collectionConfig?.slug || globalConfig?.slug;
13
13
  try {
14
- const formState = await buildFormState({
14
+ const {
15
+ state: formState
16
+ } = await buildFormState({
15
17
  req: {
16
18
  ...req,
17
19
  data: {
@@ -32,7 +34,16 @@ export const getDocumentData = async args => {
32
34
  } catch (error) {
33
35
  console.error('Error getting document data', error) // eslint-disable-line no-console
34
36
  ;
35
- return {};
37
+ return {
38
+ data: null,
39
+ formState: {
40
+ fields: {
41
+ initialValue: undefined,
42
+ valid: false,
43
+ value: undefined
44
+ }
45
+ }
46
+ };
36
47
  }
37
48
  };
38
49
  //# sourceMappingURL=getDocumentData.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"getDocumentData.js","names":["buildFormState","reduceFieldsToValues","getDocumentData","args","id","collectionConfig","globalConfig","locale","req","schemaPath","schemaPathFromProps","slug","formState","data","collectionSlug","globalSlug","code","operation","error","console"],"sources":["../../../src/views/Document/getDocumentData.tsx"],"sourcesContent":["import type {\n Data,\n Locale,\n PayloadRequest,\n SanitizedCollectionConfig,\n SanitizedGlobalConfig,\n} from 'payload'\n\nimport { buildFormState } from '@payloadcms/ui/utilities/buildFormState'\nimport { reduceFieldsToValues } from 'payload/shared'\n\nexport const getDocumentData = async (args: {\n collectionConfig?: SanitizedCollectionConfig\n globalConfig?: SanitizedGlobalConfig\n id?: number | string\n locale: Locale\n req: PayloadRequest\n schemaPath?: string\n}): Promise<Data> => {\n const { id, collectionConfig, globalConfig, locale, req, schemaPath: schemaPathFromProps } = args\n\n const schemaPath = schemaPathFromProps || collectionConfig?.slug || globalConfig?.slug\n\n try {\n const formState = await buildFormState({\n req: {\n ...req,\n data: {\n id,\n collectionSlug: collectionConfig?.slug,\n globalSlug: globalConfig?.slug,\n locale: locale?.code,\n operation: (collectionConfig && id) || globalConfig ? 'update' : 'create',\n schemaPath,\n },\n },\n })\n\n const data = reduceFieldsToValues(formState, true)\n\n return {\n data,\n formState,\n }\n } catch (error) {\n console.error('Error getting document data', error) // eslint-disable-line no-console\n return {}\n }\n}\n"],"mappings":"AAQA,SAASA,cAAc,QAAQ;AAC/B,SAASC,oBAAoB,QAAQ;AAErC,OAAO,MAAMC,eAAA,GAAkB,MAAOC,IAAA;EAQpC,MAAM;IAAEC,EAAE;IAAEC,gBAAgB;IAAEC,YAAY;IAAEC,MAAM;IAAEC,GAAG;IAAEC,UAAA,EAAYC;EAAmB,CAAE,GAAGP,IAAA;EAE7F,MAAMM,UAAA,GAAaC,mBAAA,IAAuBL,gBAAA,EAAkBM,IAAA,IAAQL,YAAA,EAAcK,IAAA;EAElF,IAAI;IACF,MAAMC,SAAA,GAAY,MAAMZ,cAAA,CAAe;MACrCQ,GAAA,EAAK;QACH,GAAGA,GAAG;QACNK,IAAA,EAAM;UACJT,EAAA;UACAU,cAAA,EAAgBT,gBAAA,EAAkBM,IAAA;UAClCI,UAAA,EAAYT,YAAA,EAAcK,IAAA;UAC1BJ,MAAA,EAAQA,MAAA,EAAQS,IAAA;UAChBC,SAAA,EAAWZ,gBAAC,IAAoBD,EAAA,IAAOE,YAAA,GAAe,WAAW;UACjEG;QACF;MACF;IACF;IAEA,MAAMI,IAAA,GAAOZ,oBAAA,CAAqBW,SAAA,EAAW;IAE7C,OAAO;MACLC,IAAA;MACAD;IACF;EACF,EAAE,OAAOM,KAAA,EAAO;IACdC,OAAA,CAAQD,KAAK,CAAC,+BAA+BA,KAAA,EAAO;IAAA;IACpD,OAAO,CAAC;EACV;AACF","ignoreList":[]}
1
+ {"version":3,"file":"getDocumentData.js","names":["buildFormState","reduceFieldsToValues","getDocumentData","args","id","collectionConfig","globalConfig","locale","req","schemaPath","schemaPathFromProps","slug","state","formState","data","collectionSlug","globalSlug","code","operation","error","console","fields","initialValue","undefined","valid","value"],"sources":["../../../src/views/Document/getDocumentData.tsx"],"sourcesContent":["import type {\n Data,\n FormState,\n Locale,\n PayloadRequest,\n SanitizedCollectionConfig,\n SanitizedGlobalConfig,\n} from 'payload'\n\nimport { buildFormState } from '@payloadcms/ui/utilities/buildFormState'\nimport { reduceFieldsToValues } from 'payload/shared'\n\nexport const getDocumentData = async (args: {\n collectionConfig?: SanitizedCollectionConfig\n globalConfig?: SanitizedGlobalConfig\n id?: number | string\n locale: Locale\n req: PayloadRequest\n schemaPath?: string\n}): Promise<{\n data: Data\n formState: FormState\n}> => {\n const { id, collectionConfig, globalConfig, locale, req, schemaPath: schemaPathFromProps } = args\n\n const schemaPath = schemaPathFromProps || collectionConfig?.slug || globalConfig?.slug\n\n try {\n const { state: formState } = await buildFormState({\n req: {\n ...req,\n data: {\n id,\n collectionSlug: collectionConfig?.slug,\n globalSlug: globalConfig?.slug,\n locale: locale?.code,\n operation: (collectionConfig && id) || globalConfig ? 'update' : 'create',\n schemaPath,\n },\n },\n })\n\n const data = reduceFieldsToValues(formState, true)\n\n return {\n data,\n formState,\n }\n } catch (error) {\n console.error('Error getting document data', error) // eslint-disable-line no-console\n return {\n data: null,\n formState: {\n fields: {\n initialValue: undefined,\n valid: false,\n value: undefined,\n },\n },\n }\n }\n}\n"],"mappings":"AASA,SAASA,cAAc,QAAQ;AAC/B,SAASC,oBAAoB,QAAQ;AAErC,OAAO,MAAMC,eAAA,GAAkB,MAAOC,IAAA;EAWpC,MAAM;IAAEC,EAAE;IAAEC,gBAAgB;IAAEC,YAAY;IAAEC,MAAM;IAAEC,GAAG;IAAEC,UAAA,EAAYC;EAAmB,CAAE,GAAGP,IAAA;EAE7F,MAAMM,UAAA,GAAaC,mBAAA,IAAuBL,gBAAA,EAAkBM,IAAA,IAAQL,YAAA,EAAcK,IAAA;EAElF,IAAI;IACF,MAAM;MAAEC,KAAA,EAAOC;IAAS,CAAE,GAAG,MAAMb,cAAA,CAAe;MAChDQ,GAAA,EAAK;QACH,GAAGA,GAAG;QACNM,IAAA,EAAM;UACJV,EAAA;UACAW,cAAA,EAAgBV,gBAAA,EAAkBM,IAAA;UAClCK,UAAA,EAAYV,YAAA,EAAcK,IAAA;UAC1BJ,MAAA,EAAQA,MAAA,EAAQU,IAAA;UAChBC,SAAA,EAAWb,gBAAC,IAAoBD,EAAA,IAAOE,YAAA,GAAe,WAAW;UACjEG;QACF;MACF;IACF;IAEA,MAAMK,IAAA,GAAOb,oBAAA,CAAqBY,SAAA,EAAW;IAE7C,OAAO;MACLC,IAAA;MACAD;IACF;EACF,EAAE,OAAOM,KAAA,EAAO;IACdC,OAAA,CAAQD,KAAK,CAAC,+BAA+BA,KAAA,EAAO;IAAA;IACpD,OAAO;MACLL,IAAA,EAAM;MACND,SAAA,EAAW;QACTQ,MAAA,EAAQ;UACNC,YAAA,EAAcC,SAAA;UACdC,KAAA,EAAO;UACPC,KAAA,EAAOF;QACT;MACF;IACF;EACF;AACF","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/views/Edit/Default/index.tsx"],"names":[],"mappings":"AAqBA,OAAO,KAA0C,MAAM,OAAO,CAAA;AAI9D,OAAO,cAAc,CAAA;AASrB,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAqQnC,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/views/Edit/Default/index.tsx"],"names":[],"mappings":"AA2BA,OAAO,KAA6D,MAAM,OAAO,CAAA;AAMjF,OAAO,cAAc,CAAA;AASrB,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAycnC,CAAA"}
@@ -2,9 +2,11 @@
2
2
 
3
3
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
4
4
  import { DocumentControls, DocumentFields, Form, OperationProvider, RenderComponent, Upload, useAuth, useConfig, useDocumentEvents, useDocumentInfo, useEditDepth, useUploadEdits } from '@payloadcms/ui';
5
- import { formatAdminURL, getFormState } from '@payloadcms/ui/shared';
5
+ import { formatAdminURL, getFormState, handleBackToDashboard, handleGoBack, handleTakeOver } from '@payloadcms/ui/shared';
6
6
  import { useRouter, useSearchParams } from 'next/navigation.js';
7
- import React, { Fragment, useCallback, useState } from 'react';
7
+ import React, { Fragment, useCallback, useEffect, useRef, useState } from 'react';
8
+ import { DocumentLocked } from '../../../elements/DocumentLocked/index.js';
9
+ import { DocumentTakeOver } from '../../../elements/DocumentTakeOver/index.js';
8
10
  import { LeaveWithoutSaving } from '../../../elements/LeaveWithoutSaving/index.js';
9
11
  import { Auth } from './Auth/index.js';
10
12
  import { SetDocumentStepNav } from './SetDocumentStepNav/index.js';
@@ -23,10 +25,12 @@ export const DefaultEditView = () => {
23
25
  BeforeDocument,
24
26
  BeforeFields,
25
27
  collectionSlug,
28
+ currentEditor,
26
29
  disableActions,
27
30
  disableCreate,
28
31
  disableLeaveWithoutSaving,
29
32
  docPermissions,
33
+ documentIsLocked,
30
34
  getDocPreferences,
31
35
  getVersions,
32
36
  globalSlug,
@@ -41,7 +45,11 @@ export const DefaultEditView = () => {
41
45
  onDuplicate,
42
46
  onSave: onSaveFromContext,
43
47
  redirectAfterDelete,
44
- redirectAfterDuplicate
48
+ redirectAfterDuplicate,
49
+ setCurrentEditor,
50
+ setDocumentIsLocked,
51
+ unlockDocument,
52
+ updateDocumentEditor
45
53
  } = useDocumentInfo();
46
54
  const {
47
55
  refreshCookieAsync,
@@ -81,15 +89,33 @@ export const DefaultEditView = () => {
81
89
  const operation = collectionSlug && !id ? 'create' : 'update';
82
90
  const auth = collectionConfig ? collectionConfig.auth : undefined;
83
91
  const upload = collectionConfig ? collectionConfig.upload : undefined;
84
- const preventLeaveWithoutSaving = (!(collectionConfig?.versions?.drafts && collectionConfig?.versions?.drafts?.autosave) || !(globalConfig?.versions?.drafts && globalConfig?.versions?.drafts?.autosave)) && !disableLeaveWithoutSaving;
85
- const classes = [baseClass, id && `${baseClass}--is-editing`];
92
+ const docConfig = collectionConfig || globalConfig;
93
+ const lockDocumentsProp = docConfig?.lockDocuments !== undefined ? docConfig?.lockDocuments : true;
94
+ const isLockingEnabled = lockDocumentsProp !== false;
95
+ let preventLeaveWithoutSaving = true;
96
+ if (collectionConfig) {
97
+ preventLeaveWithoutSaving = !(collectionConfig?.versions?.drafts && collectionConfig?.versions?.drafts?.autosave);
98
+ } else if (globalConfig) {
99
+ preventLeaveWithoutSaving = !(globalConfig?.versions?.drafts && globalConfig?.versions?.drafts?.autosave);
100
+ } else if (typeof disableLeaveWithoutSaving !== 'undefined') {
101
+ preventLeaveWithoutSaving = !disableLeaveWithoutSaving;
102
+ }
103
+ const [isReadOnlyForIncomingUser, setIsReadOnlyForIncomingUser] = useState(false);
104
+ const [showTakeOverModal, setShowTakeOverModal] = useState(false);
105
+ const documentLockStateRef = useRef({
106
+ hasShownLockedModal: false,
107
+ isLocked: false,
108
+ user: null
109
+ });
110
+ const [lastUpdateTime, setLastUpdateTime] = useState(Date.now());
111
+ const classes = [baseClass, (id || globalSlug) && `${baseClass}--is-editing`];
86
112
  if (globalSlug) {
87
113
  classes.push(`global-edit--${globalSlug}`);
88
114
  }
89
115
  if (collectionSlug) {
90
116
  classes.push(`collection-edit--${collectionSlug}`);
91
117
  }
92
- const [schemaPath, setSchemaPath] = React.useState(() => {
118
+ const [schemaPath, setSchemaPath] = useState(() => {
93
119
  if (operation === 'create' && auth && !auth.disableLocalStrategy) {
94
120
  return `_${entitySlug}.auth`;
95
121
  }
@@ -119,6 +145,10 @@ export const DefaultEditView = () => {
119
145
  operation: id ? 'update' : 'create'
120
146
  });
121
147
  }
148
+ // Unlock the document after save
149
+ if ((id || globalSlug) && isLockingEnabled) {
150
+ setDocumentIsLocked(false);
151
+ }
122
152
  if (!isEditing && depth < 2) {
123
153
  // Redirect to the same locale if it's been set
124
154
  const redirectRoute = formatAdminURL({
@@ -129,12 +159,22 @@ export const DefaultEditView = () => {
129
159
  } else {
130
160
  resetUploadEdits();
131
161
  }
132
- }, [onSaveFromContext, userSlug, reportUpdate, id, entitySlug, user, depth, collectionSlug, getVersions, isEditing, refreshCookieAsync, adminRoute, router, locale, resetUploadEdits]);
162
+ }, [onSaveFromContext, userSlug, reportUpdate, id, entitySlug, user, depth, collectionSlug, getVersions, isEditing, refreshCookieAsync, adminRoute, router, locale, resetUploadEdits, globalSlug, isLockingEnabled, setDocumentIsLocked]);
133
163
  const onChange = useCallback(async ({
134
164
  formState: prevFormState
135
165
  }) => {
166
+ const currentTime = Date.now();
167
+ const timeSinceLastUpdate = currentTime - lastUpdateTime;
168
+ const updateLastEdited = isLockingEnabled && timeSinceLastUpdate >= 10000 // 10 seconds
169
+ ;
170
+ if (updateLastEdited) {
171
+ setLastUpdateTime(currentTime);
172
+ }
136
173
  const docPreferences = await getDocPreferences();
137
- return getFormState({
174
+ const {
175
+ lockedState,
176
+ state
177
+ } = await getFormState({
138
178
  apiRoute,
139
179
  body: {
140
180
  id,
@@ -143,11 +183,56 @@ export const DefaultEditView = () => {
143
183
  formState: prevFormState,
144
184
  globalSlug,
145
185
  operation,
146
- schemaPath
186
+ returnLockStatus: isLockingEnabled ? true : false,
187
+ schemaPath,
188
+ updateLastEdited
147
189
  },
148
190
  serverURL
149
191
  });
150
- }, [apiRoute, collectionSlug, schemaPath, getDocPreferences, globalSlug, id, operation, serverURL]);
192
+ setDocumentIsLocked(true);
193
+ if (isLockingEnabled) {
194
+ const previousOwnerId = documentLockStateRef.current?.user?.id;
195
+ if (lockedState) {
196
+ if (!documentLockStateRef.current || lockedState.user.id !== previousOwnerId) {
197
+ if (previousOwnerId === user.id && lockedState.user.id !== user.id) {
198
+ setShowTakeOverModal(true);
199
+ documentLockStateRef.current.hasShownLockedModal = true;
200
+ }
201
+ documentLockStateRef.current = documentLockStateRef.current = {
202
+ hasShownLockedModal: documentLockStateRef.current?.hasShownLockedModal || false,
203
+ isLocked: true,
204
+ user: lockedState.user
205
+ };
206
+ setCurrentEditor(lockedState.user);
207
+ }
208
+ }
209
+ }
210
+ return state;
211
+ }, [apiRoute, collectionSlug, schemaPath, getDocPreferences, globalSlug, id, operation, serverURL, user, documentLockStateRef, setCurrentEditor, isLockingEnabled, setDocumentIsLocked, lastUpdateTime]);
212
+ // Clean up when the component unmounts or when the document is unlocked
213
+ useEffect(() => {
214
+ return () => {
215
+ if (!isLockingEnabled) {
216
+ return;
217
+ }
218
+ const currentPath = window.location.pathname;
219
+ const documentId = id || globalSlug;
220
+ // Routes where we do NOT want to unlock the document
221
+ const stayWithinDocumentPaths = ['preview', 'api', 'versions'];
222
+ const isStayingWithinDocument = stayWithinDocumentPaths.some(path => currentPath.includes(path));
223
+ // Unlock the document only if we're actually navigating away from the document
224
+ if (documentId && documentIsLocked && !isStayingWithinDocument) {
225
+ // Check if this user is still the current editor
226
+ if (documentLockStateRef.current?.user?.id === user.id) {
227
+ void unlockDocument(id, collectionSlug ?? globalSlug);
228
+ setDocumentIsLocked(false);
229
+ setCurrentEditor(null);
230
+ }
231
+ }
232
+ setShowTakeOverModal(false);
233
+ };
234
+ }, [collectionSlug, globalSlug, id, unlockDocument, user.id, setCurrentEditor, isLockingEnabled, documentIsLocked, setDocumentIsLocked]);
235
+ const shouldShowDocumentLockedModal = documentIsLocked && currentEditor && currentEditor.id !== user.id && !isReadOnlyForIncomingUser && !showTakeOverModal && !documentLockStateRef.current?.hasShownLockedModal;
151
236
  return /*#__PURE__*/_jsx("main", {
152
237
  className: classes.filter(Boolean).join(' '),
153
238
  children: /*#__PURE__*/_jsx(OperationProvider, {
@@ -155,14 +240,38 @@ export const DefaultEditView = () => {
155
240
  children: /*#__PURE__*/_jsxs(Form, {
156
241
  action: action,
157
242
  className: `${baseClass}__form`,
158
- disabled: isInitializing || !hasSavePermission,
243
+ disabled: isReadOnlyForIncomingUser || isInitializing || !hasSavePermission,
159
244
  disableValidationOnSubmit: !validateBeforeSubmit,
160
245
  initialState: !isInitializing && initialState,
161
246
  isInitializing: isInitializing,
162
247
  method: id ? 'PATCH' : 'POST',
163
248
  onChange: [onChange],
164
249
  onSuccess: onSave,
165
- children: [BeforeDocument, preventLeaveWithoutSaving && /*#__PURE__*/_jsx(LeaveWithoutSaving, {}), /*#__PURE__*/_jsx(SetDocumentStepNav, {
250
+ children: [BeforeDocument, isLockingEnabled && shouldShowDocumentLockedModal && !isReadOnlyForIncomingUser && /*#__PURE__*/_jsx(DocumentLocked, {
251
+ handleGoBack: () => handleGoBack({
252
+ adminRoute,
253
+ collectionSlug,
254
+ router
255
+ }),
256
+ isActive: shouldShowDocumentLockedModal,
257
+ onReadOnly: () => {
258
+ setIsReadOnlyForIncomingUser(true);
259
+ setShowTakeOverModal(false);
260
+ },
261
+ onTakeOver: () => handleTakeOver(id, collectionSlug, globalSlug, user, false, updateDocumentEditor, setCurrentEditor, documentLockStateRef, isLockingEnabled),
262
+ updatedAt: lastUpdateTime,
263
+ user: currentEditor
264
+ }), isLockingEnabled && showTakeOverModal && /*#__PURE__*/_jsx(DocumentTakeOver, {
265
+ handleBackToDashboard: () => handleBackToDashboard({
266
+ adminRoute,
267
+ router
268
+ }),
269
+ isActive: showTakeOverModal,
270
+ onReadOnly: () => {
271
+ setIsReadOnlyForIncomingUser(true);
272
+ setShowTakeOverModal(false);
273
+ }
274
+ }), !isReadOnlyForIncomingUser && preventLeaveWithoutSaving && /*#__PURE__*/_jsx(LeaveWithoutSaving, {}), /*#__PURE__*/_jsx(SetDocumentStepNav, {
166
275
  collectionSlug: collectionConfig?.slug,
167
276
  globalSlug: globalConfig?.slug,
168
277
  id: id,
@@ -186,10 +295,13 @@ export const DefaultEditView = () => {
186
295
  onDrawerCreate: onDrawerCreate,
187
296
  onDuplicate: onDuplicate,
188
297
  onSave: onSave,
298
+ onTakeOver: () => handleTakeOver(id, collectionSlug, globalSlug, user, true, updateDocumentEditor, setCurrentEditor, documentLockStateRef, isLockingEnabled, setIsReadOnlyForIncomingUser),
189
299
  permissions: docPermissions,
300
+ readOnlyForIncomingUser: isReadOnlyForIncomingUser,
190
301
  redirectAfterDelete: redirectAfterDelete,
191
302
  redirectAfterDuplicate: redirectAfterDuplicate,
192
- slug: collectionConfig?.slug || globalConfig?.slug
303
+ slug: collectionConfig?.slug || globalConfig?.slug,
304
+ user: currentEditor
193
305
  }), /*#__PURE__*/_jsx(DocumentFields, {
194
306
  AfterFields: AfterFields,
195
307
  BeforeFields: BeforeFields || /*#__PURE__*/_jsxs(Fragment, {
@@ -204,6 +316,7 @@ export const DefaultEditView = () => {
204
316
  requirePassword: !id,
205
317
  setSchemaPath: setSchemaPath,
206
318
  setValidateBeforeSubmit: setValidateBeforeSubmit,
319
+ // eslint-disable-next-line react-compiler/react-compiler
207
320
  useAPIKey: auth.useAPIKey,
208
321
  username: data?.username,
209
322
  verify: auth.verify
@@ -219,7 +332,7 @@ export const DefaultEditView = () => {
219
332
  }),
220
333
  docPermissions: docPermissions,
221
334
  fields: (collectionConfig || globalConfig)?.fields,
222
- readOnly: !hasSavePermission,
335
+ readOnly: isReadOnlyForIncomingUser || !hasSavePermission,
223
336
  schemaPath: schemaPath
224
337
  }), AfterDocument]
225
338
  })
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["DocumentControls","DocumentFields","Form","OperationProvider","RenderComponent","Upload","useAuth","useConfig","useDocumentEvents","useDocumentInfo","useEditDepth","useUploadEdits","formatAdminURL","getFormState","useRouter","useSearchParams","React","Fragment","useCallback","useState","LeaveWithoutSaving","Auth","SetDocumentStepNav","SetDocumentTitle","baseClass","DefaultEditView","id","action","AfterDocument","AfterFields","apiURL","BeforeDocument","BeforeFields","collectionSlug","disableActions","disableCreate","disableLeaveWithoutSaving","docPermissions","getDocPreferences","getVersions","globalSlug","hasPublishPermission","hasSavePermission","initialData","data","initialState","isEditing","isInitializing","onDelete","onDrawerCreate","onDuplicate","onSave","onSaveFromContext","redirectAfterDelete","redirectAfterDuplicate","refreshCookieAsync","user","config","admin","userSlug","routes","adminRoute","api","apiRoute","serverURL","getEntityConfig","router","depth","params","reportUpdate","resetUploadEdits","locale","get","collectionConfig","globalConfig","entitySlug","slug","operation","auth","undefined","upload","preventLeaveWithoutSaving","versions","drafts","autosave","classes","push","schemaPath","setSchemaPath","disableLocalStrategy","validateBeforeSubmit","setValidateBeforeSubmit","json","updatedAt","result","Date","toISOString","redirectRoute","path","doc","onChange","formState","prevFormState","docPreferences","body","_jsx","className","filter","Boolean","join","_jsxs","disabled","disableValidationOnSubmit","method","onSuccess","pluralLabel","labels","plural","useAsTitle","fallback","toString","permissions","email","loginWithUsername","readOnly","requirePassword","useAPIKey","username","verify","components","edit","mappedComponent","uploadConfig","fields"],"sources":["../../../../src/views/Edit/Default/index.tsx"],"sourcesContent":["'use client'\n\nimport type { ClientCollectionConfig, ClientGlobalConfig } from 'payload'\n\nimport {\n DocumentControls,\n DocumentFields,\n Form,\n type FormProps,\n OperationProvider,\n RenderComponent,\n Upload,\n useAuth,\n useConfig,\n useDocumentEvents,\n useDocumentInfo,\n useEditDepth,\n useUploadEdits,\n} from '@payloadcms/ui'\nimport { formatAdminURL, getFormState } from '@payloadcms/ui/shared'\nimport { useRouter, useSearchParams } from 'next/navigation.js'\nimport React, { Fragment, useCallback, useState } from 'react'\n\nimport { LeaveWithoutSaving } from '../../../elements/LeaveWithoutSaving/index.js'\nimport { Auth } from './Auth/index.js'\nimport './index.scss'\nimport { SetDocumentStepNav } from './SetDocumentStepNav/index.js'\nimport { SetDocumentTitle } from './SetDocumentTitle/index.js'\n\nconst baseClass = 'collection-edit'\n\n// This component receives props only on _pages_\n// When rendered within a drawer, props are empty\n// This is solely to support custom edit views which get server-rendered\nexport const DefaultEditView: React.FC = () => {\n const {\n id,\n action,\n AfterDocument,\n AfterFields,\n apiURL,\n BeforeDocument,\n BeforeFields,\n collectionSlug,\n disableActions,\n disableCreate,\n disableLeaveWithoutSaving,\n docPermissions,\n getDocPreferences,\n getVersions,\n globalSlug,\n hasPublishPermission,\n hasSavePermission,\n initialData: data,\n initialState,\n isEditing,\n isInitializing,\n onDelete,\n onDrawerCreate,\n onDuplicate,\n onSave: onSaveFromContext,\n redirectAfterDelete,\n redirectAfterDuplicate,\n } = useDocumentInfo()\n\n const { refreshCookieAsync, user } = useAuth()\n\n const {\n config,\n config: {\n admin: { user: userSlug },\n routes: { admin: adminRoute, api: apiRoute },\n serverURL,\n },\n getEntityConfig,\n } = useConfig()\n\n const router = useRouter()\n const depth = useEditDepth()\n const params = useSearchParams()\n const { reportUpdate } = useDocumentEvents()\n const { resetUploadEdits } = useUploadEdits()\n\n const locale = params.get('locale')\n\n const collectionConfig = getEntityConfig({ collectionSlug }) as ClientCollectionConfig\n\n const globalConfig = getEntityConfig({ globalSlug }) as ClientGlobalConfig\n\n const entitySlug = collectionConfig?.slug || globalConfig?.slug\n\n const operation = collectionSlug && !id ? 'create' : 'update'\n\n const auth = collectionConfig ? collectionConfig.auth : undefined\n const upload = collectionConfig ? collectionConfig.upload : undefined\n\n const preventLeaveWithoutSaving =\n (!(collectionConfig?.versions?.drafts && collectionConfig?.versions?.drafts?.autosave) ||\n !(globalConfig?.versions?.drafts && globalConfig?.versions?.drafts?.autosave)) &&\n !disableLeaveWithoutSaving\n\n const classes = [baseClass, id && `${baseClass}--is-editing`]\n\n if (globalSlug) {\n classes.push(`global-edit--${globalSlug}`)\n }\n if (collectionSlug) {\n classes.push(`collection-edit--${collectionSlug}`)\n }\n\n const [schemaPath, setSchemaPath] = React.useState(() => {\n if (operation === 'create' && auth && !auth.disableLocalStrategy) {\n return `_${entitySlug}.auth`\n }\n\n return entitySlug\n })\n const [validateBeforeSubmit, setValidateBeforeSubmit] = useState(() => {\n if (operation === 'create' && auth && !auth.disableLocalStrategy) {\n return true\n }\n\n return false\n })\n\n const onSave = useCallback(\n (json) => {\n reportUpdate({\n id,\n entitySlug,\n updatedAt: json?.result?.updatedAt || new Date().toISOString(),\n })\n\n // If we're editing the doc of the logged-in user,\n // Refresh the cookie to get new permissions\n if (user && collectionSlug === userSlug && id === user.id) {\n void refreshCookieAsync()\n }\n\n void getVersions()\n\n if (typeof onSaveFromContext === 'function') {\n void onSaveFromContext({\n ...json,\n operation: id ? 'update' : 'create',\n })\n }\n\n if (!isEditing && depth < 2) {\n // Redirect to the same locale if it's been set\n const redirectRoute = formatAdminURL({\n adminRoute,\n path: `/collections/${collectionSlug}/${json?.doc?.id}${locale ? `?locale=${locale}` : ''}`,\n })\n router.push(redirectRoute)\n } else {\n resetUploadEdits()\n }\n },\n [\n onSaveFromContext,\n userSlug,\n reportUpdate,\n id,\n entitySlug,\n user,\n depth,\n collectionSlug,\n getVersions,\n isEditing,\n refreshCookieAsync,\n adminRoute,\n router,\n locale,\n resetUploadEdits,\n ],\n )\n\n const onChange: FormProps['onChange'][0] = useCallback(\n async ({ formState: prevFormState }) => {\n const docPreferences = await getDocPreferences()\n return getFormState({\n apiRoute,\n body: {\n id,\n collectionSlug,\n docPreferences,\n formState: prevFormState,\n globalSlug,\n operation,\n schemaPath,\n },\n serverURL,\n })\n },\n [apiRoute, collectionSlug, schemaPath, getDocPreferences, globalSlug, id, operation, serverURL],\n )\n\n return (\n <main className={classes.filter(Boolean).join(' ')}>\n <OperationProvider operation={operation}>\n <Form\n action={action}\n className={`${baseClass}__form`}\n disabled={isInitializing || !hasSavePermission}\n disableValidationOnSubmit={!validateBeforeSubmit}\n initialState={!isInitializing && initialState}\n isInitializing={isInitializing}\n method={id ? 'PATCH' : 'POST'}\n onChange={[onChange]}\n onSuccess={onSave}\n >\n {BeforeDocument}\n {preventLeaveWithoutSaving && <LeaveWithoutSaving />}\n <SetDocumentStepNav\n collectionSlug={collectionConfig?.slug}\n globalSlug={globalConfig?.slug}\n id={id}\n pluralLabel={collectionConfig?.labels?.plural}\n useAsTitle={collectionConfig?.admin?.useAsTitle}\n />\n <SetDocumentTitle\n collectionConfig={collectionConfig}\n config={config}\n fallback={depth <= 1 ? id?.toString() : undefined}\n globalConfig={globalConfig}\n />\n <DocumentControls\n apiURL={apiURL}\n data={data}\n disableActions={disableActions}\n disableCreate={disableCreate}\n hasPublishPermission={hasPublishPermission}\n hasSavePermission={hasSavePermission}\n id={id}\n isEditing={isEditing}\n onDelete={onDelete}\n onDrawerCreate={onDrawerCreate}\n onDuplicate={onDuplicate}\n onSave={onSave}\n permissions={docPermissions}\n redirectAfterDelete={redirectAfterDelete}\n redirectAfterDuplicate={redirectAfterDuplicate}\n slug={collectionConfig?.slug || globalConfig?.slug}\n />\n <DocumentFields\n AfterFields={AfterFields}\n BeforeFields={\n BeforeFields || (\n <Fragment>\n {auth && (\n <Auth\n className={`${baseClass}__auth`}\n collectionSlug={collectionConfig.slug}\n disableLocalStrategy={collectionConfig.auth?.disableLocalStrategy}\n email={data?.email}\n loginWithUsername={auth?.loginWithUsername}\n operation={operation}\n readOnly={!hasSavePermission}\n requirePassword={!id}\n setSchemaPath={setSchemaPath}\n setValidateBeforeSubmit={setValidateBeforeSubmit}\n useAPIKey={auth.useAPIKey}\n username={data?.username}\n verify={auth.verify}\n />\n )}\n {upload && (\n <React.Fragment>\n {collectionConfig?.admin?.components?.edit?.Upload ? (\n <RenderComponent\n mappedComponent={collectionConfig.admin.components.edit.Upload}\n />\n ) : (\n <Upload\n collectionSlug={collectionConfig.slug}\n initialState={initialState}\n uploadConfig={upload}\n />\n )}\n </React.Fragment>\n )}\n </Fragment>\n )\n }\n docPermissions={docPermissions}\n fields={(collectionConfig || globalConfig)?.fields}\n readOnly={!hasSavePermission}\n schemaPath={schemaPath}\n />\n {AfterDocument}\n </Form>\n </OperationProvider>\n </main>\n )\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["DocumentControls","DocumentFields","Form","OperationProvider","RenderComponent","Upload","useAuth","useConfig","useDocumentEvents","useDocumentInfo","useEditDepth","useUploadEdits","formatAdminURL","getFormState","handleBackToDashboard","handleGoBack","handleTakeOver","useRouter","useSearchParams","React","Fragment","useCallback","useEffect","useRef","useState","DocumentLocked","DocumentTakeOver","LeaveWithoutSaving","Auth","SetDocumentStepNav","SetDocumentTitle","baseClass","DefaultEditView","id","action","AfterDocument","AfterFields","apiURL","BeforeDocument","BeforeFields","collectionSlug","currentEditor","disableActions","disableCreate","disableLeaveWithoutSaving","docPermissions","documentIsLocked","getDocPreferences","getVersions","globalSlug","hasPublishPermission","hasSavePermission","initialData","data","initialState","isEditing","isInitializing","onDelete","onDrawerCreate","onDuplicate","onSave","onSaveFromContext","redirectAfterDelete","redirectAfterDuplicate","setCurrentEditor","setDocumentIsLocked","unlockDocument","updateDocumentEditor","refreshCookieAsync","user","config","admin","userSlug","routes","adminRoute","api","apiRoute","serverURL","getEntityConfig","router","depth","params","reportUpdate","resetUploadEdits","locale","get","collectionConfig","globalConfig","entitySlug","slug","operation","auth","undefined","upload","docConfig","lockDocumentsProp","lockDocuments","isLockingEnabled","preventLeaveWithoutSaving","versions","drafts","autosave","isReadOnlyForIncomingUser","setIsReadOnlyForIncomingUser","showTakeOverModal","setShowTakeOverModal","documentLockStateRef","hasShownLockedModal","isLocked","lastUpdateTime","setLastUpdateTime","Date","now","classes","push","schemaPath","setSchemaPath","disableLocalStrategy","validateBeforeSubmit","setValidateBeforeSubmit","json","updatedAt","result","toISOString","redirectRoute","path","doc","onChange","formState","prevFormState","currentTime","timeSinceLastUpdate","updateLastEdited","docPreferences","lockedState","state","body","returnLockStatus","previousOwnerId","current","currentPath","window","location","pathname","documentId","stayWithinDocumentPaths","isStayingWithinDocument","some","includes","shouldShowDocumentLockedModal","_jsx","className","filter","Boolean","join","_jsxs","disabled","disableValidationOnSubmit","method","onSuccess","isActive","onReadOnly","onTakeOver","pluralLabel","labels","plural","useAsTitle","fallback","toString","permissions","readOnlyForIncomingUser","email","loginWithUsername","readOnly","requirePassword","useAPIKey","username","verify","components","edit","mappedComponent","uploadConfig","fields"],"sources":["../../../../src/views/Edit/Default/index.tsx"],"sourcesContent":["'use client'\n\nimport type { ClientCollectionConfig, ClientGlobalConfig, ClientUser } from 'payload'\n\nimport {\n DocumentControls,\n DocumentFields,\n Form,\n type FormProps,\n OperationProvider,\n RenderComponent,\n Upload,\n useAuth,\n useConfig,\n useDocumentEvents,\n useDocumentInfo,\n useEditDepth,\n useUploadEdits,\n} from '@payloadcms/ui'\nimport {\n formatAdminURL,\n getFormState,\n handleBackToDashboard,\n handleGoBack,\n handleTakeOver,\n} from '@payloadcms/ui/shared'\nimport { useRouter, useSearchParams } from 'next/navigation.js'\nimport React, { Fragment, useCallback, useEffect, useRef, useState } from 'react'\n\nimport { DocumentLocked } from '../../../elements/DocumentLocked/index.js'\nimport { DocumentTakeOver } from '../../../elements/DocumentTakeOver/index.js'\nimport { LeaveWithoutSaving } from '../../../elements/LeaveWithoutSaving/index.js'\nimport { Auth } from './Auth/index.js'\nimport './index.scss'\nimport { SetDocumentStepNav } from './SetDocumentStepNav/index.js'\nimport { SetDocumentTitle } from './SetDocumentTitle/index.js'\n\nconst baseClass = 'collection-edit'\n\n// This component receives props only on _pages_\n// When rendered within a drawer, props are empty\n// This is solely to support custom edit views which get server-rendered\nexport const DefaultEditView: React.FC = () => {\n const {\n id,\n action,\n AfterDocument,\n AfterFields,\n apiURL,\n BeforeDocument,\n BeforeFields,\n collectionSlug,\n currentEditor,\n disableActions,\n disableCreate,\n disableLeaveWithoutSaving,\n docPermissions,\n documentIsLocked,\n getDocPreferences,\n getVersions,\n globalSlug,\n hasPublishPermission,\n hasSavePermission,\n initialData: data,\n initialState,\n isEditing,\n isInitializing,\n onDelete,\n onDrawerCreate,\n onDuplicate,\n onSave: onSaveFromContext,\n redirectAfterDelete,\n redirectAfterDuplicate,\n setCurrentEditor,\n setDocumentIsLocked,\n unlockDocument,\n updateDocumentEditor,\n } = useDocumentInfo()\n\n const { refreshCookieAsync, user } = useAuth()\n const {\n config,\n config: {\n admin: { user: userSlug },\n routes: { admin: adminRoute, api: apiRoute },\n serverURL,\n },\n getEntityConfig,\n } = useConfig()\n\n const router = useRouter()\n const depth = useEditDepth()\n const params = useSearchParams()\n const { reportUpdate } = useDocumentEvents()\n const { resetUploadEdits } = useUploadEdits()\n\n const locale = params.get('locale')\n\n const collectionConfig = getEntityConfig({ collectionSlug }) as ClientCollectionConfig\n\n const globalConfig = getEntityConfig({ globalSlug }) as ClientGlobalConfig\n\n const entitySlug = collectionConfig?.slug || globalConfig?.slug\n\n const operation = collectionSlug && !id ? 'create' : 'update'\n\n const auth = collectionConfig ? collectionConfig.auth : undefined\n const upload = collectionConfig ? collectionConfig.upload : undefined\n\n const docConfig = collectionConfig || globalConfig\n\n const lockDocumentsProp = docConfig?.lockDocuments !== undefined ? docConfig?.lockDocuments : true\n\n const isLockingEnabled = lockDocumentsProp !== false\n\n let preventLeaveWithoutSaving = true\n\n if (collectionConfig) {\n preventLeaveWithoutSaving = !(\n collectionConfig?.versions?.drafts && collectionConfig?.versions?.drafts?.autosave\n )\n } else if (globalConfig) {\n preventLeaveWithoutSaving = !(\n globalConfig?.versions?.drafts && globalConfig?.versions?.drafts?.autosave\n )\n } else if (typeof disableLeaveWithoutSaving !== 'undefined') {\n preventLeaveWithoutSaving = !disableLeaveWithoutSaving\n }\n\n const [isReadOnlyForIncomingUser, setIsReadOnlyForIncomingUser] = useState(false)\n const [showTakeOverModal, setShowTakeOverModal] = useState(false)\n\n const documentLockStateRef = useRef<{\n hasShownLockedModal: boolean\n isLocked: boolean\n user: ClientUser\n } | null>({\n hasShownLockedModal: false,\n isLocked: false,\n user: null,\n })\n\n const [lastUpdateTime, setLastUpdateTime] = useState(Date.now())\n\n const classes = [baseClass, (id || globalSlug) && `${baseClass}--is-editing`]\n\n if (globalSlug) {\n classes.push(`global-edit--${globalSlug}`)\n }\n if (collectionSlug) {\n classes.push(`collection-edit--${collectionSlug}`)\n }\n\n const [schemaPath, setSchemaPath] = useState(() => {\n if (operation === 'create' && auth && !auth.disableLocalStrategy) {\n return `_${entitySlug}.auth`\n }\n\n return entitySlug\n })\n const [validateBeforeSubmit, setValidateBeforeSubmit] = useState(() => {\n if (operation === 'create' && auth && !auth.disableLocalStrategy) {\n return true\n }\n\n return false\n })\n\n const onSave = useCallback(\n (json) => {\n reportUpdate({\n id,\n entitySlug,\n updatedAt: json?.result?.updatedAt || new Date().toISOString(),\n })\n\n // If we're editing the doc of the logged-in user,\n // Refresh the cookie to get new permissions\n if (user && collectionSlug === userSlug && id === user.id) {\n void refreshCookieAsync()\n }\n\n void getVersions()\n\n if (typeof onSaveFromContext === 'function') {\n void onSaveFromContext({\n ...json,\n operation: id ? 'update' : 'create',\n })\n }\n\n // Unlock the document after save\n if ((id || globalSlug) && isLockingEnabled) {\n setDocumentIsLocked(false)\n }\n\n if (!isEditing && depth < 2) {\n // Redirect to the same locale if it's been set\n const redirectRoute = formatAdminURL({\n adminRoute,\n path: `/collections/${collectionSlug}/${json?.doc?.id}${locale ? `?locale=${locale}` : ''}`,\n })\n router.push(redirectRoute)\n } else {\n resetUploadEdits()\n }\n },\n [\n onSaveFromContext,\n userSlug,\n reportUpdate,\n id,\n entitySlug,\n user,\n depth,\n collectionSlug,\n getVersions,\n isEditing,\n refreshCookieAsync,\n adminRoute,\n router,\n locale,\n resetUploadEdits,\n globalSlug,\n isLockingEnabled,\n setDocumentIsLocked,\n ],\n )\n\n const onChange: FormProps['onChange'][0] = useCallback(\n async ({ formState: prevFormState }) => {\n const currentTime = Date.now()\n const timeSinceLastUpdate = currentTime - lastUpdateTime\n\n const updateLastEdited = isLockingEnabled && timeSinceLastUpdate >= 10000 // 10 seconds\n\n if (updateLastEdited) {\n setLastUpdateTime(currentTime)\n }\n\n const docPreferences = await getDocPreferences()\n\n const { lockedState, state } = await getFormState({\n apiRoute,\n body: {\n id,\n collectionSlug,\n docPreferences,\n formState: prevFormState,\n globalSlug,\n operation,\n returnLockStatus: isLockingEnabled ? true : false,\n schemaPath,\n updateLastEdited,\n },\n serverURL,\n })\n\n setDocumentIsLocked(true)\n\n if (isLockingEnabled) {\n const previousOwnerId = documentLockStateRef.current?.user?.id\n\n if (lockedState) {\n if (!documentLockStateRef.current || lockedState.user.id !== previousOwnerId) {\n if (previousOwnerId === user.id && lockedState.user.id !== user.id) {\n setShowTakeOverModal(true)\n documentLockStateRef.current.hasShownLockedModal = true\n }\n\n documentLockStateRef.current = documentLockStateRef.current = {\n hasShownLockedModal: documentLockStateRef.current?.hasShownLockedModal || false,\n isLocked: true,\n user: lockedState.user,\n }\n setCurrentEditor(lockedState.user)\n }\n }\n }\n\n return state\n },\n [\n apiRoute,\n collectionSlug,\n schemaPath,\n getDocPreferences,\n globalSlug,\n id,\n operation,\n serverURL,\n user,\n documentLockStateRef,\n setCurrentEditor,\n isLockingEnabled,\n setDocumentIsLocked,\n lastUpdateTime,\n ],\n )\n\n // Clean up when the component unmounts or when the document is unlocked\n useEffect(() => {\n return () => {\n if (!isLockingEnabled) {\n return\n }\n\n const currentPath = window.location.pathname\n\n const documentId = id || globalSlug\n\n // Routes where we do NOT want to unlock the document\n const stayWithinDocumentPaths = ['preview', 'api', 'versions']\n\n const isStayingWithinDocument = stayWithinDocumentPaths.some((path) =>\n currentPath.includes(path),\n )\n\n // Unlock the document only if we're actually navigating away from the document\n if (documentId && documentIsLocked && !isStayingWithinDocument) {\n // Check if this user is still the current editor\n if (documentLockStateRef.current?.user?.id === user.id) {\n void unlockDocument(id, collectionSlug ?? globalSlug)\n setDocumentIsLocked(false)\n setCurrentEditor(null)\n }\n }\n\n setShowTakeOverModal(false)\n }\n }, [\n collectionSlug,\n globalSlug,\n id,\n unlockDocument,\n user.id,\n setCurrentEditor,\n isLockingEnabled,\n documentIsLocked,\n setDocumentIsLocked,\n ])\n\n const shouldShowDocumentLockedModal =\n documentIsLocked &&\n currentEditor &&\n currentEditor.id !== user.id &&\n !isReadOnlyForIncomingUser &&\n !showTakeOverModal &&\n !documentLockStateRef.current?.hasShownLockedModal\n\n return (\n <main className={classes.filter(Boolean).join(' ')}>\n <OperationProvider operation={operation}>\n <Form\n action={action}\n className={`${baseClass}__form`}\n disabled={isReadOnlyForIncomingUser || isInitializing || !hasSavePermission}\n disableValidationOnSubmit={!validateBeforeSubmit}\n initialState={!isInitializing && initialState}\n isInitializing={isInitializing}\n method={id ? 'PATCH' : 'POST'}\n onChange={[onChange]}\n onSuccess={onSave}\n >\n {BeforeDocument}\n {isLockingEnabled && shouldShowDocumentLockedModal && !isReadOnlyForIncomingUser && (\n <DocumentLocked\n handleGoBack={() => handleGoBack({ adminRoute, collectionSlug, router })}\n isActive={shouldShowDocumentLockedModal}\n onReadOnly={() => {\n setIsReadOnlyForIncomingUser(true)\n setShowTakeOverModal(false)\n }}\n onTakeOver={() =>\n handleTakeOver(\n id,\n collectionSlug,\n globalSlug,\n user,\n false,\n updateDocumentEditor,\n setCurrentEditor,\n documentLockStateRef,\n isLockingEnabled,\n )\n }\n updatedAt={lastUpdateTime}\n user={currentEditor}\n />\n )}\n {isLockingEnabled && showTakeOverModal && (\n <DocumentTakeOver\n handleBackToDashboard={() => handleBackToDashboard({ adminRoute, router })}\n isActive={showTakeOverModal}\n onReadOnly={() => {\n setIsReadOnlyForIncomingUser(true)\n setShowTakeOverModal(false)\n }}\n />\n )}\n {!isReadOnlyForIncomingUser && preventLeaveWithoutSaving && <LeaveWithoutSaving />}\n <SetDocumentStepNav\n collectionSlug={collectionConfig?.slug}\n globalSlug={globalConfig?.slug}\n id={id}\n pluralLabel={collectionConfig?.labels?.plural}\n useAsTitle={collectionConfig?.admin?.useAsTitle}\n />\n <SetDocumentTitle\n collectionConfig={collectionConfig}\n config={config}\n fallback={depth <= 1 ? id?.toString() : undefined}\n globalConfig={globalConfig}\n />\n <DocumentControls\n apiURL={apiURL}\n data={data}\n disableActions={disableActions}\n disableCreate={disableCreate}\n hasPublishPermission={hasPublishPermission}\n hasSavePermission={hasSavePermission}\n id={id}\n isEditing={isEditing}\n onDelete={onDelete}\n onDrawerCreate={onDrawerCreate}\n onDuplicate={onDuplicate}\n onSave={onSave}\n onTakeOver={() =>\n handleTakeOver(\n id,\n collectionSlug,\n globalSlug,\n user,\n true,\n updateDocumentEditor,\n setCurrentEditor,\n documentLockStateRef,\n isLockingEnabled,\n setIsReadOnlyForIncomingUser,\n )\n }\n permissions={docPermissions}\n readOnlyForIncomingUser={isReadOnlyForIncomingUser}\n redirectAfterDelete={redirectAfterDelete}\n redirectAfterDuplicate={redirectAfterDuplicate}\n slug={collectionConfig?.slug || globalConfig?.slug}\n user={currentEditor}\n />\n <DocumentFields\n AfterFields={AfterFields}\n BeforeFields={\n BeforeFields || (\n <Fragment>\n {auth && (\n <Auth\n className={`${baseClass}__auth`}\n collectionSlug={collectionConfig.slug}\n disableLocalStrategy={collectionConfig.auth?.disableLocalStrategy}\n email={data?.email}\n loginWithUsername={auth?.loginWithUsername}\n operation={operation}\n readOnly={!hasSavePermission}\n requirePassword={!id}\n setSchemaPath={setSchemaPath}\n setValidateBeforeSubmit={setValidateBeforeSubmit}\n // eslint-disable-next-line react-compiler/react-compiler\n useAPIKey={auth.useAPIKey}\n username={data?.username}\n verify={auth.verify}\n />\n )}\n {upload && (\n <React.Fragment>\n {collectionConfig?.admin?.components?.edit?.Upload ? (\n <RenderComponent\n mappedComponent={collectionConfig.admin.components.edit.Upload}\n />\n ) : (\n <Upload\n collectionSlug={collectionConfig.slug}\n initialState={initialState}\n uploadConfig={upload}\n />\n )}\n </React.Fragment>\n )}\n </Fragment>\n )\n }\n docPermissions={docPermissions}\n fields={(collectionConfig || globalConfig)?.fields}\n readOnly={isReadOnlyForIncomingUser || !hasSavePermission}\n schemaPath={schemaPath}\n />\n {AfterDocument}\n </Form>\n </OperationProvider>\n </main>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -134,6 +134,9 @@ export const ForgotPasswordForm = () => {
134
134
  fields: {}
135
135
  },
136
136
  req: {
137
+ payload: {
138
+ config
139
+ },
137
140
  t
138
141
  },
139
142
  required: true,