@strapi/content-manager 0.0.0-next.bec3f8cddf61be32ee5516609a1d4d6032933972 → 0.0.0-next.c22d1aa5024dc77092c3df7e990ad89dcd79e7b0

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-Co2eC_-C.js +276 -0
  6. package/dist/admin/chunks/ComponentConfigurationPage-Co2eC_-C.js.map +1 -0
  7. package/dist/admin/chunks/ComponentConfigurationPage-Dj1bNvEF.js +298 -0
  8. package/dist/admin/chunks/ComponentConfigurationPage-Dj1bNvEF.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-Dm5woBp9.js +180 -0
  14. package/dist/admin/chunks/EditConfigurationPage-Dm5woBp9.js.map +1 -0
  15. package/dist/admin/chunks/EditConfigurationPage-zd9OLaVh.js +158 -0
  16. package/dist/admin/chunks/EditConfigurationPage-zd9OLaVh.js.map +1 -0
  17. package/dist/admin/chunks/EditViewPage-DsBKmSPb.js +337 -0
  18. package/dist/admin/chunks/EditViewPage-DsBKmSPb.js.map +1 -0
  19. package/dist/admin/chunks/EditViewPage-kAIaYTg0.js +314 -0
  20. package/dist/admin/chunks/EditViewPage-kAIaYTg0.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-BO69oITe.js +955 -0
  26. package/dist/admin/chunks/Form-BO69oITe.js.map +1 -0
  27. package/dist/admin/chunks/Form-BPIhJKyf.js +978 -0
  28. package/dist/admin/chunks/Form-BPIhJKyf.js.map +1 -0
  29. package/dist/admin/chunks/History-BzvpM-Gw.js +1357 -0
  30. package/dist/admin/chunks/History-BzvpM-Gw.js.map +1 -0
  31. package/dist/admin/chunks/History-DBQ96jv2.js +1380 -0
  32. package/dist/admin/chunks/History-DBQ96jv2.js.map +1 -0
  33. package/dist/admin/chunks/Input-BlDcbhUC.js +6755 -0
  34. package/dist/admin/chunks/Input-BlDcbhUC.js.map +1 -0
  35. package/dist/admin/chunks/Input-Dh1MtWno.js +6786 -0
  36. package/dist/admin/chunks/Input-Dh1MtWno.js.map +1 -0
  37. package/dist/admin/chunks/ListConfigurationPage-8d3BsQIr.js +818 -0
  38. package/dist/admin/chunks/ListConfigurationPage-8d3BsQIr.js.map +1 -0
  39. package/dist/admin/chunks/ListConfigurationPage-DK0ARecn.js +795 -0
  40. package/dist/admin/chunks/ListConfigurationPage-DK0ARecn.js.map +1 -0
  41. package/dist/admin/chunks/ListViewPage-BF2q7N6W.js +1132 -0
  42. package/dist/admin/chunks/ListViewPage-BF2q7N6W.js.map +1 -0
  43. package/dist/admin/chunks/ListViewPage-CS1ED-vI.js +1154 -0
  44. package/dist/admin/chunks/ListViewPage-CS1ED-vI.js.map +1 -0
  45. package/dist/admin/chunks/NoContentTypePage-C5Qxz3I4.js +59 -0
  46. package/dist/admin/chunks/NoContentTypePage-C5Qxz3I4.js.map +1 -0
  47. package/dist/admin/chunks/NoContentTypePage-DjdXr1-j.js +57 -0
  48. package/dist/admin/chunks/NoContentTypePage-DjdXr1-j.js.map +1 -0
  49. package/dist/admin/chunks/NoPermissionsPage-BUwtKUEP.js +36 -0
  50. package/dist/admin/chunks/NoPermissionsPage-BUwtKUEP.js.map +1 -0
  51. package/dist/admin/chunks/NoPermissionsPage-C5dC0MtL.js +38 -0
  52. package/dist/admin/chunks/NoPermissionsPage-C5dC0MtL.js.map +1 -0
  53. package/dist/admin/chunks/Preview-C9kXTY6C.js +531 -0
  54. package/dist/admin/chunks/Preview-C9kXTY6C.js.map +1 -0
  55. package/dist/admin/chunks/Preview-DBvmhR7Q.js +553 -0
  56. package/dist/admin/chunks/Preview-DBvmhR7Q.js.map +1 -0
  57. package/dist/admin/chunks/Relations-Cn0atFpd.js +827 -0
  58. package/dist/admin/chunks/Relations-Cn0atFpd.js.map +1 -0
  59. package/dist/admin/chunks/Relations-XHxDKEvT.js +853 -0
  60. package/dist/admin/chunks/Relations-XHxDKEvT.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/admin/chunks/en-C1CjdAtC.js.map +1 -0
  79. package/dist/admin/chunks/en-LfhocNG2.js +308 -0
  80. package/dist/{_chunks/en-C-J4DGEe.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-BczuAULz.js +5416 -0
  114. package/dist/admin/chunks/index-BczuAULz.js.map +1 -0
  115. package/dist/admin/chunks/index-BkyR-Bnu.js +5350 -0
  116. package/dist/admin/chunks/index-BkyR-Bnu.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-DcDoRT8g.js +618 -0
  130. package/dist/admin/chunks/layout-DcDoRT8g.js.map +1 -0
  131. package/dist/admin/chunks/layout-fghBgRgX.js +598 -0
  132. package/dist/admin/chunks/layout-fghBgRgX.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-CgaydhiM.js +178 -0
  162. package/dist/admin/chunks/relations-CgaydhiM.js.map +1 -0
  163. package/dist/admin/chunks/relations-DPVgU_rq.js +173 -0
  164. package/dist/admin/chunks/relations-DPVgU_rq.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/EditViewPage.d.ts +9 -1
  222. package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +1 -1
  223. package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +3 -3
  224. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.d.ts +7 -0
  225. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/utils/prismLanguages.d.ts +49 -0
  226. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/constants.d.ts +1 -0
  227. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.d.ts +4 -1
  228. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/Field.d.ts +4 -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 +3 -0
  232. package/dist/admin/src/preview/components/PreviewHeader.d.ts +3 -0
  233. package/dist/admin/src/preview/index.d.ts +2 -3
  234. package/dist/admin/src/preview/pages/Preview.d.ts +11 -0
  235. package/dist/admin/src/preview/routes.d.ts +3 -0
  236. package/dist/admin/src/preview/services/preview.d.ts +1 -1
  237. package/dist/admin/src/router.d.ts +1 -1
  238. package/dist/admin/src/services/api.d.ts +1 -1
  239. package/dist/admin/src/services/components.d.ts +2 -2
  240. package/dist/admin/src/services/contentTypes.d.ts +3 -3
  241. package/dist/admin/src/services/documents.d.ts +16 -19
  242. package/dist/admin/src/services/init.d.ts +1 -1
  243. package/dist/admin/src/services/relations.d.ts +2 -2
  244. package/dist/admin/src/services/uid.d.ts +3 -3
  245. package/dist/server/index.js +5461 -4346
  246. package/dist/server/index.js.map +1 -1
  247. package/dist/server/index.mjs +5433 -4315
  248. package/dist/server/index.mjs.map +1 -1
  249. package/dist/server/src/controllers/utils/metadata.d.ts +2 -1
  250. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
  251. package/dist/server/src/history/controllers/history-version.d.ts +1 -1
  252. package/dist/server/src/history/controllers/history-version.d.ts.map +1 -1
  253. package/dist/server/src/history/services/history.d.ts +3 -3
  254. package/dist/server/src/history/services/history.d.ts.map +1 -1
  255. package/dist/server/src/history/services/utils.d.ts +6 -10
  256. package/dist/server/src/history/services/utils.d.ts.map +1 -1
  257. package/dist/server/src/index.d.ts +3 -2
  258. package/dist/server/src/index.d.ts.map +1 -1
  259. package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -1
  260. package/dist/server/src/preview/index.d.ts.map +1 -1
  261. package/dist/server/src/preview/services/index.d.ts +1 -0
  262. package/dist/server/src/preview/services/index.d.ts.map +1 -1
  263. package/dist/server/src/preview/services/preview-config.d.ts +2 -0
  264. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -1
  265. package/dist/server/src/preview/utils.d.ts +1 -0
  266. package/dist/server/src/preview/utils.d.ts.map +1 -1
  267. package/dist/server/src/register.d.ts.map +1 -1
  268. package/dist/server/src/services/document-manager.d.ts.map +1 -1
  269. package/dist/server/src/services/document-metadata.d.ts +4 -2
  270. package/dist/server/src/services/document-metadata.d.ts.map +1 -1
  271. package/dist/server/src/services/index.d.ts +3 -2
  272. package/dist/server/src/services/index.d.ts.map +1 -1
  273. package/dist/server/src/services/utils/configuration/index.d.ts +2 -2
  274. package/dist/server/src/services/utils/configuration/layouts.d.ts +2 -2
  275. package/dist/server/src/services/utils/count.d.ts +1 -1
  276. package/dist/server/src/services/utils/count.d.ts.map +1 -1
  277. package/dist/server/src/services/utils/populate.d.ts +3 -3
  278. package/dist/server/src/services/utils/populate.d.ts.map +1 -1
  279. package/dist/shared/contracts/collection-types.d.ts +0 -1
  280. package/dist/shared/contracts/components.d.ts +0 -1
  281. package/dist/shared/contracts/content-types.d.ts +0 -1
  282. package/dist/shared/contracts/history-versions.d.ts +0 -1
  283. package/dist/shared/contracts/index.d.ts +0 -1
  284. package/dist/shared/contracts/init.d.ts +0 -1
  285. package/dist/shared/contracts/preview.d.ts +0 -1
  286. package/dist/shared/contracts/relations.d.ts +1 -2
  287. package/dist/shared/contracts/relations.d.ts.map +1 -1
  288. package/dist/shared/contracts/review-workflows.d.ts +0 -1
  289. package/dist/shared/contracts/single-types.d.ts +0 -1
  290. package/dist/shared/contracts/uid.d.ts +0 -1
  291. package/dist/shared/index.d.ts +0 -1
  292. package/dist/shared/index.js +35 -24
  293. package/dist/shared/index.js.map +1 -1
  294. package/dist/shared/index.mjs +34 -25
  295. package/dist/shared/index.mjs.map +1 -1
  296. package/package.json +19 -15
  297. package/dist/_chunks/CardDragPreview-C0QyJgRA.js +0 -69
  298. package/dist/_chunks/CardDragPreview-C0QyJgRA.js.map +0 -1
  299. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs +0 -70
  300. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +0 -1
  301. package/dist/_chunks/ComponentConfigurationPage-BUOQFZ08.mjs +0 -236
  302. package/dist/_chunks/ComponentConfigurationPage-BUOQFZ08.mjs.map +0 -1
  303. package/dist/_chunks/ComponentConfigurationPage-WtZ2yaRP.js +0 -255
  304. package/dist/_chunks/ComponentConfigurationPage-WtZ2yaRP.js.map +0 -1
  305. package/dist/_chunks/ComponentIcon-BXdiCGQp.js +0 -176
  306. package/dist/_chunks/ComponentIcon-BXdiCGQp.js.map +0 -1
  307. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs +0 -157
  308. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +0 -1
  309. package/dist/_chunks/EditConfigurationPage-BVrCP5lF.js +0 -151
  310. package/dist/_chunks/EditConfigurationPage-BVrCP5lF.js.map +0 -1
  311. package/dist/_chunks/EditConfigurationPage-D7HkxcAN.mjs +0 -132
  312. package/dist/_chunks/EditConfigurationPage-D7HkxcAN.mjs.map +0 -1
  313. package/dist/_chunks/EditViewPage-BKQ83NAk.js +0 -243
  314. package/dist/_chunks/EditViewPage-BKQ83NAk.js.map +0 -1
  315. package/dist/_chunks/EditViewPage-zKmMBER4.mjs +0 -224
  316. package/dist/_chunks/EditViewPage-zKmMBER4.mjs.map +0 -1
  317. package/dist/_chunks/Field-BbrX_tUG.mjs +0 -5563
  318. package/dist/_chunks/Field-BbrX_tUG.mjs.map +0 -1
  319. package/dist/_chunks/Field-BhN0lyyZ.js +0 -5595
  320. package/dist/_chunks/Field-BhN0lyyZ.js.map +0 -1
  321. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs +0 -50
  322. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +0 -1
  323. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js +0 -49
  324. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +0 -1
  325. package/dist/_chunks/Form-B-E8l73g.mjs +0 -758
  326. package/dist/_chunks/Form-B-E8l73g.mjs.map +0 -1
  327. package/dist/_chunks/Form-CkbrtNZd.js +0 -779
  328. package/dist/_chunks/Form-CkbrtNZd.js.map +0 -1
  329. package/dist/_chunks/History-B2Dg9q7H.js +0 -1050
  330. package/dist/_chunks/History-B2Dg9q7H.js.map +0 -1
  331. package/dist/_chunks/History-C72HQ0-i.mjs +0 -1029
  332. package/dist/_chunks/History-C72HQ0-i.mjs.map +0 -1
  333. package/dist/_chunks/ListConfigurationPage-BQCc3BnJ.js +0 -652
  334. package/dist/_chunks/ListConfigurationPage-BQCc3BnJ.js.map +0 -1
  335. package/dist/_chunks/ListConfigurationPage-BalSo5dp.mjs +0 -632
  336. package/dist/_chunks/ListConfigurationPage-BalSo5dp.mjs.map +0 -1
  337. package/dist/_chunks/ListViewPage-Cu5dZKZe.js +0 -863
  338. package/dist/_chunks/ListViewPage-Cu5dZKZe.js.map +0 -1
  339. package/dist/_chunks/ListViewPage-Dfue5wQ2.mjs +0 -839
  340. package/dist/_chunks/ListViewPage-Dfue5wQ2.mjs.map +0 -1
  341. package/dist/_chunks/NoContentTypePage-BLC8M9U0.mjs +0 -51
  342. package/dist/_chunks/NoContentTypePage-BLC8M9U0.mjs.map +0 -1
  343. package/dist/_chunks/NoContentTypePage-MGzn4JPu.js +0 -51
  344. package/dist/_chunks/NoContentTypePage-MGzn4JPu.js.map +0 -1
  345. package/dist/_chunks/NoPermissionsPage-BpAoEQy_.mjs +0 -23
  346. package/dist/_chunks/NoPermissionsPage-BpAoEQy_.mjs.map +0 -1
  347. package/dist/_chunks/NoPermissionsPage-DJPwEpOD.js +0 -23
  348. package/dist/_chunks/NoPermissionsPage-DJPwEpOD.js.map +0 -1
  349. package/dist/_chunks/Relations-BULOkyWN.mjs +0 -730
  350. package/dist/_chunks/Relations-BULOkyWN.mjs.map +0 -1
  351. package/dist/_chunks/Relations-DTiqnyGx.js +0 -750
  352. package/dist/_chunks/Relations-DTiqnyGx.js.map +0 -1
  353. package/dist/_chunks/ar-BUUWXIYu.js +0 -226
  354. package/dist/_chunks/ar-BUUWXIYu.js.map +0 -1
  355. package/dist/_chunks/ar-CCEVvqGG.mjs +0 -226
  356. package/dist/_chunks/ar-CCEVvqGG.mjs.map +0 -1
  357. package/dist/_chunks/ca-5U32ON2v.mjs +0 -201
  358. package/dist/_chunks/ca-5U32ON2v.mjs.map +0 -1
  359. package/dist/_chunks/ca-Cmk45QO6.js +0 -201
  360. package/dist/_chunks/cs-CM2aBUar.mjs +0 -125
  361. package/dist/_chunks/cs-CM2aBUar.mjs.map +0 -1
  362. package/dist/_chunks/cs-CkJy6B2v.js +0 -125
  363. package/dist/_chunks/de-C72KDNOl.mjs +0 -199
  364. package/dist/_chunks/de-C72KDNOl.mjs.map +0 -1
  365. package/dist/_chunks/de-CCEmbAah.js +0 -199
  366. package/dist/_chunks/en-C-J4DGEe.js +0 -295
  367. package/dist/_chunks/en-DPfZ6tPQ.mjs +0 -295
  368. package/dist/_chunks/en-DPfZ6tPQ.mjs.map +0 -1
  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-76eawJUd.js +0 -4175
  398. package/dist/_chunks/index-76eawJUd.js.map +0 -1
  399. package/dist/_chunks/index-DW7xp_LG.mjs +0 -4155
  400. package/dist/_chunks/index-DW7xp_LG.mjs.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-CVz8WiDC.js +0 -489
  411. package/dist/_chunks/layout-CVz8WiDC.js.map +0 -1
  412. package/dist/_chunks/layout-DNfLIjbP.mjs +0 -471
  413. package/dist/_chunks/layout-DNfLIjbP.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-B6K4WRjW.js +0 -130
  441. package/dist/_chunks/relations-B6K4WRjW.js.map +0 -1
  442. package/dist/_chunks/relations-ByHSIjSe.mjs +0 -131
  443. package/dist/_chunks/relations-ByHSIjSe.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,1050 +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-76eawJUd.js");
11
- const pipe = require("lodash/fp/pipe");
12
- const hooks = require("./hooks-BAaaKPS_.js");
13
- const Field = require("./Field-BhN0lyyZ.js");
14
- const Icons = require("@strapi/icons");
15
- const styledComponents = require("styled-components");
16
- const relations = require("./relations-B6K4WRjW.js");
17
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
18
- function _interopNamespace(e) {
19
- if (e && e.__esModule)
20
- return e;
21
- const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
22
- if (e) {
23
- for (const k in e) {
24
- if (k !== "default") {
25
- const d = Object.getOwnPropertyDescriptor(e, k);
26
- Object.defineProperty(n, k, d.get ? d : {
27
- enumerable: true,
28
- get: () => e[k]
29
- });
30
- }
31
- }
32
- }
33
- n.default = e;
34
- return Object.freeze(n);
35
- }
36
- const React__namespace = /* @__PURE__ */ _interopNamespace(React);
37
- const pipe__default = /* @__PURE__ */ _interopDefault(pipe);
38
- const StyledAlert = styledComponents.styled(designSystem.Alert).attrs({ closeLabel: "Close", onClose: () => {
39
- }, shadow: "none" })`
40
- button {
41
- display: none;
42
- }
43
- `;
44
- const LinkEllipsis = styledComponents.styled(designSystem.Link)`
45
- display: block;
46
-
47
- & > span {
48
- white-space: nowrap;
49
- overflow: hidden;
50
- text-overflow: ellipsis;
51
- display: block;
52
- }
53
- `;
54
- const CustomRelationInput = (props) => {
55
- const { formatMessage } = reactIntl.useIntl();
56
- const field = strapiAdmin.useField(props.name);
57
- let formattedFieldValue;
58
- if (field) {
59
- formattedFieldValue = Array.isArray(field.value) ? { results: field.value, meta: { missingCount: 0 } } : field.value;
60
- }
61
- if (!formattedFieldValue || formattedFieldValue.results.length === 0 && formattedFieldValue.meta.missingCount === 0) {
62
- return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
63
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { action: props.labelAction, children: props.label }),
64
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { marginTop: 1, children: /* @__PURE__ */ jsxRuntime.jsx(StyledAlert, { variant: "default", children: formatMessage({
65
- id: "content-manager.history.content.no-relations",
66
- defaultMessage: "No relations."
67
- }) }) })
68
- ] });
69
- }
70
- const { results, meta } = formattedFieldValue;
71
- return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Box, { children: [
72
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: props.label }),
73
- results.length > 0 && /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", gap: 2, marginTop: 1, alignItems: "stretch", children: results.map((relationData) => {
74
- const { targetModel } = props.attribute;
75
- const href = `../${index.COLLECTION_TYPES}/${targetModel}/${relationData.documentId}`;
76
- const label = relations.getRelationLabel(relationData, props.mainField);
77
- const isAdminUserRelation = targetModel === "admin::user";
78
- return /* @__PURE__ */ jsxRuntime.jsxs(
79
- designSystem.Flex,
80
- {
81
- paddingTop: 2,
82
- paddingBottom: 2,
83
- paddingLeft: 4,
84
- paddingRight: 4,
85
- hasRadius: true,
86
- borderColor: "neutral200",
87
- background: "neutral150",
88
- justifyContent: "space-between",
89
- children: [
90
- /* @__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 }) }) }),
91
- /* @__PURE__ */ jsxRuntime.jsx(index.DocumentStatus, { status: relationData.status })
92
- ]
93
- },
94
- relationData.documentId ?? relationData.id
95
- );
96
- }) }),
97
- meta.missingCount > 0 && /* @ts-expect-error – we dont need closeLabel */
98
- /* @__PURE__ */ jsxRuntime.jsx(
99
- StyledAlert,
100
- {
101
- marginTop: 1,
102
- variant: "warning",
103
- title: formatMessage(
104
- {
105
- id: "content-manager.history.content.missing-relations.title",
106
- defaultMessage: "{number, plural, =1 {Missing relation} other {{number} missing relations}}"
107
- },
108
- { number: meta.missingCount }
109
- ),
110
- children: formatMessage(
111
- {
112
- id: "content-manager.history.content.missing-relations.message",
113
- defaultMessage: "{number, plural, =1 {It has} other {They have}} been deleted and can't be restored."
114
- },
115
- { number: meta.missingCount }
116
- )
117
- }
118
- )
119
- ] });
120
- };
121
- const CustomMediaInput = (props) => {
122
- const { value } = strapiAdmin.useField(props.name);
123
- const results = value ? value.results : [];
124
- const meta = value ? value.meta : { missingCount: 0 };
125
- const { formatMessage } = reactIntl.useIntl();
126
- const fields = strapiAdmin.useStrapiApp("CustomMediaInput", (state) => state.fields);
127
- const MediaLibrary = fields.media;
128
- return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", gap: 2, alignItems: "stretch", children: [
129
- /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Form, { method: "PUT", disabled: true, initialValues: { [props.name]: results }, children: /* @__PURE__ */ jsxRuntime.jsx(MediaLibrary, { ...props, disabled: true, multiple: results.length > 1 }) }),
130
- meta.missingCount > 0 && /* @__PURE__ */ jsxRuntime.jsx(
131
- StyledAlert,
132
- {
133
- variant: "warning",
134
- closeLabel: "Close",
135
- onClose: () => {
136
- },
137
- title: formatMessage(
138
- {
139
- id: "content-manager.history.content.missing-assets.title",
140
- defaultMessage: "{number, plural, =1 {Missing asset} other {{number} missing assets}}"
141
- },
142
- { number: meta.missingCount }
143
- ),
144
- children: formatMessage(
145
- {
146
- id: "content-manager.history.content.missing-assets.message",
147
- defaultMessage: "{number, plural, =1 {It has} other {They have}} been deleted in the Media Library and can't be restored."
148
- },
149
- { number: meta.missingCount }
150
- )
151
- }
152
- )
153
- ] });
154
- };
155
- const getLabelAction = (labelAction) => {
156
- if (!React__namespace.isValidElement(labelAction)) {
157
- return labelAction;
158
- }
159
- const labelActionTitleId = labelAction.props.title.id;
160
- if (labelActionTitleId === "i18n.Field.localized") {
161
- return React__namespace.cloneElement(labelAction, {
162
- ...labelAction.props,
163
- title: {
164
- id: "history.content.localized",
165
- defaultMessage: "This value is specific to this locale. If you restore this version, the content will not be replaced for other locales."
166
- }
167
- });
168
- }
169
- if (labelActionTitleId === "i18n.Field.not-localized") {
170
- return React__namespace.cloneElement(labelAction, {
171
- ...labelAction.props,
172
- title: {
173
- id: "history.content.not-localized",
174
- 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."
175
- }
176
- });
177
- }
178
- return labelAction;
179
- };
180
- const VersionInputRenderer = ({
181
- visible,
182
- hint: providedHint,
183
- shouldIgnoreRBAC = false,
184
- labelAction,
185
- ...props
186
- }) => {
187
- const customLabelAction = getLabelAction(labelAction);
188
- const { formatMessage } = reactIntl.useIntl();
189
- const version = useHistoryContext("VersionContent", (state) => state.selectedVersion);
190
- const configuration = useHistoryContext("VersionContent", (state) => state.configuration);
191
- const fieldSizes = hooks.useTypedSelector((state) => state["content-manager"].app.fieldSizes);
192
- const { id, components } = index.useDoc();
193
- const isFormDisabled = strapiAdmin.useForm("InputRenderer", (state) => state.disabled);
194
- const isInDynamicZone = Field.useDynamicZone("isInDynamicZone", (state) => state.isInDynamicZone);
195
- const canCreateFields = index.useDocumentRBAC("InputRenderer", (rbac) => rbac.canCreateFields);
196
- const canReadFields = index.useDocumentRBAC("InputRenderer", (rbac) => rbac.canReadFields);
197
- const canUpdateFields = index.useDocumentRBAC("InputRenderer", (rbac) => rbac.canUpdateFields);
198
- const canUserAction = index.useDocumentRBAC("InputRenderer", (rbac) => rbac.canUserAction);
199
- const editableFields = id ? canUpdateFields : canCreateFields;
200
- const readableFields = id ? canReadFields : canCreateFields;
201
- const canUserReadField = canUserAction(props.name, readableFields, props.type);
202
- const canUserEditField = canUserAction(props.name, editableFields, props.type);
203
- const fields = strapiAdmin.useStrapiApp("InputRenderer", (app) => app.fields);
204
- const { lazyComponentStore } = Field.useLazyComponents(
205
- attributeHasCustomFieldProperty(props.attribute) ? [props.attribute.customField] : void 0
206
- );
207
- const hint = Field.useFieldHint(providedHint, props.attribute);
208
- const {
209
- edit: { components: componentsLayout }
210
- } = index.useDocLayout();
211
- if (!visible) {
212
- return null;
213
- }
214
- if (!shouldIgnoreRBAC && !canUserReadField && !isInDynamicZone) {
215
- return /* @__PURE__ */ jsxRuntime.jsx(Field.NotAllowedInput, { hint, ...props });
216
- }
217
- const fieldIsDisabled = !canUserEditField && !isInDynamicZone || props.disabled || isFormDisabled;
218
- const addedAttributes = version.meta.unknownAttributes.added;
219
- if (Object.keys(addedAttributes).includes(props.name)) {
220
- return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "flex-start", gap: 1, children: [
221
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: props.label }),
222
- /* @__PURE__ */ jsxRuntime.jsx(
223
- StyledAlert,
224
- {
225
- width: "100%",
226
- closeLabel: "Close",
227
- onClose: () => {
228
- },
229
- variant: "warning",
230
- title: formatMessage({
231
- id: "content-manager.history.content.new-field.title",
232
- defaultMessage: "New field"
233
- }),
234
- children: formatMessage({
235
- id: "content-manager.history.content.new-field.message",
236
- defaultMessage: "This field didn't exist when this version was saved. If you restore this version, it will be empty."
237
- })
238
- }
239
- )
240
- ] });
241
- }
242
- if (attributeHasCustomFieldProperty(props.attribute)) {
243
- const CustomInput = lazyComponentStore[props.attribute.customField];
244
- if (CustomInput) {
245
- return /* @__PURE__ */ jsxRuntime.jsx(
246
- CustomInput,
247
- {
248
- ...props,
249
- hint,
250
- labelAction: customLabelAction,
251
- disabled: fieldIsDisabled
252
- }
253
- );
254
- }
255
- return /* @__PURE__ */ jsxRuntime.jsx(
256
- strapiAdmin.InputRenderer,
257
- {
258
- ...props,
259
- hint,
260
- labelAction: customLabelAction,
261
- type: props.attribute.customField,
262
- disabled: fieldIsDisabled
263
- }
264
- );
265
- }
266
- if (props.type === "media") {
267
- return /* @__PURE__ */ jsxRuntime.jsx(CustomMediaInput, { ...props, labelAction: customLabelAction, disabled: fieldIsDisabled });
268
- }
269
- const addedInputTypes = Object.keys(fields);
270
- if (!attributeHasCustomFieldProperty(props.attribute) && addedInputTypes.includes(props.type)) {
271
- const CustomInput = fields[props.type];
272
- return /* @__PURE__ */ jsxRuntime.jsx(
273
- CustomInput,
274
- {
275
- ...props,
276
- hint,
277
- labelAction: customLabelAction,
278
- disabled: fieldIsDisabled
279
- }
280
- );
281
- }
282
- switch (props.type) {
283
- case "blocks":
284
- return /* @__PURE__ */ jsxRuntime.jsx(Field.MemoizedBlocksInput, { ...props, hint, type: props.type, disabled: fieldIsDisabled });
285
- case "component":
286
- const { layout } = componentsLayout[props.attribute.component];
287
- const [remainingFieldsLayout] = getRemaingFieldsLayout({
288
- layout: [layout],
289
- metadatas: configuration.components[props.attribute.component].metadatas,
290
- fieldSizes,
291
- schemaAttributes: components[props.attribute.component].attributes
292
- });
293
- return /* @__PURE__ */ jsxRuntime.jsx(
294
- Field.MemoizedComponentInput,
295
- {
296
- ...props,
297
- layout: [...layout, ...remainingFieldsLayout || []],
298
- hint,
299
- labelAction: customLabelAction,
300
- disabled: fieldIsDisabled,
301
- children: (inputProps) => /* @__PURE__ */ jsxRuntime.jsx(VersionInputRenderer, { ...inputProps, shouldIgnoreRBAC: true })
302
- }
303
- );
304
- case "dynamiczone":
305
- return /* @__PURE__ */ jsxRuntime.jsx(
306
- Field.DynamicZone,
307
- {
308
- ...props,
309
- hint,
310
- labelAction: customLabelAction,
311
- disabled: fieldIsDisabled
312
- }
313
- );
314
- case "relation":
315
- return /* @__PURE__ */ jsxRuntime.jsx(
316
- CustomRelationInput,
317
- {
318
- ...props,
319
- hint,
320
- labelAction: customLabelAction,
321
- disabled: fieldIsDisabled
322
- }
323
- );
324
- case "richtext":
325
- return /* @__PURE__ */ jsxRuntime.jsx(
326
- Field.MemoizedWysiwyg,
327
- {
328
- ...props,
329
- hint,
330
- type: props.type,
331
- labelAction: customLabelAction,
332
- disabled: fieldIsDisabled
333
- }
334
- );
335
- case "uid":
336
- return /* @__PURE__ */ jsxRuntime.jsx(
337
- Field.MemoizedUIDInput,
338
- {
339
- ...props,
340
- hint,
341
- type: props.type,
342
- labelAction: customLabelAction,
343
- disabled: fieldIsDisabled
344
- }
345
- );
346
- case "enumeration":
347
- return /* @__PURE__ */ jsxRuntime.jsx(
348
- strapiAdmin.InputRenderer,
349
- {
350
- ...props,
351
- hint,
352
- labelAction: customLabelAction,
353
- options: props.attribute.enum.map((value) => ({ value })),
354
- type: props.customField ? "custom-field" : props.type,
355
- disabled: fieldIsDisabled
356
- }
357
- );
358
- default:
359
- const { unique: _unique, mainField: _mainField, ...restProps } = props;
360
- return /* @__PURE__ */ jsxRuntime.jsx(
361
- strapiAdmin.InputRenderer,
362
- {
363
- ...restProps,
364
- hint,
365
- labelAction: customLabelAction,
366
- type: props.customField ? "custom-field" : props.type,
367
- disabled: fieldIsDisabled
368
- }
369
- );
370
- }
371
- };
372
- const attributeHasCustomFieldProperty = (attribute) => "customField" in attribute && typeof attribute.customField === "string";
373
- const createLayoutFromFields = (fields) => {
374
- return fields.reduce((rows, field) => {
375
- if (field.type === "dynamiczone") {
376
- rows.push([field]);
377
- return rows;
378
- }
379
- if (!rows[rows.length - 1]) {
380
- rows.push([]);
381
- }
382
- rows[rows.length - 1].push(field);
383
- return rows;
384
- }, []).map((row) => [row]);
385
- };
386
- function getRemaingFieldsLayout({
387
- layout,
388
- metadatas,
389
- schemaAttributes,
390
- fieldSizes
391
- }) {
392
- const fieldsInLayout = layout.flatMap(
393
- (panel) => panel.flatMap((row) => row.flatMap((field) => field.name))
394
- );
395
- const remainingFields = Object.entries(metadatas).reduce(
396
- (currentRemainingFields, [name, field]) => {
397
- if (!fieldsInLayout.includes(name) && field.edit.visible === true) {
398
- const attribute = schemaAttributes[name];
399
- currentRemainingFields.push({
400
- attribute,
401
- type: attribute.type,
402
- visible: true,
403
- disabled: true,
404
- label: field.edit.label || name,
405
- name,
406
- size: fieldSizes[attribute.type].default ?? 12
407
- });
408
- }
409
- return currentRemainingFields;
410
- },
411
- []
412
- );
413
- return createLayoutFromFields(remainingFields);
414
- }
415
- const FormPanel = ({ panel }) => {
416
- if (panel.some((row) => row.some((field) => field.type === "dynamiczone"))) {
417
- const [row] = panel;
418
- const [field] = row;
419
- 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);
420
- }
421
- return /* @__PURE__ */ jsxRuntime.jsx(
422
- designSystem.Box,
423
- {
424
- hasRadius: true,
425
- background: "neutral0",
426
- shadow: "tableShadow",
427
- paddingLeft: 6,
428
- paddingRight: 6,
429
- paddingTop: 6,
430
- paddingBottom: 6,
431
- borderColor: "neutral150",
432
- 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 }) => {
433
- return /* @__PURE__ */ jsxRuntime.jsx(
434
- designSystem.Grid.Item,
435
- {
436
- col: size,
437
- s: 12,
438
- xs: 12,
439
- direction: "column",
440
- alignItems: "stretch",
441
- children: /* @__PURE__ */ jsxRuntime.jsx(VersionInputRenderer, { ...field })
442
- },
443
- field.name
444
- );
445
- }) }, gridRowIndex)) })
446
- }
447
- );
448
- };
449
- const VersionContent = () => {
450
- const { formatMessage } = reactIntl.useIntl();
451
- const { fieldSizes } = hooks.useTypedSelector((state) => state["content-manager"].app);
452
- const version = useHistoryContext("VersionContent", (state) => state.selectedVersion);
453
- const layout = useHistoryContext("VersionContent", (state) => state.layout);
454
- const configuration = useHistoryContext("VersionContent", (state) => state.configuration);
455
- const schema = useHistoryContext("VersionContent", (state) => state.schema);
456
- const removedAttributes = version.meta.unknownAttributes.removed;
457
- const removedAttributesAsFields = Object.entries(removedAttributes).map(
458
- ([attributeName, attribute]) => {
459
- const field = {
460
- attribute,
461
- shouldIgnoreRBAC: true,
462
- type: attribute.type,
463
- visible: true,
464
- disabled: true,
465
- label: attributeName,
466
- name: attributeName,
467
- size: fieldSizes[attribute.type].default ?? 12
468
- };
469
- return field;
470
- }
471
- );
472
- const unknownFieldsLayout = createLayoutFromFields(removedAttributesAsFields);
473
- const remainingFieldsLayout = getRemaingFieldsLayout({
474
- metadatas: configuration.contentType.metadatas,
475
- layout,
476
- schemaAttributes: schema.attributes,
477
- fieldSizes
478
- });
479
- const { components } = index.useDoc();
480
- const transformedData = React__namespace.useMemo(() => {
481
- const transform = (schemaAttributes, components2 = {}) => (document) => {
482
- const schema2 = { attributes: schemaAttributes };
483
- const transformations = pipe__default.default(
484
- Field.removeFieldsThatDontExistOnSchema(schema2),
485
- Field.prepareTempKeys(schema2, components2)
486
- );
487
- return transformations(document);
488
- };
489
- return transform(version.schema, components)(version.data);
490
- }, [components, version.data, version.schema]);
491
- return /* @__PURE__ */ jsxRuntime.jsxs(strapiAdmin.Layouts.Content, { children: [
492
- /* @__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) => {
493
- return /* @__PURE__ */ jsxRuntime.jsx(FormPanel, { panel }, index2);
494
- }) }) }) }),
495
- removedAttributesAsFields.length > 0 && /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
496
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Divider, {}),
497
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Box, { paddingTop: 8, children: [
498
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "flex-start", paddingBottom: 6, gap: 1, children: [
499
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "delta", children: formatMessage({
500
- id: "content-manager.history.content.unknown-fields.title",
501
- defaultMessage: "Unknown fields"
502
- }) }),
503
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "pi", children: formatMessage(
504
- {
505
- id: "content-manager.history.content.unknown-fields.message",
506
- defaultMessage: "These fields have been deleted or renamed in the Content-Type Builder. <b>These fields will not be restored.</b>"
507
- },
508
- {
509
- b: (chunks) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "pi", fontWeight: "bold", children: chunks })
510
- }
511
- ) })
512
- ] }),
513
- /* @__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) => {
514
- return /* @__PURE__ */ jsxRuntime.jsx(FormPanel, { panel }, index2);
515
- }) }) })
516
- ] })
517
- ] })
518
- ] });
519
- };
520
- const historyVersionsApi = index.contentManagerApi.injectEndpoints({
521
- endpoints: (builder) => ({
522
- getHistoryVersions: builder.query({
523
- query(params) {
524
- return {
525
- url: `/content-manager/history-versions`,
526
- method: "GET",
527
- config: {
528
- params
529
- }
530
- };
531
- },
532
- providesTags: ["HistoryVersion"]
533
- }),
534
- restoreVersion: builder.mutation({
535
- query({ params, body }) {
536
- return {
537
- url: `/content-manager/history-versions/${params.versionId}/restore`,
538
- method: "PUT",
539
- data: body
540
- };
541
- },
542
- invalidatesTags: (_res, _error, { documentId, collectionType, params }) => {
543
- return [
544
- "HistoryVersion",
545
- {
546
- type: "Document",
547
- id: collectionType === index.COLLECTION_TYPES ? `${params.contentType}_${documentId}` : params.contentType
548
- }
549
- ];
550
- }
551
- })
552
- })
553
- });
554
- const { useGetHistoryVersionsQuery, useRestoreVersionMutation } = historyVersionsApi;
555
- const VersionHeader = ({ headerId }) => {
556
- const [isConfirmDialogOpen, setIsConfirmDialogOpen] = React__namespace.useState(false);
557
- const navigate = reactRouterDom.useNavigate();
558
- const { formatMessage, formatDate } = reactIntl.useIntl();
559
- const { toggleNotification } = strapiAdmin.useNotification();
560
- const [{ query }] = strapiAdmin.useQueryParams();
561
- const { collectionType, slug } = reactRouterDom.useParams();
562
- const [restoreVersion, { isLoading }] = useRestoreVersionMutation();
563
- const { allowedActions } = strapiAdmin.useRBAC(index.PERMISSIONS.map((action) => ({ action, subject: slug })));
564
- const version = useHistoryContext("VersionHeader", (state) => state.selectedVersion);
565
- const mainField = useHistoryContext("VersionHeader", (state) => state.mainField);
566
- const schema = useHistoryContext("VersionHeader", (state) => state.schema);
567
- const isCurrentVersion = useHistoryContext(
568
- "VersionHeader",
569
- (state) => state.page === 1 && state.versions.data[0].id === state.selectedVersion.id
570
- );
571
- const mainFieldValue = version.data[mainField];
572
- const getNextNavigation = () => {
573
- const pluginsQueryParams = qs.stringify({ plugins: query.plugins }, { encode: false });
574
- if (collectionType === index.COLLECTION_TYPES) {
575
- return {
576
- pathname: "..",
577
- search: pluginsQueryParams
578
- };
579
- }
580
- return {
581
- pathname: "..",
582
- search: pluginsQueryParams
583
- };
584
- };
585
- const handleRestore = async () => {
586
- try {
587
- const response = await restoreVersion({
588
- documentId: version.relatedDocumentId,
589
- collectionType,
590
- params: {
591
- versionId: version.id,
592
- contentType: version.contentType
593
- },
594
- body: { contentType: version.contentType }
595
- });
596
- if ("data" in response) {
597
- navigate(getNextNavigation(), { relative: "path" });
598
- toggleNotification({
599
- type: "success",
600
- title: formatMessage({
601
- id: "content-manager.restore.success.title",
602
- defaultMessage: "Version restored."
603
- }),
604
- message: formatMessage({
605
- id: "content-manager.restore.success.message",
606
- defaultMessage: "The content of the restored version is not published yet."
607
- })
608
- });
609
- }
610
- if ("error" in response) {
611
- toggleNotification({
612
- type: "danger",
613
- message: formatMessage({
614
- id: "content-manager.history.restore.error.message",
615
- defaultMessage: "Could not restore version."
616
- })
617
- });
618
- }
619
- } catch (error) {
620
- toggleNotification({
621
- type: "danger",
622
- message: formatMessage({ id: "notification.error", defaultMessage: "An error occurred" })
623
- });
624
- }
625
- };
626
- return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Dialog.Root, { open: isConfirmDialogOpen, onOpenChange: setIsConfirmDialogOpen, children: [
627
- /* @__PURE__ */ jsxRuntime.jsx(
628
- strapiAdmin.Layouts.BaseHeader,
629
- {
630
- id: headerId,
631
- title: formatDate(new Date(version.createdAt), {
632
- year: "numeric",
633
- month: "numeric",
634
- day: "numeric",
635
- hour: "numeric",
636
- minute: "numeric"
637
- }),
638
- subtitle: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "epsilon", textColor: "neutral600", children: formatMessage(
639
- {
640
- id: "content-manager.history.version.subtitle",
641
- defaultMessage: "{hasLocale, select, true {{subtitle}, in {locale}} other {{subtitle}}}"
642
- },
643
- {
644
- hasLocale: Boolean(version.locale),
645
- subtitle: `${mainFieldValue || ""} (${schema.info.singularName})`.trim(),
646
- locale: version.locale?.name
647
- }
648
- ) }),
649
- navigationAction: /* @__PURE__ */ jsxRuntime.jsx(
650
- designSystem.Link,
651
- {
652
- startIcon: /* @__PURE__ */ jsxRuntime.jsx(Icons.ArrowLeft, {}),
653
- tag: reactRouterDom.NavLink,
654
- to: getNextNavigation(),
655
- relative: "path",
656
- isExternal: false,
657
- children: formatMessage({
658
- id: "global.back",
659
- defaultMessage: "Back"
660
- })
661
- }
662
- ),
663
- sticky: false,
664
- primaryAction: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Dialog.Trigger, { children: /* @__PURE__ */ jsxRuntime.jsx(
665
- designSystem.Button,
666
- {
667
- disabled: !allowedActions.canUpdate || isCurrentVersion,
668
- onClick: () => {
669
- setIsConfirmDialogOpen(true);
670
- },
671
- children: formatMessage({
672
- id: "content-manager.history.restore.confirm.button",
673
- defaultMessage: "Restore"
674
- })
675
- }
676
- ) })
677
- }
678
- ),
679
- /* @__PURE__ */ jsxRuntime.jsx(
680
- strapiAdmin.ConfirmDialog,
681
- {
682
- onConfirm: handleRestore,
683
- endAction: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { variant: "secondary", onClick: handleRestore, loading: isLoading, children: formatMessage({
684
- id: "content-manager.history.restore.confirm.button",
685
- defaultMessage: "Restore"
686
- }) }),
687
- children: /* @__PURE__ */ jsxRuntime.jsxs(
688
- designSystem.Flex,
689
- {
690
- direction: "column",
691
- alignItems: "center",
692
- justifyContent: "center",
693
- gap: 2,
694
- textAlign: "center",
695
- children: [
696
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { justifyContent: "center", children: /* @__PURE__ */ jsxRuntime.jsx(Icons.WarningCircle, { width: "24px", height: "24px", fill: "danger600" }) }),
697
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { children: formatMessage({
698
- id: "content-manager.history.restore.confirm.title",
699
- defaultMessage: "Are you sure you want to restore this version?"
700
- }) }),
701
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { children: formatMessage(
702
- {
703
- id: "content-manager.history.restore.confirm.message",
704
- 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.}}"
705
- },
706
- {
707
- isDraft: version.status === "draft"
708
- }
709
- ) })
710
- ]
711
- }
712
- )
713
- }
714
- )
715
- ] });
716
- };
717
- const BlueText = (children) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "primary600", variant: "pi", children });
718
- const VersionCard = ({ version, isCurrent }) => {
719
- const { formatDate, formatMessage } = reactIntl.useIntl();
720
- const [{ query }] = strapiAdmin.useQueryParams();
721
- const statusData = (() => {
722
- switch (version.status) {
723
- case "draft":
724
- return {
725
- background: "secondary100",
726
- border: "secondary200",
727
- text: "secondary700",
728
- message: {
729
- id: "content-manager.containers.List.draft",
730
- defaultMessage: "Draft"
731
- }
732
- };
733
- case "modified":
734
- return {
735
- background: "alternative100",
736
- border: "alternative200",
737
- text: "alternative700",
738
- message: {
739
- // TODO: check the translation key once D&P v5 is done
740
- id: "content-manager.containers.List.modified",
741
- defaultMessage: "Modified"
742
- }
743
- };
744
- case "published":
745
- default:
746
- return {
747
- background: "success100",
748
- border: "success200",
749
- text: "success700",
750
- message: {
751
- id: "content-manager.containers.List.published",
752
- defaultMessage: "Published"
753
- }
754
- };
755
- }
756
- })();
757
- const isActive = query.id === version.id.toString();
758
- const author = version.createdBy && index.getDisplayName(version.createdBy);
759
- return /* @__PURE__ */ jsxRuntime.jsxs(
760
- designSystem.Flex,
761
- {
762
- direction: "column",
763
- alignItems: "flex-start",
764
- gap: 3,
765
- hasRadius: true,
766
- borderWidth: "1px",
767
- borderStyle: "solid",
768
- borderColor: isActive ? "primary600" : "neutral200",
769
- color: "neutral800",
770
- padding: 5,
771
- tag: reactRouterDom.Link,
772
- to: `?${qs.stringify({ ...query, id: version.id })}`,
773
- style: { textDecoration: "none" },
774
- children: [
775
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", gap: 1, alignItems: "flex-start", children: [
776
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { tag: "h3", fontWeight: "semiBold", children: formatDate(version.createdAt, {
777
- day: "numeric",
778
- month: "numeric",
779
- year: "numeric",
780
- hour: "2-digit",
781
- minute: "2-digit"
782
- }) }),
783
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { tag: "p", variant: "pi", textColor: "neutral600", children: formatMessage(
784
- {
785
- id: "content-manager.history.sidebar.versionDescription",
786
- defaultMessage: "{distanceToNow}{isAnonymous, select, true {} other { by {author}}}{isCurrent, select, true { <b>(current)</b>} other {}}"
787
- },
788
- {
789
- distanceToNow: /* @__PURE__ */ jsxRuntime.jsx(index.RelativeTime, { timestamp: new Date(version.createdAt) }),
790
- author,
791
- isAnonymous: !Boolean(version.createdBy),
792
- isCurrent,
793
- b: BlueText
794
- }
795
- ) })
796
- ] }),
797
- version.status && /* @__PURE__ */ jsxRuntime.jsx(
798
- designSystem.Box,
799
- {
800
- background: statusData.background,
801
- borderStyle: "solid",
802
- borderWidth: "1px",
803
- borderColor: statusData.border,
804
- hasRadius: true,
805
- paddingLeft: "6px",
806
- paddingRight: "6px",
807
- paddingTop: "2px",
808
- paddingBottom: "2px",
809
- children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "pi", fontWeight: "bold", textColor: statusData.text, children: formatMessage(statusData.message) })
810
- }
811
- )
812
- ]
813
- }
814
- );
815
- };
816
- const PaginationButton = ({ page, children }) => {
817
- const [{ query }] = strapiAdmin.useQueryParams();
818
- const { id: _id, ...queryRest } = query;
819
- 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 }) });
820
- };
821
- const VersionsList = () => {
822
- const { formatMessage } = reactIntl.useIntl();
823
- const { versions, page } = useHistoryContext("VersionsList", (state) => ({
824
- versions: state.versions,
825
- page: state.page
826
- }));
827
- return /* @__PURE__ */ jsxRuntime.jsxs(
828
- designSystem.Flex,
829
- {
830
- shrink: 0,
831
- direction: "column",
832
- alignItems: "stretch",
833
- width: "320px",
834
- height: "100vh",
835
- background: "neutral0",
836
- borderColor: "neutral200",
837
- borderWidth: "0 0 0 1px",
838
- borderStyle: "solid",
839
- tag: "aside",
840
- children: [
841
- /* @__PURE__ */ jsxRuntime.jsxs(
842
- designSystem.Flex,
843
- {
844
- direction: "row",
845
- justifyContent: "space-between",
846
- padding: 4,
847
- borderColor: "neutral200",
848
- borderWidth: "0 0 1px",
849
- borderStyle: "solid",
850
- tag: "header",
851
- children: [
852
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { tag: "h2", variant: "omega", fontWeight: "semiBold", children: formatMessage({
853
- id: "content-manager.history.sidebar.title",
854
- defaultMessage: "Versions"
855
- }) }),
856
- /* @__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 }) })
857
- ]
858
- }
859
- ),
860
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Box, { flex: 1, overflow: "auto", children: [
861
- versions.meta.pagination.page > 1 && /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { paddingTop: 4, textAlign: "center", children: /* @__PURE__ */ jsxRuntime.jsx(PaginationButton, { page: page - 1, children: formatMessage({
862
- id: "content-manager.history.sidebar.show-newer",
863
- defaultMessage: "Show newer versions"
864
- }) }) }),
865
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", gap: 3, padding: 4, tag: "ul", alignItems: "stretch", children: versions.data.map((version, index2) => /* @__PURE__ */ jsxRuntime.jsx(
866
- "li",
867
- {
868
- "aria-label": formatMessage({
869
- id: "content-manager.history.sidebar.title.version-card.aria-label",
870
- defaultMessage: "Version card"
871
- }),
872
- children: /* @__PURE__ */ jsxRuntime.jsx(VersionCard, { version, isCurrent: page === 1 && index2 === 0 })
873
- },
874
- version.id
875
- )) }),
876
- 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({
877
- id: "content-manager.history.sidebar.show-older",
878
- defaultMessage: "Show older versions"
879
- }) }) })
880
- ] })
881
- ]
882
- }
883
- );
884
- };
885
- const [HistoryProvider, useHistoryContext] = strapiAdmin.createContext("HistoryPage");
886
- const HistoryPage = () => {
887
- const headerId = React__namespace.useId();
888
- const { formatMessage } = reactIntl.useIntl();
889
- const {
890
- slug,
891
- id: documentId,
892
- collectionType
893
- } = reactRouterDom.useParams();
894
- const { isLoading: isLoadingDocument, schema } = index.useDocument({
895
- collectionType,
896
- model: slug
897
- });
898
- const {
899
- isLoading: isLoadingLayout,
900
- edit: {
901
- layout,
902
- settings: { displayName, mainField }
903
- }
904
- } = index.useDocumentLayout(slug);
905
- const { data: configuration, isLoading: isLoadingConfiguration } = index.useGetContentTypeConfigurationQuery(slug);
906
- const [{ query }] = strapiAdmin.useQueryParams();
907
- const { id: selectedVersionId, ...queryWithoutId } = query;
908
- const validQueryParamsWithoutId = index.buildValidParams(queryWithoutId);
909
- const page = validQueryParamsWithoutId.page ? Number(validQueryParamsWithoutId.page) : 1;
910
- const versionsResponse = useGetHistoryVersionsQuery(
911
- {
912
- contentType: slug,
913
- ...documentId ? { documentId } : {},
914
- // Omit id since it's not needed by the endpoint and caused extra refetches
915
- ...validQueryParamsWithoutId
916
- },
917
- { refetchOnMountOrArgChange: true }
918
- );
919
- const initialRequestId = React__namespace.useRef(versionsResponse.requestId);
920
- const isStaleRequest = versionsResponse.requestId === initialRequestId.current;
921
- if (!slug || collectionType === index.COLLECTION_TYPES && !documentId) {
922
- return /* @__PURE__ */ jsxRuntime.jsx(reactRouterDom.Navigate, { to: "/content-manager" });
923
- }
924
- if (isLoadingDocument || isLoadingLayout || versionsResponse.isFetching || isStaleRequest || isLoadingConfiguration) {
925
- return /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Loading, {});
926
- }
927
- if (!versionsResponse.isError && !versionsResponse.data?.data?.length) {
928
- return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: /* @__PURE__ */ jsxRuntime.jsx(
929
- strapiAdmin.Page.NoData,
930
- {
931
- action: /* @__PURE__ */ jsxRuntime.jsx(
932
- designSystem.Link,
933
- {
934
- tag: reactRouterDom.NavLink,
935
- to: `/content-manager/${collectionType}/${slug}${documentId ? `/${documentId}` : ""}`,
936
- children: formatMessage({
937
- id: "global.back",
938
- defaultMessage: "Back"
939
- })
940
- }
941
- )
942
- }
943
- ) });
944
- }
945
- if (versionsResponse.data?.data?.length && !selectedVersionId) {
946
- return /* @__PURE__ */ jsxRuntime.jsx(
947
- reactRouterDom.Navigate,
948
- {
949
- to: { search: qs.stringify({ ...query, id: versionsResponse.data.data[0].id }) },
950
- replace: true
951
- }
952
- );
953
- }
954
- const selectedVersion = versionsResponse.data?.data?.find(
955
- (version) => version.id.toString() === selectedVersionId
956
- );
957
- if (versionsResponse.isError || !layout || !schema || !selectedVersion || !configuration || // This should not happen as it's covered by versionsResponse.isError, but we need it for TS
958
- versionsResponse.data.error) {
959
- return /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Error, {});
960
- }
961
- return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
962
- /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Title, { children: formatMessage(
963
- {
964
- id: "content-manager.history.page-title",
965
- defaultMessage: "{contentType} history"
966
- },
967
- {
968
- contentType: displayName
969
- }
970
- ) }),
971
- /* @__PURE__ */ jsxRuntime.jsx(
972
- HistoryProvider,
973
- {
974
- contentType: slug,
975
- id: documentId,
976
- schema,
977
- layout,
978
- configuration,
979
- selectedVersion,
980
- versions: versionsResponse.data,
981
- page,
982
- mainField,
983
- children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "row", alignItems: "flex-start", children: [
984
- /* @__PURE__ */ jsxRuntime.jsxs(
985
- designSystem.Main,
986
- {
987
- grow: 1,
988
- height: "100vh",
989
- background: "neutral100",
990
- paddingBottom: 6,
991
- overflow: "auto",
992
- labelledBy: headerId,
993
- children: [
994
- /* @__PURE__ */ jsxRuntime.jsx(VersionHeader, { headerId }),
995
- /* @__PURE__ */ jsxRuntime.jsx(VersionContent, {})
996
- ]
997
- }
998
- ),
999
- /* @__PURE__ */ jsxRuntime.jsx(VersionsList, {})
1000
- ] })
1001
- }
1002
- )
1003
- ] });
1004
- };
1005
- const ProtectedHistoryPageImpl = () => {
1006
- const { slug } = reactRouterDom.useParams();
1007
- const {
1008
- permissions = [],
1009
- isLoading,
1010
- error
1011
- } = strapiAdmin.useRBAC(index.PERMISSIONS.map((action) => ({ action, subject: slug })));
1012
- if (isLoading) {
1013
- return /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Loading, {});
1014
- }
1015
- if (error || !slug) {
1016
- return /* @__PURE__ */ jsxRuntime.jsx(
1017
- designSystem.Box,
1018
- {
1019
- height: "100vh",
1020
- width: "100vw",
1021
- position: "fixed",
1022
- top: 0,
1023
- left: 0,
1024
- zIndex: 2,
1025
- background: "neutral0",
1026
- children: /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Error, {})
1027
- }
1028
- );
1029
- }
1030
- return /* @__PURE__ */ jsxRuntime.jsx(
1031
- designSystem.Box,
1032
- {
1033
- height: "100vh",
1034
- width: "100vw",
1035
- position: "fixed",
1036
- top: 0,
1037
- left: 0,
1038
- zIndex: 2,
1039
- background: "neutral0",
1040
- children: /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Protect, { permissions, children: ({ permissions: permissions2 }) => /* @__PURE__ */ jsxRuntime.jsx(index.DocumentRBAC, { permissions: permissions2, children: /* @__PURE__ */ jsxRuntime.jsx(HistoryPage, {}) }) })
1041
- }
1042
- );
1043
- };
1044
- const ProtectedHistoryPage = () => {
1045
- return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Portal, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.FocusTrap, { children: /* @__PURE__ */ jsxRuntime.jsx(ProtectedHistoryPageImpl, {}) }) });
1046
- };
1047
- exports.HistoryProvider = HistoryProvider;
1048
- exports.ProtectedHistoryPage = ProtectedHistoryPage;
1049
- exports.useHistoryContext = useHistoryContext;
1050
- //# sourceMappingURL=History-B2Dg9q7H.js.map