@strapi/content-manager 0.0.0-experimental.826f263c58b6886b849d3f03b81f7a530bc51c91 → 0.0.0-experimental.82afe56cecefd0078d534e25909834ecf5fdd404

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 (231) hide show
  1. package/LICENSE +18 -3
  2. package/dist/_chunks/CardDragPreview-C0QyJgRA.js.map +1 -1
  3. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +1 -1
  4. package/dist/_chunks/{ComponentConfigurationPage-DJcn1DrO.js → ComponentConfigurationPage-DMxUlNOo.js} +5 -6
  5. package/dist/_chunks/{ComponentConfigurationPage-DJcn1DrO.js.map → ComponentConfigurationPage-DMxUlNOo.js.map} +1 -1
  6. package/dist/_chunks/{ComponentConfigurationPage-CR5XdR33.mjs → ComponentConfigurationPage-baEkO-OV.mjs} +4 -4
  7. package/dist/_chunks/{ComponentConfigurationPage-CR5XdR33.mjs.map → ComponentConfigurationPage-baEkO-OV.mjs.map} +1 -1
  8. package/dist/_chunks/{ComponentIcon-BXdiCGQp.js → ComponentIcon-CRbtQEUV.js} +2 -3
  9. package/dist/_chunks/{ComponentIcon-BXdiCGQp.js.map → ComponentIcon-CRbtQEUV.js.map} +1 -1
  10. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +1 -1
  11. package/dist/_chunks/{EditConfigurationPage-tDtWj7R2.js → EditConfigurationPage-CXxV7mKn.js} +5 -6
  12. package/dist/_chunks/{EditConfigurationPage-tDtWj7R2.js.map → EditConfigurationPage-CXxV7mKn.js.map} +1 -1
  13. package/dist/_chunks/{EditConfigurationPage-DmCIb4kD.mjs → EditConfigurationPage-YR8-4VCS.mjs} +4 -4
  14. package/dist/_chunks/{EditConfigurationPage-DmCIb4kD.mjs.map → EditConfigurationPage-YR8-4VCS.mjs.map} +1 -1
  15. package/dist/_chunks/{EditViewPage-CoQEnFlC.js → EditViewPage-BfR6jAR6.js} +71 -84
  16. package/dist/_chunks/EditViewPage-BfR6jAR6.js.map +1 -0
  17. package/dist/_chunks/EditViewPage-DFF7c27p.mjs +191 -0
  18. package/dist/_chunks/EditViewPage-DFF7c27p.mjs.map +1 -0
  19. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +1 -1
  20. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +1 -1
  21. package/dist/_chunks/{Form-Bpig5rch.js → Form-CjcMRP5A.js} +55 -38
  22. package/dist/_chunks/Form-CjcMRP5A.js.map +1 -0
  23. package/dist/_chunks/{Form-Dxmihyw8.mjs → Form-MSOSfGGN.mjs} +55 -37
  24. package/dist/_chunks/Form-MSOSfGGN.mjs.map +1 -0
  25. package/dist/_chunks/{History-BfX6XmZK.js → History-BgZ7gVuF.js} +208 -138
  26. package/dist/_chunks/History-BgZ7gVuF.js.map +1 -0
  27. package/dist/_chunks/{History-BZP8n7KT.mjs → History-WOQNVho-.mjs} +201 -130
  28. package/dist/_chunks/History-WOQNVho-.mjs.map +1 -0
  29. package/dist/_chunks/{Field-Cz_J9551.mjs → Input-BkKwZ6Qt.mjs} +1757 -1383
  30. package/dist/_chunks/Input-BkKwZ6Qt.mjs.map +1 -0
  31. package/dist/_chunks/{Field-ZdrmmQ4Y.js → Input-BwOibhc3.js} +1748 -1374
  32. package/dist/_chunks/Input-BwOibhc3.js.map +1 -0
  33. package/dist/_chunks/{ListConfigurationPage-DxKuVkKz.mjs → ListConfigurationPage-BeXfr6uW.mjs} +63 -52
  34. package/dist/_chunks/ListConfigurationPage-BeXfr6uW.mjs.map +1 -0
  35. package/dist/_chunks/{ListConfigurationPage-B3CXj8PY.js → ListConfigurationPage-DnJ3nbwL.js} +62 -51
  36. package/dist/_chunks/ListConfigurationPage-DnJ3nbwL.js.map +1 -0
  37. package/dist/_chunks/{ListViewPage-Bk9VO__I.js → ListViewPage-CJFDudKl.js} +155 -129
  38. package/dist/_chunks/ListViewPage-CJFDudKl.js.map +1 -0
  39. package/dist/_chunks/{ListViewPage-D5D3tVPq.mjs → ListViewPage-VK2v44Q1.mjs} +156 -129
  40. package/dist/_chunks/ListViewPage-VK2v44Q1.mjs.map +1 -0
  41. package/dist/_chunks/{NoContentTypePage-DnMeuQCj.mjs → NoContentTypePage-T8ttty6K.mjs} +2 -2
  42. package/dist/_chunks/{NoContentTypePage-DnMeuQCj.mjs.map → NoContentTypePage-T8ttty6K.mjs.map} +1 -1
  43. package/dist/_chunks/{NoContentTypePage-DsB2F7Z1.js → NoContentTypePage-en2PwWgI.js} +2 -2
  44. package/dist/_chunks/{NoContentTypePage-DsB2F7Z1.js.map → NoContentTypePage-en2PwWgI.js.map} +1 -1
  45. package/dist/_chunks/{NoPermissionsPage-BQDM64_b.js → NoPermissionsPage-CcjILry3.js} +2 -2
  46. package/dist/_chunks/{NoPermissionsPage-BQDM64_b.js.map → NoPermissionsPage-CcjILry3.js.map} +1 -1
  47. package/dist/_chunks/{NoPermissionsPage-OyoME_Tf.mjs → NoPermissionsPage-CokBHhhy.mjs} +2 -2
  48. package/dist/_chunks/{NoPermissionsPage-OyoME_Tf.mjs.map → NoPermissionsPage-CokBHhhy.mjs.map} +1 -1
  49. package/dist/_chunks/Preview-BF81YhRj.mjs +287 -0
  50. package/dist/_chunks/Preview-BF81YhRj.mjs.map +1 -0
  51. package/dist/_chunks/Preview-DgzAuzWQ.js +305 -0
  52. package/dist/_chunks/Preview-DgzAuzWQ.js.map +1 -0
  53. package/dist/_chunks/{Relations-B6B3A3mb.js → Relations-1O-JcM4t.js} +76 -43
  54. package/dist/_chunks/Relations-1O-JcM4t.js.map +1 -0
  55. package/dist/_chunks/{Relations-BOYZmuWy.mjs → Relations-BncdhGCd.mjs} +76 -42
  56. package/dist/_chunks/Relations-BncdhGCd.mjs.map +1 -0
  57. package/dist/_chunks/{en-Dzv55oQw.mjs → en-BZaUty0m.mjs} +41 -18
  58. package/dist/_chunks/{en-Dzv55oQw.mjs.map → en-BZaUty0m.mjs.map} +1 -1
  59. package/dist/_chunks/{en-BN1bvFK7.js → en-CzCnBk4S.js} +41 -18
  60. package/dist/_chunks/{en-BN1bvFK7.js.map → en-CzCnBk4S.js.map} +1 -1
  61. package/dist/_chunks/{es-EUonQTon.js → es-9K52xZIr.js} +2 -2
  62. package/dist/_chunks/{ja-CcFe8diO.js.map → es-9K52xZIr.js.map} +1 -1
  63. package/dist/_chunks/{es-CeXiYflN.mjs → es-D34tqjMw.mjs} +2 -2
  64. package/dist/_chunks/{es-CeXiYflN.mjs.map → es-D34tqjMw.mjs.map} +1 -1
  65. package/dist/_chunks/{fr-CD9VFbPM.mjs → fr--pg5jUbt.mjs} +13 -3
  66. package/dist/_chunks/{fr-CD9VFbPM.mjs.map → fr--pg5jUbt.mjs.map} +1 -1
  67. package/dist/_chunks/{fr-B7kGGg3E.js → fr-B2Kyv8Z9.js} +13 -3
  68. package/dist/_chunks/{fr-B7kGGg3E.js.map → fr-B2Kyv8Z9.js.map} +1 -1
  69. package/dist/_chunks/hooks-BAaaKPS_.js.map +1 -1
  70. package/dist/_chunks/{index-VHviNMeW.mjs → index-DiluOUp6.mjs} +1469 -966
  71. package/dist/_chunks/index-DiluOUp6.mjs.map +1 -0
  72. package/dist/_chunks/{index-DzN3kBgx.js → index-EXJvmn4t.js} +1439 -936
  73. package/dist/_chunks/index-EXJvmn4t.js.map +1 -0
  74. package/dist/_chunks/{ja-CcFe8diO.js → ja-7sfIbjxE.js} +2 -2
  75. package/dist/_chunks/{es-EUonQTon.js.map → ja-7sfIbjxE.js.map} +1 -1
  76. package/dist/_chunks/{ja-CtsUxOvk.mjs → ja-BHqhDq4V.mjs} +2 -2
  77. package/dist/_chunks/{ja-CtsUxOvk.mjs.map → ja-BHqhDq4V.mjs.map} +1 -1
  78. package/dist/_chunks/{layout-b91XRlD2.js → layout-4TbKVax8.js} +41 -24
  79. package/dist/_chunks/layout-4TbKVax8.js.map +1 -0
  80. package/dist/_chunks/{layout-CPn1PM6x.mjs → layout-mSwsYzxv.mjs} +42 -24
  81. package/dist/_chunks/layout-mSwsYzxv.mjs.map +1 -0
  82. package/dist/_chunks/{objects-gigeqt7s.js → objects-BcXOv6_9.js} +2 -4
  83. package/dist/_chunks/{objects-gigeqt7s.js.map → objects-BcXOv6_9.js.map} +1 -1
  84. package/dist/_chunks/{objects-mKMAmfec.mjs → objects-D6yBsdmx.mjs} +2 -4
  85. package/dist/_chunks/{objects-mKMAmfec.mjs.map → objects-D6yBsdmx.mjs.map} +1 -1
  86. package/dist/_chunks/{relations-BsqxS6tR.mjs → relations--YOvQBqv.mjs} +6 -7
  87. package/dist/_chunks/relations--YOvQBqv.mjs.map +1 -0
  88. package/dist/_chunks/{relations-CA7IYmcP.js → relations-Ai6Izh7h.js} +6 -7
  89. package/dist/_chunks/relations-Ai6Izh7h.js.map +1 -0
  90. package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js → useDragAndDrop-BMtgCYzL.js} +5 -9
  91. package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js.map → useDragAndDrop-BMtgCYzL.js.map} +1 -1
  92. package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs → useDragAndDrop-DJ6jqvZN.mjs} +4 -7
  93. package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs.map → useDragAndDrop-DJ6jqvZN.mjs.map} +1 -1
  94. package/dist/_chunks/usePrev-CZGy2Vjf.mjs +29 -0
  95. package/dist/_chunks/usePrev-CZGy2Vjf.mjs.map +1 -0
  96. package/dist/_chunks/{usePrev-B9w_-eYc.js → usePrev-D5J_2fEu.js} +14 -1
  97. package/dist/_chunks/usePrev-D5J_2fEu.js.map +1 -0
  98. package/dist/admin/index.js +3 -1
  99. package/dist/admin/index.js.map +1 -1
  100. package/dist/admin/index.mjs +10 -8
  101. package/dist/admin/src/content-manager.d.ts +3 -2
  102. package/dist/admin/src/exports.d.ts +2 -1
  103. package/dist/admin/src/history/components/VersionInputRenderer.d.ts +1 -1
  104. package/dist/admin/src/history/index.d.ts +3 -0
  105. package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
  106. package/dist/admin/src/hooks/useDocument.d.ts +49 -1
  107. package/dist/admin/src/index.d.ts +1 -0
  108. package/dist/admin/src/pages/EditView/EditViewPage.d.ts +9 -1
  109. package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +9 -4
  110. package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +3 -3
  111. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.d.ts +7 -0
  112. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/utils/prismLanguages.d.ts +49 -0
  113. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/constants.d.ts +5 -0
  114. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.d.ts +4 -1
  115. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/Field.d.ts +4 -1
  116. package/dist/admin/src/pages/EditView/components/FormInputs/Relations.d.ts +20 -0
  117. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.d.ts +2 -2
  118. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygFooter.d.ts +2 -2
  119. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygStyles.d.ts +6 -58
  120. package/dist/admin/src/pages/EditView/components/FormLayout.d.ts +27 -0
  121. package/dist/admin/src/pages/EditView/components/Header.d.ts +11 -11
  122. package/dist/admin/src/pages/EditView/utils/data.d.ts +1 -0
  123. package/dist/admin/src/pages/ListView/components/BulkActions/Actions.d.ts +3 -30
  124. package/dist/admin/src/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.d.ts +2 -2
  125. package/dist/admin/src/preview/components/PreviewContent.d.ts +2 -0
  126. package/dist/admin/src/preview/components/PreviewHeader.d.ts +2 -0
  127. package/dist/admin/src/preview/components/PreviewSidePanel.d.ts +3 -0
  128. package/dist/admin/src/preview/index.d.ts +4 -0
  129. package/dist/admin/src/preview/pages/Preview.d.ts +11 -0
  130. package/dist/admin/src/preview/routes.d.ts +3 -0
  131. package/dist/admin/src/preview/services/preview.d.ts +3 -0
  132. package/dist/admin/src/router.d.ts +1 -1
  133. package/dist/admin/src/services/api.d.ts +1 -1
  134. package/dist/admin/src/services/components.d.ts +2 -2
  135. package/dist/admin/src/services/contentTypes.d.ts +3 -3
  136. package/dist/admin/src/services/documents.d.ts +19 -20
  137. package/dist/admin/src/services/init.d.ts +1 -1
  138. package/dist/admin/src/services/relations.d.ts +2 -2
  139. package/dist/admin/src/services/uid.d.ts +3 -3
  140. package/dist/admin/src/utils/validation.d.ts +4 -1
  141. package/dist/server/index.js +765 -434
  142. package/dist/server/index.js.map +1 -1
  143. package/dist/server/index.mjs +766 -434
  144. package/dist/server/index.mjs.map +1 -1
  145. package/dist/server/src/bootstrap.d.ts.map +1 -1
  146. package/dist/server/src/controllers/collection-types.d.ts.map +1 -1
  147. package/dist/server/src/controllers/index.d.ts.map +1 -1
  148. package/dist/server/src/controllers/relations.d.ts.map +1 -1
  149. package/dist/server/src/controllers/uid.d.ts.map +1 -1
  150. package/dist/server/src/controllers/utils/metadata.d.ts +16 -1
  151. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
  152. package/dist/server/src/controllers/validation/dimensions.d.ts +4 -2
  153. package/dist/server/src/controllers/validation/dimensions.d.ts.map +1 -1
  154. package/dist/server/src/history/controllers/history-version.d.ts +1 -1
  155. package/dist/server/src/history/controllers/history-version.d.ts.map +1 -1
  156. package/dist/server/src/history/services/history.d.ts +3 -3
  157. package/dist/server/src/history/services/history.d.ts.map +1 -1
  158. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -1
  159. package/dist/server/src/history/services/utils.d.ts +8 -12
  160. package/dist/server/src/history/services/utils.d.ts.map +1 -1
  161. package/dist/server/src/index.d.ts +7 -6
  162. package/dist/server/src/index.d.ts.map +1 -1
  163. package/dist/server/src/policies/hasPermissions.d.ts.map +1 -1
  164. package/dist/server/src/preview/controllers/index.d.ts +2 -0
  165. package/dist/server/src/preview/controllers/index.d.ts.map +1 -0
  166. package/dist/server/src/preview/controllers/preview.d.ts +13 -0
  167. package/dist/server/src/preview/controllers/preview.d.ts.map +1 -0
  168. package/dist/server/src/preview/controllers/validation/preview.d.ts +6 -0
  169. package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -0
  170. package/dist/server/src/preview/index.d.ts +4 -0
  171. package/dist/server/src/preview/index.d.ts.map +1 -0
  172. package/dist/server/src/preview/routes/index.d.ts +8 -0
  173. package/dist/server/src/preview/routes/index.d.ts.map +1 -0
  174. package/dist/server/src/preview/routes/preview.d.ts +4 -0
  175. package/dist/server/src/preview/routes/preview.d.ts.map +1 -0
  176. package/dist/server/src/preview/services/index.d.ts +16 -0
  177. package/dist/server/src/preview/services/index.d.ts.map +1 -0
  178. package/dist/server/src/preview/services/preview-config.d.ts +32 -0
  179. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -0
  180. package/dist/server/src/preview/services/preview.d.ts +12 -0
  181. package/dist/server/src/preview/services/preview.d.ts.map +1 -0
  182. package/dist/server/src/preview/utils.d.ts +19 -0
  183. package/dist/server/src/preview/utils.d.ts.map +1 -0
  184. package/dist/server/src/register.d.ts.map +1 -1
  185. package/dist/server/src/routes/index.d.ts.map +1 -1
  186. package/dist/server/src/services/document-manager.d.ts.map +1 -1
  187. package/dist/server/src/services/document-metadata.d.ts +12 -10
  188. package/dist/server/src/services/document-metadata.d.ts.map +1 -1
  189. package/dist/server/src/services/index.d.ts +7 -6
  190. package/dist/server/src/services/index.d.ts.map +1 -1
  191. package/dist/server/src/services/permission-checker.d.ts.map +1 -1
  192. package/dist/server/src/services/utils/populate.d.ts +2 -2
  193. package/dist/server/src/services/utils/populate.d.ts.map +1 -1
  194. package/dist/server/src/utils/index.d.ts +2 -0
  195. package/dist/server/src/utils/index.d.ts.map +1 -1
  196. package/dist/shared/contracts/collection-types.d.ts +3 -1
  197. package/dist/shared/contracts/collection-types.d.ts.map +1 -1
  198. package/dist/shared/contracts/index.d.ts +1 -0
  199. package/dist/shared/contracts/index.d.ts.map +1 -1
  200. package/dist/shared/contracts/preview.d.ts +27 -0
  201. package/dist/shared/contracts/preview.d.ts.map +1 -0
  202. package/dist/shared/index.js +4 -0
  203. package/dist/shared/index.js.map +1 -1
  204. package/dist/shared/index.mjs +4 -0
  205. package/dist/shared/index.mjs.map +1 -1
  206. package/package.json +17 -16
  207. package/dist/_chunks/EditViewPage-CoQEnFlC.js.map +0 -1
  208. package/dist/_chunks/EditViewPage-DvaV7U9b.mjs +0 -203
  209. package/dist/_chunks/EditViewPage-DvaV7U9b.mjs.map +0 -1
  210. package/dist/_chunks/Field-Cz_J9551.mjs.map +0 -1
  211. package/dist/_chunks/Field-ZdrmmQ4Y.js.map +0 -1
  212. package/dist/_chunks/Form-Bpig5rch.js.map +0 -1
  213. package/dist/_chunks/Form-Dxmihyw8.mjs.map +0 -1
  214. package/dist/_chunks/History-BZP8n7KT.mjs.map +0 -1
  215. package/dist/_chunks/History-BfX6XmZK.js.map +0 -1
  216. package/dist/_chunks/ListConfigurationPage-B3CXj8PY.js.map +0 -1
  217. package/dist/_chunks/ListConfigurationPage-DxKuVkKz.mjs.map +0 -1
  218. package/dist/_chunks/ListViewPage-Bk9VO__I.js.map +0 -1
  219. package/dist/_chunks/ListViewPage-D5D3tVPq.mjs.map +0 -1
  220. package/dist/_chunks/Relations-B6B3A3mb.js.map +0 -1
  221. package/dist/_chunks/Relations-BOYZmuWy.mjs.map +0 -1
  222. package/dist/_chunks/index-DzN3kBgx.js.map +0 -1
  223. package/dist/_chunks/index-VHviNMeW.mjs.map +0 -1
  224. package/dist/_chunks/layout-CPn1PM6x.mjs.map +0 -1
  225. package/dist/_chunks/layout-b91XRlD2.js.map +0 -1
  226. package/dist/_chunks/relations-BsqxS6tR.mjs.map +0 -1
  227. package/dist/_chunks/relations-CA7IYmcP.js.map +0 -1
  228. package/dist/_chunks/usePrev-B9w_-eYc.js.map +0 -1
  229. package/dist/_chunks/usePrev-DH6iah0A.mjs +0 -16
  230. package/dist/_chunks/usePrev-DH6iah0A.mjs.map +0 -1
  231. package/strapi-server.js +0 -3
