@capillarytech/creatives-library 8.0.242-alpha.10 → 8.0.242-alpha.11

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 (256) hide show
  1. package/assets/Android.png +0 -0
  2. package/assets/iOS.png +0 -0
  3. package/config/app.js +1 -1
  4. package/constants/unified.js +2 -2
  5. package/initialReducer.js +0 -2
  6. package/package.json +1 -1
  7. package/services/api.js +5 -10
  8. package/services/tests/api.test.js +0 -18
  9. package/translations/en.json +4 -3
  10. package/utils/common.js +6 -5
  11. package/utils/commonUtils.js +1 -14
  12. package/utils/imageUrlUpload.js +141 -0
  13. package/utils/tests/commonUtil.test.js +0 -224
  14. package/utils/transformTemplateConfig.js +10 -0
  15. package/v2Components/CapDeviceContent/index.js +56 -61
  16. package/v2Components/CapImageUpload/constants.js +2 -0
  17. package/v2Components/CapImageUpload/index.js +65 -16
  18. package/v2Components/CapImageUpload/index.scss +4 -1
  19. package/v2Components/CapImageUpload/messages.js +5 -1
  20. package/v2Components/CapImageUrlUpload/constants.js +26 -0
  21. package/v2Components/CapImageUrlUpload/index.js +365 -0
  22. package/v2Components/CapImageUrlUpload/index.scss +35 -0
  23. package/v2Components/CapImageUrlUpload/messages.js +47 -0
  24. package/v2Components/CapTagList/index.js +1 -6
  25. package/v2Components/CapTagListWithInput/index.js +1 -5
  26. package/v2Components/CapTagListWithInput/messages.js +1 -1
  27. package/v2Components/CapWhatsappCTA/tests/index.test.js +0 -5
  28. package/v2Components/ErrorInfoNote/index.js +72 -412
  29. package/v2Components/ErrorInfoNote/messages.js +0 -22
  30. package/v2Components/ErrorInfoNote/style.scss +2 -279
  31. package/v2Components/HtmlEditor/HTMLEditor.js +91 -220
  32. package/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +133 -1132
  33. package/v2Components/HtmlEditor/__tests__/index.lazy.test.js +12 -17
  34. package/v2Components/HtmlEditor/_htmlEditor.scss +45 -107
  35. package/v2Components/HtmlEditor/_index.lazy.scss +1 -1
  36. package/v2Components/HtmlEditor/components/CodeEditorPane/_codeEditorPane.scss +101 -13
  37. package/v2Components/HtmlEditor/components/CodeEditorPane/index.js +139 -148
  38. package/v2Components/HtmlEditor/components/DeviceToggle/_deviceToggle.scss +1 -2
  39. package/v2Components/HtmlEditor/components/DeviceToggle/index.js +3 -3
  40. package/v2Components/HtmlEditor/components/EditorToolbar/_editorToolbar.scss +0 -9
  41. package/v2Components/HtmlEditor/components/EditorToolbar/index.js +1 -1
  42. package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +0 -22
  43. package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +7 -4
  44. package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +45 -35
  45. package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +3 -1
  46. package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
  47. package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +6 -7
  48. package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +6 -3
  49. package/v2Components/HtmlEditor/components/PreviewPane/index.js +11 -10
  50. package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
  51. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +72 -70
  52. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +31 -49
  53. package/v2Components/HtmlEditor/constants.js +20 -29
  54. package/v2Components/HtmlEditor/hooks/__tests__/useInAppContent.test.js +16 -373
  55. package/v2Components/HtmlEditor/hooks/useEditorContent.js +2 -5
  56. package/v2Components/HtmlEditor/hooks/useInAppContent.js +146 -88
  57. package/v2Components/HtmlEditor/index.js +1 -1
  58. package/v2Components/HtmlEditor/messages.js +85 -95
  59. package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +101 -99
  60. package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +25 -23
  61. package/v2Components/HtmlEditor/utils/validationAdapter.js +41 -34
  62. package/v2Components/MobilePushPreviewV2/index.js +7 -32
  63. package/v2Components/TemplatePreview/_templatePreview.scss +24 -44
  64. package/v2Components/TemplatePreview/index.js +32 -47
  65. package/v2Components/TemplatePreview/messages.js +0 -4
  66. package/v2Components/TestAndPreviewSlidebox/index.js +25 -31
  67. package/v2Containers/App/constants.js +5 -0
  68. package/v2Containers/BeeEditor/index.js +80 -82
  69. package/v2Containers/Cap/tests/__snapshots__/index.test.js.snap +4 -3
  70. package/v2Containers/CreativesContainer/SlideBoxContent.js +118 -148
  71. package/v2Containers/CreativesContainer/SlideBoxFooter.js +3 -9
  72. package/v2Containers/CreativesContainer/SlideBoxHeader.js +2 -2
  73. package/v2Containers/CreativesContainer/constants.js +2 -1
  74. package/v2Containers/CreativesContainer/index.js +41 -173
  75. package/v2Containers/CreativesContainer/messages.js +4 -4
  76. package/v2Containers/CreativesContainer/tests/SlideBoxContent.test.js +210 -0
  77. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +354 -38
  78. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +0 -36
  79. package/v2Containers/Email/actions.js +0 -7
  80. package/v2Containers/Email/constants.js +1 -5
  81. package/v2Containers/Email/index.js +0 -13
  82. package/v2Containers/Email/messages.js +0 -32
  83. package/v2Containers/Email/reducer.js +1 -12
  84. package/v2Containers/Email/sagas.js +6 -41
  85. package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +0 -2
  86. package/v2Containers/EmailWrapper/components/EmailWrapperView.js +7 -193
  87. package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +74 -40
  88. package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +67 -2
  89. package/v2Containers/EmailWrapper/constants.js +0 -2
  90. package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +67 -436
  91. package/v2Containers/EmailWrapper/index.js +23 -99
  92. package/v2Containers/EmailWrapper/messages.js +1 -61
  93. package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +214 -0
  94. package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +77 -111
  95. package/v2Containers/InApp/actions.js +0 -7
  96. package/v2Containers/InApp/constants.js +4 -20
  97. package/v2Containers/InApp/index.js +357 -801
  98. package/v2Containers/InApp/index.scss +3 -4
  99. package/v2Containers/InApp/messages.js +3 -7
  100. package/v2Containers/InApp/reducer.js +3 -21
  101. package/v2Containers/InApp/sagas.js +9 -29
  102. package/v2Containers/InApp/selectors.js +5 -25
  103. package/v2Containers/InApp/tests/index.test.js +50 -154
  104. package/v2Containers/InApp/tests/reducer.test.js +0 -34
  105. package/v2Containers/InApp/tests/sagas.test.js +9 -61
  106. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +12 -12
  107. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +8 -8
  108. package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +100 -77
  109. package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +72 -63
  110. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +184 -150
  111. package/v2Containers/SmsTrai/Create/tests/__snapshots__/index.test.js.snap +16 -12
  112. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +32 -28
  113. package/v2Containers/TagList/index.js +1 -67
  114. package/v2Containers/Templates/ChannelTypeIllustration.js +13 -1
  115. package/v2Containers/Templates/_templates.scss +202 -56
  116. package/v2Containers/Templates/actions.js +2 -1
  117. package/v2Containers/Templates/constants.js +1 -0
  118. package/v2Containers/Templates/index.js +278 -128
  119. package/v2Containers/Templates/messages.js +24 -4
  120. package/v2Containers/Templates/reducer.js +2 -0
  121. package/v2Containers/Templates/tests/index.test.js +10 -0
  122. package/v2Containers/TemplatesV2/index.js +8 -1
  123. package/v2Containers/TemplatesV2/messages.js +4 -0
  124. package/v2Containers/WebPush/Create/components/BrandIconSection.js +108 -0
  125. package/v2Containers/WebPush/Create/components/ButtonForm.js +172 -0
  126. package/v2Containers/WebPush/Create/components/ButtonItem.js +101 -0
  127. package/v2Containers/WebPush/Create/components/ButtonList.js +145 -0
  128. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.js +164 -0
  129. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.test.js +463 -0
  130. package/v2Containers/WebPush/Create/components/FormActions.js +54 -0
  131. package/v2Containers/WebPush/Create/components/FormActions.test.js +163 -0
  132. package/v2Containers/WebPush/Create/components/MediaSection.js +142 -0
  133. package/v2Containers/WebPush/Create/components/MediaSection.test.js +341 -0
  134. package/v2Containers/WebPush/Create/components/MessageSection.js +103 -0
  135. package/v2Containers/WebPush/Create/components/MessageSection.test.js +268 -0
  136. package/v2Containers/WebPush/Create/components/NotificationTitleSection.js +87 -0
  137. package/v2Containers/WebPush/Create/components/NotificationTitleSection.test.js +210 -0
  138. package/v2Containers/WebPush/Create/components/TemplateNameSection.js +54 -0
  139. package/v2Containers/WebPush/Create/components/TemplateNameSection.test.js +143 -0
  140. package/v2Containers/WebPush/Create/components/__snapshots__/ButtonsLinksSection.test.js.snap +86 -0
  141. package/v2Containers/WebPush/Create/components/__snapshots__/FormActions.test.js.snap +16 -0
  142. package/v2Containers/WebPush/Create/components/__snapshots__/MediaSection.test.js.snap +41 -0
  143. package/v2Containers/WebPush/Create/components/__snapshots__/MessageSection.test.js.snap +54 -0
  144. package/v2Containers/WebPush/Create/components/__snapshots__/NotificationTitleSection.test.js.snap +37 -0
  145. package/v2Containers/WebPush/Create/components/__snapshots__/TemplateNameSection.test.js.snap +21 -0
  146. package/v2Containers/WebPush/Create/components/_buttons.scss +246 -0
  147. package/v2Containers/WebPush/Create/components/tests/ButtonForm.test.js +554 -0
  148. package/v2Containers/WebPush/Create/components/tests/ButtonItem.test.js +607 -0
  149. package/v2Containers/WebPush/Create/components/tests/ButtonList.test.js +633 -0
  150. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonForm.test.js.snap +666 -0
  151. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonItem.test.js.snap +74 -0
  152. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonList.test.js.snap +78 -0
  153. package/v2Containers/WebPush/Create/hooks/useButtonManagement.js +138 -0
  154. package/v2Containers/WebPush/Create/hooks/useButtonManagement.test.js +406 -0
  155. package/v2Containers/WebPush/Create/hooks/useCharacterCount.js +30 -0
  156. package/v2Containers/WebPush/Create/hooks/useCharacterCount.test.js +151 -0
  157. package/v2Containers/WebPush/Create/hooks/useImageUpload.js +104 -0
  158. package/v2Containers/WebPush/Create/hooks/useImageUpload.test.js +538 -0
  159. package/v2Containers/WebPush/Create/hooks/useTagManagement.js +122 -0
  160. package/v2Containers/WebPush/Create/hooks/useTagManagement.test.js +633 -0
  161. package/v2Containers/WebPush/Create/index.js +1056 -0
  162. package/v2Containers/WebPush/Create/index.scss +134 -0
  163. package/v2Containers/WebPush/Create/messages.js +203 -0
  164. package/v2Containers/WebPush/Create/preview/DevicePreviewContent.js +228 -0
  165. package/v2Containers/WebPush/Create/preview/NotificationContainer.js +294 -0
  166. package/v2Containers/WebPush/Create/preview/PreviewContent.js +90 -0
  167. package/v2Containers/WebPush/Create/preview/PreviewControls.js +305 -0
  168. package/v2Containers/WebPush/Create/preview/PreviewDisclaimer.js +23 -0
  169. package/v2Containers/WebPush/Create/preview/WebPushPreview.js +150 -0
  170. package/v2Containers/WebPush/Create/preview/assets/Light.svg +53 -0
  171. package/v2Containers/WebPush/Create/preview/assets/Top.svg +5 -0
  172. package/v2Containers/WebPush/Create/preview/assets/android-arrow-down.svg +9 -0
  173. package/v2Containers/WebPush/Create/preview/assets/android-arrow-up.svg +9 -0
  174. package/v2Containers/WebPush/Create/preview/assets/chrome-icon.png +0 -0
  175. package/v2Containers/WebPush/Create/preview/assets/edge-icon.png +0 -0
  176. package/v2Containers/WebPush/Create/preview/assets/firefox-icon.svg +106 -0
  177. package/v2Containers/WebPush/Create/preview/assets/iOS.svg +26 -0
  178. package/v2Containers/WebPush/Create/preview/assets/macos-arrow-down-icon.svg +9 -0
  179. package/v2Containers/WebPush/Create/preview/assets/macos-triple-dot-icon.svg +9 -0
  180. package/v2Containers/WebPush/Create/preview/assets/opera-icon.svg +18 -0
  181. package/v2Containers/WebPush/Create/preview/assets/safari-icon.svg +29 -0
  182. package/v2Containers/WebPush/Create/preview/assets/windows-close-icon.svg +9 -0
  183. package/v2Containers/WebPush/Create/preview/assets/windows-triple-dot-icon.svg +9 -0
  184. package/v2Containers/WebPush/Create/preview/components/AndroidMobileChromeHeader.js +47 -0
  185. package/v2Containers/WebPush/Create/preview/components/AndroidMobileExpanded.js +141 -0
  186. package/v2Containers/WebPush/Create/preview/components/IOSHeader.js +45 -0
  187. package/v2Containers/WebPush/Create/preview/components/NotificationExpandedContent.js +68 -0
  188. package/v2Containers/WebPush/Create/preview/components/NotificationHeader.js +61 -0
  189. package/v2Containers/WebPush/Create/preview/components/WindowsChromeExpanded.js +99 -0
  190. package/v2Containers/WebPush/Create/preview/components/tests/AndroidMobileExpanded.test.js +733 -0
  191. package/v2Containers/WebPush/Create/preview/components/tests/WindowsChromeExpanded.test.js +571 -0
  192. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/AndroidMobileExpanded.test.js.snap +81 -0
  193. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/WindowsChromeExpanded.test.js.snap +81 -0
  194. package/v2Containers/WebPush/Create/preview/config/notificationMappings.js +50 -0
  195. package/v2Containers/WebPush/Create/preview/constants.js +637 -0
  196. package/v2Containers/WebPush/Create/preview/notification-container.scss +79 -0
  197. package/v2Containers/WebPush/Create/preview/preview.scss +351 -0
  198. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-chrome.scss +370 -0
  199. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-edge.scss +12 -0
  200. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-firefox.scss +12 -0
  201. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-opera.scss +12 -0
  202. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-chrome.scss +47 -0
  203. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-edge.scss +11 -0
  204. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-firefox.scss +11 -0
  205. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-opera.scss +11 -0
  206. package/v2Containers/WebPush/Create/preview/styles/_base.scss +207 -0
  207. package/v2Containers/WebPush/Create/preview/styles/_ios.scss +153 -0
  208. package/v2Containers/WebPush/Create/preview/styles/_ipados.scss +107 -0
  209. package/v2Containers/WebPush/Create/preview/styles/_macos-chrome.scss +101 -0
  210. package/v2Containers/WebPush/Create/preview/styles/_windows-chrome.scss +229 -0
  211. package/v2Containers/WebPush/Create/preview/tests/DevicePreviewContent.test.js +909 -0
  212. package/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +1081 -0
  213. package/v2Containers/WebPush/Create/preview/tests/PreviewControls.test.js +723 -0
  214. package/v2Containers/WebPush/Create/preview/tests/WebPushPreview.test.js +943 -0
  215. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/DevicePreviewContent.test.js.snap +131 -0
  216. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/NotificationContainer.test.js.snap +112 -0
  217. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/PreviewControls.test.js.snap +144 -0
  218. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/WebPushPreview.test.js.snap +129 -0
  219. package/v2Containers/WebPush/Create/utils/payloadBuilder.js +94 -0
  220. package/v2Containers/WebPush/Create/utils/payloadBuilder.test.js +390 -0
  221. package/v2Containers/WebPush/Create/utils/previewUtils.js +89 -0
  222. package/v2Containers/WebPush/Create/utils/urlValidation.js +115 -0
  223. package/v2Containers/WebPush/Create/utils/urlValidation.test.js +449 -0
  224. package/v2Containers/WebPush/Create/utils/validation.js +75 -0
  225. package/v2Containers/WebPush/Create/utils/validation.test.js +283 -0
  226. package/v2Containers/WebPush/actions.js +60 -0
  227. package/v2Containers/WebPush/constants.js +128 -0
  228. package/v2Containers/WebPush/index.js +2 -0
  229. package/v2Containers/WebPush/reducer.js +104 -0
  230. package/v2Containers/WebPush/sagas.js +119 -0
  231. package/v2Containers/WebPush/selectors.js +65 -0
  232. package/v2Containers/WebPush/tests/reducer.test.js +863 -0
  233. package/v2Containers/WebPush/tests/sagas.test.js +566 -0
  234. package/v2Containers/WebPush/tests/selectors.test.js +843 -0
  235. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +528 -431
  236. package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +0 -254
  237. package/v2Components/HtmlEditor/components/ValidationTabs/index.js +0 -362
  238. package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +0 -51
  239. package/v2Containers/BeePopupEditor/constants.js +0 -10
  240. package/v2Containers/BeePopupEditor/index.js +0 -193
  241. package/v2Containers/BeePopupEditor/tests/index.test.js +0 -627
  242. package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +0 -1046
  243. package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +0 -376
  244. package/v2Containers/InApp/__tests__/sagas.test.js +0 -363
  245. package/v2Containers/InApp/tests/selectors.test.js +0 -612
  246. package/v2Containers/InAppWrapper/components/InAppWrapperView.js +0 -162
  247. package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +0 -267
  248. package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +0 -9
  249. package/v2Containers/InAppWrapper/constants.js +0 -16
  250. package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +0 -473
  251. package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +0 -198
  252. package/v2Containers/InAppWrapper/index.js +0 -148
  253. package/v2Containers/InAppWrapper/messages.js +0 -49
  254. package/v2Containers/InappAdvance/index.js +0 -1099
  255. package/v2Containers/InappAdvance/index.scss +0 -10
  256. package/v2Containers/InappAdvance/tests/index.test.js +0 -448
