@payloadcms/next 3.43.0-internal.c5bbc84 → 3.43.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (217) hide show
  1. package/dist/elements/DocumentHeader/Tabs/Tab/index.d.ts.map +1 -1
  2. package/dist/elements/DocumentHeader/Tabs/Tab/index.js +26 -36
  3. package/dist/elements/DocumentHeader/Tabs/Tab/index.js.map +1 -1
  4. package/dist/elements/DocumentHeader/Tabs/index.d.ts.map +1 -1
  5. package/dist/elements/DocumentHeader/Tabs/index.js +35 -81
  6. package/dist/elements/DocumentHeader/Tabs/index.js.map +1 -1
  7. package/dist/elements/DocumentHeader/Tabs/tabs/index.d.ts +8 -6
  8. package/dist/elements/DocumentHeader/Tabs/tabs/index.d.ts.map +1 -1
  9. package/dist/elements/DocumentHeader/Tabs/tabs/index.js +91 -61
  10. package/dist/elements/DocumentHeader/Tabs/tabs/index.js.map +1 -1
  11. package/dist/elements/DocumentHeader/index.d.ts.map +1 -1
  12. package/dist/elements/DocumentHeader/index.js.map +1 -1
  13. package/dist/prod/styles.css +1 -1
  14. package/dist/utilities/handleServerFunctions.d.ts.map +1 -1
  15. package/dist/utilities/handleServerFunctions.js +10 -10
  16. package/dist/utilities/handleServerFunctions.js.map +1 -1
  17. package/dist/views/Account/index.d.ts.map +1 -1
  18. package/dist/views/Account/index.js +1 -0
  19. package/dist/views/Account/index.js.map +1 -1
  20. package/dist/views/Document/getDocumentView.d.ts +18 -0
  21. package/dist/views/Document/getDocumentView.d.ts.map +1 -0
  22. package/dist/views/Document/getDocumentView.js +264 -0
  23. package/dist/views/Document/getDocumentView.js.map +1 -0
  24. package/dist/views/Document/getMetaBySegment.d.ts.map +1 -1
  25. package/dist/views/Document/getMetaBySegment.js +10 -3
  26. package/dist/views/Document/getMetaBySegment.js.map +1 -1
  27. package/dist/views/Document/handleServerFunction.d.ts +2 -21
  28. package/dist/views/Document/handleServerFunction.d.ts.map +1 -1
  29. package/dist/views/Document/handleServerFunction.js +8 -4
  30. package/dist/views/Document/handleServerFunction.js.map +1 -1
  31. package/dist/views/Document/index.d.ts +4 -2
  32. package/dist/views/Document/index.d.ts.map +1 -1
  33. package/dist/views/Document/index.js +38 -77
  34. package/dist/views/Document/index.js.map +1 -1
  35. package/dist/views/Document/renderDocumentSlots.d.ts +3 -3
  36. package/dist/views/Document/renderDocumentSlots.d.ts.map +1 -1
  37. package/dist/views/Document/renderDocumentSlots.js +7 -0
  38. package/dist/views/Document/renderDocumentSlots.js.map +1 -1
  39. package/dist/views/List/handleServerFunction.d.ts +3 -4
  40. package/dist/views/List/handleServerFunction.d.ts.map +1 -1
  41. package/dist/views/List/handleServerFunction.js.map +1 -1
  42. package/dist/views/Unauthorized/index.d.ts +1 -0
  43. package/dist/views/Unauthorized/index.d.ts.map +1 -1
  44. package/dist/views/Unauthorized/index.js +9 -1
  45. package/dist/views/Unauthorized/index.js.map +1 -1
  46. package/dist/views/Unauthorized/index.scss +4 -0
  47. package/dist/views/Version/Default/SetStepNav.d.ts +4 -5
  48. package/dist/views/Version/Default/SetStepNav.d.ts.map +1 -1
  49. package/dist/views/Version/Default/SetStepNav.js +45 -70
  50. package/dist/views/Version/Default/SetStepNav.js.map +1 -1
  51. package/dist/views/Version/Default/index.d.ts.map +1 -1
  52. package/dist/views/Version/Default/index.js +189 -103
  53. package/dist/views/Version/Default/index.js.map +1 -1
  54. package/dist/views/Version/Default/index.scss +128 -34
  55. package/dist/views/Version/Default/types.d.ts +16 -10
  56. package/dist/views/Version/Default/types.d.ts.map +1 -1
  57. package/dist/views/Version/Default/types.js.map +1 -1
  58. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.d.ts +10 -13
  59. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.d.ts.map +1 -1
  60. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js +65 -61
  61. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.js.map +1 -1
  62. package/dist/views/Version/RenderFieldsToDiff/DiffCollapser/index.scss +41 -6
  63. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.d.ts +6 -1
  64. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.d.ts.map +1 -1
  65. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js +21 -17
  66. package/dist/views/Version/RenderFieldsToDiff/RenderVersionFieldsToDiff.js.map +1 -1
  67. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.d.ts +4 -3
  68. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.d.ts.map +1 -1
  69. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js +87 -57
  70. package/dist/views/Version/RenderFieldsToDiff/buildVersionFields.js.map +1 -1
  71. package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js +12 -12
  72. package/dist/views/Version/RenderFieldsToDiff/fields/Collapsible/index.js.map +1 -1
  73. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.d.ts +4 -0
  74. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.d.ts.map +1 -0
  75. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.js +75 -0
  76. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.js.map +1 -0
  77. package/dist/views/Version/RenderFieldsToDiff/fields/Date/index.scss +12 -0
  78. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js +12 -12
  79. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.js.map +1 -1
  80. package/dist/views/Version/RenderFieldsToDiff/fields/Group/index.scss +0 -10
  81. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.d.ts.map +1 -1
  82. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js +31 -22
  83. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.js.map +1 -1
  84. package/dist/views/Version/RenderFieldsToDiff/fields/Iterable/index.scss +37 -5
  85. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.d.ts +10 -0
  86. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.d.ts.map +1 -0
  87. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.js +41 -0
  88. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/generateLabelFromValue.js.map +1 -0
  89. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.d.ts +19 -2
  90. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.d.ts.map +1 -1
  91. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js +175 -131
  92. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.js.map +1 -1
  93. package/dist/views/Version/RenderFieldsToDiff/fields/Relationship/index.scss +84 -8
  94. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.d.ts.map +1 -1
  95. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js +38 -48
  96. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.js.map +1 -1
  97. package/dist/views/Version/RenderFieldsToDiff/fields/Select/index.scss +0 -11
  98. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.d.ts.map +1 -1
  99. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js +38 -38
  100. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.js.map +1 -1
  101. package/dist/views/Version/RenderFieldsToDiff/fields/Tabs/index.scss +0 -11
  102. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.d.ts.map +1 -1
  103. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js +77 -60
  104. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.js.map +1 -1
  105. package/dist/views/Version/RenderFieldsToDiff/fields/Text/index.scss +0 -11
  106. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.d.ts +24 -0
  107. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.d.ts.map +1 -0
  108. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.js +176 -0
  109. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.js.map +1 -0
  110. package/dist/views/Version/RenderFieldsToDiff/fields/Upload/index.scss +121 -0
  111. package/dist/views/Version/RenderFieldsToDiff/fields/index.d.ts +2 -2
  112. package/dist/views/Version/RenderFieldsToDiff/fields/index.d.ts.map +1 -1
  113. package/dist/views/Version/RenderFieldsToDiff/fields/index.js +4 -2
  114. package/dist/views/Version/RenderFieldsToDiff/fields/index.js.map +1 -1
  115. package/dist/views/Version/RenderFieldsToDiff/index.js +1 -0
  116. package/dist/views/Version/RenderFieldsToDiff/index.js.map +1 -1
  117. package/dist/views/Version/Restore/index.d.ts +14 -4
  118. package/dist/views/Version/Restore/index.d.ts.map +1 -1
  119. package/dist/views/Version/Restore/index.js +26 -31
  120. package/dist/views/Version/Restore/index.js.map +1 -1
  121. package/dist/views/Version/Restore/index.scss +6 -1
  122. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.d.ts +3 -0
  123. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.d.ts.map +1 -0
  124. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.js +90 -0
  125. package/dist/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.js.map +1 -0
  126. package/dist/views/Version/SelectComparison/VersionDrawer/index.d.ts +30 -0
  127. package/dist/views/Version/SelectComparison/VersionDrawer/index.d.ts.map +1 -0
  128. package/dist/views/Version/SelectComparison/VersionDrawer/index.js +232 -0
  129. package/dist/views/Version/SelectComparison/VersionDrawer/index.js.map +1 -0
  130. package/dist/views/Version/SelectComparison/VersionDrawer/index.scss +18 -0
  131. package/dist/views/Version/SelectComparison/index.d.ts +1 -1
  132. package/dist/views/Version/SelectComparison/index.d.ts.map +1 -1
  133. package/dist/views/Version/SelectComparison/index.js +37 -162
  134. package/dist/views/Version/SelectComparison/index.js.map +1 -1
  135. package/dist/views/Version/SelectComparison/index.scss +4 -10
  136. package/dist/views/Version/SelectComparison/types.d.ts +4 -7
  137. package/dist/views/Version/SelectComparison/types.d.ts.map +1 -1
  138. package/dist/views/Version/SelectComparison/types.js.map +1 -1
  139. package/dist/views/Version/SelectLocales/index.d.ts +9 -2
  140. package/dist/views/Version/SelectLocales/index.d.ts.map +1 -1
  141. package/dist/views/Version/SelectLocales/index.js +33 -60
  142. package/dist/views/Version/SelectLocales/index.js.map +1 -1
  143. package/dist/views/Version/VersionPillLabel/VersionPillLabel.d.ts +35 -0
  144. package/dist/views/Version/VersionPillLabel/VersionPillLabel.d.ts.map +1 -0
  145. package/dist/views/Version/VersionPillLabel/VersionPillLabel.js +109 -0
  146. package/dist/views/Version/VersionPillLabel/VersionPillLabel.js.map +1 -0
  147. package/dist/views/Version/VersionPillLabel/getVersionLabel.d.ts +30 -0
  148. package/dist/views/Version/VersionPillLabel/getVersionLabel.d.ts.map +1 -0
  149. package/dist/views/Version/VersionPillLabel/getVersionLabel.js +34 -0
  150. package/dist/views/Version/VersionPillLabel/getVersionLabel.js.map +1 -0
  151. package/dist/views/Version/VersionPillLabel/index.scss +26 -0
  152. package/dist/views/Version/fetchVersions.d.ts +42 -0
  153. package/dist/views/Version/fetchVersions.d.ts.map +1 -0
  154. package/dist/views/Version/fetchVersions.js +147 -0
  155. package/dist/views/Version/fetchVersions.js.map +1 -0
  156. package/dist/views/Version/index.d.ts.map +1 -1
  157. package/dist/views/Version/index.js +253 -143
  158. package/dist/views/Version/index.js.map +1 -1
  159. package/dist/views/Version/metadata.js +1 -1
  160. package/dist/views/Version/metadata.js.map +1 -1
  161. package/dist/views/Versions/buildColumns.d.ts +13 -5
  162. package/dist/views/Versions/buildColumns.d.ts.map +1 -1
  163. package/dist/views/Versions/buildColumns.js +6 -4
  164. package/dist/views/Versions/buildColumns.js.map +1 -1
  165. package/dist/views/Versions/cells/AutosaveCell/index.d.ts +11 -5
  166. package/dist/views/Versions/cells/AutosaveCell/index.d.ts.map +1 -1
  167. package/dist/views/Versions/cells/AutosaveCell/index.js +34 -103
  168. package/dist/views/Versions/cells/AutosaveCell/index.js.map +1 -1
  169. package/dist/views/Versions/cells/CreatedAt/index.d.ts +1 -2
  170. package/dist/views/Versions/cells/CreatedAt/index.d.ts.map +1 -1
  171. package/dist/views/Versions/cells/CreatedAt/index.js.map +1 -1
  172. package/dist/views/Versions/index.d.ts +0 -1
  173. package/dist/views/Versions/index.d.ts.map +1 -1
  174. package/dist/views/Versions/index.js +89 -153
  175. package/dist/views/Versions/index.js.map +1 -1
  176. package/package.json +6 -7
  177. package/dist/elements/DocumentHeader/Tabs/getCustomViews.d.ts +0 -6
  178. package/dist/elements/DocumentHeader/Tabs/getCustomViews.d.ts.map +0 -1
  179. package/dist/elements/DocumentHeader/Tabs/getCustomViews.js +0 -34
  180. package/dist/elements/DocumentHeader/Tabs/getCustomViews.js.map +0 -1
  181. package/dist/elements/DocumentHeader/Tabs/getViewConfig.d.ts +0 -7
  182. package/dist/elements/DocumentHeader/Tabs/getViewConfig.d.ts.map +0 -1
  183. package/dist/elements/DocumentHeader/Tabs/getViewConfig.js +0 -17
  184. package/dist/elements/DocumentHeader/Tabs/getViewConfig.js.map +0 -1
  185. package/dist/views/Document/getViewsFromConfig.d.ts +0 -27
  186. package/dist/views/Document/getViewsFromConfig.d.ts.map +0 -1
  187. package/dist/views/Document/getViewsFromConfig.js +0 -330
  188. package/dist/views/Document/getViewsFromConfig.js.map +0 -1
  189. package/dist/views/Version/RenderFieldsToDiff/fields/Select/DiffViewer/index.d.ts +0 -9
  190. package/dist/views/Version/RenderFieldsToDiff/fields/Select/DiffViewer/index.d.ts.map +0 -1
  191. package/dist/views/Version/RenderFieldsToDiff/fields/Select/DiffViewer/index.js +0 -23
  192. package/dist/views/Version/RenderFieldsToDiff/fields/Select/DiffViewer/index.js.map +0 -1
  193. package/dist/views/Version/RenderFieldsToDiff/fields/Text/DiffViewer/index.d.ts +0 -9
  194. package/dist/views/Version/RenderFieldsToDiff/fields/Text/DiffViewer/index.d.ts.map +0 -1
  195. package/dist/views/Version/RenderFieldsToDiff/fields/Text/DiffViewer/index.js +0 -23
  196. package/dist/views/Version/RenderFieldsToDiff/fields/Text/DiffViewer/index.js.map +0 -1
  197. package/dist/views/Version/RenderFieldsToDiff/fields/diffMethods.d.ts +0 -7
  198. package/dist/views/Version/RenderFieldsToDiff/fields/diffMethods.d.ts.map +0 -1
  199. package/dist/views/Version/RenderFieldsToDiff/fields/diffMethods.js +0 -7
  200. package/dist/views/Version/RenderFieldsToDiff/fields/diffMethods.js.map +0 -1
  201. package/dist/views/Version/RenderFieldsToDiff/fields/styles.d.ts +0 -3
  202. package/dist/views/Version/RenderFieldsToDiff/fields/styles.d.ts.map +0 -1
  203. package/dist/views/Version/RenderFieldsToDiff/fields/styles.js +0 -37
  204. package/dist/views/Version/RenderFieldsToDiff/fields/styles.js.map +0 -1
  205. package/dist/views/Version/Restore/types.d.ts +0 -12
  206. package/dist/views/Version/Restore/types.d.ts.map +0 -1
  207. package/dist/views/Version/Restore/types.js +0 -2
  208. package/dist/views/Version/Restore/types.js.map +0 -1
  209. package/dist/views/Version/SelectLocales/index.scss +0 -9
  210. package/dist/views/Version/SelectLocales/types.d.ts +0 -7
  211. package/dist/views/Version/SelectLocales/types.d.ts.map +0 -1
  212. package/dist/views/Version/SelectLocales/types.js +0 -2
  213. package/dist/views/Version/SelectLocales/types.js.map +0 -1
  214. package/dist/views/Versions/getLatestVersion.d.ts +0 -18
  215. package/dist/views/Versions/getLatestVersion.d.ts.map +0 -1
  216. package/dist/views/Versions/getLatestVersion.js +0 -59
  217. package/dist/views/Versions/getLatestVersion.js.map +0 -1
