@strapi/content-manager 0.0.0-next.b0db56479de441dfe8feb37a43c7f6f6fecf75c1 → 0.0.0-next.b4e84114b7bd2b58e34af3f2a7febca9845e6f86

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 (488) hide show
  1. package/dist/admin/chunks/CardDragPreview-DwuraT0K.js +80 -0
  2. package/dist/admin/chunks/CardDragPreview-DwuraT0K.js.map +1 -0
  3. package/dist/admin/chunks/CardDragPreview-_dubYgXO.js +82 -0
  4. package/dist/admin/chunks/CardDragPreview-_dubYgXO.js.map +1 -0
  5. package/dist/admin/chunks/ComponentConfigurationPage-DRmgLwro.js +298 -0
  6. package/dist/admin/chunks/ComponentConfigurationPage-DRmgLwro.js.map +1 -0
  7. package/dist/admin/chunks/ComponentConfigurationPage-hcjFAaTt.js +276 -0
  8. package/dist/admin/chunks/ComponentConfigurationPage-hcjFAaTt.js.map +1 -0
  9. package/dist/admin/chunks/ComponentIcon-BZcTc4rj.js +153 -0
  10. package/dist/admin/chunks/ComponentIcon-BZcTc4rj.js.map +1 -0
  11. package/dist/admin/chunks/ComponentIcon-C-EjOUPA.js +176 -0
  12. package/dist/admin/chunks/ComponentIcon-C-EjOUPA.js.map +1 -0
  13. package/dist/admin/chunks/EditConfigurationPage-C5ryBORg.js +180 -0
  14. package/dist/admin/chunks/EditConfigurationPage-C5ryBORg.js.map +1 -0
  15. package/dist/admin/chunks/EditConfigurationPage-ORXwng8p.js +158 -0
  16. package/dist/admin/chunks/EditConfigurationPage-ORXwng8p.js.map +1 -0
  17. package/dist/admin/chunks/EditViewPage-CgsVkvgj.js +337 -0
  18. package/dist/admin/chunks/EditViewPage-CgsVkvgj.js.map +1 -0
  19. package/dist/admin/chunks/EditViewPage-Df6_T4t7.js +314 -0
  20. package/dist/admin/chunks/EditViewPage-Df6_T4t7.js.map +1 -0
  21. package/dist/admin/chunks/FieldTypeIcon-BY6MrVF4.js +56 -0
  22. package/dist/admin/chunks/FieldTypeIcon-BY6MrVF4.js.map +1 -0
  23. package/dist/admin/chunks/FieldTypeIcon-Bxh-7Jin.js +58 -0
  24. package/dist/admin/chunks/FieldTypeIcon-Bxh-7Jin.js.map +1 -0
  25. package/dist/admin/chunks/Form-g52j2TSi.js +955 -0
  26. package/dist/admin/chunks/Form-g52j2TSi.js.map +1 -0
  27. package/dist/admin/chunks/Form-xuxxhsNO.js +978 -0
  28. package/dist/admin/chunks/Form-xuxxhsNO.js.map +1 -0
  29. package/dist/admin/chunks/History-D9EcggaE.js +1380 -0
  30. package/dist/admin/chunks/History-D9EcggaE.js.map +1 -0
  31. package/dist/admin/chunks/History-wYB-tJbr.js +1357 -0
  32. package/dist/admin/chunks/History-wYB-tJbr.js.map +1 -0
  33. package/dist/admin/chunks/Input-F_UqXLzm.js +6996 -0
  34. package/dist/admin/chunks/Input-F_UqXLzm.js.map +1 -0
  35. package/dist/admin/chunks/Input-qBTXe_I4.js +6965 -0
  36. package/dist/admin/chunks/Input-qBTXe_I4.js.map +1 -0
  37. package/dist/admin/chunks/ListConfigurationPage-B_v1ysCO.js +818 -0
  38. package/dist/admin/chunks/ListConfigurationPage-B_v1ysCO.js.map +1 -0
  39. package/dist/admin/chunks/ListConfigurationPage-DnwGzMJ3.js +795 -0
  40. package/dist/admin/chunks/ListConfigurationPage-DnwGzMJ3.js.map +1 -0
  41. package/dist/admin/chunks/ListViewPage-D05DSlSi.js +1154 -0
  42. package/dist/admin/chunks/ListViewPage-D05DSlSi.js.map +1 -0
  43. package/dist/admin/chunks/ListViewPage-DAmeMGMI.js +1132 -0
  44. package/dist/admin/chunks/ListViewPage-DAmeMGMI.js.map +1 -0
  45. package/dist/admin/chunks/NoContentTypePage-D6Q57D_I.js +57 -0
  46. package/dist/admin/chunks/NoContentTypePage-D6Q57D_I.js.map +1 -0
  47. package/dist/admin/chunks/NoContentTypePage-HciaFArd.js +59 -0
  48. package/dist/admin/chunks/NoContentTypePage-HciaFArd.js.map +1 -0
  49. package/dist/admin/chunks/NoPermissionsPage-CHgR2_8S.js +36 -0
  50. package/dist/admin/chunks/NoPermissionsPage-CHgR2_8S.js.map +1 -0
  51. package/dist/admin/chunks/NoPermissionsPage-CNrw1E8U.js +38 -0
  52. package/dist/admin/chunks/NoPermissionsPage-CNrw1E8U.js.map +1 -0
  53. package/dist/admin/chunks/Preview-CfwUW26E.js +553 -0
  54. package/dist/admin/chunks/Preview-CfwUW26E.js.map +1 -0
  55. package/dist/admin/chunks/Preview-DmZ0DoPB.js +531 -0
  56. package/dist/admin/chunks/Preview-DmZ0DoPB.js.map +1 -0
  57. package/dist/admin/chunks/Relations-D3RzvR4H.js +1318 -0
  58. package/dist/admin/chunks/Relations-D3RzvR4H.js.map +1 -0
  59. package/dist/admin/chunks/Relations-DMJRnyAR.js +1291 -0
  60. package/dist/admin/chunks/Relations-DMJRnyAR.js.map +1 -0
  61. package/dist/admin/chunks/ar-DckYq_WK.js +222 -0
  62. package/dist/admin/chunks/ar-DckYq_WK.js.map +1 -0
  63. package/dist/admin/chunks/ar-DeQBSsfl.js +227 -0
  64. package/dist/{_chunks/ru-BT3ybNny.js.map → admin/chunks/ar-DeQBSsfl.js.map} +1 -1
  65. package/dist/admin/chunks/ca-ClDTvatJ.js +202 -0
  66. package/dist/admin/chunks/ca-ClDTvatJ.js.map +1 -0
  67. package/dist/admin/chunks/ca-DviY7mRj.js +197 -0
  68. package/dist/{_chunks/de-CCEmbAah.js.map → admin/chunks/ca-DviY7mRj.js.map} +1 -1
  69. package/dist/admin/chunks/cs-BJFxwIWj.js +126 -0
  70. package/dist/{_chunks/ms-BuFotyP_.js.map → admin/chunks/cs-BJFxwIWj.js.map} +1 -1
  71. package/dist/admin/chunks/cs-C7OSYFQ7.js +122 -0
  72. package/dist/{_chunks/cs-CkJy6B2v.js.map → admin/chunks/cs-C7OSYFQ7.js.map} +1 -1
  73. package/dist/admin/chunks/de-5QRlDHyR.js +195 -0
  74. package/dist/{_chunks/ja-7sfIbjxE.js.map → admin/chunks/de-5QRlDHyR.js.map} +1 -1
  75. package/dist/admin/chunks/de-CbImAUA5.js +200 -0
  76. package/dist/{_chunks/gu-BRmF601H.js.map → admin/chunks/de-CbImAUA5.js.map} +1 -1
  77. package/dist/admin/chunks/en-C1CjdAtC.js +313 -0
  78. package/dist/{_chunks/en-69jRDM9j.mjs.map → admin/chunks/en-C1CjdAtC.js.map} +1 -1
  79. package/dist/admin/chunks/en-LfhocNG2.js +308 -0
  80. package/dist/{_chunks/en-DAgtrRoa.js.map → admin/chunks/en-LfhocNG2.js.map} +1 -1
  81. package/dist/admin/chunks/es-C8vLuvZL.js +197 -0
  82. package/dist/admin/chunks/es-C8vLuvZL.js.map +1 -0
  83. package/dist/admin/chunks/es-DkoWSExG.js +192 -0
  84. package/dist/{_chunks/ko-woFZPmLk.js.map → admin/chunks/es-DkoWSExG.js.map} +1 -1
  85. package/dist/admin/chunks/eu-BG1xX7HK.js +198 -0
  86. package/dist/admin/chunks/eu-BG1xX7HK.js.map +1 -0
  87. package/dist/admin/chunks/eu-BJW3AvXu.js +203 -0
  88. package/dist/admin/chunks/eu-BJW3AvXu.js.map +1 -0
  89. package/dist/admin/chunks/fr-CFdRaRVj.js +215 -0
  90. package/dist/admin/chunks/fr-CFdRaRVj.js.map +1 -0
  91. package/dist/admin/chunks/fr-gQSilC7w.js +220 -0
  92. package/dist/admin/chunks/fr-gQSilC7w.js.map +1 -0
  93. package/dist/admin/chunks/gu-D5MMMXRs.js +196 -0
  94. package/dist/admin/chunks/gu-D5MMMXRs.js.map +1 -0
  95. package/dist/admin/chunks/gu-DPU4wyx7.js +201 -0
  96. package/dist/{_chunks/eu-VDH-3ovk.js.map → admin/chunks/gu-DPU4wyx7.js.map} +1 -1
  97. package/dist/admin/chunks/hi-Dp4omeBb.js +201 -0
  98. package/dist/admin/chunks/hi-Dp4omeBb.js.map +1 -0
  99. package/dist/admin/chunks/hi-lp17SCjr.js +196 -0
  100. package/dist/admin/chunks/hi-lp17SCjr.js.map +1 -0
  101. package/dist/{_chunks/hooks-BAaaKPS_.js → admin/chunks/hooks-D-sOYd1s.js} +6 -3
  102. package/dist/admin/chunks/hooks-D-sOYd1s.js.map +1 -0
  103. package/dist/admin/chunks/hooks-DMvik5y_.js +7 -0
  104. package/dist/admin/chunks/hooks-DMvik5y_.js.map +1 -0
  105. package/dist/admin/chunks/hu-CLka1U2C.js +198 -0
  106. package/dist/admin/chunks/hu-CLka1U2C.js.map +1 -0
  107. package/dist/admin/chunks/hu-CtFJuhTd.js +203 -0
  108. package/dist/admin/chunks/hu-CtFJuhTd.js.map +1 -0
  109. package/dist/admin/chunks/id-D7V5S1rB.js +161 -0
  110. package/dist/{_chunks/it-DkBIs7vD.js.map → admin/chunks/id-D7V5S1rB.js.map} +1 -1
  111. package/dist/admin/chunks/id-USfY9m1g.js +156 -0
  112. package/dist/admin/chunks/id-USfY9m1g.js.map +1 -0
  113. package/dist/admin/chunks/index-DX7uPg4s.js +5350 -0
  114. package/dist/admin/chunks/index-DX7uPg4s.js.map +1 -0
  115. package/dist/admin/chunks/index-DmMcoOHn.js +5416 -0
  116. package/dist/admin/chunks/index-DmMcoOHn.js.map +1 -0
  117. package/dist/admin/chunks/it-BAHrwmYS.js +158 -0
  118. package/dist/admin/chunks/it-BAHrwmYS.js.map +1 -0
  119. package/dist/admin/chunks/it-CQFpa_Dc.js +163 -0
  120. package/dist/{_chunks/es-9K52xZIr.js.map → admin/chunks/it-CQFpa_Dc.js.map} +1 -1
  121. package/dist/admin/chunks/ja-BWKmBJFT.js +192 -0
  122. package/dist/admin/chunks/ja-BWKmBJFT.js.map +1 -0
  123. package/dist/admin/chunks/ja-jdQM-B79.js +197 -0
  124. package/dist/admin/chunks/ja-jdQM-B79.js.map +1 -0
  125. package/dist/admin/chunks/ko-CgADGBNt.js +191 -0
  126. package/dist/admin/chunks/ko-CgADGBNt.js.map +1 -0
  127. package/dist/admin/chunks/ko-k46sEyzt.js +196 -0
  128. package/dist/admin/chunks/ko-k46sEyzt.js.map +1 -0
  129. package/dist/admin/chunks/layout-BxEpnOP6.js +598 -0
  130. package/dist/admin/chunks/layout-BxEpnOP6.js.map +1 -0
  131. package/dist/admin/chunks/layout-COxNlvCo.js +618 -0
  132. package/dist/admin/chunks/layout-COxNlvCo.js.map +1 -0
  133. package/dist/admin/chunks/ml-CnhCfOn_.js +196 -0
  134. package/dist/admin/chunks/ml-CnhCfOn_.js.map +1 -0
  135. package/dist/admin/chunks/ml-DqxPwODx.js +201 -0
  136. package/dist/admin/chunks/ml-DqxPwODx.js.map +1 -0
  137. package/dist/admin/chunks/ms-Bh09NFff.js +140 -0
  138. package/dist/{_chunks/uk-C8EiqJY7.js.map → admin/chunks/ms-Bh09NFff.js.map} +1 -1
  139. package/dist/admin/chunks/ms-CvSC0OdG.js +145 -0
  140. package/dist/admin/chunks/ms-CvSC0OdG.js.map +1 -0
  141. package/dist/admin/chunks/nl-BEubhS8C.js +203 -0
  142. package/dist/admin/chunks/nl-BEubhS8C.js.map +1 -0
  143. package/dist/admin/chunks/nl-C8HYflTc.js +198 -0
  144. package/dist/admin/chunks/nl-C8HYflTc.js.map +1 -0
  145. package/dist/admin/chunks/objects-C3EebVVe.js +76 -0
  146. package/dist/admin/chunks/objects-C3EebVVe.js.map +1 -0
  147. package/dist/admin/chunks/objects-wl73iEma.js +73 -0
  148. package/dist/admin/chunks/objects-wl73iEma.js.map +1 -0
  149. package/dist/admin/chunks/pl-DWhGDzmM.js +200 -0
  150. package/dist/{_chunks/ca-Cmk45QO6.js.map → admin/chunks/pl-DWhGDzmM.js.map} +1 -1
  151. package/dist/admin/chunks/pl-MFCZJZuZ.js +195 -0
  152. package/dist/admin/chunks/pl-MFCZJZuZ.js.map +1 -0
  153. package/dist/admin/chunks/pt-BR-CPtAXD-4.js +202 -0
  154. package/dist/admin/chunks/pt-BR-CPtAXD-4.js.map +1 -0
  155. package/dist/admin/chunks/pt-BR-CcotyBGJ.js +197 -0
  156. package/dist/{_chunks/pt-BR-BiOz37D9.js.map → admin/chunks/pt-BR-CcotyBGJ.js.map} +1 -1
  157. package/dist/admin/chunks/pt-BoPxN80n.js +96 -0
  158. package/dist/admin/chunks/pt-BoPxN80n.js.map +1 -0
  159. package/dist/admin/chunks/pt-HbmgeiYO.js +93 -0
  160. package/dist/admin/chunks/pt-HbmgeiYO.js.map +1 -0
  161. package/dist/admin/chunks/relations-DZTNnyj0.js +173 -0
  162. package/dist/admin/chunks/relations-DZTNnyj0.js.map +1 -0
  163. package/dist/admin/chunks/relations-wpp_E6PG.js +178 -0
  164. package/dist/admin/chunks/relations-wpp_E6PG.js.map +1 -0
  165. package/dist/admin/chunks/ru-C0op0ALG.js +232 -0
  166. package/dist/admin/chunks/ru-C0op0ALG.js.map +1 -0
  167. package/dist/admin/chunks/ru-CB4BUyQp.js +230 -0
  168. package/dist/admin/chunks/ru-CB4BUyQp.js.map +1 -0
  169. package/dist/admin/chunks/sa-B_FuPyMw.js +201 -0
  170. package/dist/admin/chunks/sa-B_FuPyMw.js.map +1 -0
  171. package/dist/admin/chunks/sa-n_aPA-pU.js +196 -0
  172. package/dist/admin/chunks/sa-n_aPA-pU.js.map +1 -0
  173. package/dist/admin/chunks/sk-D_iXML2C.js +203 -0
  174. package/dist/admin/chunks/sk-D_iXML2C.js.map +1 -0
  175. package/dist/admin/chunks/sk-tn_BDjE2.js +198 -0
  176. package/dist/admin/chunks/sk-tn_BDjE2.js.map +1 -0
  177. package/dist/admin/chunks/sv-BstBC1Yp.js +203 -0
  178. package/dist/admin/chunks/sv-BstBC1Yp.js.map +1 -0
  179. package/dist/admin/chunks/sv-cq4ZrQRd.js +198 -0
  180. package/dist/admin/chunks/sv-cq4ZrQRd.js.map +1 -0
  181. package/dist/admin/chunks/th-lXoOCqPC.js +149 -0
  182. package/dist/{_chunks/th-D9_GfAjc.js.map → admin/chunks/th-lXoOCqPC.js.map} +1 -1
  183. package/dist/admin/chunks/th-mUH7hEtc.js +144 -0
  184. package/dist/admin/chunks/th-mUH7hEtc.js.map +1 -0
  185. package/dist/admin/chunks/tr-CkS6sLIE.js +200 -0
  186. package/dist/admin/chunks/tr-CkS6sLIE.js.map +1 -0
  187. package/dist/admin/chunks/tr-Yt38daxh.js +195 -0
  188. package/dist/admin/chunks/tr-Yt38daxh.js.map +1 -0
  189. package/dist/admin/chunks/uk-B24MoTVg.js +145 -0
  190. package/dist/admin/chunks/uk-B24MoTVg.js.map +1 -0
  191. package/dist/admin/chunks/uk-Cpgmm7gE.js +140 -0
  192. package/dist/admin/chunks/uk-Cpgmm7gE.js.map +1 -0
  193. package/dist/admin/chunks/useDragAndDrop-HYwNDExe.js +247 -0
  194. package/dist/admin/chunks/useDragAndDrop-HYwNDExe.js.map +1 -0
  195. package/dist/admin/chunks/useDragAndDrop-gcqEJMnO.js +271 -0
  196. package/dist/admin/chunks/useDragAndDrop-gcqEJMnO.js.map +1 -0
  197. package/dist/admin/chunks/usePrev-Bjw2dhmq.js +18 -0
  198. package/dist/admin/chunks/usePrev-Bjw2dhmq.js.map +1 -0
  199. package/dist/admin/chunks/usePrev-DIYl-IAL.js +21 -0
  200. package/dist/admin/chunks/usePrev-DIYl-IAL.js.map +1 -0
  201. package/dist/admin/chunks/vi-BGr1X_HZ.js +112 -0
  202. package/dist/admin/chunks/vi-BGr1X_HZ.js.map +1 -0
  203. package/dist/admin/chunks/vi-CvBGlTjr.js +108 -0
  204. package/dist/{_chunks/vi-CJlYDheJ.js.map → admin/chunks/vi-CvBGlTjr.js.map} +1 -1
  205. package/dist/admin/chunks/zh-BmF-sHaT.js +205 -0
  206. package/dist/admin/chunks/zh-BmF-sHaT.js.map +1 -0
  207. package/dist/admin/chunks/zh-DwFu_Kfj.js +210 -0
  208. package/dist/admin/chunks/zh-DwFu_Kfj.js.map +1 -0
  209. package/dist/admin/chunks/zh-Hans-CI0HKio3.js +934 -0
  210. package/dist/{_chunks/zh-Hans-9kOncHGw.js.map → admin/chunks/zh-Hans-CI0HKio3.js.map} +1 -1
  211. package/dist/admin/chunks/zh-Hans-JVK9x7xr.js +953 -0
  212. package/dist/{_chunks/zh-Hans-BPQcRIyH.mjs.map → admin/chunks/zh-Hans-JVK9x7xr.js.map} +1 -1
  213. package/dist/admin/index.js +24 -4
  214. package/dist/admin/index.js.map +1 -1
  215. package/dist/admin/index.mjs +16 -12
  216. package/dist/admin/index.mjs.map +1 -1
  217. package/dist/admin/src/content-manager.d.ts +3 -2
  218. package/dist/admin/src/exports.d.ts +1 -0
  219. package/dist/admin/src/history/services/historyVersion.d.ts +2 -2
  220. package/dist/admin/src/hooks/useDocument.d.ts +21 -4
  221. package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +1 -1
  222. package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +1 -1
  223. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.d.ts +7 -0
  224. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/utils/prismLanguages.d.ts +49 -0
  225. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/constants.d.ts +1 -0
  226. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.d.ts +4 -1
  227. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/Field.d.ts +4 -1
  228. package/dist/admin/src/pages/EditView/components/FormInputs/Relations.d.ts +2 -1
  229. package/dist/admin/src/pages/EditView/components/FormLayout.d.ts +27 -0
  230. package/dist/admin/src/pages/EditView/utils/data.d.ts +1 -0
  231. package/dist/admin/src/preview/components/PreviewContent.d.ts +2 -1
  232. package/dist/admin/src/preview/components/PreviewHeader.d.ts +2 -1
  233. package/dist/admin/src/preview/index.d.ts +2 -3
  234. package/dist/admin/src/preview/pages/Preview.d.ts +1 -1
  235. package/dist/admin/src/preview/services/preview.d.ts +1 -1
  236. package/dist/admin/src/services/api.d.ts +1 -1
  237. package/dist/admin/src/services/components.d.ts +2 -2
  238. package/dist/admin/src/services/contentTypes.d.ts +3 -3
  239. package/dist/admin/src/services/documents.d.ts +16 -19
  240. package/dist/admin/src/services/init.d.ts +1 -1
  241. package/dist/admin/src/services/relations.d.ts +2 -2
  242. package/dist/admin/src/services/uid.d.ts +3 -3
  243. package/dist/server/index.js +5461 -4346
  244. package/dist/server/index.js.map +1 -1
  245. package/dist/server/index.mjs +5433 -4315
  246. package/dist/server/index.mjs.map +1 -1
  247. package/dist/server/src/controllers/utils/metadata.d.ts +2 -1
  248. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
  249. package/dist/server/src/history/controllers/history-version.d.ts +1 -1
  250. package/dist/server/src/history/controllers/history-version.d.ts.map +1 -1
  251. package/dist/server/src/history/services/history.d.ts +3 -3
  252. package/dist/server/src/history/services/history.d.ts.map +1 -1
  253. package/dist/server/src/history/services/utils.d.ts +6 -10
  254. package/dist/server/src/history/services/utils.d.ts.map +1 -1
  255. package/dist/server/src/index.d.ts +3 -2
  256. package/dist/server/src/index.d.ts.map +1 -1
  257. package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -1
  258. package/dist/server/src/preview/index.d.ts.map +1 -1
  259. package/dist/server/src/preview/services/index.d.ts +1 -0
  260. package/dist/server/src/preview/services/index.d.ts.map +1 -1
  261. package/dist/server/src/preview/services/preview-config.d.ts +2 -0
  262. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -1
  263. package/dist/server/src/preview/utils.d.ts +1 -0
  264. package/dist/server/src/preview/utils.d.ts.map +1 -1
  265. package/dist/server/src/register.d.ts.map +1 -1
  266. package/dist/server/src/services/document-metadata.d.ts +4 -2
  267. package/dist/server/src/services/document-metadata.d.ts.map +1 -1
  268. package/dist/server/src/services/index.d.ts +3 -2
  269. package/dist/server/src/services/index.d.ts.map +1 -1
  270. package/dist/server/src/services/utils/configuration/index.d.ts +2 -2
  271. package/dist/server/src/services/utils/configuration/layouts.d.ts +2 -2
  272. package/dist/server/src/services/utils/count.d.ts +1 -1
  273. package/dist/server/src/services/utils/count.d.ts.map +1 -1
  274. package/dist/server/src/services/utils/populate.d.ts +3 -3
  275. package/dist/server/src/services/utils/populate.d.ts.map +1 -1
  276. package/dist/shared/contracts/collection-types.d.ts +0 -1
  277. package/dist/shared/contracts/components.d.ts +0 -1
  278. package/dist/shared/contracts/content-types.d.ts +0 -1
  279. package/dist/shared/contracts/history-versions.d.ts +0 -1
  280. package/dist/shared/contracts/index.d.ts +0 -1
  281. package/dist/shared/contracts/init.d.ts +0 -1
  282. package/dist/shared/contracts/preview.d.ts +0 -1
  283. package/dist/shared/contracts/relations.d.ts +1 -2
  284. package/dist/shared/contracts/relations.d.ts.map +1 -1
  285. package/dist/shared/contracts/review-workflows.d.ts +0 -1
  286. package/dist/shared/contracts/single-types.d.ts +0 -1
  287. package/dist/shared/contracts/uid.d.ts +0 -1
  288. package/dist/shared/index.d.ts +0 -1
  289. package/dist/shared/index.js +35 -24
  290. package/dist/shared/index.js.map +1 -1
  291. package/dist/shared/index.mjs +34 -25
  292. package/dist/shared/index.mjs.map +1 -1
  293. package/package.json +19 -15
  294. package/dist/_chunks/CardDragPreview-C0QyJgRA.js +0 -69
  295. package/dist/_chunks/CardDragPreview-C0QyJgRA.js.map +0 -1
  296. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs +0 -70
  297. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +0 -1
  298. package/dist/_chunks/ComponentConfigurationPage-Cjr64OS0.js +0 -255
  299. package/dist/_chunks/ComponentConfigurationPage-Cjr64OS0.js.map +0 -1
  300. package/dist/_chunks/ComponentConfigurationPage-DKuCF_uX.mjs +0 -236
  301. package/dist/_chunks/ComponentConfigurationPage-DKuCF_uX.mjs.map +0 -1
  302. package/dist/_chunks/ComponentIcon-BXdiCGQp.js +0 -176
  303. package/dist/_chunks/ComponentIcon-BXdiCGQp.js.map +0 -1
  304. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs +0 -157
  305. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +0 -1
  306. package/dist/_chunks/EditConfigurationPage-BeikGxvq.js +0 -151
  307. package/dist/_chunks/EditConfigurationPage-BeikGxvq.js.map +0 -1
  308. package/dist/_chunks/EditConfigurationPage-CyqSP6ru.mjs +0 -132
  309. package/dist/_chunks/EditConfigurationPage-CyqSP6ru.mjs.map +0 -1
  310. package/dist/_chunks/EditViewPage-PrPHZN_9.mjs +0 -254
  311. package/dist/_chunks/EditViewPage-PrPHZN_9.mjs.map +0 -1
  312. package/dist/_chunks/EditViewPage-pyqEgLgP.js +0 -273
  313. package/dist/_chunks/EditViewPage-pyqEgLgP.js.map +0 -1
  314. package/dist/_chunks/Field-DuAYQka5.mjs +0 -5583
  315. package/dist/_chunks/Field-DuAYQka5.mjs.map +0 -1
  316. package/dist/_chunks/Field-fKtb7rWK.js +0 -5615
  317. package/dist/_chunks/Field-fKtb7rWK.js.map +0 -1
  318. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs +0 -50
  319. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +0 -1
  320. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js +0 -49
  321. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +0 -1
  322. package/dist/_chunks/Form-BPXw-S-J.js +0 -779
  323. package/dist/_chunks/Form-BPXw-S-J.js.map +0 -1
  324. package/dist/_chunks/Form-Dxh71ckp.mjs +0 -758
  325. package/dist/_chunks/Form-Dxh71ckp.mjs.map +0 -1
  326. package/dist/_chunks/History-BGGn9JGY.js +0 -994
  327. package/dist/_chunks/History-BGGn9JGY.js.map +0 -1
  328. package/dist/_chunks/History-CGblSVMc.mjs +0 -973
  329. package/dist/_chunks/History-CGblSVMc.mjs.map +0 -1
  330. package/dist/_chunks/ListConfigurationPage-D3Avyi4t.js +0 -652
  331. package/dist/_chunks/ListConfigurationPage-D3Avyi4t.js.map +0 -1
  332. package/dist/_chunks/ListConfigurationPage-TIM0JveM.mjs +0 -632
  333. package/dist/_chunks/ListConfigurationPage-TIM0JveM.mjs.map +0 -1
  334. package/dist/_chunks/ListViewPage-C975eW-t.mjs +0 -850
  335. package/dist/_chunks/ListViewPage-C975eW-t.mjs.map +0 -1
  336. package/dist/_chunks/ListViewPage-DtAHWFMV.js +0 -874
  337. package/dist/_chunks/ListViewPage-DtAHWFMV.js.map +0 -1
  338. package/dist/_chunks/NoContentTypePage-BFjWZX0i.js +0 -51
  339. package/dist/_chunks/NoContentTypePage-BFjWZX0i.js.map +0 -1
  340. package/dist/_chunks/NoContentTypePage-SgNTVGjF.mjs +0 -51
  341. package/dist/_chunks/NoContentTypePage-SgNTVGjF.mjs.map +0 -1
  342. package/dist/_chunks/NoPermissionsPage-D4XYRoPf.mjs +0 -23
  343. package/dist/_chunks/NoPermissionsPage-D4XYRoPf.mjs.map +0 -1
  344. package/dist/_chunks/NoPermissionsPage-j7oulOpl.js +0 -23
  345. package/dist/_chunks/NoPermissionsPage-j7oulOpl.js.map +0 -1
  346. package/dist/_chunks/Preview-Bx1WfmKJ.js +0 -256
  347. package/dist/_chunks/Preview-Bx1WfmKJ.js.map +0 -1
  348. package/dist/_chunks/Preview-Cy6fuAnd.mjs +0 -237
  349. package/dist/_chunks/Preview-Cy6fuAnd.mjs.map +0 -1
  350. package/dist/_chunks/Relations-CXQqwRXC.js +0 -750
  351. package/dist/_chunks/Relations-CXQqwRXC.js.map +0 -1
  352. package/dist/_chunks/Relations-DUrYWw0N.mjs +0 -730
  353. package/dist/_chunks/Relations-DUrYWw0N.mjs.map +0 -1
  354. package/dist/_chunks/ar-BUUWXIYu.js +0 -226
  355. package/dist/_chunks/ar-BUUWXIYu.js.map +0 -1
  356. package/dist/_chunks/ar-CCEVvqGG.mjs +0 -226
  357. package/dist/_chunks/ar-CCEVvqGG.mjs.map +0 -1
  358. package/dist/_chunks/ca-5U32ON2v.mjs +0 -201
  359. package/dist/_chunks/ca-5U32ON2v.mjs.map +0 -1
  360. package/dist/_chunks/ca-Cmk45QO6.js +0 -201
  361. package/dist/_chunks/cs-CM2aBUar.mjs +0 -125
  362. package/dist/_chunks/cs-CM2aBUar.mjs.map +0 -1
  363. package/dist/_chunks/cs-CkJy6B2v.js +0 -125
  364. package/dist/_chunks/de-C72KDNOl.mjs +0 -199
  365. package/dist/_chunks/de-C72KDNOl.mjs.map +0 -1
  366. package/dist/_chunks/de-CCEmbAah.js +0 -199
  367. package/dist/_chunks/en-69jRDM9j.mjs +0 -303
  368. package/dist/_chunks/en-DAgtrRoa.js +0 -303
  369. package/dist/_chunks/es-9K52xZIr.js +0 -196
  370. package/dist/_chunks/es-D34tqjMw.mjs +0 -196
  371. package/dist/_chunks/es-D34tqjMw.mjs.map +0 -1
  372. package/dist/_chunks/eu-CdALomew.mjs +0 -202
  373. package/dist/_chunks/eu-CdALomew.mjs.map +0 -1
  374. package/dist/_chunks/eu-VDH-3ovk.js +0 -202
  375. package/dist/_chunks/fr--pg5jUbt.mjs +0 -216
  376. package/dist/_chunks/fr--pg5jUbt.mjs.map +0 -1
  377. package/dist/_chunks/fr-B2Kyv8Z9.js +0 -216
  378. package/dist/_chunks/fr-B2Kyv8Z9.js.map +0 -1
  379. package/dist/_chunks/gu-BRmF601H.js +0 -200
  380. package/dist/_chunks/gu-CNpaMDpH.mjs +0 -200
  381. package/dist/_chunks/gu-CNpaMDpH.mjs.map +0 -1
  382. package/dist/_chunks/hi-CCJBptSq.js +0 -200
  383. package/dist/_chunks/hi-CCJBptSq.js.map +0 -1
  384. package/dist/_chunks/hi-Dwvd04m3.mjs +0 -200
  385. package/dist/_chunks/hi-Dwvd04m3.mjs.map +0 -1
  386. package/dist/_chunks/hooks-BAaaKPS_.js.map +0 -1
  387. package/dist/_chunks/hooks-E5u1mcgM.mjs +0 -8
  388. package/dist/_chunks/hooks-E5u1mcgM.mjs.map +0 -1
  389. package/dist/_chunks/hu-CeYvaaO0.mjs +0 -202
  390. package/dist/_chunks/hu-CeYvaaO0.mjs.map +0 -1
  391. package/dist/_chunks/hu-sNV_yLYy.js +0 -202
  392. package/dist/_chunks/hu-sNV_yLYy.js.map +0 -1
  393. package/dist/_chunks/id-B5Ser98A.js +0 -160
  394. package/dist/_chunks/id-B5Ser98A.js.map +0 -1
  395. package/dist/_chunks/id-BtwA9WJT.mjs +0 -160
  396. package/dist/_chunks/id-BtwA9WJT.mjs.map +0 -1
  397. package/dist/_chunks/index-Ta--2bRa.mjs +0 -4161
  398. package/dist/_chunks/index-Ta--2bRa.mjs.map +0 -1
  399. package/dist/_chunks/index-_j7lH3CO.js +0 -4181
  400. package/dist/_chunks/index-_j7lH3CO.js.map +0 -1
  401. package/dist/_chunks/it-BrVPqaf1.mjs +0 -162
  402. package/dist/_chunks/it-BrVPqaf1.mjs.map +0 -1
  403. package/dist/_chunks/it-DkBIs7vD.js +0 -162
  404. package/dist/_chunks/ja-7sfIbjxE.js +0 -196
  405. package/dist/_chunks/ja-BHqhDq4V.mjs +0 -196
  406. package/dist/_chunks/ja-BHqhDq4V.mjs.map +0 -1
  407. package/dist/_chunks/ko-HVQRlfUI.mjs +0 -195
  408. package/dist/_chunks/ko-HVQRlfUI.mjs.map +0 -1
  409. package/dist/_chunks/ko-woFZPmLk.js +0 -195
  410. package/dist/_chunks/layout-BDwU2I_y.js +0 -489
  411. package/dist/_chunks/layout-BDwU2I_y.js.map +0 -1
  412. package/dist/_chunks/layout-C8H4oKDo.mjs +0 -471
  413. package/dist/_chunks/layout-C8H4oKDo.mjs.map +0 -1
  414. package/dist/_chunks/ml-BihZwQit.mjs +0 -200
  415. package/dist/_chunks/ml-BihZwQit.mjs.map +0 -1
  416. package/dist/_chunks/ml-C2W8N8k1.js +0 -200
  417. package/dist/_chunks/ml-C2W8N8k1.js.map +0 -1
  418. package/dist/_chunks/ms-BuFotyP_.js +0 -144
  419. package/dist/_chunks/ms-m_WjyWx7.mjs +0 -144
  420. package/dist/_chunks/ms-m_WjyWx7.mjs.map +0 -1
  421. package/dist/_chunks/nl-D4R9gHx5.mjs +0 -202
  422. package/dist/_chunks/nl-D4R9gHx5.mjs.map +0 -1
  423. package/dist/_chunks/nl-bbEOHChV.js +0 -202
  424. package/dist/_chunks/nl-bbEOHChV.js.map +0 -1
  425. package/dist/_chunks/objects-BcXOv6_9.js +0 -47
  426. package/dist/_chunks/objects-BcXOv6_9.js.map +0 -1
  427. package/dist/_chunks/objects-D6yBsdmx.mjs +0 -45
  428. package/dist/_chunks/objects-D6yBsdmx.mjs.map +0 -1
  429. package/dist/_chunks/pl-sbx9mSt_.mjs +0 -199
  430. package/dist/_chunks/pl-sbx9mSt_.mjs.map +0 -1
  431. package/dist/_chunks/pl-uzwG-hk7.js +0 -199
  432. package/dist/_chunks/pl-uzwG-hk7.js.map +0 -1
  433. package/dist/_chunks/pt-BR-BiOz37D9.js +0 -201
  434. package/dist/_chunks/pt-BR-C71iDxnh.mjs +0 -201
  435. package/dist/_chunks/pt-BR-C71iDxnh.mjs.map +0 -1
  436. package/dist/_chunks/pt-BsaFvS8-.mjs +0 -95
  437. package/dist/_chunks/pt-BsaFvS8-.mjs.map +0 -1
  438. package/dist/_chunks/pt-CeXQuq50.js +0 -95
  439. package/dist/_chunks/pt-CeXQuq50.js.map +0 -1
  440. package/dist/_chunks/relations-CPfMNzM6.js +0 -133
  441. package/dist/_chunks/relations-CPfMNzM6.js.map +0 -1
  442. package/dist/_chunks/relations-Ch70q86O.mjs +0 -134
  443. package/dist/_chunks/relations-Ch70q86O.mjs.map +0 -1
  444. package/dist/_chunks/ru-BE6A4Exp.mjs +0 -231
  445. package/dist/_chunks/ru-BE6A4Exp.mjs.map +0 -1
  446. package/dist/_chunks/ru-BT3ybNny.js +0 -231
  447. package/dist/_chunks/sa-CcvkYInH.js +0 -200
  448. package/dist/_chunks/sa-CcvkYInH.js.map +0 -1
  449. package/dist/_chunks/sa-Dag0k-Z8.mjs +0 -200
  450. package/dist/_chunks/sa-Dag0k-Z8.mjs.map +0 -1
  451. package/dist/_chunks/sk-BFg-R8qJ.mjs +0 -202
  452. package/dist/_chunks/sk-BFg-R8qJ.mjs.map +0 -1
  453. package/dist/_chunks/sk-CvY09Xjv.js +0 -202
  454. package/dist/_chunks/sk-CvY09Xjv.js.map +0 -1
  455. package/dist/_chunks/sv-CUnfWGsh.mjs +0 -202
  456. package/dist/_chunks/sv-CUnfWGsh.mjs.map +0 -1
  457. package/dist/_chunks/sv-MYDuzgvT.js +0 -202
  458. package/dist/_chunks/sv-MYDuzgvT.js.map +0 -1
  459. package/dist/_chunks/th-BqbI8lIT.mjs +0 -148
  460. package/dist/_chunks/th-BqbI8lIT.mjs.map +0 -1
  461. package/dist/_chunks/th-D9_GfAjc.js +0 -148
  462. package/dist/_chunks/tr-CgeK3wJM.mjs +0 -199
  463. package/dist/_chunks/tr-CgeK3wJM.mjs.map +0 -1
  464. package/dist/_chunks/tr-D9UH-O_R.js +0 -199
  465. package/dist/_chunks/tr-D9UH-O_R.js.map +0 -1
  466. package/dist/_chunks/uk-C8EiqJY7.js +0 -144
  467. package/dist/_chunks/uk-CR-zDhAY.mjs +0 -144
  468. package/dist/_chunks/uk-CR-zDhAY.mjs.map +0 -1
  469. package/dist/_chunks/useDebounce-CtcjDB3L.js +0 -28
  470. package/dist/_chunks/useDebounce-CtcjDB3L.js.map +0 -1
  471. package/dist/_chunks/useDebounce-DmuSJIF3.mjs +0 -29
  472. package/dist/_chunks/useDebounce-DmuSJIF3.mjs.map +0 -1
  473. package/dist/_chunks/useDragAndDrop-DdHgKsqq.mjs +0 -231
  474. package/dist/_chunks/useDragAndDrop-DdHgKsqq.mjs.map +0 -1
  475. package/dist/_chunks/useDragAndDrop-J0TUUbR6.js +0 -249
  476. package/dist/_chunks/useDragAndDrop-J0TUUbR6.js.map +0 -1
  477. package/dist/_chunks/vi-CJlYDheJ.js +0 -111
  478. package/dist/_chunks/vi-DUXIk_fw.mjs +0 -111
  479. package/dist/_chunks/vi-DUXIk_fw.mjs.map +0 -1
  480. package/dist/_chunks/zh-BWZspA60.mjs +0 -209
  481. package/dist/_chunks/zh-BWZspA60.mjs.map +0 -1
  482. package/dist/_chunks/zh-CQQfszqR.js +0 -209
  483. package/dist/_chunks/zh-CQQfszqR.js.map +0 -1
  484. package/dist/_chunks/zh-Hans-9kOncHGw.js +0 -952
  485. package/dist/_chunks/zh-Hans-BPQcRIyH.mjs +0 -952
  486. package/dist/admin/src/preview/constants.d.ts +0 -1
  487. package/dist/server/src/preview/constants.d.ts +0 -2
  488. package/dist/server/src/preview/constants.d.ts.map +0 -1
