@strapi/content-manager 0.0.0-experimental.fdacf4285d1cada9d94ab4dcd756c5362cba1b54 → 0.0.0-next.03640aa70ec25f95e1f09348e1baadbf150bf0c5

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 (181) hide show
  1. package/dist/_chunks/CardDragPreview-C0QyJgRA.js.map +1 -1
  2. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +1 -1
  3. package/dist/_chunks/{ComponentConfigurationPage-CI7K072v.js → ComponentConfigurationPage-4TPewfw0.js} +5 -6
  4. package/dist/_chunks/{ComponentConfigurationPage-CI7K072v.js.map → ComponentConfigurationPage-4TPewfw0.js.map} +1 -1
  5. package/dist/_chunks/{ComponentConfigurationPage-CVfoYQ9p.mjs → ComponentConfigurationPage-Cw9zmV1T.mjs} +4 -4
  6. package/dist/_chunks/{ComponentConfigurationPage-CVfoYQ9p.mjs.map → ComponentConfigurationPage-Cw9zmV1T.mjs.map} +1 -1
  7. package/dist/_chunks/{ComponentIcon-BXdiCGQp.js → ComponentIcon-CRbtQEUV.js} +2 -3
  8. package/dist/_chunks/{ComponentIcon-BXdiCGQp.js.map → ComponentIcon-CRbtQEUV.js.map} +1 -1
  9. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +1 -1
  10. package/dist/_chunks/{EditConfigurationPage-Cg1Esg_N.mjs → EditConfigurationPage-B98IU2Ul.mjs} +4 -4
  11. package/dist/_chunks/{EditConfigurationPage-Cg1Esg_N.mjs.map → EditConfigurationPage-B98IU2Ul.mjs.map} +1 -1
  12. package/dist/_chunks/{EditConfigurationPage-CtnhGgIx.js → EditConfigurationPage-BfXCCaoj.js} +5 -6
  13. package/dist/_chunks/{EditConfigurationPage-CtnhGgIx.js.map → EditConfigurationPage-BfXCCaoj.js.map} +1 -1
  14. package/dist/_chunks/{EditViewPage-C_iuCG0Z.mjs → EditViewPage-D5NJMgTB.mjs} +30 -8
  15. package/dist/_chunks/EditViewPage-D5NJMgTB.mjs.map +1 -0
  16. package/dist/_chunks/{EditViewPage-MURPhGdY.js → EditViewPage-z4N1z6hE.js} +30 -9
  17. package/dist/_chunks/EditViewPage-z4N1z6hE.js.map +1 -0
  18. package/dist/_chunks/{Field-D1c7z74Q.js → Field-B35qWmBP.js} +65 -66
  19. package/dist/_chunks/Field-B35qWmBP.js.map +1 -0
  20. package/dist/_chunks/{Field-55cGR9kd.mjs → Field-CuvC32FT.mjs} +64 -64
  21. package/dist/_chunks/Field-CuvC32FT.mjs.map +1 -0
  22. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +1 -1
  23. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +1 -1
  24. package/dist/_chunks/{Form-oLrvgmvM.mjs → Form-B1DVIq72.mjs} +3 -3
  25. package/dist/_chunks/{Form-oLrvgmvM.mjs.map → Form-B1DVIq72.mjs.map} +1 -1
  26. package/dist/_chunks/{Form-D1cecnu3.js → Form-DM3cOoGs.js} +5 -6
  27. package/dist/_chunks/{Form-D1cecnu3.js.map → Form-DM3cOoGs.js.map} +1 -1
  28. package/dist/_chunks/{History-5VbTZWYl.mjs → History-Bbxb1MFm.mjs} +23 -93
  29. package/dist/_chunks/History-Bbxb1MFm.mjs.map +1 -0
  30. package/dist/_chunks/{History-DJpjbGJZ.js → History-DpsAiewY.js} +23 -94
  31. package/dist/_chunks/History-DpsAiewY.js.map +1 -0
  32. package/dist/_chunks/{ListConfigurationPage-BNs0g27c.mjs → ListConfigurationPage-Bg3gL7PO.mjs} +7 -6
  33. package/dist/_chunks/ListConfigurationPage-Bg3gL7PO.mjs.map +1 -0
  34. package/dist/_chunks/{ListConfigurationPage-DylRESaU.js → ListConfigurationPage-QgEe3A5Q.js} +7 -7
  35. package/dist/_chunks/ListConfigurationPage-QgEe3A5Q.js.map +1 -0
  36. package/dist/_chunks/{ListViewPage-MbdmfkXa.js → ListViewPage-CCiBxdYh.js} +63 -41
  37. package/dist/_chunks/ListViewPage-CCiBxdYh.js.map +1 -0
  38. package/dist/_chunks/{ListViewPage-DelIyZ5D.mjs → ListViewPage-CkEvkdm7.mjs} +62 -39
  39. package/dist/_chunks/ListViewPage-CkEvkdm7.mjs.map +1 -0
  40. package/dist/_chunks/{NoContentTypePage-CoXa1X8-.mjs → NoContentTypePage-BHlUUnaH.mjs} +2 -2
  41. package/dist/_chunks/{NoContentTypePage-CoXa1X8-.mjs.map → NoContentTypePage-BHlUUnaH.mjs.map} +1 -1
  42. package/dist/_chunks/{NoContentTypePage-BDQ1MdsC.js → NoContentTypePage-DMqJwbCS.js} +2 -2
  43. package/dist/_chunks/{NoContentTypePage-BDQ1MdsC.js.map → NoContentTypePage-DMqJwbCS.js.map} +1 -1
  44. package/dist/_chunks/{NoPermissionsPage-CnnuMd2Y.js → NoPermissionsPage-CGThcHIp.js} +2 -2
  45. package/dist/_chunks/{NoPermissionsPage-CnnuMd2Y.js.map → NoPermissionsPage-CGThcHIp.js.map} +1 -1
  46. package/dist/_chunks/{NoPermissionsPage-GgkDXRq3.mjs → NoPermissionsPage-lfWiEoK1.mjs} +2 -2
  47. package/dist/_chunks/{NoPermissionsPage-GgkDXRq3.mjs.map → NoPermissionsPage-lfWiEoK1.mjs.map} +1 -1
  48. package/dist/_chunks/Preview-BUiUISol.mjs +272 -0
  49. package/dist/_chunks/Preview-BUiUISol.mjs.map +1 -0
  50. package/dist/_chunks/Preview-DOdb2qG8.js +290 -0
  51. package/dist/_chunks/Preview-DOdb2qG8.js.map +1 -0
  52. package/dist/_chunks/{Relations-DVeWgAT4.js → Relations-Bhki9PTq.js} +47 -23
  53. package/dist/_chunks/Relations-Bhki9PTq.js.map +1 -0
  54. package/dist/_chunks/{Relations-BKnC9peY.mjs → Relations-DXV77Rwu.mjs} +47 -22
  55. package/dist/_chunks/Relations-DXV77Rwu.mjs.map +1 -0
  56. package/dist/_chunks/{en-Bm0D0IWz.js → en-BK8Xyl5I.js} +16 -4
  57. package/dist/_chunks/{en-Bm0D0IWz.js.map → en-BK8Xyl5I.js.map} +1 -1
  58. package/dist/_chunks/{en-DKV44jRb.mjs → en-Dtk_ot79.mjs} +16 -4
  59. package/dist/_chunks/{en-DKV44jRb.mjs.map → en-Dtk_ot79.mjs.map} +1 -1
  60. package/dist/_chunks/{es-EUonQTon.js → es-9K52xZIr.js} +2 -2
  61. package/dist/_chunks/{ja-CcFe8diO.js.map → es-9K52xZIr.js.map} +1 -1
  62. package/dist/_chunks/{es-CeXiYflN.mjs → es-D34tqjMw.mjs} +2 -2
  63. package/dist/_chunks/{es-CeXiYflN.mjs.map → es-D34tqjMw.mjs.map} +1 -1
  64. package/dist/_chunks/{fr-CD9VFbPM.mjs → fr--pg5jUbt.mjs} +13 -3
  65. package/dist/_chunks/{fr-CD9VFbPM.mjs.map → fr--pg5jUbt.mjs.map} +1 -1
  66. package/dist/_chunks/{fr-B7kGGg3E.js → fr-B2Kyv8Z9.js} +13 -3
  67. package/dist/_chunks/{fr-B7kGGg3E.js.map → fr-B2Kyv8Z9.js.map} +1 -1
  68. package/dist/_chunks/hooks-BAaaKPS_.js.map +1 -1
  69. package/dist/_chunks/{index-jwACjpe1.mjs → index-D5Kyqqml.mjs} +353 -184
  70. package/dist/_chunks/index-D5Kyqqml.mjs.map +1 -0
  71. package/dist/_chunks/{index-B9u01WiI.js → index-hR3DeJ4w.js} +351 -182
  72. package/dist/_chunks/index-hR3DeJ4w.js.map +1 -0
  73. package/dist/_chunks/{ja-CcFe8diO.js → ja-7sfIbjxE.js} +2 -2
  74. package/dist/_chunks/{es-EUonQTon.js.map → ja-7sfIbjxE.js.map} +1 -1
  75. package/dist/_chunks/{ja-CtsUxOvk.mjs → ja-BHqhDq4V.mjs} +2 -2
  76. package/dist/_chunks/{ja-CtsUxOvk.mjs.map → ja-BHqhDq4V.mjs.map} +1 -1
  77. package/dist/_chunks/{layout-D51YDRJV.mjs → layout-DaHFw5kD.mjs} +4 -4
  78. package/dist/_chunks/{layout-D51YDRJV.mjs.map → layout-DaHFw5kD.mjs.map} +1 -1
  79. package/dist/_chunks/{layout-DDtbDqUd.js → layout-aYm7fih0.js} +5 -6
  80. package/dist/_chunks/{layout-DDtbDqUd.js.map → layout-aYm7fih0.js.map} +1 -1
  81. package/dist/_chunks/{objects-gigeqt7s.js → objects-BcXOv6_9.js} +2 -4
  82. package/dist/_chunks/{objects-gigeqt7s.js.map → objects-BcXOv6_9.js.map} +1 -1
  83. package/dist/_chunks/{objects-mKMAmfec.mjs → objects-D6yBsdmx.mjs} +2 -4
  84. package/dist/_chunks/{objects-mKMAmfec.mjs.map → objects-D6yBsdmx.mjs.map} +1 -1
  85. package/dist/_chunks/{relations-Bgc8jKKt.mjs → relations-BaJei9O4.mjs} +6 -7
  86. package/dist/_chunks/relations-BaJei9O4.mjs.map +1 -0
  87. package/dist/_chunks/{relations-DtsF4GJw.js → relations-CgGEzgRk.js} +6 -7
  88. package/dist/_chunks/relations-CgGEzgRk.js.map +1 -0
  89. package/dist/_chunks/useDebounce-CtcjDB3L.js.map +1 -1
  90. package/dist/_chunks/useDebounce-DmuSJIF3.mjs.map +1 -1
  91. package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js → useDragAndDrop-BMtgCYzL.js} +5 -9
  92. package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js.map → useDragAndDrop-BMtgCYzL.js.map} +1 -1
  93. package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs → useDragAndDrop-DJ6jqvZN.mjs} +4 -7
  94. package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs.map → useDragAndDrop-DJ6jqvZN.mjs.map} +1 -1
  95. package/dist/admin/index.js +1 -1
  96. package/dist/admin/index.mjs +4 -4
  97. package/dist/admin/src/content-manager.d.ts +3 -2
  98. package/dist/admin/src/pages/EditView/EditViewPage.d.ts +9 -1
  99. package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +1 -1
  100. package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +2 -2
  101. package/dist/admin/src/preview/components/PreviewContent.d.ts +2 -0
  102. package/dist/admin/src/preview/components/PreviewHeader.d.ts +2 -0
  103. package/dist/admin/src/preview/components/PreviewSidePanel.d.ts +3 -0
  104. package/dist/admin/src/preview/constants.d.ts +1 -0
  105. package/dist/admin/src/preview/index.d.ts +4 -0
  106. package/dist/admin/src/preview/pages/Preview.d.ts +11 -0
  107. package/dist/admin/src/preview/routes.d.ts +3 -0
  108. package/dist/admin/src/preview/services/preview.d.ts +3 -0
  109. package/dist/admin/src/router.d.ts +1 -1
  110. package/dist/admin/src/services/documents.d.ts +0 -3
  111. package/dist/server/index.js +409 -180
  112. package/dist/server/index.js.map +1 -1
  113. package/dist/server/index.mjs +409 -179
  114. package/dist/server/index.mjs.map +1 -1
  115. package/dist/server/src/bootstrap.d.ts.map +1 -1
  116. package/dist/server/src/controllers/index.d.ts.map +1 -1
  117. package/dist/server/src/controllers/relations.d.ts.map +1 -1
  118. package/dist/server/src/controllers/utils/metadata.d.ts +15 -1
  119. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
  120. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -1
  121. package/dist/server/src/history/services/utils.d.ts +2 -3
  122. package/dist/server/src/history/services/utils.d.ts.map +1 -1
  123. package/dist/server/src/index.d.ts +4 -4
  124. package/dist/server/src/preview/constants.d.ts +2 -0
  125. package/dist/server/src/preview/constants.d.ts.map +1 -0
  126. package/dist/server/src/preview/controllers/index.d.ts +2 -0
  127. package/dist/server/src/preview/controllers/index.d.ts.map +1 -0
  128. package/dist/server/src/preview/controllers/preview.d.ts +13 -0
  129. package/dist/server/src/preview/controllers/preview.d.ts.map +1 -0
  130. package/dist/server/src/preview/controllers/validation/preview.d.ts +6 -0
  131. package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -0
  132. package/dist/server/src/preview/index.d.ts +4 -0
  133. package/dist/server/src/preview/index.d.ts.map +1 -0
  134. package/dist/server/src/preview/routes/index.d.ts +8 -0
  135. package/dist/server/src/preview/routes/index.d.ts.map +1 -0
  136. package/dist/server/src/preview/routes/preview.d.ts +4 -0
  137. package/dist/server/src/preview/routes/preview.d.ts.map +1 -0
  138. package/dist/server/src/preview/services/index.d.ts +16 -0
  139. package/dist/server/src/preview/services/index.d.ts.map +1 -0
  140. package/dist/server/src/preview/services/preview-config.d.ts +32 -0
  141. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -0
  142. package/dist/server/src/preview/services/preview.d.ts +12 -0
  143. package/dist/server/src/preview/services/preview.d.ts.map +1 -0
  144. package/dist/server/src/preview/utils.d.ts +19 -0
  145. package/dist/server/src/preview/utils.d.ts.map +1 -0
  146. package/dist/server/src/register.d.ts.map +1 -1
  147. package/dist/server/src/routes/index.d.ts.map +1 -1
  148. package/dist/server/src/services/document-manager.d.ts.map +1 -1
  149. package/dist/server/src/services/document-metadata.d.ts +8 -8
  150. package/dist/server/src/services/document-metadata.d.ts.map +1 -1
  151. package/dist/server/src/services/index.d.ts +4 -4
  152. package/dist/server/src/services/index.d.ts.map +1 -1
  153. package/dist/server/src/services/utils/configuration/index.d.ts +2 -2
  154. package/dist/server/src/services/utils/configuration/layouts.d.ts +2 -2
  155. package/dist/server/src/utils/index.d.ts +2 -0
  156. package/dist/server/src/utils/index.d.ts.map +1 -1
  157. package/dist/shared/contracts/index.d.ts +1 -0
  158. package/dist/shared/contracts/index.d.ts.map +1 -1
  159. package/dist/shared/contracts/preview.d.ts +27 -0
  160. package/dist/shared/contracts/preview.d.ts.map +1 -0
  161. package/dist/shared/index.js +4 -0
  162. package/dist/shared/index.js.map +1 -1
  163. package/dist/shared/index.mjs +4 -0
  164. package/dist/shared/index.mjs.map +1 -1
  165. package/package.json +11 -11
  166. package/dist/_chunks/EditViewPage-C_iuCG0Z.mjs.map +0 -1
  167. package/dist/_chunks/EditViewPage-MURPhGdY.js.map +0 -1
  168. package/dist/_chunks/Field-55cGR9kd.mjs.map +0 -1
  169. package/dist/_chunks/Field-D1c7z74Q.js.map +0 -1
  170. package/dist/_chunks/History-5VbTZWYl.mjs.map +0 -1
  171. package/dist/_chunks/History-DJpjbGJZ.js.map +0 -1
  172. package/dist/_chunks/ListConfigurationPage-BNs0g27c.mjs.map +0 -1
  173. package/dist/_chunks/ListConfigurationPage-DylRESaU.js.map +0 -1
  174. package/dist/_chunks/ListViewPage-DelIyZ5D.mjs.map +0 -1
  175. package/dist/_chunks/ListViewPage-MbdmfkXa.js.map +0 -1
  176. package/dist/_chunks/Relations-BKnC9peY.mjs.map +0 -1
  177. package/dist/_chunks/Relations-DVeWgAT4.js.map +0 -1
  178. package/dist/_chunks/index-B9u01WiI.js.map +0 -1
  179. package/dist/_chunks/index-jwACjpe1.mjs.map +0 -1
  180. package/dist/_chunks/relations-Bgc8jKKt.mjs.map +0 -1
  181. package/dist/_chunks/relations-DtsF4GJw.js.map +0 -1
