@strapi/content-manager 0.0.0-next.959c5589d0d3efa25d7ca014656d9ff48c173399 → 0.0.0-next.9e9a841899e6378b6f48ab8f419e4b0cc62bdf32

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