@strapi/content-manager 0.0.0-experimental.c72b48da735f44a3ccafb7a6dc9ba5213f3844db → 0.0.0-experimental.ca5f02ef2ec166e219546983049c0543bed92f8d

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 (286) hide show
  1. package/dist/admin/components/ConfigurationForm/Fields.js +300 -204
  2. package/dist/admin/components/ConfigurationForm/Fields.js.map +1 -1
  3. package/dist/admin/components/ConfigurationForm/Fields.mjs +304 -209
  4. package/dist/admin/components/ConfigurationForm/Fields.mjs.map +1 -1
  5. package/dist/admin/components/LeftMenu.js +34 -30
  6. package/dist/admin/components/LeftMenu.js.map +1 -1
  7. package/dist/admin/components/LeftMenu.mjs +36 -32
  8. package/dist/admin/components/LeftMenu.mjs.map +1 -1
  9. package/dist/admin/components/Widgets.js +253 -0
  10. package/dist/admin/components/Widgets.js.map +1 -1
  11. package/dist/admin/components/Widgets.mjs +236 -3
  12. package/dist/admin/components/Widgets.mjs.map +1 -1
  13. package/dist/admin/history/components/VersionContent.js +24 -3
  14. package/dist/admin/history/components/VersionContent.js.map +1 -1
  15. package/dist/admin/history/components/VersionContent.mjs +25 -4
  16. package/dist/admin/history/components/VersionContent.mjs.map +1 -1
  17. package/dist/admin/history/components/VersionHeader.js +6 -0
  18. package/dist/admin/history/components/VersionHeader.js.map +1 -1
  19. package/dist/admin/history/components/VersionHeader.mjs +7 -1
  20. package/dist/admin/history/components/VersionHeader.mjs.map +1 -1
  21. package/dist/admin/hooks/useDocumentActions.js +7 -6
  22. package/dist/admin/hooks/useDocumentActions.js.map +1 -1
  23. package/dist/admin/hooks/useDocumentActions.mjs +8 -7
  24. package/dist/admin/hooks/useDocumentActions.mjs.map +1 -1
  25. package/dist/admin/index.js +47 -8
  26. package/dist/admin/index.js.map +1 -1
  27. package/dist/admin/index.mjs +47 -9
  28. package/dist/admin/index.mjs.map +1 -1
  29. package/dist/admin/layout.js +1 -27
  30. package/dist/admin/layout.js.map +1 -1
  31. package/dist/admin/layout.mjs +2 -9
  32. package/dist/admin/layout.mjs.map +1 -1
  33. package/dist/admin/pages/EditView/EditViewPage.js +90 -74
  34. package/dist/admin/pages/EditView/EditViewPage.js.map +1 -1
  35. package/dist/admin/pages/EditView/EditViewPage.mjs +92 -76
  36. package/dist/admin/pages/EditView/EditViewPage.mjs.map +1 -1
  37. package/dist/admin/pages/EditView/components/Blocker.js +36 -0
  38. package/dist/admin/pages/EditView/components/Blocker.js.map +1 -0
  39. package/dist/admin/pages/EditView/components/Blocker.mjs +34 -0
  40. package/dist/admin/pages/EditView/components/Blocker.mjs.map +1 -0
  41. package/dist/admin/pages/EditView/components/DocumentActions.js +83 -70
  42. package/dist/admin/pages/EditView/components/DocumentActions.js.map +1 -1
  43. package/dist/admin/pages/EditView/components/DocumentActions.mjs +85 -72
  44. package/dist/admin/pages/EditView/components/DocumentActions.mjs.map +1 -1
  45. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.js +12 -15
  46. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.js.map +1 -1
  47. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.mjs +12 -15
  48. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.mjs.map +1 -1
  49. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.js +54 -14
  50. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.js.map +1 -1
  51. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.mjs +55 -15
  52. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.mjs.map +1 -1
  53. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.js +21 -35
  54. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.js.map +1 -1
  55. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.mjs +21 -35
  56. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.mjs.map +1 -1
  57. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.js +12 -1
  58. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.js.map +1 -1
  59. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.mjs +13 -2
  60. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.mjs.map +1 -1
  61. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.js +15 -3
  62. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.js.map +1 -1
  63. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.mjs +16 -4
  64. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.mjs.map +1 -1
  65. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.js +18 -5
  66. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.js.map +1 -1
  67. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.mjs +20 -7
  68. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.mjs.map +1 -1
  69. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.js +1 -0
  70. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.js.map +1 -1
  71. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.mjs +1 -0
  72. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.mjs.map +1 -1
  73. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.js +158 -106
  74. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.js.map +1 -1
  75. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.mjs +161 -109
  76. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.mjs.map +1 -1
  77. package/dist/admin/pages/EditView/components/FormInputs/UID.js +4 -2
  78. package/dist/admin/pages/EditView/components/FormInputs/UID.js.map +1 -1
  79. package/dist/admin/pages/EditView/components/FormInputs/UID.mjs +4 -2
  80. package/dist/admin/pages/EditView/components/FormInputs/UID.mjs.map +1 -1
  81. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.js +1 -1
  82. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.js.map +1 -1
  83. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.mjs +1 -1
  84. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.mjs.map +1 -1
  85. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.js +86 -118
  86. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.js.map +1 -1
  87. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.mjs +86 -118
  88. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.mjs.map +1 -1
  89. package/dist/admin/pages/EditView/components/FormLayout.js +46 -26
  90. package/dist/admin/pages/EditView/components/FormLayout.js.map +1 -1
  91. package/dist/admin/pages/EditView/components/FormLayout.mjs +46 -26
  92. package/dist/admin/pages/EditView/components/FormLayout.mjs.map +1 -1
  93. package/dist/admin/pages/EditView/components/InputRenderer.js +40 -11
  94. package/dist/admin/pages/EditView/components/InputRenderer.js.map +1 -1
  95. package/dist/admin/pages/EditView/components/InputRenderer.mjs +41 -12
  96. package/dist/admin/pages/EditView/components/InputRenderer.mjs.map +1 -1
  97. package/dist/admin/pages/EditView/utils/data.js +103 -0
  98. package/dist/admin/pages/EditView/utils/data.js.map +1 -1
  99. package/dist/admin/pages/EditView/utils/data.mjs +103 -1
  100. package/dist/admin/pages/EditView/utils/data.mjs.map +1 -1
  101. package/dist/admin/pages/ListView/ListViewPage.js +227 -132
  102. package/dist/admin/pages/ListView/ListViewPage.js.map +1 -1
  103. package/dist/admin/pages/ListView/ListViewPage.mjs +229 -134
  104. package/dist/admin/pages/ListView/ListViewPage.mjs.map +1 -1
  105. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.js +2 -1
  106. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.js.map +1 -1
  107. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.mjs +2 -1
  108. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.mjs.map +1 -1
  109. package/dist/admin/pages/ListView/components/Filters.js +4 -1
  110. package/dist/admin/pages/ListView/components/Filters.js.map +1 -1
  111. package/dist/admin/pages/ListView/components/Filters.mjs +4 -1
  112. package/dist/admin/pages/ListView/components/Filters.mjs.map +1 -1
  113. package/dist/admin/pages/ListView/components/TableActions.js +13 -3
  114. package/dist/admin/pages/ListView/components/TableActions.js.map +1 -1
  115. package/dist/admin/pages/ListView/components/TableActions.mjs +13 -3
  116. package/dist/admin/pages/ListView/components/TableActions.mjs.map +1 -1
  117. package/dist/admin/preview/components/PreviewSidePanel.js +31 -4
  118. package/dist/admin/preview/components/PreviewSidePanel.js.map +1 -1
  119. package/dist/admin/preview/components/PreviewSidePanel.mjs +32 -5
  120. package/dist/admin/preview/components/PreviewSidePanel.mjs.map +1 -1
  121. package/dist/admin/preview/pages/Preview.js +231 -69
  122. package/dist/admin/preview/pages/Preview.js.map +1 -1
  123. package/dist/admin/preview/pages/Preview.mjs +233 -71
  124. package/dist/admin/preview/pages/Preview.mjs.map +1 -1
  125. package/dist/admin/preview/utils/constants.js +9 -0
  126. package/dist/admin/preview/utils/constants.js.map +1 -0
  127. package/dist/admin/preview/utils/constants.mjs +7 -0
  128. package/dist/admin/preview/utils/constants.mjs.map +1 -0
  129. package/dist/admin/preview/utils/script.js +300 -0
  130. package/dist/admin/preview/utils/script.js.map +1 -0
  131. package/dist/admin/preview/utils/script.mjs +298 -0
  132. package/dist/admin/preview/utils/script.mjs.map +1 -0
  133. package/dist/admin/preview/utils/usePreviewInputManager.js +93 -0
  134. package/dist/admin/preview/utils/usePreviewInputManager.js.map +1 -0
  135. package/dist/admin/preview/utils/usePreviewInputManager.mjs +72 -0
  136. package/dist/admin/preview/utils/usePreviewInputManager.mjs.map +1 -0
  137. package/dist/admin/services/api.js +3 -1
  138. package/dist/admin/services/api.js.map +1 -1
  139. package/dist/admin/services/api.mjs +3 -1
  140. package/dist/admin/services/api.mjs.map +1 -1
  141. package/dist/admin/services/documents.js +32 -16
  142. package/dist/admin/services/documents.js.map +1 -1
  143. package/dist/admin/services/documents.mjs +32 -16
  144. package/dist/admin/services/documents.mjs.map +1 -1
  145. package/dist/admin/services/homepage.js +11 -2
  146. package/dist/admin/services/homepage.js.map +1 -1
  147. package/dist/admin/services/homepage.mjs +11 -3
  148. package/dist/admin/services/homepage.mjs.map +1 -1
  149. package/dist/admin/src/components/ConfigurationForm/Fields.d.ts +6 -4
  150. package/dist/admin/src/components/Widgets.d.ts +2 -1
  151. package/dist/admin/src/exports.d.ts +1 -0
  152. package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
  153. package/dist/admin/src/hooks/useDocumentActions.d.ts +1 -0
  154. package/dist/admin/src/pages/EditView/components/Blocker.d.ts +2 -0
  155. package/dist/admin/src/pages/EditView/components/FormInputs/UID.d.ts +1 -0
  156. package/dist/admin/src/pages/EditView/components/FormLayout.d.ts +7 -7
  157. package/dist/admin/src/pages/EditView/utils/data.d.ts +19 -1
  158. package/dist/admin/src/preview/pages/Preview.d.ts +3 -0
  159. package/dist/admin/src/preview/services/preview.d.ts +1 -1
  160. package/dist/admin/src/preview/utils/constants.d.ts +7 -0
  161. package/dist/admin/src/preview/utils/script.d.ts +23 -0
  162. package/dist/admin/src/preview/utils/usePreviewInputManager.d.ts +3 -0
  163. package/dist/admin/src/services/api.d.ts +1 -1
  164. package/dist/admin/src/services/components.d.ts +2 -2
  165. package/dist/admin/src/services/contentTypes.d.ts +3 -3
  166. package/dist/admin/src/services/documents.d.ts +23 -17
  167. package/dist/admin/src/services/homepage.d.ts +6 -2
  168. package/dist/admin/src/services/init.d.ts +1 -1
  169. package/dist/admin/src/services/relations.d.ts +2 -2
  170. package/dist/admin/src/services/uid.d.ts +3 -3
  171. package/dist/admin/src/utils/validation.d.ts +1 -0
  172. package/dist/admin/translations/en.json.js +7 -0
  173. package/dist/admin/translations/en.json.js.map +1 -1
  174. package/dist/admin/translations/en.json.mjs +7 -0
  175. package/dist/admin/translations/en.json.mjs.map +1 -1
  176. package/dist/admin/translations/es.json.js +5 -2
  177. package/dist/admin/translations/es.json.js.map +1 -1
  178. package/dist/admin/translations/es.json.mjs +5 -2
  179. package/dist/admin/translations/es.json.mjs.map +1 -1
  180. package/dist/admin/translations/fr.json.js +10 -2
  181. package/dist/admin/translations/fr.json.js.map +1 -1
  182. package/dist/admin/translations/fr.json.mjs +10 -2
  183. package/dist/admin/translations/fr.json.mjs.map +1 -1
  184. package/dist/admin/utils/validation.js +19 -7
  185. package/dist/admin/utils/validation.js.map +1 -1
  186. package/dist/admin/utils/validation.mjs +19 -7
  187. package/dist/admin/utils/validation.mjs.map +1 -1
  188. package/dist/server/controllers/content-types.js +11 -1
  189. package/dist/server/controllers/content-types.js.map +1 -1
  190. package/dist/server/controllers/content-types.mjs +11 -1
  191. package/dist/server/controllers/content-types.mjs.map +1 -1
  192. package/dist/server/controllers/relations.js +2 -2
  193. package/dist/server/controllers/relations.js.map +1 -1
  194. package/dist/server/controllers/relations.mjs +2 -2
  195. package/dist/server/controllers/relations.mjs.map +1 -1
  196. package/dist/server/controllers/validation/index.js +14 -2
  197. package/dist/server/controllers/validation/index.js.map +1 -1
  198. package/dist/server/controllers/validation/index.mjs +14 -2
  199. package/dist/server/controllers/validation/index.mjs.map +1 -1
  200. package/dist/server/history/services/lifecycles.js +23 -19
  201. package/dist/server/history/services/lifecycles.js.map +1 -1
  202. package/dist/server/history/services/lifecycles.mjs +23 -19
  203. package/dist/server/history/services/lifecycles.mjs.map +1 -1
  204. package/dist/server/homepage/controllers/homepage.js +5 -0
  205. package/dist/server/homepage/controllers/homepage.js.map +1 -1
  206. package/dist/server/homepage/controllers/homepage.mjs +5 -0
  207. package/dist/server/homepage/controllers/homepage.mjs.map +1 -1
  208. package/dist/server/homepage/routes/homepage.js +11 -0
  209. package/dist/server/homepage/routes/homepage.js.map +1 -1
  210. package/dist/server/homepage/routes/homepage.mjs +11 -0
  211. package/dist/server/homepage/routes/homepage.mjs.map +1 -1
  212. package/dist/server/homepage/services/homepage.js +86 -46
  213. package/dist/server/homepage/services/homepage.js.map +1 -1
  214. package/dist/server/homepage/services/homepage.mjs +86 -46
  215. package/dist/server/homepage/services/homepage.mjs.map +1 -1
  216. package/dist/server/preview/services/preview-config.js +5 -1
  217. package/dist/server/preview/services/preview-config.js.map +1 -1
  218. package/dist/server/preview/services/preview-config.mjs +5 -1
  219. package/dist/server/preview/services/preview-config.mjs.map +1 -1
  220. package/dist/server/preview/services/preview.js +4 -0
  221. package/dist/server/preview/services/preview.js.map +1 -1
  222. package/dist/server/preview/services/preview.mjs +4 -0
  223. package/dist/server/preview/services/preview.mjs.map +1 -1
  224. package/dist/server/services/data-mapper.js +4 -1
  225. package/dist/server/services/data-mapper.js.map +1 -1
  226. package/dist/server/services/data-mapper.mjs +4 -1
  227. package/dist/server/services/data-mapper.mjs.map +1 -1
  228. package/dist/server/services/document-manager.js +8 -1
  229. package/dist/server/services/document-manager.js.map +1 -1
  230. package/dist/server/services/document-manager.mjs +8 -1
  231. package/dist/server/services/document-manager.mjs.map +1 -1
  232. package/dist/server/services/document-metadata.js +3 -1
  233. package/dist/server/services/document-metadata.js.map +1 -1
  234. package/dist/server/services/document-metadata.mjs +3 -1
  235. package/dist/server/services/document-metadata.mjs.map +1 -1
  236. package/dist/server/services/utils/configuration/attributes.js +1 -1
  237. package/dist/server/services/utils/configuration/attributes.js.map +1 -1
  238. package/dist/server/services/utils/configuration/attributes.mjs +1 -1
  239. package/dist/server/services/utils/configuration/attributes.mjs.map +1 -1
  240. package/dist/server/services/utils/configuration/layouts.js +1 -1
  241. package/dist/server/services/utils/configuration/layouts.js.map +1 -1
  242. package/dist/server/services/utils/configuration/layouts.mjs +1 -1
  243. package/dist/server/services/utils/configuration/layouts.mjs.map +1 -1
  244. package/dist/server/services/utils/configuration/metadatas.js +8 -0
  245. package/dist/server/services/utils/configuration/metadatas.js.map +1 -1
  246. package/dist/server/services/utils/configuration/metadatas.mjs +8 -0
  247. package/dist/server/services/utils/configuration/metadatas.mjs.map +1 -1
  248. package/dist/server/services/utils/populate.js +11 -0
  249. package/dist/server/services/utils/populate.js.map +1 -1
  250. package/dist/server/services/utils/populate.mjs +11 -0
  251. package/dist/server/services/utils/populate.mjs.map +1 -1
  252. package/dist/server/src/controllers/content-types.d.ts.map +1 -1
  253. package/dist/server/src/controllers/validation/index.d.ts +6 -1
  254. package/dist/server/src/controllers/validation/index.d.ts.map +1 -1
  255. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -1
  256. package/dist/server/src/homepage/controllers/homepage.d.ts +2 -1
  257. package/dist/server/src/homepage/controllers/homepage.d.ts.map +1 -1
  258. package/dist/server/src/homepage/index.d.ts +7 -0
  259. package/dist/server/src/homepage/index.d.ts.map +1 -1
  260. package/dist/server/src/homepage/routes/homepage.d.ts.map +1 -1
  261. package/dist/server/src/homepage/services/homepage.d.ts +4 -1
  262. package/dist/server/src/homepage/services/homepage.d.ts.map +1 -1
  263. package/dist/server/src/homepage/services/index.d.ts +7 -0
  264. package/dist/server/src/homepage/services/index.d.ts.map +1 -1
  265. package/dist/server/src/index.d.ts +8 -0
  266. package/dist/server/src/index.d.ts.map +1 -1
  267. package/dist/server/src/preview/services/index.d.ts +1 -0
  268. package/dist/server/src/preview/services/index.d.ts.map +1 -1
  269. package/dist/server/src/preview/services/preview-config.d.ts +1 -0
  270. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -1
  271. package/dist/server/src/preview/services/preview.d.ts.map +1 -1
  272. package/dist/server/src/preview/utils.d.ts +1 -0
  273. package/dist/server/src/preview/utils.d.ts.map +1 -1
  274. package/dist/server/src/services/data-mapper.d.ts +1 -0
  275. package/dist/server/src/services/data-mapper.d.ts.map +1 -1
  276. package/dist/server/src/services/document-manager.d.ts.map +1 -1
  277. package/dist/server/src/services/document-metadata.d.ts.map +1 -1
  278. package/dist/server/src/services/index.d.ts +8 -0
  279. package/dist/server/src/services/index.d.ts.map +1 -1
  280. package/dist/server/src/services/utils/configuration/metadatas.d.ts.map +1 -1
  281. package/dist/server/src/services/utils/populate.d.ts.map +1 -1
  282. package/dist/shared/contracts/collection-types.d.ts +0 -1
  283. package/dist/shared/contracts/collection-types.d.ts.map +1 -1
  284. package/dist/shared/contracts/homepage.d.ts +13 -0
  285. package/dist/shared/contracts/homepage.d.ts.map +1 -1
  286. package/package.json +11 -9
