@strapi/content-manager 0.0.0-next.39c0188c3aa01bec7b64b948211571d5159e811d → 0.0.0-next.3a1d87a9c3b1d4d89f741c6ecd7f501230fd8d76

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 (439) hide show
  1. package/dist/_chunks/CardDragPreview-C0QyJgRA.js +69 -0
  2. package/dist/_chunks/CardDragPreview-C0QyJgRA.js.map +1 -0
  3. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs +70 -0
  4. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +1 -0
  5. package/dist/_chunks/ComponentConfigurationPage-DMxUlNOo.js +254 -0
  6. package/dist/_chunks/ComponentConfigurationPage-DMxUlNOo.js.map +1 -0
  7. package/dist/_chunks/ComponentConfigurationPage-baEkO-OV.mjs +236 -0
  8. package/dist/_chunks/ComponentConfigurationPage-baEkO-OV.mjs.map +1 -0
  9. package/dist/_chunks/ComponentIcon-CRbtQEUV.js +175 -0
  10. package/dist/_chunks/ComponentIcon-CRbtQEUV.js.map +1 -0
  11. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs +157 -0
  12. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +1 -0
  13. package/dist/_chunks/EditConfigurationPage-CXxV7mKn.js +150 -0
  14. package/dist/_chunks/EditConfigurationPage-CXxV7mKn.js.map +1 -0
  15. package/dist/_chunks/EditConfigurationPage-YR8-4VCS.mjs +132 -0
  16. package/dist/_chunks/EditConfigurationPage-YR8-4VCS.mjs.map +1 -0
  17. package/dist/_chunks/EditViewPage-BfR6jAR6.js +209 -0
  18. package/dist/_chunks/EditViewPage-BfR6jAR6.js.map +1 -0
  19. package/dist/_chunks/EditViewPage-DFF7c27p.mjs +191 -0
  20. package/dist/_chunks/EditViewPage-DFF7c27p.mjs.map +1 -0
  21. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs +50 -0
  22. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +1 -0
  23. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js +49 -0
  24. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +1 -0
  25. package/dist/_chunks/Form-CjcMRP5A.js +778 -0
  26. package/dist/_chunks/Form-CjcMRP5A.js.map +1 -0
  27. package/dist/_chunks/Form-MSOSfGGN.mjs +758 -0
  28. package/dist/_chunks/Form-MSOSfGGN.mjs.map +1 -0
  29. package/dist/_chunks/History-BgZ7gVuF.js +1019 -0
  30. package/dist/_chunks/History-BgZ7gVuF.js.map +1 -0
  31. package/dist/_chunks/History-WOQNVho-.mjs +999 -0
  32. package/dist/_chunks/History-WOQNVho-.mjs.map +1 -0
  33. package/dist/_chunks/Input-BkKwZ6Qt.mjs +5585 -0
  34. package/dist/_chunks/Input-BkKwZ6Qt.mjs.map +1 -0
  35. package/dist/_chunks/Input-BwOibhc3.js +5617 -0
  36. package/dist/_chunks/Input-BwOibhc3.js.map +1 -0
  37. package/dist/_chunks/ListConfigurationPage-BeXfr6uW.mjs +633 -0
  38. package/dist/_chunks/ListConfigurationPage-BeXfr6uW.mjs.map +1 -0
  39. package/dist/_chunks/ListConfigurationPage-DnJ3nbwL.js +652 -0
  40. package/dist/_chunks/ListConfigurationPage-DnJ3nbwL.js.map +1 -0
  41. package/dist/_chunks/ListViewPage-CJFDudKl.js +877 -0
  42. package/dist/_chunks/ListViewPage-CJFDudKl.js.map +1 -0
  43. package/dist/_chunks/ListViewPage-VK2v44Q1.mjs +854 -0
  44. package/dist/_chunks/ListViewPage-VK2v44Q1.mjs.map +1 -0
  45. package/dist/_chunks/NoContentTypePage-T8ttty6K.mjs +51 -0
  46. package/dist/_chunks/NoContentTypePage-T8ttty6K.mjs.map +1 -0
  47. package/dist/_chunks/NoContentTypePage-en2PwWgI.js +51 -0
  48. package/dist/_chunks/NoContentTypePage-en2PwWgI.js.map +1 -0
  49. package/dist/_chunks/NoPermissionsPage-CcjILry3.js +23 -0
  50. package/dist/_chunks/NoPermissionsPage-CcjILry3.js.map +1 -0
  51. package/dist/_chunks/NoPermissionsPage-CokBHhhy.mjs +23 -0
  52. package/dist/_chunks/NoPermissionsPage-CokBHhhy.mjs.map +1 -0
  53. package/dist/_chunks/Preview-BF81YhRj.mjs +287 -0
  54. package/dist/_chunks/Preview-BF81YhRj.mjs.map +1 -0
  55. package/dist/_chunks/Preview-DgzAuzWQ.js +305 -0
  56. package/dist/_chunks/Preview-DgzAuzWQ.js.map +1 -0
  57. package/dist/_chunks/Relations-1O-JcM4t.js +747 -0
  58. package/dist/_chunks/Relations-1O-JcM4t.js.map +1 -0
  59. package/dist/_chunks/Relations-BncdhGCd.mjs +728 -0
  60. package/dist/_chunks/Relations-BncdhGCd.mjs.map +1 -0
  61. package/dist/_chunks/ar-BUUWXIYu.js +226 -0
  62. package/dist/{admin/chunks/ar-DckYq_WK.js.map → _chunks/ar-BUUWXIYu.js.map} +1 -1
  63. package/dist/_chunks/ar-CCEVvqGG.mjs +226 -0
  64. package/dist/_chunks/ar-CCEVvqGG.mjs.map +1 -0
  65. package/dist/_chunks/ca-5U32ON2v.mjs +201 -0
  66. package/dist/_chunks/ca-5U32ON2v.mjs.map +1 -0
  67. package/dist/_chunks/ca-Cmk45QO6.js +201 -0
  68. package/dist/{admin/chunks/de-CbImAUA5.js.map → _chunks/ca-Cmk45QO6.js.map} +1 -1
  69. package/dist/_chunks/cs-CM2aBUar.mjs +125 -0
  70. package/dist/_chunks/cs-CM2aBUar.mjs.map +1 -0
  71. package/dist/_chunks/cs-CkJy6B2v.js +125 -0
  72. package/dist/{admin/chunks/cs-C7OSYFQ7.js.map → _chunks/cs-CkJy6B2v.js.map} +1 -1
  73. package/dist/_chunks/de-C72KDNOl.mjs +199 -0
  74. package/dist/_chunks/de-C72KDNOl.mjs.map +1 -0
  75. package/dist/_chunks/de-CCEmbAah.js +199 -0
  76. package/dist/{admin/chunks/es-C8vLuvZL.js.map → _chunks/de-CCEmbAah.js.map} +1 -1
  77. package/dist/_chunks/en-BZaUty0m.mjs +311 -0
  78. package/dist/{admin/chunks/en-C1CjdAtC.js.map → _chunks/en-BZaUty0m.mjs.map} +1 -1
  79. package/dist/_chunks/en-CzCnBk4S.js +311 -0
  80. package/dist/{admin/chunks/en-LfhocNG2.js.map → _chunks/en-CzCnBk4S.js.map} +1 -1
  81. package/dist/_chunks/es-9K52xZIr.js +196 -0
  82. package/dist/{admin/chunks/de-5QRlDHyR.js.map → _chunks/es-9K52xZIr.js.map} +1 -1
  83. package/dist/_chunks/es-D34tqjMw.mjs +196 -0
  84. package/dist/_chunks/es-D34tqjMw.mjs.map +1 -0
  85. package/dist/_chunks/eu-CdALomew.mjs +202 -0
  86. package/dist/_chunks/eu-CdALomew.mjs.map +1 -0
  87. package/dist/_chunks/eu-VDH-3ovk.js +202 -0
  88. package/dist/_chunks/eu-VDH-3ovk.js.map +1 -0
  89. package/dist/_chunks/fr--pg5jUbt.mjs +216 -0
  90. package/dist/_chunks/fr--pg5jUbt.mjs.map +1 -0
  91. package/dist/_chunks/fr-B2Kyv8Z9.js +216 -0
  92. package/dist/_chunks/fr-B2Kyv8Z9.js.map +1 -0
  93. package/dist/_chunks/gu-BRmF601H.js +200 -0
  94. package/dist/_chunks/gu-BRmF601H.js.map +1 -0
  95. package/dist/_chunks/gu-CNpaMDpH.mjs +200 -0
  96. package/dist/_chunks/gu-CNpaMDpH.mjs.map +1 -0
  97. package/dist/_chunks/hi-CCJBptSq.js +200 -0
  98. package/dist/_chunks/hi-CCJBptSq.js.map +1 -0
  99. package/dist/_chunks/hi-Dwvd04m3.mjs +200 -0
  100. package/dist/_chunks/hi-Dwvd04m3.mjs.map +1 -0
  101. package/dist/{admin/chunks/hooks-D-sOYd1s.js → _chunks/hooks-BAaaKPS_.js} +3 -6
  102. package/dist/_chunks/hooks-BAaaKPS_.js.map +1 -0
  103. package/dist/_chunks/hooks-E5u1mcgM.mjs +8 -0
  104. package/dist/_chunks/hooks-E5u1mcgM.mjs.map +1 -0
  105. package/dist/_chunks/hu-CeYvaaO0.mjs +202 -0
  106. package/dist/_chunks/hu-CeYvaaO0.mjs.map +1 -0
  107. package/dist/_chunks/hu-sNV_yLYy.js +202 -0
  108. package/dist/_chunks/hu-sNV_yLYy.js.map +1 -0
  109. package/dist/_chunks/id-B5Ser98A.js +160 -0
  110. package/dist/{admin/chunks/it-BAHrwmYS.js.map → _chunks/id-B5Ser98A.js.map} +1 -1
  111. package/dist/_chunks/id-BtwA9WJT.mjs +160 -0
  112. package/dist/_chunks/id-BtwA9WJT.mjs.map +1 -0
  113. package/dist/_chunks/index-DiluOUp6.mjs +4423 -0
  114. package/dist/_chunks/index-DiluOUp6.mjs.map +1 -0
  115. package/dist/_chunks/index-EXJvmn4t.js +4442 -0
  116. package/dist/_chunks/index-EXJvmn4t.js.map +1 -0
  117. package/dist/_chunks/it-BrVPqaf1.mjs +162 -0
  118. package/dist/_chunks/it-BrVPqaf1.mjs.map +1 -0
  119. package/dist/_chunks/it-DkBIs7vD.js +162 -0
  120. package/dist/{admin/chunks/id-D7V5S1rB.js.map → _chunks/it-DkBIs7vD.js.map} +1 -1
  121. package/dist/_chunks/ja-7sfIbjxE.js +196 -0
  122. package/dist/{admin/chunks/it-CQFpa_Dc.js.map → _chunks/ja-7sfIbjxE.js.map} +1 -1
  123. package/dist/_chunks/ja-BHqhDq4V.mjs +196 -0
  124. package/dist/_chunks/ja-BHqhDq4V.mjs.map +1 -0
  125. package/dist/_chunks/ko-HVQRlfUI.mjs +195 -0
  126. package/dist/_chunks/ko-HVQRlfUI.mjs.map +1 -0
  127. package/dist/_chunks/ko-woFZPmLk.js +195 -0
  128. package/dist/{admin/chunks/es-DkoWSExG.js.map → _chunks/ko-woFZPmLk.js.map} +1 -1
  129. package/dist/_chunks/layout-4TbKVax8.js +488 -0
  130. package/dist/_chunks/layout-4TbKVax8.js.map +1 -0
  131. package/dist/_chunks/layout-mSwsYzxv.mjs +471 -0
  132. package/dist/_chunks/layout-mSwsYzxv.mjs.map +1 -0
  133. package/dist/_chunks/ml-BihZwQit.mjs +200 -0
  134. package/dist/_chunks/ml-BihZwQit.mjs.map +1 -0
  135. package/dist/_chunks/ml-C2W8N8k1.js +200 -0
  136. package/dist/_chunks/ml-C2W8N8k1.js.map +1 -0
  137. package/dist/_chunks/ms-BuFotyP_.js +144 -0
  138. package/dist/{admin/chunks/cs-BJFxwIWj.js.map → _chunks/ms-BuFotyP_.js.map} +1 -1
  139. package/dist/_chunks/ms-m_WjyWx7.mjs +144 -0
  140. package/dist/_chunks/ms-m_WjyWx7.mjs.map +1 -0
  141. package/dist/_chunks/nl-D4R9gHx5.mjs +202 -0
  142. package/dist/_chunks/nl-D4R9gHx5.mjs.map +1 -0
  143. package/dist/_chunks/nl-bbEOHChV.js +202 -0
  144. package/dist/_chunks/nl-bbEOHChV.js.map +1 -0
  145. package/dist/_chunks/objects-BcXOv6_9.js +47 -0
  146. package/dist/_chunks/objects-BcXOv6_9.js.map +1 -0
  147. package/dist/_chunks/objects-D6yBsdmx.mjs +45 -0
  148. package/dist/_chunks/objects-D6yBsdmx.mjs.map +1 -0
  149. package/dist/_chunks/pl-sbx9mSt_.mjs +199 -0
  150. package/dist/_chunks/pl-sbx9mSt_.mjs.map +1 -0
  151. package/dist/_chunks/pl-uzwG-hk7.js +199 -0
  152. package/dist/{admin/chunks/ca-DviY7mRj.js.map → _chunks/pl-uzwG-hk7.js.map} +1 -1
  153. package/dist/_chunks/pt-BR-BiOz37D9.js +201 -0
  154. package/dist/{admin/chunks/pt-BR-CcotyBGJ.js.map → _chunks/pt-BR-BiOz37D9.js.map} +1 -1
  155. package/dist/_chunks/pt-BR-C71iDxnh.mjs +201 -0
  156. package/dist/_chunks/pt-BR-C71iDxnh.mjs.map +1 -0
  157. package/dist/_chunks/pt-BsaFvS8-.mjs +95 -0
  158. package/dist/_chunks/pt-BsaFvS8-.mjs.map +1 -0
  159. package/dist/_chunks/pt-CeXQuq50.js +95 -0
  160. package/dist/_chunks/pt-CeXQuq50.js.map +1 -0
  161. package/dist/_chunks/relations--YOvQBqv.mjs +134 -0
  162. package/dist/_chunks/relations--YOvQBqv.mjs.map +1 -0
  163. package/dist/_chunks/relations-Ai6Izh7h.js +133 -0
  164. package/dist/_chunks/relations-Ai6Izh7h.js.map +1 -0
  165. package/dist/_chunks/ru-BE6A4Exp.mjs +231 -0
  166. package/dist/{admin/chunks/ar-DeQBSsfl.js.map → _chunks/ru-BE6A4Exp.mjs.map} +1 -1
  167. package/dist/_chunks/ru-BT3ybNny.js +231 -0
  168. package/dist/{admin/chunks/ru-CB4BUyQp.js.map → _chunks/ru-BT3ybNny.js.map} +1 -1
  169. package/dist/_chunks/sa-CcvkYInH.js +200 -0
  170. package/dist/_chunks/sa-CcvkYInH.js.map +1 -0
  171. package/dist/_chunks/sa-Dag0k-Z8.mjs +200 -0
  172. package/dist/_chunks/sa-Dag0k-Z8.mjs.map +1 -0
  173. package/dist/_chunks/sk-BFg-R8qJ.mjs +202 -0
  174. package/dist/_chunks/sk-BFg-R8qJ.mjs.map +1 -0
  175. package/dist/_chunks/sk-CvY09Xjv.js +202 -0
  176. package/dist/_chunks/sk-CvY09Xjv.js.map +1 -0
  177. package/dist/_chunks/sv-CUnfWGsh.mjs +202 -0
  178. package/dist/_chunks/sv-CUnfWGsh.mjs.map +1 -0
  179. package/dist/_chunks/sv-MYDuzgvT.js +202 -0
  180. package/dist/_chunks/sv-MYDuzgvT.js.map +1 -0
  181. package/dist/_chunks/th-BqbI8lIT.mjs +148 -0
  182. package/dist/_chunks/th-BqbI8lIT.mjs.map +1 -0
  183. package/dist/_chunks/th-D9_GfAjc.js +148 -0
  184. package/dist/{admin/chunks/ms-CvSC0OdG.js.map → _chunks/th-D9_GfAjc.js.map} +1 -1
  185. package/dist/_chunks/tr-CgeK3wJM.mjs +199 -0
  186. package/dist/_chunks/tr-CgeK3wJM.mjs.map +1 -0
  187. package/dist/_chunks/tr-D9UH-O_R.js +199 -0
  188. package/dist/_chunks/tr-D9UH-O_R.js.map +1 -0
  189. package/dist/_chunks/uk-C8EiqJY7.js +144 -0
  190. package/dist/{admin/chunks/ms-Bh09NFff.js.map → _chunks/uk-C8EiqJY7.js.map} +1 -1
  191. package/dist/_chunks/uk-CR-zDhAY.mjs +144 -0
  192. package/dist/_chunks/uk-CR-zDhAY.mjs.map +1 -0
  193. package/dist/_chunks/useDragAndDrop-BMtgCYzL.js +245 -0
  194. package/dist/_chunks/useDragAndDrop-BMtgCYzL.js.map +1 -0
  195. package/dist/_chunks/useDragAndDrop-DJ6jqvZN.mjs +228 -0
  196. package/dist/_chunks/useDragAndDrop-DJ6jqvZN.mjs.map +1 -0
  197. package/dist/_chunks/usePrev-CZGy2Vjf.mjs +29 -0
  198. package/dist/_chunks/usePrev-CZGy2Vjf.mjs.map +1 -0
  199. package/dist/_chunks/usePrev-D5J_2fEu.js +28 -0
  200. package/dist/_chunks/usePrev-D5J_2fEu.js.map +1 -0
  201. package/dist/_chunks/vi-CJlYDheJ.js +111 -0
  202. package/dist/{admin/chunks/vi-CvBGlTjr.js.map → _chunks/vi-CJlYDheJ.js.map} +1 -1
  203. package/dist/_chunks/vi-DUXIk_fw.mjs +111 -0
  204. package/dist/_chunks/vi-DUXIk_fw.mjs.map +1 -0
  205. package/dist/_chunks/zh-BWZspA60.mjs +209 -0
  206. package/dist/_chunks/zh-BWZspA60.mjs.map +1 -0
  207. package/dist/_chunks/zh-CQQfszqR.js +209 -0
  208. package/dist/{admin/chunks/ca-ClDTvatJ.js.map → _chunks/zh-CQQfszqR.js.map} +1 -1
  209. package/dist/_chunks/zh-Hans-9kOncHGw.js +952 -0
  210. package/dist/{admin/chunks/zh-Hans-CI0HKio3.js.map → _chunks/zh-Hans-9kOncHGw.js.map} +1 -1
  211. package/dist/_chunks/zh-Hans-BPQcRIyH.mjs +952 -0
  212. package/dist/{admin/chunks/zh-Hans-JVK9x7xr.js.map → _chunks/zh-Hans-BPQcRIyH.mjs.map} +1 -1
  213. package/dist/admin/index.js +4 -23
  214. package/dist/admin/index.js.map +1 -1
  215. package/dist/admin/index.mjs +13 -16
  216. package/dist/admin/index.mjs.map +1 -1
  217. package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
  218. package/dist/admin/src/hooks/useDocument.d.ts +2 -2
  219. package/dist/admin/src/preview/components/PreviewContent.d.ts +1 -2
  220. package/dist/admin/src/preview/components/PreviewHeader.d.ts +1 -2
  221. package/dist/admin/src/preview/index.d.ts +3 -2
  222. package/dist/server/index.js +4396 -5468
  223. package/dist/server/index.js.map +1 -1
  224. package/dist/server/index.mjs +4368 -5442
  225. package/dist/server/index.mjs.map +1 -1
  226. package/dist/server/src/controllers/utils/metadata.d.ts +1 -1
  227. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
  228. package/dist/server/src/history/services/utils.d.ts.map +1 -1
  229. package/dist/server/src/services/utils/count.d.ts +1 -1
  230. package/dist/server/src/services/utils/count.d.ts.map +1 -1
  231. package/dist/server/src/services/utils/populate.d.ts +1 -1
  232. package/dist/server/src/services/utils/populate.d.ts.map +1 -1
  233. package/dist/shared/contracts/collection-types.d.ts +1 -0
  234. package/dist/shared/contracts/components.d.ts +1 -0
  235. package/dist/shared/contracts/content-types.d.ts +1 -0
  236. package/dist/shared/contracts/history-versions.d.ts +1 -0
  237. package/dist/shared/contracts/index.d.ts +1 -0
  238. package/dist/shared/contracts/init.d.ts +1 -0
  239. package/dist/shared/contracts/preview.d.ts +1 -0
  240. package/dist/shared/contracts/relations.d.ts +2 -1
  241. package/dist/shared/contracts/relations.d.ts.map +1 -1
  242. package/dist/shared/contracts/review-workflows.d.ts +1 -0
  243. package/dist/shared/contracts/single-types.d.ts +1 -0
  244. package/dist/shared/contracts/uid.d.ts +1 -0
  245. package/dist/shared/index.d.ts +1 -0
  246. package/dist/shared/index.js +24 -35
  247. package/dist/shared/index.js.map +1 -1
  248. package/dist/shared/index.mjs +25 -34
  249. package/dist/shared/index.mjs.map +1 -1
  250. package/package.json +10 -13
  251. package/dist/admin/chunks/CardDragPreview-DwuraT0K.js +0 -80
  252. package/dist/admin/chunks/CardDragPreview-DwuraT0K.js.map +0 -1
  253. package/dist/admin/chunks/CardDragPreview-_dubYgXO.js +0 -82
  254. package/dist/admin/chunks/CardDragPreview-_dubYgXO.js.map +0 -1
  255. package/dist/admin/chunks/ComponentConfigurationPage-Co2eC_-C.js +0 -276
  256. package/dist/admin/chunks/ComponentConfigurationPage-Co2eC_-C.js.map +0 -1
  257. package/dist/admin/chunks/ComponentConfigurationPage-Dj1bNvEF.js +0 -298
  258. package/dist/admin/chunks/ComponentConfigurationPage-Dj1bNvEF.js.map +0 -1
  259. package/dist/admin/chunks/ComponentIcon-BZcTc4rj.js +0 -153
  260. package/dist/admin/chunks/ComponentIcon-BZcTc4rj.js.map +0 -1
  261. package/dist/admin/chunks/ComponentIcon-C-EjOUPA.js +0 -176
  262. package/dist/admin/chunks/ComponentIcon-C-EjOUPA.js.map +0 -1
  263. package/dist/admin/chunks/EditConfigurationPage-Dm5woBp9.js +0 -180
  264. package/dist/admin/chunks/EditConfigurationPage-Dm5woBp9.js.map +0 -1
  265. package/dist/admin/chunks/EditConfigurationPage-zd9OLaVh.js +0 -158
  266. package/dist/admin/chunks/EditConfigurationPage-zd9OLaVh.js.map +0 -1
  267. package/dist/admin/chunks/EditViewPage-DsBKmSPb.js +0 -337
  268. package/dist/admin/chunks/EditViewPage-DsBKmSPb.js.map +0 -1
  269. package/dist/admin/chunks/EditViewPage-kAIaYTg0.js +0 -314
  270. package/dist/admin/chunks/EditViewPage-kAIaYTg0.js.map +0 -1
  271. package/dist/admin/chunks/FieldTypeIcon-BY6MrVF4.js +0 -56
  272. package/dist/admin/chunks/FieldTypeIcon-BY6MrVF4.js.map +0 -1
  273. package/dist/admin/chunks/FieldTypeIcon-Bxh-7Jin.js +0 -58
  274. package/dist/admin/chunks/FieldTypeIcon-Bxh-7Jin.js.map +0 -1
  275. package/dist/admin/chunks/Form-BO69oITe.js +0 -955
  276. package/dist/admin/chunks/Form-BO69oITe.js.map +0 -1
  277. package/dist/admin/chunks/Form-BPIhJKyf.js +0 -978
  278. package/dist/admin/chunks/Form-BPIhJKyf.js.map +0 -1
  279. package/dist/admin/chunks/History-BzvpM-Gw.js +0 -1357
  280. package/dist/admin/chunks/History-BzvpM-Gw.js.map +0 -1
  281. package/dist/admin/chunks/History-DBQ96jv2.js +0 -1380
  282. package/dist/admin/chunks/History-DBQ96jv2.js.map +0 -1
  283. package/dist/admin/chunks/Input-BlDcbhUC.js +0 -6755
  284. package/dist/admin/chunks/Input-BlDcbhUC.js.map +0 -1
  285. package/dist/admin/chunks/Input-Dh1MtWno.js +0 -6786
  286. package/dist/admin/chunks/Input-Dh1MtWno.js.map +0 -1
  287. package/dist/admin/chunks/ListConfigurationPage-8d3BsQIr.js +0 -818
  288. package/dist/admin/chunks/ListConfigurationPage-8d3BsQIr.js.map +0 -1
  289. package/dist/admin/chunks/ListConfigurationPage-DK0ARecn.js +0 -795
  290. package/dist/admin/chunks/ListConfigurationPage-DK0ARecn.js.map +0 -1
  291. package/dist/admin/chunks/ListViewPage-BF2q7N6W.js +0 -1132
  292. package/dist/admin/chunks/ListViewPage-BF2q7N6W.js.map +0 -1
  293. package/dist/admin/chunks/ListViewPage-CS1ED-vI.js +0 -1154
  294. package/dist/admin/chunks/ListViewPage-CS1ED-vI.js.map +0 -1
  295. package/dist/admin/chunks/NoContentTypePage-C5Qxz3I4.js +0 -59
  296. package/dist/admin/chunks/NoContentTypePage-C5Qxz3I4.js.map +0 -1
  297. package/dist/admin/chunks/NoContentTypePage-DjdXr1-j.js +0 -57
  298. package/dist/admin/chunks/NoContentTypePage-DjdXr1-j.js.map +0 -1
  299. package/dist/admin/chunks/NoPermissionsPage-BUwtKUEP.js +0 -36
  300. package/dist/admin/chunks/NoPermissionsPage-BUwtKUEP.js.map +0 -1
  301. package/dist/admin/chunks/NoPermissionsPage-C5dC0MtL.js +0 -38
  302. package/dist/admin/chunks/NoPermissionsPage-C5dC0MtL.js.map +0 -1
  303. package/dist/admin/chunks/Preview-C9kXTY6C.js +0 -531
  304. package/dist/admin/chunks/Preview-C9kXTY6C.js.map +0 -1
  305. package/dist/admin/chunks/Preview-DBvmhR7Q.js +0 -553
  306. package/dist/admin/chunks/Preview-DBvmhR7Q.js.map +0 -1
  307. package/dist/admin/chunks/Relations-Cn0atFpd.js +0 -827
  308. package/dist/admin/chunks/Relations-Cn0atFpd.js.map +0 -1
  309. package/dist/admin/chunks/Relations-XHxDKEvT.js +0 -853
  310. package/dist/admin/chunks/Relations-XHxDKEvT.js.map +0 -1
  311. package/dist/admin/chunks/ar-DckYq_WK.js +0 -222
  312. package/dist/admin/chunks/ar-DeQBSsfl.js +0 -227
  313. package/dist/admin/chunks/ca-ClDTvatJ.js +0 -202
  314. package/dist/admin/chunks/ca-DviY7mRj.js +0 -197
  315. package/dist/admin/chunks/cs-BJFxwIWj.js +0 -126
  316. package/dist/admin/chunks/cs-C7OSYFQ7.js +0 -122
  317. package/dist/admin/chunks/de-5QRlDHyR.js +0 -195
  318. package/dist/admin/chunks/de-CbImAUA5.js +0 -200
  319. package/dist/admin/chunks/en-C1CjdAtC.js +0 -313
  320. package/dist/admin/chunks/en-LfhocNG2.js +0 -308
  321. package/dist/admin/chunks/es-C8vLuvZL.js +0 -197
  322. package/dist/admin/chunks/es-DkoWSExG.js +0 -192
  323. package/dist/admin/chunks/eu-BG1xX7HK.js +0 -198
  324. package/dist/admin/chunks/eu-BG1xX7HK.js.map +0 -1
  325. package/dist/admin/chunks/eu-BJW3AvXu.js +0 -203
  326. package/dist/admin/chunks/eu-BJW3AvXu.js.map +0 -1
  327. package/dist/admin/chunks/fr-CFdRaRVj.js +0 -215
  328. package/dist/admin/chunks/fr-CFdRaRVj.js.map +0 -1
  329. package/dist/admin/chunks/fr-gQSilC7w.js +0 -220
  330. package/dist/admin/chunks/fr-gQSilC7w.js.map +0 -1
  331. package/dist/admin/chunks/gu-D5MMMXRs.js +0 -196
  332. package/dist/admin/chunks/gu-D5MMMXRs.js.map +0 -1
  333. package/dist/admin/chunks/gu-DPU4wyx7.js +0 -201
  334. package/dist/admin/chunks/gu-DPU4wyx7.js.map +0 -1
  335. package/dist/admin/chunks/hi-Dp4omeBb.js +0 -201
  336. package/dist/admin/chunks/hi-Dp4omeBb.js.map +0 -1
  337. package/dist/admin/chunks/hi-lp17SCjr.js +0 -196
  338. package/dist/admin/chunks/hi-lp17SCjr.js.map +0 -1
  339. package/dist/admin/chunks/hooks-D-sOYd1s.js.map +0 -1
  340. package/dist/admin/chunks/hooks-DMvik5y_.js +0 -7
  341. package/dist/admin/chunks/hooks-DMvik5y_.js.map +0 -1
  342. package/dist/admin/chunks/hu-CLka1U2C.js +0 -198
  343. package/dist/admin/chunks/hu-CLka1U2C.js.map +0 -1
  344. package/dist/admin/chunks/hu-CtFJuhTd.js +0 -203
  345. package/dist/admin/chunks/hu-CtFJuhTd.js.map +0 -1
  346. package/dist/admin/chunks/id-D7V5S1rB.js +0 -161
  347. package/dist/admin/chunks/id-USfY9m1g.js +0 -156
  348. package/dist/admin/chunks/id-USfY9m1g.js.map +0 -1
  349. package/dist/admin/chunks/index-BczuAULz.js +0 -5416
  350. package/dist/admin/chunks/index-BczuAULz.js.map +0 -1
  351. package/dist/admin/chunks/index-BkyR-Bnu.js +0 -5350
  352. package/dist/admin/chunks/index-BkyR-Bnu.js.map +0 -1
  353. package/dist/admin/chunks/it-BAHrwmYS.js +0 -158
  354. package/dist/admin/chunks/it-CQFpa_Dc.js +0 -163
  355. package/dist/admin/chunks/ja-BWKmBJFT.js +0 -192
  356. package/dist/admin/chunks/ja-BWKmBJFT.js.map +0 -1
  357. package/dist/admin/chunks/ja-jdQM-B79.js +0 -197
  358. package/dist/admin/chunks/ja-jdQM-B79.js.map +0 -1
  359. package/dist/admin/chunks/ko-CgADGBNt.js +0 -191
  360. package/dist/admin/chunks/ko-CgADGBNt.js.map +0 -1
  361. package/dist/admin/chunks/ko-k46sEyzt.js +0 -196
  362. package/dist/admin/chunks/ko-k46sEyzt.js.map +0 -1
  363. package/dist/admin/chunks/layout-DcDoRT8g.js +0 -618
  364. package/dist/admin/chunks/layout-DcDoRT8g.js.map +0 -1
  365. package/dist/admin/chunks/layout-fghBgRgX.js +0 -598
  366. package/dist/admin/chunks/layout-fghBgRgX.js.map +0 -1
  367. package/dist/admin/chunks/ml-CnhCfOn_.js +0 -196
  368. package/dist/admin/chunks/ml-CnhCfOn_.js.map +0 -1
  369. package/dist/admin/chunks/ml-DqxPwODx.js +0 -201
  370. package/dist/admin/chunks/ml-DqxPwODx.js.map +0 -1
  371. package/dist/admin/chunks/ms-Bh09NFff.js +0 -140
  372. package/dist/admin/chunks/ms-CvSC0OdG.js +0 -145
  373. package/dist/admin/chunks/nl-BEubhS8C.js +0 -203
  374. package/dist/admin/chunks/nl-BEubhS8C.js.map +0 -1
  375. package/dist/admin/chunks/nl-C8HYflTc.js +0 -198
  376. package/dist/admin/chunks/nl-C8HYflTc.js.map +0 -1
  377. package/dist/admin/chunks/objects-C3EebVVe.js +0 -76
  378. package/dist/admin/chunks/objects-C3EebVVe.js.map +0 -1
  379. package/dist/admin/chunks/objects-wl73iEma.js +0 -73
  380. package/dist/admin/chunks/objects-wl73iEma.js.map +0 -1
  381. package/dist/admin/chunks/pl-DWhGDzmM.js +0 -200
  382. package/dist/admin/chunks/pl-DWhGDzmM.js.map +0 -1
  383. package/dist/admin/chunks/pl-MFCZJZuZ.js +0 -195
  384. package/dist/admin/chunks/pl-MFCZJZuZ.js.map +0 -1
  385. package/dist/admin/chunks/pt-BR-CPtAXD-4.js +0 -202
  386. package/dist/admin/chunks/pt-BR-CPtAXD-4.js.map +0 -1
  387. package/dist/admin/chunks/pt-BR-CcotyBGJ.js +0 -197
  388. package/dist/admin/chunks/pt-BoPxN80n.js +0 -96
  389. package/dist/admin/chunks/pt-BoPxN80n.js.map +0 -1
  390. package/dist/admin/chunks/pt-HbmgeiYO.js +0 -93
  391. package/dist/admin/chunks/pt-HbmgeiYO.js.map +0 -1
  392. package/dist/admin/chunks/relations-CgaydhiM.js +0 -178
  393. package/dist/admin/chunks/relations-CgaydhiM.js.map +0 -1
  394. package/dist/admin/chunks/relations-DPVgU_rq.js +0 -173
  395. package/dist/admin/chunks/relations-DPVgU_rq.js.map +0 -1
  396. package/dist/admin/chunks/ru-C0op0ALG.js +0 -232
  397. package/dist/admin/chunks/ru-C0op0ALG.js.map +0 -1
  398. package/dist/admin/chunks/ru-CB4BUyQp.js +0 -230
  399. package/dist/admin/chunks/sa-B_FuPyMw.js +0 -201
  400. package/dist/admin/chunks/sa-B_FuPyMw.js.map +0 -1
  401. package/dist/admin/chunks/sa-n_aPA-pU.js +0 -196
  402. package/dist/admin/chunks/sa-n_aPA-pU.js.map +0 -1
  403. package/dist/admin/chunks/sk-D_iXML2C.js +0 -203
  404. package/dist/admin/chunks/sk-D_iXML2C.js.map +0 -1
  405. package/dist/admin/chunks/sk-tn_BDjE2.js +0 -198
  406. package/dist/admin/chunks/sk-tn_BDjE2.js.map +0 -1
  407. package/dist/admin/chunks/sv-BstBC1Yp.js +0 -203
  408. package/dist/admin/chunks/sv-BstBC1Yp.js.map +0 -1
  409. package/dist/admin/chunks/sv-cq4ZrQRd.js +0 -198
  410. package/dist/admin/chunks/sv-cq4ZrQRd.js.map +0 -1
  411. package/dist/admin/chunks/th-lXoOCqPC.js +0 -149
  412. package/dist/admin/chunks/th-lXoOCqPC.js.map +0 -1
  413. package/dist/admin/chunks/th-mUH7hEtc.js +0 -144
  414. package/dist/admin/chunks/th-mUH7hEtc.js.map +0 -1
  415. package/dist/admin/chunks/tr-CkS6sLIE.js +0 -200
  416. package/dist/admin/chunks/tr-CkS6sLIE.js.map +0 -1
  417. package/dist/admin/chunks/tr-Yt38daxh.js +0 -195
  418. package/dist/admin/chunks/tr-Yt38daxh.js.map +0 -1
  419. package/dist/admin/chunks/uk-B24MoTVg.js +0 -145
  420. package/dist/admin/chunks/uk-B24MoTVg.js.map +0 -1
  421. package/dist/admin/chunks/uk-Cpgmm7gE.js +0 -140
  422. package/dist/admin/chunks/uk-Cpgmm7gE.js.map +0 -1
  423. package/dist/admin/chunks/useDragAndDrop-HYwNDExe.js +0 -247
  424. package/dist/admin/chunks/useDragAndDrop-HYwNDExe.js.map +0 -1
  425. package/dist/admin/chunks/useDragAndDrop-gcqEJMnO.js +0 -271
  426. package/dist/admin/chunks/useDragAndDrop-gcqEJMnO.js.map +0 -1
  427. package/dist/admin/chunks/usePrev-Bjw2dhmq.js +0 -18
  428. package/dist/admin/chunks/usePrev-Bjw2dhmq.js.map +0 -1
  429. package/dist/admin/chunks/usePrev-DIYl-IAL.js +0 -21
  430. package/dist/admin/chunks/usePrev-DIYl-IAL.js.map +0 -1
  431. package/dist/admin/chunks/vi-BGr1X_HZ.js +0 -112
  432. package/dist/admin/chunks/vi-BGr1X_HZ.js.map +0 -1
  433. package/dist/admin/chunks/vi-CvBGlTjr.js +0 -108
  434. package/dist/admin/chunks/zh-BmF-sHaT.js +0 -205
  435. package/dist/admin/chunks/zh-BmF-sHaT.js.map +0 -1
  436. package/dist/admin/chunks/zh-DwFu_Kfj.js +0 -210
  437. package/dist/admin/chunks/zh-DwFu_Kfj.js.map +0 -1
  438. package/dist/admin/chunks/zh-Hans-CI0HKio3.js +0 -934
  439. package/dist/admin/chunks/zh-Hans-JVK9x7xr.js +0 -953
