@capillarytech/creatives-library 8.0.242-alpha.1 → 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 (255) 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 +89 -210
  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 +23 -8
  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/index.js +1 -1
  41. package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +0 -1
  42. package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +7 -4
  43. package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +45 -35
  44. package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +3 -1
  45. package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
  46. package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +6 -7
  47. package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +6 -3
  48. package/v2Components/HtmlEditor/components/PreviewPane/index.js +11 -10
  49. package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
  50. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +62 -87
  51. package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +31 -49
  52. package/v2Components/HtmlEditor/constants.js +20 -29
  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/index.js +1 -1
  57. package/v2Components/HtmlEditor/messages.js +85 -95
  58. package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +101 -99
  59. package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +25 -23
  60. package/v2Components/HtmlEditor/utils/validationAdapter.js +41 -34
  61. package/v2Components/MobilePushPreviewV2/index.js +7 -32
  62. package/v2Components/TemplatePreview/_templatePreview.scss +24 -44
  63. package/v2Components/TemplatePreview/index.js +32 -47
  64. package/v2Components/TemplatePreview/messages.js +0 -4
  65. package/v2Components/TestAndPreviewSlidebox/index.js +25 -31
  66. package/v2Containers/App/constants.js +5 -0
  67. package/v2Containers/BeeEditor/index.js +80 -82
  68. package/v2Containers/Cap/tests/__snapshots__/index.test.js.snap +4 -3
  69. package/v2Containers/CreativesContainer/SlideBoxContent.js +118 -148
  70. package/v2Containers/CreativesContainer/SlideBoxFooter.js +3 -9
  71. package/v2Containers/CreativesContainer/SlideBoxHeader.js +2 -2
  72. package/v2Containers/CreativesContainer/constants.js +2 -1
  73. package/v2Containers/CreativesContainer/index.js +41 -173
  74. package/v2Containers/CreativesContainer/messages.js +4 -4
  75. package/v2Containers/CreativesContainer/tests/SlideBoxContent.test.js +210 -0
  76. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +354 -38
  77. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +0 -36
  78. package/v2Containers/Email/actions.js +0 -7
  79. package/v2Containers/Email/constants.js +1 -5
  80. package/v2Containers/Email/index.js +0 -13
  81. package/v2Containers/Email/messages.js +0 -32
  82. package/v2Containers/Email/reducer.js +1 -12
  83. package/v2Containers/Email/sagas.js +6 -41
  84. package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +0 -2
  85. package/v2Containers/EmailWrapper/components/EmailWrapperView.js +7 -193
  86. package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +74 -40
  87. package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +67 -2
  88. package/v2Containers/EmailWrapper/constants.js +0 -2
  89. package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +67 -436
  90. package/v2Containers/EmailWrapper/index.js +23 -99
  91. package/v2Containers/EmailWrapper/messages.js +1 -61
  92. package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +1 -26
  93. package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +77 -111
  94. package/v2Containers/InApp/actions.js +0 -7
  95. package/v2Containers/InApp/constants.js +4 -20
  96. package/v2Containers/InApp/index.js +357 -800
  97. package/v2Containers/InApp/index.scss +3 -4
  98. package/v2Containers/InApp/messages.js +3 -7
  99. package/v2Containers/InApp/reducer.js +3 -21
  100. package/v2Containers/InApp/sagas.js +9 -29
  101. package/v2Containers/InApp/selectors.js +5 -25
  102. package/v2Containers/InApp/tests/index.test.js +50 -154
  103. package/v2Containers/InApp/tests/reducer.test.js +0 -34
  104. package/v2Containers/InApp/tests/sagas.test.js +9 -61
  105. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +12 -12
  106. package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +8 -8
  107. package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +100 -77
  108. package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +72 -63
  109. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +184 -150
  110. package/v2Containers/SmsTrai/Create/tests/__snapshots__/index.test.js.snap +16 -12
  111. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +32 -28
  112. package/v2Containers/TagList/index.js +1 -67
  113. package/v2Containers/Templates/ChannelTypeIllustration.js +13 -1
  114. package/v2Containers/Templates/_templates.scss +202 -56
  115. package/v2Containers/Templates/actions.js +2 -1
  116. package/v2Containers/Templates/constants.js +1 -0
  117. package/v2Containers/Templates/index.js +278 -128
  118. package/v2Containers/Templates/messages.js +24 -4
  119. package/v2Containers/Templates/reducer.js +2 -0
  120. package/v2Containers/Templates/tests/index.test.js +10 -0
  121. package/v2Containers/TemplatesV2/index.js +8 -1
  122. package/v2Containers/TemplatesV2/messages.js +4 -0
  123. package/v2Containers/WebPush/Create/components/BrandIconSection.js +108 -0
  124. package/v2Containers/WebPush/Create/components/ButtonForm.js +172 -0
  125. package/v2Containers/WebPush/Create/components/ButtonItem.js +101 -0
  126. package/v2Containers/WebPush/Create/components/ButtonList.js +145 -0
  127. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.js +164 -0
  128. package/v2Containers/WebPush/Create/components/ButtonsLinksSection.test.js +463 -0
  129. package/v2Containers/WebPush/Create/components/FormActions.js +54 -0
  130. package/v2Containers/WebPush/Create/components/FormActions.test.js +163 -0
  131. package/v2Containers/WebPush/Create/components/MediaSection.js +142 -0
  132. package/v2Containers/WebPush/Create/components/MediaSection.test.js +341 -0
  133. package/v2Containers/WebPush/Create/components/MessageSection.js +103 -0
  134. package/v2Containers/WebPush/Create/components/MessageSection.test.js +268 -0
  135. package/v2Containers/WebPush/Create/components/NotificationTitleSection.js +87 -0
  136. package/v2Containers/WebPush/Create/components/NotificationTitleSection.test.js +210 -0
  137. package/v2Containers/WebPush/Create/components/TemplateNameSection.js +54 -0
  138. package/v2Containers/WebPush/Create/components/TemplateNameSection.test.js +143 -0
  139. package/v2Containers/WebPush/Create/components/__snapshots__/ButtonsLinksSection.test.js.snap +86 -0
  140. package/v2Containers/WebPush/Create/components/__snapshots__/FormActions.test.js.snap +16 -0
  141. package/v2Containers/WebPush/Create/components/__snapshots__/MediaSection.test.js.snap +41 -0
  142. package/v2Containers/WebPush/Create/components/__snapshots__/MessageSection.test.js.snap +54 -0
  143. package/v2Containers/WebPush/Create/components/__snapshots__/NotificationTitleSection.test.js.snap +37 -0
  144. package/v2Containers/WebPush/Create/components/__snapshots__/TemplateNameSection.test.js.snap +21 -0
  145. package/v2Containers/WebPush/Create/components/_buttons.scss +246 -0
  146. package/v2Containers/WebPush/Create/components/tests/ButtonForm.test.js +554 -0
  147. package/v2Containers/WebPush/Create/components/tests/ButtonItem.test.js +607 -0
  148. package/v2Containers/WebPush/Create/components/tests/ButtonList.test.js +633 -0
  149. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonForm.test.js.snap +666 -0
  150. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonItem.test.js.snap +74 -0
  151. package/v2Containers/WebPush/Create/components/tests/__snapshots__/ButtonList.test.js.snap +78 -0
  152. package/v2Containers/WebPush/Create/hooks/useButtonManagement.js +138 -0
  153. package/v2Containers/WebPush/Create/hooks/useButtonManagement.test.js +406 -0
  154. package/v2Containers/WebPush/Create/hooks/useCharacterCount.js +30 -0
  155. package/v2Containers/WebPush/Create/hooks/useCharacterCount.test.js +151 -0
  156. package/v2Containers/WebPush/Create/hooks/useImageUpload.js +104 -0
  157. package/v2Containers/WebPush/Create/hooks/useImageUpload.test.js +538 -0
  158. package/v2Containers/WebPush/Create/hooks/useTagManagement.js +122 -0
  159. package/v2Containers/WebPush/Create/hooks/useTagManagement.test.js +633 -0
  160. package/v2Containers/WebPush/Create/index.js +1056 -0
  161. package/v2Containers/WebPush/Create/index.scss +134 -0
  162. package/v2Containers/WebPush/Create/messages.js +203 -0
  163. package/v2Containers/WebPush/Create/preview/DevicePreviewContent.js +228 -0
  164. package/v2Containers/WebPush/Create/preview/NotificationContainer.js +294 -0
  165. package/v2Containers/WebPush/Create/preview/PreviewContent.js +90 -0
  166. package/v2Containers/WebPush/Create/preview/PreviewControls.js +305 -0
  167. package/v2Containers/WebPush/Create/preview/PreviewDisclaimer.js +23 -0
  168. package/v2Containers/WebPush/Create/preview/WebPushPreview.js +150 -0
  169. package/v2Containers/WebPush/Create/preview/assets/Light.svg +53 -0
  170. package/v2Containers/WebPush/Create/preview/assets/Top.svg +5 -0
  171. package/v2Containers/WebPush/Create/preview/assets/android-arrow-down.svg +9 -0
  172. package/v2Containers/WebPush/Create/preview/assets/android-arrow-up.svg +9 -0
  173. package/v2Containers/WebPush/Create/preview/assets/chrome-icon.png +0 -0
  174. package/v2Containers/WebPush/Create/preview/assets/edge-icon.png +0 -0
  175. package/v2Containers/WebPush/Create/preview/assets/firefox-icon.svg +106 -0
  176. package/v2Containers/WebPush/Create/preview/assets/iOS.svg +26 -0
  177. package/v2Containers/WebPush/Create/preview/assets/macos-arrow-down-icon.svg +9 -0
  178. package/v2Containers/WebPush/Create/preview/assets/macos-triple-dot-icon.svg +9 -0
  179. package/v2Containers/WebPush/Create/preview/assets/opera-icon.svg +18 -0
  180. package/v2Containers/WebPush/Create/preview/assets/safari-icon.svg +29 -0
  181. package/v2Containers/WebPush/Create/preview/assets/windows-close-icon.svg +9 -0
  182. package/v2Containers/WebPush/Create/preview/assets/windows-triple-dot-icon.svg +9 -0
  183. package/v2Containers/WebPush/Create/preview/components/AndroidMobileChromeHeader.js +47 -0
  184. package/v2Containers/WebPush/Create/preview/components/AndroidMobileExpanded.js +141 -0
  185. package/v2Containers/WebPush/Create/preview/components/IOSHeader.js +45 -0
  186. package/v2Containers/WebPush/Create/preview/components/NotificationExpandedContent.js +68 -0
  187. package/v2Containers/WebPush/Create/preview/components/NotificationHeader.js +61 -0
  188. package/v2Containers/WebPush/Create/preview/components/WindowsChromeExpanded.js +99 -0
  189. package/v2Containers/WebPush/Create/preview/components/tests/AndroidMobileExpanded.test.js +733 -0
  190. package/v2Containers/WebPush/Create/preview/components/tests/WindowsChromeExpanded.test.js +571 -0
  191. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/AndroidMobileExpanded.test.js.snap +81 -0
  192. package/v2Containers/WebPush/Create/preview/components/tests/__snapshots__/WindowsChromeExpanded.test.js.snap +81 -0
  193. package/v2Containers/WebPush/Create/preview/config/notificationMappings.js +50 -0
  194. package/v2Containers/WebPush/Create/preview/constants.js +637 -0
  195. package/v2Containers/WebPush/Create/preview/notification-container.scss +79 -0
  196. package/v2Containers/WebPush/Create/preview/preview.scss +351 -0
  197. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-chrome.scss +370 -0
  198. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-edge.scss +12 -0
  199. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-firefox.scss +12 -0
  200. package/v2Containers/WebPush/Create/preview/styles/_android-mobile-opera.scss +12 -0
  201. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-chrome.scss +47 -0
  202. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-edge.scss +11 -0
  203. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-firefox.scss +11 -0
  204. package/v2Containers/WebPush/Create/preview/styles/_android-tablet-opera.scss +11 -0
  205. package/v2Containers/WebPush/Create/preview/styles/_base.scss +207 -0
  206. package/v2Containers/WebPush/Create/preview/styles/_ios.scss +153 -0
  207. package/v2Containers/WebPush/Create/preview/styles/_ipados.scss +107 -0
  208. package/v2Containers/WebPush/Create/preview/styles/_macos-chrome.scss +101 -0
  209. package/v2Containers/WebPush/Create/preview/styles/_windows-chrome.scss +229 -0
  210. package/v2Containers/WebPush/Create/preview/tests/DevicePreviewContent.test.js +909 -0
  211. package/v2Containers/WebPush/Create/preview/tests/NotificationContainer.test.js +1081 -0
  212. package/v2Containers/WebPush/Create/preview/tests/PreviewControls.test.js +723 -0
  213. package/v2Containers/WebPush/Create/preview/tests/WebPushPreview.test.js +943 -0
  214. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/DevicePreviewContent.test.js.snap +131 -0
  215. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/NotificationContainer.test.js.snap +112 -0
  216. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/PreviewControls.test.js.snap +144 -0
  217. package/v2Containers/WebPush/Create/preview/tests/__snapshots__/WebPushPreview.test.js.snap +129 -0
  218. package/v2Containers/WebPush/Create/utils/payloadBuilder.js +94 -0
  219. package/v2Containers/WebPush/Create/utils/payloadBuilder.test.js +390 -0
  220. package/v2Containers/WebPush/Create/utils/previewUtils.js +89 -0
  221. package/v2Containers/WebPush/Create/utils/urlValidation.js +115 -0
  222. package/v2Containers/WebPush/Create/utils/urlValidation.test.js +449 -0
  223. package/v2Containers/WebPush/Create/utils/validation.js +75 -0
  224. package/v2Containers/WebPush/Create/utils/validation.test.js +283 -0
  225. package/v2Containers/WebPush/actions.js +60 -0
  226. package/v2Containers/WebPush/constants.js +128 -0
  227. package/v2Containers/WebPush/index.js +2 -0
  228. package/v2Containers/WebPush/reducer.js +104 -0
  229. package/v2Containers/WebPush/sagas.js +119 -0
  230. package/v2Containers/WebPush/selectors.js +65 -0
  231. package/v2Containers/WebPush/tests/reducer.test.js +863 -0
  232. package/v2Containers/WebPush/tests/sagas.test.js +566 -0
  233. package/v2Containers/WebPush/tests/selectors.test.js +843 -0
  234. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +528 -431
  235. package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +0 -254
  236. package/v2Components/HtmlEditor/components/ValidationTabs/index.js +0 -362
  237. package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +0 -51
  238. package/v2Containers/BeePopupEditor/constants.js +0 -10
  239. package/v2Containers/BeePopupEditor/index.js +0 -193
  240. package/v2Containers/BeePopupEditor/tests/index.test.js +0 -627
  241. package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +0 -1045
  242. package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +0 -376
  243. package/v2Containers/InApp/__tests__/sagas.test.js +0 -363
  244. package/v2Containers/InApp/tests/selectors.test.js +0 -612
  245. package/v2Containers/InAppWrapper/components/InAppWrapperView.js +0 -162
  246. package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +0 -267
  247. package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +0 -9
  248. package/v2Containers/InAppWrapper/constants.js +0 -16
  249. package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +0 -473
  250. package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +0 -198
  251. package/v2Containers/InAppWrapper/index.js +0 -148
  252. package/v2Containers/InAppWrapper/messages.js +0 -49
  253. package/v2Containers/InappAdvance/index.js +0 -1099
  254. package/v2Containers/InappAdvance/index.scss +0 -10
  255. 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
  });
