@strapi/content-manager 0.0.0-next.ce5699024a72ea224891438d5bbe39f904ec6774 → 0.0.0-next.ce8ed0c8aa03361c3009f41af96f742be028ffd9

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 (519) hide show
  1. package/dist/admin/components/ComponentIcon.js +3 -0
  2. package/dist/admin/components/ComponentIcon.js.map +1 -1
  3. package/dist/admin/components/ComponentIcon.mjs +3 -0
  4. package/dist/admin/components/ComponentIcon.mjs.map +1 -1
  5. package/dist/admin/components/ConfigurationForm/EditFieldForm.js +1 -1
  6. package/dist/admin/components/ConfigurationForm/EditFieldForm.js.map +1 -1
  7. package/dist/admin/components/ConfigurationForm/EditFieldForm.mjs +1 -1
  8. package/dist/admin/components/ConfigurationForm/EditFieldForm.mjs.map +1 -1
  9. package/dist/admin/components/ConfigurationForm/Fields.js +304 -205
  10. package/dist/admin/components/ConfigurationForm/Fields.js.map +1 -1
  11. package/dist/admin/components/ConfigurationForm/Fields.mjs +309 -211
  12. package/dist/admin/components/ConfigurationForm/Fields.mjs.map +1 -1
  13. package/dist/admin/components/ConfigurationForm/Form.js +1 -1
  14. package/dist/admin/components/ConfigurationForm/Form.js.map +1 -1
  15. package/dist/admin/components/ConfigurationForm/Form.mjs +3 -3
  16. package/dist/admin/components/ConfigurationForm/Form.mjs.map +1 -1
  17. package/dist/admin/components/DragPreviews/CardDragPreview.js +3 -1
  18. package/dist/admin/components/DragPreviews/CardDragPreview.js.map +1 -1
  19. package/dist/admin/components/DragPreviews/CardDragPreview.mjs +3 -1
  20. package/dist/admin/components/DragPreviews/CardDragPreview.mjs.map +1 -1
  21. package/dist/admin/components/DragPreviews/ComponentDragPreview.js +3 -1
  22. package/dist/admin/components/DragPreviews/ComponentDragPreview.js.map +1 -1
  23. package/dist/admin/components/DragPreviews/ComponentDragPreview.mjs +3 -1
  24. package/dist/admin/components/DragPreviews/ComponentDragPreview.mjs.map +1 -1
  25. package/dist/admin/components/DragPreviews/RelationDragPreview.js +3 -1
  26. package/dist/admin/components/DragPreviews/RelationDragPreview.js.map +1 -1
  27. package/dist/admin/components/DragPreviews/RelationDragPreview.mjs +3 -1
  28. package/dist/admin/components/DragPreviews/RelationDragPreview.mjs.map +1 -1
  29. package/dist/admin/components/LeftMenu.js +94 -50
  30. package/dist/admin/components/LeftMenu.js.map +1 -1
  31. package/dist/admin/components/LeftMenu.mjs +97 -53
  32. package/dist/admin/components/LeftMenu.mjs.map +1 -1
  33. package/dist/admin/components/RelativeTime.js.map +1 -1
  34. package/dist/admin/components/RelativeTime.mjs.map +1 -1
  35. package/dist/admin/components/Widgets.js +437 -0
  36. package/dist/admin/components/Widgets.js.map +1 -0
  37. package/dist/admin/components/Widgets.mjs +414 -0
  38. package/dist/admin/components/Widgets.mjs.map +1 -0
  39. package/dist/admin/content-manager.js.map +1 -1
  40. package/dist/admin/content-manager.mjs.map +1 -1
  41. package/dist/admin/history/components/HistoryAction.js.map +1 -1
  42. package/dist/admin/history/components/HistoryAction.mjs.map +1 -1
  43. package/dist/admin/history/components/VersionContent.js +24 -3
  44. package/dist/admin/history/components/VersionContent.js.map +1 -1
  45. package/dist/admin/history/components/VersionContent.mjs +25 -4
  46. package/dist/admin/history/components/VersionContent.mjs.map +1 -1
  47. package/dist/admin/history/components/VersionHeader.js +7 -0
  48. package/dist/admin/history/components/VersionHeader.js.map +1 -1
  49. package/dist/admin/history/components/VersionHeader.mjs +8 -1
  50. package/dist/admin/history/components/VersionHeader.mjs.map +1 -1
  51. package/dist/admin/history/components/VersionInputRenderer.js.map +1 -1
  52. package/dist/admin/history/components/VersionInputRenderer.mjs.map +1 -1
  53. package/dist/admin/history/components/VersionsList.js +1 -1
  54. package/dist/admin/history/components/VersionsList.js.map +1 -1
  55. package/dist/admin/history/components/VersionsList.mjs +1 -1
  56. package/dist/admin/history/components/VersionsList.mjs.map +1 -1
  57. package/dist/admin/history/pages/History.js +8 -16
  58. package/dist/admin/history/pages/History.js.map +1 -1
  59. package/dist/admin/history/pages/History.mjs +8 -16
  60. package/dist/admin/history/pages/History.mjs.map +1 -1
  61. package/dist/admin/history/services/historyVersion.js.map +1 -1
  62. package/dist/admin/history/services/historyVersion.mjs.map +1 -1
  63. package/dist/admin/hooks/useContentManagerInitData.js.map +1 -1
  64. package/dist/admin/hooks/useContentManagerInitData.mjs.map +1 -1
  65. package/dist/admin/hooks/useDocumentActions.js +43 -12
  66. package/dist/admin/hooks/useDocumentActions.js.map +1 -1
  67. package/dist/admin/hooks/useDocumentActions.mjs +44 -13
  68. package/dist/admin/hooks/useDocumentActions.mjs.map +1 -1
  69. package/dist/admin/hooks/useDocumentContext.js +57 -0
  70. package/dist/admin/hooks/useDocumentContext.js.map +1 -0
  71. package/dist/admin/hooks/useDocumentContext.mjs +36 -0
  72. package/dist/admin/hooks/useDocumentContext.mjs.map +1 -0
  73. package/dist/admin/index.js +81 -5
  74. package/dist/admin/index.js.map +1 -1
  75. package/dist/admin/index.mjs +80 -3
  76. package/dist/admin/index.mjs.map +1 -1
  77. package/dist/admin/layout.js +28 -33
  78. package/dist/admin/layout.js.map +1 -1
  79. package/dist/admin/layout.mjs +29 -15
  80. package/dist/admin/layout.mjs.map +1 -1
  81. package/dist/admin/pages/EditView/EditViewPage.js +101 -88
  82. package/dist/admin/pages/EditView/EditViewPage.js.map +1 -1
  83. package/dist/admin/pages/EditView/EditViewPage.mjs +103 -90
  84. package/dist/admin/pages/EditView/EditViewPage.mjs.map +1 -1
  85. package/dist/admin/pages/EditView/components/Blocker.js +18 -0
  86. package/dist/admin/pages/EditView/components/Blocker.js.map +1 -0
  87. package/dist/admin/pages/EditView/components/Blocker.mjs +16 -0
  88. package/dist/admin/pages/EditView/components/Blocker.mjs.map +1 -0
  89. package/dist/admin/pages/EditView/components/DocumentActions.js +335 -123
  90. package/dist/admin/pages/EditView/components/DocumentActions.js.map +1 -1
  91. package/dist/admin/pages/EditView/components/DocumentActions.mjs +342 -130
  92. package/dist/admin/pages/EditView/components/DocumentActions.mjs.map +1 -1
  93. package/dist/admin/pages/EditView/components/DocumentStatus.js.map +1 -1
  94. package/dist/admin/pages/EditView/components/DocumentStatus.mjs.map +1 -1
  95. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.js.map +1 -1
  96. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.mjs.map +1 -1
  97. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Blocks/Link.js +66 -2
  98. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Blocks/Link.js.map +1 -1
  99. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Blocks/Link.mjs +66 -2
  100. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Blocks/Link.mjs.map +1 -1
  101. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Blocks/Quote.js.map +1 -1
  102. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Blocks/Quote.mjs.map +1 -1
  103. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.js +12 -15
  104. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.js.map +1 -1
  105. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.mjs +12 -15
  106. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.mjs.map +1 -1
  107. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.js +61 -26
  108. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.js.map +1 -1
  109. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.mjs +63 -28
  110. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.mjs.map +1 -1
  111. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.js +21 -35
  112. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.js.map +1 -1
  113. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.mjs +21 -35
  114. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.mjs.map +1 -1
  115. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/EditorLayout.js +46 -95
  116. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/EditorLayout.js.map +1 -1
  117. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/EditorLayout.mjs +48 -78
  118. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/EditorLayout.mjs.map +1 -1
  119. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Modifiers.js.map +1 -1
  120. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/Modifiers.mjs.map +1 -1
  121. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/utils/links.js +7 -3
  122. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/utils/links.js.map +1 -1
  123. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/utils/links.mjs +7 -3
  124. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/utils/links.mjs.map +1 -1
  125. package/dist/admin/pages/EditView/components/FormInputs/Component/Input.js +2 -2
  126. package/dist/admin/pages/EditView/components/FormInputs/Component/Input.js.map +1 -1
  127. package/dist/admin/pages/EditView/components/FormInputs/Component/Input.mjs +2 -2
  128. package/dist/admin/pages/EditView/components/FormInputs/Component/Input.mjs.map +1 -1
  129. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.js +14 -3
  130. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.js.map +1 -1
  131. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.mjs +15 -4
  132. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.mjs.map +1 -1
  133. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.js +19 -5
  134. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.js.map +1 -1
  135. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.mjs +20 -6
  136. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.mjs.map +1 -1
  137. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/ComponentCategory.js +1 -2
  138. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/ComponentCategory.js.map +1 -1
  139. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/ComponentCategory.mjs +1 -2
  140. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/ComponentCategory.mjs.map +1 -1
  141. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.js +27 -24
  142. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.js.map +1 -1
  143. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.mjs +29 -26
  144. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.mjs.map +1 -1
  145. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/Field.js +2 -3
  146. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/Field.js.map +1 -1
  147. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/Field.mjs +2 -3
  148. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/Field.mjs.map +1 -1
  149. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.js +508 -345
  150. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.js.map +1 -1
  151. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.mjs +508 -347
  152. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.mjs.map +1 -1
  153. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.js +180 -70
  154. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.js.map +1 -1
  155. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.mjs +184 -74
  156. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.mjs.map +1 -1
  157. package/dist/admin/pages/EditView/components/FormInputs/UID.js +13 -10
  158. package/dist/admin/pages/EditView/components/FormInputs/UID.js.map +1 -1
  159. package/dist/admin/pages/EditView/components/FormInputs/UID.mjs +13 -10
  160. package/dist/admin/pages/EditView/components/FormInputs/UID.mjs.map +1 -1
  161. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.js +1 -1
  162. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.js.map +1 -1
  163. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.mjs +1 -1
  164. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.mjs.map +1 -1
  165. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.js +50 -97
  166. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.js.map +1 -1
  167. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.mjs +51 -79
  168. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.mjs.map +1 -1
  169. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/PreviewWysiwyg.js.map +1 -1
  170. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/PreviewWysiwyg.mjs.map +1 -1
  171. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.js +86 -118
  172. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.js.map +1 -1
  173. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.mjs +86 -118
  174. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.mjs.map +1 -1
  175. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygStyles.js.map +1 -1
  176. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygStyles.mjs.map +1 -1
  177. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/utils/utils.js.map +1 -1
  178. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/utils/utils.mjs.map +1 -1
  179. package/dist/admin/pages/EditView/components/FormLayout.js +59 -34
  180. package/dist/admin/pages/EditView/components/FormLayout.js.map +1 -1
  181. package/dist/admin/pages/EditView/components/FormLayout.mjs +60 -34
  182. package/dist/admin/pages/EditView/components/FormLayout.mjs.map +1 -1
  183. package/dist/admin/pages/EditView/components/Header.js +92 -27
  184. package/dist/admin/pages/EditView/components/Header.js.map +1 -1
  185. package/dist/admin/pages/EditView/components/Header.mjs +94 -29
  186. package/dist/admin/pages/EditView/components/Header.mjs.map +1 -1
  187. package/dist/admin/pages/EditView/components/InputRenderer.js +35 -28
  188. package/dist/admin/pages/EditView/components/InputRenderer.js.map +1 -1
  189. package/dist/admin/pages/EditView/components/InputRenderer.mjs +35 -28
  190. package/dist/admin/pages/EditView/components/InputRenderer.mjs.map +1 -1
  191. package/dist/admin/pages/EditView/utils/data.js +128 -0
  192. package/dist/admin/pages/EditView/utils/data.js.map +1 -1
  193. package/dist/admin/pages/EditView/utils/data.mjs +128 -1
  194. package/dist/admin/pages/EditView/utils/data.mjs.map +1 -1
  195. package/dist/admin/pages/ListConfiguration/ListConfigurationPage.js +1 -0
  196. package/dist/admin/pages/ListConfiguration/ListConfigurationPage.js.map +1 -1
  197. package/dist/admin/pages/ListConfiguration/ListConfigurationPage.mjs +1 -0
  198. package/dist/admin/pages/ListConfiguration/ListConfigurationPage.mjs.map +1 -1
  199. package/dist/admin/pages/ListConfiguration/components/DraggableCard.js.map +1 -1
  200. package/dist/admin/pages/ListConfiguration/components/DraggableCard.mjs.map +1 -1
  201. package/dist/admin/pages/ListConfiguration/components/Header.js.map +1 -1
  202. package/dist/admin/pages/ListConfiguration/components/Header.mjs.map +1 -1
  203. package/dist/admin/pages/ListView/ListViewPage.js +225 -132
  204. package/dist/admin/pages/ListView/ListViewPage.js.map +1 -1
  205. package/dist/admin/pages/ListView/ListViewPage.mjs +227 -134
  206. package/dist/admin/pages/ListView/ListViewPage.mjs.map +1 -1
  207. package/dist/admin/pages/ListView/components/AutoCloneFailureModal.js.map +1 -1
  208. package/dist/admin/pages/ListView/components/AutoCloneFailureModal.mjs.map +1 -1
  209. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.js +2 -1
  210. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.js.map +1 -1
  211. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.mjs +2 -1
  212. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.mjs.map +1 -1
  213. package/dist/admin/pages/ListView/components/BulkActions/PublishAction.js +12 -2
  214. package/dist/admin/pages/ListView/components/BulkActions/PublishAction.js.map +1 -1
  215. package/dist/admin/pages/ListView/components/BulkActions/PublishAction.mjs +12 -2
  216. package/dist/admin/pages/ListView/components/BulkActions/PublishAction.mjs.map +1 -1
  217. package/dist/admin/pages/ListView/components/Filters.js +8 -2
  218. package/dist/admin/pages/ListView/components/Filters.js.map +1 -1
  219. package/dist/admin/pages/ListView/components/Filters.mjs +8 -2
  220. package/dist/admin/pages/ListView/components/Filters.mjs.map +1 -1
  221. package/dist/admin/pages/ListView/components/TableActions.js +13 -3
  222. package/dist/admin/pages/ListView/components/TableActions.js.map +1 -1
  223. package/dist/admin/pages/ListView/components/TableActions.mjs +13 -3
  224. package/dist/admin/pages/ListView/components/TableActions.mjs.map +1 -1
  225. package/dist/admin/pages/ListView/components/TableCells/Media.js.map +1 -1
  226. package/dist/admin/pages/ListView/components/TableCells/Media.mjs.map +1 -1
  227. package/dist/admin/pages/ListView/components/ViewSettingsMenu.js +5 -2
  228. package/dist/admin/pages/ListView/components/ViewSettingsMenu.js.map +1 -1
  229. package/dist/admin/pages/ListView/components/ViewSettingsMenu.mjs +5 -2
  230. package/dist/admin/pages/ListView/components/ViewSettingsMenu.mjs.map +1 -1
  231. package/dist/admin/preview/components/InputPopover.js +189 -0
  232. package/dist/admin/preview/components/InputPopover.js.map +1 -0
  233. package/dist/admin/preview/components/InputPopover.mjs +167 -0
  234. package/dist/admin/preview/components/InputPopover.mjs.map +1 -0
  235. package/dist/admin/preview/components/PreviewHeader.js +2 -6
  236. package/dist/admin/preview/components/PreviewHeader.js.map +1 -1
  237. package/dist/admin/preview/components/PreviewHeader.mjs +2 -6
  238. package/dist/admin/preview/components/PreviewHeader.mjs.map +1 -1
  239. package/dist/admin/preview/components/PreviewSidePanel.js +31 -4
  240. package/dist/admin/preview/components/PreviewSidePanel.js.map +1 -1
  241. package/dist/admin/preview/components/PreviewSidePanel.mjs +32 -5
  242. package/dist/admin/preview/components/PreviewSidePanel.mjs.map +1 -1
  243. package/dist/admin/preview/hooks/usePreviewInputManager.js +77 -0
  244. package/dist/admin/preview/hooks/usePreviewInputManager.js.map +1 -0
  245. package/dist/admin/preview/hooks/usePreviewInputManager.mjs +56 -0
  246. package/dist/admin/preview/hooks/usePreviewInputManager.mjs.map +1 -0
  247. package/dist/admin/preview/pages/Preview.js +180 -84
  248. package/dist/admin/preview/pages/Preview.js.map +1 -1
  249. package/dist/admin/preview/pages/Preview.mjs +182 -86
  250. package/dist/admin/preview/pages/Preview.mjs.map +1 -1
  251. package/dist/admin/preview/services/preview.js.map +1 -1
  252. package/dist/admin/preview/services/preview.mjs.map +1 -1
  253. package/dist/admin/preview/utils/constants.js +56 -0
  254. package/dist/admin/preview/utils/constants.js.map +1 -0
  255. package/dist/admin/preview/utils/constants.mjs +52 -0
  256. package/dist/admin/preview/utils/constants.mjs.map +1 -0
  257. package/dist/admin/preview/utils/fieldUtils.js +107 -0
  258. package/dist/admin/preview/utils/fieldUtils.js.map +1 -0
  259. package/dist/admin/preview/utils/fieldUtils.mjs +102 -0
  260. package/dist/admin/preview/utils/fieldUtils.mjs.map +1 -0
  261. package/dist/admin/preview/utils/getSendMessage.js +22 -0
  262. package/dist/admin/preview/utils/getSendMessage.js.map +1 -0
  263. package/dist/admin/preview/utils/getSendMessage.mjs +20 -0
  264. package/dist/admin/preview/utils/getSendMessage.mjs.map +1 -0
  265. package/dist/admin/preview/utils/previewScript.js +534 -0
  266. package/dist/admin/preview/utils/previewScript.js.map +1 -0
  267. package/dist/admin/preview/utils/previewScript.mjs +532 -0
  268. package/dist/admin/preview/utils/previewScript.mjs.map +1 -0
  269. package/dist/admin/router.js.map +1 -1
  270. package/dist/admin/router.mjs.map +1 -1
  271. package/dist/admin/services/api.js +5 -1
  272. package/dist/admin/services/api.js.map +1 -1
  273. package/dist/admin/services/api.mjs +5 -1
  274. package/dist/admin/services/api.mjs.map +1 -1
  275. package/dist/admin/services/documents.js +59 -17
  276. package/dist/admin/services/documents.js.map +1 -1
  277. package/dist/admin/services/documents.mjs +59 -17
  278. package/dist/admin/services/documents.mjs.map +1 -1
  279. package/dist/admin/services/homepage.js +30 -0
  280. package/dist/admin/services/homepage.js.map +1 -0
  281. package/dist/admin/services/homepage.mjs +28 -0
  282. package/dist/admin/services/homepage.mjs.map +1 -0
  283. package/dist/admin/services/relations.js.map +1 -1
  284. package/dist/admin/services/relations.mjs.map +1 -1
  285. package/dist/admin/src/components/ConfigurationForm/Fields.d.ts +6 -4
  286. package/dist/admin/src/components/LeftMenu.d.ts +3 -1
  287. package/dist/admin/src/components/Widgets.d.ts +8 -0
  288. package/dist/admin/src/content-manager.d.ts +0 -3
  289. package/dist/admin/src/exports.d.ts +1 -0
  290. package/dist/admin/src/features/DocumentRBAC.d.ts +1 -1
  291. package/dist/admin/src/history/pages/History.d.ts +1 -1
  292. package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
  293. package/dist/admin/src/hooks/useDocumentActions.d.ts +1 -0
  294. package/dist/admin/src/hooks/useDocumentContext.d.ts +30 -0
  295. package/dist/admin/src/pages/EditView/components/Blocker.d.ts +5 -0
  296. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/EditorLayout.d.ts +2 -2
  297. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/links.d.ts +2 -0
  298. package/dist/admin/src/pages/EditView/components/FormInputs/ComponentContext.d.ts +1 -1
  299. package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/Field.d.ts +1 -1
  300. package/dist/admin/src/pages/EditView/components/FormInputs/Relations/RelationModal.d.ts +73 -7
  301. package/dist/admin/src/pages/EditView/components/FormInputs/Relations/Relations.d.ts +1 -0
  302. package/dist/admin/src/pages/EditView/components/FormInputs/UID.d.ts +1 -0
  303. package/dist/admin/src/pages/EditView/components/FormLayout.d.ts +7 -11
  304. package/dist/admin/src/pages/EditView/components/Header.d.ts +15 -0
  305. package/dist/admin/src/pages/EditView/components/InputRenderer.d.ts +2 -2
  306. package/dist/admin/src/pages/EditView/utils/data.d.ts +19 -1
  307. package/dist/admin/src/preview/components/InputPopover.d.ts +6 -0
  308. package/dist/admin/src/preview/hooks/usePreviewInputManager.d.ts +5 -0
  309. package/dist/admin/src/preview/pages/Preview.d.ts +14 -1
  310. package/dist/admin/src/preview/services/preview.d.ts +1 -1
  311. package/dist/admin/src/preview/utils/constants.d.ts +55 -0
  312. package/dist/admin/src/preview/utils/fieldUtils.d.ts +22 -0
  313. package/dist/admin/src/preview/utils/getSendMessage.d.ts +11 -0
  314. package/dist/admin/src/preview/utils/previewScript.d.ts +24 -0
  315. package/dist/admin/src/services/api.d.ts +1 -1
  316. package/dist/admin/src/services/components.d.ts +2 -2
  317. package/dist/admin/src/services/contentTypes.d.ts +3 -3
  318. package/dist/admin/src/services/documents.d.ts +23 -17
  319. package/dist/admin/src/services/homepage.d.ts +5 -0
  320. package/dist/admin/src/services/init.d.ts +1 -1
  321. package/dist/admin/src/services/relations.d.ts +2 -2
  322. package/dist/admin/src/services/uid.d.ts +3 -3
  323. package/dist/admin/src/utils/api.d.ts +1 -1
  324. package/dist/admin/src/utils/validation.d.ts +1 -0
  325. package/dist/admin/translations/en.json.js +15 -1
  326. package/dist/admin/translations/en.json.js.map +1 -1
  327. package/dist/admin/translations/en.json.mjs +15 -1
  328. package/dist/admin/translations/en.json.mjs.map +1 -1
  329. package/dist/admin/translations/es.json.js +6 -2
  330. package/dist/admin/translations/es.json.js.map +1 -1
  331. package/dist/admin/translations/es.json.mjs +6 -2
  332. package/dist/admin/translations/es.json.mjs.map +1 -1
  333. package/dist/admin/translations/fr.json.js +12 -3
  334. package/dist/admin/translations/fr.json.js.map +1 -1
  335. package/dist/admin/translations/fr.json.mjs +12 -3
  336. package/dist/admin/translations/fr.json.mjs.map +1 -1
  337. package/dist/admin/translations/ru.json.js +235 -226
  338. package/dist/admin/translations/ru.json.js.map +1 -1
  339. package/dist/admin/translations/ru.json.mjs +230 -226
  340. package/dist/admin/translations/ru.json.mjs.map +1 -1
  341. package/dist/admin/utils/api.js +1 -1
  342. package/dist/admin/utils/api.js.map +1 -1
  343. package/dist/admin/utils/api.mjs +1 -1
  344. package/dist/admin/utils/api.mjs.map +1 -1
  345. package/dist/admin/utils/translations.js.map +1 -1
  346. package/dist/admin/utils/translations.mjs.map +1 -1
  347. package/dist/admin/utils/urls.js.map +1 -1
  348. package/dist/admin/utils/urls.mjs.map +1 -1
  349. package/dist/admin/utils/users.js.map +1 -1
  350. package/dist/admin/utils/users.mjs.map +1 -1
  351. package/dist/admin/utils/validation.js +19 -7
  352. package/dist/admin/utils/validation.js.map +1 -1
  353. package/dist/admin/utils/validation.mjs +19 -7
  354. package/dist/admin/utils/validation.mjs.map +1 -1
  355. package/dist/server/controllers/collection-types.js +2 -1
  356. package/dist/server/controllers/collection-types.js.map +1 -1
  357. package/dist/server/controllers/collection-types.mjs +2 -1
  358. package/dist/server/controllers/collection-types.mjs.map +1 -1
  359. package/dist/server/controllers/content-types.js +11 -1
  360. package/dist/server/controllers/content-types.js.map +1 -1
  361. package/dist/server/controllers/content-types.mjs +11 -1
  362. package/dist/server/controllers/content-types.mjs.map +1 -1
  363. package/dist/server/controllers/index.js +3 -1
  364. package/dist/server/controllers/index.js.map +1 -1
  365. package/dist/server/controllers/index.mjs +3 -1
  366. package/dist/server/controllers/index.mjs.map +1 -1
  367. package/dist/server/controllers/relations.js +8 -6
  368. package/dist/server/controllers/relations.js.map +1 -1
  369. package/dist/server/controllers/relations.mjs +8 -6
  370. package/dist/server/controllers/relations.mjs.map +1 -1
  371. package/dist/server/controllers/single-types.js.map +1 -1
  372. package/dist/server/controllers/single-types.mjs.map +1 -1
  373. package/dist/server/controllers/validation/dimensions.js.map +1 -1
  374. package/dist/server/controllers/validation/dimensions.mjs.map +1 -1
  375. package/dist/server/controllers/validation/index.js +14 -2
  376. package/dist/server/controllers/validation/index.js.map +1 -1
  377. package/dist/server/controllers/validation/index.mjs +14 -2
  378. package/dist/server/controllers/validation/index.mjs.map +1 -1
  379. package/dist/server/history/services/lifecycles.js +23 -19
  380. package/dist/server/history/services/lifecycles.js.map +1 -1
  381. package/dist/server/history/services/lifecycles.mjs +23 -19
  382. package/dist/server/history/services/lifecycles.mjs.map +1 -1
  383. package/dist/server/history/utils.js.map +1 -1
  384. package/dist/server/history/utils.mjs.map +1 -1
  385. package/dist/server/homepage/controllers/homepage.js +62 -0
  386. package/dist/server/homepage/controllers/homepage.js.map +1 -0
  387. package/dist/server/homepage/controllers/homepage.mjs +41 -0
  388. package/dist/server/homepage/controllers/homepage.mjs.map +1 -0
  389. package/dist/server/homepage/controllers/index.js +10 -0
  390. package/dist/server/homepage/controllers/index.js.map +1 -0
  391. package/dist/server/homepage/controllers/index.mjs +8 -0
  392. package/dist/server/homepage/controllers/index.mjs.map +1 -0
  393. package/dist/server/homepage/index.js +14 -0
  394. package/dist/server/homepage/index.js.map +1 -0
  395. package/dist/server/homepage/index.mjs +12 -0
  396. package/dist/server/homepage/index.mjs.map +1 -0
  397. package/dist/server/homepage/routes/homepage.js +36 -0
  398. package/dist/server/homepage/routes/homepage.js.map +1 -0
  399. package/dist/server/homepage/routes/homepage.mjs +34 -0
  400. package/dist/server/homepage/routes/homepage.mjs.map +1 -0
  401. package/dist/server/homepage/routes/index.js +13 -0
  402. package/dist/server/homepage/routes/index.js.map +1 -0
  403. package/dist/server/homepage/routes/index.mjs +11 -0
  404. package/dist/server/homepage/routes/index.mjs.map +1 -0
  405. package/dist/server/homepage/services/homepage.js +197 -0
  406. package/dist/server/homepage/services/homepage.js.map +1 -0
  407. package/dist/server/homepage/services/homepage.mjs +195 -0
  408. package/dist/server/homepage/services/homepage.mjs.map +1 -0
  409. package/dist/server/homepage/services/index.js +10 -0
  410. package/dist/server/homepage/services/index.js.map +1 -0
  411. package/dist/server/homepage/services/index.mjs +8 -0
  412. package/dist/server/homepage/services/index.mjs.map +1 -0
  413. package/dist/server/middlewares/routing.js.map +1 -1
  414. package/dist/server/middlewares/routing.mjs.map +1 -1
  415. package/dist/server/preview/services/preview-config.js +11 -32
  416. package/dist/server/preview/services/preview-config.js.map +1 -1
  417. package/dist/server/preview/services/preview-config.mjs +12 -33
  418. package/dist/server/preview/services/preview-config.mjs.map +1 -1
  419. package/dist/server/preview/services/preview.js +4 -1
  420. package/dist/server/preview/services/preview.js.map +1 -1
  421. package/dist/server/preview/services/preview.mjs +4 -1
  422. package/dist/server/preview/services/preview.mjs.map +1 -1
  423. package/dist/server/preview/utils.js.map +1 -1
  424. package/dist/server/preview/utils.mjs.map +1 -1
  425. package/dist/server/routes/index.js +3 -1
  426. package/dist/server/routes/index.js.map +1 -1
  427. package/dist/server/routes/index.mjs +3 -1
  428. package/dist/server/routes/index.mjs.map +1 -1
  429. package/dist/server/services/configuration.js.map +1 -1
  430. package/dist/server/services/configuration.mjs.map +1 -1
  431. package/dist/server/services/data-mapper.js +4 -1
  432. package/dist/server/services/data-mapper.js.map +1 -1
  433. package/dist/server/services/data-mapper.mjs +4 -1
  434. package/dist/server/services/data-mapper.mjs.map +1 -1
  435. package/dist/server/services/document-manager.js +8 -1
  436. package/dist/server/services/document-manager.js.map +1 -1
  437. package/dist/server/services/document-manager.mjs +8 -1
  438. package/dist/server/services/document-manager.mjs.map +1 -1
  439. package/dist/server/services/document-metadata.js +26 -2
  440. package/dist/server/services/document-metadata.js.map +1 -1
  441. package/dist/server/services/document-metadata.mjs +26 -2
  442. package/dist/server/services/document-metadata.mjs.map +1 -1
  443. package/dist/server/services/field-sizes.js.map +1 -1
  444. package/dist/server/services/field-sizes.mjs.map +1 -1
  445. package/dist/server/services/index.js +3 -1
  446. package/dist/server/services/index.js.map +1 -1
  447. package/dist/server/services/index.mjs +3 -1
  448. package/dist/server/services/index.mjs.map +1 -1
  449. package/dist/server/services/uid.js.map +1 -1
  450. package/dist/server/services/uid.mjs.map +1 -1
  451. package/dist/server/services/utils/configuration/attributes.js +1 -1
  452. package/dist/server/services/utils/configuration/attributes.js.map +1 -1
  453. package/dist/server/services/utils/configuration/attributes.mjs +1 -1
  454. package/dist/server/services/utils/configuration/attributes.mjs.map +1 -1
  455. package/dist/server/services/utils/configuration/layouts.js +1 -1
  456. package/dist/server/services/utils/configuration/layouts.js.map +1 -1
  457. package/dist/server/services/utils/configuration/layouts.mjs +1 -1
  458. package/dist/server/services/utils/configuration/layouts.mjs.map +1 -1
  459. package/dist/server/services/utils/configuration/metadatas.js +8 -0
  460. package/dist/server/services/utils/configuration/metadatas.js.map +1 -1
  461. package/dist/server/services/utils/configuration/metadatas.mjs +8 -0
  462. package/dist/server/services/utils/configuration/metadatas.mjs.map +1 -1
  463. package/dist/server/services/utils/populate.js +11 -0
  464. package/dist/server/services/utils/populate.js.map +1 -1
  465. package/dist/server/services/utils/populate.mjs +11 -0
  466. package/dist/server/services/utils/populate.mjs.map +1 -1
  467. package/dist/server/services/utils/store.js.map +1 -1
  468. package/dist/server/services/utils/store.mjs.map +1 -1
  469. package/dist/server/src/controllers/collection-types.d.ts.map +1 -1
  470. package/dist/server/src/controllers/content-types.d.ts.map +1 -1
  471. package/dist/server/src/controllers/index.d.ts.map +1 -1
  472. package/dist/server/src/controllers/relations.d.ts.map +1 -1
  473. package/dist/server/src/controllers/single-types.d.ts.map +1 -1
  474. package/dist/server/src/controllers/validation/index.d.ts +6 -1
  475. package/dist/server/src/controllers/validation/index.d.ts.map +1 -1
  476. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -1
  477. package/dist/server/src/homepage/controllers/homepage.d.ts +8 -0
  478. package/dist/server/src/homepage/controllers/homepage.d.ts.map +1 -0
  479. package/dist/server/src/homepage/controllers/index.d.ts +2 -0
  480. package/dist/server/src/homepage/controllers/index.d.ts.map +1 -0
  481. package/dist/server/src/homepage/index.d.ts +23 -0
  482. package/dist/server/src/homepage/index.d.ts.map +1 -0
  483. package/dist/server/src/homepage/routes/homepage.d.ts +4 -0
  484. package/dist/server/src/homepage/routes/homepage.d.ts.map +1 -0
  485. package/dist/server/src/homepage/routes/index.d.ts +8 -0
  486. package/dist/server/src/homepage/routes/index.d.ts.map +1 -0
  487. package/dist/server/src/homepage/services/homepage.d.ts +14 -0
  488. package/dist/server/src/homepage/services/homepage.d.ts.map +1 -0
  489. package/dist/server/src/homepage/services/index.d.ts +16 -0
  490. package/dist/server/src/homepage/services/index.d.ts.map +1 -0
  491. package/dist/server/src/index.d.ts +15 -0
  492. package/dist/server/src/index.d.ts.map +1 -1
  493. package/dist/server/src/preview/services/index.d.ts +1 -0
  494. package/dist/server/src/preview/services/index.d.ts.map +1 -1
  495. package/dist/server/src/preview/services/preview-config.d.ts +1 -0
  496. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -1
  497. package/dist/server/src/preview/services/preview.d.ts.map +1 -1
  498. package/dist/server/src/preview/utils.d.ts +1 -0
  499. package/dist/server/src/preview/utils.d.ts.map +1 -1
  500. package/dist/server/src/routes/index.d.ts +1 -0
  501. package/dist/server/src/routes/index.d.ts.map +1 -1
  502. package/dist/server/src/services/data-mapper.d.ts +1 -0
  503. package/dist/server/src/services/data-mapper.d.ts.map +1 -1
  504. package/dist/server/src/services/document-manager.d.ts.map +1 -1
  505. package/dist/server/src/services/document-metadata.d.ts.map +1 -1
  506. package/dist/server/src/services/index.d.ts +14 -0
  507. package/dist/server/src/services/index.d.ts.map +1 -1
  508. package/dist/server/src/services/utils/configuration/metadatas.d.ts.map +1 -1
  509. package/dist/server/src/services/utils/populate.d.ts.map +1 -1
  510. package/dist/shared/contracts/collection-types.d.ts +0 -1
  511. package/dist/shared/contracts/collection-types.d.ts.map +1 -1
  512. package/dist/shared/contracts/homepage.d.ts +38 -0
  513. package/dist/shared/contracts/homepage.d.ts.map +1 -0
  514. package/package.json +12 -10
  515. package/dist/admin/features/DocumentContext.js +0 -71
  516. package/dist/admin/features/DocumentContext.js.map +0 -1
  517. package/dist/admin/features/DocumentContext.mjs +0 -49
  518. package/dist/admin/features/DocumentContext.mjs.map +0 -1
  519. package/dist/admin/src/features/DocumentContext.d.ts +0 -53