@@ -24,6 +24,11 @@ const PreviewSidePanel = ({ model, documentId, document })=>{
24
24
  const { pathname } = reactRouterDom.useLocation();
25
25
  const [{ query }] = strapiAdmin.useQueryParams();
26
26
  const isModified = strapiAdmin.useForm('PreviewSidePanel', (state)=>state.modified);
27
+ const isUnsaved = Boolean(!document || !document.id);
28
+ const title = formatMessage({
29
+ id: 'content-manager.preview.panel.title',
30
+ defaultMessage: 'Preview'
31
+ });
27
32
  /**
28
33
  * The preview URL isn't used in this component, we just fetch it to know if preview is enabled
29
34
  * for the content type. If it's not, the panel is not displayed. If it is, we display a link to
@@ -37,7 +42,32 @@ const PreviewSidePanel = ({ model, documentId, document })=>{
37
42
  locale: document?.locale,
38
43
  status: document?.status
39
44
  }
45
+ }, // Don't bother making the request since we won't show any UI
46
+ {
47
+ skip: isUnsaved
40
48
  });
49
+ if (isUnsaved) {
50
+ return null;
51
+ }
52
+ // Preview was not configured but not disabled either (otherwise it would be a success 204).
53
+ // So we encourage the user to set it up.
54
+ if (error && error.name === 'NotFoundError') {
55
+ return {
56
+ title,
57
+ content: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Button, {
58
+ variant: "tertiary",
59
+ tag: reactRouterDom.Link,
60
+ to: "https://docs.strapi.io/cms/features/preview",
61
+ target: "_blank",
62
+ rel: "noopener noreferrer",
63
+ width: "100%",
64
+ children: formatMessage({
65
+ id: 'content-manager.preview.panel.button-configuration',
66
+ defaultMessage: 'Set up preview'
67
+ })
68
+ })
69
+ };
70
+ }
41
71
  if (!data?.data?.url || error) {
42
72
  return null;
43
73
  }
@@ -50,10 +80,7 @@ const PreviewSidePanel = ({ model, documentId, document })=>{
50
80
  });
51
81
  };
52
82
  return {
53
- title: formatMessage({
54
- id: 'content-manager.preview.panel.title',
55
- defaultMessage: 'Preview'
56
- }),
83
+ title,
57
84
  content: /*#__PURE__*/ jsxRuntime.jsx(ConditionalTooltip, {
58
85
  label: formatMessage({
59
86
  id: 'content-manager.preview.panel.button-disabled-tooltip',
@@ -1 +1 @@
1
- {"version":3,"file":"PreviewSidePanel.js","sources":["../../../../admin/src/preview/components/PreviewSidePanel.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { useQueryParams, useTracking, useForm } from '@strapi/admin/strapi-admin';\nimport { Box, Button, Tooltip, type TooltipProps } from '@strapi/design-system';\nimport { stringify } from 'qs';\nimport { useIntl } from 'react-intl';\nimport { Link, useLocation } from 'react-router-dom';\n\nimport { useGetPreviewUrlQuery } from '../services/preview';\n\nimport type { PanelComponent } from '@strapi/content-manager/strapi-admin';\nimport type { UID } from '@strapi/types';\n\ninterface ConditionalTooltipProps {\n isShown: boolean;\n label: TooltipProps['label'];\n children: React.ReactNode;\n}\n\nconst ConditionalTooltip = ({ isShown, label, children }: ConditionalTooltipProps) => {\n if (isShown) {\n return <Tooltip label={label}>{children}</Tooltip>;\n }\n\n return children;\n};\n\nconst PreviewSidePanel: PanelComponent = ({ model, documentId, document }) => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const { pathname } = useLocation();\n const [{ query }] = useQueryParams();\n const isModified = useForm('PreviewSidePanel', (state) => state.modified);\n\n /**\n * The preview URL isn't used in this component, we just fetch it to know if preview is enabled\n * for the content type. If it's not, the panel is not displayed. If it is, we display a link to\n * /preview, and the URL will already be loaded in the RTK query cache.\n */\n const { data, error } = useGetPreviewUrlQuery({\n params: {\n contentType: model as UID.ContentType,\n },\n query: {\n documentId,\n locale: document?.locale,\n status: document?.status,\n },\n });\n\n if (!data?.data?.url || error) {\n return null;\n }\n\n const trackNavigation = () => {\n // Append /preview to the current URL\n const destinationPathname = pathname.replace(/\\/$/, '') + '/preview';\n trackUsage('willNavigate', { from: pathname, to: destinationPathname });\n };\n\n return {\n title: formatMessage({ id: 'content-manager.preview.panel.title', defaultMessage: 'Preview' }),\n content: (\n <ConditionalTooltip\n label={formatMessage({\n id: 'content-manager.preview.panel.button-disabled-tooltip',\n defaultMessage: 'Please save to open the preview',\n })}\n isShown={isModified}\n >\n <Box cursor=\"not-allowed\" width=\"100%\">\n <Button\n variant=\"tertiary\"\n tag={Link}\n to={{ pathname: 'preview', search: stringify(query, { encode: false }) }}\n onClick={trackNavigation}\n width=\"100%\"\n disabled={isModified}\n pointerEvents={isModified ? 'none' : undefined}\n tabIndex={isModified ? -1 : undefined}\n >\n {formatMessage({\n id: 'content-manager.preview.panel.button',\n defaultMessage: 'Open preview',\n })}\n </Button>\n </Box>\n </ConditionalTooltip>\n ),\n };\n};\n\nexport { PreviewSidePanel };\n"],"names":["ConditionalTooltip","isShown","label","children","_jsx","Tooltip","PreviewSidePanel","model","documentId","document","formatMessage","useIntl","trackUsage","useTracking","pathname","useLocation","query","useQueryParams","isModified","useForm","state","modified","data","error","useGetPreviewUrlQuery","params","contentType","locale","status","url","trackNavigation","destinationPathname","replace","from","to","title","id","defaultMessage","content","Box","cursor","width","Button","variant","tag","Link","search","stringify","encode","onClick","disabled","pointerEvents","undefined","tabIndex"],"mappings":";;;;;;;;;;;AAmBA,MAAMA,kBAAAA,GAAqB,CAAC,EAAEC,OAAO,EAAEC,KAAK,EAAEC,QAAQ,EAA2B,GAAA;AAC/E,IAAA,IAAIF,OAAS,EAAA;AACX,QAAA,qBAAOG,cAACC,CAAAA,oBAAAA,EAAAA;YAAQH,KAAOA,EAAAA,KAAAA;AAAQC,YAAAA,QAAAA,EAAAA;;AACjC;IAEA,OAAOA,QAAAA;AACT,CAAA;AAEMG,MAAAA,gBAAAA,GAAmC,CAAC,EAAEC,KAAK,EAAEC,UAAU,EAAEC,QAAQ,EAAE,GAAA;IACvE,MAAM,EAAEC,aAAa,EAAE,GAAGC,iBAAAA,EAAAA;IAC1B,MAAM,EAAEC,UAAU,EAAE,GAAGC,uBAAAA,EAAAA;IACvB,MAAM,EAAEC,QAAQ,EAAE,GAAGC,0BAAAA,EAAAA;AACrB,IAAA,MAAM,CAAC,EAAEC,KAAK,EAAE,CAAC,GAAGC,0BAAAA,EAAAA;AACpB,IAAA,MAAMC,aAAaC,mBAAQ,CAAA,kBAAA,EAAoB,CAACC,KAAAA,GAAUA,MAAMC,QAAQ,CAAA;AAExE;;;;AAIC,MACD,MAAM,EAAEC,IAAI,EAAEC,KAAK,EAAE,GAAGC,6BAAsB,CAAA;QAC5CC,MAAQ,EAAA;YACNC,WAAanB,EAAAA;AACf,SAAA;QACAS,KAAO,EAAA;AACLR,YAAAA,UAAAA;AACAmB,YAAAA,MAAAA,EAAQlB,QAAUkB,EAAAA,MAAAA;AAClBC,YAAAA,MAAAA,EAAQnB,QAAUmB,EAAAA;AACpB;AACF,KAAA,CAAA;AAEA,IAAA,IAAI,CAACN,IAAAA,EAAMA,IAAMO,EAAAA,GAAAA,IAAON,KAAO,EAAA;QAC7B,OAAO,IAAA;AACT;AAEA,IAAA,MAAMO,eAAkB,GAAA,IAAA;;AAEtB,QAAA,MAAMC,mBAAsBjB,GAAAA,QAAAA,CAASkB,OAAO,CAAC,OAAO,EAAM,CAAA,GAAA,UAAA;AAC1DpB,QAAAA,UAAAA,CAAW,cAAgB,EAAA;YAAEqB,IAAMnB,EAAAA,QAAAA;YAAUoB,EAAIH,EAAAA;AAAoB,SAAA,CAAA;AACvE,KAAA;IAEA,OAAO;AACLI,QAAAA,KAAAA,EAAOzB,aAAc,CAAA;YAAE0B,EAAI,EAAA,qCAAA;YAAuCC,cAAgB,EAAA;AAAU,SAAA,CAAA;AAC5FC,QAAAA,OAAAA,gBACElC,cAACJ,CAAAA,kBAAAA,EAAAA;AACCE,YAAAA,KAAAA,EAAOQ,aAAc,CAAA;gBACnB0B,EAAI,EAAA,uDAAA;gBACJC,cAAgB,EAAA;AAClB,aAAA,CAAA;YACApC,OAASiB,EAAAA,UAAAA;AAET,YAAA,QAAA,gBAAAd,cAACmC,CAAAA,gBAAAA,EAAAA;gBAAIC,MAAO,EAAA,aAAA;gBAAcC,KAAM,EAAA,MAAA;AAC9B,gBAAA,QAAA,gBAAArC,cAACsC,CAAAA,mBAAAA,EAAAA;oBACCC,OAAQ,EAAA,UAAA;oBACRC,GAAKC,EAAAA,mBAAAA;oBACLX,EAAI,EAAA;wBAAEpB,QAAU,EAAA,SAAA;AAAWgC,wBAAAA,MAAAA,EAAQC,aAAU/B,KAAO,EAAA;4BAAEgC,MAAQ,EAAA;AAAM,yBAAA;AAAG,qBAAA;oBACvEC,OAASnB,EAAAA,eAAAA;oBACTW,KAAM,EAAA,MAAA;oBACNS,QAAUhC,EAAAA,UAAAA;AACViC,oBAAAA,aAAAA,EAAejC,aAAa,MAASkC,GAAAA,SAAAA;oBACrCC,QAAUnC,EAAAA,UAAAA,GAAa,CAAC,CAAIkC,GAAAA,SAAAA;8BAE3B1C,aAAc,CAAA;wBACb0B,EAAI,EAAA,sCAAA;wBACJC,cAAgB,EAAA;AAClB,qBAAA;;;;AAKV,KAAA;AACF;;;;"}
1
+ {"version":3,"file":"PreviewSidePanel.js","sources":["../../../../admin/src/preview/components/PreviewSidePanel.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { useQueryParams, useTracking, useForm } from '@strapi/admin/strapi-admin';\nimport { Box, Button, Tooltip, type TooltipProps } from '@strapi/design-system';\nimport { stringify } from 'qs';\nimport { useIntl } from 'react-intl';\nimport { Link, useLocation } from 'react-router-dom';\n\nimport { useGetPreviewUrlQuery } from '../services/preview';\n\nimport type { PanelComponent } from '@strapi/content-manager/strapi-admin';\nimport type { UID } from '@strapi/types';\n\ninterface ConditionalTooltipProps {\n isShown: boolean;\n label: TooltipProps['label'];\n children: React.ReactNode;\n}\n\nconst ConditionalTooltip = ({ isShown, label, children }: ConditionalTooltipProps) => {\n if (isShown) {\n return <Tooltip label={label}>{children}</Tooltip>;\n }\n\n return children;\n};\n\nconst PreviewSidePanel: PanelComponent = ({ model, documentId, document }) => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const { pathname } = useLocation();\n const [{ query }] = useQueryParams();\n const isModified = useForm('PreviewSidePanel', (state) => state.modified);\n const isUnsaved = Boolean(!document || !document.id);\n\n const title = formatMessage({\n id: 'content-manager.preview.panel.title',\n defaultMessage: 'Preview',\n });\n\n /**\n * The preview URL isn't used in this component, we just fetch it to know if preview is enabled\n * for the content type. If it's not, the panel is not displayed. If it is, we display a link to\n * /preview, and the URL will already be loaded in the RTK query cache.\n */\n const { data, error } = useGetPreviewUrlQuery(\n {\n params: {\n contentType: model as UID.ContentType,\n },\n query: {\n documentId,\n locale: document?.locale,\n status: document?.status,\n },\n },\n // Don't bother making the request since we won't show any UI\n { skip: isUnsaved }\n );\n\n if (isUnsaved) {\n return null;\n }\n\n // Preview was not configured but not disabled either (otherwise it would be a success 204).\n // So we encourage the user to set it up.\n if (error && error.name === 'NotFoundError') {\n return {\n title,\n content: (\n <Button\n variant=\"tertiary\"\n tag={Link}\n to=\"https://docs.strapi.io/cms/features/preview\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n width=\"100%\"\n >\n {formatMessage({\n id: 'content-manager.preview.panel.button-configuration',\n defaultMessage: 'Set up preview',\n })}\n </Button>\n ),\n };\n }\n\n if (!data?.data?.url || error) {\n return null;\n }\n\n const trackNavigation = () => {\n // Append /preview to the current URL\n const destinationPathname = pathname.replace(/\\/$/, '') + '/preview';\n trackUsage('willNavigate', { from: pathname, to: destinationPathname });\n };\n\n return {\n title,\n content: (\n <ConditionalTooltip\n label={formatMessage({\n id: 'content-manager.preview.panel.button-disabled-tooltip',\n defaultMessage: 'Please save to open the preview',\n })}\n isShown={isModified}\n >\n <Box cursor=\"not-allowed\" width=\"100%\">\n <Button\n variant=\"tertiary\"\n tag={Link}\n to={{ pathname: 'preview', search: stringify(query, { encode: false }) }}\n onClick={trackNavigation}\n width=\"100%\"\n disabled={isModified}\n pointerEvents={isModified ? 'none' : undefined}\n tabIndex={isModified ? -1 : undefined}\n >\n {formatMessage({\n id: 'content-manager.preview.panel.button',\n defaultMessage: 'Open preview',\n })}\n </Button>\n </Box>\n </ConditionalTooltip>\n ),\n };\n};\n\nexport { PreviewSidePanel };\n"],"names":["ConditionalTooltip","isShown","label","children","_jsx","Tooltip","PreviewSidePanel","model","documentId","document","formatMessage","useIntl","trackUsage","useTracking","pathname","useLocation","query","useQueryParams","isModified","useForm","state","modified","isUnsaved","Boolean","id","title","defaultMessage","data","error","useGetPreviewUrlQuery","params","contentType","locale","status","skip","name","content","Button","variant","tag","Link","to","target","rel","width","url","trackNavigation","destinationPathname","replace","from","Box","cursor","search","stringify","encode","onClick","disabled","pointerEvents","undefined","tabIndex"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import 'react';
3
3
  import { useTracking, useQueryParams, useForm } from '@strapi/admin/strapi-admin';
4
- import { Box, Button, Tooltip } from '@strapi/design-system';
4
+ import { Button, Box, Tooltip } from '@strapi/design-system';
5
5
  import { stringify } from 'qs';
6
6
  import { useIntl } from 'react-intl';
7
7
  import { useLocation, Link } from 'react-router-dom';
@@ -22,6 +22,11 @@ const PreviewSidePanel = ({ model, documentId, document })=>{
22
22
  const { pathname } = useLocation();
23
23
  const [{ query }] = useQueryParams();
24
24
  const isModified = useForm('PreviewSidePanel', (state)=>state.modified);
25
+ const isUnsaved = Boolean(!document || !document.id);
26
+ const title = formatMessage({
27
+ id: 'content-manager.preview.panel.title',
28
+ defaultMessage: 'Preview'
29
+ });
25
30
  /**
26
31
  * The preview URL isn't used in this component, we just fetch it to know if preview is enabled
27
32
  * for the content type. If it's not, the panel is not displayed. If it is, we display a link to
@@ -35,7 +40,32 @@ const PreviewSidePanel = ({ model, documentId, document })=>{
35
40
  locale: document?.locale,
36
41
  status: document?.status
37
42
  }
43
+ }, // Don't bother making the request since we won't show any UI
44
+ {
45
+ skip: isUnsaved
38
46
  });
47
+ if (isUnsaved) {
48
+ return null;
49
+ }
50
+ // Preview was not configured but not disabled either (otherwise it would be a success 204).
51
+ // So we encourage the user to set it up.
52
+ if (error && error.name === 'NotFoundError') {
53
+ return {
54
+ title,
55
+ content: /*#__PURE__*/ jsx(Button, {
56
+ variant: "tertiary",
57
+ tag: Link,
58
+ to: "https://docs.strapi.io/cms/features/preview",
59
+ target: "_blank",
60
+ rel: "noopener noreferrer",
61
+ width: "100%",
62
+ children: formatMessage({
63
+ id: 'content-manager.preview.panel.button-configuration',
64
+ defaultMessage: 'Set up preview'
65
+ })
66
+ })
67
+ };
68
+ }
39
69
  if (!data?.data?.url || error) {
40
70
  return null;
41
71
  }
@@ -48,10 +78,7 @@ const PreviewSidePanel = ({ model, documentId, document })=>{
48
78
  });
49
79
  };
50
80
  return {
51
- title: formatMessage({
52
- id: 'content-manager.preview.panel.title',
53
- defaultMessage: 'Preview'
54
- }),
81
+ title,
55
82
  content: /*#__PURE__*/ jsx(ConditionalTooltip, {
56
83
  label: formatMessage({
57
84
  id: 'content-manager.preview.panel.button-disabled-tooltip',
@@ -1 +1 @@
1
- {"version":3,"file":"PreviewSidePanel.mjs","sources":["../../../../admin/src/preview/components/PreviewSidePanel.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { useQueryParams, useTracking, useForm } from '@strapi/admin/strapi-admin';\nimport { Box, Button, Tooltip, type TooltipProps } from '@strapi/design-system';\nimport { stringify } from 'qs';\nimport { useIntl } from 'react-intl';\nimport { Link, useLocation } from 'react-router-dom';\n\nimport { useGetPreviewUrlQuery } from '../services/preview';\n\nimport type { PanelComponent } from '@strapi/content-manager/strapi-admin';\nimport type { UID } from '@strapi/types';\n\ninterface ConditionalTooltipProps {\n isShown: boolean;\n label: TooltipProps['label'];\n children: React.ReactNode;\n}\n\nconst ConditionalTooltip = ({ isShown, label, children }: ConditionalTooltipProps) => {\n if (isShown) {\n return <Tooltip label={label}>{children}</Tooltip>;\n }\n\n return children;\n};\n\nconst PreviewSidePanel: PanelComponent = ({ model, documentId, document }) => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const { pathname } = useLocation();\n const [{ query }] = useQueryParams();\n const isModified = useForm('PreviewSidePanel', (state) => state.modified);\n\n /**\n * The preview URL isn't used in this component, we just fetch it to know if preview is enabled\n * for the content type. If it's not, the panel is not displayed. If it is, we display a link to\n * /preview, and the URL will already be loaded in the RTK query cache.\n */\n const { data, error } = useGetPreviewUrlQuery({\n params: {\n contentType: model as UID.ContentType,\n },\n query: {\n documentId,\n locale: document?.locale,\n status: document?.status,\n },\n });\n\n if (!data?.data?.url || error) {\n return null;\n }\n\n const trackNavigation = () => {\n // Append /preview to the current URL\n const destinationPathname = pathname.replace(/\\/$/, '') + '/preview';\n trackUsage('willNavigate', { from: pathname, to: destinationPathname });\n };\n\n return {\n title: formatMessage({ id: 'content-manager.preview.panel.title', defaultMessage: 'Preview' }),\n content: (\n <ConditionalTooltip\n label={formatMessage({\n id: 'content-manager.preview.panel.button-disabled-tooltip',\n defaultMessage: 'Please save to open the preview',\n })}\n isShown={isModified}\n >\n <Box cursor=\"not-allowed\" width=\"100%\">\n <Button\n variant=\"tertiary\"\n tag={Link}\n to={{ pathname: 'preview', search: stringify(query, { encode: false }) }}\n onClick={trackNavigation}\n width=\"100%\"\n disabled={isModified}\n pointerEvents={isModified ? 'none' : undefined}\n tabIndex={isModified ? -1 : undefined}\n >\n {formatMessage({\n id: 'content-manager.preview.panel.button',\n defaultMessage: 'Open preview',\n })}\n </Button>\n </Box>\n </ConditionalTooltip>\n ),\n };\n};\n\nexport { PreviewSidePanel };\n"],"names":["ConditionalTooltip","isShown","label","children","_jsx","Tooltip","PreviewSidePanel","model","documentId","document","formatMessage","useIntl","trackUsage","useTracking","pathname","useLocation","query","useQueryParams","isModified","useForm","state","modified","data","error","useGetPreviewUrlQuery","params","contentType","locale","status","url","trackNavigation","destinationPathname","replace","from","to","title","id","defaultMessage","content","Box","cursor","width","Button","variant","tag","Link","search","stringify","encode","onClick","disabled","pointerEvents","undefined","tabIndex"],"mappings":"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"}
1
+ {"version":3,"file":"PreviewSidePanel.mjs","sources":["../../../../admin/src/preview/components/PreviewSidePanel.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { useQueryParams, useTracking, useForm } from '@strapi/admin/strapi-admin';\nimport { Box, Button, Tooltip, type TooltipProps } from '@strapi/design-system';\nimport { stringify } from 'qs';\nimport { useIntl } from 'react-intl';\nimport { Link, useLocation } from 'react-router-dom';\n\nimport { useGetPreviewUrlQuery } from '../services/preview';\n\nimport type { PanelComponent } from '@strapi/content-manager/strapi-admin';\nimport type { UID } from '@strapi/types';\n\ninterface ConditionalTooltipProps {\n isShown: boolean;\n label: TooltipProps['label'];\n children: React.ReactNode;\n}\n\nconst ConditionalTooltip = ({ isShown, label, children }: ConditionalTooltipProps) => {\n if (isShown) {\n return <Tooltip label={label}>{children}</Tooltip>;\n }\n\n return children;\n};\n\nconst PreviewSidePanel: PanelComponent = ({ model, documentId, document }) => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const { pathname } = useLocation();\n const [{ query }] = useQueryParams();\n const isModified = useForm('PreviewSidePanel', (state) => state.modified);\n const isUnsaved = Boolean(!document || !document.id);\n\n const title = formatMessage({\n id: 'content-manager.preview.panel.title',\n defaultMessage: 'Preview',\n });\n\n /**\n * The preview URL isn't used in this component, we just fetch it to know if preview is enabled\n * for the content type. If it's not, the panel is not displayed. If it is, we display a link to\n * /preview, and the URL will already be loaded in the RTK query cache.\n */\n const { data, error } = useGetPreviewUrlQuery(\n {\n params: {\n contentType: model as UID.ContentType,\n },\n query: {\n documentId,\n locale: document?.locale,\n status: document?.status,\n },\n },\n // Don't bother making the request since we won't show any UI\n { skip: isUnsaved }\n );\n\n if (isUnsaved) {\n return null;\n }\n\n // Preview was not configured but not disabled either (otherwise it would be a success 204).\n // So we encourage the user to set it up.\n if (error && error.name === 'NotFoundError') {\n return {\n title,\n content: (\n <Button\n variant=\"tertiary\"\n tag={Link}\n to=\"https://docs.strapi.io/cms/features/preview\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n width=\"100%\"\n >\n {formatMessage({\n id: 'content-manager.preview.panel.button-configuration',\n defaultMessage: 'Set up preview',\n })}\n </Button>\n ),\n };\n }\n\n if (!data?.data?.url || error) {\n return null;\n }\n\n const trackNavigation = () => {\n // Append /preview to the current URL\n const destinationPathname = pathname.replace(/\\/$/, '') + '/preview';\n trackUsage('willNavigate', { from: pathname, to: destinationPathname });\n };\n\n return {\n title,\n content: (\n <ConditionalTooltip\n label={formatMessage({\n id: 'content-manager.preview.panel.button-disabled-tooltip',\n defaultMessage: 'Please save to open the preview',\n })}\n isShown={isModified}\n >\n <Box cursor=\"not-allowed\" width=\"100%\">\n <Button\n variant=\"tertiary\"\n tag={Link}\n to={{ pathname: 'preview', search: stringify(query, { encode: false }) }}\n onClick={trackNavigation}\n width=\"100%\"\n disabled={isModified}\n pointerEvents={isModified ? 'none' : undefined}\n tabIndex={isModified ? -1 : undefined}\n >\n {formatMessage({\n id: 'content-manager.preview.panel.button',\n defaultMessage: 'Open preview',\n })}\n </Button>\n </Box>\n </ConditionalTooltip>\n ),\n };\n};\n\nexport { PreviewSidePanel };\n"],"names":["ConditionalTooltip","isShown","label","children","_jsx","Tooltip","PreviewSidePanel","model","documentId","document","formatMessage","useIntl","trackUsage","useTracking","pathname","useLocation","query","useQueryParams","isModified","useForm","state","modified","isUnsaved","Boolean","id","title","defaultMessage","data","error","useGetPreviewUrlQuery","params","contentType","locale","status","skip","name","content","Button","variant","tag","Link","to","target","rel","width","url","trackNavigation","destinationPathname","replace","from","Box","cursor","search","stringify","encode","onClick","disabled","pointerEvents","undefined","tabIndex"],"mappings":"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"}
@@ -12,11 +12,15 @@ var collections = require('../../constants/collections.js');
12
12
  var DocumentRBAC = require('../../features/DocumentRBAC.js');
13
13
  var useDocument = require('../../hooks/useDocument.js');
14
14
  var useDocumentLayout = require('../../hooks/useDocumentLayout.js');
15
+ var Blocker = require('../../pages/EditView/components/Blocker.js');
15
16
  var FormLayout = require('../../pages/EditView/components/FormLayout.js');
17
+ var InputRenderer = require('../../pages/EditView/components/InputRenderer.js');
18
+ var data = require('../../pages/EditView/utils/data.js');
16
19
  var api = require('../../utils/api.js');
17
20
  var validation = require('../../utils/validation.js');
18
21
  var PreviewHeader = require('../components/PreviewHeader.js');
19
22
  var preview = require('../services/preview.js');
23
+ var script = require('../utils/script.js');
20
24
 
21
25
  function _interopNamespaceDefault(e) {
22
26
  var n = Object.create(null);
@@ -37,12 +41,86 @@ function _interopNamespaceDefault(e) {
37
41
 
38
42
  var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
39
43
 
44
+ /* -------------------------------------------------------------------------------------------------
45
+ * Constants
46
+ * -----------------------------------------------------------------------------------------------*/ const DEVICES = [
47
+ {
48
+ name: 'desktop',
49
+ label: {
50
+ id: 'content-manager.preview.device.desktop',
51
+ defaultMessage: 'Desktop'
52
+ },
53
+ width: '100%',
54
+ height: '100%'
55
+ },
56
+ {
57
+ name: 'mobile',
58
+ label: {
59
+ id: 'content-manager.preview.device.mobile',
60
+ defaultMessage: 'Mobile'
61
+ },
62
+ width: '375px',
63
+ height: '667px'
64
+ }
65
+ ];
40
66
  const [PreviewProvider, usePreviewContext] = strapiAdmin.createContext('PreviewPage');
67
+ /* -------------------------------------------------------------------------------------------------
68
+ * VisualEditingPopover
69
+ * -----------------------------------------------------------------------------------------------*/ const VisualEditingPopover = ({ popoverField, setPopoverField, documentResponse })=>{
70
+ const iframeRef = usePreviewContext('VisualEditingPopover', (state)=>state.iframeRef);
71
+ if (!popoverField || !documentResponse.schema || !iframeRef.current) {
72
+ return null;
73
+ }
74
+ const iframeRect = iframeRef.current.getBoundingClientRect();
75
+ return /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
76
+ children: [
77
+ popoverField && /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
78
+ position: 'fixed',
79
+ top: iframeRect.top + 'px',
80
+ left: iframeRect.left + 'px',
81
+ width: iframeRect.width + 'px',
82
+ height: iframeRect.height + 'px',
83
+ zIndex: 4
84
+ }),
85
+ /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Popover.Root, {
86
+ open: popoverField != null,
87
+ onOpenChange: (open)=>!open && setPopoverField(null),
88
+ children: [
89
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Popover.Trigger, {
90
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
91
+ id: "popover-trigger",
92
+ position: "fixed",
93
+ width: popoverField.position.width + 'px',
94
+ height: popoverField.position.height + 'px',
95
+ top: iframeRect.top + popoverField.position.top + 'px',
96
+ left: iframeRect.left + popoverField.position.left + 'px'
97
+ })
98
+ }),
99
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Popover.Content, {
100
+ sideOffset: 4,
101
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
102
+ padding: 4,
103
+ width: "400px",
104
+ children: /*#__PURE__*/ jsxRuntime.jsx(InputRenderer.InputRenderer, {
105
+ document: documentResponse,
106
+ attribute: documentResponse.schema.attributes[popoverField.path],
107
+ label: popoverField.path,
108
+ name: popoverField.path,
109
+ type: documentResponse.schema.attributes[popoverField.path].type,
110
+ visible: true
111
+ })
112
+ })
113
+ })
114
+ ]
115
+ })
116
+ ]
117
+ });
118
+ };
41
119
  /* -------------------------------------------------------------------------------------------------
42
120
  * PreviewPage
43
121
  * -----------------------------------------------------------------------------------------------*/ const AnimatedArrow = styledComponents.styled(Icons.ArrowLineLeft)`
44
122
  will-change: transform;
45
- rotate: ${(props)=>props.isSideEditorOpen ? '0deg' : '180deg'};
123
+ rotate: ${(props)=>props.$isSideEditorOpen ? '0deg' : '180deg'};
46
124
  transition: rotate 0.2s ease-in-out;
47
125
  `;