@@ -7,17 +7,16 @@ const designSystem = require("@strapi/design-system");
7
7
  const qs = require("qs");
8
8
  const reactIntl = require("react-intl");
9
9
  const reactRouterDom = require("react-router-dom");
10
- const index = require("./index-DzN3kBgx.js");
10
+ const index = require("./index-EXJvmn4t.js");
11
11
  const pipe = require("lodash/fp/pipe");
12
12
  const hooks = require("./hooks-BAaaKPS_.js");
13
- const Field = require("./Field-ZdrmmQ4Y.js");
14
13
  const Icons = require("@strapi/icons");
15
14
  const styledComponents = require("styled-components");
16
- const relations = require("./relations-CA7IYmcP.js");
15
+ const Input = require("./Input-BwOibhc3.js");
16
+ const relations = require("./relations-Ai6Izh7h.js");
17
17
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
18
18
  function _interopNamespace(e) {
19
- if (e && e.__esModule)
20
- return e;
19
+ if (e && e.__esModule) return e;
21
20
  const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
22
21
  if (e) {
23
22
  for (const k in e) {
@@ -36,7 +35,7 @@ function _interopNamespace(e) {
36
35
  const React__namespace = /* @__PURE__ */ _interopNamespace(React);
37
36
  const pipe__default = /* @__PURE__ */ _interopDefault(pipe);
38
37
  const StyledAlert = styledComponents.styled(designSystem.Alert).attrs({ closeLabel: "Close", onClose: () => {
39
- } })`
38
+ }, shadow: "none" })`
40
39
  button {
41
40
  display: none;
42
41
  }
@@ -54,13 +53,13 @@ const LinkEllipsis = styledComponents.styled(designSystem.Link)`
54
53
  const CustomRelationInput = (props) => {
55
54
  const { formatMessage } = reactIntl.useIntl();
56
55
  const field = strapiAdmin.useField(props.name);
57
- const formattedFieldValue = Array.isArray(field.value) ? {
58
- results: field.value,
59
- meta: { missingCount: 0 }
60
- } : field.value;
56
+ let formattedFieldValue;
57
+ if (field) {
58
+ formattedFieldValue = Array.isArray(field.value) ? { results: field.value, meta: { missingCount: 0 } } : field.value;
59
+ }
61
60
  if (!formattedFieldValue || formattedFieldValue.results.length === 0 && formattedFieldValue.meta.missingCount === 0) {
62
61
  return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
63
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: props.label }),
62
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { action: props.labelAction, children: props.label }),
64
63
  /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { marginTop: 1, children: /* @__PURE__ */ jsxRuntime.jsx(StyledAlert, { variant: "default", children: formatMessage({
65
64
  id: "content-manager.history.content.no-relations",
66
65
  defaultMessage: "No relations."
@@ -71,8 +70,10 @@ const CustomRelationInput = (props) => {
71
70
  return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Box, { children: [
72
71
  /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: props.label }),
73
72
  results.length > 0 && /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", gap: 2, marginTop: 1, alignItems: "stretch", children: results.map((relationData) => {
74
- const href = `../${index.COLLECTION_TYPES}/${props.attribute.targetModel}/${relationData.documentId}`;
73
+ const { targetModel } = props.attribute;
74
+ const href = `../${index.COLLECTION_TYPES}/${targetModel}/${relationData.documentId}`;
75
75
  const label = relations.getRelationLabel(relationData, props.mainField);
76
+ const isAdminUserRelation = targetModel === "admin::user";
76
77
  return /* @__PURE__ */ jsxRuntime.jsxs(
77
78
  designSystem.Flex,
78
79
  {
@@ -85,11 +86,11 @@ const CustomRelationInput = (props) => {
85
86
  background: "neutral150",
86
87
  justifyContent: "space-between",
87
88
  children: [
88
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { minWidth: 0, paddingTop: 1, paddingBottom: 1, paddingRight: 4, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Tooltip, { description: label, children: /* @__PURE__ */ jsxRuntime.jsx(LinkEllipsis, { tag: reactRouterDom.NavLink, to: href, children: label }) }) }),
89
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { minWidth: 0, paddingTop: 1, paddingBottom: 1, paddingRight: 4, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Tooltip, { label, children: isAdminUserRelation ? /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { children: label }) : /* @__PURE__ */ jsxRuntime.jsx(LinkEllipsis, { tag: reactRouterDom.NavLink, to: href, children: label }) }) }),
89
90
  /* @__PURE__ */ jsxRuntime.jsx(index.DocumentStatus, { status: relationData.status })
90
91
  ]
91
92
  },
92
- relationData.documentId
93
+ relationData.documentId ?? relationData.id
93
94
  );
94
95
  }) }),
95
96
  meta.missingCount > 0 && /* @ts-expect-error – we dont need closeLabel */
@@ -116,15 +117,38 @@ const CustomRelationInput = (props) => {
116
117
  )
117
118
  ] });
118
119
  };
120
+ const createInitialValuesForPath = (keyPath, value) => {
121
+ const keys = keyPath.split(".");
122
+ const root = {};
123
+ let node = root;
124
+ keys.forEach((key, index2) => {
125
+ if (key === "__proto__" || key === "constructor") return;
126
+ if (index2 === keys.length - 1) {
127
+ node[key] = value;
128
+ } else {
129
+ node[key] = node[key] || {};
130
+ }
131
+ node = node[key];
132
+ });
133
+ return root;
134
+ };
119
135
  const CustomMediaInput = (props) => {
120
- const {
121
- value: { results, meta }
122
- } = strapiAdmin.useField(props.name);
136
+ const { value } = strapiAdmin.useField(props.name);
137
+ const results = value?.results ?? [];
138
+ const meta = value?.meta ?? { missingCount: 0 };
123
139
  const { formatMessage } = reactIntl.useIntl();
124
140
  const fields = strapiAdmin.useStrapiApp("CustomMediaInput", (state) => state.fields);
125
141
  const MediaLibrary = fields.media;
126
142
  return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", gap: 2, alignItems: "stretch", children: [
127
- /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Form, { method: "PUT", disabled: true, initialValues: { [props.name]: results }, children: /* @__PURE__ */ jsxRuntime.jsx(MediaLibrary, { ...props, disabled: true, multiple: results.length > 1 }) }),
143
+ /* @__PURE__ */ jsxRuntime.jsx(
144
+ strapiAdmin.Form,
145
+ {
146
+ method: "PUT",
147
+ disabled: true,
148
+ initialValues: createInitialValuesForPath(props.name, results),
149
+ children: /* @__PURE__ */ jsxRuntime.jsx(MediaLibrary, { ...props, disabled: true, multiple: results.length > 1 })
150
+ }
151
+ ),
128
152
  meta.missingCount > 0 && /* @__PURE__ */ jsxRuntime.jsx(
129
153
  StyledAlert,
130
154
  {
@@ -150,19 +174,46 @@ const CustomMediaInput = (props) => {
150
174
  )
151
175
  ] });
152
176
  };
177
+ const getLabelAction = (labelAction) => {
178
+ if (!React__namespace.isValidElement(labelAction)) {
179
+ return labelAction;
180
+ }
181
+ const labelActionTitleId = labelAction.props.title.id;
182
+ if (labelActionTitleId === "i18n.Field.localized") {
183
+ return React__namespace.cloneElement(labelAction, {
184
+ ...labelAction.props,
185
+ title: {
186
+ id: "history.content.localized",
187
+ defaultMessage: "This value is specific to this locale. If you restore this version, the content will not be replaced for other locales."
188
+ }
189
+ });
190
+ }
191
+ if (labelActionTitleId === "i18n.Field.not-localized") {
192
+ return React__namespace.cloneElement(labelAction, {
193
+ ...labelAction.props,
194
+ title: {
195
+ id: "history.content.not-localized",
196
+ defaultMessage: "This value is common to all locales. If you restore this version and save the changes, the content will be replaced for all locales."
197
+ }
198
+ });
199
+ }
200
+ return labelAction;
201
+ };
153
202
  const VersionInputRenderer = ({
154
203
  visible,
155
204
  hint: providedHint,
156
205
  shouldIgnoreRBAC = false,
206
+ labelAction,
157
207
  ...props
158
208
  }) => {
209
+ const customLabelAction = getLabelAction(labelAction);
159
210
  const { formatMessage } = reactIntl.useIntl();
160
211
  const version = useHistoryContext("VersionContent", (state) => state.selectedVersion);
161
212
  const configuration = useHistoryContext("VersionContent", (state) => state.configuration);
162
213
  const fieldSizes = hooks.useTypedSelector((state) => state["content-manager"].app.fieldSizes);
163
214
  const { id, components } = index.useDoc();
164
215
  const isFormDisabled = strapiAdmin.useForm("InputRenderer", (state) => state.disabled);
165
- const isInDynamicZone = Field.useDynamicZone("isInDynamicZone", (state) => state.isInDynamicZone);
216
+ const isInDynamicZone = Input.useDynamicZone("isInDynamicZone", (state) => state.isInDynamicZone);
166
217
  const canCreateFields = index.useDocumentRBAC("InputRenderer", (rbac) => rbac.canCreateFields);
167
218
  const canReadFields = index.useDocumentRBAC("InputRenderer", (rbac) => rbac.canReadFields);
168
219
  const canUpdateFields = index.useDocumentRBAC("InputRenderer", (rbac) => rbac.canUpdateFields);
@@ -172,10 +223,10 @@ const VersionInputRenderer = ({
172
223
  const canUserReadField = canUserAction(props.name, readableFields, props.type);
173
224
  const canUserEditField = canUserAction(props.name, editableFields, props.type);
174
225
  const fields = strapiAdmin.useStrapiApp("InputRenderer", (app) => app.fields);
175
- const { lazyComponentStore } = Field.useLazyComponents(
226
+ const { lazyComponentStore } = Input.useLazyComponents(
176
227
  attributeHasCustomFieldProperty(props.attribute) ? [props.attribute.customField] : void 0
177
228
  );
178
- const hint = Field.useFieldHint(providedHint, props.attribute);
229
+ const hint = Input.useFieldHint(providedHint, props.attribute);
179
230
  const {
180
231
  edit: { components: componentsLayout }
181
232
  } = index.useDocLayout();
@@ -183,7 +234,7 @@ const VersionInputRenderer = ({
183
234
  return null;
184
235
  }
185
236
  if (!shouldIgnoreRBAC && !canUserReadField && !isInDynamicZone) {
186
- return /* @__PURE__ */ jsxRuntime.jsx(Field.NotAllowedInput, { hint, ...props });
237
+ return /* @__PURE__ */ jsxRuntime.jsx(Input.NotAllowedInput, { hint, ...props });
187
238
  }
188
239
  const fieldIsDisabled = !canUserEditField && !isInDynamicZone || props.disabled || isFormDisabled;
189
240
  const addedAttributes = version.meta.unknownAttributes.added;
@@ -213,29 +264,46 @@ const VersionInputRenderer = ({
213
264
  if (attributeHasCustomFieldProperty(props.attribute)) {
214
265
  const CustomInput = lazyComponentStore[props.attribute.customField];
215
266
  if (CustomInput) {
216
- return /* @__PURE__ */ jsxRuntime.jsx(CustomInput, { ...props, hint, disabled: fieldIsDisabled });
267
+ return /* @__PURE__ */ jsxRuntime.jsx(
268
+ CustomInput,
269
+ {
270
+ ...props,
271
+ hint,
272
+ labelAction: customLabelAction,
273
+ disabled: fieldIsDisabled
274
+ }
275
+ );
217
276
  }
218
277
  return /* @__PURE__ */ jsxRuntime.jsx(
219
278
  strapiAdmin.InputRenderer,
220
279
  {
221
280
  ...props,
222
281
  hint,
282
+ labelAction: customLabelAction,
223
283
  type: props.attribute.customField,
224
284
  disabled: fieldIsDisabled
225
285
  }
226
286
  );
227
287
  }
228
288
  if (props.type === "media") {
229
- return /* @__PURE__ */ jsxRuntime.jsx(CustomMediaInput, { ...props, disabled: fieldIsDisabled });
289
+ return /* @__PURE__ */ jsxRuntime.jsx(CustomMediaInput, { ...props, labelAction: customLabelAction, disabled: fieldIsDisabled });
230
290
  }
231
291
  const addedInputTypes = Object.keys(fields);
232
292
  if (!attributeHasCustomFieldProperty(props.attribute) && addedInputTypes.includes(props.type)) {
233
293
  const CustomInput = fields[props.type];
234
- return /* @__PURE__ */ jsxRuntime.jsx(CustomInput, { ...props, hint, disabled: fieldIsDisabled });
294
+ return /* @__PURE__ */ jsxRuntime.jsx(
295
+ CustomInput,
296
+ {
297
+ ...props,
298
+ hint,
299
+ labelAction: customLabelAction,
300
+ disabled: fieldIsDisabled
301
+ }
302
+ );
235
303
  }
236
304
  switch (props.type) {
237
305
  case "blocks":
238
- return /* @__PURE__ */ jsxRuntime.jsx(Field.MemoizedBlocksInput, { ...props, hint, type: props.type, disabled: fieldIsDisabled });
306
+ return /* @__PURE__ */ jsxRuntime.jsx(Input.MemoizedBlocksInput, { ...props, hint, type: props.type, disabled: fieldIsDisabled });
239
307
  case "component":
240
308
  const { layout } = componentsLayout[props.attribute.component];
241
309
  const [remainingFieldsLayout] = getRemaingFieldsLayout({
@@ -245,29 +313,66 @@ const VersionInputRenderer = ({
245
313
  schemaAttributes: components[props.attribute.component].attributes
246
314
  });
247
315
  return /* @__PURE__ */ jsxRuntime.jsx(
248
- Field.MemoizedComponentInput,
316
+ Input.MemoizedComponentInput,
249
317
  {
250
318
  ...props,
251
319
  layout: [...layout, ...remainingFieldsLayout || []],
252
320
  hint,
321
+ labelAction: customLabelAction,
253
322
  disabled: fieldIsDisabled,
254
323
  children: (inputProps) => /* @__PURE__ */ jsxRuntime.jsx(VersionInputRenderer, { ...inputProps, shouldIgnoreRBAC: true })
255
324
  }
256
325
  );
257
326
  case "dynamiczone":
258
- return /* @__PURE__ */ jsxRuntime.jsx(Field.DynamicZone, { ...props, hint, disabled: fieldIsDisabled });
327
+ return /* @__PURE__ */ jsxRuntime.jsx(
328
+ Input.DynamicZone,
329
+ {
330
+ ...props,
331
+ hint,
332
+ labelAction: customLabelAction,
333
+ disabled: fieldIsDisabled,
334
+ children: (inputProps) => /* @__PURE__ */ jsxRuntime.jsx(VersionInputRenderer, { ...inputProps, shouldIgnoreRBAC: true })
335
+ }
336
+ );
259
337
  case "relation":
260
- return /* @__PURE__ */ jsxRuntime.jsx(CustomRelationInput, { ...props, hint, disabled: fieldIsDisabled });
338
+ return /* @__PURE__ */ jsxRuntime.jsx(
339
+ CustomRelationInput,
340
+ {
341
+ ...props,
342
+ hint,
343
+ labelAction: customLabelAction,
344
+ disabled: fieldIsDisabled
345
+ }
346
+ );
261
347
  case "richtext":
262
- return /* @__PURE__ */ jsxRuntime.jsx(Field.MemoizedWysiwyg, { ...props, hint, type: props.type, disabled: fieldIsDisabled });
348
+ return /* @__PURE__ */ jsxRuntime.jsx(
349
+ Input.MemoizedWysiwyg,
350
+ {
351
+ ...props,
352
+ hint,
353
+ type: props.type,
354
+ labelAction: customLabelAction,
355
+ disabled: fieldIsDisabled
356
+ }
357
+ );
263
358
  case "uid":
264
- return /* @__PURE__ */ jsxRuntime.jsx(Field.MemoizedUIDInput, { ...props, hint, type: props.type, disabled: fieldIsDisabled });
359
+ return /* @__PURE__ */ jsxRuntime.jsx(
360
+ Input.MemoizedUIDInput,
361
+ {
362
+ ...props,
363
+ hint,
364
+ type: props.type,
365
+ labelAction: customLabelAction,
366
+ disabled: fieldIsDisabled
367
+ }
368
+ );
265
369
  case "enumeration":
266
370
  return /* @__PURE__ */ jsxRuntime.jsx(
267
371
  strapiAdmin.InputRenderer,
268
372
  {
269
373
  ...props,
270
374
  hint,
375
+ labelAction: customLabelAction,
271
376
  options: props.attribute.enum.map((value) => ({ value })),
272
377
  type: props.customField ? "custom-field" : props.type,
273
378
  disabled: fieldIsDisabled
@@ -280,6 +385,7 @@ const VersionInputRenderer = ({
280
385
  {
281
386
  ...restProps,
282
387
  hint,
388
+ labelAction: customLabelAction,
283
389
  type: props.customField ? "custom-field" : props.type,
284
390
  disabled: fieldIsDisabled
285
391
  }
@@ -333,7 +439,7 @@ const FormPanel = ({ panel }) => {
333
439
  if (panel.some((row) => row.some((field) => field.type === "dynamiczone"))) {
334
440
  const [row] = panel;
335
441
  const [field] = row;
336
- return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid, { gap: 4, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.GridItem, { col: 12, s: 12, xs: 12, children: /* @__PURE__ */ jsxRuntime.jsx(VersionInputRenderer, { ...field }) }) }, field.name);
442
+ return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Root, { gap: 4, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 12, s: 12, xs: 12, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsx(VersionInputRenderer, { ...field }) }) }, field.name);
337
443
  }
338
444
  return /* @__PURE__ */ jsxRuntime.jsx(
339
445
  designSystem.Box,
@@ -346,8 +452,19 @@ const FormPanel = ({ panel }) => {
346
452
  paddingTop: 6,
347
453
  paddingBottom: 6,
348
454
  borderColor: "neutral150",
349
- children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 6, children: panel.map((row, gridRowIndex) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid, { gap: 4, children: row.map(({ size, ...field }) => {
350
- return /* @__PURE__ */ jsxRuntime.jsx(designSystem.GridItem, { col: size, s: 12, xs: 12, children: /* @__PURE__ */ jsxRuntime.jsx(VersionInputRenderer, { ...field }) }, field.name);
455
+ children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 6, children: panel.map((row, gridRowIndex) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Root, { gap: 4, children: row.map(({ size, ...field }) => {
456
+ return /* @__PURE__ */ jsxRuntime.jsx(
457
+ designSystem.Grid.Item,
458
+ {
459
+ col: size,
460
+ s: 12,
461
+ xs: 12,
462
+ direction: "column",
463
+ alignItems: "stretch",
464
+ children: /* @__PURE__ */ jsxRuntime.jsx(VersionInputRenderer, { ...field })
465
+ },
466
+ field.name
467
+ );
351
468
  }) }, gridRowIndex)) })
352
469
  }
353
470
  );
@@ -387,8 +504,8 @@ const VersionContent = () => {
387
504
  const transform = (schemaAttributes, components2 = {}) => (document) => {
388
505
  const schema2 = { attributes: schemaAttributes };
389
506
  const transformations = pipe__default.default(
390
- Field.removeFieldsThatDontExistOnSchema(schema2),
391
- Field.prepareTempKeys(schema2, components2)
507
+ index.removeFieldsThatDontExistOnSchema(schema2),
508
+ index.prepareTempKeys(schema2, components2)
392
509
  );
393
510
  return transformations(document);
394
511
  };
@@ -462,6 +579,7 @@ const VersionHeader = ({ headerId }) => {
462
579
  const [isConfirmDialogOpen, setIsConfirmDialogOpen] = React__namespace.useState(false);
463
580
  const navigate = reactRouterDom.useNavigate();
464
581
  const { formatMessage, formatDate } = reactIntl.useIntl();
582
+ const { trackUsage } = strapiAdmin.useTracking();
465
583
  const { toggleNotification } = strapiAdmin.useNotification();
466
584
  const [{ query }] = strapiAdmin.useQueryParams();
467
585
  const { collectionType, slug } = reactRouterDom.useParams();
@@ -477,14 +595,8 @@ const VersionHeader = ({ headerId }) => {
477
595
  const mainFieldValue = version.data[mainField];
478
596
  const getNextNavigation = () => {
479
597
  const pluginsQueryParams = qs.stringify({ plugins: query.plugins }, { encode: false });
480
- if (collectionType === index.COLLECTION_TYPES) {
481
- return {
482
- pathname: `/content-manager/${collectionType}/${version.contentType}/${version.relatedDocumentId}`,
483
- search: pluginsQueryParams
484
- };
485
- }
486
598
  return {
487
- pathname: `/content-manager/${collectionType}/${version.contentType}`,
599
+ pathname: "..",
488
600
  search: pluginsQueryParams
489
601
  };
490
602
  };
@@ -500,7 +612,7 @@ const VersionHeader = ({ headerId }) => {
500
612
  body: { contentType: version.contentType }
501
613
  });
502
614
  if ("data" in response) {
503
- navigate(getNextNavigation());
615
+ navigate(getNextNavigation(), { relative: "path" });
504
616
  toggleNotification({
505
617
  type: "success",
506
618
  title: formatMessage({
@@ -509,9 +621,10 @@ const VersionHeader = ({ headerId }) => {
509
621
  }),
510
622
  message: formatMessage({
511
623
  id: "content-manager.restore.success.message",
512
- defaultMessage: "The content of the restored version is not published yet."
624
+ defaultMessage: "A past version of the content was restored."
513
625
  })
514
626
  });
627
+ trackUsage("didRestoreHistoryVersion");
515
628
  }
516
629
  if ("error" in response) {
517
630
  toggleNotification({
@@ -529,7 +642,7 @@ const VersionHeader = ({ headerId }) => {
529
642
  });
530
643
  }
531
644
  };
532
- return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
645
+ return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Dialog.Root, { open: isConfirmDialogOpen, onOpenChange: setIsConfirmDialogOpen, children: [
533
646
  /* @__PURE__ */ jsxRuntime.jsx(
534
647
  strapiAdmin.Layouts.BaseHeader,
535
648
  {
@@ -541,7 +654,7 @@ const VersionHeader = ({ headerId }) => {
541
654
  hour: "numeric",
542
655
  minute: "numeric"
543
656
  }),
544
- subtitle: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "epsilon", children: formatMessage(
657
+ subtitle: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "epsilon", textColor: "neutral600", children: formatMessage(
545
658
  {
546
659
  id: "content-manager.history.version.subtitle",
547
660
  defaultMessage: "{hasLocale, select, true {{subtitle}, in {locale}} other {{subtitle}}}"
@@ -552,12 +665,22 @@ const VersionHeader = ({ headerId }) => {
552
665
  locale: version.locale?.name
553
666
  }
554
667
  ) }),
555
- navigationAction: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Link, { startIcon: /* @__PURE__ */ jsxRuntime.jsx(Icons.ArrowLeft, {}), tag: reactRouterDom.NavLink, to: getNextNavigation(), isExternal: false, children: formatMessage({
556
- id: "global.back",
557
- defaultMessage: "Back"
558
- }) }),
668
+ navigationAction: /* @__PURE__ */ jsxRuntime.jsx(
669
+ designSystem.Link,
670
+ {
671
+ startIcon: /* @__PURE__ */ jsxRuntime.jsx(Icons.ArrowLeft, {}),
672
+ tag: reactRouterDom.NavLink,
673
+ to: getNextNavigation(),
674
+ relative: "path",
675
+ isExternal: false,
676
+ children: formatMessage({
677
+ id: "global.back",
678
+ defaultMessage: "Back"
679
+ })
680
+ }
681
+ ),
559
682
  sticky: false,
560
- primaryAction: /* @__PURE__ */ jsxRuntime.jsx(
683
+ primaryAction: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Dialog.Trigger, { children: /* @__PURE__ */ jsxRuntime.jsx(
561
684
  designSystem.Button,
562
685
  {
563
686
  disabled: !allowedActions.canUpdate || isCurrentVersion,
@@ -569,16 +692,13 @@ const VersionHeader = ({ headerId }) => {
569
692
  defaultMessage: "Restore"
570
693
  })
571
694
  }
572
- )
695
+ ) })
573
696
  }
574
697
  ),
575
698
  /* @__PURE__ */ jsxRuntime.jsx(
576
699
  strapiAdmin.ConfirmDialog,
577
700
  {
578
- isOpen: isConfirmDialogOpen,
579
- onClose: () => setIsConfirmDialogOpen(false),
580
701
  onConfirm: handleRestore,
581
- icon: /* @__PURE__ */ jsxRuntime.jsx(Icons.WarningCircle, {}),
582
702
  endAction: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { variant: "secondary", onClick: handleRestore, loading: isLoading, children: formatMessage({
583
703
  id: "content-manager.history.restore.confirm.button",
584
704
  defaultMessage: "Restore"
@@ -592,6 +712,7 @@ const VersionHeader = ({ headerId }) => {
592
712
  gap: 2,
593
713
  textAlign: "center",
594
714
  children: [
715
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { justifyContent: "center", children: /* @__PURE__ */ jsxRuntime.jsx(Icons.WarningCircle, { width: "24px", height: "24px", fill: "danger600" }) }),
595
716
  /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { children: formatMessage({
596
717
  id: "content-manager.history.restore.confirm.title",
597
718
  defaultMessage: "Are you sure you want to restore this version?"
@@ -612,46 +733,10 @@ const VersionHeader = ({ headerId }) => {
612
733
  )
613
734
  ] });
614
735
  };
615
- const BlueText = (children) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "primary600", children });
736
+ const BlueText = (children) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "primary600", variant: "pi", children });
616
737
  const VersionCard = ({ version, isCurrent }) => {
617
738
  const { formatDate, formatMessage } = reactIntl.useIntl();
618
739
  const [{ query }] = strapiAdmin.useQueryParams();
619
- const statusData = (() => {
620
- switch (version.status) {
621
- case "draft":
622
- return {
623
- background: "secondary100",
624
- border: "secondary200",
625
- text: "secondary700",
626
- message: {
627
- id: "content-manager.containers.List.draft",
628
- defaultMessage: "Draft"
629
- }
630
- };
631
- case "modified":
632
- return {
633
- background: "alternative100",
634
- border: "alternative200",
635
- text: "alternative700",
636
- message: {
637
- // TODO: check the translation key once D&P v5 is done
638
- id: "content-manager.containers.List.modified",
639
- defaultMessage: "Modified"
640
- }
641
- };
642
- case "published":
643
- default:
644
- return {
645
- background: "success100",
646
- border: "success200",
647
- text: "success700",
648
- message: {
649
- id: "content-manager.containers.List.published",
650
- defaultMessage: "Published"
651
- }
652
- };
653
- }
654
- })();
655
740
  const isActive = query.id === version.id.toString();
656
741
  const author = version.createdBy && index.getDisplayName(version.createdBy);
657
742
  return /* @__PURE__ */ jsxRuntime.jsxs(
@@ -665,10 +750,7 @@ const VersionCard = ({ version, isCurrent }) => {
665
750
  borderStyle: "solid",
666
751
  borderColor: isActive ? "primary600" : "neutral200",
667
752
  color: "neutral800",
668
- paddingTop: 4,
669
- paddingBottom: 4,
670
- paddingLeft: 5,
671
- paddingRight: 5,
753
+ padding: 5,
672
754
  tag: reactRouterDom.Link,
673
755
  to: `?${qs.stringify({ ...query, id: version.id })}`,
674
756
  style: { textDecoration: "none" },
@@ -695,21 +777,7 @@ const VersionCard = ({ version, isCurrent }) => {
695
777
  }
696
778
  ) })
697
779
  ] }),
698
- version.status && /* @__PURE__ */ jsxRuntime.jsx(
699
- designSystem.Box,
700
- {
701
- background: statusData.background,
702
- borderStyle: "solid",
703
- borderWidth: "1px",
704
- borderColor: statusData.border,
705
- hasRadius: true,
706
- paddingLeft: "6px",
707
- paddingRight: "6px",
708
- paddingTop: "2px",
709
- paddingBottom: "2px",
710
- children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "pi", fontWeight: "bold", textColor: statusData.text, children: formatMessage(statusData.message) })
711
- }
712
- )
780
+ version.status && /* @__PURE__ */ jsxRuntime.jsx(index.DocumentStatus, { status: version.status, size: "XS" })
713
781
  ]
714
782
  }
715
783
  );
@@ -763,31 +831,18 @@ const VersionsList = () => {
763
831
  id: "content-manager.history.sidebar.show-newer",
764
832
  defaultMessage: "Show newer versions"
765
833
  }) }) }),
766
- /* @__PURE__ */ jsxRuntime.jsx(
767
- designSystem.Flex,
834
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", gap: 3, padding: 4, tag: "ul", alignItems: "stretch", children: versions.data.map((version, index2) => /* @__PURE__ */ jsxRuntime.jsx(
835
+ "li",
768
836
  {
769
- direction: "column",
770
- gap: 3,
771
- paddingTop: 5,
772
- paddingBottom: 5,
773
- paddingLeft: 4,
774
- paddingRight: 4,
775
- tag: "ul",
776
- alignItems: "stretch",
777
- children: versions.data.map((version, index2) => /* @__PURE__ */ jsxRuntime.jsx(
778
- "li",
779
- {
780
- "aria-label": formatMessage({
781
- id: "content-manager.history.sidebar.title.version-card.aria-label",
782
- defaultMessage: "Version card"
783
- }),
784
- children: /* @__PURE__ */ jsxRuntime.jsx(VersionCard, { version, isCurrent: page === 1 && index2 === 0 })
785
- },
786
- version.id
787
- ))
788
- }
789
- ),
790
- versions.meta.pagination.page < versions.meta.pagination.pageCount && /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { paddingBottom: 5, textAlign: "center", children: /* @__PURE__ */ jsxRuntime.jsx(PaginationButton, { page: page + 1, children: formatMessage({
837
+ "aria-label": formatMessage({
838
+ id: "content-manager.history.sidebar.title.version-card.aria-label",
839
+ defaultMessage: "Version card"
840
+ }),
841
+ children: /* @__PURE__ */ jsxRuntime.jsx(VersionCard, { version, isCurrent: page === 1 && index2 === 0 })
842
+ },
843
+ version.id
844
+ )) }),
845
+ versions.meta.pagination.page < versions.meta.pagination.pageCount && /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { paddingBottom: 4, textAlign: "center", children: /* @__PURE__ */ jsxRuntime.jsx(PaginationButton, { page: page + 1, children: formatMessage({
791
846
  id: "content-manager.history.sidebar.show-older",
792
847
  defaultMessage: "Show older versions"
793
848
  }) }) })
@@ -839,7 +894,22 @@ const HistoryPage = () => {
839
894
  return /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Loading, {});
840
895
  }
841
896
  if (!versionsResponse.isError && !versionsResponse.data?.data?.length) {
842
- return /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.NoData, {});
897
+ return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: /* @__PURE__ */ jsxRuntime.jsx(
898
+ strapiAdmin.Page.NoData,
899
+ {
900
+ action: /* @__PURE__ */ jsxRuntime.jsx(
901
+ designSystem.Link,
902
+ {
903
+ tag: reactRouterDom.NavLink,
904
+ to: `/content-manager/${collectionType}/${slug}${documentId ? `/${documentId}` : ""}`,
905
+ children: formatMessage({
906
+ id: "global.back",
907
+ defaultMessage: "Back"
908
+ })
909
+ }
910
+ )
911
+ }
912
+ ) });
843
913
  }
844
914
  if (versionsResponse.data?.data?.length && !selectedVersionId) {
845
915
  return /* @__PURE__ */ jsxRuntime.jsx(
@@ -946,4 +1016,4 @@ const ProtectedHistoryPage = () => {
946
1016
  exports.HistoryProvider = HistoryProvider;
947
1017
  exports.ProtectedHistoryPage = ProtectedHistoryPage;
948
1018
  exports.useHistoryContext = useHistoryContext;
949
- //# sourceMappingURL=History-BfX6XmZK.js.map
1019
+ //# sourceMappingURL=History-BgZ7gVuF.js.map