@@ -1 +1 @@
1
- {"version":3,"file":"FormLayout.js","sources":["../../../../../admin/src/pages/EditView/components/FormLayout.tsx"],"sourcesContent":["import { Box, Flex, Grid } from '@strapi/design-system';\nimport { useIntl } from 'react-intl';\nimport { styled } from 'styled-components';\n\nimport { EditLayout } from '../../../hooks/useDocumentLayout';\n\nimport { InputRenderer } from './InputRenderer';\n\nimport type { UseDocument } from '../../../hooks/useDocument';\n\nexport const RESPONSIVE_CONTAINER_BREAKPOINTS = {\n sm: '27.5rem', // 440px\n};\n\nexport const ResponsiveGridRoot = styled(Grid.Root)`\n container-type: inline-size;\n`;\n\nexport const ResponsiveGridItem =\n /**\n * TODO:\n * JSDOM cannot handle container queries.\n * This is a temporary workaround so that tests do not fail in the CI when jestdom throws an error\n * for failing to parse the stylesheet.\n */\n process.env.NODE_ENV !== 'test'\n ? styled(Grid.Item)<{ col: number }>`\n grid-column: span 12;\n @container (min-width: ${RESPONSIVE_CONTAINER_BREAKPOINTS.sm}) {\n ${({ col }) => col && `grid-column: span ${col};`}\n }\n `\n : styled(Grid.Item)<{ col: number }>`\n grid-column: span 12;\n `;\n\ninterface FormLayoutProps extends Pick<EditLayout, 'layout'> {\n hasBackground?: boolean;\n model?: string;\n document: ReturnType<UseDocument>;\n}\n\nconst FormLayout = ({ layout, document, hasBackground = true }: FormLayoutProps) => {\n const { formatMessage } = useIntl();\n const model = document.schema?.modelName;\n\n return (\n <Flex direction=\"column\" alignItems=\"stretch\" gap={6}>\n {layout.map((panel, index) => {\n if (panel.some((row) => row.some((field) => field.type === 'dynamiczone'))) {\n const [row] = panel;\n const [field] = row;\n\n const fieldWithTranslatedLabel = {\n ...field,\n label: formatMessage({\n id: `content-manager.content-types.${model}.${field.name}`,\n defaultMessage: field.label,\n }),\n };\n\n return (\n <Grid.Root key={field.name} gap={4}>\n <Grid.Item col={12} s={12} xs={12} direction=\"column\" alignItems=\"stretch\">\n <InputRenderer {...fieldWithTranslatedLabel} document={document} />\n </Grid.Item>\n </Grid.Root>\n );\n }\n\n return (\n <Box\n key={index}\n {...(hasBackground && {\n padding: 6,\n borderColor: 'neutral150',\n background: 'neutral0',\n hasRadius: true,\n shadow: 'tableShadow',\n })}\n >\n <Flex direction=\"column\" alignItems=\"stretch\" gap={6}>\n {panel.map((row, gridRowIndex) => (\n <ResponsiveGridRoot key={gridRowIndex} gap={4}>\n {row.map(({ size, ...field }) => {\n const fieldWithTranslatedLabel = {\n ...field,\n label: formatMessage({\n id: `content-manager.content-types.${model}.${field.name}`,\n defaultMessage: field.label,\n }),\n };\n return (\n <ResponsiveGridItem\n col={size}\n key={field.name}\n s={12}\n xs={12}\n direction=\"column\"\n alignItems=\"stretch\"\n >\n <InputRenderer {...fieldWithTranslatedLabel} document={document} />\n </ResponsiveGridItem>\n );\n })}\n </ResponsiveGridRoot>\n ))}\n </Flex>\n </Box>\n );\n })}\n </Flex>\n );\n};\n\nexport { FormLayout, FormLayoutProps };\n"],"names":["RESPONSIVE_CONTAINER_BREAKPOINTS","sm","ResponsiveGridRoot","styled","Grid","Root","ResponsiveGridItem","process","env","NODE_ENV","Item","col","FormLayout","layout","document","hasBackground","formatMessage","useIntl","model","schema","modelName","_jsx","Flex","direction","alignItems","gap","map","panel","index","some","row","field","type","fieldWithTranslatedLabel","label","id","name","defaultMessage","s","xs","InputRenderer","Box","padding","borderColor","background","hasRadius","shadow","gridRowIndex","size"],"mappings":"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"}
1
+ {"version":3,"file":"FormLayout.js","sources":["../../../../../admin/src/pages/EditView/components/FormLayout.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { useForm, createRulesEngine } from '@strapi/admin/strapi-admin';\nimport { Box, BoxProps, Flex, Grid } from '@strapi/design-system';\nimport { useIntl } from 'react-intl';\nimport { styled } from 'styled-components';\n\nimport { EditLayout } from '../../../hooks/useDocumentLayout';\n\nimport { InputRenderer } from './InputRenderer';\n\nimport type { UseDocument } from '../../../hooks/useDocument';\n\nexport const ResponsiveGridRoot = styled(Grid.Root)`\n container-type: inline-size;\n`;\n\nexport const ResponsiveGridItem =\n /**\n * TODO:\n * JSDOM cannot handle container queries.\n * This is a temporary workaround so that tests do not fail in the CI when jestdom throws an error\n * for failing to parse the stylesheet.\n */\n process.env.NODE_ENV !== 'test'\n ? styled(Grid.Item)<{ col: number }>`\n grid-column: span 12;\n ${({ theme }) => theme.breakpoints.medium} {\n ${({ col }) => col && `grid-column: span ${col};`}\n }\n `\n : styled(Grid.Item)<{ col: number }>`\n grid-column: span 12;\n `;\n\nconst panelStyles = {\n padding: {\n initial: 4,\n medium: 6,\n },\n borderColor: 'neutral150',\n background: 'neutral0',\n hasRadius: true,\n shadow: 'tableShadow',\n} satisfies BoxProps;\n\ninterface FormLayoutProps extends Pick<EditLayout, 'layout'> {\n hasBackground?: boolean;\n document: ReturnType<UseDocument>;\n}\n\nconst FormLayout = ({ layout, document, hasBackground = true }: FormLayoutProps) => {\n const { formatMessage } = useIntl();\n const modelUid = document.schema?.uid;\n const fieldValues = useForm('Fields', (state) => state.values);\n const rulesEngine = createRulesEngine();\n\n const getLabel = (name: string, label: string) => {\n return formatMessage({\n id: `content-manager.content-types.${modelUid}.${name}`,\n defaultMessage: label,\n });\n };\n\n return (\n <Flex\n direction=\"column\"\n alignItems=\"stretch\"\n gap={{\n initial: 4,\n large: 6,\n }}\n >\n {layout.map((panel, index) => {\n if (panel.some((row) => row.some((field) => field.type === 'dynamiczone'))) {\n const [row] = panel;\n const [field] = row;\n const attribute = document.schema?.attributes[field.name];\n const condition = attribute?.conditions?.visible;\n\n if (condition) {\n const isVisible = rulesEngine.evaluate(condition, fieldValues);\n if (!isVisible) {\n return null; // Skip rendering the dynamic zone if the condition is not met\n }\n }\n\n return (\n <Grid.Root key={field.name} gap={4}>\n <Grid.Item col={12} s={12} xs={12} direction=\"column\" alignItems=\"stretch\">\n <InputRenderer\n {...field}\n label={getLabel(field.name, field.label)}\n document={document}\n />\n </Grid.Item>\n </Grid.Root>\n );\n }\n\n return (\n <Box key={index} {...(hasBackground && panelStyles)}>\n <Flex\n direction=\"column\"\n alignItems=\"stretch\"\n gap={{\n initial: 4,\n large: 6,\n }}\n >\n {panel.map((row, gridRowIndex) => {\n const visibleFields = row.filter(({ name }) => {\n const attribute = document.schema?.attributes[name];\n const condition = attribute?.conditions?.visible;\n\n if (condition) {\n return rulesEngine.evaluate(condition, fieldValues);\n }\n\n return true;\n });\n\n if (visibleFields.length === 0) {\n return null; // Skip rendering the entire grid row\n }\n\n return (\n <ResponsiveGridRoot key={gridRowIndex} gap={4}>\n {visibleFields.map(({ size, ...field }) => {\n return (\n <ResponsiveGridItem\n col={size}\n key={field.name}\n s={12}\n xs={12}\n direction=\"column\"\n alignItems=\"stretch\"\n >\n <InputRenderer\n {...field}\n label={getLabel(field.name, field.label)}\n document={document}\n />\n </ResponsiveGridItem>\n );\n })}\n </ResponsiveGridRoot>\n );\n })}\n </Flex>\n </Box>\n );\n })}\n </Flex>\n );\n};\n\nexport { FormLayout, FormLayoutProps };\n"],"names":["ResponsiveGridRoot","styled","Grid","Root","ResponsiveGridItem","process","env","NODE_ENV","Item","theme","breakpoints","medium","col","panelStyles","padding","initial","borderColor","background","hasRadius","shadow","FormLayout","layout","document","hasBackground","formatMessage","useIntl","modelUid","schema","uid","fieldValues","useForm","state","values","rulesEngine","createRulesEngine","getLabel","name","label","id","defaultMessage","_jsx","Flex","direction","alignItems","gap","large","map","panel","index","some","row","field","type","attribute","attributes","condition","conditions","visible","isVisible","evaluate","s","xs","InputRenderer","Box","gridRowIndex","visibleFields","filter","length","size"],"mappings":"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"}
@@ -1,12 +1,11 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
+ import 'react';
3
+ import { useForm, createRulesEngine } from '@strapi/admin/strapi-admin';
2
4
  import { Grid, Flex, Box } from '@strapi/design-system';