@@ -0,0 +1,163 @@
1
+ import React from 'react';
2
+ import { mountWithIntl, shallowWithIntl } from '../../../../helpers/intl-enzym-test-helpers';
3
+ import FormActions from './FormActions';
4
+ import CapButton from '@capillarytech/cap-ui-library/CapButton';
5
+ import CapError from '@capillarytech/cap-ui-library/CapError';
6
+ import CapRow from '@capillarytech/cap-ui-library/CapRow';
7
+
8
+ describe('FormActions', () => {
9
+ const mockFormatMessage = jest.fn((message) => message.defaultMessage || message);
10
+ const mockOnSave = jest.fn();
11
+
12
+ const mockMessages = {
13
+ saveTemplate: {
14
+ defaultMessage: 'Save Template',
15
+ },
16
+ };
17
+
18
+ const defaultProps = {
19
+ onSave: mockOnSave,
20
+ isSaveDisabled: false,
21
+ errorText: '',
22
+ accountErrorText: '',
23
+ formatMessage: mockFormatMessage,
24
+ messages: mockMessages,
25
+ };
26
+
27
+ beforeEach(() => {
28
+ jest.clearAllMocks();
29
+ });
30
+
31
+ describe('Rendering', () => {
32
+ it('should render correctly with default props', () => {
33
+ const wrapper = shallowWithIntl(<FormActions {...defaultProps} />);
34
+ expect(wrapper).toMatchSnapshot();
35
+ });
36
+
37
+ it('should render save button', () => {
38
+ const wrapper = mountWithIntl(<FormActions {...defaultProps} />);
39
+ const saveButton = wrapper.find(CapButton);
40
+ expect(saveButton.exists()).toBe(true);
41
+ expect(saveButton.prop('type')).toBe('primary');
42
+ expect(saveButton.prop('disabled')).toBe(false);
43
+ });
44
+
45
+ it('should render save button with correct text', () => {
46
+ const wrapper = mountWithIntl(<FormActions {...defaultProps} />);
47
+ const saveButton = wrapper.find(CapButton);
48
+ expect(saveButton.exists()).toBe(true);
49
+ expect(mockFormatMessage).toHaveBeenCalledWith(mockMessages.saveTemplate);
50
+ });
51
+
52
+ it('should disable save button when isSaveDisabled is true', () => {
53
+ const wrapper = mountWithIntl(<FormActions {...defaultProps} isSaveDisabled={true} />);
54
+ const saveButton = wrapper.find(CapButton);
55
+ expect(saveButton.prop('disabled')).toBe(true);
56
+ });
57
+
58
+ it('should enable save button when isSaveDisabled is false', () => {
59
+ const wrapper = mountWithIntl(<FormActions {...defaultProps} isSaveDisabled={false} />);
60
+ const saveButton = wrapper.find(CapButton);
61
+ expect(saveButton.prop('disabled')).toBe(false);
62
+ });
63
+ });
64
+
65
+ describe('Error Messages', () => {
66
+ it('should not render error text when errorText is empty', () => {
67
+ const wrapper = mountWithIntl(<FormActions {...defaultProps} errorText="" />);
68
+ const errorRows = wrapper.find(CapRow).findWhere((node) => {
69
+ const error = node.find(CapError);
70
+ return error.exists() && error.prop('className') === 'webpush-template-error';
71
+ });
72
+ expect(errorRows.length).toBe(0);
73
+ });
74
+
75
+ it('should render error text when errorText is provided', () => {
76
+ const errorText = 'Template save failed';
77
+ const wrapper = mountWithIntl(<FormActions {...defaultProps} errorText={errorText} />);
78
+ const error = wrapper.find(CapError).find('.webpush-template-error');
79
+ expect(error.exists()).toBe(true);
80
+ expect(error.length).toBeGreaterThan(0);
81
+ });
82
+
83
+ it('should not render account error text when accountErrorText is empty', () => {
84
+ const wrapper = mountWithIntl(<FormActions {...defaultProps} accountErrorText="" />);
85
+ const errorRows = wrapper.find(CapRow).findWhere((node) => {
86
+ const error = node.find(CapError);
87
+ return error.exists() && error.prop('className') === 'webpush-template-account-error';
88
+ });
89
+ expect(errorRows.length).toBe(0);
90
+ });
91
+
92
+ it('should render account error text when accountErrorText is provided', () => {
93
+ const accountErrorText = 'Account error occurred';
94
+ const wrapper = mountWithIntl(
95
+ <FormActions {...defaultProps} accountErrorText={accountErrorText} />
96
+ );
97
+ const error = wrapper.find(CapError).find('.webpush-template-account-error');
98
+ expect(error.exists()).toBe(true);
99
+ expect(error.length).toBeGreaterThan(0);
100
+ });
101
+
102
+ it('should render both error texts when both are provided', () => {
103
+ const wrapper = mountWithIntl(
104
+ <FormActions
105
+ {...defaultProps}
106
+ errorText="Template error"
107
+ accountErrorText="Account error"
108
+ />
109
+ );
110
+ const templateError = wrapper.find(CapError).find('.webpush-template-error');
111
+ const accountError = wrapper.find(CapError).find('.webpush-template-account-error');
112
+ expect(templateError.exists()).toBe(true);
113
+ expect(accountError.exists()).toBe(true);
114
+ });
115
+ });
116
+
117
+ describe('Save Button Interaction', () => {
118
+ it('should call onSave when save button is clicked', () => {
119
+ const wrapper = mountWithIntl(<FormActions {...defaultProps} />);
120
+ const saveButton = wrapper.find(CapButton);
121
+ saveButton.simulate('click');
122
+ expect(mockOnSave).toHaveBeenCalledTimes(1);
123
+ });
124
+
125
+ it('should not call onSave when button is disabled and clicked', () => {
126
+ const wrapper = mountWithIntl(<FormActions {...defaultProps} isSaveDisabled={true} />);
127
+ const saveButton = wrapper.find(CapButton);
128
+ saveButton.simulate('click');
129
+ // Even if disabled, the click event might fire, but the button should be disabled
130
+ expect(saveButton.prop('disabled')).toBe(true);
131
+ expect(defaultProps.onSave).not.toHaveBeenCalled();
132
+ });
133
+ });
134
+
135
+ describe('Default Props', () => {
136
+ it('should use default errorText when not provided', () => {
137
+ const wrapper = mountWithIntl(
138
+ <FormActions
139
+ onSave={mockOnSave}
140
+ isSaveDisabled={false}
141
+ formatMessage={mockFormatMessage}
142
+ messages={mockMessages}
143
+ />
144
+ );
145
+ const error = wrapper.find(CapError).find('.webpush-template-error');
146
+ expect(error.exists()).toBe(false);
147
+ });
148
+
149
+ it('should use default accountErrorText when not provided', () => {
150
+ const wrapper = mountWithIntl(
151
+ <FormActions
152
+ onSave={mockOnSave}
153
+ isSaveDisabled={false}
154
+ formatMessage={mockFormatMessage}
155
+ messages={mockMessages}
156
+ />
157
+ );
158
+ const error = wrapper.find(CapError).find('.webpush-template-account-error');
159
+ expect(error.exists()).toBe(false);
160
+ });
161
+ });
162
+ });
163
+
@@ -0,0 +1,142 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { FormattedMessage } from 'react-intl';
4
+ import CapRow from '@capillarytech/cap-ui-library/CapRow';
5
+ import CapHeading from '@capillarytech/cap-ui-library/CapHeading';
6
+ import CapSelect from '@capillarytech/cap-ui-library/CapSelect';
7
+ import CapDivider from '@capillarytech/cap-ui-library/CapDivider';
8
+ import CapImageUpload from '../../../../v2Components/CapImageUpload';
9
+ import CapImageUrlUpload from '../../../../v2Components/CapImageUrlUpload';
10
+ import { WEBPUSH } from '../../../CreativesContainer/constants';
11
+ import {
12
+ WEBPUSH_MEDIA_TYPES,
13
+ WEBPUSH_MEDIA_TYPES_OPTIONS,
14
+ ALLOWED_IMAGE_EXTENSIONS_REGEX,
15
+ WEBPUSH_IMG_SIZE,
16
+ WEBPUSH_RECOMMENDED_DIMENSIONS,
17
+ IMAGE_UPLOAD_METHODS,
18
+ } from '../../constants';
19
+
20
+ /**
21
+ * MediaSection component - Media type selection and image upload
22
+ */
23
+ export const MediaSection = ({
24
+ mediaType,
25
+ onMediaTypeChange,
26
+ imageUpload,
27
+ isLocked,
28
+ isAnyUploadActive,
29
+ formatMessage,
30
+ messages,
31
+ webPush,
32
+ isFullMode,
33
+ }) => {
34
+ const {
35
+ uploadMethod,
36
+ imageSrc,
37
+ imageUrl,
38
+ isValidating,
39
+ isUploading,
40
+ uploadAsset,
41
+ setUpdateImageSrc,
42
+ updateOnReUpload,
43
+ handleUrlChange,
44
+ handleValidationStateChange,
45
+ handleUploadStateChange,
46
+ } = imageUpload;
47
+
48
+ const isImageFieldActive = isValidating || isUploading;
49
+
50
+ return (
51
+ <>
52
+ <CapRow className="creatives-webpush-media">
53
+ <CapHeading type="h4" className="webpush-media-type">
54
+ <FormattedMessage {...messages.mediaType} />
55
+ </CapHeading>
56
+ <CapSelect.CapCustomSelect
57
+ width="100%"
58
+ className="margin-t-4"
59
+ options={WEBPUSH_MEDIA_TYPES_OPTIONS}
60
+ value={mediaType}
61
+ onChange={onMediaTypeChange}
62
+ disabled={isAnyUploadActive}
63
+ />
64
+ </CapRow>
65
+ {mediaType === WEBPUSH_MEDIA_TYPES.IMAGE && (
66
+ <>
67
+ {uploadMethod === IMAGE_UPLOAD_METHODS.UPLOAD_IMAGE && (
68
+ <CapRow
69
+ className="webpush-image-upload-section"
70
+ style={isLocked ? { pointerEvents: 'none', opacity: 0.5 } : undefined}
71
+ aria-disabled={isLocked}
72
+ >
73
+ <CapImageUpload
74
+ allowedExtensionsRegex={ALLOWED_IMAGE_EXTENSIONS_REGEX}
75
+ imgSize={WEBPUSH_IMG_SIZE}
76
+ uploadAsset={uploadAsset}
77
+ isFullMode={isFullMode}
78
+ imageSrc={imageSrc}
79
+ updateImageSrc={setUpdateImageSrc}
80
+ updateOnReUpload={updateOnReUpload}
81
+ index={0}
82
+ className="cap-custom-image-upload"
83
+ key="webpush-uploaded-image"
84
+ imageData={webPush}
85
+ channel={WEBPUSH}
86
+ showReUploadButton
87
+ recommendedDimensions={WEBPUSH_RECOMMENDED_DIMENSIONS}
88
+ />
89
+ </CapRow>
90
+ )}
91
+ {uploadMethod === IMAGE_UPLOAD_METHODS.ADD_IMAGE_URL && (
92
+ <CapRow
93
+ className="webpush-image-url-section"
94
+ style={isLocked ? { pointerEvents: 'none', opacity: 0.5 } : undefined}
95
+ aria-disabled={isLocked}
96
+ >
97
+ <CapImageUrlUpload
98
+ uploadAsset={uploadAsset}
99
+ imgSize={WEBPUSH_IMG_SIZE}
100
+ recommendedDimensions={WEBPUSH_RECOMMENDED_DIMENSIONS}
101
+ sizeLabel={formatMessage(messages.sizeLimit)}
102
+ formatLabel={formatMessage(messages.formatTypes)}
103
+ imageUrl={imageUrl}
104
+ imageSrc={imageSrc}
105
+ onUrlChange={handleUrlChange}
106
+ onValidationStateChange={handleValidationStateChange}
107
+ onUploadStateChange={handleUploadStateChange}
108
+ isExternalUploading={isImageFieldActive}
109
+ disabled={isLocked}
110
+ className="webpush-image-url-upload"
111
+ fileNamePrefix="webpush-image"
112
+ />
113
+ </CapRow>
114
+ )}
115
+ </>
116
+ )}
117
+ <CapDivider />
118
+ </>
119
+ );
120
+ };
121
+
122
+ MediaSection.propTypes = {
123
+ mediaType: PropTypes.string.isRequired,
124
+ onMediaTypeChange: PropTypes.func.isRequired,
125
+ imageUpload: PropTypes.object.isRequired,
126
+ isLocked: PropTypes.bool,
127
+ isAnyUploadActive: PropTypes.bool,
128
+ formatMessage: PropTypes.func.isRequired,
129
+ messages: PropTypes.object.isRequired,
130
+ webPush: PropTypes.object,
131
+ isFullMode: PropTypes.bool,
132
+ };
133
+
134
+ MediaSection.defaultProps = {
135
+ isLocked: false,
136
+ isAnyUploadActive: false,
137
+ webPush: {},
138
+ isFullMode: true,
139
+ };
140
+
141
+ export default MediaSection;
142
+
@@ -0,0 +1,341 @@
1
+ import React from 'react';
2
+ import { mountWithIntl, shallowWithIntl } from '../../../../helpers/intl-enzym-test-helpers';
3
+ import MediaSection from './MediaSection';
4
+ import CapRow from '@capillarytech/cap-ui-library/CapRow';
5
+ import CapHeading from '@capillarytech/cap-ui-library/CapHeading';
6
+ import CapSelect from '@capillarytech/cap-ui-library/CapSelect';
7
+ import CapDivider from '@capillarytech/cap-ui-library/CapDivider';
8
+ import {
9
+ WEBPUSH_MEDIA_TYPES,
10
+ IMAGE_UPLOAD_METHODS,
11
+ } from '../../constants';
12
+
13
+ // Mock CapImageUpload
14
+ jest.mock('../../../../v2Components/CapImageUpload', () => {
15
+ const React = require('react');
16
+ return function MockCapImageUpload(props) {
17
+ return (
18
+ <div data-testid="cap-image-upload" className="cap-image-upload-mock">
19
+ <div>CapImageUpload</div>
20
+ <div>imageSrc: {props.imageSrc}</div>
21
+ <div>channel: {props.channel}</div>
22
+ </div>
23
+ );
24
+ };
25
+ });
26
+
27
+ // Mock CapImageUrlUpload
28
+ jest.mock('../../../../v2Components/CapImageUrlUpload', () => {
29
+ const React = require('react');
30
+ return function MockCapImageUrlUpload(props) {
31
+ return (
32
+ <div data-testid="cap-image-url-upload" className="cap-image-url-upload-mock">
33
+ <div>CapImageUrlUpload</div>
34
+ <div>imageUrl: {props.imageUrl}</div>
35
+ <div>imageSrc: {props.imageSrc}</div>
36
+ <div>disabled: {props.disabled ? 'true' : 'false'}</div>
37
+ </div>
38
+ );
39
+ };
40
+ });
41
+
42
+ describe('MediaSection', () => {
43
+ const mockFormatMessage = jest.fn((message) => message?.defaultMessage || message?.id || message);
44
+ const mockOnMediaTypeChange = jest.fn();
45
+
46
+ const mockMessages = {
47
+ mediaType: {
48
+ id: 'app.webpush.mediaType',
49
+ defaultMessage: 'Media Type',
50
+ },
51
+ sizeLimit: {
52
+ id: 'app.webpush.sizeLimit',
53
+ defaultMessage: 'Size limit',
54
+ },
55
+ formatTypes: {
56
+ id: 'app.webpush.formatTypes',
57
+ defaultMessage: 'Format types',
58
+ },
59
+ };
60
+
61
+ const mockImageUpload = {
62
+ uploadMethod: IMAGE_UPLOAD_METHODS.UPLOAD_IMAGE,
63
+ imageSrc: '',
64
+ imageUrl: '',
65
+ isValidating: false,
66
+ isUploading: false,
67
+ uploadAsset: jest.fn(),
68
+ setUpdateImageSrc: jest.fn(),
69
+ updateOnReUpload: jest.fn(),
70
+ handleUrlChange: jest.fn(),
71
+ handleValidationStateChange: jest.fn(),
72
+ handleUploadStateChange: jest.fn(),
73
+ };
74
+
75
+ const defaultProps = {
76
+ mediaType: WEBPUSH_MEDIA_TYPES.NONE,
77
+ onMediaTypeChange: mockOnMediaTypeChange,
78
+ imageUpload: mockImageUpload,
79
+ isLocked: false,
80
+ isAnyUploadActive: false,
81
+ formatMessage: mockFormatMessage,
82
+ messages: mockMessages,
83
+ webPush: {},
84
+ isFullMode: true,
85
+ };
86
+
87
+ beforeEach(() => {
88
+ jest.clearAllMocks();
89
+ });
90
+
91
+ describe('Rendering', () => {
92
+ it('should render correctly with default props', () => {
93
+ const wrapper = shallowWithIntl(<MediaSection {...defaultProps} />);
94
+ expect(wrapper).toMatchSnapshot();
95
+ });
96
+
97
+ it('should render main container with correct class', () => {
98
+ const wrapper = mountWithIntl(<MediaSection {...defaultProps} />);
99
+ const container = wrapper.find('.creatives-webpush-media');
100
+ expect(container.exists()).toBe(true);
101
+ });
102
+
103
+ it('should render heading', () => {
104
+ const wrapper = mountWithIntl(<MediaSection {...defaultProps} />);
105
+ const heading = wrapper.find(CapHeading).find('.webpush-media-type');
106
+ expect(heading.exists()).toBe(true);
107
+ });
108
+
109
+ it('should render CapSelect.CapCustomSelect with correct props', () => {
110
+ const wrapper = mountWithIntl(<MediaSection {...defaultProps} />);
111
+ const select = wrapper.find(CapSelect.CapCustomSelect);
112
+ expect(select.exists()).toBe(true);
113
+ expect(select.prop('width')).toBe('100%');
114
+ expect(select.prop('className')).toBe('margin-t-4');
115
+ expect(select.prop('value')).toBe(WEBPUSH_MEDIA_TYPES.NONE);
116
+ expect(select.prop('disabled')).toBe(false);
117
+ });
118
+
119
+ it('should render Divider', () => {
120
+ const wrapper = mountWithIntl(<MediaSection {...defaultProps} />);
121
+ const divider = wrapper.find(CapDivider);
122
+ expect(divider.exists()).toBe(true);
123
+ });
124
+ });
125
+
126
+ describe('Media Type Selection', () => {
127
+ it('should call onMediaTypeChange when select changes', () => {
128
+ const wrapper = mountWithIntl(<MediaSection {...defaultProps} />);
129
+ const select = wrapper.find(CapSelect.CapCustomSelect);
130
+ select.prop('onChange')(WEBPUSH_MEDIA_TYPES.IMAGE);
131
+ expect(mockOnMediaTypeChange).toHaveBeenCalledWith(WEBPUSH_MEDIA_TYPES.IMAGE);
132
+ });
133
+
134
+ it('should disable select when isAnyUploadActive is true', () => {
135
+ const wrapper = mountWithIntl(
136
+ <MediaSection {...defaultProps} isAnyUploadActive={true} />
137
+ );
138
+ const select = wrapper.find(CapSelect.CapCustomSelect);
139
+ expect(select.prop('disabled')).toBe(true);
140
+ });
141
+ });
142
+
143
+ describe('Image Upload - UPLOAD_IMAGE Method', () => {
144
+ it('should render CapImageUpload when mediaType is IMAGE and uploadMethod is UPLOAD_IMAGE', () => {
145
+ const wrapper = mountWithIntl(
146
+ <MediaSection
147
+ {...defaultProps}
148
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
149
+ imageUpload={{
150
+ ...mockImageUpload,
151
+ uploadMethod: IMAGE_UPLOAD_METHODS.UPLOAD_IMAGE,
152
+ imageSrc: 'path/to/image.jpg',
153
+ }}
154
+ />
155
+ );
156
+ const imageUpload = wrapper.find('[data-testid="cap-image-upload"]');
157
+ expect(imageUpload.exists()).toBe(true);
158
+ });
159
+
160
+ it('should not render CapImageUpload when mediaType is NONE', () => {
161
+ const wrapper = mountWithIntl(<MediaSection {...defaultProps} />);
162
+ const imageUpload = wrapper.find('[data-testid="cap-image-upload"]');
163
+ expect(imageUpload.exists()).toBe(false);
164
+ });
165
+
166
+ it('should apply locked styles when isLocked is true', () => {
167
+ const wrapper = mountWithIntl(
168
+ <MediaSection
169
+ {...defaultProps}
170
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
171
+ isLocked={true}
172
+ />
173
+ );
174
+ const uploadSection = wrapper.find('.webpush-image-upload-section').first();
175
+ expect(uploadSection.exists()).toBe(true);
176
+ expect(uploadSection.prop('aria-disabled')).toBe(true);
177
+ });
178
+
179
+ it('should not apply locked styles when isLocked is false', () => {
180
+ const wrapper = mountWithIntl(
181
+ <MediaSection
182
+ {...defaultProps}
183
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
184
+ isLocked={false}
185
+ />
186
+ );
187
+ const uploadSection = wrapper.find('.webpush-image-upload-section');
188
+ expect(uploadSection.exists()).toBe(true);
189
+ });
190
+ });
191
+
192
+ describe('Image Upload - ADD_IMAGE_URL Method', () => {
193
+ it('should render CapImageUrlUpload when mediaType is IMAGE and uploadMethod is ADD_IMAGE_URL', () => {
194
+ const wrapper = mountWithIntl(
195
+ <MediaSection
196
+ {...defaultProps}
197
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
198
+ imageUpload={{
199
+ ...mockImageUpload,
200
+ uploadMethod: IMAGE_UPLOAD_METHODS.ADD_IMAGE_URL,
201
+ imageUrl: 'https://example.com/image.jpg',
202
+ }}
203
+ />
204
+ );
205
+ const imageUrlUpload = wrapper.find('[data-testid="cap-image-url-upload"]');
206
+ expect(imageUrlUpload.exists()).toBe(true);
207
+ });
208
+
209
+ it('should not render CapImageUrlUpload when mediaType is NONE', () => {
210
+ const wrapper = mountWithIntl(<MediaSection {...defaultProps} />);
211
+ const imageUrlUpload = wrapper.find('[data-testid="cap-image-url-upload"]');
212
+ expect(imageUrlUpload.exists()).toBe(false);
213
+ });
214
+
215
+ it('should apply locked styles when isLocked is true', () => {
216
+ const wrapper = mountWithIntl(
217
+ <MediaSection
218
+ {...defaultProps}
219
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
220
+ imageUpload={{
221
+ ...mockImageUpload,
222
+ uploadMethod: IMAGE_UPLOAD_METHODS.ADD_IMAGE_URL,
223
+ }}
224
+ isLocked={true}
225
+ />
226
+ );
227
+ const urlSection = wrapper.find('.webpush-image-url-section').first();
228
+ expect(urlSection.exists()).toBe(true);
229
+ expect(urlSection.prop('aria-disabled')).toBe(true);
230
+ });
231
+
232
+ it('should pass disabled prop to CapImageUrlUpload when isLocked is true', () => {
233
+ const wrapper = mountWithIntl(
234
+ <MediaSection
235
+ {...defaultProps}
236
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
237
+ imageUpload={{
238
+ ...mockImageUpload,
239
+ uploadMethod: IMAGE_UPLOAD_METHODS.ADD_IMAGE_URL,
240
+ }}
241
+ isLocked={true}
242
+ />
243
+ );
244
+ const imageUrlUpload = wrapper.find('[data-testid="cap-image-url-upload"]');
245
+ expect(imageUrlUpload.exists()).toBe(true);
246
+ });
247
+ });
248
+
249
+ describe('Image Upload State', () => {
250
+ it('should set isImageFieldActive when isValidating is true', () => {
251
+ const wrapper = mountWithIntl(
252
+ <MediaSection
253
+ {...defaultProps}
254
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
255
+ imageUpload={{
256
+ ...mockImageUpload,
257
+ uploadMethod: IMAGE_UPLOAD_METHODS.ADD_IMAGE_URL,
258
+ isValidating: true,
259
+ }}
260
+ />
261
+ );
262
+ const imageUrlUpload = wrapper.find('[data-testid="cap-image-url-upload"]');
263
+ expect(imageUrlUpload.exists()).toBe(true);
264
+ });
265
+
266
+ it('should set isImageFieldActive when isUploading is true', () => {
267
+ const wrapper = mountWithIntl(
268
+ <MediaSection
269
+ {...defaultProps}
270
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
271
+ imageUpload={{
272
+ ...mockImageUpload,
273
+ uploadMethod: IMAGE_UPLOAD_METHODS.ADD_IMAGE_URL,
274
+ isUploading: true,
275
+ }}
276
+ />
277
+ );
278
+ const imageUrlUpload = wrapper.find('[data-testid="cap-image-url-upload"]');
279
+ expect(imageUrlUpload.exists()).toBe(true);
280
+ });
281
+ });
282
+
283
+ describe('Default Props', () => {
284
+ it('should use default isLocked when not provided', () => {
285
+ const wrapper = mountWithIntl(
286
+ <MediaSection
287
+ mediaType={WEBPUSH_MEDIA_TYPES.NONE}
288
+ onMediaTypeChange={mockOnMediaTypeChange}
289
+ imageUpload={mockImageUpload}
290
+ formatMessage={mockFormatMessage}
291
+ messages={mockMessages}
292
+ />
293
+ );
294
+ const select = wrapper.find(CapSelect.CapCustomSelect);
295
+ expect(select.prop('disabled')).toBe(false);
296
+ });
297
+
298
+ it('should use default isAnyUploadActive when not provided', () => {
299
+ const wrapper = mountWithIntl(
300
+ <MediaSection
301
+ mediaType={WEBPUSH_MEDIA_TYPES.NONE}
302
+ onMediaTypeChange={mockOnMediaTypeChange}
303
+ imageUpload={mockImageUpload}
304
+ formatMessage={mockFormatMessage}
305
+ messages={mockMessages}
306
+ />
307
+ );
308
+ const select = wrapper.find(CapSelect.CapCustomSelect);
309
+ expect(select.prop('disabled')).toBe(false);
310
+ });
311
+
312
+ it('should use default webPush when not provided', () => {
313
+ const wrapper = mountWithIntl(
314
+ <MediaSection
315
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
316
+ onMediaTypeChange={mockOnMediaTypeChange}
317
+ imageUpload={mockImageUpload}
318
+ formatMessage={mockFormatMessage}
319
+ messages={mockMessages}
320
+ />
321
+ );
322
+ const imageUpload = wrapper.find('[data-testid="cap-image-upload"]');
323
+ expect(imageUpload.exists()).toBe(true);
324
+ });
325
+
326
+ it('should use default isFullMode when not provided', () => {
327
+ const wrapper = mountWithIntl(
328
+ <MediaSection
329
+ mediaType={WEBPUSH_MEDIA_TYPES.IMAGE}
330
+ onMediaTypeChange={mockOnMediaTypeChange}
331
+ imageUpload={mockImageUpload}
332
+ formatMessage={mockFormatMessage}
333
+ messages={mockMessages}
334
+ />
335
+ );
336
+ const imageUpload = wrapper.find('[data-testid="cap-image-upload"]');
337
+ expect(imageUpload.exists()).toBe(true);
338
+ });
339
+ });
340
+ });
341
+