@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
@@ -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,18 +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
67
  } = props;
88
68
 
89
69
  // Pass destructured props to the custom hook
@@ -137,68 +117,32 @@ const EmailWrapper = (props) => {
137
117
  handleTestAndPreview,
138
118
  handleCloseTestAndPreview,
139
119
  isTestAndPreviewMode,
140
- location,
141
- emailActions,
142
- Email,
143
- templateData,
144
- params,
145
120
  });
146
121
 
147
122
  // Render using the presentation component with data from the hook
148
123
  return (
149
124
  <div>
150
125
  <EmailWrapperView
151
- isUploading={isUploading}
152
- emailCreateMode={emailCreateMode}
153
- step={step}
154
- isFullMode={isFullMode}
155
- templateName={templateName}
156
- onTemplateNameChange={onTemplateNameChange}
157
- isTemplateNameEmpty={isTemplateNameEmpty}
158
- modes={modes}
159
- onChange={onChange}
160
- EmailLayout={EmailLayout}
161
- modeContent={modeContent}
162
- useFileUpload={useFileUpload}
163
- uploadButtonLabel={uploadButtonLabel}
164
- isShowEmailCreate={isShowEmailCreate}
165
- emailProps={emailProps}
166
- cmsTemplatesProps={cmsTemplatesProps}
167
- onPreviewContentClicked={onPreviewContentClicked}
168
- onTestContentClicked={onTestContentClicked}
169
- editor={editor}
170
- // New flow props - only used when supportCKEditor is false
171
- // These props are needed for EmailHTMLEditor component (tag loading, validation, etc.)
172
- metaEntities={metaEntities}
173
- loadingTags={loadingTags}
174
- injectedTags={injectedTags}
175
- globalActions={globalActionsProp}
176
- supportedTags={props.supportedTags}
177
- getDefaultTags={type}
178
- location={location}
179
- currentOrgDetails={currentOrgDetails}
180
- onValidationFail={onValidationFail}
181
- forwardedTags={forwardedTags}
182
- selectedOfferDetails={selectedOfferDetails}
183
- eventContextTags={eventContextTags}
184
- getFormdata={getFormdata}
185
- isGetFormData={isGetFormData}
186
- getLiquidTags={globalActionsProp?.getLiquidTags}
187
- showLiquidErrorInFooter={showLiquidErrorInFooter}
188
- intl={intl}
189
- emailActions={emailActions}
190
- showTestAndPreviewSlidebox={showTestAndPreviewSlidebox}
191
- handleTestAndPreview={handleTestAndPreview}
192
- handleCloseTestAndPreview={handleCloseTestAndPreview}
193
- Email={Email}
194
- setIsLoadingContent={setIsLoadingContent}
195
- templateData={templateData}
196
- params={params}
197
- showTemplateName={showTemplateName}
198
- fetchingLiquidTags={fetchingLiquidTags}
199
- createTemplateInProgress={createTemplateInProgress}
200
- fetchingCmsData={fetchingCmsData}
201
- />
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
+ />
202
146
 
203
147
  {/* HTMLEditor Testing Component - Console Controlled */}
204
148
  <HTMLEditorTesting />
@@ -215,7 +159,7 @@ EmailWrapper.propTypes = {
215
159
  templatesActions: PropTypes.object,
216
160
  CmsTemplates: PropTypes.arrayOf(PropTypes.object),
217
161
  SelectedEdmDefaultTemplate: PropTypes.object,
218
- step: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
162
+ step: PropTypes.string,
219
163
  showNextStep: PropTypes.func,
220
164
  getFormdata: PropTypes.func,
221
165
  intl: intlShape,
@@ -243,7 +187,6 @@ EmailWrapper.propTypes = {
243
187
  handleTestAndPreview: PropTypes.func,
244
188
  handleCloseTestAndPreview: PropTypes.func,
245
189
  isTestAndPreviewMode: PropTypes.bool,
246
- location: PropTypes.object,
247
190
  };
248
191
 
249
192
  const mapStateToProps = createStructuredSelector({
@@ -253,31 +196,12 @@ const mapStateToProps = createStructuredSelector({
253
196
  isUploading: uploadSelector(),
254
197
  cmsTemplatesLoader: selectCmsTemplatesLoader(),
255
198
  currentOrgDetails: selectCurrentOrgDetails(),
256
- Email: makeSelectEmail(),
257
- metaEntities: makeSelectMetaEntities(),
258
- loadingTags: isLoadingMetaEntities(),
259
- injectedTags: setInjectedTags(),
260
- fetchingLiquidTags: selectLiquidStateDetails(),
261
- createTemplateInProgress: selectLoadingStatus(),
262
- fetchingCmsData: makeSelectFetchingCmsData(),
263
199
  });
264
200
 
265
201
  function mapDispatchToProps(dispatch) {
266
202
  return {
267
203
  templatesActions: bindActionCreators(templatesActionsCreators, dispatch),
268
- emailActions: bindActionCreators(emailActionsCreators, dispatch),
269
- globalActions: bindActionCreators(globalActions, dispatch),
270
204
  };
271
205
  }
272
206
 
273
- // Inject Email reducer and saga so that getCmsSetting action can be handled
274
- const withReducer = injectReducer({ key: 'email', reducer: v2EmailReducer });
275
- const withEmailSaga = injectSaga({ key: 'email', saga: v2EmailSagas });
276
-
277
- const ConnectedEmailWrapper = connect(mapStateToProps, mapDispatchToProps)(injectIntl(EmailWrapper));
278
-
279
- export default compose(
280
- UserIsAuthenticated,
281
- withReducer,
282
- withEmailSaga,
283
- )(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
+ });