@strapi/content-manager 0.0.0-experimental.17b4116f461a49b8ce5386f7c8d79c511d40fb3b → 0.0.0-experimental.1905f36833468f12a6ad1dbd03650aa3b6474658

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 (530) hide show
  1. package/LICENSE +18 -3
  2. package/dist/admin/chunks/CardDragPreview-DwuraT0K.mjs +80 -0
  3. package/dist/admin/chunks/CardDragPreview-DwuraT0K.mjs.map +1 -0
  4. package/dist/admin/chunks/CardDragPreview-_dubYgXO.js +82 -0
  5. package/dist/admin/chunks/CardDragPreview-_dubYgXO.js.map +1 -0
  6. package/dist/admin/chunks/ComponentConfigurationPage-Bn-SMKJG.js +299 -0
  7. package/dist/admin/chunks/ComponentConfigurationPage-Bn-SMKJG.js.map +1 -0
  8. package/dist/admin/chunks/ComponentConfigurationPage-Cqi5KqZa.mjs +277 -0
  9. package/dist/admin/chunks/ComponentConfigurationPage-Cqi5KqZa.mjs.map +1 -0
  10. package/dist/admin/chunks/ComponentIcon-BZcTc4rj.mjs +153 -0
  11. package/dist/admin/chunks/ComponentIcon-BZcTc4rj.mjs.map +1 -0
  12. package/dist/admin/chunks/ComponentIcon-C-EjOUPA.js +176 -0
  13. package/dist/admin/chunks/ComponentIcon-C-EjOUPA.js.map +1 -0
  14. package/dist/admin/chunks/EditConfigurationPage-CRxsqOhS.js +181 -0
  15. package/dist/admin/chunks/EditConfigurationPage-CRxsqOhS.js.map +1 -0
  16. package/dist/admin/chunks/EditConfigurationPage-Dm16gciL.mjs +159 -0
  17. package/dist/admin/chunks/EditConfigurationPage-Dm16gciL.mjs.map +1 -0
  18. package/dist/admin/chunks/EditViewPage-Dk8CeS40.js +334 -0
  19. package/dist/admin/chunks/EditViewPage-Dk8CeS40.js.map +1 -0
  20. package/dist/admin/chunks/EditViewPage-eTCSh2HB.mjs +311 -0
  21. package/dist/admin/chunks/EditViewPage-eTCSh2HB.mjs.map +1 -0
  22. package/dist/admin/chunks/FieldTypeIcon-BY6MrVF4.mjs +56 -0
  23. package/dist/admin/chunks/FieldTypeIcon-BY6MrVF4.mjs.map +1 -0
  24. package/dist/admin/chunks/FieldTypeIcon-Bxh-7Jin.js +58 -0
  25. package/dist/admin/chunks/FieldTypeIcon-Bxh-7Jin.js.map +1 -0
  26. package/dist/admin/chunks/Form-K_hq8zU4.mjs +955 -0
  27. package/dist/admin/chunks/Form-K_hq8zU4.mjs.map +1 -0
  28. package/dist/admin/chunks/Form-PB1sNax8.js +978 -0
  29. package/dist/admin/chunks/Form-PB1sNax8.js.map +1 -0
  30. package/dist/admin/chunks/History-CD5uVchr.mjs +1357 -0
  31. package/dist/admin/chunks/History-CD5uVchr.mjs.map +1 -0
  32. package/dist/admin/chunks/History-CfsF-U-3.js +1380 -0
  33. package/dist/admin/chunks/History-CfsF-U-3.js.map +1 -0
  34. package/dist/admin/chunks/Input-CU93J6dl.js +7221 -0
  35. package/dist/admin/chunks/Input-CU93J6dl.js.map +1 -0
  36. package/dist/admin/chunks/Input-grmHplxs.mjs +7190 -0
  37. package/dist/admin/chunks/Input-grmHplxs.mjs.map +1 -0
  38. package/dist/admin/chunks/ListConfigurationPage-Eo8txFp0.mjs +796 -0
  39. package/dist/admin/chunks/ListConfigurationPage-Eo8txFp0.mjs.map +1 -0
  40. package/dist/admin/chunks/ListConfigurationPage-nZti--Mw.js +819 -0
  41. package/dist/admin/chunks/ListConfigurationPage-nZti--Mw.js.map +1 -0
  42. package/dist/admin/chunks/ListViewPage-BBX-zSka.mjs +1133 -0
  43. package/dist/admin/chunks/ListViewPage-BBX-zSka.mjs.map +1 -0
  44. package/dist/admin/chunks/ListViewPage-DQYvHCxn.js +1155 -0
  45. package/dist/admin/chunks/ListViewPage-DQYvHCxn.js.map +1 -0
  46. package/dist/admin/chunks/NoContentTypePage-C-rbOQO1.mjs +58 -0
  47. package/dist/admin/chunks/NoContentTypePage-C-rbOQO1.mjs.map +1 -0
  48. package/dist/admin/chunks/NoContentTypePage-ChYgz3sN.js +60 -0
  49. package/dist/admin/chunks/NoContentTypePage-ChYgz3sN.js.map +1 -0
  50. package/dist/admin/chunks/NoPermissionsPage-CuxrInhz.mjs +37 -0
  51. package/dist/admin/chunks/NoPermissionsPage-CuxrInhz.mjs.map +1 -0
  52. package/dist/admin/chunks/NoPermissionsPage-H4SAlJeF.js +39 -0
  53. package/dist/admin/chunks/NoPermissionsPage-H4SAlJeF.js.map +1 -0
  54. package/dist/admin/chunks/Preview-Bz2dgOiw.js +692 -0
  55. package/dist/admin/chunks/Preview-Bz2dgOiw.js.map +1 -0
  56. package/dist/admin/chunks/Preview-HqnNXn4S.mjs +670 -0
  57. package/dist/admin/chunks/Preview-HqnNXn4S.mjs.map +1 -0
  58. package/dist/admin/chunks/Relations-BMvL4yMN.mjs +1291 -0
  59. package/dist/admin/chunks/Relations-BMvL4yMN.mjs.map +1 -0
  60. package/dist/admin/chunks/Relations-CbCAt692.js +1318 -0
  61. package/dist/admin/chunks/Relations-CbCAt692.js.map +1 -0
  62. package/dist/admin/chunks/ar-DckYq_WK.mjs +222 -0
  63. package/dist/{_chunks/ar-CCEVvqGG.mjs.map → admin/chunks/ar-DckYq_WK.mjs.map} +1 -1
  64. package/dist/admin/chunks/ar-DeQBSsfl.js +227 -0
  65. package/dist/{_chunks/ru-BT3ybNny.js.map → admin/chunks/ar-DeQBSsfl.js.map} +1 -1
  66. package/dist/admin/chunks/ca-ClDTvatJ.js +202 -0
  67. package/dist/admin/chunks/ca-ClDTvatJ.js.map +1 -0
  68. package/dist/admin/chunks/ca-DviY7mRj.mjs +197 -0
  69. package/dist/admin/chunks/ca-DviY7mRj.mjs.map +1 -0
  70. package/dist/admin/chunks/cs-BJFxwIWj.js +126 -0
  71. package/dist/{_chunks/cs-CkJy6B2v.js.map → admin/chunks/cs-BJFxwIWj.js.map} +1 -1
  72. package/dist/admin/chunks/cs-C7OSYFQ7.mjs +122 -0
  73. package/dist/{_chunks/cs-CM2aBUar.mjs.map → admin/chunks/cs-C7OSYFQ7.mjs.map} +1 -1
  74. package/dist/admin/chunks/de-5QRlDHyR.mjs +195 -0
  75. package/dist/{_chunks/eu-CdALomew.mjs.map → admin/chunks/de-5QRlDHyR.mjs.map} +1 -1
  76. package/dist/admin/chunks/de-CbImAUA5.js +200 -0
  77. package/dist/{_chunks/gu-BRmF601H.js.map → admin/chunks/de-CbImAUA5.js.map} +1 -1
  78. package/dist/admin/chunks/en-CImiNxXE.mjs +310 -0
  79. package/dist/{_chunks/en-MBPul9Su.mjs.map → admin/chunks/en-CImiNxXE.mjs.map} +1 -1
  80. package/dist/admin/chunks/en-CLf4SuMQ.js +315 -0
  81. package/dist/admin/chunks/en-CLf4SuMQ.js.map +1 -0
  82. package/dist/admin/chunks/es-C8vLuvZL.js +197 -0
  83. package/dist/{_chunks/es-EUonQTon.js.map → admin/chunks/es-C8vLuvZL.js.map} +1 -1
  84. package/dist/admin/chunks/es-DkoWSExG.mjs +192 -0
  85. package/dist/{_chunks/ja-CtsUxOvk.mjs.map → admin/chunks/es-DkoWSExG.mjs.map} +1 -1
  86. package/dist/admin/chunks/eu-BG1xX7HK.mjs +198 -0
  87. package/dist/admin/chunks/eu-BG1xX7HK.mjs.map +1 -0
  88. package/dist/admin/chunks/eu-BJW3AvXu.js +203 -0
  89. package/dist/admin/chunks/eu-BJW3AvXu.js.map +1 -0
  90. package/dist/admin/chunks/fr-CFdRaRVj.mjs +215 -0
  91. package/dist/admin/chunks/fr-CFdRaRVj.mjs.map +1 -0
  92. package/dist/admin/chunks/fr-gQSilC7w.js +220 -0
  93. package/dist/admin/chunks/fr-gQSilC7w.js.map +1 -0
  94. package/dist/admin/chunks/gu-D5MMMXRs.mjs +196 -0
  95. package/dist/admin/chunks/gu-D5MMMXRs.mjs.map +1 -0
  96. package/dist/admin/chunks/gu-DPU4wyx7.js +201 -0
  97. package/dist/{_chunks/eu-VDH-3ovk.js.map → admin/chunks/gu-DPU4wyx7.js.map} +1 -1
  98. package/dist/admin/chunks/hi-Dp4omeBb.js +201 -0
  99. package/dist/admin/chunks/hi-Dp4omeBb.js.map +1 -0
  100. package/dist/admin/chunks/hi-lp17SCjr.mjs +196 -0
  101. package/dist/admin/chunks/hi-lp17SCjr.mjs.map +1 -0
  102. package/dist/{_chunks/hooks-BAaaKPS_.js → admin/chunks/hooks-D-sOYd1s.js} +6 -3
  103. package/dist/admin/chunks/hooks-D-sOYd1s.js.map +1 -0
  104. package/dist/admin/chunks/hooks-DMvik5y_.mjs +7 -0
  105. package/dist/admin/chunks/hooks-DMvik5y_.mjs.map +1 -0
  106. package/dist/admin/chunks/hu-CLka1U2C.mjs +198 -0
  107. package/dist/admin/chunks/hu-CLka1U2C.mjs.map +1 -0
  108. package/dist/admin/chunks/hu-CtFJuhTd.js +203 -0
  109. package/dist/admin/chunks/hu-CtFJuhTd.js.map +1 -0
  110. package/dist/admin/chunks/id-D7V5S1rB.js +161 -0
  111. package/dist/{_chunks/it-DkBIs7vD.js.map → admin/chunks/id-D7V5S1rB.js.map} +1 -1
  112. package/dist/admin/chunks/id-USfY9m1g.mjs +156 -0
  113. package/dist/{_chunks/id-BtwA9WJT.mjs.map → admin/chunks/id-USfY9m1g.mjs.map} +1 -1
  114. package/dist/admin/chunks/index-CS_nLuw2.mjs +5382 -0
  115. package/dist/admin/chunks/index-CS_nLuw2.mjs.map +1 -0
  116. package/dist/admin/chunks/index-DfX0uEQT.js +5449 -0
  117. package/dist/admin/chunks/index-DfX0uEQT.js.map +1 -0
  118. package/dist/admin/chunks/it-BAHrwmYS.mjs +158 -0
  119. package/dist/{_chunks/it-BrVPqaf1.mjs.map → admin/chunks/it-BAHrwmYS.mjs.map} +1 -1
  120. package/dist/admin/chunks/it-CQFpa_Dc.js +163 -0
  121. package/dist/{_chunks/ko-woFZPmLk.js.map → admin/chunks/it-CQFpa_Dc.js.map} +1 -1
  122. package/dist/admin/chunks/ja-BWKmBJFT.mjs +192 -0
  123. package/dist/{_chunks/ko-HVQRlfUI.mjs.map → admin/chunks/ja-BWKmBJFT.mjs.map} +1 -1
  124. package/dist/admin/chunks/ja-jdQM-B79.js +197 -0
  125. package/dist/{_chunks/de-CCEmbAah.js.map → admin/chunks/ja-jdQM-B79.js.map} +1 -1
  126. package/dist/admin/chunks/ko-CgADGBNt.mjs +191 -0
  127. package/dist/{_chunks/es-CeXiYflN.mjs.map → admin/chunks/ko-CgADGBNt.mjs.map} +1 -1
  128. package/dist/admin/chunks/ko-k46sEyzt.js +196 -0
  129. package/dist/{_chunks/ja-CcFe8diO.js.map → admin/chunks/ko-k46sEyzt.js.map} +1 -1
  130. package/dist/admin/chunks/layout-B4Uk0v1z.js +619 -0
  131. package/dist/admin/chunks/layout-B4Uk0v1z.js.map +1 -0
  132. package/dist/admin/chunks/layout-BInXGFmo.mjs +599 -0
  133. package/dist/admin/chunks/layout-BInXGFmo.mjs.map +1 -0
  134. package/dist/admin/chunks/ml-CnhCfOn_.mjs +196 -0
  135. package/dist/admin/chunks/ml-CnhCfOn_.mjs.map +1 -0
  136. package/dist/admin/chunks/ml-DqxPwODx.js +201 -0
  137. package/dist/admin/chunks/ml-DqxPwODx.js.map +1 -0
  138. package/dist/admin/chunks/ms-Bh09NFff.mjs +140 -0
  139. package/dist/{_chunks/ms-m_WjyWx7.mjs.map → admin/chunks/ms-Bh09NFff.mjs.map} +1 -1
  140. package/dist/admin/chunks/ms-CvSC0OdG.js +145 -0
  141. package/dist/{_chunks/ms-BuFotyP_.js.map → admin/chunks/ms-CvSC0OdG.js.map} +1 -1
  142. package/dist/admin/chunks/nl-BEubhS8C.js +203 -0
  143. package/dist/admin/chunks/nl-BEubhS8C.js.map +1 -0
  144. package/dist/admin/chunks/nl-C8HYflTc.mjs +198 -0
  145. package/dist/admin/chunks/nl-C8HYflTc.mjs.map +1 -0
  146. package/dist/admin/chunks/objects-C3EebVVe.js +76 -0
  147. package/dist/admin/chunks/objects-C3EebVVe.js.map +1 -0
  148. package/dist/admin/chunks/objects-wl73iEma.mjs +73 -0
  149. package/dist/admin/chunks/objects-wl73iEma.mjs.map +1 -0
  150. package/dist/admin/chunks/pl-DWhGDzmM.js +200 -0
  151. package/dist/{_chunks/ca-Cmk45QO6.js.map → admin/chunks/pl-DWhGDzmM.js.map} +1 -1
  152. package/dist/admin/chunks/pl-MFCZJZuZ.mjs +195 -0
  153. package/dist/{_chunks/ca-5U32ON2v.mjs.map → admin/chunks/pl-MFCZJZuZ.mjs.map} +1 -1
  154. package/dist/admin/chunks/pt-BR-CPtAXD-4.js +202 -0
  155. package/dist/{_chunks/pt-BR-BiOz37D9.js.map → admin/chunks/pt-BR-CPtAXD-4.js.map} +1 -1
  156. package/dist/admin/chunks/pt-BR-CcotyBGJ.mjs +197 -0
  157. package/dist/{_chunks/pt-BR-C71iDxnh.mjs.map → admin/chunks/pt-BR-CcotyBGJ.mjs.map} +1 -1
  158. package/dist/admin/chunks/pt-BoPxN80n.js +96 -0
  159. package/dist/admin/chunks/pt-BoPxN80n.js.map +1 -0
  160. package/dist/admin/chunks/pt-HbmgeiYO.mjs +93 -0
  161. package/dist/admin/chunks/pt-HbmgeiYO.mjs.map +1 -0
  162. package/dist/admin/chunks/relations-9C5dQI9e.js +178 -0
  163. package/dist/admin/chunks/relations-9C5dQI9e.js.map +1 -0
  164. package/dist/admin/chunks/relations-CwL0ThH9.mjs +173 -0
  165. package/dist/admin/chunks/relations-CwL0ThH9.mjs.map +1 -0
  166. package/dist/admin/chunks/ru-C0op0ALG.js +232 -0
  167. package/dist/{_chunks/en-C-V1_90f.js.map → admin/chunks/ru-C0op0ALG.js.map} +1 -1
  168. package/dist/admin/chunks/ru-CB4BUyQp.mjs +230 -0
  169. package/dist/{_chunks/ru-BE6A4Exp.mjs.map → admin/chunks/ru-CB4BUyQp.mjs.map} +1 -1
  170. package/dist/admin/chunks/sa-B_FuPyMw.js +201 -0
  171. package/dist/admin/chunks/sa-B_FuPyMw.js.map +1 -0
  172. package/dist/admin/chunks/sa-n_aPA-pU.mjs +196 -0
  173. package/dist/admin/chunks/sa-n_aPA-pU.mjs.map +1 -0
  174. package/dist/admin/chunks/sk-D_iXML2C.js +203 -0
  175. package/dist/admin/chunks/sk-D_iXML2C.js.map +1 -0
  176. package/dist/admin/chunks/sk-tn_BDjE2.mjs +198 -0
  177. package/dist/admin/chunks/sk-tn_BDjE2.mjs.map +1 -0
  178. package/dist/admin/chunks/sv-BstBC1Yp.js +203 -0
  179. package/dist/admin/chunks/sv-BstBC1Yp.js.map +1 -0
  180. package/dist/admin/chunks/sv-cq4ZrQRd.mjs +198 -0
  181. package/dist/admin/chunks/sv-cq4ZrQRd.mjs.map +1 -0
  182. package/dist/admin/chunks/th-lXoOCqPC.js +149 -0
  183. package/dist/{_chunks/th-D9_GfAjc.js.map → admin/chunks/th-lXoOCqPC.js.map} +1 -1
  184. package/dist/admin/chunks/th-mUH7hEtc.mjs +144 -0
  185. package/dist/{_chunks/uk-CR-zDhAY.mjs.map → admin/chunks/th-mUH7hEtc.mjs.map} +1 -1
  186. package/dist/admin/chunks/tr-CkS6sLIE.js +200 -0
  187. package/dist/admin/chunks/tr-CkS6sLIE.js.map +1 -0
  188. package/dist/admin/chunks/tr-Yt38daxh.mjs +195 -0
  189. package/dist/{_chunks/de-C72KDNOl.mjs.map → admin/chunks/tr-Yt38daxh.mjs.map} +1 -1
  190. package/dist/admin/chunks/uk-BtM6WnaE.mjs +313 -0
  191. package/dist/admin/chunks/uk-BtM6WnaE.mjs.map +1 -0
  192. package/dist/admin/chunks/uk-DB6OgySY.js +318 -0
  193. package/dist/admin/chunks/uk-DB6OgySY.js.map +1 -0
  194. package/dist/admin/chunks/useDragAndDrop-HYwNDExe.mjs +247 -0
  195. package/dist/admin/chunks/useDragAndDrop-HYwNDExe.mjs.map +1 -0
  196. package/dist/admin/chunks/useDragAndDrop-gcqEJMnO.js +271 -0
  197. package/dist/admin/chunks/useDragAndDrop-gcqEJMnO.js.map +1 -0
  198. package/dist/admin/chunks/usePrev-Bjw2dhmq.mjs +18 -0
  199. package/dist/admin/chunks/usePrev-Bjw2dhmq.mjs.map +1 -0
  200. package/dist/admin/chunks/usePrev-DIYl-IAL.js +21 -0
  201. package/dist/admin/chunks/usePrev-DIYl-IAL.js.map +1 -0
  202. package/dist/admin/chunks/vi-BGr1X_HZ.js +112 -0
  203. package/dist/{_chunks/vi-CJlYDheJ.js.map → admin/chunks/vi-BGr1X_HZ.js.map} +1 -1
  204. package/dist/admin/chunks/vi-CvBGlTjr.mjs +108 -0
  205. package/dist/{_chunks/vi-DUXIk_fw.mjs.map → admin/chunks/vi-CvBGlTjr.mjs.map} +1 -1
  206. package/dist/admin/chunks/zh-BmF-sHaT.mjs +205 -0
  207. package/dist/admin/chunks/zh-BmF-sHaT.mjs.map +1 -0
  208. package/dist/admin/chunks/zh-DwFu_Kfj.js +210 -0
  209. package/dist/admin/chunks/zh-DwFu_Kfj.js.map +1 -0
  210. package/dist/admin/chunks/zh-Hans-CI0HKio3.mjs +934 -0
  211. package/dist/{_chunks/zh-Hans-BPQcRIyH.mjs.map → admin/chunks/zh-Hans-CI0HKio3.mjs.map} +1 -1
  212. package/dist/admin/chunks/zh-Hans-JVK9x7xr.js +953 -0
  213. package/dist/{_chunks/zh-Hans-9kOncHGw.js.map → admin/chunks/zh-Hans-JVK9x7xr.js.map} +1 -1
  214. package/dist/admin/index.js +27 -4
  215. package/dist/admin/index.js.map +1 -1
  216. package/dist/admin/index.mjs +17 -10
  217. package/dist/admin/index.mjs.map +1 -1
  218. package/dist/admin/src/components/ComponentIcon.d.ts +6 -3
  219. package/dist/admin/src/components/InjectionZone.d.ts +7 -1
  220. package/dist/admin/src/content-manager.d.ts +9 -5
  221. package/dist/admin/src/exports.d.ts +3 -1
  222. package/dist/admin/src/history/components/VersionInputRenderer.d.ts +1 -1
  223. package/dist/admin/src/history/index.d.ts +3 -0
  224. package/dist/admin/src/history/services/historyVersion.d.ts +2 -2
  225. package/dist/admin/src/hooks/useDocument.d.ts +54 -9
  226. package/dist/admin/src/hooks/useDocumentActions.d.ts +25 -3
  227. package/dist/admin/src/hooks/useDocumentLayout.d.ts +2 -2
  228. package/dist/admin/src/hooks/useDragAndDrop.d.ts +4 -4
  229. package/dist/admin/src/hooks/useKeyboardDragAndDrop.d.ts +1 -1
  230. package/dist/admin/src/index.d.ts +2 -0
  231. package/dist/admin/src/pages/EditView/EditViewPage.d.ts +9 -1
  232. package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +14 -6
  233. package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +3 -3
  234. package/dist/admin/src/pages/EditView/components/EditorToolbarObserver.d.ts +11 -0
  235. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.d.ts +55 -0
  236. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/BlocksInput.d.ts +3 -3
  237. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/constants.d.ts +5 -0
  238. package/dist/admin/src/pages/EditView/components/FormInputs/Component/Input.d.ts +2 -2
  239. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/ComponentCategory.d.ts +3 -5
  240. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.d.ts +4 -1
  241. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/Field.d.ts +4 -1
  242. package/dist/admin/src/pages/EditView/components/FormInputs/Relations.d.ts +31 -18
  243. package/dist/admin/src/pages/EditView/components/FormInputs/UID.d.ts +2 -2
  244. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.d.ts +3 -49
  245. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/Field.d.ts +2 -2
  246. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygFooter.d.ts +2 -2
  247. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.d.ts +1 -2
  248. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygStyles.d.ts +16 -53
  249. package/dist/admin/src/pages/EditView/components/FormLayout.d.ts +29 -1
  250. package/dist/admin/src/pages/EditView/components/Header.d.ts +11 -11
  251. package/dist/admin/src/pages/EditView/components/InputRenderer.d.ts +2 -10
  252. package/dist/admin/src/pages/EditView/utils/data.d.ts +1 -0
  253. package/dist/admin/src/pages/ListView/components/BulkActions/Actions.d.ts +3 -30
  254. package/dist/admin/src/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.d.ts +2 -2
  255. package/dist/admin/src/pages/ListView/components/BulkActions/PublishAction.d.ts +9 -26
  256. package/dist/admin/src/preview/components/PreviewContent.d.ts +3 -0
  257. package/dist/admin/src/preview/components/PreviewHeader.d.ts +3 -0
  258. package/dist/admin/src/preview/components/PreviewSidePanel.d.ts +3 -0
  259. package/dist/admin/src/preview/index.d.ts +3 -0
  260. package/dist/admin/src/preview/pages/Preview.d.ts +13 -0
  261. package/dist/admin/src/preview/routes.d.ts +3 -0
  262. package/dist/admin/src/preview/services/preview.d.ts +3 -0
  263. package/dist/admin/src/router.d.ts +1 -1
  264. package/dist/admin/src/services/api.d.ts +2 -3
  265. package/dist/admin/src/services/components.d.ts +2 -2
  266. package/dist/admin/src/services/contentTypes.d.ts +5 -5
  267. package/dist/admin/src/services/documents.d.ts +31 -20
  268. package/dist/admin/src/services/init.d.ts +2 -2
  269. package/dist/admin/src/services/relations.d.ts +3 -3
  270. package/dist/admin/src/services/uid.d.ts +3 -3
  271. package/dist/admin/src/utils/api.d.ts +4 -18
  272. package/dist/admin/src/utils/validation.d.ts +5 -7
  273. package/dist/server/index.js +5479 -3991
  274. package/dist/server/index.js.map +1 -1
  275. package/dist/server/index.mjs +5473 -3982
  276. package/dist/server/index.mjs.map +1 -1
  277. package/dist/server/src/bootstrap.d.ts.map +1 -1
  278. package/dist/server/src/controllers/collection-types.d.ts.map +1 -1
  279. package/dist/server/src/controllers/index.d.ts.map +1 -1
  280. package/dist/server/src/controllers/relations.d.ts.map +1 -1
  281. package/dist/server/src/controllers/single-types.d.ts.map +1 -1
  282. package/dist/server/src/controllers/uid.d.ts.map +1 -1
  283. package/dist/server/src/controllers/utils/metadata.d.ts +23 -0
  284. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -0
  285. package/dist/server/src/controllers/validation/dimensions.d.ts +11 -0
  286. package/dist/server/src/controllers/validation/dimensions.d.ts.map +1 -0
  287. package/dist/server/src/controllers/validation/index.d.ts +1 -1
  288. package/dist/server/src/history/controllers/history-version.d.ts +1 -1
  289. package/dist/server/src/history/controllers/history-version.d.ts.map +1 -1
  290. package/dist/server/src/history/services/history.d.ts +3 -3
  291. package/dist/server/src/history/services/history.d.ts.map +1 -1
  292. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -1
  293. package/dist/server/src/history/services/utils.d.ts +8 -12
  294. package/dist/server/src/history/services/utils.d.ts.map +1 -1
  295. package/dist/server/src/index.d.ts +21 -36
  296. package/dist/server/src/index.d.ts.map +1 -1
  297. package/dist/server/src/policies/hasPermissions.d.ts.map +1 -1
  298. package/dist/server/src/preview/controllers/index.d.ts +2 -0
  299. package/dist/server/src/preview/controllers/index.d.ts.map +1 -0
  300. package/dist/server/src/preview/controllers/preview.d.ts +13 -0
  301. package/dist/server/src/preview/controllers/preview.d.ts.map +1 -0
  302. package/dist/server/src/preview/controllers/validation/preview.d.ts +6 -0
  303. package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -0
  304. package/dist/server/src/preview/index.d.ts +4 -0
  305. package/dist/server/src/preview/index.d.ts.map +1 -0
  306. package/dist/server/src/preview/routes/index.d.ts +8 -0
  307. package/dist/server/src/preview/routes/index.d.ts.map +1 -0
  308. package/dist/server/src/preview/routes/preview.d.ts +4 -0
  309. package/dist/server/src/preview/routes/preview.d.ts.map +1 -0
  310. package/dist/server/src/preview/services/index.d.ts +16 -0
  311. package/dist/server/src/preview/services/index.d.ts.map +1 -0
  312. package/dist/server/src/preview/services/preview-config.d.ts +32 -0
  313. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -0
  314. package/dist/server/src/preview/services/preview.d.ts +12 -0
  315. package/dist/server/src/preview/services/preview.d.ts.map +1 -0
  316. package/dist/server/src/preview/utils.d.ts +19 -0
  317. package/dist/server/src/preview/utils.d.ts.map +1 -0
  318. package/dist/server/src/register.d.ts.map +1 -1
  319. package/dist/server/src/routes/index.d.ts.map +1 -1
  320. package/dist/server/src/services/document-manager.d.ts +11 -6
  321. package/dist/server/src/services/document-manager.d.ts.map +1 -1
  322. package/dist/server/src/services/document-metadata.d.ts +16 -35
  323. package/dist/server/src/services/document-metadata.d.ts.map +1 -1
  324. package/dist/server/src/services/index.d.ts +21 -36
  325. package/dist/server/src/services/index.d.ts.map +1 -1
  326. package/dist/server/src/services/permission-checker.d.ts.map +1 -1
  327. package/dist/server/src/services/utils/count.d.ts +1 -1
  328. package/dist/server/src/services/utils/count.d.ts.map +1 -1
  329. package/dist/server/src/services/utils/populate.d.ts +9 -2
  330. package/dist/server/src/services/utils/populate.d.ts.map +1 -1
  331. package/dist/server/src/utils/index.d.ts +2 -0
  332. package/dist/server/src/utils/index.d.ts.map +1 -1
  333. package/dist/shared/contracts/collection-types.d.ts +17 -8
  334. package/dist/shared/contracts/collection-types.d.ts.map +1 -1
  335. package/dist/shared/contracts/components.d.ts +0 -1
  336. package/dist/shared/contracts/content-types.d.ts +0 -1
  337. package/dist/shared/contracts/history-versions.d.ts +0 -1
  338. package/dist/shared/contracts/index.d.ts +1 -1
  339. package/dist/shared/contracts/index.d.ts.map +1 -1
  340. package/dist/shared/contracts/init.d.ts +0 -1
  341. package/dist/shared/contracts/preview.d.ts +26 -0
  342. package/dist/shared/contracts/preview.d.ts.map +1 -0
  343. package/dist/shared/contracts/relations.d.ts +3 -4
  344. package/dist/shared/contracts/relations.d.ts.map +1 -1
  345. package/dist/shared/contracts/review-workflows.d.ts +0 -1
  346. package/dist/shared/contracts/single-types.d.ts +0 -1
  347. package/dist/shared/contracts/uid.d.ts +0 -1
  348. package/dist/shared/index.d.ts +0 -1
  349. package/dist/shared/index.js +37 -22
  350. package/dist/shared/index.js.map +1 -1
  351. package/dist/shared/index.mjs +36 -23
  352. package/dist/shared/index.mjs.map +1 -1
  353. package/package.json +30 -27
  354. package/dist/_chunks/CardDragPreview-DSVYodBX.js +0 -73
  355. package/dist/_chunks/CardDragPreview-DSVYodBX.js.map +0 -1
  356. package/dist/_chunks/CardDragPreview-ikSG4M46.mjs +0 -72
  357. package/dist/_chunks/CardDragPreview-ikSG4M46.mjs.map +0 -1
  358. package/dist/_chunks/ComponentConfigurationPage-2iOVVhqV.js +0 -255
  359. package/dist/_chunks/ComponentConfigurationPage-2iOVVhqV.js.map +0 -1
  360. package/dist/_chunks/ComponentConfigurationPage-DjQBdcKF.mjs +0 -236
  361. package/dist/_chunks/ComponentConfigurationPage-DjQBdcKF.mjs.map +0 -1
  362. package/dist/_chunks/ComponentIcon-BBQsYCVn.js +0 -170
  363. package/dist/_chunks/ComponentIcon-BBQsYCVn.js.map +0 -1
  364. package/dist/_chunks/ComponentIcon-BOFnK76n.mjs +0 -151
  365. package/dist/_chunks/ComponentIcon-BOFnK76n.mjs.map +0 -1
  366. package/dist/_chunks/EditConfigurationPage-B7dw5_cS.js +0 -151
  367. package/dist/_chunks/EditConfigurationPage-B7dw5_cS.js.map +0 -1
  368. package/dist/_chunks/EditConfigurationPage-BoBb-DLH.mjs +0 -132
  369. package/dist/_chunks/EditConfigurationPage-BoBb-DLH.mjs.map +0 -1
  370. package/dist/_chunks/EditViewPage-KRG56aCq.js +0 -224
  371. package/dist/_chunks/EditViewPage-KRG56aCq.js.map +0 -1
  372. package/dist/_chunks/EditViewPage-aUnqL-63.mjs +0 -203
  373. package/dist/_chunks/EditViewPage-aUnqL-63.mjs.map +0 -1
  374. package/dist/_chunks/Field-kVFO4ZKB.mjs +0 -5319
  375. package/dist/_chunks/Field-kVFO4ZKB.mjs.map +0 -1
  376. package/dist/_chunks/Field-kq1c2TF1.js +0 -5352
  377. package/dist/_chunks/Field-kq1c2TF1.js.map +0 -1
  378. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs +0 -50
  379. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +0 -1
  380. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js +0 -49
  381. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +0 -1
  382. package/dist/_chunks/Form-CQ67ZifP.js +0 -759
  383. package/dist/_chunks/Form-CQ67ZifP.js.map +0 -1
  384. package/dist/_chunks/Form-Jgh5hGTu.mjs +0 -737
  385. package/dist/_chunks/Form-Jgh5hGTu.mjs.map +0 -1
  386. package/dist/_chunks/History-BLEnudTX.js +0 -956
  387. package/dist/_chunks/History-BLEnudTX.js.map +0 -1
  388. package/dist/_chunks/History-DKhZAPcK.mjs +0 -934
  389. package/dist/_chunks/History-DKhZAPcK.mjs.map +0 -1
  390. package/dist/_chunks/ListConfigurationPage-Zso_LUjn.js +0 -643
  391. package/dist/_chunks/ListConfigurationPage-Zso_LUjn.js.map +0 -1
  392. package/dist/_chunks/ListConfigurationPage-nrXcxNYi.mjs +0 -622
  393. package/dist/_chunks/ListConfigurationPage-nrXcxNYi.mjs.map +0 -1
  394. package/dist/_chunks/ListViewPage-ChhYmA-L.mjs +0 -835
  395. package/dist/_chunks/ListViewPage-ChhYmA-L.mjs.map +0 -1
  396. package/dist/_chunks/ListViewPage-DsaOakWQ.js +0 -859
  397. package/dist/_chunks/ListViewPage-DsaOakWQ.js.map +0 -1
  398. package/dist/_chunks/NoContentTypePage-BrdFcN33.mjs +0 -51
  399. package/dist/_chunks/NoContentTypePage-BrdFcN33.mjs.map +0 -1
  400. package/dist/_chunks/NoContentTypePage-DPCuS9Y1.js +0 -51
  401. package/dist/_chunks/NoContentTypePage-DPCuS9Y1.js.map +0 -1
  402. package/dist/_chunks/NoPermissionsPage-B9dqrtTy.mjs +0 -23
  403. package/dist/_chunks/NoPermissionsPage-B9dqrtTy.mjs.map +0 -1
  404. package/dist/_chunks/NoPermissionsPage-DdyOfdKb.js +0 -23
  405. package/dist/_chunks/NoPermissionsPage-DdyOfdKb.js.map +0 -1
  406. package/dist/_chunks/Relations-CY8Isqdu.js +0 -705
  407. package/dist/_chunks/Relations-CY8Isqdu.js.map +0 -1
  408. package/dist/_chunks/Relations-DjFiYd7-.mjs +0 -684
  409. package/dist/_chunks/Relations-DjFiYd7-.mjs.map +0 -1
  410. package/dist/_chunks/ar-BUUWXIYu.js +0 -226
  411. package/dist/_chunks/ar-BUUWXIYu.js.map +0 -1
  412. package/dist/_chunks/ar-CCEVvqGG.mjs +0 -226
  413. package/dist/_chunks/ca-5U32ON2v.mjs +0 -201
  414. package/dist/_chunks/ca-Cmk45QO6.js +0 -201
  415. package/dist/_chunks/cs-CM2aBUar.mjs +0 -125
  416. package/dist/_chunks/cs-CkJy6B2v.js +0 -125
  417. package/dist/_chunks/de-C72KDNOl.mjs +0 -199
  418. package/dist/_chunks/de-CCEmbAah.js +0 -199
  419. package/dist/_chunks/en-C-V1_90f.js +0 -285
  420. package/dist/_chunks/en-MBPul9Su.mjs +0 -285
  421. package/dist/_chunks/es-CeXiYflN.mjs +0 -196
  422. package/dist/_chunks/es-EUonQTon.js +0 -196
  423. package/dist/_chunks/eu-CdALomew.mjs +0 -202
  424. package/dist/_chunks/eu-VDH-3ovk.js +0 -202
  425. package/dist/_chunks/fr-B7kGGg3E.js +0 -206
  426. package/dist/_chunks/fr-B7kGGg3E.js.map +0 -1
  427. package/dist/_chunks/fr-CD9VFbPM.mjs +0 -206
  428. package/dist/_chunks/fr-CD9VFbPM.mjs.map +0 -1
  429. package/dist/_chunks/gu-BRmF601H.js +0 -200
  430. package/dist/_chunks/gu-CNpaMDpH.mjs +0 -200
  431. package/dist/_chunks/gu-CNpaMDpH.mjs.map +0 -1
  432. package/dist/_chunks/hi-CCJBptSq.js +0 -200
  433. package/dist/_chunks/hi-CCJBptSq.js.map +0 -1
  434. package/dist/_chunks/hi-Dwvd04m3.mjs +0 -200
  435. package/dist/_chunks/hi-Dwvd04m3.mjs.map +0 -1
  436. package/dist/_chunks/hooks-BAaaKPS_.js.map +0 -1
  437. package/dist/_chunks/hooks-E5u1mcgM.mjs +0 -8
  438. package/dist/_chunks/hooks-E5u1mcgM.mjs.map +0 -1
  439. package/dist/_chunks/hu-CeYvaaO0.mjs +0 -202
  440. package/dist/_chunks/hu-CeYvaaO0.mjs.map +0 -1
  441. package/dist/_chunks/hu-sNV_yLYy.js +0 -202
  442. package/dist/_chunks/hu-sNV_yLYy.js.map +0 -1
  443. package/dist/_chunks/id-B5Ser98A.js +0 -160
  444. package/dist/_chunks/id-B5Ser98A.js.map +0 -1
  445. package/dist/_chunks/id-BtwA9WJT.mjs +0 -160
  446. package/dist/_chunks/index-CAc9yTnx.mjs +0 -3175
  447. package/dist/_chunks/index-CAc9yTnx.mjs.map +0 -1
  448. package/dist/_chunks/index-DNa1J4HE.js +0 -3195
  449. package/dist/_chunks/index-DNa1J4HE.js.map +0 -1
  450. package/dist/_chunks/it-BrVPqaf1.mjs +0 -162
  451. package/dist/_chunks/it-DkBIs7vD.js +0 -162
  452. package/dist/_chunks/ja-CcFe8diO.js +0 -196
  453. package/dist/_chunks/ja-CtsUxOvk.mjs +0 -196
  454. package/dist/_chunks/ko-HVQRlfUI.mjs +0 -195
  455. package/dist/_chunks/ko-woFZPmLk.js +0 -195
  456. package/dist/_chunks/layout-BqtLA6Lb.js +0 -473
  457. package/dist/_chunks/layout-BqtLA6Lb.js.map +0 -1
  458. package/dist/_chunks/layout-CXsHbc3E.mjs +0 -453
  459. package/dist/_chunks/layout-CXsHbc3E.mjs.map +0 -1
  460. package/dist/_chunks/ml-BihZwQit.mjs +0 -200
  461. package/dist/_chunks/ml-BihZwQit.mjs.map +0 -1
  462. package/dist/_chunks/ml-C2W8N8k1.js +0 -200
  463. package/dist/_chunks/ml-C2W8N8k1.js.map +0 -1
  464. package/dist/_chunks/ms-BuFotyP_.js +0 -144
  465. package/dist/_chunks/ms-m_WjyWx7.mjs +0 -144
  466. package/dist/_chunks/nl-D4R9gHx5.mjs +0 -202
  467. package/dist/_chunks/nl-D4R9gHx5.mjs.map +0 -1
  468. package/dist/_chunks/nl-bbEOHChV.js +0 -202
  469. package/dist/_chunks/nl-bbEOHChV.js.map +0 -1
  470. package/dist/_chunks/objects-gigeqt7s.js +0 -49
  471. package/dist/_chunks/objects-gigeqt7s.js.map +0 -1
  472. package/dist/_chunks/objects-mKMAmfec.mjs +0 -47
  473. package/dist/_chunks/objects-mKMAmfec.mjs.map +0 -1
  474. package/dist/_chunks/pl-sbx9mSt_.mjs +0 -199
  475. package/dist/_chunks/pl-sbx9mSt_.mjs.map +0 -1
  476. package/dist/_chunks/pl-uzwG-hk7.js +0 -199
  477. package/dist/_chunks/pl-uzwG-hk7.js.map +0 -1
  478. package/dist/_chunks/pt-BR-BiOz37D9.js +0 -201
  479. package/dist/_chunks/pt-BR-C71iDxnh.mjs +0 -201
  480. package/dist/_chunks/pt-BsaFvS8-.mjs +0 -95
  481. package/dist/_chunks/pt-BsaFvS8-.mjs.map +0 -1
  482. package/dist/_chunks/pt-CeXQuq50.js +0 -95
  483. package/dist/_chunks/pt-CeXQuq50.js.map +0 -1
  484. package/dist/_chunks/relations-BHY_KDJ_.js +0 -134
  485. package/dist/_chunks/relations-BHY_KDJ_.js.map +0 -1
  486. package/dist/_chunks/relations-mMFEcZRq.mjs +0 -135
  487. package/dist/_chunks/relations-mMFEcZRq.mjs.map +0 -1
  488. package/dist/_chunks/ru-BE6A4Exp.mjs +0 -231
  489. package/dist/_chunks/ru-BT3ybNny.js +0 -231
  490. package/dist/_chunks/sa-CcvkYInH.js +0 -200
  491. package/dist/_chunks/sa-CcvkYInH.js.map +0 -1
  492. package/dist/_chunks/sa-Dag0k-Z8.mjs +0 -200
  493. package/dist/_chunks/sa-Dag0k-Z8.mjs.map +0 -1
  494. package/dist/_chunks/sk-BFg-R8qJ.mjs +0 -202
  495. package/dist/_chunks/sk-BFg-R8qJ.mjs.map +0 -1
  496. package/dist/_chunks/sk-CvY09Xjv.js +0 -202
  497. package/dist/_chunks/sk-CvY09Xjv.js.map +0 -1
  498. package/dist/_chunks/sv-CUnfWGsh.mjs +0 -202
  499. package/dist/_chunks/sv-CUnfWGsh.mjs.map +0 -1
  500. package/dist/_chunks/sv-MYDuzgvT.js +0 -202
  501. package/dist/_chunks/sv-MYDuzgvT.js.map +0 -1
  502. package/dist/_chunks/th-BqbI8lIT.mjs +0 -148
  503. package/dist/_chunks/th-BqbI8lIT.mjs.map +0 -1
  504. package/dist/_chunks/th-D9_GfAjc.js +0 -148
  505. package/dist/_chunks/tr-CgeK3wJM.mjs +0 -199
  506. package/dist/_chunks/tr-CgeK3wJM.mjs.map +0 -1
  507. package/dist/_chunks/tr-D9UH-O_R.js +0 -199
  508. package/dist/_chunks/tr-D9UH-O_R.js.map +0 -1
  509. package/dist/_chunks/uk-C8EiqJY7.js +0 -144
  510. package/dist/_chunks/uk-C8EiqJY7.js.map +0 -1
  511. package/dist/_chunks/uk-CR-zDhAY.mjs +0 -144
  512. package/dist/_chunks/urls-CbOsUOoW.mjs +0 -7
  513. package/dist/_chunks/urls-CbOsUOoW.mjs.map +0 -1
  514. package/dist/_chunks/urls-DzZya_gm.js +0 -6
  515. package/dist/_chunks/urls-DzZya_gm.js.map +0 -1
  516. package/dist/_chunks/useDragAndDrop-DdHgKsqq.mjs +0 -231
  517. package/dist/_chunks/useDragAndDrop-DdHgKsqq.mjs.map +0 -1
  518. package/dist/_chunks/useDragAndDrop-J0TUUbR6.js +0 -249
  519. package/dist/_chunks/useDragAndDrop-J0TUUbR6.js.map +0 -1
  520. package/dist/_chunks/vi-CJlYDheJ.js +0 -111
  521. package/dist/_chunks/vi-DUXIk_fw.mjs +0 -111
  522. package/dist/_chunks/zh-BWZspA60.mjs +0 -209
  523. package/dist/_chunks/zh-BWZspA60.mjs.map +0 -1
  524. package/dist/_chunks/zh-CQQfszqR.js +0 -209
  525. package/dist/_chunks/zh-CQQfszqR.js.map +0 -1
  526. package/dist/_chunks/zh-Hans-9kOncHGw.js +0 -952
  527. package/dist/_chunks/zh-Hans-BPQcRIyH.mjs +0 -952
  528. package/dist/server/src/controllers/utils/dimensions.d.ts +0 -5
  529. package/dist/server/src/controllers/utils/dimensions.d.ts.map +0 -1
  530. package/strapi-server.js +0 -3