@@ -5,34 +5,10 @@ import { IntlProvider } from 'react-intl';
5
5
  import { Provider } from 'react-redux';
6
6
  import { configureStore } from '@capillarytech/vulcan-react-sdk/utils'
7
7
  import { initialReducer } from '../../../initialReducer';
8
- import history from '../../../utils/history';
9
8
  import EmailWrapperView from '../components/EmailWrapperView';
10
9
  import { EmailWrapperViewMockProps } from '../mockdata/mockdata';
11
10
  import { EMAIL_CREATE_MODES } from '../constants';
12
-
13
- // Mock pathConfig before history import - must be a string, not undefined
14
- jest.mock('../../../config/path', () => ({
15
- publicPath: '/creatives/ui',
16
- engagePlusPublicPath: '/campaigns/ui',
17
- }));
18
-
19
- // Mock window.location for createBrowserHistory
20
- const originalLocation = window.location;
21
- beforeAll(() => {
22
- delete window.location;
23
- window.location = {
24
- ...originalLocation,
25
- pathname: '/',
26
- search: '',
27
- hash: '',
28
- href: 'http://localhost/',
29
- replace: jest.fn(),
30
- };
31
- });
32
-
33
- afterAll(() => {
34
- window.location = originalLocation;
35
- });
11
+ import history from '../../../utils/history';
36
12
 
37
13
  // This mock needs to be before any imports
38
14
  jest.mock('../../../v2Containers/Email', () => ({
@@ -83,7 +59,6 @@ describe('EmailWrapperView', () => {
83
59
  let store;
84
60
 
85
61
  beforeAll(() => {
86
- // Use the real history (pathConfig is mocked, so it should work)
87
62
  store = configureStore(initialState, initialReducer, history);
88
63
  });
89
64