@@ -0,0 +1,24 @@
1
+ import type { FileData, PayloadRequest, TypeWithID, UploadField, UploadFieldDiffServerComponent } from 'payload';
2
+ import { type I18nClient } from '@payloadcms/translations';
3
+ import './index.scss';
4
+ import React from 'react';
5
+ export declare const Upload: UploadFieldDiffServerComponent;
6
+ export declare const HasManyUploadDiff: React.FC<{
7
+ field: UploadField;
8
+ i18n: I18nClient;
9
+ locale: string;
10
+ nestingLevel?: number;
11
+ req: PayloadRequest;
12
+ valueFrom: Array<FileData & TypeWithID>;
13
+ valueTo: Array<FileData & TypeWithID>;
14
+ }>;
15
+ export declare const SingleUploadDiff: React.FC<{
16
+ field: UploadField;
17
+ i18n: I18nClient;
18
+ locale: string;
19
+ nestingLevel?: number;
20
+ req: PayloadRequest;
21
+ valueFrom: FileData & TypeWithID;
22
+ valueTo: FileData & TypeWithID;
23
+ }>;
24
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/views/Version/RenderFieldsToDiff/fields/Upload/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,QAAQ,EACR,cAAc,EACd,UAAU,EACV,WAAW,EACX,8BAA8B,EAC/B,MAAM,SAAS,CAAA;AAEhB,OAAO,EAAkB,KAAK,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAG1E,OAAO,cAAc,CAAA;AAErB,OAAO,KAAK,MAAM,OAAO,CAAA;AAIzB,eAAO,MAAM,MAAM,EAAE,8BAoCpB,CAAA;AAED,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC;IACvC,KAAK,EAAE,WAAW,CAAA;IAClB,IAAI,EAAE,UAAU,CAAA;IAChB,MAAM,EAAE,MAAM,CAAA;IACd,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,GAAG,EAAE,cAAc,CAAA;IACnB,SAAS,EAAE,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC,CAAA;IACvC,OAAO,EAAE,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC,CAAA;CACtC,CAqEA,CAAA;AAED,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC;IACtC,KAAK,EAAE,WAAW,CAAA;IAClB,IAAI,EAAE,UAAU,CAAA;IAChB,MAAM,EAAE,MAAM,CAAA;IACd,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,GAAG,EAAE,cAAc,CAAA;IACnB,SAAS,EAAE,QAAQ,GAAG,UAAU,CAAA;IAChC,OAAO,EAAE,QAAQ,GAAG,UAAU,CAAA;CAC/B,CAyDA,CAAA"}
@@ -0,0 +1,176 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { getTranslation } from '@payloadcms/translations';
3
+ import { FieldDiffContainer, File, getHTMLDiffComponents } from '@payloadcms/ui/rsc';
4
+ import React from 'react';
5
+ const baseClass = 'upload-diff';
6
+ export const Upload = args => {
7
+ const {
8
+ comparisonValue: valueFrom,
9
+ field,
10
+ i18n,
11
+ locale,
12
+ nestingLevel,
13
+ req,
14
+ versionValue: valueTo
15
+ } = args;
16
+ if ('hasMany' in field && field.hasMany && Array.isArray(valueTo)) {
17
+ return /*#__PURE__*/_jsx(HasManyUploadDiff, {
18
+ field: field,
19
+ i18n: i18n,
20
+ locale: locale,
21
+ nestingLevel: nestingLevel,
22
+ req: req,
23
+ valueFrom: valueFrom,
24
+ valueTo: valueTo
25
+ });
26
+ }
27
+ return /*#__PURE__*/_jsx(SingleUploadDiff, {
28
+ field: field,
29
+ i18n: i18n,
30
+ locale: locale,
31
+ nestingLevel: nestingLevel,
32
+ req: req,
33
+ valueFrom: valueFrom,
34
+ valueTo: valueTo
35
+ });
36
+ };
37
+ export const HasManyUploadDiff = async args => {
38
+ const {
39
+ field,
40
+ i18n,
41
+ locale,
42
+ nestingLevel,
43
+ req,
44
+ valueFrom,
45
+ valueTo
46
+ } = args;
47
+ const ReactDOMServer = (await import('react-dom/server')).default;
48
+ let From = '';
49
+ let To = '';
50
+ const showCollectionSlug = Array.isArray(field.relationTo);
51
+ const FromComponents = valueFrom ? valueFrom.map(uploadDoc => /*#__PURE__*/_jsx(UploadDocumentDiff, {
52
+ i18n: i18n,
53
+ relationTo: field.relationTo,
54
+ req: req,
55
+ showCollectionSlug: showCollectionSlug,
56
+ uploadDoc: uploadDoc
57
+ }, uploadDoc.id)) : null;
58
+ const ToComponents = valueTo ? valueTo.map(uploadDoc => /*#__PURE__*/_jsx(UploadDocumentDiff, {
59
+ i18n: i18n,
60
+ relationTo: field.relationTo,
61
+ req: req,
62
+ showCollectionSlug: showCollectionSlug,
63
+ uploadDoc: uploadDoc
64
+ }, uploadDoc.id)) : null;
65
+ const diffResult = getHTMLDiffComponents({
66
+ fromHTML: `<div class="${baseClass}-hasMany">` + (FromComponents ? FromComponents.map(component => `<div>${ReactDOMServer.renderToStaticMarkup(component)}</div>`).join('') : '') + '</div>',
67
+ toHTML: `<div class="${baseClass}-hasMany">` + (ToComponents ? ToComponents.map(component => `<div>${ReactDOMServer.renderToStaticMarkup(component)}</div>`).join('') : '') + '</div>',
68
+ tokenizeByCharacter: false
69
+ });
70
+ From = diffResult.From;
71
+ To = diffResult.To;
72
+ return /*#__PURE__*/_jsx(FieldDiffContainer, {
73
+ className: `${baseClass}-container ${baseClass}-container--hasMany`,
74
+ From: From,
75
+ i18n: i18n,
76
+ label: {
77
+ label: field.label,
78
+ locale
79
+ },
80
+ nestingLevel: nestingLevel,
81
+ To: To
82
+ });
83
+ };
84
+ export const SingleUploadDiff = async args => {
85
+ const {
86
+ field,
87
+ i18n,
88
+ locale,
89
+ nestingLevel,
90
+ req,
91
+ valueFrom,
92
+ valueTo
93
+ } = args;
94
+ const ReactDOMServer = (await import('react-dom/server')).default;
95
+ let From = '';
96
+ let To = '';
97
+ const showCollectionSlug = Array.isArray(field.relationTo);
98
+ const FromComponent = valueFrom ? /*#__PURE__*/_jsx(UploadDocumentDiff, {
99
+ i18n: i18n,
100
+ relationTo: field.relationTo,
101
+ req: req,
102
+ showCollectionSlug: showCollectionSlug,
103
+ uploadDoc: valueFrom
104
+ }) : null;
105
+ const ToComponent = valueTo ? /*#__PURE__*/_jsx(UploadDocumentDiff, {
106
+ i18n: i18n,
107
+ relationTo: field.relationTo,
108
+ req: req,
109
+ showCollectionSlug: showCollectionSlug,
110
+ uploadDoc: valueTo
111
+ }) : null;
112
+ const fromHtml = FromComponent ? ReactDOMServer.renderToStaticMarkup(FromComponent) : '<p>' + '' + '</p>';
113
+ const toHtml = ToComponent ? ReactDOMServer.renderToStaticMarkup(ToComponent) : '<p>' + '' + '</p>';
114
+ const diffResult = getHTMLDiffComponents({
115
+ fromHTML: fromHtml,
116
+ toHTML: toHtml,
117
+ tokenizeByCharacter: false
118
+ });
119
+ From = diffResult.From;
120
+ To = diffResult.To;
121
+ return /*#__PURE__*/_jsx(FieldDiffContainer, {
122
+ className: `${baseClass}-container ${baseClass}-container--hasOne`,
123
+ From: From,
124
+ i18n: i18n,
125
+ label: {
126
+ label: field.label,
127
+ locale
128
+ },
129
+ nestingLevel: nestingLevel,
130
+ To: To
131
+ });
132
+ };
133
+ const UploadDocumentDiff = args => {
134
+ const {
135
+ i18n,
136
+ relationTo,
137
+ req,
138
+ showCollectionSlug,
139
+ uploadDoc
140
+ } = args;
141
+ const thumbnailSRC = 'thumbnailURL' in uploadDoc && uploadDoc?.thumbnailURL || uploadDoc?.url || '';
142
+ let pillLabel = null;
143
+ if (showCollectionSlug) {
144
+ const uploadConfig = req.payload.collections[relationTo].config;
145
+ pillLabel = uploadConfig.labels?.singular ? getTranslation(uploadConfig.labels.singular, i18n) : uploadConfig.slug;
146
+ }
147
+ return /*#__PURE__*/_jsx("div", {
148
+ className: `${baseClass}`,
149
+ "data-enable-match": "true",
150
+ "data-id": uploadDoc?.id,
151
+ "data-relation-to": relationTo,
152
+ children: /*#__PURE__*/_jsxs("div", {
153
+ className: `${baseClass}__card`,
154
+ children: [/*#__PURE__*/_jsx("div", {
155
+ className: `${baseClass}__thumbnail`,
156
+ children: thumbnailSRC?.length ? /*#__PURE__*/_jsx("img", {
157
+ alt: uploadDoc?.filename,
158
+ src: thumbnailSRC
159
+ }) : /*#__PURE__*/_jsx(File, {})
160
+ }), pillLabel && /*#__PURE__*/_jsx("div", {
161
+ className: `${baseClass}__pill`,
162
+ "data-enable-match": "false",
163
+ children: /*#__PURE__*/_jsx("span", {
164
+ children: pillLabel
165
+ })
166
+ }), /*#__PURE__*/_jsx("div", {
167
+ className: `${baseClass}__info`,
168
+ "data-enable-match": "false",
169
+ children: /*#__PURE__*/_jsx("strong", {
170
+ children: uploadDoc?.filename
171
+ })
172
+ })]
173
+ })
174
+ });
175
+ };
176
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["getTranslation","FieldDiffContainer","File","getHTMLDiffComponents","React","baseClass","Upload","args","comparisonValue","valueFrom","field","i18n","locale","nestingLevel","req","versionValue","valueTo","hasMany","Array","isArray","_jsx","HasManyUploadDiff","SingleUploadDiff","ReactDOMServer","default","From","To","showCollectionSlug","relationTo","FromComponents","map","uploadDoc","UploadDocumentDiff","id","ToComponents","diffResult","fromHTML","component","renderToStaticMarkup","join","toHTML","tokenizeByCharacter","className","label","FromComponent","ToComponent","fromHtml","toHtml","thumbnailSRC","thumbnailURL","url","pillLabel","uploadConfig","payload","collections","config","labels","singular","slug","_jsxs","length","alt","filename","src"],"sources":["../../../../../../src/views/Version/RenderFieldsToDiff/fields/Upload/index.tsx"],"sourcesContent":["import type {\n FileData,\n PayloadRequest,\n TypeWithID,\n UploadField,\n UploadFieldDiffServerComponent,\n} from 'payload'\n\nimport { getTranslation, type I18nClient } from '@payloadcms/translations'\nimport { FieldDiffContainer, File, getHTMLDiffComponents } from '@payloadcms/ui/rsc'\n\nimport './index.scss'\n\nimport React from 'react'\n\nconst baseClass = 'upload-diff'\n\nexport const Upload: UploadFieldDiffServerComponent = (args) => {\n const {\n comparisonValue: valueFrom,\n field,\n i18n,\n locale,\n nestingLevel,\n req,\n versionValue: valueTo,\n } = args\n\n if ('hasMany' in field && field.hasMany && Array.isArray(valueTo)) {\n return (\n <HasManyUploadDiff\n field={field}\n i18n={i18n}\n locale={locale}\n nestingLevel={nestingLevel}\n req={req}\n valueFrom={valueFrom as any}\n valueTo={valueTo as any}\n />\n )\n }\n\n return (\n <SingleUploadDiff\n field={field}\n i18n={i18n}\n locale={locale}\n nestingLevel={nestingLevel}\n req={req}\n valueFrom={valueFrom as any}\n valueTo={valueTo as any}\n />\n )\n}\n\nexport const HasManyUploadDiff: React.FC<{\n field: UploadField\n i18n: I18nClient\n locale: string\n nestingLevel?: number\n req: PayloadRequest\n valueFrom: Array<FileData & TypeWithID>\n valueTo: Array<FileData & TypeWithID>\n}> = async (args) => {\n const { field, i18n, locale, nestingLevel, req, valueFrom, valueTo } = args\n const ReactDOMServer = (await import('react-dom/server')).default\n\n let From: React.ReactNode = ''\n let To: React.ReactNode = ''\n\n const showCollectionSlug = Array.isArray(field.relationTo)\n\n const FromComponents = valueFrom\n ? valueFrom.map((uploadDoc) => (\n <UploadDocumentDiff\n i18n={i18n}\n key={uploadDoc.id}\n relationTo={field.relationTo}\n req={req}\n showCollectionSlug={showCollectionSlug}\n uploadDoc={uploadDoc}\n />\n ))\n : null\n const ToComponents = valueTo\n ? valueTo.map((uploadDoc) => (\n <UploadDocumentDiff\n i18n={i18n}\n key={uploadDoc.id}\n relationTo={field.relationTo}\n req={req}\n showCollectionSlug={showCollectionSlug}\n uploadDoc={uploadDoc}\n />\n ))\n : null\n\n const diffResult = getHTMLDiffComponents({\n fromHTML:\n `<div class=\"${baseClass}-hasMany\">` +\n (FromComponents\n ? FromComponents.map(\n (component) => `<div>${ReactDOMServer.renderToStaticMarkup(component)}</div>`,\n ).join('')\n : '') +\n '</div>',\n toHTML:\n `<div class=\"${baseClass}-hasMany\">` +\n (ToComponents\n ? ToComponents.map(\n (component) => `<div>${ReactDOMServer.renderToStaticMarkup(component)}</div>`,\n ).join('')\n : '') +\n '</div>',\n tokenizeByCharacter: false,\n })\n From = diffResult.From\n To = diffResult.To\n\n return (\n <FieldDiffContainer\n className={`${baseClass}-container ${baseClass}-container--hasMany`}\n From={From}\n i18n={i18n}\n label={{\n label: field.label,\n locale,\n }}\n nestingLevel={nestingLevel}\n To={To}\n />\n )\n}\n\nexport const SingleUploadDiff: React.FC<{\n field: UploadField\n i18n: I18nClient\n locale: string\n nestingLevel?: number\n req: PayloadRequest\n valueFrom: FileData & TypeWithID\n valueTo: FileData & TypeWithID\n}> = async (args) => {\n const { field, i18n, locale, nestingLevel, req, valueFrom, valueTo } = args\n\n const ReactDOMServer = (await import('react-dom/server')).default\n\n let From: React.ReactNode = ''\n let To: React.ReactNode = ''\n\n const showCollectionSlug = Array.isArray(field.relationTo)\n\n const FromComponent = valueFrom ? (\n <UploadDocumentDiff\n i18n={i18n}\n relationTo={field.relationTo}\n req={req}\n showCollectionSlug={showCollectionSlug}\n uploadDoc={valueFrom}\n />\n ) : null\n const ToComponent = valueTo ? (\n <UploadDocumentDiff\n i18n={i18n}\n relationTo={field.relationTo}\n req={req}\n showCollectionSlug={showCollectionSlug}\n uploadDoc={valueTo}\n />\n ) : null\n\n const fromHtml = FromComponent\n ? ReactDOMServer.renderToStaticMarkup(FromComponent)\n : '<p>' + '' + '</p>'\n const toHtml = ToComponent\n ? ReactDOMServer.renderToStaticMarkup(ToComponent)\n : '<p>' + '' + '</p>'\n\n const diffResult = getHTMLDiffComponents({\n fromHTML: fromHtml,\n toHTML: toHtml,\n tokenizeByCharacter: false,\n })\n From = diffResult.From\n To = diffResult.To\n\n return (\n <FieldDiffContainer\n className={`${baseClass}-container ${baseClass}-container--hasOne`}\n From={From}\n i18n={i18n}\n label={{\n label: field.label,\n locale,\n }}\n nestingLevel={nestingLevel}\n To={To}\n />\n )\n}\n\nconst UploadDocumentDiff = (args: {\n i18n: I18nClient\n relationTo: string\n req: PayloadRequest\n showCollectionSlug?: boolean\n uploadDoc: FileData & TypeWithID\n}) => {\n const { i18n, relationTo, req, showCollectionSlug, uploadDoc } = args\n\n const thumbnailSRC: string =\n ('thumbnailURL' in uploadDoc && (uploadDoc?.thumbnailURL as string)) || uploadDoc?.url || ''\n\n let pillLabel: null | string = null\n\n if (showCollectionSlug) {\n const uploadConfig = req.payload.collections[relationTo].config\n pillLabel = uploadConfig.labels?.singular\n ? getTranslation(uploadConfig.labels.singular, i18n)\n : uploadConfig.slug\n }\n\n return (\n <div\n className={`${baseClass}`}\n data-enable-match=\"true\"\n data-id={uploadDoc?.id}\n data-relation-to={relationTo}\n >\n <div className={`${baseClass}__card`}>\n <div className={`${baseClass}__thumbnail`}>\n {thumbnailSRC?.length ? <img alt={uploadDoc?.filename} src={thumbnailSRC} /> : <File />}\n </div>\n {pillLabel && (\n <div className={`${baseClass}__pill`} data-enable-match=\"false\">\n <span>{pillLabel}</span>\n </div>\n )}\n <div className={`${baseClass}__info`} data-enable-match=\"false\">\n <strong>{uploadDoc?.filename}</strong>\n </div>\n </div>\n </div>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,121 @@
1
+ @import '~@payloadcms/ui/scss';
2
+
3
+ @layer payload-default {
4
+ .upload-diff-container .field-diff-content {
5
+ padding: 0;
6
+ background: unset;
7
+ }
8
+
9
+ .upload-diff-hasMany {
10
+ display: flex;
11
+ flex-direction: column;
12
+ gap: calc(var(--base) * 0.4);
13
+ }
14
+
15
+ .upload-diff {
16
+ @extend %body;
17
+ min-width: 100%;
18
+ max-width: fit-content;
19
+ display: flex;
20
+ align-items: center;
21
+ background-color: var(--theme-elevation-50);
22
+ border-radius: $style-radius-s;
23
+ border: 1px solid var(--theme-elevation-150);
24
+ position: relative;
25
+ font-family: var(--font-body);
26
+ max-height: calc(var(--base) * 3);
27
+ padding: calc(var(--base) * 0.1);
28
+
29
+ &[data-match-type='create'] {
30
+ border-color: var(--diff-create-pill-border);
31
+ color: var(--diff-create-parent-color);
32
+
33
+ * {
34
+ color: var(--diff-create-parent-color);
35
+ }
36
+
37
+ .upload-diff__thumbnail {
38
+ border-radius: 0px;
39
+ border-color: var(--diff-create-pill-border);
40
+ background-color: none;
41
+ }
42
+ }
43
+
44
+ &[data-match-type='delete'] {
45
+ border-color: var(--diff-delete-pill-border);
46
+ text-decoration-line: none;
47
+ color: var(--diff-delete-parent-color);
48
+ background-color: var(--diff-delete-pill-bg);
49
+
50
+ * {
51
+ text-decoration-line: none;
52
+ color: var(--diff-delete-parent-color);
53
+ }
54
+
55
+ .upload-diff__thumbnail {
56
+ border-radius: 0px;
57
+ border-color: var(--diff-delete-pill-border);
58
+ background-color: none;
59
+ }
60
+ }
61
+
62
+ &__card {
63
+ display: flex;
64
+ flex-direction: row;
65
+ align-items: center;
66
+ width: 100%;
67
+ }
68
+
69
+ &__thumbnail {
70
+ width: calc(var(--base) * 3 - base(0.8) * 2);
71
+ height: calc(var(--base) * 3 - base(0.8) * 2);
72
+ position: relative;
73
+ overflow: hidden;
74
+ flex-shrink: 0;
75
+ border-radius: 0px;
76
+ border: 1px solid var(--theme-elevation-100);
77
+
78
+ img,
79
+ svg {
80
+ position: absolute;
81
+ object-fit: cover;
82
+ width: 100%;
83
+ height: 100%;
84
+ border-radius: 0px;
85
+ }
86
+ }
87
+
88
+ &__info {
89
+ flex-grow: 1;
90
+ display: flex;
91
+ align-items: flex-start;
92
+ flex-direction: column;
93
+ padding: calc(var(--base) * 0.25) calc(var(--base) * 0.6);
94
+ justify-content: space-between;
95
+ font-weight: 400;
96
+
97
+ strong {
98
+ font-weight: 500;
99
+ }
100
+ }
101
+
102
+ &__pill {
103
+ border-radius: $style-radius-s;
104
+ margin-left: calc(var(--base) * 0.6);
105
+ padding: 0 calc(var(--base) * 0.1);
106
+
107
+ background-color: var(--theme-elevation-150);
108
+ color: var(--theme-elevation-750);
109
+ }
110
+
111
+ &[data-match-type='create'] .upload-diff__pill {
112
+ background-color: var(--diff-create-parent-bg);
113
+ color: var(--diff-create-pill-color);
114
+ }
115
+
116
+ &[data-match-type='delete'] .upload-diff__pill {
117
+ background-color: var(--diff-delete-parent-bg);
118
+ color: var(--diff-delete-pill-color);
119
+ }
120
+ }
121
+ }
@@ -1,3 +1,3 @@
1
- import type { FieldDiffClientProps, FieldTypes } from 'payload';
2
- export declare const diffComponents: Record<FieldTypes, React.ComponentType<FieldDiffClientProps>>;
1
+ import type { FieldDiffClientProps, FieldDiffServerProps, FieldTypes } from 'payload';
2
+ export declare const diffComponents: Record<FieldTypes, React.ComponentType<FieldDiffClientProps | FieldDiffServerProps>>;
3
3
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/views/Version/RenderFieldsToDiff/fields/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAW/D,eAAO,MAAM,cAAc,EAAE,MAAM,CAAC,UAAU,EAAE,KAAK,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAuBxF,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/views/Version/RenderFieldsToDiff/fields/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAarF,eAAO,MAAM,cAAc,EAAE,MAAM,CACjC,UAAU,EACV,KAAK,CAAC,aAAa,CAAC,oBAAoB,GAAG,oBAAoB,CAAC,CAwBjE,CAAA"}
@@ -1,4 +1,5 @@
1
1
  import { Collapsible } from './Collapsible/index.js';
2
+ import { DateDiffComponent } from './Date/index.js';
2
3
  import { Group } from './Group/index.js';
3
4
  import { Iterable } from './Iterable/index.js';
4
5
  import { Relationship } from './Relationship/index.js';
@@ -6,13 +7,14 @@ import { Row } from './Row/index.js';
6
7
  import { Select } from './Select/index.js';
7
8
  import { Tabs } from './Tabs/index.js';
8
9
  import { Text } from './Text/index.js';
10
+ import { Upload } from './Upload/index.js';
9
11
  export const diffComponents = {
10
12
  array: Iterable,
11
13
  blocks: Iterable,
12
14
  checkbox: Text,
13
15
  code: Text,
14
16
  collapsible: Collapsible,
15
- date: Text,
17
+ date: DateDiffComponent,
16
18
  email: Text,
17
19
  group: Group,
18
20
  join: null,
@@ -28,6 +30,6 @@ export const diffComponents = {
28
30
  text: Text,
29
31
  textarea: Text,
30
32
  ui: null,
31
- upload: Relationship
33
+ upload: Upload
32
34
  };
33
35
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["Collapsible","Group","Iterable","Relationship","Row","Select","Tabs","Text","diffComponents","array","blocks","checkbox","code","collapsible","date","email","group","join","json","number","point","radio","relationship","richText","row","select","tabs","text","textarea","ui","upload"],"sources":["../../../../../src/views/Version/RenderFieldsToDiff/fields/index.tsx"],"sourcesContent":["import type { FieldDiffClientProps, FieldTypes } from 'payload'\n\nimport { Collapsible } from './Collapsible/index.js'\nimport { Group } from './Group/index.js'\nimport { Iterable } from './Iterable/index.js'\nimport { Relationship } from './Relationship/index.js'\nimport { Row } from './Row/index.js'\nimport { Select } from './Select/index.js'\nimport { Tabs } from './Tabs/index.js'\nimport { Text } from './Text/index.js'\n\nexport const diffComponents: Record<FieldTypes, React.ComponentType<FieldDiffClientProps>> = {\n array: Iterable,\n blocks: Iterable,\n checkbox: Text,\n code: Text,\n collapsible: Collapsible,\n date: Text,\n email: Text,\n group: Group,\n join: null,\n json: Text,\n number: Text,\n point: Text,\n radio: Select,\n relationship: Relationship,\n richText: Text,\n row: Row,\n select: Select,\n tabs: Tabs,\n text: Text,\n textarea: Text,\n ui: null,\n upload: Relationship,\n}\n"],"mappings":"AAEA,SAASA,WAAW,QAAQ;AAC5B,SAASC,KAAK,QAAQ;AACtB,SAASC,QAAQ,QAAQ;AACzB,SAASC,YAAY,QAAQ;AAC7B,SAASC,GAAG,QAAQ;AACpB,SAASC,MAAM,QAAQ;AACvB,SAASC,IAAI,QAAQ;AACrB,SAASC,IAAI,QAAQ;AAErB,OAAO,MAAMC,cAAA,GAAgF;EAC3FC,KAAA,EAAOP,QAAA;EACPQ,MAAA,EAAQR,QAAA;EACRS,QAAA,EAAUJ,IAAA;EACVK,IAAA,EAAML,IAAA;EACNM,WAAA,EAAab,WAAA;EACbc,IAAA,EAAMP,IAAA;EACNQ,KAAA,EAAOR,IAAA;EACPS,KAAA,EAAOf,KAAA;EACPgB,IAAA,EAAM;EACNC,IAAA,EAAMX,IAAA;EACNY,MAAA,EAAQZ,IAAA;EACRa,KAAA,EAAOb,IAAA;EACPc,KAAA,EAAOhB,MAAA;EACPiB,YAAA,EAAcnB,YAAA;EACdoB,QAAA,EAAUhB,IAAA;EACViB,GAAA,EAAKpB,GAAA;EACLqB,MAAA,EAAQpB,MAAA;EACRqB,IAAA,EAAMpB,IAAA;EACNqB,IAAA,EAAMpB,IAAA;EACNqB,QAAA,EAAUrB,IAAA;EACVsB,EAAA,EAAI;EACJC,MAAA,EAAQ3B;AACV","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["Collapsible","DateDiffComponent","Group","Iterable","Relationship","Row","Select","Tabs","Text","Upload","diffComponents","array","blocks","checkbox","code","collapsible","date","email","group","join","json","number","point","radio","relationship","richText","row","select","tabs","text","textarea","ui","upload"],"sources":["../../../../../src/views/Version/RenderFieldsToDiff/fields/index.ts"],"sourcesContent":["import type { FieldDiffClientProps, FieldDiffServerProps, FieldTypes } from 'payload'\n\nimport { Collapsible } from './Collapsible/index.js'\nimport { DateDiffComponent } from './Date/index.js'\nimport { Group } from './Group/index.js'\nimport { Iterable } from './Iterable/index.js'\nimport { Relationship } from './Relationship/index.js'\nimport { Row } from './Row/index.js'\nimport { Select } from './Select/index.js'\nimport { Tabs } from './Tabs/index.js'\nimport { Text } from './Text/index.js'\nimport { Upload } from './Upload/index.js'\n\nexport const diffComponents: Record<\n FieldTypes,\n React.ComponentType<FieldDiffClientProps | FieldDiffServerProps>\n> = {\n array: Iterable,\n blocks: Iterable,\n checkbox: Text,\n code: Text,\n collapsible: Collapsible,\n date: DateDiffComponent,\n email: Text,\n group: Group,\n join: null,\n json: Text,\n number: Text,\n point: Text,\n radio: Select,\n relationship: Relationship,\n richText: Text,\n row: Row,\n select: Select,\n tabs: Tabs,\n text: Text,\n textarea: Text,\n ui: null,\n upload: Upload,\n}\n"],"mappings":"AAEA,SAASA,WAAW,QAAQ;AAC5B,SAASC,iBAAiB,QAAQ;AAClC,SAASC,KAAK,QAAQ;AACtB,SAASC,QAAQ,QAAQ;AACzB,SAASC,YAAY,QAAQ;AAC7B,SAASC,GAAG,QAAQ;AACpB,SAASC,MAAM,QAAQ;AACvB,SAASC,IAAI,QAAQ;AACrB,SAASC,IAAI,QAAQ;AACrB,SAASC,MAAM,QAAQ;AAEvB,OAAO,MAAMC,cAAA,GAGT;EACFC,KAAA,EAAOR,QAAA;EACPS,MAAA,EAAQT,QAAA;EACRU,QAAA,EAAUL,IAAA;EACVM,IAAA,EAAMN,IAAA;EACNO,WAAA,EAAaf,WAAA;EACbgB,IAAA,EAAMf,iBAAA;EACNgB,KAAA,EAAOT,IAAA;EACPU,KAAA,EAAOhB,KAAA;EACPiB,IAAA,EAAM;EACNC,IAAA,EAAMZ,IAAA;EACNa,MAAA,EAAQb,IAAA;EACRc,KAAA,EAAOd,IAAA;EACPe,KAAA,EAAOjB,MAAA;EACPkB,YAAA,EAAcpB,YAAA;EACdqB,QAAA,EAAUjB,IAAA;EACVkB,GAAA,EAAKrB,GAAA;EACLsB,MAAA,EAAQrB,MAAA;EACRsB,IAAA,EAAMrB,IAAA;EACNsB,IAAA,EAAMrB,IAAA;EACNsB,QAAA,EAAUtB,IAAA;EACVuB,EAAA,EAAI;EACJC,MAAA,EAAQvB;AACV","ignoreList":[]}
@@ -6,6 +6,7 @@ export const RenderDiff = args => {
6
6
  versionFields
7
7
  } = buildVersionFields(args);
8
8
  return /*#__PURE__*/_jsx(RenderVersionFieldsToDiff, {
9
+ parent: true,
9
10
  versionFields: versionFields
10
11
  });
11
12
  };
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["buildVersionFields","RenderVersionFieldsToDiff","RenderDiff","args","versionFields","_jsx"],"sources":["../../../../src/views/Version/RenderFieldsToDiff/index.tsx"],"sourcesContent":["import { buildVersionFields, type BuildVersionFieldsArgs } from './buildVersionFields.js'\nimport { RenderVersionFieldsToDiff } from './RenderVersionFieldsToDiff.js'\n\nexport const RenderDiff = (args: BuildVersionFieldsArgs): React.ReactNode => {\n const { versionFields } = buildVersionFields(args)\n\n return <RenderVersionFieldsToDiff versionFields={versionFields} />\n}\n"],"mappings":";AAAA,SAASA,kBAAkB,QAAqC;AAChE,SAASC,yBAAyB,QAAQ;AAE1C,OAAO,MAAMC,UAAA,GAAcC,IAAA;EACzB,MAAM;IAAEC;EAAa,CAAE,GAAGJ,kBAAA,CAAmBG,IAAA;EAE7C,oBAAOE,IAAA,CAACJ,yBAAA;IAA0BG,aAAA,EAAeA;;AACnD","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["buildVersionFields","RenderVersionFieldsToDiff","RenderDiff","args","versionFields","_jsx","parent"],"sources":["../../../../src/views/Version/RenderFieldsToDiff/index.tsx"],"sourcesContent":["import { buildVersionFields, type BuildVersionFieldsArgs } from './buildVersionFields.js'\nimport { RenderVersionFieldsToDiff } from './RenderVersionFieldsToDiff.js'\n\nexport const RenderDiff = (args: BuildVersionFieldsArgs): React.ReactNode => {\n const { versionFields } = buildVersionFields(args)\n\n return <RenderVersionFieldsToDiff parent={true} versionFields={versionFields} />\n}\n"],"mappings":";AAAA,SAASA,kBAAkB,QAAqC;AAChE,SAASC,yBAAyB,QAAQ;AAE1C,OAAO,MAAMC,UAAA,GAAcC,IAAA;EACzB,MAAM;IAAEC;EAAa,CAAE,GAAGJ,kBAAA,CAAmBG,IAAA;EAE7C,oBAAOE,IAAA,CAACJ,yBAAA;IAA0BK,MAAA,EAAQ;IAAMF,aAAA,EAAeA;;AACjE","ignoreList":[]}
@@ -1,6 +1,16 @@
1
- import React from 'react';
2
- import type { Props } from './types.js';
1
+ import type { ClientCollectionConfig, ClientGlobalConfig, SanitizedCollectionConfig } from 'payload';
3
2
  import './index.scss';
4
- declare const Restore: React.FC<Props>;
5
- export default Restore;
3
+ import React from 'react';
4
+ type Props = {
5
+ className?: string;
6
+ collectionConfig?: ClientCollectionConfig;
7
+ globalConfig?: ClientGlobalConfig;
8
+ label: SanitizedCollectionConfig['labels']['singular'];
9
+ originalDocID: number | string;
10
+ status?: string;
11
+ versionDateFormatted: string;
12
+ versionID: string;
13
+ };
14
+ export declare const Restore: React.FC<Props>;
15
+ export {};
6
16
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/views/Version/Restore/index.tsx"],"names":[],"mappings":"AAgBA,OAAO,KAA0C,MAAM,OAAO,CAAA;AAE9D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAEvC,OAAO,cAAc,CAAA;AAKrB,QAAA,MAAM,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAoG5B,CAAA;AAED,eAAe,OAAO,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/views/Version/Restore/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,sBAAsB,EAAE,kBAAkB,EAAE,yBAAyB,EAAE,MAAM,SAAS,CAAA;AAiBpG,OAAO,cAAc,CAAA;AAErB,OAAO,KAA0C,MAAM,OAAO,CAAA;AAK9D,KAAK,KAAK,GAAG;IACX,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,gBAAgB,CAAC,EAAE,sBAAsB,CAAA;IACzC,YAAY,CAAC,EAAE,kBAAkB,CAAA;IACjC,KAAK,EAAE,yBAAyB,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAA;IACtD,aAAa,EAAE,MAAM,GAAG,MAAM,CAAA;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,oBAAoB,EAAE,MAAM,CAAA;IAC5B,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,eAAO,MAAM,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAgHnC,CAAA"}
@@ -9,14 +9,14 @@ import { formatAdminURL } from 'payload/shared';
9
9
  import React, { Fragment, useCallback, useState } from 'react';
10
10
  const baseClass = 'restore-version';
11
11
  const modalSlug = 'restore-version';
12
- const Restore = ({
12
+ export const Restore = ({
13
13
  className,
14
- collectionSlug,
15
- globalSlug,
14
+ collectionConfig,
15
+ globalConfig,
16
16
  label,
17
17
  originalDocID,
18
18
  status,
19
- versionDate,
19
+ versionDateFormatted,
20
20
  versionID
21
21
  }) => {
22
22
  const {
@@ -26,12 +26,8 @@ const Restore = ({
26
26
  api: apiRoute
27
27
  },
28
28
  serverURL
29
- },
30
- getEntityConfig
29
+ }
31
30
  } = useConfig();
32
- const collectionConfig = getEntityConfig({
33
- collectionSlug
34
- });
35
31
  const {
36
32
  toggleModal
37
33
  } = useModal();
@@ -46,26 +42,26 @@ const Restore = ({
46
42
  } = useRouteTransition();
47
43
  const restoreMessage = t('version:aboutToRestoreGlobal', {
48
44
  label: getTranslation(label, i18n),
49
- versionDate
45
+ versionDate: versionDateFormatted
50
46
  });
51
- let fetchURL = `${serverURL}${apiRoute}`;
52
- let redirectURL;
53
47
  const canRestoreAsDraft = status !== 'draft' && collectionConfig?.versions?.drafts;
54
- if (collectionSlug) {
55
- fetchURL = `${fetchURL}/${collectionSlug}/versions/${versionID}?draft=${draft}`;
56
- redirectURL = formatAdminURL({
57
- adminRoute,
58
- path: `/collections/${collectionSlug}/${originalDocID}`
59
- });
60
- }
61
- if (globalSlug) {
62
- fetchURL = `${fetchURL}/globals/${globalSlug}/versions/${versionID}?draft=${draft}`;
63
- redirectURL = formatAdminURL({
64
- adminRoute,
65
- path: `/globals/${globalSlug}`
66
- });
67
- }
68
48
  const handleRestore = useCallback(async () => {
49
+ let fetchURL = `${serverURL}${apiRoute}`;
50
+ let redirectURL;
51
+ if (collectionConfig) {
52
+ fetchURL = `${fetchURL}/${collectionConfig.slug}/versions/${versionID}?draft=${draft}`;
53
+ redirectURL = formatAdminURL({
54
+ adminRoute,
55
+ path: `/collections/${collectionConfig.slug}/${originalDocID}`
56
+ });
57
+ }
58
+ if (globalConfig) {
59
+ fetchURL = `${fetchURL}/globals/${globalConfig.slug}/versions/${versionID}?draft=${draft}`;
60
+ redirectURL = formatAdminURL({
61
+ adminRoute,
62
+ path: `/globals/${globalConfig.slug}`
63
+ });
64
+ }
69
65
  const res = await requests.post(fetchURL, {
70
66
  headers: {
71
67
  'Accept-Language': i18n.language
@@ -78,15 +74,15 @@ const Restore = ({
78
74
  } else {
79
75
  toast.error(t('version:problemRestoringVersion'));
80
76
  }
81
- }, [fetchURL, redirectURL, t, i18n, router, startRouteTransition]);
77
+ }, [serverURL, apiRoute, collectionConfig, globalConfig, i18n.language, versionID, draft, adminRoute, originalDocID, startRouteTransition, router, t]);
82
78
  return /*#__PURE__*/_jsxs(Fragment, {
83
79
  children: [/*#__PURE__*/_jsx("div", {
84
80
  className: [baseClass, className].filter(Boolean).join(' '),
85
81
  children: /*#__PURE__*/_jsx(Button, {
86
- buttonStyle: "pill",
87
- className: [canRestoreAsDraft && `${baseClass}__button`].filter(Boolean).join(' '),
82
+ buttonStyle: "primary",
83
+ className: [canRestoreAsDraft && `${baseClass}__restore-as-draft-button`].filter(Boolean).join(' '),
88
84
  onClick: () => toggleModal(modalSlug),
89
- size: "small",
85
+ size: "xsmall",
90
86
  SubMenuPopupContent: canRestoreAsDraft ? () => /*#__PURE__*/_jsx(PopupList.ButtonGroup, {
91
87
  children: /*#__PURE__*/_jsx(PopupList.Button, {
92
88
  onClick: () => [setDraft(true), toggleModal(modalSlug)],
@@ -104,5 +100,4 @@ const Restore = ({
104
100
  })]
105
101
  });
106
102
  };
107
- export default Restore;
108
103
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["getTranslation","Button","ConfirmationModal","PopupList","toast","useConfig","useModal","useRouteTransition","useTranslation","requests","useRouter","formatAdminURL","React","Fragment","useCallback","useState","baseClass","modalSlug","Restore","className","collectionSlug","globalSlug","label","originalDocID","status","versionDate","versionID","config","routes","admin","adminRoute","api","apiRoute","serverURL","getEntityConfig","collectionConfig","toggleModal","router","i18n","t","draft","setDraft","startRouteTransition","restoreMessage","fetchURL","redirectURL","canRestoreAsDraft","versions","drafts","path","handleRestore","res","post","headers","language","json","success","message","push","error","_jsxs","_jsx","filter","Boolean","join","buttonStyle","onClick","size","SubMenuPopupContent","ButtonGroup","body","confirmingLabel","heading","onConfirm"],"sources":["../../../../src/views/Version/Restore/index.tsx"],"sourcesContent":["'use client'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport {\n Button,\n ConfirmationModal,\n PopupList,\n toast,\n useConfig,\n useModal,\n useRouteTransition,\n useTranslation,\n} from '@payloadcms/ui'\nimport { requests } from '@payloadcms/ui/shared'\nimport { useRouter } from 'next/navigation.js'\nimport { formatAdminURL } from 'payload/shared'\nimport React, { Fragment, useCallback, useState } from 'react'\n\nimport type { Props } from './types.js'\n\nimport './index.scss'\n\nconst baseClass = 'restore-version'\nconst modalSlug = 'restore-version'\n\nconst Restore: React.FC<Props> = ({\n className,\n collectionSlug,\n globalSlug,\n label,\n originalDocID,\n status,\n versionDate,\n versionID,\n}) => {\n const {\n config: {\n routes: { admin: adminRoute, api: apiRoute },\n serverURL,\n },\n getEntityConfig,\n } = useConfig()\n\n const collectionConfig = getEntityConfig({ collectionSlug })\n\n const { toggleModal } = useModal()\n const router = useRouter()\n const { i18n, t } = useTranslation()\n const [draft, setDraft] = useState(false)\n const { startRouteTransition } = useRouteTransition()\n\n const restoreMessage = t('version:aboutToRestoreGlobal', {\n label: getTranslation(label, i18n),\n versionDate,\n })\n\n let fetchURL = `${serverURL}${apiRoute}`\n let redirectURL: string\n\n const canRestoreAsDraft = status !== 'draft' && collectionConfig?.versions?.drafts\n\n if (collectionSlug) {\n fetchURL = `${fetchURL}/${collectionSlug}/versions/${versionID}?draft=${draft}`\n redirectURL = formatAdminURL({\n adminRoute,\n path: `/collections/${collectionSlug}/${originalDocID}`,\n })\n }\n\n if (globalSlug) {\n fetchURL = `${fetchURL}/globals/${globalSlug}/versions/${versionID}?draft=${draft}`\n redirectURL = formatAdminURL({\n adminRoute,\n path: `/globals/${globalSlug}`,\n })\n }\n\n const handleRestore = useCallback(async () => {\n const res = await requests.post(fetchURL, {\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (res.status === 200) {\n const json = await res.json()\n toast.success(json.message)\n return startRouteTransition(() => router.push(redirectURL))\n } else {\n toast.error(t('version:problemRestoringVersion'))\n }\n }, [fetchURL, redirectURL, t, i18n, router, startRouteTransition])\n\n return (\n <Fragment>\n <div className={[baseClass, className].filter(Boolean).join(' ')}>\n <Button\n buttonStyle=\"pill\"\n className={[canRestoreAsDraft && `${baseClass}__button`].filter(Boolean).join(' ')}\n onClick={() => toggleModal(modalSlug)}\n size=\"small\"\n SubMenuPopupContent={\n canRestoreAsDraft\n ? () => (\n <PopupList.ButtonGroup>\n <PopupList.Button onClick={() => [setDraft(true), toggleModal(modalSlug)]}>\n {t('version:restoreAsDraft')}\n </PopupList.Button>\n </PopupList.ButtonGroup>\n )\n : null\n }\n >\n {t('version:restoreThisVersion')}\n </Button>\n </div>\n <ConfirmationModal\n body={restoreMessage}\n confirmingLabel={t('version:restoring')}\n heading={t('version:confirmVersionRestoration')}\n modalSlug={modalSlug}\n onConfirm={handleRestore}\n />\n </Fragment>\n )\n}\n\nexport default Restore\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["getTranslation","Button","ConfirmationModal","PopupList","toast","useConfig","useModal","useRouteTransition","useTranslation","requests","useRouter","formatAdminURL","React","Fragment","useCallback","useState","baseClass","modalSlug","Restore","className","collectionConfig","globalConfig","label","originalDocID","status","versionDateFormatted","versionID","config","routes","admin","adminRoute","api","apiRoute","serverURL","toggleModal","router","i18n","t","draft","setDraft","startRouteTransition","restoreMessage","versionDate","canRestoreAsDraft","versions","drafts","handleRestore","fetchURL","redirectURL","slug","path","res","post","headers","language","json","success","message","push","error","_jsxs","_jsx","filter","Boolean","join","buttonStyle","onClick","size","SubMenuPopupContent","ButtonGroup","body","confirmingLabel","heading","onConfirm"],"sources":["../../../../src/views/Version/Restore/index.tsx"],"sourcesContent":["'use client'\n\nimport type { ClientCollectionConfig, ClientGlobalConfig, SanitizedCollectionConfig } from 'payload'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport {\n Button,\n ConfirmationModal,\n PopupList,\n toast,\n useConfig,\n useModal,\n useRouteTransition,\n useTranslation,\n} from '@payloadcms/ui'\nimport { requests } from '@payloadcms/ui/shared'\nimport { useRouter } from 'next/navigation.js'\nimport { formatAdminURL } from 'payload/shared'\n\nimport './index.scss'\n\nimport React, { Fragment, useCallback, useState } from 'react'\n\nconst baseClass = 'restore-version'\nconst modalSlug = 'restore-version'\n\ntype Props = {\n className?: string\n collectionConfig?: ClientCollectionConfig\n globalConfig?: ClientGlobalConfig\n label: SanitizedCollectionConfig['labels']['singular']\n originalDocID: number | string\n status?: string\n versionDateFormatted: string\n versionID: string\n}\n\nexport const Restore: React.FC<Props> = ({\n className,\n collectionConfig,\n globalConfig,\n label,\n originalDocID,\n status,\n versionDateFormatted,\n versionID,\n}) => {\n const {\n config: {\n routes: { admin: adminRoute, api: apiRoute },\n serverURL,\n },\n } = useConfig()\n\n const { toggleModal } = useModal()\n const router = useRouter()\n const { i18n, t } = useTranslation()\n const [draft, setDraft] = useState(false)\n const { startRouteTransition } = useRouteTransition()\n\n const restoreMessage = t('version:aboutToRestoreGlobal', {\n label: getTranslation(label, i18n),\n versionDate: versionDateFormatted,\n })\n\n const canRestoreAsDraft = status !== 'draft' && collectionConfig?.versions?.drafts\n\n const handleRestore = useCallback(async () => {\n let fetchURL = `${serverURL}${apiRoute}`\n let redirectURL: string\n\n if (collectionConfig) {\n fetchURL = `${fetchURL}/${collectionConfig.slug}/versions/${versionID}?draft=${draft}`\n redirectURL = formatAdminURL({\n adminRoute,\n path: `/collections/${collectionConfig.slug}/${originalDocID}`,\n })\n }\n\n if (globalConfig) {\n fetchURL = `${fetchURL}/globals/${globalConfig.slug}/versions/${versionID}?draft=${draft}`\n redirectURL = formatAdminURL({\n adminRoute,\n path: `/globals/${globalConfig.slug}`,\n })\n }\n\n const res = await requests.post(fetchURL, {\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (res.status === 200) {\n const json = await res.json()\n toast.success(json.message)\n return startRouteTransition(() => router.push(redirectURL))\n } else {\n toast.error(t('version:problemRestoringVersion'))\n }\n }, [\n serverURL,\n apiRoute,\n collectionConfig,\n globalConfig,\n i18n.language,\n versionID,\n draft,\n adminRoute,\n originalDocID,\n startRouteTransition,\n router,\n t,\n ])\n\n return (\n <Fragment>\n <div className={[baseClass, className].filter(Boolean).join(' ')}>\n <Button\n buttonStyle=\"primary\"\n className={[canRestoreAsDraft && `${baseClass}__restore-as-draft-button`]\n .filter(Boolean)\n .join(' ')}\n onClick={() => toggleModal(modalSlug)}\n size=\"xsmall\"\n SubMenuPopupContent={\n canRestoreAsDraft\n ? () => (\n <PopupList.ButtonGroup>\n <PopupList.Button onClick={() => [setDraft(true), toggleModal(modalSlug)]}>\n {t('version:restoreAsDraft')}\n </PopupList.Button>\n </PopupList.ButtonGroup>\n )\n : null\n }\n >\n {t('version:restoreThisVersion')}\n </Button>\n </div>\n <ConfirmationModal\n body={restoreMessage}\n confirmingLabel={t('version:restoring')}\n heading={t('version:confirmVersionRestoration')}\n modalSlug={modalSlug}\n onConfirm={handleRestore}\n />\n </Fragment>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -4,6 +4,7 @@
4
4
  .restore-version {
5
5
  cursor: pointer;
6
6
  display: flex;
7
+ min-width: max-content;
7
8
 
8
9
  .popup-button {
9
10
  display: flex;
@@ -24,7 +25,11 @@
24
25
  }
25
26
  }
26
27
 
27
- &__button {
28
+ .btn {
29
+ margin-block: 0;
30
+ }
31
+
32
+ &__restore-as-draft-button {
28
33
  border-top-right-radius: 0px;
29
34
  border-bottom-right-radius: 0px;
30
35
  margin-right: 2px;
@@ -0,0 +1,3 @@
1
+ import type { CreatedAtCellProps } from '../../../Versions/cells/CreatedAt/index.js';
2
+ export declare const VersionDrawerCreatedAtCell: React.FC<CreatedAtCellProps>;
3
+ //# sourceMappingURL=CreatedAtCell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CreatedAtCell.d.ts","sourceRoot":"","sources":["../../../../../src/views/Version/SelectComparison/VersionDrawer/CreatedAtCell.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAA;AAEpF,eAAO,MAAM,0BAA0B,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAqCnE,CAAA"}