@@ -1,835 +0,0 @@
1
- import { jsxs, jsx, Fragment } from "react/jsx-runtime";
2
- import * as React from "react";
3
- import { useRef, useEffect } from "react";
4
- import { useTracking, useAuth, useQueryParams, useAdminUsers, Filters, useField, useRBAC, useNotification, useAPIErrorHandler, useStrapiApp, Page, Layouts, BackButton, SearchInput, Table, Pagination } from "@strapi/admin/strapi-admin";
5
- import { useCollator, Combobox, ComboboxOption, Typography, Menu, Tooltip, Badge, Avatar, Flex, AvatarGroup, useNotifyAT, Loader, IconButton, Popover, LinkButton, TextButton, BaseCheckbox, Button } from "@strapi/design-system";
6
- import { Cog, ListPlus, Plus } from "@strapi/icons";
7
- import isEqual from "lodash/isEqual";
8
- import { stringify } from "qs";
9
- import { useIntl } from "react-intl";
10
- import { NavLink, useNavigate, Link, useParams } from "react-router-dom";
11
- import styled from "styled-components";
12
- import { n as useContentTypeSchema, o as useGetContentTypeConfigurationQuery, p as CREATOR_FIELDS, q as getMainField, t as getDisplayName, b as useDoc, g as getTranslation, f as useDocumentLayout, v as checkIfAttributeIsDisplayable, c as buildValidParams, w as useGetAllDocumentsQuery, e as useDocumentRBAC, I as InjectionZone, D as DocumentStatus, T as TableActions, j as PERMISSIONS, k as DocumentRBAC, H as HOOKS, x as convertListLayoutToFieldLayouts } from "./index-CAc9yTnx.mjs";
13
- import isEmpty from "lodash/isEmpty";
14
- import parseISO from "date-fns/parseISO";
15
- import toString from "lodash/toString";
16
- import { p as prefixFileUrlWithBackendUrl } from "./urls-CbOsUOoW.mjs";
17
- import { g as getRelationLabel, u as useGetRelationsQuery } from "./relations-mMFEcZRq.mjs";
18
- import { u as useTypedSelector } from "./hooks-E5u1mcgM.mjs";
19
- const usePrev = (value) => {
20
- const ref = useRef();
21
- useEffect(() => {
22
- ref.current = value;
23
- }, [value]);
24
- return ref.current;
25
- };
26
- const NOT_ALLOWED_FILTERS = [
27
- "json",
28
- "component",
29
- "media",
30
- "richtext",
31
- "dynamiczone",
32
- "password",
33
- "blocks"
34
- ];
35
- const DEFAULT_ALLOWED_FILTERS = ["createdAt", "updatedAt"];
36
- const USER_FILTER_ATTRIBUTES = [...CREATOR_FIELDS, "strapi_assignee"];
37
- const FiltersImpl = ({ disabled, schema }) => {
38
- const { attributes, uid: model, options } = schema;
39
- const { formatMessage, locale } = useIntl();
40
- const { trackUsage } = useTracking();
41
- const allPermissions = useAuth("FiltersImpl", (state) => state.permissions);
42
- const [{ query }] = useQueryParams();
43
- const { schemas } = useContentTypeSchema();
44
- const canReadAdminUsers = React.useMemo(
45
- () => allPermissions.filter(
46
- (permission) => permission.action === "admin::users.read" && permission.subject === null
47
- ).length > 0,
48
- [allPermissions]
49
- );
50
- const selectedUserIds = (query?.filters?.$and ?? []).reduce((acc, filter) => {
51
- const [key, value] = Object.entries(filter)[0];
52
- if (typeof value.id !== "object") {
53
- return acc;
54
- }
55
- const id = value.id.$eq || value.id.$ne;
56
- if (id && USER_FILTER_ATTRIBUTES.includes(key) && !acc.includes(id)) {
57
- acc.push(id);
58
- }
59
- return acc;
60
- }, []);
61
- const { data: userData, isLoading: isLoadingAdminUsers } = useAdminUsers(
62
- { filters: { id: { $in: selectedUserIds } } },
63
- {
64
- // fetch the list of admin users only if the filter contains users and the
65
- // current user has permissions to display users
66
- skip: selectedUserIds.length === 0 || !canReadAdminUsers
67
- }
68
- );
69
- const { users = [] } = userData ?? {};
70
- const { metadata } = useGetContentTypeConfigurationQuery(model, {
71
- selectFromResult: ({ data }) => ({ metadata: data?.contentType.metadatas ?? {} })
72
- });
73
- const formatter = useCollator(locale, {
74
- sensitivity: "base"
75
- });
76
- const displayedFilters = React.useMemo(() => {
77
- const [{ properties: { fields = [] } = { fields: [] } }] = allPermissions.filter(
78
- (permission) => permission.action === "plugin::content-manager.explorer.read" && permission.subject === model
79
- );
80
- const allowedFields = fields.filter((field) => {
81
- const attribute = attributes[field] ?? {};
82
- return attribute.type && !NOT_ALLOWED_FILTERS.includes(attribute.type);
83
- });
84
- return [
85
- "id",
86
- ...allowedFields,
87
- ...DEFAULT_ALLOWED_FILTERS,
88
- ...canReadAdminUsers ? CREATOR_FIELDS : []
89
- ].map((name) => {
90
- const attribute = attributes[name];
91
- if (NOT_ALLOWED_FILTERS.includes(attribute.type)) {
92
- return null;
93
- }
94
- const { mainField: mainFieldName = "", label } = metadata[name].list;
95
- let filter = {
96
- name,
97
- label: label ?? "",
98
- mainField: getMainField(attribute, mainFieldName, { schemas, components: {} }),
99
- // @ts-expect-error – TODO: this is filtered out above in the `allowedFields` call but TS complains, is there a better way to solve this?
100
- type: attribute.type
101
- };
102
- if (attribute.type === "relation" && "target" in attribute && attribute.target === "admin::user") {
103
- filter = {
104
- ...filter,
105
- input: AdminUsersFilter,
106
- options: users.map((user) => ({
107
- label: getDisplayName(user),
108
- value: user.id.toString()
109
- })),
110
- operators: [
111
- {
112
- label: formatMessage({
113
- id: "components.FilterOptions.FILTER_TYPES.$eq",
114
- defaultMessage: "is"
115
- }),
116
- value: "$eq"
117
- },
118
- {
119
- label: formatMessage({
120
- id: "components.FilterOptions.FILTER_TYPES.$ne",
121
- defaultMessage: "is not"
122
- }),
123
- value: "$ne"
124
- }
125
- ],
126
- mainField: {
127
- name: "id",
128
- type: "integer"
129
- }
130
- };
131
- }
132
- return filter;
133
- }).filter(Boolean).toSorted((a, b) => formatter.compare(a.label, b.label));
134
- }, [
135
- allPermissions,
136
- canReadAdminUsers,
137
- model,
138
- attributes,
139
- metadata,
140
- schemas,
141
- users,
142
- formatMessage,
143
- formatter
144
- ]);
145
- const onOpenChange = (isOpen) => {
146
- if (isOpen) {
147
- trackUsage("willFilterEntries");
148
- }
149
- };
150
- const handleFilterChange = (data) => {
151
- const attribute = attributes[data.name];
152
- if (attribute) {
153
- trackUsage("didFilterEntries", {
154
- useRelation: attribute.type === "relation"
155
- });
156
- }
157
- };
158
- return /* @__PURE__ */ jsxs(
159
- Filters.Root,
160
- {
161
- disabled,
162
- options: displayedFilters,
163
- onOpenChange,
164
- onChange: handleFilterChange,
165
- children: [
166
- /* @__PURE__ */ jsx(Filters.Trigger, {}),
167
- /* @__PURE__ */ jsx(Filters.Popover, {}),
168
- /* @__PURE__ */ jsx(Filters.List, {})
169
- ]
170
- }
171
- );
172
- };
173
- const AdminUsersFilter = ({ name }) => {
174
- const [page, setPage] = React.useState(1);
175
- const { formatMessage } = useIntl();
176
- const { data, isLoading } = useAdminUsers({
177
- page
178
- });
179
- const field = useField(name);
180
- const handleOpenChange = (isOpen) => {
181
- if (!isOpen) {
182
- setPage(1);
183
- }
184
- };
185
- const users = data?.users || [];
186
- return /* @__PURE__ */ jsx(
187
- Combobox,
188
- {
189
- value: field.value,
190
- "aria-label": formatMessage({
191
- id: "content-manager.components.Filters.usersSelect.label",
192
- defaultMessage: "Search and select a user to filter"
193
- }),
194
- onOpenChange: handleOpenChange,
195
- onChange: (value) => field.onChange(name, value),
196
- loading: isLoading,
197
- onLoadMore: () => setPage((prev) => prev + 1),
198
- children: users.map((user) => {
199
- return /* @__PURE__ */ jsx(ComboboxOption, { value: user.id.toString(), children: getDisplayName(user) }, user.id);
200
- })
201
- }
202
- );
203
- };
204
- const CellValue = ({ type, value }) => {
205
- const { formatDate, formatTime, formatNumber } = useIntl();
206
- let formattedValue = value;
207
- if (type === "date") {
208
- formattedValue = formatDate(parseISO(value), { dateStyle: "full" });
209
- }
210
- if (type === "datetime") {
211
- formattedValue = formatDate(value, { dateStyle: "full", timeStyle: "short" });
212
- }
213
- if (type === "time") {
214
- const [hour, minute, second] = value.split(":");
215
- const date = /* @__PURE__ */ new Date();
216
- date.setHours(hour);
217
- date.setMinutes(minute);
218
- date.setSeconds(second);
219
- formattedValue = formatTime(date, {
220
- timeStyle: "short"
221
- });
222
- }
223
- if (["float", "decimal"].includes(type)) {
224
- formattedValue = formatNumber(value, {
225
- // Should be kept in sync with the corresponding value
226
- // in the design-system/NumberInput: https://github.com/strapi/design-system/blob/main/packages/strapi-design-system/src/NumberInput/NumberInput.js#L53
227
- maximumFractionDigits: 20
228
- });
229
- }
230
- if (["integer", "biginteger"].includes(type)) {
231
- formattedValue = formatNumber(value, { maximumFractionDigits: 0 });
232
- }
233
- return toString(formattedValue);
234
- };
235
- const SingleComponent = ({ content, mainField }) => {
236
- if (!mainField) {
237
- return null;
238
- }
239
- return /* @__PURE__ */ jsx(Tooltip, { label: content[mainField.name], children: /* @__PURE__ */ jsx(SingleComponentTypography, { textColor: "neutral800", ellipsis: true, children: /* @__PURE__ */ jsx(CellValue, { type: mainField.type, value: content[mainField.name] }) }) });
240
- };
241
- const SingleComponentTypography = styled(Typography)`
242
- max-width: 250px;
243
- `;
244
- const RepeatableComponent = ({ content, mainField }) => {
245
- const { formatMessage } = useIntl();
246
- if (!mainField) {
247
- return null;
248
- }
249
- return /* @__PURE__ */ jsxs(Menu.Root, { children: [
250
- /* @__PURE__ */ jsxs(MenuTrigger$1, { onClick: (e) => e.stopPropagation(), children: [
251
- /* @__PURE__ */ jsx(Badge, { children: content.length }),
252
- " ",
253
- formatMessage(
254
- {
255
- id: "content-manager.containers.list.items",
256
- defaultMessage: "{number, plural, =0 {items} one {item} other {items}}"
257
- },
258
- { number: content.length }
259
- )
260
- ] }),
261
- /* @__PURE__ */ jsx(Menu.Content, { children: content.map((item) => /* @__PURE__ */ jsx(Menu.Item, { disabled: true, children: /* @__PURE__ */ jsx(RepeatableComponentTypography, { ellipsis: true, children: /* @__PURE__ */ jsx(CellValue, { type: mainField.type, value: item[mainField.name] }) }) }, item.id)) })
262
- ] });
263
- };
264
- const RepeatableComponentTypography = styled(Typography)`
265
- max-width: 500px;
266
- `;
267
- const MenuTrigger$1 = styled(Menu.Trigger)`
268
- svg {
269
- width: 0.6rem;
270
- height: 0.4rem;
271
- }
272
- `;
273
- const getFileExtension = (ext) => ext && ext[0] === "." ? ext.substring(1) : ext;
274
- const MediaSingle = ({ url, mime, alternativeText, name, ext, formats }) => {
275
- const fileURL = prefixFileUrlWithBackendUrl(url);
276
- if (mime.includes("image")) {
277
- const thumbnail = formats?.thumbnail?.url;
278
- const mediaURL = prefixFileUrlWithBackendUrl(thumbnail) || fileURL;
279
- return /* @__PURE__ */ jsx(Avatar, { src: mediaURL, alt: alternativeText || name, preview: true });
280
- }
281
- const fileExtension = getFileExtension(ext);
282
- const fileName = name.length > 100 ? `${name.substring(0, 100)}...` : name;
283
- return /* @__PURE__ */ jsx(Tooltip, { description: fileName, children: /* @__PURE__ */ jsx(FileWrapper, { children: fileExtension }) });
284
- };
285
- const FileWrapper = ({ children }) => {
286
- return /* @__PURE__ */ jsx(
287
- Flex,
288
- {
289
- as: "span",
290
- position: "relative",
291
- borderRadius: "50%",
292
- width: "26px",
293
- height: "26px",
294
- borderColor: "neutral200",
295
- background: "neutral150",
296
- paddingLeft: "1px",
297
- justifyContent: "center",
298
- alignItems: "center",
299
- children: /* @__PURE__ */ jsx(FileTypography, { variant: "sigma", textColor: "neutral600", children })
300
- }
301
- );
302
- };
303
- const FileTypography = styled(Typography)`
304
- font-size: 0.9rem;
305
- line-height: 0.9rem;
306
- `;
307
- const MediaMultiple = ({ content }) => {
308
- return /* @__PURE__ */ jsx(AvatarGroup, { children: content.map((file, index) => {
309
- const key = `${file.id}${index}`;
310
- if (index === 3) {
311
- const remainingFiles = `+${content.length - 3}`;
312
- return /* @__PURE__ */ jsx(FileWrapper, { children: remainingFiles }, key);
313
- }
314
- if (index > 3) {
315
- return null;
316
- }
317
- return /* @__PURE__ */ jsx(MediaSingle, { ...file }, key);
318
- }) });
319
- };
320
- const RelationSingle = ({ mainField, content }) => {
321
- return /* @__PURE__ */ jsx(TypographyMaxWidth$1, { textColor: "neutral800", ellipsis: true, children: getRelationLabel(content, mainField) });
322
- };
323
- const TypographyMaxWidth$1 = styled(Typography)`
324
- max-width: 500px;
325
- `;
326
- const RelationMultiple = ({ mainField, content, rowId, name }) => {
327
- const { model } = useDoc();
328
- const { formatMessage } = useIntl();
329
- const { notifyStatus } = useNotifyAT();
330
- const [isOpen, setIsOpen] = React.useState(false);
331
- const [targetField] = name.split(".");
332
- const { data, isLoading } = useGetRelationsQuery(
333
- {
334
- model,
335
- id: rowId,
336
- targetField
337
- },
338
- {
339
- skip: !isOpen,
340
- refetchOnMountOrArgChange: true
341
- }
342
- );
343
- React.useEffect(() => {
344
- if (data) {
345
- notifyStatus(
346
- formatMessage({
347
- id: getTranslation("DynamicTable.relation-loaded"),
348
- defaultMessage: "Relations have been loaded"
349
- })
350
- );
351
- }
352
- }, [data, formatMessage, notifyStatus]);
353
- return /* @__PURE__ */ jsxs(Menu.Root, { onOpenChange: (isOpen2) => setIsOpen(isOpen2), children: [
354
- /* @__PURE__ */ jsx(MenuTrigger, { onClick: (e) => e.stopPropagation(), children: /* @__PURE__ */ jsxs(Flex, { gap: 1, wrap: "nowrap", children: [
355
- /* @__PURE__ */ jsx(Badge, { children: content.count }),
356
- formatMessage(
357
- {
358
- id: "content-manager.containers.list.items",
359
- defaultMessage: "{number, plural, =0 {items} one {item} other {items}}"
360
- },
361
- { number: content.count }
362
- )
363
- ] }) }),
364
- /* @__PURE__ */ jsxs(Menu.Content, { children: [
365
- isLoading && /* @__PURE__ */ jsx(Menu.Item, { disabled: true, children: /* @__PURE__ */ jsx(Loader, { small: true, children: formatMessage({
366
- id: getTranslation("ListViewTable.relation-loading"),
367
- defaultMessage: "Relations are loading"
368
- }) }) }),
369
- data?.results && /* @__PURE__ */ jsxs(Fragment, { children: [
370
- data.results.map((entry) => /* @__PURE__ */ jsx(Menu.Item, { disabled: true, children: /* @__PURE__ */ jsx(TypographyMaxWidth$1, { ellipsis: true, children: getRelationLabel(entry, mainField) }) }, entry.documentId)),
371
- data?.pagination && data?.pagination.total > 10 && /* @__PURE__ */ jsx(
372
- Menu.Item,
373
- {
374
- "aria-disabled": true,
375
- "aria-label": formatMessage({
376
- id: getTranslation("ListViewTable.relation-more"),
377
- defaultMessage: "This relation contains more entities than displayed"
378
- }),
379
- children: /* @__PURE__ */ jsx(Typography, { children: "…" })
380
- }
381
- )
382
- ] })
383
- ] })
384
- ] });
385
- };
386
- const MenuTrigger = styled(Menu.Trigger)`
387
- svg {
388
- width: 0.6rem;
389
- height: 0.4rem;
390
- }
391
- `;
392
- const CellContent = ({ content, mainField, attribute, rowId, name }) => {
393
- if (!hasContent(content, mainField, attribute)) {
394
- return /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", children: "-" });
395
- }
396
- switch (attribute.type) {
397
- case "media":
398
- if (!attribute.multiple) {
399
- return /* @__PURE__ */ jsx(MediaSingle, { ...content });
400
- }
401
- return /* @__PURE__ */ jsx(MediaMultiple, { content });
402
- case "relation": {
403
- if (isSingleRelation(attribute.relation)) {
404
- return /* @__PURE__ */ jsx(RelationSingle, { mainField, content });
405
- }
406
- return /* @__PURE__ */ jsx(RelationMultiple, { rowId, mainField, content, name });
407
- }
408
- case "component":
409
- if (attribute.repeatable) {
410
- return /* @__PURE__ */ jsx(RepeatableComponent, { mainField, content });
411
- }
412
- return /* @__PURE__ */ jsx(SingleComponent, { mainField, content });
413
- case "string":
414
- return /* @__PURE__ */ jsx(Tooltip, { description: content, children: /* @__PURE__ */ jsx(TypographyMaxWidth, { ellipsis: true, textColor: "neutral800", children: /* @__PURE__ */ jsx(CellValue, { type: attribute.type, value: content }) }) });
415
- default:
416
- return /* @__PURE__ */ jsx(TypographyMaxWidth, { ellipsis: true, textColor: "neutral800", children: /* @__PURE__ */ jsx(CellValue, { type: attribute.type, value: content }) });
417
- }
418
- };
419
- const TypographyMaxWidth = styled(Typography)`
420
- max-width: 300px;
421
- `;
422
- const hasContent = (content, mainField, attribute) => {
423
- if (attribute.type === "component") {
424
- if (attribute.repeatable || !mainField) {
425
- return content?.length > 0;
426
- }
427
- const value = content?.[mainField.name];
428
- if (mainField.name === "id" && ![void 0, null].includes(value)) {
429
- return true;
430
- }
431
- return !isEmpty(value);
432
- }
433
- if (attribute.type === "relation") {
434
- if (isSingleRelation(attribute.relation)) {
435
- return !isEmpty(content);
436
- }
437
- return content?.count > 0;
438
- }
439
- if (["integer", "decimal", "float", "number"].includes(attribute.type)) {
440
- return typeof content === "number";
441
- }
442
- if (attribute.type === "boolean") {
443
- return content !== null;
444
- }
445
- return !isEmpty(content);
446
- };
447
- const isSingleRelation = (type) => ["oneToOne", "manyToOne", "oneToOneMorph"].includes(type);
448
- const ViewSettingsMenu = (props) => {
449
- const [isVisible, setIsVisible] = React.useState(false);
450
- const cogButtonRef = React.useRef(null);
451
- const permissions = useTypedSelector(
452
- (state) => state.admin_app.permissions.contentManager?.collectionTypesConfigurations ?? []
453
- );
454
- const [{ query }] = useQueryParams();
455
- const { formatMessage } = useIntl();
456
- const {
457
- allowedActions: { canConfigureView }
458
- } = useRBAC(permissions);
459
- const handleToggle = () => {
460
- setIsVisible((prev) => !prev);
461
- };
462
- return /* @__PURE__ */ jsxs(Fragment, { children: [
463
- /* @__PURE__ */ jsx(
464
- IconButton,
465
- {
466
- icon: /* @__PURE__ */ jsx(Cog, {}),
467
- label: formatMessage({
468
- id: "components.ViewSettings.tooltip",
469
- defaultMessage: "View Settings"
470
- }),
471
- ref: cogButtonRef,
472
- onClick: handleToggle
473
- }
474
- ),
475
- isVisible && /* @__PURE__ */ jsx(
476
- Popover,
477
- {
478
- placement: "bottom-end",
479
- source: cogButtonRef,
480
- onDismiss: handleToggle,
481
- spacing: 4,
482
- padding: 3,
483
- children: /* @__PURE__ */ jsxs(Flex, { alignItems: "stretch", direction: "column", gap: 3, children: [
484
- canConfigureView ? /* @__PURE__ */ jsx(
485
- LinkButton,
486
- {
487
- size: "S",
488
- startIcon: /* @__PURE__ */ jsx(ListPlus, {}),
489
- variant: "secondary",
490
- as: NavLink,
491
- to: {
492
- pathname: "configurations/list",
493
- search: query.plugins ? stringify({ plugins: query.plugins }, { encode: false }) : ""
494
- },
495
- children: formatMessage({
496
- id: "app.links.configure-view",
497
- defaultMessage: "Configure the view"
498
- })
499
- }
500
- ) : null,
501
- /* @__PURE__ */ jsx(FieldPicker, { ...props })
502
- ] })
503
- }
504
- )
505
- ] });
506
- };
507
- const FieldPicker = ({ headers = [], resetHeaders, setHeaders }) => {
508
- const { trackUsage } = useTracking();
509
- const { formatMessage, locale } = useIntl();
510
- const { schema, model } = useDoc();
511
- const { list } = useDocumentLayout(model);
512
- const formatter = useCollator(locale, {
513
- sensitivity: "base"
514
- });
515
- const attributes = schema?.attributes ?? {};
516
- const columns = Object.keys(attributes).filter((name) => checkIfAttributeIsDisplayable(attributes[name])).map((name) => ({
517
- name,
518
- label: list.metadatas[name]?.label ?? ""
519
- })).sort((a, b) => formatter.compare(a.label, b.label));
520
- const handleChange = (name) => {
521
- trackUsage("didChangeDisplayedFields");
522
- const newHeaders = headers.includes(name) ? headers.filter((header) => header !== name) : [...headers, name];
523
- setHeaders(newHeaders);
524
- };
525
- const handleReset = () => {
526
- resetHeaders();
527
- };
528
- return /* @__PURE__ */ jsxs(Flex, { as: "fieldset", direction: "column", alignItems: "stretch", gap: 3, children: [
529
- /* @__PURE__ */ jsxs(Flex, { justifyContent: "space-between", children: [
530
- /* @__PURE__ */ jsx(Typography, { as: "legend", variant: "pi", fontWeight: "bold", children: formatMessage({
531
- id: "containers.list.displayedFields",
532
- defaultMessage: "Displayed fields"
533
- }) }),
534
- /* @__PURE__ */ jsx(TextButton, { onClick: handleReset, children: formatMessage({
535
- id: "app.components.Button.reset",
536
- defaultMessage: "Reset"
537
- }) })
538
- ] }),
539
- /* @__PURE__ */ jsx(Flex, { direction: "column", alignItems: "stretch", children: columns.map((header) => {
540
- const isActive = headers.includes(header.name);
541
- return /* @__PURE__ */ jsxs(
542
- ChackboxWrapper,
543
- {
544
- wrap: "wrap",
545
- gap: 2,
546
- as: "label",
547
- background: isActive ? "primary100" : "transparent",
548
- hasRadius: true,
549
- padding: 2,
550
- children: [
551
- /* @__PURE__ */ jsx(
552
- BaseCheckbox,
553
- {
554
- onChange: () => handleChange(header.name),
555
- value: isActive,
556
- name: header.name
557
- }
558
- ),
559
- /* @__PURE__ */ jsx(Typography, { fontSize: 1, children: header.label })
560
- ]
561
- },
562
- header.name
563
- );
564
- }) })
565
- ] });
566
- };
567
- const ChackboxWrapper = styled(Flex)`
568
- :hover {
569
- background-color: ${(props) => props.theme.colors.primary100};
570
- }
571
- `;
572
- const { INJECT_COLUMN_IN_TABLE } = HOOKS;
573
- const ListViewPage = () => {
574
- const { trackUsage } = useTracking();
575
- const navigate = useNavigate();
576
- const { formatMessage } = useIntl();
577
- const { toggleNotification } = useNotification();
578
- const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler(getTranslation);
579
- const { collectionType, model, schema } = useDoc();
580
- const { list } = useDocumentLayout(model);
581
- const [displayedHeaders, setDisplayedHeaders] = React.useState([]);
582
- const listLayout = usePrev(list.layout);
583
- React.useEffect(() => {
584
- if (!isEqual(listLayout, list.layout)) {
585
- setDisplayedHeaders(list.layout);
586
- }
587
- }, [list.layout, listLayout]);
588
- const handleSetHeaders = (headers) => {
589
- setDisplayedHeaders(
590
- convertListLayoutToFieldLayouts(headers, schema.attributes, list.metadatas)
591
- );
592
- };
593
- const [{ query }] = useQueryParams({
594
- page: "1",
595
- pageSize: list.settings.pageSize.toString(),
596
- sort: list.settings.defaultSortBy ? `${list.settings.defaultSortBy}:${list.settings.defaultSortOrder}` : ""
597
- });
598
- const params = React.useMemo(() => buildValidParams(query), [query]);
599
- const { data, error, isLoading } = useGetAllDocumentsQuery({
600
- model,
601
- params
602
- });
603
- React.useEffect(() => {
604
- if (error) {
605
- toggleNotification({
606
- type: "danger",
607
- message: formatAPIError(error)
608
- });
609
- }
610
- }, [error, formatAPIError, toggleNotification]);
611
- const { results = [], pagination } = data ?? {};
612
- React.useEffect(() => {
613
- if (pagination && pagination.pageCount > 0 && pagination.page > pagination.pageCount) {
614
- navigate(
615
- {
616
- search: stringify({
617
- ...query,
618
- page: pagination.pageCount
619
- })
620
- },
621
- { replace: true }
622
- );
623
- }
624
- }, [pagination, formatMessage, query, navigate]);
625
- const { canCreate } = useDocumentRBAC("ListViewPage", ({ canCreate: canCreate2 }) => ({
626
- canCreate: canCreate2
627
- }));
628
- const runHookWaterfall = useStrapiApp("ListViewPage", ({ runHookWaterfall: runHookWaterfall2 }) => runHookWaterfall2);
629
- const tableHeaders = React.useMemo(() => {
630
- const headers = runHookWaterfall(INJECT_COLUMN_IN_TABLE, {
631
- displayedHeaders,
632
- layout: list
633
- });
634
- const formattedHeaders = headers.displayedHeaders.map((header) => {
635
- return {
636
- ...header,
637
- label: typeof header.label === "string" ? header.label : formatMessage(header.label),
638
- name: `${header.name}${header.mainField ? `.${header.mainField}` : ""}`
639
- };
640
- });
641
- if (schema?.options?.draftAndPublish) {
642
- formattedHeaders.push({
643
- attribute: {
644
- type: "custom"
645
- },
646
- name: "status",
647
- label: formatMessage({
648
- id: getTranslation(`containers.list.table-headers.status`),
649
- defaultMessage: "status"
650
- }),
651
- searchable: false,
652
- sortable: false
653
- });
654
- }
655
- return formattedHeaders;
656
- }, [displayedHeaders, formatMessage, list, runHookWaterfall, schema?.options?.draftAndPublish]);
657
- if (isLoading) {
658
- return /* @__PURE__ */ jsx(Page.Loading, {});
659
- }
660
- if (error) {
661
- return /* @__PURE__ */ jsx(Page.Error, {});
662
- }
663
- const contentTypeTitle = schema?.info.displayName ?? "Untitled";
664
- const handleRowClick = (id) => () => {
665
- trackUsage("willEditEntryFromList");
666
- navigate({
667
- pathname: id.toString(),
668
- search: stringify({ plugins: query.plugins })
669
- });
670
- };
671
- return /* @__PURE__ */ jsxs(Page.Main, { children: [
672
- /* @__PURE__ */ jsx(Page.Title, { children: `${contentTypeTitle}` }),
673
- /* @__PURE__ */ jsx(
674
- Layouts.Header,
675
- {
676
- primaryAction: canCreate ? /* @__PURE__ */ jsx(CreateButton, {}) : null,
677
- subtitle: formatMessage(
678
- {
679
- id: getTranslation("pages.ListView.header-subtitle"),
680
- defaultMessage: "{number, plural, =0 {# entries} one {# entry} other {# entries}} found"
681
- },
682
- { number: pagination?.total }
683
- ),
684
- title: contentTypeTitle,
685
- navigationAction: /* @__PURE__ */ jsx(BackButton, {})
686
- }
687
- ),
688
- /* @__PURE__ */ jsx(
689
- Layouts.Action,
690
- {
691
- endActions: /* @__PURE__ */ jsxs(Fragment, { children: [
692
- /* @__PURE__ */ jsx(InjectionZone, { area: "listView.actions" }),
693
- /* @__PURE__ */ jsx(
694
- ViewSettingsMenu,
695
- {
696
- setHeaders: handleSetHeaders,
697
- resetHeaders: () => setDisplayedHeaders(list.layout),
698
- headers: displayedHeaders.map((header) => header.name)
699
- }
700
- )
701
- ] }),
702
- startActions: /* @__PURE__ */ jsxs(Fragment, { children: [
703
- list.settings.searchable && /* @__PURE__ */ jsx(
704
- SearchInput,
705
- {
706
- disabled: results.length === 0,
707
- label: formatMessage(
708
- { id: "app.component.search.label", defaultMessage: "Search for {target}" },
709
- { target: contentTypeTitle }
710
- ),
711
- placeholder: formatMessage({
712
- id: "global.search",
713
- defaultMessage: "Search"
714
- }),
715
- trackedEvent: "didSearch"
716
- }
717
- ),
718
- list.settings.filterable && schema ? /* @__PURE__ */ jsx(FiltersImpl, { disabled: results.length === 0, schema }) : null
719
- ] })
720
- }
721
- ),
722
- /* @__PURE__ */ jsx(Layouts.Content, { children: /* @__PURE__ */ jsxs(Flex, { gap: 4, direction: "column", alignItems: "stretch", children: [
723
- /* @__PURE__ */ jsxs(Table.Root, { rows: results, headers: tableHeaders, isLoading, children: [
724
- /* @__PURE__ */ jsx(Table.ActionBar, {}),
725
- /* @__PURE__ */ jsxs(Table.Content, { children: [
726
- /* @__PURE__ */ jsxs(Table.Head, { children: [
727
- /* @__PURE__ */ jsx(Table.HeaderCheckboxCell, {}),
728
- tableHeaders.map((header) => /* @__PURE__ */ jsx(Table.HeaderCell, { ...header }, header.name))
729
- ] }),
730
- /* @__PURE__ */ jsx(Table.Loading, {}),
731
- /* @__PURE__ */ jsx(Table.Empty, { action: canCreate ? /* @__PURE__ */ jsx(CreateButton, { variant: "secondary" }) : null }),
732
- /* @__PURE__ */ jsx(Table.Body, { children: results.map((row) => {
733
- return /* @__PURE__ */ jsxs(
734
- Table.Row,
735
- {
736
- cursor: "pointer",
737
- onClick: handleRowClick(row.documentId),
738
- children: [
739
- /* @__PURE__ */ jsx(Table.CheckboxCell, { id: row.id }),
740
- tableHeaders.map(({ cellFormatter, ...header }) => {
741
- if (header.name === "status") {
742
- const { status } = row;
743
- return /* @__PURE__ */ jsx(Table.Cell, { children: /* @__PURE__ */ jsx(DocumentStatus, { status, maxWidth: "min-content" }) }, header.name);
744
- }
745
- if (["createdBy", "updatedBy"].includes(header.name.split(".")[0])) {
746
- return /* @__PURE__ */ jsx(Table.Cell, { children: /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", children: row[header.name.split(".")[0]] ? getDisplayName(row[header.name.split(".")[0]]) : "-" }) }, header.name);
747
- }
748
- if (typeof cellFormatter === "function") {
749
- return /* @__PURE__ */ jsx(Table.Cell, { children: cellFormatter(row, header, { collectionType, model }) }, header.name);
750
- }
751
- return /* @__PURE__ */ jsx(Table.Cell, { children: /* @__PURE__ */ jsx(
752
- CellContent,
753
- {
754
- content: row[header.name.split(".")[0]],
755
- rowId: row.documentId,
756
- ...header
757
- }
758
- ) }, header.name);
759
- }),
760
- /* @__PURE__ */ jsx(ActionsCell, { onClick: (e) => e.stopPropagation(), children: /* @__PURE__ */ jsx(TableActions, { document: row }) })
761
- ]
762
- },
763
- row.id
764
- );
765
- }) })
766
- ] })
767
- ] }),
768
- /* @__PURE__ */ jsxs(
769
- Pagination.Root,
770
- {
771
- ...pagination,
772
- onPageSizeChange: () => trackUsage("willChangeNumberOfEntriesPerPage"),
773
- children: [
774
- /* @__PURE__ */ jsx(Pagination.PageSize, {}),
775
- /* @__PURE__ */ jsx(Pagination.Links, {})
776
- ]
777
- }
778
- )
779
- ] }) })
780
- ] });
781
- };
782
- const ActionsCell = styled(Table.Cell)`
783
- display: flex;
784
- justify-content: flex-end;
785
- `;
786
- const CreateButton = ({ variant }) => {
787
- const { formatMessage } = useIntl();
788
- const { trackUsage } = useTracking();
789
- const [{ query }] = useQueryParams();
790
- return /* @__PURE__ */ jsx(
791
- Button,
792
- {
793
- variant,
794
- forwardedAs: Link,
795
- onClick: () => {
796
- trackUsage("willCreateEntry", { status: "draft" });
797
- },
798
- startIcon: /* @__PURE__ */ jsx(Plus, {}),
799
- style: { textDecoration: "none" },
800
- to: {
801
- pathname: "create",
802
- search: stringify({ plugins: query.plugins })
803
- },
804
- children: formatMessage({
805
- id: getTranslation("HeaderLayout.button.label-add-entry"),
806
- defaultMessage: "Create new entry"
807
- })
808
- }
809
- );
810
- };
811
- const ProtectedListViewPage = () => {
812
- const { slug = "" } = useParams();
813
- const {
814
- permissions = [],
815
- isLoading,
816
- error
817
- } = useRBAC(
818
- PERMISSIONS.map((action) => ({
819
- action,
820
- subject: slug
821
- }))
822
- );
823
- if (isLoading) {
824
- return /* @__PURE__ */ jsx(Page.Loading, {});
825
- }
826
- if (error || !slug) {
827
- return /* @__PURE__ */ jsx(Page.Error, {});
828
- }
829
- return /* @__PURE__ */ jsx(Page.Protect, { permissions, children: ({ permissions: permissions2 }) => /* @__PURE__ */ jsx(DocumentRBAC, { permissions: permissions2, children: /* @__PURE__ */ jsx(ListViewPage, {}) }) });
830
- };
831
- export {
832
- ListViewPage,
833
- ProtectedListViewPage
834
- };
835
- //# sourceMappingURL=ListViewPage-ChhYmA-L.mjs.map