3
5
  import { useIntl } from 'react-intl';
4
6
  import { styled } from 'styled-components';
5
7
  import { InputRenderer as MemoizedInputRenderer } from './InputRenderer.mjs';
6
8
 
7
- const RESPONSIVE_CONTAINER_BREAKPOINTS = {
8
- sm: '27.5rem'
9
- };
10
9
  const ResponsiveGridRoot = styled(Grid.Root)`
11
10
  container-type: inline-size;
12
11
  `;
@@ -17,30 +16,52 @@ const ResponsiveGridItem = /**
17
16
  * for failing to parse the stylesheet.
18
17
  */ process.env.NODE_ENV !== 'test' ? styled(Grid.Item)`
19
18
  grid-column: span 12;
20
- @container (min-width: ${RESPONSIVE_CONTAINER_BREAKPOINTS.sm}) {
19
+ ${({ theme })=>theme.breakpoints.medium} {
21
20
  ${({ col })=>col && `grid-column: span ${col};`}
22
21
  }
23
22
  ` : styled(Grid.Item)`
24
23
  grid-column: span 12;
25
24
  `;
25
+ const panelStyles = {
26
+ padding: {
27
+ initial: 4,
28
+ medium: 6
29
+ },
30
+ borderColor: 'neutral150',
31
+ background: 'neutral0',
32
+ hasRadius: true,
33
+ shadow: 'tableShadow'
34
+ };
26
35
  const FormLayout = ({ layout, document, hasBackground = true })=>{
27
36
  const { formatMessage } = useIntl();
28
- const model = document.schema?.modelName;
37
+ const modelUid = document.schema?.uid;
38
+ const fieldValues = useForm('Fields', (state)=>state.values);
39
+ const rulesEngine = createRulesEngine();
40
+ const getLabel = (name, label)=>{
41
+ return formatMessage({
42
+ id: `content-manager.content-types.${modelUid}.${name}`,
43
+ defaultMessage: label
44
+ });
45
+ };
29
46
  return /*#__PURE__*/ jsx(Flex, {
30
47
  direction: "column",
31
48
  alignItems: "stretch",
32
- gap: 6,
49
+ gap: {
50
+ initial: 4,
51
+ large: 6
52
+ },
33
53
  children: layout.map((panel, index)=>{
34
54
  if (panel.some((row)=>row.some((field)=>field.type === 'dynamiczone'))) {
35
55
  const [row] = panel;
36
56
  const [field] = row;
37
- const fieldWithTranslatedLabel = {
38
- ...field,
39
- label: formatMessage({
40
- id: `content-manager.content-types.${model}.${field.name}`,
41
- defaultMessage: field.label
42
- })
43
- };
57
+ const attribute = document.schema?.attributes[field.name];
58
+ const condition = attribute?.conditions?.visible;
59
+ if (condition) {
60
+ const isVisible = rulesEngine.evaluate(condition, fieldValues);
61
+ if (!isVisible) {
62
+ return null; // Skip rendering the dynamic zone if the condition is not met
63
+ }
64
+ }
44
65
  return /*#__PURE__*/ jsx(Grid.Root, {
45
66
  gap: 4,
46
67
  children: /*#__PURE__*/ jsx(Grid.Item, {
@@ -50,34 +71,37 @@ const FormLayout = ({ layout, document, hasBackground = true })=>{
50
71
  direction: "column",
51
72
  alignItems: "stretch",
52
73
  children: /*#__PURE__*/ jsx(MemoizedInputRenderer, {
53
- ...fieldWithTranslatedLabel,
74
+ ...field,
75
+ label: getLabel(field.name, field.label),
54
76
  document: document
55
77
  })
56
78
  })
57
79
  }, field.name);
58
80
  }
59
81
  return /*#__PURE__*/ jsx(Box, {
60
- ...hasBackground && {
61
- padding: 6,
62
- borderColor: 'neutral150',
63
- background: 'neutral0',
64
- hasRadius: true,
65
- shadow: 'tableShadow'
66
- },
82
+ ...hasBackground && panelStyles,
67
83
  children: /*#__PURE__*/ jsx(Flex, {
68
84
  direction: "column",
69
85
  alignItems: "stretch",
70
- gap: 6,
71
- children: panel.map((row, gridRowIndex)=>/*#__PURE__*/ jsx(ResponsiveGridRoot, {
86
+ gap: {
87
+ initial: 4,
88
+ large: 6
89
+ },
90
+ children: panel.map((row, gridRowIndex)=>{
91
+ const visibleFields = row.filter(({ name })=>{
92
+ const attribute = document.schema?.attributes[name];
93
+ const condition = attribute?.conditions?.visible;
94
+ if (condition) {
95
+ return rulesEngine.evaluate(condition, fieldValues);
96
+ }
97
+ return true;
98
+ });
99
+ if (visibleFields.length === 0) {
100
+ return null; // Skip rendering the entire grid row
101
+ }
102
+ return /*#__PURE__*/ jsx(ResponsiveGridRoot, {
72
103
  gap: 4,
73
- children: row.map(({ size, ...field })=>{
74
- const fieldWithTranslatedLabel = {
75
- ...field,
76
- label: formatMessage({
77
- id: `content-manager.content-types.${model}.${field.name}`,
78
- defaultMessage: field.label
79
- })
80
- };
104
+ children: visibleFields.map(({ size, ...field })=>{
81
105
  return /*#__PURE__*/ jsx(ResponsiveGridItem, {
82
106
  col: size,
83
107
  s: 12,
@@ -85,17 +109,19 @@ const FormLayout = ({ layout, document, hasBackground = true })=>{
85
109
  direction: "column",
86
110
  alignItems: "stretch",
87
111
  children: /*#__PURE__*/ jsx(MemoizedInputRenderer, {
88
- ...fieldWithTranslatedLabel,
112
+ ...field,
113
+ label: getLabel(field.name, field.label),
89
114
  document: document
90
115
  })
91
116
  }, field.name);
92
117
  })
93
- }, gridRowIndex))
118
+ }, gridRowIndex);
119
+ })
94
120
  })
95
121
  }, index);
96
122
  })
97
123
  });
98
124
  };
99
125
 
100
- export { FormLayout, RESPONSIVE_CONTAINER_BREAKPOINTS, ResponsiveGridItem, ResponsiveGridRoot };
126
+ export { FormLayout, ResponsiveGridItem, ResponsiveGridRoot };
101
127
  //# sourceMappingURL=FormLayout.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"FormLayout.mjs","sources":["../../../../../admin/src/pages/EditView/components/FormLayout.tsx"],"sourcesContent":["import { Box, Flex, Grid } from '@strapi/design-system';\nimport { useIntl } from 'react-intl';\nimport { styled } from 'styled-components';\n\nimport { EditLayout } from '../../../hooks/useDocumentLayout';\n\nimport { InputRenderer } from './InputRenderer';\n\nimport type { UseDocument } from '../../../hooks/useDocument';\n\nexport const RESPONSIVE_CONTAINER_BREAKPOINTS = {\n sm: '27.5rem', // 440px\n};\n\nexport const ResponsiveGridRoot = styled(Grid.Root)`\n container-type: inline-size;\n`;\n\nexport const ResponsiveGridItem =\n /**\n * TODO:\n * JSDOM cannot handle container queries.\n * This is a temporary workaround so that tests do not fail in the CI when jestdom throws an error\n * for failing to parse the stylesheet.\n */\n process.env.NODE_ENV !== 'test'\n ? styled(Grid.Item)<{ col: number }>`\n grid-column: span 12;\n @container (min-width: ${RESPONSIVE_CONTAINER_BREAKPOINTS.sm}) {\n ${({ col }) => col && `grid-column: span ${col};`}\n }\n `\n : styled(Grid.Item)<{ col: number }>`\n grid-column: span 12;\n `;\n\ninterface FormLayoutProps extends Pick<EditLayout, 'layout'> {\n hasBackground?: boolean;\n model?: string;\n document: ReturnType<UseDocument>;\n}\n\nconst FormLayout = ({ layout, document, hasBackground = true }: FormLayoutProps) => {\n const { formatMessage } = useIntl();\n const model = document.schema?.modelName;\n\n return (\n <Flex direction=\"column\" alignItems=\"stretch\" gap={6}>\n {layout.map((panel, index) => {\n if (panel.some((row) => row.some((field) => field.type === 'dynamiczone'))) {\n const [row] = panel;\n const [field] = row;\n\n const fieldWithTranslatedLabel = {\n ...field,\n label: formatMessage({\n id: `content-manager.content-types.${model}.${field.name}`,\n defaultMessage: field.label,\n }),\n };\n\n return (\n <Grid.Root key={field.name} gap={4}>\n <Grid.Item col={12} s={12} xs={12} direction=\"column\" alignItems=\"stretch\">\n <InputRenderer {...fieldWithTranslatedLabel} document={document} />\n </Grid.Item>\n </Grid.Root>\n );\n }\n\n return (\n <Box\n key={index}\n {...(hasBackground && {\n padding: 6,\n borderColor: 'neutral150',\n background: 'neutral0',\n hasRadius: true,\n shadow: 'tableShadow',\n })}\n >\n <Flex direction=\"column\" alignItems=\"stretch\" gap={6}>\n {panel.map((row, gridRowIndex) => (\n <ResponsiveGridRoot key={gridRowIndex} gap={4}>\n {row.map(({ size, ...field }) => {\n const fieldWithTranslatedLabel = {\n ...field,\n label: formatMessage({\n id: `content-manager.content-types.${model}.${field.name}`,\n defaultMessage: field.label,\n }),\n };\n return (\n <ResponsiveGridItem\n col={size}\n key={field.name}\n s={12}\n xs={12}\n direction=\"column\"\n alignItems=\"stretch\"\n >\n <InputRenderer {...fieldWithTranslatedLabel} document={document} />\n </ResponsiveGridItem>\n );\n })}\n </ResponsiveGridRoot>\n ))}\n </Flex>\n </Box>\n );\n })}\n </Flex>\n );\n};\n\nexport { FormLayout, FormLayoutProps };\n"],"names":["RESPONSIVE_CONTAINER_BREAKPOINTS","sm","ResponsiveGridRoot","styled","Grid","Root","ResponsiveGridItem","process","env","NODE_ENV","Item","col","FormLayout","layout","document","hasBackground","formatMessage","useIntl","model","schema","modelName","_jsx","Flex","direction","alignItems","gap","map","panel","index","some","row","field","type","fieldWithTranslatedLabel","label","id","name","defaultMessage","s","xs","InputRenderer","Box","padding","borderColor","background","hasRadius","shadow","gridRowIndex","size"],"mappings":"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"}
1
+ {"version":3,"file":"FormLayout.mjs","sources":["../../../../../admin/src/pages/EditView/components/FormLayout.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { useForm, createRulesEngine } from '@strapi/admin/strapi-admin';\nimport { Box, BoxProps, Flex, Grid } from '@strapi/design-system';\nimport { useIntl } from 'react-intl';\nimport { styled } from 'styled-components';\n\nimport { EditLayout } from '../../../hooks/useDocumentLayout';\n\nimport { InputRenderer } from './InputRenderer';\n\nimport type { UseDocument } from '../../../hooks/useDocument';\n\nexport const ResponsiveGridRoot = styled(Grid.Root)`\n container-type: inline-size;\n`;\n\nexport const ResponsiveGridItem =\n /**\n * TODO:\n * JSDOM cannot handle container queries.\n * This is a temporary workaround so that tests do not fail in the CI when jestdom throws an error\n * for failing to parse the stylesheet.\n */\n process.env.NODE_ENV !== 'test'\n ? styled(Grid.Item)<{ col: number }>`\n grid-column: span 12;\n ${({ theme }) => theme.breakpoints.medium} {\n ${({ col }) => col && `grid-column: span ${col};`}\n }\n `\n : styled(Grid.Item)<{ col: number }>`\n grid-column: span 12;\n `;\n\nconst panelStyles = {\n padding: {\n initial: 4,\n medium: 6,\n },\n borderColor: 'neutral150',\n background: 'neutral0',\n hasRadius: true,\n shadow: 'tableShadow',\n} satisfies BoxProps;\n\ninterface FormLayoutProps extends Pick<EditLayout, 'layout'> {\n hasBackground?: boolean;\n document: ReturnType<UseDocument>;\n}\n\nconst FormLayout = ({ layout, document, hasBackground = true }: FormLayoutProps) => {\n const { formatMessage } = useIntl();\n const modelUid = document.schema?.uid;\n const fieldValues = useForm('Fields', (state) => state.values);\n const rulesEngine = createRulesEngine();\n\n const getLabel = (name: string, label: string) => {\n return formatMessage({\n id: `content-manager.content-types.${modelUid}.${name}`,\n defaultMessage: label,\n });\n };\n\n return (\n <Flex\n direction=\"column\"\n alignItems=\"stretch\"\n gap={{\n initial: 4,\n large: 6,\n }}\n >\n {layout.map((panel, index) => {\n if (panel.some((row) => row.some((field) => field.type === 'dynamiczone'))) {\n const [row] = panel;\n const [field] = row;\n const attribute = document.schema?.attributes[field.name];\n const condition = attribute?.conditions?.visible;\n\n if (condition) {\n const isVisible = rulesEngine.evaluate(condition, fieldValues);\n if (!isVisible) {\n return null; // Skip rendering the dynamic zone if the condition is not met\n }\n }\n\n return (\n <Grid.Root key={field.name} gap={4}>\n <Grid.Item col={12} s={12} xs={12} direction=\"column\" alignItems=\"stretch\">\n <InputRenderer\n {...field}\n label={getLabel(field.name, field.label)}\n document={document}\n />\n </Grid.Item>\n </Grid.Root>\n );\n }\n\n return (\n <Box key={index} {...(hasBackground && panelStyles)}>\n <Flex\n direction=\"column\"\n alignItems=\"stretch\"\n gap={{\n initial: 4,\n large: 6,\n }}\n >\n {panel.map((row, gridRowIndex) => {\n const visibleFields = row.filter(({ name }) => {\n const attribute = document.schema?.attributes[name];\n const condition = attribute?.conditions?.visible;\n\n if (condition) {\n return rulesEngine.evaluate(condition, fieldValues);\n }\n\n return true;\n });\n\n if (visibleFields.length === 0) {\n return null; // Skip rendering the entire grid row\n }\n\n return (\n <ResponsiveGridRoot key={gridRowIndex} gap={4}>\n {visibleFields.map(({ size, ...field }) => {\n return (\n <ResponsiveGridItem\n col={size}\n key={field.name}\n s={12}\n xs={12}\n direction=\"column\"\n alignItems=\"stretch\"\n >\n <InputRenderer\n {...field}\n label={getLabel(field.name, field.label)}\n document={document}\n />\n </ResponsiveGridItem>\n );\n })}\n </ResponsiveGridRoot>\n );\n })}\n </Flex>\n </Box>\n );\n })}\n </Flex>\n );\n};\n\nexport { FormLayout, FormLayoutProps };\n"],"names":["ResponsiveGridRoot","styled","Grid","Root","ResponsiveGridItem","process","env","NODE_ENV","Item","theme","breakpoints","medium","col","panelStyles","padding","initial","borderColor","background","hasRadius","shadow","FormLayout","layout","document","hasBackground","formatMessage","useIntl","modelUid","schema","uid","fieldValues","useForm","state","values","rulesEngine","createRulesEngine","getLabel","name","label","id","defaultMessage","_jsx","Flex","direction","alignItems","gap","large","map","panel","index","some","row","field","type","attribute","attributes","condition","conditions","visible","isVisible","evaluate","s","xs","InputRenderer","Box","gridRowIndex","visibleFields","filter","length","size"],"mappings":"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"}
@@ -48,8 +48,14 @@ const Header = ({ isCreating, status, title: documentTitle = 'Untitled' })=>{
48
48
  return /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
49
49
  direction: "column",
50
50
  alignItems: "flex-start",
51
- paddingTop: 6,
52
- paddingBottom: 4,
51
+ paddingTop: {
52
+ initial: 4,
53
+ large: 6
54
+ },
55
+ paddingBottom: {
56
+ initial: 0,
57
+ large: 4
58
+ },
53
59
  gap: 2,
54
60
  children: [
55
61
  /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.BackButton, {
@@ -58,8 +64,15 @@ const Header = ({ isCreating, status, title: documentTitle = 'Untitled' })=>{
58
64
  /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
59
65
  width: "100%",
60
66
  justifyContent: "space-between",
61
- gap: "80px",
67
+ gap: {
68
+ initial: 2,
69
+ medium: '8rem'
70
+ },
62
71
  alignItems: "flex-start",
72
+ direction: {
73
+ initial: 'column',
74
+ medium: 'row'
75
+ },
63
76
  children: [
64
77
  /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
65
78
  variant: "alpha",
@@ -276,34 +289,84 @@ const HeaderActions = ({ actions })=>{
276
289
  onChange: action.onSelect,
277
290
  "aria-label": action.label,
278
291
  ...action,
279
- children: action.options.map(({ label, ...option })=>/*#__PURE__*/ jsxRuntime.jsx(designSystem.SingleSelectOption, {
292
+ children: action.options.map(({ label, ...option })=>{
293
+ if (option._render) {
294
+ return option._render();
295
+ }
296
+ return /*#__PURE__*/ jsxRuntime.jsx(designSystem.SingleSelectOption, {
280
297
  ...option,
281
298
  children: label
282
- }, option.value))
299
+ }, option.value);
300
+ })
301
+ }, action.id);
302
+ } else if (action._status) {
303
+ return /*#__PURE__*/ jsxRuntime.jsx(HeaderActionStatus, {
304
+ tooltip: action._status?.tooltip,
305
+ children: action._status.message
283
306
  }, action.id);
284
307
  } else {
285
- if (action.type === 'icon') {
286
- return /*#__PURE__*/ jsxRuntime.jsxs(React__namespace.Fragment, {
287
- children: [
288
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.IconButton, {
289
- disabled: action.disabled,
290
- label: action.label,
291
- size: "S",
292
- onClick: handleClick(action),
293
- children: action.icon
294
- }),
295
- action.dialog ? /*#__PURE__*/ jsxRuntime.jsx(HeaderActionDialog, {
296
- ...action.dialog,
297
- isOpen: dialogId === action.id,
298
- onClose: handleClose
299
- }) : null
300
- ]
301
- }, action.id);
302
- }
308
+ return /*#__PURE__*/ jsxRuntime.jsxs(React__namespace.Fragment, {
309
+ children: [
310
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.IconButton, {
311
+ disabled: action.disabled,
312
+ label: action.label,
313
+ size: "S",
314
+ onClick: handleClick(action),
315
+ children: action.icon
316
+ }),
317
+ action.dialog ? /*#__PURE__*/ jsxRuntime.jsx(HeaderActionDialog, {
318
+ ...action.dialog,
319
+ isOpen: dialogId === action.id,
320
+ onClose: handleClose
321
+ }) : null
322
+ ]
323
+ }, action.id);
303
324
  }
304
325
  })
305
326
  });
306
327
  };
