@capillarytech/creatives-library 8.0.250-alpha.2 → 8.0.251

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 (276) hide show
  1. package/assets/Android.png +0 -0
  2. package/assets/iOS.png +0 -0
  3. package/constants/unified.js +1 -3
  4. package/initialReducer.js +0 -2
  5. package/package.json +1 -1
  6. package/services/api.js +0 -15
  7. package/services/tests/api.test.js +0 -34
  8. package/translations/en.json +3 -4
  9. package/utils/common.js +0 -11
  10. package/utils/commonUtils.js +5 -28
  11. package/utils/tests/commonUtil.test.js +0 -224
  12. package/utils/tests/transformerUtils.test.js +0 -297
  13. package/utils/transformTemplateConfig.js +10 -0
  14. package/utils/transformerUtils.js +0 -40
  15. package/v2Components/CapDeviceContent/index.js +56 -61
  16. package/v2Components/CapImageUpload/constants.js +0 -2
  17. package/v2Components/CapImageUpload/index.js +16 -65
  18. package/v2Components/CapImageUpload/index.scss +1 -4
  19. package/v2Components/CapImageUpload/messages.js +1 -5
  20. package/v2Components/CapTagList/index.js +1 -6
  21. package/v2Components/CapTagListWithInput/index.js +1 -5
  22. package/v2Components/CapTagListWithInput/messages.js +1 -1
  23. package/v2Components/CapWhatsappCTA/tests/index.test.js +0 -5
  24. package/v2Components/ErrorInfoNote/index.js +72 -455
  25. package/v2Components/ErrorInfoNote/messages.js +6 -36
  26. package/v2Components/ErrorInfoNote/style.scss +4 -280
  27. package/v2Components/FormBuilder/tests/index.test.js +4 -13
  28. package/v2Components/HtmlEditor/HTMLEditor.js +94 -547
  29. package/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +133 -1358
  30. package/v2Components/HtmlEditor/__tests__/index.lazy.test.js +16 -27
  31. package/v2Components/HtmlEditor/_htmlEditor.scss +45 -108
  32. package/v2Components/HtmlEditor/_index.lazy.scss +1 -1
  33. package/v2Components/HtmlEditor/components/CodeEditorPane/_codeEditorPane.scss +101 -22
  34. package/v2Components/HtmlEditor/components/CodeEditorPane/index.js +140 -146
  35. package/v2Components/HtmlEditor/components/DeviceToggle/_deviceToggle.scss +1 -2
  36. package/v2Components/HtmlEditor/components/DeviceToggle/index.js +3 -3
  37. package/v2Components/HtmlEditor/components/EditorToolbar/_editorToolbar.scss +0 -9
  38. package/v2Components/HtmlEditor/components/EditorToolbar/index.js +1 -1
  39. package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +0 -22
  40. package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +7 -4
  41. package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +45 -35
  42. package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +3 -1
  43. package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
  44. package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +6 -7
  45. package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +6 -3
  46. package/v2Components/HtmlEditor/components/PreviewPane/index.js +34 -24
  47. package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
  48. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +152 -0
  49. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +31 -49
  50. package/v2Components/HtmlEditor/components/ValidationPanel/_validationPanel.scss +34 -50
  51. package/v2Components/HtmlEditor/components/ValidationPanel/index.js +41 -70
  52. package/v2Components/HtmlEditor/constants.js +20 -42
  53. package/v2Components/HtmlEditor/hooks/__tests__/useInAppContent.test.js +16 -373
  54. package/v2Components/HtmlEditor/hooks/useEditorContent.js +2 -5
  55. package/v2Components/HtmlEditor/hooks/useInAppContent.js +146 -88
  56. package/v2Components/HtmlEditor/hooks/useValidation.js +53 -189
  57. package/v2Components/HtmlEditor/index.js +1 -1
  58. package/v2Components/HtmlEditor/messages.js +85 -95
  59. package/v2Components/HtmlEditor/utils/__tests__/htmlValidator.enhanced.test.js +45 -94
  60. package/v2Components/HtmlEditor/utils/__tests__/validationAdapter.test.js +0 -134
  61. package/v2Components/HtmlEditor/utils/contentSanitizer.js +41 -40
  62. package/v2Components/HtmlEditor/utils/htmlValidator.js +72 -71
  63. package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +102 -134
  64. package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +25 -23
  65. package/v2Components/HtmlEditor/utils/validationAdapter.js +41 -66
  66. package/v2Components/MobilePushPreviewV2/index.js +7 -32
  67. package/v2Components/TemplatePreview/_templatePreview.scss +24 -55
  68. package/v2Components/TemplatePreview/index.js +32 -47
  69. package/v2Components/TemplatePreview/messages.js +0 -4
  70. package/v2Components/TestAndPreviewSlidebox/_testAndPreviewSlidebox.scss +0 -1
  71. package/v2Containers/App/constants.js +0 -5
  72. package/v2Containers/BeeEditor/index.js +90 -172
  73. package/v2Containers/Cap/tests/__snapshots__/index.test.js.snap +3 -4
  74. package/v2Containers/CreativesContainer/SlideBoxContent.js +53 -184
  75. package/v2Containers/CreativesContainer/SlideBoxFooter.js +13 -163
  76. package/v2Containers/CreativesContainer/SlideBoxHeader.js +1 -3
  77. package/v2Containers/CreativesContainer/constants.js +0 -4
  78. package/v2Containers/CreativesContainer/index.js +46 -407
  79. package/v2Containers/CreativesContainer/messages.js +0 -12
  80. package/v2Containers/CreativesContainer/tests/SlideBoxContent.test.js +0 -210
  81. package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +2 -11
  82. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +50 -342
  83. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +0 -106
  84. package/v2Containers/Email/actions.js +0 -7
  85. package/v2Containers/Email/constants.js +1 -5
  86. package/v2Containers/Email/index.js +29 -234
  87. package/v2Containers/Email/messages.js +0 -32
  88. package/v2Containers/Email/reducer.js +1 -12
  89. package/v2Containers/Email/sagas.js +7 -61
  90. package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +0 -2
  91. package/v2Containers/Email/tests/reducer.test.js +0 -46
  92. package/v2Containers/Email/tests/sagas.test.js +29 -320
  93. package/v2Containers/EmailWrapper/components/EmailWrapperView.js +19 -207
  94. package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +74 -40
  95. package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +67 -2
  96. package/v2Containers/EmailWrapper/constants.js +0 -2
  97. package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +77 -629
  98. package/v2Containers/EmailWrapper/index.js +23 -103
  99. package/v2Containers/EmailWrapper/messages.js +1 -61
  100. package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +214 -0
  101. package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +77 -594
  102. package/v2Containers/InApp/actions.js +0 -7
  103. package/v2Containers/InApp/constants.js +4 -20
  104. package/v2Containers/InApp/index.js +359 -802
  105. package/v2Containers/InApp/index.scss +3 -4
  106. package/v2Containers/InApp/messages.js +3 -7
  107. package/v2Containers/InApp/reducer.js +3 -21
  108. package/v2Containers/InApp/sagas.js +9 -29
  109. package/v2Containers/InApp/selectors.js +5 -25
  110. package/v2Containers/InApp/tests/index.test.js +50 -154
  111. package/v2Containers/InApp/tests/reducer.test.js +0 -34
  112. package/v2Containers/InApp/tests/sagas.test.js +9 -61
  113. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +9 -15
  114. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +6 -10
  115. package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +75 -102
  116. package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +54 -81
  117. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +174 -244
  118. package/v2Containers/SmsTrai/Create/tests/__snapshots__/index.test.js.snap +12 -16
  119. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +36 -52
  120. package/v2Containers/TagList/index.js +19 -62
  121. package/v2Containers/Templates/ChannelTypeIllustration.js +1 -13
  122. package/v2Containers/Templates/_templates.scss +1 -265
  123. package/v2Containers/Templates/actions.js +1 -2
  124. package/v2Containers/Templates/constants.js +0 -1
  125. package/v2Containers/Templates/index.js +38 -363
  126. package/v2Containers/Templates/messages.js +0 -28
  127. package/v2Containers/Templates/reducer.js +0 -4
  128. package/v2Containers/Templates/tests/index.test.js +0 -10
  129. package/v2Containers/TemplatesV2/index.js +7 -15
  130. package/v2Containers/TemplatesV2/messages.js +0 -4
  131. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +486 -682
  132. package/utils/imageUrlUpload.js +0 -141
  133. package/v2Components/CapImageUrlUpload/constants.js +0 -26
  134. package/v2Components/CapImageUrlUpload/index.js +0 -365
  135. package/v2Components/CapImageUrlUpload/index.scss +0 -35
  136. package/v2Components/CapImageUrlUpload/messages.js +0 -47
  137. package/v2Components/HtmlEditor/__tests__/HTMLEditor.apiErrors.test.js +0 -874
  138. package/v2Components/HtmlEditor/components/ValidationPanel/constants.js +0 -6
  139. package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +0 -254
  140. package/v2Components/HtmlEditor/components/ValidationTabs/index.js +0 -364
  141. package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +0 -51
  142. package/v2Components/HtmlEditor/hooks/__tests__/useValidation.apiErrors.test.js +0 -795
  143. package/v2Components/HtmlEditor/utils/validationConstants.js +0 -40
  144. package/v2Containers/BeePopupEditor/_beePopupEditor.scss +0 -14
  145. package/v2Containers/BeePopupEditor/constants.js +0 -10
  146. package/v2Containers/BeePopupEditor/index.js +0 -194
  147. package/v2Containers/BeePopupEditor/tests/index.test.js +0 -627
  148. package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +0 -1285
  149. package/v2Containers/EmailWrapper/components/__tests__/EmailHTMLEditor.test.js +0 -1870
  150. package/v2Containers/EmailWrapper/components/__tests__/EmailWrapperView.test.js +0 -520
  151. package/v2Containers/EmailWrapper/tests/useEmailWrapper.edgeCases.test.js +0 -643
  152. package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +0 -376
  153. package/v2Containers/InApp/__tests__/sagas.test.js +0 -363
  154. package/v2Containers/InApp/tests/selectors.test.js +0 -612
  155. package/v2Containers/InAppWrapper/components/InAppWrapperView.js +0 -151
  156. package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +0 -267
  157. package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +0 -23
  158. package/v2Containers/InAppWrapper/constants.js +0 -16
  159. package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +0 -473
  160. package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +0 -198
  161. package/v2Containers/InAppWrapper/index.js +0 -148
  162. package/v2Containers/InAppWrapper/messages.js +0 -49
  163. package/v2Containers/InappAdvance/index.js +0 -1099
  164. package/v2Containers/InappAdvance/index.scss +0 -10
  165. package/v2Containers/InappAdvance/tests/index.test.js +0 -448
  166. package/v2Containers/WebPush/Create/components/BrandIconSection.js +0 -108
  167. package/v2Containers/WebPush/Create/components/ButtonForm.js +0 -172
  168. package/v2Containers/WebPush/Create/components/ButtonItem.js +0 -101
  169. package/v2Containers/WebPush/Create/components/ButtonList.js +0 -107
  170. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.js +0 -160
  171. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.test.js +0 -476
  172. package/v2Containers/WebPush/Create/components/FormActions.js +0 -54
  173. package/v2Containers/WebPush/Create/components/FormActions.test.js +0 -163
  174. package/v2Containers/WebPush/Create/components/MediaSection.js +0 -143
  175. package/v2Containers/WebPush/Create/components/MediaSection.test.js +0 -341
  176. package/v2Containers/WebPush/Create/components/MessageSection.js +0 -103
  177. package/v2Containers/WebPush/Create/components/MessageSection.test.js +0 -268
  178. package/v2Containers/WebPush/Create/components/NotificationTitleSection.js +0 -87
  179. package/v2Containers/WebPush/Create/components/NotificationTitleSection.test.js +0 -210
  180. package/v2Containers/WebPush/Create/components/TemplateNameSection.js +0 -54
  181. package/v2Containers/WebPush/Create/components/TemplateNameSection.test.js +0 -143
  182. package/v2Containers/WebPush/Create/components/__snapshots__/ButtonsLinksSection.test.js.snap +0 -82
  183. package/v2Containers/WebPush/Create/components/__snapshots__/FormActions.test.js.snap +0 -16
  184. package/v2Containers/WebPush/Create/components/__snapshots__/MediaSection.test.js.snap +0 -41
  185. package/v2Containers/WebPush/Create/components/__snapshots__/MessageSection.test.js.snap +0 -54
  186. package/v2Containers/WebPush/Create/components/__snapshots__/NotificationTitleSection.test.js.snap +0 -37
  187. package/v2Containers/WebPush/Create/components/__snapshots__/TemplateNameSection.test.js.snap +0 -21
  188. package/v2Containers/WebPush/Create/components/_buttons.scss +0 -246
  189. package/v2Containers/WebPush/Create/components/tests/ButtonForm.test.js +0 -554
  190. package/v2Containers/WebPush/Create/components/tests/ButtonItem.test.js +0 -607
  191. package/v2Containers/WebPush/Create/components/tests/ButtonList.test.js +0 -515
  192. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonForm.test.js.snap +0 -666
  193. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonItem.test.js.snap +0 -74
  194. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonList.test.js.snap +0 -46
  195. package/v2Containers/WebPush/Create/hooks/useButtonManagement.js +0 -150
  196. package/v2Containers/WebPush/Create/hooks/useButtonManagement.test.js +0 -406
  197. package/v2Containers/WebPush/Create/hooks/useCharacterCount.js +0 -30
  198. package/v2Containers/WebPush/Create/hooks/useCharacterCount.test.js +0 -151
  199. package/v2Containers/WebPush/Create/hooks/useImageUpload.js +0 -104
  200. package/v2Containers/WebPush/Create/hooks/useImageUpload.test.js +0 -538
  201. package/v2Containers/WebPush/Create/hooks/useTagManagement.js +0 -122
  202. package/v2Containers/WebPush/Create/hooks/useTagManagement.test.js +0 -633
  203. package/v2Containers/WebPush/Create/index.js +0 -1148
  204. package/v2Containers/WebPush/Create/index.scss +0 -134
  205. package/v2Containers/WebPush/Create/messages.js +0 -203
  206. package/v2Containers/WebPush/Create/preview/DevicePreviewContent.js +0 -228
  207. package/v2Containers/WebPush/Create/preview/NotificationContainer.js +0 -294
  208. package/v2Containers/WebPush/Create/preview/PreviewContent.js +0 -90
  209. package/v2Containers/WebPush/Create/preview/PreviewControls.js +0 -305
  210. package/v2Containers/WebPush/Create/preview/PreviewDisclaimer.js +0 -23
  211. package/v2Containers/WebPush/Create/preview/WebPushPreview.js +0 -155
  212. package/v2Containers/WebPush/Create/preview/assets/Light.svg +0 -53
  213. package/v2Containers/WebPush/Create/preview/assets/Top.svg +0 -5
  214. package/v2Containers/WebPush/Create/preview/assets/android-arrow-down.svg +0 -9
  215. package/v2Containers/WebPush/Create/preview/assets/android-arrow-up.svg +0 -9
  216. package/v2Containers/WebPush/Create/preview/assets/chrome-icon.png +0 -0
  217. package/v2Containers/WebPush/Create/preview/assets/edge-icon.png +0 -0
  218. package/v2Containers/WebPush/Create/preview/assets/firefox-icon.svg +0 -106
  219. package/v2Containers/WebPush/Create/preview/assets/iOS.svg +0 -26
  220. package/v2Containers/WebPush/Create/preview/assets/macos-arrow-down-icon.svg +0 -9
  221. package/v2Containers/WebPush/Create/preview/assets/macos-triple-dot-icon.svg +0 -9
  222. package/v2Containers/WebPush/Create/preview/assets/opera-icon.svg +0 -18
  223. package/v2Containers/WebPush/Create/preview/assets/safari-icon.svg +0 -29
  224. package/v2Containers/WebPush/Create/preview/assets/windows-close-icon.svg +0 -9
  225. package/v2Containers/WebPush/Create/preview/assets/windows-triple-dot-icon.svg +0 -9
  226. package/v2Containers/WebPush/Create/preview/components/AndroidMobileChromeHeader.js +0 -47
  227. package/v2Containers/WebPush/Create/preview/components/AndroidMobileExpanded.js +0 -141
  228. package/v2Containers/WebPush/Create/preview/components/IOSHeader.js +0 -45
  229. package/v2Containers/WebPush/Create/preview/components/NotificationExpandedContent.js +0 -68
  230. package/v2Containers/WebPush/Create/preview/components/NotificationHeader.js +0 -61
  231. package/v2Containers/WebPush/Create/preview/components/WindowsChromeExpanded.js +0 -99
  232. package/v2Containers/WebPush/Create/preview/components/tests/AndroidMobileExpanded.test.js +0 -733
  233. package/v2Containers/WebPush/Create/preview/components/tests/WindowsChromeExpanded.test.js +0 -571
  234. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/AndroidMobileExpanded.test.js.snap +0 -81
  235. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/WindowsChromeExpanded.test.js.snap +0 -81
  236. package/v2Containers/WebPush/Create/preview/config/notificationMappings.js +0 -50
  237. package/v2Containers/WebPush/Create/preview/constants.js +0 -637
  238. package/v2Containers/WebPush/Create/preview/notification-container.scss +0 -79
  239. package/v2Containers/WebPush/Create/preview/preview.scss +0 -351
  240. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-chrome.scss +0 -370
  241. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-edge.scss +0 -12
  242. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-firefox.scss +0 -12
  243. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-opera.scss +0 -12
  244. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-chrome.scss +0 -47
  245. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-edge.scss +0 -11
  246. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-firefox.scss +0 -11
  247. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-opera.scss +0 -11
  248. package/v2Containers/WebPush/Create/preview/styles/_base.scss +0 -207
  249. package/v2Containers/WebPush/Create/preview/styles/_ios.scss +0 -153
  250. package/v2Containers/WebPush/Create/preview/styles/_ipados.scss +0 -107
  251. package/v2Containers/WebPush/Create/preview/styles/_macos-chrome.scss +0 -101
  252. package/v2Containers/WebPush/Create/preview/styles/_windows-chrome.scss +0 -229
  253. package/v2Containers/WebPush/Create/preview/tests/DevicePreviewContent.test.js +0 -909
  254. package/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +0 -1081
  255. package/v2Containers/WebPush/Create/preview/tests/PreviewControls.test.js +0 -723
  256. package/v2Containers/WebPush/Create/preview/tests/WebPushPreview.test.js +0 -1327
  257. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/DevicePreviewContent.test.js.snap +0 -131
  258. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/NotificationContainer.test.js.snap +0 -112
  259. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/PreviewControls.test.js.snap +0 -144
  260. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/WebPushPreview.test.js.snap +0 -129
  261. package/v2Containers/WebPush/Create/utils/payloadBuilder.js +0 -96
  262. package/v2Containers/WebPush/Create/utils/payloadBuilder.test.js +0 -396
  263. package/v2Containers/WebPush/Create/utils/previewUtils.js +0 -89
  264. package/v2Containers/WebPush/Create/utils/urlValidation.js +0 -115
  265. package/v2Containers/WebPush/Create/utils/urlValidation.test.js +0 -449
  266. package/v2Containers/WebPush/Create/utils/validation.js +0 -75
  267. package/v2Containers/WebPush/Create/utils/validation.test.js +0 -283
  268. package/v2Containers/WebPush/actions.js +0 -60
  269. package/v2Containers/WebPush/constants.js +0 -132
  270. package/v2Containers/WebPush/index.js +0 -2
  271. package/v2Containers/WebPush/reducer.js +0 -104
  272. package/v2Containers/WebPush/sagas.js +0 -119
  273. package/v2Containers/WebPush/selectors.js +0 -65
  274. package/v2Containers/WebPush/tests/reducer.test.js +0 -863
  275. package/v2Containers/WebPush/tests/sagas.test.js +0 -566
  276. package/v2Containers/WebPush/tests/selectors.test.js +0 -960
