@strapi/content-manager 0.0.0-experimental.c592deb623aed3f74ef7fdacfad9757ed59d34f7 → 0.0.0-experimental.cb74730ce5154c26404d4dccca14976a22319002

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 (183) 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-7-qB29e7.mjs → ComponentConfigurationPage-BgCLcjXO.mjs} +4 -4
  4. package/dist/_chunks/{ComponentConfigurationPage-7-qB29e7.mjs.map → ComponentConfigurationPage-BgCLcjXO.mjs.map} +1 -1
  5. package/dist/_chunks/{ComponentConfigurationPage-DP7AC0UU.js → ComponentConfigurationPage-DywpTZeV.js} +5 -6
  6. package/dist/_chunks/{ComponentConfigurationPage-DP7AC0UU.js.map → ComponentConfigurationPage-DywpTZeV.js.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-CI4XoymK.mjs → EditConfigurationPage-BNjOAHNS.mjs} +4 -4
  11. package/dist/_chunks/{EditConfigurationPage-CI4XoymK.mjs.map → EditConfigurationPage-BNjOAHNS.mjs.map} +1 -1
  12. package/dist/_chunks/{EditConfigurationPage-DITVliEI.js → EditConfigurationPage-CxRlP5if.js} +5 -6
  13. package/dist/_chunks/{EditConfigurationPage-DITVliEI.js.map → EditConfigurationPage-CxRlP5if.js.map} +1 -1
  14. package/dist/_chunks/{EditViewPage-CUS2EAhB.js → EditViewPage-BRewdTqE.js} +45 -10
  15. package/dist/_chunks/EditViewPage-BRewdTqE.js.map +1 -0
  16. package/dist/_chunks/{EditViewPage-Dzpno8xI.mjs → EditViewPage-CD_hqc1J.mjs} +45 -9
  17. package/dist/_chunks/EditViewPage-CD_hqc1J.mjs.map +1 -0
  18. package/dist/_chunks/{Field-B_jG_EV9.mjs → Field-BPkQ-3Ku.mjs} +102 -70
  19. package/dist/_chunks/Field-BPkQ-3Ku.mjs.map +1 -0
  20. package/dist/_chunks/{Field-CtUU1Fg8.js → Field-DwvmENVf.js} +103 -72
  21. package/dist/_chunks/Field-DwvmENVf.js.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-DTqO0ymI.js → Form-C_Gwv8P_.js} +6 -7
  25. package/dist/_chunks/Form-C_Gwv8P_.js.map +1 -0
  26. package/dist/_chunks/{Form-BXHao2mZ.mjs → Form-Czi0cf_2.mjs} +4 -4
  27. package/dist/_chunks/Form-Czi0cf_2.mjs.map +1 -0
  28. package/dist/_chunks/{History-C_uSGzO5.js → History-C1TKAig-.js} +42 -100
  29. package/dist/_chunks/History-C1TKAig-.js.map +1 -0
  30. package/dist/_chunks/{History-2Ah2CQ4T.mjs → History-CIQHyi4T.mjs} +43 -100
  31. package/dist/_chunks/History-CIQHyi4T.mjs.map +1 -0
  32. package/dist/_chunks/{ListConfigurationPage-nyuP7OSy.js → ListConfigurationPage-D-NGRLYu.js} +7 -7
  33. package/dist/_chunks/ListConfigurationPage-D-NGRLYu.js.map +1 -0
  34. package/dist/_chunks/{ListConfigurationPage-BjSJlaoC.mjs → ListConfigurationPage-DcZsfyEL.mjs} +7 -6
  35. package/dist/_chunks/ListConfigurationPage-DcZsfyEL.mjs.map +1 -0
  36. package/dist/_chunks/{ListViewPage-B75x3nz2.mjs → ListViewPage-C10McTK1.mjs} +62 -39
  37. package/dist/_chunks/ListViewPage-C10McTK1.mjs.map +1 -0
  38. package/dist/_chunks/{ListViewPage-DHgHD8Xg.js → ListViewPage-xv5IQoZp.js} +63 -41
  39. package/dist/_chunks/ListViewPage-xv5IQoZp.js.map +1 -0
  40. package/dist/_chunks/{NoContentTypePage-DUacQSyF.mjs → NoContentTypePage-CPc0Cd3S.mjs} +2 -2
  41. package/dist/_chunks/{NoContentTypePage-DUacQSyF.mjs.map → NoContentTypePage-CPc0Cd3S.mjs.map} +1 -1
  42. package/dist/_chunks/{NoContentTypePage-CDUKdZ7d.js → NoContentTypePage-Dzw5Yj5u.js} +2 -2
  43. package/dist/_chunks/{NoContentTypePage-CDUKdZ7d.js.map → NoContentTypePage-Dzw5Yj5u.js.map} +1 -1
  44. package/dist/_chunks/{NoPermissionsPage-zwIZydDI.js → NoPermissionsPage-DAe5CDCC.js} +2 -2
  45. package/dist/_chunks/{NoPermissionsPage-zwIZydDI.js.map → NoPermissionsPage-DAe5CDCC.js.map} +1 -1
  46. package/dist/_chunks/{NoPermissionsPage-SFllMekk.mjs → NoPermissionsPage-wfPBh2_0.mjs} +2 -2
  47. package/dist/_chunks/{NoPermissionsPage-SFllMekk.mjs.map → NoPermissionsPage-wfPBh2_0.mjs.map} +1 -1
  48. package/dist/_chunks/Preview-B7LyGT_b.js +290 -0
  49. package/dist/_chunks/Preview-B7LyGT_b.js.map +1 -0
  50. package/dist/_chunks/Preview-BVFFm7uB.mjs +272 -0
  51. package/dist/_chunks/Preview-BVFFm7uB.mjs.map +1 -0
  52. package/dist/_chunks/{Relations-NFLaRNPr.js → Relations-BmYR1AjY.js} +68 -39
  53. package/dist/_chunks/Relations-BmYR1AjY.js.map +1 -0
  54. package/dist/_chunks/{Relations-D2NRW8fC.mjs → Relations-JPhWxk-s.mjs} +68 -38
  55. package/dist/_chunks/Relations-JPhWxk-s.mjs.map +1 -0
  56. package/dist/_chunks/{en-BlhnxQfj.js → en-BK8Xyl5I.js} +22 -10
  57. package/dist/_chunks/{en-BlhnxQfj.js.map → en-BK8Xyl5I.js.map} +1 -1
  58. package/dist/_chunks/{en-C8YBvRrK.mjs → en-Dtk_ot79.mjs} +22 -10
  59. package/dist/_chunks/{en-C8YBvRrK.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-ovJRE1FM.js → index-C2Q_PLWj.js} +294 -167
  70. package/dist/_chunks/index-C2Q_PLWj.js.map +1 -0
  71. package/dist/_chunks/{index-C9HxCo5R.mjs → index-DLIkNVnQ.mjs} +297 -170
  72. package/dist/_chunks/index-DLIkNVnQ.mjs.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-UNWstw_s.js → layout-7AsWJzZJ.js} +5 -6
  78. package/dist/_chunks/{layout-UNWstw_s.js.map → layout-7AsWJzZJ.js.map} +1 -1
  79. package/dist/_chunks/{layout-DaUjDiWQ.mjs → layout-qE8qkNH_.mjs} +4 -4
  80. package/dist/_chunks/{layout-DaUjDiWQ.mjs.map → layout-qE8qkNH_.mjs.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-D8iFAeRu.mjs → relations-BjHH_1Am.mjs} +6 -7
  86. package/dist/_chunks/relations-BjHH_1Am.mjs.map +1 -0
  87. package/dist/_chunks/{relations-NN3coOG5.js → relations-EifVzf_2.js} +6 -7
  88. package/dist/_chunks/relations-EifVzf_2.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/pages/EditView/EditViewPage.d.ts +9 -1
  98. package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +2 -2
  99. package/dist/admin/src/preview/components/PreviewContent.d.ts +2 -0
  100. package/dist/admin/src/preview/components/PreviewHeader.d.ts +2 -0
  101. package/dist/admin/src/preview/components/PreviewSidePanel.d.ts +3 -0
  102. package/dist/admin/src/preview/constants.d.ts +1 -0
  103. package/dist/admin/src/preview/index.d.ts +4 -0
  104. package/dist/admin/src/preview/pages/Preview.d.ts +11 -0
  105. package/dist/admin/src/preview/routes.d.ts +3 -0
  106. package/dist/admin/src/preview/services/preview.d.ts +3 -0
  107. package/dist/admin/src/router.d.ts +1 -1
  108. package/dist/admin/src/services/documents.d.ts +0 -3
  109. package/dist/server/index.js +426 -190
  110. package/dist/server/index.js.map +1 -1
  111. package/dist/server/index.mjs +426 -189
  112. package/dist/server/index.mjs.map +1 -1
  113. package/dist/server/src/bootstrap.d.ts.map +1 -1
  114. package/dist/server/src/controllers/collection-types.d.ts.map +1 -1
  115. package/dist/server/src/controllers/index.d.ts.map +1 -1
  116. package/dist/server/src/controllers/relations.d.ts.map +1 -1
  117. package/dist/server/src/controllers/utils/metadata.d.ts +15 -1
  118. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
  119. package/dist/server/src/history/services/history.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 +12 -12
  166. package/dist/_chunks/EditViewPage-CUS2EAhB.js.map +0 -1
  167. package/dist/_chunks/EditViewPage-Dzpno8xI.mjs.map +0 -1
  168. package/dist/_chunks/Field-B_jG_EV9.mjs.map +0 -1
  169. package/dist/_chunks/Field-CtUU1Fg8.js.map +0 -1
  170. package/dist/_chunks/Form-BXHao2mZ.mjs.map +0 -1
  171. package/dist/_chunks/Form-DTqO0ymI.js.map +0 -1
  172. package/dist/_chunks/History-2Ah2CQ4T.mjs.map +0 -1
  173. package/dist/_chunks/History-C_uSGzO5.js.map +0 -1
  174. package/dist/_chunks/ListConfigurationPage-BjSJlaoC.mjs.map +0 -1
  175. package/dist/_chunks/ListConfigurationPage-nyuP7OSy.js.map +0 -1
  176. package/dist/_chunks/ListViewPage-B75x3nz2.mjs.map +0 -1
  177. package/dist/_chunks/ListViewPage-DHgHD8Xg.js.map +0 -1
  178. package/dist/_chunks/Relations-D2NRW8fC.mjs.map +0 -1
  179. package/dist/_chunks/Relations-NFLaRNPr.js.map +0 -1
  180. package/dist/_chunks/index-C9HxCo5R.mjs.map +0 -1
  181. package/dist/_chunks/index-ovJRE1FM.js.map +0 -1
  182. package/dist/_chunks/relations-D8iFAeRu.mjs.map +0 -1
  183. package/dist/_chunks/relations-NN3coOG5.js.map +0 -1