@@ -3,23 +3,31 @@ import { jsx, Fragment, jsxs } from "react/jsx-runtime";
3
3
  import { useStrapiApp, createContext, useQueryParams, useAuth, useRBAC, Page, adminApi, translatedErrors, useNotification, useAPIErrorHandler, getYupValidationErrors, useForm, useTracking, useGuidedTour, BackButton, DescriptionComponentRenderer, useTable, Table } from "@strapi/admin/strapi-admin";
4
4
  import * as React from "react";
5
5
  import { lazy } from "react";
6
- import { Button, Menu, VisuallyHidden, Flex, Typography, Dialog, Modal, Radio, Status, Box, SingleSelect, SingleSelectOption, IconButton, Loader, Tooltip, LinkButton } from "@strapi/design-system";
6
+ import { Menu, Button, VisuallyHidden, Flex, Dialog, Modal, Typography, Radio, Status, Box, SingleSelect, SingleSelectOption, IconButton, Loader, Tooltip, LinkButton } from "@strapi/design-system";
7
+ import mapValues from "lodash/fp/mapValues";
7
8
  import { useIntl } from "react-intl";
8
9
  import { useParams, useNavigate, Navigate, useMatch, useLocation, Link, NavLink } from "react-router-dom";
10
+ import { styled } from "styled-components";
9
11
  import * as yup from "yup";
