@payloadcms/next 3.19.0 → 3.20.0-canary.0e01b65
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/Account/index.d.ts.map +1 -1
- package/dist/views/Account/index.js +2 -1
- package/dist/views/Account/index.js.map +1 -1
- package/dist/views/CreateFirstUser/index.client.d.ts.map +1 -1
- package/dist/views/CreateFirstUser/index.client.js +4 -2
- package/dist/views/CreateFirstUser/index.client.js.map +1 -1
- package/dist/views/CreateFirstUser/index.d.ts.map +1 -1
- package/dist/views/CreateFirstUser/index.js +2 -1
- package/dist/views/CreateFirstUser/index.js.map +1 -1
- package/dist/views/Document/getDocumentPermissions.js +2 -2
- package/dist/views/Document/getDocumentPermissions.js.map +1 -1
- package/dist/views/Document/index.d.ts.map +1 -1
- package/dist/views/Document/index.js +2 -1
- package/dist/views/Document/index.js.map +1 -1
- package/dist/views/ForgotPassword/ForgotPasswordForm/index.d.ts.map +1 -1
- package/dist/views/ForgotPassword/ForgotPasswordForm/index.js +2 -0
- package/dist/views/ForgotPassword/ForgotPasswordForm/index.js.map +1 -1
- package/dist/views/LivePreview/index.client.d.ts.map +1 -1
- package/dist/views/LivePreview/index.client.js +5 -2
- package/dist/views/LivePreview/index.client.js.map +1 -1
- package/dist/views/Version/Default/SelectedLocalesContext.d.ts +8 -0
- package/dist/views/Version/Default/SelectedLocalesContext.d.ts.map +1 -0
- package/dist/views/Version/Default/SelectedLocalesContext.js +10 -0
- package/dist/views/Version/Default/SelectedLocalesContext.js.map +1 -0
- package/dist/views/Version/Default/index.d.ts.map +1 -1
- package/dist/views/Version/Default/index.js +89 -159
- package/dist/views/Version/Default/index.js.map +1 -1
- package/dist/views/Version/Default/types.d.ts +4 -4
- 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/RenderFieldsToDiff/DiffCollapser/index.d.ts +27 -0
- package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js +76 -0
- package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.scss +46 -0
- package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.d.ts +6 -0
- package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js +36 -0
- package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.d.ts +30 -0
- package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js +300 -0
- package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.d.ts +4 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js +64 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.d.ts +5 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js +69 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.scss +14 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.d.ts +3 -4
- package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.d.ts.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js +100 -63
- package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.scss +3 -12
- package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.d.ts +2 -4
- package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.d.ts.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js +18 -17
- package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.d.ts +4 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.js +17 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Row/index.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.d.ts +2 -4
- package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.d.ts.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js +56 -28
- package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.d.ts +3 -4
- package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.d.ts.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js +146 -42
- package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.scss +20 -0
- package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.d.ts +2 -4
- package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.d.ts.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js +71 -37
- package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/index.d.ts +2 -22
- package/dist/views/Version/RenderFieldsToDiff/fields/index.d.ts.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/index.js +13 -9
- package/dist/views/Version/RenderFieldsToDiff/fields/index.js.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/index.d.ts +2 -5
- package/dist/views/Version/RenderFieldsToDiff/index.d.ts.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/index.js +8 -113
- package/dist/views/Version/RenderFieldsToDiff/index.js.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/types.d.ts +2 -20
- package/dist/views/Version/RenderFieldsToDiff/types.d.ts.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/types.js.map +1 -1
- package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.d.ts +21 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.js +194 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.spec.js +860 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/countChangedFields.spec.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.d.ts +2 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.js +4 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.spec.js +46 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/fieldHasChanges.spec.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldPathsModified.d.ts +27 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldPathsModified.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldPathsModified.js +30 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldPathsModified.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.d.ts +18 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.d.ts.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.js +44 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.js.map +1 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.spec.js +122 -0
- package/dist/views/Version/RenderFieldsToDiff/utilities/getFieldsForRowComparison.spec.js.map +1 -0
- package/dist/views/Version/Restore/index.d.ts.map +1 -1
- package/dist/views/Version/Restore/index.js +2 -2
- package/dist/views/Version/Restore/index.js.map +1 -1
- package/dist/views/Version/SelectComparison/index.d.ts.map +1 -1
- package/dist/views/Version/SelectComparison/index.js +7 -3
- package/dist/views/Version/SelectComparison/index.js.map +1 -1
- package/dist/views/Version/index.d.ts.map +1 -1
- package/dist/views/Version/index.js +117 -15
- package/dist/views/Version/index.js.map +1 -1
- package/dist/views/Versions/getLatestVersion.d.ts +4 -1
- package/dist/views/Versions/getLatestVersion.d.ts.map +1 -1
- package/dist/views/Versions/getLatestVersion.js +6 -0
- package/dist/views/Versions/getLatestVersion.js.map +1 -1
- package/package.json +8 -8
- package/dist/views/Version/RenderFieldsToDiff/fields/Nested/index.d.ts +0 -6
- package/dist/views/Version/RenderFieldsToDiff/fields/Nested/index.d.ts.map +0 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Nested/index.js +0 -43
- package/dist/views/Version/RenderFieldsToDiff/fields/Nested/index.js.map +0 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/Nested/index.scss +0 -14
- package/dist/views/Version/RenderFieldsToDiff/fields/types.d.ts +0 -22
- package/dist/views/Version/RenderFieldsToDiff/fields/types.d.ts.map +0 -1
- package/dist/views/Version/RenderFieldsToDiff/fields/types.js +0 -2
- package/dist/views/Version/RenderFieldsToDiff/fields/types.js.map +0 -1
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { ChevronIcon, Pill, useTranslation } from '@payloadcms/ui';
|
|
3
|
+
import { fieldIsArrayType, fieldIsBlockType } from 'payload/shared';
|
|
4
|
+
import React, { useState } from 'react';
|
|
5
|
+
import Label from '../Label/index.js';
|
|
6
|
+
import { countChangedFields, countChangedFieldsInRows } from '../utilities/countChangedFields.js';
|
|
7
|
+
const baseClass = 'diff-collapser';
|
|
8
|
+
export const DiffCollapser = ({
|
|
9
|
+
children,
|
|
10
|
+
comparison,
|
|
11
|
+
field,
|
|
12
|
+
fields,
|
|
13
|
+
initCollapsed = false,
|
|
14
|
+
isIterable = false,
|
|
15
|
+
label,
|
|
16
|
+
locales,
|
|
17
|
+
version
|
|
18
|
+
}) => {
|
|
19
|
+
const {
|
|
20
|
+
t
|
|
21
|
+
} = useTranslation();
|
|
22
|
+
const [isCollapsed, setIsCollapsed] = useState(initCollapsed);
|
|
23
|
+
let changeCount = 0;
|
|
24
|
+
if (isIterable) {
|
|
25
|
+
if (!fieldIsArrayType(field) && !fieldIsBlockType(field)) {
|
|
26
|
+
throw new Error('DiffCollapser: field must be an array or blocks field when isIterable is true');
|
|
27
|
+
}
|
|
28
|
+
const comparisonRows = comparison ?? [];
|
|
29
|
+
const versionRows = version ?? [];
|
|
30
|
+
if (!Array.isArray(comparisonRows) || !Array.isArray(versionRows)) {
|
|
31
|
+
throw new Error('DiffCollapser: comparison and version must be arrays when isIterable is true');
|
|
32
|
+
}
|
|
33
|
+
changeCount = countChangedFieldsInRows({
|
|
34
|
+
comparisonRows,
|
|
35
|
+
field,
|
|
36
|
+
locales,
|
|
37
|
+
versionRows
|
|
38
|
+
});
|
|
39
|
+
} else {
|
|
40
|
+
changeCount = countChangedFields({
|
|
41
|
+
comparison,
|
|
42
|
+
fields,
|
|
43
|
+
locales,
|
|
44
|
+
version
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
const contentClassNames = [`${baseClass}__content`, isCollapsed && `${baseClass}__content--is-collapsed`].filter(Boolean).join(' ');
|
|
48
|
+
return /*#__PURE__*/_jsxs("div", {
|
|
49
|
+
className: baseClass,
|
|
50
|
+
children: [/*#__PURE__*/_jsxs(Label, {
|
|
51
|
+
children: [/*#__PURE__*/_jsx("button", {
|
|
52
|
+
"aria-label": isCollapsed ? 'Expand' : 'Collapse',
|
|
53
|
+
className: `${baseClass}__toggle-button`,
|
|
54
|
+
onClick: () => setIsCollapsed(!isCollapsed),
|
|
55
|
+
type: "button",
|
|
56
|
+
children: /*#__PURE__*/_jsx(ChevronIcon, {
|
|
57
|
+
direction: isCollapsed ? 'right' : 'down'
|
|
58
|
+
})
|
|
59
|
+
}), /*#__PURE__*/_jsx("span", {
|
|
60
|
+
className: `${baseClass}__label`,
|
|
61
|
+
children: label
|
|
62
|
+
}), changeCount > 0 && /*#__PURE__*/_jsx(Pill, {
|
|
63
|
+
className: `${baseClass}__field-change-count`,
|
|
64
|
+
pillStyle: "light-gray",
|
|
65
|
+
size: "small",
|
|
66
|
+
children: t('version:changedFieldsCount', {
|
|
67
|
+
count: changeCount
|
|
68
|
+
})
|
|
69
|
+
})]
|
|
70
|
+
}), /*#__PURE__*/_jsx("div", {
|
|
71
|
+
className: contentClassNames,
|
|
72
|
+
children: children
|
|
73
|
+
})]
|
|
74
|
+
});
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":["ChevronIcon","Pill","useTranslation","fieldIsArrayType","fieldIsBlockType","React","useState","Label","countChangedFields","countChangedFieldsInRows","baseClass","DiffCollapser","children","comparison","field","fields","initCollapsed","isIterable","label","locales","version","t","isCollapsed","setIsCollapsed","changeCount","Error","comparisonRows","versionRows","Array","isArray","contentClassNames","filter","Boolean","join","_jsxs","className","_jsx","onClick","type","direction","pillStyle","size","count"],"sources":["../../../../../src/views/Version/RenderFieldsToDiff/DiffCollapser/index.tsx"],"sourcesContent":["import type { ClientField } from 'payload'\n\nimport { ChevronIcon, Pill, useTranslation } from '@payloadcms/ui'\nimport { fieldIsArrayType, fieldIsBlockType } from 'payload/shared'\nimport React, { useState } from 'react'\n\nimport Label from '../Label/index.js'\nimport './index.scss'\nimport { countChangedFields, countChangedFieldsInRows } from '../utilities/countChangedFields.js'\n\nconst baseClass = 'diff-collapser'\n\ntype Props =\n | {\n // fields collapser\n children: React.ReactNode\n comparison: unknown\n field?: never\n fields: ClientField[]\n initCollapsed?: boolean\n isIterable?: false\n label: React.ReactNode\n locales: string[] | undefined\n version: unknown\n }\n | {\n // iterable collapser\n children: React.ReactNode\n comparison?: unknown\n field: ClientField\n fields?: never\n initCollapsed?: boolean\n isIterable: true\n label: React.ReactNode\n locales: string[] | undefined\n version: unknown\n }\n\nexport const DiffCollapser: React.FC<Props> = ({\n children,\n comparison,\n field,\n fields,\n initCollapsed = false,\n isIterable = false,\n label,\n locales,\n version,\n}) => {\n const { t } = useTranslation()\n const [isCollapsed, setIsCollapsed] = useState(initCollapsed)\n\n let changeCount = 0\n\n if (isIterable) {\n if (!fieldIsArrayType(field) && !fieldIsBlockType(field)) {\n throw new Error(\n 'DiffCollapser: field must be an array or blocks field when isIterable is true',\n )\n }\n const comparisonRows = comparison ?? []\n const versionRows = version ?? []\n\n if (!Array.isArray(comparisonRows) || !Array.isArray(versionRows)) {\n throw new Error(\n 'DiffCollapser: comparison and version must be arrays when isIterable is true',\n )\n }\n\n changeCount = countChangedFieldsInRows({\n comparisonRows,\n field,\n locales,\n versionRows,\n })\n } else {\n changeCount = countChangedFields({\n comparison,\n fields,\n locales,\n version,\n })\n }\n\n const contentClassNames = [\n `${baseClass}__content`,\n isCollapsed && `${baseClass}__content--is-collapsed`,\n ]\n .filter(Boolean)\n .join(' ')\n\n return (\n <div className={baseClass}>\n <Label>\n <button\n aria-label={isCollapsed ? 'Expand' : 'Collapse'}\n className={`${baseClass}__toggle-button`}\n onClick={() => setIsCollapsed(!isCollapsed)}\n type=\"button\"\n >\n <ChevronIcon direction={isCollapsed ? 'right' : 'down'} />\n </button>\n <span className={`${baseClass}__label`}>{label}</span>\n {changeCount > 0 && (\n <Pill className={`${baseClass}__field-change-count`} pillStyle=\"light-gray\" size=\"small\">\n {t('version:changedFieldsCount', { count: changeCount })}\n </Pill>\n )}\n </Label>\n <div className={contentClassNames}>{children}</div>\n </div>\n )\n}\n"],"mappings":";AAEA,SAASA,WAAW,EAAEC,IAAI,EAAEC,cAAc,QAAQ;AAClD,SAASC,gBAAgB,EAAEC,gBAAgB,QAAQ;AACnD,OAAOC,KAAA,IAASC,QAAQ,QAAQ;AAEhC,OAAOC,KAAA,MAAW;AAElB,SAASC,kBAAkB,EAAEC,wBAAwB,QAAQ;AAE7D,MAAMC,SAAA,GAAY;AA4BlB,OAAO,MAAMC,aAAA,GAAiCA,CAAC;EAC7CC,QAAQ;EACRC,UAAU;EACVC,KAAK;EACLC,MAAM;EACNC,aAAA,GAAgB,KAAK;EACrBC,UAAA,GAAa,KAAK;EAClBC,KAAK;EACLC,OAAO;EACPC;AAAO,CACR;EACC,MAAM;IAAEC;EAAC,CAAE,GAAGnB,cAAA;EACd,MAAM,CAACoB,WAAA,EAAaC,cAAA,CAAe,GAAGjB,QAAA,CAASU,aAAA;EAE/C,IAAIQ,WAAA,GAAc;EAElB,IAAIP,UAAA,EAAY;IACd,IAAI,CAACd,gBAAA,CAAiBW,KAAA,KAAU,CAACV,gBAAA,CAAiBU,KAAA,GAAQ;MACxD,MAAM,IAAIW,KAAA,CACR;IAEJ;IACA,MAAMC,cAAA,GAAiBb,UAAA,IAAc,EAAE;IACvC,MAAMc,WAAA,GAAcP,OAAA,IAAW,EAAE;IAEjC,IAAI,CAACQ,KAAA,CAAMC,OAAO,CAACH,cAAA,KAAmB,CAACE,KAAA,CAAMC,OAAO,CAACF,WAAA,GAAc;MACjE,MAAM,IAAIF,KAAA,CACR;IAEJ;IAEAD,WAAA,GAAcf,wBAAA,CAAyB;MACrCiB,cAAA;MACAZ,KAAA;MACAK,OAAA;MACAQ;IACF;EACF,OAAO;IACLH,WAAA,GAAchB,kBAAA,CAAmB;MAC/BK,UAAA;MACAE,MAAA;MACAI,OAAA;MACAC;IACF;EACF;EAEA,MAAMU,iBAAA,GAAoB,CACxB,GAAGpB,SAAA,WAAoB,EACvBY,WAAA,IAAe,GAAGZ,SAAA,yBAAkC,CACrD,CACEqB,MAAM,CAACC,OAAA,EACPC,IAAI,CAAC;EAER,oBACEC,KAAA,CAAC;IAAIC,SAAA,EAAWzB,SAAA;4BACdwB,KAAA,CAAC3B,KAAA;8BACC6B,IAAA,CAAC;QACC,cAAYd,WAAA,GAAc,WAAW;QACrCa,SAAA,EAAW,GAAGzB,SAAA,iBAA0B;QACxC2B,OAAA,EAASA,CAAA,KAAMd,cAAA,CAAe,CAACD,WAAA;QAC/BgB,IAAA,EAAK;kBAEL,aAAAF,IAAA,CAACpC,WAAA;UAAYuC,SAAA,EAAWjB,WAAA,GAAc,UAAU;;uBAElDc,IAAA,CAAC;QAAKD,SAAA,EAAW,GAAGzB,SAAA,SAAkB;kBAAGQ;UACxCM,WAAA,GAAc,kBACbY,IAAA,CAACnC,IAAA;QAAKkC,SAAA,EAAW,GAAGzB,SAAA,sBAA+B;QAAE8B,SAAA,EAAU;QAAaC,IAAA,EAAK;kBAC9EpB,CAAA,CAAE,8BAA8B;UAAEqB,KAAA,EAAOlB;QAAY;;qBAI5DY,IAAA,CAAC;MAAID,SAAA,EAAWL,iBAAA;gBAAoBlB;;;AAG1C","ignoreList":[]}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
@layer payload-default {
|
|
2
|
+
.diff-collapser {
|
|
3
|
+
&__toggle-button {
|
|
4
|
+
all: unset;
|
|
5
|
+
cursor: pointer;
|
|
6
|
+
// Align the chevron visually with the label text
|
|
7
|
+
vertical-align: 1px;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
&__label {
|
|
11
|
+
// Add space between label, chevron, and change count
|
|
12
|
+
margin: 0 calc(var(--base) * 0.25);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
&__field-change-count {
|
|
16
|
+
// Reset the font weight of the change count to normal
|
|
17
|
+
font-weight: normal;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
&__content {
|
|
21
|
+
[dir='ltr'] & {
|
|
22
|
+
// Vertical gutter
|
|
23
|
+
border-left: 3px solid var(--theme-elevation-50);
|
|
24
|
+
// Center-align the gutter with the chevron
|
|
25
|
+
margin-left: 3px;
|
|
26
|
+
// Content indentation
|
|
27
|
+
padding-left: calc(var(--base) * 0.5);
|
|
28
|
+
}
|
|
29
|
+
[dir='rtl'] & {
|
|
30
|
+
// Vertical gutter
|
|
31
|
+
border-right: 3px solid var(--theme-elevation-50);
|
|
32
|
+
// Center-align the gutter with the chevron
|
|
33
|
+
margin-right: 3px;
|
|
34
|
+
// Content indentation
|
|
35
|
+
padding-right: calc(var(--base) * 0.5);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
&__content--is-collapsed {
|
|
40
|
+
// Hide the content when collapsed. We use display: none instead of
|
|
41
|
+
// conditional rendering to avoid loosing children's collapsed state when
|
|
42
|
+
// remounting.
|
|
43
|
+
display: none;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RenderVersionFieldsToDiff.d.ts","sourceRoot":"","sources":["../../../../src/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAE3C,OAAO,cAAc,CAAA;AAErB,eAAO,MAAM,yBAAyB,uBAEnC;IACD,aAAa,EAAE,YAAY,EAAE,CAAA;CAC9B,KAAG,KAAK,CAAC,SA8BT,CAAA"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
4
|
+
const baseClass = 'render-field-diffs';
|
|
5
|
+
export const RenderVersionFieldsToDiff = ({
|
|
6
|
+
versionFields
|
|
7
|
+
}) => {
|
|
8
|
+
return /*#__PURE__*/_jsx("div", {
|
|
9
|
+
className: baseClass,
|
|
10
|
+
children: versionFields?.map((field, fieldIndex) => {
|
|
11
|
+
if (field.fieldByLocale) {
|
|
12
|
+
const LocaleComponents = [];
|
|
13
|
+
for (const [locale, baseField] of Object.entries(field.fieldByLocale)) {
|
|
14
|
+
LocaleComponents.push(/*#__PURE__*/_jsx("div", {
|
|
15
|
+
className: `${baseClass}__locale`,
|
|
16
|
+
children: /*#__PURE__*/_jsx("div", {
|
|
17
|
+
className: `${baseClass}__locale-value`,
|
|
18
|
+
children: baseField.CustomComponent
|
|
19
|
+
})
|
|
20
|
+
}, [locale, fieldIndex].join('-')));
|
|
21
|
+
}
|
|
22
|
+
return /*#__PURE__*/_jsx("div", {
|
|
23
|
+
className: `${baseClass}__field`,
|
|
24
|
+
children: LocaleComponents
|
|
25
|
+
}, fieldIndex);
|
|
26
|
+
} else if (field.field) {
|
|
27
|
+
return /*#__PURE__*/_jsx("div", {
|
|
28
|
+
className: `${baseClass}__field field__${field.type}`,
|
|
29
|
+
children: field.field.CustomComponent
|
|
30
|
+
}, fieldIndex);
|
|
31
|
+
}
|
|
32
|
+
return null;
|
|
33
|
+
})
|
|
34
|
+
});
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=RenderVersionFieldsToDiff.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RenderVersionFieldsToDiff.js","names":["baseClass","RenderVersionFieldsToDiff","versionFields","_jsx","className","map","field","fieldIndex","fieldByLocale","LocaleComponents","locale","baseField","Object","entries","push","CustomComponent","join","type"],"sources":["../../../../src/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.tsx"],"sourcesContent":["'use client'\nconst baseClass = 'render-field-diffs'\nimport type { VersionField } from 'payload'\n\nimport './index.scss'\n\nexport const RenderVersionFieldsToDiff = ({\n versionFields,\n}: {\n versionFields: VersionField[]\n}): React.ReactNode => {\n return (\n <div className={baseClass}>\n {versionFields?.map((field, fieldIndex) => {\n if (field.fieldByLocale) {\n const LocaleComponents: React.ReactNode[] = []\n for (const [locale, baseField] of Object.entries(field.fieldByLocale)) {\n LocaleComponents.push(\n <div className={`${baseClass}__locale`} key={[locale, fieldIndex].join('-')}>\n <div className={`${baseClass}__locale-value`}>{baseField.CustomComponent}</div>\n </div>,\n )\n }\n return (\n <div className={`${baseClass}__field`} key={fieldIndex}>\n {LocaleComponents}\n </div>\n )\n } else if (field.field) {\n return (\n <div className={`${baseClass}__field field__${field.type}`} key={fieldIndex}>\n {field.field.CustomComponent}\n </div>\n )\n }\n\n return null\n })}\n </div>\n )\n}\n"],"mappings":"AAAA;;;AACA,MAAMA,SAAA,GAAY;AAKlB,OAAO,MAAMC,yBAAA,GAA4BA,CAAC;EACxCC;AAAa,CAGd;EACC,oBACEC,IAAA,CAAC;IAAIC,SAAA,EAAWJ,SAAA;cACbE,aAAA,EAAeG,GAAA,CAAI,CAACC,KAAA,EAAOC,UAAA;MAC1B,IAAID,KAAA,CAAME,aAAa,EAAE;QACvB,MAAMC,gBAAA,GAAsC,EAAE;QAC9C,KAAK,MAAM,CAACC,MAAA,EAAQC,SAAA,CAAU,IAAIC,MAAA,CAAOC,OAAO,CAACP,KAAA,CAAME,aAAa,GAAG;UACrEC,gBAAA,CAAiBK,IAAI,cACnBX,IAAA,CAAC;YAAIC,SAAA,EAAW,GAAGJ,SAAA,UAAmB;sBACpC,aAAAG,IAAA,CAAC;cAAIC,SAAA,EAAW,GAAGJ,SAAA,gBAAyB;wBAAGW,SAAA,CAAUI;;aADd,CAACL,MAAA,EAAQH,UAAA,CAAW,CAACS,IAAI,CAAC;QAI3E;QACA,oBACEb,IAAA,CAAC;UAAIC,SAAA,EAAW,GAAGJ,SAAA,SAAkB;oBAClCS;WADyCF,UAAA;MAIhD,OAAO,IAAID,KAAA,CAAMA,KAAK,EAAE;QACtB,oBACEH,IAAA,CAAC;UAAIC,SAAA,EAAW,GAAGJ,SAAA,kBAA2BM,KAAA,CAAMW,IAAI,EAAE;oBACvDX,KAAA,CAAMA,KAAK,CAACS;WADkDR,UAAA;MAIrE;MAEA,OAAO;IACT;;AAGN","ignoreList":[]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { I18nClient } from '@payloadcms/translations';
|
|
2
|
+
import type { ClientFieldSchemaMap, DiffComponentProps, DiffComponentServerProps, Field, FieldTypes, PayloadComponent, PayloadRequest, SanitizedFieldPermissions, VersionField } from 'payload';
|
|
3
|
+
export type BuildVersionFieldsArgs = {
|
|
4
|
+
clientSchemaMap: ClientFieldSchemaMap;
|
|
5
|
+
comparisonSiblingData: object;
|
|
6
|
+
customDiffComponents: Partial<Record<FieldTypes, PayloadComponent<DiffComponentServerProps, DiffComponentProps>>>;
|
|
7
|
+
entitySlug: string;
|
|
8
|
+
fieldPermissions: {
|
|
9
|
+
[key: string]: SanitizedFieldPermissions;
|
|
10
|
+
} | true;
|
|
11
|
+
fields: Field[];
|
|
12
|
+
i18n: I18nClient;
|
|
13
|
+
parentIndexPath: string;
|
|
14
|
+
parentPath: string;
|
|
15
|
+
parentSchemaPath: string;
|
|
16
|
+
req: PayloadRequest;
|
|
17
|
+
selectedLocales: string[];
|
|
18
|
+
versionSiblingData: object;
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* Build up an object that contains rendered diff components for each field.
|
|
22
|
+
* This is then sent to the client to be rendered.
|
|
23
|
+
*
|
|
24
|
+
* Here, the server is responsible for traversing through the document data and building up this
|
|
25
|
+
* version state object.
|
|
26
|
+
*/
|
|
27
|
+
export declare const buildVersionFields: ({ clientSchemaMap, comparisonSiblingData, customDiffComponents, entitySlug, fieldPermissions, fields, i18n, parentIndexPath, parentPath, parentSchemaPath, req, selectedLocales, versionSiblingData, }: BuildVersionFieldsArgs) => {
|
|
28
|
+
versionFields: VersionField[];
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=buildVersionFields.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildVersionFields.d.ts","sourceRoot":"","sources":["../../../../src/views/Version/RenderFieldsToDiff/buildVersionFields.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAC1D,OAAO,KAAK,EAGV,oBAAoB,EACpB,kBAAkB,EAClB,wBAAwB,EACxB,KAAK,EACL,UAAU,EACV,gBAAgB,EAChB,cAAc,EACd,yBAAyB,EACzB,YAAY,EACb,MAAM,SAAS,CAAA;AAUhB,MAAM,MAAM,sBAAsB,GAAG;IACnC,eAAe,EAAE,oBAAoB,CAAA;IACrC,qBAAqB,EAAE,MAAM,CAAA;IAC7B,oBAAoB,EAAE,OAAO,CAC3B,MAAM,CAAC,UAAU,EAAE,gBAAgB,CAAC,wBAAwB,EAAE,kBAAkB,CAAC,CAAC,CACnF,CAAA;IACD,UAAU,EAAE,MAAM,CAAA;IAClB,gBAAgB,EACZ;QACE,CAAC,GAAG,EAAE,MAAM,GAAG,yBAAyB,CAAA;KACzC,GACD,IAAI,CAAA;IACR,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,IAAI,EAAE,UAAU,CAAA;IAChB,eAAe,EAAE,MAAM,CAAA;IACvB,UAAU,EAAE,MAAM,CAAA;IAClB,gBAAgB,EAAE,MAAM,CAAA;IACxB,GAAG,EAAE,cAAc,CAAA;IACnB,eAAe,EAAE,MAAM,EAAE,CAAA;IACzB,kBAAkB,EAAE,MAAM,CAAA;CAC3B,CAAA;AAED;;;;;;GAMG;AACH,eAAO,MAAM,kBAAkB,2MAc5B,sBAAsB,KAAG;IAC1B,aAAa,EAAE,YAAY,EAAE,CAAA;CA8F9B,CAAA"}
|
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
import { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent';
|
|
2
|
+
import { fieldIsID, getUniqueListBy, tabHasName } from 'payload/shared';
|
|
3
|
+
import { diffMethods } from './fields/diffMethods.js';
|
|
4
|
+
import { diffComponents } from './fields/index.js';
|
|
5
|
+
import { getFieldPathsModified } from './utilities/getFieldPathsModified.js';
|
|
6
|
+
/**
|
|
7
|
+
* Build up an object that contains rendered diff components for each field.
|
|
8
|
+
* This is then sent to the client to be rendered.
|
|
9
|
+
*
|
|
10
|
+
* Here, the server is responsible for traversing through the document data and building up this
|
|
11
|
+
* version state object.
|
|
12
|
+
*/
|
|
13
|
+
export const buildVersionFields = ({
|
|
14
|
+
clientSchemaMap,
|
|
15
|
+
comparisonSiblingData,
|
|
16
|
+
customDiffComponents,
|
|
17
|
+
entitySlug,
|
|
18
|
+
fieldPermissions,
|
|
19
|
+
fields,
|
|
20
|
+
i18n,
|
|
21
|
+
parentIndexPath,
|
|
22
|
+
parentPath,
|
|
23
|
+
parentSchemaPath,
|
|
24
|
+
req,
|
|
25
|
+
selectedLocales,
|
|
26
|
+
versionSiblingData
|
|
27
|
+
}) => {
|
|
28
|
+
const versionFields = [];
|
|
29
|
+
let fieldIndex = -1;
|
|
30
|
+
for (const field of fields) {
|
|
31
|
+
fieldIndex++;
|
|
32
|
+
if (fieldIsID(field)) {
|
|
33
|
+
continue;
|
|
34
|
+
}
|
|
35
|
+
const {
|
|
36
|
+
indexPath,
|
|
37
|
+
path,
|
|
38
|
+
schemaPath
|
|
39
|
+
} = getFieldPathsModified({
|
|
40
|
+
field,
|
|
41
|
+
index: fieldIndex,
|
|
42
|
+
parentIndexPath: 'name' in field ? '' : parentIndexPath,
|
|
43
|
+
parentPath,
|
|
44
|
+
parentSchemaPath
|
|
45
|
+
});
|
|
46
|
+
const clientField = clientSchemaMap.get(entitySlug + '.' + schemaPath);
|
|
47
|
+
if (!clientField) {
|
|
48
|
+
req.payload.logger.error({
|
|
49
|
+
clientFieldKey: entitySlug + '.' + schemaPath,
|
|
50
|
+
clientSchemaMapKeys: Array.from(clientSchemaMap.keys()),
|
|
51
|
+
msg: 'No client field found for ' + entitySlug + '.' + schemaPath,
|
|
52
|
+
parentPath,
|
|
53
|
+
parentSchemaPath,
|
|
54
|
+
path,
|
|
55
|
+
schemaPath
|
|
56
|
+
});
|
|
57
|
+
throw new Error('No client field found for ' + entitySlug + '.' + schemaPath);
|
|
58
|
+
}
|
|
59
|
+
const versionField = {
|
|
60
|
+
type: field.type
|
|
61
|
+
};
|
|
62
|
+
const isLocalized = 'localized' in field && field.localized;
|
|
63
|
+
const fieldName = 'name' in field ? field.name : null;
|
|
64
|
+
const versionValue = fieldName ? versionSiblingData?.[fieldName] : versionSiblingData;
|
|
65
|
+
const comparisonValue = fieldName ? comparisonSiblingData?.[fieldName] : comparisonSiblingData;
|
|
66
|
+
if (isLocalized) {
|
|
67
|
+
versionField.fieldByLocale = {};
|
|
68
|
+
for (const locale of selectedLocales) {
|
|
69
|
+
versionField.fieldByLocale[locale] = buildVersionField({
|
|
70
|
+
clientField: clientField,
|
|
71
|
+
clientSchemaMap,
|
|
72
|
+
comparisonValue: comparisonValue?.[locale],
|
|
73
|
+
customDiffComponents,
|
|
74
|
+
entitySlug,
|
|
75
|
+
field,
|
|
76
|
+
fieldPermissions,
|
|
77
|
+
i18n,
|
|
78
|
+
indexPath,
|
|
79
|
+
locale,
|
|
80
|
+
parentPath,
|
|
81
|
+
parentSchemaPath,
|
|
82
|
+
path,
|
|
83
|
+
req,
|
|
84
|
+
schemaPath,
|
|
85
|
+
selectedLocales,
|
|
86
|
+
versionValue: versionValue?.[locale]
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
} else {
|
|
90
|
+
versionField.field = buildVersionField({
|
|
91
|
+
clientField: clientField,
|
|
92
|
+
clientSchemaMap,
|
|
93
|
+
comparisonValue,
|
|
94
|
+
customDiffComponents,
|
|
95
|
+
entitySlug,
|
|
96
|
+
field,
|
|
97
|
+
fieldPermissions,
|
|
98
|
+
i18n,
|
|
99
|
+
indexPath,
|
|
100
|
+
parentPath,
|
|
101
|
+
parentSchemaPath,
|
|
102
|
+
path,
|
|
103
|
+
req,
|
|
104
|
+
schemaPath,
|
|
105
|
+
selectedLocales,
|
|
106
|
+
versionValue
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
versionFields.push(versionField);
|
|
110
|
+
}
|
|
111
|
+
return {
|
|
112
|
+
versionFields
|
|
113
|
+
};
|
|
114
|
+
};
|
|
115
|
+
const buildVersionField = ({
|
|
116
|
+
clientField,
|
|
117
|
+
clientSchemaMap,
|
|
118
|
+
comparisonValue,
|
|
119
|
+
customDiffComponents,
|
|
120
|
+
entitySlug,
|
|
121
|
+
field,
|
|
122
|
+
fieldPermissions,
|
|
123
|
+
i18n,
|
|
124
|
+
indexPath,
|
|
125
|
+
locale,
|
|
126
|
+
parentPath,
|
|
127
|
+
parentSchemaPath,
|
|
128
|
+
path,
|
|
129
|
+
req,
|
|
130
|
+
schemaPath,
|
|
131
|
+
selectedLocales,
|
|
132
|
+
versionValue
|
|
133
|
+
}) => {
|
|
134
|
+
const fieldName = 'name' in field ? field.name : null;
|
|
135
|
+
const diffMethod = diffMethods[field.type] || 'CHARS';
|
|
136
|
+
const hasPermission = fieldPermissions === true || !fieldName || fieldPermissions?.[fieldName] === true || fieldPermissions?.[fieldName]?.read;
|
|
137
|
+
const subFieldPermissions = fieldPermissions === true || !fieldName || fieldPermissions?.[fieldName] === true || fieldPermissions?.[fieldName]?.fields;
|
|
138
|
+
if (!hasPermission) {
|
|
139
|
+
return null;
|
|
140
|
+
}
|
|
141
|
+
const CustomComponent = field?.admin?.components?.Diff ?? customDiffComponents?.[field.type];
|
|
142
|
+
const DefaultComponent = diffComponents?.[field.type];
|
|
143
|
+
const baseVersionField = {
|
|
144
|
+
fields: []
|
|
145
|
+
};
|
|
146
|
+
if (field.type === 'tabs' && 'tabs' in field) {
|
|
147
|
+
baseVersionField.tabs = [];
|
|
148
|
+
let tabIndex = -1;
|
|
149
|
+
for (const tab of field.tabs) {
|
|
150
|
+
tabIndex++;
|
|
151
|
+
const isNamedTab = tabHasName(tab);
|
|
152
|
+
const {
|
|
153
|
+
indexPath: tabIndexPath,
|
|
154
|
+
path: tabPath,
|
|
155
|
+
schemaPath: tabSchemaPath
|
|
156
|
+
} = getFieldPathsModified({
|
|
157
|
+
field: {
|
|
158
|
+
...tab,
|
|
159
|
+
type: 'tab'
|
|
160
|
+
},
|
|
161
|
+
index: tabIndex,
|
|
162
|
+
parentIndexPath: indexPath,
|
|
163
|
+
parentPath,
|
|
164
|
+
parentSchemaPath
|
|
165
|
+
});
|
|
166
|
+
baseVersionField.tabs.push({
|
|
167
|
+
name: 'name' in tab ? tab.name : null,
|
|
168
|
+
fields: buildVersionFields({
|
|
169
|
+
clientSchemaMap,
|
|
170
|
+
comparisonSiblingData: 'name' in tab ? comparisonValue?.[tab.name] : comparisonValue,
|
|
171
|
+
customDiffComponents,
|
|
172
|
+
entitySlug,
|
|
173
|
+
fieldPermissions,
|
|
174
|
+
fields: tab.fields,
|
|
175
|
+
i18n,
|
|
176
|
+
parentIndexPath: isNamedTab ? '' : tabIndexPath,
|
|
177
|
+
parentPath: tabPath,
|
|
178
|
+
parentSchemaPath: tabSchemaPath,
|
|
179
|
+
req,
|
|
180
|
+
selectedLocales,
|
|
181
|
+
versionSiblingData: 'name' in tab ? versionValue?.[tab.name] : versionValue
|
|
182
|
+
}).versionFields,
|
|
183
|
+
label: tab.label
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
} else if ('fields' in field) {
|
|
187
|
+
if (field.type === 'array') {
|
|
188
|
+
if (!Array.isArray(versionValue)) {
|
|
189
|
+
throw new Error('Expected versionValue to be an array');
|
|
190
|
+
}
|
|
191
|
+
baseVersionField.rows = [];
|
|
192
|
+
for (let i = 0; i < versionValue.length; i++) {
|
|
193
|
+
const comparisonRow = comparisonValue?.[i] || {};
|
|
194
|
+
const versionRow = versionValue?.[i] || {};
|
|
195
|
+
baseVersionField.rows[i] = buildVersionFields({
|
|
196
|
+
clientSchemaMap,
|
|
197
|
+
comparisonSiblingData: comparisonRow,
|
|
198
|
+
customDiffComponents,
|
|
199
|
+
entitySlug,
|
|
200
|
+
fieldPermissions,
|
|
201
|
+
fields: field.fields,
|
|
202
|
+
i18n,
|
|
203
|
+
parentIndexPath: 'name' in field ? '' : indexPath,
|
|
204
|
+
parentPath: path + '.' + i,
|
|
205
|
+
parentSchemaPath: schemaPath,
|
|
206
|
+
req,
|
|
207
|
+
selectedLocales,
|
|
208
|
+
versionSiblingData: versionRow
|
|
209
|
+
}).versionFields;
|
|
210
|
+
}
|
|
211
|
+
} else {
|
|
212
|
+
baseVersionField.fields = buildVersionFields({
|
|
213
|
+
clientSchemaMap,
|
|
214
|
+
comparisonSiblingData: comparisonValue,
|
|
215
|
+
customDiffComponents,
|
|
216
|
+
entitySlug,
|
|
217
|
+
fieldPermissions,
|
|
218
|
+
fields: field.fields,
|
|
219
|
+
i18n,
|
|
220
|
+
parentIndexPath: 'name' in field ? '' : indexPath,
|
|
221
|
+
parentPath: path,
|
|
222
|
+
parentSchemaPath: schemaPath,
|
|
223
|
+
req,
|
|
224
|
+
selectedLocales,
|
|
225
|
+
versionSiblingData: versionValue
|
|
226
|
+
}).versionFields;
|
|
227
|
+
}
|
|
228
|
+
} else if (field.type === 'blocks') {
|
|
229
|
+
baseVersionField.rows = [];
|
|
230
|
+
if (!Array.isArray(versionValue)) {
|
|
231
|
+
throw new Error('Expected versionValue to be an array');
|
|
232
|
+
}
|
|
233
|
+
for (let i = 0; i < versionValue.length; i++) {
|
|
234
|
+
const comparisonRow = comparisonValue?.[i] || {};
|
|
235
|
+
const versionRow = versionValue[i] || {};
|
|
236
|
+
const versionBlock = field.blocks.find(block => block.slug === versionRow.blockType);
|
|
237
|
+
let fields = [];
|
|
238
|
+
if (versionRow.blockType === comparisonRow.blockType) {
|
|
239
|
+
fields = versionBlock.fields;
|
|
240
|
+
} else {
|
|
241
|
+
const comparisonBlock = field.blocks.find(block => block.slug === comparisonRow.blockType);
|
|
242
|
+
if (comparisonBlock) {
|
|
243
|
+
fields = getUniqueListBy([...versionBlock.fields, ...comparisonBlock.fields], 'name');
|
|
244
|
+
} else {
|
|
245
|
+
fields = versionBlock.fields;
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
baseVersionField.rows[i] = buildVersionFields({
|
|
249
|
+
clientSchemaMap,
|
|
250
|
+
comparisonSiblingData: comparisonRow,
|
|
251
|
+
customDiffComponents,
|
|
252
|
+
entitySlug,
|
|
253
|
+
fieldPermissions,
|
|
254
|
+
fields,
|
|
255
|
+
i18n,
|
|
256
|
+
parentIndexPath: 'name' in field ? '' : indexPath,
|
|
257
|
+
parentPath: path + '.' + i,
|
|
258
|
+
parentSchemaPath: schemaPath + '.' + versionBlock.slug,
|
|
259
|
+
req,
|
|
260
|
+
selectedLocales,
|
|
261
|
+
versionSiblingData: versionRow
|
|
262
|
+
}).versionFields;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
const clientCellProps = {
|
|
266
|
+
baseVersionField: {
|
|
267
|
+
...baseVersionField,
|
|
268
|
+
CustomComponent: undefined
|
|
269
|
+
},
|
|
270
|
+
comparisonValue,
|
|
271
|
+
diffMethod,
|
|
272
|
+
field: clientField,
|
|
273
|
+
fieldPermissions: subFieldPermissions,
|
|
274
|
+
versionValue
|
|
275
|
+
};
|
|
276
|
+
const serverCellProps = {
|
|
277
|
+
...clientCellProps,
|
|
278
|
+
clientField,
|
|
279
|
+
field,
|
|
280
|
+
i18n,
|
|
281
|
+
req,
|
|
282
|
+
selectedLocales
|
|
283
|
+
};
|
|
284
|
+
baseVersionField.CustomComponent = RenderServerComponent({
|
|
285
|
+
clientProps: locale ? {
|
|
286
|
+
...clientCellProps,
|
|
287
|
+
locale
|
|
288
|
+
} : clientCellProps,
|
|
289
|
+
Component: CustomComponent,
|
|
290
|
+
Fallback: DefaultComponent,
|
|
291
|
+
importMap: req.payload.importMap,
|
|
292
|
+
key: 'diff component',
|
|
293
|
+
serverProps: locale ? {
|
|
294
|
+
...serverCellProps,
|
|
295
|
+
locale
|
|
296
|
+
} : serverCellProps
|
|
297
|
+
});
|
|
298
|
+
return baseVersionField;
|
|
299
|
+
};
|
|
300
|
+
//# sourceMappingURL=buildVersionFields.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildVersionFields.js","names":["RenderServerComponent","fieldIsID","getUniqueListBy","tabHasName","diffMethods","diffComponents","getFieldPathsModified","buildVersionFields","clientSchemaMap","comparisonSiblingData","customDiffComponents","entitySlug","fieldPermissions","fields","i18n","parentIndexPath","parentPath","parentSchemaPath","req","selectedLocales","versionSiblingData","versionFields","fieldIndex","field","indexPath","path","schemaPath","index","clientField","get","payload","logger","error","clientFieldKey","clientSchemaMapKeys","Array","from","keys","msg","Error","versionField","type","isLocalized","localized","fieldName","name","versionValue","comparisonValue","fieldByLocale","locale","buildVersionField","push","diffMethod","hasPermission","read","subFieldPermissions","CustomComponent","admin","components","Diff","DefaultComponent","baseVersionField","tabs","tabIndex","tab","isNamedTab","tabIndexPath","tabPath","tabSchemaPath","label","isArray","rows","i","length","comparisonRow","versionRow","versionBlock","blocks","find","block","slug","blockType","comparisonBlock","clientCellProps","undefined","serverCellProps","clientProps","Component","Fallback","importMap","key","serverProps"],"sources":["../../../../src/views/Version/RenderFieldsToDiff/buildVersionFields.tsx"],"sourcesContent":["import type { I18nClient } from '@payloadcms/translations'\nimport type {\n BaseVersionField,\n ClientField,\n ClientFieldSchemaMap,\n DiffComponentProps,\n DiffComponentServerProps,\n Field,\n FieldTypes,\n PayloadComponent,\n PayloadRequest,\n SanitizedFieldPermissions,\n VersionField,\n} from 'payload'\nimport type { DiffMethod } from 'react-diff-viewer-continued'\n\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { fieldIsID, getUniqueListBy, tabHasName } from 'payload/shared'\n\nimport { diffMethods } from './fields/diffMethods.js'\nimport { diffComponents } from './fields/index.js'\nimport { getFieldPathsModified } from './utilities/getFieldPathsModified.js'\n\nexport type BuildVersionFieldsArgs = {\n clientSchemaMap: ClientFieldSchemaMap\n comparisonSiblingData: object\n customDiffComponents: Partial<\n Record<FieldTypes, PayloadComponent<DiffComponentServerProps, DiffComponentProps>>\n >\n entitySlug: string\n fieldPermissions:\n | {\n [key: string]: SanitizedFieldPermissions\n }\n | true\n fields: Field[]\n i18n: I18nClient\n parentIndexPath: string\n parentPath: string\n parentSchemaPath: string\n req: PayloadRequest\n selectedLocales: string[]\n versionSiblingData: object\n}\n\n/**\n * Build up an object that contains rendered diff components for each field.\n * This is then sent to the client to be rendered.\n *\n * Here, the server is responsible for traversing through the document data and building up this\n * version state object.\n */\nexport const buildVersionFields = ({\n clientSchemaMap,\n comparisonSiblingData,\n customDiffComponents,\n entitySlug,\n fieldPermissions,\n fields,\n i18n,\n parentIndexPath,\n parentPath,\n parentSchemaPath,\n req,\n selectedLocales,\n versionSiblingData,\n}: BuildVersionFieldsArgs): {\n versionFields: VersionField[]\n} => {\n const versionFields: VersionField[] = []\n let fieldIndex = -1\n for (const field of fields) {\n fieldIndex++\n if (fieldIsID(field)) {\n continue\n }\n\n const { indexPath, path, schemaPath } = getFieldPathsModified({\n field,\n index: fieldIndex,\n parentIndexPath: 'name' in field ? '' : parentIndexPath,\n parentPath,\n parentSchemaPath,\n })\n\n const clientField = clientSchemaMap.get(entitySlug + '.' + schemaPath)\n\n if (!clientField) {\n req.payload.logger.error({\n clientFieldKey: entitySlug + '.' + schemaPath,\n clientSchemaMapKeys: Array.from(clientSchemaMap.keys()),\n msg: 'No client field found for ' + entitySlug + '.' + schemaPath,\n parentPath,\n parentSchemaPath,\n path,\n schemaPath,\n })\n throw new Error('No client field found for ' + entitySlug + '.' + schemaPath)\n }\n\n const versionField: VersionField = {\n type: field.type,\n }\n const isLocalized = 'localized' in field && field.localized\n const fieldName: null | string = 'name' in field ? field.name : null\n\n const versionValue = fieldName ? versionSiblingData?.[fieldName] : versionSiblingData\n\n const comparisonValue = fieldName ? comparisonSiblingData?.[fieldName] : comparisonSiblingData\n\n if (isLocalized) {\n versionField.fieldByLocale = {}\n\n for (const locale of selectedLocales) {\n versionField.fieldByLocale[locale] = buildVersionField({\n clientField: clientField as ClientField,\n clientSchemaMap,\n comparisonValue: comparisonValue?.[locale],\n customDiffComponents,\n entitySlug,\n field,\n fieldPermissions,\n i18n,\n indexPath,\n locale,\n parentPath,\n parentSchemaPath,\n path,\n req,\n schemaPath,\n selectedLocales,\n versionValue: versionValue?.[locale],\n })\n }\n } else {\n versionField.field = buildVersionField({\n clientField: clientField as ClientField,\n clientSchemaMap,\n comparisonValue,\n customDiffComponents,\n entitySlug,\n field,\n fieldPermissions,\n i18n,\n indexPath,\n parentPath,\n parentSchemaPath,\n path,\n req,\n schemaPath,\n selectedLocales,\n versionValue,\n })\n }\n\n versionFields.push(versionField)\n }\n\n return {\n versionFields,\n }\n}\n\nconst buildVersionField = ({\n clientField,\n clientSchemaMap,\n comparisonValue,\n customDiffComponents,\n entitySlug,\n field,\n fieldPermissions,\n i18n,\n indexPath,\n locale,\n parentPath,\n parentSchemaPath,\n path,\n req,\n schemaPath,\n selectedLocales,\n versionValue,\n}: {\n clientField: ClientField\n comparisonValue: unknown\n field: Field\n indexPath: string\n locale?: string\n path: string\n schemaPath: string\n versionValue: unknown\n} & Omit<\n BuildVersionFieldsArgs,\n 'comparisonSiblingData' | 'fields' | 'parentIndexPath' | 'versionSiblingData'\n>): BaseVersionField | null => {\n const fieldName: null | string = 'name' in field ? field.name : null\n\n const diffMethod: DiffMethod = diffMethods[field.type] || 'CHARS'\n\n const hasPermission =\n fieldPermissions === true ||\n !fieldName ||\n fieldPermissions?.[fieldName] === true ||\n fieldPermissions?.[fieldName]?.read\n\n const subFieldPermissions =\n fieldPermissions === true ||\n !fieldName ||\n fieldPermissions?.[fieldName] === true ||\n fieldPermissions?.[fieldName]?.fields\n\n if (!hasPermission) {\n return null\n }\n\n const CustomComponent = field?.admin?.components?.Diff ?? customDiffComponents?.[field.type]\n const DefaultComponent = diffComponents?.[field.type]\n\n const baseVersionField: BaseVersionField = {\n fields: [],\n }\n\n if (field.type === 'tabs' && 'tabs' in field) {\n baseVersionField.tabs = []\n let tabIndex = -1\n for (const tab of field.tabs) {\n tabIndex++\n const isNamedTab = tabHasName(tab)\n\n const {\n indexPath: tabIndexPath,\n path: tabPath,\n schemaPath: tabSchemaPath,\n } = getFieldPathsModified({\n field: {\n ...tab,\n type: 'tab',\n },\n index: tabIndex,\n parentIndexPath: indexPath,\n parentPath,\n parentSchemaPath,\n })\n baseVersionField.tabs.push({\n name: 'name' in tab ? tab.name : null,\n fields: buildVersionFields({\n clientSchemaMap,\n comparisonSiblingData: 'name' in tab ? comparisonValue?.[tab.name] : comparisonValue,\n customDiffComponents,\n entitySlug,\n fieldPermissions,\n fields: tab.fields,\n i18n,\n parentIndexPath: isNamedTab ? '' : tabIndexPath,\n parentPath: tabPath,\n parentSchemaPath: tabSchemaPath,\n req,\n selectedLocales,\n versionSiblingData: 'name' in tab ? versionValue?.[tab.name] : versionValue,\n }).versionFields,\n label: tab.label,\n })\n }\n } // At this point, we are dealing with a `row`, etc\n else if ('fields' in field) {\n if (field.type === 'array') {\n if (!Array.isArray(versionValue)) {\n throw new Error('Expected versionValue to be an array')\n }\n baseVersionField.rows = []\n\n for (let i = 0; i < versionValue.length; i++) {\n const comparisonRow = comparisonValue?.[i] || {}\n const versionRow = versionValue?.[i] || {}\n baseVersionField.rows[i] = buildVersionFields({\n clientSchemaMap,\n comparisonSiblingData: comparisonRow,\n customDiffComponents,\n entitySlug,\n fieldPermissions,\n fields: field.fields,\n i18n,\n parentIndexPath: 'name' in field ? '' : indexPath,\n parentPath: path + '.' + i,\n parentSchemaPath: schemaPath,\n req,\n selectedLocales,\n versionSiblingData: versionRow,\n }).versionFields\n }\n } else {\n baseVersionField.fields = buildVersionFields({\n clientSchemaMap,\n comparisonSiblingData: comparisonValue as object,\n customDiffComponents,\n entitySlug,\n fieldPermissions,\n fields: field.fields,\n i18n,\n parentIndexPath: 'name' in field ? '' : indexPath,\n parentPath: path,\n parentSchemaPath: schemaPath,\n req,\n selectedLocales,\n versionSiblingData: versionValue as object,\n }).versionFields\n }\n } else if (field.type === 'blocks') {\n baseVersionField.rows = []\n\n if (!Array.isArray(versionValue)) {\n throw new Error('Expected versionValue to be an array')\n }\n\n for (let i = 0; i < versionValue.length; i++) {\n const comparisonRow = comparisonValue?.[i] || {}\n const versionRow = versionValue[i] || {}\n const versionBlock = field.blocks.find((block) => block.slug === versionRow.blockType)\n\n let fields = []\n\n if (versionRow.blockType === comparisonRow.blockType) {\n fields = versionBlock.fields\n } else {\n const comparisonBlock = field.blocks.find((block) => block.slug === comparisonRow.blockType)\n if (comparisonBlock) {\n fields = getUniqueListBy<Field>(\n [...versionBlock.fields, ...comparisonBlock.fields],\n 'name',\n )\n } else {\n fields = versionBlock.fields\n }\n }\n\n baseVersionField.rows[i] = buildVersionFields({\n clientSchemaMap,\n comparisonSiblingData: comparisonRow,\n customDiffComponents,\n entitySlug,\n fieldPermissions,\n fields,\n i18n,\n parentIndexPath: 'name' in field ? '' : indexPath,\n parentPath: path + '.' + i,\n parentSchemaPath: schemaPath + '.' + versionBlock.slug,\n req,\n selectedLocales,\n versionSiblingData: versionRow,\n }).versionFields\n }\n }\n\n const clientCellProps: DiffComponentProps = {\n baseVersionField: {\n ...baseVersionField,\n CustomComponent: undefined,\n },\n comparisonValue,\n diffMethod,\n field: clientField,\n fieldPermissions: subFieldPermissions,\n versionValue,\n }\n\n const serverCellProps: DiffComponentServerProps = {\n ...clientCellProps,\n clientField,\n field,\n i18n,\n req,\n selectedLocales,\n }\n\n baseVersionField.CustomComponent = RenderServerComponent({\n clientProps: locale\n ? ({\n ...clientCellProps,\n locale,\n } as DiffComponentProps)\n : clientCellProps,\n Component: CustomComponent,\n Fallback: DefaultComponent,\n importMap: req.payload.importMap,\n key: 'diff component',\n serverProps: locale\n ? ({\n ...serverCellProps,\n locale,\n } as DiffComponentServerProps)\n : serverCellProps,\n })\n\n return baseVersionField\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/views/Version/RenderFieldsToDiff/fields/Collapsible/index.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,sBAAsB,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAIzE,OAAO,KAAK,MAAM,OAAO,CAAA;AAQzB,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,CA0B5E,CAAA"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { c as _c } from "react/compiler-runtime";
|
|
4
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
5
|
+
import { getTranslation } from '@payloadcms/translations';
|
|
6
|
+
import { useTranslation } from '@payloadcms/ui';
|
|
7
|
+
import React from 'react';
|
|
8
|
+
import { useSelectedLocales } from '../../../Default/SelectedLocalesContext.js';
|
|
9
|
+
import { DiffCollapser } from '../../DiffCollapser/index.js';
|
|
10
|
+
import { RenderVersionFieldsToDiff } from '../../RenderVersionFieldsToDiff.js';
|
|
11
|
+
const baseClass = 'collapsible-diff';
|
|
12
|
+
export const Collapsible = t0 => {
|
|
13
|
+
const $ = _c(10);
|
|
14
|
+
const {
|
|
15
|
+
baseVersionField,
|
|
16
|
+
comparisonValue,
|
|
17
|
+
field,
|
|
18
|
+
versionValue
|
|
19
|
+
} = t0;
|
|
20
|
+
const {
|
|
21
|
+
i18n
|
|
22
|
+
} = useTranslation();
|
|
23
|
+
const {
|
|
24
|
+
selectedLocales
|
|
25
|
+
} = useSelectedLocales();
|
|
26
|
+
let t1;
|
|
27
|
+
if ($[0] !== field || $[1] !== i18n) {
|
|
28
|
+
t1 = "label" in field && field.label && typeof field.label !== "function" && _jsx("span", {
|
|
29
|
+
children: getTranslation(field.label, i18n)
|
|
30
|
+
});
|
|
31
|
+
$[0] = field;
|
|
32
|
+
$[1] = i18n;
|
|
33
|
+
$[2] = t1;
|
|
34
|
+
} else {
|
|
35
|
+
t1 = $[2];
|
|
36
|
+
}
|
|
37
|
+
let t2;
|
|
38
|
+
if ($[3] !== baseVersionField.fields || $[4] !== comparisonValue || $[5] !== field.fields || $[6] !== selectedLocales || $[7] !== t1 || $[8] !== versionValue) {
|
|
39
|
+
t2 = _jsx("div", {
|
|
40
|
+
className: baseClass,
|
|
41
|
+
children: _jsx(DiffCollapser, {
|
|
42
|
+
comparison: comparisonValue,
|
|
43
|
+
fields: field.fields,
|
|
44
|
+
label: t1,
|
|
45
|
+
locales: selectedLocales,
|
|
46
|
+
version: versionValue,
|
|
47
|
+
children: _jsx(RenderVersionFieldsToDiff, {
|
|
48
|
+
versionFields: baseVersionField.fields
|
|
49
|
+
})
|
|
50
|
+
})
|
|
51
|
+
});
|
|
52
|
+
$[3] = baseVersionField.fields;
|
|
53
|
+
$[4] = comparisonValue;
|
|
54
|
+
$[5] = field.fields;
|
|
55
|
+
$[6] = selectedLocales;
|
|
56
|
+
$[7] = t1;
|
|
57
|
+
$[8] = versionValue;
|
|
58
|
+
$[9] = t2;
|
|
59
|
+
} else {
|
|
60
|
+
t2 = $[9];
|
|
61
|
+
}
|
|
62
|
+
return t2;
|
|
63
|
+
};
|
|
64
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":["c","_c","getTranslation","useTranslation","React","useSelectedLocales","DiffCollapser","RenderVersionFieldsToDiff","baseClass","Collapsible","t0","$","baseVersionField","comparisonValue","field","versionValue","i18n","selectedLocales","t1","label","_jsx","children","t2","className","comparison","fields","version","versionFields"],"sources":["../../../../../../src/views/Version/RenderFieldsToDiff/fields/Collapsible/index.tsx"],"sourcesContent":["'use client'\nimport type { CollapsibleFieldClient, DiffComponentProps } from 'payload'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport { useTranslation } from '@payloadcms/ui'\nimport React from 'react'\n\nimport { useSelectedLocales } from '../../../Default/SelectedLocalesContext.js'\nimport { DiffCollapser } from '../../DiffCollapser/index.js'\nimport { RenderVersionFieldsToDiff } from '../../RenderVersionFieldsToDiff.js'\n\nconst baseClass = 'collapsible-diff'\n\nexport const Collapsible: React.FC<DiffComponentProps<CollapsibleFieldClient>> = ({\n baseVersionField,\n comparisonValue,\n field,\n versionValue,\n}) => {\n const { i18n } = useTranslation()\n const { selectedLocales } = useSelectedLocales()\n\n return (\n <div className={baseClass}>\n <DiffCollapser\n comparison={comparisonValue}\n fields={field.fields}\n label={\n 'label' in field &&\n field.label &&\n typeof field.label !== 'function' && <span>{getTranslation(field.label, i18n)}</span>\n }\n locales={selectedLocales}\n version={versionValue}\n >\n <RenderVersionFieldsToDiff versionFields={baseVersionField.fields} />\n </DiffCollapser>\n </div>\n )\n}\n"],"mappings":"AAAA;;AAAA,SAAAA,CAAA,IAAAC,EAAA;;AAGA,SAASC,cAAc,QAAQ;AAC/B,SAASC,cAAc,QAAQ;AAC/B,OAAOC,KAAA,MAAW;AAElB,SAASC,kBAAkB,QAAQ;AACnC,SAASC,aAAa,QAAQ;AAC9B,SAASC,yBAAyB,QAAQ;AAE1C,MAAMC,SAAA,GAAY;AAElB,OAAO,MAAMC,WAAA,GAAoEC,EAAA;EAAA,MAAAC,CAAA,GAAAV,EAAA;EAAC;IAAAW,gBAAA;IAAAC,eAAA;IAAAC,KAAA;IAAAC;EAAA,IAAAL,EAKjF;EACC;IAAAM;EAAA,IAAiBb,cAAA;EACjB;IAAAc;EAAA,IAA4BZ,kBAAA;EAAA,IAAAa,EAAA;EAAA,IAAAP,CAAA,QAAAG,KAAA,IAAAH,CAAA,QAAAK,IAAA;IAQpBE,EAAA,cAAWJ,KAAA,IACXA,KAAA,CAAAK,KAAW,IACX,OAAOL,KAAA,CAAAK,KAAA,KAAgB,cAAcC,IAAA,CAAC;MAAAC,QAAA,EAAMnB,cAAA,CAAeY,KAAA,CAAAK,KAAA,EAAaH,IAAA;IAAA,C;;;;;;;;;IAP9EM,EAAA,GAAAF,IAAA,CAAC;MAAAG,SAAA,EAAAf,SAAA;MAAAa,QAAA,EACCD,IAAA,CAAAd,aAAA;QAAAkB,UAAA,EACcX,eAAA;QAAAY,MAAA,EACJX,KAAA,CAAAW,MAAA;QAAAN,KAAA,EAEND,E;iBAIOD,eAAA;QAAAS,OAAA,EACAX,YAAA;QAAAM,QAAA,EAETD,IAAA,CAAAb,yBAAA;UAAAoB,aAAA,EAA0Cf,gBAAA,CAAAa;QAAA,C;;;;;;;;;;;;;SAZ9CH,E;CAgBJ","ignoreList":[]}
|