@strapi/content-manager 5.9.0 → 5.10.0

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