@strapi/content-manager 0.0.0-experimental.0e316dc69ac15cab63af4c7f91191d12fc2bbc27

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 (517) hide show
  1. package/LICENSE +37 -0
  2. package/README.md +9 -0
  3. package/dist/_chunks/CardDragPreview-C0QyJgRA.js +69 -0
  4. package/dist/_chunks/CardDragPreview-C0QyJgRA.js.map +1 -0
  5. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs +70 -0
  6. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +1 -0
  7. package/dist/_chunks/ComponentConfigurationPage-CIjXcRAB.mjs +236 -0
  8. package/dist/_chunks/ComponentConfigurationPage-CIjXcRAB.mjs.map +1 -0
  9. package/dist/_chunks/ComponentConfigurationPage-gsCd80MU.js +255 -0
  10. package/dist/_chunks/ComponentConfigurationPage-gsCd80MU.js.map +1 -0
  11. package/dist/_chunks/ComponentIcon-BXdiCGQp.js +176 -0
  12. package/dist/_chunks/ComponentIcon-BXdiCGQp.js.map +1 -0
  13. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs +157 -0
  14. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +1 -0
  15. package/dist/_chunks/EditConfigurationPage-BglmD_BF.mjs +132 -0
  16. package/dist/_chunks/EditConfigurationPage-BglmD_BF.mjs.map +1 -0
  17. package/dist/_chunks/EditConfigurationPage-DHDQKBzw.js +151 -0
  18. package/dist/_chunks/EditConfigurationPage-DHDQKBzw.js.map +1 -0
  19. package/dist/_chunks/EditViewPage-C4iTxUPU.js +243 -0
  20. package/dist/_chunks/EditViewPage-C4iTxUPU.js.map +1 -0
  21. package/dist/_chunks/EditViewPage-CiwVPMaK.mjs +224 -0
  22. package/dist/_chunks/EditViewPage-CiwVPMaK.mjs.map +1 -0
  23. package/dist/_chunks/Field-DIjL1b5d.mjs +5563 -0
  24. package/dist/_chunks/Field-DIjL1b5d.mjs.map +1 -0
  25. package/dist/_chunks/Field-DhXEK8y1.js +5595 -0
  26. package/dist/_chunks/Field-DhXEK8y1.js.map +1 -0
  27. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs +50 -0
  28. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +1 -0
  29. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js +49 -0
  30. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +1 -0
  31. package/dist/_chunks/Form-CmNesrvR.mjs +758 -0
  32. package/dist/_chunks/Form-CmNesrvR.mjs.map +1 -0
  33. package/dist/_chunks/Form-CwmJ4sWe.js +779 -0
  34. package/dist/_chunks/Form-CwmJ4sWe.js.map +1 -0
  35. package/dist/_chunks/History-BLCCNgCt.js +1066 -0
  36. package/dist/_chunks/History-BLCCNgCt.js.map +1 -0
  37. package/dist/_chunks/History-D-99Wh30.mjs +1045 -0
  38. package/dist/_chunks/History-D-99Wh30.mjs.map +1 -0
  39. package/dist/_chunks/ListConfigurationPage-DxWpeZrO.js +652 -0
  40. package/dist/_chunks/ListConfigurationPage-DxWpeZrO.js.map +1 -0
  41. package/dist/_chunks/ListConfigurationPage-JPWZz7Kg.mjs +632 -0
  42. package/dist/_chunks/ListConfigurationPage-JPWZz7Kg.mjs.map +1 -0
  43. package/dist/_chunks/ListViewPage-CIQekSFz.js +863 -0
  44. package/dist/_chunks/ListViewPage-CIQekSFz.js.map +1 -0
  45. package/dist/_chunks/ListViewPage-DSK3f0ST.mjs +839 -0
  46. package/dist/_chunks/ListViewPage-DSK3f0ST.mjs.map +1 -0
  47. package/dist/_chunks/NoContentTypePage-C5cxKvC2.js +51 -0
  48. package/dist/_chunks/NoContentTypePage-C5cxKvC2.js.map +1 -0
  49. package/dist/_chunks/NoContentTypePage-D99LU1YP.mjs +51 -0
  50. package/dist/_chunks/NoContentTypePage-D99LU1YP.mjs.map +1 -0
  51. package/dist/_chunks/NoPermissionsPage-DBrBw-0y.mjs +23 -0
  52. package/dist/_chunks/NoPermissionsPage-DBrBw-0y.mjs.map +1 -0
  53. package/dist/_chunks/NoPermissionsPage-Oy4tmUrW.js +23 -0
  54. package/dist/_chunks/NoPermissionsPage-Oy4tmUrW.js.map +1 -0
  55. package/dist/_chunks/Relations-BBmhcWFV.mjs +727 -0
  56. package/dist/_chunks/Relations-BBmhcWFV.mjs.map +1 -0
  57. package/dist/_chunks/Relations-eG-9p_qS.js +747 -0
  58. package/dist/_chunks/Relations-eG-9p_qS.js.map +1 -0
  59. package/dist/_chunks/ar-BUUWXIYu.js +226 -0
  60. package/dist/_chunks/ar-BUUWXIYu.js.map +1 -0
  61. package/dist/_chunks/ar-CCEVvqGG.mjs +226 -0
  62. package/dist/_chunks/ar-CCEVvqGG.mjs.map +1 -0
  63. package/dist/_chunks/ca-5U32ON2v.mjs +201 -0
  64. package/dist/_chunks/ca-5U32ON2v.mjs.map +1 -0
  65. package/dist/_chunks/ca-Cmk45QO6.js +201 -0
  66. package/dist/_chunks/ca-Cmk45QO6.js.map +1 -0
  67. package/dist/_chunks/cs-CM2aBUar.mjs +125 -0
  68. package/dist/_chunks/cs-CM2aBUar.mjs.map +1 -0
  69. package/dist/_chunks/cs-CkJy6B2v.js +125 -0
  70. package/dist/_chunks/cs-CkJy6B2v.js.map +1 -0
  71. package/dist/_chunks/de-C72KDNOl.mjs +199 -0
  72. package/dist/_chunks/de-C72KDNOl.mjs.map +1 -0
  73. package/dist/_chunks/de-CCEmbAah.js +199 -0
  74. package/dist/_chunks/de-CCEmbAah.js.map +1 -0
  75. package/dist/_chunks/en-Bm0D0IWz.js +293 -0
  76. package/dist/_chunks/en-Bm0D0IWz.js.map +1 -0
  77. package/dist/_chunks/en-DKV44jRb.mjs +293 -0
  78. package/dist/_chunks/en-DKV44jRb.mjs.map +1 -0
  79. package/dist/_chunks/es-CeXiYflN.mjs +196 -0
  80. package/dist/_chunks/es-CeXiYflN.mjs.map +1 -0
  81. package/dist/_chunks/es-EUonQTon.js +196 -0
  82. package/dist/_chunks/es-EUonQTon.js.map +1 -0
  83. package/dist/_chunks/eu-CdALomew.mjs +202 -0
  84. package/dist/_chunks/eu-CdALomew.mjs.map +1 -0
  85. package/dist/_chunks/eu-VDH-3ovk.js +202 -0
  86. package/dist/_chunks/eu-VDH-3ovk.js.map +1 -0
  87. package/dist/_chunks/fr-B7kGGg3E.js +206 -0
  88. package/dist/_chunks/fr-B7kGGg3E.js.map +1 -0
  89. package/dist/_chunks/fr-CD9VFbPM.mjs +206 -0
  90. package/dist/_chunks/fr-CD9VFbPM.mjs.map +1 -0
  91. package/dist/_chunks/gu-BRmF601H.js +200 -0
  92. package/dist/_chunks/gu-BRmF601H.js.map +1 -0
  93. package/dist/_chunks/gu-CNpaMDpH.mjs +200 -0
  94. package/dist/_chunks/gu-CNpaMDpH.mjs.map +1 -0
  95. package/dist/_chunks/hi-CCJBptSq.js +200 -0
  96. package/dist/_chunks/hi-CCJBptSq.js.map +1 -0
  97. package/dist/_chunks/hi-Dwvd04m3.mjs +200 -0
  98. package/dist/_chunks/hi-Dwvd04m3.mjs.map +1 -0
  99. package/dist/_chunks/hooks-BAaaKPS_.js +7 -0
  100. package/dist/_chunks/hooks-BAaaKPS_.js.map +1 -0
  101. package/dist/_chunks/hooks-E5u1mcgM.mjs +8 -0
  102. package/dist/_chunks/hooks-E5u1mcgM.mjs.map +1 -0
  103. package/dist/_chunks/hu-CeYvaaO0.mjs +202 -0
  104. package/dist/_chunks/hu-CeYvaaO0.mjs.map +1 -0
  105. package/dist/_chunks/hu-sNV_yLYy.js +202 -0
  106. package/dist/_chunks/hu-sNV_yLYy.js.map +1 -0
  107. package/dist/_chunks/id-B5Ser98A.js +160 -0
  108. package/dist/_chunks/id-B5Ser98A.js.map +1 -0
  109. package/dist/_chunks/id-BtwA9WJT.mjs +160 -0
  110. package/dist/_chunks/id-BtwA9WJT.mjs.map +1 -0
  111. package/dist/_chunks/index-BIWDoFLK.js +4133 -0
  112. package/dist/_chunks/index-BIWDoFLK.js.map +1 -0
  113. package/dist/_chunks/index-BrUzbQ30.mjs +4113 -0
  114. package/dist/_chunks/index-BrUzbQ30.mjs.map +1 -0
  115. package/dist/_chunks/it-BrVPqaf1.mjs +162 -0
  116. package/dist/_chunks/it-BrVPqaf1.mjs.map +1 -0
  117. package/dist/_chunks/it-DkBIs7vD.js +162 -0
  118. package/dist/_chunks/it-DkBIs7vD.js.map +1 -0
  119. package/dist/_chunks/ja-CcFe8diO.js +196 -0
  120. package/dist/_chunks/ja-CcFe8diO.js.map +1 -0
  121. package/dist/_chunks/ja-CtsUxOvk.mjs +196 -0
  122. package/dist/_chunks/ja-CtsUxOvk.mjs.map +1 -0
  123. package/dist/_chunks/ko-HVQRlfUI.mjs +195 -0
  124. package/dist/_chunks/ko-HVQRlfUI.mjs.map +1 -0
  125. package/dist/_chunks/ko-woFZPmLk.js +195 -0
  126. package/dist/_chunks/ko-woFZPmLk.js.map +1 -0
  127. package/dist/_chunks/layout-_5-cXs34.mjs +471 -0
  128. package/dist/_chunks/layout-_5-cXs34.mjs.map +1 -0
  129. package/dist/_chunks/layout-lMc9i1-Z.js +489 -0
  130. package/dist/_chunks/layout-lMc9i1-Z.js.map +1 -0
  131. package/dist/_chunks/ml-BihZwQit.mjs +200 -0
  132. package/dist/_chunks/ml-BihZwQit.mjs.map +1 -0
  133. package/dist/_chunks/ml-C2W8N8k1.js +200 -0
  134. package/dist/_chunks/ml-C2W8N8k1.js.map +1 -0
  135. package/dist/_chunks/ms-BuFotyP_.js +144 -0
  136. package/dist/_chunks/ms-BuFotyP_.js.map +1 -0
  137. package/dist/_chunks/ms-m_WjyWx7.mjs +144 -0
  138. package/dist/_chunks/ms-m_WjyWx7.mjs.map +1 -0
  139. package/dist/_chunks/nl-D4R9gHx5.mjs +202 -0
  140. package/dist/_chunks/nl-D4R9gHx5.mjs.map +1 -0
  141. package/dist/_chunks/nl-bbEOHChV.js +202 -0
  142. package/dist/_chunks/nl-bbEOHChV.js.map +1 -0
  143. package/dist/_chunks/objects-BcXOv6_9.js +47 -0
  144. package/dist/_chunks/objects-BcXOv6_9.js.map +1 -0
  145. package/dist/_chunks/objects-D6yBsdmx.mjs +45 -0
  146. package/dist/_chunks/objects-D6yBsdmx.mjs.map +1 -0
  147. package/dist/_chunks/pl-sbx9mSt_.mjs +199 -0
  148. package/dist/_chunks/pl-sbx9mSt_.mjs.map +1 -0
  149. package/dist/_chunks/pl-uzwG-hk7.js +199 -0
  150. package/dist/_chunks/pl-uzwG-hk7.js.map +1 -0
  151. package/dist/_chunks/pt-BR-BiOz37D9.js +201 -0
  152. package/dist/_chunks/pt-BR-BiOz37D9.js.map +1 -0
  153. package/dist/_chunks/pt-BR-C71iDxnh.mjs +201 -0
  154. package/dist/_chunks/pt-BR-C71iDxnh.mjs.map +1 -0
  155. package/dist/_chunks/pt-BsaFvS8-.mjs +95 -0
  156. package/dist/_chunks/pt-BsaFvS8-.mjs.map +1 -0
  157. package/dist/_chunks/pt-CeXQuq50.js +95 -0
  158. package/dist/_chunks/pt-CeXQuq50.js.map +1 -0
  159. package/dist/_chunks/relations-BRHithi8.js +130 -0
  160. package/dist/_chunks/relations-BRHithi8.js.map +1 -0
  161. package/dist/_chunks/relations-B_VLk-DD.mjs +131 -0
  162. package/dist/_chunks/relations-B_VLk-DD.mjs.map +1 -0
  163. package/dist/_chunks/ru-BE6A4Exp.mjs +231 -0
  164. package/dist/_chunks/ru-BE6A4Exp.mjs.map +1 -0
  165. package/dist/_chunks/ru-BT3ybNny.js +231 -0
  166. package/dist/_chunks/ru-BT3ybNny.js.map +1 -0
  167. package/dist/_chunks/sa-CcvkYInH.js +200 -0
  168. package/dist/_chunks/sa-CcvkYInH.js.map +1 -0
  169. package/dist/_chunks/sa-Dag0k-Z8.mjs +200 -0
  170. package/dist/_chunks/sa-Dag0k-Z8.mjs.map +1 -0
  171. package/dist/_chunks/sk-BFg-R8qJ.mjs +202 -0
  172. package/dist/_chunks/sk-BFg-R8qJ.mjs.map +1 -0
  173. package/dist/_chunks/sk-CvY09Xjv.js +202 -0
  174. package/dist/_chunks/sk-CvY09Xjv.js.map +1 -0
  175. package/dist/_chunks/sv-CUnfWGsh.mjs +202 -0
  176. package/dist/_chunks/sv-CUnfWGsh.mjs.map +1 -0
  177. package/dist/_chunks/sv-MYDuzgvT.js +202 -0
  178. package/dist/_chunks/sv-MYDuzgvT.js.map +1 -0
  179. package/dist/_chunks/th-BqbI8lIT.mjs +148 -0
  180. package/dist/_chunks/th-BqbI8lIT.mjs.map +1 -0
  181. package/dist/_chunks/th-D9_GfAjc.js +148 -0
  182. package/dist/_chunks/th-D9_GfAjc.js.map +1 -0
  183. package/dist/_chunks/tr-CgeK3wJM.mjs +199 -0
  184. package/dist/_chunks/tr-CgeK3wJM.mjs.map +1 -0
  185. package/dist/_chunks/tr-D9UH-O_R.js +199 -0
  186. package/dist/_chunks/tr-D9UH-O_R.js.map +1 -0
  187. package/dist/_chunks/uk-C8EiqJY7.js +144 -0
  188. package/dist/_chunks/uk-C8EiqJY7.js.map +1 -0
  189. package/dist/_chunks/uk-CR-zDhAY.mjs +144 -0
  190. package/dist/_chunks/uk-CR-zDhAY.mjs.map +1 -0
  191. package/dist/_chunks/useDebounce-CtcjDB3L.js +28 -0
  192. package/dist/_chunks/useDebounce-CtcjDB3L.js.map +1 -0
  193. package/dist/_chunks/useDebounce-DmuSJIF3.mjs +29 -0
  194. package/dist/_chunks/useDebounce-DmuSJIF3.mjs.map +1 -0
  195. package/dist/_chunks/useDragAndDrop-DdHgKsqq.mjs +231 -0
  196. package/dist/_chunks/useDragAndDrop-DdHgKsqq.mjs.map +1 -0
  197. package/dist/_chunks/useDragAndDrop-J0TUUbR6.js +249 -0
  198. package/dist/_chunks/useDragAndDrop-J0TUUbR6.js.map +1 -0
  199. package/dist/_chunks/vi-CJlYDheJ.js +111 -0
  200. package/dist/_chunks/vi-CJlYDheJ.js.map +1 -0
  201. package/dist/_chunks/vi-DUXIk_fw.mjs +111 -0
  202. package/dist/_chunks/vi-DUXIk_fw.mjs.map +1 -0
  203. package/dist/_chunks/zh-BWZspA60.mjs +209 -0
  204. package/dist/_chunks/zh-BWZspA60.mjs.map +1 -0
  205. package/dist/_chunks/zh-CQQfszqR.js +209 -0
  206. package/dist/_chunks/zh-CQQfszqR.js.map +1 -0
  207. package/dist/_chunks/zh-Hans-9kOncHGw.js +952 -0
  208. package/dist/_chunks/zh-Hans-9kOncHGw.js.map +1 -0
  209. package/dist/_chunks/zh-Hans-BPQcRIyH.mjs +952 -0
  210. package/dist/_chunks/zh-Hans-BPQcRIyH.mjs.map +1 -0
  211. package/dist/admin/index.js +13 -0
  212. package/dist/admin/index.js.map +1 -0
  213. package/dist/admin/index.mjs +13 -0
  214. package/dist/admin/index.mjs.map +1 -0
  215. package/dist/admin/src/components/ComponentIcon.d.ts +11 -0
  216. package/dist/admin/src/components/ConfigurationForm/EditFieldForm.d.ts +9 -0
  217. package/dist/admin/src/components/ConfigurationForm/Fields.d.ts +21 -0
  218. package/dist/admin/src/components/ConfigurationForm/Form.d.ts +32 -0
  219. package/dist/admin/src/components/DragLayer.d.ts +13 -0
  220. package/dist/admin/src/components/DragPreviews/CardDragPreview.d.ts +7 -0
  221. package/dist/admin/src/components/DragPreviews/ComponentDragPreview.d.ts +6 -0
  222. package/dist/admin/src/components/DragPreviews/RelationDragPreview.d.ts +11 -0
  223. package/dist/admin/src/components/FieldTypeIcon.d.ts +9 -0
  224. package/dist/admin/src/components/InjectionZone.d.ts +45 -0
  225. package/dist/admin/src/components/LeftMenu.d.ts +2 -0
  226. package/dist/admin/src/components/RelativeTime.d.ts +28 -0
  227. package/dist/admin/src/constants/attributes.d.ts +14 -0
  228. package/dist/admin/src/constants/collections.d.ts +3 -0
  229. package/dist/admin/src/constants/dragAndDrop.d.ts +8 -0
  230. package/dist/admin/src/constants/hooks.d.ts +26 -0
  231. package/dist/admin/src/constants/plugin.d.ts +3 -0
  232. package/dist/admin/src/content-manager.d.ts +133 -0
  233. package/dist/admin/src/exports.d.ts +12 -0
  234. package/dist/admin/src/features/DocumentRBAC.d.ts +36 -0
  235. package/dist/admin/src/history/components/HistoryAction.d.ts +3 -0
  236. package/dist/admin/src/history/components/VersionContent.d.ts +17 -0
  237. package/dist/admin/src/history/components/VersionHeader.d.ts +5 -0
  238. package/dist/admin/src/history/components/VersionInputRenderer.d.ts +19 -0
  239. package/dist/admin/src/history/components/VersionsList.d.ts +2 -0
  240. package/dist/admin/src/history/index.d.ts +3 -0
  241. package/dist/admin/src/history/pages/History.d.ts +27 -0
  242. package/dist/admin/src/history/routes.d.ts +6 -0
  243. package/dist/admin/src/history/services/historyVersion.d.ts +12 -0
  244. package/dist/admin/src/hooks/useContentManagerInitData.d.ts +15 -0
  245. package/dist/admin/src/hooks/useContentTypeSchema.d.ts +25 -0
  246. package/dist/admin/src/hooks/useDebounce.d.ts +1 -0
  247. package/dist/admin/src/hooks/useDocument.d.ts +118 -0
  248. package/dist/admin/src/hooks/useDocumentActions.d.ts +123 -0
  249. package/dist/admin/src/hooks/useDocumentLayout.d.ts +137 -0
  250. package/dist/admin/src/hooks/useDragAndDrop.d.ts +51 -0
  251. package/dist/admin/src/hooks/useKeyboardDragAndDrop.d.ts +14 -0
  252. package/dist/admin/src/hooks/useLazyComponents.d.ts +13 -0
  253. package/dist/admin/src/hooks/useOnce.d.ts +2 -0
  254. package/dist/admin/src/hooks/usePrev.d.ts +1 -0
  255. package/dist/admin/src/index.d.ts +17 -0
  256. package/dist/admin/src/layout.d.ts +2 -0
  257. package/dist/admin/src/modules/app.d.ts +20 -0
  258. package/dist/admin/src/modules/hooks.d.ts +10 -0
  259. package/dist/admin/src/modules/reducers.d.ts +6 -0
  260. package/dist/admin/src/pages/ComponentConfigurationPage.d.ts +3 -0
  261. package/dist/admin/src/pages/EditConfigurationPage.d.ts +3 -0
  262. package/dist/admin/src/pages/EditView/EditViewPage.d.ts +3 -0
  263. package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +76 -0
  264. package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +16 -0
  265. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.d.ts +3 -0
  266. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Heading.d.ts +3 -0
  267. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Image.d.ts +3 -0
  268. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Link.d.ts +3 -0
  269. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/List.d.ts +3 -0
  270. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Paragraph.d.ts +3 -0
  271. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Quote.d.ts +3 -0
  272. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.d.ts +6 -0
  273. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.d.ts +61 -0
  274. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/BlocksInput.d.ts +11 -0
  275. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.d.ts +10 -0
  276. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/EditorLayout.d.ts +10 -0
  277. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Modifiers.d.ts +16 -0
  278. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/plugins/withImages.d.ts +11 -0
  279. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/plugins/withLinks.d.ts +9 -0
  280. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/plugins/withStrapiSchema.d.ts +8 -0
  281. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/constants.d.ts +4 -0
  282. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/conversions.d.ts +13 -0
  283. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/enterKey.d.ts +6 -0
  284. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/links.d.ts +10 -0
  285. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/types.d.ts +10 -0
  286. package/dist/admin/src/pages/EditView/components/FormInputs/Component/Initializer.d.ts +9 -0
  287. package/dist/admin/src/pages/EditView/components/FormInputs/Component/Input.d.ts +18 -0
  288. package/dist/admin/src/pages/EditView/components/FormInputs/Component/NonRepeatable.d.ts +5 -0
  289. package/dist/admin/src/pages/EditView/components/FormInputs/Component/Repeatable.d.ts +5 -0
  290. package/dist/admin/src/pages/EditView/components/FormInputs/ComponentContext.d.ts +42 -0
  291. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/AddComponentButton.d.ts +11 -0
  292. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/ComponentCard.d.ts +9 -0
  293. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/ComponentCategory.d.ts +15 -0
  294. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/ComponentPicker.d.ts +9 -0
  295. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.d.ts +14 -0
  296. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/DynamicZoneLabel.d.ts +12 -0
  297. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/Field.d.ts +14 -0
  298. package/dist/admin/src/pages/EditView/components/FormInputs/NotAllowed.d.ts +7 -0
  299. package/dist/admin/src/pages/EditView/components/FormInputs/Relations.d.ts +38 -0
  300. package/dist/admin/src/pages/EditView/components/FormInputs/UID.d.ts +9 -0
  301. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/Editor.d.ts +17 -0
  302. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.d.ts +14 -0
  303. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/Field.d.ts +11 -0
  304. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/PreviewWysiwyg.d.ts +5 -0
  305. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygFooter.d.ts +7 -0
  306. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.d.ts +17 -0
  307. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygStyles.d.ts +18 -0
  308. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/utils/continueList.d.ts +5 -0
  309. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/utils/mdRenderer.d.ts +4 -0
  310. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/utils/utils.d.ts +16 -0
  311. package/dist/admin/src/pages/EditView/components/FormLayout.d.ts +5 -0
  312. package/dist/admin/src/pages/EditView/components/Header.d.ts +35 -0
  313. package/dist/admin/src/pages/EditView/components/InputRenderer.d.ts +9 -0
  314. package/dist/admin/src/pages/EditView/components/Panels.d.ts +10 -0
  315. package/dist/admin/src/pages/EditView/utils/data.d.ts +33 -0
  316. package/dist/admin/src/pages/EditView/utils/forms.d.ts +9 -0
  317. package/dist/admin/src/pages/ListConfiguration/ListConfigurationPage.d.ts +10 -0
  318. package/dist/admin/src/pages/ListConfiguration/components/DraggableCard.d.ts +12 -0
  319. package/dist/admin/src/pages/ListConfiguration/components/EditFieldForm.d.ts +8 -0
  320. package/dist/admin/src/pages/ListConfiguration/components/Header.d.ts +8 -0
  321. package/dist/admin/src/pages/ListConfiguration/components/Settings.d.ts +19 -0
  322. package/dist/admin/src/pages/ListConfiguration/components/SortDisplayedFields.d.ts +6 -0
  323. package/dist/admin/src/pages/ListView/ListViewPage.d.ts +3 -0
  324. package/dist/admin/src/pages/ListView/components/AutoCloneFailureModal.d.ts +7 -0
  325. package/dist/admin/src/pages/ListView/components/BulkActions/Actions.d.ts +24 -0
  326. package/dist/admin/src/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.d.ts +15 -0
  327. package/dist/admin/src/pages/ListView/components/BulkActions/PublishAction.d.ts +14 -0
  328. package/dist/admin/src/pages/ListView/components/Filters.d.ts +8 -0
  329. package/dist/admin/src/pages/ListView/components/TableActions.d.ts +8 -0
  330. package/dist/admin/src/pages/ListView/components/TableCells/CellContent.d.ts +9 -0
  331. package/dist/admin/src/pages/ListView/components/TableCells/CellValue.d.ts +8 -0
  332. package/dist/admin/src/pages/ListView/components/TableCells/Components.d.ts +12 -0
  333. package/dist/admin/src/pages/ListView/components/TableCells/Media.d.ts +23 -0
  334. package/dist/admin/src/pages/ListView/components/TableCells/Relations.d.ts +12 -0
  335. package/dist/admin/src/pages/ListView/components/ViewSettingsMenu.d.ts +10 -0
  336. package/dist/admin/src/pages/NoContentTypePage.d.ts +2 -0
  337. package/dist/admin/src/pages/NoPermissionsPage.d.ts +2 -0
  338. package/dist/admin/src/preview/constants.d.ts +1 -0
  339. package/dist/admin/src/preview/index.d.ts +4 -0
  340. package/dist/admin/src/router.d.ts +5 -0
  341. package/dist/admin/src/services/api.d.ts +2 -0
  342. package/dist/admin/src/services/components.d.ts +5 -0
  343. package/dist/admin/src/services/contentTypes.d.ts +17 -0
  344. package/dist/admin/src/services/documents.d.ts +103 -0
  345. package/dist/admin/src/services/init.d.ts +9 -0
  346. package/dist/admin/src/services/relations.d.ts +49 -0
  347. package/dist/admin/src/services/uid.d.ts +32 -0
  348. package/dist/admin/src/utils/api.d.ts +24 -0
  349. package/dist/admin/src/utils/attributes.d.ts +19 -0
  350. package/dist/admin/src/utils/objects.d.ts +33 -0
  351. package/dist/admin/src/utils/relations.d.ts +12 -0
  352. package/dist/admin/src/utils/strings.d.ts +2 -0
  353. package/dist/admin/src/utils/translations.d.ts +4 -0
  354. package/dist/admin/src/utils/urls.d.ts +2 -0
  355. package/dist/admin/src/utils/users.d.ts +6 -0
  356. package/dist/admin/src/utils/validation.d.ts +10 -0
  357. package/dist/server/index.js +4491 -0
  358. package/dist/server/index.js.map +1 -0
  359. package/dist/server/index.mjs +4467 -0
  360. package/dist/server/index.mjs.map +1 -0
  361. package/dist/server/src/bootstrap.d.ts +3 -0
  362. package/dist/server/src/bootstrap.d.ts.map +1 -0
  363. package/dist/server/src/config.d.ts +6 -0
  364. package/dist/server/src/config.d.ts.map +1 -0
  365. package/dist/server/src/constants/index.d.ts +6 -0
  366. package/dist/server/src/constants/index.d.ts.map +1 -0
  367. package/dist/server/src/controllers/collection-types.d.ts +23 -0
  368. package/dist/server/src/controllers/collection-types.d.ts.map +1 -0
  369. package/dist/server/src/controllers/components.d.ts +7 -0
  370. package/dist/server/src/controllers/components.d.ts.map +1 -0
  371. package/dist/server/src/controllers/content-types.d.ts +8 -0
  372. package/dist/server/src/controllers/content-types.d.ts.map +1 -0
  373. package/dist/server/src/controllers/index.d.ts +53 -0
  374. package/dist/server/src/controllers/index.d.ts.map +1 -0
  375. package/dist/server/src/controllers/init.d.ts +5 -0
  376. package/dist/server/src/controllers/init.d.ts.map +1 -0
  377. package/dist/server/src/controllers/relations.d.ts +13 -0
  378. package/dist/server/src/controllers/relations.d.ts.map +1 -0
  379. package/dist/server/src/controllers/single-types.d.ts +11 -0
  380. package/dist/server/src/controllers/single-types.d.ts.map +1 -0
  381. package/dist/server/src/controllers/uid.d.ts +6 -0
  382. package/dist/server/src/controllers/uid.d.ts.map +1 -0
  383. package/dist/server/src/controllers/utils/clone.d.ts +12 -0
  384. package/dist/server/src/controllers/utils/clone.d.ts.map +1 -0
  385. package/dist/server/src/controllers/utils/metadata.d.ts +22 -0
  386. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -0
  387. package/dist/server/src/controllers/validation/dimensions.d.ts +11 -0
  388. package/dist/server/src/controllers/validation/dimensions.d.ts.map +1 -0
  389. package/dist/server/src/controllers/validation/index.d.ts +20 -0
  390. package/dist/server/src/controllers/validation/index.d.ts.map +1 -0
  391. package/dist/server/src/controllers/validation/model-configuration.d.ts +22 -0
  392. package/dist/server/src/controllers/validation/model-configuration.d.ts.map +1 -0
  393. package/dist/server/src/controllers/validation/relations.d.ts +4 -0
  394. package/dist/server/src/controllers/validation/relations.d.ts.map +1 -0
  395. package/dist/server/src/destroy.d.ts +4 -0
  396. package/dist/server/src/destroy.d.ts.map +1 -0
  397. package/dist/server/src/history/constants.d.ts +3 -0
  398. package/dist/server/src/history/constants.d.ts.map +1 -0
  399. package/dist/server/src/history/controllers/history-version.d.ts +19 -0
  400. package/dist/server/src/history/controllers/history-version.d.ts.map +1 -0
  401. package/dist/server/src/history/controllers/index.d.ts +2 -0
  402. package/dist/server/src/history/controllers/index.d.ts.map +1 -0
  403. package/dist/server/src/history/controllers/validation/history-version.d.ts +2 -0
  404. package/dist/server/src/history/controllers/validation/history-version.d.ts.map +1 -0
  405. package/dist/server/src/history/index.d.ts +4 -0
  406. package/dist/server/src/history/index.d.ts.map +1 -0
  407. package/dist/server/src/history/models/history-version.d.ts +4 -0
  408. package/dist/server/src/history/models/history-version.d.ts.map +1 -0
  409. package/dist/server/src/history/routes/history-version.d.ts +4 -0
  410. package/dist/server/src/history/routes/history-version.d.ts.map +1 -0
  411. package/dist/server/src/history/routes/index.d.ts +8 -0
  412. package/dist/server/src/history/routes/index.d.ts.map +1 -0
  413. package/dist/server/src/history/services/history.d.ts +16 -0
  414. package/dist/server/src/history/services/history.d.ts.map +1 -0
  415. package/dist/server/src/history/services/index.d.ts +19 -0
  416. package/dist/server/src/history/services/index.d.ts.map +1 -0
  417. package/dist/server/src/history/services/lifecycles.d.ts +9 -0
  418. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -0
  419. package/dist/server/src/history/services/utils.d.ts +45 -0
  420. package/dist/server/src/history/services/utils.d.ts.map +1 -0
  421. package/dist/server/src/history/utils.d.ts +22 -0
  422. package/dist/server/src/history/utils.d.ts.map +1 -0
  423. package/dist/server/src/index.d.ts +353 -0
  424. package/dist/server/src/index.d.ts.map +1 -0
  425. package/dist/server/src/middlewares/index.d.ts +3 -0
  426. package/dist/server/src/middlewares/index.d.ts.map +1 -0
  427. package/dist/server/src/middlewares/routing.d.ts +4 -0
  428. package/dist/server/src/middlewares/routing.d.ts.map +1 -0
  429. package/dist/server/src/policies/hasPermissions.d.ts +7 -0
  430. package/dist/server/src/policies/hasPermissions.d.ts.map +1 -0
  431. package/dist/server/src/policies/index.d.ts +9 -0
  432. package/dist/server/src/policies/index.d.ts.map +1 -0
  433. package/dist/server/src/preview/constants.d.ts +2 -0
  434. package/dist/server/src/preview/constants.d.ts.map +1 -0
  435. package/dist/server/src/preview/index.d.ts +4 -0
  436. package/dist/server/src/preview/index.d.ts.map +1 -0
  437. package/dist/server/src/register.d.ts +4 -0
  438. package/dist/server/src/register.d.ts.map +1 -0
  439. package/dist/server/src/routes/admin.d.ts +41 -0
  440. package/dist/server/src/routes/admin.d.ts.map +1 -0
  441. package/dist/server/src/routes/index.d.ts +43 -0
  442. package/dist/server/src/routes/index.d.ts.map +1 -0
  443. package/dist/server/src/services/components.d.ts +32 -0
  444. package/dist/server/src/services/components.d.ts.map +1 -0
  445. package/dist/server/src/services/configuration.d.ts +20 -0
  446. package/dist/server/src/services/configuration.d.ts.map +1 -0
  447. package/dist/server/src/services/content-types.d.ts +18 -0
  448. package/dist/server/src/services/content-types.d.ts.map +1 -0
  449. package/dist/server/src/services/data-mapper.d.ts +20 -0
  450. package/dist/server/src/services/data-mapper.d.ts.map +1 -0
  451. package/dist/server/src/services/document-manager.d.ts +48 -0
  452. package/dist/server/src/services/document-manager.d.ts.map +1 -0
  453. package/dist/server/src/services/document-metadata.d.ts +67 -0
  454. package/dist/server/src/services/document-metadata.d.ts.map +1 -0
  455. package/dist/server/src/services/field-sizes.d.ts +19 -0
  456. package/dist/server/src/services/field-sizes.d.ts.map +1 -0
  457. package/dist/server/src/services/index.d.ts +245 -0
  458. package/dist/server/src/services/index.d.ts.map +1 -0
  459. package/dist/server/src/services/metrics.d.ts +9 -0
  460. package/dist/server/src/services/metrics.d.ts.map +1 -0
  461. package/dist/server/src/services/permission-checker.d.ts +54 -0
  462. package/dist/server/src/services/permission-checker.d.ts.map +1 -0
  463. package/dist/server/src/services/permission.d.ts +12 -0
  464. package/dist/server/src/services/permission.d.ts.map +1 -0
  465. package/dist/server/src/services/populate-builder.d.ts +30 -0
  466. package/dist/server/src/services/populate-builder.d.ts.map +1 -0
  467. package/dist/server/src/services/uid.d.ts +25 -0
  468. package/dist/server/src/services/uid.d.ts.map +1 -0
  469. package/dist/server/src/services/utils/configuration/attributes.d.ts +17 -0
  470. package/dist/server/src/services/utils/configuration/attributes.d.ts.map +1 -0
  471. package/dist/server/src/services/utils/configuration/index.d.ts +21 -0
  472. package/dist/server/src/services/utils/configuration/index.d.ts.map +1 -0
  473. package/dist/server/src/services/utils/configuration/layouts.d.ts +14 -0
  474. package/dist/server/src/services/utils/configuration/layouts.d.ts.map +1 -0
  475. package/dist/server/src/services/utils/configuration/metadatas.d.ts +5 -0
  476. package/dist/server/src/services/utils/configuration/metadatas.d.ts.map +1 -0
  477. package/dist/server/src/services/utils/configuration/settings.d.ts +5 -0
  478. package/dist/server/src/services/utils/configuration/settings.d.ts.map +1 -0
  479. package/dist/server/src/services/utils/count.d.ts +5 -0
  480. package/dist/server/src/services/utils/count.d.ts.map +1 -0
  481. package/dist/server/src/services/utils/draft.d.ts +11 -0
  482. package/dist/server/src/services/utils/draft.d.ts.map +1 -0
  483. package/dist/server/src/services/utils/populate.d.ts +42 -0
  484. package/dist/server/src/services/utils/populate.d.ts.map +1 -0
  485. package/dist/server/src/services/utils/store.d.ts +16 -0
  486. package/dist/server/src/services/utils/store.d.ts.map +1 -0
  487. package/dist/server/src/utils/index.d.ts +11 -0
  488. package/dist/server/src/utils/index.d.ts.map +1 -0
  489. package/dist/server/src/validation/policies/hasPermissions.d.ts +2 -0
  490. package/dist/server/src/validation/policies/hasPermissions.d.ts.map +1 -0
  491. package/dist/shared/contracts/collection-types.d.ts +338 -0
  492. package/dist/shared/contracts/collection-types.d.ts.map +1 -0
  493. package/dist/shared/contracts/components.d.ts +65 -0
  494. package/dist/shared/contracts/components.d.ts.map +1 -0
  495. package/dist/shared/contracts/content-types.d.ts +113 -0
  496. package/dist/shared/contracts/content-types.d.ts.map +1 -0
  497. package/dist/shared/contracts/history-versions.d.ts +92 -0
  498. package/dist/shared/contracts/history-versions.d.ts.map +1 -0
  499. package/dist/shared/contracts/index.d.ts +10 -0
  500. package/dist/shared/contracts/index.d.ts.map +1 -0
  501. package/dist/shared/contracts/init.d.ts +24 -0
  502. package/dist/shared/contracts/init.d.ts.map +1 -0
  503. package/dist/shared/contracts/relations.d.ts +70 -0
  504. package/dist/shared/contracts/relations.d.ts.map +1 -0
  505. package/dist/shared/contracts/review-workflows.d.ts +78 -0
  506. package/dist/shared/contracts/review-workflows.d.ts.map +1 -0
  507. package/dist/shared/contracts/single-types.d.ts +113 -0
  508. package/dist/shared/contracts/single-types.d.ts.map +1 -0
  509. package/dist/shared/contracts/uid.d.ts +48 -0
  510. package/dist/shared/contracts/uid.d.ts.map +1 -0
  511. package/dist/shared/index.d.ts +2 -0
  512. package/dist/shared/index.d.ts.map +1 -0
  513. package/dist/shared/index.js +43 -0
  514. package/dist/shared/index.js.map +1 -0
  515. package/dist/shared/index.mjs +43 -0
  516. package/dist/shared/index.mjs.map +1 -0
  517. package/package.json +133 -0
@@ -0,0 +1,839 @@
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