@@ -9,7 +9,6 @@ import { connect } from 'react-redux';
9
9
  import { injectIntl, intlShape } from 'react-intl';
10
10
  import { createStructuredSelector } from 'reselect';
11
11
  import { bindActionCreators } from 'redux';
12
- import { compose } from 'redux';
13
12
  import { UserIsAuthenticated } from '../../utils/authWrapper';
14
13
  import {
15
14
  selectEmailLayout,
@@ -19,17 +18,10 @@ import {
19
18
  selectCmsTemplatesLoader,
20
19
  } from '../Templates/selectors';
21
20
  import * as templatesActionsCreators from '../Templates/actions';
22
- import { selectCurrentOrgDetails, makeSelectMetaEntities, isLoadingMetaEntities, setInjectedTags, selectLiquidStateDetails } from "../../v2Containers/Cap/selectors";
23
- import { makeSelectEmail, selectLoadingStatus, makeSelectFetchingCmsData } from '../Email/selectors';
24
- import * as emailActionsCreators from '../Email/actions';
25
- import * as globalActions from '../Cap/actions';
21
+ import { selectCurrentOrgDetails } from "../../v2Containers/Cap/selectors";
26
22
  import EmailWrapperView from './components/EmailWrapperView';
27
23
  import useEmailWrapper from './hooks/useEmailWrapper';
28
24
  import HTMLEditorTesting from './components/HTMLEditorTesting';
29
- import injectReducer from '../../utils/injectReducer';
30
- import injectSaga from '../../utils/injectSaga';
31
- import v2EmailReducer from '../Email/reducer';
32
- import { v2EmailSagas } from '../Email/sagas';
33
25
 
34
26
 
35
27
  const EmailWrapper = (props) => {
@@ -72,19 +64,6 @@ const EmailWrapper = (props) => {
72
64
  handleTestAndPreview,
73
65
  handleCloseTestAndPreview,
74
66
  isTestAndPreviewMode,
75
- location,
76
- emailActions,
77
- Email,
78
- metaEntities,
79
- loadingTags,
80
- injectedTags,
81
- globalActions: globalActionsProp,
82
- templateData,
83
- params,
84
- fetchingLiquidTags,
85
- createTemplateInProgress,
86
- fetchingCmsData,
87
- onHtmlEditorValidationStateChange,
88
67
  } = props;
89
68
 
90
69
  // Pass destructured props to the custom hook
@@ -138,70 +117,32 @@ const EmailWrapper = (props) => {
138
117
  handleTestAndPreview,
139
118
  handleCloseTestAndPreview,
140
119
  isTestAndPreviewMode,
141
- location,
142
- emailActions,
143
- Email,
144
- templateData,
145
- params,
146
120
  });
147
121
 
148
122
  // Render using the presentation component with data from the hook
149
123
  return (
150
124
  <div>
151
125
  <EmailWrapperView
152
- isUploading={isUploading}
153
- emailCreateMode={emailCreateMode}
154
- step={step}
155
- isFullMode={isFullMode}
156
- templateName={templateName}
157
- onTemplateNameChange={onTemplateNameChange}
158
- isTemplateNameEmpty={isTemplateNameEmpty}
159
- modes={modes}
160
- onChange={onChange}
161
- EmailLayout={EmailLayout}
162
- modeContent={modeContent}
163
- useFileUpload={useFileUpload}
164
- uploadButtonLabel={uploadButtonLabel}
165
- isShowEmailCreate={isShowEmailCreate}
166
- emailProps={emailProps}
167
- cmsTemplatesProps={cmsTemplatesProps}
168
- onPreviewContentClicked={onPreviewContentClicked}
169
- onTestContentClicked={onTestContentClicked}
170
- editor={editor}
171
- // New flow props - only used when supportCKEditor is false
172
- // These props are needed for EmailHTMLEditor component (tag loading, validation, etc.)
173
- metaEntities={metaEntities}
174
- loadingTags={loadingTags}
175
- injectedTags={injectedTags}
176
- globalActions={globalActionsProp}
177
- supportedTags={props.supportedTags}
178
- getDefaultTags={type}
179
- location={location}
180
- currentOrgDetails={currentOrgDetails}
181
- onValidationFail={onValidationFail}
182
- forwardedTags={forwardedTags}
183
- selectedOfferDetails={selectedOfferDetails}
184
- eventContextTags={eventContextTags}
185
- getFormdata={getFormdata}
186
- isGetFormData={isGetFormData}
187
- getLiquidTags={globalActionsProp?.getLiquidTags}
188
- showLiquidErrorInFooter={showLiquidErrorInFooter}
189
- intl={intl}
190
- emailActions={emailActions}
191
- showTestAndPreviewSlidebox={showTestAndPreviewSlidebox}
192
- handleTestAndPreview={handleTestAndPreview}
193
- handleCloseTestAndPreview={handleCloseTestAndPreview}
194
- Email={Email}
195
- setIsLoadingContent={setIsLoadingContent}
196
- templateData={templateData}
197
- params={params}
198
- showTemplateName={showTemplateName}
199
- fetchingLiquidTags={fetchingLiquidTags}
200
- createTemplateInProgress={createTemplateInProgress}
201
- fetchingCmsData={fetchingCmsData}
202
- onHtmlEditorValidationStateChange={onHtmlEditorValidationStateChange}
203
- moduleType={moduleType}
204
- />
126
+ isUploading={isUploading}
127
+ emailCreateMode={emailCreateMode}
128
+ step={step}
129
+ isFullMode={isFullMode}
130
+ templateName={templateName}
131
+ onTemplateNameChange={onTemplateNameChange}
132
+ isTemplateNameEmpty={isTemplateNameEmpty}
133
+ modes={modes}
134
+ onChange={onChange}
135
+ EmailLayout={EmailLayout}
136
+ modeContent={modeContent}
137
+ useFileUpload={useFileUpload}
138
+ uploadButtonLabel={uploadButtonLabel}
139
+ isShowEmailCreate={isShowEmailCreate}
140
+ emailProps={emailProps}
141
+ cmsTemplatesProps={cmsTemplatesProps}
142
+ onPreviewContentClicked={onPreviewContentClicked}
143
+ onTestContentClicked={onTestContentClicked}
144
+ editor={editor}
145
+ />
205
146
 
206
147
  {/* HTMLEditor Testing Component - Console Controlled */}
207
148
  <HTMLEditorTesting />
@@ -218,7 +159,7 @@ EmailWrapper.propTypes = {
218
159
  templatesActions: PropTypes.object,
219
160
  CmsTemplates: PropTypes.arrayOf(PropTypes.object),
220
161
  SelectedEdmDefaultTemplate: PropTypes.object,
221
- step: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
162
+ step: PropTypes.string,
222
163
  showNextStep: PropTypes.func,
223
164
  getFormdata: PropTypes.func,
224
165
  intl: intlShape,
@@ -246,8 +187,6 @@ EmailWrapper.propTypes = {
246
187
  handleTestAndPreview: PropTypes.func,
247
188
  handleCloseTestAndPreview: PropTypes.func,
248
189
  isTestAndPreviewMode: PropTypes.bool,
249
- location: PropTypes.object,
250
- onHtmlEditorValidationStateChange: PropTypes.func,
251
190
  };
252
191
 
253
192
  const mapStateToProps = createStructuredSelector({
@@ -257,31 +196,12 @@ const mapStateToProps = createStructuredSelector({
257
196
  isUploading: uploadSelector(),
258
197
  cmsTemplatesLoader: selectCmsTemplatesLoader(),
259
198
  currentOrgDetails: selectCurrentOrgDetails(),
260
- Email: makeSelectEmail(),
261
- metaEntities: makeSelectMetaEntities(),
262
- loadingTags: isLoadingMetaEntities(),
263
- injectedTags: setInjectedTags(),
264
- fetchingLiquidTags: selectLiquidStateDetails(),
265
- createTemplateInProgress: selectLoadingStatus(),
266
- fetchingCmsData: makeSelectFetchingCmsData(),
267
199
  });
268
200
 
269
201
  function mapDispatchToProps(dispatch) {
270
202
  return {
271
203
  templatesActions: bindActionCreators(templatesActionsCreators, dispatch),
272
- emailActions: bindActionCreators(emailActionsCreators, dispatch),
273
- globalActions: bindActionCreators(globalActions, dispatch),
274
204
  };
275
205
  }
276
206
 
277
- // Inject Email reducer and saga so that getCmsSetting action can be handled
278
- const withReducer = injectReducer({ key: 'email', reducer: v2EmailReducer });
279
- const withEmailSaga = injectSaga({ key: 'email', saga: v2EmailSagas });
280
-
281
- const ConnectedEmailWrapper = connect(mapStateToProps, mapDispatchToProps)(injectIntl(EmailWrapper));
282
-
283
- export default compose(
284
- UserIsAuthenticated,
285
- withReducer,
286
- withEmailSaga,
287
- )(ConnectedEmailWrapper);
207
+ export default UserIsAuthenticated(connect(mapStateToProps, mapDispatchToProps)(injectIntl(EmailWrapper)));
@@ -60,66 +60,6 @@ export default defineMessages({
60
60
  },
61
61
  emptyTemplateName: {
62
62
  id: `creatives.containersV2.EmailWrapper.emptyTemplateName`,
63
- defaultMessage: `Please enter template name.`,
64
- },
65
- htmlEditorTitle: {
66
- id: 'creatives.EmailWrapper.htmlEditorTitle',
67
- defaultMessage: 'HTML editor',
68
- },
69
- htmlEditorDesc: {
70
- id: 'creatives.EmailWrapper.htmlEditorDesc',
71
- defaultMessage: 'Use a basic HTML editor to write and format your content. Suitable if you are familiar with HTML.',
72
- },
73
- dragDropEditorTitle: {
74
- id: 'creatives.EmailWrapper.dragDropEditorTitle',
75
- defaultMessage: 'Drag & drop editor',
76
- },
77
- dragDropEditorDesc: {
78
- id: 'creatives.EmailWrapper.dragDropEditorDesc',
79
- defaultMessage: 'Create your content visually by dragging blocks — no coding needed. Great for quick, easy designs.',
80
- },
81
- uploadZipTitle: {
82
- id: 'creatives.EmailWrapper.uploadZipTitle',
83
- defaultMessage: 'Upload zip file',
84
- },
85
- uploadZipDesc: {
86
- id: 'creatives.EmailWrapper.uploadZipDesc',
87
- defaultMessage: 'Upload a ZIP containing your custom HTML, images, and assets. Ideal if your content is already built.',
88
- },
89
- next: {
90
- id: 'creatives.EmailWrapper.next',
91
- defaultMessage: 'Next',
92
- },
93
- beeEditorDisabledTooltip: {
94
- id: 'creatives.EmailWrapper.beeEditorDisabledTooltip',
95
- defaultMessage: 'Please get the drag & drop editor enabled for your brand',
96
- },
97
- emailContent: {
98
- id: 'creatives.containersV2.Email.emailContent',
99
- defaultMessage: 'Email content',
100
- },
101
- create: {
102
- id: 'creatives.containersV2.EmailWrapper.create',
103
- defaultMessage: 'Create',
104
- },
105
- update: {
106
- id: 'creatives.containersV2.EmailWrapper.update',
107
- defaultMessage: 'Update',
108
- },
109
- previewAndTest: {
110
- id: 'creatives.containersV2.EmailWrapper.previewAndTest',
111
- defaultMessage: 'Preview and Test',
112
- },
113
- required: {
114
- id: 'creatives.containersV2.EmailWrapper.required',
115
- defaultMessage: 'Required',
116
- },
117
- subject: {
118
- id: 'creatives.containersV2.EmailWrapper.subject',
119
- defaultMessage: 'Subject',
120
- },
121
- enterEmailSubject: {
122
- id: 'creatives.containersV2.EmailWrapper.enterEmailSubject',
123
- defaultMessage: 'Enter Email Subject',
63
+ defaultMessage: `Please enter template name.`
124
64
  },
125
65
  });
@@ -0,0 +1,214 @@
1
+ import React from 'react';
2
+ import { render, fireEvent, within, screen } from '@testing-library/react';
3
+ import '@testing-library/jest-dom';
4
+ import { IntlProvider } from 'react-intl';
5
+ import { Provider } from 'react-redux';
6
+ import { configureStore } from '@capillarytech/vulcan-react-sdk/utils'
7
+ import { initialReducer } from '../../../initialReducer';
8
+ import EmailWrapperView from '../components/EmailWrapperView';
9
+ import { EmailWrapperViewMockProps } from '../mockdata/mockdata';
10
+ import { EMAIL_CREATE_MODES } from '../constants';
11
+ import history from '../../../utils/history';
12
+
13
+ // This mock needs to be before any imports
14
+ jest.mock('../../../v2Containers/Email', () => ({
15
+ __esModule: true,
16
+ default: () => <div data-testid="email-create-container" />,
17
+ }));
18
+
19
+ // Mock react-router
20
+ jest.mock('react-router-dom', () => ({
21
+ ...jest.requireActual('react-router-dom'),
22
+ useHistory: () => ({
23
+ push: jest.fn(),
24
+ replace: jest.fn(),
25
+ go: jest.fn(),
26
+ goBack: jest.fn(),
27
+ goForward: jest.fn(),
28
+ location: { search: '' }
29
+ }),
30
+ }));
31
+
32
+ // Mock redux-auth-wrapper
33
+ jest.mock('redux-auth-wrapper/history4/redirect', () => ({
34
+ connectedRouterRedirect: () => (Component) => Component,
35
+ }));
36
+
37
+ // Mock react-router
38
+ jest.mock('connected-react-router', () => ({
39
+ push: jest.fn(),
40
+ replace: jest.fn(),
41
+ go: jest.fn(),
42
+ goBack: jest.fn(),
43
+ goForward: jest.fn(),
44
+ }));
45
+
46
+ // Mock the saga injector
47
+ jest.mock('@capillarytech/vulcan-react-sdk/utils/injectSaga', () => ({
48
+ __esModule: true,
49
+ default: () => (Component) => Component,
50
+ }));
51
+
52
+
53
+ const initialState = {
54
+ cap: { loading: false, error: null },
55
+ router: { location: { pathname: '/' } }
56
+ };
57
+
58
+ describe('EmailWrapperView', () => {
59
+ let store;
60
+
61
+ beforeAll(() => {
62
+ store = configureStore(initialState, initialReducer, history);
63
+ });
64
+
65
+ const renderWithProviders = (component) => {
66
+ return render(
67
+ <Provider store={store}>
68
+ <IntlProvider locale="en" messages={{}}>
69
+ {component}
70
+ </IntlProvider>
71
+ </Provider>
72
+ );
73
+ };
74
+
75
+ it('renders mode selection UI when step is modeSelection', () => {
76
+ const props = {
77
+ ...EmailWrapperViewMockProps,
78
+ step: 'modeSelection',
79
+ };
80
+
81
+ const { getByText } = renderWithProviders(<EmailWrapperView {...props} />);
82
+ expect(getByText('Create using editor')).toBeInTheDocument();
83
+ expect(getByText('Upload zip file')).toBeInTheDocument();
84
+ });
85
+
86
+ it('shows template name input in full mode', () => {
87
+ const props = {
88
+ ...EmailWrapperViewMockProps,
89
+ isFullMode: true,
90
+ step: 'modeSelection',
91
+ };
92
+
93
+ const { container } = renderWithProviders(<EmailWrapperView {...props} />);
94
+ const input = container.querySelector('.ant-input');
95
+ expect(input).toBeInTheDocument();
96
+ expect(input.value).toBe(props.templateName);
97
+ });
98
+
99
+ it('handles template name changes', () => {
100
+ const props = {
101
+ ...EmailWrapperViewMockProps,
102
+ isFullMode: true,
103
+ step: 'modeSelection',
104
+ onTemplateNameChange: jest.fn(),
105
+ };
106
+
107
+ const { container } = renderWithProviders(<EmailWrapperView {...props} />);
108
+ const input = container.querySelector('.ant-input');
109
+ expect(input).toBeInTheDocument();
110
+
111
+ // Create a change event and fire it
112
+ fireEvent.change(input, { target: { value: 'New Template Name' } });
113
+
114
+ // Just verify that the function was called
115
+ expect(props.onTemplateNameChange).toHaveBeenCalled();
116
+ });
117
+
118
+ it('shows upload button when in upload mode', () => {
119
+ const props = {
120
+ ...EmailWrapperViewMockProps,
121
+ step: 'modeSelection',
122
+ emailCreateMode: EMAIL_CREATE_MODES.UPLOAD,
123
+ uploadButtonLabel: 'Upload',
124
+ };
125
+
126
+ const { getByText, container } = renderWithProviders(<EmailWrapperView {...props} />);
127
+
128
+ // Find the "Upload zip file" section
129
+ const modeSelectionSection = getByText('Upload zip file').closest('div');
130
+
131
+ // Find any button in the upload section
132
+ const uploadButton = container.querySelector('.ant-btn');
133
+
134
+ // Verify that we found an upload button
135
+ expect(uploadButton).toBeInTheDocument();
136
+ expect(uploadButton.textContent).toContain('Upload');
137
+ });
138
+
139
+ it('shows loading spinner when uploading', () => {
140
+ const props = {
141
+ ...EmailWrapperViewMockProps,
142
+ isUploading: true,
143
+ emailCreateMode: EMAIL_CREATE_MODES.UPLOAD,
144
+ step: 'modeSelection',
145
+ };
146
+
147
+ const { container } = renderWithProviders(<EmailWrapperView {...props} />);
148
+ const spinner = container.querySelector('.ant-spin');
149
+ expect(spinner).toBeInTheDocument();
150
+ });
151
+
152
+ it('shows content creation UI when not in mode selection', () => {
153
+ const props = {
154
+ ...EmailWrapperViewMockProps,
155
+ step: 'contentCreation',
156
+ isShowEmailCreate: true,
157
+ };
158
+
159
+ const { getByTestId } = renderWithProviders(<EmailWrapperView {...props} />);
160
+ expect(getByTestId('email-create-container')).toBeInTheDocument();
161
+ });
162
+
163
+ it('disables upload button when template name is empty in full mode', () => {
164
+ const props = {
165
+ ...EmailWrapperViewMockProps,
166
+ isFullMode: true,
167
+ step: 'modeSelection',
168
+ emailCreateMode: EMAIL_CREATE_MODES.UPLOAD,
169
+ templateName: '',
170
+ isTemplateNameEmpty: true,
171
+ uploadButtonLabel: 'Upload',
172
+ };
173
+
174
+ const { getByText, container } = renderWithProviders(<EmailWrapperView {...props} />);
175
+
176
+ // Find the Upload section
177
+ getByText('Upload zip file');
178
+
179
+ // Find button in the container
180
+ const uploadButton = container.querySelector('.ant-btn');
181
+
182
+ // Check if the button is disabled
183
+ expect(uploadButton).toBeDisabled();
184
+ });
185
+
186
+ it('shows error message when template name is empty during upload', () => {
187
+ const props = {
188
+ ...EmailWrapperViewMockProps,
189
+ isFullMode: true,
190
+ step: 'modeSelection',
191
+ emailCreateMode: EMAIL_CREATE_MODES.UPLOAD,
192
+ templateName: '',
193
+ isTemplateNameEmpty: true,
194
+ // Add errorMessage directly to the props
195
+ errorMessage: 'Please enter template name',
196
+ intl: {
197
+ formatMessage: () => 'Please enter template name',
198
+ },
199
+ };
200
+
201
+ const { container } = renderWithProviders(<EmailWrapperView {...props} />);
202
+
203
+ // Look for error feedback in the Ant Design form
204
+ const errorElement = container.querySelector('.ant-form-item-explain');
205
+
206
+ if (errorElement) {
207
+ expect(errorElement.textContent).toContain('Please enter template name');
208
+ } else {
209
+ // If the standard error element is not found, look for any element containing the error text
210
+ const allText = container.textContent;
211
+ expect(allText).toContain('Please enter template name');
212
+ }
213
+ });
214
+ });