@@ -1,1154 +0,0 @@
1
- 'use strict';
2
-
3
- var jsxRuntime = require('react/jsx-runtime');
4
- var React = require('react');
5
- var strapiAdmin = require('@strapi/admin/strapi-admin');
6
- var designSystem = require('@strapi/design-system');
7
- var Icons = require('@strapi/icons');
8
- var isEqual = require('lodash/isEqual');
9
- var qs = require('qs');
10
- var reactIntl = require('react-intl');
11
- var reactRouterDom = require('react-router-dom');
12
- var styledComponents = require('styled-components');
13
- var index = require('./index-BczuAULz.js');
14
- var usePrev = require('./usePrev-DIYl-IAL.js');
15
- var relations = require('./relations-CgaydhiM.js');
16
- var isEmpty = require('lodash/isEmpty');
17
- var parseISO = require('date-fns/parseISO');
18
- var toString = require('lodash/toString');
19
- var hooks = require('./hooks-D-sOYd1s.js');
20
- require('lodash/fp/mapValues');
21
- require('yup');
22
- require('fractional-indexing');
23
- require('lodash/fp/pipe');
24
- require('date-fns');
25
- require('@reduxjs/toolkit');
26
- require('react-redux');
27
-
28
- function _interopNamespaceDefault(e) {
29
- var n = Object.create(null);
30
- if (e) {
31
- Object.keys(e).forEach(function (k) {
32
- if (k !== 'default') {
33
- var d = Object.getOwnPropertyDescriptor(e, k);
34
- Object.defineProperty(n, k, d.get ? d : {
35
- enumerable: true,
36
- get: function () { return e[k]; }
37
- });
38
- }
39
- });
40
- }
41
- n.default = e;
42
- return Object.freeze(n);
43
- }
44
-
45
- var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
46
-
47
- /**
48
- * If new attributes are added, this list needs to be updated.
49
- */ const NOT_ALLOWED_FILTERS = [
50
- 'json',
51
- 'component',
52
- 'media',
53
- 'richtext',
54
- 'dynamiczone',
55
- 'password',
56
- 'blocks'
57
- ];
58
- const DEFAULT_ALLOWED_FILTERS = [
59
- 'createdAt',
60
- 'updatedAt'
61
- ];
62
- const USER_FILTER_ATTRIBUTES = [
63
- ...index.CREATOR_FIELDS,
64
- 'strapi_assignee'
65
- ];
66
- const FiltersImpl = ({ disabled, schema })=>{
67
- const { attributes, uid: model, options } = schema;
68
- const { formatMessage, locale } = reactIntl.useIntl();
69
- const { trackUsage } = strapiAdmin.useTracking();
70
- const allPermissions = strapiAdmin.useAuth('FiltersImpl', (state)=>state.permissions);
71
- const [{ query }] = strapiAdmin.useQueryParams();
72
- const { schemas } = index.useContentTypeSchema();
73
- const canReadAdminUsers = React__namespace.useMemo(()=>allPermissions.filter((permission)=>permission.action === 'admin::users.read' && permission.subject === null).length > 0, [
74
- allPermissions
75
- ]);
76
- const selectedUserIds = (query?.filters?.$and ?? []).reduce((acc, filter)=>{
77
- const [key, value] = Object.entries(filter)[0];
78
- if (typeof value.id !== 'object') {
79
- return acc;
80
- }
81
- const id = value.id.$eq || value.id.$ne;
82
- if (id && USER_FILTER_ATTRIBUTES.includes(key) && !acc.includes(id)) {
83
- acc.push(id);
84
- }
85
- return acc;
86
- }, []);
87
- const { data: userData, isLoading: isLoadingAdminUsers } = strapiAdmin.useAdminUsers({
88
- filters: {
89
- id: {
90
- $in: selectedUserIds
91
- }
92
- }
93
- }, {
94
- // fetch the list of admin users only if the filter contains users and the
95
- // current user has permissions to display users
96
- skip: selectedUserIds.length === 0 || !canReadAdminUsers
97
- });
98
- const { users = [] } = userData ?? {};
99
- const { metadata } = index.useGetContentTypeConfigurationQuery(model, {
100
- selectFromResult: ({ data })=>({
101
- metadata: data?.contentType.metadatas ?? {}
102
- })
103
- });
104
- const formatter = designSystem.useCollator(locale, {
105
- sensitivity: 'base'
106
- });
107
- const displayedFilters = React__namespace.useMemo(()=>{
108
- const [{ properties: { fields = [] } = {
109
- fields: []
110
- } }] = allPermissions.filter((permission)=>permission.action === 'plugin::content-manager.explorer.read' && permission.subject === model);
111
- const allowedFields = fields.filter((field)=>{
112
- const attribute = attributes[field] ?? {};
113
- return attribute.type && !NOT_ALLOWED_FILTERS.includes(attribute.type);
114
- });
115
- return [
116
- 'id',
117
- ...allowedFields,
118
- ...DEFAULT_ALLOWED_FILTERS,
119
- ...canReadAdminUsers ? index.CREATOR_FIELDS : []
120
- ].map((name)=>{
121
- const attribute = attributes[name];
122
- if (NOT_ALLOWED_FILTERS.includes(attribute.type)) {
123
- return null;
124
- }
125
- const { mainField: mainFieldName = '', label } = metadata[name].list;
126
- let filter = {
127
- name,
128
- label: label ?? '',
129
- mainField: index.getMainField(attribute, mainFieldName, {
130
- schemas,
131
- components: {}
132
- }),
133
- // @ts-expect-error – TODO: this is filtered out above in the `allowedFields` call but TS complains, is there a better way to solve this?
134
- type: attribute.type
135
- };
136
- if (attribute.type === 'relation' && 'target' in attribute && attribute.target === 'admin::user') {
137
- filter = {
138
- ...filter,
139
- input: AdminUsersFilter,
140
- options: users.map((user)=>({
141
- label: index.getDisplayName(user),
142
- value: user.id.toString()
143
- })),
144
- operators: [
145
- {
146
- label: formatMessage({
147
- id: 'components.FilterOptions.FILTER_TYPES.$eq',
148
- defaultMessage: 'is'
149
- }),
150
- value: '$eq'
151
- },
152
- {
153
- label: formatMessage({
154
- id: 'components.FilterOptions.FILTER_TYPES.$ne',
155
- defaultMessage: 'is not'
156
- }),
157
- value: '$ne'
158
- }
159
- ],
160
- mainField: {
161
- name: 'id',
162
- type: 'integer'
163
- }
164
- };
165
- }
166
- if (attribute.type === 'enumeration') {
167
- filter = {
168
- ...filter,
169
- options: attribute.enum.map((value)=>({
170
- label: value,
171
- value
172
- }))
173
- };
174
- }
175
- return filter;
176
- }).filter(Boolean).toSorted((a, b)=>formatter.compare(a.label, b.label));
177
- }, [
178
- allPermissions,
179
- canReadAdminUsers,
180
- model,
181
- attributes,
182
- metadata,
183
- schemas,
184
- users,
185
- formatMessage,
186
- formatter
187
- ]);
188
- const onOpenChange = (isOpen)=>{
189
- if (isOpen) {
190
- trackUsage('willFilterEntries');
191
- }
192
- };
193
- const handleFilterChange = (data)=>{
194
- const attribute = attributes[data.name];
195
- if (attribute) {
196
- trackUsage('didFilterEntries', {
197
- useRelation: attribute.type === 'relation'
198
- });
199
- }
200
- };
201
- return /*#__PURE__*/ jsxRuntime.jsxs(strapiAdmin.Filters.Root, {
202
- disabled: disabled,
203
- options: displayedFilters,
204
- onOpenChange: onOpenChange,
205
- onChange: handleFilterChange,
206
- children: [
207
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Filters.Trigger, {}),
208
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Filters.Popover, {}),
209
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Filters.List, {})
210
- ]
211
- });
212
- };
213
- /* -------------------------------------------------------------------------------------------------
214
- * AdminUsersFilter
215
- * -----------------------------------------------------------------------------------------------*/ const AdminUsersFilter = ({ name })=>{
216
- const [pageSize, setPageSize] = React__namespace.useState(10);
217
- const [search, setSearch] = React__namespace.useState('');
218
- const { formatMessage } = reactIntl.useIntl();
219
- const debouncedSearch = relations.useDebounce(search, 300);
220
- const { data, isLoading } = strapiAdmin.useAdminUsers({
221
- pageSize,
222
- _q: debouncedSearch
223
- });
224
- const field = strapiAdmin.useField(name);
225
- const handleOpenChange = (isOpen)=>{
226
- if (!isOpen) {
227
- setPageSize(10);
228
- }
229
- };
230
- const { users = [], pagination } = data ?? {};
231
- const { pageCount = 1, page = 1 } = pagination ?? {};
232
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Combobox, {
233
- value: field.value,
234
- "aria-label": formatMessage({
235
- id: 'content-manager.components.Filters.usersSelect.label',
236
- defaultMessage: 'Search and select a user to filter'
237
- }),
238
- onOpenChange: handleOpenChange,
239
- onChange: (value)=>field.onChange(name, value),
240
- loading: isLoading,
241
- onLoadMore: ()=>setPageSize(pageSize + 10),
242
- hasMoreItems: page < pageCount,
243
- onInputChange: (e)=>{
244
- setSearch(e.currentTarget.value);
245
- },
246
- children: users.map((user)=>{
247
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.ComboboxOption, {
248
- value: user.id.toString(),
249
- children: index.getDisplayName(user)
250
- }, user.id);
251
- })
252
- });
253
- };
254
-
255
- const CellValue = ({ type, value })=>{
256
- const { formatDate, formatTime, formatNumber } = reactIntl.useIntl();
257
- let formattedValue = value;
258
- if (type === 'date') {
259
- formattedValue = formatDate(parseISO(value), {
260
- dateStyle: 'full'
261
- });
262
- }
263
- if (type === 'datetime') {
264
- formattedValue = formatDate(value, {
265
- dateStyle: 'full',
266
- timeStyle: 'short'
267
- });
268
- }
269
- if (type === 'time') {
270
- const [hour, minute, second] = value.split(':');
271
- const date = new Date();
272
- date.setHours(hour);
273
- date.setMinutes(minute);
274
- date.setSeconds(second);
275
- formattedValue = formatTime(date, {
276
- timeStyle: 'short'
277
- });
278
- }
279
- if ([
280
- 'float',
281
- 'decimal'
282
- ].includes(type)) {
283
- formattedValue = formatNumber(value, {
284
- // Should be kept in sync with the corresponding value
285
- // in the design-system/NumberInput: https://github.com/strapi/design-system/blob/main/packages/strapi-design-system/src/NumberInput/NumberInput.js#L53
286
- maximumFractionDigits: 20
287
- });
288
- }
289
- if ([
290
- 'integer',
291
- 'biginteger'
292
- ].includes(type)) {
293
- formattedValue = formatNumber(value, {
294
- maximumFractionDigits: 0
295
- });
296
- }
297
- return toString(formattedValue);
298
- };
299
-
300
- const SingleComponent = ({ content, mainField })=>{
301
- if (!mainField) {
302
- return null;
303
- }
304
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Tooltip, {
305
- label: content[mainField.name],
306
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
307
- maxWidth: "25rem",
308
- textColor: "neutral800",
309
- ellipsis: true,
310
- children: /*#__PURE__*/ jsxRuntime.jsx(CellValue, {
311
- type: mainField.type,
312
- value: content[mainField.name]
313
- })
314
- })
315
- });
316
- };
317
- const RepeatableComponent = ({ content, mainField })=>{
318
- const { formatMessage } = reactIntl.useIntl();
319
- if (!mainField) {
320
- return null;
321
- }
322
- return /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Menu.Root, {
323
- children: [
324
- /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Menu.Trigger, {
325
- onClick: (e)=>e.stopPropagation(),
326
- children: [
327
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Badge, {
328
- children: content.length
329
- }),
330
- formatMessage({
331
- id: 'content-manager.containers.list.items',
332
- defaultMessage: '{number, plural, =0 {items} one {item} other {items}}'
333
- }, {
334
- number: content.length
335
- })
336
- ]
337
- }),
338
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Menu.Content, {
339
- children: content.map((item)=>/*#__PURE__*/ jsxRuntime.jsx(designSystem.Menu.Item, {
340
- disabled: true,
341
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
342
- maxWidth: "50rem",
343
- ellipsis: true,
344
- children: /*#__PURE__*/ jsxRuntime.jsx(CellValue, {
345
- type: mainField.type,
346
- value: item[mainField.name]
347
- })
348
- })
349
- }, item.id))
350
- })
351
- ]
352
- });
353
- };
354
-
355
- const getFileExtension = (ext)=>ext && ext[0] === '.' ? ext.substring(1) : ext;
356
- const MediaSingle = ({ url, mime, alternativeText, name, ext, formats })=>{
357
- const fileURL = usePrev.prefixFileUrlWithBackendUrl(url);
358
- if (mime.includes('image')) {
359
- const thumbnail = formats?.thumbnail?.url;
360
- const mediaURL = usePrev.prefixFileUrlWithBackendUrl(thumbnail) || fileURL;
361
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Avatar.Item, {
362
- src: mediaURL,
363
- alt: alternativeText || name,
364
- fallback: alternativeText || name,
365
- preview: true
366
- });
367
- }
368
- const fileExtension = getFileExtension(ext);
369
- const fileName = name.length > 100 ? `${name.substring(0, 100)}...` : name;
370
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Tooltip, {
371
- description: fileName,
372
- children: /*#__PURE__*/ jsxRuntime.jsx(FileWrapper, {
373
- children: fileExtension
374
- })
375
- });
376
- };
377
- const FileWrapper = ({ children })=>{
378
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Flex, {
379
- tag: "span",
380
- position: "relative",
381
- borderRadius: "50%",
382
- width: "26px",
383
- height: "26px",
384
- borderColor: "neutral200",
385
- background: "neutral150",
386
- paddingLeft: "1px",
387
- justifyContent: "center",
388
- alignItems: "center",
389
- children: /*#__PURE__*/ jsxRuntime.jsx(FileTypography, {
390
- variant: "sigma",
391
- textColor: "neutral600",
392
- children: children
393
- })
394
- });
395
- };
396
- const FileTypography = styledComponents.styled(designSystem.Typography)`
397
- font-size: 0.9rem;
398
- line-height: 0.9rem;
399
- `;
400
- const MediaMultiple = ({ content })=>{
401
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Avatar.Group, {
402
- children: content.map((file, index)=>{
403
- const key = `${file.id}${index}`;
404
- if (index === 3) {
405
- const remainingFiles = `+${content.length - 3}`;
406
- return /*#__PURE__*/ jsxRuntime.jsx(FileWrapper, {
407
- children: remainingFiles
408
- }, key);
409
- }
410
- if (index > 3) {
411
- return null;
412
- }
413
- return /*#__PURE__*/ jsxRuntime.jsx(MediaSingle, {
414
- ...file
415
- }, key);
416
- })
417
- });
418
- };
419
-
420
- const RelationSingle = ({ mainField, content })=>{
421
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
422
- maxWidth: "50rem",
423
- textColor: "neutral800",
424
- ellipsis: true,
425
- children: relations.getRelationLabel(content, mainField)
426
- });
427
- };
428
- /**
429
- * TODO: fix this component – tracking issue https://strapi-inc.atlassian.net/browse/CONTENT-2184
430
- */ const RelationMultiple = ({ mainField, content, rowId, name })=>{
431
- const { model } = index.useDoc();
432
- const { formatMessage } = reactIntl.useIntl();
433
- const { notifyStatus } = designSystem.useNotifyAT();
434
- const [isOpen, setIsOpen] = React__namespace.useState(false);
435
- const [targetField] = name.split('.');
436
- const { data, isLoading } = relations.useGetRelationsQuery({
437
- model,
438
- id: rowId,
439
- targetField
440
- }, {
441
- skip: !isOpen,
442
- refetchOnMountOrArgChange: true
443
- });
444
- const contentCount = Array.isArray(content) ? content.length : content.count;
445
- React__namespace.useEffect(()=>{
446
- if (data) {
447
- notifyStatus(formatMessage({
448
- id: index.getTranslation('DynamicTable.relation-loaded'),
449
- defaultMessage: 'Relations have been loaded'
450
- }));
451
- }
452
- }, [
453
- data,
454
- formatMessage,
455
- notifyStatus
456
- ]);
457
- return /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Menu.Root, {
458
- onOpenChange: (isOpen)=>setIsOpen(isOpen),
459
- children: [
460
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Menu.Trigger, {
461
- onClick: (e)=>e.stopPropagation(),
462
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
463
- style: {
464
- cursor: 'pointer'
465
- },
466
- textColor: "neutral800",
467
- fontWeight: "regular",
468
- children: contentCount > 0 ? formatMessage({
469
- id: 'content-manager.containers.list.items',
470
- defaultMessage: '{number} {number, plural, =0 {items} one {item} other {items}}'
471
- }, {
472
- number: contentCount
473
- }) : '-'
474
- })
475
- }),
476
- /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Menu.Content, {
477
- children: [
478
- isLoading && /*#__PURE__*/ jsxRuntime.jsx(designSystem.Menu.Item, {
479
- disabled: true,
480
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Loader, {
481
- small: true,
482
- children: formatMessage({
483
- id: index.getTranslation('ListViewTable.relation-loading'),
484
- defaultMessage: 'Relations are loading'
485
- })
486
- })
487
- }),
488
- data?.results && /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
489
- children: [
490
- data.results.map((entry)=>/*#__PURE__*/ jsxRuntime.jsx(designSystem.Menu.Item, {
491
- disabled: true,
492
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
493
- maxWidth: "50rem",
494
- ellipsis: true,
495
- children: relations.getRelationLabel(entry, mainField)
496
- })
497
- }, entry.documentId)),
498
- data?.pagination && data?.pagination.total > 10 && /*#__PURE__*/ jsxRuntime.jsx(designSystem.Menu.Item, {
499
- "aria-disabled": true,
500
- "aria-label": formatMessage({
501
- id: index.getTranslation('ListViewTable.relation-more'),
502
- defaultMessage: 'This relation contains more entities than displayed'
503
- }),
504
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
505
- children: "…"
506
- })
507
- })
508
- ]
509
- })
510
- ]
511
- })
512
- ]
513
- });
514
- };
515
-
516
- const CellContent = ({ content, mainField, attribute, rowId, name })=>{
517
- if (!hasContent(content, mainField, attribute)) {
518
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
519
- textColor: "neutral800",
520
- paddingLeft: attribute.type === ('relation') ? '1.6rem' : 0,
521
- paddingRight: attribute.type === ('relation') ? '1.6rem' : 0,
522
- children: "-"
523
- });
524
- }
525
- switch(attribute.type){
526
- case 'media':
527
- if (!attribute.multiple) {
528
- return /*#__PURE__*/ jsxRuntime.jsx(MediaSingle, {
529
- ...content
530
- });
531
- }
532
- return /*#__PURE__*/ jsxRuntime.jsx(MediaMultiple, {
533
- content: content
534
- });
535
- case 'relation':
536
- {
537
- if (isSingleRelation(attribute.relation)) {
538
- return /*#__PURE__*/ jsxRuntime.jsx(RelationSingle, {
539
- mainField: mainField,
540
- content: content
541
- });
542
- }
543
- return /*#__PURE__*/ jsxRuntime.jsx(RelationMultiple, {
544
- rowId: rowId,
545
- mainField: mainField,
546
- content: content,
547
- name: name
548
- });
549
- }
550
- case 'component':
551
- if (attribute.repeatable) {
552
- return /*#__PURE__*/ jsxRuntime.jsx(RepeatableComponent, {
553
- mainField: mainField,
554
- content: content
555
- });
556
- }
557
- return /*#__PURE__*/ jsxRuntime.jsx(SingleComponent, {
558
- mainField: mainField,
559
- content: content
560
- });
561
- case 'string':
562
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Tooltip, {
563
- description: content,
564
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
565
- maxWidth: "30rem",
566
- ellipsis: true,
567
- textColor: "neutral800",
568
- children: /*#__PURE__*/ jsxRuntime.jsx(CellValue, {
569
- type: attribute.type,
570
- value: content
571
- })
572
- })
573
- });
574
- default:
575
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
576
- maxWidth: "30rem",
577
- ellipsis: true,
578
- textColor: "neutral800",
579
- children: /*#__PURE__*/ jsxRuntime.jsx(CellValue, {
580
- type: attribute.type,
581
- value: content
582
- })
583
- });
584
- }
585
- };
586
- const hasContent = (content, mainField, attribute)=>{
587
- if (attribute.type === 'component') {
588
- // Repeatable fields show the ID as fallback, in case the mainField
589
- // doesn't have any content
590
- if (attribute.repeatable || !mainField) {
591
- return content?.length > 0;
592
- }
593
- const value = content?.[mainField.name];
594
- // relations, media ... show the id as fallback
595
- if (mainField.name === 'id' && ![
596
- undefined,
597
- null
598
- ].includes(value)) {
599
- return true;
600
- }
601
- return !isEmpty(value);
602
- }
603
- if (attribute.type === 'relation') {
604
- if (isSingleRelation(attribute.relation)) {
605
- return !isEmpty(content);
606
- }
607
- if (Array.isArray(content)) {
608
- return content.length > 0;
609
- }
610
- return content?.count > 0;
611
- }
612
- /*
613
- Biginteger fields need to be treated as strings, as `isNumber`
614
- doesn't deal with them.
615
- */ if ([
616
- 'integer',
617
- 'decimal',
618
- 'float',
619
- 'number'
620
- ].includes(attribute.type)) {
621
- return typeof content === 'number';
622
- }
623
- if (attribute.type === 'boolean') {
624
- return content !== null;
625
- }
626
- return !isEmpty(content);
627
- };
628
- const isSingleRelation = (type)=>[
629
- 'oneToOne',
630
- 'manyToOne',
631
- 'oneToOneMorph'
632
- ].includes(type);
633
-
634
- const ViewSettingsMenu = (props)=>{
635
- const permissions = hooks.useTypedSelector((state)=>state.admin_app.permissions.contentManager?.collectionTypesConfigurations ?? []);
636
- const [{ query }] = strapiAdmin.useQueryParams();
637
- const { formatMessage } = reactIntl.useIntl();
638
- const { allowedActions: { canConfigureView } } = strapiAdmin.useRBAC(permissions);
639
- return /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Popover.Root, {
640
- children: [
641
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Popover.Trigger, {
642
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.IconButton, {
643
- label: formatMessage({
644
- id: 'components.ViewSettings.tooltip',
645
- defaultMessage: 'View Settings'
646
- }),
647
- children: /*#__PURE__*/ jsxRuntime.jsx(Icons.Cog, {})
648
- })
649
- }),
650
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Popover.Content, {
651
- side: "bottom",
652
- align: "end",
653
- sideOffset: 4,
654
- children: /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
655
- alignItems: "stretch",
656
- direction: "column",
657
- padding: 3,
658
- gap: 3,
659
- children: [
660
- canConfigureView ? /*#__PURE__*/ jsxRuntime.jsx(designSystem.LinkButton, {
661
- size: "S",
662
- startIcon: /*#__PURE__*/ jsxRuntime.jsx(Icons.ListPlus, {}),
663
- variant: "secondary",
664
- tag: reactRouterDom.NavLink,
665
- to: {
666
- pathname: 'configurations/list',
667
- search: query.plugins ? qs.stringify({
668
- plugins: query.plugins
669
- }, {
670
- encode: false
671
- }) : ''
672
- },
673
- children: formatMessage({
674
- id: 'app.links.configure-view',
675
- defaultMessage: 'Configure the view'
676
- })
677
- }) : null,
678
- /*#__PURE__*/ jsxRuntime.jsx(FieldPicker, {
679
- ...props
680
- })
681
- ]
682
- })
683
- })
684
- ]
685
- });
686
- };
687
- const FieldPicker = ({ headers = [], resetHeaders, setHeaders })=>{
688
- const { trackUsage } = strapiAdmin.useTracking();
689
- const { formatMessage, locale } = reactIntl.useIntl();
690
- const { schema, model } = index.useDoc();
691
- const { list } = index.useDocumentLayout(model);
692
- const formatter = designSystem.useCollator(locale, {
693
- sensitivity: 'base'
694
- });
695
- const attributes = schema?.attributes ?? {};
696
- const columns = Object.keys(attributes).filter((name)=>index.checkIfAttributeIsDisplayable(attributes[name])).map((name)=>({
697
- name,
698
- label: list.metadatas[name]?.label ?? ''
699
- })).sort((a, b)=>formatter.compare(a.label, b.label));
700
- const handleChange = (name)=>{
701
- trackUsage('didChangeDisplayedFields');
702
- /**
703
- * create an array of the new headers, if the new name exists it should be removed,
704
- * otherwise it should be added
705
- */ const newHeaders = headers.includes(name) ? headers.filter((header)=>header !== name) : [
706
- ...headers,
707
- name
708
- ];
709
- setHeaders(newHeaders);
710
- };
711
- const handleReset = ()=>{
712
- resetHeaders();
713
- };
714
- return /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
715
- tag: "fieldset",
716
- direction: "column",
717
- alignItems: "stretch",
718
- gap: 3,
719
- borderWidth: 0,
720
- maxHeight: '240px',
721
- overflow: 'scroll',
722
- children: [
723
- /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
724
- justifyContent: "space-between",
725
- children: [
726
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
727
- tag: "legend",
728
- variant: "pi",
729
- fontWeight: "bold",
730
- children: formatMessage({
731
- id: 'containers.list.displayedFields',
732
- defaultMessage: 'Displayed fields'
733
- })
734
- }),
735
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.TextButton, {
736
- onClick: handleReset,
737
- children: formatMessage({
738
- id: 'app.components.Button.reset',
739
- defaultMessage: 'Reset'
740
- })
741
- })
742
- ]
743
- }),
744
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Flex, {
745
- direction: "column",
746
- alignItems: "stretch",
747
- children: columns.map((header)=>{
748
- const isActive = headers.includes(header.name);
749
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Flex, {
750
- wrap: "wrap",
751
- gap: 2,
752
- background: isActive ? 'primary100' : 'transparent',
753
- hasRadius: true,
754
- padding: 2,
755
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Checkbox, {
756
- onCheckedChange: ()=>handleChange(header.name),
757
- checked: isActive,
758
- name: header.name,
759
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
760
- fontSize: 1,
761
- children: header.label
762
- })
763
- })
764
- }, header.name);
765
- })
766
- })
767
- ]
768
- });
769
- };
770
-
771
- const { INJECT_COLUMN_IN_TABLE } = index.HOOKS;
772
- /* -------------------------------------------------------------------------------------------------
773
- * ListViewPage
774
- * -----------------------------------------------------------------------------------------------*/ const LayoutsHeaderCustom = styledComponents.styled(strapiAdmin.Layouts.Header)`
775
- overflow-wrap: anywhere;
776
- `;
777
- const ListViewPage = ()=>{
778
- const { trackUsage } = strapiAdmin.useTracking();
779
- const navigate = reactRouterDom.useNavigate();
780
- const { formatMessage } = reactIntl.useIntl();
781
- const { toggleNotification } = strapiAdmin.useNotification();
782
- const { _unstableFormatAPIError: formatAPIError } = strapiAdmin.useAPIErrorHandler(index.getTranslation);
783
- const { collectionType, model, schema } = index.useDoc();
784
- const { list } = index.useDocumentLayout(model);
785
- const [displayedHeaders, setDisplayedHeaders] = React__namespace.useState([]);
786
- const listLayout = usePrev.usePrev(list.layout);
787
- React__namespace.useEffect(()=>{
788
- /**
789
- * ONLY update the displayedHeaders if the document
790
- * layout has actually changed in value.
791
- */ if (!isEqual(listLayout, list.layout)) {
792
- setDisplayedHeaders(list.layout);
793
- }
794
- }, [
795
- list.layout,
796
- listLayout
797
- ]);
798
- const handleSetHeaders = (headers)=>{
799
- setDisplayedHeaders(index.convertListLayoutToFieldLayouts(headers, schema.attributes, list.metadatas));
800
- };
801
- const [{ query }] = strapiAdmin.useQueryParams({
802
- page: '1',
803
- pageSize: list.settings.pageSize.toString(),
804
- sort: list.settings.defaultSortBy ? `${list.settings.defaultSortBy}:${list.settings.defaultSortOrder}` : ''
805
- });
806
- const params = React__namespace.useMemo(()=>index.buildValidParams(query), [
807
- query
808
- ]);
809
- const { data, error, isFetching } = index.useGetAllDocumentsQuery({
810
- model,
811
- params
812
- });
813
- /**
814
- * If the API returns an error, display a notification
815
- */ React__namespace.useEffect(()=>{
816
- if (error) {
817
- toggleNotification({
818
- type: 'danger',
819
- message: formatAPIError(error)
820
- });
821
- }
822
- }, [
823
- error,
824
- formatAPIError,
825
- toggleNotification
826
- ]);
827
- const { results = [], pagination } = data ?? {};
828
- React__namespace.useEffect(()=>{
829
- if (pagination && pagination.pageCount > 0 && pagination.page > pagination.pageCount) {
830
- navigate({
831
- search: qs.stringify({
832
- ...query,
833
- page: pagination.pageCount
834
- })
835
- }, {
836
- replace: true
837
- });
838
- }
839
- }, [
840
- pagination,
841
- formatMessage,
842
- query,
843
- navigate
844
- ]);
845
- const { canCreate } = index.useDocumentRBAC('ListViewPage', ({ canCreate })=>({
846
- canCreate
847
- }));
848
- const runHookWaterfall = strapiAdmin.useStrapiApp('ListViewPage', ({ runHookWaterfall })=>runHookWaterfall);
849
- /**
850
- * Run the waterfall and then inject our additional table headers.
851
- */ const tableHeaders = React__namespace.useMemo(()=>{
852
- const headers = runHookWaterfall(INJECT_COLUMN_IN_TABLE, {
853
- displayedHeaders,
854
- layout: list
855
- });
856
- const formattedHeaders = headers.displayedHeaders.map((header)=>{
857
- /**
858
- * When the header label is a string, it is an attribute on the current content-type:
859
- * Use the attribute name value to compute the translation.
860
- * Otherwise, it should be a translation object coming from a plugin that injects into the table (ie i18n, content-releases, review-workflows):
861
- * Use the translation object as is.
862
- */ const translation = typeof header.label === 'string' ? {
863
- id: `content-manager.content-types.${model}.${header.name}`,
864
- defaultMessage: header.label
865
- } : header.label;
866
- return {
867
- ...header,
868
- label: formatMessage(translation),
869
- name: `${header.name}${header.mainField?.name ? `.${header.mainField.name}` : ''}`
870
- };
871
- });
872
- if (schema?.options?.draftAndPublish) {
873
- formattedHeaders.push({
874
- attribute: {
875
- type: 'custom'
876
- },
877
- name: 'status',
878
- label: formatMessage({
879
- id: index.getTranslation(`containers.list.table-headers.status`),
880
- defaultMessage: 'status'
881
- }),
882
- searchable: false,
883
- sortable: false
884
- });
885
- }
886
- return formattedHeaders;
887
- }, [
888
- displayedHeaders,
889
- formatMessage,
890
- list,
891
- runHookWaterfall,
892
- schema?.options?.draftAndPublish,
893
- model
894
- ]);
895
- if (isFetching) {
896
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Loading, {});
897
- }
898
- if (error) {
899
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Error, {});
900
- }
901
- const contentTypeTitle = schema?.info.displayName ? formatMessage({
902
- id: schema.info.displayName,
903
- defaultMessage: schema.info.displayName
904
- }) : formatMessage({
905
- id: 'content-manager.containers.untitled',
906
- defaultMessage: 'Untitled'
907
- });
908
- const handleRowClick = (id)=>()=>{
909
- trackUsage('willEditEntryFromList');
910
- navigate({
911
- pathname: id.toString(),
912
- search: qs.stringify({
913
- plugins: query.plugins
914
- })
915
- });
916
- };
917
- return /*#__PURE__*/ jsxRuntime.jsxs(strapiAdmin.Page.Main, {
918
- children: [
919
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Title, {
920
- children: `${contentTypeTitle}`
921
- }),
922
- /*#__PURE__*/ jsxRuntime.jsx(LayoutsHeaderCustom, {
923
- primaryAction: canCreate ? /*#__PURE__*/ jsxRuntime.jsx(CreateButton, {}) : null,
924
- subtitle: formatMessage({
925
- id: index.getTranslation('pages.ListView.header-subtitle'),
926
- defaultMessage: '{number, plural, =0 {# entries} one {# entry} other {# entries}} found'
927
- }, {
928
- number: pagination?.total
929
- }),
930
- title: contentTypeTitle,
931
- navigationAction: /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.BackButton, {})
932
- }),
933
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Layouts.Action, {
934
- endActions: /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
935
- children: [
936
- /*#__PURE__*/ jsxRuntime.jsx(index.InjectionZone, {
937
- area: "listView.actions"
938
- }),
939
- /*#__PURE__*/ jsxRuntime.jsx(ViewSettingsMenu, {
940
- setHeaders: handleSetHeaders,
941
- resetHeaders: ()=>setDisplayedHeaders(list.layout),
942
- headers: displayedHeaders.map((header)=>header.name)
943
- })
944
- ]
945
- }),
946
- startActions: /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
947
- children: [
948
- list.settings.searchable && /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.SearchInput, {
949
- disabled: results.length === 0,
950
- label: formatMessage({
951
- id: 'app.component.search.label',
952
- defaultMessage: 'Search for {target}'
953
- }, {
954
- target: contentTypeTitle
955
- }),
956
- placeholder: formatMessage({
957
- id: 'global.search',
958
- defaultMessage: 'Search'
959
- }),
960
- trackedEvent: "didSearch"
961
- }),
962
- list.settings.filterable && schema ? /*#__PURE__*/ jsxRuntime.jsx(FiltersImpl, {
963
- disabled: results.length === 0,
964
- schema: schema
965
- }) : null
966
- ]
967
- })
968
- }),
969
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Layouts.Content, {
970
- children: /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
971
- gap: 4,
972
- direction: "column",
973
- alignItems: "stretch",
974
- children: [
975
- /*#__PURE__*/ jsxRuntime.jsxs(strapiAdmin.Table.Root, {
976
- rows: results,
977
- headers: tableHeaders,
978
- isLoading: isFetching,
979
- children: [
980
- /*#__PURE__*/ jsxRuntime.jsx(TableActionsBar, {}),
981
- /*#__PURE__*/ jsxRuntime.jsxs(strapiAdmin.Table.Content, {
982
- children: [
983
- /*#__PURE__*/ jsxRuntime.jsxs(strapiAdmin.Table.Head, {
984
- children: [
985
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.HeaderCheckboxCell, {}),
986
- tableHeaders.map((header)=>/*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.HeaderCell, {
987
- ...header
988
- }, header.name))
989
- ]
990
- }),
991
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.Loading, {}),
992
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.Empty, {
993
- action: canCreate ? /*#__PURE__*/ jsxRuntime.jsx(CreateButton, {
994
- variant: "secondary"
995
- }) : null
996
- }),
997
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.Body, {
998
- children: results.map((row)=>{
999
- return /*#__PURE__*/ jsxRuntime.jsxs(strapiAdmin.Table.Row, {
1000
- cursor: "pointer",
1001
- onClick: handleRowClick(row.documentId),
1002
- children: [
1003
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.CheckboxCell, {
1004
- id: row.id
1005
- }),
1006
- tableHeaders.map(({ cellFormatter, ...header })=>{
1007
- if (header.name === 'status') {
1008
- const { status } = row;
1009
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.Cell, {
1010
- children: /*#__PURE__*/ jsxRuntime.jsx(index.DocumentStatus, {
1011
- status: status,
1012
- maxWidth: 'min-content'
1013
- })
1014
- }, header.name);
1015
- }
1016
- if ([
1017
- 'createdBy',
1018
- 'updatedBy'
1019
- ].includes(header.name.split('.')[0])) {
1020
- // Display the users full name
1021
- // Some entries doesn't have a user assigned as creator/updater (ex: entries created through content API)
1022
- // In this case, we display a dash
1023
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.Cell, {
1024
- children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
1025
- textColor: "neutral800",
1026
- children: row[header.name.split('.')[0]] ? index.getDisplayName(row[header.name.split('.')[0]]) : '-'
1027
- })
1028
- }, header.name);
1029
- }
1030
- if (typeof cellFormatter === 'function') {
1031
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.Cell, {
1032
- children: cellFormatter(row, header, {
1033
- collectionType,
1034
- model
1035
- })
1036
- }, header.name);
1037
- }
1038
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.Cell, {
1039
- children: /*#__PURE__*/ jsxRuntime.jsx(CellContent, {
1040
- content: row[header.name.split('.')[0]],
1041
- rowId: row.documentId,
1042
- ...header
1043
- })
1044
- }, header.name);
1045
- }),
1046
- /*#__PURE__*/ jsxRuntime.jsx(ActionsCell, {
1047
- onClick: (e)=>e.stopPropagation(),
1048
- children: /*#__PURE__*/ jsxRuntime.jsx(index.TableActions, {
1049
- document: row
1050
- })
1051
- })
1052
- ]
1053
- }, row.id);
1054
- })
1055
- })
1056
- ]
1057
- })
1058
- ]
1059
- }),
1060
- /*#__PURE__*/ jsxRuntime.jsxs(strapiAdmin.Pagination.Root, {
1061
- ...pagination,
1062
- onPageSizeChange: ()=>trackUsage('willChangeNumberOfEntriesPerPage'),
1063
- children: [
1064
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Pagination.PageSize, {}),
1065
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Pagination.Links, {})
1066
- ]
1067
- })
1068
- ]
1069
- })
1070
- })
1071
- ]
1072
- });
1073
- };
1074
- const ActionsCell = styledComponents.styled(strapiAdmin.Table.Cell)`
1075
- display: flex;
1076
- justify-content: flex-end;
1077
- `;
1078
- /* -------------------------------------------------------------------------------------------------
1079
- * TableActionsBar
1080
- * -----------------------------------------------------------------------------------------------*/ const TableActionsBar = ()=>{
1081
- const selectRow = strapiAdmin.useTable('TableActionsBar', (state)=>state.selectRow);
1082
- const [{ query }] = strapiAdmin.useQueryParams();
1083
- const locale = query?.plugins?.i18n?.locale;
1084
- const prevLocale = usePrev.usePrev(locale);
1085
- // TODO: find a better way to reset the selected rows when the locale changes across all the app
1086
- React__namespace.useEffect(()=>{
1087
- if (prevLocale !== locale) {
1088
- selectRow([]);
1089
- }
1090
- }, [
1091
- selectRow,
1092
- prevLocale,
1093
- locale
1094
- ]);
1095
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Table.ActionBar, {
1096
- children: /*#__PURE__*/ jsxRuntime.jsx(index.BulkActionsRenderer, {})
1097
- });
1098
- };
1099
- const CreateButton = ({ variant })=>{
1100
- const { formatMessage } = reactIntl.useIntl();
1101
- const { trackUsage } = strapiAdmin.useTracking();
1102
- const [{ query }] = strapiAdmin.useQueryParams();
1103
- return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Button, {
1104
- variant: variant,
1105
- tag: reactRouterDom.Link,
1106
- onClick: ()=>{
1107
- trackUsage('willCreateEntry', {
1108
- status: 'draft'
1109
- });
1110
- },
1111
- startIcon: /*#__PURE__*/ jsxRuntime.jsx(Icons.Plus, {}),
1112
- style: {
1113
- textDecoration: 'none'
1114
- },
1115
- to: {
1116
- pathname: 'create',
1117
- search: qs.stringify({
1118
- plugins: query.plugins
1119
- })
1120
- },
1121
- minWidth: "max-content",
1122
- marginLeft: 2,
1123
- children: formatMessage({
1124
- id: index.getTranslation('HeaderLayout.button.label-add-entry'),
1125
- defaultMessage: 'Create new entry'
1126
- })
1127
- });
1128
- };
1129
- /* -------------------------------------------------------------------------------------------------
1130
- * ProtectedListViewPage
1131
- * -----------------------------------------------------------------------------------------------*/ const ProtectedListViewPage = ()=>{
1132
- const { slug = '' } = reactRouterDom.useParams();
1133
- const { permissions = [], isLoading, error } = strapiAdmin.useRBAC(index.PERMISSIONS.map((action)=>({
1134
- action,
1135
- subject: slug
1136
- })));
1137
- if (isLoading) {
1138
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Loading, {});
1139
- }
1140
- if (error || !slug) {
1141
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Error, {});
1142
- }
1143
- return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Protect, {
1144
- permissions: permissions,
1145
- children: ({ permissions })=>/*#__PURE__*/ jsxRuntime.jsx(index.DocumentRBAC, {
1146
- permissions: permissions,
1147
- children: /*#__PURE__*/ jsxRuntime.jsx(ListViewPage, {})
1148
- })
1149
- });
1150
- };
1151
-
1152
- exports.ListViewPage = ListViewPage;
1153
- exports.ProtectedListViewPage = ProtectedListViewPage;
1154
- //# sourceMappingURL=ListViewPage-CS1ED-vI.js.map