10
12
  import { ValidationError } from "yup";
13
+ import { stringify } from "qs";
11
14
  import pipe from "lodash/fp/pipe";
12
15
  import { intervalToDuration, isPast } from "date-fns";
13
- import { styled } from "styled-components";
14
- import { stringify } from "qs";
15
16
  import { createSlice, combineReducers } from "@reduxjs/toolkit";
16
- const __variableDynamicImportRuntimeHelper = (glob, path) => {
17
+ const __variableDynamicImportRuntimeHelper = (glob, path, segs) => {
17
18
  const v = glob[path];
18
19
  if (v) {
19
20
  return typeof v === "function" ? v() : Promise.resolve(v);
20
21
  }
21
22
  return new Promise((_, reject) => {
22
- (typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(reject.bind(null, new Error("Unknown variable dynamic import: " + path)));
23
+ (typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(
24
+ reject.bind(
25
+ null,
26
+ new Error(
27
+ "Unknown variable dynamic import: " + path + (path.split("/").length !== segs ? ". Note that variables only represent file names one level deep." : "")
28
+ )
29
+ )
30
+ );
23
31
  });
24
32
  };
25
33
  const PLUGIN_ID = "content-manager";
@@ -273,7 +281,7 @@ const documentApi = contentManagerApi.injectEndpoints({
273
281
  url: `/content-manager/collection-types/${model}`,
274
282
  method: "GET",
275
283
  config: {
276
- params
284
+ params: stringify(params, { encode: true })
277
285
  }
278
286
  }),
279
287
  providesTags: (result, _error, arg) => {
@@ -452,8 +460,7 @@ const {
452
460
  useUnpublishManyDocumentsMutation
453
461
  } = documentApi;
454
462
  const buildValidParams = (query) => {
455
- if (!query)
456
- return query;
463
+ if (!query) return query;
457
464
  const { plugins: _, ...validQueryParams } = {
458
465
  ...query,
459
466
  ...Object.values(query?.plugins ?? {}).reduce(
@@ -461,9 +468,6 @@ const buildValidParams = (query) => {
461
468
  {}
462
469
  )
463
470
  };
464
- if ("_q" in validQueryParams) {
465
- validQueryParams._q = encodeURIComponent(validQueryParams._q);
466
- }
467
471
  return validQueryParams;
468
472
  };
469
473
  const isBaseQueryError = (error) => {
@@ -968,9 +972,10 @@ const formatEditLayout = (data, {
968
972
  currentPanelIndex += 2;
969
973
  } else {
970
974
  if (!panels[currentPanelIndex]) {
971
- panels.push([]);
975
+ panels.push([row]);
976
+ } else {
977
+ panels[currentPanelIndex].push(row);
972
978
  }
973
- panels[currentPanelIndex].push(row);
974
979
  }
975
980
  return panels;
976
981
  }, []);
@@ -1228,9 +1233,6 @@ const useContentManagerContext = () => {
1228
1233
  };
1229
1234
  };
1230
1235
  const prefixPluginTranslations = (trad, pluginId) => {
1231
- if (!pluginId) {
1232
- throw new TypeError("pluginId can't be empty");
1233
- }
1234
1236
  return Object.keys(trad).reduce((acc, current) => {
1235
1237
  acc[`${pluginId}.${current}`] = trad[current];
1236
1238
  return acc;
@@ -1664,10 +1666,10 @@ const useDocumentActions = () => {
1664
1666
  update
1665
1667
  };
1666
1668
  };
1667
- const ProtectedHistoryPage = lazy(
1668
- () => import("./History-5VbTZWYl.mjs").then((mod) => ({ default: mod.ProtectedHistoryPage }))
1669
+ const ProtectedHistoryPage = React.lazy(
1670
+ () => import("./History-Bbxb1MFm.mjs").then((mod) => ({ default: mod.ProtectedHistoryPage }))
1669
1671
  );
1670
- const routes$1 = [
1672
+ const routes$2 = [
1671
1673
  {
1672
1674
  path: ":collectionType/:slug/:id/history",
1673
1675
  Component: ProtectedHistoryPage
@@ -1677,32 +1679,45 @@ const routes$1 = [
1677
1679
  Component: ProtectedHistoryPage
1678
1680
  }
1679
1681
  ];
1682
+ const ProtectedPreviewPage = React.lazy(
1683
+ () => import("./Preview-BUiUISol.mjs").then((mod) => ({ default: mod.ProtectedPreviewPage }))
1684
+ );
1685
+ const routes$1 = [
1686
+ {
1687
+ path: ":collectionType/:slug/:id/preview",
1688
+ Component: ProtectedPreviewPage
1689
+ },
1690
+ {
1691
+ path: ":collectionType/:slug/preview",
1692
+ Component: ProtectedPreviewPage
1693
+ }
1694
+ ];
1680
1695
  const ProtectedEditViewPage = lazy(
1681
- () => import("./EditViewPage-C_iuCG0Z.mjs").then((mod) => ({ default: mod.ProtectedEditViewPage }))
1696
+ () => import("./EditViewPage-D5NJMgTB.mjs").then((mod) => ({ default: mod.ProtectedEditViewPage }))
1682
1697
  );
1683
1698
  const ProtectedListViewPage = lazy(
1684
- () => import("./ListViewPage-DelIyZ5D.mjs").then((mod) => ({ default: mod.ProtectedListViewPage }))
1699
+ () => import("./ListViewPage-CkEvkdm7.mjs").then((mod) => ({ default: mod.ProtectedListViewPage }))
1685
1700
  );
1686
1701
  const ProtectedListConfiguration = lazy(
1687
- () => import("./ListConfigurationPage-BNs0g27c.mjs").then((mod) => ({
1702
+ () => import("./ListConfigurationPage-Bg3gL7PO.mjs").then((mod) => ({
1688
1703
  default: mod.ProtectedListConfiguration
1689
1704
  }))
1690
1705
  );
1691
1706
  const ProtectedEditConfigurationPage = lazy(
1692
- () => import("./EditConfigurationPage-Cg1Esg_N.mjs").then((mod) => ({
1707
+ () => import("./EditConfigurationPage-B98IU2Ul.mjs").then((mod) => ({
1693
1708
  default: mod.ProtectedEditConfigurationPage
1694
1709
  }))
1695
1710
  );
1696
1711
  const ProtectedComponentConfigurationPage = lazy(
1697
- () => import("./ComponentConfigurationPage-CVfoYQ9p.mjs").then((mod) => ({
1712
+ () => import("./ComponentConfigurationPage-Cw9zmV1T.mjs").then((mod) => ({
1698
1713
  default: mod.ProtectedComponentConfigurationPage
1699
1714
  }))
1700
1715
  );
1701
1716
  const NoPermissions = lazy(
1702
- () => import("./NoPermissionsPage-GgkDXRq3.mjs").then((mod) => ({ default: mod.NoPermissions }))
1717
+ () => import("./NoPermissionsPage-lfWiEoK1.mjs").then((mod) => ({ default: mod.NoPermissions }))
1703
1718
  );
1704
1719
  const NoContentType = lazy(
1705
- () => import("./NoContentTypePage-CoXa1X8-.mjs").then((mod) => ({ default: mod.NoContentType }))
1720
+ () => import("./NoContentTypePage-BHlUUnaH.mjs").then((mod) => ({ default: mod.NoContentType }))
1706
1721
  );
1707
1722
  const CollectionTypePages = () => {
1708
1723
  const { collectionType } = useParams();
@@ -1714,7 +1729,7 @@ const CollectionTypePages = () => {
1714
1729
  const CLONE_RELATIVE_PATH = ":collectionType/:slug/clone/:origin";
1715
1730
  const CLONE_PATH = `/content-manager/${CLONE_RELATIVE_PATH}`;
1716
1731
  const LIST_RELATIVE_PATH = ":collectionType/:slug";
1717
- const LIST_PATH = `/content-manager/${LIST_RELATIVE_PATH}`;
1732
+ const LIST_PATH = `/content-manager/collection-types/:slug`;
1718
1733
  const routes = [
1719
1734
  {
1720
1735
  path: LIST_RELATIVE_PATH,
@@ -1748,6 +1763,7 @@ const routes = [
1748
1763
  path: "no-content-types",
1749
1764
  Component: NoContentType
1750
1765
  },
1766
+ ...routes$2,
1751
1767
  ...routes$1
1752
1768
  ];
1753
1769
  const DocumentActions = ({ actions: actions2 }) => {
@@ -1846,6 +1862,11 @@ const DocumentActionButton = (action) => {
1846
1862
  ) : null
1847
1863
  ] });
1848
1864
  };
1865
+ const MenuItem = styled(Menu.Item)`
1866
+ &:hover {
1867
+ background: ${({ theme, isVariantDanger, isDisabled }) => isVariantDanger && !isDisabled ? theme.colors.danger100 : "neutral"};
1868
+ }
1869
+ `;
1849
1870
  const DocumentActionsMenu = ({
1850
1871
  actions: actions2,
1851
1872
  children,
@@ -1904,48 +1925,32 @@ const DocumentActionsMenu = ({
1904
1925
  /* @__PURE__ */ jsxs(Menu.Content, { maxHeight: void 0, popoverPlacement: "bottom-end", children: [
1905
1926
  actions2.map((action) => {
1906
1927
  return /* @__PURE__ */ jsx(
1907
- Menu.Item,
1928
+ MenuItem,
1908
1929
  {
1909
1930
  disabled: action.disabled,
1910
1931
  onSelect: handleClick(action),
1911
1932
  display: "block",
1912
- children: /* @__PURE__ */ jsxs(Flex, { justifyContent: "space-between", gap: 4, children: [
1913
- /* @__PURE__ */ jsxs(
1914
- Flex,
1915
- {
1916
- color: !action.disabled ? convertActionVariantToColor(action.variant) : "inherit",
1917
- gap: 2,
1918
- tag: "span",
1919
- children: [
1920
- /* @__PURE__ */ jsx(
1921
- Flex,
1922
- {
1923
- tag: "span",
1924
- color: !action.disabled ? convertActionVariantToIconColor(action.variant) : "inherit",
1925
- children: action.icon
1926
- }
1927
- ),
1928
- action.label
1929
- ]
1930
- }
1931
- ),
1932
- action.id.startsWith("HistoryAction") && /* @__PURE__ */ jsx(
1933
- Flex,
1934
- {
1935
- alignItems: "center",
1936
- background: "alternative100",
1937
- borderStyle: "solid",
1938
- borderColor: "alternative200",
1939
- borderWidth: "1px",
1940
- height: 5,
1941
- paddingLeft: 2,
1942
- paddingRight: 2,
1943
- hasRadius: true,
1944
- color: "alternative600",
1945
- children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", fontWeight: "bold", lineHeight: 1, children: formatMessage({ id: "global.new", defaultMessage: "New" }) })
1946
- }
1947
- )
1948
- ] })
1933
+ isVariantDanger: action.variant === "danger",
1934
+ isDisabled: action.disabled,
1935
+ children: /* @__PURE__ */ jsx(Flex, { justifyContent: "space-between", gap: 4, children: /* @__PURE__ */ jsxs(
1936
+ Flex,
1937
+ {
1938
+ color: !action.disabled ? convertActionVariantToColor(action.variant) : "inherit",
1939
+ gap: 2,
1940
+ tag: "span",
1941
+ children: [
1942
+ /* @__PURE__ */ jsx(
1943
+ Flex,
1944
+ {
1945
+ tag: "span",
1946
+ color: !action.disabled ? convertActionVariantToIconColor(action.variant) : "inherit",
1947
+ children: action.icon
1948
+ }
1949
+ ),
1950
+ action.label
1951
+ ]
1952
+ }
1953
+ ) })
1949
1954
  },
1950
1955
  action.id
1951
1956
  );
@@ -2056,6 +2061,18 @@ const DocumentActionModal = ({
2056
2061
  typeof Footer === "function" ? /* @__PURE__ */ jsx(Footer, { onClose: handleClose }) : Footer
2057
2062
  ] }) });
2058
2063
  };
2064
+ const transformData = (data) => {
2065
+ if (Array.isArray(data)) {
2066
+ return data.map(transformData);
2067
+ }
2068
+ if (typeof data === "object" && data !== null) {
2069
+ if ("apiData" in data) {
2070
+ return data.apiData;
2071
+ }
2072
+ return mapValues(transformData)(data);
2073
+ }
2074
+ return data;
2075
+ };
2059
2076
  const PublishAction$1 = ({
2060
2077
  activeTab,
2061
2078
  documentId,
@@ -2070,6 +2087,7 @@ const PublishAction$1 = ({
2070
2087
  const { _unstableFormatValidationErrors: formatValidationErrors } = useAPIErrorHandler();
2071
2088
  const isListView = useMatch(LIST_PATH) !== null;
2072
2089
  const isCloning = useMatch(CLONE_PATH) !== null;
2090
+ const { id } = useParams();
2073
2091
  const { formatMessage } = useIntl();
2074
2092
  const canPublish = useDocumentRBAC("PublishAction", ({ canPublish: canPublish2 }) => canPublish2);
2075
2093
  const { publish } = useDocumentActions();
@@ -2169,13 +2187,15 @@ const PublishAction$1 = ({
2169
2187
  documentId,
2170
2188
  params
2171
2189
  },
2172
- formValues
2190
+ transformData(formValues)
2173
2191
  );
2174
2192
  if ("data" in res && collectionType !== SINGLE_TYPES) {
2175
- navigate({
2176
- pathname: `../${collectionType}/${model}/${res.data.documentId}`,
2177
- search: rawQuery
2178
- });
2193
+ if (id === "create") {
2194
+ navigate({
2195
+ pathname: `../${collectionType}/${model}/${res.data.documentId}`,
2196
+ search: rawQuery
2197
+ });
2198
+ }
2179
2199
  } else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
2180
2200
  setErrors(formatValidationErrors(res.error));
2181
2201
  }
@@ -2228,6 +2248,7 @@ const PublishAction$1 = ({
2228
2248
  };
2229
2249
  };
2230
2250
  PublishAction$1.type = "publish";
2251
+ PublishAction$1.position = "panel";
2231
2252
  const UpdateAction = ({
2232
2253
  activeTab,
2233
2254
  documentId,
@@ -2250,96 +2271,134 @@ const UpdateAction = ({
2250
2271
  const validate = useForm("UpdateAction", (state) => state.validate);
2251
2272
  const setErrors = useForm("UpdateAction", (state) => state.setErrors);
2252
2273
  const resetForm = useForm("PublishAction", ({ resetForm: resetForm2 }) => resetForm2);
2253
- return {
2254
- /**
2255
- * Disabled when:
2256
- * - the form is submitting
2257
- * - the document is not modified & we're not cloning (you can save a clone entity straight away)
2258
- * - the active tab is the published tab
2259
- */
2260
- disabled: isSubmitting || !modified && !isCloning || activeTab === "published",
2261
- label: formatMessage({
2262
- id: "content-manager.containers.Edit.save",
2263
- defaultMessage: "Save"
2264
- }),
2265
- onClick: async () => {
2266
- setSubmitting(true);
2267
- try {
2268
- const { errors } = await validate(true, {
2269
- status: "draft"
2274
+ const handleUpdate = React.useCallback(async () => {
2275
+ setSubmitting(true);
2276
+ try {
2277
+ if (!modified) {
2278
+ return;
2279
+ }
2280
+ const { errors } = await validate(true, {
2281
+ status: "draft"
2282
+ });
2283
+ if (errors) {
2284
+ toggleNotification({
2285
+ type: "danger",
2286
+ message: formatMessage({
2287
+ id: "content-manager.validation.error",
2288
+ defaultMessage: "There are validation errors in your document. Please fix them before saving."
2289
+ })
2270
2290
  });
2271
- if (errors) {
2272
- toggleNotification({
2273
- type: "danger",
2274
- message: formatMessage({
2275
- id: "content-manager.validation.error",
2276
- defaultMessage: "There are validation errors in your document. Please fix them before saving."
2277
- })
2278
- });
2279
- return;
2280
- }
2281
- if (isCloning) {
2282
- const res = await clone(
2283
- {
2284
- model,
2285
- documentId: cloneMatch.params.origin,
2286
- params
2287
- },
2288
- document
2289
- );
2290
- if ("data" in res) {
2291
- navigate(
2292
- {
2293
- pathname: `../${res.data.documentId}`,
2294
- search: rawQuery
2295
- },
2296
- { relative: "path" }
2297
- );
2298
- } else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
2299
- setErrors(formatValidationErrors(res.error));
2300
- }
2301
- } else if (documentId || collectionType === SINGLE_TYPES) {
2302
- const res = await update(
2291
+ return;
2292
+ }
2293
+ if (isCloning) {
2294
+ const res = await clone(
2295
+ {
2296
+ model,
2297
+ documentId: cloneMatch.params.origin,
2298
+ params
2299
+ },
2300
+ transformData(document)
2301
+ );
2302
+ if ("data" in res) {
2303
+ navigate(
2303
2304
  {
2304
- collectionType,
2305
- model,
2306
- documentId,
2307
- params
2305
+ pathname: `../${res.data.documentId}`,
2306
+ search: rawQuery
2308
2307
  },
2309
- document
2308
+ { relative: "path" }
2310
2309
  );
2311
- if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
2312
- setErrors(formatValidationErrors(res.error));
2313
- } else {
2314
- resetForm();
2315
- }
2310
+ } else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
2311
+ setErrors(formatValidationErrors(res.error));
2312
+ }
2313
+ } else if (documentId || collectionType === SINGLE_TYPES) {
2314
+ const res = await update(
2315
+ {
2316
+ collectionType,
2317
+ model,
2318
+ documentId,
2319
+ params
2320
+ },
2321
+ transformData(document)
2322
+ );
2323
+ if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
2324
+ setErrors(formatValidationErrors(res.error));
2316
2325
  } else {
2317
- const res = await create(
2326
+ resetForm();
2327
+ }
2328
+ } else {
2329
+ const res = await create(
2330
+ {
2331
+ model,
2332
+ params
2333
+ },
2334
+ transformData(document)
2335
+ );
2336
+ if ("data" in res && collectionType !== SINGLE_TYPES) {
2337
+ navigate(
2318
2338
  {
2319
- model,
2320
- params
2339
+ pathname: `../${res.data.documentId}`,
2340
+ search: rawQuery
2321
2341
  },
2322
- document
2342
+ { replace: true, relative: "path" }
2323
2343
  );
2324
- if ("data" in res && collectionType !== SINGLE_TYPES) {
2325
- navigate(
2326
- {
2327
- pathname: `../${res.data.documentId}`,
2328
- search: rawQuery
2329
- },
2330
- { replace: true, relative: "path" }
2331
- );
2332
- } else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
2333
- setErrors(formatValidationErrors(res.error));
2334
- }
2344
+ } else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
2345
+ setErrors(formatValidationErrors(res.error));
2335
2346
  }
2336
- } finally {
2337
- setSubmitting(false);
2338
2347
  }
2348
+ } finally {
2349
+ setSubmitting(false);
2339
2350
  }
2351
+ }, [
2352
+ clone,
2353
+ cloneMatch?.params.origin,
2354
+ collectionType,
2355
+ create,
2356
+ document,
2357
+ documentId,
2358
+ formatMessage,
2359
+ formatValidationErrors,
2360
+ isCloning,
2361
+ model,
2362
+ modified,
2363
+ navigate,
2364
+ params,
2365
+ rawQuery,
2366
+ resetForm,
2367
+ setErrors,
2368
+ setSubmitting,
2369
+ toggleNotification,
2370
+ update,
2371
+ validate
2372
+ ]);
2373
+ React.useEffect(() => {
2374
+ const handleKeyDown = (e) => {
2375
+ if (e.key === "Enter" && (e.metaKey || e.ctrlKey)) {
2376
+ e.preventDefault();
2377
+ handleUpdate();
2378
+ }
2379
+ };
2380
+ window.addEventListener("keydown", handleKeyDown);
2381
+ return () => {
2382
+ window.removeEventListener("keydown", handleKeyDown);
2383
+ };
2384
+ }, [handleUpdate]);
2385
+ return {
2386
+ /**
2387
+ * Disabled when:
2388
+ * - the form is submitting
2389
+ * - the document is not modified & we're not cloning (you can save a clone entity straight away)
2390
+ * - the active tab is the published tab
2391
+ */
2392
+ disabled: isSubmitting || !modified && !isCloning || activeTab === "published",
2393
+ label: formatMessage({
2394
+ id: "global.save",
2395
+ defaultMessage: "Save"
2396
+ }),
2397
+ onClick: handleUpdate
2340
2398
  };
2341
2399
  };
2342
2400
  UpdateAction.type = "update";
2401
+ UpdateAction.position = "panel";
2343
2402
  const UNPUBLISH_DRAFT_OPTIONS = {
2344
2403
  KEEP: "keep",
2345
2404
  DISCARD: "discard"
@@ -2462,6 +2521,7 @@ const UnpublishAction$1 = ({
2462
2521
  };
2463
2522
  };
2464
2523
  UnpublishAction$1.type = "unpublish";
2524
+ UnpublishAction$1.position = "panel";
2465
2525
  const DiscardAction = ({
2466
2526
  activeTab,
2467
2527
  documentId,
@@ -2512,6 +2572,7 @@ const DiscardAction = ({
2512
2572
  };
2513
2573
  };
2514
2574
  DiscardAction.type = "discard";
2575
+ DiscardAction.position = "panel";
2515
2576
  const DEFAULT_ACTIONS = [PublishAction$1, UpdateAction, UnpublishAction$1, DiscardAction];
2516
2577
  const intervals = ["years", "months", "days", "hours", "minutes", "seconds"];
2517
2578
  const RelativeTime = React.forwardRef(
@@ -2524,7 +2585,7 @@ const RelativeTime = React.forwardRef(
2524
2585
  });
2525
2586
  const unit = intervals.find((intervalUnit) => {
2526
2587
  return interval[intervalUnit] > 0 && Object.keys(interval).includes(intervalUnit);
2527
- });
2588
+ }) ?? "seconds";
2528
2589
  const relativeTime = isPast(timestamp) ? -interval[unit] : interval[unit];
2529
2590
  const customInterval = customIntervals.find(
2530
2591
  (custom) => interval[custom.unit] < custom.threshold
@@ -2558,19 +2619,29 @@ const getDisplayName = ({
2558
2619
  return email ?? "";
2559
2620
  };
2560
2621
  const capitalise = (str) => str.charAt(0).toUpperCase() + str.slice(1);
2561
- const DocumentStatus = ({ status = "draft", ...restProps }) => {
2622
+ const DocumentStatus = ({ status = "draft", size = "S", ...restProps }) => {
2562
2623
  const statusVariant = status === "draft" ? "secondary" : status === "published" ? "success" : "alternative";
2563
- return /* @__PURE__ */ jsx(Status, { ...restProps, showBullet: false, size: "S", variant: statusVariant, children: /* @__PURE__ */ jsx(Typography, { tag: "span", variant: "omega", fontWeight: "bold", children: capitalise(status) }) });
2624
+ const { formatMessage } = useIntl();
2625
+ return /* @__PURE__ */ jsx(Status, { ...restProps, size, variant: statusVariant, children: /* @__PURE__ */ jsx(Typography, { tag: "span", variant: "omega", fontWeight: "bold", children: formatMessage({
2626
+ id: `content-manager.containers.List.${status}`,
2627
+ defaultMessage: capitalise(status)
2628
+ }) }) });
2564
2629
  };
2565
2630
  const Header = ({ isCreating, status, title: documentTitle = "Untitled" }) => {
2566
2631
  const { formatMessage } = useIntl();
2567
2632
  const isCloning = useMatch(CLONE_PATH) !== null;
2633
+ const params = useParams();
2568
2634
  const title = isCreating ? formatMessage({
2569
2635
  id: "content-manager.containers.edit.title.new",
2570
2636
  defaultMessage: "Create an entry"
2571
2637
  }) : documentTitle;
2572
2638
  return /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "flex-start", paddingTop: 6, paddingBottom: 4, gap: 2, children: [
2573
- /* @__PURE__ */ jsx(BackButton, {}),
2639
+ /* @__PURE__ */ jsx(
2640
+ BackButton,
2641
+ {
2642
+ fallback: params.collectionType === SINGLE_TYPES ? void 0 : `../${COLLECTION_TYPES}/${params.slug}`
2643
+ }
2644
+ ),
2574
2645
  /* @__PURE__ */ jsxs(Flex, { width: "100%", justifyContent: "space-between", gap: "80px", alignItems: "flex-start", children: [
2575
2646
  /* @__PURE__ */ jsx(Typography, { variant: "alpha", tag: "h1", children: title }),
2576
2647
  /* @__PURE__ */ jsx(HeaderToolbar, {})
@@ -2621,7 +2692,7 @@ const HeaderToolbar = () => {
2621
2692
  meta: isCloning ? void 0 : meta,
2622
2693
  collectionType
2623
2694
  },
2624
- descriptions: plugins["content-manager"].apis.getDocumentActions(),
2695
+ descriptions: plugins["content-manager"].apis.getDocumentActions("header"),
2625
2696
  children: (actions2) => {
2626
2697
  const headerActions = actions2.filter((action) => {
2627
2698
  const positions = Array.isArray(action.position) ? action.position : [action.position];
@@ -2829,6 +2900,7 @@ const ConfigureTheViewAction = ({ collectionType, model }) => {
2829
2900
  };
2830
2901
  };
2831
2902
  ConfigureTheViewAction.type = "configure-the-view";
2903
+ ConfigureTheViewAction.position = "header";
2832
2904
  const EditTheModelAction = ({ model }) => {
2833
2905
  const navigate = useNavigate();
2834
2906
  const { formatMessage } = useIntl();
@@ -2845,6 +2917,7 @@ const EditTheModelAction = ({ model }) => {
2845
2917
  };
2846
2918
  };
2847
2919
  EditTheModelAction.type = "edit-the-model";
2920
+ EditTheModelAction.position = "header";
2848
2921
  const DeleteAction$1 = ({ documentId, model, collectionType, document }) => {
2849
2922
  const navigate = useNavigate();
2850
2923
  const { formatMessage } = useIntl();
@@ -2918,6 +2991,7 @@ const DeleteAction$1 = ({ documentId, model, collectionType, document }) => {
2918
2991
  };
2919
2992
  };
2920
2993
  DeleteAction$1.type = "delete";
2994
+ DeleteAction$1.position = ["header", "table-row"];
2921
2995
  const DEFAULT_HEADER_ACTIONS = [EditTheModelAction, ConfigureTheViewAction, DeleteAction$1];
2922
2996
  const Panels = () => {
2923
2997
  const isCloning = useMatch(CLONE_PATH) !== null;
@@ -2980,7 +3054,7 @@ const ActionsPanelContent = () => {
2980
3054
  DescriptionComponentRenderer,
2981
3055
  {
2982
3056
  props,
2983
- descriptions: plugins["content-manager"].apis.getDocumentActions(),
3057
+ descriptions: plugins["content-manager"].apis.getDocumentActions("panel"),
2984
3058
  children: (actions2) => /* @__PURE__ */ jsx(DocumentActions, { actions: actions2 })
2985
3059
  }
2986
3060
  ),
@@ -3007,7 +3081,7 @@ const Panel = React.forwardRef(({ children, title }, ref) => {
3007
3081
  justifyContent: "stretch",
3008
3082
  alignItems: "flex-start",
3009
3083
  children: [
3010
- /* @__PURE__ */ jsx(Typography, { tag: "h2", variant: "sigma", textTransform: "uppercase", children: title }),
3084
+ /* @__PURE__ */ jsx(Typography, { tag: "h2", variant: "sigma", textTransform: "uppercase", textColor: "neutral600", children: title }),
3011
3085
  children
3012
3086
  ]
3013
3087
  }
@@ -3257,18 +3331,10 @@ const SelectedEntriesTableContent = ({
3257
3331
  search: row.locale && `?plugins[i18n][locale]=${row.locale}`
3258
3332
  },
3259
3333
  state: { from: pathname },
3260
- label: formatMessage(
3261
- { id: "app.component.HelperPluginTable.edit", defaultMessage: "Edit {target}" },
3262
- {
3263
- target: formatMessage(
3264
- {
3265
- id: "content-manager.components.ListViewHelperPluginTable.row-line",
3266
- defaultMessage: "item line {number}"
3267
- },
3268
- { number: index2 + 1 }
3269
- )
3270
- }
3271
- ),
3334
+ label: formatMessage({
3335
+ id: "content-manager.bulk-publish.edit",
3336
+ defaultMessage: "Edit"
3337
+ }),
3272
3338
  target: "_blank",
3273
3339
  marginLeft: "auto",
3274
3340
  variant: "ghost",
@@ -3442,8 +3508,7 @@ const PublishAction = ({ documents, model }) => {
3442
3508
  const refetchList = () => {
3443
3509
  contentManagerApi.util.invalidateTags([{ type: "Document", id: `${model}_LIST` }]);
3444
3510
  };
3445
- if (!showPublishButton)
3446
- return null;
3511
+ if (!showPublishButton) return null;
3447
3512
  return {
3448
3513
  actionType: "publish",
3449
3514
  variant: "tertiary",
@@ -3511,8 +3576,7 @@ const DeleteAction = ({ documents, model }) => {
3511
3576
  selectRow([]);
3512
3577
  }
3513
3578
  };
3514
- if (!hasDeletePermission)
3515
- return null;
3579
+ if (!hasDeletePermission) return null;
3516
3580
  return {
3517
3581
  variant: "danger-light",
3518
3582
  label: formatMessage({ id: "global.delete", defaultMessage: "Delete" }),
@@ -3561,8 +3625,7 @@ const UnpublishAction = ({ documents, model }) => {
3561
3625
  }
3562
3626
  };
3563
3627
  const showUnpublishButton = hasDraftAndPublishEnabled && hasPublishPermission && documents.some((entry) => entry.status === "published" || entry.status === "modified");
3564
- if (!showUnpublishButton)
3565
- return null;
3628
+ if (!showUnpublishButton) return null;
3566
3629
  return {
3567
3630
  variant: "tertiary",
3568
3631
  label: formatMessage({ id: "app.utils.unpublish", defaultMessage: "Unpublish" }),
@@ -3667,7 +3730,7 @@ const TableActions = ({ document }) => {
3667
3730
  DescriptionComponentRenderer,
3668
3731
  {
3669
3732
  props,
3670
- descriptions: plugins["content-manager"].apis.getDocumentActions().filter((action) => action.name !== "PublishAction"),
3733
+ descriptions: plugins["content-manager"].apis.getDocumentActions("table-row").filter((action) => action.name !== "PublishAction"),
3671
3734
  children: (actions2) => {
3672
3735
  const tableRowActions = actions2.filter((action) => {
3673
3736
  const positions = Array.isArray(action.position) ? action.position : [action.position];
@@ -3726,6 +3789,7 @@ const EditAction = ({ documentId }) => {
3726
3789
  };
3727
3790
  };
3728
3791
  EditAction.type = "edit";
3792
+ EditAction.position = "table-row";
3729
3793
  const StyledPencil = styled(Pencil)`
3730
3794
  path {
3731
3795
  fill: currentColor;
@@ -3802,6 +3866,7 @@ const CloneAction = ({ model, documentId }) => {
3802
3866
  };
3803
3867
  };
3804
3868
  CloneAction.type = "clone";
3869
+ CloneAction.position = "table-row";
3805
3870
  const StyledDuplicate = styled(Duplicate)`
3806
3871
  path {
3807
3872
  fill: currentColor;
@@ -3888,7 +3953,14 @@ class ContentManagerPlugin {
3888
3953
  addDocumentHeaderAction: this.addDocumentHeaderAction.bind(this),
3889
3954
  addEditViewSidePanel: this.addEditViewSidePanel.bind(this),
3890
3955
  getBulkActions: () => this.bulkActions,
3891
- getDocumentActions: () => this.documentActions,
3956
+ getDocumentActions: (position) => {
3957
+ if (position) {
3958
+ return this.documentActions.filter(
3959
+ (action) => action.position == void 0 || [action.position].flat().includes(position)
3960
+ );
3961
+ }
3962
+ return this.documentActions;
3963
+ },
3892
3964
  getEditViewSidePanels: () => this.editViewSidePanels,
3893
3965
  getHeaderActions: () => this.headerActions
3894
3966
  }
@@ -3898,10 +3970,8 @@ class ContentManagerPlugin {
3898
3970
  const getPrintableType = (value) => {
3899
3971
  const nativeType = typeof value;
3900
3972
  if (nativeType === "object") {
3901
- if (value === null)
3902
- return "null";
3903
- if (Array.isArray(value))
3904
- return "array";
3973
+ if (value === null) return "null";
3974
+ if (Array.isArray(value)) return "array";
3905
3975
  if (value instanceof Object && value.constructor.name !== "Object") {
3906
3976
  return value.constructor.name;
3907
3977
  }
@@ -3912,17 +3982,27 @@ const HistoryAction = ({ model, document }) => {
3912
3982
  const { formatMessage } = useIntl();
3913
3983
  const [{ query }] = useQueryParams();
3914
3984
  const navigate = useNavigate();
3985
+ const { trackUsage } = useTracking();
3986
+ const { pathname } = useLocation();
3915
3987
  const pluginsQueryParams = stringify({ plugins: query.plugins }, { encode: false });
3916
3988
  if (!window.strapi.features.isEnabled("cms-content-history")) {
3917
3989
  return null;
3918
3990
  }
3991
+ const handleOnClick = () => {
3992
+ const destination = { pathname: "history", search: pluginsQueryParams };
3993
+ trackUsage("willNavigate", {
3994
+ from: pathname,
3995
+ to: `${pathname}/${destination.pathname}`
3996
+ });
3997
+ navigate(destination);
3998
+ };
3919
3999
  return {
3920
4000
  icon: /* @__PURE__ */ jsx(ClockCounterClockwise, {}),
3921
4001
  label: formatMessage({
3922
4002
  id: "content-manager.history.document-action",
3923
4003
  defaultMessage: "Content History"
3924
4004
  }),
3925
- onClick: () => navigate({ pathname: "history", search: pluginsQueryParams }),
4005
+ onClick: handleOnClick,
3926
4006
  disabled: (
3927
4007
  /**
3928
4008
  * The user is creating a new document.
@@ -3944,6 +4024,7 @@ const HistoryAction = ({ model, document }) => {
3944
4024
  };
3945
4025
  };
3946
4026
  HistoryAction.type = "history";
4027
+ HistoryAction.position = "header";
3947
4028
  const historyAdmin = {
3948
4029
  bootstrap(app) {
3949
4030
  const { addDocumentAction } = app.getPlugin("content-manager").apis;
@@ -3990,6 +4071,90 @@ const { setInitialData } = actions;
3990
4071
  const reducer = combineReducers({
3991
4072
  app: reducer$1
3992
4073
  });
4074
+ const previewApi = contentManagerApi.injectEndpoints({
4075
+ endpoints: (builder) => ({
4076
+ getPreviewUrl: builder.query({
4077
+ query({ query, params }) {
4078
+ return {
4079
+ url: `/content-manager/preview/url/${params.contentType}`,
4080
+ method: "GET",
4081
+ config: {
4082
+ params: query
4083
+ }
4084
+ };
4085
+ }
4086
+ })
4087
+ })
4088
+ });
4089
+ const { useGetPreviewUrlQuery } = previewApi;
4090
+ const ConditionalTooltip = ({ isShown, label, children }) => {
4091
+ if (isShown) {
4092
+ return /* @__PURE__ */ jsx(Tooltip, { label, children });
4093
+ }
4094
+ return children;
4095
+ };
4096
+ const PreviewSidePanel = ({ model, documentId, document }) => {
4097
+ const { formatMessage } = useIntl();
4098
+ const { trackUsage } = useTracking();
4099
+ const { pathname } = useLocation();
4100
+ const [{ query }] = useQueryParams();
4101
+ const isModified = useForm("PreviewSidePanel", (state) => state.modified);
4102
+ const { data, error } = useGetPreviewUrlQuery({
4103
+ params: {
4104
+ contentType: model
4105
+ },
4106
+ query: {
4107
+ documentId,
4108
+ locale: document?.locale,
4109
+ status: document?.status
4110
+ }
4111
+ });
4112
+ if (!data?.data?.url || error) {
4113
+ return null;
4114
+ }
4115
+ const trackNavigation = () => {
4116
+ const destinationPathname = pathname.replace(/\/$/, "") + "/preview";
4117
+ trackUsage("willNavigate", { from: pathname, to: destinationPathname });
4118
+ };
4119
+ return {
4120
+ title: formatMessage({ id: "content-manager.preview.panel.title", defaultMessage: "Preview" }),
4121
+ content: /* @__PURE__ */ jsx(Flex, { gap: 2, width: "100%", children: /* @__PURE__ */ jsx(
4122
+ ConditionalTooltip,
4123
+ {
4124
+ label: formatMessage({
4125
+ id: "content-manager.preview.panel.button-disabled-tooltip",
4126
+ defaultMessage: "Please save to open the preview"
4127
+ }),
4128
+ isShown: isModified,
4129
+ children: /* @__PURE__ */ jsx(
4130
+ Button,
4131
+ {
4132
+ variant: "tertiary",
4133
+ tag: Link,
4134
+ to: { pathname: "preview", search: stringify(query, { encode: false }) },
4135
+ onClick: trackNavigation,
4136
+ flex: "auto",
4137
+ disabled: isModified,
4138
+ children: formatMessage({
4139
+ id: "content-manager.preview.panel.button",
4140
+ defaultMessage: "Open preview"
4141
+ })
4142
+ }
4143
+ )
4144
+ }
4145
+ ) })
4146
+ };
4147
+ };
4148
+ const FEATURE_ID = "preview";
4149
+ const previewAdmin = {
4150
+ bootstrap(app) {
4151
+ if (!window.strapi.future.isEnabled(FEATURE_ID)) {
4152
+ return;
4153
+ }
4154
+ const contentManagerPluginApis = app.getPlugin("content-manager").apis;
4155
+ contentManagerPluginApis.addEditViewSidePanel([PreviewSidePanel]);
4156
+ }
4157
+ };
3993
4158
  const index = {
3994
4159
  register(app) {
3995
4160
  const cm = new ContentManagerPlugin();
@@ -4009,7 +4174,7 @@ const index = {
4009
4174
  app.router.addRoute({
4010
4175
  path: "content-manager/*",
4011
4176
  lazy: async () => {
4012
- const { Layout } = await import("./layout-D51YDRJV.mjs");
4177
+ const { Layout } = await import("./layout-DaHFw5kD.mjs");
4013
4178
  return {
4014
4179
  Component: Layout
4015
4180
  };
@@ -4022,11 +4187,14 @@ const index = {
4022
4187
  if (typeof historyAdmin.bootstrap === "function") {
4023
4188
  historyAdmin.bootstrap(app);
4024
4189
  }
4190
+ if (typeof previewAdmin.bootstrap === "function") {
4191
+ previewAdmin.bootstrap(app);
4192
+ }
4025
4193
  },
4026
4194
  async registerTrads({ locales }) {
4027
4195
  const importedTrads = await Promise.all(
4028
4196
  locales.map((locale) => {
4029
- return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/ar.json": () => import("./ar-CCEVvqGG.mjs"), "./translations/ca.json": () => import("./ca-5U32ON2v.mjs"), "./translations/cs.json": () => import("./cs-CM2aBUar.mjs"), "./translations/de.json": () => import("./de-C72KDNOl.mjs"), "./translations/en.json": () => import("./en-DKV44jRb.mjs"), "./translations/es.json": () => import("./es-CeXiYflN.mjs"), "./translations/eu.json": () => import("./eu-CdALomew.mjs"), "./translations/fr.json": () => import("./fr-CD9VFbPM.mjs"), "./translations/gu.json": () => import("./gu-CNpaMDpH.mjs"), "./translations/hi.json": () => import("./hi-Dwvd04m3.mjs"), "./translations/hu.json": () => import("./hu-CeYvaaO0.mjs"), "./translations/id.json": () => import("./id-BtwA9WJT.mjs"), "./translations/it.json": () => import("./it-BrVPqaf1.mjs"), "./translations/ja.json": () => import("./ja-CtsUxOvk.mjs"), "./translations/ko.json": () => import("./ko-HVQRlfUI.mjs"), "./translations/ml.json": () => import("./ml-BihZwQit.mjs"), "./translations/ms.json": () => import("./ms-m_WjyWx7.mjs"), "./translations/nl.json": () => import("./nl-D4R9gHx5.mjs"), "./translations/pl.json": () => import("./pl-sbx9mSt_.mjs"), "./translations/pt-BR.json": () => import("./pt-BR-C71iDxnh.mjs"), "./translations/pt.json": () => import("./pt-BsaFvS8-.mjs"), "./translations/ru.json": () => import("./ru-BE6A4Exp.mjs"), "./translations/sa.json": () => import("./sa-Dag0k-Z8.mjs"), "./translations/sk.json": () => import("./sk-BFg-R8qJ.mjs"), "./translations/sv.json": () => import("./sv-CUnfWGsh.mjs"), "./translations/th.json": () => import("./th-BqbI8lIT.mjs"), "./translations/tr.json": () => import("./tr-CgeK3wJM.mjs"), "./translations/uk.json": () => import("./uk-CR-zDhAY.mjs"), "./translations/vi.json": () => import("./vi-DUXIk_fw.mjs"), "./translations/zh-Hans.json": () => import("./zh-Hans-BPQcRIyH.mjs"), "./translations/zh.json": () => import("./zh-BWZspA60.mjs") }), `./translations/${locale}.json`).then(({ default: data }) => {
4197
+ return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/ar.json": () => import("./ar-CCEVvqGG.mjs"), "./translations/ca.json": () => import("./ca-5U32ON2v.mjs"), "./translations/cs.json": () => import("./cs-CM2aBUar.mjs"), "./translations/de.json": () => import("./de-C72KDNOl.mjs"), "./translations/en.json": () => import("./en-Dtk_ot79.mjs"), "./translations/es.json": () => import("./es-D34tqjMw.mjs"), "./translations/eu.json": () => import("./eu-CdALomew.mjs"), "./translations/fr.json": () => import("./fr--pg5jUbt.mjs"), "./translations/gu.json": () => import("./gu-CNpaMDpH.mjs"), "./translations/hi.json": () => import("./hi-Dwvd04m3.mjs"), "./translations/hu.json": () => import("./hu-CeYvaaO0.mjs"), "./translations/id.json": () => import("./id-BtwA9WJT.mjs"), "./translations/it.json": () => import("./it-BrVPqaf1.mjs"), "./translations/ja.json": () => import("./ja-BHqhDq4V.mjs"), "./translations/ko.json": () => import("./ko-HVQRlfUI.mjs"), "./translations/ml.json": () => import("./ml-BihZwQit.mjs"), "./translations/ms.json": () => import("./ms-m_WjyWx7.mjs"), "./translations/nl.json": () => import("./nl-D4R9gHx5.mjs"), "./translations/pl.json": () => import("./pl-sbx9mSt_.mjs"), "./translations/pt-BR.json": () => import("./pt-BR-C71iDxnh.mjs"), "./translations/pt.json": () => import("./pt-BsaFvS8-.mjs"), "./translations/ru.json": () => import("./ru-BE6A4Exp.mjs"), "./translations/sa.json": () => import("./sa-Dag0k-Z8.mjs"), "./translations/sk.json": () => import("./sk-BFg-R8qJ.mjs"), "./translations/sv.json": () => import("./sv-CUnfWGsh.mjs"), "./translations/th.json": () => import("./th-BqbI8lIT.mjs"), "./translations/tr.json": () => import("./tr-CgeK3wJM.mjs"), "./translations/uk.json": () => import("./uk-CR-zDhAY.mjs"), "./translations/vi.json": () => import("./vi-DUXIk_fw.mjs"), "./translations/zh-Hans.json": () => import("./zh-Hans-BPQcRIyH.mjs"), "./translations/zh.json": () => import("./zh-BWZspA60.mjs") }), `./translations/${locale}.json`, 3).then(({ default: data }) => {
4030
4198
  return {
4031
4199
  data: prefixPluginTranslations(data, PLUGIN_ID),
4032
4200
  locale
@@ -4053,9 +4221,10 @@ export {
4053
4221
  HOOKS as H,
4054
4222
  InjectionZone as I,
4055
4223
  useDocument as J,
4056
- index as K,
4057
- useContentManagerContext as L,
4058
- useDocumentActions as M,
4224
+ useGetPreviewUrlQuery as K,
4225
+ index as L,
4226
+ useContentManagerContext as M,
4227
+ useDocumentActions as N,
4059
4228
  Panels as P,
4060
4229
  RelativeTime as R,
4061
4230
  SINGLE_TYPES as S,
@@ -4087,4 +4256,4 @@ export {
4087
4256
  capitalise as y,
4088
4257
  useUpdateContentTypeConfigurationMutation as z
4089
4258
  };
4090
- //# sourceMappingURL=index-jwACjpe1.mjs.map
4259
+ //# sourceMappingURL=index-D5Kyqqml.mjs.map