@@ -10,8 +10,7 @@ const qs = require("qs");
10
10
  const slugify = require("@sindresorhus/slugify");
11
11
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
12
12
  function _interopNamespace(e) {
13
- if (e && e.__esModule)
14
- return e;
13
+ if (e && e.__esModule) return e;
15
14
  const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
16
15
  if (e) {
17
16
  for (const k in e) {
@@ -33,10 +32,10 @@ const isNil__default = /* @__PURE__ */ _interopDefault(isNil);
33
32
  const ___default = /* @__PURE__ */ _interopDefault(_);
34
33
  const qs__default = /* @__PURE__ */ _interopDefault(qs);
35
34
  const slugify__default = /* @__PURE__ */ _interopDefault(slugify);
36
- const getService$1 = (name) => {
35
+ const getService$2 = (name) => {
37
36
  return strapi.plugin("content-manager").service(name);
38
37
  };
39
- function getService(strapi2, name) {
38
+ function getService$1(strapi2, name) {
40
39
  return strapi2.service(`plugin::content-manager.${name}`);
41
40
  }
42
41
  const historyRestoreVersionSchema = yup__namespace.object().shape({
@@ -72,7 +71,7 @@ const createHistoryVersionController = ({ strapi: strapi2 }) => {
72
71
  if (!isSingleType && (!contentTypeUid || !ctx.query.documentId)) {
73
72
  throw new strapiUtils.errors.ForbiddenError("contentType and documentId are required");
74
73
  }
75
- const permissionChecker2 = getService$1("permission-checker").create({
74
+ const permissionChecker2 = getService$2("permission-checker").create({
76
75
  userAbility: ctx.state.userAbility,
77
76
  model: ctx.query.contentType
78
77
  });
@@ -80,7 +79,7 @@ const createHistoryVersionController = ({ strapi: strapi2 }) => {
80
79
  return ctx.forbidden();
81
80
  }
82
81
  const query = await permissionChecker2.sanitizeQuery(ctx.query);
83
- const { results, pagination } = await getService(strapi2, "history").findVersionsPage({
82
+ const { results, pagination } = await getService$1(strapi2, "history").findVersionsPage({
84
83
  query: {
85
84
  ...query,
86
85
  ...getValidPagination({ page: query.page, pageSize: query.pageSize })
@@ -105,14 +104,14 @@ const createHistoryVersionController = ({ strapi: strapi2 }) => {
105
104
  async restoreVersion(ctx) {
106
105
  const request = ctx.request;
107
106
  await validateRestoreVersion(request.body, "contentType is required");
108
- const permissionChecker2 = getService$1("permission-checker").create({
107
+ const permissionChecker2 = getService$2("permission-checker").create({
109
108
  userAbility: ctx.state.userAbility,
110
109
  model: request.body.contentType
111
110
  });
112
111
  if (permissionChecker2.cannot.update()) {
113
112
  throw new strapiUtils.errors.ForbiddenError();
114
113
  }
115
- const restoredDocument = await getService(strapi2, "history").restoreVersion(
114
+ const restoredDocument = await getService$1(strapi2, "history").restoreVersion(
116
115
  request.params.versionId
117
116
  );
118
117
  return {
@@ -121,7 +120,7 @@ const createHistoryVersionController = ({ strapi: strapi2 }) => {
121
120
  }
122
121
  };
123
122
  };
124
- const controllers$1 = {
123
+ const controllers$2 = {
125
124
  "history-version": createHistoryVersionController
126
125
  /**
127
126
  * Casting is needed because the types aren't aware that Strapi supports
@@ -167,8 +166,7 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
167
166
  };
168
167
  const getRelationRestoreValue = async (versionRelationData, attribute) => {
169
168
  if (Array.isArray(versionRelationData)) {
170
- if (versionRelationData.length === 0)
171
- return versionRelationData;
169
+ if (versionRelationData.length === 0) return versionRelationData;
172
170
  const existingAndMissingRelations = await Promise.all(
173
171
  versionRelationData.map((relation) => {
174
172
  return strapi2.documents(attribute.target).findOne({
@@ -203,8 +201,7 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
203
201
  const getDefaultLocale = async () => localesService ? localesService.getDefaultLocale() : null;
204
202
  const isLocalizedContentType = (model) => i18nContentTypeService ? i18nContentTypeService.isLocalizedContentType(model) : false;
205
203
  const getLocaleDictionary = async () => {
206
- if (!localesService)
207
- return {};
204
+ if (!localesService) return {};
208
205
  const locales = await localesService.find() || [];
209
206
  return locales.reduce(
210
207
  (acc, locale) => {
@@ -228,6 +225,17 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
228
225
  const meta = await documentMetadataService.getMetadata(contentTypeUid, document);
229
226
  return documentMetadataService.getStatus(document, meta.availableStatus);
230
227
  };
228
+ const getComponentFields = (componentUID) => {
229
+ return Object.entries(strapi2.getModel(componentUID).attributes).reduce(
230
+ (fieldsAcc, [key, attribute]) => {
231
+ if (!["relation", "media", "component", "dynamiczone"].includes(attribute.type)) {
232
+ fieldsAcc.push(key);
233
+ }
234
+ return fieldsAcc;
235
+ },
236
+ []
237
+ );
238
+ };
231
239
  const getDeepPopulate2 = (uid2, useDatabaseSyntax = false) => {
232
240
  const model = strapi2.getModel(uid2);
233
241
  const attributes = Object.entries(model.attributes);
@@ -251,13 +259,19 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
251
259
  }
252
260
  case "component": {
253
261
  const populate = getDeepPopulate2(attribute.component);
254
- acc[attributeName] = { populate };
262
+ acc[attributeName] = {
263
+ populate,
264
+ [fieldSelector]: getComponentFields(attribute.component)
265
+ };
255
266
  break;
256
267
  }
257
268
  case "dynamiczone": {
258
269
  const populatedComponents = (attribute.components || []).reduce(
259
270
  (acc2, componentUID) => {
260
- acc2[componentUID] = { populate: getDeepPopulate2(componentUID) };
271
+ acc2[componentUID] = {
272
+ populate: getDeepPopulate2(componentUID),
273
+ [fieldSelector]: getComponentFields(componentUID)
274
+ };
261
275
  return acc2;
262
276
  },
263
277
  {}
@@ -370,7 +384,7 @@ const createHistoryService = ({ strapi: strapi2 }) => {
370
384
  const attributeValue = entry.data[attributeKey];
371
385
  const attributeValues = Array.isArray(attributeValue) ? attributeValue : [attributeValue];
372
386
  if (attributeSchema.type === "media") {
373
- const permissionChecker2 = getService$1("permission-checker").create({
387
+ const permissionChecker2 = getService$2("permission-checker").create({
374
388
  userAbility: params.state.userAbility,
375
389
  model: "plugin::upload.file"
376
390
  });
@@ -393,7 +407,12 @@ const createHistoryService = ({ strapi: strapi2 }) => {
393
407
  if (userToPopulate == null) {
394
408
  return null;
395
409
  }
396
- return strapi2.query("admin::user").findOne({ where: { id: userToPopulate.id } });
410
+ return strapi2.query("admin::user").findOne({
411
+ where: {
412
+ ...userToPopulate.id ? { id: userToPopulate.id } : {},
413
+ ...userToPopulate.documentId ? { documentId: userToPopulate.documentId } : {}
414
+ }
415
+ });
397
416
  })
398
417
  );
399
418
  return {
@@ -406,7 +425,7 @@ const createHistoryService = ({ strapi: strapi2 }) => {
406
425
  [attributeKey]: adminUsers
407
426
  };
408
427
  }
409
- const permissionChecker2 = getService$1("permission-checker").create({
428
+ const permissionChecker2 = getService$2("permission-checker").create({
410
429
  userAbility: params.state.userAbility,
411
430
  model: attributeSchema.target
412
431
  });
@@ -582,7 +601,7 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
582
601
  onCommit(async () => {
583
602
  for (const entry of localeEntries) {
584
603
  const status = await serviceUtils.getVersionStatus(uid2, entry);
585
- await getService(strapi2, "history").createVersion({
604
+ await getService$1(strapi2, "history").createVersion({
586
605
  contentType: uid2,
587
606
  data: fp.omit(FIELDS_TO_IGNORE, entry),
588
607
  relatedDocumentId: documentId,
@@ -595,15 +614,19 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
595
614
  });
596
615
  return result;
597
616
  });
598
- state.deleteExpiredJob = nodeSchedule.scheduleJob("0 0 * * *", () => {
617
+ state.deleteExpiredJob = nodeSchedule.scheduleJob("historyDaily", "0 0 * * *", () => {
599
618
  const retentionDaysInMilliseconds = serviceUtils.getRetentionDays() * 24 * 60 * 60 * 1e3;
600
619
  const expirationDate = new Date(Date.now() - retentionDaysInMilliseconds);
601
620
  strapi2.db.query(HISTORY_VERSION_UID).deleteMany({
602
621
  where: {
603
622
  created_at: {
604
- $lt: expirationDate.toISOString()
623
+ $lt: expirationDate
605
624
  }
606
625
  }
626
+ }).catch((error) => {
627
+ if (error instanceof Error) {
628
+ strapi2.log.error("Error deleting expired history versions", error.message);
629
+ }
607
630
  });
608
631
  });
609
632
  state.isInitialized = true;
@@ -615,17 +638,17 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
615
638
  }
616
639
  };
617
640
  };
618
- const services$1 = {
641
+ const services$2 = {
619
642
  history: createHistoryService,
620
643
  lifecycles: createLifecyclesService
621
644
  };
622
- const info = { pluginName: "content-manager", type: "admin" };
645
+ const info$1 = { pluginName: "content-manager", type: "admin" };
623
646
  const historyVersionRouter = {
624
647
  type: "admin",
625
648
  routes: [
626
649
  {
627
650
  method: "GET",
628
- info,
651
+ info: info$1,
629
652
  path: "/history-versions",
630
653
  handler: "history-version.findMany",
631
654
  config: {
@@ -634,7 +657,7 @@ const historyVersionRouter = {
634
657
  },
635
658
  {
636
659
  method: "PUT",
637
- info,
660
+ info: info$1,
638
661
  path: "/history-versions/:versionId/restore",
639
662
  handler: "history-version.restoreVersion",
640
663
  config: {
@@ -643,7 +666,7 @@ const historyVersionRouter = {
643
666
  }
644
667
  ]
645
668
  };
646
- const routes$1 = {
669
+ const routes$2 = {
647
670
  "history-version": historyVersionRouter
648
671
  };
649
672
  const historyVersion = {
@@ -690,21 +713,21 @@ const historyVersion = {
690
713
  }
691
714
  }
692
715
  };
693
- const getFeature = () => {
716
+ const getFeature$1 = () => {
694
717
  if (strapi.ee.features.isEnabled("cms-content-history")) {
695
718
  return {
696
719
  register({ strapi: strapi2 }) {
697
720
  strapi2.get("models").add(historyVersion);
698
721
  },
699
722
  bootstrap({ strapi: strapi2 }) {
700
- getService(strapi2, "lifecycles").bootstrap();
723
+ getService$1(strapi2, "lifecycles").bootstrap();
701
724
  },
702
725
  destroy({ strapi: strapi2 }) {
703
- getService(strapi2, "lifecycles").destroy();
726
+ getService$1(strapi2, "lifecycles").destroy();
704
727
  },
705
- controllers: controllers$1,
706
- services: services$1,
707
- routes: routes$1
728
+ controllers: controllers$2,
729
+ services: services$2,
730
+ routes: routes$2
708
731
  };
709
732
  }
710
733
  return {
@@ -713,9 +736,205 @@ const getFeature = () => {
713
736
  }
714
737
  };
715
738
  };
716
- const history = getFeature();
739
+ const history = getFeature$1();
740
+ const FEATURE_ID = "preview";
741
+ const info = { pluginName: "content-manager", type: "admin" };
742
+ const previewRouter = {
743
+ type: "admin",
744
+ routes: [
745
+ {
746
+ method: "GET",
747
+ info,
748
+ path: "/preview/url/:contentType",
749
+ handler: "preview.getPreviewUrl",
750
+ config: {
751
+ policies: ["admin::isAuthenticatedAdmin"]
752
+ }
753
+ }
754
+ ]
755
+ };
756
+ const routes$1 = {
757
+ preview: previewRouter
758
+ };
759
+ function getService(strapi2, name) {
760
+ return strapi2.service(`plugin::content-manager.${name}`);
761
+ }
762
+ const getPreviewUrlSchema = yup__namespace.object().shape({
763
+ // Will be undefined for single types
764
+ documentId: yup__namespace.string(),
765
+ locale: yup__namespace.string().nullable(),
766
+ status: yup__namespace.string()
767
+ }).required();
768
+ const validatePreviewUrl = async (strapi2, uid2, params) => {
769
+ await strapiUtils.validateYupSchema(getPreviewUrlSchema)(params);
770
+ const newParams = fp.pick(["documentId", "locale", "status"], params);
771
+ const model = strapi2.getModel(uid2);
772
+ if (!model || model.modelType !== "contentType") {
773
+ throw new strapiUtils.errors.ValidationError("Invalid content type");
774
+ }
775
+ const isSingleType = model?.kind === "singleType";
776
+ if (!isSingleType && !params.documentId) {
777
+ throw new strapiUtils.errors.ValidationError("documentId is required for Collection Types");
778
+ }
779
+ if (isSingleType) {
780
+ const doc = await strapi2.documents(uid2).findFirst();
781
+ if (!doc) {
782
+ throw new strapiUtils.errors.NotFoundError("Document not found");
783
+ }
784
+ newParams.documentId = doc?.documentId;
785
+ }
786
+ if (!newParams.status) {
787
+ const isDPEnabled = model?.options?.draftAndPublish;
788
+ newParams.status = isDPEnabled ? "draft" : "published";
789
+ }
790
+ return newParams;
791
+ };
792
+ const createPreviewController = () => {
793
+ return {
794
+ /**
795
+ * Transforms an entry into a preview URL, so that it can be previewed
796
+ * in the Content Manager.
797
+ */
798
+ async getPreviewUrl(ctx) {
799
+ const uid2 = ctx.params.contentType;
800
+ const query = ctx.request.query;
801
+ const params = await validatePreviewUrl(strapi, uid2, query);
802
+ const previewService = getService(strapi, "preview");
803
+ const url = await previewService.getPreviewUrl(uid2, params);
804
+ if (!url) {
805
+ ctx.status = 204;
806
+ }
807
+ return {
808
+ data: { url }
809
+ };
810
+ }
811
+ };
812
+ };
813
+ const controllers$1 = {
814
+ preview: createPreviewController
815
+ /**
816
+ * Casting is needed because the types aren't aware that Strapi supports
817
+ * passing a controller factory as the value, instead of a controller object directly
818
+ */
819
+ };
820
+ const createPreviewService = ({ strapi: strapi2 }) => {
821
+ const config = getService(strapi2, "preview-config");
822
+ return {
823
+ async getPreviewUrl(uid2, params) {
824
+ const handler = config.getPreviewHandler();
825
+ try {
826
+ return handler(uid2, params);
827
+ } catch (error) {
828
+ strapi2.log.error(`Failed to get preview URL: ${error}`);
829
+ throw new strapiUtils.errors.ApplicationError("Failed to get preview URL");
830
+ }
831
+ return;
832
+ }
833
+ };
834
+ };
835
+ const extendMiddlewareConfiguration = (middleware = { name: "", config: {} }) => {
836
+ const middlewares = strapi.config.get("middlewares");
837
+ const configuredMiddlewares = middlewares.map((currentMiddleware) => {
838
+ if (currentMiddleware === middleware.name) {
839
+ return middleware;
840
+ }
841
+ if (currentMiddleware.name === middleware.name) {
842
+ return fp.mergeWith(
843
+ (objValue, srcValue) => {
844
+ if (Array.isArray(objValue)) {
845
+ return objValue.concat(srcValue);
846
+ }
847
+ return void 0;
848
+ },
849
+ currentMiddleware,
850
+ middleware
851
+ );
852
+ }
853
+ return currentMiddleware;
854
+ });
855
+ strapi.config.set("middlewares", configuredMiddlewares);
856
+ };
857
+ const createPreviewConfigService = ({ strapi: strapi2 }) => {
858
+ return {
859
+ register() {
860
+ if (!this.isEnabled()) {
861
+ return;
862
+ }
863
+ const config = strapi2.config.get("admin.preview");
864
+ if (config.config?.allowedOrigins) {
865
+ extendMiddlewareConfiguration({
866
+ name: "strapi::security",
867
+ config: {
868
+ contentSecurityPolicy: {
869
+ directives: {
870
+ "frame-src": config.config.allowedOrigins
871
+ }
872
+ }
873
+ }
874
+ });
875
+ }
876
+ },
877
+ isEnabled() {
878
+ const config = strapi2.config.get("admin.preview");
879
+ if (!config) {
880
+ return false;
881
+ }
882
+ return config?.enabled ?? true;
883
+ },
884
+ /**
885
+ * Validate if the configuration is valid
886
+ */
887
+ validate() {
888
+ if (!this.isEnabled()) {
889
+ return;
890
+ }
891
+ const handler = this.getPreviewHandler();
892
+ if (typeof handler !== "function") {
893
+ throw new strapiUtils.errors.ValidationError(
894
+ "Preview configuration is invalid. Handler must be a function"
895
+ );
896
+ }
897
+ },
898
+ /**
899
+ * Utility to get the preview handler from the configuration
900
+ */
901
+ getPreviewHandler() {
902
+ const config = strapi2.config.get("admin.preview");
903
+ const emptyHandler = () => {
904
+ return void 0;
905
+ };
906
+ if (!this.isEnabled()) {
907
+ return emptyHandler;
908
+ }
909
+ return config?.config?.handler || emptyHandler;
910
+ }
911
+ };
912
+ };
913
+ const services$1 = {
914
+ preview: createPreviewService,
915
+ "preview-config": createPreviewConfigService
916
+ };
917
+ const getFeature = () => {
918
+ if (!strapi.features.future.isEnabled(FEATURE_ID)) {
919
+ return {};
920
+ }
921
+ return {
922
+ register() {
923
+ const config = getService(strapi, "preview-config");
924
+ config.validate();
925
+ config.register();
926
+ },
927
+ bootstrap() {
928
+ },
929
+ routes: routes$1,
930
+ controllers: controllers$1,
931
+ services: services$1
932
+ };
933
+ };
934
+ const preview = getFeature();
717
935
  const register = async ({ strapi: strapi2 }) => {
718
936
  await history.register?.({ strapi: strapi2 });
937
+ await preview.register?.({ strapi: strapi2 });
719
938
  };
720
939
  const ALLOWED_WEBHOOK_EVENTS = {
721
940
  ENTRY_PUBLISH: "entry.publish",
@@ -725,11 +944,12 @@ const bootstrap = async () => {
725
944
  Object.entries(ALLOWED_WEBHOOK_EVENTS).forEach(([key, value]) => {
726
945
  strapi.get("webhookStore").addAllowedEvent(key, value);
727
946
  });
728
- getService$1("field-sizes").setCustomFieldInputSizes();
729
- await getService$1("components").syncConfigurations();
730
- await getService$1("content-types").syncConfigurations();
731
- await getService$1("permission").registerPermissions();
947
+ getService$2("field-sizes").setCustomFieldInputSizes();
948
+ await getService$2("components").syncConfigurations();
949
+ await getService$2("content-types").syncConfigurations();
950
+ await getService$2("permission").registerPermissions();
732
951
  await history.bootstrap?.({ strapi });
952
+ await preview.bootstrap?.({ strapi });
733
953
  };
734
954
  const destroy = async ({ strapi: strapi2 }) => {
735
955
  await history.destroy?.({ strapi: strapi2 });
@@ -1219,7 +1439,8 @@ const admin = {
1219
1439
  };
1220
1440
  const routes = {
1221
1441
  admin,
1222
- ...history.routes ? history.routes : {}
1442
+ ...history.routes ? history.routes : {},
1443
+ ...preview.routes ? preview.routes : {}
1223
1444
  };
1224
1445
  const hasPermissionsSchema = strapiUtils.yup.object({
1225
1446
  actions: strapiUtils.yup.array().of(strapiUtils.yup.string()),
@@ -1282,8 +1503,7 @@ const isSortable = (schema, name) => {
1282
1503
  if (!___default.default.has(schema.attributes, name)) {
1283
1504
  return false;
1284
1505
  }
1285
- if (schema.modelType === "component" && name === "id")
1286
- return false;
1506
+ if (schema.modelType === "component" && name === "id") return false;
1287
1507
  const attribute = schema.attributes[name];
1288
1508
  if (NON_SORTABLES.includes(attribute.type)) {
1289
1509
  return false;
@@ -1428,8 +1648,7 @@ const createDefaultSettings = async (schema) => {
1428
1648
  };
1429
1649
  };
1430
1650
  const syncSettings = async (configuration, schema) => {
1431
- if (fp.isEmpty(configuration.settings))
1432
- return createDefaultSettings(schema);
1651
+ if (fp.isEmpty(configuration.settings)) return createDefaultSettings(schema);
1433
1652
  const defaultField = getDefaultMainField(schema);
1434
1653
  const { mainField = defaultField, defaultSortBy = defaultField } = configuration.settings || {};
1435
1654
  return {
@@ -1476,7 +1695,7 @@ const createMetadasSchema = (schema) => {
1476
1695
  if (!value) {
1477
1696
  return strapiUtils.yup.string();
1478
1697
  }
1479
- const targetSchema = getService$1("content-types").findContentType(
1698
+ const targetSchema = getService$2("content-types").findContentType(
1480
1699
  schema.attributes[key].targetModel
1481
1700
  );
1482
1701
  if (!targetSchema) {
@@ -1605,8 +1824,7 @@ const excludeNotCreatableFields = (uid2, permissionChecker2) => (body, path = []
1605
1824
  }
1606
1825
  switch (attribute.type) {
1607
1826
  case "relation": {
1608
- if (canCreate(attributePath))
1609
- return body2;
1827
+ if (canCreate(attributePath)) return body2;
1610
1828
  return fp.set(attributePath, { set: [] }, body2);
1611
1829
  }
1612
1830
  case "component": {
@@ -1616,8 +1834,7 @@ const excludeNotCreatableFields = (uid2, permissionChecker2) => (body, path = []
1616
1834
  ]);
1617
1835
  }
1618
1836
  default: {
1619
- if (canCreate(attributePath))
1620
- return body2;
1837
+ if (canCreate(attributePath)) return body2;
1621
1838
  return fp.set(attributePath, null, body2);
1622
1839
  }
1623
1840
  }
@@ -1645,7 +1862,7 @@ const getDocumentLocaleAndStatus = async (request, model, opts = { allowMultiple
1645
1862
  }
1646
1863
  };
1647
1864
  const formatDocumentWithMetadata = async (permissionChecker2, uid2, document, opts = {}) => {
1648
- const documentMetadata2 = getService$1("document-metadata");
1865
+ const documentMetadata2 = getService$2("document-metadata");
1649
1866
  const serviceOutput = await documentMetadata2.formatDocumentWithMetadata(uid2, document, opts);
1650
1867
  let {
1651
1868
  meta: { availableLocales, availableStatus }
@@ -1671,8 +1888,8 @@ const createDocument = async (ctx, opts) => {
1671
1888
  const { userAbility, user } = ctx.state;
1672
1889
  const { model } = ctx.params;
1673
1890
  const { body } = ctx.request;
1674
- const documentManager2 = getService$1("document-manager");
1675
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
1891
+ const documentManager2 = getService$2("document-manager");
1892
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1676
1893
  if (permissionChecker2.cannot.create()) {
1677
1894
  throw new strapiUtils.errors.ForbiddenError();
1678
1895
  }
@@ -1692,13 +1909,13 @@ const updateDocument = async (ctx, opts) => {
1692
1909
  const { userAbility, user } = ctx.state;
1693
1910
  const { id, model } = ctx.params;
1694
1911
  const { body } = ctx.request;
1695
- const documentManager2 = getService$1("document-manager");
1696
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
1912
+ const documentManager2 = getService$2("document-manager");
1913
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1697
1914
  if (permissionChecker2.cannot.update()) {
1698
1915
  throw new strapiUtils.errors.ForbiddenError();
1699
1916
  }
1700
1917
  const permissionQuery = await permissionChecker2.sanitizedQuery.update(ctx.query);
1701
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
1918
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
1702
1919
  const { locale } = await getDocumentLocaleAndStatus(body, model);
1703
1920
  const [documentVersion, documentExists] = await Promise.all([
1704
1921
  documentManager2.findOne(id, model, { populate, locale, status: "draft" }),
@@ -1715,7 +1932,7 @@ const updateDocument = async (ctx, opts) => {
1715
1932
  throw new strapiUtils.errors.ForbiddenError();
1716
1933
  }
1717
1934
  const pickPermittedFields = documentVersion ? permissionChecker2.sanitizeUpdateInput(documentVersion) : permissionChecker2.sanitizeCreateInput;
1718
- const setCreator = strapiUtils.setCreatorFields({ user, isEdition: true });
1935
+ const setCreator = documentVersion ? strapiUtils.setCreatorFields({ user, isEdition: true }) : strapiUtils.setCreatorFields({ user });
1719
1936
  const sanitizeFn = strapiUtils.async.pipe(pickPermittedFields, setCreator);
1720
1937
  const sanitizedBody = await sanitizeFn(body);
1721
1938
  return documentManager2.update(documentVersion?.documentId || id, model, {
@@ -1729,14 +1946,14 @@ const collectionTypes = {
1729
1946
  const { userAbility } = ctx.state;
1730
1947
  const { model } = ctx.params;
1731
1948
  const { query } = ctx.request;
1732
- const documentMetadata2 = getService$1("document-metadata");
1733
- const documentManager2 = getService$1("document-manager");
1734
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
1949
+ const documentMetadata2 = getService$2("document-metadata");
1950
+ const documentManager2 = getService$2("document-manager");
1951
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1735
1952
  if (permissionChecker2.cannot.read()) {
1736
1953
  return ctx.forbidden();
1737
1954
  }
1738
1955
  const permissionQuery = await permissionChecker2.sanitizedQuery.read(query);
1739
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(1).countRelations({ toOne: false, toMany: true }).build();
1956
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(1).countRelations({ toOne: false, toMany: true }).build();
1740
1957
  const { locale, status } = await getDocumentLocaleAndStatus(query, model);
1741
1958
  const { results: documents, pagination } = await documentManager2.findPage(
1742
1959
  { ...permissionQuery, populate, locale, status },
@@ -1765,13 +1982,13 @@ const collectionTypes = {
1765
1982
  async findOne(ctx) {
1766
1983
  const { userAbility } = ctx.state;
1767
1984
  const { model, id } = ctx.params;
1768
- const documentManager2 = getService$1("document-manager");
1769
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
1985
+ const documentManager2 = getService$2("document-manager");
1986
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1770
1987
  if (permissionChecker2.cannot.read()) {
1771
1988
  return ctx.forbidden();
1772
1989
  }
1773
1990
  const permissionQuery = await permissionChecker2.sanitizedQuery.read(ctx.query);
1774
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
1991
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
1775
1992
  const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);
1776
1993
  const version = await documentManager2.findOne(id, model, {
1777
1994
  populate,
@@ -1802,7 +2019,7 @@ const collectionTypes = {
1802
2019
  async create(ctx) {
1803
2020
  const { userAbility } = ctx.state;
1804
2021
  const { model } = ctx.params;
1805
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2022
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1806
2023
  const [totalEntries, document] = await Promise.all([
1807
2024
  strapi.db.query(model).count(),
1808
2025
  createDocument(ctx)
@@ -1823,7 +2040,7 @@ const collectionTypes = {
1823
2040
  async update(ctx) {
1824
2041
  const { userAbility } = ctx.state;
1825
2042
  const { model } = ctx.params;
1826
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2043
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1827
2044
  const updatedVersion = await updateDocument(ctx);
1828
2045
  const sanitizedVersion = await permissionChecker2.sanitizeOutput(updatedVersion);
1829
2046
  ctx.body = await formatDocumentWithMetadata(permissionChecker2, model, sanitizedVersion);
@@ -1832,13 +2049,13 @@ const collectionTypes = {
1832
2049
  const { userAbility, user } = ctx.state;
1833
2050
  const { model, sourceId: id } = ctx.params;
1834
2051
  const { body } = ctx.request;
1835
- const documentManager2 = getService$1("document-manager");
1836
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2052
+ const documentManager2 = getService$2("document-manager");
2053
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1837
2054
  if (permissionChecker2.cannot.create()) {
1838
2055
  return ctx.forbidden();
1839
2056
  }
1840
2057
  const permissionQuery = await permissionChecker2.sanitizedQuery.create(ctx.query);
1841
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
2058
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
1842
2059
  const { locale } = await getDocumentLocaleAndStatus(body, model);
1843
2060
  const document = await documentManager2.findOne(id, model, {
1844
2061
  populate,
@@ -1877,13 +2094,13 @@ const collectionTypes = {
1877
2094
  async delete(ctx) {
1878
2095
  const { userAbility } = ctx.state;
1879
2096
  const { id, model } = ctx.params;
1880
- const documentManager2 = getService$1("document-manager");
1881
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2097
+ const documentManager2 = getService$2("document-manager");
2098
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1882
2099
  if (permissionChecker2.cannot.delete()) {
1883
2100
  return ctx.forbidden();
1884
2101
  }
1885
2102
  const permissionQuery = await permissionChecker2.sanitizedQuery.delete(ctx.query);
1886
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
2103
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
1887
2104
  const { locale } = await getDocumentLocaleAndStatus(ctx.query, model);
1888
2105
  const documentLocales = await documentManager2.findLocales(id, model, { populate, locale });
1889
2106
  if (documentLocales.length === 0) {
@@ -1905,14 +2122,14 @@ const collectionTypes = {
1905
2122
  const { userAbility } = ctx.state;
1906
2123
  const { id, model } = ctx.params;
1907
2124
  const { body } = ctx.request;
1908
- const documentManager2 = getService$1("document-manager");
1909
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2125
+ const documentManager2 = getService$2("document-manager");
2126
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1910
2127
  if (permissionChecker2.cannot.publish()) {
1911
2128
  return ctx.forbidden();
1912
2129
  }
1913
2130
  const publishedDocument = await strapi.db.transaction(async () => {
1914
2131
  const permissionQuery = await permissionChecker2.sanitizedQuery.publish(ctx.query);
1915
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
2132
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
1916
2133
  let document;
1917
2134
  const { locale } = await getDocumentLocaleAndStatus(body, model);
1918
2135
  const isCreate = fp.isNil(id);
@@ -1960,13 +2177,13 @@ const collectionTypes = {
1960
2177
  const { body } = ctx.request;
1961
2178
  const { documentIds } = body;
1962
2179
  await validateBulkActionInput(body);
1963
- const documentManager2 = getService$1("document-manager");
1964
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2180
+ const documentManager2 = getService$2("document-manager");
2181
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1965
2182
  if (permissionChecker2.cannot.publish()) {
1966
2183
  return ctx.forbidden();
1967
2184
  }
1968
2185
  const permissionQuery = await permissionChecker2.sanitizedQuery.publish(ctx.query);
1969
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
2186
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
1970
2187
  const { locale } = await getDocumentLocaleAndStatus(body, model, {
1971
2188
  allowMultipleLocales: true
1972
2189
  });
@@ -1991,8 +2208,8 @@ const collectionTypes = {
1991
2208
  const { body } = ctx.request;
1992
2209
  const { documentIds } = body;
1993
2210
  await validateBulkActionInput(body);
1994
- const documentManager2 = getService$1("document-manager");
1995
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2211
+ const documentManager2 = getService$2("document-manager");
2212
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
1996
2213
  if (permissionChecker2.cannot.unpublish()) {
1997
2214
  return ctx.forbidden();
1998
2215
  }
@@ -2021,8 +2238,8 @@ const collectionTypes = {
2021
2238
  const {
2022
2239
  body: { discardDraft, ...body }
2023
2240
  } = ctx.request;
2024
- const documentManager2 = getService$1("document-manager");
2025
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2241
+ const documentManager2 = getService$2("document-manager");
2242
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2026
2243
  if (permissionChecker2.cannot.unpublish()) {
2027
2244
  return ctx.forbidden();
2028
2245
  }
@@ -2030,7 +2247,7 @@ const collectionTypes = {
2030
2247
  return ctx.forbidden();
2031
2248
  }
2032
2249
  const permissionQuery = await permissionChecker2.sanitizedQuery.unpublish(ctx.query);
2033
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
2250
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
2034
2251
  const { locale } = await getDocumentLocaleAndStatus(body, model);
2035
2252
  const document = await documentManager2.findOne(id, model, {
2036
2253
  populate,
@@ -2061,13 +2278,13 @@ const collectionTypes = {
2061
2278
  const { userAbility } = ctx.state;
2062
2279
  const { id, model } = ctx.params;
2063
2280
  const { body } = ctx.request;
2064
- const documentManager2 = getService$1("document-manager");
2065
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2281
+ const documentManager2 = getService$2("document-manager");
2282
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2066
2283
  if (permissionChecker2.cannot.discard()) {
2067
2284
  return ctx.forbidden();
2068
2285
  }
2069
2286
  const permissionQuery = await permissionChecker2.sanitizedQuery.discard(ctx.query);
2070
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
2287
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
2071
2288
  const { locale } = await getDocumentLocaleAndStatus(body, model);
2072
2289
  const document = await documentManager2.findOne(id, model, {
2073
2290
  populate,
@@ -2092,13 +2309,13 @@ const collectionTypes = {
2092
2309
  const { query, body } = ctx.request;
2093
2310
  const { documentIds } = body;
2094
2311
  await validateBulkActionInput(body);
2095
- const documentManager2 = getService$1("document-manager");
2096
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2312
+ const documentManager2 = getService$2("document-manager");
2313
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2097
2314
  if (permissionChecker2.cannot.delete()) {
2098
2315
  return ctx.forbidden();
2099
2316
  }
2100
2317
  const permissionQuery = await permissionChecker2.sanitizedQuery.delete(query);
2101
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
2318
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
2102
2319
  const { locale } = await getDocumentLocaleAndStatus(body, model);
2103
2320
  const documentLocales = await documentManager2.findLocales(documentIds, model, {
2104
2321
  populate,
@@ -2119,13 +2336,13 @@ const collectionTypes = {
2119
2336
  async countDraftRelations(ctx) {
2120
2337
  const { userAbility } = ctx.state;
2121
2338
  const { model, id } = ctx.params;
2122
- const documentManager2 = getService$1("document-manager");
2123
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2339
+ const documentManager2 = getService$2("document-manager");
2340
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2124
2341
  if (permissionChecker2.cannot.read()) {
2125
2342
  return ctx.forbidden();
2126
2343
  }
2127
2344
  const permissionQuery = await permissionChecker2.sanitizedQuery.read(ctx.query);
2128
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
2345
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
2129
2346
  const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);
2130
2347
  const entity = await documentManager2.findOne(id, model, { populate, locale, status });
2131
2348
  if (!entity) {
@@ -2144,8 +2361,8 @@ const collectionTypes = {
2144
2361
  const ids = ctx.request.query.documentIds;
2145
2362
  const locale = ctx.request.query.locale;
2146
2363
  const { model } = ctx.params;
2147
- const documentManager2 = getService$1("document-manager");
2148
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2364
+ const documentManager2 = getService$2("document-manager");
2365
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2149
2366
  if (permissionChecker2.cannot.read()) {
2150
2367
  return ctx.forbidden();
2151
2368
  }
@@ -2169,13 +2386,13 @@ const collectionTypes = {
2169
2386
  };
2170
2387
  const components$1 = {
2171
2388
  findComponents(ctx) {
2172
- const components2 = getService$1("components").findAllComponents();
2173
- const { toDto } = getService$1("data-mapper");
2389
+ const components2 = getService$2("components").findAllComponents();
2390
+ const { toDto } = getService$2("data-mapper");
2174
2391
  ctx.body = { data: components2.map(toDto) };
2175
2392
  },
2176
2393
  async findComponentConfiguration(ctx) {
2177
2394
  const { uid: uid2 } = ctx.params;
2178
- const componentService = getService$1("components");
2395
+ const componentService = getService$2("components");
2179
2396
  const component = componentService.findComponent(uid2);
2180
2397
  if (!component) {
2181
2398
  return ctx.notFound("component.notFound");
@@ -2192,7 +2409,7 @@ const components$1 = {
2192
2409
  async updateComponentConfiguration(ctx) {
2193
2410
  const { uid: uid2 } = ctx.params;
2194
2411
  const { body } = ctx.request;
2195
- const componentService = getService$1("components");
2412
+ const componentService = getService$2("components");
2196
2413
  const component = componentService.findComponent(uid2);
2197
2414
  if (!component) {
2198
2415
  return ctx.notFound("component.notFound");
@@ -2226,12 +2443,12 @@ const contentTypes = {
2226
2443
  } catch (error) {
2227
2444
  return ctx.send({ error }, 400);
2228
2445
  }
2229
- const contentTypes2 = getService$1("content-types").findContentTypesByKind(kind);
2230
- const { toDto } = getService$1("data-mapper");
2446
+ const contentTypes2 = getService$2("content-types").findContentTypesByKind(kind);
2447
+ const { toDto } = getService$2("data-mapper");
2231
2448
  ctx.body = { data: contentTypes2.map(toDto) };
2232
2449
  },
2233
2450
  async findContentTypesSettings(ctx) {
2234
- const { findAllContentTypes, findConfiguration } = getService$1("content-types");
2451
+ const { findAllContentTypes, findConfiguration } = getService$2("content-types");
2235
2452
  const contentTypes2 = await findAllContentTypes();
2236
2453
  const configurations = await Promise.all(
2237
2454
  contentTypes2.map(async (contentType) => {
@@ -2245,7 +2462,7 @@ const contentTypes = {
2245
2462
  },
2246
2463
  async findContentTypeConfiguration(ctx) {
2247
2464
  const { uid: uid2 } = ctx.params;
2248
- const contentTypeService = getService$1("content-types");
2465
+ const contentTypeService = getService$2("content-types");
2249
2466
  const contentType = await contentTypeService.findContentType(uid2);
2250
2467
  if (!contentType) {
2251
2468
  return ctx.notFound("contentType.notFound");
@@ -2267,13 +2484,13 @@ const contentTypes = {
2267
2484
  const { userAbility } = ctx.state;
2268
2485
  const { uid: uid2 } = ctx.params;
2269
2486
  const { body } = ctx.request;
2270
- const contentTypeService = getService$1("content-types");
2271
- const metricsService = getService$1("metrics");
2487
+ const contentTypeService = getService$2("content-types");
2488
+ const metricsService = getService$2("metrics");
2272
2489
  const contentType = await contentTypeService.findContentType(uid2);
2273
2490
  if (!contentType) {
2274
2491
  return ctx.notFound("contentType.notFound");
2275
2492
  }
2276
- if (!getService$1("permission").canConfigureContentType({ userAbility, contentType })) {
2493
+ if (!getService$2("permission").canConfigureContentType({ userAbility, contentType })) {
2277
2494
  return ctx.forbidden();
2278
2495
  }
2279
2496
  let input;
@@ -2306,10 +2523,10 @@ const contentTypes = {
2306
2523
  };
2307
2524
  const init = {
2308
2525
  getInitData(ctx) {
2309
- const { toDto } = getService$1("data-mapper");
2310
- const { findAllComponents } = getService$1("components");
2311
- const { getAllFieldSizes } = getService$1("field-sizes");
2312
- const { findAllContentTypes } = getService$1("content-types");
2526
+ const { toDto } = getService$2("data-mapper");
2527
+ const { findAllComponents } = getService$2("components");
2528
+ const { getAllFieldSizes } = getService$2("field-sizes");
2529
+ const { findAllContentTypes } = getService$2("content-types");
2313
2530
  ctx.body = {
2314
2531
  data: {
2315
2532
  fieldSizes: getAllFieldSizes(),
@@ -2345,7 +2562,7 @@ const addFiltersClause = (params, filtersClause) => {
2345
2562
  params.filters.$and.push(filtersClause);
2346
2563
  };
2347
2564
  const sanitizeMainField = (model, mainField, userAbility) => {
2348
- const permissionChecker2 = getService$1("permission-checker").create({
2565
+ const permissionChecker2 = getService$2("permission-checker").create({
2349
2566
  userAbility,
2350
2567
  model: model.uid
2351
2568
  });
@@ -2359,15 +2576,27 @@ const sanitizeMainField = (model, mainField, userAbility) => {
2359
2576
  }
2360
2577
  return mainField;
2361
2578
  };
2362
- const addStatusToRelations = async (uid2, relations2) => {
2363
- if (!strapiUtils.contentTypes.hasDraftAndPublish(strapi.contentTypes[uid2])) {
2579
+ const addStatusToRelations = async (targetUid, relations2) => {
2580
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(strapi.getModel(targetUid))) {
2581
+ return relations2;
2582
+ }
2583
+ const documentMetadata2 = getService$2("document-metadata");
2584
+ if (!relations2.length) {
2364
2585
  return relations2;
2365
2586
  }
2366
- const documentMetadata2 = getService$1("document-metadata");
2367
- const documentsAvailableStatus = await documentMetadata2.getManyAvailableStatus(uid2, relations2);
2587
+ const firstRelation = relations2[0];
2588
+ const filters = {
2589
+ documentId: { $in: relations2.map((r) => r.documentId) },
2590
+ // NOTE: find the "opposite" status
2591
+ publishedAt: firstRelation.publishedAt !== null ? { $null: true } : { $notNull: true }
2592
+ };
2593
+ const availableStatus = await strapi.query(targetUid).findMany({
2594
+ select: ["id", "documentId", "locale", "updatedAt", "createdAt", "publishedAt"],
2595
+ filters
2596
+ });
2368
2597
  return relations2.map((relation) => {
2369
- const availableStatuses = documentsAvailableStatus.filter(
2370
- (availableDocument) => availableDocument.documentId === relation.documentId
2598
+ const availableStatuses = availableStatus.filter(
2599
+ (availableDocument) => availableDocument.documentId === relation.documentId && (relation.locale ? availableDocument.locale === relation.locale : true)
2371
2600
  );
2372
2601
  return {
2373
2602
  ...relation,
@@ -2388,11 +2617,8 @@ const validateLocale = (sourceUid, targetUid, locale) => {
2388
2617
  const isLocalized = strapi.plugin("i18n").service("content-types").isLocalizedContentType;
2389
2618
  const isSourceLocalized = isLocalized(sourceModel);
2390
2619
  const isTargetLocalized = isLocalized(targetModel);
2391
- let validatedLocale = locale;
2392
- if (!targetModel || !isTargetLocalized)
2393
- validatedLocale = void 0;
2394
2620
  return {
2395
- locale: validatedLocale,
2621
+ locale,
2396
2622
  isSourceLocalized,
2397
2623
  isTargetLocalized
2398
2624
  };
@@ -2401,8 +2627,7 @@ const validateStatus = (sourceUid, status) => {
2401
2627
  const sourceModel = strapi.getModel(sourceUid);
2402
2628
  const isDP = strapiUtils.contentTypes.hasDraftAndPublish;
2403
2629
  const isSourceDP = isDP(sourceModel);
2404
- if (!isSourceDP)
2405
- return { status: void 0 };
2630
+ if (!isSourceDP) return { status: void 0 };
2406
2631
  switch (status) {
2407
2632
  case "published":
2408
2633
  return { status: "published" };
@@ -2432,7 +2657,7 @@ const relations = {
2432
2657
  ctx.request?.query?.locale
2433
2658
  );
2434
2659
  const { status } = validateStatus(sourceUid, ctx.request?.query?.status);
2435
- const permissionChecker2 = getService$1("permission-checker").create({
2660
+ const permissionChecker2 = getService$2("permission-checker").create({
2436
2661
  userAbility,
2437
2662
  model
2438
2663
  });
@@ -2457,7 +2682,7 @@ const relations = {
2457
2682
  where.id = id;
2458
2683
  }
2459
2684
  const permissionQuery = await permissionChecker2.sanitizedQuery.read(ctx.query);
2460
- const populate = await getService$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
2685
+ const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
2461
2686
  const currentEntity = await strapi.db.query(model).findOne({
2462
2687
  where,
2463
2688
  populate
@@ -2472,7 +2697,7 @@ const relations = {
2472
2697
  }
2473
2698
  entryId = currentEntity.id;
2474
2699
  }
2475
- const modelConfig = isComponent2 ? await getService$1("components").findConfiguration(sourceSchema) : await getService$1("content-types").findConfiguration(sourceSchema);
2700
+ const modelConfig = isComponent2 ? await getService$2("components").findConfiguration(sourceSchema) : await getService$2("content-types").findConfiguration(sourceSchema);
2476
2701
  const targetSchema = strapi.getModel(targetUid);
2477
2702
  const mainField = fp.flow(
2478
2703
  fp.prop(`metadatas.${targetField}.edit.mainField`),
@@ -2495,7 +2720,7 @@ const relations = {
2495
2720
  attribute,
2496
2721
  fieldsToSelect,
2497
2722
  mainField,
2498
- source: { schema: sourceSchema },
2723
+ source: { schema: sourceSchema, isLocalized: isSourceLocalized },
2499
2724
  target: { schema: targetSchema, isLocalized: isTargetLocalized },
2500
2725
  sourceSchema,
2501
2726
  targetSchema,
@@ -2517,7 +2742,8 @@ const relations = {
2517
2742
  fieldsToSelect,
2518
2743
  mainField,
2519
2744
  source: {
2520
- schema: { uid: sourceUid, modelType: sourceModelType }
2745
+ schema: { uid: sourceUid, modelType: sourceModelType },
2746
+ isLocalized: isSourceLocalized
2521
2747
  },
2522
2748
  target: {
2523
2749
  schema: { uid: targetUid },
@@ -2525,7 +2751,7 @@ const relations = {
2525
2751
  }
2526
2752
  } = await this.extractAndValidateRequestInfo(ctx, id);
2527
2753
  const { idsToOmit, idsToInclude, _q, ...query } = ctx.request.query;
2528
- const permissionChecker2 = getService$1("permission-checker").create({
2754
+ const permissionChecker2 = getService$2("permission-checker").create({
2529
2755
  userAbility: ctx.state.userAbility,
2530
2756
  model: targetUid
2531
2757
  });
@@ -2559,9 +2785,12 @@ const relations = {
2559
2785
  if (!fp.isEmpty(publishedAt)) {
2560
2786
  where[`${alias}.published_at`] = publishedAt;
2561
2787
  }
2562
- if (filterByLocale) {
2788
+ if (isTargetLocalized && locale) {
2563
2789
  where[`${alias}.locale`] = locale;
2564
2790
  }
2791
+ if (isSourceLocalized && locale) {
2792
+ where.locale = locale;
2793
+ }
2565
2794
  if ((idsToInclude?.length ?? 0) !== 0) {
2566
2795
  where[`${alias}.id`].$notIn = idsToInclude;
2567
2796
  }
@@ -2579,7 +2808,8 @@ const relations = {
2579
2808
  id: { $notIn: fp.uniq(idsToOmit) }
2580
2809
  });
2581
2810
  }
2582
- const res = await strapi.db.query(targetUid).findPage(strapi.get("query-params").transform(targetUid, queryParams));
2811
+ const dbQuery = strapi.get("query-params").transform(targetUid, queryParams);
2812
+ const res = await strapi.db.query(targetUid).findPage(dbQuery);
2583
2813
  ctx.body = {
2584
2814
  ...res,
2585
2815
  results: await addStatusToRelations(targetUid, res.results)
@@ -2594,21 +2824,33 @@ const relations = {
2594
2824
  attribute,
2595
2825
  targetField,
2596
2826
  fieldsToSelect,
2597
- source: {
2598
- schema: { uid: sourceUid }
2599
- },
2600
- target: {
2601
- schema: { uid: targetUid }
2602
- }
2827
+ status,
2828
+ source: { schema: sourceSchema },
2829
+ target: { schema: targetSchema }
2603
2830
  } = await this.extractAndValidateRequestInfo(ctx, id);
2604
- const permissionQuery = await getService$1("permission-checker").create({ userAbility, model: targetUid }).sanitizedQuery.read({ fields: fieldsToSelect });
2831
+ const { uid: sourceUid } = sourceSchema;
2832
+ const { uid: targetUid } = targetSchema;
2833
+ const permissionQuery = await getService$2("permission-checker").create({ userAbility, model: targetUid }).sanitizedQuery.read({ fields: fieldsToSelect });
2605
2834
  const dbQuery = strapi.db.query(sourceUid);
2606
2835
  const loadRelations = strapiUtils.relations.isAnyToMany(attribute) ? (...args) => dbQuery.loadPages(...args) : (...args) => dbQuery.load(...args).then((res2) => ({ results: res2 ? [res2] : [] }));
2836
+ const filters = {};
2837
+ if (sourceSchema?.options?.draftAndPublish) {
2838
+ if (targetSchema?.options?.draftAndPublish) {
2839
+ if (status === "published") {
2840
+ filters.publishedAt = { $notNull: true };
2841
+ } else {
2842
+ filters.publishedAt = { $null: true };
2843
+ }
2844
+ }
2845
+ } else if (targetSchema?.options?.draftAndPublish) {
2846
+ filters.publishedAt = { $null: true };
2847
+ }
2607
2848
  const res = await loadRelations({ id: entryId }, targetField, {
2608
- select: ["id", "documentId", "locale", "publishedAt"],
2849
+ select: ["id", "documentId", "locale", "publishedAt", "updatedAt"],
2609
2850
  ordering: "desc",
2610
2851
  page: ctx.request.query.page,
2611
- pageSize: ctx.request.query.pageSize
2852
+ pageSize: ctx.request.query.pageSize,
2853
+ filters
2612
2854
  });
2613
2855
  const loadedIds = res.results.map((item) => item.id);
2614
2856
  addFiltersClause(permissionQuery, { id: { $in: loadedIds } });
@@ -2629,10 +2871,10 @@ const relations = {
2629
2871
  }
2630
2872
  };
2631
2873
  const buildPopulateFromQuery = async (query, model) => {
2632
- return getService$1("populate-builder")(model).populateFromQuery(query).populateDeep(Infinity).countRelations().build();
2874
+ return getService$2("populate-builder")(model).populateFromQuery(query).populateDeep(Infinity).countRelations().build();
2633
2875
  };
2634
2876
  const findDocument = async (query, uid2, opts = {}) => {
2635
- const documentManager2 = getService$1("document-manager");
2877
+ const documentManager2 = getService$2("document-manager");
2636
2878
  const populate = await buildPopulateFromQuery(query, uid2);
2637
2879
  return documentManager2.findMany({ ...opts, populate }, uid2).then((documents) => documents[0]);
2638
2880
  };
@@ -2640,8 +2882,8 @@ const createOrUpdateDocument = async (ctx, opts) => {
2640
2882
  const { user, userAbility } = ctx.state;
2641
2883
  const { model } = ctx.params;
2642
2884
  const { body, query } = ctx.request;
2643
- const documentManager2 = getService$1("document-manager");
2644
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2885
+ const documentManager2 = getService$2("document-manager");
2886
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2645
2887
  if (permissionChecker2.cannot.create() && permissionChecker2.cannot.update()) {
2646
2888
  throw new strapiUtils.errors.ForbiddenError();
2647
2889
  }
@@ -2682,7 +2924,7 @@ const singleTypes = {
2682
2924
  const { userAbility } = ctx.state;
2683
2925
  const { model } = ctx.params;
2684
2926
  const { query = {} } = ctx.request;
2685
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2927
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2686
2928
  if (permissionChecker2.cannot.read()) {
2687
2929
  return ctx.forbidden();
2688
2930
  }
@@ -2716,7 +2958,7 @@ const singleTypes = {
2716
2958
  async createOrUpdate(ctx) {
2717
2959
  const { userAbility } = ctx.state;
2718
2960
  const { model } = ctx.params;
2719
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2961
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2720
2962
  const document = await createOrUpdateDocument(ctx);
2721
2963
  const sanitizedDocument = await permissionChecker2.sanitizeOutput(document);
2722
2964
  ctx.body = await formatDocumentWithMetadata(permissionChecker2, model, sanitizedDocument);
@@ -2725,8 +2967,8 @@ const singleTypes = {
2725
2967
  const { userAbility } = ctx.state;
2726
2968
  const { model } = ctx.params;
2727
2969
  const { query = {} } = ctx.request;
2728
- const documentManager2 = getService$1("document-manager");
2729
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2970
+ const documentManager2 = getService$2("document-manager");
2971
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2730
2972
  if (permissionChecker2.cannot.delete()) {
2731
2973
  return ctx.forbidden();
2732
2974
  }
@@ -2754,8 +2996,8 @@ const singleTypes = {
2754
2996
  const { userAbility } = ctx.state;
2755
2997
  const { model } = ctx.params;
2756
2998
  const { query = {} } = ctx.request;
2757
- const documentManager2 = getService$1("document-manager");
2758
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
2999
+ const documentManager2 = getService$2("document-manager");
3000
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2759
3001
  if (permissionChecker2.cannot.publish()) {
2760
3002
  return ctx.forbidden();
2761
3003
  }
@@ -2783,8 +3025,8 @@ const singleTypes = {
2783
3025
  body: { discardDraft, ...body },
2784
3026
  query = {}
2785
3027
  } = ctx.request;
2786
- const documentManager2 = getService$1("document-manager");
2787
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
3028
+ const documentManager2 = getService$2("document-manager");
3029
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2788
3030
  if (permissionChecker2.cannot.unpublish()) {
2789
3031
  return ctx.forbidden();
2790
3032
  }
@@ -2818,8 +3060,8 @@ const singleTypes = {
2818
3060
  const { userAbility } = ctx.state;
2819
3061
  const { model } = ctx.params;
2820
3062
  const { body, query = {} } = ctx.request;
2821
- const documentManager2 = getService$1("document-manager");
2822
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
3063
+ const documentManager2 = getService$2("document-manager");
3064
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2823
3065
  if (permissionChecker2.cannot.discard()) {
2824
3066
  return ctx.forbidden();
2825
3067
  }
@@ -2842,8 +3084,8 @@ const singleTypes = {
2842
3084
  const { userAbility } = ctx.state;
2843
3085
  const { model } = ctx.params;
2844
3086
  const { query } = ctx.request;
2845
- const documentManager2 = getService$1("document-manager");
2846
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
3087
+ const documentManager2 = getService$2("document-manager");
3088
+ const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
2847
3089
  const { locale } = await getDocumentLocaleAndStatus(query, model);
2848
3090
  if (permissionChecker2.cannot.read()) {
2849
3091
  return ctx.forbidden();
@@ -2867,7 +3109,7 @@ const uid$1 = {
2867
3109
  const { query = {} } = ctx.request;
2868
3110
  const { locale } = await getDocumentLocaleAndStatus(query, contentTypeUID);
2869
3111
  await validateUIDField(contentTypeUID, field);
2870
- const uidService = getService$1("uid");
3112
+ const uidService = getService$2("uid");
2871
3113
  ctx.body = {
2872
3114
  data: await uidService.generateUIDField({ contentTypeUID, field, data, locale })
2873
3115
  };
@@ -2879,7 +3121,7 @@ const uid$1 = {
2879
3121
  const { query = {} } = ctx.request;
2880
3122
  const { locale } = await getDocumentLocaleAndStatus(query, contentTypeUID);
2881
3123
  await validateUIDField(contentTypeUID, field);
2882
- const uidService = getService$1("uid");
3124
+ const uidService = getService$2("uid");
2883
3125
  const isAvailable = await uidService.checkUIDAvailability({
2884
3126
  contentTypeUID,
2885
3127
  field,
@@ -2900,7 +3142,8 @@ const controllers = {
2900
3142
  relations,
2901
3143
  "single-types": singleTypes,
2902
3144
  uid: uid$1,
2903
- ...history.controllers ? history.controllers : {}
3145
+ ...history.controllers ? history.controllers : {},
3146
+ ...preview.controllers ? preview.controllers : {}
2904
3147
  };
2905
3148
  const keys = {
2906
3149
  CONFIGURATION: "configuration"
@@ -3029,18 +3272,15 @@ async function syncMetadatas(configuration, schema) {
3029
3272
  ___default.default.set(updatedMeta, ["list", "searchable"], false);
3030
3273
  ___default.default.set(acc, [key], updatedMeta);
3031
3274
  }
3032
- if (!___default.default.has(edit, "mainField"))
3033
- return acc;
3275
+ if (!___default.default.has(edit, "mainField")) return acc;
3034
3276
  if (!isRelation$1(attr)) {
3035
3277
  ___default.default.set(updatedMeta, "edit", ___default.default.omit(edit, ["mainField"]));
3036
3278
  ___default.default.set(acc, [key], updatedMeta);
3037
3279
  return acc;
3038
3280
  }
3039
- if (edit.mainField === "id")
3040
- return acc;
3281
+ if (edit.mainField === "id") return acc;
3041
3282
  const targetSchema = getTargetSchema(attr.targetModel);
3042
- if (!targetSchema)
3043
- return acc;
3283
+ if (!targetSchema) return acc;
3044
3284
  if (!isSortable(targetSchema, edit.mainField) && !isListable(targetSchema, edit.mainField)) {
3045
3285
  ___default.default.set(updatedMeta, ["edit", "mainField"], getDefaultMainField(targetSchema));
3046
3286
  ___default.default.set(acc, [key], updatedMeta);
@@ -3051,12 +3291,12 @@ async function syncMetadatas(configuration, schema) {
3051
3291
  return ___default.default.assign(metasWithDefaults, updatedMetas);
3052
3292
  }
3053
3293
  const getTargetSchema = (targetModel) => {
3054
- return getService$1("content-types").findContentType(targetModel);
3294
+ return getService$2("content-types").findContentType(targetModel);
3055
3295
  };
3056
3296
  const DEFAULT_LIST_LENGTH = 4;
3057
3297
  const MAX_ROW_SIZE = 12;
3058
3298
  const isAllowedFieldSize = (type, size) => {
3059
- const { getFieldSize } = getService$1("field-sizes");
3299
+ const { getFieldSize } = getService$2("field-sizes");
3060
3300
  const fieldSize = getFieldSize(type);
3061
3301
  if (!fieldSize.isResizable && size !== fieldSize.default) {
3062
3302
  return false;
@@ -3064,7 +3304,7 @@ const isAllowedFieldSize = (type, size) => {
3064
3304
  return size <= MAX_ROW_SIZE;
3065
3305
  };
3066
3306
  const getDefaultFieldSize = (attribute) => {
3067
- const { hasFieldSize, getFieldSize } = getService$1("field-sizes");
3307
+ const { hasFieldSize, getFieldSize } = getService$2("field-sizes");
3068
3308
  return getFieldSize(hasFieldSize(attribute.customField) ? attribute.customField : attribute.type).default;
3069
3309
  };
3070
3310
  async function createDefaultLayouts(schema) {
@@ -3085,8 +3325,7 @@ function createDefaultEditLayout(schema) {
3085
3325
  return appendToEditLayout([], keys2, schema);
3086
3326
  }
3087
3327
  function syncLayouts(configuration, schema) {
3088
- if (___default.default.isEmpty(configuration.layouts))
3089
- return createDefaultLayouts(schema);
3328
+ if (___default.default.isEmpty(configuration.layouts)) return createDefaultLayouts(schema);
3090
3329
  const { list = [], editRelations = [], edit = [] } = configuration.layouts || {};
3091
3330
  let cleanList = list.filter((attr) => isListable(schema, attr));
3092
3331
  const cleanEditRelations = editRelations.filter(
@@ -3097,9 +3336,8 @@ function syncLayouts(configuration, schema) {
3097
3336
  for (const row of edit) {
3098
3337
  const newRow = [];
3099
3338
  for (const el of row) {
3100
- if (!hasEditableAttribute(schema, el.name))
3101
- continue;
3102
- const { hasFieldSize } = getService$1("field-sizes");
3339
+ if (!hasEditableAttribute(schema, el.name)) continue;
3340
+ const { hasFieldSize } = getService$2("field-sizes");
3103
3341
  const fieldType = hasFieldSize(schema.attributes[el.name].customField) ? schema.attributes[el.name].customField : schema.attributes[el.name].type;
3104
3342
  if (!isAllowedFieldSize(fieldType, el.size)) {
3105
3343
  elementsToReAppend.push(el.name);
@@ -3129,8 +3367,7 @@ function syncLayouts(configuration, schema) {
3129
3367
  };
3130
3368
  }
3131
3369
  const appendToEditLayout = (layout = [], keysToAppend, schema) => {
3132
- if (keysToAppend.length === 0)
3133
- return layout;
3370
+ if (keysToAppend.length === 0) return layout;
3134
3371
  let currentRowIndex = Math.max(layout.length - 1, 0);
3135
3372
  if (!layout[currentRowIndex]) {
3136
3373
  layout[currentRowIndex] = [];
@@ -3239,17 +3476,17 @@ const configurationService$1 = createConfigurationService({
3239
3476
  isComponent: true,
3240
3477
  prefix: STORE_KEY_PREFIX,
3241
3478
  getModels() {
3242
- const { toContentManagerModel } = getService$1("data-mapper");
3479
+ const { toContentManagerModel } = getService$2("data-mapper");
3243
3480
  return fp.mapValues(toContentManagerModel, strapi.components);
3244
3481
  }
3245
3482
  });
3246
3483
  const components = ({ strapi: strapi2 }) => ({
3247
3484
  findAllComponents() {
3248
- const { toContentManagerModel } = getService$1("data-mapper");
3485
+ const { toContentManagerModel } = getService$2("data-mapper");
3249
3486
  return Object.values(strapi2.components).map(toContentManagerModel);
3250
3487
  },
3251
3488
  findComponent(uid2) {
3252
- const { toContentManagerModel } = getService$1("data-mapper");
3489
+ const { toContentManagerModel } = getService$2("data-mapper");
3253
3490
  const component = strapi2.components[uid2];
3254
3491
  return fp.isNil(component) ? component : toContentManagerModel(component);
3255
3492
  },
@@ -3300,17 +3537,17 @@ const configurationService = createConfigurationService({
3300
3537
  storeUtils,
3301
3538
  prefix: "content_types",
3302
3539
  getModels() {
3303
- const { toContentManagerModel } = getService$1("data-mapper");
3540
+ const { toContentManagerModel } = getService$2("data-mapper");
3304
3541
  return fp.mapValues(toContentManagerModel, strapi.contentTypes);
3305
3542
  }
3306
3543
  });
3307
3544
  const service = ({ strapi: strapi2 }) => ({
3308
3545
  findAllContentTypes() {
3309
- const { toContentManagerModel } = getService$1("data-mapper");
3546
+ const { toContentManagerModel } = getService$2("data-mapper");
3310
3547
  return Object.values(strapi2.contentTypes).map(toContentManagerModel);
3311
3548
  },
3312
3549
  findContentType(uid2) {
3313
- const { toContentManagerModel } = getService$1("data-mapper");
3550
+ const { toContentManagerModel } = getService$2("data-mapper");
3314
3551
  const contentType = strapi2.contentTypes[uid2];
3315
3552
  return fp.isNil(contentType) ? contentType : toContentManagerModel(contentType);
3316
3553
  },
@@ -3339,7 +3576,7 @@ const service = ({ strapi: strapi2 }) => ({
3339
3576
  return this.findConfiguration(contentType);
3340
3577
  },
3341
3578
  findComponentsConfigurations(contentType) {
3342
- return getService$1("components").findComponentsConfigurations(contentType);
3579
+ return getService$2("components").findComponentsConfigurations(contentType);
3343
3580
  },
3344
3581
  syncConfigurations() {
3345
3582
  return configurationService.syncConfigurations();
@@ -3611,7 +3848,7 @@ const permission = ({ strapi: strapi2 }) => ({
3611
3848
  return userAbility.can(action);
3612
3849
  },
3613
3850
  async registerPermissions() {
3614
- const displayedContentTypes = getService$1("content-types").findDisplayedContentTypes();
3851
+ const displayedContentTypes = getService$2("content-types").findDisplayedContentTypes();
3615
3852
  const contentTypesUids = displayedContentTypes.map(fp.prop("uid"));
3616
3853
  const actions = [
3617
3854
  {
@@ -3887,7 +4124,7 @@ const getQueryPopulate = async (uid2, query) => {
3887
4124
  return populateQuery;
3888
4125
  };
3889
4126
  const buildDeepPopulate = (uid2) => {
3890
- return getService$1("populate-builder")(uid2).populateDeep(Infinity).countRelations().build();
4127
+ return getService$2("populate-builder")(uid2).populateDeep(Infinity).countRelations().build();
3891
4128
  };
3892
4129
  const populateBuilder = (uid2) => {
3893
4130
  let getInitialPopulate = async () => {
@@ -4072,7 +4309,9 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
4072
4309
  */
4073
4310
  async getAvailableLocales(uid2, version, allVersions, validatableFields = []) {
4074
4311
  const versionsByLocale = fp.groupBy("locale", allVersions);
4075
- delete versionsByLocale[version.locale];
4312
+ if (version.locale) {
4313
+ delete versionsByLocale[version.locale];
4314
+ }
4076
4315
  const model = strapi2.getModel(uid2);
4077
4316
  const keysToKeep = [...AVAILABLE_LOCALES_FIELDS, ...validatableFields];
4078
4317
  const traversalFunction = async (localeVersion) => strapiUtils.traverseEntity(
@@ -4119,8 +4358,7 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
4119
4358
  const matchStatus = status === "published" ? v.publishedAt !== null : v.publishedAt === null;
4120
4359
  return matchLocale && matchStatus;
4121
4360
  });
4122
- if (!availableStatus)
4123
- return availableStatus;
4361
+ if (!availableStatus) return availableStatus;
4124
4362
  return fp.pick(AVAILABLE_STATUS_FIELDS, availableStatus);
4125
4363
  },
4126
4364
  /**
@@ -4130,8 +4368,7 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
4130
4368
  * @returns
4131
4369
  */
4132
4370
  async getManyAvailableStatus(uid2, documents) {
4133
- if (!documents.length)
4134
- return [];
4371
+ if (!documents.length) return [];
4135
4372
  const status = documents[0].publishedAt !== null ? "published" : "draft";
4136
4373
  const locale = documents[0]?.locale;
4137
4374
  const otherStatus = status === "published" ? "draft" : "published";
@@ -4158,10 +4395,8 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
4158
4395
  } else if (otherVersion) {
4159
4396
  draftVersion = otherVersion;
4160
4397
  }
4161
- if (!draftVersion)
4162
- return CONTENT_MANAGER_STATUS.PUBLISHED;
4163
- if (!publishedVersion)
4164
- return CONTENT_MANAGER_STATUS.DRAFT;
4398
+ if (!draftVersion) return CONTENT_MANAGER_STATUS.PUBLISHED;
4399
+ if (!publishedVersion) return CONTENT_MANAGER_STATUS.DRAFT;
4165
4400
  const isDraftModified = getIsVersionLatestModification(draftVersion, publishedVersion);
4166
4401
  return isDraftModified ? CONTENT_MANAGER_STATUS.MODIFIED : CONTENT_MANAGER_STATUS.PUBLISHED;
4167
4402
  },
@@ -4428,7 +4663,8 @@ const services = {
4428
4663
  permission,
4429
4664
  "populate-builder": populateBuilder$1,
4430
4665
  uid,
4431
- ...history.services ? history.services : {}
4666
+ ...history.services ? history.services : {},
4667
+ ...preview.services ? preview.services : {}
4432
4668
  };
4433
4669
  const index = () => {
4434
4670
  return {