48
126
  const PreviewPage = ()=>{
@@ -52,10 +130,48 @@ const PreviewPage = ()=>{
52
130
  const [isSideEditorOpen, setIsSideEditorOpen] = React__namespace.useState(true);
53
131
  // Read all the necessary data from the URL to find the right preview URL
54
132
  const { slug: model, id: documentId, collectionType } = reactRouterDom.useParams();
55
- const [{ query }] = strapiAdmin.useQueryParams();
133
+ const [{ query: { field: _field, ...query } }, setQuery] = strapiAdmin.useQueryParams();
56
134
  const params = React__namespace.useMemo(()=>api.buildValidParams(query), [
57
135
  query
58
136
  ]);
137
+ const [deviceName, setDeviceName] = React__namespace.useState(DEVICES[0].name);
138
+ const device = DEVICES.find((d)=>d.name === deviceName) ?? DEVICES[0];
139
+ const [popoverField, setPopoverField] = React__namespace.useState(null);
140
+ // Listen for ready message from iframe before injecting script
141
+ React__namespace.useEffect(()=>{
142
+ const handleMessage = (event)=>{
143
+ if (event.data?.type === 'strapiReady') {
144
+ const script$1 = `(${script.previewScript.toString()})()`;
145
+ iframeRef?.current?.contentWindow?.postMessage({
146
+ type: 'strapiScript',
147
+ script: script$1
148
+ }, new URL(iframeRef.current.src).origin);
149
+ }
150
+ };
151
+ window.addEventListener('message', handleMessage);
152
+ return ()=>{
153
+ window.removeEventListener('message', handleMessage);
154
+ };
155
+ }, []);
156
+ // Listen for willEditField message from iframe
157
+ React__namespace.useEffect(()=>{
158
+ const handleMessage = (event)=>{
159
+ if (event.data?.type === 'willEditField') {
160
+ if (isSideEditorOpen) {
161
+ setQuery({
162
+ field: event.data.payload.path
163
+ }, 'push', true);
164
+ } else {
165
+ setPopoverField(event.data.payload);
166
+ }
167
+ }
168
+ };
169
+ window.addEventListener('message', handleMessage);
170
+ return ()=>window.removeEventListener('message', handleMessage);
171
+ }, [
172
+ isSideEditorOpen,
173
+ setQuery
174
+ ]);
59
175
  if (!collectionType) {
60
176
  throw new Error('Could not find collectionType in url params');
61
177
  }
@@ -84,7 +200,7 @@ const PreviewPage = ()=>{
84
200
  });
85
201
  const documentLayoutResponse = useDocumentLayout.useDocumentLayout(model);
86
202
  const isLoading = previewUrlResponse.isLoading || documentLayoutResponse.isLoading || documentResponse.isLoading;
87
- if (isLoading && !documentResponse.document?.documentId) {
203
+ if (isLoading && (!documentResponse.document?.documentId || previewUrlResponse.isLoading)) {
88
204
  return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Loading, {});
89
205
  }
90
206
  const initialValues = documentResponse.getInitialFormValues();
@@ -96,11 +212,17 @@ const PreviewPage = ()=>{
96
212
  }
97
213
  const documentTitle = documentResponse.getTitle(documentLayoutResponse.edit.settings.mainField);
98
214
  const validateSync = (values, options)=>{
215
+ const { data: cleanedValues, removedAttributes } = data.handleInvisibleAttributes(values, {
216
+ schema: documentResponse.schema,
217
+ initialValues,
218
+ components: documentResponse.components
219
+ });
99
220
  const yupSchema = validation.createYupSchema(documentResponse.schema?.attributes, documentResponse.components, {
100
221
  status: documentResponse.document?.status,
222
+ removedAttributes,
101
223
  ...options
102
224
  });
103
- return yupSchema.validateSync(values, {
225
+ return yupSchema.validateSync(cleanedValues, {
104
226
  abortEarly: false
105
227
  });
106
228
  };
@@ -130,6 +252,8 @@ const PreviewPage = ()=>{
130
252
  schema: documentResponse.schema,
131
253
  layout: documentLayoutResponse.edit,
132
254
  onPreview: onPreview,
255
+ iframeRef: iframeRef,
256
+ isSideEditorOpen: isSideEditorOpen,
133
257
  children: /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Form, {
134
258
  method: "PUT",
135
259
  disabled: query.status === 'published' && documentResponse && documentResponse.document.status !== 'draft',
@@ -137,52 +261,101 @@ const PreviewPage = ()=>{
137
261
  initialErrors: location?.state?.forceValidation ? validateSync(initialValues, {}) : {},
138
262
  height: "100%",
139
263
  validate: (values, options)=>{
264
+ const { data: cleanedValues, removedAttributes } = data.handleInvisibleAttributes(values, {
265
+ schema: documentResponse.schema,
266
+ initialValues,
267
+ components: documentResponse.components
268
+ });
140
269
  const yupSchema = validation.createYupSchema(documentResponse.schema?.attributes, documentResponse.components, {
141
270
  status: documentResponse.document?.status,
271
+ removedAttributes,
142
272
  ...options
143
273
  });
144
- return yupSchema.validate(values, {
274
+ return yupSchema.validate(cleanedValues, {
145
275
  abortEarly: false
146
276
  });
147
277
  },
148
- children: ({ resetForm })=>/*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
149
- direction: "column",
150
- height: "100%",
151
- alignItems: "stretch",
152
- children: [
153
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Blocker, {
154
- onProceed: resetForm
155
- }),
156
- /*#__PURE__*/ jsxRuntime.jsx(PreviewHeader.PreviewHeader, {}),
157
- /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
158
- flex: 1,
159
- overflow: "auto",
160
- alignItems: "stretch",
161
- children: [
162
- hasAdvancedPreview && /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
163
- overflow: "auto",
164
- width: isSideEditorOpen ? '50%' : 0,
165
- borderWidth: "0 1px 0 0",
166
- borderColor: "neutral150",
167
- paddingTop: 6,
168
- paddingBottom: 6,
169
- // Remove horizontal padding when the editor is closed or it won't fully disappear
170
- paddingLeft: isSideEditorOpen ? 6 : 0,
171
- paddingRight: isSideEditorOpen ? 6 : 0,
172
- transition: "all 0.2s ease-in-out",
173
- children: /*#__PURE__*/ jsxRuntime.jsx(FormLayout.FormLayout, {
174
- layout: documentLayoutResponse.edit.layout,
175
- document: documentResponse,
176
- hasBackground: false
177
- })
178
- }),
179
- /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Box, {
180
- position: "relative",
181
- flex: 1,
182
- height: "100%",
183
- overflow: "hidden",
184
- children: [
185
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
278
+ children: /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
279
+ direction: "column",
280
+ height: "100%",
281
+ alignItems: "stretch",
282
+ children: [
283
+ /*#__PURE__*/ jsxRuntime.jsx(Blocker.Blocker, {}),
284
+ /*#__PURE__*/ jsxRuntime.jsx(PreviewHeader.PreviewHeader, {}),
285
+ /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
286
+ flex: 1,
287
+ overflow: "auto",
288
+ alignItems: "stretch",
289
+ children: [
290
+ hasAdvancedPreview && /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
291
+ overflow: "auto",
292
+ width: isSideEditorOpen ? '50%' : 0,
293
+ borderWidth: "0 1px 0 0",
294
+ borderColor: "neutral150",
295
+ paddingTop: 6,
296
+ paddingBottom: 6,
297
+ // Remove horizontal padding when the editor is closed or it won't fully disappear
298
+ paddingLeft: isSideEditorOpen ? 6 : 0,
299
+ paddingRight: isSideEditorOpen ? 6 : 0,
300
+ transition: "all 0.2s ease-in-out",
301
+ children: /*#__PURE__*/ jsxRuntime.jsx(FormLayout.FormLayout, {
302
+ layout: documentLayoutResponse.edit.layout,
303
+ document: documentResponse,
304
+ hasBackground: false
305
+ })
306
+ }),
307
+ /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
308
+ direction: "column",
309
+ alignItems: "stretch",
310
+ flex: 1,
311
+ height: "100%",
312
+ overflow: "hidden",
313
+ children: [
314
+ /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
315
+ direction: "row",
316
+ background: "neutral0",
317
+ padding: 2,
318
+ borderWidth: "0 0 1px 0",
319
+ borderColor: "neutral150",
320
+ children: [
321
+ hasAdvancedPreview && /*#__PURE__*/ jsxRuntime.jsx(designSystem.IconButton, {
322
+ variant: "ghost",
323
+ label: formatMessage(isSideEditorOpen ? {
324
+ id: 'content-manager.preview.content.close-editor',
325
+ defaultMessage: 'Close editor'
326
+ } : {
327
+ id: 'content-manager.preview.content.open-editor',
328
+ defaultMessage: 'Open editor'
329
+ }),
330
+ onClick: ()=>setIsSideEditorOpen((prev)=>!prev),
331
+ children: /*#__PURE__*/ jsxRuntime.jsx(AnimatedArrow, {
332
+ $isSideEditorOpen: isSideEditorOpen
333
+ })
334
+ }),
335
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Flex, {
336
+ justifyContent: "center",
337
+ flex: 1,
338
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.SingleSelect, {
339
+ value: deviceName,
340
+ onChange: (name)=>setDeviceName(name.toString()),
341
+ "aria-label": formatMessage({
342
+ id: 'content-manager.preview.device.select',
343
+ defaultMessage: 'Select device type'
344
+ }),
345
+ children: DEVICES.map((deviceOption)=>/*#__PURE__*/ jsxRuntime.jsx(designSystem.SingleSelectOption, {
346
+ value: deviceOption.name,
347
+ children: formatMessage(deviceOption.label)
348
+ }, deviceOption.name))
349
+ })
350
+ })
351
+ ]
352
+ }),
353
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Flex, {
354
+ direction: "column",
355
+ justifyContent: "center",
356
+ background: "neutral0",
357
+ flex: 1,
358
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
186
359
  "data-testid": "preview-iframe",
187
360
  ref: iframeRef,
188
361
  src: previewUrl,
@@ -190,34 +363,23 @@ const PreviewPage = ()=>{
190
363
  id: 'content-manager.preview.panel.title',
191
364
  defaultMessage: 'Preview'
192
365
  }),
193
- width: "100%",
194
- height: "100%",
366
+ width: device.width,
367
+ height: device.height,
195
368
  borderWidth: 0,
196
369
  tag: "iframe"
197
- }, previewUrl),
198
- hasAdvancedPreview && /*#__PURE__*/ jsxRuntime.jsx(designSystem.IconButton, {
199
- variant: "tertiary",
200
- label: formatMessage(isSideEditorOpen ? {
201
- id: 'content-manager.preview.content.close-editor',
202
- defaultMessage: 'Close editor'
203
- } : {
204
- id: 'content-manager.preview.content.open-editor',
205
- defaultMessage: 'Open editor'
206
- }),
207
- onClick: ()=>setIsSideEditorOpen((prev)=>!prev),
208
- position: "absolute",
209
- top: 2,
210
- left: 2,
211
- children: /*#__PURE__*/ jsxRuntime.jsx(AnimatedArrow, {
212
- isSideEditorOpen: isSideEditorOpen
213
- })
214
- })
215
- ]
216
- })
217
- ]
218
- })
219
- ]
220
- })
370
+ }, previewUrl)
371
+ })
372
+ ]
373
+ })
374
+ ]
375
+ }),
376
+ /*#__PURE__*/ jsxRuntime.jsx(VisualEditingPopover, {
377
+ popoverField: popoverField,
378
+ setPopoverField: setPopoverField,
379
+ documentResponse: documentResponse
380
+ })
381
+ ]
382
+ })
221
383
  })
222
384
  })
223
385
  ]