@payloadcms/next 3.0.0-beta.61 → 3.0.0-beta.63
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.
- package/dist/prod/styles.css +1 -1
- package/dist/views/Edit/Default/Auth/index.scss +17 -2
- package/dist/views/Version/Default/SetStepNav.d.ts +0 -1
- package/dist/views/Version/Default/SetStepNav.d.ts.map +1 -1
- package/dist/views/Version/Default/SetStepNav.js +7 -7
- package/dist/views/Version/Default/SetStepNav.js.map +1 -1
- package/dist/views/Version/Default/index.d.ts.map +1 -1
- package/dist/views/Version/Default/index.js +11 -13
- package/dist/views/Version/Default/index.js.map +1 -1
- package/dist/views/Version/Default/types.d.ts +3 -3
- package/dist/views/Version/Default/types.d.ts.map +1 -1
- package/dist/views/Version/Default/types.js.map +1 -1
- package/dist/views/Version/SelectComparison/index.d.ts.map +1 -1
- package/dist/views/Version/SelectComparison/index.js +48 -27
- package/dist/views/Version/SelectComparison/index.js.map +1 -1
- package/dist/views/Version/SelectComparison/index.scss +1 -1
- package/dist/views/Version/SelectComparison/types.d.ts +2 -1
- package/dist/views/Version/SelectComparison/types.d.ts.map +1 -1
- package/dist/views/Version/SelectComparison/types.js.map +1 -1
- package/dist/views/Version/index.d.ts.map +1 -1
- package/dist/views/Version/index.js +22 -43
- package/dist/views/Version/index.js.map +1 -1
- package/dist/views/Versions/buildColumns.d.ts +3 -1
- package/dist/views/Versions/buildColumns.d.ts.map +1 -1
- package/dist/views/Versions/buildColumns.js +7 -4
- package/dist/views/Versions/buildColumns.js.map +1 -1
- package/dist/views/Versions/cells/AutosaveCell/index.d.ts +7 -1
- package/dist/views/Versions/cells/AutosaveCell/index.d.ts.map +1 -1
- package/dist/views/Versions/cells/AutosaveCell/index.js +31 -13
- package/dist/views/Versions/cells/AutosaveCell/index.js.map +1 -1
- package/dist/views/Versions/getLatestVersion.d.ts +5 -0
- package/dist/views/Versions/getLatestVersion.d.ts.map +1 -0
- package/dist/views/Versions/getLatestVersion.js +29 -0
- package/dist/views/Versions/getLatestVersion.js.map +1 -0
- package/dist/views/Versions/index.d.ts.map +1 -1
- package/dist/views/Versions/index.js +22 -2
- package/dist/views/Versions/index.js.map +1 -1
- package/package.json +6 -6
- package/dist/views/Version/shared.d.ts +0 -9
- package/dist/views/Version/shared.d.ts.map +0 -1
- package/dist/views/Version/shared.js +0 -10
- package/dist/views/Version/shared.js.map +0 -1
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
import { notFound } from 'next/navigation.js';
|
|
3
3
|
import React from 'react';
|
|
4
|
+
import { getLatestVersion } from '../Versions/getLatestVersion.js';
|
|
4
5
|
import { DefaultVersionView } from './Default/index.js';
|
|
5
6
|
export const VersionView = async (props)=>{
|
|
6
7
|
const { initPageResult, routeSegments } = props;
|
|
@@ -12,8 +13,8 @@ export const VersionView = async (props)=>{
|
|
|
12
13
|
let docPermissions;
|
|
13
14
|
let slug;
|
|
14
15
|
let doc;
|
|
15
|
-
let
|
|
16
|
-
let
|
|
16
|
+
let latestPublishedVersion = null;
|
|
17
|
+
let latestDraftVersion = null;
|
|
17
18
|
if (collectionSlug) {
|
|
18
19
|
// /collections/:slug/:id/versions/:versionID
|
|
19
20
|
slug = collectionSlug;
|
|
@@ -28,26 +29,10 @@ export const VersionView = async (props)=>{
|
|
|
28
29
|
req,
|
|
29
30
|
user
|
|
30
31
|
});
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
draft: false,
|
|
36
|
-
locale: '*',
|
|
37
|
-
overrideAccess: false,
|
|
38
|
-
req,
|
|
39
|
-
user
|
|
40
|
-
});
|
|
41
|
-
mostRecentDoc = await payload.findByID({
|
|
42
|
-
id,
|
|
43
|
-
collection: slug,
|
|
44
|
-
depth: 1,
|
|
45
|
-
draft: true,
|
|
46
|
-
locale: '*',
|
|
47
|
-
overrideAccess: false,
|
|
48
|
-
req,
|
|
49
|
-
user
|
|
50
|
-
});
|
|
32
|
+
if (collectionConfig?.versions?.drafts) {
|
|
33
|
+
latestDraftVersion = await getLatestVersion(payload, slug, 'draft', 'collection');
|
|
34
|
+
latestPublishedVersion = await getLatestVersion(payload, slug, 'published', 'collection');
|
|
35
|
+
}
|
|
51
36
|
} catch (error) {
|
|
52
37
|
return notFound();
|
|
53
38
|
}
|
|
@@ -66,42 +51,36 @@ export const VersionView = async (props)=>{
|
|
|
66
51
|
req,
|
|
67
52
|
user
|
|
68
53
|
});
|
|
69
|
-
|
|
70
|
-
slug,
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
locale: '*',
|
|
74
|
-
overrideAccess: false,
|
|
75
|
-
req,
|
|
76
|
-
user
|
|
77
|
-
});
|
|
78
|
-
mostRecentDoc = await payload.findGlobal({
|
|
79
|
-
slug,
|
|
80
|
-
depth: 1,
|
|
81
|
-
draft: true,
|
|
82
|
-
locale: '*',
|
|
83
|
-
overrideAccess: false,
|
|
84
|
-
req,
|
|
85
|
-
user
|
|
86
|
-
});
|
|
54
|
+
if (globalConfig?.versions?.drafts) {
|
|
55
|
+
latestDraftVersion = await getLatestVersion(payload, slug, 'draft', 'global');
|
|
56
|
+
latestPublishedVersion = await getLatestVersion(payload, slug, 'published', 'global');
|
|
57
|
+
}
|
|
87
58
|
} catch (error) {
|
|
88
59
|
return notFound();
|
|
89
60
|
}
|
|
90
61
|
}
|
|
62
|
+
const publishedNewerThanDraft = latestPublishedVersion?.updatedAt > latestDraftVersion?.updatedAt;
|
|
63
|
+
if (publishedNewerThanDraft) {
|
|
64
|
+
latestDraftVersion = {
|
|
65
|
+
id: '',
|
|
66
|
+
updatedAt: ''
|
|
67
|
+
};
|
|
68
|
+
}
|
|
91
69
|
const localeOptions = localization && localization?.locales && localization.locales.map(({ code, label })=>({
|
|
92
70
|
label: typeof label === 'string' ? label : '',
|
|
93
71
|
value: code
|
|
94
72
|
}));
|
|
73
|
+
const latestVersion = latestPublishedVersion?.updatedAt > latestDraftVersion?.updatedAt ? latestPublishedVersion : latestDraftVersion;
|
|
95
74
|
if (!doc) {
|
|
96
75
|
return notFound();
|
|
97
76
|
}
|
|
98
77
|
return /*#__PURE__*/ _jsx(DefaultVersionView, {
|
|
99
78
|
doc: doc,
|
|
100
79
|
docPermissions: docPermissions,
|
|
101
|
-
initialComparisonDoc:
|
|
80
|
+
initialComparisonDoc: latestVersion,
|
|
81
|
+
latestDraftVersion: latestDraftVersion.id,
|
|
82
|
+
latestPublishedVersion: latestPublishedVersion.id,
|
|
102
83
|
localeOptions: localeOptions,
|
|
103
|
-
mostRecentDoc: mostRecentDoc,
|
|
104
|
-
publishedDoc: publishedDoc,
|
|
105
84
|
versionID: versionID
|
|
106
85
|
});
|
|
107
86
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/views/Version/index.tsx"],"sourcesContent":["import type {\n CollectionPermission,\n Document,\n EditViewComponent,\n GlobalPermission,\n OptionObject,\n} from 'payload'\n\nimport { notFound } from 'next/navigation.js'\nimport React from 'react'\n\nimport { DefaultVersionView } from './Default/index.js'\n\nexport const VersionView: EditViewComponent = async (props) => {\n const { initPageResult, routeSegments } = props\n\n const {\n collectionConfig,\n docID: id,\n globalConfig,\n permissions,\n req,\n req: { payload, payload: { config } = {}, user } = {},\n } = initPageResult\n\n const versionID = routeSegments[routeSegments.length - 1]\n\n const collectionSlug = collectionConfig?.slug\n const globalSlug = globalConfig?.slug\n\n const { localization } = config\n\n let docPermissions: CollectionPermission | GlobalPermission\n let slug: string\n\n let doc: Document\n let
|
|
1
|
+
{"version":3,"sources":["../../../src/views/Version/index.tsx"],"sourcesContent":["import type {\n CollectionPermission,\n Document,\n EditViewComponent,\n GlobalPermission,\n OptionObject,\n} from 'payload'\n\nimport { notFound } from 'next/navigation.js'\nimport React from 'react'\n\nimport { getLatestVersion } from '../Versions/getLatestVersion.js'\nimport { DefaultVersionView } from './Default/index.js'\n\nexport const VersionView: EditViewComponent = async (props) => {\n const { initPageResult, routeSegments } = props\n\n const {\n collectionConfig,\n docID: id,\n globalConfig,\n permissions,\n req,\n req: { payload, payload: { config } = {}, user } = {},\n } = initPageResult\n\n const versionID = routeSegments[routeSegments.length - 1]\n\n const collectionSlug = collectionConfig?.slug\n const globalSlug = globalConfig?.slug\n\n const { localization } = config\n\n let docPermissions: CollectionPermission | GlobalPermission\n let slug: string\n\n let doc: Document\n let latestPublishedVersion = null\n let latestDraftVersion = null\n\n if (collectionSlug) {\n // /collections/:slug/:id/versions/:versionID\n slug = collectionSlug\n docPermissions = permissions.collections[collectionSlug]\n\n try {\n doc = await payload.findVersionByID({\n id: versionID,\n collection: slug,\n depth: 1,\n locale: '*',\n overrideAccess: false,\n req,\n user,\n })\n\n if (collectionConfig?.versions?.drafts) {\n latestDraftVersion = await getLatestVersion(payload, slug, 'draft', 'collection')\n latestPublishedVersion = await getLatestVersion(payload, slug, 'published', 'collection')\n }\n } catch (error) {\n return notFound()\n }\n }\n\n if (globalSlug) {\n // /globals/:slug/versions/:versionID\n slug = globalSlug\n docPermissions = permissions.globals[globalSlug]\n\n try {\n doc = await payload.findGlobalVersionByID({\n id: versionID,\n slug,\n depth: 1,\n locale: '*',\n overrideAccess: false,\n req,\n user,\n })\n\n if (globalConfig?.versions?.drafts) {\n latestDraftVersion = await getLatestVersion(payload, slug, 'draft', 'global')\n latestPublishedVersion = await getLatestVersion(payload, slug, 'published', 'global')\n }\n } catch (error) {\n return notFound()\n }\n }\n\n const publishedNewerThanDraft = latestPublishedVersion?.updatedAt > latestDraftVersion?.updatedAt\n\n if (publishedNewerThanDraft) {\n latestDraftVersion = {\n id: '',\n updatedAt: '',\n }\n }\n\n const localeOptions: OptionObject[] =\n localization &&\n localization?.locales &&\n localization.locales.map(({ code, label }) => ({\n label: typeof label === 'string' ? label : '',\n value: code,\n }))\n\n const latestVersion =\n latestPublishedVersion?.updatedAt > latestDraftVersion?.updatedAt\n ? latestPublishedVersion\n : latestDraftVersion\n\n if (!doc) {\n return notFound()\n }\n\n return (\n <DefaultVersionView\n doc={doc}\n docPermissions={docPermissions}\n initialComparisonDoc={latestVersion}\n latestDraftVersion={latestDraftVersion.id}\n latestPublishedVersion={latestPublishedVersion.id}\n localeOptions={localeOptions}\n versionID={versionID}\n />\n )\n}\n"],"names":["notFound","React","getLatestVersion","DefaultVersionView","VersionView","props","initPageResult","routeSegments","collectionConfig","docID","id","globalConfig","permissions","req","payload","config","user","versionID","length","collectionSlug","slug","globalSlug","localization","docPermissions","doc","latestPublishedVersion","latestDraftVersion","collections","findVersionByID","collection","depth","locale","overrideAccess","versions","drafts","error","globals","findGlobalVersionByID","publishedNewerThanDraft","updatedAt","localeOptions","locales","map","code","label","value","latestVersion","initialComparisonDoc"],"mappings":";AAQA,SAASA,QAAQ,QAAQ,qBAAoB;AAC7C,OAAOC,WAAW,QAAO;AAEzB,SAASC,gBAAgB,QAAQ,kCAAiC;AAClE,SAASC,kBAAkB,QAAQ,qBAAoB;AAEvD,OAAO,MAAMC,cAAiC,OAAOC;IACnD,MAAM,EAAEC,cAAc,EAAEC,aAAa,EAAE,GAAGF;IAE1C,MAAM,EACJG,gBAAgB,EAChBC,OAAOC,EAAE,EACTC,YAAY,EACZC,WAAW,EACXC,GAAG,EACHA,KAAK,EAAEC,OAAO,EAAEA,SAAS,EAAEC,MAAM,EAAE,GAAG,CAAC,CAAC,EAAEC,IAAI,EAAE,GAAG,CAAC,CAAC,EACtD,GAAGV;IAEJ,MAAMW,YAAYV,aAAa,CAACA,cAAcW,MAAM,GAAG,EAAE;IAEzD,MAAMC,iBAAiBX,kBAAkBY;IACzC,MAAMC,aAAaV,cAAcS;IAEjC,MAAM,EAAEE,YAAY,EAAE,GAAGP;IAEzB,IAAIQ;IACJ,IAAIH;IAEJ,IAAII;IACJ,IAAIC,yBAAyB;IAC7B,IAAIC,qBAAqB;IAEzB,IAAIP,gBAAgB;QAClB,6CAA6C;QAC7CC,OAAOD;QACPI,iBAAiBX,YAAYe,WAAW,CAACR,eAAe;QAExD,IAAI;YACFK,MAAM,MAAMV,QAAQc,eAAe,CAAC;gBAClClB,IAAIO;gBACJY,YAAYT;gBACZU,OAAO;gBACPC,QAAQ;gBACRC,gBAAgB;gBAChBnB;gBACAG;YACF;YAEA,IAAIR,kBAAkByB,UAAUC,QAAQ;gBACtCR,qBAAqB,MAAMxB,iBAAiBY,SAASM,MAAM,SAAS;gBACpEK,yBAAyB,MAAMvB,iBAAiBY,SAASM,MAAM,aAAa;YAC9E;QACF,EAAE,OAAOe,OAAO;YACd,OAAOnC;QACT;IACF;IAEA,IAAIqB,YAAY;QACd,qCAAqC;QACrCD,OAAOC;QACPE,iBAAiBX,YAAYwB,OAAO,CAACf,WAAW;QAEhD,IAAI;YACFG,MAAM,MAAMV,QAAQuB,qBAAqB,CAAC;gBACxC3B,IAAIO;gBACJG;gBACAU,OAAO;gBACPC,QAAQ;gBACRC,gBAAgB;gBAChBnB;gBACAG;YACF;YAEA,IAAIL,cAAcsB,UAAUC,QAAQ;gBAClCR,qBAAqB,MAAMxB,iBAAiBY,SAASM,MAAM,SAAS;gBACpEK,yBAAyB,MAAMvB,iBAAiBY,SAASM,MAAM,aAAa;YAC9E;QACF,EAAE,OAAOe,OAAO;YACd,OAAOnC;QACT;IACF;IAEA,MAAMsC,0BAA0Bb,wBAAwBc,YAAYb,oBAAoBa;IAExF,IAAID,yBAAyB;QAC3BZ,qBAAqB;YACnBhB,IAAI;YACJ6B,WAAW;QACb;IACF;IAEA,MAAMC,gBACJlB,gBACAA,cAAcmB,WACdnB,aAAamB,OAAO,CAACC,GAAG,CAAC,CAAC,EAAEC,IAAI,EAAEC,KAAK,EAAE,GAAM,CAAA;YAC7CA,OAAO,OAAOA,UAAU,WAAWA,QAAQ;YAC3CC,OAAOF;QACT,CAAA;IAEF,MAAMG,gBACJrB,wBAAwBc,YAAYb,oBAAoBa,YACpDd,yBACAC;IAEN,IAAI,CAACF,KAAK;QACR,OAAOxB;IACT;IAEA,qBACE,KAACG;QACCqB,KAAKA;QACLD,gBAAgBA;QAChBwB,sBAAsBD;QACtBpB,oBAAoBA,mBAAmBhB,EAAE;QACzCe,wBAAwBA,uBAAuBf,EAAE;QACjD8B,eAAeA;QACfvB,WAAWA;;AAGjB,EAAC"}
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import type { I18n } from '@payloadcms/translations';
|
|
2
2
|
import type { SanitizedCollectionConfig, SanitizedConfig, SanitizedGlobalConfig } from 'payload';
|
|
3
3
|
import { type Column } from '@payloadcms/ui';
|
|
4
|
-
export declare const buildVersionColumns: ({ collectionConfig, docID, globalConfig, i18n: { t }, }: {
|
|
4
|
+
export declare const buildVersionColumns: ({ collectionConfig, docID, globalConfig, i18n: { t }, latestDraftVersion, latestPublishedVersion, }: {
|
|
5
5
|
collectionConfig?: SanitizedCollectionConfig;
|
|
6
6
|
config: SanitizedConfig;
|
|
7
7
|
docID?: number | string;
|
|
8
8
|
globalConfig?: SanitizedGlobalConfig;
|
|
9
9
|
i18n: I18n;
|
|
10
|
+
latestDraftVersion?: string;
|
|
11
|
+
latestPublishedVersion?: string;
|
|
10
12
|
}) => Column[];
|
|
11
13
|
//# sourceMappingURL=buildColumns.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"buildColumns.d.ts","sourceRoot":"","sources":["../../../src/views/Versions/buildColumns.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,EAAE,yBAAyB,EAAE,eAAe,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAEhG,OAAO,EAAE,KAAK,MAAM,EAAc,MAAM,gBAAgB,CAAA;AAOxD,eAAO,MAAM,mBAAmB,
|
|
1
|
+
{"version":3,"file":"buildColumns.d.ts","sourceRoot":"","sources":["../../../src/views/Versions/buildColumns.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAA;AACpD,OAAO,KAAK,EAAE,yBAAyB,EAAE,eAAe,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAEhG,OAAO,EAAE,KAAK,MAAM,EAAc,MAAM,gBAAgB,CAAA;AAOxD,eAAO,MAAM,mBAAmB,wGAO7B;IACD,gBAAgB,CAAC,EAAE,yBAAyB,CAAA;IAC5C,MAAM,EAAE,eAAe,CAAA;IACvB,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACvB,YAAY,CAAC,EAAE,qBAAqB,CAAA;IACpC,IAAI,EAAE,IAAI,CAAA;IACV,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,sBAAsB,CAAC,EAAE,MAAM,CAAA;CAChC,KAAG,MAAM,EAyDT,CAAA"}
|
|
@@ -4,7 +4,7 @@ import React from 'react';
|
|
|
4
4
|
import { AutosaveCell } from './cells/AutosaveCell/index.js';
|
|
5
5
|
import { CreatedAtCell } from './cells/CreatedAt/index.js';
|
|
6
6
|
import { IDCell } from './cells/ID/index.js';
|
|
7
|
-
export const buildVersionColumns = ({ collectionConfig, docID, globalConfig, i18n: { t } })=>{
|
|
7
|
+
export const buildVersionColumns = ({ collectionConfig, docID, globalConfig, i18n: { t }, latestDraftVersion, latestPublishedVersion })=>{
|
|
8
8
|
const entityConfig = collectionConfig || globalConfig;
|
|
9
9
|
const columns = [
|
|
10
10
|
{
|
|
@@ -49,11 +49,14 @@ export const buildVersionColumns = ({ collectionConfig, docID, globalConfig, i18
|
|
|
49
49
|
accessor: '_status',
|
|
50
50
|
active: true,
|
|
51
51
|
components: {
|
|
52
|
-
Cell: /*#__PURE__*/ _jsx(AutosaveCell, {
|
|
52
|
+
Cell: /*#__PURE__*/ _jsx(AutosaveCell, {
|
|
53
|
+
latestDraftVersion: latestDraftVersion,
|
|
54
|
+
latestPublishedVersion: latestPublishedVersion
|
|
55
|
+
}),
|
|
53
56
|
Heading: /*#__PURE__*/ _jsx(SortColumn, {
|
|
54
|
-
Label: t('version:
|
|
57
|
+
Label: t('version:status'),
|
|
55
58
|
disable: true,
|
|
56
|
-
name: "
|
|
59
|
+
name: "status"
|
|
57
60
|
})
|
|
58
61
|
}
|
|
59
62
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/views/Versions/buildColumns.tsx"],"sourcesContent":["import type { I18n } from '@payloadcms/translations'\nimport type { SanitizedCollectionConfig, SanitizedConfig, SanitizedGlobalConfig } from 'payload'\n\nimport { type Column, SortColumn } from '@payloadcms/ui'\nimport React from 'react'\n\nimport { AutosaveCell } from './cells/AutosaveCell/index.js'\nimport { CreatedAtCell } from './cells/CreatedAt/index.js'\nimport { IDCell } from './cells/ID/index.js'\n\nexport const buildVersionColumns = ({\n collectionConfig,\n docID,\n globalConfig,\n i18n: { t },\n}: {\n collectionConfig?: SanitizedCollectionConfig\n config: SanitizedConfig\n docID?: number | string\n globalConfig?: SanitizedGlobalConfig\n i18n: I18n\n}): Column[] => {\n const entityConfig = collectionConfig || globalConfig\n\n const columns: Column[] = [\n {\n name: '',\n type: 'date',\n Label: '',\n accessor: 'updatedAt',\n active: true,\n components: {\n Cell: (\n <CreatedAtCell\n collectionSlug={collectionConfig?.slug}\n docID={docID}\n globalSlug={globalConfig?.slug}\n />\n ),\n Heading: <SortColumn Label={t('general:updatedAt')} name=\"updatedAt\" />,\n },\n },\n {\n name: '',\n type: 'text',\n Label: '',\n accessor: 'id',\n active: true,\n components: {\n Cell: <IDCell />,\n Heading: <SortColumn Label={t('version:versionID')} disable name=\"id\" />,\n },\n },\n ]\n\n if (\n entityConfig?.versions?.drafts ||\n (entityConfig?.versions?.drafts && entityConfig.versions.drafts?.autosave)\n ) {\n columns.push({\n name: '',\n type: 'checkbox',\n Label: '',\n accessor: '_status',\n active: true,\n components: {\n Cell: <AutosaveCell
|
|
1
|
+
{"version":3,"sources":["../../../src/views/Versions/buildColumns.tsx"],"sourcesContent":["import type { I18n } from '@payloadcms/translations'\nimport type { SanitizedCollectionConfig, SanitizedConfig, SanitizedGlobalConfig } from 'payload'\n\nimport { type Column, SortColumn } from '@payloadcms/ui'\nimport React from 'react'\n\nimport { AutosaveCell } from './cells/AutosaveCell/index.js'\nimport { CreatedAtCell } from './cells/CreatedAt/index.js'\nimport { IDCell } from './cells/ID/index.js'\n\nexport const buildVersionColumns = ({\n collectionConfig,\n docID,\n globalConfig,\n i18n: { t },\n latestDraftVersion,\n latestPublishedVersion,\n}: {\n collectionConfig?: SanitizedCollectionConfig\n config: SanitizedConfig\n docID?: number | string\n globalConfig?: SanitizedGlobalConfig\n i18n: I18n\n latestDraftVersion?: string\n latestPublishedVersion?: string\n}): Column[] => {\n const entityConfig = collectionConfig || globalConfig\n\n const columns: Column[] = [\n {\n name: '',\n type: 'date',\n Label: '',\n accessor: 'updatedAt',\n active: true,\n components: {\n Cell: (\n <CreatedAtCell\n collectionSlug={collectionConfig?.slug}\n docID={docID}\n globalSlug={globalConfig?.slug}\n />\n ),\n Heading: <SortColumn Label={t('general:updatedAt')} name=\"updatedAt\" />,\n },\n },\n {\n name: '',\n type: 'text',\n Label: '',\n accessor: 'id',\n active: true,\n components: {\n Cell: <IDCell />,\n Heading: <SortColumn Label={t('version:versionID')} disable name=\"id\" />,\n },\n },\n ]\n\n if (\n entityConfig?.versions?.drafts ||\n (entityConfig?.versions?.drafts && entityConfig.versions.drafts?.autosave)\n ) {\n columns.push({\n name: '',\n type: 'checkbox',\n Label: '',\n accessor: '_status',\n active: true,\n components: {\n Cell: (\n <AutosaveCell\n latestDraftVersion={latestDraftVersion}\n latestPublishedVersion={latestPublishedVersion}\n />\n ),\n Heading: <SortColumn Label={t('version:status')} disable name=\"status\" />,\n },\n })\n }\n\n return columns\n}\n"],"names":["SortColumn","React","AutosaveCell","CreatedAtCell","IDCell","buildVersionColumns","collectionConfig","docID","globalConfig","i18n","t","latestDraftVersion","latestPublishedVersion","entityConfig","columns","name","type","Label","accessor","active","components","Cell","collectionSlug","slug","globalSlug","Heading","disable","versions","drafts","autosave","push"],"mappings":";AAGA,SAAsBA,UAAU,QAAQ,iBAAgB;AACxD,OAAOC,WAAW,QAAO;AAEzB,SAASC,YAAY,QAAQ,gCAA+B;AAC5D,SAASC,aAAa,QAAQ,6BAA4B;AAC1D,SAASC,MAAM,QAAQ,sBAAqB;AAE5C,OAAO,MAAMC,sBAAsB,CAAC,EAClCC,gBAAgB,EAChBC,KAAK,EACLC,YAAY,EACZC,MAAM,EAAEC,CAAC,EAAE,EACXC,kBAAkB,EAClBC,sBAAsB,EASvB;IACC,MAAMC,eAAeP,oBAAoBE;IAEzC,MAAMM,UAAoB;QACxB;YACEC,MAAM;YACNC,MAAM;YACNC,OAAO;YACPC,UAAU;YACVC,QAAQ;YACRC,YAAY;gBACVC,oBACE,KAAClB;oBACCmB,gBAAgBhB,kBAAkBiB;oBAClChB,OAAOA;oBACPiB,YAAYhB,cAAce;;gBAG9BE,uBAAS,KAACzB;oBAAWiB,OAAOP,EAAE;oBAAsBK,MAAK;;YAC3D;QACF;QACA;YACEA,MAAM;YACNC,MAAM;YACNC,OAAO;YACPC,UAAU;YACVC,QAAQ;YACRC,YAAY;gBACVC,oBAAM,KAACjB;gBACPqB,uBAAS,KAACzB;oBAAWiB,OAAOP,EAAE;oBAAsBgB,OAAO;oBAACX,MAAK;;YACnE;QACF;KACD;IAED,IACEF,cAAcc,UAAUC,UACvBf,cAAcc,UAAUC,UAAUf,aAAac,QAAQ,CAACC,MAAM,EAAEC,UACjE;QACAf,QAAQgB,IAAI,CAAC;YACXf,MAAM;YACNC,MAAM;YACNC,OAAO;YACPC,UAAU;YACVC,QAAQ;YACRC,YAAY;gBACVC,oBACE,KAACnB;oBACCS,oBAAoBA;oBACpBC,wBAAwBA;;gBAG5Ba,uBAAS,KAACzB;oBAAWiB,OAAOP,EAAE;oBAAmBgB,OAAO;oBAACX,MAAK;;YAChE;QACF;IACF;IAEA,OAAOD;AACT,EAAC"}
|
|
@@ -1,3 +1,9 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
|
|
2
|
+
type AutosaveCellProps = {
|
|
3
|
+
latestDraftVersion?: string;
|
|
4
|
+
latestPublishedVersion?: string;
|
|
5
|
+
};
|
|
6
|
+
export declare const renderPill: (data: any, latestVersion: any, currentLabel: any, previousLabel: any, pillStyle: any) => React.JSX.Element;
|
|
7
|
+
export declare const AutosaveCell: React.FC<AutosaveCellProps>;
|
|
8
|
+
export {};
|
|
3
9
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/views/Versions/cells/AutosaveCell/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmB,MAAM,OAAO,CAAA;AAEvC,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/views/Versions/cells/AutosaveCell/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmB,MAAM,OAAO,CAAA;AAEvC,KAAK,iBAAiB,GAAG;IACvB,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,sBAAsB,CAAC,EAAE,MAAM,CAAA;CAChC,CAAA;AAED,eAAO,MAAM,UAAU,6GAWtB,CAAA;AAED,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAqCpD,CAAA"}
|
|
@@ -2,9 +2,38 @@
|
|
|
2
2
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
3
|
import { Pill, useTableCell, useTranslation } from '@payloadcms/ui';
|
|
4
4
|
import React, { Fragment } from 'react';
|
|
5
|
-
export const
|
|
5
|
+
export const renderPill = (data, latestVersion, currentLabel, previousLabel, pillStyle)=>{
|
|
6
|
+
return /*#__PURE__*/ _jsxs(React.Fragment, {
|
|
7
|
+
children: [
|
|
8
|
+
data?.id === latestVersion ? /*#__PURE__*/ _jsx(Pill, {
|
|
9
|
+
pillStyle: pillStyle,
|
|
10
|
+
children: currentLabel
|
|
11
|
+
}) : /*#__PURE__*/ _jsx(Pill, {
|
|
12
|
+
children: previousLabel
|
|
13
|
+
}),
|
|
14
|
+
" "
|
|
15
|
+
]
|
|
16
|
+
});
|
|
17
|
+
};
|
|
18
|
+
export const AutosaveCell = ({ latestDraftVersion, latestPublishedVersion })=>{
|
|
6
19
|
const { t } = useTranslation();
|
|
7
20
|
const { rowData } = useTableCell();
|
|
21
|
+
const status = rowData?.version._status;
|
|
22
|
+
const versionInfo = {
|
|
23
|
+
draft: {
|
|
24
|
+
currentLabel: t('version:currentDraft'),
|
|
25
|
+
latestVersion: latestDraftVersion,
|
|
26
|
+
pillStyle: undefined,
|
|
27
|
+
previousLabel: t('version:draft')
|
|
28
|
+
},
|
|
29
|
+
published: {
|
|
30
|
+
currentLabel: t('version:currentPublishedVersion'),
|
|
31
|
+
latestVersion: latestPublishedVersion,
|
|
32
|
+
pillStyle: 'success',
|
|
33
|
+
previousLabel: t('version:previouslyPublished')
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
const { currentLabel, latestVersion, pillStyle, previousLabel } = versionInfo[status] || {};
|
|
8
37
|
return /*#__PURE__*/ _jsxs(Fragment, {
|
|
9
38
|
children: [
|
|
10
39
|
rowData?.autosave && /*#__PURE__*/ _jsxs(React.Fragment, {
|
|
@@ -15,18 +44,7 @@ export const AutosaveCell = ()=>{
|
|
|
15
44
|
" "
|
|
16
45
|
]
|
|
17
46
|
}),
|
|
18
|
-
|
|
19
|
-
children: [
|
|
20
|
-
/*#__PURE__*/ _jsx(Pill, {
|
|
21
|
-
pillStyle: "success",
|
|
22
|
-
children: t('version:published')
|
|
23
|
-
}),
|
|
24
|
-
" "
|
|
25
|
-
]
|
|
26
|
-
}),
|
|
27
|
-
rowData?.version._status === 'draft' && /*#__PURE__*/ _jsx(Pill, {
|
|
28
|
-
children: t('version:draft')
|
|
29
|
-
})
|
|
47
|
+
status && renderPill(rowData, latestVersion, currentLabel, previousLabel, pillStyle)
|
|
30
48
|
]
|
|
31
49
|
});
|
|
32
50
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/views/Versions/cells/AutosaveCell/index.tsx"],"sourcesContent":["'use client'\nimport { Pill, useTableCell, useTranslation } from '@payloadcms/ui'\nimport React, { Fragment } from 'react'\n\nexport const AutosaveCell: React.FC = () => {\n const { t } = useTranslation()\n
|
|
1
|
+
{"version":3,"sources":["../../../../../src/views/Versions/cells/AutosaveCell/index.tsx"],"sourcesContent":["'use client'\nimport { Pill, useTableCell, useTranslation } from '@payloadcms/ui'\nimport React, { Fragment } from 'react'\n\ntype AutosaveCellProps = {\n latestDraftVersion?: string\n latestPublishedVersion?: string\n}\n\nexport const renderPill = (data, latestVersion, currentLabel, previousLabel, pillStyle) => {\n return (\n <React.Fragment>\n {data?.id === latestVersion ? (\n <Pill pillStyle={pillStyle}>{currentLabel}</Pill>\n ) : (\n <Pill>{previousLabel}</Pill>\n )}\n \n </React.Fragment>\n )\n}\n\nexport const AutosaveCell: React.FC<AutosaveCellProps> = ({\n latestDraftVersion,\n latestPublishedVersion,\n}) => {\n const { t } = useTranslation()\n const { rowData } = useTableCell()\n\n const status = rowData?.version._status\n\n const versionInfo = {\n draft: {\n currentLabel: t('version:currentDraft'),\n latestVersion: latestDraftVersion,\n pillStyle: undefined,\n previousLabel: t('version:draft'),\n },\n published: {\n currentLabel: t('version:currentPublishedVersion'),\n latestVersion: latestPublishedVersion,\n pillStyle: 'success',\n previousLabel: t('version:previouslyPublished'),\n },\n }\n\n const { currentLabel, latestVersion, pillStyle, previousLabel } = versionInfo[status] || {}\n\n return (\n <Fragment>\n {rowData?.autosave && (\n <React.Fragment>\n <Pill>{t('version:autosave')}</Pill>\n \n </React.Fragment>\n )}\n {status && renderPill(rowData, latestVersion, currentLabel, previousLabel, pillStyle)}\n </Fragment>\n )\n}\n"],"names":["Pill","useTableCell","useTranslation","React","Fragment","renderPill","data","latestVersion","currentLabel","previousLabel","pillStyle","id","AutosaveCell","latestDraftVersion","latestPublishedVersion","t","rowData","status","version","_status","versionInfo","draft","undefined","published","autosave"],"mappings":"AAAA;;AACA,SAASA,IAAI,EAAEC,YAAY,EAAEC,cAAc,QAAQ,iBAAgB;AACnE,OAAOC,SAASC,QAAQ,QAAQ,QAAO;AAOvC,OAAO,MAAMC,aAAa,CAACC,MAAMC,eAAeC,cAAcC,eAAeC;IAC3E,qBACE,MAACP,MAAMC,QAAQ;;YACZE,MAAMK,OAAOJ,8BACZ,KAACP;gBAAKU,WAAWA;0BAAYF;+BAE7B,KAACR;0BAAMS;;YACP;;;AAIR,EAAC;AAED,OAAO,MAAMG,eAA4C,CAAC,EACxDC,kBAAkB,EAClBC,sBAAsB,EACvB;IACC,MAAM,EAAEC,CAAC,EAAE,GAAGb;IACd,MAAM,EAAEc,OAAO,EAAE,GAAGf;IAEpB,MAAMgB,SAASD,SAASE,QAAQC;IAEhC,MAAMC,cAAc;QAClBC,OAAO;YACLb,cAAcO,EAAE;YAChBR,eAAeM;YACfH,WAAWY;YACXb,eAAeM,EAAE;QACnB;QACAQ,WAAW;YACTf,cAAcO,EAAE;YAChBR,eAAeO;YACfJ,WAAW;YACXD,eAAeM,EAAE;QACnB;IACF;IAEA,MAAM,EAAEP,YAAY,EAAED,aAAa,EAAEG,SAAS,EAAED,aAAa,EAAE,GAAGW,WAAW,CAACH,OAAO,IAAI,CAAC;IAE1F,qBACE,MAACb;;YACEY,SAASQ,0BACR,MAACrB,MAAMC,QAAQ;;kCACb,KAACJ;kCAAMe,EAAE;;oBAA2B;;;YAIvCE,UAAUZ,WAAWW,SAAST,eAAeC,cAAcC,eAAeC;;;AAGjF,EAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getLatestVersion.d.ts","sourceRoot":"","sources":["../../../src/views/Versions/getLatestVersion.ts"],"names":[],"mappings":"AAAA,wBAAsB,gBAAgB,CAAC,OAAO,KAAA,EAAE,IAAI,KAAA,EAAE,MAAM,KAAA,EAAE,IAAI,SAAe;;;GA+BhF"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export async function getLatestVersion(payload, slug, status, type = 'collection') {
|
|
2
|
+
try {
|
|
3
|
+
const sharedOptions = {
|
|
4
|
+
depth: 0,
|
|
5
|
+
limit: 1,
|
|
6
|
+
sort: '-updatedAt',
|
|
7
|
+
where: {
|
|
8
|
+
'version._status': {
|
|
9
|
+
equals: status
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
const response = type === 'collection' ? await payload.findVersions({
|
|
14
|
+
collection: slug,
|
|
15
|
+
...sharedOptions
|
|
16
|
+
}) : await payload.findGlobalVersions({
|
|
17
|
+
slug,
|
|
18
|
+
...sharedOptions
|
|
19
|
+
});
|
|
20
|
+
return {
|
|
21
|
+
id: response.docs[0].id,
|
|
22
|
+
updatedAt: response.docs[0].updatedAt
|
|
23
|
+
};
|
|
24
|
+
} catch (e) {
|
|
25
|
+
console.error(e);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
//# sourceMappingURL=getLatestVersion.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/views/Versions/getLatestVersion.ts"],"sourcesContent":["export async function getLatestVersion(payload, slug, status, type = 'collection') {\n try {\n const sharedOptions = {\n depth: 0,\n limit: 1,\n sort: '-updatedAt',\n where: {\n 'version._status': {\n equals: status,\n },\n },\n }\n\n const response =\n type === 'collection'\n ? await payload.findVersions({\n collection: slug,\n ...sharedOptions,\n })\n : await payload.findGlobalVersions({\n slug,\n ...sharedOptions,\n })\n\n return {\n id: response.docs[0].id,\n updatedAt: response.docs[0].updatedAt,\n }\n } catch (e) {\n console.error(e)\n }\n}\n"],"names":["getLatestVersion","payload","slug","status","type","sharedOptions","depth","limit","sort","where","equals","response","findVersions","collection","findGlobalVersions","id","docs","updatedAt","e","console","error"],"mappings":"AAAA,OAAO,eAAeA,iBAAiBC,OAAO,EAAEC,IAAI,EAAEC,MAAM,EAAEC,OAAO,YAAY;IAC/E,IAAI;QACF,MAAMC,gBAAgB;YACpBC,OAAO;YACPC,OAAO;YACPC,MAAM;YACNC,OAAO;gBACL,mBAAmB;oBACjBC,QAAQP;gBACV;YACF;QACF;QAEA,MAAMQ,WACJP,SAAS,eACL,MAAMH,QAAQW,YAAY,CAAC;YACzBC,YAAYX;YACZ,GAAGG,aAAa;QAClB,KACA,MAAMJ,QAAQa,kBAAkB,CAAC;YAC/BZ;YACA,GAAGG,aAAa;QAClB;QAEN,OAAO;YACLU,IAAIJ,SAASK,IAAI,CAAC,EAAE,CAACD,EAAE;YACvBE,WAAWN,SAASK,IAAI,CAAC,EAAE,CAACC,SAAS;QACvC;IACF,EAAE,OAAOC,GAAG;QACVC,QAAQC,KAAK,CAACF;IAChB;AACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Versions/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAiB,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/views/Versions/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAiB,MAAM,SAAS,CAAA;AAW/D,OAAO,cAAc,CAAA;AAErB,eAAO,MAAM,SAAS,aAAa,CAAA;AAEnC,eAAO,MAAM,YAAY,EAAE,iBA8I1B,CAAA"}
|
|
@@ -5,6 +5,7 @@ import { isNumber } from 'payload/shared';
|
|
|
5
5
|
import React from 'react';
|
|
6
6
|
import { SetDocumentStepNav } from '../Edit/Default/SetDocumentStepNav/index.js';
|
|
7
7
|
import { buildVersionColumns } from './buildColumns.js';
|
|
8
|
+
import { getLatestVersion } from './getLatestVersion.js';
|
|
8
9
|
import { VersionsViewClient } from './index.client.js';
|
|
9
10
|
export const baseClass = 'versions';
|
|
10
11
|
export const VersionsView = async (props)=>{
|
|
@@ -16,6 +17,8 @@ export const VersionsView = async (props)=>{
|
|
|
16
17
|
const { routes: { api: apiRoute }, serverURL } = config;
|
|
17
18
|
let versionsData;
|
|
18
19
|
let limitToUse = isNumber(limit) ? Number(limit) : undefined;
|
|
20
|
+
let latestPublishedVersion = null;
|
|
21
|
+
let latestDraftVersion = null;
|
|
19
22
|
if (collectionSlug) {
|
|
20
23
|
limitToUse = limitToUse || collectionConfig.admin.pagination.defaultLimit;
|
|
21
24
|
try {
|
|
@@ -34,6 +37,10 @@ export const VersionsView = async (props)=>{
|
|
|
34
37
|
}
|
|
35
38
|
}
|
|
36
39
|
});
|
|
40
|
+
if (collectionConfig?.versions?.drafts) {
|
|
41
|
+
latestDraftVersion = await getLatestVersion(payload, collectionSlug, 'draft', 'collection');
|
|
42
|
+
latestPublishedVersion = await getLatestVersion(payload, collectionSlug, 'published', 'collection');
|
|
43
|
+
}
|
|
37
44
|
} catch (error) {
|
|
38
45
|
console.error(error) // eslint-disable-line no-console
|
|
39
46
|
;
|
|
@@ -52,6 +59,10 @@ export const VersionsView = async (props)=>{
|
|
|
52
59
|
sort: sort,
|
|
53
60
|
user
|
|
54
61
|
});
|
|
62
|
+
if (globalConfig?.versions?.drafts) {
|
|
63
|
+
latestDraftVersion = await getLatestVersion(payload, globalSlug, 'draft', 'global');
|
|
64
|
+
latestPublishedVersion = await getLatestVersion(payload, globalSlug, 'published', 'global');
|
|
65
|
+
}
|
|
55
66
|
} catch (error) {
|
|
56
67
|
console.error(error) // eslint-disable-line no-console
|
|
57
68
|
;
|
|
@@ -60,14 +71,23 @@ export const VersionsView = async (props)=>{
|
|
|
60
71
|
return notFound();
|
|
61
72
|
}
|
|
62
73
|
}
|
|
74
|
+
const fetchURL = collectionSlug ? `${serverURL}${apiRoute}/${collectionSlug}/versions` : globalSlug ? `${serverURL}${apiRoute}/globals/${globalSlug}/versions` : '';
|
|
75
|
+
const publishedNewerThanDraft = latestPublishedVersion?.updatedAt > latestDraftVersion?.updatedAt;
|
|
76
|
+
if (publishedNewerThanDraft) {
|
|
77
|
+
latestDraftVersion = {
|
|
78
|
+
id: '',
|
|
79
|
+
updatedAt: ''
|
|
80
|
+
};
|
|
81
|
+
}
|
|
63
82
|
const columns = buildVersionColumns({
|
|
64
83
|
collectionConfig,
|
|
65
84
|
config,
|
|
66
85
|
docID: id,
|
|
67
86
|
globalConfig,
|
|
68
|
-
i18n
|
|
87
|
+
i18n,
|
|
88
|
+
latestDraftVersion: latestDraftVersion?.id,
|
|
89
|
+
latestPublishedVersion: latestPublishedVersion?.id
|
|
69
90
|
});
|
|
70
|
-
const fetchURL = collectionSlug ? `${serverURL}${apiRoute}/${collectionSlug}/versions` : globalSlug ? `${serverURL}${apiRoute}/globals/${globalSlug}/versions` : '';
|
|
71
91
|
return /*#__PURE__*/ _jsxs(React.Fragment, {
|
|
72
92
|
children: [
|
|
73
93
|
/*#__PURE__*/ _jsx(SetDocumentStepNav, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/views/Versions/index.tsx"],"sourcesContent":["import type { EditViewComponent, PaginatedDocs } from 'payload'\n\nimport { Gutter, ListQueryProvider } from '@payloadcms/ui'\nimport { notFound } from 'next/navigation.js'\nimport { isNumber } from 'payload/shared'\nimport React from 'react'\n\nimport { SetDocumentStepNav } from '../Edit/Default/SetDocumentStepNav/index.js'\nimport { buildVersionColumns } from './buildColumns.js'\nimport { VersionsViewClient } from './index.client.js'\nimport './index.scss'\n\nexport const baseClass = 'versions'\n\nexport const VersionsView: EditViewComponent = async (props) => {\n const { initPageResult, searchParams } = props\n\n const {\n collectionConfig,\n docID: id,\n globalConfig,\n req,\n req: {\n i18n,\n payload,\n payload: { config },\n user,\n },\n } = initPageResult\n\n const collectionSlug = collectionConfig?.slug\n const globalSlug = globalConfig?.slug\n const { limit, page, sort } = searchParams\n\n const {\n routes: { api: apiRoute },\n serverURL,\n } = config\n\n let versionsData: PaginatedDocs\n let limitToUse = isNumber(limit) ? Number(limit) : undefined\n\n if (collectionSlug) {\n limitToUse = limitToUse || collectionConfig.admin.pagination.defaultLimit\n try {\n versionsData = await payload.findVersions({\n collection: collectionSlug,\n depth: 0,\n limit: limitToUse,\n overrideAccess: false,\n page: page ? parseInt(page.toString(), 10) : undefined,\n req,\n sort: sort as string,\n user,\n where: {\n parent: {\n equals: id,\n },\n },\n })\n } catch (error) {\n console.error(error) // eslint-disable-line no-console\n }\n }\n\n if (globalSlug) {\n limitToUse = limitToUse || 10\n try {\n versionsData = await payload.findGlobalVersions({\n slug: globalSlug,\n depth: 0,\n limit: limitToUse,\n overrideAccess: false,\n page: page ? parseInt(page as string, 10) : undefined,\n req,\n sort: sort as string,\n user,\n })\n } catch (error) {\n console.error(error) // eslint-disable-line no-console\n }\n\n if (!versionsData) {\n return notFound()\n }\n }\n
|
|
1
|
+
{"version":3,"sources":["../../../src/views/Versions/index.tsx"],"sourcesContent":["import type { EditViewComponent, PaginatedDocs } from 'payload'\n\nimport { Gutter, ListQueryProvider } from '@payloadcms/ui'\nimport { notFound } from 'next/navigation.js'\nimport { isNumber } from 'payload/shared'\nimport React from 'react'\n\nimport { SetDocumentStepNav } from '../Edit/Default/SetDocumentStepNav/index.js'\nimport { buildVersionColumns } from './buildColumns.js'\nimport { getLatestVersion } from './getLatestVersion.js'\nimport { VersionsViewClient } from './index.client.js'\nimport './index.scss'\n\nexport const baseClass = 'versions'\n\nexport const VersionsView: EditViewComponent = async (props) => {\n const { initPageResult, searchParams } = props\n\n const {\n collectionConfig,\n docID: id,\n globalConfig,\n req,\n req: {\n i18n,\n payload,\n payload: { config },\n user,\n },\n } = initPageResult\n\n const collectionSlug = collectionConfig?.slug\n const globalSlug = globalConfig?.slug\n const { limit, page, sort } = searchParams\n\n const {\n routes: { api: apiRoute },\n serverURL,\n } = config\n\n let versionsData: PaginatedDocs\n let limitToUse = isNumber(limit) ? Number(limit) : undefined\n let latestPublishedVersion = null\n let latestDraftVersion = null\n\n if (collectionSlug) {\n limitToUse = limitToUse || collectionConfig.admin.pagination.defaultLimit\n try {\n versionsData = await payload.findVersions({\n collection: collectionSlug,\n depth: 0,\n limit: limitToUse,\n overrideAccess: false,\n page: page ? parseInt(page.toString(), 10) : undefined,\n req,\n sort: sort as string,\n user,\n where: {\n parent: {\n equals: id,\n },\n },\n })\n if (collectionConfig?.versions?.drafts) {\n latestDraftVersion = await getLatestVersion(payload, collectionSlug, 'draft', 'collection')\n latestPublishedVersion = await getLatestVersion(\n payload,\n collectionSlug,\n 'published',\n 'collection',\n )\n }\n } catch (error) {\n console.error(error) // eslint-disable-line no-console\n }\n }\n\n if (globalSlug) {\n limitToUse = limitToUse || 10\n try {\n versionsData = await payload.findGlobalVersions({\n slug: globalSlug,\n depth: 0,\n limit: limitToUse,\n overrideAccess: false,\n page: page ? parseInt(page as string, 10) : undefined,\n req,\n sort: sort as string,\n user,\n })\n\n if (globalConfig?.versions?.drafts) {\n latestDraftVersion = await getLatestVersion(payload, globalSlug, 'draft', 'global')\n latestPublishedVersion = await getLatestVersion(payload, globalSlug, 'published', 'global')\n }\n } catch (error) {\n console.error(error) // eslint-disable-line no-console\n }\n\n if (!versionsData) {\n return notFound()\n }\n }\n const fetchURL = collectionSlug\n ? `${serverURL}${apiRoute}/${collectionSlug}/versions`\n : globalSlug\n ? `${serverURL}${apiRoute}/globals/${globalSlug}/versions`\n : ''\n\n const publishedNewerThanDraft = latestPublishedVersion?.updatedAt > latestDraftVersion?.updatedAt\n\n if (publishedNewerThanDraft) {\n latestDraftVersion = {\n id: '',\n updatedAt: '',\n }\n }\n\n const columns = buildVersionColumns({\n collectionConfig,\n config,\n docID: id,\n globalConfig,\n i18n,\n latestDraftVersion: latestDraftVersion?.id,\n latestPublishedVersion: latestPublishedVersion?.id,\n })\n\n return (\n <React.Fragment>\n <SetDocumentStepNav\n collectionSlug={collectionConfig?.slug}\n globalSlug={globalConfig?.slug}\n id={id}\n pluralLabel={collectionConfig?.labels?.plural || globalConfig?.label}\n useAsTitle={collectionConfig?.admin?.useAsTitle || globalConfig?.slug}\n view={i18n.t('version:versions')}\n />\n <main className={baseClass}>\n <Gutter className={`${baseClass}__wrap`}>\n <ListQueryProvider\n data={versionsData}\n defaultLimit={limitToUse}\n defaultSort={sort as string}\n modifySearchParams\n >\n <VersionsViewClient\n baseClass={baseClass}\n columns={columns}\n fetchURL={fetchURL}\n paginationLimits={collectionConfig?.admin?.pagination?.limits}\n />\n </ListQueryProvider>\n </Gutter>\n </main>\n </React.Fragment>\n )\n}\n"],"names":["Gutter","ListQueryProvider","notFound","isNumber","React","SetDocumentStepNav","buildVersionColumns","getLatestVersion","VersionsViewClient","baseClass","VersionsView","props","initPageResult","searchParams","collectionConfig","docID","id","globalConfig","req","i18n","payload","config","user","collectionSlug","slug","globalSlug","limit","page","sort","routes","api","apiRoute","serverURL","versionsData","limitToUse","Number","undefined","latestPublishedVersion","latestDraftVersion","admin","pagination","defaultLimit","findVersions","collection","depth","overrideAccess","parseInt","toString","where","parent","equals","versions","drafts","error","console","findGlobalVersions","fetchURL","publishedNewerThanDraft","updatedAt","columns","Fragment","pluralLabel","labels","plural","label","useAsTitle","view","t","main","className","data","defaultSort","modifySearchParams","paginationLimits","limits"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@payloadcms/next",
|
|
3
|
-
"version": "3.0.0-beta.
|
|
3
|
+
"version": "3.0.0-beta.63",
|
|
4
4
|
"homepage": "https://payloadcms.com",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -63,9 +63,9 @@
|
|
|
63
63
|
"sonner": "^1.5.0",
|
|
64
64
|
"uuid": "10.0.0",
|
|
65
65
|
"ws": "^8.16.0",
|
|
66
|
-
"@payloadcms/graphql": "3.0.0-beta.
|
|
67
|
-
"@payloadcms/
|
|
68
|
-
"@payloadcms/
|
|
66
|
+
"@payloadcms/graphql": "3.0.0-beta.63",
|
|
67
|
+
"@payloadcms/ui": "3.0.0-beta.63",
|
|
68
|
+
"@payloadcms/translations": "3.0.0-beta.63"
|
|
69
69
|
},
|
|
70
70
|
"devDependencies": {
|
|
71
71
|
"@next/eslint-plugin-next": "^14.1.0",
|
|
@@ -78,12 +78,12 @@
|
|
|
78
78
|
"esbuild-sass-plugin": "3.3.1",
|
|
79
79
|
"swc-plugin-transform-remove-imports": "1.14.0",
|
|
80
80
|
"@payloadcms/eslint-config": "3.0.0-beta.59",
|
|
81
|
-
"payload": "3.0.0-beta.
|
|
81
|
+
"payload": "3.0.0-beta.63"
|
|
82
82
|
},
|
|
83
83
|
"peerDependencies": {
|
|
84
84
|
"graphql": "^16.8.1",
|
|
85
85
|
"next": "^15.0.0-canary.53",
|
|
86
|
-
"payload": "3.0.0-beta.
|
|
86
|
+
"payload": "3.0.0-beta.63"
|
|
87
87
|
},
|
|
88
88
|
"engines": {
|
|
89
89
|
"node": "^18.20.2 || >=20.9.0"
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"shared.d.ts","sourceRoot":"","sources":["../../../src/views/Version/shared.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,uBAAuB;;;CAGnC,CAAA;AAED,eAAO,MAAM,sBAAsB;;;CAGlC,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/views/Version/shared.ts"],"sourcesContent":["export const mostRecentVersionOption = {\n label: 'Most recent',\n value: 'mostRecent',\n}\n\nexport const publishedVersionOption = {\n label: 'Most recently published',\n value: 'published',\n}\n"],"names":["mostRecentVersionOption","label","value","publishedVersionOption"],"mappings":"AAAA,OAAO,MAAMA,0BAA0B;IACrCC,OAAO;IACPC,OAAO;AACT,EAAC;AAED,OAAO,MAAMC,yBAAyB;IACpCF,OAAO;IACPC,OAAO;AACT,EAAC"}
|