328
+ const HeaderActionStatus = ({ tooltip, children })=>{
329
+ const [open, setOpen] = React__namespace.useState(false);
330
+ // Debounce the open/close so the user can hover over the popover content before it closes
331
+ const debouncedOpen = strapiAdmin.useDebounce(open, 100);
332
+ const handleMouseEnter = ()=>{
333
+ if (tooltip) {
334
+ setOpen(true);
335
+ }
336
+ };
337
+ const handleMouseLeave = ()=>{
338
+ if (tooltip) {
339
+ setOpen(false);
340
+ }
341
+ };
342
+ return /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Popover.Root, {
343
+ open: debouncedOpen,
344
+ onOpenChange: setOpen,
345
+ children: [
346
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Popover.Anchor, {
347
+ style: {
348
+ alignSelf: 'stretch'
349
+ },
350
+ onMouseEnter: handleMouseEnter,
351
+ onMouseLeave: handleMouseLeave,
352
+ "aria-describedby": "document-header-action-status",
353
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
354
+ height: "100%",
355
+ children: children
356
+ })
357
+ }),
358
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Popover.Content, {
359
+ role: "tooltip",
360
+ id: "document-header-action-status",
361
+ side: "bottom",
362
+ align: "center",
363
+ onMouseEnter: handleMouseEnter,
364
+ onMouseLeave: handleMouseLeave,
365
+ children: tooltip
366
+ })
367
+ ]
368
+ });
369
+ };
307
370
  const HeaderActionDialog = ({ onClose, onCancel, title, content: Content, isOpen })=>{
308
371
  const handleClose = async ()=>{
309
372
  if (onCancel) {
@@ -331,7 +394,8 @@ const HeaderActionDialog = ({ onClose, onCancel, title, content: Content, isOpen
331
394
  * -----------------------------------------------------------------------------------------------*/ const ConfigureTheViewAction = ({ collectionType, model })=>{
332
395
  const navigate = reactRouterDom.useNavigate();
333
396
  const { formatMessage } = reactIntl.useIntl();
334
- return {
397
+ const isDesktop = strapiAdmin.useIsDesktop();
398
+ return isDesktop ? {
335
399
  label: formatMessage({
336
400
  id: 'app.links.configure-view',
337
401
  defaultMessage: 'Configure the view'
@@ -341,14 +405,15 @@ const HeaderActionDialog = ({ onClose, onCancel, title, content: Content, isOpen
341
405
  navigate(`../${collectionType}/${model}/configurations/edit`);
342
406
  },
343
407
  position: 'header'
344
- };
408
+ } : null;
345
409
  };
346
410
  ConfigureTheViewAction.type = 'configure-the-view';
347
411
  ConfigureTheViewAction.position = 'header';
348
412
  const EditTheModelAction = ({ model })=>{
349
413
  const navigate = reactRouterDom.useNavigate();
350
414
  const { formatMessage } = reactIntl.useIntl();
351
- return {
415
+ const isDesktop = strapiAdmin.useIsDesktop();
416
+ return isDesktop ? {
352
417
  label: formatMessage({
353
418
  id: 'content-manager.link-to-ctb',
354
419
  defaultMessage: 'Edit the model'
@@ -358,7 +423,7 @@ const EditTheModelAction = ({ model })=>{
358
423
  navigate(`/plugins/content-type-builder/content-types/${model}`);
359
424
  },
360
425
  position: 'header'
361
- };
426
+ } : null;
362
427
  };
363
428
  EditTheModelAction.type = 'edit-the-model';
364
429
  EditTheModelAction.position = 'header';