@@ -1,973 +0,0 @@
1
- import { jsx, jsxs, Fragment } from "react/jsx-runtime";
2
- import * as React from "react";
3
- import { useForm, useStrapiApp, InputRenderer, useField, Form, Layouts, useNotification, useQueryParams, useRBAC, ConfirmDialog, createContext, Page } from "@strapi/admin/strapi-admin";
4
- import { Alert, Link, Flex, Field, Box, Tooltip, Typography, Divider, Grid, Dialog, Button, Portal, FocusTrap, Main } from "@strapi/design-system";
5
- import { stringify } from "qs";
6
- import { useIntl } from "react-intl";
7
- import { NavLink, useNavigate, useParams, Link as Link$1, Navigate } from "react-router-dom";
8
- import { c as useDoc, f as useDocumentRBAC, o as useDocLayout, C as COLLECTION_TYPES, D as DocumentStatus, e as contentManagerApi, k as PERMISSIONS, t as getDisplayName, R as RelativeTime, l as DocumentRBAC, J as useDocument, h as useDocumentLayout, p as useGetContentTypeConfigurationQuery, d as buildValidParams } from "./index-Ta--2bRa.mjs";
9
- import pipe from "lodash/fp/pipe";
10
- import { u as useTypedSelector } from "./hooks-E5u1mcgM.mjs";
11
- import { a as useDynamicZone, u as useLazyComponents, b as useFieldHint, N as NotAllowedInput, d as MemoizedUIDInput, e as MemoizedWysiwyg, D as DynamicZone, f as MemoizedComponentInput, g as MemoizedBlocksInput, r as removeFieldsThatDontExistOnSchema, p as prepareTempKeys } from "./Field-DuAYQka5.mjs";
12
- import { ArrowLeft, WarningCircle } from "@strapi/icons";
13
- import { styled } from "styled-components";
14
- import { g as getRelationLabel } from "./relations-Ch70q86O.mjs";
15
- const StyledAlert = styled(Alert).attrs({ closeLabel: "Close", onClose: () => {
16
- }, shadow: "none" })`
17
- button {
18
- display: none;
19
- }
20
- `;
21
- const LinkEllipsis = styled(Link)`
22
- display: block;
23
-
24
- & > span {
25
- white-space: nowrap;
26
- overflow: hidden;
27
- text-overflow: ellipsis;
28
- display: block;
29
- }
30
- `;
31
- const CustomRelationInput = (props) => {
32
- const { formatMessage } = useIntl();
33
- const field = useField(props.name);
34
- let formattedFieldValue;
35
- if (field) {
36
- formattedFieldValue = Array.isArray(field.value) ? { results: field.value, meta: { missingCount: 0 } } : field.value;
37
- }
38
- if (!formattedFieldValue || formattedFieldValue.results.length === 0 && formattedFieldValue.meta.missingCount === 0) {
39
- return /* @__PURE__ */ jsxs(Fragment, { children: [
40
- /* @__PURE__ */ jsx(Field.Label, { action: props.labelAction, children: props.label }),
41
- /* @__PURE__ */ jsx(Box, { marginTop: 1, children: /* @__PURE__ */ jsx(StyledAlert, { variant: "default", children: formatMessage({
42
- id: "content-manager.history.content.no-relations",
43
- defaultMessage: "No relations."
44
- }) }) })
45
- ] });
46
- }
47
- const { results, meta } = formattedFieldValue;
48
- return /* @__PURE__ */ jsxs(Box, { children: [
49
- /* @__PURE__ */ jsx(Field.Label, { children: props.label }),
50
- results.length > 0 && /* @__PURE__ */ jsx(Flex, { direction: "column", gap: 2, marginTop: 1, alignItems: "stretch", children: results.map((relationData) => {
51
- const { targetModel } = props.attribute;
52
- const href = `../${COLLECTION_TYPES}/${targetModel}/${relationData.documentId}`;
53
- const label = getRelationLabel(relationData, props.mainField);
54
- const isAdminUserRelation = targetModel === "admin::user";
55
- return /* @__PURE__ */ jsxs(
56
- Flex,
57
- {
58
- paddingTop: 2,
59
- paddingBottom: 2,
60
- paddingLeft: 4,
61
- paddingRight: 4,
62
- hasRadius: true,
63
- borderColor: "neutral200",
64
- background: "neutral150",
65
- justifyContent: "space-between",
66
- children: [
67
- /* @__PURE__ */ jsx(Box, { minWidth: 0, paddingTop: 1, paddingBottom: 1, paddingRight: 4, children: /* @__PURE__ */ jsx(Tooltip, { label, children: isAdminUserRelation ? /* @__PURE__ */ jsx(Typography, { children: label }) : /* @__PURE__ */ jsx(LinkEllipsis, { tag: NavLink, to: href, children: label }) }) }),
68
- /* @__PURE__ */ jsx(DocumentStatus, { status: relationData.status })
69
- ]
70
- },
71
- relationData.documentId ?? relationData.id
72
- );
73
- }) }),
74
- meta.missingCount > 0 && /* @ts-expect-error – we dont need closeLabel */
75
- /* @__PURE__ */ jsx(
76
- StyledAlert,
77
- {
78
- marginTop: 1,
79
- variant: "warning",
80
- title: formatMessage(
81
- {
82
- id: "content-manager.history.content.missing-relations.title",
83
- defaultMessage: "{number, plural, =1 {Missing relation} other {{number} missing relations}}"
84
- },
85
- { number: meta.missingCount }
86
- ),
87
- children: formatMessage(
88
- {
89
- id: "content-manager.history.content.missing-relations.message",
90
- defaultMessage: "{number, plural, =1 {It has} other {They have}} been deleted and can't be restored."
91
- },
92
- { number: meta.missingCount }
93
- )
94
- }
95
- )
96
- ] });
97
- };
98
- const CustomMediaInput = (props) => {
99
- const { value } = useField(props.name);
100
- const results = value ? value.results : [];
101
- const meta = value ? value.meta : { missingCount: 0 };
102
- const { formatMessage } = useIntl();
103
- const fields = useStrapiApp("CustomMediaInput", (state) => state.fields);
104
- const MediaLibrary = fields.media;
105
- return /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: 2, alignItems: "stretch", children: [
106
- /* @__PURE__ */ jsx(Form, { method: "PUT", disabled: true, initialValues: { [props.name]: results }, children: /* @__PURE__ */ jsx(MediaLibrary, { ...props, disabled: true, multiple: results.length > 1 }) }),
107
- meta.missingCount > 0 && /* @__PURE__ */ jsx(
108
- StyledAlert,
109
- {
110
- variant: "warning",
111
- closeLabel: "Close",
112
- onClose: () => {
113
- },
114
- title: formatMessage(
115
- {
116
- id: "content-manager.history.content.missing-assets.title",
117
- defaultMessage: "{number, plural, =1 {Missing asset} other {{number} missing assets}}"
118
- },
119
- { number: meta.missingCount }
120
- ),
121
- children: formatMessage(
122
- {
123
- id: "content-manager.history.content.missing-assets.message",
124
- defaultMessage: "{number, plural, =1 {It has} other {They have}} been deleted in the Media Library and can't be restored."
125
- },
126
- { number: meta.missingCount }
127
- )
128
- }
129
- )
130
- ] });
131
- };
132
- const getLabelAction = (labelAction) => {
133
- if (!React.isValidElement(labelAction)) {
134
- return labelAction;
135
- }
136
- const labelActionTitleId = labelAction.props.title.id;
137
- if (labelActionTitleId === "i18n.Field.localized") {
138
- return React.cloneElement(labelAction, {
139
- ...labelAction.props,
140
- title: {
141
- id: "history.content.localized",
142
- defaultMessage: "This value is specific to this locale. If you restore this version, the content will not be replaced for other locales."
143
- }
144
- });
145
- }
146
- if (labelActionTitleId === "i18n.Field.not-localized") {
147
- return React.cloneElement(labelAction, {
148
- ...labelAction.props,
149
- title: {
150
- id: "history.content.not-localized",
151
- defaultMessage: "This value is common to all locales. If you restore this version and save the changes, the content will be replaced for all locales."
152
- }
153
- });
154
- }
155
- return labelAction;
156
- };
157
- const VersionInputRenderer = ({
158
- visible,
159
- hint: providedHint,
160
- shouldIgnoreRBAC = false,
161
- labelAction,
162
- ...props
163
- }) => {
164
- const customLabelAction = getLabelAction(labelAction);
165
- const { formatMessage } = useIntl();
166
- const version = useHistoryContext("VersionContent", (state) => state.selectedVersion);
167
- const configuration = useHistoryContext("VersionContent", (state) => state.configuration);
168
- const fieldSizes = useTypedSelector((state) => state["content-manager"].app.fieldSizes);
169
- const { id, components } = useDoc();
170
- const isFormDisabled = useForm("InputRenderer", (state) => state.disabled);
171
- const isInDynamicZone = useDynamicZone("isInDynamicZone", (state) => state.isInDynamicZone);
172
- const canCreateFields = useDocumentRBAC("InputRenderer", (rbac) => rbac.canCreateFields);
173
- const canReadFields = useDocumentRBAC("InputRenderer", (rbac) => rbac.canReadFields);
174
- const canUpdateFields = useDocumentRBAC("InputRenderer", (rbac) => rbac.canUpdateFields);
175
- const canUserAction = useDocumentRBAC("InputRenderer", (rbac) => rbac.canUserAction);
176
- const editableFields = id ? canUpdateFields : canCreateFields;
177
- const readableFields = id ? canReadFields : canCreateFields;
178
- const canUserReadField = canUserAction(props.name, readableFields, props.type);
179
- const canUserEditField = canUserAction(props.name, editableFields, props.type);
180
- const fields = useStrapiApp("InputRenderer", (app) => app.fields);
181
- const { lazyComponentStore } = useLazyComponents(
182
- attributeHasCustomFieldProperty(props.attribute) ? [props.attribute.customField] : void 0
183
- );
184
- const hint = useFieldHint(providedHint, props.attribute);
185
- const {
186
- edit: { components: componentsLayout }
187
- } = useDocLayout();
188
- if (!visible) {
189
- return null;
190
- }
191
- if (!shouldIgnoreRBAC && !canUserReadField && !isInDynamicZone) {
192
- return /* @__PURE__ */ jsx(NotAllowedInput, { hint, ...props });
193
- }
194
- const fieldIsDisabled = !canUserEditField && !isInDynamicZone || props.disabled || isFormDisabled;
195
- const addedAttributes = version.meta.unknownAttributes.added;
196
- if (Object.keys(addedAttributes).includes(props.name)) {
197
- return /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "flex-start", gap: 1, children: [
198
- /* @__PURE__ */ jsx(Field.Label, { children: props.label }),
199
- /* @__PURE__ */ jsx(
200
- StyledAlert,
201
- {
202
- width: "100%",
203
- closeLabel: "Close",
204
- onClose: () => {
205
- },
206
- variant: "warning",
207
- title: formatMessage({
208
- id: "content-manager.history.content.new-field.title",
209
- defaultMessage: "New field"
210
- }),
211
- children: formatMessage({
212
- id: "content-manager.history.content.new-field.message",
213
- defaultMessage: "This field didn't exist when this version was saved. If you restore this version, it will be empty."
214
- })
215
- }
216
- )
217
- ] });
218
- }
219
- if (attributeHasCustomFieldProperty(props.attribute)) {
220
- const CustomInput = lazyComponentStore[props.attribute.customField];
221
- if (CustomInput) {
222
- return /* @__PURE__ */ jsx(
223
- CustomInput,
224
- {
225
- ...props,
226
- hint,
227
- labelAction: customLabelAction,
228
- disabled: fieldIsDisabled
229
- }
230
- );
231
- }
232
- return /* @__PURE__ */ jsx(
233
- InputRenderer,
234
- {
235
- ...props,
236
- hint,
237
- labelAction: customLabelAction,
238
- type: props.attribute.customField,
239
- disabled: fieldIsDisabled
240
- }
241
- );
242
- }
243
- if (props.type === "media") {
244
- return /* @__PURE__ */ jsx(CustomMediaInput, { ...props, labelAction: customLabelAction, disabled: fieldIsDisabled });
245
- }
246
- const addedInputTypes = Object.keys(fields);
247
- if (!attributeHasCustomFieldProperty(props.attribute) && addedInputTypes.includes(props.type)) {
248
- const CustomInput = fields[props.type];
249
- return /* @__PURE__ */ jsx(
250
- CustomInput,
251
- {
252
- ...props,
253
- hint,
254
- labelAction: customLabelAction,
255
- disabled: fieldIsDisabled
256
- }
257
- );
258
- }
259
- switch (props.type) {
260
- case "blocks":
261
- return /* @__PURE__ */ jsx(MemoizedBlocksInput, { ...props, hint, type: props.type, disabled: fieldIsDisabled });
262
- case "component":
263
- const { layout } = componentsLayout[props.attribute.component];
264
- const [remainingFieldsLayout] = getRemaingFieldsLayout({
265
- layout: [layout],
266
- metadatas: configuration.components[props.attribute.component].metadatas,
267
- fieldSizes,
268
- schemaAttributes: components[props.attribute.component].attributes
269
- });
270
- return /* @__PURE__ */ jsx(
271
- MemoizedComponentInput,
272
- {
273
- ...props,
274
- layout: [...layout, ...remainingFieldsLayout || []],
275
- hint,
276
- labelAction: customLabelAction,
277
- disabled: fieldIsDisabled,
278
- children: (inputProps) => /* @__PURE__ */ jsx(VersionInputRenderer, { ...inputProps, shouldIgnoreRBAC: true })
279
- }
280
- );
281
- case "dynamiczone":
282
- return /* @__PURE__ */ jsx(
283
- DynamicZone,
284
- {
285
- ...props,
286
- hint,
287
- labelAction: customLabelAction,
288
- disabled: fieldIsDisabled
289
- }
290
- );
291
- case "relation":
292
- return /* @__PURE__ */ jsx(
293
- CustomRelationInput,
294
- {
295
- ...props,
296
- hint,
297
- labelAction: customLabelAction,
298
- disabled: fieldIsDisabled
299
- }
300
- );
301
- case "richtext":
302
- return /* @__PURE__ */ jsx(
303
- MemoizedWysiwyg,
304
- {
305
- ...props,
306
- hint,
307
- type: props.type,
308
- labelAction: customLabelAction,
309
- disabled: fieldIsDisabled
310
- }
311
- );
312
- case "uid":
313
- return /* @__PURE__ */ jsx(
314
- MemoizedUIDInput,
315
- {
316
- ...props,
317
- hint,
318
- type: props.type,
319
- labelAction: customLabelAction,
320
- disabled: fieldIsDisabled
321
- }
322
- );
323
- case "enumeration":
324
- return /* @__PURE__ */ jsx(
325
- InputRenderer,
326
- {
327
- ...props,
328
- hint,
329
- labelAction: customLabelAction,
330
- options: props.attribute.enum.map((value) => ({ value })),
331
- type: props.customField ? "custom-field" : props.type,
332
- disabled: fieldIsDisabled
333
- }
334
- );
335
- default:
336
- const { unique: _unique, mainField: _mainField, ...restProps } = props;
337
- return /* @__PURE__ */ jsx(
338
- InputRenderer,
339
- {
340
- ...restProps,
341
- hint,
342
- labelAction: customLabelAction,
343
- type: props.customField ? "custom-field" : props.type,
344
- disabled: fieldIsDisabled
345
- }
346
- );
347
- }
348
- };
349
- const attributeHasCustomFieldProperty = (attribute) => "customField" in attribute && typeof attribute.customField === "string";
350
- const createLayoutFromFields = (fields) => {
351
- return fields.reduce((rows, field) => {
352
- if (field.type === "dynamiczone") {
353
- rows.push([field]);
354
- return rows;
355
- }
356
- if (!rows[rows.length - 1]) {
357
- rows.push([]);
358
- }
359
- rows[rows.length - 1].push(field);
360
- return rows;
361
- }, []).map((row) => [row]);
362
- };
363
- function getRemaingFieldsLayout({
364
- layout,
365
- metadatas,
366
- schemaAttributes,
367
- fieldSizes
368
- }) {
369
- const fieldsInLayout = layout.flatMap(
370
- (panel) => panel.flatMap((row) => row.flatMap((field) => field.name))
371
- );
372
- const remainingFields = Object.entries(metadatas).reduce(
373
- (currentRemainingFields, [name, field]) => {
374
- if (!fieldsInLayout.includes(name) && field.edit.visible === true) {
375
- const attribute = schemaAttributes[name];
376
- currentRemainingFields.push({
377
- attribute,
378
- type: attribute.type,
379
- visible: true,
380
- disabled: true,
381
- label: field.edit.label || name,
382
- name,
383
- size: fieldSizes[attribute.type].default ?? 12
384
- });
385
- }
386
- return currentRemainingFields;
387
- },
388
- []
389
- );
390
- return createLayoutFromFields(remainingFields);
391
- }
392
- const FormPanel = ({ panel }) => {
393
- if (panel.some((row) => row.some((field) => field.type === "dynamiczone"))) {
394
- const [row] = panel;
395
- const [field] = row;
396
- return /* @__PURE__ */ jsx(Grid.Root, { gap: 4, children: /* @__PURE__ */ jsx(Grid.Item, { col: 12, s: 12, xs: 12, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsx(VersionInputRenderer, { ...field }) }) }, field.name);
397
- }
398
- return /* @__PURE__ */ jsx(
399
- Box,
400
- {
401
- hasRadius: true,
402
- background: "neutral0",
403
- shadow: "tableShadow",
404
- paddingLeft: 6,
405
- paddingRight: 6,
406
- paddingTop: 6,
407
- paddingBottom: 6,
408
- borderColor: "neutral150",
409
- children: /* @__PURE__ */ jsx(Flex, { direction: "column", alignItems: "stretch", gap: 6, children: panel.map((row, gridRowIndex) => /* @__PURE__ */ jsx(Grid.Root, { gap: 4, children: row.map(({ size, ...field }) => {
410
- return /* @__PURE__ */ jsx(
411
- Grid.Item,
412
- {
413
- col: size,
414
- s: 12,
415
- xs: 12,
416
- direction: "column",
417
- alignItems: "stretch",
418
- children: /* @__PURE__ */ jsx(VersionInputRenderer, { ...field })
419
- },
420
- field.name
421
- );
422
- }) }, gridRowIndex)) })
423
- }
424
- );
425
- };
426
- const VersionContent = () => {
427
- const { formatMessage } = useIntl();
428
- const { fieldSizes } = useTypedSelector((state) => state["content-manager"].app);
429
- const version = useHistoryContext("VersionContent", (state) => state.selectedVersion);
430
- const layout = useHistoryContext("VersionContent", (state) => state.layout);
431
- const configuration = useHistoryContext("VersionContent", (state) => state.configuration);
432
- const schema = useHistoryContext("VersionContent", (state) => state.schema);
433
- const removedAttributes = version.meta.unknownAttributes.removed;
434
- const removedAttributesAsFields = Object.entries(removedAttributes).map(
435
- ([attributeName, attribute]) => {
436
- const field = {
437
- attribute,
438
- shouldIgnoreRBAC: true,
439
- type: attribute.type,
440
- visible: true,
441
- disabled: true,
442
- label: attributeName,
443
- name: attributeName,
444
- size: fieldSizes[attribute.type].default ?? 12
445
- };
446
- return field;
447
- }
448
- );
449
- const unknownFieldsLayout = createLayoutFromFields(removedAttributesAsFields);
450
- const remainingFieldsLayout = getRemaingFieldsLayout({
451
- metadatas: configuration.contentType.metadatas,
452
- layout,
453
- schemaAttributes: schema.attributes,
454
- fieldSizes
455
- });
456
- const { components } = useDoc();
457
- const transformedData = React.useMemo(() => {
458
- const transform = (schemaAttributes, components2 = {}) => (document) => {
459
- const schema2 = { attributes: schemaAttributes };
460
- const transformations = pipe(
461
- removeFieldsThatDontExistOnSchema(schema2),
462
- prepareTempKeys(schema2, components2)
463
- );
464
- return transformations(document);
465
- };
466
- return transform(version.schema, components)(version.data);
467
- }, [components, version.data, version.schema]);
468
- return /* @__PURE__ */ jsxs(Layouts.Content, { children: [
469
- /* @__PURE__ */ jsx(Box, { paddingBottom: 8, children: /* @__PURE__ */ jsx(Form, { disabled: true, method: "PUT", initialValues: transformedData, children: /* @__PURE__ */ jsx(Flex, { direction: "column", alignItems: "stretch", gap: 6, position: "relative", children: [...layout, ...remainingFieldsLayout].map((panel, index) => {
470
- return /* @__PURE__ */ jsx(FormPanel, { panel }, index);
471
- }) }) }) }),
472
- removedAttributesAsFields.length > 0 && /* @__PURE__ */ jsxs(Fragment, { children: [
473
- /* @__PURE__ */ jsx(Divider, {}),
474
- /* @__PURE__ */ jsxs(Box, { paddingTop: 8, children: [
475
- /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "flex-start", paddingBottom: 6, gap: 1, children: [
476
- /* @__PURE__ */ jsx(Typography, { variant: "delta", children: formatMessage({
477
- id: "content-manager.history.content.unknown-fields.title",
478
- defaultMessage: "Unknown fields"
479
- }) }),
480
- /* @__PURE__ */ jsx(Typography, { variant: "pi", children: formatMessage(
481
- {
482
- id: "content-manager.history.content.unknown-fields.message",
483
- defaultMessage: "These fields have been deleted or renamed in the Content-Type Builder. <b>These fields will not be restored.</b>"
484
- },
485
- {
486
- b: (chunks) => /* @__PURE__ */ jsx(Typography, { variant: "pi", fontWeight: "bold", children: chunks })
487
- }
488
- ) })
489
- ] }),
490
- /* @__PURE__ */ jsx(Form, { disabled: true, method: "PUT", initialValues: version.data, children: /* @__PURE__ */ jsx(Flex, { direction: "column", alignItems: "stretch", gap: 6, position: "relative", children: unknownFieldsLayout.map((panel, index) => {
491
- return /* @__PURE__ */ jsx(FormPanel, { panel }, index);
492
- }) }) })
493
- ] })
494
- ] })
495
- ] });
496
- };
497
- const historyVersionsApi = contentManagerApi.injectEndpoints({
498
- endpoints: (builder) => ({
499
- getHistoryVersions: builder.query({
500
- query(params) {
501
- return {
502
- url: `/content-manager/history-versions`,
503
- method: "GET",
504
- config: {
505
- params
506
- }
507
- };
508
- },
509
- providesTags: ["HistoryVersion"]
510
- }),
511
- restoreVersion: builder.mutation({
512
- query({ params, body }) {
513
- return {
514
- url: `/content-manager/history-versions/${params.versionId}/restore`,
515
- method: "PUT",
516
- data: body
517
- };
518
- },
519
- invalidatesTags: (_res, _error, { documentId, collectionType, params }) => {
520
- return [
521
- "HistoryVersion",
522
- {
523
- type: "Document",
524
- id: collectionType === COLLECTION_TYPES ? `${params.contentType}_${documentId}` : params.contentType
525
- }
526
- ];
527
- }
528
- })
529
- })
530
- });
531
- const { useGetHistoryVersionsQuery, useRestoreVersionMutation } = historyVersionsApi;
532
- const VersionHeader = ({ headerId }) => {
533
- const [isConfirmDialogOpen, setIsConfirmDialogOpen] = React.useState(false);
534
- const navigate = useNavigate();
535
- const { formatMessage, formatDate } = useIntl();
536
- const { toggleNotification } = useNotification();
537
- const [{ query }] = useQueryParams();
538
- const { collectionType, slug } = useParams();
539
- const [restoreVersion, { isLoading }] = useRestoreVersionMutation();
540
- const { allowedActions } = useRBAC(PERMISSIONS.map((action) => ({ action, subject: slug })));
541
- const version = useHistoryContext("VersionHeader", (state) => state.selectedVersion);
542
- const mainField = useHistoryContext("VersionHeader", (state) => state.mainField);
543
- const schema = useHistoryContext("VersionHeader", (state) => state.schema);
544
- const isCurrentVersion = useHistoryContext(
545
- "VersionHeader",
546
- (state) => state.page === 1 && state.versions.data[0].id === state.selectedVersion.id
547
- );
548
- const mainFieldValue = version.data[mainField];
549
- const getNextNavigation = () => {
550
- const pluginsQueryParams = stringify({ plugins: query.plugins }, { encode: false });
551
- return {
552
- pathname: "..",
553
- search: pluginsQueryParams
554
- };
555
- };
556
- const handleRestore = async () => {
557
- try {
558
- const response = await restoreVersion({
559
- documentId: version.relatedDocumentId,
560
- collectionType,
561
- params: {
562
- versionId: version.id,
563
- contentType: version.contentType
564
- },
565
- body: { contentType: version.contentType }
566
- });
567
- if ("data" in response) {
568
- navigate(getNextNavigation(), { relative: "path" });
569
- toggleNotification({
570
- type: "success",
571
- title: formatMessage({
572
- id: "content-manager.restore.success.title",
573
- defaultMessage: "Version restored."
574
- }),
575
- message: formatMessage({
576
- id: "content-manager.restore.success.message",
577
- defaultMessage: "The content of the restored version is not published yet."
578
- })
579
- });
580
- }
581
- if ("error" in response) {
582
- toggleNotification({
583
- type: "danger",
584
- message: formatMessage({
585
- id: "content-manager.history.restore.error.message",
586
- defaultMessage: "Could not restore version."
587
- })
588
- });
589
- }
590
- } catch (error) {
591
- toggleNotification({
592
- type: "danger",
593
- message: formatMessage({ id: "notification.error", defaultMessage: "An error occurred" })
594
- });
595
- }
596
- };
597
- return /* @__PURE__ */ jsxs(Dialog.Root, { open: isConfirmDialogOpen, onOpenChange: setIsConfirmDialogOpen, children: [
598
- /* @__PURE__ */ jsx(
599
- Layouts.BaseHeader,
600
- {
601
- id: headerId,
602
- title: formatDate(new Date(version.createdAt), {
603
- year: "numeric",
604
- month: "numeric",
605
- day: "numeric",
606
- hour: "numeric",
607
- minute: "numeric"
608
- }),
609
- subtitle: /* @__PURE__ */ jsx(Typography, { variant: "epsilon", textColor: "neutral600", children: formatMessage(
610
- {
611
- id: "content-manager.history.version.subtitle",
612
- defaultMessage: "{hasLocale, select, true {{subtitle}, in {locale}} other {{subtitle}}}"
613
- },
614
- {
615
- hasLocale: Boolean(version.locale),
616
- subtitle: `${mainFieldValue || ""} (${schema.info.singularName})`.trim(),
617
- locale: version.locale?.name
618
- }
619
- ) }),
620
- navigationAction: /* @__PURE__ */ jsx(
621
- Link,
622
- {
623
- startIcon: /* @__PURE__ */ jsx(ArrowLeft, {}),
624
- tag: NavLink,
625
- to: getNextNavigation(),
626
- relative: "path",
627
- isExternal: false,
628
- children: formatMessage({
629
- id: "global.back",
630
- defaultMessage: "Back"
631
- })
632
- }
633
- ),
634
- sticky: false,
635
- primaryAction: /* @__PURE__ */ jsx(Dialog.Trigger, { children: /* @__PURE__ */ jsx(
636
- Button,
637
- {
638
- disabled: !allowedActions.canUpdate || isCurrentVersion,
639
- onClick: () => {
640
- setIsConfirmDialogOpen(true);
641
- },
642
- children: formatMessage({
643
- id: "content-manager.history.restore.confirm.button",
644
- defaultMessage: "Restore"
645
- })
646
- }
647
- ) })
648
- }
649
- ),
650
- /* @__PURE__ */ jsx(
651
- ConfirmDialog,
652
- {
653
- onConfirm: handleRestore,
654
- endAction: /* @__PURE__ */ jsx(Button, { variant: "secondary", onClick: handleRestore, loading: isLoading, children: formatMessage({
655
- id: "content-manager.history.restore.confirm.button",
656
- defaultMessage: "Restore"
657
- }) }),
658
- children: /* @__PURE__ */ jsxs(
659
- Flex,
660
- {
661
- direction: "column",
662
- alignItems: "center",
663
- justifyContent: "center",
664
- gap: 2,
665
- textAlign: "center",
666
- children: [
667
- /* @__PURE__ */ jsx(Flex, { justifyContent: "center", children: /* @__PURE__ */ jsx(WarningCircle, { width: "24px", height: "24px", fill: "danger600" }) }),
668
- /* @__PURE__ */ jsx(Typography, { children: formatMessage({
669
- id: "content-manager.history.restore.confirm.title",
670
- defaultMessage: "Are you sure you want to restore this version?"
671
- }) }),
672
- /* @__PURE__ */ jsx(Typography, { children: formatMessage(
673
- {
674
- id: "content-manager.history.restore.confirm.message",
675
- defaultMessage: "{isDraft, select, true {The restored content will override your draft.} other {The restored content won't be published, it will override the draft and be saved as pending changes. You'll be able to publish the changes at anytime.}}"
676
- },
677
- {
678
- isDraft: version.status === "draft"
679
- }
680
- ) })
681
- ]
682
- }
683
- )
684
- }
685
- )
686
- ] });
687
- };
688
- const BlueText = (children) => /* @__PURE__ */ jsx(Typography, { textColor: "primary600", variant: "pi", children });
689
- const VersionCard = ({ version, isCurrent }) => {
690
- const { formatDate, formatMessage } = useIntl();
691
- const [{ query }] = useQueryParams();
692
- const isActive = query.id === version.id.toString();
693
- const author = version.createdBy && getDisplayName(version.createdBy);
694
- return /* @__PURE__ */ jsxs(
695
- Flex,
696
- {
697
- direction: "column",
698
- alignItems: "flex-start",
699
- gap: 3,
700
- hasRadius: true,
701
- borderWidth: "1px",
702
- borderStyle: "solid",
703
- borderColor: isActive ? "primary600" : "neutral200",
704
- color: "neutral800",
705
- padding: 5,
706
- tag: Link$1,
707
- to: `?${stringify({ ...query, id: version.id })}`,
708
- style: { textDecoration: "none" },
709
- children: [
710
- /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: 1, alignItems: "flex-start", children: [
711
- /* @__PURE__ */ jsx(Typography, { tag: "h3", fontWeight: "semiBold", children: formatDate(version.createdAt, {
712
- day: "numeric",
713
- month: "numeric",
714
- year: "numeric",
715
- hour: "2-digit",
716
- minute: "2-digit"
717
- }) }),
718
- /* @__PURE__ */ jsx(Typography, { tag: "p", variant: "pi", textColor: "neutral600", children: formatMessage(
719
- {
720
- id: "content-manager.history.sidebar.versionDescription",
721
- defaultMessage: "{distanceToNow}{isAnonymous, select, true {} other { by {author}}}{isCurrent, select, true { <b>(current)</b>} other {}}"
722
- },
723
- {
724
- distanceToNow: /* @__PURE__ */ jsx(RelativeTime, { timestamp: new Date(version.createdAt) }),
725
- author,
726
- isAnonymous: !Boolean(version.createdBy),
727
- isCurrent,
728
- b: BlueText
729
- }
730
- ) })
731
- ] }),
732
- version.status && /* @__PURE__ */ jsx(DocumentStatus, { status: version.status, size: "XS" })
733
- ]
734
- }
735
- );
736
- };
737
- const PaginationButton = ({ page, children }) => {
738
- const [{ query }] = useQueryParams();
739
- const { id: _id, ...queryRest } = query;
740
- return /* @__PURE__ */ jsx(Link$1, { to: { search: stringify({ ...queryRest, page }) }, style: { textDecoration: "none" }, children: /* @__PURE__ */ jsx(Typography, { variant: "omega", textColor: "primary600", children }) });
741
- };
742
- const VersionsList = () => {
743
- const { formatMessage } = useIntl();
744
- const { versions, page } = useHistoryContext("VersionsList", (state) => ({
745
- versions: state.versions,
746
- page: state.page
747
- }));
748
- return /* @__PURE__ */ jsxs(
749
- Flex,
750
- {
751
- shrink: 0,
752
- direction: "column",
753
- alignItems: "stretch",
754
- width: "320px",
755
- height: "100vh",
756
- background: "neutral0",
757
- borderColor: "neutral200",
758
- borderWidth: "0 0 0 1px",
759
- borderStyle: "solid",
760
- tag: "aside",
761
- children: [
762
- /* @__PURE__ */ jsxs(
763
- Flex,
764
- {
765
- direction: "row",
766
- justifyContent: "space-between",
767
- padding: 4,
768
- borderColor: "neutral200",
769
- borderWidth: "0 0 1px",
770
- borderStyle: "solid",
771
- tag: "header",
772
- children: [
773
- /* @__PURE__ */ jsx(Typography, { tag: "h2", variant: "omega", fontWeight: "semiBold", children: formatMessage({
774
- id: "content-manager.history.sidebar.title",
775
- defaultMessage: "Versions"
776
- }) }),
777
- /* @__PURE__ */ jsx(Box, { background: "neutral150", hasRadius: true, padding: 1, children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", textColor: "neutral600", children: versions.meta.pagination.total }) })
778
- ]
779
- }
780
- ),
781
- /* @__PURE__ */ jsxs(Box, { flex: 1, overflow: "auto", children: [
782
- versions.meta.pagination.page > 1 && /* @__PURE__ */ jsx(Box, { paddingTop: 4, textAlign: "center", children: /* @__PURE__ */ jsx(PaginationButton, { page: page - 1, children: formatMessage({
783
- id: "content-manager.history.sidebar.show-newer",
784
- defaultMessage: "Show newer versions"
785
- }) }) }),
786
- /* @__PURE__ */ jsx(Flex, { direction: "column", gap: 3, padding: 4, tag: "ul", alignItems: "stretch", children: versions.data.map((version, index) => /* @__PURE__ */ jsx(
787
- "li",
788
- {
789
- "aria-label": formatMessage({
790
- id: "content-manager.history.sidebar.title.version-card.aria-label",
791
- defaultMessage: "Version card"
792
- }),
793
- children: /* @__PURE__ */ jsx(VersionCard, { version, isCurrent: page === 1 && index === 0 })
794
- },
795
- version.id
796
- )) }),
797
- versions.meta.pagination.page < versions.meta.pagination.pageCount && /* @__PURE__ */ jsx(Box, { paddingBottom: 4, textAlign: "center", children: /* @__PURE__ */ jsx(PaginationButton, { page: page + 1, children: formatMessage({
798
- id: "content-manager.history.sidebar.show-older",
799
- defaultMessage: "Show older versions"
800
- }) }) })
801
- ] })
802
- ]
803
- }
804
- );
805
- };
806
- const [HistoryProvider, useHistoryContext] = createContext("HistoryPage");
807
- const HistoryPage = () => {
808
- const headerId = React.useId();
809
- const { formatMessage } = useIntl();
810
- const {
811
- slug,
812
- id: documentId,
813
- collectionType
814
- } = useParams();
815
- const { isLoading: isLoadingDocument, schema } = useDocument({
816
- collectionType,
817
- model: slug
818
- });
819
- const {
820
- isLoading: isLoadingLayout,
821
- edit: {
822
- layout,
823
- settings: { displayName, mainField }
824
- }
825
- } = useDocumentLayout(slug);
826
- const { data: configuration, isLoading: isLoadingConfiguration } = useGetContentTypeConfigurationQuery(slug);
827
- const [{ query }] = useQueryParams();
828
- const { id: selectedVersionId, ...queryWithoutId } = query;
829
- const validQueryParamsWithoutId = buildValidParams(queryWithoutId);
830
- const page = validQueryParamsWithoutId.page ? Number(validQueryParamsWithoutId.page) : 1;
831
- const versionsResponse = useGetHistoryVersionsQuery(
832
- {
833
- contentType: slug,
834
- ...documentId ? { documentId } : {},
835
- // Omit id since it's not needed by the endpoint and caused extra refetches
836
- ...validQueryParamsWithoutId
837
- },
838
- { refetchOnMountOrArgChange: true }
839
- );
840
- const initialRequestId = React.useRef(versionsResponse.requestId);
841
- const isStaleRequest = versionsResponse.requestId === initialRequestId.current;
842
- if (!slug || collectionType === COLLECTION_TYPES && !documentId) {
843
- return /* @__PURE__ */ jsx(Navigate, { to: "/content-manager" });
844
- }
845
- if (isLoadingDocument || isLoadingLayout || versionsResponse.isFetching || isStaleRequest || isLoadingConfiguration) {
846
- return /* @__PURE__ */ jsx(Page.Loading, {});
847
- }
848
- if (!versionsResponse.isError && !versionsResponse.data?.data?.length) {
849
- return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsx(
850
- Page.NoData,
851
- {
852
- action: /* @__PURE__ */ jsx(
853
- Link,
854
- {
855
- tag: NavLink,
856
- to: `/content-manager/${collectionType}/${slug}${documentId ? `/${documentId}` : ""}`,
857
- children: formatMessage({
858
- id: "global.back",
859
- defaultMessage: "Back"
860
- })
861
- }
862
- )
863
- }
864
- ) });
865
- }
866
- if (versionsResponse.data?.data?.length && !selectedVersionId) {
867
- return /* @__PURE__ */ jsx(
868
- Navigate,
869
- {
870
- to: { search: stringify({ ...query, id: versionsResponse.data.data[0].id }) },
871
- replace: true
872
- }
873
- );
874
- }
875
- const selectedVersion = versionsResponse.data?.data?.find(
876
- (version) => version.id.toString() === selectedVersionId
877
- );
878
- if (versionsResponse.isError || !layout || !schema || !selectedVersion || !configuration || // This should not happen as it's covered by versionsResponse.isError, but we need it for TS
879
- versionsResponse.data.error) {
880
- return /* @__PURE__ */ jsx(Page.Error, {});
881
- }
882
- return /* @__PURE__ */ jsxs(Fragment, { children: [
883
- /* @__PURE__ */ jsx(Page.Title, { children: formatMessage(
884
- {
885
- id: "content-manager.history.page-title",
886
- defaultMessage: "{contentType} history"
887
- },
888
- {
889
- contentType: displayName
890
- }
891
- ) }),
892
- /* @__PURE__ */ jsx(
893
- HistoryProvider,
894
- {
895
- contentType: slug,
896
- id: documentId,
897
- schema,
898
- layout,
899
- configuration,
900
- selectedVersion,
901
- versions: versionsResponse.data,
902
- page,
903
- mainField,
904
- children: /* @__PURE__ */ jsxs(Flex, { direction: "row", alignItems: "flex-start", children: [
905
- /* @__PURE__ */ jsxs(
906
- Main,
907
- {
908
- grow: 1,
909
- height: "100vh",
910
- background: "neutral100",
911
- paddingBottom: 6,
912
- overflow: "auto",
913
- labelledBy: headerId,
914
- children: [
915
- /* @__PURE__ */ jsx(VersionHeader, { headerId }),
916
- /* @__PURE__ */ jsx(VersionContent, {})
917
- ]
918
- }
919
- ),
920
- /* @__PURE__ */ jsx(VersionsList, {})
921
- ] })
922
- }
923
- )
924
- ] });
925
- };
926
- const ProtectedHistoryPageImpl = () => {
927
- const { slug } = useParams();
928
- const {
929
- permissions = [],
930
- isLoading,
931
- error
932
- } = useRBAC(PERMISSIONS.map((action) => ({ action, subject: slug })));
933
- if (isLoading) {
934
- return /* @__PURE__ */ jsx(Page.Loading, {});
935
- }
936
- if (error || !slug) {
937
- return /* @__PURE__ */ jsx(
938
- Box,
939
- {
940
- height: "100vh",
941
- width: "100vw",
942
- position: "fixed",
943
- top: 0,
944
- left: 0,
945
- zIndex: 2,
946
- background: "neutral0",
947
- children: /* @__PURE__ */ jsx(Page.Error, {})
948
- }
949
- );
950
- }
951
- return /* @__PURE__ */ jsx(
952
- Box,
953
- {
954
- height: "100vh",
955
- width: "100vw",
956
- position: "fixed",
957
- top: 0,
958
- left: 0,
959
- zIndex: 2,
960
- background: "neutral0",
961
- children: /* @__PURE__ */ jsx(Page.Protect, { permissions, children: ({ permissions: permissions2 }) => /* @__PURE__ */ jsx(DocumentRBAC, { permissions: permissions2, children: /* @__PURE__ */ jsx(HistoryPage, {}) }) })
962
- }
963
- );
964
- };
965
- const ProtectedHistoryPage = () => {
966
- return /* @__PURE__ */ jsx(Portal, { children: /* @__PURE__ */ jsx(FocusTrap, { children: /* @__PURE__ */ jsx(ProtectedHistoryPageImpl, {}) }) });
967
- };
968
- export {
969
- HistoryProvider,
970
- ProtectedHistoryPage,
971
- useHistoryContext
972
- };
973
- //# sourceMappingURL=History-CGblSVMc.mjs.map